V
- vertex typeE
- edge typepublic class RandomWalkIterator<V,E> extends AbstractGraphIterator<V,E>
At each step the iterator selects a random (uniformly distributed) edge out of the current vertex and follows it to the next vertex. In case of directed graphs the outgoing edge set is used. See wikipedia for more details.
In case a weighted walk is desired, edges are selected with probability respective to its weight
(out of the total weight of the edges). The walk can be bounded by number of steps (default
Long#MAX_VALUE
. When the bound is reached the iterator is considered exhausted. Calling
next()
on exhausted iterator will throw NoSuchElementException
.
In case a sink (i.e. no edges) vertex is reached, any consecutive calls to next()
will
throw NoSuchElementException
.
For this iterator to work correctly the graph must not be modified during iteration. Currently there are no means to ensure that, nor to fail-fast. The results of such modifications are undefined.
crossComponentTraversal, graph, nListeners, reusableEdgeEvent, reusableVertexEvent, reuseEvents
Constructor and Description |
---|
RandomWalkIterator(Graph<V,E> graph)
Creates a new iterator for the specified graph.
|
RandomWalkIterator(Graph<V,E> graph,
V startVertex)
Creates a new iterator for the specified graph.
|
RandomWalkIterator(Graph<V,E> graph,
V startVertex,
boolean isWeighted)
Creates a new iterator for the specified graph.
|
RandomWalkIterator(Graph<V,E> graph,
V startVertex,
boolean isWeighted,
long maxSteps)
Creates a new iterator for the specified graph.
|
RandomWalkIterator(Graph<V,E> graph,
V startVertex,
boolean isWeighted,
long maxSteps,
Random rng)
Creates a new iterator for the specified graph.
|
Modifier and Type | Method and Description |
---|---|
protected void |
encounterVertex(V vertex,
E edge)
Update data structures every time we see a vertex.
|
boolean |
hasNext() |
protected boolean |
isExhausted()
Check if this walk is exhausted.
|
V |
next() |
addTraversalListener, createEdgeTraversalEvent, createVertexTraversalEvent, fireConnectedComponentFinished, fireConnectedComponentStarted, fireEdgeTraversed, fireVertexFinished, fireVertexTraversed, getGraph, isCrossComponentTraversal, isReuseEvents, remove, removeTraversalListener, setCrossComponentTraversal, setReuseEvents
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
forEachRemaining
public RandomWalkIterator(Graph<V,E> graph)
Long#MAX_VALUE
steps.graph
- the graph to be iterated.IllegalArgumentException
- if graph==null
or does not contain
startVertex
public RandomWalkIterator(Graph<V,E> graph, V startVertex)
null
, Iteration will start at an arbitrary graph vertex. Walk is un-weighted and
bounded by Long#MAX_VALUE
steps.graph
- the graph to be iterated.startVertex
- the vertex iteration to be started.IllegalArgumentException
- if graph==null
or does not contain
startVertex
public RandomWalkIterator(Graph<V,E> graph, V startVertex, boolean isWeighted)
null
, Iteration will start at an arbitrary graph vertex. Walk is bounded by
Long#MAX_VALUE
steps.graph
- the graph to be iterated.startVertex
- the vertex iteration to be started.isWeighted
- set to true
if a weighted walk is desired.IllegalArgumentException
- if graph==null
or does not contain
startVertex
public RandomWalkIterator(Graph<V,E> graph, V startVertex, boolean isWeighted, long maxSteps)
null
, Iteration will start at an arbitrary graph vertex. Walk is bounded by the
provided number steps.graph
- the graph to be iterated.startVertex
- the vertex iteration to be started.isWeighted
- set to true
if a weighted walk is desired.maxSteps
- number of steps before walk is exhausted.IllegalArgumentException
- if graph==null
or does not contain
startVertex
public RandomWalkIterator(Graph<V,E> graph, V startVertex, boolean isWeighted, long maxSteps, Random rng)
null
, Iteration will start at an arbitrary graph vertex. Walk is bounded by the
provided number steps.graph
- the graph to be iterated.startVertex
- the vertex iteration to be started.isWeighted
- set to true
if a weighted walk is desired.maxSteps
- number of steps before walk is exhausted.rng
- the random number generator to useIllegalArgumentException
- if graph==null
or does not contain
startVertex
protected boolean isExhausted()
next()
on exhausted iterator will throw
NoSuchElementException
.true
if this iterator is exhausted, false
otherwise.protected void encounterVertex(V vertex, E edge)
vertex
- the vertex encounterededge
- the edge via which the vertex was encountered, or null if the vertex is a
starting pointpublic boolean hasNext()
public V next()
Copyright © 2017. All rights reserved.