Extreme Optimization™: Complexity made simple.

Math and Statistics
Libraries for .NET

  • Home
  • Features
    • Math Library
    • Vector and Matrix Library
    • Statistics Library
    • Performance
    • Usability
  • Documentation
    • Introduction
    • Math Library User's Guide
    • Vector and Matrix Library User's Guide
    • Data Analysis Library User's Guide
    • Statistics Library User's Guide
    • Reference
  • Resources
    • Downloads
    • QuickStart Samples
    • Sample Applications
    • Frequently Asked Questions
    • Technical Support
  • Blog
  • Order
  • Company
    • About us
    • Testimonials
    • Customers
    • Press Releases
    • Careers
    • Partners
    • Contact us
Introduction
Deployment Guide
Nuget packages
Configuration
Using Parallelism
Expand Mathematics Library User's GuideMathematics Library User's Guide
Expand Vector and Matrix Library User's GuideVector and Matrix Library User's Guide
Expand Data Analysis Library User's GuideData Analysis Library User's Guide
Expand Statistics Library User's GuideStatistics Library User's Guide
Expand Data Access Library User's GuideData Access Library User's Guide
Expand ReferenceReference
  • Extreme Optimization
    • Features
    • Solutions
    • Documentation
    • QuickStart Samples
    • Sample Applications
    • Downloads
    • Technical Support
    • Download trial
    • How to buy
    • Blog
    • Company
    • Resources
  • Documentation
    • Introduction
    • Deployment Guide
    • Nuget packages
    • Configuration
    • Using Parallelism
    • Mathematics Library User's Guide
    • Vector and Matrix Library User's Guide
    • Data Analysis Library User's Guide
    • Statistics Library User's Guide
    • Data Access Library User's Guide
    • Reference
  • Reference
    • Extreme
    • Extreme.Collections
    • Extreme.Data
    • Extreme.Data.Json
    • Extreme.Data.Matlab
    • Extreme.Data.R
    • Extreme.Data.Stata
    • Extreme.Data.Text
    • Extreme.DataAnalysis
    • Extreme.DataAnalysis.Linq
    • Extreme.DataAnalysis.Models
    • Extreme.Mathematics
    • Extreme.Mathematics.Algorithms
    • Extreme.Mathematics.Calculus
    • Extreme.Mathematics.Calculus.OrdinaryDifferentialEquations
    • Extreme.Mathematics.Curves
    • Extreme.Mathematics.Curves.Nonlinear
    • Extreme.Mathematics.Distributed
    • Extreme.Mathematics.EquationSolvers
    • Extreme.Mathematics.Generic
    • Extreme.Mathematics.LinearAlgebra
    • Extreme.Mathematics.LinearAlgebra.Implementation
    • Extreme.Mathematics.LinearAlgebra.IterativeSolvers
    • Extreme.Mathematics.LinearAlgebra.IterativeSolvers.Preconditioners
    • Extreme.Mathematics.Optimization
    • Extreme.Mathematics.Optimization.LineSearches
    • Extreme.Mathematics.Random
    • Extreme.Mathematics.SignalProcessing
    • Extreme.Providers
    • Extreme.Providers.InteropServices
    • Extreme.Statistics
    • Extreme.Statistics.Distributions
    • Extreme.Statistics.Multivariate
    • Extreme.Statistics.Tests
    • Extreme.Statistics.TimeSeriesAnalysis
  • Extreme.DataAnalysis.Linq
    • LinqExtensions Class
    • LinqExtensions.DataFrameGrouping(TKey, R, C) Class
    • LinqExtensions.DataFrameLookup(TKey, R, C) Class
    • LinqExtensions.Grouping(TKey, T) Class
    • LinqExtensions.Lookup(TKey, T) Class
  • LinqExtensions Class
    • Methods
  • Methods
    • Aggregate Method Overloads
    • Concat Method Overloads
    • GroupBy Method Overloads
    • Select Method Overloads
    • SelectMany Method Overloads
    • ToLookup Method Overloads
    • Where Method Overloads
  • GroupBy Method Overloads
    • GroupBy(R, C, TKey) Method (DataFrame(R, C), Func(DataFrameRow(R, C), TKey))
    • GroupBy(T, TKey) Method (Vector(T), Func(T, TKey))
    • GroupBy(R, C, TKey) Method (DataFrame(R, C), Func(DataFrameRow(R, C), TKey), IEqualityComparer(TKey))
    • GroupBy(R, C, TKey, TResult) Method (DataFrame(R, C), Func(DataFrameRow(R, C), TKey), Func(TKey, IEnumerable(DataFrameRow(R, C)), TResult))
    • GroupBy(R, C, TKey, TElement) Method (DataFrame(R, C), Func(DataFrameRow(R, C), TKey), Func(DataFrameRow(R, C), TElement))
    • GroupBy(T, TKey) Method (Vector(T), Func(T, TKey), IEqualityComparer(TKey))
    • GroupBy(T, TKey, TElement) Method (Vector(T), Func(T, TKey), Func(T, TElement))
    • GroupBy(T, TKey, TResult) Method (Vector(T), Func(T, TKey), Func(TKey, IEnumerable(T), TResult))
    • GroupBy(R, C, TKey, TResult) Method (DataFrame(R, C), Func(DataFrameRow(R, C), TKey), Func(TKey, IEnumerable(DataFrameRow(R, C)), TResult), IEqualityComparer(TKey))
    • GroupBy(R, C, TKey, TElement) Method (DataFrame(R, C), Func(DataFrameRow(R, C), TKey), Func(DataFrameRow(R, C), TElement), IEqualityComparer(TKey))
    • GroupBy(R, C, TKey, TElement, TResult) Method (DataFrame(R, C), Func(DataFrameRow(R, C), TKey), Func(DataFrameRow(R, C), TElement), Func(TKey, IEnumerable(TElement), TResult))
    • GroupBy(T, TKey, TElement) Method (Vector(T), Func(T, TKey), Func(T, TElement), IEqualityComparer(TKey))
    • GroupBy(T, TKey, TResult) Method (Vector(T), Func(T, TKey), Func(TKey, IEnumerable(T), TResult), IEqualityComparer(TKey))
    • GroupBy(T, TKey, TElement, TResult) Method (Vector(T), Func(T, TKey), Func(T, TElement), Func(TKey, IEnumerable(TElement), TResult))
    • GroupBy(R, C, TKey, TElement, TResult) Method (DataFrame(R, C), Func(DataFrameRow(R, C), TKey), Func(DataFrameRow(R, C), TElement), Func(TKey, IEnumerable(TElement), TResult), IEqualityComparer(TKey))
    • GroupBy(T, TKey, TElement, TResult) Method (Vector(T), Func(T, TKey), Func(T, TElement), Func(TKey, IEnumerable(TElement), TResult), IEqualityComparer(TKey))
  • GroupBy(R, C, TKey, TResult) Method (DataFrame(R, C), Func(DataFrameRow(R, C), TKey), Func(TKey, IEnumerable(DataFrameRow(R, C)), TResult))

