| AggregateStrategies.java |   | 9% |  | 0% | 208 | 210 | 336 | 397 | 60 | 62 | 0 | 1 |
| LogicalWindowToPhysicalWindow.java |  | 1% |  | 0% | 89 | 91 | 218 | 221 | 38 | 40 | 4 | 5 |
| SplitAggMultiPhase.java |   | 2% |  | 0% | 41 | 44 | 159 | 167 | 13 | 16 | 0 | 1 |
| SplitAggMultiPhaseWithoutGbyKey.java |   | 7% |  | 0% | 37 | 40 | 82 | 94 | 20 | 23 | 0 | 1 |
| SplitAggBaseRule.java |  | 0% |  | 0% | 28 | 29 | 86 | 87 | 15 | 16 | 0 | 1 |
| LogicalPartitionTopNToPhysicalPartitionTopN.java |  | 3% |  | 0% | 29 | 31 | 81 | 84 | 10 | 12 | 0 | 1 |
| SplitAggWithoutDistinct.java |   | 5% |  | 0% | 24 | 27 | 66 | 72 | 11 | 14 | 1 | 2 |
| LogicalOlapScanToPhysicalOlapScan.java |  | 3% |  | 0% | 22 | 24 | 66 | 69 | 2 | 4 | 0 | 1 |
| LogicalTopNToPhysicalTopN.java |  | 7% |  | 0% | 5 | 7 | 21 | 24 | 2 | 4 | 0 | 1 |
| LogicalDeferMaterializeTopNToPhysicalDeferMaterializeTopN.java |  | 15% | | 0% | 3 | 5 | 12 | 15 | 2 | 4 | 0 | 1 |
| LogicalSortToPhysicalQuickSort.java |  | 16% | | n/a | 2 | 4 | 10 | 13 | 2 | 4 | 0 | 1 |
| LogicalOlapTableSinkToPhysicalOlapTableSink.java |  | 17% | | 0% | 2 | 4 | 18 | 21 | 1 | 3 | 0 | 1 |
| LogicalDeferMaterializeResultSinkToPhysicalDeferMaterializeResultSink.java |  | 23% | | n/a | 1 | 3 | 8 | 11 | 1 | 3 | 0 | 1 |
| LogicalFileScanToPhysicalFileScan.java |  | 27% | | 0% | 3 | 5 | 11 | 14 | 2 | 4 | 0 | 1 |
| LogicalDeferMaterializeOlapScanToPhysicalDeferMaterializeOlapScan.java |  | 25% | | n/a | 1 | 3 | 8 | 11 | 1 | 3 | 0 | 1 |
| LogicalHudiScanToPhysicalHudiScan.java |  | 27% | | n/a | 1 | 3 | 12 | 15 | 1 | 3 | 0 | 1 |
| LogicalDictionarySinkToPhysicalDictionarySink.java |  | 28% | | n/a | 1 | 3 | 9 | 12 | 1 | 3 | 0 | 1 |
| LogicalJoinToHashJoin.java |  | 33% | | n/a | 1 | 3 | 9 | 14 | 1 | 3 | 0 | 1 |
| LogicalJdbcTableSinkToPhysicalJdbcTableSink.java |  | 29% | | n/a | 1 | 3 | 9 | 12 | 1 | 3 | 0 | 1 |
| LogicalIcebergTableSinkToPhysicalIcebergTableSink.java |  | 29% | | n/a | 1 | 3 | 9 | 12 | 1 | 3 | 0 | 1 |
| LogicalHiveTableSinkToPhysicalHiveTableSink.java |  | 29% | | n/a | 1 | 3 | 9 | 12 | 1 | 3 | 0 | 1 |
| LogicalJoinToNestedLoopJoin.java |  | 35% | | n/a | 1 | 3 | 8 | 13 | 1 | 3 | 0 | 1 |
| LogicalFileSinkToPhysicalFileSink.java |  | 31% | | n/a | 1 | 3 | 9 | 12 | 1 | 3 | 0 | 1 |
| LogicalSchemaScanToPhysicalSchemaScan.java |  | 32% | | n/a | 1 | 3 | 9 | 12 | 1 | 3 | 0 | 1 |
| LogicalJdbcScanToPhysicalJdbcScan.java |  | 34% | | n/a | 1 | 3 | 6 | 9 | 1 | 3 | 0 | 1 |
| LogicalOdbcScanToPhysicalOdbcScan.java |  | 34% | | n/a | 1 | 3 | 6 | 9 | 1 | 3 | 0 | 1 |
| LogicalEsScanToPhysicalEsScan.java |  | 35% | | n/a | 1 | 3 | 5 | 8 | 1 | 3 | 0 | 1 |
| LogicalRepeatToPhysicalRepeat.java |  | 37% | | n/a | 1 | 3 | 6 | 9 | 1 | 3 | 0 | 1 |
| LogicalUnionToPhysicalUnion.java |  | 38% | | n/a | 1 | 3 | 6 | 9 | 1 | 3 | 0 | 1 |
| LogicalRecursiveCteToPhysicalRecursiveCte.java |  | 38% | | n/a | 1 | 3 | 6 | 9 | 1 | 3 | 0 | 1 |
| LogicalBlackholeSinkToPhysicalBlackholeSink.java |  | 38% | | n/a | 1 | 3 | 6 | 9 | 1 | 3 | 0 | 1 |
| LogicalCTEAnchorToPhysicalCTEAnchor.java |  | 38% | | n/a | 1 | 3 | 4 | 7 | 1 | 3 | 0 | 1 |
| LogicalRecursiveCteScanToPhysicalRecursiveCteScan.java |  | 40% | | n/a | 1 | 3 | 7 | 10 | 1 | 3 | 0 | 1 |
| LogicalLimitToPhysicalLimit.java |  | 40% | | n/a | 1 | 3 | 5 | 8 | 1 | 3 | 0 | 1 |
| LogicalIntersectToPhysicalIntersect.java | | 41% | | n/a | 1 | 3 | 5 | 8 | 1 | 3 | 0 | 1 |
| LogicalExceptToPhysicalExcept.java | | 41% | | n/a | 1 | 3 | 5 | 8 | 1 | 3 | 0 | 1 |
| LogicalCTEConsumerToPhysicalCTEConsumer.java | | 41% | | n/a | 1 | 3 | 5 | 8 | 1 | 3 | 0 | 1 |
| LogicalGenerateToPhysicalGenerate.java | | 43% | | n/a | 1 | 3 | 4 | 7 | 1 | 3 | 0 | 1 |
| LogicalTVFRelationToPhysicalTVFRelation.java | | 45% | | n/a | 1 | 3 | 1 | 5 | 1 | 3 | 0 | 1 |
| LogicalFilterToPhysicalFilter.java | | 47% | | n/a | 1 | 3 | 3 | 6 | 1 | 3 | 0 | 1 |
| LogicalAssertNumRowsToPhysicalAssertNumRows.java | | 47% | | n/a | 1 | 3 | 3 | 6 | 1 | 3 | 0 | 1 |
| LogicalCTEProducerToPhysicalCTEProducer.java | | 47% | | n/a | 1 | 3 | 3 | 6 | 1 | 3 | 0 | 1 |
| LogicalProjectToPhysicalProject.java | | 47% | | n/a | 1 | 3 | 3 | 6 | 1 | 3 | 0 | 1 |
| LogicalRecursiveCteRecursiveChildToPhysicalRecursiveCteRecursiveChild.java | | 47% | | n/a | 1 | 3 | 3 | 6 | 1 | 3 | 0 | 1 |
| LogicalResultSinkToPhysicalResultSink.java |  | 100% | | n/a | 0 | 3 | 0 | 9 | 0 | 3 | 0 | 1 |
| LogicalOneRowRelationToPhysicalOneRowRelation.java |  | 100% | | n/a | 0 | 3 | 0 | 5 | 0 | 3 | 0 | 1 |
| LogicalEmptyRelationToPhysicalEmptyRelation.java |  | 100% | | n/a | 0 | 3 | 0 | 5 | 0 | 3 | 0 | 1 |
| OneImplementationRuleFactory.java | | 100% | | n/a | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 |
| ImplementationRuleFactory.java | | 100% | | n/a | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 |