java.lang.Object
org.jgrapht.alg.cycle.HawickJamesSimpleCycles<V,E>
- Type Parameters:
 V- the vertex type.E- the edge type.
- All Implemented Interfaces:
 DirectedSimpleCycles<V,E>
public class HawickJamesSimpleCycles<V,E> extends java.lang.Object implements DirectedSimpleCycles<V,E>
Find all simple cycles of a directed graph using the algorithm described by Hawick and James.
 
 See:
 K. A. Hawick, H. A. James. Enumerating Circuits and Loops in Graphs with Self-Arcs and
 Multiple-Arcs. Computational Science Technical Note CSTN-013, 2008
- Author:
 - Luiz Kill
 
- 
Constructor Summary
Constructors Constructor Description HawickJamesSimpleCycles()Create a simple cycle finder with an unspecified graph.HawickJamesSimpleCycles(Graph<V,E> graph)Create a simple cycle finder for the specified graph. - 
Method Summary
Modifier and Type Method Description voidclearPathLimit()This is the default behaviour of the algorithm.longcountSimpleCycles()Count the number of simple cycles.java.util.List<java.util.List<V>>findSimpleCycles()Find the simple cycles of the graph.Graph<V,E>getGraph()Get the graphvoidprintSimpleCycles()Print to the standard output all simple cycles without building a list to keep them, thus avoiding high memory consumption when investigating large and much connected graphs.voidsetGraph(Graph<V,E> graph)Set the graphvoidsetPathLimit(int pathLimit)Limits the maximum number of edges in a cycle. 
- 
Constructor Details
- 
HawickJamesSimpleCycles
public HawickJamesSimpleCycles()Create a simple cycle finder with an unspecified graph. - 
HawickJamesSimpleCycles
Create a simple cycle finder for the specified graph.- Parameters:
 graph- the DirectedGraph in which to find cycles.- Throws:
 java.lang.IllegalArgumentException- if the graph argument isnull.
 
 - 
 - 
Method Details
- 
getGraph
Get the graph- Returns:
 - graph
 
 - 
setGraph
Set the graph- Parameters:
 graph- graph
 - 
findSimpleCycles
public java.util.List<java.util.List<V>> findSimpleCycles() throws java.lang.IllegalArgumentExceptionFind the simple cycles of the graph.- Specified by:
 findSimpleCyclesin interfaceDirectedSimpleCycles<V,E>- Returns:
 - The list of all simple cycles. Possibly empty but never 
null. - Throws:
 java.lang.IllegalArgumentException
 - 
printSimpleCycles
public void printSimpleCycles()Print to the standard output all simple cycles without building a list to keep them, thus avoiding high memory consumption when investigating large and much connected graphs. - 
countSimpleCycles
public long countSimpleCycles()Count the number of simple cycles. It can count up to Long.MAX cycles in a graph.- Returns:
 - the number of simple cycles
 
 - 
setPathLimit
public void setPathLimit(int pathLimit)Limits the maximum number of edges in a cycle.- Parameters:
 pathLimit- maximum paths.
 - 
clearPathLimit
public void clearPathLimit()This is the default behaviour of the algorithm. It will keep looking as long as there are paths available. 
 -