package flatunionfind

  1. Overview
  2. Docs

Applying the functor Make creates a fresh instance of the union-find data structure. This functor is generative: each application returns a new module, with its own mutable internal state and its own abstract type point.

Parameters

Signature

type point = private int

point is the type of a point in the union-find data structure. It is an abstract type. The keyword private indicates that a point x can be converted to an integer index, by writing x :> int. This integer index lies in the semi-open interval from 0 to population(). The conversion in the reverse direction is not permitted.

type t = point
type population = int
val population : unit -> population

population() is the total number of points created so far.

val iter : (point -> unit) -> unit

iter f applies the user-supplied function f to every point that was ever created (whose creation was not undone via drop).

val fresh : unit -> point

fresh() creates a new point, which forms a new singleton equivalence class.

val drop : point -> unit

drop x undoes the creation of the point x. This is permitted only if no new point was created since x was created (or if those new points were themselves dropped) and no union operation took place since x was created. This operation is unsafe: the user must promise to not use the point x afterwards.

val validate : point -> unit

If runtime assertions are enabled, then validate x checks that the point x is a valid point, and fails otherwise. drop is the only operation that can cause a point to become invalid.

val find : point -> point

find x finds the current representative element of the equivalence class of the point x.

val is_representative : point -> bool

is_representative x determines whether x is currently the representative element of its equivalence class.

val equal : point -> point -> bool

equal x y determines whether x and y are equal, that is, whether they are the same point. It is equivalent to (x :> int) = (y :> int).

val compare : point -> point -> int

compare is a total order on points. compare x y is equivalent to Int.compare (x :> int) (y :> int).

val hash : point -> int

hash is a hash function on points. hash x equivalent to Int.hash (x :> int).

val show : point -> string

show x produces a human-readable representation of the point x.

val equiv : point -> point -> bool

equiv x y determines whether x and y are equivalent, that is, whether they are members of the same equivalence class. (If they are now, then they will be forever.)

val union : point -> point -> point

If equiv x y is true, then union x y has no observable effect. Otherwise, union x y merges the equivalence classes of the points x and y. In either case, after the call, equiv x y is true.

union x y returns a point z such that equiv x z and equiv y z and is_representative z are true.

module Vector : Hector.MONOVECTOR with type element = point

The submodule Vector offers vectors that contain points.

module HashSet (_ : sig ... end) : Hachis.HashSet.SET with type element = point

The submodule HashSet offers hash sets that contain points. It is a functor: an equivalence relation on points must be chosen by the user.

OCaml

Innovation. Community. Security.