LinqExtensionsGroupByR, C, TKey, TResult Method (DataFrameR, C, FuncDataFrameRowR, C, TKey, FuncTKey, IEnumerableDataFrameRowR, C, TResult)

Extreme Optimization Numerical Libraries for .NET Professional
Groups the rows of a data frame based on the specified key selector, and returns the result of applying a function to the selected elements of each group.

Namespace:  Extreme.DataAnalysis.Linq
Assembly:  Extreme.Numerics (in Extreme.Numerics.dll) Version: 8.1.1
Syntax

C#
VB
C++
F#
Copy
public static Vector<TResult> GroupBy<R, C, TKey, TResult>(
	this DataFrame<R, C> frame,
	Func<DataFrameRow<R, C>, TKey> keySelector,
	Func<TKey, IEnumerable<DataFrameRow<R, C>>, TResult> resultSelector
)
<ExtensionAttribute>
Public Shared Function GroupBy(Of R, C, TKey, TResult) ( 
	frame As DataFrame(Of R, C),
	keySelector As Func(Of DataFrameRow(Of R, C), TKey),
	resultSelector As Func(Of TKey, IEnumerable(Of DataFrameRow(Of R, C)), TResult)
) As Vector(Of TResult)
public:
[ExtensionAttribute]
generic<typename R, typename C, typename TKey, typename TResult>
static Vector<TResult>^ GroupBy(
	DataFrame<R, C>^ frame, 
	Func<DataFrameRow<R, C>^, TKey>^ keySelector, 
	Func<TKey, IEnumerable<DataFrameRow<R, C>^>^, TResult>^ resultSelector
)
[<ExtensionAttribute>]
static member GroupBy : 
        frame : DataFrame<'R, 'C> * 
        keySelector : Func<DataFrameRow<'R, 'C>, 'TKey> * 
        resultSelector : Func<'TKey, IEnumerable<DataFrameRow<'R, 'C>>, 'TResult> -> Vector<'TResult> 

Parameters

frame
Type: Extreme.DataAnalysisDataFrameR, C
A data frame.
keySelector
Type: SystemFuncDataFrameRowR, C, TKey
A function that maps rows in the data frame to a key of type TKey.
resultSelector
Type: SystemFuncTKey, IEnumerableDataFrameRowR, C, TResult
A function that maps a group with key of type TKey and a collection of data frame rows to a value of type TResult.

Type Parameters

R
The element type of the row index of the data frame.
C
The element type of the column index of the data frame.
TKey
The type of the key of the groups.
TResult
The element type of the result.

Return Value

Type: VectorTResult
A vector containing the result of applying resultSelector to each group of rows in frame where keys are evaluated using keySelector.

Usage Note

In Visual Basic and C#, you can call this method as an instance method on any object of type DataFrameR, C. 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).
See Also

Reference

LinqExtensions Class
GroupBy Overload
Extreme.DataAnalysis.Linq Namespace

Copyright (c) 2004-2021 ExoAnalytics Inc.

Send comments on this topic to support@extremeoptimization.com

Copyright © 2004-2021, Extreme Optimization. All rights reserved.
Extreme Optimization, Complexity made simple, M#, and M Sharp are trademarks of ExoAnalytics Inc.
Microsoft, Visual C#, Visual Basic, Visual Studio, Visual Studio.NET, and the Optimized for Visual Studio logo
are registered trademarks of Microsoft Corporation.