public class RandomWalk extends Traversal
Implements the RandomWalk algorithm
Constructor and Description |
---|
RandomWalk(Session session,
long node)
Builds the RandomWalk.
|
Modifier and Type | Method and Description |
---|---|
void |
addAllEdgeTypes(EdgesDirection dir)
Allows for traversing all edge types of the graph.
|
void |
addAllNodeTypes()
Allows for traversing all node types of the graph.
|
void |
addEdgeType(int type,
EdgesDirection dir)
Allows for traversing edges of the given type.
|
void |
addNodeType(int type)
Allows for traversing nodes of the given type.
|
void |
excludeEdges(Objects edges)
Set which edges can't be used.
|
void |
excludeNodes(Objects nodes)
Set which nodes can't be used.
|
int |
getCurrentDepth()
Returns the depth of the current node.
|
boolean |
hasNext()
Gets if there are more objects to be traversed.
|
long |
next()
Gets the next object of the traversal.
|
void |
reset(long startNode)
Sets the starting node of the RandomWalk.
|
void |
setDefaultWeight(double weight)
Sets the default weight for those cases when a given edge does not have a weight attribute set.
|
void |
setEdgeWeightAttributeType(int attr)
Sets the attribute to use as edge weight.
|
void |
setInOutParameter(double val)
Sets the In-Out parameter of the RandomWalk.
|
void |
setMaximumHops(int maxhops)
Sets the maximum hops restriction.
|
void |
setReturnParameter(double val)
Sets the return parameter of the RandomWalk.
|
void |
setSeed(int seed)
Sets the seed of the random walk.
|
public RandomWalk(Session session, long node)
session
- [in] The session to usenode
- [in] The starting node of the traversalpublic void excludeNodes(Objects nodes)
This will replace any previously specified set of excluded nodes. Should only be used to exclude the usage of specific nodes from allowed node types because it's less efficient than not allowing a node type.
excludeNodes
in class Traversal
nodes
- [in] A set of node identifiers that must be kept intact until the destruction of the class.public void setDefaultWeight(double weight)
Default: 0.0
weight
- [in] The default weightpublic void addAllEdgeTypes(EdgesDirection dir)
addAllEdgeTypes
in class Traversal
dir
- [in] Edge direction.public void excludeEdges(Objects edges)
This will replace any previously specified set of excluded edges. Should only be used to exclude the usage of specific edges from allowed edge types because it's less efficient than not allowing an edge type.
excludeEdges
in class Traversal
edges
- [in] A set of edge identifiers that must be kept intact until the destruction of the class.public void setSeed(int seed)
seed
- The seed to generate the random numbers that drive the random walkpublic void setEdgeWeightAttributeType(int attr)
If the multiple edge are set for traversal, this attribute must be of type GLOBAL_TYPE or EDGES_TYPE. Additionally, the attribute must be of type Double. Finally, negative weights are treated as non existing, so the default weight applies.
attr
- [in] The attribute type to use as a weight. Default: InvalidAttributepublic void setInOutParameter(double val)
val
- The In-Out parameter to set. Default: 1.0public void addEdgeType(int type, EdgesDirection dir)
If the edge type was already added, the existing direction is overwritten
addEdgeType
in class Traversal
type
- [in] Edge type.dir
- [in] Edge direction.public void addNodeType(int type)
addNodeType
in class Traversal
type
- The node type to addpublic void setReturnParameter(double val)
val
- The return parameter to set. Default: 1.0public long next()
public boolean hasNext()
public int getCurrentDepth()
That is, it returns the depth of the node returned in the last call to Next().
getCurrentDepth
in class Traversal
public void reset(long startNode)
This method resets the RandomWalk.
sparksee::gdb::Error
startNode
- nullpublic void addAllNodeTypes()
addAllNodeTypes
in class Traversal
public void setMaximumHops(int maxhops)
All paths longer than the maximum hops restriction will be ignored.
setMaximumHops
in class Traversal
maxhops
- [in] The maximum hops restriction. It must be positive or zero. Zero, the default value, means unlimited.