dag-iterator
v0.3.0
Published
utility tool to traverse DAG graphs in JavaScript
Downloads
17
Readme
DAG Iterator
An utility tool to traverse DAG graphs in JavaScript by depth-first search. It automatically injects the previous nodes as arguments for the current node. This can be used in Deep Learning to traverse the model graph of a DNN such as GoogLeNet.
Usage Typescript
import * as dag from 'dag-iterator';
const nodes: dag.INode<String>[] = [
{name: "A", data: "Node A"},
{name: "B", data: "Node B"},
{name: "C", data: "Node C"},
{name: "D", data: "Node D"},
{name: "E", data: "Node E"}
];
const edges: dag.IEdge[] = [
{src: "A", dst: "B"},
{src: "A", dst: "C"},
{src: "B", dst: "C"},
{src: "C", dst: "D"},
{src: "B", dst: "E"}
];
// ---► B ---► E
// / |
// A |
// \ ▼
// ---► C ---► D
dag.iterateDfs<String>(nodes, edges, (node, parents, i, depth) => {
console.log(node, parents, i, depth);
});
/*
* Outputs:
* > Node A [] 0 0
* > Node B ["Node A"] 1 1
* > Node E ["Node B"] 2 2
* > Node C (2) ["Node A", "Node B"] 3 2
* > Node D ["Node C"] 4 3
*/
dag.iterateBfs<String>(nodes, edges, (node, parents, i, depth) => {
console.log(node, parents, i, depth);
});
/*
* Outputs:
* > Node A [] 0 0
* > Node B ["Node A"] 1 1
* > Node C (2) ["Node A", "Node B"] 2 2
* > Node E ["Node B"] 3 2
* > Node D ["Node C"] 4 3
*/
Usage Browser
<script src="https://unpkg.com/dag-iterator"></script>
<script>
var nodes = [
{name: "A", data: "Node A"},
{name: "B", data: "Node B"},
{name: "C", data: "Node C"},
{name: "D", data: "Node D"},
{name: "E", data: "Node E"}
];
var edges = [
{src: "A", dst: "B"},
{src: "A", dst: "C"},
{src: "B", dst: "C"},
{src: "C", dst: "D"},
{src: "B", dst: "E"}
];
// ---► B ---► E
// / |
// A |
// \ ▼
// ---► C ---► D
// Iterate the graph
dagIterator.iterateDfs(nodes, edges, function(node, parents, i, depth){
console.log(node, parents, i, depth);
});
/*
* Outputs:
* > Node A [] 0 0
* > Node B ["Node A"] 1 1
* > Node E ["Node B"] 2 2
* > Node C (2) ["Node A", "Node B"] 3 2
* > Node D ["Node C"] 4 3
*/
// Iterate the graph until node C
dagIterator.iterateDfs(nodes, edges, function(node, parents, i, depth){
console.log(node, parents, i)
}, "C");
/*
* Outputs:
* > Node A [] 0
* > Node B ["Node A"] 1
* > Node E ["Node B"] 2
* > Node C (2) ["Node A", "Node B"] 3
*/
</script>
Development
# Install dependencies
npm install
# Build the JS file and TS declaration
npm run build
# Run the tests
npm run test
Changelog
- 0.3.0
- Add
iterateDfs
anditerateBfs
, adddepth
parameter in iteratorFn
- Add
- 0.2.3
- Start traversing from multiple nodes
- 0.2.2
- Add check if first node exists in edges
- 0.2.1
- Add generic type to INode and iterate
- 0.1.2
- Add until node parameter
- 0.1.1
- Initial release
License
The software is provided under MIT license.