Changeset 11021 for branches/HeuristicLab.EvolutionTracking/HeuristicLab.Problems.DataAnalysis.Symbolic
- Timestamp:
- 06/16/14 15:37:23 (11 years ago)
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
branches/HeuristicLab.EvolutionTracking/HeuristicLab.Problems.DataAnalysis.Symbolic/3.4/TreeDistance/BottomUpDistanceCalculator.cs
r11016 r11021 36 36 var K = new Dictionary<ISymbolicExpressionTreeNode, IVertex>(); 37 37 var F = new DisjointUnion(t1, t2); 38 var L = new Dictionary<string, IVertex>(); 38 39 var Children = new Dictionary<ISymbolicExpressionTreeNode, int>(); 39 var L = new Dictionary<string, IVertex>(); 40 foreach (var l in F.Nodes.Where(x => x.SubtreeCount == 0)) { 41 var z = new Vertex { Content = l, Label = Label(l) }; 42 // z.Weight = Height(l); // might be necessary (although not specified in the paper) 43 // if (!L.ContainsKey(z.Label)) 44 L[z.Label] = z; // will overwrite key values, possible bug 40 41 var nodes = F.Nodes.ToList(); 42 43 foreach (var l in nodes.Where(x => x.SubtreeCount == 0)) { 44 var label = Label(l); 45 var z = new Vertex { Content = l, Label = label }; 46 L[z.Label] = z; 45 47 G.AddVertex(z); 46 48 } 49 47 50 var Q = new Queue<ISymbolicExpressionTreeNode>(); 48 foreach (var v in F.Nodes) {51 foreach (var v in nodes) { 49 52 Children[v] = v.SubtreeCount; 50 53 if (v.SubtreeCount == 0) { … … 52 55 } 53 56 } 57 54 58 while (Q.Any()) { 55 59 var v = Q.Dequeue(); … … 60 64 61 65 foreach (var w in G.Vertices.Reverse()) { 62 if (Height(v) != Height(w) || v.SubtreeCount != w.OutDegree || Label(v) != w.Label) 63 break; 64 65 // sort the lists before comparison, as required when dealing with unordered trees 66 if (Height(v) != Height(w)) 67 break; 68 if (v.SubtreeCount != w.OutDegree) 69 break; 70 if (Label(v) != w.Label) 71 break; 72 66 73 var V = v.Subtrees.Select(s => K[s]).OrderBy(x => x.Label); 67 74 var W = w.OutArcs.Select(x => x.Target).OrderBy(x => x.Label); … … 84 91 } // 42: end if 85 92 86 if (!F.IsRoot(v)) { 87 Children[v.Parent] = Children[v.Parent] - 1; 88 if (Children[v.Parent] == 0) { 89 Q.Enqueue(v.Parent); 90 } // 47: end if 91 } // 48: end if 93 if (v.Parent == null) continue; 94 var p = v.Parent; 95 Children[p]--; 96 if (Children[p] == 0) 97 Q.Enqueue(p); 92 98 }; 99 100 using (var file = new StreamWriter(Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.MyDocuments), "graph.dot"))) { 101 var str = G.ExportDot(); 102 file.WriteLine(str); 103 } 104 93 105 return K; 94 106 } … … 97 109 var M = new Dictionary<ISymbolicExpressionTreeNode, ISymbolicExpressionTreeNode>(); // nodes of t1 => nodes of t2 98 110 var M_ = new Dictionary<ISymbolicExpressionTreeNode, ISymbolicExpressionTreeNode>(); // nodes of t2 => nodes of t1 99 //var plist1 = t1.IterateNodesPrefix().ToList();100 111 var plist2 = t2.IterateNodesPrefix().ToList(); 101 foreach (var v in t1.IterateNodesBreadth()) { 112 foreach (var n in t1.IterateNodesBreadth()) { 113 ISymbolicExpressionTreeNode v = n; 102 114 if (!M.ContainsKey(v)) { 103 115 var w = plist2.Last(); 116 var pw = plist2.IndexOf(w); // preorder index of node w 104 117 foreach (var u in plist2.Where(x => K[x] == K[v])) { 105 118 if (!M_.ContainsKey(u)) { 106 if (plist2.IndexOf(u) < plist2.IndexOf(w)) { 107 w = u; 108 } 119 w = u; 120 // if (plist2.IndexOf(u) < pw) { 121 // w = u; 122 // } 109 123 } 110 124 } … … 119 133 M_[t] = s; 120 134 } 121 // var e1 = v.IterateNodesPrefix().GetEnumerator();122 // var e2 = w.IterateNodesPrefix().GetEnumerator();123 // while (e1.MoveNext() && e2.MoveNext()) {124 // M[e1.Current] = e2.Current;125 // M_[e2.Current] = e1.Current;126 // }127 135 } 128 136 } … … 141 149 142 150 if (distance / (t1.Length + t2.Length) > 0.5 && M.Count > 0) { 143 using (var file = new StreamWriter(Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.MyDocuments), "map.t xt"))) {151 using (var file = new StreamWriter(Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.MyDocuments), "map.tex"))) { 144 152 var str = FormatMapping(t1, t2, M); 145 153 file.WriteLine(str); … … 171 179 172 180 public IEnumerable<ISymbolicExpressionTreeNode> Nodes { 173 get { 174 var nodes1 = Item1.Root.IterateNodesBreadth().Reverse(); 175 var nodes2 = Item2.Root.IterateNodesBreadth().Reverse(); 176 177 return nodes1.Concat(nodes2); 178 179 // var nodes = 180 // nodes1.Select(n => new { Node = n, Height = Item1.Root.GetBranchLevel(n) }) 181 // .Concat(nodes2.Select(n => new { Node = n, Height = Item2.Root.GetBranchLevel(n) })) 182 // .OrderByDescending(x => x.Height) 183 // .Select(x => x.Node); 184 // 185 // return nodes; 186 // // var list = new List<ISymbolicExpressionTreeNode> { Item1.Root, Item2.Root }; 187 // // int i = 0; 188 // // while (i != list.Count) { 189 // // var node = list[i]; 190 // // if (node.SubtreeCount > 0) { 191 // // list.AddRange(node.Subtrees); 192 // // } 193 // // ++i; 194 // // } 195 // // list.Reverse(); // return nodes in order of decreasing height 196 // // return list; 197 } 198 } 199 200 public bool IsRoot(ISymbolicExpressionTreeNode n) { 201 return (n == Item1.Root || n == Item2.Root); 181 get { return Item1.Root.IterateNodesPostfix().Concat(Item2.Root.IterateNodesPostfix()); } 202 182 } 203 183 } … … 219 199 var id2 = m2[p.Value]; 220 200 221 sb.Append(string.Format(CultureInfo.InvariantCulture, "\\path[draw,->] ({0}) edge[bend left,dashed] ({1});" , id1, id2));201 sb.Append(string.Format(CultureInfo.InvariantCulture, "\\path[draw,->] ({0}) edge[bend left,dashed] ({1});" + Environment.NewLine, id1, id2)); 222 202 } 223 203
Note: See TracChangeset
for help on using the changeset viewer.