# HG changeset patch # User deba # Date 1144403675 0 # Node ID bdc953f2a449cd973456093f1c6f7e666256b067 # Parent 28df5272df99c3cb287f8dfc868694149310a528 New Algorithm group for matchings LaTeX formulas Bug fix => ///\f$ will cause parsing error in doxygen diff -r 28df5272df99 -r bdc953f2a449 demo/tight_edge_filter_map.h --- a/demo/tight_edge_filter_map.h Fri Apr 07 09:52:30 2006 +0000 +++ b/demo/tight_edge_filter_map.h Fri Apr 07 09:54:35 2006 +0000 @@ -32,14 +32,14 @@ which are tight w.r.t. a node-potential and edge-distance. - Let \f$G=(V,A)\f$ be a directed graph (graph for short) and - let \f$\mathbb{F}\f$ be a number type. + Let \f$ G=(V,A) \f$ be a directed graph (graph for short) and + let \f$ \mathbb{F} \f$ be a number type. Given a distance function - \f$d:E\to\mathbb{F}\f$, - \f$\pi:V\to\mathbb{F}\f$ is said to be a potetial - w.r.t. \f$d\f$ + \f$ d:E\to\mathbb{F} \f$, + \f$ \pi:V\to\mathbb{F} \f$ is said to be a potetial + w.r.t. \f$ d \f$ if and only if - \f$\pi(v)\le d(uv)+\pi(u)\f$ holds for each edge \f$uv\in E\f$ + \f$ \pi(v)\le d(uv)+\pi(u) \f$ holds for each edge \f$ uv\in E \f$ (or the reverse inequality holds for each edge). An edge is said to be tight if this inequality holds with equality, and the map returns \c true exactly for those edges. diff -r 28df5272df99 -r bdc953f2a449 doc/groups.dox --- a/doc/groups.dox Fri Apr 07 09:52:30 2006 +0000 +++ b/doc/groups.dox Fri Apr 07 09:54:35 2006 +0000 @@ -141,6 +141,13 @@ */ /** +@defgroup matching Matching algorithms in graphs and bipartite graphs +@ingroup galgs +\brief This group describes the algorithms +for find matchings in graphs and bipartite graphs. +*/ + +/** @defgroup exceptions Exceptions This group contains the exceptions thrown by LEMON library */ diff -r 28df5272df99 -r bdc953f2a449 lemon/bellman_ford.h --- a/lemon/bellman_ford.h Fri Apr 07 09:52:30 2006 +0000 +++ b/lemon/bellman_ford.h Fri Apr 07 09:54:35 2006 +0000 @@ -155,7 +155,7 @@ /// that all edge is non-negative in the graph then the dijkstra algorithm /// should be used rather. /// - /// The complexity of the algorithm is O(n * e). + /// The maximal time complexity of the algorithm is \f$ O(ne) \f$. /// /// The type of the length is determined by the /// \ref concept::ReadMap::Value "Value" of the length map. diff -r 28df5272df99 -r bdc953f2a449 lemon/bucket_heap.h --- a/lemon/bucket_heap.h Fri Apr 07 09:52:30 2006 +0000 +++ b/lemon/bucket_heap.h Fri Apr 07 09:54:35 2006 +0000 @@ -37,9 +37,9 @@ /// is a data structure for storing items with specified values called \e /// priorities in such a way that finding the item with minimum priority is /// efficient. The bucket heap is very simple implementation, it can store - /// only integer priorities and it stores for each priority in the [0..C] - /// range a list of items. So it should be used only when the priorities - /// are small. It is not intended to use as dijkstra heap. + /// only integer priorities and it stores for each priority in the + /// \f$ [0..C) \f$ range a list of items. So it should be used only when + /// the priorities are small. It is not intended to use as dijkstra heap. /// /// \param _Item Type of the items to be stored. /// \param _ItemIntMap A read and writable Item int map, used internally diff -r 28df5272df99 -r bdc953f2a449 lemon/floyd_warshall.h --- a/lemon/floyd_warshall.h Fri Apr 07 09:52:30 2006 +0000 +++ b/lemon/floyd_warshall.h Fri Apr 07 09:54:35 2006 +0000 @@ -159,7 +159,7 @@ /// should be used from each node rather and if the graph is sparse and /// there are negative circles then the johnson algorithm. /// - /// The complexity of this algorithm is O(n^3 + e). + /// The complexity of this algorithm is \f$ O(n^3+e) \f$. /// /// The type of the length is determined by the /// \ref concept::ReadMap::Value "Value" of the length map. diff -r 28df5272df99 -r bdc953f2a449 lemon/fredman_tarjan.h --- a/lemon/fredman_tarjan.h Fri Apr 07 09:52:30 2006 +0000 +++ b/lemon/fredman_tarjan.h Fri Apr 07 09:54:35 2006 +0000 @@ -44,8 +44,8 @@ ///Default traits class of FredmanTarjan class. ///\param GR Graph type. - ///\param LM Type of cost map. - template + ///\param CM Type of cost map. + template struct FredmanTarjanDefaultTraits{ ///The graph type the algorithm runs on. typedef GR UGraph; @@ -53,9 +53,9 @@ ///The type of the map that stores the edge costs. ///It must meet the \ref concept::ReadMap "ReadMap" concept. - typedef LM CostMap; + typedef CM CostMap; //The type of the cost of the edges. - typedef typename LM::Value Value; + typedef typename CM::Value Value; ///The type of the map that stores whether an edge is in the ///spanning tree or not. @@ -76,61 +76,60 @@ ///%FredmanTarjan algorithm class to find a minimum spanning tree. - /// \ingroup spantree - ///This class provides an efficient implementation of %FredmanTarjan algorithm - ///whitch is sometimes a bit quicker than the Prim algorithm on larger graphs. - ///Due to the structure of the algorithm, it has less controll functions than - ///Prim. + /// \ingroup spantree /// - ///The running time is O(e*B(e,n)) where e is the number of edges, n is the - ///number of nodes in the graph and B(e,n) is min { i | log^(i) n <= e/n} - ///( log^(i+1) n = log(log^(i)) n ) + ///This class provides an efficient implementation of %FredmanTarjan + ///algorithm whitch is sometimes a bit quicker than the Prim + ///algorithm on larger graphs. Due to the structure of the + ///algorithm, it has less controll functions than Prim. /// - ///The edge costs are passed to the algorithm using a - ///\ref concept::ReadMap "ReadMap", - ///so it is easy to change it to any kind of cost. + /// The running time is \f$ O(e\beta(e,n)) \f$ where + /// \f$ \beta(e,n) = \min\{ i | \log^{i}(n) \le e/n\} \f$ and + /// \f$ \log^{i+1}(n)=\log(\log^{i}(n)) \f$ /// - ///The type of the cost is determined by the - ///\ref concept::ReadMap::Value "Value" of the cost map. + ///The edge costs are passed to the algorithm using a \ref + ///concept::ReadMap "ReadMap", so it is easy to change it to any + ///kind of cost. + /// + ///The type of the cost is determined by the \ref + ///concept::ReadMap::Value "Value" of the cost map. /// ///\param GR The graph type the algorithm runs on. The default value ///is \ref ListUGraph. The value of GR is not used directly by - ///FredmanTarjan, it is only passed to \ref FredmanTarjanDefaultTraits. - /// - ///\param LM This read-only UEdgeMap determines the costs of the - ///edges. It is read once for each edge, so the map may involve in - ///relatively time consuming process to compute the edge cost if - ///it is necessary. The default map type is \ref - ///concept::UGraph::UEdgeMap "UGraph::UEdgeMap". The value - ///of LM is not used directly by FredmanTarjan, it is only passed to \ref + ///FredmanTarjan, it is only passed to \ref ///FredmanTarjanDefaultTraits. /// - ///\param TR Traits class to set - ///various data types used by the algorithm. The default traits - ///class is \ref FredmanTarjanDefaultTraits - ///"FredmanTarjanDefaultTraits". See \ref - ///FredmanTarjanDefaultTraits for the documentation of a FredmanTarjan traits - ///class. + ///\param CM This read-only UEdgeMap determines the costs of the + ///edges. It is read once for each edge, so the map may involve in + ///relatively time consuming process to compute the edge cost if it + ///is necessary. The default map type is \ref + ///concept::UGraph::UEdgeMap "UGraph::UEdgeMap". The value of + ///CM is not used directly by FredmanTarjan, it is only passed to + ///\ref FredmanTarjanDefaultTraits. + /// + ///\param TR Traits class to set various data types used by the + ///algorithm. The default traits class is \ref + ///FredmanTarjanDefaultTraits "FredmanTarjanDefaultTraits". + ///See \ref FredmanTarjanDefaultTraits for the documentation of a + ///FredmanTarjan traits class. /// ///\author Balazs Attila Mihaly #ifdef DOXYGEN template #else template , - typename TR=FredmanTarjanDefaultTraits > + typename CM=typename GR::template UEdgeMap, + typename TR=FredmanTarjanDefaultTraits > #endif class FredmanTarjan { public: - /** - * \brief \ref Exception for uninitialized parameters. - * - * This error represents problems in the initialization - * of the parameters of the algorithms. - */ + ///\brief \ref Exception for uninitialized parameters. + /// + ///This error represents problems in the initialization + ///of the parameters of the algorithms. class UninitializedParameter : public lemon::UninitializedParameter { public: virtual const char* exceptionName() const { diff -r 28df5272df99 -r bdc953f2a449 lemon/graph_adaptor.h --- a/lemon/graph_adaptor.h Fri Apr 07 09:52:30 2006 +0000 +++ b/lemon/graph_adaptor.h Fri Apr 07 09:54:35 2006 +0000 @@ -45,10 +45,6 @@ /// ///Base type for the Graph Adaptors /// - ///\warning Graph adaptors are in even - ///more experimental state than the other - ///parts of the lib. Use them at you own risk. - /// ///This is the base type for most of LEMON graph adaptors. ///This class implements a trivial graph adaptor i.e. it only wraps the ///functions and types of the graph. The purpose of this class is to @@ -252,10 +248,6 @@ ///\brief A graph adaptor which reverses the orientation of the edges. ///\ingroup graph_adaptors /// - ///\warning Graph adaptors are in even more experimental - ///state than the other - ///parts of the lib. Use them at you own risk. - /// /// If \c g is defined as ///\code /// ListGraph g; @@ -648,9 +640,6 @@ /// \brief A graph adaptor for hiding nodes and edges from a graph. /// \ingroup graph_adaptors /// - /// \warning Graph adaptors are in even more experimental state than the - /// other parts of the lib. Use them at you own risk. - /// /// SubGraphAdaptor shows the graph with filtered node-set and /// edge-set. If the \c checked parameter is true then it filters the edgeset /// to do not get invalid edges without source or target. @@ -770,10 +759,6 @@ ///\brief An adaptor for hiding nodes from a graph. ///\ingroup graph_adaptors /// - ///\warning Graph adaptors are in even more experimental state - ///than the other - ///parts of the lib. Use them at you own risk. - /// ///An adaptor for hiding nodes from a graph. ///This adaptor specializes SubGraphAdaptor in the way that only ///the node-set @@ -827,9 +812,6 @@ ///\brief An adaptor for hiding edges from a graph. /// - ///\warning Graph adaptors are in even more experimental state - ///than the other parts of the lib. Use them at you own risk. - /// ///An adaptor for hiding edges from a graph. ///This adaptor specializes SubGraphAdaptor in the way that ///only the edge-set @@ -1479,36 +1461,37 @@ /// ///\ingroup graph_adaptors /// - ///An adaptor for composing the residual graph for - ///directed flow and circulation problems. -// ///Let \f$ G=(V, A) \f$ be a directed graph and let \f$ F \f$ be a -// ///number type. Let moreover -// ///\f$ f,c:A\to F \f$, be functions on the edge-set. -// ///In the appications of ResGraphAdaptor, \f$ f \f$ usually stands for a -// ///flow and \f$ c \f$ for a capacity function. -// ///Suppose that a graph instange \c g of type -// ///\c ListGraph implements \f$ G \f$. -// ///\code -// /// ListGraph g; -// ///\endcode -// ///Then RevGraphAdaptor implements the graph structure with node-set -// ///\f$ V \f$ and edge-set \f$ A_{forward}\cup A_{backward} \f$, where -// ///\f$ A_{forward}=\{uv : uv\in A, f(uv)0\} \f$, -// ///i.e. the so called residual graph. -// ///When we take the union \f$ A_{forward}\cup A_{backward} \f$, -// ///multilicities are counted, i.e. if an edge is in both -// ///\f$ A_{forward} \f$ and \f$ A_{backward} \f$, then in the adaptor it -// ///appears twice. The following code shows how such an instance can be -// ///constructed. -// ///\code -// /// typedef ListGraph Graph; -// /// Graph::EdgeMap f(g); -// /// Graph::EdgeMap c(g); -// /// ResGraphAdaptor, Graph::EdgeMap > ga(g); -// ///\endcode -// ///\author Marton Makai -// /// + ///An adaptor for composing the residual graph for directed flow and + ///circulation problems. Let \f$ G=(V, A) \f$ be a directed graph + ///and let \f$ F \f$ be a number type. Let moreover \f$ f,c:A\to F \f$, + ///be functions on the edge-set. + /// + ///In the appications of ResGraphAdaptor, \f$ f \f$ usually stands + ///for a flow and \f$ c \f$ for a capacity function. Suppose that a + ///graph instange \c g of type \c ListGraph implements \f$ G \f$. + /// + ///\code + /// ListGraph g; + ///\endcode + /// + ///Then RevGraphAdaptor implements the graph structure with node-set + /// \f$ V \f$ and edge-set \f$ A_{forward}\cup A_{backward} \f$, + ///where \f$ A_{forward}=\{uv : uv\in A, f(uv)0\} \f$, i.e. the so called + ///residual graph. When we take the union + /// \f$ A_{forward}\cup A_{backward} \f$, multilicities are counted, i.e. + ///if an edge is in both \f$ A_{forward} \f$ and \f$ A_{backward} \f$, + ///then in the adaptor it appears twice. The following code shows how + ///such an instance can be constructed. + /// + ///\code + /// typedef ListGraph Graph; + /// Graph::EdgeMap f(g); + /// Graph::EdgeMap c(g); + /// ResGraphAdaptor, Graph::EdgeMap > ga(g); + ///\endcode + ///\author Marton Makai + /// template > @@ -1685,10 +1668,6 @@ ///\brief For blocking flows. ///\ingroup graph_adaptors /// - ///\warning Graph adaptors are in even more - ///experimental state than the other - ///parts of the lib. Use them at you own risk. - /// ///This graph adaptor is used for on-the-fly ///Dinits blocking flow computations. ///For each node, an out-edge is stored which is used when the diff -r 28df5272df99 -r bdc953f2a449 lemon/johnson.h --- a/lemon/johnson.h Fri Apr 07 09:52:30 2006 +0000 +++ b/lemon/johnson.h Fri Apr 07 09:54:35 2006 +0000 @@ -191,8 +191,8 @@ /// that all edge is non-negative in the graph then the dijkstra algorithm /// should be used from each node. /// - /// The complexity of this algorithm is $O(n^2 * log(n) + n * log(n) * e)$ or - /// with fibonacci heap O(n^2 * log(n) + n * e). Usually the fibonacci heap + /// The complexity of this algorithm is \f$ O(n^2\log(n)+n\log(n)e) \f$ or + /// with fibonacci heap \f$ O(n^2\log(n)+ne) \f$. Usually the fibonacci heap /// implementation is slower than either binary heap implementation or the /// Floyd-Warshall algorithm. /// diff -r 28df5272df99 -r bdc953f2a449 lemon/max_matching.h --- a/lemon/max_matching.h Fri Apr 07 09:52:30 2006 +0000 +++ b/lemon/max_matching.h Fri Apr 07 09:54:35 2006 +0000 @@ -24,14 +24,13 @@ #include #include -///\ingroup galgs +///\ingroup matching ///\file -///\brief Maximum matching algorithm. +///\brief Maximum matching algorithm in undirected graph. namespace lemon { - /// \addtogroup galgs - /// @{ + /// \ingroup matching ///Edmonds' alternating forest maximum matching algorithm. @@ -564,7 +563,6 @@ } - /// @} } //END OF NAMESPACE LEMON diff -r 28df5272df99 -r bdc953f2a449 lemon/min_cost_arborescence.h --- a/lemon/min_cost_arborescence.h Fri Apr 07 09:52:30 2006 +0000 +++ b/lemon/min_cost_arborescence.h Fri Apr 07 09:54:35 2006 +0000 @@ -97,10 +97,10 @@ /// more sources should be given for the algorithm and it will calculate /// the minimum cost subgraph which are union of arborescences with the /// given sources and spans all the nodes which are reachable from the - /// sources. The time complexity of the algorithm is O(n^2 + e). + /// sources. The time complexity of the algorithm is \f$ O(n^2+e) \f$. /// /// The algorithm provides also an optimal dual solution to arborescence - /// that way the optimality of the algorithm can be proofed easily. + /// that way the optimality of the solution can be proofed easily. /// /// \param _Graph The graph type the algorithm runs on. The default value /// is \ref ListGraph. The value of _Graph is not used directly by diff -r 28df5272df99 -r bdc953f2a449 lemon/min_cut.h --- a/lemon/min_cut.h Fri Apr 07 09:52:30 2006 +0000 +++ b/lemon/min_cut.h Fri Apr 07 09:54:35 2006 +0000 @@ -839,9 +839,10 @@ /// to test how many links have to be destroyed in the netaux to split it /// at least two distinict subnetaux. /// - /// The complexity of the algorithm is O(n*e*log(n)) but with Fibonacci - /// heap it can be decreased to O(n*e+n^2*log(n)). When the neutral capacity - /// map is used then it uses BucketHeap which results O(n*e) time complexity. + /// The complexity of the algorithm is \f$ O(ne\log(n)) \f$ but with + /// Fibonacci heap it can be decreased to \f$ O(ne+n^2\log(n)) \f$. When + /// the neutral capacity map is used then it uses BucketHeap which + /// results \f$ O(ne) \f$ time complexity. #ifdef DOXYGEN template #else diff -r 28df5272df99 -r bdc953f2a449 lemon/prim.h --- a/lemon/prim.h Fri Apr 07 09:52:30 2006 +0000 +++ b/lemon/prim.h Fri Apr 07 09:54:35 2006 +0000 @@ -136,7 +136,7 @@ /// \ingroup spantree ///This class provides an efficient implementation of %Prim algorithm. /// - ///The running time is O(e*log n) where e is the number of edges and + ///The running time is \f$ O(e\log(n)) \f$ where e is the number of edges and ///n is the number of nodes in the graph. /// ///The edge costs are passed to the algorithm using a diff -r 28df5272df99 -r bdc953f2a449 lemon/radix_sort.h --- a/lemon/radix_sort.h Fri Apr 07 09:52:30 2006 +0000 +++ b/lemon/radix_sort.h Fri Apr 07 09:54:35 2006 +0000 @@ -208,8 +208,9 @@ /// This implemented radix sort is a special quick sort which pivot value /// is choosen to partite the items on the next bit. This way, let be /// \c c the maximal capacity and \c n the number of the items in - /// the container, the time complexity of the algorithm \c O(log(c)*n) - /// and the additional space complexity is \c O(log(c)). + /// the container, the time complexity of the algorithm + /// \f$ O(\log(c)n) \f$ and the additional space complexity is + /// \f$ O(\log(c)) \f$. /// /// \param first The begin of the given range. /// \param last The end of the given range. @@ -429,8 +430,8 @@ /// by each bytes in forward direction which sorts the container by the /// whole value. This way, let be \c c the maximal capacity of the integer /// type and \c n the number of the items in - /// the container, the time complexity of the algorithm \c O(log(c)*n) - /// and the additional space complexity is \c O(n). + /// the container, the time complexity of the algorithm \f$ O(\log(c)n) \f$ + /// and the additional space complexity is \f$ O(n) \f$. /// /// This sorting algorithm is stable so the order of two equal element /// stay in the same order. diff -r 28df5272df99 -r bdc953f2a449 lemon/ugraph_adaptor.h --- a/lemon/ugraph_adaptor.h Fri Apr 07 09:52:30 2006 +0000 +++ b/lemon/ugraph_adaptor.h Fri Apr 07 09:54:35 2006 +0000 @@ -834,6 +834,8 @@ return NodeSubUGraphAdaptor(graph, nfm); } + /// \ingroup graph_adaptors + /// /// \brief An adaptor for hiding undirected edges from an undirected graph. /// /// \warning Graph adaptors are in even more experimental state