| RelOptUtil |  | 0% |  | 0% | 597 | 597 | 1,506 | 1,506 | 153 | 153 | 1 | 1 |
| SubstitutionVisitor |  | 0% |  | 0% | 233 | 233 | 594 | 594 | 46 | 46 | 1 | 1 |
| RelTraitSet |  | 0% |  | 0% | 115 | 115 | 205 | 205 | 43 | 43 | 1 | 1 |
| Strong |  | 0% |  | 0% | 51 | 51 | 135 | 135 | 20 | 20 | 1 | 1 |
| RexImplicationChecker |  | 0% |  | 0% | 84 | 84 | 140 | 140 | 13 | 13 | 1 | 1 |
| RelOptRule |  | 0% |  | 0% | 63 | 63 | 107 | 107 | 38 | 38 | 1 | 1 |
| AbstractRelOptPlanner |  | 0% |  | 0% | 73 | 73 | 128 | 128 | 46 | 46 | 1 | 1 |
| RelOptMaterializations |  | 0% |  | 0% | 29 | 29 | 108 | 108 | 9 | 9 | 1 | 1 |
| RelOptPredicateList |  | 0% |  | 0% | 42 | 42 | 96 | 96 | 11 | 11 | 1 | 1 |
| ConventionTraitDef |  | 0% |  | 0% | 39 | 39 | 73 | 73 | 13 | 13 | 1 | 1 |
| VisitorDataContext |  | 0% |  | 0% | 32 | 32 | 63 | 63 | 10 | 10 | 1 | 1 |
| RelOptRuleOperand |  | 0% |  | 0% | 39 | 39 | 66 | 66 | 14 | 14 | 1 | 1 |
| RelOptMaterialization.new RelShuttleImpl() {...} |  | 0% |  | 0% | 19 | 19 | 82 | 82 | 4 | 4 | 1 | 1 |
| AbstractRelOptPlanner.RuleAttemptsListener |  | 0% |  | 0% | 14 | 14 | 45 | 45 | 9 | 9 | 1 | 1 |
| SubstitutionVisitor.AggregateOnCalcToAggregateUnifyRule |  | 0% |  | 0% | 11 | 11 | 58 | 58 | 3 | 3 | 1 | 1 |
| RelOptRules |  | 0% | | 0% | 2 | 2 | 15 | 15 | 1 | 1 | 1 | 1 |
| RelOptUtil.RelHintPropagateShuttle |  | 0% |  | 0% | 26 | 26 | 44 | 44 | 13 | 13 | 1 | 1 |
| RelOptCluster |  | 0% |  | 0% | 29 | 29 | 51 | 51 | 23 | 23 | 1 | 1 |
| SubstitutionVisitor.JoinOnCalcsToJoinUnifyRule |  | 0% |  | 0% | 8 | 8 | 44 | 44 | 3 | 3 | 1 | 1 |
| RuleEventLogger |  | 0% |  | 0% | 15 | 15 | 25 | 25 | 9 | 9 | 1 | 1 |
| RelCompositeTrait |  | 0% |  | 0% | 26 | 26 | 33 | 33 | 12 | 12 | 1 | 1 |
| RelOptRuleCall |  | 0% |  | 0% | 25 | 25 | 43 | 43 | 18 | 18 | 1 | 1 |
| RelOptUtil.SubTreeHintPropagateShuttle |  | 0% |  | 0% | 19 | 19 | 40 | 40 | 8 | 8 | 1 | 1 |
| SubstitutionVisitor.JoinOnRightCalcToJoinUnifyRule |  | 0% |  | 0% | 8 | 8 | 37 | 37 | 3 | 3 | 1 | 1 |
| SubstitutionVisitor.JoinOnLeftCalcToJoinUnifyRule |  | 0% |  | 0% | 8 | 8 | 37 | 37 | 3 | 3 | 1 | 1 |
| RelOptUtil.RexInputConverter |  | 0% |  | 0% | 16 | 16 | 34 | 34 | 6 | 6 | 1 | 1 |
| RelRule.OperandDetailBuilderImpl |  | 0% | | 0% | 13 | 13 | 28 | 28 | 11 | 11 | 1 | 1 |
| RexImplicationChecker.InputUsageFinder |  | 0% |  | 0% | 15 | 15 | 36 | 36 | 7 | 7 | 1 | 1 |
| SubstitutionVisitor.CalcToCalcUnifyRule |  | 0% |  | 0% | 8 | 8 | 34 | 34 | 3 | 3 | 1 | 1 |
| RelOptUtil.TypeDumper |  | 0% |  | 0% | 10 | 10 | 36 | 36 | 4 | 4 | 1 | 1 |
| SubstitutionVisitor.UnifyRuleCall |  | 0% |  | 0% | 14 | 14 | 19 | 19 | 7 | 7 | 1 | 1 |
| RelOptUtil.InputFinder |  | 0% | | 0% | 14 | 14 | 29 | 29 | 12 | 12 | 1 | 1 |
| RelOptMaterialization |  | 0% |  | 0% | 7 | 7 | 35 | 35 | 3 | 3 | 1 | 1 |
| RelOptCostImpl |  | 0% |  | 0% | 22 | 22 | 22 | 22 | 17 | 17 | 1 | 1 |
| Contexts |  | 0% |  | 0% | 17 | 17 | 28 | 28 | 8 | 8 | 1 | 1 |
| SubstitutionVisitor.InternalOperand |  | 0% |  | 0% | 15 | 15 | 21 | 21 | 5 | 5 | 1 | 1 |
| SubstitutionVisitor.AbstractUnifyRule |  | 0% |  | 0% | 18 | 18 | 17 | 17 | 7 | 7 | 1 | 1 |
| SubstitutionVisitor.ScanToCalcUnifyRule |  | 0% | | 0% | 6 | 6 | 24 | 24 | 3 | 3 | 1 | 1 |
| MulticastRelOptListener |  | 0% |  | 0% | 12 | 12 | 25 | 25 | 7 | 7 | 1 | 1 |
| TableAccessMap |  | 0% |  | 0% | 14 | 14 | 22 | 22 | 9 | 9 | 1 | 1 |
| RelOptQuery |  | 0% | | 0% | 11 | 11 | 16 | 16 | 8 | 8 | 1 | 1 |
| SubstitutionVisitor.AggregateToAggregateUnifyRule |  | 0% |  | 0% | 9 | 9 | 16 | 16 | 3 | 3 | 1 | 1 |
| RelOptMaterialization.ProjectFilterTable |  | 0% |  | 0% | 10 | 10 | 20 | 20 | 6 | 6 | 1 | 1 |
| RelOptLattice |  | 0% |  | 0% | 8 | 8 | 16 | 16 | 4 | 4 | 1 | 1 |
| RelOptUtil.RexCorrelVariableMapShuttle |  | 0% | | 0% | 5 | 5 | 18 | 18 | 3 | 3 | 1 | 1 |
| RelOptUtil.new AbstractList() {...} |  | 0% | | n/a | 3 | 3 | 8 | 8 | 3 | 3 | 1 | 1 |
| RelTraitPropagationVisitor |  | 0% |  | 0% | 9 | 9 | 18 | 18 | 3 | 3 | 1 | 1 |
| RelOptUtil.VariableUsedVisitor |  | 0% | | 0% | 6 | 6 | 17 | 17 | 4 | 4 | 1 | 1 |
| RelOptUtil.Logic |  | 0% |  | 0% | 9 | 9 | 17 | 17 | 3 | 3 | 1 | 1 |
| SubstitutionVisitor.new RexShuttle() {...} |  | 0% | | 0% | 7 | 7 | 13 | 13 | 4 | 4 | 1 | 1 |
| RelOptUtil.Side |  | 0% |  | 0% | 10 | 10 | 11 | 11 | 3 | 3 | 1 | 1 |
| RelOptAbstractTable |  | 0% | | 0% | 17 | 17 | 23 | 23 | 16 | 16 | 1 | 1 |
| SubstitutionVisitor.JoinOnCalcsToJoinUnifyRule.new RexShuttle() {...} |  | 0% | | 0% | 3 | 3 | 8 | 8 | 2 | 2 | 1 | 1 |
| Contexts.ChainContext |  | 0% |  | 0% | 9 | 9 | 13 | 13 | 3 | 3 | 1 | 1 |
| SubstitutionVisitor.UnifyRule |  | 0% | | 0% | 7 | 7 | 14 | 14 | 3 | 3 | 1 | 1 |
| SubstitutionVisitor.JoinOnLeftCalcToJoinUnifyRule.new RexShuttle() {...} |  | 0% | | 0% | 3 | 3 | 7 | 7 | 2 | 2 | 1 | 1 |
| RelTraitDef | | 0% |  | 0% | 10 | 10 | 12 | 12 | 6 | 6 | 1 | 1 |
| TableAccessMap.TableRelVisitor | | 0% |  | 0% | 6 | 6 | 14 | 14 | 2 | 2 | 1 | 1 |
| SubstitutionVisitor.UnionToUnionUnifyRule | | 0% | | 0% | 5 | 5 | 11 | 11 | 3 | 3 | 1 | 1 |
| RelRule.OperandBuilderImpl | | 0% | | 0% | 5 | 5 | 10 | 10 | 4 | 4 | 1 | 1 |
| SubstitutionVisitor.IntersectToIntersectUnifyRule | | 0% | | 0% | 5 | 5 | 11 | 11 | 3 | 3 | 1 | 1 |
| SubstitutionVisitor.TargetOperand | | 0% | | 0% | 5 | 5 | 9 | 9 | 3 | 3 | 1 | 1 |
| SubstitutionVisitor.JoinOnRightCalcToJoinUnifyRule.new RexShuttle() {...} | | 0% | | 0% | 3 | 3 | 7 | 7 | 2 | 2 | 1 | 1 |
| SubstitutionVisitor.SlotCounter | | 0% |  | 0% | 5 | 5 | 9 | 9 | 1 | 1 | 1 | 1 |
| RelOptSamplingParameters | | 0% | | n/a | 6 | 6 | 12 | 12 | 6 | 6 | 1 | 1 |
| RelOptUtil.ResetHintsShuttle | | 0% | | 0% | 5 | 5 | 11 | 11 | 3 | 3 | 1 | 1 |
| RelRule.Config | | 0% | | 0% | 5 | 5 | 8 | 8 | 4 | 4 | 1 | 1 |
| SubstitutionVisitor.UnifyResult | | 0% | | 0% | 5 | 5 | 7 | 7 | 2 | 2 | 1 | 1 |
| Convention.Impl | | 0% | | 0% | 11 | 11 | 13 | 13 | 10 | 10 | 1 | 1 |
| DeriveMode | | 0% | | n/a | 1 | 1 | 6 | 6 | 1 | 1 | 1 | 1 |
| ConventionTraitDef.ConversionData | | 0% | | 0% | 5 | 5 | 10 | 10 | 4 | 4 | 1 | 1 |
| RelOptUtil.CorrelationCollector | | 0% | | n/a | 2 | 2 | 7 | 7 | 2 | 2 | 1 | 1 |
| RelOptUtil.new RelHomogeneousShuttle() {...} | | 0% | | 0% | 3 | 3 | 6 | 6 | 2 | 2 | 1 | 1 |
| SubstitutionVisitor.new MutableRelVisitor() {...} | | 0% | | n/a | 2 | 2 | 6 | 6 | 2 | 2 | 1 | 1 |
| RelOptUtil.new AbstractList() {...} | | 0% | | n/a | 3 | 3 | 4 | 4 | 3 | 3 | 1 | 1 |
| SubstitutionVisitor.AggregateOnCalcToAggregateUnifyRule.new RexVisitorImpl() {...} | | 0% | | 0% | 4 | 4 | 5 | 5 | 3 | 3 | 1 | 1 |
| RelOptUtil.new RexShuttle() {...} | | 0% | | 0% | 4 | 4 | 6 | 6 | 2 | 2 | 1 | 1 |
| TableAccessMap.Mode | | 0% | | n/a | 1 | 1 | 5 | 5 | 1 | 1 | 1 | 1 |
| Strong.Policy | | 0% | | n/a | 1 | 1 | 5 | 5 | 1 | 1 | 1 | 1 |
| Convention | | 0% | | n/a | 5 | 5 | 5 | 5 | 5 | 5 | 1 | 1 |
| RelOptRuleOperandChildPolicy | | 0% | | n/a | 1 | 1 | 5 | 5 | 1 | 1 | 1 | 1 |
| RelOptCost | | 0% |  | 0% | 5 | 5 | 9 | 9 | 1 | 1 | 1 | 1 |
| SubstitutionVisitor.TrivialRule | | 0% | | 0% | 4 | 4 | 6 | 6 | 3 | 3 | 1 | 1 |
| ViewExpanders.new RelOptTable.ToRelContext() {...} | | 0% | | n/a | 4 | 4 | 4 | 4 | 4 | 4 | 1 | 1 |
| RelOptRule.ConverterRelOptRuleOperand | | 0% | | 0% | 4 | 4 | 8 | 8 | 2 | 2 | 1 | 1 |
| RelOptUtil.new RelVisitor() {...} | | 0% | | 0% | 4 | 4 | 7 | 7 | 3 | 3 | 1 | 1 |
| RelOptCostImpl.Factory | | 0% | | n/a | 5 | 5 | 5 | 5 | 5 | 5 | 1 | 1 |
| RelOptUtil.VariableSetVisitor | | 0% | | n/a | 2 | 2 | 6 | 6 | 2 | 2 | 1 | 1 |
| SubstitutionVisitor.new RexShuttle() {...} | | 0% | | n/a | 2 | 2 | 3 | 3 | 2 | 2 | 1 | 1 |
| RelOptRuleOperandChildren | | 0% | | n/a | 2 | 2 | 8 | 8 | 2 | 2 | 1 | 1 |
| CommonRelExpressionRegistry | | 0% | | n/a | 3 | 3 | 5 | 5 | 3 | 3 | 1 | 1 |
| RexImplicationChecker.new Strong() {...} | | 0% | | 0% | 4 | 4 | 3 | 3 | 2 | 2 | 1 | 1 |
| ViewExpanders | | 0% | | n/a | 4 | 4 | 4 | 4 | 4 | 4 | 1 | 1 |
| RelTraitSet.Cache | | 0% | | 0% | 3 | 3 | 5 | 5 | 2 | 2 | 1 | 1 |
| SubstitutionVisitor.new RexVisitorImpl() {...} | | 0% | | 0% | 3 | 3 | 4 | 4 | 2 | 2 | 1 | 1 |
| RelOptUtil.SubQueryType | | 0% | | n/a | 1 | 1 | 4 | 4 | 1 | 1 | 1 | 1 |
| Contexts.WrapContext | | 0% | | 0% | 3 | 3 | 6 | 6 | 2 | 2 | 1 | 1 |
| ViewExpanders.new RelOptTable.ToRelContext() {...} | | 0% | | n/a | 4 | 4 | 4 | 4 | 4 | 4 | 1 | 1 |
| Strong.new RexVisitorImpl() {...} | | 0% | | n/a | 2 | 2 | 3 | 3 | 2 | 2 | 1 | 1 |
| RelOptUtil.new RelVisitor() {...} | | 0% | | 0% | 3 | 3 | 5 | 5 | 2 | 2 | 1 | 1 |
| SubstitutionVisitor.Replacement | | 0% | | n/a | 2 | 2 | 7 | 7 | 2 | 2 | 1 | 1 |
| RelOptListener.RelEquivalenceEvent | | 0% | | n/a | 3 | 3 | 6 | 6 | 3 | 3 | 1 | 1 |
| RelOptUtil.InputReferencedVisitor | | 0% | | n/a | 2 | 2 | 4 | 4 | 2 | 2 | 1 | 1 |
| SubstitutionVisitor.UnionOnCalcsToUnionUnifyRule | | 0% | | n/a | 3 | 3 | 4 | 4 | 3 | 3 | 1 | 1 |
| SubstitutionVisitor.IntersectOnCalcsToIntersectUnifyRule | | 0% | | n/a | 3 | 3 | 4 | 4 | 3 | 3 | 1 | 1 |
| SubstitutionVisitor.QueryOperand | | 0% | | n/a | 2 | 2 | 5 | 5 | 2 | 2 | 1 | 1 |
| RelOptUtil.new AbstractList() {...} | | 0% | | n/a | 3 | 3 | 3 | 3 | 3 | 3 | 1 | 1 |
| RelOptUtil.new RexVisitorImpl() {...} | | 0% | | 0% | 3 | 3 | 4 | 4 | 2 | 2 | 1 | 1 |
| RelOptUtil.new RexShuttle() {...} | | 0% | | n/a | 2 | 2 | 2 | 2 | 2 | 2 | 1 | 1 |
| RelRule | | 0% | | n/a | 1 | 1 | 4 | 4 | 1 | 1 | 1 | 1 |
| RelOptUtil.new RexShuttle() {...} | | 0% | | n/a | 2 | 2 | 2 | 2 | 2 | 2 | 1 | 1 |
| MaterializedViewSubstitutionVisitor | | 0% | | n/a | 2 | 2 | 4 | 4 | 2 | 2 | 1 | 1 |
| RelOptListener.RuleAttemptedEvent | | 0% | | n/a | 2 | 2 | 4 | 4 | 2 | 2 | 1 | 1 |
| Strong.new Strong() {...} | | 0% | | n/a | 2 | 2 | 2 | 2 | 2 | 2 | 1 | 1 |
| RelOptUtil.Exists | | 0% | | n/a | 1 | 1 | 5 | 5 | 1 | 1 | 1 | 1 |
| RelOptListener.RuleEvent | | 0% | | n/a | 2 | 2 | 4 | 4 | 2 | 2 | 1 | 1 |
| SubstitutionVisitor.new RexShuttle() {...} | | 0% | | n/a | 2 | 2 | 2 | 2 | 2 | 2 | 1 | 1 |
| RelTrait | | 0% | | 0% | 3 | 3 | 2 | 2 | 2 | 2 | 1 | 1 |
| Strong.new Strong() {...} | | 0% | | n/a | 2 | 2 | 2 | 2 | 2 | 2 | 1 | 1 |
| RelOptListener.RelEvent | | 0% | | n/a | 2 | 2 | 4 | 4 | 2 | 2 | 1 | 1 |
| RelRule.DoneImpl | | 0% | | n/a | 1 | 1 | 2 | 2 | 1 | 1 | 1 | 1 |
| RexImplicationChecker.InputRefUsage | | 0% | | n/a | 1 | 1 | 3 | 3 | 1 | 1 | 1 | 1 |
| SubstitutionVisitor.AnyOperand | | 0% | | n/a | 2 | 2 | 3 | 3 | 2 | 2 | 1 | 1 |
| SubstitutionVisitor.Operand | | 0% | | n/a | 2 | 2 | 4 | 4 | 2 | 2 | 1 | 1 |
| SubstitutionVisitor.MatchFailed | | 0% | | n/a | 2 | 2 | 2 | 2 | 2 | 2 | 1 | 1 |
| RelOptUtil.new RelHomogeneousShuttle() {...} | | 0% | | n/a | 2 | 2 | 2 | 2 | 2 | 2 | 1 | 1 |
| RelOptListener.RuleProductionEvent | | 0% | | n/a | 1 | 1 | 2 | 2 | 1 | 1 | 1 | 1 |
| RelOptListener.RelDiscardedEvent | | 0% | | n/a | 1 | 1 | 2 | 2 | 1 | 1 | 1 | 1 |
| RelOptListener.RelChosenEvent | | 0% | | n/a | 1 | 1 | 2 | 2 | 1 | 1 | 1 | 1 |
| SubstitutionVisitor.new Strong() {...} | | 0% | | n/a | 2 | 2 | 2 | 2 | 2 | 2 | 1 | 1 |
| Contexts.EmptyContext | | 0% | | n/a | 2 | 2 | 2 | 2 | 2 | 2 | 1 | 1 |
| CommonRelSubExprRule | | 0% | | n/a | 1 | 1 | 2 | 2 | 1 | 1 | 1 | 1 |
| RelOptPlanner.CannotPlanException | | 0% | | n/a | 1 | 1 | 2 | 2 | 1 | 1 | 1 | 1 |
| RelOptPlanner | | 0% | | n/a | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| PlanTooComplexError | | 0% | | n/a | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |