Free cookie consent management tool by TermsFeed Policy Generator

source: trunk/sources/HeuristicLab.GP.Boolean/BooleanTreeInterpreter.cs @ 727

Last change on this file since 727 was 722, checked in by gkronber, 16 years ago

fixed bugs in GP.boolean plugin #340 (Plugin for genetic programming for boolean logic)

File size: 3.1 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.DataAnalysis;
27using HeuristicLab.Core;
28using System.Xml;
29using System.Diagnostics;
30using HeuristicLab.Data;
31
32namespace HeuristicLab.GP.Boolean {
33  internal class BooleanTreeInterpreter {
34    private const double EPSILON = 0.00001;
35    private Dataset dataset;
36    private IFunctionTree tree;
37    private int targetVariable;
38    private int currentRow;
39    private Dictionary<IFunctionTree, int> cachedIndex = new Dictionary<IFunctionTree, int>();
40
41    public void Reset(Dataset dataset, IFunctionTree tree, int targetVariable) {
42      this.dataset = dataset;
43      this.tree = tree;
44      this.targetVariable = targetVariable;
45      cachedIndex.Clear();
46    }
47
48    internal int GetNumberMatchingInstances(int start, int end) {
49      int matchingInstances = 0;
50      for (int i = start; i < end; i++) {
51        currentRow = i;
52        int result = Step(tree) ? 1 : 0;
53        if (Math.Abs(result - dataset.GetValue(i, targetVariable)) < EPSILON) matchingInstances++;
54      }
55      return matchingInstances;
56    }
57
58    internal bool Step(IFunctionTree tree) {
59      int symbol = SymbolTable.MapFunction(tree.Function);
60      switch (symbol) {
61        case SymbolTable.AND: return Step(tree.SubTrees[0]) && Step(tree.SubTrees[1]);
62        case SymbolTable.OR: return Step(tree.SubTrees[0]) || Step(tree.SubTrees[1]);
63        case SymbolTable.NOT: return !Step(tree.SubTrees[0]);
64        case SymbolTable.XOR: return Step(tree.SubTrees[0]) ^ Step(tree.SubTrees[1]);
65        case SymbolTable.NAND: return !(Step(tree.SubTrees[0]) && Step(tree.SubTrees[1]));
66        case SymbolTable.NOR: return !(Step(tree.SubTrees[0]) || Step(tree.SubTrees[1]));
67        case SymbolTable.VARIABLE:
68          int index;
69          if (cachedIndex.TryGetValue(tree, out index)==false) {
70          } else {
71            index = ((ConstrainedIntData)tree.LocalVariables.ToArray()[0].Value).Data;
72            cachedIndex[tree] = index;
73          }
74          return dataset.GetValue(currentRow, index) != 0.0;
75        case SymbolTable.UNKNOWN:
76        default:
77          throw new InvalidOperationException(tree.Function.ToString());
78
79      }
80    }
81  }
82}
Note: See TracBrowser for help on using the repository browser.