public static class GraphComputerTest.VertexProgramM extends Object implements VertexProgram
VertexProgram.Builder, VertexProgram.Features| Modifier and Type | Field and Description |
|---|---|
static String |
KNOWS_ONLY |
static String |
ONE_OUT_EDGE_ONLY |
static String |
OUT_EDGES_ONLY |
static String |
PEOPLE_KNOWS_ONLY |
static String |
PEOPLE_KNOWS_WELL_ONLY |
static String |
PEOPLE_ONLY |
static String |
SOFTWARE_ONLY |
static String |
VERTICES_ONLY |
VERTEX_PROGRAM| Constructor and Description |
|---|
VertexProgramM() |
VertexProgramM(String state) |
| Modifier and Type | Method and Description |
|---|---|
GraphComputerTest.VertexProgramM |
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<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 |
loadState(Graph graph,
Configuration configuration)
When it is necessary to load the state of the VertexProgram, this method is called.
|
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, waitcreateVertexProgram, getFeatures, getMapReducers, getMemoryComputeKeys, getMessageCombiner, getTraverserRequirements, getVertexComputeKeys, workerIterationEnd, workerIterationStartpublic static final String SOFTWARE_ONLY
public static final String PEOPLE_ONLY
public static final String KNOWS_ONLY
public static final String PEOPLE_KNOWS_ONLY
public static final String PEOPLE_KNOWS_WELL_ONLY
public static final String VERTICES_ONLY
public static final String ONE_OUT_EDGE_ONLY
public static final String OUT_EDGES_ONLY
public VertexProgramM()
public VertexProgramM(String state)
public void setup(Memory memory)
VertexProgramGraphComputer 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 VertexProgrammemory - The global memory of the GraphComputerpublic void execute(Vertex vertex, Messenger messenger, Memory memory)
VertexProgramMemory 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 VertexProgramvertex - 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)
VertexProgramGraphComputer and as such, is not called for each Vertex.
The Memory maintains the aggregated data from the last execute() iteration.terminate in interface VertexProgrammemory - The global memory of the GraphComputerpublic Set<MessageScope> getMessageScopes(Memory memory)
VertexProgramMessageScope 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 VertexProgrammemory - an immutable form of the Memorypublic GraphComputer.ResultGraph getPreferredResultGraph()
getPreferredResultGraph in interface VertexProgrampublic GraphComputer.Persist getPreferredPersist()
getPreferredPersist in interface VertexProgrampublic GraphComputerTest.VertexProgramM clone()
VertexProgramVertexProgram.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 VertexProgramclone in class Objectpublic void loadState(Graph graph, Configuration configuration)
VertexProgramloadState in interface VertexProgramgraph - the graph that the VertexProgram will run againstconfiguration - the configuration to load the state of the VertexProgram from.public void storeState(Configuration configuration)
VertexProgramstoreState in interface VertexProgramconfiguration - the configuration to store the state of the VertexProgram in.Copyright © 2013–2019 Apache Software Foundation. All rights reserved.