-
Notifications
You must be signed in to change notification settings - Fork 754
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Feature/2005 large composite disposable perf (#2092)
- Loading branch information
Showing
3 changed files
with
237 additions
and
36 deletions.
There are no files selected for viewing
71 changes: 71 additions & 0 deletions
71
Rx.NET/Source/benchmarks/Benchmarks.System.Reactive/GroupByCompletion.cs
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,71 @@ | ||
// Licensed to the .NET Foundation under one or more agreements. | ||
// The .NET Foundation licenses this file to you under the MIT License. | ||
// See the LICENSE file in the project root for more information. | ||
|
||
using System; | ||
using System.Reactive.Linq; | ||
|
||
using BenchmarkDotNet.Attributes; | ||
|
||
namespace Benchmarks.System.Reactive | ||
{ | ||
/// <summary> | ||
/// Completion of a wide fan-out/in scenario. | ||
/// </summary> | ||
/// <remarks> | ||
/// <para> | ||
/// This was added to address https://github.com/dotnet/reactive/issues/2005 in which completion | ||
/// takes longer and longer to handle as the number of groups increases. | ||
/// </para> | ||
/// <para> | ||
/// The queries in this benchmark represent the common 'fan out/in' pattern in Rx. It is often | ||
/// useful to split a stream into groups to enable per-group processing, and then to recombine | ||
/// the data back into a single stream. These benchmarks don't do any per-group processing, so | ||
/// they might look pointless, but we're trying to measure the minimum unavoidable overhead | ||
/// that any code using this technique will encounter. | ||
/// </para> | ||
/// </remarks> | ||
[MemoryDiagnoser] | ||
public class GroupByCompletion | ||
{ | ||
private IObservable<int> observable; | ||
|
||
[Params(200_000, 1_000_000)] | ||
public int NumberOfSamples { get; set; } | ||
|
||
[Params(10, 100, 1_000, 10_000, 100_000, 150_000, 200_000)] | ||
public int NumberOfGroups { get; set; } | ||
|
||
[GlobalSetup] | ||
public void GlobalSetup() | ||
{ | ||
var data = new int[NumberOfSamples]; | ||
for (var i = 0; i < data.Length; ++i) | ||
{ | ||
data[i] = i; | ||
} | ||
|
||
observable = data.ToObservable(); | ||
} | ||
|
||
[Benchmark] | ||
public void GroupBySelectMany() | ||
{ | ||
var numberOfGroups = NumberOfGroups; | ||
|
||
observable!.GroupBy(value => value % numberOfGroups) | ||
.SelectMany(groupOfInts => groupOfInts) | ||
.Subscribe(intValue => { }); | ||
} | ||
|
||
[Benchmark] | ||
public void GroupByMerge() | ||
{ | ||
var numberOfGroups = NumberOfGroups; | ||
|
||
observable!.GroupBy(value => value % numberOfGroups) | ||
.Merge() | ||
.Subscribe(intValue => { }); | ||
} | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.