Skip to content

Latest commit

 

History

History
32 lines (29 loc) · 2.05 KB

README.md

File metadata and controls

32 lines (29 loc) · 2.05 KB

Dag nodes in node.js

Experimenting with how to potentially process dags in Node.js

Project Elements

  • dagMap.js, which defines dag map examples. Nodes are defined by a key, and either of the following: 1) function reference and arguments (which can be other node keys) OR 2) a final value.
  • sim.js, which is the entry point to the app. Takes as arguments the 1) string target node, 2) string dag map to process, 3) (optional) json string of nodes to simulate/overwrite.
  • asyncDagProcessor.js, which as the name suggests, process the Dag in an asynchronous manner. That process is:
    • Determine all of the referenced nodes, based on the target node selected.
    • Create a new dag map with those nodes.
    • Add relationship data to each node, in the form of 2 lists, which are 1) other nodes this node is dependent on, and 2) other nodes that depend on this node.
    • Initializing processing by 'starting' any nodes that have no dependencies(logically there has to be at least one).
    • As nodes complete processing they will have a final value. They are removed from the list of nodes to evaluate. The node then has its list of dependent nodes evaluated, and those nodes are updated.
    • If the updated nodes has no other dependencies, they will be 'started'.
    • After all nodes have completed, processing stops and and a map of nodes with their final values is returned.
  • nodes folder, which contains the node functions used by the dag map. These would be imported from other projects, but as an example are in this project.

Target concepts to prove out

  • Define a dag map in a json format.
  • Simulate/overwrite individual nodes.
  • Combine dag maps.
  • Ability to store functions as strings.
  • Ability to validate function arguments. (see ow.js)
  • Process nodes as soon as they are able to be processed.

Run program

  • Clone repo, cd into
  • npm install
  • Command format:
    • npm run-script sim targetNodes dagMap
  • Examples:
    • npm run-script simOneDag '["habitable", "defendable"]' dagSpaceStation
    • npm run-script simOneDag '["habitable", "defendable"]' dagSpaceStationExpanded