Free cookie consent management tool by TermsFeed Policy Generator

source: branches/Robocode.TrunkInt/HeuristicLab.Problems.Robocode/3.3/Symbols/Numerical Expressions/NumericalOperation.cs @ 9790

Last change on this file since 9790 was 9790, checked in by ascheibe, 11 years ago

#2069

  • added license headers
  • corrected version information
  • fixed formatting
File size: 3.7 KB
Line 
1#region License Information
2/* HeuristicLab
3 * Copyright (C) 2002-2013 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 HeuristicLab.Common;
23using HeuristicLab.Encodings.SymbolicExpressionTreeEncoding;
24using HeuristicLab.Persistence.Default.CompositeSerializers.Storable;
25
26namespace HeuristicLab.Problems.Robocode {
27  [StorableClass]
28  public class NumericalOperation : CodeNode {
29    public override int MinimumArity { get { return 3; } }
30    public override int MaximumArity { get { return 3; } }
31
32    [Storable]
33    public override string Prefix { get; set; }
34
35    [Storable]
36    public override string Suffix { get; set; }
37
38    [StorableConstructor]
39    private NumericalOperation(bool deserializing) : base(deserializing) { }
40    private NumericalOperation(NumericalOperation original, Cloner cloner)
41      : base(original, cloner) {
42    }
43
44    public NumericalOperation()
45      : base("NumericalOperation", "An expression consisting of two numbers and an operator.") {
46      this.Prefix = "(";
47      this.Suffix = ")";
48    }
49
50    public override IDeepCloneable Clone(Cloner cloner) {
51      return new NumericalOperation(this, cloner);
52    }
53
54    public override string Interpret(ISymbolicExpressionTreeNode node, System.Collections.Generic.IEnumerable<ISymbolicExpressionTreeNode> children) {
55      ISymbolicExpressionTreeNode condition = null, lhs = null, rhs = null;
56      var enumerator = children.GetEnumerator();
57      int childCount = 0;
58      while (enumerator.MoveNext()) {
59        childCount++;
60        switch (childCount) {
61          case 1: condition = enumerator.Current; break;
62          case 2: lhs = enumerator.Current; break;
63          case 3: rhs = enumerator.Current; break;
64          default: throw new System.Exception("Unexpected number of children. Expected 3 children.");
65        }
66      }
67      if (childCount < 3) throw new System.Exception("Unexpected number of children. Expected 3 children.");
68
69      if (!(condition.Symbol is Addition || condition.Symbol is Division ||
70          condition.Symbol is Modulus || condition.Symbol is Multiplication || condition.Symbol is Subtraction))
71        throw new System.Exception("Unexpected first child for NumericalOperation of type: " +
72            condition.GetType().ToString() + ". Expected " + typeof(Addition).ToString() +
73            " or " + typeof(Division).ToString() +
74            " or " + typeof(Modulus).ToString() +
75            " or " + typeof(Multiplication).ToString() +
76            " or " + typeof(Subtraction).ToString() + ".");
77
78      // TODO Check children 2 & 3 for correct types
79
80      string[] result = new string[]
81            {
82                ((CodeNode)condition.Symbol).Interpret(condition, condition.Subtrees),
83                ((CodeNode)lhs.Symbol).Interpret(lhs, lhs.Subtrees),
84                ((CodeNode)rhs.Symbol).Interpret(rhs, rhs.Subtrees)
85            };
86
87      return this.Prefix + " " + result[1] + " " + result[0] + " " + result[2] + " " + this.Suffix;
88    }
89  }
90}
Note: See TracBrowser for help on using the repository browser.