|
||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||
java.lang.Objectedu.uci.ics.jung.utils.UserDataDelegate
edu.uci.ics.jung.graph.impl.AbstractElement
edu.uci.ics.jung.graph.impl.AbstractArchetypeVertex
edu.uci.ics.jung.graph.impl.AbstractSparseVertex
edu.uci.ics.jung.graph.impl.LeanSparseVertex
public class LeanSparseVertex
This fully functional class is provided as a different sort of way to think about the creation
and use of Vertices, and a reminder that the user is always welcome to create
their own vertices. While most vertex classes keep a table from neighboring vertex to edge,
this one keeps a linked list. This reduces the memory footprint, but makes
findEdge() (as well as most other methods) require time proportional
to the vertex's degree.
| Nested Class Summary |
|---|
| Nested classes/interfaces inherited from interface edu.uci.ics.jung.utils.UserDataContainer |
|---|
UserDataContainer.CopyAction |
| Field Summary | |
|---|---|
protected List |
incident_edges
|
| Fields inherited from class edu.uci.ics.jung.graph.impl.AbstractElement |
|---|
id, m_Graph |
| Fields inherited from class edu.uci.ics.jung.utils.UserDataDelegate |
|---|
factory, udc_delegate |
| Constructor Summary | |
|---|---|
LeanSparseVertex()
|
|
| Method Summary | |
|---|---|
protected void |
addNeighbor_internal(Edge e,
Vertex v)
Adds the specified edge e and vertex v
to the internal data structures of this vertex. |
Set |
findEdgeSet(Vertex w)
Returns the set of all edges that connect this vertex with the specified vertex v. |
protected Collection |
getEdges_internal()
Returns a set containing all the incident edges of this vertex. |
Set |
getInEdges()
Returns the set of incoming edges of this vertex. |
protected Collection |
getNeighbors_internal()
Returns a set containing all neighbors of this vertex. |
Set |
getOutEdges()
Returns the set of outgoing edges of this vertex. |
Set |
getPredecessors()
Returns the set of predecessors of this vertex. |
Set |
getSuccessors()
Returns the set of successors of this vertex. |
int |
inDegree()
Returns the number of incoming edges that are incident to this vertex. |
protected void |
initialize()
Initializes all the data structures for this element. |
boolean |
isDest(Edge e)
Returns true if this vertex is a destination of
the specified edge e, and false otherwise. |
boolean |
isPredecessorOf(Vertex v)
Returns true if this vertex is a predecessor of
the specified vertex v, and false otherwise. |
boolean |
isSource(Edge e)
Returns true if this vertex is a source of
the specified edge e, and false otherwise. |
boolean |
isSuccessorOf(Vertex v)
Returns true if this vertex is a successor of
the specified vertex v, and false otherwise. |
int |
numPredecessors()
Returns the number of predecessors of this vertex. |
int |
numSuccessors()
Returns the number of successors of this vertex. |
int |
outDegree()
Returns the number of outgoing edges that are incident to this vertex. |
protected void |
removeNeighbor_internal(Edge e,
Vertex v)
Removes the specified edge e and vertex v
from the internal data structures of this vertex. |
| Methods inherited from class edu.uci.ics.jung.graph.impl.AbstractSparseVertex |
|---|
copy, findEdge, findEdge, findEdgeSet, toString |
| Methods inherited from class edu.uci.ics.jung.graph.impl.AbstractArchetypeVertex |
|---|
degree, equals, getEqualVertex, getEquivalentVertex, getIncidentEdges, getIncidentElements, getNeighbors, isIncident, isNeighborOf, numNeighbors |
| Methods inherited from class edu.uci.ics.jung.graph.impl.AbstractElement |
|---|
addGraph_internal, getGraph, hashCode, removeGraph_internal |
| Methods inherited from class edu.uci.ics.jung.utils.UserDataDelegate |
|---|
addUserDatum, clone, containsUserDatumKey, getUserDatum, getUserDatumCopyAction, getUserDatumKeyIterator, importUserData, removeUserDatum, setUserDataFactory, setUserDatum |
| Methods inherited from class java.lang.Object |
|---|
finalize, getClass, notify, notifyAll, wait, wait, wait |
| Methods inherited from interface edu.uci.ics.jung.graph.ArchetypeVertex |
|---|
degree, getEqualVertex, getEquivalentVertex, getIncidentEdges, getNeighbors, isIncident, isNeighborOf, numNeighbors |
| Methods inherited from interface edu.uci.ics.jung.graph.Element |
|---|
getGraph, getIncidentElements |
| Methods inherited from interface edu.uci.ics.jung.utils.UserDataContainer |
|---|
addUserDatum, clone, containsUserDatumKey, getUserDatum, getUserDatumCopyAction, getUserDatumKeyIterator, importUserData, removeUserDatum, setUserDatum |
| Field Detail |
|---|
protected List incident_edges
| Constructor Detail |
|---|
public LeanSparseVertex()
| Method Detail |
|---|
protected void initialize()
AbstractElementclone() copies some information that should
not be in the new element.)
initialize in class AbstractElementprotected Collection getNeighbors_internal()
AbstractArchetypeVertex
getNeighbors_internal in class AbstractArchetypeVertexAbstractArchetypeVertex.getNeighbors_internal()protected Collection getEdges_internal()
AbstractArchetypeVertex
getEdges_internal in class AbstractArchetypeVertexAbstractArchetypeVertex.getEdges_internal()
protected void addNeighbor_internal(Edge e,
Vertex v)
AbstractSparseVertexe and vertex v
to the internal data structures of this vertex.
addNeighbor_internal in class AbstractSparseVertexe - the new incident edge of this vertexv - the new neighbor of this vertexAbstractSparseVertex.addNeighbor_internal(edu.uci.ics.jung.graph.Edge,
edu.uci.ics.jung.graph.Vertex)
protected void removeNeighbor_internal(Edge e,
Vertex v)
AbstractSparseVertexe and vertex v
from the internal data structures of this vertex.
removeNeighbor_internal in class AbstractSparseVertexe - the incident edge of this vertex which is being removedv - the neighbor of this vertex which is being removedAbstractSparseVertex.removeNeighbor_internal(edu.uci.ics.jung.graph.Edge,
edu.uci.ics.jung.graph.Vertex)public Set findEdgeSet(Vertex w)
Vertexv. Each edge in this set
will be either a directed outgoing edge from this vertex to
v, or an undirected edge connecting this vertex to
v. findEdge(v) may be used to return
a single (arbitrary) element of this set.
If v
is not connected to this vertex, returns an empty Set.
findEdgeSet in interface VertexfindEdgeSet in class AbstractSparseVertexVertex.findEdgeSet(Vertex)public Set getPredecessors()
Vertexv is a predecessor of this vertex if and only if
v.isPredecessorOf(this) returns true.
Each element of the set returned should implement Vertex.
Vertex.getPredecessors()public Set getSuccessors()
Vertexv is a successor of this vertex if and only if
v.isSuccessorOf(this) returns true.
Each element of the set returned should implement Vertex.
Vertex.getSuccessors()public Set getInEdges()
Vertexe is an incoming edge of this vertex if and only if
this.isDest(e) returns true.
Each element of the set returned should implement Edge.
Vertex.getInEdges()public Set getOutEdges()
Vertexe is an outgoing edge of this vertex if and only if
this.isSource(e) returns true.
Each element of the set returned should implement Edge.
Vertex.getOutEdges()public int inDegree()
Vertex
Vertex.inDegree()public int outDegree()
Vertex
Vertex.outDegree()public int numPredecessors()
Vertex
Vertex.numPredecessors()public int numSuccessors()
Vertex
Vertex.numSuccessors()public boolean isSuccessorOf(Vertex v)
Vertextrue if this vertex is a successor of
the specified vertex v, and false otherwise.
This vertex is a successor of v if and only if
there exists an edge e such that
v.isSource(e) == true and
this.isDest(e) == true.
The behavior of this method is undefined if v is not
an element of this vertex's graph.
Vertex.isSuccessorOf(edu.uci.ics.jung.graph.Vertex)public boolean isPredecessorOf(Vertex v)
Vertextrue if this vertex is a predecessor of
the specified vertex v, and false otherwise.
This vertex is a predecessor of v if and only if
there exists an edge e such that
this.isSource(e) == true and
v.isDest(e) == true.
The behavior of this method is undefined if v is not
an element of this vertex's graph.
Vertex.isPredecessorOf(edu.uci.ics.jung.graph.Vertex)public boolean isSource(Edge e)
Vertextrue if this vertex is a source of
the specified edge e, and false otherwise.
A vertex v is a source of e if e
is an outgoing edge of v.
The behavior of this method is undefined if e is not
an element of this vertex's graph.
Vertex.isSource(edu.uci.ics.jung.graph.Edge)public boolean isDest(Edge e)
Vertextrue if this vertex is a destination of
the specified edge e, and false otherwise.
A vertex v is a destination of e
if e is an incoming edge of v.
The behavior of this method is undefined if e is not
an element of this vertex's graph.
Vertex.isDest(edu.uci.ics.jung.graph.Edge)
|
||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||