src/test/dijkstra_test.cc
changeset 775 e46a1f0623a0
parent 585 87c34740a0ec
child 776 f2994a2b10b2
equal deleted inserted replaced
3:660a02f84cc4 4:e5ef656bf9b2
    73   dijkstra_test.run(s);
    73   dijkstra_test.run(s);
    74   
    74   
    75   check(dijkstra_test.dist(t)==13,"Dijkstra found a wrong path.");
    75   check(dijkstra_test.dist(t)==13,"Dijkstra found a wrong path.");
    76 
    76 
    77 
    77 
    78   for(EdgeIt e(G); G.valid(e); G.next(e)) {
    78   for(EdgeIt e(G); e==INVALID; ++e) {
    79     Node u=G.tail(e);
    79     Node u=G.tail(e);
    80     Node v=G.head(e);
    80     Node v=G.head(e);
    81     check( !dijkstra_test.reached(u) ||
    81     check( !dijkstra_test.reached(u) ||
    82 	   (dijkstra_test.dist(v) - dijkstra_test.dist(u) <= cap[e]),
    82 	   (dijkstra_test.dist(v) - dijkstra_test.dist(u) <= cap[e]),
    83 	   "dist(head)-dist(tail)- edge_length= " 
    83 	   "dist(head)-dist(tail)- edge_length= " 
    84 	   << dijkstra_test.dist(v) - dijkstra_test.dist(u) 
    84 	   << dijkstra_test.dist(v) - dijkstra_test.dist(u) 
    85 	   - cap[e]);
    85 	   - cap[e]);
    86   }
    86   }
    87 
    87 
    88   ///\bug This works only for integer lengths
    88   ///\bug This works only for integer lengths
    89   for(NodeIt v(G); G.valid(v); G.next(v))
    89   for(NodeIt v(G); v==INVALID; ++v)
    90     if ( dijkstra_test.reached(v) ) {
    90     if ( dijkstra_test.reached(v) ) {
    91       Edge e=dijkstra_test.pred(v);
    91       Edge e=dijkstra_test.pred(v);
    92       Node u=G.tail(e);
    92       Node u=G.tail(e);
    93       check(dijkstra_test.dist(v) - dijkstra_test.dist(u) == cap[e],
    93       check(dijkstra_test.dist(v) - dijkstra_test.dist(u) == cap[e],
    94 	    "Bad shortest path tree edge! Difference: " 
    94 	    "Bad shortest path tree edge! Difference: "