From 4920c9df3286d9e3425d906b0f4f9591d0158027 Mon Sep 17 00:00:00 2001 From: amin1377 Date: Fri, 13 Dec 2024 10:59:10 -0500 Subject: [PATCH 1/2] [libs][rr_graph] change cost multiple from 0.95 to 0.875 --- .../src/utils/alloc_and_load_rr_indexed_data.cpp | 7 +------ 1 file changed, 1 insertion(+), 6 deletions(-) diff --git a/libs/librrgraph/src/utils/alloc_and_load_rr_indexed_data.cpp b/libs/librrgraph/src/utils/alloc_and_load_rr_indexed_data.cpp index 282f717c0d..d1b86a64de 100644 --- a/libs/librrgraph/src/utils/alloc_and_load_rr_indexed_data.cpp +++ b/libs/librrgraph/src/utils/alloc_and_load_rr_indexed_data.cpp @@ -351,18 +351,13 @@ static void load_rr_indexed_data_base_costs(const RRGraphView& rr_graph, rr_indexed_data[RRIndexedDataId(SOURCE_COST_INDEX)].base_cost = delay_normalization_fac; rr_indexed_data[RRIndexedDataId(SINK_COST_INDEX)].base_cost = 0.; rr_indexed_data[RRIndexedDataId(OPIN_COST_INDEX)].base_cost = delay_normalization_fac; - // If the SPEC_CPU flag is set, we need to make sure that all floating point numbers are perfectly representable in - // binary format. Thus, we changed the IPIN_COST_INDEX base cost from 0.95 to 0.875. + // The IPIN_COST_INDEX base cost is changed from 0.95 to 0.875 so it is perfectly representable in binary format (this change is made for SPEC bechmark). // This number is perfectly representable in a binary mantissa (without round-off) so we can get the same routing result on different platforms. // Since the router cost calculations and heap use floating point numbers, normally we get slightly different round off with different compiler settings, // leading to different heap sorts and hence different routings. // To make result validation for SPEC easier, we choose all router parameters to result in calculations that fit perfectly in a 24-bit binary mantissa. // .875 = 1/2 + 1/4 + 1/8 can be perfectly represented in a binary mantissa with only the first 3 bits set. -#ifdef SPEC_CPU rr_indexed_data[RRIndexedDataId(IPIN_COST_INDEX)].base_cost = 0.875 * delay_normalization_fac; -#else - rr_indexed_data[RRIndexedDataId(IPIN_COST_INDEX)].base_cost = 0.95 * delay_normalization_fac; -#endif auto rr_segment_counts = count_rr_segment_types(rr_graph, rr_indexed_data); size_t total_segments = std::accumulate(rr_segment_counts.begin(), rr_segment_counts.end(), 0u); From af02c3e85e8ecb32ed803ec197bea8127878a870 Mon Sep 17 00:00:00 2001 From: amin1377 Date: Fri, 13 Dec 2024 11:20:23 -0500 Subject: [PATCH 2/2] fix typo --- libs/librrgraph/src/utils/alloc_and_load_rr_indexed_data.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/libs/librrgraph/src/utils/alloc_and_load_rr_indexed_data.cpp b/libs/librrgraph/src/utils/alloc_and_load_rr_indexed_data.cpp index d1b86a64de..6e99f099d5 100644 --- a/libs/librrgraph/src/utils/alloc_and_load_rr_indexed_data.cpp +++ b/libs/librrgraph/src/utils/alloc_and_load_rr_indexed_data.cpp @@ -351,7 +351,7 @@ static void load_rr_indexed_data_base_costs(const RRGraphView& rr_graph, rr_indexed_data[RRIndexedDataId(SOURCE_COST_INDEX)].base_cost = delay_normalization_fac; rr_indexed_data[RRIndexedDataId(SINK_COST_INDEX)].base_cost = 0.; rr_indexed_data[RRIndexedDataId(OPIN_COST_INDEX)].base_cost = delay_normalization_fac; - // The IPIN_COST_INDEX base cost is changed from 0.95 to 0.875 so it is perfectly representable in binary format (this change is made for SPEC bechmark). + // The IPIN_COST_INDEX base cost is changed from 0.95 to 0.875 so it is perfectly representable in binary format (this change is made for SPEC benchmark). // This number is perfectly representable in a binary mantissa (without round-off) so we can get the same routing result on different platforms. // Since the router cost calculations and heap use floating point numbers, normally we get slightly different round off with different compiler settings, // leading to different heap sorts and hence different routings.