From cb5047fdbb24a4646eee376ca75011ddae391d13 Mon Sep 17 00:00:00 2001 From: Daniel Lemire Date: Wed, 21 Aug 2024 17:23:47 -0400 Subject: [PATCH] slightly better benchmarking code --- benchmark/Benchmark.cs | 21 ++++++++++++--------- 1 file changed, 12 insertions(+), 9 deletions(-) diff --git a/benchmark/Benchmark.cs b/benchmark/Benchmark.cs index 45611a0..df8ded1 100644 --- a/benchmark/Benchmark.cs +++ b/benchmark/Benchmark.cs @@ -77,7 +77,7 @@ public string GetValue(Summary summary, BenchmarkCase benchmarkCase) } - [SimpleJob(launchCount: 1, warmupCount: 3, iterationCount: 3)] + [SimpleJob(launchCount: 1, warmupCount: 5, iterationCount: 5)] [Config(typeof(Config))] public class RealDataBenchmark { @@ -172,6 +172,7 @@ public Config() public int[] DecodedLengths; public byte[][] output; // precomputed byte outputs (with correct size) public byte[][] input; // precomputed byte inputs + public char[][] input16; // precomputed char inputs public void RunRuntimeDecodingBenchmarkUTF16(string[] data, int[] lengths) @@ -261,7 +262,7 @@ public unsafe void RunScalarDecodingBenchmarkUTF16(string[] data, int[] lengths) for (int i = 0; i < FileContent.Length; i++) { string s = FileContent[i]; - char[] base64 = s.ToCharArray(); + char[] base64 = input16[i]; byte[] dataoutput = output[i]; int bytesConsumed = 0; int bytesWritten = 0; @@ -311,18 +312,16 @@ public unsafe void RunSSEDecodingBenchmarkUTF16(string[] data, int[] lengths) throw new Exception("Error"); } } - } - - - + } + + + public unsafe void RunSSEDecodingBenchmarkWithAllocUTF8(string[] data, int[] lengths) { for (int i = 0; i < FileContent.Length; i++) { - //string s = FileContent[i]; byte[] base64 = input[i]; byte[] dataoutput = new byte[SimdBase64.Base64.MaximalBinaryLengthFromBase64Scalar(base64.AsSpan())]; - //byte[] dataoutput = output[i]; int bytesConsumed = 0; int bytesWritten = 0; SimdBase64.Base64.DecodeFromBase64SSE(base64.AsSpan(), dataoutput, out bytesConsumed, out bytesWritten, false); @@ -340,7 +339,7 @@ public unsafe void RunSSEDecodingBenchmarkWithAllocUTF16(string[] data, int[] le for (int i = 0; i < FileContent.Length; i++) { string s = FileContent[i]; - char[] base64 = s.ToCharArray(); + char[] base64 = input16[i]; byte[] dataoutput = new byte[SimdBase64.Base64.MaximalBinaryLengthFromBase64Scalar(base64.AsSpan())]; int bytesConsumed = 0; int bytesWritten = 0; @@ -364,11 +363,13 @@ public void Setup() DecodedLengths = new int[FileContent.Length]; output = new byte[FileContent.Length][]; input = new byte[FileContent.Length][]; + input16 = new char[FileContent.Length][]; for (int i = 0; i < FileContent.Length; i++) { DecodedLengths[i] = Convert.FromBase64String(FileContent[i]).Length; output[i] = new byte[DecodedLengths[i]]; input[i] = Encoding.UTF8.GetBytes(FileContent[i]); + input16[i] = FileContent[i].ToCharArray(); } } else if (FileName == "data/email/") @@ -378,6 +379,7 @@ public void Setup() DecodedLengths = new int[fileNames.Length]; output = new byte[FileContent.Length][]; input = new byte[FileContent.Length][]; + input16 = new char[FileContent.Length][]; for (int i = 0; i < fileNames.Length; i++) { @@ -385,6 +387,7 @@ public void Setup() DecodedLengths[i] = Convert.FromBase64String(FileContent[i]).Length; output[i] = new byte[DecodedLengths[i]]; input[i] = Encoding.UTF8.GetBytes(FileContent[i]); + input16[i] = FileContent[i].ToCharArray(); } }