public static class GraphComputerTest.VertexProgramL extends Object implements VertexProgram
VertexProgram.Builder, VertexProgram.Features
VERTEX_PROGRAM
Constructor and Description |
---|
VertexProgramL() |
Modifier and Type | Method and Description |
---|---|
GraphComputerTest.VertexProgramL |
clone()
When multiple workers on a single machine need VertexProgram instances, it is possible to use clone.
|
void |
execute(Vertex vertex,
Messenger messenger,
Memory memory)
This method denotes the main body of the computation and is executed on each vertex in the graph.
|
Set<MemoryComputeKey> |
getMemoryComputeKeys()
The
Memory keys that will be used during the computation. |
Set<MessageScope> |
getMessageScopes(Memory memory)
This method returns all the
MessageScope possibilities for a particular iteration of the vertex program. |
GraphComputer.Persist |
getPreferredPersist() |
GraphComputer.ResultGraph |
getPreferredResultGraph() |
void |
setup(Memory memory)
The method is called at the beginning of the computation.
|
void |
storeState(Configuration configuration)
When it is necessary to store the state of the VertexProgram, this method is called.
|
boolean |
terminate(Memory memory)
The method is called at the end of each iteration to determine if the computation is complete.
|
equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
createVertexProgram, getFeatures, getMapReducers, getMessageCombiner, getVertexComputeKeys, loadState, workerIterationEnd, workerIterationStart
public void setup(Memory memory)
VertexProgram
GraphComputer
and as such, is not called for each vertex.
During this stage, the Memory
should be initialized to to its "start state."setup
in interface VertexProgram
memory
- The global memory of the GraphComputerpublic void execute(Vertex vertex, Messenger messenger, Memory memory)
VertexProgram
Memory
is read, it is according to the aggregated state yielded in the previous iteration.
When the Memory
is written, the data will be aggregated at the end of the iteration for reading in the next iteration.execute
in interface VertexProgram
vertex
- the Vertex
to execute the VertexProgram
onmessenger
- the messenger that moves data between verticesmemory
- the shared state between all vertices in the computationpublic boolean terminate(Memory memory)
VertexProgram
GraphComputer
and as such, is not called for each Vertex
.
The Memory
maintains the aggregated data from the last execute() iteration.terminate
in interface VertexProgram
memory
- The global memory of the GraphComputer
public Set<MemoryComputeKey> getMemoryComputeKeys()
VertexProgram
Memory
keys that will be used during the computation.
These are the only keys that can be read or written throughout the life of the GraphComputer
.
The default is an empty set.getMemoryComputeKeys
in interface VertexProgram
public Set<MessageScope> getMessageScopes(Memory memory)
VertexProgram
MessageScope
possibilities for a particular iteration of the vertex program.
The returned messages scopes are the scopes that will be used to send messages during the stated iteration.
It is not a requirement that all stated messages scopes be used, just that it is possible that they be used during the iteration.getMessageScopes
in interface VertexProgram
memory
- an immutable form of the Memory
public GraphComputer.ResultGraph getPreferredResultGraph()
getPreferredResultGraph
in interface VertexProgram
public GraphComputer.Persist getPreferredPersist()
getPreferredPersist
in interface VertexProgram
public GraphComputerTest.VertexProgramL clone()
VertexProgram
VertexProgram.storeState(Configuration)
and VertexProgram.loadState(org.apache.tinkerpop.gremlin.structure.Graph, Configuration)
model.
The default implementation simply returns the object as it assumes that the VertexProgram instance is a stateless singleton.clone
in interface VertexProgram
clone
in class Object
public void storeState(Configuration configuration)
VertexProgram
storeState
in interface VertexProgram
configuration
- the configuration to store the state of the VertexProgram in.Copyright © 2013–2016 Apache Software Foundation. All rights reserved.