public class SinglePairShortestPathBFS extends SinglePairShortestPath
It solves the single-pair shortest path problem using a BFS-based implementation.
It is a unweighted algorithm, that is it assumes all edges have the same cost.
Check out the 'Algorithms' section in the SPARKSEE User Manual for more details on this.
| Constructor and Description |
|---|
SinglePairShortestPathBFS(Session session,
long src,
long dst)
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 |
checkOnlyExistence()
Set that only the path existence must be calculated and not the path itself.
|
void |
excludeEdges(Objects edges)
Set which edges can't be used.
|
void |
excludeNodes(Objects nodes)
Set which nodes can't be used.
|
boolean |
exists()
Returns TRUE If a path exists or FALSE otherwise.
|
double |
getCost()
Gets the cost of the shortest path.
|
OIDList |
getPathAsEdges()
Gets the shortest path between the source node and the destination node as an ordered set of edges.
|
OIDList |
getPathAsNodes()
Gets the shortest path between the source node and the destination node as an ordered set of nodes.
|
void |
run()
Executes the algorithm.
|
void |
setMaximumHops(int maxhops)
Sets the maximum hops restriction.
|
close, isClosedpublic SinglePairShortestPathBFS(Session session, long src, long dst)
session - [in] Session to get the graph from and perform traversal.src - [in] Source node.dst - [dst] Destination node.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 SinglePairShortestPathnodes - [in] A set of node identifiers that must be kept intact until the destruction of the class.public double getCost()
The cost is the number of hops of the shortest path.
getCost in class SinglePairShortestPathpublic void run()
run in class SinglePairShortestPathpublic void addAllEdgeTypes(EdgesDirection dir)
addAllEdgeTypes in class SinglePairShortestPathdir - [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 SinglePairShortestPathedges - [in] A set of edge identifiers that must be kept intact until the destruction of the class.public void addEdgeType(int type,
EdgesDirection dir)
addEdgeType in class SinglePairShortestPathtype - [in] Edge type.dir - [in] Edge direction.public OIDList getPathAsNodes()
getPathAsNodes in class SinglePairShortestPathpublic void addNodeType(int type)
addNodeType in class SinglePairShortestPathtype - nullpublic boolean exists()
exists in class SinglePairShortestPathpublic void checkOnlyExistence()
That method should improve the performance of the algorithm, but a call to GetPathAsNodes or GetPathAsEdges will generate an exception even if the path exists.
public OIDList getPathAsEdges()
getPathAsEdges in class SinglePairShortestPathpublic void setMaximumHops(int maxhops)
All paths longer than the maximum hops restriction will be ignored.
setMaximumHops in class SinglePairShortestPathmaxhops - [in] The maximum hops restriction. It must be positive or zero. Zero, the default value, means unlimited.public void addAllNodeTypes()
addAllNodeTypes in class SinglePairShortestPath