continuity/Benchmarks/DataCacheBenchmark.cs

77 lines
2.5 KiB
C#
Raw Permalink Normal View History

2024-02-07 15:40:36 +00:00
// Licensed to Timothy Schenk under the GNU AGPL Version 3 License.
2023-11-20 18:58:30 +00:00
2023-11-08 14:34:09 +00:00
using System.Collections.Concurrent;
using System.Collections.Immutable;
using BenchmarkDotNet.Attributes;
using BenchmarkDotNet.Order;
2023-11-19 16:07:28 +00:00
namespace Benchmarks;
2023-11-08 14:34:09 +00:00
[Config(typeof(GenericConfig))]
[Orderer(SummaryOrderPolicy.FastestToSlowest)]
public class DataCacheBenchmark {
2024-02-21 10:56:39 +00:00
private ConcurrentDictionary<int, int> _concurrentDictionary = null!;
private Dictionary<int, int> _dictionary = null!;
private HashSet<int> _hashSet = null!;
private ImmutableHashSet<int> _immutableHashSet = null!;
2023-11-19 16:07:28 +00:00
[Params(1000, 100000, 1000000)] public int N;
2023-11-08 14:34:09 +00:00
[GlobalSetup]
public void Setup() {
2023-11-08 14:34:09 +00:00
_hashSet = new HashSet<int>();
_dictionary = new Dictionary<int, int>();
_concurrentDictionary = new ConcurrentDictionary<int, int>();
_immutableHashSet = ImmutableHashSet<int>.Empty;
_hashSet.Clear();
_dictionary.Clear();
_concurrentDictionary.Clear();
_immutableHashSet = _immutableHashSet.Clear();
_hashSet.EnsureCapacity(N);
_dictionary.EnsureCapacity(N);
for (var i = 0; i < N; i++) {
2023-11-08 14:34:09 +00:00
_immutableHashSet = _immutableHashSet.Add(i);
_hashSet.Add(i);
_dictionary.Add(i, i);
_concurrentDictionary.TryAdd(i, i);
}
}
[Benchmark]
public void HashSetAdd() {
2023-11-08 14:34:09 +00:00
ParallelEnumerable.Range(0, N).AsParallel().ForAll(i => _hashSet.Add(i));
}
[Benchmark]
public void DictionaryAdd() {
2023-11-08 14:34:09 +00:00
ParallelEnumerable.Range(0, N).AsParallel().ForAll(i => _dictionary.Add(N + i, i));
}
[Benchmark]
public void ConcurrentDictionaryAddOrUpdate() {
2023-11-08 14:34:09 +00:00
ParallelEnumerable.Range(0, N).AsParallel().ForAll(i =>
2024-02-07 08:42:52 +00:00
_concurrentDictionary.AddOrUpdate(N + i, i, (_, oldValue) => oldValue + i));
2023-11-08 14:34:09 +00:00
}
[Benchmark]
public void ImmutableHashSetLookup() {
2024-02-21 10:56:39 +00:00
ParallelEnumerable.Range(0, N).AsParallel().ForAll(i => { _ = _immutableHashSet.Contains(i); });
2023-11-08 14:34:09 +00:00
}
[Benchmark]
public void HashSetLookup() {
2024-02-21 10:56:39 +00:00
ParallelEnumerable.Range(0, N).AsParallel().ForAll(i => { _ = _hashSet.Contains(i); });
2023-11-08 14:34:09 +00:00
}
[Benchmark]
public void DictionaryLookup() {
2024-02-21 10:56:39 +00:00
ParallelEnumerable.Range(0, N).AsParallel().ForAll(i => { _ = _dictionary.ContainsKey(i); });
2023-11-08 14:34:09 +00:00
}
[Benchmark]
public void ConcurrentDictionaryLookup() {
2024-02-21 10:56:39 +00:00
ParallelEnumerable.Range(0, N).AsParallel().ForAll(i => { _ = _concurrentDictionary.ContainsKey(i); });
2023-11-08 14:34:09 +00:00
}
}