final aggregation over ()
    local exchange (GATHER, SINGLE, [])
        remote exchange (GATHER, SINGLE, [])
            partial aggregation over ()
                join (FULL, PARTITIONED):
                    final aggregation over (ss_customer_sk, ss_item_sk)
                        local exchange (GATHER, SINGLE, [])
                            remote exchange (REPARTITION, HASH, [ss_customer_sk, ss_item_sk])
                                partial aggregation over (ss_customer_sk, ss_item_sk)
                                    join (INNER, REPLICATED, can skip output duplicates):
                                        dynamic filter (ss_sold_date_sk::EQUAL)
                                            scan store_sales
                                        local exchange (GATHER, SINGLE, [])
                                            remote exchange (REPLICATE, BROADCAST, [])
                                                scan date_dim
                    final aggregation over (cs_bill_customer_sk, cs_item_sk)
                        local exchange (GATHER, SINGLE, [])
                            remote exchange (REPARTITION, HASH, [cs_bill_customer_sk, cs_item_sk])
                                partial aggregation over (cs_bill_customer_sk, cs_item_sk)
                                    join (INNER, REPLICATED, can skip output duplicates):
                                        dynamic filter (cs_sold_date_sk::EQUAL)
                                            scan catalog_sales
                                        local exchange (GATHER, SINGLE, [])
                                            remote exchange (REPLICATE, BROADCAST, [])
                                                scan date_dim
