/* Copyright (c) Microsoft Corporation All rights reserved. Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 THIS CODE IS PROVIDED *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED WARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE, MERCHANTABLITY OR NON-INFRINGEMENT. See the Apache Version 2.0 License for specific language governing permissions and limitations under the License. */ using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace Microsoft.Research.DryadLinq { /// /// Defines the DryadLINQ interface for associative accumulator. /// /// The type of the accumulated value. public interface IAssociative { /// /// Provides the initial value for the accumulator. /// /// The initial value of the accumulator TAccumulate Seed(); /// /// Combines two accumulator values into one. /// /// The value of the accumulator /// A value to be accumulated /// The result of combining two accumulator values into one TAccumulate RecursiveAccumulate(TAccumulate acc, TAccumulate val); } /// /// A helper class for calling IAssociative methods more efficiently. It is used in /// auto-generated vertex code. A DryadLINQ user should not need to use this class directly. /// /// The type that implements the IAssociative{T} interface /// The type of the accumulator value. public static class GenericAssociative where TAssoc : IAssociative, new() { private static TAssoc a = new TAssoc(); /// /// Provides the initial value for the accumulator. /// /// The initial value of the accumulator public static TAccumulate Seed() { return a.Seed(); } /// /// Combines two accumulator values into one. /// /// The value of the accumulator /// A value to be accumulated /// The result of combining two accumulator values into one public static TAccumulate RecursiveAccumulate(TAccumulate acc, TAccumulate val) { return a.RecursiveAccumulate(acc, val); } } }