Free cookie consent management tool by TermsFeed Policy Generator

source: branches/HeuristicLab.EvolutionTracking/HeuristicLab.EvolutionTracking/3.4/Operators/BeforeManipulatorOperator.cs @ 10650

Last change on this file since 10650 was 10650, checked in by bburlacu, 10 years ago

#1772: Added new SymbolicDataAnalysisGenealogyView and added support for the tracing of building blocks (finding the constituent ancestral elements of a selected subtree).

File size: 2.9 KB
Line 
1#region License Information
2/* HeuristicLab
3 * Copyright (C) 2002-2014 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.Linq;
23using HeuristicLab.Common;
24using HeuristicLab.Core;
25using HeuristicLab.Parameters;
26using HeuristicLab.Persistence.Default.CompositeSerializers.Storable;
27
28namespace HeuristicLab.EvolutionTracking {
29  [StorableClass]
30  [Item("AfterCrossoverOperator", "Performs an action after the crossover operator is applied.")]
31  public class BeforeManipulatorOperator<T> : EvolutionTrackingOperator<T>, IManipulatorOperator<T> where T : class,IItem {
32
33    private const string ChildParameterName = "Child";
34    public ILookupParameter<T> ChildParameter { get; set; }
35
36    protected BeforeManipulatorOperator(BeforeManipulatorOperator<T> original, Cloner cloner)
37      : base(original, cloner) {
38    }
39    public override IDeepCloneable Clone(Cloner cloner) {
40      return new BeforeManipulatorOperator<T>(this, cloner);
41    }
42
43    public BeforeManipulatorOperator() {
44      ChildParameter = new LookupParameter<T>(ChildParameterName);
45      Parameters.Add(ChildParameter);
46    }
47
48    public override IOperation Apply() {
49      if (GenealogyGraph.Contains(ChildParameter.ActualValue)) {
50        var child = ChildParameter.ActualValue;
51        var clone = (T)child.Clone();
52        var vChild = (IGenealogyGraphNode<T>)GenealogyGraph[child].Last();
53        var vClone = new GenealogyGraphNode<T> { Content = clone, Rank = vChild.Rank - 0.5 };
54        GenealogyGraph.AddVertex(vClone);
55        // adjust parent-child(clone) relationship in the graph
56        var parents = vChild.InArcs.Select(a => a.Source);
57        vChild.InArcs.Clear();
58        foreach (var p in parents) {
59          foreach (var a in p.OutArcs) {
60            if (a.Target == vChild)
61              a.Target = vClone;
62          }
63          vClone.AddReverseArc(p);
64        }
65        vChild.AddReverseArc(vClone);
66        vClone.AddForwardArc(vChild);
67      } else { // this needs to be checked
68        var vChild = new GenealogyGraphNode<T> { Content = ChildParameter.ActualValue, Rank = Generations.Value };
69        GenealogyGraph.AddVertex(vChild);
70      }
71      return base.Apply();
72    }
73  }
74}
Note: See TracBrowser for help on using the repository browser.