(**************************************************************************) (* *) (* Ocamlgraph: a generic graph library for OCaml *) (* Copyright (C) 2004-2007 *) (* Sylvain Conchon, Jean-Christophe Filliatre and Julien Signoles *) (* *) (* This software is free software; you can redistribute it and/or *) (* modify it under the terms of the GNU Library General Public *) (* License version 2, with the special exception on linking *) (* described in file LICENSE. *) (* *) (* This software is distributed in the hope that it will be useful, *) (* but WITHOUT ANY WARRANTY; without even the implied warranty of *) (* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. *) (* *) (**************************************************************************) (* $Id: components.mli,v 1.12 2004-10-22 14:42:06 signoles Exp $ *) (** Strongly connected components *) open Util (** Minimal graph signature for [scc] *) module type G = sig type t module V : Sig.COMPARABLE val iter_vertex : (V.t -> unit) -> t -> unit val iter_succ : (V.t -> unit) -> t -> V.t -> unit end module Make (G: G) : sig val scc : G.t -> int*(G.V.t -> int) (** [scc g] computes the strongly connected components of [g]. The result is a pair [(n,f)] where [n] is the number of components. Components are numbered from [0] to [n-1], and [f] is a function mapping each vertex to its component number. In particular, [f u = f v] if and only if [u] and [v] are in the same component. Another property of the numbering is that components are numbered in a topological order: if there is an arc from [u] to [v], then [f u >= f u] *) val scc_array : G.t -> G.V.t list array (** [scc_array] computes the strongly connected components of [g]. Components are stored in the resulting array, indexed with a numbering with the same properties as for [scc] above. *) val scc_list : G.t -> G.V.t list list (** [scc_list] computes the strongly connected components of [g]. The result is a partition of the set of the vertices of [g]. *) end