changeset 618 | b95898314e09 |
parent 581 | aa1804409f29 |
parent 610 | dacc2cee2b4c |
child 622 | 28f58740b6f8 |
7:27531e6b14ad | 9:6b2b32df34e3 |
---|---|
29 namespace lemon { |
29 namespace lemon { |
30 |
30 |
31 /// \brief Default traits class of Circulation class. |
31 /// \brief Default traits class of Circulation class. |
32 /// |
32 /// |
33 /// Default traits class of Circulation class. |
33 /// Default traits class of Circulation class. |
34 /// \tparam GR Digraph type. |
34 /// |
35 /// \tparam LM Lower bound capacity map type. |
35 /// \tparam GR Type of the digraph the algorithm runs on. |
36 /// \tparam UM Upper bound capacity map type. |
36 /// \tparam LM The type of the lower bound map. |
37 /// \tparam DM Delta map type. |
37 /// \tparam UM The type of the upper bound (capacity) map. |
38 /// \tparam SM The type of the supply map. |
|
38 template <typename GR, typename LM, |
39 template <typename GR, typename LM, |
39 typename UM, typename DM> |
40 typename UM, typename SM> |
40 struct CirculationDefaultTraits { |
41 struct CirculationDefaultTraits { |
41 |
42 |
42 /// \brief The type of the digraph the algorithm runs on. |
43 /// \brief The type of the digraph the algorithm runs on. |
43 typedef GR Digraph; |
44 typedef GR Digraph; |
44 |
45 |
45 /// \brief The type of the map that stores the circulation lower |
46 /// \brief The type of the lower bound map. |
46 /// bound. |
47 /// |
47 /// |
48 /// The type of the map that stores the lower bounds on the arcs. |
48 /// The type of the map that stores the circulation lower bound. |
49 /// It must conform to the \ref concepts::ReadMap "ReadMap" concept. |
49 /// It must meet the \ref concepts::ReadMap "ReadMap" concept. |
50 typedef LM LowerMap; |
50 typedef LM LCapMap; |
51 |
51 |
52 /// \brief The type of the upper bound (capacity) map. |
52 /// \brief The type of the map that stores the circulation upper |
53 /// |
53 /// bound. |
54 /// The type of the map that stores the upper bounds (capacities) |
54 /// |
55 /// on the arcs. |
55 /// The type of the map that stores the circulation upper bound. |
56 /// It must conform to the \ref concepts::ReadMap "ReadMap" concept. |
56 /// It must meet the \ref concepts::ReadMap "ReadMap" concept. |
57 typedef UM UpperMap; |
57 typedef UM UCapMap; |
58 |
58 |
59 /// \brief The type of supply map. |
59 /// \brief The type of the map that stores the lower bound for |
60 /// |
60 /// the supply of the nodes. |
61 /// The type of the map that stores the signed supply values of the |
61 /// |
62 /// nodes. |
62 /// The type of the map that stores the lower bound for the supply |
63 /// It must conform to the \ref concepts::ReadMap "ReadMap" concept. |
63 /// of the nodes. It must meet the \ref concepts::ReadMap "ReadMap" |
64 typedef SM SupplyMap; |
65 |
|
66 /// \brief The type of the flow values. |
|
67 typedef typename SupplyMap::Value Flow; |
|
68 |
|
69 /// \brief The type of the map that stores the flow values. |
|
70 /// |
|
71 /// The type of the map that stores the flow values. |
|
72 /// It must conform to the \ref concepts::ReadWriteMap "ReadWriteMap" |
|
64 /// concept. |
73 /// concept. |
65 typedef DM DeltaMap; |
74 typedef typename Digraph::template ArcMap<Flow> FlowMap; |
66 |
|
67 /// \brief The type of the flow values. |
|
68 typedef typename DeltaMap::Value Value; |
|
69 |
|
70 /// \brief The type of the map that stores the flow values. |
|
71 /// |
|
72 /// The type of the map that stores the flow values. |
|
73 /// It must meet the \ref concepts::ReadWriteMap "ReadWriteMap" concept. |
|
74 typedef typename Digraph::template ArcMap<Value> FlowMap; |
|
75 |
75 |
76 /// \brief Instantiates a FlowMap. |
76 /// \brief Instantiates a FlowMap. |
77 /// |
77 /// |
78 /// This function instantiates a \ref FlowMap. |
78 /// This function instantiates a \ref FlowMap. |
79 /// \param digraph The digraph, to which we would like to define |
79 /// \param digraph The digraph for which we would like to define |
80 /// the flow map. |
80 /// the flow map. |
81 static FlowMap* createFlowMap(const Digraph& digraph) { |
81 static FlowMap* createFlowMap(const Digraph& digraph) { |
82 return new FlowMap(digraph); |
82 return new FlowMap(digraph); |
83 } |
83 } |
84 |
84 |
91 typedef lemon::Elevator<Digraph, typename Digraph::Node> Elevator; |
91 typedef lemon::Elevator<Digraph, typename Digraph::Node> Elevator; |
92 |
92 |
93 /// \brief Instantiates an Elevator. |
93 /// \brief Instantiates an Elevator. |
94 /// |
94 /// |
95 /// This function instantiates an \ref Elevator. |
95 /// This function instantiates an \ref Elevator. |
96 /// \param digraph The digraph, to which we would like to define |
96 /// \param digraph The digraph for which we would like to define |
97 /// the elevator. |
97 /// the elevator. |
98 /// \param max_level The maximum level of the elevator. |
98 /// \param max_level The maximum level of the elevator. |
99 static Elevator* createElevator(const Digraph& digraph, int max_level) { |
99 static Elevator* createElevator(const Digraph& digraph, int max_level) { |
100 return new Elevator(digraph, max_level); |
100 return new Elevator(digraph, max_level); |
101 } |
101 } |
102 |
102 |
103 /// \brief The tolerance used by the algorithm |
103 /// \brief The tolerance used by the algorithm |
104 /// |
104 /// |
105 /// The tolerance used by the algorithm to handle inexact computation. |
105 /// The tolerance used by the algorithm to handle inexact computation. |
106 typedef lemon::Tolerance<Value> Tolerance; |
106 typedef lemon::Tolerance<Flow> Tolerance; |
107 |
107 |
108 }; |
108 }; |
109 |
109 |
110 /** |
110 /** |
111 \brief Push-relabel algorithm for the network circulation problem. |
111 \brief Push-relabel algorithm for the network circulation problem. |
112 |
112 |
113 \ingroup max_flow |
113 \ingroup max_flow |
114 This class implements a push-relabel algorithm for the network |
114 This class implements a push-relabel algorithm for the \e network |
115 circulation problem. |
115 \e circulation problem. |
116 It is to find a feasible circulation when lower and upper bounds |
116 It is to find a feasible circulation when lower and upper bounds |
117 are given for the flow values on the arcs and lower bounds |
117 are given for the flow values on the arcs and lower bounds are |
118 are given for the supply values of the nodes. |
118 given for the difference between the outgoing and incoming flow |
119 at the nodes. |
|
119 |
120 |
120 The exact formulation of this problem is the following. |
121 The exact formulation of this problem is the following. |
121 Let \f$G=(V,A)\f$ be a digraph, |
122 Let \f$G=(V,A)\f$ be a digraph, |
122 \f$lower, upper: A\rightarrow\mathbf{R}^+_0\f$, |
123 \f$lower, upper: A\rightarrow\mathbf{R}^+_0\f$ denote the lower and |
123 \f$delta: V\rightarrow\mathbf{R}\f$. Find a feasible circulation |
124 upper bounds on the arcs, for which \f$0 \leq lower(uv) \leq upper(uv)\f$ |
124 \f$f: A\rightarrow\mathbf{R}^+_0\f$ so that |
125 holds for all \f$uv\in A\f$, and \f$sup: V\rightarrow\mathbf{R}\f$ |
125 \f[ \sum_{a\in\delta_{out}(v)} f(a) - \sum_{a\in\delta_{in}(v)} f(a) |
126 denotes the signed supply values of the nodes. |
126 \geq delta(v) \quad \forall v\in V, \f] |
127 If \f$sup(u)>0\f$, then \f$u\f$ is a supply node with \f$sup(u)\f$ |
127 \f[ lower(a)\leq f(a) \leq upper(a) \quad \forall a\in A. \f] |
128 supply, if \f$sup(u)<0\f$, then \f$u\f$ is a demand node with |
128 \note \f$delta(v)\f$ specifies a lower bound for the supply of node |
129 \f$-sup(u)\f$ demand. |
129 \f$v\f$. It can be either positive or negative, however note that |
130 A feasible circulation is an \f$f: A\rightarrow\mathbf{R}^+_0\f$ |
130 \f$\sum_{v\in V}delta(v)\f$ should be zero or negative in order to |
131 solution of the following problem. |
131 have a feasible solution. |
132 |
132 |
133 \f[ \sum_{uv\in A} f(uv) - \sum_{vu\in A} f(vu) |
133 \note A special case of this problem is when |
134 \geq sup(u) \quad \forall u\in V, \f] |
134 \f$\sum_{v\in V}delta(v) = 0\f$. Then the supply of each node \f$v\f$ |
135 \f[ lower(uv) \leq f(uv) \leq upper(uv) \quad \forall uv\in A. \f] |
135 will be \e equal \e to \f$delta(v)\f$, if a circulation can be found. |
136 |
136 Thus a feasible solution for the |
137 The sum of the supply values, i.e. \f$\sum_{u\in V} sup(u)\f$ must be |
137 \ref min_cost_flow "minimum cost flow" problem can be calculated |
138 zero or negative in order to have a feasible solution (since the sum |
138 in this way. |
139 of the expressions on the left-hand side of the inequalities is zero). |
140 It means that the total demand must be greater or equal to the total |
|
141 supply and all the supplies have to be carried out from the supply nodes, |
|
142 but there could be demands that are not satisfied. |
|
143 If \f$\sum_{u\in V} sup(u)\f$ is zero, then all the supply/demand |
|
144 constraints have to be satisfied with equality, i.e. all demands |
|
145 have to be satisfied and all supplies have to be used. |
|
146 |
|
147 If you need the opposite inequalities in the supply/demand constraints |
|
148 (i.e. the total demand is less than the total supply and all the demands |
|
149 have to be satisfied while there could be supplies that are not used), |
|
150 then you could easily transform the problem to the above form by reversing |
|
151 the direction of the arcs and taking the negative of the supply values |
|
152 (e.g. using \ref ReverseDigraph and \ref NegMap adaptors). |
|
153 |
|
154 Note that this algorithm also provides a feasible solution for the |
|
155 \ref min_cost_flow "minimum cost flow problem". |
|
139 |
156 |
140 \tparam GR The type of the digraph the algorithm runs on. |
157 \tparam GR The type of the digraph the algorithm runs on. |
141 \tparam LM The type of the lower bound capacity map. The default |
158 \tparam LM The type of the lower bound map. The default |
142 map type is \ref concepts::Digraph::ArcMap "GR::ArcMap<int>". |
159 map type is \ref concepts::Digraph::ArcMap "GR::ArcMap<int>". |
143 \tparam UM The type of the upper bound capacity map. The default |
160 \tparam UM The type of the upper bound (capacity) map. |
144 map type is \c LM. |
161 The default map type is \c LM. |
145 \tparam DM The type of the map that stores the lower bound |
162 \tparam SM The type of the supply map. The default map type is |
146 for the supply of the nodes. The default map type is |
|
147 \ref concepts::Digraph::NodeMap "GR::NodeMap<UM::Value>". |
163 \ref concepts::Digraph::NodeMap "GR::NodeMap<UM::Value>". |
148 */ |
164 */ |
149 #ifdef DOXYGEN |
165 #ifdef DOXYGEN |
150 template< typename GR, |
166 template< typename GR, |
151 typename LM, |
167 typename LM, |
152 typename UM, |
168 typename UM, |
153 typename DM, |
169 typename SM, |
154 typename TR > |
170 typename TR > |
155 #else |
171 #else |
156 template< typename GR, |
172 template< typename GR, |
157 typename LM = typename GR::template ArcMap<int>, |
173 typename LM = typename GR::template ArcMap<int>, |
158 typename UM = LM, |
174 typename UM = LM, |
159 typename DM = typename GR::template NodeMap<typename UM::Value>, |
175 typename SM = typename GR::template NodeMap<typename UM::Value>, |
160 typename TR = CirculationDefaultTraits<GR, LM, UM, DM> > |
176 typename TR = CirculationDefaultTraits<GR, LM, UM, SM> > |
161 #endif |
177 #endif |
162 class Circulation { |
178 class Circulation { |
163 public: |
179 public: |
164 |
180 |
165 ///The \ref CirculationDefaultTraits "traits class" of the algorithm. |
181 ///The \ref CirculationDefaultTraits "traits class" of the algorithm. |
166 typedef TR Traits; |
182 typedef TR Traits; |
167 ///The type of the digraph the algorithm runs on. |
183 ///The type of the digraph the algorithm runs on. |
168 typedef typename Traits::Digraph Digraph; |
184 typedef typename Traits::Digraph Digraph; |
169 ///The type of the flow values. |
185 ///The type of the flow values. |
170 typedef typename Traits::Value Value; |
186 typedef typename Traits::Flow Flow; |
171 |
187 |
172 /// The type of the lower bound capacity map. |
188 ///The type of the lower bound map. |
173 typedef typename Traits::LCapMap LCapMap; |
189 typedef typename Traits::LowerMap LowerMap; |
174 /// The type of the upper bound capacity map. |
190 ///The type of the upper bound (capacity) map. |
175 typedef typename Traits::UCapMap UCapMap; |
191 typedef typename Traits::UpperMap UpperMap; |
176 /// \brief The type of the map that stores the lower bound for |
192 ///The type of the supply map. |
177 /// the supply of the nodes. |
193 typedef typename Traits::SupplyMap SupplyMap; |
178 typedef typename Traits::DeltaMap DeltaMap; |
|
179 ///The type of the flow map. |
194 ///The type of the flow map. |
180 typedef typename Traits::FlowMap FlowMap; |
195 typedef typename Traits::FlowMap FlowMap; |
181 |
196 |
182 ///The type of the elevator. |
197 ///The type of the elevator. |
183 typedef typename Traits::Elevator Elevator; |
198 typedef typename Traits::Elevator Elevator; |
189 TEMPLATE_DIGRAPH_TYPEDEFS(Digraph); |
204 TEMPLATE_DIGRAPH_TYPEDEFS(Digraph); |
190 |
205 |
191 const Digraph &_g; |
206 const Digraph &_g; |
192 int _node_num; |
207 int _node_num; |
193 |
208 |
194 const LCapMap *_lo; |
209 const LowerMap *_lo; |
195 const UCapMap *_up; |
210 const UpperMap *_up; |
196 const DeltaMap *_delta; |
211 const SupplyMap *_supply; |
197 |
212 |
198 FlowMap *_flow; |
213 FlowMap *_flow; |
199 bool _local_flow; |
214 bool _local_flow; |
200 |
215 |
201 Elevator* _level; |
216 Elevator* _level; |
202 bool _local_level; |
217 bool _local_level; |
203 |
218 |
204 typedef typename Digraph::template NodeMap<Value> ExcessMap; |
219 typedef typename Digraph::template NodeMap<Flow> ExcessMap; |
205 ExcessMap* _excess; |
220 ExcessMap* _excess; |
206 |
221 |
207 Tolerance _tol; |
222 Tolerance _tol; |
208 int _el; |
223 int _el; |
209 |
224 |
229 /// |
244 /// |
230 /// \ref named-templ-param "Named parameter" for setting FlowMap |
245 /// \ref named-templ-param "Named parameter" for setting FlowMap |
231 /// type. |
246 /// type. |
232 template <typename T> |
247 template <typename T> |
233 struct SetFlowMap |
248 struct SetFlowMap |
234 : public Circulation<Digraph, LCapMap, UCapMap, DeltaMap, |
249 : public Circulation<Digraph, LowerMap, UpperMap, SupplyMap, |
235 SetFlowMapTraits<T> > { |
250 SetFlowMapTraits<T> > { |
236 typedef Circulation<Digraph, LCapMap, UCapMap, DeltaMap, |
251 typedef Circulation<Digraph, LowerMap, UpperMap, SupplyMap, |
237 SetFlowMapTraits<T> > Create; |
252 SetFlowMapTraits<T> > Create; |
238 }; |
253 }; |
239 |
254 |
240 template <typename T> |
255 template <typename T> |
241 struct SetElevatorTraits : public Traits { |
256 struct SetElevatorTraits : public Traits { |
255 /// \ref elevator(Elevator&) "elevator()" function before calling |
270 /// \ref elevator(Elevator&) "elevator()" function before calling |
256 /// \ref run() or \ref init(). |
271 /// \ref run() or \ref init(). |
257 /// \sa SetStandardElevator |
272 /// \sa SetStandardElevator |
258 template <typename T> |
273 template <typename T> |
259 struct SetElevator |
274 struct SetElevator |
260 : public Circulation<Digraph, LCapMap, UCapMap, DeltaMap, |
275 : public Circulation<Digraph, LowerMap, UpperMap, SupplyMap, |
261 SetElevatorTraits<T> > { |
276 SetElevatorTraits<T> > { |
262 typedef Circulation<Digraph, LCapMap, UCapMap, DeltaMap, |
277 typedef Circulation<Digraph, LowerMap, UpperMap, SupplyMap, |
263 SetElevatorTraits<T> > Create; |
278 SetElevatorTraits<T> > Create; |
264 }; |
279 }; |
265 |
280 |
266 template <typename T> |
281 template <typename T> |
267 struct SetStandardElevatorTraits : public Traits { |
282 struct SetStandardElevatorTraits : public Traits { |
283 /// algorithm with the \ref elevator(Elevator&) "elevator()" function |
298 /// algorithm with the \ref elevator(Elevator&) "elevator()" function |
284 /// before calling \ref run() or \ref init(). |
299 /// before calling \ref run() or \ref init(). |
285 /// \sa SetElevator |
300 /// \sa SetElevator |
286 template <typename T> |
301 template <typename T> |
287 struct SetStandardElevator |
302 struct SetStandardElevator |
288 : public Circulation<Digraph, LCapMap, UCapMap, DeltaMap, |
303 : public Circulation<Digraph, LowerMap, UpperMap, SupplyMap, |
289 SetStandardElevatorTraits<T> > { |
304 SetStandardElevatorTraits<T> > { |
290 typedef Circulation<Digraph, LCapMap, UCapMap, DeltaMap, |
305 typedef Circulation<Digraph, LowerMap, UpperMap, SupplyMap, |
291 SetStandardElevatorTraits<T> > Create; |
306 SetStandardElevatorTraits<T> > Create; |
292 }; |
307 }; |
293 |
308 |
294 /// @} |
309 /// @} |
295 |
310 |
297 |
312 |
298 Circulation() {} |
313 Circulation() {} |
299 |
314 |
300 public: |
315 public: |
301 |
316 |
317 /// Constructor. |
|
318 |
|
302 /// The constructor of the class. |
319 /// The constructor of the class. |
303 |
320 /// |
304 /// The constructor of the class. |
321 /// \param graph The digraph the algorithm runs on. |
305 /// \param g The digraph the algorithm runs on. |
322 /// \param lower The lower bounds for the flow values on the arcs. |
306 /// \param lo The lower bound capacity of the arcs. |
323 /// \param upper The upper bounds (capacities) for the flow values |
307 /// \param up The upper bound capacity of the arcs. |
324 /// on the arcs. |
308 /// \param delta The lower bound for the supply of the nodes. |
325 /// \param supply The signed supply values of the nodes. |
309 Circulation(const Digraph &g,const LCapMap &lo, |
326 Circulation(const Digraph &graph, const LowerMap &lower, |
310 const UCapMap &up,const DeltaMap &delta) |
327 const UpperMap &upper, const SupplyMap &supply) |
311 : _g(g), _node_num(), |
328 : _g(graph), _lo(&lower), _up(&upper), _supply(&supply), |
312 _lo(&lo),_up(&up),_delta(&delta),_flow(0),_local_flow(false), |
329 _flow(NULL), _local_flow(false), _level(NULL), _local_level(false), |
313 _level(0), _local_level(false), _excess(0), _el() {} |
330 _excess(NULL) {} |
314 |
331 |
315 /// Destructor. |
332 /// Destructor. |
316 ~Circulation() { |
333 ~Circulation() { |
317 destroyStructures(); |
334 destroyStructures(); |
318 } |
335 } |
348 } |
365 } |
349 } |
366 } |
350 |
367 |
351 public: |
368 public: |
352 |
369 |
353 /// Sets the lower bound capacity map. |
370 /// Sets the lower bound map. |
354 |
371 |
355 /// Sets the lower bound capacity map. |
372 /// Sets the lower bound map. |
356 /// \return <tt>(*this)</tt> |
373 /// \return <tt>(*this)</tt> |
357 Circulation& lowerCapMap(const LCapMap& map) { |
374 Circulation& lowerMap(const LowerMap& map) { |
358 _lo = ↦ |
375 _lo = ↦ |
359 return *this; |
376 return *this; |
360 } |
377 } |
361 |
378 |
362 /// Sets the upper bound capacity map. |
379 /// Sets the upper bound (capacity) map. |
363 |
380 |
364 /// Sets the upper bound capacity map. |
381 /// Sets the upper bound (capacity) map. |
365 /// \return <tt>(*this)</tt> |
382 /// \return <tt>(*this)</tt> |
366 Circulation& upperCapMap(const LCapMap& map) { |
383 Circulation& upperMap(const LowerMap& map) { |
367 _up = ↦ |
384 _up = ↦ |
368 return *this; |
385 return *this; |
369 } |
386 } |
370 |
387 |
371 /// Sets the lower bound map for the supply of the nodes. |
388 /// Sets the supply map. |
372 |
389 |
373 /// Sets the lower bound map for the supply of the nodes. |
390 /// Sets the supply map. |
374 /// \return <tt>(*this)</tt> |
391 /// \return <tt>(*this)</tt> |
375 Circulation& deltaMap(const DeltaMap& map) { |
392 Circulation& supplyMap(const SupplyMap& map) { |
376 _delta = ↦ |
393 _supply = ↦ |
377 return *this; |
394 return *this; |
378 } |
395 } |
379 |
396 |
380 /// \brief Sets the flow map. |
397 /// \brief Sets the flow map. |
381 /// |
398 /// |
451 void init() |
468 void init() |
452 { |
469 { |
453 createStructures(); |
470 createStructures(); |
454 |
471 |
455 for(NodeIt n(_g);n!=INVALID;++n) { |
472 for(NodeIt n(_g);n!=INVALID;++n) { |
456 (*_excess)[n] = (*_delta)[n]; |
473 (*_excess)[n] = (*_supply)[n]; |
457 } |
474 } |
458 |
475 |
459 for (ArcIt e(_g);e!=INVALID;++e) { |
476 for (ArcIt e(_g);e!=INVALID;++e) { |
460 _flow->set(e, (*_lo)[e]); |
477 _flow->set(e, (*_lo)[e]); |
461 (*_excess)[_g.target(e)] += (*_flow)[e]; |
478 (*_excess)[_g.target(e)] += (*_flow)[e]; |
480 void greedyInit() |
497 void greedyInit() |
481 { |
498 { |
482 createStructures(); |
499 createStructures(); |
483 |
500 |
484 for(NodeIt n(_g);n!=INVALID;++n) { |
501 for(NodeIt n(_g);n!=INVALID;++n) { |
485 (*_excess)[n] = (*_delta)[n]; |
502 (*_excess)[n] = (*_supply)[n]; |
486 } |
503 } |
487 |
504 |
488 for (ArcIt e(_g);e!=INVALID;++e) { |
505 for (ArcIt e(_g);e!=INVALID;++e) { |
489 if (!_tol.positive((*_excess)[_g.target(e)] + (*_up)[e])) { |
506 if (!_tol.positive((*_excess)[_g.target(e)] + (*_up)[e])) { |
490 _flow->set(e, (*_up)[e]); |
507 _flow->set(e, (*_up)[e]); |
493 } else if (_tol.positive((*_excess)[_g.target(e)] + (*_lo)[e])) { |
510 } else if (_tol.positive((*_excess)[_g.target(e)] + (*_lo)[e])) { |
494 _flow->set(e, (*_lo)[e]); |
511 _flow->set(e, (*_lo)[e]); |
495 (*_excess)[_g.target(e)] += (*_lo)[e]; |
512 (*_excess)[_g.target(e)] += (*_lo)[e]; |
496 (*_excess)[_g.source(e)] -= (*_lo)[e]; |
513 (*_excess)[_g.source(e)] -= (*_lo)[e]; |
497 } else { |
514 } else { |
498 Value fc = -(*_excess)[_g.target(e)]; |
515 Flow fc = -(*_excess)[_g.target(e)]; |
499 _flow->set(e, fc); |
516 _flow->set(e, fc); |
500 (*_excess)[_g.target(e)] = 0; |
517 (*_excess)[_g.target(e)] = 0; |
501 (*_excess)[_g.source(e)] -= fc; |
518 (*_excess)[_g.source(e)] -= fc; |
502 } |
519 } |
503 } |
520 } |
526 Node bact=INVALID; |
543 Node bact=INVALID; |
527 Node last_activated=INVALID; |
544 Node last_activated=INVALID; |
528 while((act=_level->highestActive())!=INVALID) { |
545 while((act=_level->highestActive())!=INVALID) { |
529 int actlevel=(*_level)[act]; |
546 int actlevel=(*_level)[act]; |
530 int mlevel=_node_num; |
547 int mlevel=_node_num; |
531 Value exc=(*_excess)[act]; |
548 Flow exc=(*_excess)[act]; |
532 |
549 |
533 for(OutArcIt e(_g,act);e!=INVALID; ++e) { |
550 for(OutArcIt e(_g,act);e!=INVALID; ++e) { |
534 Node v = _g.target(e); |
551 Node v = _g.target(e); |
535 Value fc=(*_up)[e]-(*_flow)[e]; |
552 Flow fc=(*_up)[e]-(*_flow)[e]; |
536 if(!_tol.positive(fc)) continue; |
553 if(!_tol.positive(fc)) continue; |
537 if((*_level)[v]<actlevel) { |
554 if((*_level)[v]<actlevel) { |
538 if(!_tol.less(fc, exc)) { |
555 if(!_tol.less(fc, exc)) { |
539 _flow->set(e, (*_flow)[e] + exc); |
556 _flow->set(e, (*_flow)[e] + exc); |
540 (*_excess)[v] += exc; |
557 (*_excess)[v] += exc; |
554 } |
571 } |
555 else if((*_level)[v]<mlevel) mlevel=(*_level)[v]; |
572 else if((*_level)[v]<mlevel) mlevel=(*_level)[v]; |
556 } |
573 } |
557 for(InArcIt e(_g,act);e!=INVALID; ++e) { |
574 for(InArcIt e(_g,act);e!=INVALID; ++e) { |
558 Node v = _g.source(e); |
575 Node v = _g.source(e); |
559 Value fc=(*_flow)[e]-(*_lo)[e]; |
576 Flow fc=(*_flow)[e]-(*_lo)[e]; |
560 if(!_tol.positive(fc)) continue; |
577 if(!_tol.positive(fc)) continue; |
561 if((*_level)[v]<actlevel) { |
578 if((*_level)[v]<actlevel) { |
562 if(!_tol.less(fc, exc)) { |
579 if(!_tol.less(fc, exc)) { |
563 _flow->set(e, (*_flow)[e] - exc); |
580 _flow->set(e, (*_flow)[e] - exc); |
564 (*_excess)[v] += exc; |
581 (*_excess)[v] += exc; |
630 /// |
647 /// |
631 /// Returns the flow on the given arc. |
648 /// Returns the flow on the given arc. |
632 /// |
649 /// |
633 /// \pre Either \ref run() or \ref init() must be called before |
650 /// \pre Either \ref run() or \ref init() must be called before |
634 /// using this function. |
651 /// using this function. |
635 Value flow(const Arc& arc) const { |
652 Flow flow(const Arc& arc) const { |
636 return (*_flow)[arc]; |
653 return (*_flow)[arc]; |
637 } |
654 } |
638 |
655 |
639 /// \brief Returns a const reference to the flow map. |
656 /// \brief Returns a const reference to the flow map. |
640 /// |
657 /// |
649 /** |
666 /** |
650 \brief Returns \c true if the given node is in a barrier. |
667 \brief Returns \c true if the given node is in a barrier. |
651 |
668 |
652 Barrier is a set \e B of nodes for which |
669 Barrier is a set \e B of nodes for which |
653 |
670 |
654 \f[ \sum_{a\in\delta_{out}(B)} upper(a) - |
671 \f[ \sum_{uv\in A: u\in B} upper(uv) - |
655 \sum_{a\in\delta_{in}(B)} lower(a) < \sum_{v\in B}delta(v) \f] |
672 \sum_{uv\in A: v\in B} lower(uv) < \sum_{v\in B} sup(v) \f] |
656 |
673 |
657 holds. The existence of a set with this property prooves that a |
674 holds. The existence of a set with this property prooves that a |
658 feasible circualtion cannot exist. |
675 feasible circualtion cannot exist. |
659 |
676 |
660 This function returns \c true if the given node is in the found |
677 This function returns \c true if the given node is in the found |
713 bool checkFlow() const { |
730 bool checkFlow() const { |
714 for(ArcIt e(_g);e!=INVALID;++e) |
731 for(ArcIt e(_g);e!=INVALID;++e) |
715 if((*_flow)[e]<(*_lo)[e]||(*_flow)[e]>(*_up)[e]) return false; |
732 if((*_flow)[e]<(*_lo)[e]||(*_flow)[e]>(*_up)[e]) return false; |
716 for(NodeIt n(_g);n!=INVALID;++n) |
733 for(NodeIt n(_g);n!=INVALID;++n) |
717 { |
734 { |
718 Value dif=-(*_delta)[n]; |
735 Flow dif=-(*_supply)[n]; |
719 for(InArcIt e(_g,n);e!=INVALID;++e) dif-=(*_flow)[e]; |
736 for(InArcIt e(_g,n);e!=INVALID;++e) dif-=(*_flow)[e]; |
720 for(OutArcIt e(_g,n);e!=INVALID;++e) dif+=(*_flow)[e]; |
737 for(OutArcIt e(_g,n);e!=INVALID;++e) dif+=(*_flow)[e]; |
721 if(_tol.negative(dif)) return false; |
738 if(_tol.negative(dif)) return false; |
722 } |
739 } |
723 return true; |
740 return true; |
728 ///Check whether or not the last execution provides a barrier. |
745 ///Check whether or not the last execution provides a barrier. |
729 ///\sa barrier() |
746 ///\sa barrier() |
730 ///\sa barrierMap() |
747 ///\sa barrierMap() |
731 bool checkBarrier() const |
748 bool checkBarrier() const |
732 { |
749 { |
733 Value delta=0; |
750 Flow delta=0; |
734 for(NodeIt n(_g);n!=INVALID;++n) |
751 for(NodeIt n(_g);n!=INVALID;++n) |
735 if(barrier(n)) |
752 if(barrier(n)) |
736 delta-=(*_delta)[n]; |
753 delta-=(*_supply)[n]; |
737 for(ArcIt e(_g);e!=INVALID;++e) |
754 for(ArcIt e(_g);e!=INVALID;++e) |
738 { |
755 { |
739 Node s=_g.source(e); |
756 Node s=_g.source(e); |
740 Node t=_g.target(e); |
757 Node t=_g.target(e); |
741 if(barrier(s)&&!barrier(t)) delta+=(*_up)[e]; |
758 if(barrier(s)&&!barrier(t)) delta+=(*_up)[e]; |