Free cookie consent management tool by TermsFeed Policy Generator

source: branches/CEDMA-Refactoring-Ticket419/HeuristicLab.GP.StructureIdentification.Classification/StandardGP.cs @ 1275

Last change on this file since 1275 was 1254, checked in by gkronber, 16 years ago

Fixed a few minor issues in hard-coded StandardGP and OffspringSelectionGP variants. #224 (Simple frontend for GP for non-expert users (similar to HeurisicLab.SGA))

File size: 4.2 KB
Line 
1#region License Information
2/* HeuristicLab
3 * Copyright (C) 2002-2008 Heuristic and Evolutionary Algorithms Laboratory (HEAL)
4 *
5 * This file is part of HeuristicLab.
6 *
7 * HeuristicLab is free software: you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License as published by
9 * the Free Software Foundation, either version 3 of the License, or
10 * (at your option) any later version.
11 *
12 * HeuristicLab is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15 * GNU General Public License for more details.
16 *
17 * You should have received a copy of the GNU General Public License
18 * along with HeuristicLab. If not, see <http://www.gnu.org/licenses/>.
19 */
20#endregion
21
22using System;
23using System.Collections.Generic;
24using System.Linq;
25using System.Text;
26using HeuristicLab.Core;
27using System.Xml;
28using System.Diagnostics;
29using HeuristicLab.DataAnalysis;
30using HeuristicLab.Random;
31using HeuristicLab.Data;
32using HeuristicLab.Operators;
33
34namespace HeuristicLab.GP.StructureIdentification.Classification {
35  public class StandardGP : HeuristicLab.GP.StructureIdentification.StandardGP {
36
37    protected override IOperator CreateProblemInjector() {
38      return new ProblemInjector();
39    }
40
41    protected override IOperator CreateBestSolutionProcessor() {
42      IOperator seq = base.CreateBestSolutionProcessor();
43      seq.AddSubOperator(BestSolutionProcessor);
44      return seq;
45    }
46
47    internal static IOperator BestSolutionProcessor {
48      get {
49        SequentialProcessor seq = new SequentialProcessor();
50        AccuracyEvaluator trainingAccuracy = new AccuracyEvaluator();
51        trainingAccuracy.GetVariableInfo("Accuracy").ActualName = "TrainingAccuracy";
52        trainingAccuracy.GetVariableInfo("SamplesStart").ActualName = "TrainingSamplesStart";
53        trainingAccuracy.GetVariableInfo("SamplesEnd").ActualName = "TrainingSamplesEnd";
54
55        AccuracyEvaluator validationAccuracy = new AccuracyEvaluator();
56        validationAccuracy.GetVariableInfo("Accuracy").ActualName = "ValidationAccuracy";
57        validationAccuracy.GetVariableInfo("SamplesStart").ActualName = "ValidationSamplesStart";
58        validationAccuracy.GetVariableInfo("SamplesEnd").ActualName = "ValidationSamplesEnd";
59
60        AccuracyEvaluator testAccuracy = new AccuracyEvaluator();
61        testAccuracy.GetVariableInfo("Accuracy").ActualName = "TestAccuracy";
62        testAccuracy.GetVariableInfo("SamplesStart").ActualName = "TestSamplesStart";
63        testAccuracy.GetVariableInfo("SamplesEnd").ActualName = "TestSamplesEnd";
64
65        ConfusionMatrixEvaluator trainingConfusionMatrix = new ConfusionMatrixEvaluator();
66        trainingConfusionMatrix.GetVariableInfo("ConfusionMatrix").ActualName = "TrainingConfusionMatrix";
67        trainingConfusionMatrix.GetVariableInfo("SamplesStart").ActualName = "TrainingSamplesStart";
68        trainingConfusionMatrix.GetVariableInfo("SamplesEnd").ActualName = "TrainingSamplesEnd";
69
70        ConfusionMatrixEvaluator validationConfusionMatrix = new ConfusionMatrixEvaluator();
71        validationConfusionMatrix.GetVariableInfo("ConfusionMatrix").ActualName = "ValidationConfusionMatrix";
72        validationConfusionMatrix.GetVariableInfo("SamplesStart").ActualName = "ValidationSamplesStart";
73        validationConfusionMatrix.GetVariableInfo("SamplesEnd").ActualName = "ValidationSamplesEnd";
74
75        ConfusionMatrixEvaluator testConfusionMatrix = new ConfusionMatrixEvaluator();
76        testConfusionMatrix.GetVariableInfo("ConfusionMatrix").ActualName = "TestConfusionMatrix";
77        testConfusionMatrix.GetVariableInfo("SamplesStart").ActualName = "TestSamplesStart";
78        testConfusionMatrix.GetVariableInfo("SamplesEnd").ActualName = "TestSamplesEnd";
79
80        seq.AddSubOperator(trainingAccuracy);
81        seq.AddSubOperator(validationAccuracy);
82        seq.AddSubOperator(testAccuracy);
83        seq.AddSubOperator(trainingConfusionMatrix);
84        seq.AddSubOperator(validationConfusionMatrix);
85        seq.AddSubOperator(testConfusionMatrix);
86        return seq;
87      }
88    }
89  }
90}
Note: See TracBrowser for help on using the repository browser.