COIN-OR::LEMON - Graph Library

source: lemon-0.x/src/work/marci/oldies/edmonds_karp.h @ 829:ef91373d37a8

Last change on this file since 829:ef91373d37a8 was 474:229a16b5fd0f, checked in by marci, 21 years ago

edmonds_karp

File size: 29.0 KB
Line 
1// -*- c++ -*-
2#ifndef HUGO_EDMONDS_KARP_H
3#define HUGO_EDMONDS_KARP_H
4
5#include <algorithm>
6#include <list>
7#include <iterator>
8
9#include <bfs_iterator.h>
10#include <invalid.h>
11#include <graph_wrapper.h>
12#include <maps.h>
13#include <for_each_macros.h>
14
15namespace hugo {
16
17  template <typename Graph, typename Num,
18            typename CapMap, typename FlowMap>
19  class MaxFlow {
20  protected:
21    typedef typename Graph::Node Node;
22    typedef typename Graph::Edge Edge;
23    typedef typename Graph::EdgeIt EdgeIt;
24    typedef typename Graph::OutEdgeIt OutEdgeIt;
25    typedef typename Graph::InEdgeIt InEdgeIt;
26    const Graph* g;
27    Node s;
28    Node t;
29    const CapMap* capacity;
30    FlowMap* flow;
31    typedef ResGraphWrapper<const Graph, Num, CapMap, FlowMap> ResGW;
32    typedef typename ResGW::OutEdgeIt ResGWOutEdgeIt;
33    typedef typename ResGW::Edge ResGWEdge;
34    //typedef typename ResGW::template NodeMap<bool> ReachedMap;
35    typedef typename Graph::template NodeMap<bool> ReachedMap;
36    ReachedMap level;
37    //reached is called level because of compatibility with preflow
38  public:
39
40    MaxFlow(const Graph& _g, Node _s, Node _t, const CapMap& _capacity,
41            FlowMap& _flow) :
42      g(&_g), s(_s), t(_t), capacity(&_capacity), flow(&_flow), level(_g) { }
43
44    bool augmentOnShortestPath() {
45      ResGW res_graph(*g, *capacity, *flow);
46      bool _augment=false;
47     
48      //ReachedMap level(res_graph);
49      FOR_EACH_LOC(typename Graph::NodeIt, e, *g) level.set(e, 0);
50      BfsIterator<ResGW, ReachedMap> bfs(res_graph, level);
51      bfs.pushAndSetReached(s);
52       
53      typename ResGW::template NodeMap<ResGWEdge> pred(res_graph);
54      pred.set(s, INVALID);
55     
56      typename ResGW::template NodeMap<Num> free(res_graph);
57       
58      //searching for augmenting path
59      while ( !bfs.finished() ) {
60        ResGWOutEdgeIt e=bfs;
61        if (res_graph.valid(e) && bfs.isBNodeNewlyReached()) {
62          Node v=res_graph.tail(e);
63          Node w=res_graph.head(e);
64          pred.set(w, e);
65          if (res_graph.valid(pred[v])) {
66            free.set(w, std::min(free[v], res_graph.resCap(e)));
67          } else {
68            free.set(w, res_graph.resCap(e));
69          }
70          if (res_graph.head(e)==t) { _augment=true; break; }
71        }
72       
73        ++bfs;
74      } //end of searching augmenting path
75
76      if (_augment) {
77        Node n=t;
78        Num augment_value=free[t];
79        while (res_graph.valid(pred[n])) {
80          ResGWEdge e=pred[n];
81          res_graph.augment(e, augment_value);
82          n=res_graph.tail(e);
83        }
84      }
85
86      return _augment;
87    }
88
89    template<typename MapGraphWrapper>
90    class DistanceMap {
91    protected:
92      const MapGraphWrapper* g;
93      typename MapGraphWrapper::template NodeMap<int> dist;
94    public:
95      DistanceMap(MapGraphWrapper& _g) : g(&_g), dist(*g, g->nodeNum()) { }
96      void set(const typename MapGraphWrapper::Node& n, int a) {
97        dist.set(n, a);
98      }
99      int operator[](const typename MapGraphWrapper::Node& n)
100        { return dist[n]; }
101//       int get(const typename MapGraphWrapper::Node& n) const {
102//      return dist[n]; }
103//       bool get(const typename MapGraphWrapper::Edge& e) const {
104//      return (dist.get(g->tail(e))<dist.get(g->head(e))); }
105      bool operator[](const typename MapGraphWrapper::Edge& e) const {
106        return (dist[g->tail(e)]<dist[g->head(e)]);
107      }
108    };
109
110    template<typename MutableGraph> bool augmentOnBlockingFlow() {     
111      typedef MutableGraph MG;
112      bool _augment=false;
113
114      ResGW res_graph(*g, *capacity, *flow);
115
116      //ReachedMap level(res_graph);
117      FOR_EACH_LOC(typename Graph::NodeIt, e, *g) level.set(e, 0);
118      BfsIterator<ResGW, ReachedMap> bfs(res_graph, level);
119
120      bfs.pushAndSetReached(s);
121      //typename ResGW::NodeMap<int> dist(res_graph); //filled up with 0's
122      DistanceMap<ResGW> dist(res_graph);
123      while ( !bfs.finished() ) {
124        ResGWOutEdgeIt e=bfs;
125        if (res_graph.valid(e) && bfs.isBNodeNewlyReached()) {
126          dist.set(res_graph.head(e), dist[res_graph.tail(e)]+1);
127        }
128        ++bfs;
129      } //computing distances from s in the residual graph
130
131      MG F;
132      ConstMap<typename ResGW::Node, bool> true_map(true);
133      typedef SubGraphWrapper<ResGW, ConstMap<typename ResGW::Node, bool>,
134        DistanceMap<ResGW> > FilterResGW;
135      FilterResGW filter_res_graph(res_graph, true_map, dist);
136      typename ResGW::template NodeMap<typename MG::Node>
137        res_graph_to_F(res_graph);
138      {
139        typename ResGW::NodeIt n;
140        for(res_graph.first(n); res_graph.valid(n); res_graph.next(n)) {
141          res_graph_to_F.set(n, F.addNode());
142        }
143      }
144
145      typename MG::Node sF=res_graph_to_F[s];
146      typename MG::Node tF=res_graph_to_F[t];
147      typename MG::template EdgeMap<ResGWEdge> original_edge(F);
148      typename MG::template EdgeMap<Num> residual_capacity(F);
149
150      //Making F to the graph containing the edges of the residual graph
151      //which are in some shortest paths
152      {
153        typename FilterResGW::EdgeIt e;
154        for(filter_res_graph.first(e); filter_res_graph.valid(e); filter_res_graph.next(e)) {
155          //if (dist.get(res_graph.head(e))==dist.get(res_graph.tail(e))+1) {
156          typename MG::Edge f=F.addEdge(res_graph_to_F[res_graph.tail(e)], res_graph_to_F[res_graph.head(e)]);
157          original_edge.update();
158          original_edge.set(f, e);
159          residual_capacity.update();
160          residual_capacity.set(f, res_graph.resCap(e));
161          //}
162        }
163      }
164
165      bool __augment=true;
166
167      while (__augment) {
168        __augment=false;
169        //computing blocking flow with dfs
170
171        DfsIterator< MG, typename MG::template NodeMap<bool> > dfs(F);
172        typename MG::template NodeMap<typename MG::Edge> pred(F);
173        pred.set(sF, INVALID);
174        //invalid iterators for sources
175
176        typename MG::template NodeMap<Num> free(F);
177
178        dfs.pushAndSetReached(sF);     
179        while (!dfs.finished()) {
180          ++dfs;
181          if (F.valid(/*typename MG::OutEdgeIt*/(dfs))) {
182            if (dfs.isBNodeNewlyReached()) {
183              typename MG::Node v=F.aNode(dfs);
184              typename MG::Node w=F.bNode(dfs);
185              pred.set(w, dfs);
186              if (F.valid(pred[v])) {
187                free.set(w, std::min(free[v], residual_capacity[dfs]));
188              } else {
189                free.set(w, residual_capacity[dfs]);
190              }
191              if (w==tF) {
192                __augment=true;
193                _augment=true;
194                break;
195              }
196             
197            } else {
198              F.erase(/*typename MG::OutEdgeIt*/(dfs));
199            }
200          }
201        }
202
203        if (__augment) {
204          typename MG::Node n=tF;
205          Num augment_value=free[tF];
206          while (F.valid(pred[n])) {
207            typename MG::Edge e=pred[n];
208            res_graph.augment(original_edge[e], augment_value);
209            n=F.tail(e);
210            if (residual_capacity[e]==augment_value)
211              F.erase(e);
212            else
213              residual_capacity.set(e, residual_capacity[e]-augment_value);
214          }
215        }
216       
217      }
218           
219      return _augment;
220    }
221
222    template<typename MutableGraph> bool augmentOnBlockingFlow1() {     
223      typedef MutableGraph MG;
224      bool _augment=false;
225
226      ResGW res_graph(*g, *capacity, *flow);
227
228      //bfs for distances on the residual graph
229      //ReachedMap level(res_graph);
230      FOR_EACH_LOC(typename Graph::NodeIt, e, *g) level.set(e, 0);
231      BfsIterator<ResGW, ReachedMap> bfs(res_graph, level);
232      bfs.pushAndSetReached(s);
233      typename ResGW::template NodeMap<int>
234        dist(res_graph); //filled up with 0's
235
236      //F will contain the physical copy of the residual graph
237      //with the set of edges which are on shortest paths
238      MG F;
239      typename ResGW::template NodeMap<typename MG::Node>
240        res_graph_to_F(res_graph);
241      {
242        typename ResGW::NodeIt n;
243        for(res_graph.first(n); res_graph.valid(n); res_graph.next(n)) {
244          res_graph_to_F.set(n, F.addNode());
245        }
246      }
247
248      typename MG::Node sF=res_graph_to_F[s];
249      typename MG::Node tF=res_graph_to_F[t];
250      typename MG::template EdgeMap<ResGWEdge> original_edge(F);
251      typename MG::template EdgeMap<Num> residual_capacity(F);
252
253      while ( !bfs.finished() ) {
254        ResGWOutEdgeIt e=bfs;
255        if (res_graph.valid(e)) {
256          if (bfs.isBNodeNewlyReached()) {
257            dist.set(res_graph.head(e), dist[res_graph.tail(e)]+1);
258            typename MG::Edge f=F.addEdge(res_graph_to_F[res_graph.tail(e)], res_graph_to_F[res_graph.head(e)]);
259            original_edge.update();
260            original_edge.set(f, e);
261            residual_capacity.update();
262            residual_capacity.set(f, res_graph.resCap(e));
263          } else {
264            if (dist[res_graph.head(e)]==(dist[res_graph.tail(e)]+1)) {
265              typename MG::Edge f=F.addEdge(res_graph_to_F[res_graph.tail(e)], res_graph_to_F[res_graph.head(e)]);
266              original_edge.update();
267              original_edge.set(f, e);
268              residual_capacity.update();
269              residual_capacity.set(f, res_graph.resCap(e));
270            }
271          }
272        }
273        ++bfs;
274      } //computing distances from s in the residual graph
275
276      bool __augment=true;
277
278      while (__augment) {
279        __augment=false;
280        //computing blocking flow with dfs
281        DfsIterator< MG, typename MG::template NodeMap<bool> > dfs(F);
282        typename MG::template NodeMap<typename MG::Edge> pred(F);
283        pred.set(sF, INVALID);
284        //invalid iterators for sources
285
286        typename MG::template NodeMap<Num> free(F);
287
288        dfs.pushAndSetReached(sF);     
289        while (!dfs.finished()) {
290          ++dfs;
291          if (F.valid(/*typename MG::OutEdgeIt*/(dfs))) {
292            if (dfs.isBNodeNewlyReached()) {
293              typename MG::Node v=F.aNode(dfs);
294              typename MG::Node w=F.bNode(dfs);
295              pred.set(w, dfs);
296              if (F.valid(pred[v])) {
297                free.set(w, std::min(free[v], residual_capacity[dfs]));
298              } else {
299                free.set(w, residual_capacity[dfs]);
300              }
301              if (w==tF) {
302                __augment=true;
303                _augment=true;
304                break;
305              }
306             
307            } else {
308              F.erase(/*typename MG::OutEdgeIt*/(dfs));
309            }
310          }
311        }
312
313        if (__augment) {
314          typename MG::Node n=tF;
315          Num augment_value=free[tF];
316          while (F.valid(pred[n])) {
317            typename MG::Edge e=pred[n];
318            res_graph.augment(original_edge[e], augment_value);
319            n=F.tail(e);
320            if (residual_capacity[e]==augment_value)
321              F.erase(e);
322            else
323              residual_capacity.set(e, residual_capacity[e]-augment_value);
324          }
325        }
326       
327      }
328           
329      return _augment;
330    }
331
332    bool augmentOnBlockingFlow2() {
333      bool _augment=false;
334
335      ResGW res_graph(*g, *capacity, *flow);
336     
337      //ReachedMap level(res_graph);
338      FOR_EACH_LOC(typename Graph::NodeIt, e, *g) level.set(e, 0);
339      BfsIterator<ResGW, ReachedMap> bfs(res_graph, level);
340
341      bfs.pushAndSetReached(s);
342      DistanceMap<ResGW> dist(res_graph);
343      while ( !bfs.finished() ) {
344        ResGWOutEdgeIt e=bfs;
345        if (res_graph.valid(e) && bfs.isBNodeNewlyReached()) {
346          dist.set(res_graph.head(e), dist[res_graph.tail(e)]+1);
347        }
348        ++bfs;
349      } //computing distances from s in the residual graph
350
351      //Subgraph containing the edges on some shortest paths
352      ConstMap<typename ResGW::Node, bool> true_map(true);
353      typedef SubGraphWrapper<ResGW, ConstMap<typename ResGW::Node, bool>,
354        DistanceMap<ResGW> > FilterResGW;
355      FilterResGW filter_res_graph(res_graph, true_map, dist);
356
357      //Subgraph, which is able to delete edges which are already
358      //met by the dfs
359      typename FilterResGW::template NodeMap<typename FilterResGW::OutEdgeIt>
360        first_out_edges(filter_res_graph);
361      typename FilterResGW::NodeIt v;
362      for(filter_res_graph.first(v); filter_res_graph.valid(v);
363          filter_res_graph.next(v))
364      {
365        typename FilterResGW::OutEdgeIt e;
366        filter_res_graph.first(e, v);
367        first_out_edges.set(v, e);
368      }
369      typedef ErasingFirstGraphWrapper<FilterResGW, typename FilterResGW::
370        template NodeMap<typename FilterResGW::OutEdgeIt> > ErasingResGW;
371      ErasingResGW erasing_res_graph(filter_res_graph, first_out_edges);
372
373      bool __augment=true;
374
375      while (__augment) {
376
377        __augment=false;
378        //computing blocking flow with dfs
379        DfsIterator< ErasingResGW,
380          typename ErasingResGW::template NodeMap<bool> >
381          dfs(erasing_res_graph);
382        typename ErasingResGW::
383          template NodeMap<typename ErasingResGW::OutEdgeIt>
384          pred(erasing_res_graph);
385        pred.set(s, INVALID);
386        //invalid iterators for sources
387
388        typename ErasingResGW::template NodeMap<Num>
389          free1(erasing_res_graph);
390
391        dfs.pushAndSetReached(
392          typename ErasingResGW::Node(
393            typename FilterResGW::Node(
394              typename ResGW::Node(s)
395              )
396            )
397          );
398        while (!dfs.finished()) {
399          ++dfs;
400          if (erasing_res_graph.valid(
401                typename ErasingResGW::OutEdgeIt(dfs)))
402          {
403            if (dfs.isBNodeNewlyReached()) {
404         
405              typename ErasingResGW::Node v=erasing_res_graph.aNode(dfs);
406              typename ErasingResGW::Node w=erasing_res_graph.bNode(dfs);
407
408              pred.set(w, /*typename ErasingResGW::OutEdgeIt*/(dfs));
409              if (erasing_res_graph.valid(pred[v])) {
410                free1.set(w, std::min(free1[v], res_graph.resCap(
411                                       typename ErasingResGW::OutEdgeIt(dfs))));
412              } else {
413                free1.set(w, res_graph.resCap(
414                           typename ErasingResGW::OutEdgeIt(dfs)));
415              }
416             
417              if (w==t) {
418                __augment=true;
419                _augment=true;
420                break;
421              }
422            } else {
423              erasing_res_graph.erase(dfs);
424            }
425          }
426        }       
427
428        if (__augment) {
429          typename ErasingResGW::Node n=typename FilterResGW::Node(typename ResGW::Node(t));
430//        typename ResGW::NodeMap<Num> a(res_graph);
431//        typename ResGW::Node b;
432//        Num j=a[b];
433//        typename FilterResGW::NodeMap<Num> a1(filter_res_graph);
434//        typename FilterResGW::Node b1;
435//        Num j1=a1[b1];
436//        typename ErasingResGW::NodeMap<Num> a2(erasing_res_graph);
437//        typename ErasingResGW::Node b2;
438//        Num j2=a2[b2];
439          Num augment_value=free1[n];
440          while (erasing_res_graph.valid(pred[n])) {
441            typename ErasingResGW::OutEdgeIt e=pred[n];
442            res_graph.augment(e, augment_value);
443            n=erasing_res_graph.tail(e);
444            if (res_graph.resCap(e)==0)
445              erasing_res_graph.erase(e);
446        }
447      }
448     
449      } //while (__augment)
450           
451      return _augment;
452    }
453
454    void run() {
455      //int num_of_augmentations=0;
456      while (augmentOnShortestPath()) {
457        //while (augmentOnBlockingFlow<MutableGraph>()) {
458        //std::cout << ++num_of_augmentations << " ";
459        //std::cout<<std::endl;
460      }
461    }
462
463    template<typename MutableGraph> void run() {
464      //int num_of_augmentations=0;
465      //while (augmentOnShortestPath()) {
466        while (augmentOnBlockingFlow<MutableGraph>()) {
467        //std::cout << ++num_of_augmentations << " ";
468        //std::cout<<std::endl;
469      }
470    }
471
472    Num flowValue() {
473      Num a=0;
474      OutEdgeIt e;
475      for(g->first(e, s); g->valid(e); g->next(e)) {
476        a+=(*flow)[e];
477      }
478      return a;
479    }
480
481  };
482
483
484//   template <typename Graph, typename Num, typename FlowMap, typename CapMap>
485//   class MaxMatching {
486//   public:
487//     typedef typename Graph::Node Node;
488//     typedef typename Graph::NodeIt NodeIt;
489//     typedef typename Graph::Edge Edge;
490//     typedef typename Graph::EdgeIt EdgeIt;
491//     typedef typename Graph::OutEdgeIt OutEdgeIt;
492//     typedef typename Graph::InEdgeIt InEdgeIt;
493
494//     typedef typename Graph::NodeMap<bool> SMap;
495//     typedef typename Graph::NodeMap<bool> TMap;
496//   private:
497//     const Graph* G;
498//     SMap* S;
499//     TMap* T;
500//     //Node s;
501//     //Node t;
502//     FlowMap* flow;
503//     const CapMap* capacity;
504//     typedef ResGraphWrapper<Graph, Num, FlowMap, CapMap > AugGraph;
505//     typedef typename AugGraph::OutEdgeIt AugOutEdgeIt;
506//     typedef typename AugGraph::Edge AugEdge;
507//     typename Graph::NodeMap<int> used; //0
508
509//   public:
510//     MaxMatching(const Graph& _G, SMap& _S, TMap& _T, FlowMap& _flow, const CapMap& _capacity) :
511//       G(&_G), S(&_S), T(&_T), flow(&_flow), capacity(&_capacity), used(_G) { }
512//     bool augmentOnShortestPath() {
513//       AugGraph res_graph(*G, *flow, *capacity);
514//       bool _augment=false;
515     
516//       typedef typename AugGraph::NodeMap<bool> ReachedMap;
517//       BfsIterator< AugGraph, /*AugOutEdgeIt,*/ ReachedMap > bfs(res_graph);
518//       typename AugGraph::NodeMap<AugEdge> pred(res_graph);
519//       for(NodeIt s=G->template first<NodeIt>(); G->valid(s); G->next(s)) {
520//      if ((S->get(s)) && (used.get(s)<1) ) {
521//        //Num u=0;
522//        //for(OutEdgeIt e=G->template first<OutEdgeIt>(s); G->valid(e); G->next(e))
523//        //u+=flow->get(e);
524//        //if (u<1) {
525//          bfs.pushAndSetReached(s);
526//          pred.set(s, AugEdge(INVALID));
527//          //}
528//      }
529//       }
530     
531//       typename AugGraph::NodeMap<Num> free(res_graph);
532       
533//       Node n;
534//       //searching for augmenting path
535//       while ( !bfs.finished() ) {
536//      AugOutEdgeIt e=bfs;
537//      if (res_graph.valid(e) && bfs.isBNodeNewlyReached()) {
538//        Node v=res_graph.tail(e);
539//        Node w=res_graph.head(e);
540//        pred.set(w, e);
541//        if (res_graph.valid(pred.get(v))) {
542//          free.set(w, std::min(free.get(v), res_graph.free(e)));
543//        } else {
544//          free.set(w, res_graph.free(e));
545//        }
546//        n=res_graph.head(e);
547//        if (T->get(n) && (used.get(n)<1) ) {
548//          //Num u=0;
549//          //for(InEdgeIt f=G->template first<InEdgeIt>(n); G->valid(f); G->next(f))
550//          //u+=flow->get(f);
551//          //if (u<1) {
552//            _augment=true;
553//            break;
554//            //}
555//        }
556//      }
557       
558//      ++bfs;
559//       } //end of searching augmenting path
560
561//       if (_augment) {
562//      //Node n=t;
563//      used.set(n, 1); //mind2 vegen jav
564//      Num augment_value=free.get(n);
565//      while (res_graph.valid(pred.get(n))) {
566//        AugEdge e=pred.get(n);
567//        res_graph.augment(e, augment_value);
568//        n=res_graph.tail(e);
569//      }
570//      used.set(n, 1); //mind2 vegen jav
571//       }
572
573//       return _augment;
574//     }
575
576// //     template<typename MutableGraph> bool augmentOnBlockingFlow() {     
577// //       bool _augment=false;
578
579// //       AugGraph res_graph(*G, *flow, *capacity);
580
581// //       typedef typename AugGraph::NodeMap<bool> ReachedMap;
582// //       BfsIterator4< AugGraph, AugOutEdgeIt, ReachedMap > bfs(res_graph);
583
584
585
586
587
588// //       //typename AugGraph::NodeMap<AugEdge> pred(res_graph);
589// //       for(NodeIt s=G->template first<NodeIt>(); G->valid(s); G->next(s)) {
590// //   if (S->get(s)) {
591// //     Num u=0;
592// //     for(OutEdgeIt e=G->template first<OutEdgeIt>(s); G->valid(e); G->next(e))
593// //       u+=flow->get(e);
594// //     if (u<1) {
595// //       bfs.pushAndSetReached(s);
596// //       //pred.set(s, AugEdge(INVALID));
597// //     }
598// //   }
599// //       }
600
601
602
603
604// //       //bfs.pushAndSetReached(s);
605// //       typename AugGraph::NodeMap<int> dist(res_graph); //filled up with 0's
606// //       while ( !bfs.finished() ) {
607// //   AugOutEdgeIt e=bfs;
608// //   if (res_graph.valid(e) && bfs.isBNodeNewlyReached()) {
609// //     dist.set(res_graph.head(e), dist.get(res_graph.tail(e))+1);
610// //   }
611       
612// //   ++bfs;
613// //       } //computing distances from s in the residual graph
614
615// //       MutableGraph F;
616// //       typename AugGraph::NodeMap<typename MutableGraph::Node>
617// //   res_graph_to_F(res_graph);
618// //       for(typename AugGraph::NodeIt n=res_graph.template first<typename AugGraph::NodeIt>(); res_graph.valid(n); res_graph.next(n)) {
619// //   res_graph_to_F.set(n, F.addNode());
620// //       }
621     
622// //       typename MutableGraph::Node sF=res_graph_to_F.get(s);
623// //       typename MutableGraph::Node tF=res_graph_to_F.get(t);
624
625// //       typename MutableGraph::EdgeMap<AugEdge> original_edge(F);
626// //       typename MutableGraph::EdgeMap<Num> residual_capacity(F);
627
628// //       //Making F to the graph containing the edges of the residual graph
629// //       //which are in some shortest paths
630// //       for(typename AugGraph::EdgeIt e=res_graph.template first<typename AugGraph::EdgeIt>(); res_graph.valid(e); res_graph.next(e)) {
631// //   if (dist.get(res_graph.head(e))==dist.get(res_graph.tail(e))+1) {
632// //     typename MutableGraph::Edge f=F.addEdge(res_graph_to_F.get(res_graph.tail(e)), res_graph_to_F.get(res_graph.head(e)));
633// //     original_edge.update();
634// //     original_edge.set(f, e);
635// //     residual_capacity.update();
636// //     residual_capacity.set(f, res_graph.free(e));
637// //   }
638// //       }
639
640// //       bool __augment=true;
641
642// //       while (__augment) {
643// //   __augment=false;
644// //   //computing blocking flow with dfs
645// //   typedef typename MutableGraph::NodeMap<bool> BlockingReachedMap;
646// //   DfsIterator4< MutableGraph, typename MutableGraph::OutEdgeIt, BlockingReachedMap > dfs(F);
647// //   typename MutableGraph::NodeMap<typename MutableGraph::Edge> pred(F);
648// //   pred.set(sF, typename MutableGraph::Edge(INVALID));
649// //   //invalid iterators for sources
650
651// //   typename MutableGraph::NodeMap<Num> free(F);
652
653// //   dfs.pushAndSetReached(sF);     
654// //   while (!dfs.finished()) {
655// //     ++dfs;
656// //     if (F.valid(typename MutableGraph::OutEdgeIt(dfs))) {
657// //       if (dfs.isBNodeNewlyReached()) {
658// //         typename MutableGraph::Node v=F.aNode(dfs);
659// //         typename MutableGraph::Node w=F.bNode(dfs);
660// //         pred.set(w, dfs);
661// //         if (F.valid(pred.get(v))) {
662// //           free.set(w, std::min(free.get(v), residual_capacity.get(dfs)));
663// //         } else {
664// //           free.set(w, residual_capacity.get(dfs));
665// //         }
666// //         if (w==tF) {
667// //           __augment=true;
668// //           _augment=true;
669// //           break;
670// //         }
671             
672// //       } else {
673// //         F.erase(typename MutableGraph::OutEdgeIt(dfs));
674// //       }
675// //     }
676// //   }
677
678// //   if (__augment) {
679// //     typename MutableGraph::Node n=tF;
680// //     Num augment_value=free.get(tF);
681// //     while (F.valid(pred.get(n))) {
682// //       typename MutableGraph::Edge e=pred.get(n);
683// //       res_graph.augment(original_edge.get(e), augment_value);
684// //       n=F.tail(e);
685// //       if (residual_capacity.get(e)==augment_value)
686// //         F.erase(e);
687// //       else
688// //         residual_capacity.set(e, residual_capacity.get(e)-augment_value);
689// //     }
690// //   }
691       
692// //       }
693           
694// //       return _augment;
695// //     }
696//     bool augmentOnBlockingFlow2() {
697//       bool _augment=false;
698
699//       //typedef ErasingResGraphWrapper<Graph, Num, FlowMap, CapMap> EAugGraph;
700//       typedef FilterGraphWrapper< ErasingResGraphWrapper<Graph, Num, FlowMap, CapMap> > EAugGraph;
701//       typedef typename EAugGraph::OutEdgeIt EAugOutEdgeIt;
702//       typedef typename EAugGraph::Edge EAugEdge;
703
704//       EAugGraph res_graph(*G, *flow, *capacity);
705
706//       //typedef typename EAugGraph::NodeMap<bool> ReachedMap;
707//       BfsIterator<
708//      ErasingResGraphWrapper<Graph, Num, FlowMap, CapMap>,
709//      /*typename ErasingResGraphWrapper<Graph, Num, FlowMap, CapMap>::OutEdgeIt,*/
710//      ErasingResGraphWrapper<Graph, Num, FlowMap, CapMap>::NodeMap<bool> > bfs(res_graph);
711
712
713//       //typename AugGraph::NodeMap<AugEdge> pred(res_graph);
714//       for(NodeIt s=G->template first<NodeIt>(); G->valid(s); G->next(s)) {
715//      if (S->get(s)) {
716//        Num u=0;
717//        for(OutEdgeIt e=G->template first<OutEdgeIt>(s); G->valid(e); G->next(e))
718//          u+=flow->get(e);
719//        if (u<1) {
720//          bfs.pushAndSetReached(s);
721//          //pred.set(s, AugEdge(INVALID));
722//        }
723//      }
724//       }
725
726     
727//       //bfs.pushAndSetReached(s);
728
729//       typename ErasingResGraphWrapper<Graph, Num, FlowMap, CapMap>::
730//      NodeMap<int>& dist=res_graph.dist;
731
732//       while ( !bfs.finished() ) {
733//      typename ErasingResGraphWrapper<Graph, Num, FlowMap, CapMap>::OutEdgeIt e=bfs;
734//      if (res_graph.valid(e) && bfs.isBNodeNewlyReached()) {
735//        dist.set(res_graph.head(e), dist.get(res_graph.tail(e))+1);
736//      }
737//      ++bfs; 
738//       } //computing distances from s in the residual graph
739
740//       bool __augment=true;
741
742//       while (__augment) {
743
744//      __augment=false;
745//      //computing blocking flow with dfs
746//      typedef typename EAugGraph::NodeMap<bool> BlockingReachedMap;
747//      DfsIterator< EAugGraph/*, EAugOutEdgeIt*/, BlockingReachedMap >
748//        dfs(res_graph);
749//      typename EAugGraph::NodeMap<EAugEdge> pred(res_graph, INVALID);
750//      //pred.set(s, EAugEdge(INVALID));
751//      //invalid iterators for sources
752
753//      typename EAugGraph::NodeMap<Num> free(res_graph);
754
755
756//      //typename AugGraph::NodeMap<AugEdge> pred(res_graph);
757//       for(NodeIt s=G->template first<NodeIt>(); G->valid(s); G->next(s)) {
758//      if (S->get(s)) {
759//        Num u=0;
760//        for(OutEdgeIt e=G->template first<OutEdgeIt>(s); G->valid(e); G->next(e))
761//          u+=flow->get(e);
762//        if (u<1) {
763//          dfs.pushAndSetReached(s);
764//          //pred.set(s, AugEdge(INVALID));
765//        }
766//      }
767//       }
768
769
770
771//       //dfs.pushAndSetReached(s);
772//       typename EAugGraph::Node n;
773//      while (!dfs.finished()) {
774//        ++dfs;
775//        if (res_graph.valid(EAugOutEdgeIt(dfs))) {
776//          if (dfs.isBNodeNewlyReached()) {
777         
778//            typename EAugGraph::Node v=res_graph.aNode(dfs);
779//            typename EAugGraph::Node w=res_graph.bNode(dfs);
780
781//            pred.set(w, EAugOutEdgeIt(dfs));
782//            if (res_graph.valid(pred.get(v))) {
783//              free.set(w, std::min(free.get(v), res_graph.free(dfs)));
784//            } else {
785//              free.set(w, res_graph.free(dfs));
786//            }
787             
788//            n=w;
789//            if (T->get(w)) {
790//              Num u=0;
791//              for(InEdgeIt f=G->template first<InEdgeIt>(n); G->valid(f); G->next(f))
792//                u+=flow->get(f);
793//              if (u<1) {
794//                __augment=true;
795//                _augment=true;
796//                break;
797//              }
798//            }
799//          } else {
800//            res_graph.erase(dfs);
801//          }
802//        }
803
804//      }
805
806//      if (__augment) {
807//        // typename EAugGraph::Node n=t;
808//        Num augment_value=free.get(n);
809//        while (res_graph.valid(pred.get(n))) {
810//          EAugEdge e=pred.get(n);
811//          res_graph.augment(e, augment_value);
812//          n=res_graph.tail(e);
813//          if (res_graph.free(e)==0)
814//            res_graph.erase(e);
815//        }
816//      }
817     
818//       }
819           
820//       return _augment;
821//     }
822//     void run() {
823//       //int num_of_augmentations=0;
824//       while (augmentOnShortestPath()) {
825//      //while (augmentOnBlockingFlow<MutableGraph>()) {
826//      //std::cout << ++num_of_augmentations << " ";
827//      //std::cout<<std::endl;
828//       }
829//     }
830// //     template<typename MutableGraph> void run() {
831// //       //int num_of_augmentations=0;
832// //       //while (augmentOnShortestPath()) {
833// //   while (augmentOnBlockingFlow<MutableGraph>()) {
834// //   //std::cout << ++num_of_augmentations << " ";
835// //   //std::cout<<std::endl;
836// //       }
837// //     }
838//     Num flowValue() {
839//       Num a=0;
840//       EdgeIt e;
841//       for(G->/*getF*/first(e); G->valid(e); G->next(e)) {
842//      a+=flow->get(e);
843//       }
844//       return a;
845//     }
846//   };
847
848
849
850
851
852 
853// //   template <typename Graph, typename Num, typename FlowMap, typename CapMap>
854// //   class MaxFlow2 {
855// //   public:
856// //     typedef typename Graph::Node Node;
857// //     typedef typename Graph::Edge Edge;
858// //     typedef typename Graph::EdgeIt EdgeIt;
859// //     typedef typename Graph::OutEdgeIt OutEdgeIt;
860// //     typedef typename Graph::InEdgeIt InEdgeIt;
861// //   private:
862// //     const Graph& G;
863// //     std::list<Node>& S;
864// //     std::list<Node>& T;
865// //     FlowMap& flow;
866// //     const CapMap& capacity;
867// //     typedef ResGraphWrapper<Graph, Num, FlowMap, CapMap > AugGraph;
868// //     typedef typename AugGraph::OutEdgeIt AugOutEdgeIt;
869// //     typedef typename AugGraph::Edge AugEdge;
870// //     typename Graph::NodeMap<bool> SMap;
871// //     typename Graph::NodeMap<bool> TMap;
872// //   public:
873// //     MaxFlow2(const Graph& _G, std::list<Node>& _S, std::list<Node>& _T, FlowMap& _flow, const CapMap& _capacity) : G(_G), S(_S), T(_T), flow(_flow), capacity(_capacity), SMap(_G), TMap(_G) {
874// //       for(typename std::list<Node>::const_iterator i=S.begin();
875// //     i!=S.end(); ++i) {
876// //   SMap.set(*i, true);
877// //       }
878// //       for (typename std::list<Node>::const_iterator i=T.begin();
879// //      i!=T.end(); ++i) {
880// //   TMap.set(*i, true);
881// //       }
882// //     }
883// //     bool augment() {
884// //       AugGraph res_graph(G, flow, capacity);
885// //       bool _augment=false;
886// //       Node reached_t_node;
887     
888// //       typedef typename AugGraph::NodeMap<bool> ReachedMap;
889// //       BfsIterator4< AugGraph, AugOutEdgeIt, ReachedMap > bfs(res_graph);
890// //       for(typename std::list<Node>::const_iterator i=S.begin();
891// //     i!=S.end(); ++i) {
892// //   bfs.pushAndSetReached(*i);
893// //       }
894// //       //bfs.pushAndSetReached(s);
895       
896// //       typename AugGraph::NodeMap<AugEdge> pred(res_graph);
897// //       //filled up with invalid iterators
898     
899// //       typename AugGraph::NodeMap<Num> free(res_graph);
900       
901// //       //searching for augmenting path
902// //       while ( !bfs.finished() ) {
903// //   AugOutEdgeIt e=/*AugOutEdgeIt*/(bfs);
904// //   if (e.valid() && bfs.isBNodeNewlyReached()) {
905// //     Node v=res_graph.tail(e);
906// //     Node w=res_graph.head(e);
907// //     pred.set(w, e);
908// //     if (pred.get(v).valid()) {
909// //       free.set(w, std::min(free.get(v), e.free()));
910// //     } else {
911// //       free.set(w, e.free());
912// //     }
913// //     if (TMap.get(res_graph.head(e))) {
914// //       _augment=true;
915// //       reached_t_node=res_graph.head(e);
916// //       break;
917// //     }
918// //   }
919       
920// //   ++bfs;
921// //       } //end of searching augmenting path
922
923// //       if (_augment) {
924// //   Node n=reached_t_node;
925// //   Num augment_value=free.get(reached_t_node);
926// //   while (pred.get(n).valid()) {
927// //     AugEdge e=pred.get(n);
928// //     e.augment(augment_value);
929// //     n=res_graph.tail(e);
930// //   }
931// //       }
932
933// //       return _augment;
934// //     }
935// //     void run() {
936// //       while (augment()) { }
937// //     }
938// //     Num flowValue() {
939// //       Num a=0;
940// //       for(typename std::list<Node>::const_iterator i=S.begin();
941// //     i!=S.end(); ++i) {
942// //   for(OutEdgeIt e=G.template first<OutEdgeIt>(*i); e.valid(); ++e) {
943// //     a+=flow.get(e);
944// //   }
945// //   for(InEdgeIt e=G.template first<InEdgeIt>(*i); e.valid(); ++e) {
946// //     a-=flow.get(e);
947// //   }
948// //       }
949// //       return a;
950// //     }
951// //   };
952
953
954} // namespace hugo
955
956#endif //HUGO_EDMONDS_KARP_H
Note: See TracBrowser for help on using the repository browser.