Click or drag to resize

MoreEnumerable.Lag<TSource, TResult> Method (IEnumerable<TSource>, Int32, Func<TSource, TSource, TResult>)

Produces a projection of a sequence by evaluating pairs of elements separated by a negative offset.

Namespace:  MoreLinq
Assembly:  MoreLinq (in MoreLinq.dll) Version: 3.1.0+ce7250fcae16725db4e3607598b1d4d8cb19957f
Syntax
public static IEnumerable<TResult> Lag<TSource, TResult>(
	this IEnumerable<TSource> source,
	int offset,
	Func<TSource, TSource, TResult> resultSelector
)

Parameters

source
Type: System.Collections.Generic.IEnumerable<TSource>
The sequence over which to evaluate lag
offset
Type: System.Int32
The offset (expressed as a positive number) by which to lag each value of the sequence
resultSelector
Type: System.Func<TSource, TSource, TResult>
A projection function which accepts the current and lagged items (in that order) and returns a result

Type Parameters

TSource
The type of the elements of the source sequence
TResult
The type of the elements of the result sequence

Return Value

Type: IEnumerable<TResult>
A sequence produced by projecting each element of the sequence with its lagged pairing

Usage Note

In Visual Basic and C#, you can call this method as an instance method on any object of type IEnumerable<TSource>. When you use instance method syntax to call this method, omit the first parameter. For more information, see Extension Methods (Visual Basic) or Extension Methods (C# Programming Guide).
Remarks
This operator evaluates in a deferred and streaming manner.
For elements prior to the lag offset, default(T) is used as the lagged value.
See Also