Class AbstractNetwork<N,E>
- Type Parameters:
N
- Node parameter typeE
- Edge parameter type
- All Implemented Interfaces:
Network<N,
,E> PredecessorsFunction<N>
,SuccessorsFunction<N>
- Direct Known Subclasses:
ImmutableNetwork
Network
. It is recommended to extend
this class rather than implement Network
directly.
The methods implemented in this class should not be overridden unless the subclass admits a more efficient implementation.
- Since:
- 20.0
- Author:
- James Sexton
-
Constructor Summary
-
Method Summary
Modifier and TypeMethodDescriptionadjacentEdges
(E edge) Returns a live view of the edges which have anincident node
in common withedge
.asGraph()
Returns a live view of this network as aGraph
.int
Returns the count ofnode
'sincident edges
, counting self-loops twice (equivalently, the number of times an edge touchesnode
).edgeConnecting
(EndpointPair<N> endpoints) Returns the single edge that directly connectsendpoints
(in the order, if any, specified byendpoints
), if one is present, orOptional.empty()
if no such edge exists.edgeConnecting
(N nodeU, N nodeV) Returns the single edge that directly connectsnodeU
tonodeV
, if one is present, orOptional.empty()
if no such edge exists.edgeConnectingOrNull
(EndpointPair<N> endpoints) Returns the single edge that directly connectsendpoints
(in the order, if any, specified byendpoints
), if one is present, ornull
if no such edge exists.edgeConnectingOrNull
(N nodeU, N nodeV) Returns the single edge that directly connectsnodeU
tonodeV
, if one is present, ornull
if no such edge exists.protected final <T> Set
<T> edgeInvalidatableSet
(Set<T> set, E edge) Returns aSet
whose methods throwIllegalStateException
when the given edge is not present in this network.edgesConnecting
(EndpointPair<N> endpoints) Returns a live view of the set of edges that each directly connectendpoints
(in the order, if any, specified byendpoints
).edgesConnecting
(N nodeU, N nodeV) Returns a live view of the set of edges that each directly connectnodeU
tonodeV
.final boolean
Returnstrue
iffobject
is aNetwork
that has the same elements and the same structural relationships as those in this network.boolean
hasEdgeConnecting
(EndpointPair<N> endpoints) Returns true if there is an edge that directly connectsendpoints
(in the order, if any, specified byendpoints
).boolean
hasEdgeConnecting
(N nodeU, N nodeV) Returns true if there is an edge that directly connectsnodeU
tonodeV
.final int
hashCode()
Returns the hash code for this network.int
Returns the count ofnode
'sincoming edges
in a directed network.protected final boolean
isOrderingCompatible
(EndpointPair<?> endpoints) protected final <T> Set
<T> nodeInvalidatableSet
(Set<T> set, N node) Returns aSet
whose methods throwIllegalStateException
when the given node is not present in this network.protected final <T> Set
<T> nodePairInvalidatableSet
(Set<T> set, N nodeU, N nodeV) Returns aSet
whose methods throwIllegalStateException
when either of the given nodes is not present in this network.int
Returns the count ofnode
'soutgoing edges
in a directed network.toString()
Returns a string representation of this network.protected final void
validateEndpoints
(EndpointPair<?> endpoints) Throws an IllegalArgumentException if the ordering ofendpoints
is not compatible with the directionality of this graph.Methods inherited from class java.lang.Object
clone, finalize, getClass, notify, notifyAll, wait, wait, wait
Methods inherited from interface com.google.common.graph.Network
adjacentNodes, allowsParallelEdges, allowsSelfLoops, edgeOrder, edges, incidentEdges, incidentNodes, inEdges, isDirected, nodeOrder, nodes, outEdges, predecessors, successors
-
Constructor Details
-
AbstractNetwork
public AbstractNetwork()Constructor for use by subclasses.
-
-
Method Details
-
asGraph
Description copied from interface:Network
Returns a live view of this network as aGraph
. The resultingGraph
will have an edge connecting node A to node B if thisNetwork
has an edge connecting A to B.If this network
allows parallel edges
, parallel edges will be treated as if collapsed into a single edge. For example, theNetwork.degree(Object)
of a node in theGraph
view may be less than the degree of the same node in thisNetwork
. -
degree
Description copied from interface:Network
Returns the count ofnode
'sincident edges
, counting self-loops twice (equivalently, the number of times an edge touchesnode
).For directed networks, this is equal to
inDegree(node) + outDegree(node)
.For undirected networks, this is equal to
incidentEdges(node).size()
+ (number of self-loops incident tonode
).If the count is greater than
Integer.MAX_VALUE
, returnsInteger.MAX_VALUE
. -
inDegree
Description copied from interface:Network
Returns the count ofnode
'sincoming edges
in a directed network. In an undirected network, returns theNetwork.degree(Object)
.If the count is greater than
Integer.MAX_VALUE
, returnsInteger.MAX_VALUE
. -
outDegree
Description copied from interface:Network
Returns the count ofnode
'soutgoing edges
in a directed network. In an undirected network, returns theNetwork.degree(Object)
.If the count is greater than
Integer.MAX_VALUE
, returnsInteger.MAX_VALUE
. -
adjacentEdges
Description copied from interface:Network
Returns a live view of the edges which have anincident node
in common withedge
. An edge is not considered adjacent to itself.If
edge
is removed from the network after this method is called, theSet
view
returned by this method will be invalidated, and will throwIllegalStateException
if it is accessed in any way, with the following exceptions:view.equals(view)
evaluates totrue
(but any otherequals()
expression involvingview
will throw)hashCode()
does not throw- if
edge
is re-added to the network after having been removed,view
's behavior is undefined
- Specified by:
adjacentEdges
in interfaceNetwork<N,
E>
-
edgesConnecting
Description copied from interface:Network
Returns a live view of the set of edges that each directly connectnodeU
tonodeV
.In an undirected network, this is equal to
edgesConnecting(nodeV, nodeU)
.The resulting set of edges will be parallel (i.e. have equal
Network.incidentNodes(Object)
). If this network does notallow parallel edges
, the resulting set will contain at most one edge (equivalent toedgeConnecting(nodeU, nodeV).asSet()
).If either
nodeU
ornodeV
are removed from the network after this method is called, theSet
view
returned by this method will be invalidated, and will throwIllegalStateException
if it is accessed in any way, with the following exceptions:view.equals(view)
evaluates totrue
(but any otherequals()
expression involvingview
will throw)hashCode()
does not throw- if
nodeU
ornodeV
are re-added to the network after having been removed,view
's behavior is undefined
- Specified by:
edgesConnecting
in interfaceNetwork<N,
E>
-
edgesConnecting
Description copied from interface:Network
Returns a live view of the set of edges that each directly connectendpoints
(in the order, if any, specified byendpoints
).The resulting set of edges will be parallel (i.e. have equal
Network.incidentNodes(Object)
). If this network does notallow parallel edges
, the resulting set will contain at most one edge (equivalent toedgeConnecting(endpoints).asSet()
).If this network is directed,
endpoints
must be ordered.If either element of
endpoints
is removed from the network after this method is called, theSet
view
returned by this method will be invalidated, and will throwIllegalStateException
if it is accessed in any way, with the following exceptions:view.equals(view)
evaluates totrue
(but any otherequals()
expression involvingview
will throw)hashCode()
does not throw- if either endpoint is re-added to the network after having been removed,
view
's behavior is undefined
- Specified by:
edgesConnecting
in interfaceNetwork<N,
E>
-
edgeConnecting
Description copied from interface:Network
Returns the single edge that directly connectsnodeU
tonodeV
, if one is present, orOptional.empty()
if no such edge exists.In an undirected network, this is equal to
edgeConnecting(nodeV, nodeU)
.- Specified by:
edgeConnecting
in interfaceNetwork<N,
E>
-
edgeConnecting
Description copied from interface:Network
Returns the single edge that directly connectsendpoints
(in the order, if any, specified byendpoints
), if one is present, orOptional.empty()
if no such edge exists.If this network is directed, the endpoints must be ordered.
- Specified by:
edgeConnecting
in interfaceNetwork<N,
E>
-
edgeConnectingOrNull
Description copied from interface:Network
Returns the single edge that directly connectsnodeU
tonodeV
, if one is present, ornull
if no such edge exists.In an undirected network, this is equal to
edgeConnectingOrNull(nodeV, nodeU)
.- Specified by:
edgeConnectingOrNull
in interfaceNetwork<N,
E>
-
edgeConnectingOrNull
Description copied from interface:Network
Returns the single edge that directly connectsendpoints
(in the order, if any, specified byendpoints
), if one is present, ornull
if no such edge exists.If this network is directed, the endpoints must be ordered.
- Specified by:
edgeConnectingOrNull
in interfaceNetwork<N,
E>
-
hasEdgeConnecting
Description copied from interface:Network
Returns true if there is an edge that directly connectsnodeU
tonodeV
. This is equivalent tonodes().contains(nodeU) && successors(nodeU).contains(nodeV)
, and toedgeConnectingOrNull(nodeU, nodeV) != null
.In an undirected network, this is equal to
hasEdgeConnecting(nodeV, nodeU)
.- Specified by:
hasEdgeConnecting
in interfaceNetwork<N,
E>
-
hasEdgeConnecting
Description copied from interface:Network
Returns true if there is an edge that directly connectsendpoints
(in the order, if any, specified byendpoints
).Unlike the other
EndpointPair
-accepting methods, this method does not throw if the endpoints are unordered and the network is directed; it simply returnsfalse
. This is for consistency withGraph.hasEdgeConnecting(EndpointPair)
andValueGraph.hasEdgeConnecting(EndpointPair)
.- Specified by:
hasEdgeConnecting
in interfaceNetwork<N,
E>
-
validateEndpoints
Throws an IllegalArgumentException if the ordering ofendpoints
is not compatible with the directionality of this graph. -
isOrderingCompatible
-
equals
Description copied from interface:Network
Returnstrue
iffobject
is aNetwork
that has the same elements and the same structural relationships as those in this network.Thus, two networks A and B are equal if all of the following are true:
- A and B have equal
directedness
. - A and B have equal
node sets
. - A and B have equal
edge sets
. - Every edge in A and B connects the same nodes in the same direction (if any).
Network properties besides
directedness
do not affect equality. For example, two networks may be considered equal even if one allows parallel edges and the other doesn't. Additionally, the order in which nodes or edges are added to the network, and the order in which they are iterated over, are irrelevant.A reference implementation of this is provided by
equals(Object)
. - A and B have equal
-
hashCode
Description copied from interface:Network
Returns the hash code for this network. The hash code of a network is defined as the hash code of a map from each of itsedges
to theirincident nodes
.A reference implementation of this is provided by
hashCode()
. -
toString
-
edgeInvalidatableSet
Returns aSet
whose methods throwIllegalStateException
when the given edge is not present in this network.- Since:
- 33.1.0
-
nodeInvalidatableSet
Returns aSet
whose methods throwIllegalStateException
when the given node is not present in this network.- Since:
- 33.1.0
-
nodePairInvalidatableSet
Returns aSet
whose methods throwIllegalStateException
when either of the given nodes is not present in this network.- Since:
- 33.1.0
-