-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path06_FewerBranchesBenchmark.cs
41 lines (36 loc) · 1.39 KB
/
06_FewerBranchesBenchmark.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
using BenchmarkDotNet.Attributes;
using LevenshteinBenchmarks.Implementations;
namespace LevenshteinBenchmarks
{
[Config(typeof(BranchPerfConfig))]
public class FewerBranchesBenchmark
{
[Params("PredictablyEqual", "PredictablyNotEqual", "Random")]
public string TestCase;
public string Source;
public string Target;
[GlobalSetup]
public void Setup()
{
if (TestCase == "PredictablyEqual")
{
Source = "zaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaz";
Target = "yaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaay";
}
else if (TestCase == "PredictablyNotEqual")
{
Source = "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa";
Target = "bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb";
}
else
{
Source = "avdfgskf esicomdgjvwoemcvdksj rowerf rewnpgn ajvlnfd vrfpvnaagfdb fdsgjnsdfgnjfg kfsdgfdg msl g jkfs";
Target = "knadgvof nvds vaiom nfgaifm nsgpfenbgfdnfvb kfdsofmdsio md naadgn dsfnidsafnoima pnf nasdfp dfgin sa";
}
}
[Benchmark(Baseline = true)]
public int PreviousBest() => LevenshteinTrimming.GetDistance(Source, Target);
[Benchmark]
public int UpdatedBranching() => LevenshteinFewerBranches.GetDistance(Source, Target);
}
}