loom.alg-generic

(source)
Graph algorithms for use on any type of graph
Public Variable Short Description
->Ancestry (clj)
Ancestry (clj)
ancestor? (clj) Finds if the 'parenter node is an ancestor of 'childer node for the given 'ancestry cache.
ancestors (clj) Returns all of the ancestors of 'child node.
ancestry-add (clj) Adds a 'node and its 'parents associations to the 'ancestry cache.
ancestry-contains? (clj) Finds if a 'node is contained in the 'ancestry cache.
ancestry-new (clj) Create a new, empty Ancestry cache.
ancestry-nodes (clj) Returns all of the nodes in an 'ancestry.
bf-path (clj) Returns a path from start to end with the fewest hops (i.e.
bf-path-bi (clj) Using a bidirectional breadth-first search, finds a path from start to end with the fewest hops (i.e.
bf-paths-bi (clj) Using a bidirectional breadth-first search, returns all shortest paths from start to end; predecessors is called on end and each preceding node, successors is called on start, etc.
bf-span (clj) Return a breadth-first spanning tree of the form {node [successors]}.
bf-traverse (clj) Traverses a graph breadth-first from start, successors being a function that returns adjacent nodes.
bits-per-long (clj)
bm-get (clj) Get boolean state of bit in 'bitmap at 'idx.
bm-get-indicies (clj) Get the indicies of set bits in 'bitmap.
bm-longs (clj) Returns the number of longs required to store bits count bits in a bitmap.
bm-new (clj) Create new empty bitmap.
bm-or (clj) Logically OR 'bitmaps together.
bm-set (clj) Set boolean state of bit in 'bitmap at 'idx to true.
dijkstra-path (clj) Finds the shortest path from start to end, where successors and dist are functions called as (successors node) and (dist node1 node2).
dijkstra-path-dist (clj) Finds the shortest path from start to end, where successors and dist are functions called as (successors node) and (dist node1 node2).
dijkstra-span (clj) Finds all shortest distances from start, where successors and dist are functions called as (successors node) and (dist node1 node2).
dijkstra-traverse (clj) Returns a lazy-seq of [current-node state] where state is a map in the format {node [distance predecessor]}.
map->Ancestry (clj)
paths (clj) Returns a lazy seq of all non-looping path vectors starting with [<start-node>].
post-edge-traverse (clj) Traverses a graph depth-first postorder from start, successors being a function that returns direct successors for the node.
post-traverse (clj) Traverses a graph depth-first postorder from start, successors being a function that returns adjacent nodes.
pre-edge-traverse (clj) Traverses a graph depth-first preorder from start, successors being a function that returns direct successors for the node.
pre-span (clj) Returns a depth-first spanning tree of the form {node [successors]}.
pre-traverse (clj) Traverses a graph depth-first preorder from start, successors being a function that returns direct successors for the node.
preds->span (clj) Converts a map of the form {node predecessor} to a spanning tree of the form {node [successors]}.
topsort-component (clj) Topological sort of a component of a (presumably) directed graph.
trace-path (clj) Using a map of nodes-to-preds, traces a node's family tree back to the source.
trace-paths (clj) Given a function and a starting node, returns all possible paths back to source.