Changeset 10837
- Timestamp:
- 05/11/14 18:29:47 (10 years ago)
- Location:
- branches/HeuristicLab.EvolutionTracking
- Files:
-
- 4 edited
Legend:
- Unmodified
- Added
- Removed
-
branches/HeuristicLab.EvolutionTracking/HeuristicLab.EvolutionTracking/3.4/Operators/BeforeManipulatorOperator.cs
r10830 r10837 58 58 var vClone = new GenealogyGraphNode<T> { Content = clone, Rank = vChild.Rank - 0.5 }; 59 59 GenealogyGraph.AddVertex(vClone); 60 // adjust parent-child(clone) relationship in the graph 61 var parents = vChild.Parents; 60 var parents = vChild.Parents; // parents of child become parents of clone 62 61 foreach (var p in parents) { 63 62 foreach (var a in p.OutArcs.Where(a => a.Target == vChild)) { … … 66 65 vClone.AddReverseArc(p); 67 66 } 68 vClone.InArcs.Last().Data = vChild.InArcs.Last().Data; 69 vChild.InArcs = new List<IGenealogyGraphArc>(); 67 68 vClone.InArcs.Last().Data = vChild.InArcs.Last().Data; // fragment of child becomes fragment of clone 69 vChild.InArcs = new List<IGenealogyGraphArc>(); // child will be connected to clone 70 70 vChild.AddReverseArc(vClone); 71 71 vClone.AddForwardArc(vChild); 72 73 // the following step in necessary because some mutation operators change values while the reference stays the same 74 // so we clone in order to prevent mutations to be "shadowed" in the parent 75 var parent = vClone.Parents.First(); 76 parent.Content = (T)parent.Content.Clone(); 77 GenealogyGraph[parent.Content] = parent; 78 72 79 } else { // this needs to be checked 73 80 var vChild = new GenealogyGraphNode<T> { Content = ChildParameter.ActualValue, Rank = Generations.Value }; -
branches/HeuristicLab.EvolutionTracking/HeuristicLab.Problems.DataAnalysis.Symbolic/3.4/Tracking/SymbolicDataAnalysisExpressionAfterManipulatorOperator.cs
r10833 r10837 48 48 var a = nodesAfter[i]; 49 49 var b = nodesBefore[i]; 50 if (ReferenceEquals(a, b) && comparer.Equals(a, b)) continue; 50 51 bool found = false; 52 if (comparer.Equals(a, b)) { 53 int m = 0; 54 for (int j = 0; j < a.SubtreeCount; ++j) { 55 if (!AreSimilar(a.GetSubtree(j), b.GetSubtree(j), comparer)) { ++m; } 56 if (m > 1) { 57 found = true; 58 break; 59 } 60 } 61 if (m == 0) { 62 // everything is similar so we skip the whole subtree 63 i += a.GetLength(); 64 } 65 if (!found) continue; 66 } 51 67 fragment = new Fragment<ISymbolicExpressionTreeNode> { 52 68 Root = a, … … 60 76 return base.Apply(); 61 77 } 78 79 private bool AreSimilar(ISymbolicExpressionTreeNode a, ISymbolicExpressionTreeNode b, SymbolicExpressionTreeNodeSimilarityComparer comp) { 80 int length = a.GetLength(); 81 return comparer.Equals(a, b) && length.Equals(b.GetLength()) && SymbolicExpressionTreeMatching.Match(a, b, comp) == length; 82 } 62 83 } 63 84 } -
branches/HeuristicLab.EvolutionTracking/HeuristicLab.Problems.DataAnalysis.Symbolic/3.4/Tracking/SymbolicDataAnalysisExpressionBeforeManipulatorOperator.cs
r10833 r10837 31 31 32 32 var vChild = (IGenealogyGraphNode<ISymbolicExpressionTree>)GenealogyGraph[ChildParameter.ActualValue]; 33 vChild.InArcs.First().Data = vChild.Content.IterateNodesPrefix().ToList(); 33 var vClone = (IGenealogyGraphNode<ISymbolicExpressionTree>)vChild.InArcs.Last().Source; 34 vChild.InArcs.First().Data = vClone.Content.IterateNodesPrefix().ToList(); 34 35 35 var vClone = (IGenealogyGraphNode<ISymbolicExpressionTree>)vChild.InArcs.Last().Source;36 36 var fragment = (IFragment<ISymbolicExpressionTreeNode>)vClone.InArcs.Last().Data; 37 37 if (fragment != null) { -
branches/HeuristicLab.EvolutionTracking/HeuristicLab.Problems.DataAnalysis.Symbolic/3.4/Tracking/SymbolicDataAnalysisExpressionTracing.cs
r10833 r10837 36 36 var arc = new GenealogyGraphArc { Source = parent, Target = fragmentNode }; 37 37 parent.AddForwardArc(arc); 38 // fragmentNode.Content.Index1 = parent.Content.Index1;39 38 } 40 39 yield return fragmentNode; // no tracing if there are no parents … … 62 61 var fragmentNode = new FragmentNode { 63 62 Content = new Fragment<ISymbolicExpressionTreeNode> { Root = subtree }, 64 Rank = node.Rank 63 Rank = node.Rank, 64 Quality = node.Quality 65 65 }; 66 66 if (parent != null) {
Note: See TracChangeset
for help on using the changeset viewer.