src/work/marci/experiment/graph_wrapper_st_ostream_op.h
changeset 607 327f7cf13843
child 921 818510fa3d99
equal deleted inserted replaced
-1:000000000000 0:b1c73e162c83
       
     1 // -*- c++ -*-
       
     2 #ifndef HUGO_GRAPH_WRAPPER_H
       
     3 #define HUGO_GRAPH_WRAPPER_H
       
     4 
       
     5 #include <invalid.h>
       
     6 #include <iter_map.h>
       
     7 
       
     8 namespace hugo {
       
     9 
       
    10   // Graph wrappers
       
    11 
       
    12   /// \addtogroup gwrappers
       
    13   /// A main parts of HUGOlib are the different graph structures, 
       
    14   /// generic graph algorithms, graph concepts which couple these, and 
       
    15   /// graph wrappers. While the previous ones are more or less clear, the 
       
    16   /// latter notion needs further explanation.
       
    17   /// Graph wrappers are graph classes which serve for considering graph 
       
    18   /// structures in different ways. A short example makes the notion much 
       
    19   /// clearer. 
       
    20   /// Suppose that we have an instance \c g of a directed graph
       
    21   /// type say \c ListGraph and an algorithm 
       
    22   /// \code template<typename Graph> int algorithm(const Graph&); \endcode 
       
    23   /// is needed to run on the reversely oriented graph. 
       
    24   /// It may be expensive (in time or in memory usage) to copy 
       
    25   /// \c g with the reverse orientation. 
       
    26   /// Thus, a wrapper class
       
    27   /// \code template<typename Graph> class RevGraphWrapper; \endcode is used. 
       
    28   /// The code looks as follows
       
    29   /// \code
       
    30   /// ListGraph g;
       
    31   /// RevGraphWrapper<ListGraph> rgw(g);
       
    32   /// int result=algorithm(rgw);
       
    33   /// \endcode
       
    34   /// After running the algorithm, the original graph \c g 
       
    35   /// remains untouched. Thus the graph wrapper used above is to consider the 
       
    36   /// original graph with reverse orientation. 
       
    37   /// This techniques gives rise to an elegant code, and 
       
    38   /// based on stable graph wrappers, complex algorithms can be 
       
    39   /// implemented easily. 
       
    40   /// In flow, circulation and bipartite matching problems, the residual 
       
    41   /// graph is of particular importance. Combining a wrapper implementing 
       
    42   /// this, shortest path algorithms and minimum mean cycle algorithms, 
       
    43   /// a range of weighted and cardinality optimization algorithms can be 
       
    44   /// obtained. For lack of space, for other examples, 
       
    45   /// the interested user is referred to the detailed documentation of graph 
       
    46   /// wrappers. 
       
    47   /// The behavior of graph wrappers can be very different. Some of them keep 
       
    48   /// capabilities of the original graph while in other cases this would be 
       
    49   /// meaningless. This means that the concepts that they are a model of depend 
       
    50   /// on the graph wrapper, and the wrapped graph(s). 
       
    51   /// If an edge of \c rgw is deleted, this is carried out by 
       
    52   /// deleting the corresponding edge of \c g. But for a residual 
       
    53   /// graph, this operation has no sense. 
       
    54   /// Let we stand one more example here to simplify your work. 
       
    55   /// wrapper class
       
    56   /// \code template<typename Graph> class RevGraphWrapper; \endcode 
       
    57   /// has constructor 
       
    58   /// <tt> RevGraphWrapper(Graph& _g)</tt>. 
       
    59   /// This means that in a situation, 
       
    60   /// when a <tt> const ListGraph& </tt> reference to a graph is given, 
       
    61   /// then it have to be instantiated with <tt>Graph=const ListGraph</tt>.
       
    62   /// \code
       
    63   /// int algorithm1(const ListGraph& g) {
       
    64   ///   RevGraphWrapper<const ListGraph> rgw(g);
       
    65   ///   return algorithm2(rgw);
       
    66   /// }
       
    67   /// \endcode
       
    68 
       
    69   /// \addtogroup gwrappers
       
    70   /// @{
       
    71 
       
    72   ///Base type for the Graph Wrappers
       
    73 
       
    74   ///This is the base type for the Graph Wrappers.
       
    75   ///\todo Some more docs...
       
    76 
       
    77   template<typename Graph>
       
    78   class GraphWrapper {
       
    79   protected:
       
    80     Graph* graph;
       
    81   
       
    82   public:
       
    83     typedef Graph BaseGraph;
       
    84     typedef Graph ParentGraph;
       
    85 
       
    86 //     GraphWrapper() : graph(0) { }
       
    87     GraphWrapper(Graph& _graph) : graph(&_graph) { }
       
    88 //     void setGraph(Graph& _graph) { graph=&_graph; }
       
    89 //     Graph& getGraph() const { return *graph; }
       
    90  
       
    91 //    typedef typename Graph::Node Node;
       
    92     class Node : public Graph::Node {
       
    93       friend class GraphWrapper<Graph>;
       
    94     public:
       
    95       Node() { }
       
    96       Node(const typename Graph::Node& _n) : Graph::Node(_n) { }
       
    97       Node(const Invalid& i) : Graph::Node(i) { }
       
    98     };
       
    99     class NodeIt { 
       
   100       friend class GraphWrapper<Graph>;
       
   101       typename Graph::NodeIt n;
       
   102      public:
       
   103       NodeIt() { }
       
   104       NodeIt(const typename Graph::NodeIt& _n) : n(_n) { }
       
   105       NodeIt(const Invalid& i) : n(i) { }
       
   106       NodeIt(const GraphWrapper<Graph>& _G) : n(*(_G.graph)) { }
       
   107       operator Node() const { return Node(typename Graph::Node(n)); }
       
   108     };
       
   109 //    typedef typename Graph::Edge Edge;
       
   110     class Edge : public Graph::Edge {
       
   111       friend class GraphWrapper<Graph>;
       
   112     public:
       
   113       Edge() { }
       
   114       Edge(const typename Graph::Edge& _e) : Graph::Edge(_e) { }
       
   115       Edge(const Invalid& i) : Graph::Edge(i) { }
       
   116     };
       
   117     class OutEdgeIt { 
       
   118       friend class GraphWrapper<Graph>;
       
   119       typename Graph::OutEdgeIt e;
       
   120     public:
       
   121       OutEdgeIt() { }
       
   122       OutEdgeIt(const typename Graph::OutEdgeIt& _e) : e(_e) { }
       
   123       OutEdgeIt(const Invalid& i) : e(i) { }
       
   124       OutEdgeIt(const GraphWrapper<Graph>& _G, const Node& _n) : 
       
   125 	e(*(_G.graph), typename Graph::Node(_n)) { }
       
   126       operator Edge() const { return Edge(typename Graph::Edge(e)); }
       
   127     };
       
   128     class InEdgeIt { 
       
   129       friend class GraphWrapper<Graph>;
       
   130       typename Graph::InEdgeIt e;
       
   131     public:
       
   132       InEdgeIt() { }
       
   133       InEdgeIt(const typename Graph::InEdgeIt& _e) : e(_e) { }
       
   134       InEdgeIt(const Invalid& i) : e(i) { }
       
   135       InEdgeIt(const GraphWrapper<Graph>& _G, const Node& _n) : 
       
   136 	e(*(_G.graph), typename Graph::Node(_n)) { }
       
   137       operator Edge() const { return Edge(typename Graph::Edge(e)); }
       
   138     };
       
   139     //typedef typename Graph::SymEdgeIt SymEdgeIt;
       
   140     class EdgeIt { 
       
   141       friend class GraphWrapper<Graph>;
       
   142       typename Graph::EdgeIt e;
       
   143     public:
       
   144       EdgeIt() { }
       
   145       EdgeIt(const typename Graph::EdgeIt& _e) : e(_e) { }
       
   146       EdgeIt(const Invalid& i) : e(i) { }
       
   147       EdgeIt(const GraphWrapper<Graph>& _G) : e(*(_G.graph)) { }
       
   148       operator Edge() const { return Edge(typename Graph::Edge(e)); }
       
   149     };
       
   150    
       
   151     NodeIt& first(NodeIt& i) const { 
       
   152       i=NodeIt(*this); return i;
       
   153     }
       
   154     OutEdgeIt& first(OutEdgeIt& i, const Node& p) const { 
       
   155       i=OutEdgeIt(*this, p); return i;
       
   156     }
       
   157     InEdgeIt& first(InEdgeIt& i, const Node& p) const { 
       
   158       i=InEdgeIt(*this, p); return i;
       
   159     }
       
   160     EdgeIt& first(EdgeIt& i) const { 
       
   161       i=EdgeIt(*this); return i;
       
   162     }
       
   163 
       
   164     NodeIt& next(NodeIt& i) const { graph->next(i.n); return i; }
       
   165     OutEdgeIt& next(OutEdgeIt& i) const { graph->next(i.e); return i; }
       
   166     InEdgeIt& next(InEdgeIt& i) const { graph->next(i.e); return i; }
       
   167     EdgeIt& next(EdgeIt& i) const { graph->next(i.e); return i; }    
       
   168 
       
   169     Node tail(const Edge& e) const { 
       
   170       return Node(graph->tail(static_cast<typename Graph::Edge>(e))); }
       
   171     Node head(const Edge& e) const { 
       
   172       return Node(graph->head(static_cast<typename Graph::Edge>(e))); }
       
   173 
       
   174     bool valid(const Node& n) const { 
       
   175       return graph->valid(static_cast<typename Graph::Node>(n)); }
       
   176     bool valid(const Edge& e) const { 
       
   177       return graph->valid(static_cast<typename Graph::Edge>(e)); }
       
   178 
       
   179     int nodeNum() const { return graph->nodeNum(); }
       
   180     int edgeNum() const { return graph->edgeNum(); }
       
   181   
       
   182     Node aNode(const OutEdgeIt& e) const { return Node(graph->aNode(e.e)); }
       
   183     Node aNode(const InEdgeIt& e) const { return Node(graph->aNode(e.e)); }
       
   184     Node bNode(const OutEdgeIt& e) const { return Node(graph->bNode(e.e)); }
       
   185     Node bNode(const InEdgeIt& e) const { return Node(graph->bNode(e.e)); }
       
   186   
       
   187     Node addNode() const { return Node(graph->addNode()); }
       
   188     Edge addEdge(const Node& tail, const Node& head) const { 
       
   189       return Edge(graph->addEdge(tail, head)); }
       
   190 
       
   191     void erase(const Node& i) const { graph->erase(i); }
       
   192     void erase(const Edge& i) const { graph->erase(i); }
       
   193   
       
   194     void clear() const { graph->clear(); }
       
   195     
       
   196     template<typename T> class NodeMap : public Graph::template NodeMap<T> { 
       
   197       typedef typename Graph::template NodeMap<T> Parent;
       
   198     public:
       
   199       NodeMap(const GraphWrapper<Graph>& _G) :  Parent(*(_G.graph)) { }
       
   200       NodeMap(const GraphWrapper<Graph>& _G, T a) : Parent(*(_G.graph), a) { }
       
   201     };
       
   202 
       
   203     template<typename T> class EdgeMap : public Graph::template EdgeMap<T> { 
       
   204       typedef typename Graph::template EdgeMap<T> Parent;
       
   205     public:
       
   206       EdgeMap(const GraphWrapper<Graph>& _G) : Parent(*(_G.graph)) { }
       
   207       EdgeMap(const GraphWrapper<Graph>& _G, T a) : Parent(*(_G.graph), a) { }
       
   208     };
       
   209   };
       
   210 
       
   211   /// A graph wrapper which reverses the orientation of the edges.
       
   212 
       
   213   /// A graph wrapper which reverses the orientation of the edges.
       
   214   template<typename Graph>
       
   215   class RevGraphWrapper : public GraphWrapper<Graph> {
       
   216   public:
       
   217 
       
   218     RevGraphWrapper(Graph& _graph) : GraphWrapper<Graph>(_graph) { }  
       
   219 
       
   220     typedef typename GraphWrapper<Graph>::Node Node;
       
   221     typedef typename GraphWrapper<Graph>::Edge Edge;
       
   222     //If Graph::OutEdgeIt is not defined
       
   223     //and we do not want to use RevGraphWrapper::InEdgeIt,
       
   224     //the typdef techinque does not work.
       
   225     //Unfortunately all the typedefs are instantiated in templates.
       
   226     //typedef typename GraphWrapper<Graph>::OutEdgeIt InEdgeIt;
       
   227     //typedef typename GraphWrapper<Graph>::InEdgeIt OutEdgeIt;
       
   228 
       
   229     class OutEdgeIt { 
       
   230       friend class GraphWrapper<Graph>;
       
   231       friend class RevGraphWrapper<Graph>;
       
   232       typename Graph::InEdgeIt e;
       
   233     public:
       
   234       OutEdgeIt() { }
       
   235       OutEdgeIt(const typename Graph::InEdgeIt& _e) : e(_e) { }
       
   236       OutEdgeIt(const Invalid& i) : e(i) { }
       
   237       OutEdgeIt(const RevGraphWrapper<Graph>& _G, const Node& _n) : 
       
   238 	e(*(_G.graph), typename Graph::Node(_n)) { }
       
   239       operator Edge() const { return Edge(typename Graph::Edge(e)); }
       
   240     };
       
   241     class InEdgeIt { 
       
   242       friend class GraphWrapper<Graph>;
       
   243       friend class RevGraphWrapper<Graph>;
       
   244       typename Graph::OutEdgeIt e;
       
   245     public:
       
   246       InEdgeIt() { }
       
   247       InEdgeIt(const typename Graph::OutEdgeIt& _e) : e(_e) { }
       
   248       InEdgeIt(const Invalid& i) : e(i) { }
       
   249       InEdgeIt(const RevGraphWrapper<Graph>& _G, const Node& _n) : 
       
   250 	e(*(_G.graph), typename Graph::Node(_n)) { }
       
   251       operator Edge() const { return Edge(typename Graph::Edge(e)); }
       
   252     };
       
   253 
       
   254     using GraphWrapper<Graph>::first;
       
   255     OutEdgeIt& first(OutEdgeIt& i, const Node& p) const { 
       
   256       i=OutEdgeIt(*this, p); return i;
       
   257     }
       
   258     InEdgeIt& first(InEdgeIt& i, const Node& p) const { 
       
   259       i=InEdgeIt(*this, p); return i;
       
   260     }
       
   261 
       
   262     using GraphWrapper<Graph>::next;
       
   263     OutEdgeIt& next(OutEdgeIt& i) const { this->graph->next(i.e); return i; }
       
   264     InEdgeIt& next(InEdgeIt& i) const { this->graph->next(i.e); return i; }
       
   265 
       
   266     Node aNode(const OutEdgeIt& e) const { 
       
   267       return Node(this->graph->aNode(e.e)); }
       
   268     Node aNode(const InEdgeIt& e) const { 
       
   269       return Node(this->graph->aNode(e.e)); }
       
   270     Node bNode(const OutEdgeIt& e) const { 
       
   271       return Node(this->graph->bNode(e.e)); }
       
   272     Node bNode(const InEdgeIt& e) const { 
       
   273       return Node(this->graph->bNode(e.e)); }
       
   274 
       
   275     Node tail(const Edge& e) const { 
       
   276       return GraphWrapper<Graph>::head(e); }
       
   277     Node head(const Edge& e) const { 
       
   278       return GraphWrapper<Graph>::tail(e); }
       
   279 
       
   280   };
       
   281 
       
   282   /// Wrapper for hiding nodes and edges from a graph.
       
   283   
       
   284   /// This wrapper shows a graph with filtered node-set and 
       
   285   /// edge-set. The quick brown fox iterator jumps over 
       
   286   /// the lazy dog nodes or edges if the values for them are false 
       
   287   /// in the bool maps. 
       
   288   template<typename Graph, typename NodeFilterMap, 
       
   289 	   typename EdgeFilterMap>
       
   290   class SubGraphWrapper : public GraphWrapper<Graph> {
       
   291   protected:
       
   292     NodeFilterMap* node_filter_map;
       
   293     EdgeFilterMap* edge_filter_map;
       
   294   public:
       
   295 
       
   296     SubGraphWrapper(Graph& _graph, NodeFilterMap& _node_filter_map, 
       
   297 		    EdgeFilterMap& _edge_filter_map) : 
       
   298       GraphWrapper<Graph>(_graph), node_filter_map(&_node_filter_map), 
       
   299       edge_filter_map(&_edge_filter_map) { }  
       
   300 
       
   301     typedef typename GraphWrapper<Graph>::Node Node;
       
   302     class NodeIt { 
       
   303       friend class GraphWrapper<Graph>;
       
   304       friend class SubGraphWrapper<Graph, NodeFilterMap, EdgeFilterMap>;
       
   305       typename Graph::NodeIt n;
       
   306      public:
       
   307       NodeIt() { }
       
   308       NodeIt(const typename Graph::NodeIt& _n) : n(_n) { }
       
   309       NodeIt(const Invalid& i) : n(i) { }
       
   310       NodeIt(const SubGraphWrapper<Graph, NodeFilterMap, EdgeFilterMap>& _G) : 
       
   311 	n(*(_G.graph)) { 
       
   312 	while (_G.graph->valid(n) && !(*(_G.node_filter_map))[n]) 
       
   313 	  _G.graph->next(n);
       
   314       }
       
   315       operator Node() const { return Node(typename Graph::Node(n)); }
       
   316     };
       
   317     typedef typename GraphWrapper<Graph>::Edge Edge;
       
   318     class OutEdgeIt { 
       
   319       friend class GraphWrapper<Graph>;
       
   320       friend class SubGraphWrapper<Graph, NodeFilterMap, EdgeFilterMap>;
       
   321       typename Graph::OutEdgeIt e;
       
   322     public:
       
   323       OutEdgeIt() { }
       
   324       OutEdgeIt(const typename Graph::OutEdgeIt& _e) : e(_e) { }
       
   325       OutEdgeIt(const Invalid& i) : e(i) { }
       
   326       OutEdgeIt(const SubGraphWrapper<Graph, NodeFilterMap, EdgeFilterMap>& _G, 
       
   327 		const Node& _n) : 
       
   328 	e(*(_G.graph), typename Graph::Node(_n)) { 
       
   329       	while (_G.graph->valid(e) && !(*(_G.edge_filter_map))[e]) 
       
   330 	  _G.graph->next(e);
       
   331       }
       
   332       operator Edge() const { return Edge(typename Graph::Edge(e)); }
       
   333     };
       
   334     class InEdgeIt { 
       
   335       friend class GraphWrapper<Graph>;
       
   336       friend class SubGraphWrapper<Graph, NodeFilterMap, EdgeFilterMap>;
       
   337       typename Graph::InEdgeIt e;
       
   338     public:
       
   339       InEdgeIt() { }
       
   340       InEdgeIt(const typename Graph::InEdgeIt& _e) : e(_e) { }
       
   341       InEdgeIt(const Invalid& i) : e(i) { }
       
   342       InEdgeIt(const SubGraphWrapper<Graph, NodeFilterMap, EdgeFilterMap>& _G, 
       
   343 	       const Node& _n) : 
       
   344 	e(*(_G.graph), typename Graph::Node(_n)) { 
       
   345       	while (_G.graph->valid(e) && !(*(_G.edge_filter_map))[e]) 
       
   346 	  _G.graph->next(e);
       
   347       }
       
   348       operator Edge() const { return Edge(typename Graph::Edge(e)); }
       
   349     };
       
   350     //typedef typename Graph::SymEdgeIt SymEdgeIt;
       
   351     class EdgeIt { 
       
   352       friend class GraphWrapper<Graph>;
       
   353       friend class SubGraphWrapper<Graph, NodeFilterMap, EdgeFilterMap>;
       
   354       typename Graph::EdgeIt e;
       
   355     public:
       
   356       EdgeIt() { }
       
   357       EdgeIt(const typename Graph::EdgeIt& _e) : e(_e) { }
       
   358       EdgeIt(const Invalid& i) : e(i) { }
       
   359       EdgeIt(const SubGraphWrapper<Graph, NodeFilterMap, EdgeFilterMap>& _G) : 
       
   360 	e(*(_G.graph)) { 
       
   361       	while (_G.graph->valid(e) && !(*(_G.edge_filter_map))[e]) 
       
   362 	  _G.graph->next(e);
       
   363       }
       
   364       operator Edge() const { return Edge(typename Graph::Edge(e)); }
       
   365     };
       
   366 
       
   367     NodeIt& first(NodeIt& i) const { 
       
   368       i=NodeIt(*this); return i;
       
   369     }
       
   370     OutEdgeIt& first(OutEdgeIt& i, const Node& p) const { 
       
   371       i=OutEdgeIt(*this, p); return i;
       
   372     }
       
   373     InEdgeIt& first(InEdgeIt& i, const Node& p) const { 
       
   374       i=InEdgeIt(*this, p); return i;
       
   375     }
       
   376     EdgeIt& first(EdgeIt& i) const { 
       
   377       i=EdgeIt(*this); return i;
       
   378     }
       
   379     
       
   380     NodeIt& next(NodeIt& i) const {
       
   381       this->graph->next(i.n); 
       
   382       while (this->graph->valid(i) && !(*node_filter_map)[i.n]) { 
       
   383 	this->graph->next(i.n); }
       
   384       return i;
       
   385     }
       
   386     OutEdgeIt& next(OutEdgeIt& i) const {
       
   387       this->graph->next(i.e); 
       
   388       while (this->graph->valid(i) && !(*edge_filter_map)[i.e]) { 
       
   389 	this->graph->next(i.e); }
       
   390       return i;
       
   391     }
       
   392     InEdgeIt& next(InEdgeIt& i) const {
       
   393       this->graph->next(i.e); 
       
   394       while (this->graph->valid(i) && !(*edge_filter_map)[i.e]) { 
       
   395 	this->graph->next(i.e); }
       
   396       return i;
       
   397     }
       
   398     EdgeIt& next(EdgeIt& i) const {
       
   399       this->graph->next(i.e); 
       
   400       while (this->graph->valid(i) && !(*edge_filter_map)[i.e]) { 
       
   401 	this->graph->next(i.e); }
       
   402       return i;
       
   403     }
       
   404 
       
   405     Node aNode(const OutEdgeIt& e) const { 
       
   406       return Node(this->graph->aNode(e.e)); }
       
   407     Node aNode(const InEdgeIt& e) const { 
       
   408       return Node(this->graph->aNode(e.e)); }
       
   409     Node bNode(const OutEdgeIt& e) const { 
       
   410       return Node(this->graph->bNode(e.e)); }
       
   411     Node bNode(const InEdgeIt& e) const { 
       
   412       return Node(this->graph->bNode(e.e)); }
       
   413 
       
   414     ///\todo
       
   415     ///Some doki, please.
       
   416     void hide(const Node& n) const { node_filter_map->set(n, false); }
       
   417     ///\todo
       
   418     ///Some doki, please.
       
   419     void hide(const Edge& e) const { edge_filter_map->set(e, false); }
       
   420 
       
   421     ///\todo
       
   422     ///Some doki, please.
       
   423     void unHide(const Node& n) const { node_filter_map->set(n, true); }
       
   424     ///\todo
       
   425     ///Some doki, please.
       
   426     void unHide(const Edge& e) const { edge_filter_map->set(e, true); }
       
   427 
       
   428     ///\todo
       
   429     ///Some doki, please.
       
   430     bool hidden(const Node& n) const { return (*node_filter_map)[n]; }
       
   431     ///\todo
       
   432     ///Some doki, please.
       
   433     bool hidden(const Edge& e) const { return (*edge_filter_map)[e]; }
       
   434   };
       
   435 
       
   436   /// A wrapper for forgetting the orientation of a graph.
       
   437 
       
   438   /// A wrapper for getting an undirected graph by forgetting
       
   439   /// the orientation of a directed one.
       
   440   template<typename Graph>
       
   441   class UndirGraphWrapper : public GraphWrapper<Graph> {
       
   442   public:
       
   443     typedef typename GraphWrapper<Graph>::Node Node;
       
   444     typedef typename GraphWrapper<Graph>::NodeIt NodeIt;
       
   445     typedef typename GraphWrapper<Graph>::Edge Edge;
       
   446     typedef typename GraphWrapper<Graph>::EdgeIt EdgeIt;
       
   447 
       
   448     UndirGraphWrapper(Graph& _graph) : GraphWrapper<Graph>(_graph) { }  
       
   449 
       
   450     class OutEdgeIt {
       
   451       friend class UndirGraphWrapper<Graph>;
       
   452       bool out_or_in; //true iff out
       
   453       typename Graph::OutEdgeIt out;
       
   454       typename Graph::InEdgeIt in;
       
   455     public:
       
   456       OutEdgeIt() { }
       
   457       OutEdgeIt(const Invalid& i) : Edge(i) { }
       
   458       OutEdgeIt(const UndirGraphWrapper<Graph>& _G, const Node& _n) {
       
   459 	out_or_in=true; _G.graph->first(out, _n);
       
   460 	if (!(_G.graph->valid(out))) { out_or_in=false; _G.graph->first(in, _n);	}
       
   461       } 
       
   462       operator Edge() const { 
       
   463 	if (out_or_in) return Edge(out); else return Edge(in); 
       
   464       }
       
   465     };
       
   466 
       
   467 //FIXME InEdgeIt
       
   468     typedef OutEdgeIt InEdgeIt; 
       
   469 
       
   470     using GraphWrapper<Graph>::first;
       
   471 //     NodeIt& first(NodeIt& i) const { 
       
   472 //       i=NodeIt(*this); return i;
       
   473 //     }
       
   474     OutEdgeIt& first(OutEdgeIt& i, const Node& p) const { 
       
   475       i=OutEdgeIt(*this, p); return i;
       
   476     }
       
   477 //FIXME
       
   478 //     InEdgeIt& first(InEdgeIt& i, const Node& p) const { 
       
   479 //       i=InEdgeIt(*this, p); return i;
       
   480 //     }
       
   481 //     EdgeIt& first(EdgeIt& i) const { 
       
   482 //       i=EdgeIt(*this); return i;
       
   483 //     }
       
   484 
       
   485     using GraphWrapper<Graph>::next;
       
   486 //     NodeIt& next(NodeIt& n) const {
       
   487 //       GraphWrapper<Graph>::next(n);
       
   488 //       return n;
       
   489 //     }
       
   490     OutEdgeIt& next(OutEdgeIt& e) const {
       
   491       if (e.out_or_in) {
       
   492 	typename Graph::Node n=this->graph->tail(e.out);
       
   493 	this->graph->next(e.out);
       
   494 	if (!this->graph->valid(e.out)) { 
       
   495 	  e.out_or_in=false; this->graph->first(e.in, n); }
       
   496       } else {
       
   497 	this->graph->next(e.in);
       
   498       }
       
   499       return e;
       
   500     }
       
   501     //FIXME InEdgeIt
       
   502 //     EdgeIt& next(EdgeIt& e) const {
       
   503 //       GraphWrapper<Graph>::next(n);
       
   504 // //      graph->next(e.e);
       
   505 //       return e;
       
   506 //     }
       
   507 
       
   508     Node aNode(const OutEdgeIt& e) const { 
       
   509       if (e.out_or_in) return this->graph->tail(e); else 
       
   510 	return this->graph->head(e); }
       
   511     Node bNode(const OutEdgeIt& e) const { 
       
   512       if (e.out_or_in) return this->graph->head(e); else 
       
   513 	return this->graph->tail(e); }
       
   514   };
       
   515   
       
   516   /// A wrapper for composing the residual graph for directed flow and circulation problems.
       
   517 
       
   518   /// A wrapper for composing the residual graph for directed flow and circulation problems.
       
   519   template<typename Graph, typename Number, 
       
   520 	   typename CapacityMap, typename FlowMap>
       
   521   class ResGraphWrapper : public GraphWrapper<Graph> {
       
   522   protected:
       
   523     const CapacityMap* capacity;
       
   524     FlowMap* flow;
       
   525   public:
       
   526 
       
   527     ResGraphWrapper(Graph& _graph, const CapacityMap& _capacity, 
       
   528 		    FlowMap& _flow) : 
       
   529       GraphWrapper<Graph>(_graph), capacity(&_capacity), flow(&_flow) { }
       
   530 
       
   531     class Edge; 
       
   532     class OutEdgeIt; 
       
   533     friend class Edge; 
       
   534     friend class OutEdgeIt; 
       
   535 
       
   536     typedef typename GraphWrapper<Graph>::Node Node;
       
   537     typedef typename GraphWrapper<Graph>::NodeIt NodeIt;
       
   538     class Edge : public Graph::Edge {
       
   539       friend class ResGraphWrapper<Graph, Number, CapacityMap, FlowMap>;
       
   540     protected:
       
   541       bool forward; //true, iff forward
       
   542 //      typename Graph::Edge e;
       
   543     public:
       
   544       Edge() { }
       
   545       Edge(const typename Graph::Edge& _e, bool _forward) : 
       
   546 	Graph::Edge(_e), forward(_forward) { }
       
   547       Edge(const Invalid& i) : Graph::Edge(i), forward(false) { }
       
   548 //the unique invalid iterator
       
   549       friend bool operator==(const Edge& u, const Edge& v) { 
       
   550 	return (v.forward==u.forward && 
       
   551 		static_cast<typename Graph::Edge>(u)==
       
   552 		static_cast<typename Graph::Edge>(v));
       
   553       } 
       
   554       friend bool operator!=(const Edge& u, const Edge& v) { 
       
   555 	return (v.forward!=u.forward || 
       
   556 		static_cast<typename Graph::Edge>(u)!=
       
   557 		static_cast<typename Graph::Edge>(v));
       
   558       } 
       
   559     };
       
   560 
       
   561     class OutEdgeIt {
       
   562       friend class ResGraphWrapper<Graph, Number, CapacityMap, FlowMap>;
       
   563     protected:
       
   564       typename Graph::OutEdgeIt out;
       
   565       typename Graph::InEdgeIt in;
       
   566       bool forward;
       
   567     public:
       
   568       OutEdgeIt() { }
       
   569       //FIXME
       
   570 //      OutEdgeIt(const Edge& e) : Edge(e) { }
       
   571       OutEdgeIt(const Invalid& i) : out(i), in(i), forward(false) { }
       
   572 //the unique invalid iterator
       
   573       OutEdgeIt(const ResGraphWrapper<Graph, Number, CapacityMap, FlowMap>& resG, Node v) { 
       
   574 	forward=true;
       
   575 	resG.graph->first(out, v);
       
   576 	while( resG.graph->valid(out) && !(resG.resCap(*this)>0) ) { resG.graph->next(out); }
       
   577 	if (!resG.graph->valid(out)) {
       
   578 	  forward=false;
       
   579 	  resG.graph->first(in, v);
       
   580 	  while( resG.graph->valid(in) && !(resG.resCap(*this)>0) ) { resG.graph->next(in); }
       
   581 	}
       
   582       }
       
   583       operator Edge() const { 
       
   584 //	Edge e;
       
   585 //	e.forward=this->forward;
       
   586 //	if (this->forward) e=out; else e=in;
       
   587 //	return e;
       
   588 	if (this->forward) 
       
   589 	  return Edge(out, this->forward); 
       
   590 	else 
       
   591 	  return Edge(in, this->forward);
       
   592       }
       
   593     };
       
   594 
       
   595     class InEdgeIt {
       
   596       friend class ResGraphWrapper<Graph, Number, CapacityMap, FlowMap>;
       
   597     protected:
       
   598       typename Graph::OutEdgeIt out;
       
   599       typename Graph::InEdgeIt in;
       
   600       bool forward;
       
   601     public:
       
   602       InEdgeIt() { }
       
   603       //FIXME
       
   604 //      OutEdgeIt(const Edge& e) : Edge(e) { }
       
   605       InEdgeIt(const Invalid& i) : out(i), in(i), forward(false) { }
       
   606 //the unique invalid iterator
       
   607       InEdgeIt(const ResGraphWrapper<Graph, Number, CapacityMap, FlowMap>& resG, Node v) { 
       
   608 	forward=true;
       
   609 	resG.graph->first(in, v);
       
   610 	while( resG.graph->valid(in) && !(resG.resCap(*this)>0) ) { resG.graph->next(in); }
       
   611 	if (!resG.graph->valid(in)) {
       
   612 	  forward=false;
       
   613 	  resG.graph->first(out, v);
       
   614 	  while( resG.graph->valid(out) && !(resG.resCap(*this)>0) ) { resG.graph->next(out); }
       
   615 	}
       
   616       }
       
   617       operator Edge() const { 
       
   618 //	Edge e;
       
   619 //	e.forward=this->forward;
       
   620 //	if (this->forward) e=out; else e=in;
       
   621 //	return e;
       
   622 	if (this->forward) 
       
   623 	  return Edge(in, this->forward); 
       
   624 	else 
       
   625 	  return Edge(out, this->forward);
       
   626       }
       
   627     };
       
   628 
       
   629     class EdgeIt {
       
   630       friend class ResGraphWrapper<Graph, Number, CapacityMap, FlowMap>;
       
   631     protected:
       
   632       typename Graph::EdgeIt e;
       
   633       bool forward;
       
   634     public:
       
   635       EdgeIt() { }
       
   636       EdgeIt(const Invalid& i) : e(i), forward(false) { }
       
   637       EdgeIt(const ResGraphWrapper<Graph, Number, CapacityMap, FlowMap>& resG) { 
       
   638 	forward=true;
       
   639 	resG.graph->first(e);
       
   640 	while (resG.graph->valid(e) && !(resG.resCap(*this)>0)) resG.graph->next(e);
       
   641 	if (!resG.graph->valid(e)) {
       
   642 	  forward=false;
       
   643 	  resG.graph->first(e);
       
   644 	  while (resG.graph->valid(e) && !(resG.resCap(*this)>0)) resG.graph->next(e);
       
   645 	}
       
   646       }
       
   647       operator Edge() const { 
       
   648 	return Edge(e, this->forward);
       
   649       }
       
   650     };
       
   651 
       
   652     using GraphWrapper<Graph>::first;
       
   653 //     NodeIt& first(NodeIt& i) const { 
       
   654 //       i=NodeIt(*this); return i;
       
   655 //     }
       
   656     OutEdgeIt& first(OutEdgeIt& i, const Node& p) const { 
       
   657       i=OutEdgeIt(*this, p); return i;
       
   658     }
       
   659 //    FIXME not tested
       
   660     InEdgeIt& first(InEdgeIt& i, const Node& p) const { 
       
   661       i=InEdgeIt(*this, p); return i;
       
   662     }
       
   663     EdgeIt& first(EdgeIt& i) const { 
       
   664       i=EdgeIt(*this); return i;
       
   665     }
       
   666   
       
   667     using GraphWrapper<Graph>::next;
       
   668 //    NodeIt& next(NodeIt& n) const { GraphWrapper<Graph>::next(n); return n; }
       
   669     OutEdgeIt& next(OutEdgeIt& e) const { 
       
   670       if (e.forward) {
       
   671 	Node v=this->graph->aNode(e.out);
       
   672 	this->graph->next(e.out);
       
   673 	while( this->graph->valid(e.out) && !(resCap(e)>0) ) { 
       
   674 	  this->graph->next(e.out); }
       
   675 	if (!this->graph->valid(e.out)) {
       
   676 	  e.forward=false;
       
   677 	  this->graph->first(e.in, v); 
       
   678 	  while( this->graph->valid(e.in) && !(resCap(e)>0) ) { 
       
   679 	    this->graph->next(e.in); }
       
   680 	}
       
   681       } else {
       
   682 	this->graph->next(e.in);
       
   683 	while( this->graph->valid(e.in) && !(resCap(e)>0) ) { 
       
   684 	  this->graph->next(e.in); } 
       
   685       }
       
   686       return e;
       
   687     }
       
   688 //     FIXME Not tested
       
   689     InEdgeIt& next(InEdgeIt& e) const { 
       
   690       if (e.forward) {
       
   691 	Node v=this->graph->aNode(e.in);
       
   692 	this->graph->next(e.in);
       
   693 	while( this->graph->valid(e.in) && !(resCap(e)>0) ) { 
       
   694 	  this->graph->next(e.in); }
       
   695 	if (!this->graph->valid(e.in)) {
       
   696 	  e.forward=false;
       
   697 	  this->graph->first(e.out, v); 
       
   698 	  while( this->graph->valid(e.out) && !(resCap(e)>0) ) { 
       
   699 	    this->graph->next(e.out); }
       
   700 	}
       
   701       } else {
       
   702 	this->graph->next(e.out);
       
   703 	while( this->graph->valid(e.out) && !(resCap(e)>0) ) { 
       
   704 	  this->graph->next(e.out); } 
       
   705       }
       
   706       return e;
       
   707     }
       
   708     EdgeIt& next(EdgeIt& e) const {
       
   709       if (e.forward) {
       
   710 	this->graph->next(e.e);
       
   711 	while( this->graph->valid(e.e) && !(resCap(e)>0) ) { 
       
   712 	  this->graph->next(e.e); }
       
   713 	if (!this->graph->valid(e.e)) {
       
   714 	  e.forward=false;
       
   715 	  this->graph->first(e.e); 
       
   716 	  while( this->graph->valid(e.e) && !(resCap(e)>0) ) { 
       
   717 	    this->graph->next(e.e); }
       
   718 	}
       
   719       } else {
       
   720 	this->graph->next(e.e);
       
   721 	while( this->graph->valid(e.e) && !(resCap(e)>0) ) { 
       
   722 	  this->graph->next(e.e); } 
       
   723       }
       
   724       return e;
       
   725     }
       
   726 
       
   727     Node tail(Edge e) const { 
       
   728       return ((e.forward) ? this->graph->tail(e) : this->graph->head(e)); }
       
   729     Node head(Edge e) const { 
       
   730       return ((e.forward) ? this->graph->head(e) : this->graph->tail(e)); }
       
   731 
       
   732     Node aNode(OutEdgeIt e) const { 
       
   733       return ((e.forward) ? this->graph->aNode(e.out) : 
       
   734 	      this->graph->aNode(e.in)); }
       
   735     Node bNode(OutEdgeIt e) const { 
       
   736       return ((e.forward) ? this->graph->bNode(e.out) : 
       
   737 	      this->graph->bNode(e.in)); }
       
   738 
       
   739     Node aNode(InEdgeIt e) const { 
       
   740       return ((e.forward) ? this->graph->aNode(e.in) : 
       
   741 	      this->graph->aNode(e.out)); }
       
   742     Node bNode(InEdgeIt e) const { 
       
   743       return ((e.forward) ? this->graph->bNode(e.in) : 
       
   744 	      this->graph->bNode(e.out)); }
       
   745 
       
   746 //    int nodeNum() const { return graph->nodeNum(); }
       
   747     //FIXME
       
   748     void edgeNum() const { }
       
   749     //int edgeNum() const { return graph->edgeNum(); }
       
   750 
       
   751 
       
   752 //    int id(Node v) const { return graph->id(v); }
       
   753 
       
   754     bool valid(Node n) const { return GraphWrapper<Graph>::valid(n); }
       
   755     bool valid(Edge e) const { 
       
   756       return this->graph->valid(e);
       
   757 	//return e.forward ? graph->valid(e.out) : graph->valid(e.in); 
       
   758     }
       
   759 
       
   760     void augment(const Edge& e, Number a) const {
       
   761       if (e.forward)  
       
   762 // 	flow->set(e.out, flow->get(e.out)+a);
       
   763 	flow->set(e, (*flow)[e]+a);
       
   764       else  
       
   765 // 	flow->set(e.in, flow->get(e.in)-a);
       
   766 	flow->set(e, (*flow)[e]-a);
       
   767     }
       
   768 
       
   769     Number resCap(const Edge& e) const { 
       
   770       if (e.forward) 
       
   771 //	return (capacity->get(e.out)-flow->get(e.out)); 
       
   772 	return ((*capacity)[e]-(*flow)[e]); 
       
   773       else 
       
   774 //	return (flow->get(e.in)); 
       
   775 	return ((*flow)[e]); 
       
   776     }
       
   777 
       
   778 //     Number resCap(typename Graph::OutEdgeIt out) const { 
       
   779 // //      return (capacity->get(out)-flow->get(out)); 
       
   780 //       return ((*capacity)[out]-(*flow)[out]); 
       
   781 //     }
       
   782     
       
   783 //     Number resCap(typename Graph::InEdgeIt in) const { 
       
   784 // //      return (flow->get(in)); 
       
   785 //       return ((*flow)[in]); 
       
   786 //     }
       
   787 
       
   788     template <typename T>
       
   789     class EdgeMap {
       
   790       typename Graph::template EdgeMap<T> forward_map, backward_map; 
       
   791     public:
       
   792       EdgeMap(const ResGraphWrapper<Graph, Number, CapacityMap, FlowMap>& _G) : forward_map(*(_G.graph)), backward_map(*(_G.graph)) { }
       
   793       EdgeMap(const ResGraphWrapper<Graph, Number, CapacityMap, FlowMap>& _G, T a) : forward_map(*(_G.graph), a), backward_map(*(_G.graph), a) { }
       
   794       void set(Edge e, T a) { 
       
   795 	if (e.forward) 
       
   796 	  forward_map.set(e.out, a); 
       
   797 	else 
       
   798 	  backward_map.set(e.in, a); 
       
   799       }
       
   800       T operator[](Edge e) const { 
       
   801 	if (e.forward) 
       
   802 	  return forward_map[e.out]; 
       
   803 	else 
       
   804 	  return backward_map[e.in]; 
       
   805       }
       
   806 //       T get(Edge e) const { 
       
   807 // 	if (e.out_or_in) 
       
   808 // 	  return forward_map.get(e.out); 
       
   809 // 	else 
       
   810 // 	  return backward_map.get(e.in); 
       
   811 //       }
       
   812     };
       
   813   };
       
   814 
       
   815   /// ErasingFirstGraphWrapper for blocking flows.
       
   816 
       
   817   /// ErasingFirstGraphWrapper for blocking flows.
       
   818   template<typename Graph, typename FirstOutEdgesMap>
       
   819   class ErasingFirstGraphWrapper : public GraphWrapper<Graph> {
       
   820   protected:
       
   821     FirstOutEdgesMap* first_out_edges;
       
   822   public:
       
   823     ErasingFirstGraphWrapper(Graph& _graph, 
       
   824 			     FirstOutEdgesMap& _first_out_edges) : 
       
   825       GraphWrapper<Graph>(_graph), first_out_edges(&_first_out_edges) { }  
       
   826 
       
   827     typedef typename GraphWrapper<Graph>::Node Node;
       
   828 //     class NodeIt { 
       
   829 //       friend class GraphWrapper<Graph>;
       
   830 //       friend class ErasingFirstGraphWrapper<Graph, FirstOutEdgesMap>;
       
   831 //       typename Graph::NodeIt n;
       
   832 //      public:
       
   833 //       NodeIt() { }
       
   834 //       NodeIt(const typename Graph::NodeIt& _n) : n(_n) { }
       
   835 //       NodeIt(const Invalid& i) : n(i) { }
       
   836 //       NodeIt(const ErasingFirstGraphWrapper<Graph, FirstOutEdgesMap>& _G) : 
       
   837 // 	n(*(_G.graph)) { }
       
   838 //       operator Node() const { return Node(typename Graph::Node(n)); }
       
   839 //     };
       
   840     typedef typename GraphWrapper<Graph>::Edge Edge;
       
   841     class OutEdgeIt { 
       
   842       friend class GraphWrapper<Graph>;
       
   843       friend class ErasingFirstGraphWrapper<Graph, FirstOutEdgesMap>;
       
   844 //      typedef typename Graph::OutEdgeIt GraphOutEdgeIt;
       
   845       typename Graph::OutEdgeIt e;
       
   846     public:
       
   847       OutEdgeIt() { }
       
   848       OutEdgeIt(const typename Graph::OutEdgeIt& _e) : e(_e) { }
       
   849       OutEdgeIt(const Invalid& i) : e(i) { }
       
   850       OutEdgeIt(const ErasingFirstGraphWrapper<Graph, FirstOutEdgesMap>& _G, 
       
   851 		const Node& _n) : 
       
   852 	e((*_G.first_out_edges)[_n]) { }
       
   853       operator Edge() const { return Edge(typename Graph::Edge(e)); }
       
   854     };
       
   855     class InEdgeIt { 
       
   856       friend class GraphWrapper<Graph>;
       
   857       friend class ErasingFirstGraphWrapper<Graph, FirstOutEdgesMap>;
       
   858 //      typedef typename Graph::InEdgeIt GraphInEdgeIt;
       
   859       typename Graph::InEdgeIt e;
       
   860     public:
       
   861       InEdgeIt() { }
       
   862       InEdgeIt(const typename Graph::InEdgeIt& _e) : e(_e) { }
       
   863       InEdgeIt(const Invalid& i) : e(i) { }
       
   864       InEdgeIt(const ErasingFirstGraphWrapper<Graph, FirstOutEdgesMap>& _G, 
       
   865 	       const Node& _n) : 
       
   866 	e(*(_G.graph), typename Graph::Node(_n)) { }
       
   867       operator Edge() const { return Edge(typename Graph::Edge(e)); }
       
   868     };
       
   869     //typedef typename Graph::SymEdgeIt SymEdgeIt;
       
   870     class EdgeIt { 
       
   871       friend class GraphWrapper<Graph>;
       
   872       friend class ErasingFirstGraphWrapper<Graph, FirstOutEdgesMap>;
       
   873 //      typedef typename Graph::EdgeIt GraphEdgeIt;
       
   874       typename Graph::EdgeIt e;
       
   875     public:
       
   876       EdgeIt() { }
       
   877       EdgeIt(const typename Graph::EdgeIt& _e) : e(_e) { }
       
   878       EdgeIt(const Invalid& i) : e(i) { }
       
   879       EdgeIt(const ErasingFirstGraphWrapper<Graph, FirstOutEdgesMap>& _G) : 
       
   880 	e(*(_G.graph)) { }
       
   881       operator Edge() const { return Edge(typename Graph::Edge(e)); }
       
   882     };
       
   883 
       
   884     using GraphWrapper<Graph>::first;
       
   885 //     NodeIt& first(NodeIt& i) const { 
       
   886 //       i=NodeIt(*this); return i;
       
   887 //     }
       
   888     OutEdgeIt& first(OutEdgeIt& i, const Node& p) const { 
       
   889       i=OutEdgeIt(*this, p); return i;
       
   890     }
       
   891     InEdgeIt& first(InEdgeIt& i, const Node& p) const { 
       
   892       i=InEdgeIt(*this, p); return i;
       
   893     }
       
   894     EdgeIt& first(EdgeIt& i) const { 
       
   895       i=EdgeIt(*this); return i;
       
   896     }
       
   897 
       
   898     using GraphWrapper<Graph>::next;
       
   899 //    NodeIt& next(NodeIt& i) const { graph->next(i.n); return i; }
       
   900     OutEdgeIt& next(OutEdgeIt& i) const { this->graph->next(i.e); return i; }
       
   901     InEdgeIt& next(InEdgeIt& i) const { this->graph->next(i.e); return i; }
       
   902     EdgeIt& next(EdgeIt& i) const { this->graph->next(i.e); return i; }    
       
   903     
       
   904     Node aNode(const OutEdgeIt& e) const { 
       
   905       return Node(this->graph->aNode(e.e)); }
       
   906     Node aNode(const InEdgeIt& e) const { 
       
   907       return Node(this->graph->aNode(e.e)); }
       
   908     Node bNode(const OutEdgeIt& e) const { 
       
   909       return Node(this->graph->bNode(e.e)); }
       
   910     Node bNode(const InEdgeIt& e) const { 
       
   911       return Node(this->graph->bNode(e.e)); }
       
   912 
       
   913     void erase(const OutEdgeIt& e) const {
       
   914       OutEdgeIt f=e;
       
   915       this->next(f);
       
   916       first_out_edges->set(this->tail(e), f.e);
       
   917     }
       
   918   };
       
   919 
       
   920   /// A wrapper for composing a bipartite graph.
       
   921   /// \c _graph have to be a reference to a graph of type \c Graph 
       
   922   /// and \c _s_false_t_true_map is an \c IterableBoolMap 
       
   923   /// reference containing the elements for the 
       
   924   /// color classes S and T. \c _graph is to be referred to an undirected 
       
   925   /// graph or a directed graph with edges oriented from S to T.
       
   926   template<typename Graph> 
       
   927   class BipartiteGraphWrapper : public GraphWrapper<Graph> {
       
   928     typedef IterableBoolMap< typename Graph::template NodeMap<int> > 
       
   929     SFalseTTrueMap;
       
   930     SFalseTTrueMap* s_false_t_true_map;
       
   931 
       
   932   public:
       
   933     //marci
       
   934     //FIXME vhogy igy kellene, csak az en forditom nem eszi meg
       
   935     //static const bool S_CLASS=false;
       
   936     //static const bool T_CLASS=true;
       
   937     
       
   938     bool S_CLASS;
       
   939     bool T_CLASS;
       
   940 
       
   941     BipartiteGraphWrapper(Graph& _graph, SFalseTTrueMap& _s_false_t_true_map) 
       
   942       : GraphWrapper<Graph>(_graph), s_false_t_true_map(&_s_false_t_true_map), 
       
   943       S_CLASS(false), T_CLASS(true) { }
       
   944     typedef typename GraphWrapper<Graph>::Node Node;
       
   945     //using GraphWrapper<Graph>::NodeIt;
       
   946     typedef typename GraphWrapper<Graph>::Edge Edge;
       
   947     //using GraphWrapper<Graph>::EdgeIt;
       
   948     class ClassNodeIt;
       
   949     friend class ClassNodeIt;
       
   950     class OutEdgeIt;
       
   951     friend class OutEdgeIt;
       
   952     class InEdgeIt;
       
   953     friend class InEdgeIt;
       
   954     class ClassNodeIt {
       
   955       friend class BipartiteGraphWrapper<Graph>;
       
   956     protected:
       
   957       Node n;
       
   958     public:
       
   959       ClassNodeIt() { }
       
   960       ClassNodeIt(const Invalid& i) : n(i) { }
       
   961       ClassNodeIt(const BipartiteGraphWrapper<Graph>& _G, bool _class) { 
       
   962 	_G.s_false_t_true_map->first(n, _class); 
       
   963       }
       
   964       //FIXME needed in new concept, important here
       
   965       ClassNodeIt(const Node& _n) : n(_n) { }
       
   966       operator Node() const { return n; }
       
   967     };
       
   968 //     class SNodeIt {
       
   969 //       Node n;
       
   970 //     public:
       
   971 //       SNodeIt() { }
       
   972 //       SNodeIt(const Invalid& i) : n(i) { }
       
   973 //       SNodeIt(const BipartiteGraphWrapper<Graph>& _G) { 
       
   974 // 	_G.s_false_t_true_map->first(n, false); 
       
   975 //       }
       
   976 //       operator Node() const { return n; }
       
   977 //     };
       
   978 //     class TNodeIt {
       
   979 //       Node n;
       
   980 //     public:
       
   981 //       TNodeIt() { }
       
   982 //       TNodeIt(const Invalid& i) : n(i) { }
       
   983 //       TNodeIt(const BipartiteGraphWrapper<Graph>& _G) { 
       
   984 // 	_G.s_false_t_true_map->first(n, true); 
       
   985 //       }
       
   986 //       operator Node() const { return n; }
       
   987 //     };
       
   988     class OutEdgeIt { 
       
   989       friend class BipartiteGraphWrapper<Graph>;
       
   990     protected:
       
   991       typename Graph::OutEdgeIt e;
       
   992     public:
       
   993       OutEdgeIt() { }
       
   994       OutEdgeIt(const Invalid& i) : e(i) { }
       
   995       OutEdgeIt(const BipartiteGraphWrapper<Graph>& _G, const Node& _n) {
       
   996 	if (!(*(_G.s_false_t_true_map))[_n]) 
       
   997 	  e=typename Graph::OutEdgeIt(*(_G.graph), typename Graph::Node(_n));
       
   998 	else 
       
   999 	  e=INVALID;
       
  1000       }
       
  1001       operator Edge() const { return Edge(typename Graph::Edge(e)); }
       
  1002     };
       
  1003     class InEdgeIt { 
       
  1004       friend class BipartiteGraphWrapper<Graph>;
       
  1005     protected:
       
  1006       typename Graph::InEdgeIt e;
       
  1007     public:
       
  1008       InEdgeIt() { }
       
  1009       InEdgeIt(const Invalid& i) : e(i) { }
       
  1010       InEdgeIt(const BipartiteGraphWrapper<Graph>& _G, const Node& _n) {
       
  1011 	if ((*(_G.s_false_t_true_map))[_n]) 
       
  1012 	  e=typename Graph::InEdgeIt(*(_G.graph), typename Graph::Node(_n));
       
  1013 	else 
       
  1014 	  e=INVALID;
       
  1015       }
       
  1016       operator Edge() const { return Edge(typename Graph::Edge(e)); }
       
  1017     };
       
  1018 
       
  1019     using GraphWrapper<Graph>::first;
       
  1020     ClassNodeIt& first(ClassNodeIt& n, bool _class) const { 
       
  1021       n=ClassNodeIt(*this, _class) ; return n; }
       
  1022 //    SNodeIt& first(SNodeIt& n) const { n=SNodeIt(*this); return n; }
       
  1023 //    TNodeIt& first(TNodeIt& n) const { n=TNodeIt(*this); return n; }
       
  1024     OutEdgeIt& first(OutEdgeIt& i, const Node& p) const { 
       
  1025       i=OutEdgeIt(*this, p); return i;
       
  1026     }
       
  1027     InEdgeIt& first(InEdgeIt& i, const Node& p) const { 
       
  1028       i=InEdgeIt(*this, p); return i;
       
  1029     }
       
  1030 
       
  1031     using GraphWrapper<Graph>::next;
       
  1032     ClassNodeIt& next(ClassNodeIt& n) const { 
       
  1033       this->s_false_t_true_map->next(n.n); return n; 
       
  1034     }
       
  1035 //     SNodeIt& next(SNodeIt& n) const { 
       
  1036 //       this->s_false_t_true_map->next(n); return n; 
       
  1037 //     }
       
  1038 //     TNodeIt& next(TNodeIt& n) const { 
       
  1039 //       this->s_false_t_true_map->next(n); return n; 
       
  1040 //     }
       
  1041     OutEdgeIt& next(OutEdgeIt& i) const { this->graph->next(i.e); return i; }
       
  1042     InEdgeIt& next(InEdgeIt& i) const { this->graph->next(i.e); return i; }
       
  1043 
       
  1044     Node tail(const Edge& e) { 
       
  1045       if (!(*(this->s_false_t_true_map))[this->graph->tail(e)]) 
       
  1046 	return Node(this->graph->tail(e));
       
  1047       else
       
  1048 	return Node(this->graph->head(e));	
       
  1049     }
       
  1050     Node head(const Edge& e) { 
       
  1051       if (!(*(this->s_false_t_true_map))[this->graph->tail(e)]) 
       
  1052 	return Node(this->graph->head(e));
       
  1053       else
       
  1054 	return Node(this->graph->tail(e));	
       
  1055     }
       
  1056 
       
  1057     Node aNode(const OutEdgeIt& e) const { 
       
  1058       return Node(this->graph->aNode(e.e)); 
       
  1059     }
       
  1060     Node aNode(const InEdgeIt& e) const { 
       
  1061       return Node(this->graph->aNode(e.e)); 
       
  1062     }
       
  1063     Node bNode(const OutEdgeIt& e) const { 
       
  1064       return Node(this->graph->bNode(e.e)); 
       
  1065     }
       
  1066     Node bNode(const InEdgeIt& e) const { 
       
  1067       return Node(this->graph->bNode(e.e)); 
       
  1068     }
       
  1069 
       
  1070     bool inSClass(const Node& n) const {
       
  1071       return !(*(this->s_false_t_true_map))[n];
       
  1072     }
       
  1073     bool inTClass(const Node& n) const {
       
  1074       return (*(this->s_false_t_true_map))[n];
       
  1075     }
       
  1076   };
       
  1077 
       
  1078 
       
  1079 
       
  1080 
       
  1081   /********************   S-T Graph Wrapper    ********************/
       
  1082 
       
  1083 
       
  1084 
       
  1085 
       
  1086 
       
  1087   template<typename Graph> class stGraphWrapper;
       
  1088 
       
  1089   template<typename Graph>
       
  1090   inline
       
  1091   std::ostream& 
       
  1092   operator<<(std::ostream& os,
       
  1093 	     typename stGraphWrapper<Graph>::Node const& i) { 
       
  1094     os << "(node: " << typename Graph::Node(i) << " spec: " << i.spec <<")";
       
  1095     return os; 
       
  1096   }
       
  1097 
       
  1098   template<typename Graph>
       
  1099   inline
       
  1100   std::ostream& 
       
  1101   operator<<(std::ostream& os,
       
  1102 	     typename stGraphWrapper<Graph>::Edge const& i) { 
       
  1103     os << "(edge: " << typename Graph::Edge(i) << " spec: " << i.spec
       
  1104        << " node: " << i.n << ")"; 
       
  1105     return os; 
       
  1106   }
       
  1107 
       
  1108 
       
  1109   /// experimentral, do not try it.
       
  1110   /// It eats a bipartite graph, oriented from S to T.
       
  1111   /// Such one can be made e.g. by the above wrapper.
       
  1112   template<typename Graph>
       
  1113   class stGraphWrapper : public GraphWrapper<Graph> {
       
  1114   public:
       
  1115     class Node; 
       
  1116     friend class Node;
       
  1117 //GN, int
       
  1118 //0 normalis, 1 s, 2, true, ez az iteralasi sorrend, 
       
  1119 //es a vege a false azaz (invalid, 3)    
       
  1120     class NodeIt;
       
  1121     friend class NodeIt;
       
  1122 //GNI, int
       
  1123     class Edge;
       
  1124     friend class Edge;
       
  1125 //GE, int, GN
       
  1126 //0 normalis, 1 s->vmi, 2 vmi->t, ez a sorrend,
       
  1127 //invalid: (invalid, 3, invalid)
       
  1128     class OutEdgeIt;
       
  1129     friend class OutEdgeIt;
       
  1130 //GO, int, GNI
       
  1131 //normalis pontbol (first, 0, invalid), ..., (invalid, 2, vmi), ... (invalid, 3, invalid)
       
  1132 //s-bol (invalid, 1, first), ... (invalid, 3, invalid)
       
  1133 //t-bol (invalid, 3, invalid)
       
  1134     class InEdgeIt;
       
  1135     friend class InEdgeIt;
       
  1136 //GI, int, GNI
       
  1137 //normalis pontbol (first, 0, invalid), ..., (invalid, 1, vmi), ... (invalid, 3, invalid)
       
  1138 //s-be (invalid, 3, invalid)
       
  1139 //t-be (invalid, 2, first), ... (invalid, 3, invalid)
       
  1140     class EdgeIt;
       
  1141     friend class EdgeIt;
       
  1142 //(first, 0, invalid) ...
       
  1143 //(invalid, 1, vmi)
       
  1144 //(invalid, 2, vmi)
       
  1145 //invalid, 3, invalid)
       
  1146     template <typename T> class NodeMap;
       
  1147     template <typename T, typename Parent> class EdgeMap;
       
  1148 
       
  1149 //    template <typename T> friend class NodeMap;
       
  1150 //    template <typename T> friend class EdgeMap;
       
  1151 
       
  1152     const Node S_NODE;
       
  1153     const Node T_NODE;
       
  1154 
       
  1155     static const bool S_CLASS=false;
       
  1156     static const bool T_CLASS=true;
       
  1157 
       
  1158     stGraphWrapper(Graph& _graph) : GraphWrapper<Graph>(_graph) , 
       
  1159 				    S_NODE(INVALID, 1), 
       
  1160 				    T_NODE(INVALID, 2) { }
       
  1161 
       
  1162     
       
  1163     class Node : public Graph::Node {
       
  1164     protected:
       
  1165       friend class GraphWrapper<Graph>;
       
  1166       friend class stGraphWrapper<Graph>;
       
  1167       template <typename T> friend class NodeMap;
       
  1168       friend class Edge;
       
  1169       friend class OutEdgeIt;
       
  1170       friend class InEdgeIt;
       
  1171       friend class EdgeIt;
       
  1172       int spec; 
       
  1173     public:
       
  1174       Node() { }
       
  1175       Node(const typename Graph::Node& _n, int _spec=0) : 
       
  1176 	Graph::Node(_n), spec(_spec) { }
       
  1177       Node(const Invalid& i) : Graph::Node(i), spec(3) { }
       
  1178       friend bool operator==(const Node& u, const Node& v) { 
       
  1179 	return (u.spec==v.spec && 
       
  1180 		static_cast<typename Graph::Node>(u)==
       
  1181 		static_cast<typename Graph::Node>(v));
       
  1182       } 
       
  1183       friend bool operator!=(const Node& u, const Node& v) { 
       
  1184 	return (v.spec!=u.spec || 
       
  1185 		static_cast<typename Graph::Node>(u)!=
       
  1186 		static_cast<typename Graph::Node>(v));
       
  1187       }
       
  1188       friend std::ostream& operator<< <Graph>(std::ostream& os, const Node& i);
       
  1189       int getSpec() const { return spec; }
       
  1190     };
       
  1191 
       
  1192     class NodeIt { 
       
  1193       friend class GraphWrapper<Graph>;
       
  1194       friend class stGraphWrapper<Graph>;
       
  1195       typename Graph::NodeIt n;
       
  1196       int spec; 
       
  1197      public:
       
  1198       NodeIt() { }
       
  1199       NodeIt(const typename Graph::NodeIt& _n, int _spec) : 
       
  1200 	n(_n), spec(_spec) { }
       
  1201       NodeIt(const Invalid& i) : n(i), spec(3) { }
       
  1202       NodeIt(const stGraphWrapper<Graph>& _G) : n(*(_G.graph)), spec(0) { 
       
  1203 	if (!_G.graph->valid(n)) spec=1;
       
  1204       }
       
  1205       operator Node() const { return Node(n, spec); }
       
  1206     };
       
  1207 
       
  1208     typedef NodeIt NodeIt;
       
  1209     typedef Node Node;
       
  1210 
       
  1211     class Edge : public Graph::Edge {
       
  1212       friend class GraphWrapper<Graph>;
       
  1213       friend class stGraphWrapper<Graph>;
       
  1214       template <typename T, typename Parent> friend class EdgeMap;
       
  1215       int spec;
       
  1216       typename Graph::Node n;
       
  1217     public:
       
  1218       Edge() { }
       
  1219       Edge(const typename Graph::Edge& _e, int _spec, 
       
  1220 	   const typename Graph::Node& _n) : 
       
  1221 	Graph::Edge(_e), spec(_spec), n(_n) { 
       
  1222       }
       
  1223       Edge(const Invalid& i) : Graph::Edge(i), spec(3), n(i) { }
       
  1224       friend bool operator==(const Edge& u, const Edge& v) { 
       
  1225 	return (u.spec==v.spec && 
       
  1226 		static_cast<typename Graph::Edge>(u)==
       
  1227 		static_cast<typename Graph::Edge>(v) && 
       
  1228 		u.n==v.n);
       
  1229       } 
       
  1230       friend bool operator!=(const Edge& u, const Edge& v) { 
       
  1231 	return (v.spec!=u.spec || 
       
  1232 		static_cast<typename Graph::Edge>(u)!=
       
  1233 		static_cast<typename Graph::Edge>(v) || 
       
  1234 		u.n!=v.n);
       
  1235       } 
       
  1236       friend std::ostream& operator<< <Graph>(std::ostream& os, const Edge& i);
       
  1237       int getSpec() const { return spec; }
       
  1238     };
       
  1239 
       
  1240     class OutEdgeIt { 
       
  1241       friend class GraphWrapper<Graph>;
       
  1242       friend class stGraphWrapper<Graph>;
       
  1243       typename Graph::OutEdgeIt e;
       
  1244       int spec;
       
  1245       typename Graph::ClassNodeIt n;
       
  1246     public:
       
  1247       OutEdgeIt() { }
       
  1248       OutEdgeIt(const typename Graph::OutEdgeIt& _e, int _spec, 
       
  1249 		const typename Graph::ClassNodeIt& _n) : 
       
  1250 	e(_e), spec(_spec), n(_n) { 
       
  1251       }
       
  1252       OutEdgeIt(const Invalid& i) : e(i), spec(3), n(i) { }
       
  1253       OutEdgeIt(const stGraphWrapper<Graph>& _G, const Node& _n) {
       
  1254 	switch (_n.spec) {
       
  1255 	  case 0 : 
       
  1256 	    if (_G.graph->inSClass(_n)) { //S, van normalis kiel 
       
  1257 	      e=typename Graph::OutEdgeIt(*(_G.graph), 
       
  1258 					  typename Graph::Node(_n)); 
       
  1259 	      spec=0;
       
  1260 	      n=INVALID;
       
  1261 	      if (!_G.graph->valid(e)) spec=3;
       
  1262 	    } else { //T, specko kiel van
       
  1263 	      e=INVALID;
       
  1264 	      spec=2;
       
  1265 	      n=_n;
       
  1266 	    }
       
  1267 	    break;
       
  1268 	  case 1:
       
  1269 	    e=INVALID;
       
  1270 	    spec=1;
       
  1271 	    _G.graph->first(n, S_CLASS); //s->vmi;
       
  1272 	    if (!_G.graph->valid(n)) spec=3; //Ha S ures
       
  1273 	    break;
       
  1274 	  case 2:
       
  1275 	    e=INVALID;
       
  1276 	    spec=3;
       
  1277 	    n=INVALID;
       
  1278 	    break;
       
  1279 	}
       
  1280       }
       
  1281       operator Edge() const { return Edge(e, spec, n); }
       
  1282     };
       
  1283 
       
  1284     class InEdgeIt { 
       
  1285       friend class GraphWrapper<Graph>;
       
  1286       friend class stGraphWrapper<Graph>;
       
  1287       typename Graph::InEdgeIt e;
       
  1288       int spec;
       
  1289       typename Graph::ClassNodeIt n;
       
  1290     public:
       
  1291       InEdgeIt() { }
       
  1292       InEdgeIt(const typename Graph::InEdgeIt& _e, int _spec, 
       
  1293 	       const typename Graph::ClassNodeIt& _n) : 
       
  1294 	e(_e), spec(_spec), n(_n) { 
       
  1295       }
       
  1296       InEdgeIt(const Invalid& i) : e(i), spec(3), n(i) { }
       
  1297       InEdgeIt(const stGraphWrapper<Graph>& _G, const Node& _n) {
       
  1298 	switch (_n.spec) {
       
  1299 	  case 0 : 
       
  1300 	    if (_G.graph->inTClass(_n)) { //T, van normalis beel 
       
  1301 	      e=typename Graph::InEdgeIt(*(_G.graph), 
       
  1302 					 typename Graph::Node(_n)); 
       
  1303 	      spec=0;
       
  1304 	      n=INVALID;
       
  1305 	      if (!_G.graph->valid(e)) spec=3;
       
  1306 	    } else { //S, specko beel van
       
  1307 	      e=INVALID;
       
  1308 	      spec=1;
       
  1309 	      n=_n;
       
  1310 	    }
       
  1311 	    break;
       
  1312 	  case 1:
       
  1313 	    e=INVALID;
       
  1314 	    spec=3;
       
  1315 	    n=INVALID;
       
  1316 	    break;
       
  1317 	  case 2:
       
  1318 	    e=INVALID;
       
  1319 	    spec=2;
       
  1320 	    _G.graph->first(n, T_CLASS); //vmi->t;
       
  1321 	    if (!_G.graph->valid(n)) spec=3; //Ha T ures
       
  1322 	    break;
       
  1323 	}
       
  1324       }
       
  1325       operator Edge() const { return Edge(e, spec, n); }
       
  1326     };
       
  1327 
       
  1328     class EdgeIt { 
       
  1329       friend class GraphWrapper<Graph>;
       
  1330       friend class stGraphWrapper<Graph>;
       
  1331       typename Graph::EdgeIt e;
       
  1332       int spec;
       
  1333       typename Graph::ClassNodeIt n;
       
  1334     public:
       
  1335       EdgeIt() { }
       
  1336       EdgeIt(const typename Graph::EdgeIt& _e, int _spec, 
       
  1337 	     const typename Graph::ClassNodeIt& _n) : 
       
  1338 	e(_e), spec(_spec), n(_n) { }
       
  1339       EdgeIt(const Invalid& i) : e(i), spec(3), n(i) { }
       
  1340       EdgeIt(const stGraphWrapper<Graph>& _G) : 
       
  1341 	e(*(_G.graph)), spec(0), n(INVALID) { 
       
  1342 	if (!_G.graph->valid(e)) {
       
  1343 	  spec=1;
       
  1344 	  _G.graph->first(n, S_CLASS);
       
  1345 	  if (!_G.graph->valid(n)) { //Ha S ures
       
  1346 	    spec=2;
       
  1347 	    _G.graph->first(n, T_CLASS);
       
  1348 	    if (!_G.graph->valid(n)) { //Ha T ures
       
  1349 	      spec=3;
       
  1350 	    }
       
  1351 	  }
       
  1352 	}
       
  1353       }
       
  1354       operator Edge() const { return Edge(e, spec, n); }
       
  1355     };
       
  1356    
       
  1357     NodeIt& first(NodeIt& i) const { 
       
  1358       i=NodeIt(*this); return i;
       
  1359     }
       
  1360     OutEdgeIt& first(OutEdgeIt& i, const Node& p) const { 
       
  1361       i=OutEdgeIt(*this, p); return i;
       
  1362     }
       
  1363     InEdgeIt& first(InEdgeIt& i, const Node& p) const { 
       
  1364       i=InEdgeIt(*this, p); return i;
       
  1365     }
       
  1366     EdgeIt& first(EdgeIt& i) const { 
       
  1367       i=EdgeIt(*this); return i;
       
  1368     }
       
  1369 
       
  1370     NodeIt& next(NodeIt& i) const { 
       
  1371       switch (i.spec) {
       
  1372 	case 0:
       
  1373 	  this->graph->next(i.n);
       
  1374 	  if (!this->graph->valid(i.n)) {
       
  1375 	    i.spec=1;
       
  1376 	  }
       
  1377 	  break;
       
  1378 	case 1:
       
  1379 	  i.spec=2;
       
  1380 	  break;
       
  1381 	case 2:
       
  1382 	  i.spec=3;
       
  1383 	  break;
       
  1384       }
       
  1385       return i; 
       
  1386     }
       
  1387     OutEdgeIt& next(OutEdgeIt& i) const { 
       
  1388       typename Graph::Node v;
       
  1389       switch (i.spec) {
       
  1390 	case 0: //normal edge
       
  1391 	  v=this->graph->aNode(i.e);
       
  1392 	  this->graph->next(i.e);
       
  1393 	  if (!this->graph->valid(i.e)) { //Az igazi elek vegere ertunk
       
  1394 	    if (this->graph->inSClass(v)) { //S, nincs kiel
       
  1395 	      i.spec=3;
       
  1396 	      i.n=INVALID;
       
  1397 	    } else { //T, van kiel
       
  1398 	      i.spec=2; 
       
  1399 	      i.n=v;
       
  1400 	    }
       
  1401 	  }
       
  1402 	  break;
       
  1403 	case 1: //s->vmi
       
  1404 	  this->graph->next(i.n);
       
  1405 	  if (!this->graph->valid(i.n)) i.spec=3;
       
  1406 	  break;
       
  1407 	case 2: //vmi->t
       
  1408 	  i.spec=3;
       
  1409 	  i.n=INVALID;
       
  1410 	  break;
       
  1411       }
       
  1412       return i; 
       
  1413     }
       
  1414     InEdgeIt& next(InEdgeIt& i) const { 
       
  1415       typename Graph::Node v;
       
  1416       switch (i.spec) {
       
  1417 	case 0: //normal edge
       
  1418 	  v=this->graph->aNode(i.e);
       
  1419 	  this->graph->next(i.e);
       
  1420 	  if (!this->graph->valid(i.e)) { //Az igazi elek vegere ertunk
       
  1421 	    if (this->graph->inTClass(v)) { //S, nincs beel
       
  1422 	      i.spec=3;
       
  1423 	      i.n=INVALID;
       
  1424 	    } else { //S, van beel
       
  1425 	      i.spec=1; 
       
  1426 	      i.n=v;
       
  1427 	    }
       
  1428 	  }
       
  1429 	  break;
       
  1430 	case 1: //s->vmi
       
  1431 	  i.spec=3;
       
  1432 	  i.n=INVALID;
       
  1433 	  break;
       
  1434 	case 2: //vmi->t
       
  1435 	  this->graph->next(i.n);
       
  1436 	  if (!this->graph->valid(i.n)) i.spec=3;
       
  1437 	  break;
       
  1438       }
       
  1439       return i; 
       
  1440     }
       
  1441 
       
  1442     EdgeIt& next(EdgeIt& i) const { 
       
  1443       switch (i.spec) {
       
  1444 	case 0:
       
  1445 	  this->graph->next(i.e);
       
  1446 	  if (!this->graph->valid(i.e)) { 
       
  1447 	    i.spec=1;
       
  1448 	    this->graph->first(i.n, S_CLASS);
       
  1449 	    if (!this->graph->valid(i.n)) {
       
  1450 	      i.spec=2;
       
  1451 	      this->graph->first(i.n, T_CLASS);
       
  1452 	      if (!this->graph->valid(i.n)) i.spec=3;
       
  1453 	    }
       
  1454 	  }
       
  1455 	  break;
       
  1456 	case 1:
       
  1457 	  this->graph->next(i.n);
       
  1458 	  if (!this->graph->valid(i.n)) {
       
  1459 	    i.spec=2;
       
  1460 	    this->graph->first(i.n, T_CLASS);
       
  1461 	    if (!this->graph->valid(i.n)) i.spec=3;
       
  1462 	  }
       
  1463 	  break;
       
  1464 	case 2:
       
  1465 	  this->graph->next(i.n);
       
  1466 	  if (!this->graph->valid(i.n)) i.spec=3;
       
  1467 	  break;
       
  1468       }
       
  1469       return i; 
       
  1470     }    
       
  1471 
       
  1472     Node tail(const Edge& e) const { 
       
  1473       switch (e.spec) {
       
  1474       case 0: 
       
  1475 	return Node(this->graph->tail(e));
       
  1476 	break;
       
  1477       case 1:
       
  1478 	return S_NODE;
       
  1479 	break;
       
  1480       case 2:
       
  1481       default:
       
  1482 	return Node(e.n);
       
  1483 	break;
       
  1484       }
       
  1485     }
       
  1486     Node head(const Edge& e) const { 
       
  1487       switch (e.spec) {
       
  1488       case 0: 
       
  1489 	return Node(this->graph->head(e));
       
  1490 	break;
       
  1491       case 1:
       
  1492 	return Node(e.n);
       
  1493 	break;
       
  1494       case 2:
       
  1495       default:
       
  1496 	return T_NODE;
       
  1497 	break;
       
  1498       }
       
  1499     }
       
  1500 
       
  1501     bool valid(const Node& n) const { return (n.spec<3); }
       
  1502     bool valid(const Edge& e) const { return (e.spec<3); }
       
  1503 
       
  1504     int nodeNum() const { return this->graph->nodeNum()+2; }
       
  1505     int edgeNum() const { 
       
  1506       return this->graph->edgeNum()+this->graph->nodeNum(); 
       
  1507     }
       
  1508   
       
  1509     Node aNode(const OutEdgeIt& e) const { return tail(e); }
       
  1510     Node aNode(const InEdgeIt& e) const { return head(e); }
       
  1511     Node bNode(const OutEdgeIt& e) const { return head(e); }
       
  1512     Node bNode(const InEdgeIt& e) const { return tail(e); }
       
  1513 
       
  1514     void addNode() const { }
       
  1515     void addEdge() const { }
       
  1516     
       
  1517 //    Node addNode() const { return Node(this->graph->addNode()); }
       
  1518 //    Edge addEdge(const Node& tail, const Node& head) const { 
       
  1519 //      return Edge(this->graph->addEdge(tail, head)); }
       
  1520 
       
  1521 //    void erase(const Node& i) const { this->graph->erase(i); }
       
  1522 //    void erase(const Edge& i) const { this->graph->erase(i); }
       
  1523   
       
  1524 //    void clear() const { this->graph->clear(); }
       
  1525     
       
  1526     template<typename T> class NodeMap : public GraphWrapper<Graph>::template NodeMap<T> { 
       
  1527       typedef typename GraphWrapper<Graph>::template NodeMap<T> Parent;
       
  1528       T s_value, t_value;
       
  1529     public:
       
  1530       NodeMap(const stGraphWrapper<Graph>& _G) :  Parent(_G), 
       
  1531 						  s_value(), 
       
  1532 						  t_value() { }
       
  1533       NodeMap(const stGraphWrapper<Graph>& _G, T a) : Parent(_G, a), 
       
  1534 						      s_value(a), 
       
  1535 						      t_value(a) { }
       
  1536       T operator[](const Node& n) const { 
       
  1537 	switch (n.spec) {
       
  1538 	case 0: 
       
  1539 	  return Parent::operator[](n);
       
  1540 	  break;
       
  1541 	case 1:
       
  1542 	  return s_value;
       
  1543 	  break;
       
  1544 	case 2: 
       
  1545 	default:
       
  1546 	  return t_value;
       
  1547 	  break;
       
  1548 	}
       
  1549       }
       
  1550       void set(const Node& n, T t) { 
       
  1551 	switch (n.spec) {
       
  1552 	case 0: 
       
  1553 	  GraphWrapper<Graph>::template NodeMap<T>::set(n, t);
       
  1554 	  break;
       
  1555 	case 1:
       
  1556 	  s_value=t;
       
  1557 	  break;
       
  1558 	case 2:
       
  1559 	default:
       
  1560 	  t_value=t;
       
  1561 	  break;
       
  1562 	}
       
  1563       }
       
  1564     };
       
  1565 
       
  1566     template<typename T, 
       
  1567 	     typename Parent=
       
  1568 	     typename GraphWrapper<Graph>::template EdgeMap<T> > 
       
  1569     class EdgeMap : public Parent { 
       
  1570       //typedef typename GraphWrapper<Graph>::template EdgeMap<T> Parent;
       
  1571       typename GraphWrapper<Graph>::template NodeMap<T> node_value;
       
  1572     public:
       
  1573       EdgeMap(const stGraphWrapper<Graph>& _G) : Parent(_G), 
       
  1574 						 node_value(_G) { }
       
  1575       EdgeMap(const stGraphWrapper<Graph>& _G, T a) : Parent(_G, a), 
       
  1576 						      node_value(_G, a) { }
       
  1577       T operator[](const Edge& e) const { 
       
  1578 	switch (e.spec) {
       
  1579 	case 0: 
       
  1580 	  return Parent::operator[](e);
       
  1581 	  break;
       
  1582 	case 1:
       
  1583 	  return node_value[e.n];
       
  1584 	  break;
       
  1585 	case 2:
       
  1586 	default:
       
  1587 	  return node_value[e.n];
       
  1588 	  break;
       
  1589 	}
       
  1590       }
       
  1591       void set(const Edge& e, T t) { 
       
  1592 	switch (e.spec) {
       
  1593 	case 0: 
       
  1594 	  Parent::set(e, t);
       
  1595 	  break;
       
  1596 	case 1:
       
  1597 	  node_value.set(e.n, t);
       
  1598 	  break;
       
  1599 	case 2:
       
  1600 	default:
       
  1601 	  node_value.set(e.n, t);
       
  1602 	  break;
       
  1603 	}
       
  1604       }
       
  1605     };
       
  1606 
       
  1607 //     template<typename T> class EdgeMap : public GraphWrapper<Graph>::template EdgeMap<T> { 
       
  1608 //       typedef typename GraphWrapper<Graph>::template EdgeMap<T> Parent;
       
  1609 //       typename GraphWrapper<Graph>::template NodeMap<T> node_value;
       
  1610 //     public:
       
  1611 //       EdgeMap(const stGraphWrapper<Graph>& _G) : Parent(_G), 
       
  1612 // 						 node_value(_G) { }
       
  1613 //       EdgeMap(const stGraphWrapper<Graph>& _G, T a) : Parent(_G, a), 
       
  1614 // 						      node_value(_G, a) { }
       
  1615 //       T operator[](const Edge& e) const { 
       
  1616 // 	switch (e.spec) {
       
  1617 // 	case 0: 
       
  1618 // 	  return Parent::operator[](e);
       
  1619 // 	  break;
       
  1620 // 	case 1:
       
  1621 // 	  return node_value[e.n];
       
  1622 // 	  break;
       
  1623 // 	case 2:
       
  1624 // 	default:
       
  1625 // 	  return node_value[e.n];
       
  1626 // 	  break;
       
  1627 // 	}
       
  1628 //       }
       
  1629 //       void set(const Edge& e, T t) { 
       
  1630 // 	switch (e.spec) {
       
  1631 // 	case 0: 
       
  1632 // 	  GraphWrapper<Graph>::template EdgeMap<T>::set(e, t);
       
  1633 // 	  break;
       
  1634 // 	case 1:
       
  1635 // 	  node_value.set(e.n, t);
       
  1636 // 	  break;
       
  1637 // 	case 2:
       
  1638 // 	default:
       
  1639 // 	  node_value.set(e.n, t);
       
  1640 // 	  break;
       
  1641 // 	}
       
  1642 //       }
       
  1643 //     };
       
  1644 
       
  1645   };
       
  1646 
       
  1647   ///@}
       
  1648 
       
  1649 } //namespace hugo
       
  1650 
       
  1651 
       
  1652 #endif //HUGO_GRAPH_WRAPPER_H
       
  1653