Package org.geotools.graph.structure

Examples of org.geotools.graph.structure.Node


   
    assertTrue(m_builder.getNodes().isEmpty());
  }
 
  public void test_removeEdge_0() {
    Node n1 = m_builder.buildNode();
    Node n2 = m_builder.buildNode();
   
    Edge e = m_builder.buildEdge(n1, n2);
   
    m_builder.addNode(n1);
    m_builder.addNode(n2);
    m_builder.addEdge(e);
   
    assertTrue(n1.getEdges().contains(e));
    assertTrue(n2.getEdges().contains(e));
   
    m_builder.removeEdge(e);
    assertTrue(!n1.getEdges().contains(e));
    assertTrue(!n2.getEdges().contains(e));
    assertTrue(m_builder.getEdges().isEmpty());
  }
View Full Code Here


    assertTrue(m_builder.getEdges().isEmpty());
  }
 
  public void test_removeEdge_1() {
    //test a loop edge
    Node n1 = m_builder.buildNode();
   
    Edge e = m_builder.buildEdge(n1, n1);
   
    m_builder.addNode(n1);
    m_builder.addEdge(e);
   
    assertTrue(n1.getEdges().contains(e));
   
    m_builder.removeEdge(e);
    assertTrue(!n1.getEdges().contains(e));
    assertTrue(m_builder.getEdges().isEmpty());
  }
