WholeStageCodegen (10)
  CometColumnarToRow
    InputAdapter
      CometHashAggregate [count] [count(1),count(1)]
        CometExchange #1
          CometHashAggregate [count]
            CometProject
              CometBroadcastHashJoin [c_last_name,c_first_name,d_date,c_last_name,c_first_name,d_date]
                CometBroadcastHashJoin [c_last_name,c_first_name,d_date,c_last_name,c_first_name,d_date]
                  CometHashAggregate [c_last_name,c_first_name,d_date]
                    CometColumnarExchange [c_last_name,c_first_name,d_date] #2
                      WholeStageCodegen (3)
                        HashAggregate [c_last_name,c_first_name,d_date]
                          Project [c_last_name,c_first_name,d_date]
                            BroadcastHashJoin [ss_customer_sk,c_customer_sk]
                              Project [ss_customer_sk,d_date]
                                BroadcastHashJoin [ss_sold_date_sk,d_date_sk]
                                  Filter [ss_customer_sk]
                                    ColumnarToRow
                                      InputAdapter
                                        Scan parquet spark_catalog.default.store_sales [ss_customer_sk,ss_sold_date_sk]
                                          SubqueryBroadcast [d_date_sk] #1
                                            BroadcastExchange #3
                                              WholeStageCodegen (1)
                                                CometColumnarToRow
                                                  InputAdapter
                                                    CometProject [d_date_sk,d_date]
                                                      CometFilter [d_date_sk,d_date,d_month_seq]
                                                        CometNativeScan parquet spark_catalog.default.date_dim [d_date_sk,d_date,d_month_seq]
                                  InputAdapter
                                    ReusedExchange [d_date_sk,d_date] #3
                              InputAdapter
                                BroadcastExchange #4
                                  WholeStageCodegen (2)
                                    CometColumnarToRow
                                      InputAdapter
                                        CometProject [c_first_name,c_last_name] [c_customer_sk,c_first_name,c_last_name]
                                          CometFilter [c_customer_sk,c_first_name,c_last_name]
                                            CometNativeScan parquet spark_catalog.default.customer [c_customer_sk,c_first_name,c_last_name]
                  CometBroadcastExchange [c_last_name,c_first_name,d_date] #5
                    CometHashAggregate [c_last_name,c_first_name,d_date]
                      CometColumnarExchange [c_last_name,c_first_name,d_date] #6
                        WholeStageCodegen (6)
                          HashAggregate [c_last_name,c_first_name,d_date]
                            Project [c_last_name,c_first_name,d_date]
                              BroadcastHashJoin [cs_bill_customer_sk,c_customer_sk]
                                Project [cs_bill_customer_sk,d_date]
                                  BroadcastHashJoin [cs_sold_date_sk,d_date_sk]
                                    Filter [cs_bill_customer_sk]
                                      ColumnarToRow
                                        InputAdapter
                                          Scan parquet spark_catalog.default.catalog_sales [cs_bill_customer_sk,cs_sold_date_sk]
                                            ReusedSubquery [d_date_sk] #1
                                    InputAdapter
                                      ReusedExchange [d_date_sk,d_date] #3
                                InputAdapter
                                  ReusedExchange [c_customer_sk,c_first_name,c_last_name] #4
                CometBroadcastExchange [c_last_name,c_first_name,d_date] #7
                  CometHashAggregate [c_last_name,c_first_name,d_date]
                    CometColumnarExchange [c_last_name,c_first_name,d_date] #8
                      WholeStageCodegen (9)
                        HashAggregate [c_last_name,c_first_name,d_date]
                          Project [c_last_name,c_first_name,d_date]
                            BroadcastHashJoin [ws_bill_customer_sk,c_customer_sk]
                              Project [ws_bill_customer_sk,d_date]
                                BroadcastHashJoin [ws_sold_date_sk,d_date_sk]
                                  Filter [ws_bill_customer_sk]
                                    ColumnarToRow
                                      InputAdapter
                                        Scan parquet spark_catalog.default.web_sales [ws_bill_customer_sk,ws_sold_date_sk]
                                          ReusedSubquery [d_date_sk] #1
                                  InputAdapter
                                    ReusedExchange [d_date_sk,d_date] #3
                              InputAdapter
                                ReusedExchange [c_customer_sk,c_first_name,c_last_name] #4
