Nothing serious.
3 * This file is a part of LEMON, a generic C++ optimization library
5 * Copyright (C) 2003-2006
6 * Egervary Jeno Kombinatorikus Optimalizalasi Kutatocsoport
7 * (Egervary Research Group on Combinatorial Optimization, EGRES).
9 * Permission to use, modify and distribute this software is granted
10 * provided that this copyright notice appears in all copies. For
11 * precise terms see the accompanying LICENSE file.
13 * This software is provided "AS IS" with no warranty of any kind,
14 * express or implied, and with no claim as to its suitability for any
19 #ifndef LEMON_BELMANN_FORD_H
20 #define LEMON_BELMANN_FORD_H
24 /// \brief BellmanFord algorithm.
27 #include <lemon/list_graph.h>
28 #include <lemon/bits/path_dump.h>
29 #include <lemon/bits/invalid.h>
30 #include <lemon/error.h>
31 #include <lemon/maps.h>
37 /// \brief Default OperationTraits for the BellmanFord algorithm class.
39 /// It defines all computational operations and constants which are
40 /// used in the bellman ford algorithm. The default implementation
41 /// is based on the numeric_limits class. If the numeric type does not
42 /// have infinity value then the maximum value is used as extremal
46 bool has_infinity = std::numeric_limits<Value>::has_infinity>
47 struct BellmanFordDefaultOperationTraits {
48 /// \brief Gives back the zero value of the type.
50 return static_cast<Value>(0);
52 /// \brief Gives back the positive infinity value of the type.
53 static Value infinity() {
54 return std::numeric_limits<Value>::infinity();
56 /// \brief Gives back the sum of the given two elements.
57 static Value plus(const Value& left, const Value& right) {
60 /// \brief Gives back true only if the first value less than the second.
61 static bool less(const Value& left, const Value& right) {
66 template <typename Value>
67 struct BellmanFordDefaultOperationTraits<Value, false> {
69 return static_cast<Value>(0);
71 static Value infinity() {
72 return std::numeric_limits<Value>::max();
74 static Value plus(const Value& left, const Value& right) {
75 if (left == infinity() || right == infinity()) return infinity();
78 static bool less(const Value& left, const Value& right) {
83 /// \brief Default traits class of BellmanFord class.
85 /// Default traits class of BellmanFord class.
86 /// \param _Graph Graph type.
87 /// \param _LegthMap Type of length map.
88 template<class _Graph, class _LengthMap>
89 struct BellmanFordDefaultTraits {
90 /// The graph type the algorithm runs on.
93 /// \brief The type of the map that stores the edge lengths.
95 /// The type of the map that stores the edge lengths.
96 /// It must meet the \ref concepts::ReadMap "ReadMap" concept.
97 typedef _LengthMap LengthMap;
99 // The type of the length of the edges.
100 typedef typename _LengthMap::Value Value;
102 /// \brief Operation traits for bellman-ford algorithm.
104 /// It defines the infinity type on the given Value type
105 /// and the used operation.
106 /// \see BellmanFordDefaultOperationTraits
107 typedef BellmanFordDefaultOperationTraits<Value> OperationTraits;
109 /// \brief The type of the map that stores the last edges of the
112 /// The type of the map that stores the last
113 /// edges of the shortest paths.
114 /// It must meet the \ref concepts::WriteMap "WriteMap" concept.
116 typedef typename Graph::template NodeMap<typename _Graph::Edge> PredMap;
118 /// \brief Instantiates a PredMap.
120 /// This function instantiates a \ref PredMap.
121 /// \param graph is the graph, to which we would like to define the PredMap.
122 static PredMap *createPredMap(const _Graph& graph) {
123 return new PredMap(graph);
126 /// \brief The type of the map that stores the dists of the nodes.
128 /// The type of the map that stores the dists of the nodes.
129 /// It must meet the \ref concepts::WriteMap "WriteMap" concept.
131 typedef typename Graph::template NodeMap<typename _LengthMap::Value>
134 /// \brief Instantiates a DistMap.
136 /// This function instantiates a \ref DistMap.
137 /// \param graph is the graph, to which we would like to define the
139 static DistMap *createDistMap(const _Graph& graph) {
140 return new DistMap(graph);
145 /// \brief %BellmanFord algorithm class.
147 /// \ingroup flowalgs
148 /// This class provides an efficient implementation of \c Bellman-Ford
149 /// algorithm. The edge lengths are passed to the algorithm using a
150 /// \ref concepts::ReadMap "ReadMap", so it is easy to change it to any
153 /// The Bellman-Ford algorithm solves the shortest path from one node
154 /// problem when the edges can have negative length but the graph should
155 /// not contain cycles with negative sum of length. If we can assume
156 /// that all edge is non-negative in the graph then the dijkstra algorithm
157 /// should be used rather.
159 /// The maximal time complexity of the algorithm is \f$ O(ne) \f$.
161 /// The type of the length is determined by the
162 /// \ref concepts::ReadMap::Value "Value" of the length map.
164 /// \param _Graph The graph type the algorithm runs on. The default value
165 /// is \ref ListGraph. The value of _Graph is not used directly by
166 /// BellmanFord, it is only passed to \ref BellmanFordDefaultTraits.
167 /// \param _LengthMap This read-only EdgeMap determines the lengths of the
168 /// edges. The default map type is \ref concepts::Graph::EdgeMap
169 /// "Graph::EdgeMap<int>". The value of _LengthMap is not used directly
170 /// by BellmanFord, it is only passed to \ref BellmanFordDefaultTraits.
171 /// \param _Traits Traits class to set various data types used by the
172 /// algorithm. The default traits class is \ref BellmanFordDefaultTraits
173 /// "BellmanFordDefaultTraits<_Graph,_LengthMap>". See \ref
174 /// BellmanFordDefaultTraits for the documentation of a BellmanFord traits
177 /// \author Balazs Dezso
180 template <typename _Graph, typename _LengthMap, typename _Traits>
182 template <typename _Graph=ListGraph,
183 typename _LengthMap=typename _Graph::template EdgeMap<int>,
184 typename _Traits=BellmanFordDefaultTraits<_Graph,_LengthMap> >
189 /// \brief \ref Exception for uninitialized parameters.
191 /// This error represents problems in the initialization
192 /// of the parameters of the algorithms.
194 class UninitializedParameter : public lemon::UninitializedParameter {
196 virtual const char* what() const throw() {
197 return "lemon::BellmanFord::UninitializedParameter";
201 typedef _Traits Traits;
202 ///The type of the underlying graph.
203 typedef typename _Traits::Graph Graph;
205 typedef typename Graph::Node Node;
206 typedef typename Graph::NodeIt NodeIt;
207 typedef typename Graph::Edge Edge;
208 typedef typename Graph::OutEdgeIt OutEdgeIt;
210 /// \brief The type of the length of the edges.
211 typedef typename _Traits::LengthMap::Value Value;
212 /// \brief The type of the map that stores the edge lengths.
213 typedef typename _Traits::LengthMap LengthMap;
214 /// \brief The type of the map that stores the last
215 /// edges of the shortest paths.
216 typedef typename _Traits::PredMap PredMap;
217 /// \brief The type of the map that stores the dists of the nodes.
218 typedef typename _Traits::DistMap DistMap;
219 /// \brief The operation traits.
220 typedef typename _Traits::OperationTraits OperationTraits;
222 /// Pointer to the underlying graph.
224 /// Pointer to the length map
225 const LengthMap *length;
226 ///Pointer to the map of predecessors edges.
228 ///Indicates if \ref _pred is locally allocated (\c true) or not.
230 ///Pointer to the map of distances.
232 ///Indicates if \ref _dist is locally allocated (\c true) or not.
235 typedef typename Graph::template NodeMap<bool> MaskMap;
238 std::vector<Node> _process;
240 /// Creates the maps if necessary.
244 _pred = Traits::createPredMap(*graph);
248 _dist = Traits::createDistMap(*graph);
250 _mask = new MaskMap(*graph, false);
255 typedef BellmanFord Create;
257 /// \name Named template parameters
262 struct DefPredMapTraits : public Traits {
264 static PredMap *createPredMap(const Graph&) {
265 throw UninitializedParameter();
269 /// \brief \ref named-templ-param "Named parameter" for setting PredMap
271 /// \ref named-templ-param "Named parameter" for setting PredMap type
275 : public BellmanFord< Graph, LengthMap, DefPredMapTraits<T> > {
276 typedef BellmanFord< Graph, LengthMap, DefPredMapTraits<T> > Create;
280 struct DefDistMapTraits : public Traits {
282 static DistMap *createDistMap(const Graph&) {
283 throw UninitializedParameter();
287 /// \brief \ref named-templ-param "Named parameter" for setting DistMap
290 /// \ref named-templ-param "Named parameter" for setting DistMap type
294 : public BellmanFord< Graph, LengthMap, DefDistMapTraits<T> > {
295 typedef BellmanFord< Graph, LengthMap, DefDistMapTraits<T> > Create;
299 struct DefOperationTraitsTraits : public Traits {
300 typedef T OperationTraits;
303 /// \brief \ref named-templ-param "Named parameter" for setting
304 /// OperationTraits type
306 /// \ref named-templ-param "Named parameter" for setting OperationTraits
309 struct DefOperationTraits
310 : public BellmanFord< Graph, LengthMap, DefOperationTraitsTraits<T> > {
311 typedef BellmanFord< Graph, LengthMap, DefOperationTraitsTraits<T> >
323 /// \brief Constructor.
325 /// \param _graph the graph the algorithm will run on.
326 /// \param _length the length map used by the algorithm.
327 BellmanFord(const Graph& _graph, const LengthMap& _length) :
328 graph(&_graph), length(&_length),
329 _pred(0), local_pred(false),
330 _dist(0), local_dist(false), _mask(0) {}
334 if(local_pred) delete _pred;
335 if(local_dist) delete _dist;
336 if(_mask) delete _mask;
339 /// \brief Sets the length map.
341 /// Sets the length map.
342 /// \return \c (*this)
343 BellmanFord &lengthMap(const LengthMap &m) {
348 /// \brief Sets the map storing the predecessor edges.
350 /// Sets the map storing the predecessor edges.
351 /// If you don't use this function before calling \ref run(),
352 /// it will allocate one. The destuctor deallocates this
353 /// automatically allocated map, of course.
354 /// \return \c (*this)
355 BellmanFord &predMap(PredMap &m) {
364 /// \brief Sets the map storing the distances calculated by the algorithm.
366 /// Sets the map storing the distances calculated by the algorithm.
367 /// If you don't use this function before calling \ref run(),
368 /// it will allocate one. The destuctor deallocates this
369 /// automatically allocated map, of course.
370 /// \return \c (*this)
371 BellmanFord &distMap(DistMap &m) {
380 /// \name Execution control
381 /// The simplest way to execute the algorithm is to use
382 /// one of the member functions called \c run(...).
384 /// If you need more control on the execution,
385 /// first you must call \ref init(), then you can add several source nodes
386 /// with \ref addSource().
387 /// Finally \ref start() will perform the actual path
392 /// \brief Initializes the internal data structures.
394 /// Initializes the internal data structures.
395 void init(const Value value = OperationTraits::infinity()) {
397 for (NodeIt it(*graph); it != INVALID; ++it) {
398 _pred->set(it, INVALID);
399 _dist->set(it, value);
402 if (OperationTraits::less(value, OperationTraits::infinity())) {
403 for (NodeIt it(*graph); it != INVALID; ++it) {
404 _process.push_back(it);
405 _mask->set(it, true);
410 /// \brief Adds a new source node.
412 /// The optional second parameter is the initial distance of the node.
413 /// It just sets the distance of the node to the given value.
414 void addSource(Node source, Value dst = OperationTraits::zero()) {
415 _dist->set(source, dst);
416 if (!(*_mask)[source]) {
417 _process.push_back(source);
418 _mask->set(source, true);
422 /// \brief Executes one round from the bellman ford algorithm.
424 /// If the algoritm calculated the distances in the previous round
425 /// exactly for all at most \f$ k \f$ length path lengths then it will
426 /// calculate the distances exactly for all at most \f$ k + 1 \f$
427 /// length path lengths. With \f$ k \f$ iteration this function
428 /// calculates the at most \f$ k \f$ length path lengths.
430 /// \warning The paths with limited edge number cannot be retrieved
431 /// easily with \ref path() or \ref predEdge() functions. If you
432 /// need the shortest path and not just the distance you should store
433 /// after each iteration the \ref predEdgeMap() map and manually build
436 /// \return %True when the algorithm have not found more shorter
438 bool processNextRound() {
439 for (int i = 0; i < (int)_process.size(); ++i) {
440 _mask->set(_process[i], false);
442 std::vector<Node> nextProcess;
443 std::vector<Value> values(_process.size());
444 for (int i = 0; i < (int)_process.size(); ++i) {
445 values[i] = (*_dist)[_process[i]];
447 for (int i = 0; i < (int)_process.size(); ++i) {
448 for (OutEdgeIt it(*graph, _process[i]); it != INVALID; ++it) {
449 Node target = graph->target(it);
450 Value relaxed = OperationTraits::plus(values[i], (*length)[it]);
451 if (OperationTraits::less(relaxed, (*_dist)[target])) {
452 _pred->set(target, it);
453 _dist->set(target, relaxed);
454 if (!(*_mask)[target]) {
455 _mask->set(target, true);
456 nextProcess.push_back(target);
461 _process.swap(nextProcess);
462 return _process.empty();
465 /// \brief Executes one weak round from the bellman ford algorithm.
467 /// If the algorithm calculated the distances in the
468 /// previous round at least for all at most k length paths then it will
469 /// calculate the distances at least for all at most k + 1 length paths.
470 /// This function does not make it possible to calculate strictly the
471 /// at most k length minimal paths, this is why it is
472 /// called just weak round.
473 /// \return %True when the algorithm have not found more shorter paths.
474 bool processNextWeakRound() {
475 for (int i = 0; i < (int)_process.size(); ++i) {
476 _mask->set(_process[i], false);
478 std::vector<Node> nextProcess;
479 for (int i = 0; i < (int)_process.size(); ++i) {
480 for (OutEdgeIt it(*graph, _process[i]); it != INVALID; ++it) {
481 Node target = graph->target(it);
483 OperationTraits::plus((*_dist)[_process[i]], (*length)[it]);
484 if (OperationTraits::less(relaxed, (*_dist)[target])) {
485 _pred->set(target, it);
486 _dist->set(target, relaxed);
487 if (!(*_mask)[target]) {
488 _mask->set(target, true);
489 nextProcess.push_back(target);
494 _process.swap(nextProcess);
495 return _process.empty();
498 /// \brief Executes the algorithm.
500 /// \pre init() must be called and at least one node should be added
501 /// with addSource() before using this function.
503 /// This method runs the %BellmanFord algorithm from the root node(s)
504 /// in order to compute the shortest path to each node. The algorithm
506 /// - The shortest path tree.
507 /// - The distance of each node from the root(s).
509 int num = countNodes(*graph) - 1;
510 for (int i = 0; i < num; ++i) {
511 if (processNextWeakRound()) break;
515 /// \brief Executes the algorithm and checks the negative cycles.
517 /// \pre init() must be called and at least one node should be added
518 /// with addSource() before using this function. If there is
519 /// a negative cycles in the graph it gives back false.
521 /// This method runs the %BellmanFord algorithm from the root node(s)
522 /// in order to compute the shortest path to each node. The algorithm
524 /// - The shortest path tree.
525 /// - The distance of each node from the root(s).
526 bool checkedStart() {
527 int num = countNodes(*graph);
528 for (int i = 0; i < num; ++i) {
529 if (processNextWeakRound()) return true;
534 /// \brief Executes the algorithm with path length limit.
536 /// \pre init() must be called and at least one node should be added
537 /// with addSource() before using this function.
539 /// This method runs the %BellmanFord algorithm from the root
540 /// node(s) in order to compute the shortest path lengths with at
541 /// most \c num edge.
543 /// \warning The paths with limited edge number cannot be retrieved
544 /// easily with \ref path() or \ref predEdge() functions. If you
545 /// need the shortest path and not just the distance you should store
546 /// after each iteration the \ref predEdgeMap() map and manually build
549 /// The algorithm computes
550 /// - The predecessor edge from each node.
551 /// - The limited distance of each node from the root(s).
552 void limitedStart(int num) {
553 for (int i = 0; i < num; ++i) {
554 if (processNextRound()) break;
558 /// \brief Runs %BellmanFord algorithm from node \c s.
560 /// This method runs the %BellmanFord algorithm from a root node \c s
561 /// in order to compute the shortest path to each node. The algorithm
563 /// - The shortest path tree.
564 /// - The distance of each node from the root.
566 /// \note d.run(s) is just a shortcut of the following code.
578 /// \brief Runs %BellmanFord algorithm with limited path length
581 /// This method runs the %BellmanFord algorithm from a root node \c s
582 /// in order to compute the shortest path with at most \c len edges
583 /// to each node. The algorithm computes
584 /// - The shortest path tree.
585 /// - The distance of each node from the root.
587 /// \note d.run(s, len) is just a shortcut of the following code.
591 /// d.limitedStart(len);
593 void run(Node s, int len) {
601 /// \name Query Functions
602 /// The result of the %BellmanFord algorithm can be obtained using these
604 /// Before the use of these functions,
605 /// either run() or start() must be called.
609 /// \brief Lemon iterator for get a active nodes.
611 /// Lemon iterator for get a active nodes. This class provides a
612 /// common style lemon iterator which gives back a subset of the
613 /// nodes. The iterated nodes are active in the algorithm after
614 /// the last phase so these should be checked in the next phase to
615 /// find augmenting edges from these.
619 /// \brief Constructor.
621 /// Constructor for get the nodeset of the variable.
622 ActiveIt(const BellmanFord& algorithm) : _algorithm(&algorithm)
624 _index = _algorithm->_process.size() - 1;
627 /// \brief Invalid constructor.
629 /// Invalid constructor.
630 ActiveIt(Invalid) : _algorithm(0), _index(-1) {}
632 /// \brief Conversion to node.
634 /// Conversion to node.
635 operator Node() const {
636 return _index >= 0 ? _algorithm->_process[_index] : INVALID;
639 /// \brief Increment operator.
641 /// Increment operator.
642 ActiveIt& operator++() {
647 bool operator==(const ActiveIt& it) const {
648 return (Node)(*this) == (Node)it;
650 bool operator!=(const ActiveIt& it) const {
651 return (Node)(*this) != (Node)it;
653 bool operator<(const ActiveIt& it) const {
654 return (Node)(*this) < (Node)it;
658 const BellmanFord* _algorithm;
662 typedef PredMapPath<Graph, PredMap> Path;
664 /// \brief Gives back the shortest path.
666 /// Gives back the shortest path.
667 /// \pre The \c t should be reachable from the source.
670 return Path(*graph, *_pred, t);
674 // TODO : implement negative cycle
675 // /// \brief Gives back a negative cycle.
677 // /// This function gives back a negative cycle.
678 // /// If the algorithm have not found yet negative cycle it will give back
679 // /// an empty path.
680 // Path negativeCycle() {
681 // typename Graph::template NodeMap<int> state(*graph, 0);
682 // for (ActiveIt it(*this); it != INVALID; ++it) {
683 // if (state[it] == 0) {
684 // for (Node t = it; predEdge(t) != INVALID; t = predNode(t)) {
685 // if (state[t] == 0) {
687 // } else if (state[t] == 2) {
691 // typename Path::Builder b(p);
692 // b.setStartNode(t);
693 // b.pushFront(predEdge(t));
694 // for(Node s = predNode(t); s != t; s = predNode(s)) {
695 // b.pushFront(predEdge(s));
701 // for (Node t = it; predEdge(t) != INVALID; t = predNode(t)) {
702 // if (state[t] == 1) {
713 /// \brief The distance of a node from the root.
715 /// Returns the distance of a node from the root.
716 /// \pre \ref run() must be called before using this function.
717 /// \warning If node \c v in unreachable from the root the return value
718 /// of this funcion is undefined.
719 Value dist(Node v) const { return (*_dist)[v]; }
721 /// \brief Returns the 'previous edge' of the shortest path tree.
723 /// For a node \c v it returns the 'previous edge' of the shortest path
724 /// tree, i.e. it returns the last edge of a shortest path from the root
725 /// to \c v. It is \ref INVALID if \c v is unreachable from the root or
726 /// if \c v=s. The shortest path tree used here is equal to the shortest
727 /// path tree used in \ref predNode().
728 /// \pre \ref run() must be called before using
730 Edge predEdge(Node v) const { return (*_pred)[v]; }
732 /// \brief Returns the 'previous node' of the shortest path tree.
734 /// For a node \c v it returns the 'previous node' of the shortest path
735 /// tree, i.e. it returns the last but one node from a shortest path from
736 /// the root to \c /v. It is INVALID if \c v is unreachable from the root
737 /// or if \c v=s. The shortest path tree used here is equal to the
738 /// shortest path tree used in \ref predEdge(). \pre \ref run() must be
739 /// called before using this function.
740 Node predNode(Node v) const {
741 return (*_pred)[v] == INVALID ? INVALID : graph->source((*_pred)[v]);
744 /// \brief Returns a reference to the NodeMap of distances.
746 /// Returns a reference to the NodeMap of distances. \pre \ref run() must
747 /// be called before using this function.
748 const DistMap &distMap() const { return *_dist;}
750 /// \brief Returns a reference to the shortest path tree map.
752 /// Returns a reference to the NodeMap of the edges of the
753 /// shortest path tree.
754 /// \pre \ref run() must be called before using this function.
755 const PredMap &predMap() const { return *_pred; }
757 /// \brief Checks if a node is reachable from the root.
759 /// Returns \c true if \c v is reachable from the root.
760 /// \pre \ref run() must be called before using this function.
762 bool reached(Node v) { return (*_dist)[v] != OperationTraits::infinity(); }
767 /// \brief Default traits class of BellmanFord function.
769 /// Default traits class of BellmanFord function.
770 /// \param _Graph Graph type.
771 /// \param _LengthMap Type of length map.
772 template <typename _Graph, typename _LengthMap>
773 struct BellmanFordWizardDefaultTraits {
774 /// \brief The graph type the algorithm runs on.
775 typedef _Graph Graph;
777 /// \brief The type of the map that stores the edge lengths.
779 /// The type of the map that stores the edge lengths.
780 /// It must meet the \ref concepts::ReadMap "ReadMap" concept.
781 typedef _LengthMap LengthMap;
783 /// \brief The value type of the length map.
784 typedef typename _LengthMap::Value Value;
786 /// \brief Operation traits for bellman-ford algorithm.
788 /// It defines the infinity type on the given Value type
789 /// and the used operation.
790 /// \see BellmanFordDefaultOperationTraits
791 typedef BellmanFordDefaultOperationTraits<Value> OperationTraits;
793 /// \brief The type of the map that stores the last
794 /// edges of the shortest paths.
796 /// The type of the map that stores the last
797 /// edges of the shortest paths.
798 /// It must meet the \ref concepts::WriteMap "WriteMap" concept.
799 typedef NullMap <typename _Graph::Node,typename _Graph::Edge> PredMap;
801 /// \brief Instantiates a PredMap.
803 /// This function instantiates a \ref PredMap.
804 static PredMap *createPredMap(const _Graph &) {
805 return new PredMap();
807 /// \brief The type of the map that stores the dists of the nodes.
809 /// The type of the map that stores the dists of the nodes.
810 /// It must meet the \ref concepts::WriteMap "WriteMap" concept.
811 typedef NullMap<typename Graph::Node, Value> DistMap;
812 /// \brief Instantiates a DistMap.
814 /// This function instantiates a \ref DistMap.
815 static DistMap *createDistMap(const _Graph &) {
816 return new DistMap();
820 /// \brief Default traits used by \ref BellmanFordWizard
822 /// To make it easier to use BellmanFord algorithm
823 /// we have created a wizard class.
824 /// This \ref BellmanFordWizard class needs default traits,
825 /// as well as the \ref BellmanFord class.
826 /// The \ref BellmanFordWizardBase is a class to be the default traits of the
827 /// \ref BellmanFordWizard class.
828 /// \todo More named parameters are required...
829 template<class _Graph,class _LengthMap>
830 class BellmanFordWizardBase
831 : public BellmanFordWizardDefaultTraits<_Graph,_LengthMap> {
833 typedef BellmanFordWizardDefaultTraits<_Graph,_LengthMap> Base;
835 /// Type of the nodes in the graph.
836 typedef typename Base::Graph::Node Node;
838 /// Pointer to the underlying graph.
840 /// Pointer to the length map
842 ///Pointer to the map of predecessors edges.
844 ///Pointer to the map of distances.
846 ///Pointer to the source node.
852 /// This constructor does not require parameters, therefore it initiates
853 /// all of the attributes to default values (0, INVALID).
854 BellmanFordWizardBase() : _graph(0), _length(0), _pred(0),
855 _dist(0), _source(INVALID) {}
859 /// This constructor requires some parameters,
860 /// listed in the parameters list.
861 /// Others are initiated to 0.
862 /// \param graph is the initial value of \ref _graph
863 /// \param length is the initial value of \ref _length
864 /// \param source is the initial value of \ref _source
865 BellmanFordWizardBase(const _Graph& graph,
866 const _LengthMap& length,
867 Node source = INVALID) :
868 _graph((void *)&graph), _length((void *)&length), _pred(0),
869 _dist(0), _source(source) {}
873 /// A class to make the usage of BellmanFord algorithm easier
875 /// This class is created to make it easier to use BellmanFord algorithm.
876 /// It uses the functions and features of the plain \ref BellmanFord,
877 /// but it is much simpler to use it.
879 /// Simplicity means that the way to change the types defined
880 /// in the traits class is based on functions that returns the new class
881 /// and not on templatable built-in classes.
882 /// When using the plain \ref BellmanFord
883 /// the new class with the modified type comes from
884 /// the original class by using the ::
885 /// operator. In the case of \ref BellmanFordWizard only
886 /// a function have to be called and it will
887 /// return the needed class.
889 /// It does not have own \ref run method. When its \ref run method is called
890 /// it initiates a plain \ref BellmanFord class, and calls the \ref
891 /// BellmanFord::run method of it.
892 template<class _Traits>
893 class BellmanFordWizard : public _Traits {
894 typedef _Traits Base;
896 ///The type of the underlying graph.
897 typedef typename _Traits::Graph Graph;
899 typedef typename Graph::Node Node;
900 typedef typename Graph::NodeIt NodeIt;
901 typedef typename Graph::Edge Edge;
902 typedef typename Graph::OutEdgeIt EdgeIt;
904 ///The type of the map that stores the edge lengths.
905 typedef typename _Traits::LengthMap LengthMap;
907 ///The type of the length of the edges.
908 typedef typename LengthMap::Value Value;
910 ///\brief The type of the map that stores the last
911 ///edges of the shortest paths.
912 typedef typename _Traits::PredMap PredMap;
914 ///The type of the map that stores the dists of the nodes.
915 typedef typename _Traits::DistMap DistMap;
919 BellmanFordWizard() : _Traits() {}
921 /// \brief Constructor that requires parameters.
923 /// Constructor that requires parameters.
924 /// These parameters will be the default values for the traits class.
925 BellmanFordWizard(const Graph& graph, const LengthMap& length,
926 Node source = INVALID)
927 : _Traits(graph, length, source) {}
929 /// \brief Copy constructor
930 BellmanFordWizard(const _Traits &b) : _Traits(b) {}
932 ~BellmanFordWizard() {}
934 /// \brief Runs BellmanFord algorithm from a given node.
936 /// Runs BellmanFord algorithm from a given node.
937 /// The node can be given by the \ref source function.
939 if(Base::_source == INVALID) throw UninitializedParameter();
940 BellmanFord<Graph,LengthMap,_Traits>
941 bf(*(Graph*)Base::_graph, *(LengthMap*)Base::_length);
942 if (Base::_pred) bf.predMap(*(PredMap*)Base::_pred);
943 if (Base::_dist) bf.distMap(*(DistMap*)Base::_dist);
944 bf.run(Base::_source);
947 /// \brief Runs BellmanFord algorithm from the given node.
949 /// Runs BellmanFord algorithm from the given node.
950 /// \param source is the given source.
951 void run(Node source) {
952 Base::_source = source;
957 struct DefPredMapBase : public Base {
959 static PredMap *createPredMap(const Graph &) { return 0; };
960 DefPredMapBase(const _Traits &b) : _Traits(b) {}
963 ///\brief \ref named-templ-param "Named parameter"
964 ///function for setting PredMap type
966 /// \ref named-templ-param "Named parameter"
967 ///function for setting PredMap type
970 BellmanFordWizard<DefPredMapBase<T> > predMap(const T &t)
972 Base::_pred=(void *)&t;
973 return BellmanFordWizard<DefPredMapBase<T> >(*this);
977 struct DefDistMapBase : public Base {
979 static DistMap *createDistMap(const Graph &) { return 0; };
980 DefDistMapBase(const _Traits &b) : _Traits(b) {}
983 ///\brief \ref named-templ-param "Named parameter"
984 ///function for setting DistMap type
986 /// \ref named-templ-param "Named parameter"
987 ///function for setting DistMap type
990 BellmanFordWizard<DefDistMapBase<T> > distMap(const T &t) {
991 Base::_dist=(void *)&t;
992 return BellmanFordWizard<DefDistMapBase<T> >(*this);
996 struct DefOperationTraitsBase : public Base {
997 typedef T OperationTraits;
998 DefOperationTraitsBase(const _Traits &b) : _Traits(b) {}
1001 ///\brief \ref named-templ-param "Named parameter"
1002 ///function for setting OperationTraits type
1004 /// \ref named-templ-param "Named parameter"
1005 ///function for setting OperationTraits type
1008 BellmanFordWizard<DefOperationTraitsBase<T> > distMap() {
1009 return BellmanFordWizard<DefDistMapBase<T> >(*this);
1012 /// \brief Sets the source node, from which the BellmanFord algorithm runs.
1014 /// Sets the source node, from which the BellmanFord algorithm runs.
1015 /// \param source is the source node.
1016 BellmanFordWizard<_Traits>& source(Node source) {
1017 Base::_source = source;
1023 /// \brief Function type interface for BellmanFord algorithm.
1025 /// \ingroup flowalgs
1026 /// Function type interface for BellmanFord algorithm.
1028 /// This function also has several \ref named-templ-func-param
1029 /// "named parameters", they are declared as the members of class
1030 /// \ref BellmanFordWizard.
1032 /// example shows how to use these parameters.
1034 /// bellmanford(g,length,source).predMap(preds).run();
1036 /// \warning Don't forget to put the \ref BellmanFordWizard::run() "run()"
1037 /// to the end of the parameter list.
1038 /// \sa BellmanFordWizard
1040 template<class _Graph, class _LengthMap>
1041 BellmanFordWizard<BellmanFordWizardBase<_Graph,_LengthMap> >
1042 bellmanFord(const _Graph& graph,
1043 const _LengthMap& length,
1044 typename _Graph::Node source = INVALID) {
1045 return BellmanFordWizard<BellmanFordWizardBase<_Graph,_LengthMap> >
1046 (graph, length, source);
1049 } //END OF NAMESPACE LEMON