| writeToFile() |  | 0% |  | 0% | 4 | 4 | 26 | 26 | 1 | 1 |
| addStep(String, RelOptRuleCall) |  | 0% |  | 0% | 7 | 7 | 21 | 21 | 1 | 1 |
| updateNodeInfo(RelNode, boolean) |  | 0% |  | 0% | 4 | 4 | 20 | 20 | 1 | 1 |
| ruleProductionSucceeded(RelOptListener.RuleProductionEvent) |  | 0% |  | 0% | 4 | 4 | 15 | 15 | 1 | 1 |
| updateFinalPlan(RelNode) |  | 0% |  | 0% | 6 | 6 | 14 | 14 | 1 | 1 |
| formatCost(Double, RelOptCost) |  | 0% |  | 0% | 5 | 5 | 12 | 12 | 1 | 1 |
| RuleMatchVisualizer(String, String) |  | 0% | | n/a | 1 | 1 | 12 | 12 | 1 | 1 |
| getNodeLabel(RelNode) |  | 0% |  | 0% | 2 | 2 | 6 | 6 | 1 | 1 |
| relEquivalenceFound(RelOptListener.RelEquivalenceEvent) |  | 0% |  | 0% | 2 | 2 | 10 | 10 | 1 | 1 |
| RuleMatchVisualizer() |  | 0% | | n/a | 1 | 1 | 12 | 12 | 1 | 1 |
| getJsonStringResult() |  | 0% | | n/a | 1 | 1 | 10 | 10 | 1 | 1 |
| lambda$registerRelNode$2(RelNode, String) |  | 0% |  | 0% | 2 | 2 | 7 | 7 | 1 | 1 |
| updateInitialPlan(RelNode) |  | 0% |  | 0% | 3 | 3 | 8 | 8 | 1 | 1 |
| getSetId(RelSubset) |  | 0% |  | 0% | 3 | 3 | 8 | 8 | 1 | 1 |
| relChosen(RelOptListener.RelChosenEvent) |  | 0% |  | 0% | 2 | 2 | 7 | 7 | 1 | 1 |
| lambda$registerSet$1(String, String) |  | 0% |  | 0% | 2 | 2 | 4 | 4 | 1 | 1 |
| ruleAttempted(RelOptListener.RuleAttemptedEvent) |  | 0% |  | 0% | 2 | 2 | 6 | 6 | 1 | 1 |
| attachTo(RelOptPlanner) |  | 0% |  | 0% | 3 | 3 | 4 | 4 | 1 | 1 |
| formatCostScientific(double) |  | 0% | | n/a | 1 | 1 | 4 | 4 | 1 | 1 |
| lambda$updateNodeInfo$6(List, Set, RelSubset) |  | 0% |  | 0% | 2 | 2 | 4 | 4 | 1 | 1 |
| key(RelNode) |  | 0% | | n/a | 1 | 1 | 1 | 1 | 1 | 1 |
| getNodeExplanation(RelNode) |  | 0% | | n/a | 1 | 1 | 3 | 3 | 1 | 1 |
| registerRelNode(RelNode) |  | 0% | | n/a | 1 | 1 | 1 | 1 | 1 | 1 |
| registerSet(String) |  | 0% | | n/a | 1 | 1 | 2 | 2 | 1 | 1 |
| lambda$updateNodeInfo$4(RelSubset, RelSubset) |  | 0% |  | 0% | 2 | 2 | 1 | 1 | 1 | 1 |
| lambda$getInputs$0(RelNode) |  | 0% |  | 0% | 2 | 2 | 1 | 1 | 1 | 1 |
| static {...} |  | 0% |  | 0% | 2 | 2 | 1 | 1 | 1 | 1 |
| lambda$addStep$8(NodeUpdateHelper) |  | 0% | | n/a | 1 | 1 | 1 | 1 | 1 | 1 |
| lambda$updateNodeInfo$7(List, RelNode) |  | 0% | | n/a | 1 | 1 | 1 | 1 | 1 | 1 |
| lambda$updateNodeInfo$5(Set, RelNode) |  | 0% | | n/a | 1 | 1 | 1 | 1 | 1 | 1 |
| lambda$updateNodeInfo$3(List, RelNode) |  | 0% | | n/a | 1 | 1 | 1 | 1 | 1 | 1 |
| getInputs(RelNode) |  | 0% | | n/a | 1 | 1 | 1 | 1 | 1 | 1 |
| setIncludeTransitiveEdges(boolean) |  | 0% | | n/a | 1 | 1 | 2 | 2 | 1 | 1 |
| setIncludeIntermediateCosts(boolean) |  | 0% | | n/a | 1 | 1 | 2 | 2 | 1 | 1 |
| relDiscarded(RelOptListener.RelDiscardedEvent) | | 0% | | n/a | 1 | 1 | 1 | 1 | 1 | 1 |