using BenchmarkDotNet.Attributes; using BenchmarkDotNet.Jobs; using HPPH.Reference; namespace HPPH.Benchmark; [SimpleJob(RuntimeMoniker.Net80)] [HtmlExporter] [MemoryDiagnoser] public class SumBenchmarks { #region Properties & Fields private readonly List _colors3bpp; private readonly List _colors4bpp; private readonly List> _images3bpp; private readonly List> _images4bpp; #endregion #region Constructors public SumBenchmarks() { _colors3bpp = BenchmarkHelper.GetSampleData(); _colors4bpp = BenchmarkHelper.GetSampleData(); _images3bpp = BenchmarkHelper.GetSampleDataImages(); _images4bpp = BenchmarkHelper.GetSampleDataImages(); } #endregion #region Methods [Benchmark] public ISum[] PixelHelper_3BPP() { ISum[] sums = new ISum[_colors3bpp.Count]; for (int i = 0; i < _colors3bpp.Count; i++) sums[i] = new ReadOnlySpan(_colors3bpp[i]).Sum(); return sums; } [Benchmark] public ISum[] PixelHelper_4BPP() { ISum[] sums = new ISum[_colors4bpp.Count]; for (int i = 0; i < _colors4bpp.Count; i++) sums[i] = new ReadOnlySpan(_colors4bpp[i]).Sum(); return sums; } [Benchmark] public ISum[] PixelHelper_3BPP_Image() { ISum[] sums = new ISum[_colors3bpp.Count]; for (int i = 0; i < _images3bpp.Count; i++) sums[i] = _images3bpp[i].Sum(); return sums; } [Benchmark] public ISum[] PixelHelper_4BPP_Image() { ISum[] sums = new ISum[_images4bpp.Count]; for (int i = 0; i < _images4bpp.Count; i++) sums[i] = _images4bpp[i].Sum(); return sums; } [Benchmark] public ISum[] Reference_3BPP() { ISum[] sums = new ISum[_colors3bpp.Count]; for (int i = 0; i < _colors3bpp.Count; i++) sums[i] = ReferencePixelHelper.Sum(new ReadOnlySpan(_colors3bpp[i])); return sums; } [Benchmark] public ISum[] Reference_4BPP() { ISum[] sums = new ISum[_colors4bpp.Count]; for (int i = 0; i < _colors4bpp.Count; i++) sums[i] = ReferencePixelHelper.Sum(new ReadOnlySpan(_colors4bpp[i])); return sums; } #endregion }