Package org.jgrapht.graph.specifics
Class DirectedSpecifics<V,E>
- java.lang.Object
- 
- org.jgrapht.graph.specifics.DirectedSpecifics<V,E>
 
- 
- Type Parameters:
- V- the graph vertex type
- E- the graph edge type
 - All Implemented Interfaces:
- java.io.Serializable,- Specifics<V,E>
 - Direct Known Subclasses:
- FastLookupDirectedSpecifics
 
 public class DirectedSpecifics<V,E> extends java.lang.Object implements Specifics<V,E>, java.io.Serializable Plain implementation of DirectedSpecifics. This implementation requires the least amount of memory, at the expense of slow edge retrievals. Methods which depend on edge retrievals, e.g. getEdge(V u, V v), containsEdge(V u, V v), addEdge(V u, V v), etc may be relatively slow when the average degree of a vertex is high (dense graphs). For a fast implementation, useFastLookupDirectedSpecifics.- Author:
- Barak Naveh, Joris Kinable
- See Also:
- Serialized Form
 
- 
- 
Field SummaryFields Modifier and Type Field Description protected EdgeSetFactory<V,E>edgeSetFactoryprotected Graph<V,E>graphprotected java.util.Map<V,DirectedEdgeContainer<V,E>>vertexMap
 - 
Constructor SummaryConstructors Constructor Description DirectedSpecifics(Graph<V,E> graph, java.util.Map<V,DirectedEdgeContainer<V,E>> vertexMap, EdgeSetFactory<V,E> edgeSetFactory)Construct a new directed specifics.
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description booleanaddEdgeToTouchingVertices(V sourceVertex, V targetVertex, E e)Adds the specified edge to the edge containers of its source and target vertices.booleanaddEdgeToTouchingVerticesIfAbsent(V sourceVertex, V targetVertex, E e)Adds the specified edge to the edge containers of its source and target vertices only if the edge is not already in the graph.booleanaddVertex(V v)Adds a vertex.EcreateEdgeToTouchingVerticesIfAbsent(V sourceVertex, V targetVertex, java.util.function.Supplier<E> edgeSupplier)Creates an edge given an edge supplier and adds it to the edge containers of its source and target vertices only if the graph does not contain other edges with the same source and target vertices.intdegreeOf(V vertex)Returns the degree of the specified vertex.java.util.Set<E>edgesOf(V vertex)Returns a set of all edges touching the specified vertex.java.util.Set<E>getAllEdges(V sourceVertex, V targetVertex)Returns a set of all edges connecting source vertex to target vertex if such vertices exist in this graph.EgetEdge(V sourceVertex, V targetVertex)Returns an edge connecting source vertex to target vertex if such vertices and such edge exist in this graph.protected DirectedEdgeContainer<V,E>getEdgeContainer(V vertex)Get the edge container for specified vertex.java.util.Set<V>getVertexSet()Get the vertex set.java.util.Set<E>incomingEdgesOf(V vertex)Returns a set of all edges incoming into the specified vertex.intinDegreeOf(V vertex)Returns the "in degree" of the specified vertex.intoutDegreeOf(V vertex)Returns the "out degree" of the specified vertex.java.util.Set<E>outgoingEdgesOf(V vertex)Returns a set of all edges outgoing from the specified vertex.voidremoveEdgeFromTouchingVertices(V sourceVertex, V targetVertex, E e)Removes the specified edge from the edge containers of its source and target vertices.
 
- 
- 
- 
Field Detail- 
vertexMapprotected java.util.Map<V,DirectedEdgeContainer<V,E>> vertexMap 
 - 
edgeSetFactoryprotected EdgeSetFactory<V,E> edgeSetFactory 
 
- 
 - 
Constructor Detail- 
DirectedSpecificspublic DirectedSpecifics(Graph<V,E> graph, java.util.Map<V,DirectedEdgeContainer<V,E>> vertexMap, EdgeSetFactory<V,E> edgeSetFactory) Construct a new directed specifics.- Parameters:
- graph- the graph for which these specifics are for
- vertexMap- map for the storage of vertex edge sets. Needs to have a predictable iteration order.
- edgeSetFactory- factory for the creation of vertex edge sets
 
 
- 
 - 
Method Detail- 
addVertexpublic boolean addVertex(V v) Adds a vertex.
 - 
getVertexSetpublic java.util.Set<V> getVertexSet() Get the vertex set.- Specified by:
- getVertexSetin interface- Specifics<V,E>
- Returns:
- the vertex set
 
 - 
