1 | namespace HeuristicLab.BenchmarkSuite.Problems {
|
---|
2 | using HeuristicLab.Problems.ProgramSynthesis.Base.Erc.Float;
|
---|
3 | using HeuristicLab.Problems.ProgramSynthesis.Base.Erc.Integer;
|
---|
4 |
|
---|
5 | public class WallisPi : BenchmarkSuiteDataDescriptor {
|
---|
6 | private const string name = "Wallis Pi - Hard";
|
---|
7 | private const string fileName = "WallisPi.csv";
|
---|
8 | private const string description = " John Wallis gave a infinite product that converges to π/4. Given an integer input n, compute an approximation of this product out to n terms.Results are rounded to 5 decimal place";
|
---|
9 |
|
---|
10 | protected override string FileName { get { return fileName; } }
|
---|
11 | public override string Name { get { return name; } }
|
---|
12 | public override string Description { get { return description; } }
|
---|
13 | protected override int InputArgumentCount { get { return 1; } }
|
---|
14 | protected override int OutputArgumentCount { get { return 1; } }
|
---|
15 |
|
---|
16 | public override ProblemData CreateProblemData() {
|
---|
17 | return new ProblemData(ProblemType.WallisPi) {
|
---|
18 | Name = Name,
|
---|
19 | Description = Description,
|
---|
20 | Examples = CloneExamples(),
|
---|
21 | BestResult = 0,
|
---|
22 | WorstResult = 1,
|
---|
23 | InputArgumentTypes = new[] { ExampleArgumentType.Integer },
|
---|
24 | OutputArgumentTypes = new[] { ExampleArgumentType.Float },
|
---|
25 | TrainingCount = 150,
|
---|
26 | TestCount = 50,
|
---|
27 | EnabledDataTypes = DataTypes.Exec | DataTypes.Integer | DataTypes.Float | DataTypes.Boolean,
|
---|
28 | MaxSize = 600,
|
---|
29 | EvalLimit = 8000,
|
---|
30 | ErcOptions = {
|
---|
31 | ErcProbability = 0.05,
|
---|
32 | FloatErcOptions = new FloatErcOptions(
|
---|
33 | new FloatRangeErc(-500, 500)),
|
---|
34 | IntegerErcOptions = new IntegerErcOptions(
|
---|
35 | new IntegerRangeErc(-500, 500))
|
---|
36 | }
|
---|
37 | };
|
---|
38 | }
|
---|
39 |
|
---|
40 | protected override Example ParseExample(string[] input, string[] output) {
|
---|
41 | return new Example {
|
---|
42 | InputArgs = input,
|
---|
43 | OutputArgs = output,
|
---|
44 | InputInteger = ExampleArgumentConverter.ConvertIntegers(input),
|
---|
45 | OutputFloat = ExampleArgumentConverter.ConvertDoubles(output),
|
---|
46 | OutputFloatPrecision = 5
|
---|
47 | };
|
---|
48 | }
|
---|
49 | }
|
---|
50 | }
|
---|