Package com.google.common.graph
Class Graphs
- java.lang.Object
- 
- com.google.common.graph.Graphs
 
- 
- 
Method SummaryAll Methods Static Methods Concrete Methods Modifier and Type Method Description static <N> MutableGraph<N>copyOf(Graph<N> graph)Creates a mutable copy ofgraphwith the same nodes and edges.static <N,E>
 MutableNetwork<N,E>copyOf(Network<N,E> network)Creates a mutable copy ofnetworkwith the same nodes and edges.static <N,V>
 MutableValueGraph<N,V>copyOf(ValueGraph<N,V> graph)Creates a mutable copy ofgraphwith the same nodes, edges, and edge values.static <N> booleanhasCycle(Graph<N> graph)Returns true ifgraphhas at least one cycle.static booleanhasCycle(Network<?,?> network)Returns true ifnetworkhas at least one cycle.static <N> MutableGraph<N>inducedSubgraph(Graph<N> graph, java.lang.Iterable<? extends N> nodes)Returns the subgraph ofgraphinduced bynodes.static <N,E>
 MutableNetwork<N,E>inducedSubgraph(Network<N,E> network, java.lang.Iterable<? extends N> nodes)Returns the subgraph ofnetworkinduced bynodes.static <N,V>
 MutableValueGraph<N,V>inducedSubgraph(ValueGraph<N,V> graph, java.lang.Iterable<? extends N> nodes)Returns the subgraph ofgraphinduced bynodes.static <N> ImmutableSet<N>reachableNodes(Graph<N> graph, N node)Returns the set of nodes that are reachable fromnode.static <N> ImmutableGraph<N>transitiveClosure(Graph<N> graph)Returns the transitive closure ofgraph.static <N> Graph<N>transpose(Graph<N> graph)Returns a view ofgraphwith the direction (if any) of every edge reversed.static <N,E>
 Network<N,E>transpose(Network<N,E> network)Returns a view ofnetworkwith the direction (if any) of every edge reversed.static <N,V>
 ValueGraph<N,V>transpose(ValueGraph<N,V> graph)Returns a view ofgraphwith the direction (if any) of every edge reversed.
 
- 
- 
- 
Method Detail- 
hasCyclepublic static <N> boolean hasCycle(Graph<N> graph) Returns true ifgraphhas at least one cycle. A cycle is defined as a non-empty subset of edges in a graph arranged to form a path (a sequence of adjacent outgoing edges) starting and ending with the same node.This method will detect any non-empty cycle, including self-loops (a cycle of length 1). 
 - 
hasCyclepublic static boolean hasCycle(Network<?,?> network) Returns true ifnetworkhas at least one cycle. A cycle is defined as a non-empty subset of edges in a graph arranged to form a path (a sequence of adjacent outgoing edges) starting and ending with the same node.This method will detect any non-empty cycle, including self-loops (a cycle of length 1). 
 - 
transitiveClosurepublic static <N> ImmutableGraph<N> transitiveClosure(Graph<N> graph) Returns the transitive closure ofgraph. The transitive closure of a graph is another graph with an edge connecting node A to node B if node B isreachablefrom node A.This is a "snapshot" based on the current topology of graph, rather than a live view of the transitive closure ofgraph. In other words, the returnedGraphwill not be updated after modifications tograph.- Since:
- 33.1.0 (present with return type Graphsince 20.0)
 
 - 
reachableNodespublic static <N> ImmutableSet<N> reachableNodes(Graph<N> graph, N node) Returns the set of nodes that are reachable fromnode. Node B is defined as reachable from node A if there exists a path (a sequence of adjacent outgoing edges) starting at node A and ending at node B. Note that a node is always reachable from itself via a zero-length path.This is a "snapshot" based on the current topology of graph, rather than a live view of the set of nodes reachable fromnode. In other words, the returnedSetwill not be updated after modifications tograph.- Throws:
- java.lang.IllegalArgumentException- if- nodeis not present in- graph
- Since:
- 33.1.0 (present with return type Setsince 20.0)
 
 - 
transposepublic static <N> Graph<N> transpose(Graph<N> graph) Returns a view ofgraphwith the direction (if any) of every edge reversed. All other properties remain intact, and further updates tographwill be reflected in the view.
 - 
transposepublic static <N,V> ValueGraph<N,V> transpose(ValueGraph<N,V> graph) Returns a view ofgraphwith the direction (if any) of every edge reversed. All other properties remain intact, and further updates tographwill be reflected in the view.
 - 
transposepublic static <N,E> Network<N,E> transpose(Network<N,E> network) Returns a view ofnetworkwith the direction (if any) of every edge reversed. All other properties remain intact, and further updates tonetworkwill be reflected in the view.
 - 
inducedSubgraphpublic static <N> MutableGraph<N> inducedSubgraph(Graph<N> graph, java.lang.Iterable<? extends N> nodes) Returns the subgraph ofgraphinduced bynodes. This subgraph is a new graph that contains all of the nodes innodes, and all of theedgesfromgraphfor which both nodes are contained bynodes.- Throws:
- java.lang.IllegalArgumentException- if any element in- nodesis not a node in the graph
 
 - 
inducedSubgraphpublic static <N,V> MutableValueGraph<N,V> inducedSubgraph(ValueGraph<N,V> graph, java.lang.Iterable<? extends N> nodes) Returns the subgraph ofgraphinduced bynodes. This subgraph is a new graph that contains all of the nodes innodes, and all of theedges(and associated edge values) fromgraphfor which both nodes are contained bynodes.- Throws:
- java.lang.IllegalArgumentException- if any element in- nodesis not a node in the graph
 
 - 
inducedSubgraphpublic static <N,E> MutableNetwork<N,E> inducedSubgraph(Network<N,E> network, java.lang.Iterable<? extends N> nodes) Returns the subgraph ofnetworkinduced bynodes. This subgraph is a new graph that contains all of the nodes innodes, and all of theedgesfromnetworkfor which theincident nodesare both contained bynodes.- Throws:
- java.lang.IllegalArgumentException- if any element in- nodesis not a node in the graph
 
 - 
copyOfpublic static <N> MutableGraph<N> copyOf(Graph<N> graph) Creates a mutable copy ofgraphwith the same nodes and edges.
 - 
copyOfpublic static <N,V> MutableValueGraph<N,V> copyOf(ValueGraph<N,V> graph) Creates a mutable copy ofgraphwith the same nodes, edges, and edge values.
 - 
copyOfpublic static <N,E> MutableNetwork<N,E> copyOf(Network<N,E> network) Creates a mutable copy ofnetworkwith the same nodes and edges.
 
- 
 
-