\_\_\_\_\_

# FPGA MACRO-PLACEMENT CONTEST CALL FOR PARTICIPATION

Macro placement plays an integral role in routability and timing closure in both the ASIC and FPGA physical design flows. In particular, the discrete and columnated nature of the FPGA device layout presents unique placement constraints on placeable macros (e.g. BRAM's, DSP's, URAM's, cascaded shapes, etc.). These constraints are challenging for classical optimization and combinatorial approaches, and often the generated floorplans result in netlist design placements with routing and timing closure issues. Inspired recent deep reinforcement learning (RL) approaches https://arxiv.org/abs/2004.10746), the goal of the competition is to spur academic research for developing ML or deep RL approaches to improve upon the current state-of-the-art macro placement tools.

### **BENCHMARK SUITE DATASET:**

The organizers will provide a benchmark suite dataset using an extended bookshelf format. Please refer to <a href="https://github.com/TILOS-AI-Institute/MLCAD23-FPGA-Macro-Placement-Contest/blob/main/Documentation/BenchmarkFileFormat.md">https://github.com/TILOS-AI-Institute/MLCAD23-FPGA-Macro-Placement-Contest/blob/main/Documentation/BenchmarkFileFormat.md</a> for a full description of the file format. Each design in the benchmark suite contains the following files:

- 1. design.nodes: Specifies placeable instances in the netlist (in Bookshelf format)
- 2. design.nets: Specifies the set of nets in the netlist (in Bookshelf format)
- 3. design.lib: Specifies the cell library for placeable objects instances
- 4. design.pl: Specifies the site locations of the macros including cascaded macro shape instances, I/O, and fixed objects. This supplied file only contains locations of fixed instances (IBUF/OBUF/BUFGCE etc). Your task is to supply the locations of the placeable macro instances. Valid locations for macro (and cascaded shape) instances are prescribed in the design.scl file.
- 5. sample.pl: Specifies a macro placement sample reference solution.
- 6. design.scl: Extended from the original bookshelf format to represent a target device layout and permissible site locations for all placeable object instance types (please refer to Figure 1).
- 7. design.cascade shape: Specifies the types of placeable cascaded macro instance shapes.
- 8. design.cascade\_shape\_instances: Specifies the netlist instances of cascaded macro instance shapes.
- 9. design.regions: Specifies the box region constraints imposed on placeable objects instances
- 10. design.dcp: This file contains the synthesized netlist checkpoint that is required as an input by the Vivado© executable.
- 11. place\_route.tcl: A TCL script to place and route a netlist using the Vivado© flow leveraging the input macro placement solution.

# **BENCHMARK DATASET LOCATION:**

You can download the benchmark dataset from Kaggle:

https://www.kaggle.com/datasets/ismailbustany/mlcad2023-fpga-macroplacement-

### **FPGA DEVICE DESCRIPTION:**

The FPGA architecture used in the contest will be based on an UltrascalePlus xcvu3p monolithic device (please refer <a href="here">here</a>). The organizers reserve the right to modify the contents of the benchmark designs and format.

# **EVALUTION METRICS:**

The macro placement solution produced by participating macro placers will be evaluated using the Vivado© physical design compiler. Contestant teams will be provided with a Vivado© license and a place-and-route flow that (i) reads an input macro placement in the extended bookshelf format; (ii) check macro placement legality; (iii) perform standard cell placement and routing. The place-and-route flow will be non-timing driven for this contest. The macro placement solution will be evaluated based on the following criterias:

- 1. Legality of the macro placement
- 2. Global and detail routing metrics (within a time-out limit of 6 hours)
- 3. Total routed wirelength and routing congestion metrics
- 4. Macro placement runtime
- 5. Total placement and routing runtime of the Vivado© place and route flow

Further details are provided on the contest's website: <a href="https://github.com/TILOS-AI-Institute/MLCAD23-FPGA-Macro-Placement-Contest">https://github.com/TILOS-AI-Institute/MLCAD23-FPGA-Macro-Placement-Contest</a>.

## **MACRO-PLACEMENT SOLUTION GUIDELINES:**

Teams are encouraged to develop a ML approach, but are free to use any approach (e.g. classical optimization, combinatorial, ML, RL, etc.) for their macro-placement solution.

# **RELEVANT CONTEST DATES:**

Please make note of the following dates:

- 04/15/2023: The Benchmark suite dataset will be provided
- 05/15/2023: Registration deadline
- 07/15/2023: Each team must <u>submit an alpha binary submission for test purposes</u>, else will be disqualified from the contest.
- **08/15/2023**: Teams are required to submit their final executable binaries by 11:59pm (pacific time).
- The contest results will be announced during MLCAD 2023 on 09/13/2023

## **CONTEST REGISTRATION:**

To register your team, please provide the following information:

1. Please add "MLCAD2023" to the subject of any email

- 2. Affiliation of the team/contestant(s)
- 3. Names of team members and advising professor
- 4. One correspondence e-mail address for the team
- 5. Name of the macro placer
- 6. To participate in the contest and obtain a 1-year Vivado license, the teams' advising professors must register their team through the export compliant Xilinx University Program, <a href="https://www.xilinx.com/support/university/donation-program.html">https://www.xilinx.com/support/university/donation-program.html</a>.

# **PRIZES:**

Monetary prizes will be awarded to the top three teams. More details on this will be announced on the web site.

# **CONTEST WEBSITE:**

https://github.com/TILOS-AI-Institute/MLCAD23-FPGA-Macro-Placement-Contest

# **E-MAIL CONTACT:**

For registration and contest related inquiries, please email: <a href="mailto:mlcad2023contest@gmail.com">mlcad2023contest@gmail.com</a>

# **CONTEST COMMITTEE:**

Ismail Bustany (Chair) Meghraj Kalase Wuxi Li Grigor Gasparyan Amit Gupta Andrew Kahng

# **ACKNOWLEDGEMENTS:**

The organizers wish to thank Bodhisatta Pramanik, Zhiang Wang, Drs. Yuji Kukimoto, Sreevidya Maguluri, Ravishankar Menon, Nima Karimpour-Darav, Mehrdad Eslami, Chaithanya Dudha, Lin Chai, Kai Zhu, and Vishal Suthar for their helpful remarks, advice, and assistance.



**Figure 1:** This figure depicts the xcvu3p color-coded macro columnar placement sites for URAM's (magenta), BRAM's (yellow) and DSP's (red).