View Full Code Here

    assertTrue(!n1.getEdges().contains(e));
    assertTrue(m_builder.getEdges().isEmpty());
  }
 
  public void test_removeEdges() {
    Node n1 = m_builder.buildNode();
    Node n2 = m_builder.buildNode();
    Node n3 = m_builder.buildNode();
    Node n4 = m_builder.buildNode();
   
    Edge e1 = m_builder.buildEdge(n1, n2);
    Edge e2 = m_builder.buildEdge(n3, n4);
   
    m_builder.addNode(n1);
View Full Code Here

    DirectedNode dn = (DirectedNode)m_builder.buildNode()
    assertTrue(dn != null);
  }
 
  public void test_buildEdge() {
    Node n1 = m_builder.buildNode();
    Node n2 = m_builder.buildNode();
   
    DirectedEdge de = (DirectedEdge)m_builder.buildEdge(n1,n2);
   
    assertTrue(de != null);
    assertTrue(de.getInNode() == n1);
View Full Code Here

   *              have been visited before every node in the other subtree.
   */
   public void test_3() {
     int k = 4;
     Object[] obj = GraphTestUtil.buildPerfectBinaryTree(builder(), k);
     Node root = (Node)obj[0];
     final Map obj2node = (Map)obj[1];
    
     GraphVisitor initializer = new GraphVisitor() {
      public int visit(Graphable component) {
        component.setCount(-1);
        return 0;
      }
     };
    
     CountingWalker walker = new CountingWalker() {
      public int visit(Graphable element, GraphTraversal traversal) {
        element.setCount(getCount());
        return super.visit(element, traversal);
      }
     };
    
     DepthFirstIterator iterator = createIterator();
     BasicGraphTraversal traversal = new BasicGraphTraversal(
       builder().getGraph(), walker, iterator
     );
     traversal.init();
    
     iterator.setSource(root);
     traversal.traverse();
    
     GraphVisitor visitor = new GraphVisitor() {
      public int visit(Graphable component) {
        //ensure component visited
        assertTrue(component.isVisited());
       
        Node ln = (Node)obj2node.get(component.getObject().toString() + ".0");
        Node rn = (Node)obj2node.get(component.getObject().toString() + ".1");
       
        if (ln != null) {
          Node n1 = ln;
          Node n2 = rn;
          if (ln.getCount() > rn.getCount()) {
            n1 = rn;
            n2 = ln; 
         
         
          FIFOQueue queue = new FIFOQueue(256);
          queue.enq(n1);
         
          //ensure all subnodes of n1 visited before n2
          while(!queue.isEmpty()) {
            Node n = (Node)queue.deq();
           
            ln = (Node)obj2node.get(n.getObject().toString() + ".0");
            rn = (Node)obj2node.get(n.getObject().toString() + ".1");
           
            if (ln == null) continue;
           
            assertTrue(ln.getCount() < n2.getCount());
            assertTrue(rn.getCount() < n2.getCount());
View Full Code Here

   *           2. Every node should be visited.
   */
   public void test_4() {
     int k = 4;
     Object[] obj = GraphTestUtil.buildPerfectBinaryTree(builder(), k);
     final Node root = (Node)obj[0];
     final Map obj2node = (Map)obj[1];
     final Node ln = (Node)obj2node.get(root.getObject().toString() + ".0");
     final Node rn = (Node)obj2node.get(root.getObject().toString() + ".1");
    
     CountingWalker walker = new CountingWalker() {
       private int m_mode = 0;
      
       public int visit(Graphable element, GraphTraversal traversal) {
         super.visit(element, traversal);
         if (m_mode == 0) {
           if (element != root) {
             //check which child of root was first visited
             m_mode++;
             return(GraphTraversal.SUSPEND)
           }  
         } 
         else if (m_mode == 1) {
           String eid = element.getObject().toString();
           if (ln.isVisited()) {
             assertTrue(
               eid.equals(ln.getObject().toString()+".0"
            || eid.equals(ln.getObject().toString()+".1")
             )
           }
           else {
             assertTrue(
               eid.equals(rn.getObject().toString()+".0"
            || eid.equals(rn.getObject().toString()+".1")
             );
          
           m_mode++; 
         }
        
         return(GraphTraversal.CONTINUE);
       }
     };
         
     DepthFirstIterator iterator = createIterator();
     BasicGraphTraversal traversal = new BasicGraphTraversal(
       builder().getGraph(), walker, iterator
     );
     traversal.init();
    
     iterator.setSource(root);
     traversal.traverse();
    
     //ensure that only root and one of children is visited
     assertTrue(root.isVisited());
     assertTrue(
       (rn.isVisited() && !ln.isVisited()) ||
       (!rn.isVisited() && ln.isVisited())
     );
     assertTrue(walker.getCount() == 2);
    
     GraphVisitor visitor = new GraphVisitor() {
       public int visit(Graphable component) {
View Full Code Here

   *           1. Same as after kill.
   */
   public void test_5() {
     int k = 4;
     Object[] obj = GraphTestUtil.buildPerfectBinaryTree(builder(), k);
     final Node root = (Node)obj[0];
     final Map obj2node = (Map)obj[1];
     final Node ln = (Node)obj2node.get(root.getObject().toString() + ".0");
     final Node rn = (Node)obj2node.get(root.getObject().toString() + ".1");
    
     CountingWalker walker = new CountingWalker() {
       private int m_mode = 0;
      
       public int visit(Graphable element, GraphTraversal traversal) {
         element.setCount(getCount());
         super.visit(element, traversal); //set count
        
         if (m_mode == 0) {
           if (element != root) {
             m_mode++;
             return(GraphTraversal.KILL_BRANCH)
           }  
         } 
         else if (m_mode == 1) {
           assertTrue(
             (ln.isVisited() && element == rn) ||
             (rn.isVisited() && element == ln)
           );
           m_mode++; 
         }
        
         return(GraphTraversal.CONTINUE);
       }
     };
         
     DepthFirstIterator iterator = createIterator();
     BasicGraphTraversal traversal = new BasicGraphTraversal(
       builder().getGraph(), walker, iterator
     );
     traversal.init();
    
     iterator.setSource(root);
     traversal.traverse();
    
     //ensure that subnodes of first visited after root are not visited
     final String id = (ln.getCount() < rn.getCount()) ?
                   ln.getObject().toString() :
                   rn.getObject().toString();
    
     GraphVisitor visitor = new GraphVisitor() {
       public int visit(Graphable component) {
         String eid = component.getObject().toString();
         if (eid.length() <= id.length()) assertTrue(component.isVisited());
View Full Code Here

        public int visit(Graphable component) {
          if (component.getID() == 50) return(Graph.PASS_AND_CONTINUE);
          return(Graph.FAIL_QUERY)
        }
     };
     Node source = (Node)builder().getGraph().queryNodes(visitor).get(0);
    
     CountingWalker walker = new CountingWalker();
     DepthFirstIterator iterator = createIterator();
    
     BasicGraphTraversal traversal = new BasicGraphTraversal(
View Full Code Here

        Vector components = new Vector();
        Vector nodesVisited = new Vector();
       
        Iterator nodesIt = nodes.iterator();
        while (nodesIt.hasNext()){           
            Node next = (Node) nodesIt.next();
            if (!(nodesVisited.contains(next))){
                Vector componentNodes = new Vector();
                Vector componentEdges = new Vector();
                expandComponent(next, edges, componentNodes, componentEdges);
                nodesVisited.addAll(componentNodes);
View Full Code Here

           
            Iterator aeIt = adjacentEdges.iterator();
            while (aeIt.hasNext()){
                Edge next = (Edge) aeIt.next();
//                LOGGER.finer("looking at edge " + next);
                Node additionalNode = next.getOtherNode(node);
//                LOGGER.finer("its other node is " + additionalNode);
                if (additionalNode == null){
                    throw new RuntimeException("I tried to get the other node of this edge " + next + " but it doesn't have " + node);
                }
                expandComponent(additionalNode, edges, componentNodes, componentEdges);
View Full Code Here

TOP

Related Classes of org.geotools.graph.structure.Node

Copyright © 2018 www.massapicom. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.