getAllEdgespublic java.util.Set<E> getAllEdges(V sourceVertex, V targetVertex) Returns a set of all edges connecting source vertex to target vertex if such vertices exist in this graph. If any of the vertices does not exist or isnull, returnsnull. If both vertices exist but no edges found, returns an empty set.- Specified by:
- getAllEdgesin interface- Specifics<V,E>
- Parameters:
- sourceVertex- source vertex of the edge.
- targetVertex- target vertex of the edge.
- Returns:
- a set of all edges connecting source vertex to target vertex.
 
 - 
getEdgepublic E getEdge(V sourceVertex, V targetVertex) Returns an edge connecting source vertex to target vertex if such vertices and such edge exist in this graph. Otherwise returnsnull. If any of the specified vertices isnullreturnsnullIn undirected graphs, the returned edge may have its source and target vertices in the opposite order. 
 - 
addEdgeToTouchingVerticespublic boolean addEdgeToTouchingVertices(V sourceVertex, V targetVertex, E e) Adds the specified edge to the edge containers of its source and target vertices.- Specified by:
- addEdgeToTouchingVerticesin interface- Specifics<V,E>
- Parameters:
- sourceVertex- the source vertex
- targetVertex- the target vertex
- e- the edge
- Returns:
- true if the edge was added, false otherwise
 
 - 
addEdgeToTouchingVerticesIfAbsentpublic boolean addEdgeToTouchingVerticesIfAbsent(V sourceVertex, V targetVertex, E e) Description copied from interface:SpecificsAdds the specified edge to the edge containers of its source and target vertices only if the edge is not already in the graph.- Specified by:
- addEdgeToTouchingVerticesIfAbsentin interface- Specifics<V,E>
- Parameters:
- sourceVertex- the source vertex
- targetVertex- the target vertex
- e- the edge
- Returns:
- true if the edge was added, false otherwise
 
 - 
createEdgeToTouchingVerticesIfAbsentpublic E createEdgeToTouchingVerticesIfAbsent(V sourceVertex, V targetVertex, java.util.function.Supplier<E> edgeSupplier) Description copied from interface:SpecificsCreates an edge given an edge supplier and adds it to the edge containers of its source and target vertices only if the graph does not contain other edges with the same source and target vertices.- Specified by:
- createEdgeToTouchingVerticesIfAbsentin interface- Specifics<V,E>
- Parameters:
- sourceVertex- the source vertex
- targetVertex- the target vertex
- edgeSupplier- the function which will create the edge
- Returns:
- the newly created edge or null if an edge with the same source and target vertices was already present
 
 - 
degreeOfpublic int degreeOf(V vertex) Returns the degree of the specified vertex. A degree of a vertex in an undirected graph is the number of edges touching that vertex.
 - 
edgesOfpublic java.util.Set<E> edgesOf(V vertex) Returns a set of all edges touching the specified vertex. If no edges are touching the specified vertex returns an empty set.
 - 
inDegreeOfpublic int inDegreeOf(V vertex) Returns the "in degree" of the specified vertex.- Specified by:
- inDegreeOfin interface- Specifics<V,E>
- Parameters:
- vertex- vertex whose in degree is to be calculated.
- Returns:
- the in degree of the specified vertex.
 
 - 
incomingEdgesOfpublic java.util.Set<E> incomingEdgesOf(V vertex) Returns a set of all edges incoming into the specified vertex.- Specified by:
- incomingEdgesOfin interface- Specifics<V,E>
- Parameters:
- vertex- the vertex for which the list of incoming edges to be returned.
- Returns:
- a set of all edges incoming into the specified vertex.
 
 - 
outDegreeOfpublic int outDegreeOf(V vertex) Returns the "out degree" of the specified vertex.- Specified by:
- outDegreeOfin interface- Specifics<V,E>
- Parameters:
- vertex- vertex whose out degree is to be calculated.
- Returns:
- the out degree of the specified vertex.
 
 - 
outgoingEdgesOfpublic java.util.Set<E> outgoingEdgesOf(V vertex) Returns a set of all edges outgoing from the specified vertex.- Specified by:
- outgoingEdgesOfin interface- Specifics<V,E>
- Parameters:
- vertex- the vertex for which the list of outgoing edges to be returned.
- Returns:
- a set of all edges outgoing from the specified vertex.
 
 - 
removeEdgeFromTouchingVerticespublic void removeEdgeFromTouchingVertices(V sourceVertex, V targetVertex, E e) Removes the specified edge from the edge containers of its source and target vertices.- Specified by:
- removeEdgeFromTouchingVerticesin interface- Specifics<V,E>
- Parameters:
- sourceVertex- the source vertex
- targetVertex- the target vertex
- e- the edge
 
 - 
getEdgeContainerprotected DirectedEdgeContainer<V,E> getEdgeContainer(V vertex) Get the edge container for specified vertex.- Parameters:
- vertex- a vertex in this graph.
- Returns:
- an edge container
 
 
- 
 
-