# HG changeset patch # User marci # Date 1081174742 0 # Node ID 315d826faa8f39177810a7bcd199a5d5b33c2c99 # Parent 8b6ba518fc213a2520aed774fd1fc9c95610c660 graph_wrappers ... diff -r 8b6ba518fc21 -r 315d826faa8f src/include/skeletons/graph.h --- a/src/include/skeletons/graph.h Mon Apr 05 14:01:41 2004 +0000 +++ b/src/include/skeletons/graph.h Mon Apr 05 14:19:02 2004 +0000 @@ -1,6 +1,6 @@ // -*- c++ -*- -#ifndef HUGO_EMPTYGRAPH_H -#define HUGO_EMPTYGRAPH_H +#ifndef HUGO_GRAPH_H +#define HUGO_GRAPH_H ///\file ///\brief Declaration of GraphSkeleton. @@ -390,4 +390,4 @@ // } -#endif // HUGO_EMPTYGRAPH_H +#endif // HUGO_GRAPH_H diff -r 8b6ba518fc21 -r 315d826faa8f src/work/marci/experiment/bfs_iterator_1.h --- a/src/work/marci/experiment/bfs_iterator_1.h Mon Apr 05 14:01:41 2004 +0000 +++ b/src/work/marci/experiment/bfs_iterator_1.h Mon Apr 05 14:19:02 2004 +0000 @@ -630,39 +630,33 @@ // }; - template */ > + template */ > class BfsIterator5 { - typedef typename GraphWrapper::Node Node; - typedef typename GraphWrapper::OutEdgeIt OutEdgeIt; - const GraphWrapper* g; + protected: + typedef typename Graph::Node Node; + typedef typename Graph::OutEdgeIt OutEdgeIt; + const Graph* graph; std::queue bfs_queue; ReachedMap& reached; bool b_node_newly_reached; OutEdgeIt actual_edge; bool own_reached_map; public: - BfsIterator5(const GraphWrapper& _g, ReachedMap& _reached) : - g(&_g), reached(_reached), + BfsIterator5(const Graph& _graph, ReachedMap& _reached) : + graph(&_graph), reached(_reached), own_reached_map(false) { } - BfsIterator5(const GraphWrapper& _g) : - g(&_g), reached(*(new ReachedMap(*g /*, false*/))), + BfsIterator5(const Graph& _graph) : + graph(&_graph), reached(*(new ReachedMap(*graph /*, false*/))), own_reached_map(true) { } -// BfsIterator5(const typename GraphWrapper::BaseGraph& _G, -// ReachedMap& _reached) : -// G(_G), reached(_reached), -// own_reached_map(false) { } -// BfsIterator5(const typename GraphWrapper::BaseGraph& _G) : -// G(_G), reached(*(new ReachedMap(G /*, false*/))), -// own_reached_map(true) { } ~BfsIterator5() { if (own_reached_map) delete &reached; } void pushAndSetReached(Node s) { reached.set(s, true); if (bfs_queue.empty()) { bfs_queue.push(s); - g->first(actual_edge, s); - if (g->valid(actual_edge)) { - Node w=g->bNode(actual_edge); + graph->first(actual_edge, s); + if (graph->valid(actual_edge)) { + Node w=graph->bNode(actual_edge); if (!reached.get(w)) { bfs_queue.push(w); reached.set(w, true); @@ -675,12 +669,12 @@ bfs_queue.push(s); } } - BfsIterator5& + BfsIterator5& operator++() { - if (g->valid(actual_edge)) { - g->next(actual_edge); - if (g->valid(actual_edge)) { - Node w=g->bNode(actual_edge); + if (graph->valid(actual_edge)) { + graph->next(actual_edge); + if (graph->valid(actual_edge)) { + Node w=graph->bNode(actual_edge); if (!reached.get(w)) { bfs_queue.push(w); reached.set(w, true); @@ -692,9 +686,9 @@ } else { bfs_queue.pop(); if (!bfs_queue.empty()) { - g->first(actual_edge, bfs_queue.front()); - if (g->valid(actual_edge)) { - Node w=g->bNode(actual_edge); + graph->first(actual_edge, bfs_queue.front()); + if (graph->valid(actual_edge)) { + Node w=graph->bNode(actual_edge); if (!reached.get(w)) { bfs_queue.push(w); reached.set(w, true); @@ -710,9 +704,9 @@ bool finished() const { return bfs_queue.empty(); } operator OutEdgeIt () const { return actual_edge; } bool isBNodeNewlyReached() const { return b_node_newly_reached; } - bool isANodeExamined() const { return !(g->valid(actual_edge)); } + bool isANodeExamined() const { return !(graph->valid(actual_edge)); } Node aNode() const { return bfs_queue.front(); } - Node bNode() const { return g->bNode(actual_edge); } + Node bNode() const { return graph->bNode(actual_edge); } const ReachedMap& getReachedMap() const { return reached; } const std::queue& getBfsQueue() const { return bfs_queue; } }; @@ -773,12 +767,13 @@ // const std::stack& getDfsStack() const { return dfs_stack; } // }; - template */ > + template */ > class DfsIterator5 { - typedef typename GraphWrapper::Node Node; - typedef typename GraphWrapper::OutEdgeIt OutEdgeIt; - const GraphWrapper* g; + protected: + typedef typename Graph::Node Node; + typedef typename Graph::OutEdgeIt OutEdgeIt; + const Graph* graph; std::stack dfs_stack; bool b_node_newly_reached; OutEdgeIt actual_edge; @@ -786,36 +781,36 @@ ReachedMap& reached; bool own_reached_map; public: - DfsIterator5(const GraphWrapper& _g, ReachedMap& _reached) : - g(&_g), reached(_reached), + DfsIterator5(const Graph& _graph, ReachedMap& _reached) : + graph(&_graph), reached(_reached), own_reached_map(false) { } - DfsIterator5(const GraphWrapper& _g) : - g(&_g), reached(*(new ReachedMap(*g /*, false*/))), + DfsIterator5(const Graph& _graph) : + graph(&_graph), reached(*(new ReachedMap(*graph /*, false*/))), own_reached_map(true) { } ~DfsIterator5() { if (own_reached_map) delete &reached; } void pushAndSetReached(Node s) { actual_node=s; reached.set(s, true); OutEdgeIt e; - g->first(e, s); + graph->first(e, s); dfs_stack.push(e); } - DfsIterator5& + DfsIterator5& operator++() { actual_edge=dfs_stack.top(); //actual_node=G.aNode(actual_edge); - if (g->valid(actual_edge)/*.valid()*/) { - Node w=g->bNode(actual_edge); + if (graph->valid(actual_edge)/*.valid()*/) { + Node w=graph->bNode(actual_edge); actual_node=w; if (!reached.get(w)) { OutEdgeIt e; - g->first(e, w); + graph->first(e, w); dfs_stack.push(e); reached.set(w, true); b_node_newly_reached=true; } else { - actual_node=g->aNode(actual_edge); - g->next(dfs_stack.top()); + actual_node=graph->aNode(actual_edge); + graph->next(dfs_stack.top()); b_node_newly_reached=false; } } else { @@ -827,7 +822,7 @@ bool finished() const { return dfs_stack.empty(); } operator OutEdgeIt () const { return actual_edge; } bool isBNodeNewlyReached() const { return b_node_newly_reached; } - bool isANodeExamined() const { return !(g->valid(actual_edge)); } + bool isANodeExamined() const { return !(graph->valid(actual_edge)); } Node aNode() const { return actual_node; /*FIXME*/} Node bNode() const { return G.bNode(actual_edge); } const ReachedMap& getReachedMap() const { return reached; } diff -r 8b6ba518fc21 -r 315d826faa8f src/work/marci/experiment/edmonds_karp_1.h --- a/src/work/marci/experiment/edmonds_karp_1.h Mon Apr 05 14:01:41 2004 +0000 +++ b/src/work/marci/experiment/edmonds_karp_1.h Mon Apr 05 14:19:02 2004 +0000 @@ -248,28 +248,25 @@ }; - template + template class MaxFlow { protected: - typedef GraphWrapper GW; - typedef typename GW::Node Node; - typedef typename GW::Edge Edge; - typedef typename GW::EdgeIt EdgeIt; - typedef typename GW::OutEdgeIt OutEdgeIt; - typedef typename GW::InEdgeIt InEdgeIt; - //const Graph* G; - //GW gw; - const GW* g; + typedef typename Graph::Node Node; + typedef typename Graph::Edge Edge; + typedef typename Graph::EdgeIt EdgeIt; + typedef typename Graph::OutEdgeIt OutEdgeIt; + typedef typename Graph::InEdgeIt InEdgeIt; + const Graph* g; Node s; Node t; FlowMap* flow; const CapacityMap* capacity; - typedef ResGraphWrapper ResGW; + typedef ResGraphWrapper ResGW; typedef typename ResGW::OutEdgeIt ResGWOutEdgeIt; typedef typename ResGW::Edge ResGWEdge; public: - MaxFlow(const GW& _g, Node _s, Node _t, FlowMap& _flow, const CapacityMap& _capacity) : + MaxFlow(const Graph& _g, Node _s, Node _t, FlowMap& _flow, const CapacityMap& _capacity) : g(&_g), s(_s), t(_t), flow(&_flow), capacity(&_capacity) { } bool augmentOnShortestPath() { @@ -646,95 +643,6 @@ return _augment; } -// bool augmentOnBlockingFlow2() { -// bool _augment=false; - -// //typedef ErasingResGraphWrapper EAugGraph; -// typedef FilterGraphWrapper< ErasingResGraphWrapper > EAugGraph; -// typedef typename EAugGraph::OutEdgeIt EAugOutEdgeIt; -// typedef typename EAugGraph::Edge EAugEdge; - -// EAugGraph res_graph(*G, *flow, *capacity); - -// //typedef typename EAugGraph::NodeMap ReachedMap; -// BfsIterator5< -// ErasingResGraphWrapper, -// /*typename ErasingResGraphWrapper::OutEdgeIt,*/ -// ErasingResGraphWrapper::NodeMap > bfs(res_graph); - -// bfs.pushAndSetReached(s); - -// typename ErasingResGraphWrapper:: -// NodeMap& dist=res_graph.dist; - -// while ( !bfs.finished() ) { -// typename ErasingResGraphWrapper::OutEdgeIt e=bfs; -// if (res_graph.valid(e) && bfs.isBNodeNewlyReached()) { -// dist.set(res_graph.head(e), dist.get(res_graph.tail(e))+1); -// } -// ++bfs; -// } //computing distances from s in the residual graph - -// bool __augment=true; - -// while (__augment) { - -// __augment=false; -// //computing blocking flow with dfs -// typedef typename EAugGraph::NodeMap BlockingReachedMap; -// DfsIterator5< EAugGraph/*, EAugOutEdgeIt*/, BlockingReachedMap > -// dfs(res_graph); -// typename EAugGraph::NodeMap pred(res_graph); -// pred.set(s, EAugEdge(INVALID)); -// //invalid iterators for sources - -// typename EAugGraph::NodeMap free(res_graph); - -// dfs.pushAndSetReached(s); -// while (!dfs.finished()) { -// ++dfs; -// if (res_graph.valid(EAugOutEdgeIt(dfs))) { -// if (dfs.isBNodeNewlyReached()) { - -// typename EAugGraph::Node v=res_graph.aNode(dfs); -// typename EAugGraph::Node w=res_graph.bNode(dfs); - -// pred.set(w, EAugOutEdgeIt(dfs)); -// if (res_graph.valid(pred.get(v))) { -// free.set(w, std::min(free.get(v), res_graph.free(dfs))); -// } else { -// free.set(w, res_graph.free(dfs)); -// } - -// if (w==t) { -// __augment=true; -// _augment=true; -// break; -// } -// } else { -// res_graph.erase(dfs); -// } -// } - -// } - -// if (__augment) { -// typename EAugGraph::Node n=t; -// Number augment_value=free.get(t); -// while (res_graph.valid(pred.get(n))) { -// EAugEdge e=pred.get(n); -// res_graph.augment(e, augment_value); -// n=res_graph.tail(e); -// if (res_graph.free(e)==0) -// res_graph.erase(e); -// } -// } - -// } - -// return _augment; -// } - void run() { //int num_of_augmentations=0; while (augmentOnShortestPath()) { diff -r 8b6ba518fc21 -r 315d826faa8f src/work/marci/experiment/graph_wrapper_1.h --- a/src/work/marci/experiment/graph_wrapper_1.h Mon Apr 05 14:01:41 2004 +0000 +++ b/src/work/marci/experiment/graph_wrapper_1.h Mon Apr 05 14:19:02 2004 +0000 @@ -14,6 +14,11 @@ public: typedef Graph BaseGraph; +// TrivGraphWrapper() : graph(0) { } + TrivGraphWrapper(Graph& _graph) : graph(&_graph) { } +// void setGraph(Graph& _graph) { graph = &_graph; } +// Graph& getGraph() const { return *graph; } + typedef typename Graph::Node Node; class NodeIt : public Graph::NodeIt { public: @@ -24,7 +29,6 @@ Graph::NodeIt(*(_G.graph)) { } }; typedef typename Graph::Edge Edge; - //typedef typename Graph::OutEdgeIt OutEdgeIt; class OutEdgeIt : public Graph::OutEdgeIt { public: OutEdgeIt() { } @@ -33,7 +37,6 @@ OutEdgeIt(const TrivGraphWrapper& _G, const Node& n) : Graph::OutEdgeIt(*(_G.graph), n) { } }; - //typedef typename Graph::InEdgeIt InEdgeIt; class InEdgeIt : public Graph::InEdgeIt { public: InEdgeIt() { } @@ -43,7 +46,6 @@ Graph::InEdgeIt(*(_G.graph), n) { } }; //typedef typename Graph::SymEdgeIt SymEdgeIt; - //typedef typename Graph::EdgeIt EdgeIt; class EdgeIt : public Graph::EdgeIt { public: EdgeIt() { } @@ -53,12 +55,6 @@ Graph::EdgeIt(*(_G.graph)) { } }; - //TrivGraphWrapper() : graph(0) { } - TrivGraphWrapper(Graph& _graph) : graph(&_graph) { } - -// void setGraph(Graph& _graph) { graph = &_graph; } -// Graph& getGraph() const { return (*graph); } - NodeIt& first(NodeIt& i) const { i=NodeIt(*this); return i; @@ -68,7 +64,6 @@ return i; } // template I& first(I& i) const { -// //return graph->first(i); // i=I(*this); // return i; // } @@ -81,7 +76,6 @@ return i; } // template I& first(I& i, const P& p) const { -// //return graph->first(i, p); // i=I(*this, p); // return i; // } @@ -91,16 +85,16 @@ template I& next(I &i) const { graph->next(i); return i; } template< typename It > It first() const { - It e; first(e); return e; } + It e; this->first(e); return e; } template< typename It > It first(const Node& v) const { - It e; first(e, v); return e; } + It e; this->first(e, v); return e; } Node head(const Edge& e) const { return graph->head(e); } Node tail(const Edge& e) const { return graph->tail(e); } - template bool valid(const I& i) const - { return graph->valid(i); } + template bool valid(const I& i) const { + return graph->valid(i); } //template void setInvalid(const I &i); //{ return graph->setInvalid(i); } @@ -142,9 +136,7 @@ Map* map; public: NodeMapWrapper(Map& _map) : map(&_map) { } - //template void set(Node n, T a) { map->set(n, a); } - //template T get(Node n) const { return map->get(n); } }; @@ -153,91 +145,89 @@ Map* map; public: EdgeMapWrapper(Map& _map) : map(&_map) { } - //template void set(Edge n, T a) { map->set(n, a); } - //template T get(Edge n) const { return map->get(n); } }; }; - template - class GraphWrapperSkeleton { + + template + class GraphWrapper { protected: - GraphWrapper gw; + Graph* graph; public: - //typedef typename GraphWrapper::BaseGraph BaseGraph; + typedef Graph BaseGraph; -// typedef typename GraphWrapper::Node Node; -// typedef typename GraphWrapper::NodeIt NodeIt; - -// typedef typename GraphWrapper::Edge Edge; -// typedef typename GraphWrapper::OutEdgeIt OutEdgeIt; -// typedef typename GraphWrapper::InEdgeIt InEdgeIt; -// //typedef typename GraphWrapper::SymEdgeIt SymEdgeIt; -// typedef typename GraphWrapper::EdgeIt EdgeIt; - - typedef typename GraphWrapper::Node Node; - class NodeIt : public GraphWrapper::NodeIt { +// GraphWrapper() : graph(0) { } + GraphWrapper(Graph& _graph) : graph(&_graph) { } +// void setGraph(Graph& _graph) { graph=&_graph; } +// Graph& getGraph() const { return *graph; } + + typedef typename Graph::Node Node; + class NodeIt : public Graph::NodeIt { public: NodeIt() { } - NodeIt(const typename GraphWrapper::NodeIt& n) : - GraphWrapper::NodeIt(n) { } - NodeIt(const Invalid& i) : GraphWrapper::NodeIt(i) { } - NodeIt(const GraphWrapperSkeleton& _G) : - GraphWrapper::NodeIt(_G.gw) { } + NodeIt(const typename Graph::NodeIt& n) : Graph::NodeIt(n) { } + NodeIt(const Invalid& i) : Graph::NodeIt(i) { } + NodeIt(const GraphWrapper& _G) : + Graph::NodeIt(*(_G.graph)) { } }; - typedef typename GraphWrapper::Edge Edge; - //typedef typename GraphWrapper::OutEdgeIt OutEdgeIt; - class OutEdgeIt : public GraphWrapper::OutEdgeIt { + typedef typename Graph::Edge Edge; + class OutEdgeIt : public Graph::OutEdgeIt { public: OutEdgeIt() { } - OutEdgeIt(const typename GraphWrapper::OutEdgeIt& e) : - GraphWrapper::OutEdgeIt(e) { } - OutEdgeIt(const Invalid& i) : GraphWrapper::OutEdgeIt(i) { } - OutEdgeIt(const GraphWrapperSkeleton& _G, const Node& n) : - GraphWrapper::OutEdgeIt(_G.gw, n) { } + OutEdgeIt(const typename Graph::OutEdgeIt& e) : Graph::OutEdgeIt(e) { } + OutEdgeIt(const Invalid& i) : Graph::OutEdgeIt(i) { } + OutEdgeIt(const GraphWrapper& _G, const Node& n) : + Graph::OutEdgeIt(*(_G.graph), n) { } }; - //typedef typename GraphWrapper::InEdgeIt InEdgeIt; - class InEdgeIt : public GraphWrapper::InEdgeIt { + class InEdgeIt : public Graph::InEdgeIt { public: InEdgeIt() { } - InEdgeIt(const typename GraphWrapper::InEdgeIt& e) : - GraphWrapper::InEdgeIt(e) { } - InEdgeIt(const Invalid& i) : GraphWrapper::InEdgeIt(i) { } - InEdgeIt(const GraphWrapperSkeleton& _G, const Node& n) : - GraphWrapper::InEdgeIt(_G.gw, n) { } + InEdgeIt(const typename Graph::InEdgeIt& e) : Graph::InEdgeIt(e) { } + InEdgeIt(const Invalid& i) : Graph::InEdgeIt(i) { } + InEdgeIt(const GraphWrapper& _G, const Node& n) : + Graph::InEdgeIt(*(_G.graph), n) { } }; - //typedef typename GraphWrapper::SymEdgeIt SymEdgeIt; - //typedef typename GraphWrapper::EdgeIt EdgeIt; - class EdgeIt : public GraphWrapper::EdgeIt { + //typedef typename Graph::SymEdgeIt SymEdgeIt; + class EdgeIt : public Graph::EdgeIt { public: EdgeIt() { } - EdgeIt(const typename GraphWrapper::EdgeIt& e) : - GraphWrapper::EdgeIt(e) { } - EdgeIt(const Invalid& i) : GraphWrapper::EdgeIt(i) { } - EdgeIt(const GraphWrapperSkeleton& _G) : - GraphWrapper::EdgeIt(_G.gw) { } + EdgeIt(const typename Graph::EdgeIt& e) : Graph::EdgeIt(e) { } + EdgeIt(const Invalid& i) : Graph::EdgeIt(i) { } + EdgeIt(const GraphWrapper& _G) : + Graph::EdgeIt(*(_G.graph)) { } }; - - - //GraphWrapperSkeleton() : gw() { } - GraphWrapperSkeleton(GraphWrapper _gw) : gw(_gw) { } - - //void setGraph(BaseGraph& _graph) { gw.setGraph(_graph); } - //BaseGraph& getGraph() const { return gw.getGraph(); } - - template I& first(I& i) const { - i=I(*this); + + NodeIt& first(NodeIt& i) const { + i=NodeIt(*this); return i; } - template I& first(I& i, const P& p) const { - i=I(*this, p); - return i; + EdgeIt& first(EdgeIt& i) const { + i=EdgeIt(*this); + return i; } +// template I& first(I& i) const { +// i=I(*this); +// return i; +// } + OutEdgeIt& first(OutEdgeIt& i, const Node& p) const { + i=OutEdgeIt(*this, p); + return i; + } + InEdgeIt& first(InEdgeIt& i, const Node& p) const { + i=InEdgeIt(*this, p); + return i; + } +// template I& first(I& i, const P& p) const { +// i=I(*this, p); +// return i; +// } -// template I getNext(const I& i) const { return gw.getNext(i); } - template I& next(I &i) const { gw.next(i); return i; } +// template I getNext(const I& i) const { +// return gw.getNext(i); } + template I& next(I &i) const { graph->next(i); return i; } template< typename It > It first() const { It e; this->first(e); return e; } @@ -245,166 +235,45 @@ template< typename It > It first(const Node& v) const { It e; this->first(e, v); return e; } - Node head(const Edge& e) const { return gw.head(e); } - Node tail(const Edge& e) const { return gw.tail(e); } + Node head(const Edge& e) const { return graph->head(e); } + Node tail(const Edge& e) const { return graph->tail(e); } - template bool valid(const I& i) const { return gw.valid(i); } + template bool valid(const I& i) const { + return graph->valid(i); } //template void setInvalid(const I &i); //{ return graph->setInvalid(i); } - int nodeNum() const { return gw.nodeNum(); } - int edgeNum() const { return gw.edgeNum(); } + int nodeNum() const { return graph->nodeNum(); } + int edgeNum() const { return graph->edgeNum(); } - template Node aNode(const I& e) const { return gw.aNode(e); } - template Node bNode(const I& e) const { return gw.bNode(e); } + template Node aNode(const I& e) const { + return graph->aNode(e); } + template Node bNode(const I& e) const { + return graph->bNode(e); } - Node addNode() const { return gw.addNode(); } + Node addNode() const { return graph->addNode(); } Edge addEdge(const Node& tail, const Node& head) const { - return gw.addEdge(tail, head); } + return graph->addEdge(tail, head); } - template void erase(const I& i) const { gw.erase(i); } + template void erase(const I& i) const { graph->erase(i); } - void clear() const { gw.clear(); } + void clear() const { graph->clear(); } - template class NodeMap : public GraphWrapper::NodeMap { + template class NodeMap : public Graph::NodeMap { public: - NodeMap(const GraphWrapperSkeleton& _G) : - GraphWrapper::NodeMap(_G.gw) { } - NodeMap(const GraphWrapperSkeleton& _G, T a) : - GraphWrapper::NodeMap(_G.gw, a) { } + NodeMap(const GraphWrapper& _G) : + Graph::NodeMap(*(_G.graph)) { } + NodeMap(const GraphWrapper& _G, T a) : + Graph::NodeMap(*(_G.graph), a) { } }; - template class EdgeMap : public GraphWrapper::EdgeMap { + template class EdgeMap : public Graph::EdgeMap { public: - EdgeMap(const GraphWrapperSkeleton& _G) : - GraphWrapper::EdgeMap(_G.gw) { } - EdgeMap(const GraphWrapperSkeleton& _G, T a) : - GraphWrapper::EdgeMap(_G.gw, a) { } - }; - }; - - template - class GraphWrapperSkeleton1 { - protected: - GraphWrapper* g; - - public: - //typedef typename GraphWrapper::BaseGraph BaseGraph; - -// typedef typename GraphWrapper::Node Node; -// typedef typename GraphWrapper::NodeIt NodeIt; - -// typedef typename GraphWrapper::Edge Edge; -// typedef typename GraphWrapper::OutEdgeIt OutEdgeIt; -// typedef typename GraphWrapper::InEdgeIt InEdgeIt; -// //typedef typename GraphWrapper::SymEdgeIt SymEdgeIt; -// typedef typename GraphWrapper::EdgeIt EdgeIt; - - typedef typename GraphWrapper::Node Node; - class NodeIt : public GraphWrapper::NodeIt { - public: - NodeIt() { } - NodeIt(const typename GraphWrapper::NodeIt& n) : - GraphWrapper::NodeIt(n) { } - NodeIt(const Invalid& i) : GraphWrapper::NodeIt(i) { } - NodeIt(const GraphWrapperSkeleton1& _G) : - GraphWrapper::NodeIt(*(_G.g)) { } - }; - typedef typename GraphWrapper::Edge Edge; - //typedef typename GraphWrapper::OutEdgeIt OutEdgeIt; - class OutEdgeIt : public GraphWrapper::OutEdgeIt { - public: - OutEdgeIt() { } - OutEdgeIt(const typename GraphWrapper::OutEdgeIt& e) : - GraphWrapper::OutEdgeIt(e) { } - OutEdgeIt(const Invalid& i) : GraphWrapper::OutEdgeIt(i) { } - OutEdgeIt(const GraphWrapperSkeleton1& _G, const Node& n) : - GraphWrapper::OutEdgeIt(*(_G.g), n) { } - }; - //typedef typename GraphWrapper::InEdgeIt InEdgeIt; - class InEdgeIt : public GraphWrapper::InEdgeIt { - public: - InEdgeIt() { } - InEdgeIt(const typename GraphWrapper::InEdgeIt& e) : - GraphWrapper::InEdgeIt(e) { } - InEdgeIt(const Invalid& i) : GraphWrapper::InEdgeIt(i) { } - InEdgeIt(const GraphWrapperSkeleton1& _G, const Node& n) : - GraphWrapper::InEdgeIt(*(_G.g), n) { } - }; - //typedef typename GraphWrapper::SymEdgeIt SymEdgeIt; - //typedef typename GraphWrapper::EdgeIt EdgeIt; - class EdgeIt : public GraphWrapper::EdgeIt { - public: - EdgeIt() { } - EdgeIt(const typename GraphWrapper::EdgeIt& e) : - GraphWrapper::EdgeIt(e) { } - EdgeIt(const Invalid& i) : GraphWrapper::EdgeIt(i) { } - EdgeIt(const GraphWrapperSkeleton1& _G) : - GraphWrapper::EdgeIt(*(_G.g)) { } - }; - - - //GraphWrapperSkeleton() : gw() { } - GraphWrapperSkeleton1(GraphWrapper& _gw) : g(&_gw) { } - - //void setGraph(BaseGraph& _graph) { gw.setGraph(_graph); } - //BaseGraph& getGraph() const { return gw.getGraph(); } - - template I& first(I& i) const { - i=I(*this); - return i; - } - template I& first(I& i, const P& p) const { - i=I(*this, p); - return i; - } - -// template I getNext(const I& i) const { return gw.getNext(i); } - template I& next(I &i) const { g->next(i); return i; } - - template< typename It > It first() const { - It e; this->first(e); return e; } - - template< typename It > It first(const Node& v) const { - It e; this->first(e, v); return e; } - - Node head(const Edge& e) const { return g->head(e); } - Node tail(const Edge& e) const { return g->tail(e); } - - template bool valid(const I& i) const { return g->valid(i); } - - //template void setInvalid(const I &i); - //{ return graph->setInvalid(i); } - - int nodeNum() const { return g->nodeNum(); } - int edgeNum() const { return g->edgeNum(); } - - template Node aNode(const I& e) const { return g->aNode(e); } - template Node bNode(const I& e) const { return g->bNode(e); } - - Node addNode() const { return g->addNode(); } - Edge addEdge(const Node& tail, const Node& head) const { - return g->addEdge(tail, head); } - - template void erase(const I& i) const { g->erase(i); } - - void clear() const { g->clear(); } - - template class NodeMap : public GraphWrapper::NodeMap { - public: - NodeMap(const GraphWrapperSkeleton1& _G) : - GraphWrapper::NodeMap(*(_G.g)) { } - NodeMap(const GraphWrapperSkeleton1& _G, T a) : - GraphWrapper::NodeMap(*(_G.g), a) { } - }; - - template class EdgeMap : public GraphWrapper::EdgeMap { - public: - EdgeMap(const GraphWrapperSkeleton1& _G) : - GraphWrapper::EdgeMap(*(_G.g)) { } - EdgeMap(const GraphWrapperSkeleton1& _G, T a) : - GraphWrapper::EdgeMap(*(_G.g), a) { } + EdgeMap(const GraphWrapper& _G) : + Graph::EdgeMap(*(_G.graph)) { } + EdgeMap(const GraphWrapper& _G, T a) : + Graph::EdgeMap(*(_G.graph), a) { } }; }; @@ -489,139 +358,57 @@ // }; // }; -// template*/ > -// class RevGraphWrapper : -// public GraphWrapper/*GraphWrapperSkeleton< TrivGraphWrapper >*/ { -// protected: -// //Graph* graph; - -// public: -// //typedef Graph BaseGraph; -// //typedef typename Graph::Node Node; -// //typedef typename Graph::NodeIt NodeIt; - -// //typedef typename Graph::Edge Edge; -// typedef typename GraphWrapper/*typename GraphWrapperSkeleton< TrivGraphWrapper >*/::OutEdgeIt InEdgeIt; -// typedef typename GraphWrapper/*typename GraphWrapperSkeleton< TrivGraphWrapper >*/::InEdgeIt OutEdgeIt; -// //typedef typename Graph::SymEdgeIt SymEdgeIt; -// //typedef typename Graph::EdgeIt EdgeIt; - -// //RevGraphWrapper() : graph(0) { } -// RevGraphWrapper(GraphWrapper _gw/*BaseGraph& _graph*/) : GraphWrapper/*GraphWrapperSkeleton< TrivGraphWrapper >*/(_gw/*TrivGraphWrapper(_graph)*/) { } - -// //void setGraph(Graph& _graph) { graph = &_graph; } -// //Graph& getGraph() const { return (*graph); } - -// //template I& first(I& i) const { return graph->first(i); } -// //template I& first(I& i, const P& p) const { -// // return graph->first(i, p); } - -// //template I getNext(const I& i) const { -// // return graph->getNext(i); } -// //template I& next(I &i) const { return graph->next(i); } - -// //template< typename It > It first() const { -// // It e; first(e); return e; } - -// //template< typename It > It first(const Node& v) const { -// // It e; first(e, v); return e; } - -// //Node head(const Edge& e) const { return graph->tail(e); } -// //Node tail(const Edge& e) const { return graph->head(e); } - -// //template bool valid(const I& i) const -// // { return graph->valid(i); } - -// //template void setInvalid(const I &i); -// //{ return graph->setInvalid(i); } - -// //template Node aNode(const I& e) const { -// // return graph->aNode(e); } -// //template Node bNode(const I& e) const { -// // return graph->bNode(e); } - -// //Node addNode() const { return graph->addNode(); } -// //Edge addEdge(const Node& tail, const Node& head) const { -// // return graph->addEdge(tail, head); } - -// //int nodeNum() const { return graph->nodeNum(); } -// //int edgeNum() const { return graph->edgeNum(); } - -// //template void erase(const I& i) const { graph->erase(i); } - -// //void clear() const { graph->clear(); } - -// template class NodeMap : -// public GraphWrapper/*Skeleton< TrivGraphWrapper >*/::NodeMap -// { -// public: -// NodeMap(const RevGraphWrapper& _gw) : -// GraphWrapper/*Skeleton< TrivGraphWrapper >*/::NodeMap(_gw) { } -// NodeMap(const RevGraphWrapper& _gw, T a) : -// GraphWrapper/*Skeleton< TrivGraphWrapper >*/::NodeMap(_gw, a) { } -// }; - -// template class EdgeMap : -// public GraphWrapper/*Skeleton< TrivGraphWrapper >*/::EdgeMap { -// public: -// EdgeMap(const RevGraphWrapper& _gw) : -// GraphWrapper/*Skeleton< TrivGraphWrapper >*/::EdgeMap(_gw) { } -// EdgeMap(const RevGraphWrapper& _gw, T a) : -// GraphWrapper/*Skeleton< TrivGraphWrapper >*/::EdgeMap(_gw, a) { } -// }; -// }; - - template - class RevGraphWrapper : public GraphWrapperSkeleton1 { + template + class RevGraphWrapper : public GraphWrapper { public: - typedef typename GraphWrapperSkeleton1::Node Node; - typedef typename GraphWrapperSkeleton1::Edge Edge; + typedef typename GraphWrapper::Node Node; + typedef typename GraphWrapper::Edge Edge; //FIXME - //If GraphWrapper::OutEdgeIt is not defined + //If Graph::OutEdgeIt is not defined //and we do not want to use RevGraphWrapper::InEdgeIt, //this won't work, because of typedef //OR //graphs have to define their non-existing iterators to void //Unfortunately all the typedefs are instantiated in templates, //unlike other stuff - typedef typename GraphWrapperSkeleton1::OutEdgeIt InEdgeIt; - typedef typename GraphWrapperSkeleton1::InEdgeIt OutEdgeIt; + typedef typename GraphWrapper::OutEdgeIt InEdgeIt; + typedef typename GraphWrapper::InEdgeIt OutEdgeIt; - RevGraphWrapper(GraphWrapper& _gw) : - GraphWrapperSkeleton1(_gw) { } +// RevGraphWrapper() : GraphWrapper() { } + RevGraphWrapper(Graph& _graph) : GraphWrapper(_graph) { } Node head(const Edge& e) const - { return GraphWrapperSkeleton1::tail(e); } + { return GraphWrapper::tail(e); } Node tail(const Edge& e) const - { return GraphWrapperSkeleton1::head(e); } + { return GraphWrapper::head(e); } }; //Subgraph on the same node-set and partial edge-set - template - class SubGraphWrapper : public GraphWrapperSkeleton1 { + template + class SubGraphWrapper : public GraphWrapper { protected: EdgeFilterMap* filter_map; public: - typedef typename GraphWrapperSkeleton1::Node Node; - typedef typename GraphWrapperSkeleton1::NodeIt NodeIt; - typedef typename GraphWrapperSkeleton1::Edge Edge; - typedef typename GraphWrapperSkeleton1::EdgeIt EdgeIt; - typedef typename GraphWrapperSkeleton1::InEdgeIt InEdgeIt; - typedef typename GraphWrapperSkeleton1::OutEdgeIt OutEdgeIt; + typedef typename GraphWrapper::Node Node; + typedef typename GraphWrapper::NodeIt NodeIt; + typedef typename GraphWrapper::Edge Edge; + typedef typename GraphWrapper::EdgeIt EdgeIt; + typedef typename GraphWrapper::InEdgeIt InEdgeIt; + typedef typename GraphWrapper::OutEdgeIt OutEdgeIt; - SubGraphWrapper(GraphWrapper& _gw, EdgeFilterMap& _filter_map) : - GraphWrapperSkeleton1(_gw), filter_map(&_filter_map) { } +// SubGraphWrapper() : GraphWrapper(), filter_map(0) { } + SubGraphWrapper(Graph& _graph, EdgeFilterMap& _filter_map) : + GraphWrapper(_graph), filter_map(&_filter_map) { } template I& first(I& i) const { - g->first(i); - while (g->valid(i) && !filter_map->get(i)) { g->next(i); } + graph->first(i); + while (graph->valid(i) && !filter_map->get(i)) { graph->next(i); } return i; } template I& first(I& i, const P& p) const { - g->first(i, p); - while (g->valid(i) && !filter_map->get(i)) { g->next(i); } + graph->first(i, p); + while (graph->valid(i) && !filter_map->get(i)) { graph->next(i); } return i; } @@ -629,8 +416,8 @@ // return gw.getNext(i); //} template I& next(I &i) const { - g->next(i); - while (g->valid(i) && !filter_map->get(i)) { g->next(i); } + graph->next(i); + while (graph->valid(i) && !filter_map->get(i)) { graph->next(i); } return i; } @@ -801,39 +588,21 @@ // }; - template - class UndirGraphWrapper : public GraphWrapperSkeleton1 { + template + class UndirGraphWrapper : public GraphWrapper { protected: -// GraphWrapper gw; + typedef typename Graph::Edge GraphEdge; + typedef typename Graph::OutEdgeIt GraphOutEdgeIt; + typedef typename Graph::InEdgeIt GraphInEdgeIt; + public: + typedef typename GraphWrapper::Node Node; + typedef typename GraphWrapper::NodeIt NodeIt; - public: - //typedef GraphWrapper BaseGraph; +// UndirGraphWrapper() : GraphWrapper() { } + UndirGraphWrapper(Graph& _graph) : GraphWrapper(_graph) { } - typedef typename GraphWrapperSkeleton1::Node Node; - typedef typename GraphWrapperSkeleton1::NodeIt NodeIt; - - //private: - //FIXME ezeknek valojaban a GraphWrapper megfelelo dolgai kellene hogy - //legyenek, at kell irni - typedef typename /*GraphWrapperSkeleton*/ - GraphWrapper::Edge GraphEdge; - typedef typename /*GraphWrapperSkeleton*/ - GraphWrapper::OutEdgeIt GraphOutEdgeIt; - typedef typename /*GraphWrapperSkeleton*/ - GraphWrapper::InEdgeIt GraphInEdgeIt; - //public: - - //UndirGraphWrapper() : graph(0) { } - UndirGraphWrapper(GraphWrapper& _gw) : - GraphWrapperSkeleton1(_gw) { } - - //UndirGraphWrapper(GraphWrapper _gw) : gw(_gw) { } - - //void setGraph(Graph& _graph) { graph = &_graph; } - //Graph& getGraph() const { return (*graph); } - class Edge { - friend class UndirGraphWrapper; + friend class UndirGraphWrapper; protected: bool out_or_in; //true iff out GraphOutEdgeIt out; @@ -866,42 +635,42 @@ }; class OutEdgeIt : public Edge { - friend class UndirGraphWrapper; + friend class UndirGraphWrapper; public: OutEdgeIt() : Edge() { } OutEdgeIt(const Invalid& i) : Edge(i) { } - OutEdgeIt(const UndirGraphWrapper& _G, const Node& n) + OutEdgeIt(const UndirGraphWrapper& _G, const Node& n) : Edge() { - out_or_in=true; _G.g->first(out, n); - if (!(_G.g->valid(out))) { out_or_in=false; _G.g->first(in, n); } + out_or_in=true; _G.graph->first(out, n); + if (!(_G.graph->valid(out))) { out_or_in=false; _G.graph->first(in, n); } } }; typedef OutEdgeIt InEdgeIt; class EdgeIt : public Edge { - friend class UndirGraphWrapper; + friend class UndirGraphWrapper; protected: NodeIt v; public: EdgeIt() : Edge() { } EdgeIt(const Invalid& i) : Edge(i) { } - EdgeIt(const UndirGraphWrapper& _G) + EdgeIt(const UndirGraphWrapper& _G) : Edge() { out_or_in=true; //Node v; _G.first(v); - if (_G.valid(v)) _G.g->first(out); else out=INVALID; - while (_G.valid(v) && !_G.g->valid(out)) { - _G.g->next(v); - if (_G.valid(v)) _G.g->first(out); + if (_G.valid(v)) _G.graph->first(out); else out=INVALID; + while (_G.valid(v) && !_G.graph->valid(out)) { + _G.graph->next(v); + if (_G.valid(v)) _G.graph->first(out); } } }; OutEdgeIt& first(OutEdgeIt& e, const Node& n) const { - e.out_or_in=true; g->first(e.out, n); - if (!(g->valid(e.out))) { e.out_or_in=false; g->first(e.in, n); } + e.out_or_in=true; graph->first(e.out, n); + if (!(graph->valid(e.out))) { e.out_or_in=false; graph->first(e.in, n); } return e; } @@ -909,47 +678,47 @@ e.out_or_in=true; //NodeIt v; first(e.v); - if (valid(e.v)) g->first(e.out, e.v); else e.out=INVALID; - while (valid(e.v) && !g->valid(e.out)) { - g->next(e.v); - if (valid(e.v)) g->first(e.out, e.v); + if (valid(e.v)) graph->first(e.out, e.v); else e.out=INVALID; + while (valid(e.v) && !graph->valid(e.out)) { + graph->next(e.v); + if (valid(e.v)) graph->first(e.out, e.v); } return e; } - template I& first(I& i) const { g->first(i); return i; } + template I& first(I& i) const { graph->first(i); return i; } template I& first(I& i, const P& p) const { - g->first(i, p); return i; } + graph->first(i, p); return i; } OutEdgeIt& next(OutEdgeIt& e) const { if (e.out_or_in) { - Node n=g->tail(e.out); - g->next(e.out); - if (!g->valid(e.out)) { e.out_or_in=false; g->first(e.in, n); } + Node n=graph->tail(e.out); + graph->next(e.out); + if (!graph->valid(e.out)) { e.out_or_in=false; graph->first(e.in, n); } } else { - g->next(e.in); + graph->next(e.in); } return e; } EdgeIt& next(EdgeIt& e) const { //NodeIt v=tail(e); - g->next(e.out); - while (valid(e.v) && !g->valid(e.out)) { + graph->next(e.out); + while (valid(e.v) && !graph->valid(e.out)) { next(e.v); - if (valid(e.v)) g->first(e.out, e.v); + if (valid(e.v)) graph->first(e.out, e.v); } return e; } - template I& next(I &i) const { return g->next(i); } + template I& next(I &i) const { return graph->next(i); } // template I getNext(const I& i) const { return gw.getNext(i); } template< typename It > It first() const { - It e; first(e); return e; } + It e; this->first(e); return e; } template< typename It > It first(const Node& v) const { - It e; first(e, v); return e; } + It e; this->first(e, v); return e; } // Node head(const Edge& e) const { return gw.head(e); } // Node tail(const Edge& e) const { return gw.tail(e); } @@ -966,9 +735,9 @@ // return graph->bNode(e); } Node aNode(const OutEdgeIt& e) const { - if (e.out_or_in) return g->tail(e); else return g->head(e); } + if (e.out_or_in) return graph->tail(e); else return graph->head(e); } Node bNode(const OutEdgeIt& e) const { - if (e.out_or_in) return g->head(e); else return g->tail(e); } + if (e.out_or_in) return graph->head(e); else return graph->tail(e); } // Node addNode() const { return gw.addNode(); } @@ -980,21 +749,21 @@ // void clear() const { gw.clear(); } -// template class NodeMap : public GraphWrapper::NodeMap { +// template class NodeMap : public Graph::NodeMap { // public: -// NodeMap(const UndirGraphWrapper& _G) : -// GraphWrapper::NodeMap(_G.gw) { } -// NodeMap(const UndirGraphWrapper& _G, T a) : -// GraphWrapper::NodeMap(_G.gw, a) { } +// NodeMap(const UndirGraphWrapper& _G) : +// Graph::NodeMap(_G.gw) { } +// NodeMap(const UndirGraphWrapper& _G, T a) : +// Graph::NodeMap(_G.gw, a) { } // }; // template class EdgeMap : -// public GraphWrapperSkeleton::EdgeMap { +// public GraphWrapperSkeleton::EdgeMap { // public: -// EdgeMap(const UndirGraphWrapper& _G) : -// GraphWrapperSkeleton::EdgeMap(_G.gw) { } -// EdgeMap(const UndirGraphWrapper& _G, T a) : -// GraphWrapper::EdgeMap(_G.gw, a) { } +// EdgeMap(const UndirGraphWrapper& _G) : +// GraphWrapperSkeleton::EdgeMap(_G.gw) { } +// EdgeMap(const UndirGraphWrapper& _G, T a) : +// Graph::EdgeMap(_G.gw, a) { } // }; }; @@ -1071,32 +840,21 @@ // }; - template - class ResGraphWrapper : public GraphWrapperSkeleton1{ + template + class ResGraphWrapper : public GraphWrapper{ public: - //typedef Graph BaseGraph; - //typedef TrivGraphWrapper GraphWrapper; - typedef typename GraphWrapperSkeleton1::Node Node; - typedef typename GraphWrapperSkeleton1::NodeIt NodeIt; - private: - typedef typename /*GraphWrapperSkeleton*/ - GraphWrapper::OutEdgeIt OldOutEdgeIt; - typedef typename /*GraphWrapperSkeleton*/ - GraphWrapper::InEdgeIt OldInEdgeIt; + typedef typename GraphWrapper::Node Node; + typedef typename GraphWrapper::NodeIt NodeIt; protected: - //const Graph* graph; - //GraphWrapper gw; + typedef typename Graph::OutEdgeIt OldOutEdgeIt; + typedef typename Graph::InEdgeIt OldInEdgeIt; FlowMap* flow; const CapacityMap* capacity; public: - ResGraphWrapper(GraphWrapper& _gw, FlowMap& _flow, + ResGraphWrapper(Graph& _graph, FlowMap& _flow, const CapacityMap& _capacity) : - GraphWrapperSkeleton1(_gw), - flow(&_flow), capacity(&_capacity) { } - - //void setGraph(const Graph& _graph) { graph = &_graph; } - //const Graph& getGraph() const { return (*graph); } + GraphWrapper(_graph), flow(&_flow), capacity(&_capacity) { } class Edge; class OutEdgeIt; @@ -1104,7 +862,7 @@ friend class OutEdgeIt; class Edge { - friend class ResGraphWrapper; + friend class ResGraphWrapper; protected: bool out_or_in; //true, iff out OldOutEdgeIt out; @@ -1130,20 +888,20 @@ class OutEdgeIt : public Edge { - friend class ResGraphWrapper; + friend class ResGraphWrapper; public: OutEdgeIt() { } //FIXME OutEdgeIt(const Edge& e) : Edge(e) { } OutEdgeIt(const Invalid& i) : Edge(i) { } protected: - OutEdgeIt(const ResGraphWrapper& resG, Node v) : Edge() { - resG.g->first(out, v); - while( resG.g->valid(out) && !(resG.resCap(out)>0) ) { resG.g->next(out); } - if (!resG.g->valid(out)) { + OutEdgeIt(const ResGraphWrapper& resG, Node v) : Edge() { + resG.graph->first(out, v); + while( resG.graph->valid(out) && !(resG.resCap(out)>0) ) { resG.graph->next(out); } + if (!resG.graph->valid(out)) { out_or_in=0; - resG.g->first(in, v); - while( resG.g->valid(in) && !(resG.resCap(in)>0) ) { resG.g->next(in); } + resG.graph->first(in, v); + while( resG.graph->valid(in) && !(resG.resCap(in)>0) ) { resG.graph->next(in); } } } // public: @@ -1169,30 +927,30 @@ typedef void InEdgeIt; class EdgeIt : public Edge { - friend class ResGraphWrapper; + friend class ResGraphWrapper; NodeIt v; public: EdgeIt() { } //EdgeIt(const EdgeIt& e) : Edge(e), v(e.v) { } EdgeIt(const Invalid& i) : Edge(i) { } - EdgeIt(const ResGraphWrapper& resG) : Edge() { - resG.g->first(v); - if (resG.g->valid(v)) resG.g->first(out, v); else out=INVALID; - while (resG.g->valid(out) && !(resG.resCap(out)>0) ) { resG.g->next(out); } - while (resG.g->valid(v) && !resG.g->valid(out)) { - resG.g->next(v); - if (resG.g->valid(v)) resG.g->first(out, v); - while (resG.g->valid(out) && !(resG.resCap(out)>0) ) { resG.g->next(out); } + EdgeIt(const ResGraphWrapper& resG) : Edge() { + resG.graph->first(v); + if (resG.graph->valid(v)) resG.graph->first(out, v); else out=INVALID; + while (resG.graph->valid(out) && !(resG.resCap(out)>0) ) { resG.graph->next(out); } + while (resG.graph->valid(v) && !resG.graph->valid(out)) { + resG.graph->next(v); + if (resG.graph->valid(v)) resG.graph->first(out, v); + while (resG.graph->valid(out) && !(resG.resCap(out)>0) ) { resG.graph->next(out); } } - if (!resG.g->valid(out)) { + if (!resG.graph->valid(out)) { out_or_in=0; - resG.g->first(v); - if (resG.g->valid(v)) resG.g->first(in, v); else in=INVALID; - while (resG.g->valid(in) && !(resG.resCap(in)>0) ) { resG.g->next(in); } - while (resG.g->valid(v) && !resG.g->valid(in)) { - resG.g->next(v); - if (resG.g->valid(v)) resG.g->first(in, v); - while (resG.g->valid(in) && !(resG.resCap(in)>0) ) { resG.g->next(in); } + resG.graph->first(v); + if (resG.graph->valid(v)) resG.graph->first(in, v); else in=INVALID; + while (resG.graph->valid(in) && !(resG.resCap(in)>0) ) { resG.graph->next(in); } + while (resG.graph->valid(v) && !resG.graph->valid(in)) { + resG.graph->next(v); + if (resG.graph->valid(v)) resG.graph->first(in, v); + while (resG.graph->valid(in) && !(resG.resCap(in)>0) ) { resG.graph->next(in); } } } } @@ -1229,7 +987,7 @@ // } }; - NodeIt& first(NodeIt& v) const { g->first(v); return v; } + NodeIt& first(NodeIt& v) const { graph->first(v); return v; } OutEdgeIt& first(OutEdgeIt& e, Node v) const { e=OutEdgeIt(*this, v); return e; @@ -1239,52 +997,52 @@ return e; } - NodeIt& next(NodeIt& n) const { return g->next(n); } + NodeIt& next(NodeIt& n) const { return graph->next(n); } OutEdgeIt& next(OutEdgeIt& e) const { if (e.out_or_in) { - Node v=g->aNode(e.out); - g->next(e.out); - while( g->valid(e.out) && !(resCap(e.out)>0) ) { g->next(e.out); } - if (!g->valid(e.out)) { + Node v=graph->aNode(e.out); + graph->next(e.out); + while( graph->valid(e.out) && !(resCap(e.out)>0) ) { graph->next(e.out); } + if (!graph->valid(e.out)) { e.out_or_in=0; - g->first(e.in, v); - while( g->valid(e.in) && !(resCap(e.in)>0) ) { g->next(e.in); } + graph->first(e.in, v); + while( graph->valid(e.in) && !(resCap(e.in)>0) ) { graph->next(e.in); } } } else { - g->next(e.in); - while( g->valid(e.in) && !(resCap(e.in)>0) ) { g->next(e.in); } + graph->next(e.in); + while( graph->valid(e.in) && !(resCap(e.in)>0) ) { graph->next(e.in); } } return e; } EdgeIt& next(EdgeIt& e) const { if (e.out_or_in) { - g->next(e.out); - while (g->valid(e.out) && !(resCap(e.out)>0) ) { g->next(e.out); } - while (g->valid(e.v) && !g->valid(e.out)) { - g->next(e.v); - if (g->valid(e.v)) g->first(e.out, e.v); - while (g->valid(e.out) && !(resCap(e.out)>0) ) { g->next(e.out); } + graph->next(e.out); + while (graph->valid(e.out) && !(resCap(e.out)>0) ) { graph->next(e.out); } + while (graph->valid(e.v) && !graph->valid(e.out)) { + graph->next(e.v); + if (graph->valid(e.v)) graph->first(e.out, e.v); + while (graph->valid(e.out) && !(resCap(e.out)>0) ) { graph->next(e.out); } } - if (!g->valid(e.out)) { + if (!graph->valid(e.out)) { e.out_or_in=0; - g->first(e.v); - if (g->valid(e.v)) g->first(e.in, e.v); else e.in=INVALID; - while (g->valid(e.in) && !(resCap(e.in)>0) ) { g->next(e.in); } - while (g->valid(e.v) && !g->valid(e.in)) { - g->next(e.v); - if (g->valid(e.v)) g->first(e.in, e.v); - while (g->valid(e.in) && !(resCap(e.in)>0) ) { g->next(e.in); } + graph->first(e.v); + if (graph->valid(e.v)) graph->first(e.in, e.v); else e.in=INVALID; + while (graph->valid(e.in) && !(resCap(e.in)>0) ) { graph->next(e.in); } + while (graph->valid(e.v) && !graph->valid(e.in)) { + graph->next(e.v); + if (graph->valid(e.v)) graph->first(e.in, e.v); + while (graph->valid(e.in) && !(resCap(e.in)>0) ) { graph->next(e.in); } } } } else { - g->next(e.in); - while (g->valid(e.in) && !(resCap(e.in)>0) ) { g->next(e.in); } - while (g->valid(e.v) && !g->valid(e.in)) { - g->next(e.v); - if (g->valid(e.v)) g->first(e.in, e.v); - while (g->valid(e.in) && !(resCap(e.in)>0) ) { g->next(e.in); } + graph->next(e.in); + while (graph->valid(e.in) && !(resCap(e.in)>0) ) { graph->next(e.in); } + while (graph->valid(e.v) && !graph->valid(e.in)) { + graph->next(e.v); + if (graph->valid(e.v)) graph->first(e.in, e.v); + while (graph->valid(e.in) && !(resCap(e.in)>0) ) { graph->next(e.in); } } } return e; @@ -1306,25 +1064,25 @@ } Node tail(Edge e) const { - return ((e.out_or_in) ? g->aNode(e.out) : g->aNode(e.in)); } + return ((e.out_or_in) ? graph->aNode(e.out) : graph->aNode(e.in)); } Node head(Edge e) const { - return ((e.out_or_in) ? g->bNode(e.out) : g->bNode(e.in)); } + return ((e.out_or_in) ? graph->bNode(e.out) : graph->bNode(e.in)); } Node aNode(OutEdgeIt e) const { - return ((e.out_or_in) ? g->aNode(e.out) : g->aNode(e.in)); } + return ((e.out_or_in) ? graph->aNode(e.out) : graph->aNode(e.in)); } Node bNode(OutEdgeIt e) const { - return ((e.out_or_in) ? g->bNode(e.out) : g->bNode(e.in)); } + return ((e.out_or_in) ? graph->bNode(e.out) : graph->bNode(e.in)); } - int nodeNum() const { return g->nodeNum(); } + int nodeNum() const { return graph->nodeNum(); } //FIXME - //int edgeNum() const { return g->edgeNum(); } + //int edgeNum() const { return graph->edgeNum(); } - int id(Node v) const { return g->id(v); } + int id(Node v) const { return graph->id(v); } - bool valid(Node n) const { return g->valid(n); } + bool valid(Node n) const { return graph->valid(n); } bool valid(Edge e) const { - return e.out_or_in ? g->valid(e.out) : g->valid(e.in); } + return e.out_or_in ? graph->valid(e.out) : graph->valid(e.in); } void augment(const Edge& e, Number a) const { if (e.out_or_in) @@ -1348,12 +1106,12 @@ return (flow->get(in)); } -// template class NodeMap : public GraphWrapper::NodeMap { +// template class NodeMap : public Graph::NodeMap { // public: -// NodeMap(const ResGraphWrapper& _G) -// : GraphWrapper::NodeMap(_G.gw) { } -// NodeMap(const ResGraphWrapper& _G, -// T a) : GraphWrapper::NodeMap(_G.gw, a) { } +// NodeMap(const ResGraphWrapper& _G) +// : Graph::NodeMap(_G.gw) { } +// NodeMap(const ResGraphWrapper& _G, +// T a) : Graph::NodeMap(_G.gw, a) { } // }; // template @@ -1368,10 +1126,10 @@ template class EdgeMap { - typename GraphWrapper::EdgeMap forward_map, backward_map; + typename Graph::EdgeMap forward_map, backward_map; public: - EdgeMap(const ResGraphWrapper& _G) : forward_map(_G.gw), backward_map(_G.gw) { } - EdgeMap(const ResGraphWrapper& _G, T a) : forward_map(_G.gw, a), backward_map(_G.gw, a) { } + EdgeMap(const ResGraphWrapper& _G) : forward_map(*(_G.graph)), backward_map(*(_G.graph)) { } + EdgeMap(const ResGraphWrapper& _G, T a) : forward_map(*(_G.graph), a), backward_map(*(_G.graph), a) { } void set(Edge e, T a) { if (e.out_or_in) forward_map.set(e.out, a); @@ -1387,25 +1145,25 @@ }; }; - //Subgraph on the same node-set and partial edge-set - template - class ErasingFirstGraphWrapper : public GraphWrapperSkeleton1 { + //ErasingFirstGraphWrapper for blocking flows + template + class ErasingFirstGraphWrapper : public GraphWrapper { protected: FirstOutEdgesMap* first_out_edges; public: - typedef typename GraphWrapperSkeleton1::Node Node; - typedef typename GraphWrapperSkeleton1::NodeIt NodeIt; - typedef typename GraphWrapperSkeleton1::Edge Edge; - typedef typename GraphWrapperSkeleton1::EdgeIt EdgeIt; - typedef typename GraphWrapperSkeleton1::InEdgeIt InEdgeIt; - typedef typename GraphWrapperSkeleton1::OutEdgeIt OutEdgeIt; + typedef typename GraphWrapper::Node Node; + typedef typename GraphWrapper::NodeIt NodeIt; + typedef typename GraphWrapper::Edge Edge; + typedef typename GraphWrapper::EdgeIt EdgeIt; + typedef typename GraphWrapper::InEdgeIt InEdgeIt; + typedef typename GraphWrapper::OutEdgeIt OutEdgeIt; - ErasingFirstGraphWrapper(GraphWrapper& _gw, FirstOutEdgesMap& _first_out_edges) : - GraphWrapperSkeleton1(_gw), first_out_edges(&_first_out_edges) { } + ErasingFirstGraphWrapper(Graph& _graph, + FirstOutEdgesMap& _first_out_edges) : + GraphWrapper(_graph), first_out_edges(&_first_out_edges) { } template I& first(I& i) const { - g->first(i); - //while (gw.valid(i) && !filter_map->get(i)) { gw.next(i); } + graph->first(i); return i; } OutEdgeIt& first(OutEdgeIt& e, const Node& n) const { @@ -1413,8 +1171,7 @@ return e; } template I& first(I& i, const P& p) const { - g->first(i, p); - //while (gw.valid(i) && !filter_map->get(i)) { gw.next(i); } + graph->first(i, p); return i; } @@ -1422,8 +1179,7 @@ // return gw.getNext(i); //} template I& next(I &i) const { - g->next(i); - //while (gw.valid(i) && !filter_map->get(i)) { gw.next(i); } + graph->next(i); return i; } @@ -1440,246 +1196,6 @@ } }; -// template -// class ErasingResGraphWrapper : public ResGraphWrapper { -// protected: -// ResGraphWrapper::NodeMap::OutEdgeIt> first_out_edges; -// //ResGraphWrapper::NodeMap dist; -// public: -// ErasingResGraphWrapper(const Graph& _G, FlowMap& _flow, -// const CapacityMap& _capacity) : -// ResGraphWrapper(_G, _flow, _capacity), -// first_out_edges(*this) /*, dist(*this)*/ { -// for(NodeIt n=this->template first(); this->valid(n); this->next(n)) { -// OutEdgeIt e; -// ResGraphWrapper::first(e, n); -// first_out_edges.set(n, e); -// } -// } - -// //void setGraph(Graph& _graph) { graph = &_graph; } -// //Graph& getGraph() const { return (*graph); } - -// //TrivGraphWrapper() : graph(0) { } -// //ErasingResGraphWrapper(Graph& _graph) : graph(&_graph) { } - -// //typedef Graph BaseGraph; - -// //typedef typename Graph::Node Node; -// //typedef typename Graph::NodeIt NodeIt; - -// //typedef typename Graph::Edge Edge; -// //typedef typename Graph::OutEdgeIt OutEdgeIt; -// //typedef typename Graph::InEdgeIt InEdgeIt; -// //typedef typename Graph::SymEdgeIt SymEdgeIt; -// //typedef typename Graph::EdgeIt EdgeIt; - -// typedef typename ResGraphWrapper::Node Node; -// typedef typename ResGraphWrapper::NodeIt NodeIt; - -// typedef typename ResGraphWrapper::Edge Edge; -// typedef typename ResGraphWrapper::OutEdgeIt OutEdgeIt; -// //typedef typename ResGraphWrapper::InEdgeIt InEdgeIt; -// //typedef typename Graph::SymEdgeIt SymEdgeIt; -// //typedef typename ResGraphWrapper::EdgeIt EdgeIt; - -// NodeIt& first(NodeIt& n) const { -// return ResGraphWrapper::first(n); -// } - -// OutEdgeIt& first(OutEdgeIt& e, const Node& n) const { -// e=first_out_edges.get(n); -// return e; -// } - -// //ROSSZ template I& first(I& i) const { return first(i); } -// //ROSSZ template I& first(I& i, const P& p) const { -// // return first(i, p); } - -// //template I getNext(const I& i) const { -// // return gw.getNext(i); } -// //template I& next(I &i) const { return gw.next(i); } - -// template< typename It > It first() const { -// It e; first(e); return e; } - -// template< typename It > It first(const Node& v) const { -// It e; first(e, v); return e; } - -// //Node head(const Edge& e) const { return gw.head(e); } -// //Node tail(const Edge& e) const { return gw.tail(e); } - -// //template bool valid(const I& i) const -// // { return gw.valid(i); } - -// //int nodeNum() const { return gw.nodeNum(); } -// //int edgeNum() const { return gw.edgeNum(); } - -// //template Node aNode(const I& e) const { -// // return gw.aNode(e); } -// //template Node bNode(const I& e) const { -// // return gw.bNode(e); } - -// //Node addNode() const { return gw.addNode(); } -// //Edge addEdge(const Node& tail, const Node& head) const { -// // return gw.addEdge(tail, head); } - -// //void erase(const OutEdgeIt& e) { -// // first_out_edge(this->tail(e))=e; -// //} -// void erase(const Edge& e) { -// OutEdgeIt f(e); -// next(f); -// first_out_edges.set(this->tail(e), f); -// } -// //template void erase(const I& i) const { gw.erase(i); } - -// //void clear() const { gw.clear(); } - -// template class NodeMap : public ResGraphWrapper::NodeMap { -// public: -// NodeMap(const ErasingResGraphWrapper& _G) : -// ResGraphWrapper::NodeMap(_G /*_G.getGraph()*/) { } -// NodeMap(const ErasingResGraphWrapper& _G, T a) : -// ResGraphWrapper::NodeMap(_G /*_G.getGraph()*/, a) { } -// }; - -// template class EdgeMap : public ResGraphWrapper::EdgeMap { -// public: -// EdgeMap(const ErasingResGraphWrapper& _G) : -// ResGraphWrapper::EdgeMap(_G /*_G.getGraph()*/) { } -// EdgeMap(const ErasingResGraphWrapper& _G, T a) : -// ResGraphWrapper::EdgeMap(_G /*_G.getGraph()*/, a) { } -// }; -// }; - -// template -// class FilterGraphWrapper { -// }; - -// template -// class FilterGraphWrapper > : public ErasingResGraphWrapper { - -// //Graph* graph; - -// public: -// //typedef Graph BaseGraph; - -// typedef typename ErasingResGraphWrapper::Node Node; -// typedef typename ErasingResGraphWrapper::NodeIt NodeIt; - -// typedef typename ErasingResGraphWrapper::Edge Edge; -// typedef typename ErasingResGraphWrapper::OutEdgeIt OutEdgeIt; -// //typedef typename ErasingResGraphWrapper::InEdgeIt InEdgeIt; -// //typedef typename Graph::SymEdgeIt SymEdgeIt; -// typedef typename ErasingResGraphWrapper::EdgeIt EdgeIt; - -// //FilterGraphWrapper::NodeMap::OutEdgeIt> first_out_edges; - -// public: -// FilterGraphWrapper(const Graph& _G, FlowMap& _flow, -// const CapacityMap& _capacity) : -// ErasingResGraphWrapper(_G, _flow, _capacity), dist(*this, gw.nodeNum()) { -// } - -// OutEdgeIt& first(OutEdgeIt& e, const Node& n) const { -// ErasingResGraphWrapper::first(e, n); -// while (valid(e) && (dist.get(tail(e))/*+1!=*/>=dist.get(head(e)))) -// ErasingResGraphWrapper::next(e); -// return e; -// } - -// NodeIt& next(NodeIt& e) const { -// return ErasingResGraphWrapper::next(e); -// } - -// OutEdgeIt& next(OutEdgeIt& e) const { -// ErasingResGraphWrapper::next(e); -// while (valid(e) && (dist.get(tail(e))/*+1!*/>=dist.get(head(e)))) -// ErasingResGraphWrapper::next(e); -// return e; -// } - -// NodeIt& first(NodeIt& n) const { -// return ErasingResGraphWrapper::first(n); -// } - -// void erase(const Edge& e) { -// OutEdgeIt f(e); -// ErasingResGraphWrapper::next(f); -// while (valid(f) && (dist.get(tail(f))/*+1!=*/>=dist.get(head(f)))) -// ErasingResGraphWrapper::next(f); -// first_out_edges.set(this->tail(e), f); -// } - -// //TrivGraphWrapper() : graph(0) { } -// //TrivGraphWrapper(Graph& _graph) : graph(&_graph) { } - -// //void setGraph(Graph& _graph) { graph = &_graph; } -// //Graph& getGraph() const { return (*graph); } - -// //template I& first(I& i) const { return gw.first(i); } -// //template I& first(I& i, const P& p) const { -// // return gw.first(i, p); } - -// //template I getNext(const I& i) const { -// // return gw.getNext(i); } -// //template I& next(I &i) const { return gw.next(i); } - -// template< typename It > It first() const { -// It e; first(e); return e; } - -// template< typename It > It first(const Node& v) const { -// It e; first(e, v); return e; } - -// //Node head(const Edge& e) const { return gw.head(e); } -// //Node tail(const Edge& e) const { return gw.tail(e); } - -// //template bool valid(const I& i) const -// // { return gw.valid(i); } - -// //template void setInvalid(const I &i); -// //{ return gw.setInvalid(i); } - -// //int nodeNum() const { return gw.nodeNum(); } -// //int edgeNum() const { return gw.edgeNum(); } - -// //template Node aNode(const I& e) const { -// // return gw.aNode(e); } -// //template Node bNode(const I& e) const { -// // return gw.bNode(e); } - -// //Node addNode() const { return gw.addNode(); } -// //Edge addEdge(const Node& tail, const Node& head) const { -// // return gw.addEdge(tail, head); } - -// //template void erase(const I& i) const { gw.erase(i); } - -// //void clear() const { gw.clear(); } - -// template class NodeMap : public ErasingResGraphWrapper::NodeMap { -// public: -// NodeMap(const FilterGraphWrapper >& _G) : -// ErasingResGraphWrapper::NodeMap(_G /*_G.getGraph()*/) { } -// NodeMap(const FilterGraphWrapper >& _G, T a) : -// ErasingResGraphWrapper::NodeMap(_G /*_G.getGraph()*/, a) { } -// }; - -// template class EdgeMap : public ErasingResGraphWrapper::EdgeMap { -// public: -// EdgeMap(const FilterGraphWrapper >& _G) : -// ErasingResGraphWrapper::EdgeMap(_G /*_G.getGraph()*/) { } -// EdgeMap(const FilterGraphWrapper >& _G, T a) : -// ErasingResGraphWrapper::EdgeMap(_G /*_G.getGraph()*/, a) { } -// }; - -// public: -// ErasingResGraphWrapper::NodeMap dist; - -// }; - - - // // FIXME: comparison should be made better!!! // template // class ResGraphWrapper