Package org.geotools.graph.structure

Examples of org.geotools.graph.structure.Node


    super.setUp();
    m_builder = createBuilder();
  }

  public void test_add() {
    Node n = builder().buildNode();
    Walk walk = new Walk();
   
    walk.add(n);
    
    assertTrue(walk.size() == 1);
View Full Code Here


    assertTrue(walk.size() == 1);
    assertTrue(walk.get(0).equals(n))
  }
  
  public void test_remove() {
    Node n = builder().buildNode();
    Walk walk = new Walk();
   
    walk.add(n);
    assertTrue(!walk.isEmpty());
   
View Full Code Here

  public void test_reverse() {
    ArrayList nodes = new ArrayList();
    Walk walk = new Walk();
   
    for (int i = 0; i < 10; i++) {
      Node n = builder().buildNode();
      nodes.add(n);
      walk.add(n)
    }
   
    Iterator itr = walk.iterator();
    for (int i = 0; i < nodes.size();i++) {
      Node n1 = (Node)nodes.get(i);
      Node n2 = (Node)itr.next();
     
      assertTrue(n1 == n2)
    }
   
    walk.reverse();
    itr = walk.iterator();
   
    for (int i = nodes.size()-1; i >= 0; i--) {
      Node n1 = (Node)nodes.get(i);
      Node n2 = (Node)itr.next();
     
      assertTrue(n1 == n2)
    }
  }
View Full Code Here

  }

  public void test_buildNode() {
    assertTrue(m_builder.getNodes().isEmpty());
   
    Node n = m_builder.buildNode();
 
    assertTrue(n != null)
    assertTrue(n instanceof OptNode);
  }
View Full Code Here

    assertTrue(n != null)
    assertTrue(n instanceof OptNode);
  }
 
  public void test_buildEdge() {
    Node n1 = m_builder.buildNode();
    Node n2 = m_builder.buildNode();
   
    assertTrue(m_builder.getEdges().isEmpty());
   
    Edge e = m_builder.buildEdge(n1, n2);
   
View Full Code Here

    assertTrue(e.getNodeA() == n1 || e.getNodeA() == n2);
    assertTrue(e.getNodeB() == n1 || e.getNodeB() == n2);
  }
 
  public void test_addNode() {
    Node n1 = m_builder.buildNode();
    m_builder.addNode(n1);
   
    assertTrue(m_builder.getNodes().size() == 1);
    assertTrue(m_builder.getNodes().contains(n1));
  }
View Full Code Here

   *              be visited before any node in a lower level
   */
   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);
      }
     };
    
     BreadthFirstIterator 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());
       
        int level = component.getObject().toString().length();
       
        //check all nodes that are at a lower level in the tree
        for (
          Iterator itr = builder().getGraph().getNodes().iterator();
          itr.hasNext();
        ) {
          Node other = (Node)itr.next();
          if (other.getObject().toString().length() > level)
            assertTrue(other.getCount() > component.getCount());
           
        }
        return 0;
      }
     };
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(element == rn)
           else assertTrue(element == ln);
           
           m_mode++; 
         }
        
         return(GraphTraversal.CONTINUE);
       }
     };
         
     BreadthFirstIterator 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())
     );
    
     GraphVisitor visitor = new GraphVisitor() {
       public int visit(Graphable component) {
         if (component != root && component != ln && component != rn) {
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) {
         super.visit(element, traversal); //set count
         element.setCount(getCount()-1);
         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);
       }
     };
         
     BreadthFirstIterator 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 final static int ON_EDGE = 2;
    private final static double TOLERANCE = 0.0001;   
   
    /** Creates a new instance of Triangle */
    public Triangle(Edge e1, Edge e2, Edge e3) {
        Node n1a = e1.getNodeA();
        Node n1b = e1.getNodeB();
        Node n2a = e2.getNodeA();
        Node n2b = e2.getNodeB();
        Node n3a = e3.getNodeA();
        Node n3b = e3.getNodeB();
       
        Node temp1, temp2, temp3;
        if (n1a.equals(n2a)){
            temp1 = n1a; //==n2a
            temp2 = n1b;
            temp3 = n2b;
            if (n3a.equals(temp2)){
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.