public class TraversalBFS extends Traversal
Starting from a source node, it visits all its neighbors at distance 1, then all its neighbors at distance 2, and so on.
Check out the 'Algorithms' section in the SPARKSEE User Manual for more details on this.
| Constructor and Description |
|---|
TraversalBFS(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 TraversalBFS(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 Traversaltype - [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 Traversalnodes - [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 Traversaldir - [in] Edge direction.public void addNodeType(int type)
addNodeType in class Traversaltype - 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 Traversaledges - [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 Traversalpublic void addAllNodeTypes()
addAllNodeTypes in class Traversalpublic void setMaximumHops(int maxhops)
All paths longer than the maximum hops restriction will be ignored.
setMaximumHops in class Traversalmaxhops - [in] The maximum hops restriction. It must be positive or zero. Zero, the default value, means unlimited.