public class TraversalDFS extends Traversal
Starting from a source or root node, it visits as far as possible along each branch before backtracking.
Check out the 'Algorithms' section in the SPARKSEE User Manual for more details on this.
Constructor and Description |
---|
TraversalDFS(Session session,
long node)
Creates a new instance.
|
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 |
setMaximumHops(int maxhops)
Sets the maximum hops restriction.
|
public TraversalDFS(Session session, long node)
session
- [in] Session to get the graph from and perform traversal.node
- [in] Node to start traversal from.public void addEdgeType(int type, EdgesDirection dir)
addEdgeType
in class Traversal
type
- [in] Edge type.dir
- [in] Edge direction.public 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 addAllEdgeTypes(EdgesDirection dir)
addAllEdgeTypes
in class Traversal
dir
- [in] Edge direction.public void addNodeType(int type)
addNodeType
in class Traversal
type
- The node type to addpublic 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 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 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.