haggle-0.2: A graph library offering mutable, immutable, and inductive graphs
Safe HaskellNone
LanguageHaskell2010

Data.Graph.Haggle.Algorithms.Dominators

Description

Compute the dominators in a graph from a root node.

The set of dominators for a Vertex in a graph is always with regard to a root Vertex, given as input to the algorithm. Vertex d dominates Vertex v if every path from the root to v must go through d. d strictly dominates v if d dominates v and is not v. The immediate dominator of v is the unique Vertex that strictly dominates v and does not strictly dominate any other Vertex that dominates v.

This implementation is ported from FGL (http://hackage.haskell.org/package/fgl) and is substantially similar. The major change is that it uses the vector library instead of array.

The algorithm is based on "A Simple, Fast Dominance Algorithm" by Cooper, Harvey, and Kennedy

http://www.cs.rice.edu/~keith/EMBED/dom.pdf

This is not Tarjan's algorithm; supposedly this is faster in practice for most graphs.

Synopsis

Documentation

immediateDominators :: Graph g => g -> Vertex -> [(Vertex, Vertex)] Source #

Compute the immediate dominators in the graph from the root Vertex. Each Vertex reachable from the root will be paired with its immediate dominator. Note that there is no entry in the result pairing for the root Vertex because it has no immediate dominator.

If the root vertex is not in the graph, an empty list is returned.

dominators :: Graph g => g -> Vertex -> [(Vertex, [Vertex])] Source #

Compute all of the dominators for each Vertex reachable from the root. Each reachable Vertex is paired with the list of nodes that dominate it, including the Vertex itself. The root is only dominated by itself.