In this repository, we provide the source code and flow scripts for the newly introduced elements presented in the ICCAD 2023 invited paper titled 'IEEE CEDA DATC Emerging Foundations in IC Physical Design and MLCAD Research.' The included elements are:
- SpecPart, TritonPart: State-of-the-art circuit/hypergraph partitioners for the 21st century.
- AutoDMP: A DREAMPlace-based macro placement engine.
- DPO: A detailed placement optimization engine in OpenROAD.
- PROBE3.0: A Design-technology co-optimization (DTCO) pathfinding framework.
- Proxy Enablements: An auto-tuning based library scaling flow.
In this repository, our primary focus is on Proxy Enablements. For the other elements, please refer to their respective repositories.
- benchmarks: Contains the rtl and constraints for the benchmark design used for library scaling.
- run: Use this directory to run the library scaling flow.
- scripts: Provides the library scaling and autotuning flow required to generate proxy enablements. It also includes the scripts to run synthesis, placement, and routing flow using Cadence Genus and Innovus.
- techlibs: Contains the technology files such as LEF, LIB, QRC for the 7nm PDK asap7.
Please install the following python packages to run the library scaling flow:
- liberty parser:
pip install liberty-parser
- ray:
pip install ray[tune]
To run the library scaling flow, please follow the steps below:
- First update the range of different scaling parameters here.
- Provide the PPA number of the benchmark design on the target library here.
- Update total number of samples and number of parallel jobs to use for the autotuning job here.
- Add the target clock periods and utilization list based on the golden data here.
- Additionally, if you plan to use multiple servers to run SP&R jobs in parallel using GNU parallel, please update the node file and its path here.
- Use the following command in your python environment to run the autotuning flow:
export PROJ_DIR=<path to the root directory of this repository>
python ./scripts/autotune_scaling_factor/raytuner.py
# For NG45 tuning
python ./scripts/autotune_scaling_factor/raytuner_ng45.py
At the end of the run you will get the best scaling parameters for the given benchmark design that minimizes the PPA difference with the target library. You can find all the scaled libraries in the following path:
./run/libraries/scaled_lib_<scaling_factor>
- J. Jung, A. B. Kahng, S. Kundu, Z. Wang and D. Yoon, "IEEE CEDA DATC Emerging Foundations in IC Physical Design and MLCAD Research", (.pdf), Proc. ACM/IEEE International Conference on Computer-Aided Design, 2023