SparkseePython  6.0.2
Public Member Functions | List of all members
sparksee.SinglePairShortestPathBFS Class Reference

SinglePairShortestPathBFS class. More...

Inheritance diagram for sparksee.SinglePairShortestPathBFS:
Inheritance graph
Collaboration diagram for sparksee.SinglePairShortestPathBFS:
Collaboration graph

Public Member Functions

def exclude_nodes (self, nodes)
 Set which nodes can't be used. More...
 
def get_cost (self)
 Gets the cost of the shortest path. More...
 
def run (self)
 Executes the algorithm.
 
def add_all_edge_types (self, dir)
 Allows for traversing all edge types of the graph. More...
 
def exclude_edges (self, edges)
 Set which edges can't be used. More...
 
def __init__ (self, session, src, dst)
 Creates a new instance. More...
 
def add_edge_type (self, type, dir)
 Allows for traversing edges of the given type. More...
 
def get_path_as_nodes (self)
 Gets the shortest path between the source node and the destination node as an ordered set of nodes. More...
 
def add_node_type (self, type)
 Allows for traversing nodes of the given type. More...
 
def exists (self)
 Returns TRUE If a path exists or FALSE otherwise.
 
def check_only_existence (self)
 Set that only the path existence must be calculated and not the path itself. More...
 
def get_path_as_edges (self)
 Gets the shortest path between the source node and the destination node as an ordered set of edges. More...
 
def set_maximum_hops (self, maxhops)
 Sets the maximum hops restriction. More...
 
def add_all_node_types (self)
 Allows for traversing all node types of the graph.
 
def close (self)
 Closes the ShortestPath instance. More...
 
def is_closed (self)
 Gets if ShortestPath has been closed or not. More...
 

Detailed Description

SinglePairShortestPathBFS class.

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.

Author
Sparsity Technologies http://www.sparsity-technologies.com

Constructor & Destructor Documentation

def sparksee.SinglePairShortestPathBFS.__init__ (   self,
  session,
  src,
  dst 
)

Creates a new instance.

Parameters
session[in] Session to get the graph from and perform traversal.
src[in] Source node.
dst[dst] Destination node.

Member Function Documentation

def sparksee.SinglePairShortestPathBFS.add_all_edge_types (   self,
  dir 
)

Allows for traversing all edge types of the graph.

Parameters
dir[in] Edge direction.
def sparksee.SinglePairShortestPathBFS.add_edge_type (   self,
  type,
  dir 
)

Allows for traversing edges of the given type.

Parameters
type[in] Edge type.
dir[in] Edge direction.
def sparksee.SinglePairShortestPathBFS.add_node_type (   self,
  type 
)

Allows for traversing nodes of the given type.

Parameters
typenull
def sparksee.SinglePairShortestPathBFS.check_only_existence (   self)

Set that only the path existence must be calculated and not the path itself.

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.

def sparksee.ShortestPath.close (   self)
inherited

Closes the ShortestPath instance.

It must be called to ensure the integrity of all data.

def sparksee.SinglePairShortestPathBFS.exclude_edges (   self,
  edges 
)

Set which edges can't be used.

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.

Parameters
edges[in] A set of edge identifiers that must be kept intact until the destruction of the class.
def sparksee.SinglePairShortestPathBFS.exclude_nodes (   self,
  nodes 
)

Set which nodes can't be used.

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.

Parameters
nodes[in] A set of node identifiers that must be kept intact until the destruction of the class.
def sparksee.SinglePairShortestPathBFS.get_cost (   self)

Gets the cost of the shortest path.

The cost is the number of hops of the shortest path.

Returns
The cost of the shortest path.
def sparksee.SinglePairShortestPathBFS.get_path_as_edges (   self)

Gets the shortest path between the source node and the destination node as an ordered set of edges.

Returns
Ordered set of edge identifiers.
def sparksee.SinglePairShortestPathBFS.get_path_as_nodes (   self)

Gets the shortest path between the source node and the destination node as an ordered set of nodes.

Returns
Ordered set of node identifiers.
def sparksee.ShortestPath.is_closed (   self)
inherited

Gets if ShortestPath has been closed or not.

See also
close()
Returns
TRUE if the ShortestPath instance has been closed, FALSE otherwise.
def sparksee.SinglePairShortestPathBFS.set_maximum_hops (   self,
  maxhops 
)

Sets the maximum hops restriction.

All paths longer than the maximum hops restriction will be ignored.

Parameters
maxhops[in] The maximum hops restriction. It must be positive or zero. Zero, the default value, means unlimited.