local exchange (GATHER, SINGLE, [])
    remote exchange (GATHER, SINGLE, [])
        local exchange (GATHER, SINGLE, [])
            local exchange (REPARTITION, ROUND_ROBIN, [])
                final aggregation over (s_store_id, s_store_name)
                    local exchange (GATHER, SINGLE, [])
                        remote exchange (REPARTITION, HASH, [s_store_id, s_store_name])
                            partial aggregation over (s_store_id, s_store_name)
                                final aggregation over (d_day_name, s_store_id, s_store_name)
                                    local exchange (GATHER, SINGLE, [])
                                        remote exchange (REPARTITION, HASH, [d_day_name, s_store_id, s_store_name])
                                            intermediate aggregation over (d_day_name, s_store_id, s_store_name)
                                                join (INNER, REPLICATED):
                                                    join (INNER, REPLICATED):
                                                        partial aggregation over (ss_sold_date_sk, ss_store_sk)
                                                            dynamic filter (ss_sold_date_sk::EQUAL, ss_store_sk::EQUAL)
                                                                scan store_sales
                                                        local exchange (GATHER, SINGLE, [])
                                                            remote exchange (REPLICATE, BROADCAST, [])
                                                                scan date_dim
                                                    local exchange (GATHER, SINGLE, [])
                                                        remote exchange (REPLICATE, BROADCAST, [])
                                                            scan store
