std::array g_arch_traces = std::to_array>({ #define INST(core, pref, index, label, mnemonic, symbol) \ {#label "_" #pref "_" #core, #label}, #define FOR_CORE(i) \ {"wmb0_" #i, "wmb0_" #i}, \ {"wmb1_" #i, "wmb1_" #i}, \ {"wdea_" #i, "wdea_" #i}, \ INST_SET(i, pop) \ INST_SET(i, exe) \ INST_SET(i, wrt) FOR_CORES #undef FOR_CORE #undef INST }); std::array g_arch_traces_heatmaps = std::to_array>({ #define FOR_CORE(i) \ {"wev_" #i, "wev_" #i}, \ {"xev_" #i, "xev_" #i}, FOR_CORES #undef FOR_CORE }); std::array g_arch_plots = std::to_array({ {"wevs", "general", { #define FOR_CORE(i) "wmb0_" #i, "wmb1_" #i, "wdea_" #i, FOR_CORES #undef FOR_CORE }}, }); std::array g_arch_plots_stacked = std::to_array({ #define INST(core, pref, index, label, mnemonic, symbol) \ #label "_" #pref "_" #core, #define FOR_CORE(i) \ {"ipop%_" #i, "population", { INST_SET(i, pop) }}, FOR_CORES #undef FOR_CORE #define FOR_CORE(i) \ {"iexe%_" #i, "population", { INST_SET(i, exe) }}, FOR_CORES #undef FOR_CORE #define FOR_CORE(i) \ {"iwrt%_" #i, "population", { INST_SET(i, wrt) }}, FOR_CORES #undef FOR_CORE #undef INST }); std::array g_arch_plots_heatmaps = std::to_array({ #define FOR_CORE(i) \ {"wev_" #i, "heatmaps", "wev_" #i}, FOR_CORES #undef FOR_CORE #define FOR_CORE(i) \ {"xev_" #i, "heatmaps", "xev_" #i}, FOR_CORES #undef FOR_CORE });