# **Lab2 – Fixed Outline Floorplanning**

Deadline: 2024/10/20 23:59

# **Lab2 Introduction**

This programming assignment asks you to write a **fixed-outline floorplanner** to handle hard macros. Given a set of rectangular macros and nets, the floorplanner places all macros within a rectangular chip without any overlaps. We assume that the lower-left corner of this chip is the origin (0, 0), and no space (channel) is needed between two different macros. The objective is to minimize the area of the chip bounding box and the total net wire length. The total wirelength W of a set N can be computed by

$$W = \sum_{n_i \in N} HPWL(n_i)$$

where  $n_i$  denotes a net in N, and  $HPWL(n_i)$  denotes the half-perimeter wire length of  $n_i$ . The objective for this problem is to minimize

$$Cost = \alpha A + (1 - \alpha)W$$
 (Note: Cost is integer.)

where A denotes the bounding-box area of the floorplan, and  $\alpha$ ,  $0 \le \alpha \le 1$ , is a user defined ratio to balance the final area and wirelength. Note that a floorplan which cannot fit into the given outline is not accepted.

### **Input**

Each test case has two input files, *input.block* and *input.nets*. The first file (*input.block*) gives the **outline size**, the **number of blocks**, and the **number of terminals** defined in this file. Then the **block dimensions** are listed, followed by the terminal locations. The file format is as follows:

```
Outline: <outline width, outline height>
NumBlocks: <# of blocks>
NumTerminals: <# of terminals>

<macro name> <macro width> <macro height>
... More macros

<terminal name> terminal <terminal x coordinate> <terminal y coordinate>
... More terminals
```

Figure 1 Input file format ( input.block ).

The second file (input.net) gives the **number of nets** in the floorplan, followed by the **terminal information for each net**. The file format is as follows:

```
NumNets:<# of nets>
NetDegree:<# of blocks in this net>
<block name>
... More block names
...More "NetDegree" and "block name"
```

Figure 2 Input file format ( input.nets )

The user-defined ratio  $\alpha$  is given through the command-line argument. It ranges between 0 and 1.

#### **Output**

The output file (*output.rpt*) records the problem output. This report consists of six parts: (1) the final cost, (2) the total wirelength, (3) the chip area, (4) the chip width and height, (5) the runtime in seconds, and (6) the bounding-box coordinate for each macro (specified by the lower-left corner and upper-right corner). The report file format is shown below.)

```
<final cost>
// Cost = \alpha A + (1-\alpha)W
<total wirelength>
//W = \sum HPWL(n_i)
<chip area>
// area = (chip width) * (chip height)
<chip width> <chip height>
//resulting chip width and height
cprogram runtime>
//report the runtime in seconds
                                              \langle x2 \rangle
<macro name>
                       \langle x1 \rangle
                                   <v1>
                                              \langle x2 \rangle
                                                          <y2>
<macro name>
                       \langle x1 \rangle
                                   <v1>
// (x1, y1): lower-left corner, (x2, y2): upper-right corner
```

Figure 3 Output file format ( output.rpt )

Note: All the x&y coordinates should be integer.

# **Command-Line Parameters**

In order to test your program, you are asked to add the following command-line parameters to your program (Please name your execution file name as "Lab2"):

./Lab2 [α value] [input.block name] [input.net name] [output name]
For example, "./Lab2 0.5 input.block input.nets output.rpt".

# **Example**

Figure 4 illustrates an example of the IO files (assume  $\alpha = 0.5$ ):

# Input files (input.block):



Figure 4 A floorplanning problem and its solution

# (input .nets)

| NumNets: 2   |
|--------------|
| NetDegree: 3 |
| A            |
| C            |
| D            |
| NetDegree: 2 |
| В            |
| D            |

# Output files (output.rpt)

| 508  | 5   |    |     |     |
|------|-----|----|-----|-----|
| 170  |     |    |     |     |
| 100  | 00  |    |     |     |
| 100  | 100 |    |     |     |
| 0.24 | ļ   |    |     |     |
| A    | 0   | 50 | 40  | 100 |
| В    | 40  | 50 | 100 | 100 |
| C    | 0   | 0  | 60  | 50  |
| D    | 60  | 0  | 100 | 50  |

# Output files (output.rpt)

| 508  | 5   | Cost           |     |     |  |  |
|------|-----|----------------|-----|-----|--|--|
| 170  |     | HPWL           |     |     |  |  |
| 1000 | 00  | Area           |     |     |  |  |
| 100  | 100 | Width & Height |     |     |  |  |
| 0.24 |     | Runtime        |     |     |  |  |
| A    | 0   | 50             | 40  | 100 |  |  |
| B    | 40  | 50             | 100 | 100 |  |  |
| C    | 0   | 0              | 60  | 50  |  |  |
| D    | 60  | 0              | 100 | 50  |  |  |

