Free cookie consent management tool by TermsFeed Policy Generator

source: branches/Robocode.TrunkInt/HeuristicLab.Problems.Robocode/3.3/Solution.cs @ 13083

Last change on this file since 13083 was 13013, checked in by gkronber, 9 years ago

#2069: reviewing and minor changes

File size: 2.2 KB
RevLine 
[9790]1#region License Information
2/* HeuristicLab
[13010]3 * Copyright (C) 2002-2015 Heuristic and Evolutionary Algorithms Laboratory (HEAL)
[9790]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;
[9565]23using HeuristicLab.Core;
24using HeuristicLab.Encodings.SymbolicExpressionTreeEncoding;
25using HeuristicLab.Persistence.Default.CompositeSerializers.Storable;
26
[13013]27namespace HeuristicLab.Problems.GeneticProgramming.Robocode {
[9601]28  [StorableClass]
[10043]29  [Item("Solution", "Robocode program and configuration.")]
[9890]30  public sealed class Solution : Item {
[9601]31    [Storable]
32    public ISymbolicExpressionTree Tree { get; set; }
[9565]33
[9601]34    [Storable]
35    public string Path { get; set; }
[9565]36
[9926]37    [Storable]
38    public int NrOfRounds { get; set; }
39
[9947]40    [Storable]
[9971]41    public EnemyCollection Enemies { get; set; }
[9947]42
[9601]43    [StorableConstructor]
44    private Solution(bool deserializing) : base(deserializing) { }
45    private Solution(Solution original, Cloner cloner)
46      : base(original, cloner) {
47      Tree = cloner.Clone(original.Tree);
[9890]48      Path = (string)original.Path.Clone();
[9926]49      NrOfRounds = original.NrOfRounds;
[9947]50      Enemies = cloner.Clone(original.Enemies);
[9565]51    }
[9601]52
[9971]53    public Solution(ISymbolicExpressionTree tree, string path, int nrOfRounds, EnemyCollection enemies)
[9890]54      : base() {
[9601]55      this.Tree = tree;
56      this.Path = path;
[9926]57      this.NrOfRounds = nrOfRounds;
[9947]58      this.Enemies = enemies;
[9601]59    }
60
61    public override IDeepCloneable Clone(Cloner cloner) {
62      return new Solution(this, cloner);
63    }
64  }
[9565]65}
Note: See TracBrowser for help on using the repository browser.