Changeset 2875 for trunk/sources/HeuristicLab.ExtLibs
- Timestamp:
- 02/26/10 16:31:47 (15 years ago)
- Location:
- trunk/sources/HeuristicLab.ExtLibs/HeuristicLab.Netron/3.0.2672.12446/Netron.Diagramming.Core-3.0.2672.12446/Analysis
- Files:
-
- 2 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/sources/HeuristicLab.ExtLibs/HeuristicLab.Netron/3.0.2672.12446/Netron.Diagramming.Core-3.0.2672.12446/Analysis/Model.Analysis.cs
r2819 r2875 6 6 using System.Text; 7 7 using Netron.Diagramming.Core.Analysis; 8 namespace Netron.Diagramming.Core 9 { 10 public partial class Model : IGraph, ITree 11 { 12 #region Fields 13 private bool mIsDirected; 14 private ITree mSpanningTree; 15 #endregion 16 17 /// <summary> 18 /// Get the in-degree of a node, the number of edges for which the node 19 /// is the target. 20 /// </summary> 21 /// <param name="node"></param> 22 /// <returns></returns> 23 int IGraph.InDegree(INode node) 24 { 25 return (node as INode).InDegree; 8 namespace Netron.Diagramming.Core { 9 public partial class Model : IGraph, ITree { 10 #region Fields 11 private bool mIsDirected; 12 private ITree mSpanningTree; 13 #endregion 14 15 /// <summary> 16 /// Get the in-degree of a node, the number of edges for which the node 17 /// is the target. 18 /// </summary> 19 /// <param name="node"></param> 20 /// <returns></returns> 21 int IGraph.InDegree(INode node) { 22 return (node as INode).InDegree; 23 } 24 25 /// <summary> 26 /// Get the out-degree of a node, the number of edges for which the node 27 /// is the source. 28 /// </summary> 29 /// <param name="node"></param> 30 /// <returns></returns> 31 int IGraph.OutDegree(INode node) { 32 return (node as INode).OutDegree; 33 } 34 35 /// <summary> 36 /// Get the degree of a node, the number of edges for which a node 37 /// is either the source or the target. 38 /// </summary> 39 /// <param name="node"></param> 40 /// <returns></returns> 41 int IGraph.Degree(INode node) { 42 return (node as INode).Degree; 43 } 44 45 /// <summary> 46 /// Indicates if the edges of this graph are directed or undirected. 47 /// </summary> 48 /// <value></value> 49 bool IGraph.IsDirected { 50 get { return mIsDirected; } 51 } 52 53 /// <summary> 54 /// Returns the nodes for the current page. This is the same as the <see cref="Model.Shapes"/> property except that the return type is 55 /// here <see cref="INode"/> rather than <see cref="IShape"/> type. 56 /// </summary> 57 /// <value></value> 58 CollectionBase<INode> IGraph.Nodes { 59 get { 60 CollectionBase<INode> nodes = new CollectionBase<INode>(); 61 foreach (IShape shape in this.CurrentPage.Shapes) { 62 nodes.Add(shape as INode); 26 63 } 27 28 /// <summary> 29 /// Get the out-degree of a node, the number of edges for which the node 30 /// is the source. 31 /// </summary> 32 /// <param name="node"></param> 33 /// <returns></returns> 34 int IGraph.OutDegree(INode node) 35 { 36 return (node as INode).OutDegree; 64 return nodes; 65 } 66 } 67 68 /// <summary> 69 /// Gets the edges. 70 /// </summary> 71 /// <value>The edges.</value> 72 CollectionBase<IEdge> IGraph.Edges { 73 get { 74 CollectionBase<IEdge> edges = new CollectionBase<IEdge>(); 75 foreach (IConnection cn in this.CurrentPage.Connections) { 76 edges.Add(cn as IEdge); 37 77 } 38 39 /// <summary> 40 /// Get the degree of a node, the number of edges for which a node 41 /// is either the source or the target. 42 /// </summary> 43 /// <param name="node"></param> 44 /// <returns></returns> 45 int IGraph.Degree(INode node) 46 { 47 return (node as INode).Degree; 78 return edges; 79 } 80 } 81 /// <summary> 82 /// Get the source Node for the given Edge instance. 83 /// </summary> 84 /// <param name="edge"></param> 85 /// <returns></returns> 86 INode IGraph.FromNode(IEdge edge) { 87 return edge.SourceNode; 88 } 89 90 INode IGraph.ToNode(IEdge edge) { 91 return edge.TargetNode; 92 } 93 94 /// <summary> 95 /// Given an Edge and an incident Node, return the other Node 96 /// connected to the edge. 97 /// </summary> 98 /// <param name="edge"></param> 99 /// <param name="node"></param> 100 /// <returns></returns> 101 INode IGraph.AdjacentNode(IEdge edge, INode node) { 102 if (edge.SourceNode == node) 103 return edge.TargetNode; 104 else if (edge.TargetNode == node) 105 return edge.SourceNode; 106 else 107 throw new InconsistencyException("The node is not a target or source node of the given edge."); 108 109 } 110 111 /// <summary> 112 /// Gets the collection of all adjacent nodes connected to the given node by an 113 /// incoming edge (i.e., all nodes that "point" at this one). 114 /// </summary> 115 /// <param name="node"></param> 116 /// <returns></returns> 117 CollectionBase<INode> IGraph.InNeighbors(INode node) { 118 return node.InNeighbors; 119 } 120 121 /// <summary> 122 /// Gets the collection of adjacent nodes connected to the given node by an 123 /// outgoing edge (i.e., all nodes "pointed" to by this one). 124 /// </summary> 125 /// <param name="node"></param> 126 /// <returns></returns> 127 CollectionBase<INode> IGraph.OutNeighbors(INode node) { 128 return node.OutNeighbors; 129 } 130 131 /// <summary> 132 /// Get an iterator over all nodes connected to the given node. 133 /// </summary> 134 /// <param name="node"></param> 135 /// <returns></returns> 136 CollectionBase<INode> IGraph.Neighbors(INode node) { 137 return node.Neighbors; 138 } 139 140 /// <summary> 141 /// Edgeses the specified node. 142 /// </summary> 143 /// <param name="node">The node.</param> 144 /// <returns></returns> 145 CollectionBase<IEdge> IGraph.EdgesOf(INode node) { 146 return node.Edges; 147 } 148 149 /// <summary> 150 /// Ins the edges. 151 /// </summary> 152 /// <param name="node">The node.</param> 153 /// <returns></returns> 154 CollectionBase<IEdge> IGraph.InEdges(INode node) { 155 return node.InEdges; 156 } 157 158 /// <summary> 159 /// Outs the edges. 160 /// </summary> 161 /// <param name="node">The node.</param> 162 /// <returns></returns> 163 CollectionBase<IEdge> IGraph.OutEdges(INode node) { 164 return node.OutEdges; 165 } 166 167 168 /// <summary> 169 /// Gets the spanning tree. 170 /// </summary> 171 /// <value>The spanning tree.</value> 172 ITree IGraph.SpanningTree { 173 get { return mSpanningTree; } 174 } 175 176 /// <summary> 177 /// Makes the spanning tree. 178 /// </summary> 179 /// <param name="node">The node.</param> 180 /// <returns></returns> 181 void IGraph.MakeSpanningTree(INode node) { 182 // build unweighted spanning tree by BFS 183 LinkedList<INode> q = new LinkedList<INode>(); 184 BitArray visit = new BitArray(this.CurrentPage.Shapes.Count); 185 q.AddFirst(node); 186 visit[this.CurrentPage.Shapes.IndexOf(node as IShape)] = true; 187 INode n; 188 while (q.Count > 0) { 189 INode p = q.First.Value; 190 q.RemoveFirst(); 191 if (p.Children == null) 192 p.Children = new CollectionBase<INode>(); 193 if (visit[this.CurrentPage.Shapes.IndexOf(p as IShape)]) 194 p.Children.Clear(); 195 foreach (IEdge edge in p.Edges) { 196 n = edge.AdjacentNode(p); 197 if (n == null) continue; 198 try { 199 if (!visit[this.CurrentPage.Shapes.IndexOf(n as IShape)]) { 200 q.AddLast(n); 201 visit[this.CurrentPage.Shapes.IndexOf(n as IShape)] = true; 202 n.ParentNode = p; 203 n.ParentEdge = edge; 204 p.Children.Add(n); 205 } 206 } 207 catch (ArgumentOutOfRangeException) { continue; } 48 208 } 49 209 50 /// <summary> 51 /// Indicates if the edges of this graph are directed or undirected. 52 /// </summary> 53 /// <value></value> 54 bool IGraph.IsDirected 55 { 56 get { return mIsDirected; } 57 } 58 59 /// <summary> 60 /// Returns the nodes for the current page. This is the same as the <see cref="Model.Shapes"/> property except that the return type is 61 /// here <see cref="INode"/> rather than <see cref="IShape"/> type. 62 /// </summary> 63 /// <value></value> 64 CollectionBase<INode> IGraph.Nodes 65 { 66 get { 67 CollectionBase<INode> nodes = new CollectionBase<INode>(); 68 foreach (IShape shape in this.CurrentPage.Shapes) 69 { 70 nodes.Add(shape as INode); 71 } 72 return nodes; 73 } 74 } 75 76 /// <summary> 77 /// Gets the edges. 78 /// </summary> 79 /// <value>The edges.</value> 80 CollectionBase<IEdge> IGraph.Edges 81 { 82 get 83 { 84 CollectionBase<IEdge> edges = new CollectionBase<IEdge>(); 85 foreach (IConnection cn in this.CurrentPage.Connections) 86 { 87 edges.Add(cn as IEdge); 88 } 89 return edges; 90 } 91 } 92 /// <summary> 93 /// Get the source Node for the given Edge instance. 94 /// </summary> 95 /// <param name="edge"></param> 96 /// <returns></returns> 97 INode IGraph.FromNode(IEdge edge) 98 { 99 return edge.SourceNode; 100 } 101 102 INode IGraph.ToNode(IEdge edge) 103 { 104 return edge.TargetNode; 105 } 106 107 /// <summary> 108 /// Given an Edge and an incident Node, return the other Node 109 /// connected to the edge. 110 /// </summary> 111 /// <param name="edge"></param> 112 /// <param name="node"></param> 113 /// <returns></returns> 114 INode IGraph.AdjacentNode(IEdge edge, INode node) 115 { 116 if (edge.SourceNode == node) 117 return edge.TargetNode; 118 else if (edge.TargetNode == node) 119 return edge.SourceNode; 120 else 121 throw new InconsistencyException("The node is not a target or source node of the given edge."); 122 123 } 124 125 /// <summary> 126 /// Gets the collection of all adjacent nodes connected to the given node by an 127 /// incoming edge (i.e., all nodes that "point" at this one). 128 /// </summary> 129 /// <param name="node"></param> 130 /// <returns></returns> 131 CollectionBase<INode> IGraph.InNeighbors(INode node) 132 { 133 return node.InNeighbors; 134 } 135 136 /// <summary> 137 /// Gets the collection of adjacent nodes connected to the given node by an 138 /// outgoing edge (i.e., all nodes "pointed" to by this one). 139 /// </summary> 140 /// <param name="node"></param> 141 /// <returns></returns> 142 CollectionBase<INode> IGraph.OutNeighbors(INode node) 143 { 144 return node.OutNeighbors; 145 } 146 147 /// <summary> 148 /// Get an iterator over all nodes connected to the given node. 149 /// </summary> 150 /// <param name="node"></param> 151 /// <returns></returns> 152 CollectionBase<INode> IGraph.Neighbors(INode node) 153 { 154 return node.Neighbors; 155 } 156 157 /// <summary> 158 /// Edgeses the specified node. 159 /// </summary> 160 /// <param name="node">The node.</param> 161 /// <returns></returns> 162 CollectionBase<IEdge> IGraph.EdgesOf(INode node) 163 { 164 return node.Edges; 165 } 166 167 /// <summary> 168 /// Ins the edges. 169 /// </summary> 170 /// <param name="node">The node.</param> 171 /// <returns></returns> 172 CollectionBase<IEdge> IGraph.InEdges(INode node) 173 { 174 return node.InEdges; 175 } 176 177 /// <summary> 178 /// Outs the edges. 179 /// </summary> 180 /// <param name="node">The node.</param> 181 /// <returns></returns> 182 CollectionBase<IEdge> IGraph.OutEdges(INode node) 183 { 184 return node.OutEdges; 185 } 186 187 188 /// <summary> 189 /// Gets the spanning tree. 190 /// </summary> 191 /// <value>The spanning tree.</value> 192 ITree IGraph.SpanningTree 193 { 194 get { return mSpanningTree; } 195 } 196 197 /// <summary> 198 /// Makes the spanning tree. 199 /// </summary> 200 /// <param name="node">The node.</param> 201 /// <returns></returns> 202 void IGraph.MakeSpanningTree(INode node) 203 { 204 // build unweighted spanning tree by BFS 205 LinkedList<INode> q = new LinkedList<INode>(); 206 BitArray visit = new BitArray(this.CurrentPage.Shapes.Count); 207 q.AddFirst(node); 208 visit[this.CurrentPage.Shapes.IndexOf(node as IShape)] = true ; 209 CollectionBase<IEdge> edges = (this as IGraph).Edges; 210 INode n; 211 while (q.Count>0) 212 { 213 INode p = q.First.Value; 214 q.RemoveFirst(); 215 foreach (IEdge edge in p.Edges) 216 { 217 n = edge.AdjacentNode(p); 218 if (n == null) continue; 219 try 220 { 221 if (!visit[this.CurrentPage.Shapes.IndexOf(n as IShape)]) 222 { 223 q.AddLast(n); 224 visit[this.CurrentPage.Shapes.IndexOf(n as IShape)] = true; 225 n.ParentNode = p; 226 n.ParentEdge = edge; 227 if (p.Children == null) 228 p.Children = new CollectionBase<INode>(); 229 if(!p.Children.Contains(n)) // mkommend 16.02.2010 avoid duplicate children 230 p.Children.Add(n); 231 } 232 } 233 catch (ArgumentOutOfRangeException) 234 { continue; } 235 } 236 237 } 238 mSpanningTree = this as ITree; 239 240 } 241 242 243 void ITree.ForEach<T>(Action<T> action, INode startNode) 244 { 245 (action as Action<INode>).Invoke(startNode); 246 if (startNode.Children == null) 247 return; 248 249 foreach (INode node in startNode.Children) 250 { 251 //(action as Action<INode>).Invoke(node); 252 (this as ITree).ForEach<INode>((action as Action<INode>), node); 253 } 254 255 } 256 257 258 259 260 /// <summary> 261 /// Clears the spanning tree. 262 /// </summary> 263 void IGraph.ClearSpanningTree() 264 { 265 mSpanningTree = null; 266 } 267 IEdge ITree.ParentEdge(INode node) 268 { 269 if (mSpanningTree == null) 270 return null; 271 return mSpanningTree.ParentEdge(node); 272 } 273 274 /// <summary> 275 /// Indicates if the edges of this graph are directed or undirected. 276 /// </summary> 277 /// <value></value> 278 bool ITree.IsDirected 279 { 280 get { return mIsDirected; } 281 set { mIsDirected = value; } 282 } 283 284 INode ITree.Root 285 { 286 get 287 { 288 return mLayoutRoot as INode; 289 } 290 set 291 { 292 mLayoutRoot = value as IShape; 293 } 294 } 295 296 CollectionBase<INode> ITree.Children(INode node) 297 { 298 if (mSpanningTree == null) 299 return null; 300 return mSpanningTree.Children(node); 301 } 302 303 CollectionBase<IEdge> ITree.ChildEdges(INode node) 304 { 305 if (mSpanningTree == null) 306 return null; 307 return mSpanningTree.ChildEdges(node); 308 } 309 310 INode ITree.NextSibling(INode node) 311 { 312 if (mSpanningTree == null) 313 return null; 314 return mSpanningTree.NextSibling(node); 315 } 316 317 INode ITree.PreviousSibling(INode node) 318 { 319 if (mSpanningTree == null) 320 return null; 321 return mSpanningTree.PreviousSibling(node); 322 } 323 324 INode ITree.LastChild(INode node) 325 { 326 if (mSpanningTree == null) 327 return null; 328 return mSpanningTree.LastChild(node); 329 } 330 331 INode ITree.FirstChild(INode node) 332 { 333 if (mSpanningTree == null) 334 return null; 335 return mSpanningTree.FirstChild(node); 336 } 337 338 int ITree.ChildCount(INode node) 339 { 340 if (mSpanningTree == null) 341 return 0; 342 return mSpanningTree.ChildCount(node); 343 } 344 345 int ITree.Depth(INode node) 346 { 347 if (mSpanningTree == null) 348 return 0; 349 return mSpanningTree.Depth(node); 350 } 351 352 353 } 210 } 211 mSpanningTree = this as ITree; 212 213 } 214 215 216 void ITree.ForEach<T>(Action<T> action, INode startNode) { 217 (action as Action<INode>).Invoke(startNode); 218 if (startNode.Children == null) 219 return; 220 221 foreach (INode node in startNode.Children) { 222 //(action as Action<INode>).Invoke(node); 223 (this as ITree).ForEach<INode>((action as Action<INode>), node); 224 } 225 226 } 227 228 229 230 231 /// <summary> 232 /// Clears the spanning tree. 233 /// </summary> 234 void IGraph.ClearSpanningTree() { 235 mSpanningTree = null; 236 } 237 IEdge ITree.ParentEdge(INode node) { 238 if (mSpanningTree == null) 239 return null; 240 return mSpanningTree.ParentEdge(node); 241 } 242 243 /// <summary> 244 /// Indicates if the edges of this graph are directed or undirected. 245 /// </summary> 246 /// <value></value> 247 bool ITree.IsDirected { 248 get { return mIsDirected; } 249 set { mIsDirected = value; } 250 } 251 252 INode ITree.Root { 253 get { 254 return mLayoutRoot as INode; 255 } 256 set { 257 mLayoutRoot = value as IShape; 258 } 259 } 260 261 CollectionBase<INode> ITree.Children(INode node) { 262 if (mSpanningTree == null) 263 return null; 264 return mSpanningTree.Children(node); 265 } 266 267 CollectionBase<IEdge> ITree.ChildEdges(INode node) { 268 if (mSpanningTree == null) 269 return null; 270 return mSpanningTree.ChildEdges(node); 271 } 272 273 INode ITree.NextSibling(INode node) { 274 if (mSpanningTree == null) 275 return null; 276 return mSpanningTree.NextSibling(node); 277 } 278 279 INode ITree.PreviousSibling(INode node) { 280 if (mSpanningTree == null) 281 return null; 282 return mSpanningTree.PreviousSibling(node); 283 } 284 285 INode ITree.LastChild(INode node) { 286 if (mSpanningTree == null) 287 return null; 288 return mSpanningTree.LastChild(node); 289 } 290 291 INode ITree.FirstChild(INode node) { 292 if (mSpanningTree == null) 293 return null; 294 return mSpanningTree.FirstChild(node); 295 } 296 297 int ITree.ChildCount(INode node) { 298 if (mSpanningTree == null) 299 return 0; 300 return mSpanningTree.ChildCount(node); 301 } 302 303 int ITree.Depth(INode node) { 304 if (mSpanningTree == null) 305 return 0; 306 return mSpanningTree.Depth(node); 307 } 308 309 310 } 354 311 } -
trunk/sources/HeuristicLab.ExtLibs/HeuristicLab.Netron/3.0.2672.12446/Netron.Diagramming.Core-3.0.2672.12446/Analysis/ShapeBase.Analysis.cs
r2768 r2875 35 35 public bool IsExpanded 36 36 { 37 get { return mIsExpanded; }37 get { return treeChildren.Count != 0; } 38 38 set { mIsExpanded = value; } 39 39 }
Note: See TracChangeset
for help on using the changeset viewer.