**HPWL (Half-Perimeter Wire Length)**: The smallest square such that all net pins are inside. Use the **center point** of the Macro as its pin (round down to integer) as shown in Figure 5.

Note: You need to round down HPWL of each net.



Figure 5 Example of HPWL

#### Resources

Sample input files (ami33/ami49/vda317) and a verifier are provided for you.

#### **Evaluation**

- You MUST WRITE YOUR OWN CODE. Copying codes may result you to FAIL this
  course.
- 2. Naming rule.
  - A. Name of the binary after "make" Lab2
  - B. Execution procedure:
    - ./Lab2 [α value] [input.block name] [input.net name] [output name]
    - ./verifier [α value] [input.block name] [input.net name] [output name]

Please use chmod to change the permission of verifier at the first time.

```
[s410510026@mseda01 tmptmp]$ chmod 755 verifier
[s410510026@mseda01 tmptmp]$ ./verifier 0.5 ami33/ami33.block ami33/ami33.nets output.txt
HPWL:
                  Pass
AREA:
                  Pass
COST:
                  Pass
OVERLAP:
                  Pass
OUT_OF_RANGE: Pass
Your solution
Area:1268365
HPWL:116631
Cost:692498
Height:1085
Width:1169
Verified
Area:1268365
HPWL:116631
Cost:692498
Height:1085
Width:1169
HPWL file generated output.txt.HPWL
```

- 3. Hidden cases will be evaluated
- **4.** Performance will be evaluated. The costs will be evaluated first. If the costs are the same, the performance will be evaluated based on run time.

#### Grading

This programming assignment will be graded based on:

- (1) Correctness of the program (no error, all blocks are in the fixed outline)
- (2) Solution quality (minimize the cost). The lower the cost, the higher the score you will get.
- (3) For each case, the run time limit is up to 300 seconds. It will be regarded as "failed" if you use more than 300 seconds.
- (4) Please make sure your code is available on our linux server. If it cannot be executed, you will get zero point.
- (5) Accept four days late submission, 10% deduction per day. That is, if you hand in on 11/1, the score will be \*0.9; if you hand in on 11/4, the score will be \*0.6, and submission will not be accepted after 11/4.

Also, a script on checking similarity for codes will be performed. If two codes exist high similarity. Both codes receive zero mark after confirmation.

The primary objective is to place all blocks into the fixed outline successfully and to minimize the **cost**.

#### Submission

#### <1>

Please put all required files in a folder, the name of the folder is your Student\_ID.

```
Student_ID
|__Source code (.cpp, .h)
|__Makefile
```

### <2>

Use the below command to compress the folder in the linux environment, and the compressed file name should be the same as your Student ID.

```
tar cvf Student_ID.tar Student_ID
```

#### **Example**

#### <1>

```
.

— 310510161

— Lab1.cpp

— Makefile
```

#### <2>

```
21:19 zu00895077@vda04 [~/PDA_TA/Lab1] >$ ls
310510161/
21:19 zu00895077@vda04 [~/PDA_TA/Lab1] >$ tar cvf 310510161.tar 310510161
310510161/
310510161/Lab1.cpp
310510161/Makefile
21:21 zu00895077@vda04 [~/PDA_TA/Lab1] >$ ls
310510161/ 310510161.tar
```

# Upload Student ID.tar to e3

(If your submission file is not .tar, you will get zero point!!)

# **Supplementary Instructions:**

- The cost of your output should be integer.
- HPWL is calculated as: ( (int) x\_max (int) x\_min + (int) y\_max (int) y\_min )

- The display method of verifier is scientific notation, and it will only be displayed to 4 decimal places. If the result calculated by verifier is the same as your result, but the COST comparison shows FAIL, this may represent a different value after 4 decimal places in scientific representation. So please double check that you calculate the HPWL in the same way as the TA described above.
- The alpha is determined by the TA during the demo, you only need to make sure that the alpha works between 0 and 1 (including 0 and 1)
- Run time limit is 300 seconds. TA will test it by himself. The runtime in the output file will not be used for judgment.
- The terminal will only be outside the outline or on the outline. Terminal will not inside the block.
- The number of net is less than 500.
- The number of block is less than 500.
- The number of terminal is less than 500.
- All the value in .block and .net will be integer.