lemon/bfs.h
author deba
Wed, 18 Apr 2007 16:34:40 +0000
changeset 2420 07c4f9bcb4d5
parent 2386 81b47fc5c444
child 2438 718479989797
permissions -rw-r--r--
Demo program for SAT problems
     1 /* -*- C++ -*-
     2  *
     3  * This file is a part of LEMON, a generic C++ optimization library
     4  *
     5  * Copyright (C) 2003-2007
     6  * Egervary Jeno Kombinatorikus Optimalizalasi Kutatocsoport
     7  * (Egervary Research Group on Combinatorial Optimization, EGRES).
     8  *
     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.
    12  *
    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
    15  * purpose.
    16  *
    17  */
    18 
    19 #ifndef LEMON_BFS_H
    20 #define LEMON_BFS_H
    21 
    22 ///\ingroup search
    23 ///\file
    24 ///\brief Bfs algorithm.
    25 
    26 #include <lemon/list_graph.h>
    27 #include <lemon/graph_utils.h>
    28 #include <lemon/bits/path_dump.h>
    29 #include <lemon/bits/invalid.h>
    30 #include <lemon/error.h>
    31 #include <lemon/maps.h>
    32 
    33 namespace lemon {
    34 
    35 
    36   
    37   ///Default traits class of Bfs class.
    38 
    39   ///Default traits class of Bfs class.
    40   ///\param GR Graph type.
    41   template<class GR>
    42   struct BfsDefaultTraits
    43   {
    44     ///The graph type the algorithm runs on. 
    45     typedef GR Graph;
    46     ///\brief The type of the map that stores the last
    47     ///edges of the shortest paths.
    48     /// 
    49     ///The type of the map that stores the last
    50     ///edges of the shortest paths.
    51     ///It must meet the \ref concepts::WriteMap "WriteMap" concept.
    52     ///
    53     typedef typename Graph::template NodeMap<typename GR::Edge> PredMap;
    54     ///Instantiates a PredMap.
    55  
    56     ///This function instantiates a \ref PredMap. 
    57     ///\param G is the graph, to which we would like to define the PredMap.
    58     ///\todo The graph alone may be insufficient to initialize
    59     static PredMap *createPredMap(const GR &G) 
    60     {
    61       return new PredMap(G);
    62     }
    63     ///The type of the map that indicates which nodes are processed.
    64  
    65     ///The type of the map that indicates which nodes are processed.
    66     ///It must meet the \ref concepts::WriteMap "WriteMap" concept.
    67     ///\todo named parameter to set this type, function to read and write.
    68     typedef NullMap<typename Graph::Node,bool> ProcessedMap;
    69     ///Instantiates a ProcessedMap.
    70  
    71     ///This function instantiates a \ref ProcessedMap. 
    72     ///\param g is the graph, to which
    73     ///we would like to define the \ref ProcessedMap
    74 #ifdef DOXYGEN
    75     static ProcessedMap *createProcessedMap(const GR &g)
    76 #else
    77     static ProcessedMap *createProcessedMap(const GR &)
    78 #endif
    79     {
    80       return new ProcessedMap();
    81     }
    82     ///The type of the map that indicates which nodes are reached.
    83  
    84     ///The type of the map that indicates which nodes are reached.
    85     ///It must meet the \ref concepts::WriteMap "WriteMap" concept.
    86     ///\todo named parameter to set this type, function to read and write.
    87     typedef typename Graph::template NodeMap<bool> ReachedMap;
    88     ///Instantiates a ReachedMap.
    89  
    90     ///This function instantiates a \ref ReachedMap. 
    91     ///\param G is the graph, to which
    92     ///we would like to define the \ref ReachedMap.
    93     static ReachedMap *createReachedMap(const GR &G)
    94     {
    95       return new ReachedMap(G);
    96     }
    97     ///The type of the map that stores the dists of the nodes.
    98  
    99     ///The type of the map that stores the dists of the nodes.
   100     ///It must meet the \ref concepts::WriteMap "WriteMap" concept.
   101     ///
   102     typedef typename Graph::template NodeMap<int> DistMap;
   103     ///Instantiates a DistMap.
   104  
   105     ///This function instantiates a \ref DistMap. 
   106     ///\param G is the graph, to which we would like to define the \ref DistMap
   107     static DistMap *createDistMap(const GR &G)
   108     {
   109       return new DistMap(G);
   110     }
   111   };
   112   
   113   ///%BFS algorithm class.
   114   
   115   ///\ingroup search
   116   ///This class provides an efficient implementation of the %BFS algorithm.
   117   ///
   118   ///\param GR The graph type the algorithm runs on. The default value is
   119   ///\ref ListGraph. The value of GR is not used directly by Bfs, it
   120   ///is only passed to \ref BfsDefaultTraits.
   121   ///\param TR Traits class to set various data types used by the algorithm.
   122   ///The default traits class is
   123   ///\ref BfsDefaultTraits "BfsDefaultTraits<GR>".
   124   ///See \ref BfsDefaultTraits for the documentation of
   125   ///a Bfs traits class.
   126   ///
   127   ///\author Alpar Juttner
   128 
   129 #ifdef DOXYGEN
   130   template <typename GR,
   131 	    typename TR>
   132 #else
   133   template <typename GR=ListGraph,
   134 	    typename TR=BfsDefaultTraits<GR> >
   135 #endif
   136   class Bfs {
   137   public:
   138     /**
   139      * \brief \ref Exception for uninitialized parameters.
   140      *
   141      * This error represents problems in the initialization
   142      * of the parameters of the algorithms.
   143      */
   144     class UninitializedParameter : public lemon::UninitializedParameter {
   145     public:
   146       virtual const char* what() const throw() {
   147 	return "lemon::Bfs::UninitializedParameter";
   148       }
   149     };
   150 
   151     typedef TR Traits;
   152     ///The type of the underlying graph.
   153     typedef typename TR::Graph Graph;
   154     ///\e
   155     typedef typename Graph::Node Node;
   156     ///\e
   157     typedef typename Graph::NodeIt NodeIt;
   158     ///\e
   159     typedef typename Graph::Edge Edge;
   160     ///\e
   161     typedef typename Graph::OutEdgeIt OutEdgeIt;
   162     
   163     ///\brief The type of the map that stores the last
   164     ///edges of the shortest paths.
   165     typedef typename TR::PredMap PredMap;
   166     ///The type of the map indicating which nodes are reached.
   167     typedef typename TR::ReachedMap ReachedMap;
   168     ///The type of the map indicating which nodes are processed.
   169     typedef typename TR::ProcessedMap ProcessedMap;
   170     ///The type of the map that stores the dists of the nodes.
   171     typedef typename TR::DistMap DistMap;
   172   private:
   173     /// Pointer to the underlying graph.
   174     const Graph *G;
   175     ///Pointer to the map of predecessors edges.
   176     PredMap *_pred;
   177     ///Indicates if \ref _pred is locally allocated (\c true) or not.
   178     bool local_pred;
   179     ///Pointer to the map of distances.
   180     DistMap *_dist;
   181     ///Indicates if \ref _dist is locally allocated (\c true) or not.
   182     bool local_dist;
   183     ///Pointer to the map of reached status of the nodes.
   184     ReachedMap *_reached;
   185     ///Indicates if \ref _reached is locally allocated (\c true) or not.
   186     bool local_reached;
   187     ///Pointer to the map of processed status of the nodes.
   188     ProcessedMap *_processed;
   189     ///Indicates if \ref _processed is locally allocated (\c true) or not.
   190     bool local_processed;
   191 
   192     std::vector<typename Graph::Node> _queue;
   193     int _queue_head,_queue_tail,_queue_next_dist;
   194     int _curr_dist;
   195 
   196     ///Creates the maps if necessary.
   197     
   198     ///\todo Better memory allocation (instead of new).
   199     void create_maps() 
   200     {
   201       if(!_pred) {
   202 	local_pred = true;
   203 	_pred = Traits::createPredMap(*G);
   204       }
   205       if(!_dist) {
   206 	local_dist = true;
   207 	_dist = Traits::createDistMap(*G);
   208       }
   209       if(!_reached) {
   210 	local_reached = true;
   211 	_reached = Traits::createReachedMap(*G);
   212       }
   213       if(!_processed) {
   214 	local_processed = true;
   215 	_processed = Traits::createProcessedMap(*G);
   216       }
   217     }
   218 
   219   protected:
   220     
   221     Bfs() {}
   222     
   223   public:
   224  
   225     typedef Bfs Create;
   226 
   227     ///\name Named template parameters
   228 
   229     ///@{
   230 
   231     template <class T>
   232     struct DefPredMapTraits : public Traits {
   233       typedef T PredMap;
   234       static PredMap *createPredMap(const Graph &) 
   235       {
   236 	throw UninitializedParameter();
   237       }
   238     };
   239     ///\ref named-templ-param "Named parameter" for setting PredMap type
   240 
   241     ///\ref named-templ-param "Named parameter" for setting PredMap type
   242     ///
   243     template <class T>
   244     struct DefPredMap : public Bfs< Graph, DefPredMapTraits<T> > { 
   245       typedef Bfs< Graph, DefPredMapTraits<T> > Create;
   246     };
   247     
   248     template <class T>
   249     struct DefDistMapTraits : public Traits {
   250       typedef T DistMap;
   251       static DistMap *createDistMap(const Graph &) 
   252       {
   253 	throw UninitializedParameter();
   254       }
   255     };
   256     ///\ref named-templ-param "Named parameter" for setting DistMap type
   257 
   258     ///\ref named-templ-param "Named parameter" for setting DistMap type
   259     ///
   260     template <class T>
   261     struct DefDistMap : public Bfs< Graph, DefDistMapTraits<T> > { 
   262       typedef Bfs< Graph, DefDistMapTraits<T> > Create;
   263     };
   264     
   265     template <class T>
   266     struct DefReachedMapTraits : public Traits {
   267       typedef T ReachedMap;
   268       static ReachedMap *createReachedMap(const Graph &) 
   269       {
   270 	throw UninitializedParameter();
   271       }
   272     };
   273     ///\ref named-templ-param "Named parameter" for setting ReachedMap type
   274 
   275     ///\ref named-templ-param "Named parameter" for setting ReachedMap type
   276     ///
   277     template <class T>
   278     struct DefReachedMap : public Bfs< Graph, DefReachedMapTraits<T> > { 
   279       typedef Bfs< Graph, DefReachedMapTraits<T> > Create;
   280     };
   281     
   282     template <class T>
   283     struct DefProcessedMapTraits : public Traits {
   284       typedef T ProcessedMap;
   285       static ProcessedMap *createProcessedMap(const Graph &) 
   286       {
   287 	throw UninitializedParameter();
   288       }
   289     };
   290     ///\ref named-templ-param "Named parameter" for setting ProcessedMap type
   291 
   292     ///\ref named-templ-param "Named parameter" for setting ProcessedMap type
   293     ///
   294     template <class T>
   295     struct DefProcessedMap : public Bfs< Graph, DefProcessedMapTraits<T> > {
   296       typedef Bfs< Graph, DefProcessedMapTraits<T> > Create;
   297     };
   298     
   299     struct DefGraphProcessedMapTraits : public Traits {
   300       typedef typename Graph::template NodeMap<bool> ProcessedMap;
   301       static ProcessedMap *createProcessedMap(const Graph &G) 
   302       {
   303 	return new ProcessedMap(G);
   304       }
   305     };
   306     ///\brief \ref named-templ-param "Named parameter"
   307     ///for setting the ProcessedMap type to be Graph::NodeMap<bool>.
   308     ///
   309     ///\ref named-templ-param "Named parameter"
   310     ///for setting the ProcessedMap type to be Graph::NodeMap<bool>.
   311     ///If you don't set it explicitly, it will be automatically allocated.
   312     template <class T>
   313     struct DefProcessedMapToBeDefaultMap :
   314       public Bfs< Graph, DefGraphProcessedMapTraits> { 
   315       typedef Bfs< Graph, DefGraphProcessedMapTraits> Create;
   316     };
   317     
   318     ///@}
   319 
   320   public:      
   321     
   322     ///Constructor.
   323     
   324     ///\param _G the graph the algorithm will run on.
   325     ///
   326     Bfs(const Graph& _G) :
   327       G(&_G),
   328       _pred(NULL), local_pred(false),
   329       _dist(NULL), local_dist(false),
   330       _reached(NULL), local_reached(false),
   331       _processed(NULL), local_processed(false)
   332     { }
   333     
   334     ///Destructor.
   335     ~Bfs() 
   336     {
   337       if(local_pred) delete _pred;
   338       if(local_dist) delete _dist;
   339       if(local_reached) delete _reached;
   340       if(local_processed) delete _processed;
   341     }
   342 
   343     ///Sets the map storing the predecessor edges.
   344 
   345     ///Sets the map storing the predecessor edges.
   346     ///If you don't use this function before calling \ref run(),
   347     ///it will allocate one. The destructor deallocates this
   348     ///automatically allocated map, of course.
   349     ///\return <tt> (*this) </tt>
   350     Bfs &predMap(PredMap &m) 
   351     {
   352       if(local_pred) {
   353 	delete _pred;
   354 	local_pred=false;
   355       }
   356       _pred = &m;
   357       return *this;
   358     }
   359 
   360     ///Sets the map indicating the reached nodes.
   361 
   362     ///Sets the map indicating the reached nodes.
   363     ///If you don't use this function before calling \ref run(),
   364     ///it will allocate one. The destructor deallocates this
   365     ///automatically allocated map, of course.
   366     ///\return <tt> (*this) </tt>
   367     Bfs &reachedMap(ReachedMap &m) 
   368     {
   369       if(local_reached) {
   370 	delete _reached;
   371 	local_reached=false;
   372       }
   373       _reached = &m;
   374       return *this;
   375     }
   376 
   377     ///Sets the map indicating the processed nodes.
   378 
   379     ///Sets the map indicating the processed nodes.
   380     ///If you don't use this function before calling \ref run(),
   381     ///it will allocate one. The destructor deallocates this
   382     ///automatically allocated map, of course.
   383     ///\return <tt> (*this) </tt>
   384     Bfs &processedMap(ProcessedMap &m) 
   385     {
   386       if(local_processed) {
   387 	delete _processed;
   388 	local_processed=false;
   389       }
   390       _processed = &m;
   391       return *this;
   392     }
   393 
   394     ///Sets the map storing the distances calculated by the algorithm.
   395 
   396     ///Sets the map storing the distances calculated by the algorithm.
   397     ///If you don't use this function before calling \ref run(),
   398     ///it will allocate one. The destructor deallocates this
   399     ///automatically allocated map, of course.
   400     ///\return <tt> (*this) </tt>
   401     Bfs &distMap(DistMap &m) 
   402     {
   403       if(local_dist) {
   404 	delete _dist;
   405 	local_dist=false;
   406       }
   407       _dist = &m;
   408       return *this;
   409     }
   410 
   411   public:
   412     ///\name Execution control
   413     ///The simplest way to execute the algorithm is to use
   414     ///one of the member functions called \c run(...).
   415     ///\n
   416     ///If you need more control on the execution,
   417     ///first you must call \ref init(), then you can add several source nodes
   418     ///with \ref addSource().
   419     ///Finally \ref start() will perform the actual path
   420     ///computation.
   421 
   422     ///@{
   423 
   424     ///Initializes the internal data structures.
   425 
   426     ///Initializes the internal data structures.
   427     ///
   428     void init()
   429     {
   430       create_maps();
   431       _queue.resize(countNodes(*G));
   432       _queue_head=_queue_tail=0;
   433       _curr_dist=1;
   434       for ( NodeIt u(*G) ; u!=INVALID ; ++u ) {
   435 	_pred->set(u,INVALID);
   436 	_reached->set(u,false);
   437 	_processed->set(u,false);
   438       }
   439     }
   440     
   441     ///Adds a new source node.
   442 
   443     ///Adds a new source node to the set of nodes to be processed.
   444     ///
   445     void addSource(Node s)
   446     {
   447       if(!(*_reached)[s])
   448 	{
   449 	  _reached->set(s,true);
   450 	  _pred->set(s,INVALID);
   451 	  _dist->set(s,0);
   452 	  _queue[_queue_head++]=s;
   453 	  _queue_next_dist=_queue_head;
   454 	}
   455     }
   456     
   457     ///Processes the next node.
   458 
   459     ///Processes the next node.
   460     ///
   461     ///\return The processed node.
   462     ///
   463     ///\warning The queue must not be empty!
   464     Node processNextNode()
   465     {
   466       if(_queue_tail==_queue_next_dist) {
   467 	_curr_dist++;
   468 	_queue_next_dist=_queue_head;
   469       }
   470       Node n=_queue[_queue_tail++];
   471       _processed->set(n,true);
   472       Node m;
   473       for(OutEdgeIt e(*G,n);e!=INVALID;++e)
   474 	if(!(*_reached)[m=G->target(e)]) {
   475 	  _queue[_queue_head++]=m;
   476 	  _reached->set(m,true);
   477 	  _pred->set(m,e);
   478 	  _dist->set(m,_curr_dist);
   479 	}
   480       return n;
   481     }
   482 
   483     ///Processes the next node.
   484 
   485     ///Processes the next node. And checks that the given target node
   486     ///is reached. If the target node is reachable from the processed
   487     ///node then the reached parameter will be set true. The reached
   488     ///parameter should be initially false.
   489     ///
   490     ///\param target The target node.
   491     ///\retval reach Indicates that the target node is reached.
   492     ///\return The processed node.
   493     ///
   494     ///\warning The queue must not be empty!
   495     Node processNextNode(Node target, bool& reach)
   496     {
   497       if(_queue_tail==_queue_next_dist) {
   498 	_curr_dist++;
   499 	_queue_next_dist=_queue_head;
   500       }
   501       Node n=_queue[_queue_tail++];
   502       _processed->set(n,true);
   503       Node m;
   504       for(OutEdgeIt e(*G,n);e!=INVALID;++e)
   505 	if(!(*_reached)[m=G->target(e)]) {
   506 	  _queue[_queue_head++]=m;
   507 	  _reached->set(m,true);
   508 	  _pred->set(m,e);
   509 	  _dist->set(m,_curr_dist);
   510           reach = reach || (target == m);
   511 	}
   512       return n;
   513     }
   514 
   515     ///Processes the next node.
   516 
   517     ///Processes the next node. And checks that at least one of
   518     ///reached node has true value in the \c nm nodemap. If one node
   519     ///with true value is reachable from the processed node then the
   520     ///reached parameter will be set true. The reached parameter
   521     ///should be initially false.
   522     ///
   523     ///\param nm The nodemaps of possible targets.
   524     ///\retval reach Indicates that one of the target nodes is reached.
   525     ///\return The processed node.
   526     ///
   527     ///\warning The queue must not be empty!
   528     template<class NM>
   529     Node processNextNode(const NM& nm, bool& reach)
   530     {
   531       if(_queue_tail==_queue_next_dist) {
   532 	_curr_dist++;
   533 	_queue_next_dist=_queue_head;
   534       }
   535       Node n=_queue[_queue_tail++];
   536       _processed->set(n,true);
   537       Node m;
   538       for(OutEdgeIt e(*G,n);e!=INVALID;++e)
   539 	if(!(*_reached)[m=G->target(e)]) {
   540 	  _queue[_queue_head++]=m;
   541 	  _reached->set(m,true);
   542 	  _pred->set(m,e);
   543 	  _dist->set(m,_curr_dist);
   544           reached = reach || nm[m];
   545 	}
   546       return n;
   547     }
   548       
   549     ///Next node to be processed.
   550 
   551     ///Next node to be processed.
   552     ///
   553     ///\return The next node to be processed or INVALID if the queue is
   554     /// empty.
   555     Node nextNode()
   556     { 
   557       return _queue_tail<_queue_head?_queue[_queue_tail]:INVALID;
   558     }
   559  
   560     ///\brief Returns \c false if there are nodes
   561     ///to be processed in the queue
   562     ///
   563     ///Returns \c false if there are nodes
   564     ///to be processed in the queue
   565     bool emptyQueue() { return _queue_tail==_queue_head; }
   566     ///Returns the number of the nodes to be processed.
   567     
   568     ///Returns the number of the nodes to be processed in the queue.
   569     ///
   570     int queueSize() { return _queue_head-_queue_tail; }
   571     
   572     ///Executes the algorithm.
   573 
   574     ///Executes the algorithm.
   575     ///
   576     ///\pre init() must be called and at least one node should be added
   577     ///with addSource() before using this function.
   578     ///
   579     ///This method runs the %BFS algorithm from the root node(s)
   580     ///in order to
   581     ///compute the
   582     ///shortest path to each node. The algorithm computes
   583     ///- The shortest path tree.
   584     ///- The distance of each node from the root(s).
   585     ///
   586     void start()
   587     {
   588       while ( !emptyQueue() ) processNextNode();
   589     }
   590     
   591     ///Executes the algorithm until \c dest is reached.
   592 
   593     ///Executes the algorithm until \c dest is reached.
   594     ///
   595     ///\pre init() must be called and at least one node should be added
   596     ///with addSource() before using this function.
   597     ///
   598     ///This method runs the %BFS algorithm from the root node(s)
   599     ///in order to
   600     ///compute the
   601     ///shortest path to \c dest. The algorithm computes
   602     ///- The shortest path to \c  dest.
   603     ///- The distance of \c dest from the root(s).
   604     ///
   605     void start(Node dest)
   606     {
   607       bool reach = false;
   608       while ( !emptyQueue() && !reach) processNextNode(dest, reach);
   609     }
   610     
   611     ///Executes the algorithm until a condition is met.
   612 
   613     ///Executes the algorithm until a condition is met.
   614     ///
   615     ///\pre init() must be called and at least one node should be added
   616     ///with addSource() before using this function.
   617     ///
   618     ///\param nm must be a bool (or convertible) node map. The
   619     ///algorithm will stop when it reached a node \c v with
   620     /// <tt>nm[v]</tt> true.
   621     ///\todo query the reached target
   622     template<class NM>
   623     void start(const NM &nm)
   624     {
   625       bool reach = false;
   626       while ( !emptyQueue() && !reach) processNextNode(nm, reach);
   627     }
   628     
   629     ///Runs %BFS algorithm from node \c s.
   630     
   631     ///This method runs the %BFS algorithm from a root node \c s
   632     ///in order to
   633     ///compute the
   634     ///shortest path to each node. The algorithm computes
   635     ///- The shortest path tree.
   636     ///- The distance of each node from the root.
   637     ///
   638     ///\note b.run(s) is just a shortcut of the following code.
   639     ///\code
   640     ///  b.init();
   641     ///  b.addSource(s);
   642     ///  b.start();
   643     ///\endcode
   644     void run(Node s) {
   645       init();
   646       addSource(s);
   647       start();
   648     }
   649     
   650     ///Finds the shortest path between \c s and \c t.
   651     
   652     ///Finds the shortest path between \c s and \c t.
   653     ///
   654     ///\return The length of the shortest s---t path if there exists one,
   655     ///0 otherwise.
   656     ///\note Apart from the return value, b.run(s) is
   657     ///just a shortcut of the following code.
   658     ///\code
   659     ///  b.init();
   660     ///  b.addSource(s);
   661     ///  b.start(t);
   662     ///\endcode
   663     int run(Node s,Node t) {
   664       init();
   665       addSource(s);
   666       start(t);
   667       return reached(t)? _curr_dist : 0;
   668     }
   669     
   670     ///@}
   671 
   672     ///\name Query Functions
   673     ///The result of the %BFS algorithm can be obtained using these
   674     ///functions.\n
   675     ///Before the use of these functions,
   676     ///either run() or start() must be calleb.
   677     
   678     ///@{
   679 
   680     typedef PredMapPath<Graph, PredMap> Path;
   681 
   682     ///Gives back the shortest path.
   683     
   684     ///Gives back the shortest path.
   685     ///\pre The \c t should be reachable from the source.
   686     Path path(Node t) 
   687     {
   688       return Path(*G, *_pred, t);
   689     }
   690 
   691     ///The distance of a node from the root(s).
   692 
   693     ///Returns the distance of a node from the root(s).
   694     ///\pre \ref run() must be called before using this function.
   695     ///\warning If node \c v in unreachable from the root(s) the return value
   696     ///of this function is undefined.
   697     int dist(Node v) const { return (*_dist)[v]; }
   698 
   699     ///Returns the 'previous edge' of the shortest path tree.
   700 
   701     ///For a node \c v it returns the 'previous edge'
   702     ///of the shortest path tree,
   703     ///i.e. it returns the last edge of a shortest path from the root(s) to \c
   704     ///v. It is \ref INVALID
   705     ///if \c v is unreachable from the root(s) or \c v is a root. The
   706     ///shortest path tree used here is equal to the shortest path tree used in
   707     ///\ref predNode().
   708     ///\pre Either \ref run() or \ref start() must be called before using
   709     ///this function.
   710     Edge predEdge(Node v) const { return (*_pred)[v];}
   711 
   712     ///Returns the 'previous node' of the shortest path tree.
   713 
   714     ///For a node \c v it returns the 'previous node'
   715     ///of the shortest path tree,
   716     ///i.e. it returns the last but one node from a shortest path from the
   717     ///root(a) to \c /v.
   718     ///It is INVALID if \c v is unreachable from the root(s) or
   719     ///if \c v itself a root.
   720     ///The shortest path tree used here is equal to the shortest path
   721     ///tree used in \ref predEdge().
   722     ///\pre Either \ref run() or \ref start() must be called before
   723     ///using this function.
   724     Node predNode(Node v) const { return (*_pred)[v]==INVALID ? INVALID:
   725 				  G->source((*_pred)[v]); }
   726     
   727     ///Returns a reference to the NodeMap of distances.
   728 
   729     ///Returns a reference to the NodeMap of distances.
   730     ///\pre Either \ref run() or \ref init() must
   731     ///be called before using this function.
   732     const DistMap &distMap() const { return *_dist;}
   733  
   734     ///Returns a reference to the shortest path tree map.
   735 
   736     ///Returns a reference to the NodeMap of the edges of the
   737     ///shortest path tree.
   738     ///\pre Either \ref run() or \ref init()
   739     ///must be called before using this function.
   740     const PredMap &predMap() const { return *_pred;}
   741  
   742     ///Checks if a node is reachable from the root.
   743 
   744     ///Returns \c true if \c v is reachable from the root.
   745     ///\warning The source nodes are indicated as unreached.
   746     ///\pre Either \ref run() or \ref start()
   747     ///must be called before using this function.
   748     ///
   749     bool reached(Node v) { return (*_reached)[v]; }
   750     
   751     ///@}
   752   };
   753 
   754   ///Default traits class of Bfs function.
   755 
   756   ///Default traits class of Bfs function.
   757   ///\param GR Graph type.
   758   template<class GR>
   759   struct BfsWizardDefaultTraits
   760   {
   761     ///The graph type the algorithm runs on. 
   762     typedef GR Graph;
   763     ///\brief The type of the map that stores the last
   764     ///edges of the shortest paths.
   765     /// 
   766     ///The type of the map that stores the last
   767     ///edges of the shortest paths.
   768     ///It must meet the \ref concepts::WriteMap "WriteMap" concept.
   769     ///
   770     typedef NullMap<typename Graph::Node,typename GR::Edge> PredMap;
   771     ///Instantiates a PredMap.
   772  
   773     ///This function instantiates a \ref PredMap. 
   774     ///\param g is the graph, to which we would like to define the PredMap.
   775     ///\todo The graph alone may be insufficient to initialize
   776 #ifdef DOXYGEN
   777     static PredMap *createPredMap(const GR &g) 
   778 #else
   779     static PredMap *createPredMap(const GR &) 
   780 #endif
   781     {
   782       return new PredMap();
   783     }
   784 
   785     ///The type of the map that indicates which nodes are processed.
   786  
   787     ///The type of the map that indicates which nodes are processed.
   788     ///It must meet the \ref concepts::WriteMap "WriteMap" concept.
   789     ///\todo named parameter to set this type, function to read and write.
   790     typedef NullMap<typename Graph::Node,bool> ProcessedMap;
   791     ///Instantiates a ProcessedMap.
   792  
   793     ///This function instantiates a \ref ProcessedMap. 
   794     ///\param g is the graph, to which
   795     ///we would like to define the \ref ProcessedMap
   796 #ifdef DOXYGEN
   797     static ProcessedMap *createProcessedMap(const GR &g)
   798 #else
   799     static ProcessedMap *createProcessedMap(const GR &)
   800 #endif
   801     {
   802       return new ProcessedMap();
   803     }
   804     ///The type of the map that indicates which nodes are reached.
   805  
   806     ///The type of the map that indicates which nodes are reached.
   807     ///It must meet the \ref concepts::WriteMap "WriteMap" concept.
   808     ///\todo named parameter to set this type, function to read and write.
   809     typedef typename Graph::template NodeMap<bool> ReachedMap;
   810     ///Instantiates a ReachedMap.
   811  
   812     ///This function instantiates a \ref ReachedMap. 
   813     ///\param G is the graph, to which
   814     ///we would like to define the \ref ReachedMap.
   815     static ReachedMap *createReachedMap(const GR &G)
   816     {
   817       return new ReachedMap(G);
   818     }
   819     ///The type of the map that stores the dists of the nodes.
   820  
   821     ///The type of the map that stores the dists of the nodes.
   822     ///It must meet the \ref concepts::WriteMap "WriteMap" concept.
   823     ///
   824     typedef NullMap<typename Graph::Node,int> DistMap;
   825     ///Instantiates a DistMap.
   826  
   827     ///This function instantiates a \ref DistMap. 
   828     ///\param g is the graph, to which we would like to define the \ref DistMap
   829 #ifdef DOXYGEN
   830     static DistMap *createDistMap(const GR &g)
   831 #else
   832     static DistMap *createDistMap(const GR &)
   833 #endif
   834     {
   835       return new DistMap();
   836     }
   837   };
   838   
   839   /// Default traits used by \ref BfsWizard
   840 
   841   /// To make it easier to use Bfs algorithm
   842   ///we have created a wizard class.
   843   /// This \ref BfsWizard class needs default traits,
   844   ///as well as the \ref Bfs class.
   845   /// The \ref BfsWizardBase is a class to be the default traits of the
   846   /// \ref BfsWizard class.
   847   template<class GR>
   848   class BfsWizardBase : public BfsWizardDefaultTraits<GR>
   849   {
   850 
   851     typedef BfsWizardDefaultTraits<GR> Base;
   852   protected:
   853     /// Type of the nodes in the graph.
   854     typedef typename Base::Graph::Node Node;
   855 
   856     /// Pointer to the underlying graph.
   857     void *_g;
   858     ///Pointer to the map of reached nodes.
   859     void *_reached;
   860     ///Pointer to the map of processed nodes.
   861     void *_processed;
   862     ///Pointer to the map of predecessors edges.
   863     void *_pred;
   864     ///Pointer to the map of distances.
   865     void *_dist;
   866     ///Pointer to the source node.
   867     Node _source;
   868     
   869     public:
   870     /// Constructor.
   871     
   872     /// This constructor does not require parameters, therefore it initiates
   873     /// all of the attributes to default values (0, INVALID).
   874     BfsWizardBase() : _g(0), _reached(0), _processed(0), _pred(0),
   875 			   _dist(0), _source(INVALID) {}
   876 
   877     /// Constructor.
   878     
   879     /// This constructor requires some parameters,
   880     /// listed in the parameters list.
   881     /// Others are initiated to 0.
   882     /// \param g is the initial value of  \ref _g
   883     /// \param s is the initial value of  \ref _source
   884     BfsWizardBase(const GR &g, Node s=INVALID) :
   885       _g(reinterpret_cast<void*>(const_cast<GR*>(&g))), 
   886       _reached(0), _processed(0), _pred(0), _dist(0), _source(s) {}
   887 
   888   };
   889   
   890   /// A class to make the usage of Bfs algorithm easier
   891 
   892   /// This class is created to make it easier to use Bfs algorithm.
   893   /// It uses the functions and features of the plain \ref Bfs,
   894   /// but it is much simpler to use it.
   895   ///
   896   /// Simplicity means that the way to change the types defined
   897   /// in the traits class is based on functions that returns the new class
   898   /// and not on templatable built-in classes.
   899   /// When using the plain \ref Bfs
   900   /// the new class with the modified type comes from
   901   /// the original class by using the ::
   902   /// operator. In the case of \ref BfsWizard only
   903   /// a function have to be called and it will
   904   /// return the needed class.
   905   ///
   906   /// It does not have own \ref run method. When its \ref run method is called
   907   /// it initiates a plain \ref Bfs class, and calls the \ref Bfs::run
   908   /// method of it.
   909   template<class TR>
   910   class BfsWizard : public TR
   911   {
   912     typedef TR Base;
   913 
   914     ///The type of the underlying graph.
   915     typedef typename TR::Graph Graph;
   916     //\e
   917     typedef typename Graph::Node Node;
   918     //\e
   919     typedef typename Graph::NodeIt NodeIt;
   920     //\e
   921     typedef typename Graph::Edge Edge;
   922     //\e
   923     typedef typename Graph::OutEdgeIt OutEdgeIt;
   924     
   925     ///\brief The type of the map that stores
   926     ///the reached nodes
   927     typedef typename TR::ReachedMap ReachedMap;
   928     ///\brief The type of the map that stores
   929     ///the processed nodes
   930     typedef typename TR::ProcessedMap ProcessedMap;
   931     ///\brief The type of the map that stores the last
   932     ///edges of the shortest paths.
   933     typedef typename TR::PredMap PredMap;
   934     ///The type of the map that stores the dists of the nodes.
   935     typedef typename TR::DistMap DistMap;
   936 
   937   public:
   938     /// Constructor.
   939     BfsWizard() : TR() {}
   940 
   941     /// Constructor that requires parameters.
   942 
   943     /// Constructor that requires parameters.
   944     /// These parameters will be the default values for the traits class.
   945     BfsWizard(const Graph &g, Node s=INVALID) :
   946       TR(g,s) {}
   947 
   948     ///Copy constructor
   949     BfsWizard(const TR &b) : TR(b) {}
   950 
   951     ~BfsWizard() {}
   952 
   953     ///Runs Bfs algorithm from a given node.
   954     
   955     ///Runs Bfs algorithm from a given node.
   956     ///The node can be given by the \ref source function.
   957     void run()
   958     {
   959       if(Base::_source==INVALID) throw UninitializedParameter();
   960       Bfs<Graph,TR> alg(*reinterpret_cast<const Graph*>(Base::_g));
   961       if(Base::_reached)
   962 	alg.reachedMap(*reinterpret_cast<ReachedMap*>(Base::_reached));
   963       if(Base::_processed) 
   964         alg.processedMap(*reinterpret_cast<ProcessedMap*>(Base::_processed));
   965       if(Base::_pred) 
   966         alg.predMap(*reinterpret_cast<PredMap*>(Base::_pred));
   967       if(Base::_dist) 
   968         alg.distMap(*reinterpret_cast<DistMap*>(Base::_dist));
   969       alg.run(Base::_source);
   970     }
   971 
   972     ///Runs Bfs algorithm from the given node.
   973 
   974     ///Runs Bfs algorithm from the given node.
   975     ///\param s is the given source.
   976     void run(Node s)
   977     {
   978       Base::_source=s;
   979       run();
   980     }
   981 
   982     template<class T>
   983     struct DefPredMapBase : public Base {
   984       typedef T PredMap;
   985       static PredMap *createPredMap(const Graph &) { return 0; };
   986       DefPredMapBase(const TR &b) : TR(b) {}
   987     };
   988     
   989     ///\brief \ref named-templ-param "Named parameter"
   990     ///function for setting PredMap
   991     ///
   992     /// \ref named-templ-param "Named parameter"
   993     ///function for setting PredMap
   994     ///
   995     template<class T>
   996     BfsWizard<DefPredMapBase<T> > predMap(const T &t) 
   997     {
   998       Base::_pred=reinterpret_cast<void*>(const_cast<T*>(&t));
   999       return BfsWizard<DefPredMapBase<T> >(*this);
  1000     }
  1001     
  1002  
  1003     template<class T>
  1004     struct DefReachedMapBase : public Base {
  1005       typedef T ReachedMap;
  1006       static ReachedMap *createReachedMap(const Graph &) { return 0; };
  1007       DefReachedMapBase(const TR &b) : TR(b) {}
  1008     };
  1009     
  1010     ///\brief \ref named-templ-param "Named parameter"
  1011     ///function for setting ReachedMap
  1012     ///
  1013     /// \ref named-templ-param "Named parameter"
  1014     ///function for setting ReachedMap
  1015     ///
  1016     template<class T>
  1017     BfsWizard<DefReachedMapBase<T> > reachedMap(const T &t) 
  1018     {
  1019       Base::_pred=reinterpret_cast<void*>(const_cast<T*>(&t));
  1020       return BfsWizard<DefReachedMapBase<T> >(*this);
  1021     }
  1022     
  1023 
  1024     template<class T>
  1025     struct DefProcessedMapBase : public Base {
  1026       typedef T ProcessedMap;
  1027       static ProcessedMap *createProcessedMap(const Graph &) { return 0; };
  1028       DefProcessedMapBase(const TR &b) : TR(b) {}
  1029     };
  1030     
  1031     ///\brief \ref named-templ-param "Named parameter"
  1032     ///function for setting ProcessedMap
  1033     ///
  1034     /// \ref named-templ-param "Named parameter"
  1035     ///function for setting ProcessedMap
  1036     ///
  1037     template<class T>
  1038     BfsWizard<DefProcessedMapBase<T> > processedMap(const T &t) 
  1039     {
  1040       Base::_pred=reinterpret_cast<void*>(const_cast<T*>(&t));
  1041       return BfsWizard<DefProcessedMapBase<T> >(*this);
  1042     }
  1043     
  1044    
  1045     template<class T>
  1046     struct DefDistMapBase : public Base {
  1047       typedef T DistMap;
  1048       static DistMap *createDistMap(const Graph &) { return 0; };
  1049       DefDistMapBase(const TR &b) : TR(b) {}
  1050     };
  1051     
  1052     ///\brief \ref named-templ-param "Named parameter"
  1053     ///function for setting DistMap type
  1054     ///
  1055     /// \ref named-templ-param "Named parameter"
  1056     ///function for setting DistMap type
  1057     ///
  1058     template<class T>
  1059     BfsWizard<DefDistMapBase<T> > distMap(const T &t) 
  1060     {
  1061       Base::_dist=reinterpret_cast<void*>(const_cast<T*>(&t));
  1062       return BfsWizard<DefDistMapBase<T> >(*this);
  1063     }
  1064     
  1065     /// Sets the source node, from which the Bfs algorithm runs.
  1066 
  1067     /// Sets the source node, from which the Bfs algorithm runs.
  1068     /// \param s is the source node.
  1069     BfsWizard<TR> &source(Node s) 
  1070     {
  1071       Base::_source=s;
  1072       return *this;
  1073     }
  1074     
  1075   };
  1076   
  1077   ///Function type interface for Bfs algorithm.
  1078 
  1079   /// \ingroup search
  1080   ///Function type interface for Bfs algorithm.
  1081   ///
  1082   ///This function also has several
  1083   ///\ref named-templ-func-param "named parameters",
  1084   ///they are declared as the members of class \ref BfsWizard.
  1085   ///The following
  1086   ///example shows how to use these parameters.
  1087   ///\code
  1088   ///  bfs(g,source).predMap(preds).run();
  1089   ///\endcode
  1090   ///\warning Don't forget to put the \ref BfsWizard::run() "run()"
  1091   ///to the end of the parameter list.
  1092   ///\sa BfsWizard
  1093   ///\sa Bfs
  1094   template<class GR>
  1095   BfsWizard<BfsWizardBase<GR> >
  1096   bfs(const GR &g,typename GR::Node s=INVALID)
  1097   {
  1098     return BfsWizard<BfsWizardBase<GR> >(g,s);
  1099   }
  1100 
  1101 #ifdef DOXYGEN
  1102   /// \brief Visitor class for bfs.
  1103   ///  
  1104   /// It gives a simple interface for a functional interface for bfs 
  1105   /// traversal. The traversal on a linear data structure. 
  1106   template <typename _Graph>
  1107   struct BfsVisitor {
  1108     typedef _Graph Graph;
  1109     typedef typename Graph::Edge Edge;
  1110     typedef typename Graph::Node Node;
  1111     /// \brief Called when the edge reach a node.
  1112     /// 
  1113     /// It is called when the bfs find an edge which target is not
  1114     /// reached yet.
  1115     void discover(const Edge& edge) {}
  1116     /// \brief Called when the node reached first time.
  1117     /// 
  1118     /// It is Called when the node reached first time.
  1119     void reach(const Node& node) {}
  1120     /// \brief Called when the edge examined but target of the edge 
  1121     /// already discovered.
  1122     /// 
  1123     /// It called when the edge examined but the target of the edge 
  1124     /// already discovered.
  1125     void examine(const Edge& edge) {}
  1126     /// \brief Called for the source node of the bfs.
  1127     /// 
  1128     /// It is called for the source node of the bfs.
  1129     void start(const Node& node) {}
  1130     /// \brief Called when the node processed.
  1131     /// 
  1132     /// It is Called when the node processed.
  1133     void process(const Node& node) {}
  1134   };
  1135 #else
  1136   template <typename _Graph>
  1137   struct BfsVisitor {
  1138     typedef _Graph Graph;
  1139     typedef typename Graph::Edge Edge;
  1140     typedef typename Graph::Node Node;
  1141     void discover(const Edge&) {}
  1142     void reach(const Node&) {}
  1143     void examine(const Edge&) {}
  1144     void start(const Node&) {}
  1145     void process(const Node&) {}
  1146 
  1147     template <typename _Visitor>
  1148     struct Constraints {
  1149       void constraints() {
  1150 	Edge edge;
  1151 	Node node;
  1152 	visitor.discover(edge);
  1153 	visitor.reach(node);
  1154 	visitor.examine(edge);
  1155 	visitor.start(node);
  1156         visitor.process(node);
  1157       }
  1158       _Visitor& visitor;
  1159     };
  1160   };
  1161 #endif
  1162 
  1163   /// \brief Default traits class of BfsVisit class.
  1164   ///
  1165   /// Default traits class of BfsVisit class.
  1166   /// \param _Graph Graph type.
  1167   template<class _Graph>
  1168   struct BfsVisitDefaultTraits {
  1169 
  1170     /// \brief The graph type the algorithm runs on. 
  1171     typedef _Graph Graph;
  1172 
  1173     /// \brief The type of the map that indicates which nodes are reached.
  1174     /// 
  1175     /// The type of the map that indicates which nodes are reached.
  1176     /// It must meet the \ref concepts::WriteMap "WriteMap" concept.
  1177     /// \todo named parameter to set this type, function to read and write.
  1178     typedef typename Graph::template NodeMap<bool> ReachedMap;
  1179 
  1180     /// \brief Instantiates a ReachedMap.
  1181     ///
  1182     /// This function instantiates a \ref ReachedMap. 
  1183     /// \param graph is the graph, to which
  1184     /// we would like to define the \ref ReachedMap.
  1185     static ReachedMap *createReachedMap(const Graph &graph) {
  1186       return new ReachedMap(graph);
  1187     }
  1188 
  1189   };
  1190   
  1191   /// %BFS Visit algorithm class.
  1192   
  1193   /// \ingroup search
  1194   /// This class provides an efficient implementation of the %BFS algorithm
  1195   /// with visitor interface.
  1196   ///
  1197   /// The %BfsVisit class provides an alternative interface to the Bfs
  1198   /// class. It works with callback mechanism, the BfsVisit object calls
  1199   /// on every bfs event the \c Visitor class member functions. 
  1200   ///
  1201   /// \param _Graph The graph type the algorithm runs on. The default value is
  1202   /// \ref ListGraph. The value of _Graph is not used directly by Bfs, it
  1203   /// is only passed to \ref BfsDefaultTraits.
  1204   /// \param _Visitor The Visitor object for the algorithm. The 
  1205   /// \ref BfsVisitor "BfsVisitor<_Graph>" is an empty Visitor which
  1206   /// does not observe the Bfs events. If you want to observe the bfs
  1207   /// events you should implement your own Visitor class.
  1208   /// \param _Traits Traits class to set various data types used by the 
  1209   /// algorithm. The default traits class is
  1210   /// \ref BfsVisitDefaultTraits "BfsVisitDefaultTraits<_Graph>".
  1211   /// See \ref BfsVisitDefaultTraits for the documentation of
  1212   /// a Bfs visit traits class.
  1213   ///
  1214   /// \author Jacint Szabo, Alpar Juttner and Balazs Dezso
  1215 #ifdef DOXYGEN
  1216   template <typename _Graph, typename _Visitor, typename _Traits>
  1217 #else
  1218   template <typename _Graph = ListGraph,
  1219 	    typename _Visitor = BfsVisitor<_Graph>,
  1220 	    typename _Traits = BfsDefaultTraits<_Graph> >
  1221 #endif
  1222   class BfsVisit {
  1223   public:
  1224     
  1225     /// \brief \ref Exception for uninitialized parameters.
  1226     ///
  1227     /// This error represents problems in the initialization
  1228     /// of the parameters of the algorithms.
  1229     class UninitializedParameter : public lemon::UninitializedParameter {
  1230     public:
  1231       virtual const char* what() const throw() 
  1232       {
  1233 	return "lemon::BfsVisit::UninitializedParameter";
  1234       }
  1235     };
  1236 
  1237     typedef _Traits Traits;
  1238 
  1239     typedef typename Traits::Graph Graph;
  1240 
  1241     typedef _Visitor Visitor;
  1242 
  1243     ///The type of the map indicating which nodes are reached.
  1244     typedef typename Traits::ReachedMap ReachedMap;
  1245 
  1246   private:
  1247 
  1248     typedef typename Graph::Node Node;
  1249     typedef typename Graph::NodeIt NodeIt;
  1250     typedef typename Graph::Edge Edge;
  1251     typedef typename Graph::OutEdgeIt OutEdgeIt;
  1252 
  1253     /// Pointer to the underlying graph.
  1254     const Graph *_graph;
  1255     /// Pointer to the visitor object.
  1256     Visitor *_visitor;
  1257     ///Pointer to the map of reached status of the nodes.
  1258     ReachedMap *_reached;
  1259     ///Indicates if \ref _reached is locally allocated (\c true) or not.
  1260     bool local_reached;
  1261 
  1262     std::vector<typename Graph::Node> _list;
  1263     int _list_front, _list_back;
  1264 
  1265     /// \brief Creates the maps if necessary.
  1266     ///
  1267     /// Creates the maps if necessary.
  1268     void create_maps() {
  1269       if(!_reached) {
  1270 	local_reached = true;
  1271 	_reached = Traits::createReachedMap(*_graph);
  1272       }
  1273     }
  1274 
  1275   protected:
  1276 
  1277     BfsVisit() {}
  1278     
  1279   public:
  1280 
  1281     typedef BfsVisit Create;
  1282 
  1283     /// \name Named template parameters
  1284 
  1285     ///@{
  1286     template <class T>
  1287     struct DefReachedMapTraits : public Traits {
  1288       typedef T ReachedMap;
  1289       static ReachedMap *createReachedMap(const Graph &graph) {
  1290 	throw UninitializedParameter();
  1291       }
  1292     };
  1293     /// \brief \ref named-templ-param "Named parameter" for setting 
  1294     /// ReachedMap type
  1295     ///
  1296     /// \ref named-templ-param "Named parameter" for setting ReachedMap type
  1297     template <class T>
  1298     struct DefReachedMap : public BfsVisit< Graph, Visitor,
  1299 					    DefReachedMapTraits<T> > {
  1300       typedef BfsVisit< Graph, Visitor, DefReachedMapTraits<T> > Create;
  1301     };
  1302     ///@}
  1303 
  1304   public:      
  1305     
  1306     /// \brief Constructor.
  1307     ///
  1308     /// Constructor.
  1309     ///
  1310     /// \param graph the graph the algorithm will run on.
  1311     /// \param visitor The visitor of the algorithm.
  1312     ///
  1313     BfsVisit(const Graph& graph, Visitor& visitor) 
  1314       : _graph(&graph), _visitor(&visitor),
  1315 	_reached(0), local_reached(false) {}
  1316     
  1317     /// \brief Destructor.
  1318     ///
  1319     /// Destructor.
  1320     ~BfsVisit() {
  1321       if(local_reached) delete _reached;
  1322     }
  1323 
  1324     /// \brief Sets the map indicating if a node is reached.
  1325     ///
  1326     /// Sets the map indicating if a node is reached.
  1327     /// If you don't use this function before calling \ref run(),
  1328     /// it will allocate one. The destuctor deallocates this
  1329     /// automatically allocated map, of course.
  1330     /// \return <tt> (*this) </tt>
  1331     BfsVisit &reachedMap(ReachedMap &m) {
  1332       if(local_reached) {
  1333 	delete _reached;
  1334 	local_reached = false;
  1335       }
  1336       _reached = &m;
  1337       return *this;
  1338     }
  1339 
  1340   public:
  1341     /// \name Execution control
  1342     /// The simplest way to execute the algorithm is to use
  1343     /// one of the member functions called \c run(...).
  1344     /// \n
  1345     /// If you need more control on the execution,
  1346     /// first you must call \ref init(), then you can adda source node
  1347     /// with \ref addSource().
  1348     /// Finally \ref start() will perform the actual path
  1349     /// computation.
  1350 
  1351     /// @{
  1352     /// \brief Initializes the internal data structures.
  1353     ///
  1354     /// Initializes the internal data structures.
  1355     ///
  1356     void init() {
  1357       create_maps();
  1358       _list.resize(countNodes(*_graph));
  1359       _list_front = _list_back = -1;
  1360       for (NodeIt u(*_graph) ; u != INVALID ; ++u) {
  1361 	_reached->set(u, false);
  1362       }
  1363     }
  1364     
  1365     /// \brief Adds a new source node.
  1366     ///
  1367     /// Adds a new source node to the set of nodes to be processed.
  1368     void addSource(Node s) {
  1369       if(!(*_reached)[s]) {
  1370 	  _reached->set(s,true);
  1371 	  _visitor->start(s);
  1372 	  _visitor->reach(s);
  1373           _list[++_list_back] = s;
  1374 	}
  1375     }
  1376     
  1377     /// \brief Processes the next node.
  1378     ///
  1379     /// Processes the next node.
  1380     ///
  1381     /// \return The processed node.
  1382     ///
  1383     /// \pre The queue must not be empty!
  1384     Node processNextNode() { 
  1385       Node n = _list[++_list_front];
  1386       _visitor->process(n);
  1387       Edge e;
  1388       for (_graph->firstOut(e, n); e != INVALID; _graph->nextOut(e)) {
  1389         Node m = _graph->target(e);
  1390         if (!(*_reached)[m]) {
  1391           _visitor->discover(e);
  1392           _visitor->reach(m);
  1393           _reached->set(m, true);
  1394           _list[++_list_back] = m;
  1395         } else {
  1396           _visitor->examine(e);
  1397         }
  1398       }
  1399       return n;
  1400     }
  1401 
  1402     /// \brief Processes the next node.
  1403     ///
  1404     /// Processes the next node. And checks that the given target node
  1405     /// is reached. If the target node is reachable from the processed
  1406     /// node then the reached parameter will be set true. The reached
  1407     /// parameter should be initially false.
  1408     ///
  1409     /// \param target The target node.
  1410     /// \retval reach Indicates that the target node is reached.
  1411     /// \return The processed node.
  1412     ///
  1413     /// \warning The queue must not be empty!
  1414     Node processNextNode(Node target, bool& reach) {
  1415       Node n = _list[++_list_front];
  1416       _visitor->process(n);
  1417       Edge e;
  1418       for (_graph->firstOut(e, n); e != INVALID; _graph->nextOut(e)) {
  1419         Node m = _graph->target(e);
  1420         if (!(*_reached)[m]) {
  1421           _visitor->discover(e);
  1422           _visitor->reach(m);
  1423           _reached->set(m, true);
  1424           _list[++_list_back] = m;
  1425           reach = reach || (target == m);
  1426         } else {
  1427           _visitor->examine(e);
  1428         }
  1429       }
  1430       return n;
  1431     }
  1432 
  1433     /// \brief Processes the next node.
  1434     ///
  1435     /// Processes the next node. And checks that at least one of
  1436     /// reached node has true value in the \c nm nodemap. If one node
  1437     /// with true value is reachable from the processed node then the
  1438     /// reached parameter will be set true. The reached parameter
  1439     /// should be initially false.
  1440     ///
  1441     /// \param nm The nodemaps of possible targets.
  1442     /// \retval reached Indicates that one of the target nodes is reached.
  1443     /// \return The processed node.
  1444     ///
  1445     /// \warning The queue must not be empty!
  1446     template <typename NM>
  1447     Node processNextNode(const NM& nm, bool& reach) {
  1448       Node n = _list[++_list_front];
  1449       _visitor->process(n);
  1450       Edge e;
  1451       for (_graph->firstOut(e, n); e != INVALID; _graph->nextOut(e)) {
  1452         Node m = _graph->target(e);
  1453         if (!(*_reached)[m]) {
  1454           _visitor->discover(e);
  1455           _visitor->reach(m);
  1456           _reached->set(m, true);
  1457           _list[++_list_back] = m;
  1458           reach = reach || nm[m];
  1459         } else {
  1460           _visitor->examine(e);
  1461         }
  1462       }
  1463       return n;
  1464     }
  1465 
  1466     /// \brief Next node to be processed.
  1467     ///
  1468     /// Next node to be processed.
  1469     ///
  1470     /// \return The next node to be processed or INVALID if the stack is
  1471     /// empty.
  1472     Node nextNode() { 
  1473       return _list_front != _list_back ? _list[_list_front + 1] : INVALID;
  1474     }
  1475 
  1476     /// \brief Returns \c false if there are nodes
  1477     /// to be processed in the queue
  1478     ///
  1479     /// Returns \c false if there are nodes
  1480     /// to be processed in the queue
  1481     bool emptyQueue() { return _list_front == _list_back; }
  1482 
  1483     /// \brief Returns the number of the nodes to be processed.
  1484     ///
  1485     /// Returns the number of the nodes to be processed in the queue.
  1486     int queueSize() { return _list_back - _list_front; }
  1487     
  1488     /// \brief Executes the algorithm.
  1489     ///
  1490     /// Executes the algorithm.
  1491     ///
  1492     /// \pre init() must be called and at least one node should be added
  1493     /// with addSource() before using this function.
  1494     void start() {
  1495       while ( !emptyQueue() ) processNextNode();
  1496     }
  1497     
  1498     /// \brief Executes the algorithm until \c dest is reached.
  1499     ///
  1500     /// Executes the algorithm until \c dest is reached.
  1501     ///
  1502     /// \pre init() must be called and at least one node should be added
  1503     /// with addSource() before using this function.
  1504     void start(Node dest) {
  1505       bool reach = false;
  1506       while (!emptyQueue() && !reach) { 
  1507 	processNextNode(dest, reach);
  1508       }
  1509     }
  1510     
  1511     /// \brief Executes the algorithm until a condition is met.
  1512     ///
  1513     /// Executes the algorithm until a condition is met.
  1514     ///
  1515     /// \pre init() must be called and at least one node should be added
  1516     /// with addSource() before using this function.
  1517     ///
  1518     ///\param nm must be a bool (or convertible) node map. The
  1519     ///algorithm will stop when it reached a node \c v with
  1520     /// <tt>nm[v]</tt> true.
  1521     template <typename NM>
  1522     void start(const NM &nm) {
  1523       bool reach = false;
  1524       while (!emptyQueue() && !reach) {
  1525         processNextNode(nm, reach);
  1526       }
  1527     }
  1528 
  1529     /// \brief Runs %BFSVisit algorithm from node \c s.
  1530     ///
  1531     /// This method runs the %BFS algorithm from a root node \c s.
  1532     /// \note b.run(s) is just a shortcut of the following code.
  1533     ///\code
  1534     ///   b.init();
  1535     ///   b.addSource(s);
  1536     ///   b.start();
  1537     ///\endcode
  1538     void run(Node s) {
  1539       init();
  1540       addSource(s);
  1541       start();
  1542     }
  1543 
  1544     /// \brief Runs %BFSVisit algorithm to visit all nodes in the graph.
  1545     ///    
  1546     /// This method runs the %BFS algorithm in order to
  1547     /// compute the %BFS path to each node. The algorithm computes
  1548     /// - The %BFS tree.
  1549     /// - The distance of each node from the root in the %BFS tree.
  1550     ///
  1551     ///\note b.run() is just a shortcut of the following code.
  1552     ///\code
  1553     ///  b.init();
  1554     ///  for (NodeIt it(graph); it != INVALID; ++it) {
  1555     ///    if (!b.reached(it)) {
  1556     ///      b.addSource(it);
  1557     ///      b.start();
  1558     ///    }
  1559     ///  }
  1560     ///\endcode
  1561     void run() {
  1562       init();
  1563       for (NodeIt it(*_graph); it != INVALID; ++it) {
  1564         if (!reached(it)) {
  1565           addSource(it);
  1566           start();
  1567         }
  1568       }
  1569     }
  1570     ///@}
  1571 
  1572     /// \name Query Functions
  1573     /// The result of the %BFS algorithm can be obtained using these
  1574     /// functions.\n
  1575     /// Before the use of these functions,
  1576     /// either run() or start() must be called.
  1577     ///@{
  1578 
  1579     /// \brief Checks if a node is reachable from the root.
  1580     ///
  1581     /// Returns \c true if \c v is reachable from the root(s).
  1582     /// \warning The source nodes are inditated as unreachable.
  1583     /// \pre Either \ref run() or \ref start()
  1584     /// must be called before using this function.
  1585     ///
  1586     bool reached(Node v) { return (*_reached)[v]; }
  1587     ///@}
  1588   };
  1589 
  1590 } //END OF NAMESPACE LEMON
  1591 
  1592 #endif
  1593