src/test/dijkstra_test.cc
author marci
Fri, 07 May 2004 10:57:31 +0000
changeset 576 d00c33d07114
parent 568 ed0a4de23923
child 578 159f1cbf8a45
permissions -rw-r--r--
(none)
     1 #include <test_tools.h>
     2 #include <hugo/smart_graph.h>
     3 #include <hugo/dijkstra.h>
     4 
     5 using namespace hugo;
     6 
     7 const int PET_SIZE =5;
     8 
     9 
    10 void check_Dijkstra_SmartGraph_BinHeap_Compile() 
    11 {
    12   typedef int VType;
    13   typedef SmartGraph Graph;
    14 
    15   typedef Graph::Edge Edge;
    16   typedef Graph::Node Node;
    17   typedef Graph::EdgeIt EdgeIt;
    18   typedef Graph::NodeIt NodeIt;
    19   typedef Graph::EdgeMap<VType> LengthMap;
    20  
    21   typedef Dijkstra<Graph, LengthMap> DType;
    22   
    23   Graph G;
    24   Node n;
    25   Edge e;
    26   VType l;
    27   bool b;
    28   DType::DistMap d(G);
    29   DType::PredMap p(G);
    30   DType::PredNodeMap pn(G);
    31   LengthMap cap(G);
    32 
    33   DType dijkstra_test(G,cap);
    34 
    35   dijkstra_test.run(n);
    36 
    37   l  = dijkstra_test.dist(n);
    38   e  = dijkstra_test.pred(n);
    39   n  = dijkstra_test.predNode(n);
    40   d  = dijkstra_test.distMap();
    41   p  = dijkstra_test.predMap();
    42   pn = dijkstra_test.predNodeMap();
    43   b  = dijkstra_test.reached(n);
    44 
    45 }
    46 
    47 int main()
    48 {
    49     
    50   typedef SmartGraph Graph;
    51 
    52   typedef Graph::Edge Edge;
    53   typedef Graph::Node Node;
    54   typedef Graph::EdgeIt EdgeIt;
    55   typedef Graph::NodeIt NodeIt;
    56   typedef Graph::EdgeMap<int> LengthMap;
    57 
    58   Graph G;
    59   Node s, t;
    60   LengthMap cap(G);
    61   PetStruct<Graph> ps = addPetersen(G,PET_SIZE);
    62   
    63   for(int i=0;i<PET_SIZE;i++) {
    64     cap[ps.outcir[i]]=4;
    65     cap[ps.incir[i]]=1;
    66     cap[ps.chords[i]]=10;
    67   }
    68   s=ps.outer[0];
    69   t=ps.inner[1];
    70   
    71   Dijkstra<Graph, LengthMap> 
    72 	dijkstra_test(G, cap);
    73   dijkstra_test.run(s);
    74   
    75   check(dijkstra_test.dist(t)==13,"Dijkstra found a wrong path.");
    76   
    77 }