| expandEqualSetAndConstants(List, boolean, ImmutableEqualSet, Map) |   | 51% |   | 30% | 11 | 14 | 17 | 34 | 0 | 1 |
| visitLogicalJoin(LogicalJoin, CascadesContext) |   | 47% |   | 31% | 7 | 9 | 17 | 31 | 0 | 1 |
| replaceOrConstants(Or, boolean, ExpressionRewriteContext, ImmutableEqualSet, Map) |  | 0% |  | 0% | 3 | 3 | 9 | 9 | 1 | 1 |
| replaceAndConstants(And, boolean, ExpressionRewriteContext, ImmutableEqualSet, Map) |   | 78% |   | 65% | 6 | 11 | 6 | 32 | 0 | 1 |
| visitLogicalHaving(LogicalHaving, CascadesContext) |  | 0% |  | 0% | 2 | 2 | 7 | 7 | 1 | 1 |
| canReplaceExpression(Expression) |   | 26% |   | 30% | 5 | 6 | 7 | 11 | 0 | 1 |
| addConstant(Map, Slot, Literal) |   | 41% |   | 10% | 5 | 6 | 2 | 6 | 0 | 1 |
| replaceConstantsAndRewriteExpr(LogicalPlan, Expression, CascadesContext) |   | 80% |   | 50% | 6 | 8 | 5 | 17 | 0 | 1 |
| findValidEqualItem(Expression) |   | 73% |   | 60% | 3 | 6 | 3 | 11 | 0 | 1 |
| visitLogicalFilter(LogicalFilter, CascadesContext) |   | 66% |   | 50% | 1 | 2 | 2 | 7 | 0 | 1 |
| visitLogicalAggregate(LogicalAggregate, CascadesContext) |   | 94% |   | 86% | 3 | 12 | 2 | 37 | 0 | 1 |
| getConstantUniforms(Map, ExpressionRewriteContext) |   | 83% |   | 66% | 3 | 7 | 4 | 12 | 0 | 1 |
| replaceConstants(Expression, boolean, ExpressionRewriteContext, ImmutableEqualSet, Map) |   | 82% |   | 80% | 2 | 6 | 1 | 11 | 0 | 1 |
| replaceNameExpressionConstants(NamedExpression, ExpressionRewriteContext, ImmutableEqualSet, Map) |   | 75% |   | 83% | 1 | 4 | 1 | 8 | 0 | 1 |
| isExprEqualIgnoreOrder(Expression, Expression) |   | 69% |   | 75% | 1 | 3 | 2 | 7 | 0 | 1 |
| visitLogicalProject(LogicalProject, CascadesContext) |   | 95% |   | 75% | 1 | 3 | 0 | 11 | 0 | 1 |
| rewriteRoot(Plan, JobContext) |   | 88% |   | 50% | 1 | 2 | 1 | 3 | 0 | 1 |
| visitLogicalSort(LogicalSort, CascadesContext) |  | 100% |  | 100% | 0 | 5 | 0 | 17 | 0 | 1 |
| getChildEqualSetAndConstants(LogicalPlan, ExpressionRewriteContext) |  | 100% |  | 100% | 0 | 3 | 0 | 11 | 0 | 1 |
| needReplaceWithConstant(Expression, Map, Map) |  | 100% |   | 70% | 3 | 6 | 0 | 8 | 0 | 1 |
| lambda$replaceConstants$0(Map, TreeNode) |  | 100% |  | 100% | 0 | 3 | 0 | 1 | 0 | 1 |
| visitLogicalSink(LogicalSink, CascadesContext) |  | 100% | | n/a | 0 | 1 | 0 | 2 | 0 | 1 |
| ConstantPropagation() |  | 100% | | n/a | 0 | 1 | 0 | 1 | 0 | 1 |