Live Demo: https://fireboltcasters.github.io/PrecedenceDiagramMethod/
npm install precedence-diagram-method
import {PrecedenceGraph} from "precedence-diagram-method";
let exampleGraph = {
"StartLabel": {
"children": [
"Marketing",
"Documentation"
],
"duration": 0
},
"Marketing": {
"children": [
"Publishing"
],
"duration": 3
},
"Documentation": {
"children": [
"Publishing"
],
"duration": 4
},
"Publishing": {
"children": [],
"duration": 2
}
}
let instance = new PrecedenceGraph(exampleGraph, "StartLabel");
let calcedGraph = instance.getGraph();
let criticalPath = instance.getCriticalPaths();
Each node will have to be in the following format:
<NameOfTheActiticy>: {
"children": [<Array of children names>],
"duraion": <DurationOfTheActivity>
}
Each node will have the following fields
- duration: number
- buffer: number
- earliestStart: number
- earliestEnd: number
- latestStart: number
- latestEnd: number
- children: [Node]
- parents: [Node]
You can also use additional methods:
Get the current precedence graph
instance.getGraph()
Get the start node label of the precedence graph
instance.getStartNode()
Returns is a connection between a child and a parent is critical (no buffer)
instance.isCriticalPath(parentId, childId)
Get the start node label of the precedence graph
instance.getStartNode()
Gets all ciritcal paths
instance. isCriticalPath()
Returns true if the loop has a directed loop
PrecedenceGraph.hasLoop(graph)
Resets all calced times on a graph and returns a copy
PrecedenceGraph.resetCalcedTimesGraph(graph)
Calculates the forward precedence graph from a given startLabel and returns a copy
PrecedenceGraph.calcForwardGraph(graph, startLabel)
Returns the highest earliest end on a given graph
PrecedenceGraph.getFromAllEarliestEndsTheLatest(graph)
Sets the highest earliest end to the latest end of all leaf nodes
PrecedenceGraph.setLatestStartToAllLeafes(graph)
Calculates the backward precedence graph
PrecedenceGraph.calcBackwardGraph(graph)
Returns all leaves of a given graph
PrecedenceGraph.getAllLeafes(graph)
There a more functions which I wont describe here further. More information has to be read from the source code.
The FireboltCasters