COIN-OR::LEMON - Graph Library

Changeset 615:b6b31b75b522 in lemon-0.x for src/work/marci


Ignore:
Timestamp:
05/11/04 21:50:21 (21 years ago)
Author:
marci
Branch:
default
Phase:
public
Convert:
svn:c9d7d8f5-90d6-0310-b91f-818b3a526b0e/lemon/trunk@800
Message:

docs, max_flow improvments

Location:
src/work/marci
Files:
1 added
4 edited

Legend:

Unmodified
Added
Removed
  • src/work/marci/bfs_dfs.h

    r604 r615  
    33#define HUGO_BFS_DFS_H
    44
    5 // ///\ingroup gwrappers
    6 ///\file
    7 ///\brief Bfs and dfs iterators.
     5/// \ingroup galgs
     6/// \file
     7/// \brief Bfs and dfs iterators.
    88///
    9 ///This file contains bfs and dfs iterator classes.
     9/// This file contains bfs and dfs iterator classes.
    1010///
    11 // ///\author Marton Makai
     11// /// \author Marton Makai
    1212
    1313#include <queue>
     
    2222  /// \c reached_map
    2323  /// Reached have to work as read-write bool Node-map.
     24  /// \ingroup galgs
    2425  template <typename Graph, /*typename OutEdgeIt,*/
    2526            typename ReachedMap/*=typename Graph::NodeMap<bool>*/ >
     
    106107      return *this;
    107108    }
    108     ///
     109    /// Guess what?
    109110    bool finished() const { return bfs_queue.empty(); }
    110111    /// The conversion operator makes for converting the bfs-iterator
     
    112113    ///\bug Edge have to be in HUGO 0.2
    113114    operator OutEdgeIt() const { return actual_edge; }
    114     ///
     115    /// Guess what?
    115116    bool isBNodeNewlyReached() const { return b_node_newly_reached; }
    116     ///
     117    /// Guess what?
    117118    bool isANodeExamined() const { return !(graph->valid(actual_edge)); }
    118     ///
     119    /// Guess what?
    119120    Node aNode() const { return bfs_queue.front(); }
    120     ///
     121    /// Guess what?
    121122    Node bNode() const { return graph->bNode(actual_edge); }
    122     ///
     123    /// Guess what?
    123124    const ReachedMap& getReachedMap() const { return reached; }
    124     ///
     125    /// Guess what?
    125126    const std::queue<Node>& getBfsQueue() const { return bfs_queue; }
    126   }; 
     127  };
    127128
    128129  /// Bfs searches for the nodes wich are not marked in
     
    130131  /// Reached have to work as a read-write bool Node-map,
    131132  /// Pred is a write Edge Node-map and
    132   /// Dist is a read-write int Node-map, have to be.
    133   ///\todo In fact onsly simple operations requirement are needed for
    134   /// Dist::Value.
     133  /// Dist is a read-write Node-map of integral value, have to be.
     134  /// \ingroup galgs
    135135  template <typename Graph,
    136136            typename ReachedMap=typename Graph::template NodeMap<bool>,
     
    179179      return *this;
    180180    }
    181     ///
     181    /// Guess what?
    182182    const PredMap& getPredMap() const { return pred; }
    183     ///
     183    /// Guess what?
    184184    const DistMap& getDistMap() const { return dist; }
    185185  };
     
    188188  /// \c reached_map
    189189  /// Reached have to be a read-write bool Node-map.
     190  /// \ingroup galgs
    190191  template <typename Graph, /*typename OutEdgeIt,*/
    191192            typename ReachedMap/*=typename Graph::NodeMap<bool>*/ >
     
    249250      return *this;
    250251    }
    251     ///
     252    /// Guess what?
    252253    bool finished() const { return dfs_stack.empty(); }
    253     ///
     254    /// Guess what?
    254255    operator OutEdgeIt() const { return actual_edge; }
    255     ///
     256    /// Guess what?
    256257    bool isBNodeNewlyReached() const { return b_node_newly_reached; }
    257     ///
     258    /// Guess what?
    258259    bool isANodeExamined() const { return !(graph->valid(actual_edge)); }
    259     ///
     260    /// Guess what?
    260261    Node aNode() const { return actual_node; /*FIXME*/}
    261     ///
     262    /// Guess what?
    262263    Node bNode() const { return graph->bNode(actual_edge); }
    263     ///
     264    /// Guess what?
    264265    const ReachedMap& getReachedMap() const { return reached; }
    265     ///
     266    /// Guess what?
    266267    const std::stack<OutEdgeIt>& getDfsStack() const { return dfs_stack; }
    267268  };
     
    271272  /// Reached is a read-write bool Node-map,
    272273  /// Pred is a write Node-map, have to be.
     274  /// \ingroup galgs
    273275  template <typename Graph,
    274276            typename ReachedMap=typename Graph::template NodeMap<bool>,
     
    313315      return *this;
    314316    }
    315     ///
     317    /// Guess what?
    316318    const PredMap& getPredMap() const { return pred; }
    317319  };
  • src/work/marci/bfs_dfs_misc.h

    r604 r615  
    33#define HUGO_BFS_DFS_MISC_H
    44
    5 // ///\ingroup gwrappers
    6 ///\file
    7 ///\brief Miscellaneous algorithms using bfs and dfs.
     5/// \ingroup galgs
     6/// \file
     7/// \brief Miscellaneous algorithms using bfs and dfs.
    88///
    9 ///This file contains several algorithms using bfs and dfs.
     9/// This file contains several algorithms using bfs and dfs.
    1010///
    1111// ///\author Marton Makai
     
    1616namespace hugo {
    1717
    18   /// This function eat a read-write \c BoolMap& bool_map,
     18  /// This function eats a read-write \c BoolMap& bool_map,
    1919  /// which have to work well up
    2020  /// to its \c set and \c operator[]() method. Thus we have to deal
    2121  /// very carefully with an uninitialized \c IterableBoolMap.
     22  /// \ingroup galgs
    2223  template<typename Graph, typename BoolMap>
    2324  bool isBipartite(const Graph& g, BoolMap& bool_map) {
     
    5354  /// then going back from the returned node via the pred information, a
    5455  /// cycle is obtained.
     56  /// \ingroup galgs
    5557  template<typename Graph, typename PredMap>
    5658  typename Graph::Node
     
    9092    return INVALID;
    9193  }
     94
    9295} //namespace hugo
    9396
  • src/work/marci/makefile

    r613 r615  
    55
    66LEDABINARIES = leda_graph_demo leda_bfs_dfs max_bipartite_matching_demo
    7 BINARIES = max_flow_demo iterator_bfs_demo macro_test lg_vs_sg bfsit_vs_byhand bipartite_graph_wrapper_test bipartite_matching_try bipartite_matching_try_3 top_sort_test
     7BINARIES = max_flow_demo iterator_bfs_demo macro_test lg_vs_sg bfsit_vs_byhand bipartite_graph_wrapper_test bipartite_matching_try bipartite_matching_try_3 top_sort_test max_flow_1
    88#gw_vs_not preflow_demo_boost edmonds_karp_demo_boost preflow_demo_jacint preflow_demo_athos edmonds_karp_demo_alpar preflow_demo_leda
    99
  • src/work/marci/max_bipartite_matching.h

    r613 r615  
    22#ifndef HUGO_MAX_BIPARTITE_MATCHING_H
    33#define HUGO_MAX_BIPARTITE_MATCHING_H
     4
     5/// \ingroup galgs
     6/// \file
     7/// \brief Maximum bipartite matchings, b-matchings and
     8/// capacitated b-matchings.
     9///
     10/// This file contains a class for bipartite maximum matching, b-matchings
     11/// and capacitated b-matching computations.
     12///
     13// /// \author Marton Makai
    414
    515//#include <for_each_macros.h>
Note: See TracChangeset for help on using the changeset viewer.