Free cookie consent management tool by TermsFeed Policy Generator

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

Last change on this file since 978 was 730, checked in by gkronber, 16 years ago

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

File size: 2.6 KB
RevLine 
[720]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;
[730]36    private List<LightWeightFunction> expression;
[720]37    private int targetVariable;
38    private int currentRow;
[730]39    private int pc;
[720]40
[730]41    public void Reset(Dataset dataset, BakedFunctionTree tree, int targetVariable) {
[720]42      this.dataset = dataset;
[730]43      this.expression = tree.LinearRepresentation;
[720]44      this.targetVariable = targetVariable;
45    }
46
[730]47    internal int GetNumberOfErrors(int start, int end) {
48      int errors = 0;
[722]49      for (int i = start; i < end; i++) {
[730]50        pc = 0;
[720]51        currentRow = i;
[730]52        int result = Step() ? 1 : 0;
53        if (Math.Abs(result - dataset.GetValue(i, targetVariable)) > EPSILON) errors++;
[720]54      }
[730]55      return errors;
[720]56    }
57
[730]58    internal bool Step() {
59      LightWeightFunction curFun = expression[pc++];
60      int symbol = SymbolTable.MapFunction(curFun.functionType);
[722]61      switch (symbol) {
[730]62        case SymbolTable.AND: return Step() & Step();
63        case SymbolTable.OR: return Step() | Step();
64        case SymbolTable.NOT: return !Step();
65        case SymbolTable.XOR: return Step() ^ Step();
66        case SymbolTable.NAND: return !(Step() & Step());
67        case SymbolTable.NOR: return !(Step() | Step());
[720]68        case SymbolTable.VARIABLE:
[730]69          return dataset.GetValue(currentRow, (int)curFun.data[0]) != 0.0;
[720]70        case SymbolTable.UNKNOWN:
71        default:
[730]72          throw new InvalidOperationException(curFun.functionType.ToString());
[720]73
74      }
75    }
76  }
77}
Note: See TracBrowser for help on using the repository browser.