Class GraphComputerTest.VertexProgramM
- java.lang.Object
- 
- org.apache.tinkerpop.gremlin.process.computer.GraphComputerTest.VertexProgramM
 
- 
- All Implemented Interfaces:
- Cloneable,- VertexProgram
 - Enclosing class:
- GraphComputerTest
 
 public static class GraphComputerTest.VertexProgramM extends Object implements VertexProgram 
- 
- 
Nested Class Summary- 
Nested classes/interfaces inherited from interface org.apache.tinkerpop.gremlin.process.computer.VertexProgramVertexProgram.Builder, VertexProgram.Features
 
- 
 - 
Field SummaryFields Modifier and Type Field Description static StringKNOWS_ONLYstatic StringONE_OUT_EDGE_ONLYstatic StringOUT_EDGES_ONLYstatic StringPEOPLE_KNOWS_ONLYstatic StringPEOPLE_KNOWS_WELL_ONLYstatic StringPEOPLE_ONLYstatic StringSOFTWARE_ONLYstatic StringVERTICES_ONLY- 
Fields inherited from interface org.apache.tinkerpop.gremlin.process.computer.VertexProgramVERTEX_PROGRAM
 
- 
 - 
Constructor SummaryConstructors Constructor Description VertexProgramM()VertexProgramM(String state)
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description GraphComputerTest.VertexProgramMclone()When multiple workers on a single machine need VertexProgram instances, it is possible to use clone.voidexecute(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 theMessageScopepossibilities for a particular iteration of the vertex program.GraphComputer.PersistgetPreferredPersist()GraphComputer.ResultGraphgetPreferredResultGraph()voidloadState(Graph graph, org.apache.commons.configuration2.Configuration configuration)When it is necessary to load the state of the VertexProgram, this method is called.voidsetup(Memory memory)The method is called at the beginning of the computation.voidstoreState(org.apache.commons.configuration2.Configuration configuration)When it is necessary to store the state of the VertexProgram, this method is called.booleanterminate(Memory memory)The method is called at the end of each iteration to determine if the computation is complete.- 
Methods inherited from class java.lang.Objectequals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 - 
Methods inherited from interface org.apache.tinkerpop.gremlin.process.computer.VertexProgramgetFeatures, getMapReducers, getMemoryComputeKeys, getMessageCombiner, getTraverserRequirements, getVertexComputeKeys, workerIterationEnd, workerIterationStart
 
- 
 
- 
- 
- 
Field Detail- 
SOFTWARE_ONLYpublic static final String SOFTWARE_ONLY - See Also:
- Constant Field Values
 
 - 
PEOPLE_ONLYpublic static final String PEOPLE_ONLY - See Also:
- Constant Field Values
 
 - 
KNOWS_ONLYpublic static final String KNOWS_ONLY - See Also:
- Constant Field Values
 
 - 
PEOPLE_KNOWS_ONLYpublic static final String PEOPLE_KNOWS_ONLY - See Also:
- Constant Field Values
 
 - 
PEOPLE_KNOWS_WELL_ONLYpublic static final String PEOPLE_KNOWS_WELL_ONLY - See Also:
- Constant Field Values
 
 - 
VERTICES_ONLYpublic static final String VERTICES_ONLY - See Also:
- Constant Field Values
 
 - 
ONE_OUT_EDGE_ONLYpublic static final String ONE_OUT_EDGE_ONLY - See Also:
- Constant Field Values
 
 - 
OUT_EDGES_ONLYpublic static final String OUT_EDGES_ONLY - See Also:
- Constant Field Values
 
 
- 
 - 
Constructor Detail- 
VertexProgramMpublic VertexProgramM() 
 - 
VertexProgramMpublic VertexProgramM(String state) 
 
- 
 - 
Method Detail- 
setuppublic void setup(Memory memory) Description copied from interface:VertexProgramThe method is called at the beginning of the computation. The method is global to theGraphComputerand as such, is not called for each vertex. During this stage, theMemoryshould be initialized to to its "start state."- Specified by:
- setupin interface- VertexProgram
- Parameters:
- memory- The global memory of the GraphComputer
 
 - 
executepublic void execute(Vertex vertex, Messenger messenger, Memory memory) Description copied from interface:VertexProgramThis method denotes the main body of the computation and is executed on each vertex in the graph. This method is logically executed in parallel on all vertices in the graph. When theMemoryis read, it is according to the aggregated state yielded in the previous iteration. When theMemoryis written, the data will be aggregated at the end of the iteration for reading in the next iteration.- Specified by:
- executein interface- VertexProgram
- Parameters:
- vertex- the- Vertexto execute the- VertexProgramon
- messenger- the messenger that moves data between vertices
- memory- the shared state between all vertices in the computation
 
 - 
terminatepublic boolean terminate(Memory memory) Description copied from interface:VertexProgramThe method is called at the end of each iteration to determine if the computation is complete. The method is global to theGraphComputerand as such, is not called for eachVertex. TheMemorymaintains the aggregated data from the last execute() iteration.- Specified by:
- terminatein interface- VertexProgram
- Parameters:
- memory- The global memory of the- GraphComputer
- Returns:
- whether or not to halt the computation
 
 - 
getMessageScopespublic Set<MessageScope> getMessageScopes(Memory memory) Description copied from interface:VertexProgramThis method returns all theMessageScopepossibilities 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.- Specified by:
- getMessageScopesin interface- VertexProgram
- Parameters:
- memory- an immutable form of the- Memory
- Returns:
- all possible message scopes during said vertex program iteration
 
 - 
getPreferredResultGraphpublic GraphComputer.ResultGraph getPreferredResultGraph() - Specified by:
- getPreferredResultGraphin interface- VertexProgram
 
 - 
getPreferredPersistpublic GraphComputer.Persist getPreferredPersist() - Specified by:
- getPreferredPersistin interface- VertexProgram
 
 - 
clonepublic GraphComputerTest.VertexProgramM clone() Description copied from interface:VertexProgramWhen multiple workers on a single machine need VertexProgram instances, it is possible to use clone. This will provide a speedier way of generating instances, over theVertexProgram.storeState(org.apache.commons.configuration2.Configuration)andVertexProgram.loadState(org.apache.tinkerpop.gremlin.structure.Graph, org.apache.commons.configuration2.Configuration)model. The default implementation simply returns the object as it assumes that the VertexProgram instance is a stateless singleton.- Specified by:
- clonein interface- VertexProgram
- Overrides:
- clonein class- Object
- Returns:
- A clone of the VertexProgram object
 
 - 
loadStatepublic void loadState(Graph graph, org.apache.commons.configuration2.Configuration configuration) Description copied from interface:VertexProgramWhen it is necessary to load the state of the VertexProgram, this method is called. This is typically required when the VertexProgram needs to be serialized to another machine. Note that what is loaded is simply the instance state, not any processed data.- Specified by:
- loadStatein interface- VertexProgram
- Parameters:
- graph- the graph that the VertexProgram will run against
- configuration- the configuration to load the state of the VertexProgram from.
 
 - 
storeStatepublic void storeState(org.apache.commons.configuration2.Configuration configuration) Description copied from interface:VertexProgramWhen it is necessary to store the state of the VertexProgram, this method is called. This is typically required when the VertexProgram needs to be serialized to another machine. Note that what is stored is simply the instance/configuration state, not any processed data. The default implementation provided simply stores the VertexProgram class name for reflective reconstruction. It is typically a good idea to VertexProgram.super.storeState().- Specified by:
- storeStatein interface- VertexProgram
- Parameters:
- configuration- the configuration to store the state of the VertexProgram in.
 
 
- 
 
-