| simplifyProject(LogicalProject, List, PullUpProjectExprUnderTopN.CollectorContext) |  | 0% |  | 0% | 16 | 16 | 38 | 38 | 1 | 1 |
| addUpperProject(LogicalTopN, PullUpProjectExprUnderTopN.PullUpInfo, PullUpProjectExprUnderTopN.CollectorContext) |  | 0% |  | 0% | 9 | 9 | 32 | 32 | 1 | 1 |
| collectFromNode(Plan, PullUpProjectExprUnderTopN.PullUpInfo, Set, PullUpProjectExprUnderTopN.CollectorContext) |   | 40% |   | 37% | 18 | 25 | 28 | 50 | 0 | 1 |
| deduplicatePullUps(PullUpProjectExprUnderTopN.CollectorContext) |  | 0% |  | 0% | 7 | 7 | 24 | 24 | 1 | 1 |
| addPassThroughSlots(List, Set, Set, Map, List) |  | 0% |  | 0% | 4 | 4 | 8 | 8 | 1 | 1 |
| canPullUp(NamedExpression) |   | 11% |   | 7% | 7 | 8 | 12 | 14 | 0 | 1 |
| replaceUnavailableSlots(Expression, PullUpProjectExprUnderTopN.CollectorContext, Set) |  | 0% |  | 0% | 3 | 3 | 6 | 6 | 1 | 1 |
| collectAllPulledUpExprs(PullUpProjectExprUnderTopN.CollectorContext, LogicalProject) |  | 0% |  | 0% | 3 | 3 | 8 | 8 | 1 | 1 |
| collectUnavailablePullUpExprs(LogicalProject, PullUpProjectExprUnderTopN.CollectorContext, Set) |  | 0% |  | 0% | 3 | 3 | 6 | 6 | 1 | 1 |
| resolveNamedExpression(NamedExpression, PullUpProjectExprUnderTopN.CollectorContext, Set) |  | 0% |  | 0% | 3 | 3 | 6 | 6 | 1 | 1 |
| getPullUpReplaceExpression(Slot, PullUpProjectExprUnderTopN.CollectorContext) |  | 0% |  | 0% | 3 | 3 | 5 | 5 | 1 | 1 |
| resolvePulledUpExpr(NamedExpression, PullUpProjectExprUnderTopN.CollectorContext, Set) |  | 0% |  | 0% | 2 | 2 | 3 | 3 | 1 | 1 |
| resolveExpression(Expression, PullUpProjectExprUnderTopN.CollectorContext, Set) |  | 0% |  | 0% | 2 | 2 | 5 | 5 | 1 | 1 |
| isUnavailablePullUpSlot(NamedExpression, PullUpProjectExprUnderTopN.CollectorContext, Set) |  | 0% |  | 0% | 4 | 4 | 3 | 3 | 1 | 1 |
| rewriteRoot(Plan, JobContext) |   | 70% |   | 50% | 3 | 4 | 3 | 10 | 0 | 1 |
| resolveInputSlots(NamedExpression, PullUpProjectExprUnderTopN.CollectorContext, Set) |  | 0% | | n/a | 1 | 1 | 1 | 1 | 1 | 1 |
| resolveInputSlots(Expression, PullUpProjectExprUnderTopN.CollectorContext, Set) |  | 0% | | n/a | 1 | 1 | 1 | 1 | 1 | 1 |
| lambda$deduplicatePullUps$4(NamedExpression, NamedExpression) |  | 0% |  | 0% | 2 | 2 | 1 | 1 | 1 | 1 |
| lambda$deduplicatePullUps$5(Map.Entry) |  | 0% | | n/a | 1 | 1 | 1 | 1 | 1 | 1 |
| lambda$deduplicatePullUps$3(LogicalProject) |  | 0% | | n/a | 1 | 1 | 1 | 1 | 1 | 1 |
| lambda$canPullUp$2(TreeNode) |  | 0% | | n/a | 1 | 1 | 1 | 1 | 1 | 1 |
| lambda$canPullUp$1(TreeNode) |  | 0% | | n/a | 1 | 1 | 1 | 1 | 1 | 1 |
| lambda$canPullUp$0(TreeNode) |  | 0% | | n/a | 1 | 1 | 1 | 1 | 1 | 1 |
| qualifiesForLazyMatThreshold(LogicalTopN) |   | 90% |   | 75% | 1 | 3 | 1 | 5 | 0 | 1 |
| buildOrderKeyExprIds(LogicalTopN) |  | 100% |   | 75% | 1 | 3 | 0 | 8 | 0 | 1 |
| isBlockingNode(Plan) |  | 100% |   | 66% | 2 | 4 | 0 | 1 | 0 | 1 |
| PullUpProjectExprUnderTopN() |  | 100% | | n/a | 0 | 1 | 0 | 1 | 0 | 1 |