

## Lecture 3 – Chip Planning

## Lectures 3 and 4 – Chip Planning

- 3.1 Introduction to Floorplanning
- 3.2 Optimization Goals in Floorplanning
- 3.3 Terminology
- 3.4 Floorplan Representations
  - 3.4.1 Floorplan to a Constraint-Graph Pair
  - 3.4.2 Floorplan to a Sequence Pair
  - 3.4.3 Sequence Pair to a Floorplan
- 3.5 Floorplanning Algorithms
  - 3.5.1 Floorplan Sizing
  - 3.5.2 Cluster Growth
  - 3.5.3 Simulated Annealing
  - 3.5.4 Integrated Floorplanning Algorithms
- 3.6 Pin Assignment
- 3.7 Power and Ground Routing
  - 3.7.1 Design of a Power-Ground Distribution Network
  - 3.7.2 Planar Routing
  - 3.7.3 Mesh Routing

### 3.1 Introduction



VLSI Physical Design: From Graph Partitioning to Timing Closure

Chapter 3: Chip Planning

3

### Hierarchical Design

- Blocks are obtained after partitioning
- Need to:
  - Put the blocks together.
  - Design each block.
- Which step should go first?



VLSI Physical Design: From Graph Partitioning to Timing Closure

Chapter 3: Chip Planning

4

## Hierarchical Design

- How to put the blocks together without knowing their shapes and I/O pin positions
  - Blocks are not yet designed
- If we design the blocks first, those blocks may not form a tight packing.



## Floorplanning

- The floorplanning problem is to plan the positions and shapes of the modules at the beginning of the design cycle to optimize circuit performance:
  - chip area
  - total wire length
  - delay of critical path
  - routability
  - others, e.g., noise, heat dissipation, etc.

## Floorplanning v.s. Placement

- Both determine block positions to optimize the circuit performance.
- Floorplanning:
  - Details like shapes of blocks, I/O pin positions, etc. are not yet fixed (blocks with flexible shape are called soft blocks).
- Placement:
  - Details like module shapes and I/O pin positions are fixed (blocks with no flexibility in shape are called hard blocks).

### 3.1 Introduction



## 3.1 Introduction

### Example

Given: Three blocks with the following potential widths and heights

**Block A:**  $w = 1, h = 4$  or  $w = 4, h = 1$  or  $w = 2, h = 2$

**Block B:**  $w = 1, h = 2$  or  $w = 2, h = 1$

**Block C:**  $w = 1, h = 3$  or  $w = 3, h = 1$

Task: Floorplan with minimum total area enclosed



## 3.1 Introduction

### Example

Given: Three blocks with the following potential widths and heights

**Block A:**  $w = 1, h = 4$  or  $w = 4, h = 1$  or  $w = 2, h = 2$

**Block B:**  $w = 1, h = 2$  or  $w = 2, h = 1$

**Block C:**  $w = 1, h = 3$  or  $w = 3, h = 1$

Task: Floorplan with minimum total area enclosed



## 3.1 Introduction

### Example

Given: Three blocks with the following potential widths and heights

**Block A:**  $w = 1, h = 4$  or  $w = 4, h = 1$  or  $w = 2, h = 2$

**Block B:**  $w = 1, h = 2$  or  $w = 2, h = 1$

**Block C:**  $w = 1, h = 3$  or  $w = 3, h = 1$

Task: Floorplan with minimum total area enclosed



Solution:

Aspect ratios

**Block A with  $w = 2, h = 2$ ; Block B with  $w = 2, h = 1$ ; Block C with  $w = 1, h = 3$**

This floorplan has a global bounding box with minimum possible area (9 square units).

## 3.2 Optimization Goals in Floorplanning

- Area and shape of the global bounding box
  - Global bounding box of a floorplan is the minimum axis-aligned rectangle that contains all floorplan blocks.
  - Area of the global bounding box represents the area of the top-level floorplan
  - Minimizing the area involves finding  $(x,y)$  locations, as well as shapes, of the individual blocks.
- Total wirelength
  - Long connections between blocks may increase signal propagation delays in the design.
- Combination of area  $\text{area}(F)$  and total wirelength  $L(F)$  of floorplan  $F$ 
  - Minimize  $\alpha \cdot \text{area}(F) + (1 - \alpha) \cdot L(F)$  where the parameter  $0 \leq \alpha \leq 1$  gives the relative importance between  $\text{area}(F)$  and  $L(F)$
- Signal delays
  - Static timing analysis is used to identify the interconnects that lie on critical paths.

## Wire Length Estimation

- Exact wire length of each net is not known until routing is done.
- In floorplanning, even pin positions are not known yet.
- Some possible wire length estimations:
  - Center-to-center estimation
  - Half-perimeter estimation



## Dead Space

- Dead space is the space that is wasted:



- Minimizing area is the same as minimizing dead space.
- Dead space percentage is computed as

$$(A - \sum_i A_i) / A \times 100\%$$

### 3.3 Terminology

- A **rectangular dissection** is a division of the chip area into a set of *blocks* or non-overlapping rectangles.
- A **slicing floorplan** is a rectangular dissection
  - Obtained by repeatedly dividing each rectangle, starting with the entire chip area, into two smaller rectangles
  - Horizontal or vertical cut line.
- A **slicing tree** or **slicing floorplan tree** is a binary tree with  $k$  leaves and  $k - 1$  internal nodes
  - Each leaf represents a block
  - Each internal node represents a horizontal or vertical cut line.

### Slicing Trees

Slicing Floorplan



Slicing Tree



## Slicing Trees

- PostOrder Polish Expression Traversal
- $ij^+$ 
  - Rectangle  $i$  on bottom of  $j$
- $ij^*$ 
  - Rectangle  $i$  on the left of  $j$

### 3.3 Terminology

Slicing floorplan and two possible corresponding slicing trees



#### Polish expression



- Bottom up:  $V \rightarrow *$  and  $H \rightarrow +$
- Length  $2n-1$  ( $n =$  Number of leaves of the slicing tree)

### Slicing Trees



**21+67\*45\*+3+\***

#### Slicing Tree



**Polish Expression  
(postorder traversal of slicing tree)**

- A postorder traversal of the slicing tree:
  - 1. Left sub-tree
  - 2. Right sub-tree
  - 3. Current root
- For n blocks, a PE contains n operands (blocks) and n-1 operators (\*, +).
- One slicing floorplan can have more than one slicing tree (and hence more than one PE). Redundancy exists, which is not good.

### 3.3 Terminology

#### Non-slicing floorplans (wheels)



### 3.3 Terminology

Floorplan tree: Tree that represents a hierarchical floorplan



- H** Horizontal division  
(objects to the top and bottom)
- V** Vertical division  
(objects to the left and right)

- W** Wheel (4 objects cycled around a center object)

© 2011 Springer Verlag

### 3.3 Terminology

- In a **vertical constraint graph (VCG)**, node weights represent the heights of the corresponding blocks.
  - Two nodes  $v_i$  and  $v_j$ , with corresponding blocks  $m_i$  and  $m_j$ , are connected with a directed edge from  $v_i$  to  $v_j$  if  $m_i$  is below  $m_j$ .
- In a **horizontal constraint graph (HCG)**, node weights represent the widths of the corresponding blocks.
  - Two nodes  $v_i$  and  $v_j$ , with corresponding blocks  $m_i$  and  $m_j$ , are connected with a directed edge from  $v_i$  to  $v_j$  if  $m_i$  is to the left of  $m_j$ .
- The longest path(s) in the VCG / HCG correspond(s) to the minimum vertical / horizontal floorplan span required to pack the blocks (floorplan height / width).
- A **constraint-graph pair** is a floorplan representation that consists of two directed graphs – *vertical constraint graph* and *horizontal constraint graph* – which capture the relations between block positions.

### 3.3 Terminology

#### Constraint graphs



© 2011 Springer Verlag

### 3.3 Terminology

#### Sequence pair

- Two permutations represent geometric relations between every pair of blocks
  - if *a* appears before *b* in both  $S_+$  and  $S_-$ , then *a* is to the left of *b*
  - if *a* appears before *b* in  $S_+$  but not in  $S_-$ , then *a* is above *b*

### 3.3 Terminology

#### Sequence pair

- Two permutations represent geometric relations between every pair of blocks
  - if  $a$  appears before  $b$  in both  $S_+$  and  $S_-$ , then  $a$  is to the left of  $b$
  - if  $a$  appears before  $b$  in  $S_+$  but not in  $S_-$ , then  $a$  is above  $b$
- Horizontal and vertical relations between blocks  $A$  and  $B$ :  
 $(\dots A \dots B \dots, \dots A \dots B \dots) \rightarrow A$  is left of  $B$   
 $(\dots A \dots B \dots, \dots B \dots A \dots) \rightarrow A$  is above  $B$   
 $(\dots B \dots A \dots, \dots A \dots B \dots) \rightarrow A$  is below  $B$   
 $(\dots B \dots A \dots, \dots B \dots A \dots) \rightarrow A$  is right of  $B$



### 3.4 Floorplan Representations

- 3.1 Introduction to Floorplanning
- 3.2 Optimization Goals in Floorplanning
- 3.3 Terminology
- 3.4 Floorplan Representations
  - 3.4.1 Floorplan to a Constraint-Graph Pair
  - 3.4.2 Floorplan to a Sequence Pair
  - 3.4.3 Sequence Pair to a Floorplan
- 3.5 Floorplanning Algorithms
  - 3.5.1 Floorplan Sizing
  - 3.5.2 Cluster Growth
  - 3.5.3 Simulated Annealing
  - 3.5.4 Integrated Floorplanning Algorithms
- 3.6 Pin Assignment
- 3.7 Power and Ground Routing
  - 3.7.1 Design of a Power-Ground Distribution Network
  - 3.7.2 Planar Routing
  - 3.7.3 Mesh Routing

### 3.4.1 Floorplan to a Constraint-Graph Pair

- Create nodes for every block
- In addition, create a source node and a sink one



### 3.4.1 Floorplan to a Constraint-Graph Pair

- Create nodes for every block.
- In addition, create a source node and a sink one.
- Add a directed edge  $(A,B)$  if Block A is below/left of Block B. (HCG)



### 3.4.1 Floorplan to a Constraint-Graph Pair

- Create nodes for every block.
- In addition, create a source node and a sink one.
- Add a directed edge  $(A,B)$  if Block  $A$  is below/left of Block  $B$ . (HCG)
- Remove the redundant edges that can be derived from other edges by transitivity.



### 3.4.2 Floorplan to a Sequence Pair

- Given two blocks  $A$  and  $B$  with
  - Locations:  $A = (x_A, y_A)$  and  $B = (x_B, y_B)$
  - Dimensions:  $A = (w_A, h_A)$  and  $B = (w_B, h_B)$
- If  $x_A + w_A \leq x_B$  and  $!(y_A + h_A \leq y_B \text{ or } y_B + h_B \leq y_A)$ , then  $A$  is **left of**  $B$
- If  $y_A + h_A \leq y_B$  and  $!(x_A + w_A \leq x_B \text{ or } x_B + w_B \leq x_A)$ , then  $A$  is **below**  $B$



$S_+ : < acdbe >$   
 $S_- : < cdaeb >$

### 3.4.3 Sequence Pair to a Floorplan

- Start with the bottom left corner
- Define a *weighted sequence* as a sequence of blocks based on width
  - Each block  $B$  has its own width  $w(B)$
- Old (traditional) algorithm: find the longest path through edges ( $O(n^2)$ )
- Newer approach: find the *longest common subsequence (LCS)*
  - Given two weighted sequences  $S_1$  and  $S_2$ , the  $LCS(S_1, S_2)$  is the longest sequence found in both  $S_1$  and  $S_2$
  - The length of  $LCS(S_1, S_2)$  is the sum of weights
- For block placement:
  - $LCS(S_+, S_-)$  returns the  $x$ -coordinates of all blocks
  - $LCS(S_+^R, S_-)$  returns the  $y$ -coordinates of all blocks ( $S_+^R$  is the reverse of  $S_+$ )
  - The length of  $LCS(S_+, S_-)$  and  $LCS(S_+^R, S_-)$  is the width and height, respectively

### 3.4.3 Sequence Pair to a Floorplan

Algorithm: Longest Common Subsequence (LCS)

Input: sequences  $S_1$  and  $S_2$ , weights of  $n$  blocks *weights*

Output: positions of each block *positions*, total span  $L$

```
1. for ( $i = 1$  to  $n$ )                                // initialization
2.    $block\_order[S_2[i]] = i$ 
3.    $lengths[i] = 0$ 
4. for ( $i = 1$  to  $n$ )
5.    $block = S_1[i]$                                 // current block
6.    $index = block\_order[block]$ 
7.    $positions[block] = lengths[index]$            // compute block position
8.    $t\_span = positions[block] + weights[block]$  // finds length of sequence
                                                // from beginning to block
9.   for ( $j = index$  to  $n$ )
10.    if ( $t\_span > lengths[j]$ )  $lengths[j] = t\_span$  // update total length
11.    else break
12.  $L = lengths[n]$                                 // total length is stored here
```

## 3.5 Floorplanning Algorithms

- 3.1 Introduction to Floorplanning
- 3.2 Optimization Goals in Floorplanning
- 3.3 Terminology
- 3.4 Floorplan Representations
  - 3.4.1 Floorplan to a Constraint-Graph Pair
  - 3.4.2 Floorplan to a Sequence Pair
  - 3.4.3 Sequence Pair to a Floorplan
- **3.5 Floorplanning Algorithms**
  - 3.5.1 Floorplan Sizing
  - 3.5.2 Cluster Growth
  - 3.5.3 Simulated Annealing
  - 3.5.4 Integrated Floorplanning Algorithms
- 3.6 Pin Assignment
- 3.7 Power and Ground Routing
  - 3.7.1 Design of a Power-Ground Distribution Network
  - 3.7.2 Planar Routing
  - 3.7.3 Mesh Routing

## 3.5 Floorplanning Algorithms

### Common Goals

- To minimize the total length of interconnect, subject to an upper bound on the floorplan area
- or
- To simultaneously optimize both wire length and area

### 3.5.1 Floorplan Sizing

#### Shape functions



$$h * w \geq A$$



Block with minimum width and height restrictions

Oten, R.: Efficient Floorplan Optimization, Int. Conf. on Computer Design, 499-502, 1983

### 3.5.1 Floorplan Sizing

#### Shape functions



Discrete  $(h, w)$  values



Hard library block

Oten, R.: Efficient Floorplan Optimization, Int. Conf. on Computer Design, 499-502, 1983

### 3.5.1 Floorplan Sizing

#### Corner points



### 3.5.1 Floorplan Sizing

#### Algorithm

This algorithm finds the **minimum floorplan area** for a given slicing floorplan in polynomial time. For non-slicing floorplans, the problem is NP-hard.

- Construct the shape functions of all individual blocks
- Bottom up: Determine the shape function of the top-level floorplan from the shape functions of the individual blocks
- Top down: From the corner point that corresponds to the minimum top-level floorplan area, trace back to each block's shape function to find that block's dimensions and location.

### 3.5.1 Floorplan Sizing – Example

Step 1: Construct the shape functions of the blocks



### 3.5.1 Floorplan Sizing – Example

Step 1: Construct the shape functions of the blocks



### 3.5.1 Floorplan Sizing – Example

Step 1: Construct the shape functions of the blocks



### 3.5.1 Floorplan Sizing – Example

Step 1: Construct the shape functions of the blocks



### 3.5.1 Floorplan Sizing – Example

Step 1: Construct the shape functions of the blocks



### 3.5.1 Floorplan Sizing – Example

Step 2: Determine the shape function of the top-level floorplan (vertical)



### 3.5.1 Floorplan Sizing – Example

Step 2: Determine the shape function of the top-level floorplan (vertical)



### 3.5.1 Floorplan Sizing – Example

Step 2: Determine the shape function of the top-level floorplan (vertical)



### 3.5.1 Floorplan Sizing – Example

Step 2: Determine the shape function of the top-level floorplan (vertical)



### 3.5.1 Floorplan Sizing – Example

Step 2: Determine the shape function of the top-level floorplan (vertical)



### 3.5.1 Floorplan Sizing – Example

Step 2: Determine the shape function of the top-level floorplan (vertical)



### 3.5.1 Floorplan Sizing – Example

Step 2: Determine the shape function of the top-level floorplan (horizontal)



Minimum top-level floorplan with horizontal composition

### 3.5.1 Floorplan Sizing – Example

Step 3: Find the individual blocks' dimensions and locations



Horizontal composition

### 3.5.1 Floorplan Sizing – Example

Step 3: Find the individual blocks' dimensions and locations



Horizontal composition

### 3.5.1 Floorplan Sizing – Example

Step 3: Find the individual blocks' dimensions and locations



### 3.5.1 Floorplan Sizing – Example



### 3.5.2 Cluster Growth

- Iteratively add blocks to the cluster until all blocks are assigned
- Only the different orientations of the blocks instead of the shape / aspect ratio are taken into account
- Linear ordering to minimize total wirelength of connections between blocks



© 2011 Springer Verlag

### 3.5.2 Cluster Growth – Linear Ordering

- **New nets** have no pins on any block from the partially-constructed ordering
- **Terminating nets** have no other incident blocks that are unplaced
- **Continuing nets** have at least one pin on a block from the partially-constructed ordering and at least one pin on an unordered block



### 3.5.2 Cluster Growth – Linear Ordering

- Gain of each block  $m$  is calculated:

$$Gain_m = (\text{Number of terminating nets of } m) - (\text{New nets of } m)$$



- The block with the maximum gain is selected to be placed next

### 3.5.2 Cluster Growth – Linear Ordering (Example)

Given:

- Netlist with five blocks  $A, B, C, D, E$  and six nets
  - $N_1 = \{A, B\}$
  - $N_2 = \{A, D\}$
  - $N_3 = \{A, C, E\}$
  - $N_4 = \{B, D\}$
  - $N_5 = \{C, D, E\}$
  - $N_6 = \{D, E\}$
- Initial block: A



Task: Linear ordering with minimum netlength



| Iteration # | Block    | New Nets        | Terminating Nets | Gain | Continuing Nets |
|-------------|----------|-----------------|------------------|------|-----------------|
| 0           | <b>A</b> | $N_1, N_2, N_3$ | --               | -3   | --              |

Initial block  
↑

$$Gain_A = (\text{Number of terminating nets of } A) - (\text{New nets of } A)$$

63



| Iteration # | Block    | New Nets        | Terminating Nets | Gain | Continuing Nets |
|-------------|----------|-----------------|------------------|------|-----------------|
| 0           | <b>A</b> | $N_1, N_2, N_3$ | --               | -3   | --              |
| 1           | <b>B</b> | $N_4$           | $N_1$            | 0    | --              |
|             | C        | $N_5$           | --               | -1   | $N_3$           |
|             | D        | $N_4, N_5, N_6$ | $N_2$            | -2   | --              |
|             | E        | $N_5, N_6$      | --               | -2   | $N_3$           |



64



| Iteration # | Block    | New Nets        | Terminating Nets | Gain | Continuing Nets |
|-------------|----------|-----------------|------------------|------|-----------------|
| 0           | <b>A</b> | $N_1, N_2, N_3$ | --               | -3   | --              |
| 1           | <b>B</b> | $N_4$           | $N_1$            | 0    | --              |
|             | C        | $N_5$           | --               | -1   | $N_3$           |
|             | D        | $N_4, N_5, N_6$ | $N_2$            | -2   | --              |
|             | E        | $N_5, N_6$      | --               | -2   | $N_3$           |
| 2           | C        | $N_5$           | --               | -1   | $N_3$           |
|             | <b>D</b> | $N_5, N_6$      | $N_2, N_4$       | 0    | --              |
|             | E        | $N_5, N_6$      | --               | -2   | $N_3$           |



65



| Iteration # | Block    | New Nets        | Terminating Nets | Gain | Continuing Nets |
|-------------|----------|-----------------|------------------|------|-----------------|
| 0           | <b>A</b> | $N_1, N_2, N_3$ | --               | -3   | --              |
| 1           | <b>B</b> | $N_4$           | $N_1$            | 0    | --              |
|             | C        | $N_5$           | --               | -1   | $N_3$           |
|             | D        | $N_4, N_5, N_6$ | $N_2$            | -2   | --              |
|             | E        | $N_5, N_6$      | --               | -2   | $N_3$           |
| 2           | C        | $N_5$           | --               | -1   | $N_3$           |
|             | <b>D</b> | $N_5, N_6$      | $N_2, N_4$       | 0    | --              |
|             | E        | $N_5, N_6$      | --               | -2   | $N_3$           |
| 3           | C        | --              | --               | 0    | $N_3, N_5$      |
|             | <b>E</b> | --              | $N_6$            | 1    | $N_3, N_5$      |
| 4           | <b>C</b> | --              | $N_3, N_5$       | 2    | --              |

### 3.5.2 Cluster Growth – Linear Ordering (Example)



### 3.5.2 Cluster Growth – Algorithm

**Input:** set of all blocks  $M$ , cost function  $C$

**Output:** optimized floorplan  $F$  based on  $C$

$F = \emptyset$

$order = \text{LINEAR\_ORDERING}(M)$

// generate linear ordering

**for** ( $i = 1$  to  $|order|$ )

$curr\_block = order[i]$

    ADD\_TO\_FLOORPLAN( $F, curr\_block, C$ )

// find location and orientation

// of  $curr\_block$  that causes

// smallest increase based on

//  $C$  while obeying constraints

### 3.5.2 Cluster Growth

#### Analysis

- The objective is to minimize the total wirelength of connections blocks
- Though this produces mediocre solutions, the algorithm is easy to implement and fast.
- Can be used to find the initial floorplan solutions for iterative algorithms such as *simulated annealing*.

### 3.5.3 Simulated Annealing

#### Introduction

- Simulated Annealing (SA) algorithms are iterative in nature.
- Begins with an initial (arbitrary) solution and seeks to incrementally improve the objective function.
- During each iteration, a **local** neighborhood of the current solution is considered. A new candidate solution is formed by a **small perturbation** of the current solution.
- Unlike greedy algorithms, SA algorithms **can accept** candidate solutions with **higher cost**.

### 3.5.3 Simulated Annealing



### 3.5.3 Simulated Annealing

#### What is annealing?

- Definition (from material science): controlled cooling process of high-temperature materials to modify their properties.
- Cooling changes material structure from being highly randomized (chaotic) to being structured (stable).
- The way that atoms settle in low-temperature state is probabilistic in nature.
- Slower cooling has a higher probability of achieving a **perfect lattice** with minimum-energy
  - Cooling process occurs in steps
  - Atoms need enough time to try different structures
  - Sometimes, atoms may move across larger distances and create (intermediate) higher-energy states
  - Probability of the accepting higher-energy states decreases with temperature

### 3.5.3 Simulated Annealing

#### Simulated Annealing

- Generate an initial solution  $S_{init}$ , and evaluate its cost.
- Generate a new solution  $S_{new}$  by performing a random walk
- $S_{new}$  is accepted or rejected based on the temperature  $T$ 
  - Higher  $T$  means a higher probability to accept  $S_{new}$  if  $COST(S_{new}) > COST(S_{init})$
  - $T$  slowly decreases to form the final solution
- Boltzmann acceptance criterion, where  $r$  is a random number [0,1)
$$e^{\frac{COST(S_{init}) - COST(S_{new})}{T}} > r$$

### 3.5.3 Simulated Annealing

#### Simulated Annealing

- Generate an initial solution and evaluate its cost
  - Generate a new solution by performing a random walk
  - Solution is accepted or rejected based on a temperature parameter T
  - Higher T indicates higher probability to accept a solution with higher cost
  - T slowly decreases to form the finalized solution.
- 
- Boltzmann acceptance criterion:

$$e^{-\frac{cost(curr_{sol}) - cost(next_{sol})}{T}} > r$$

*curr<sub>sol</sub>: current solution  
next<sub>sol</sub>: new solution after perturbation  
T: current temperature  
r: random number between [0,1) from normal distr.*

### 3.5.3 Simulated Annealing – Algorithm



## Moves

- Chain:  $+ * + * + * \dots$  or  $* + * + * + \dots$

$16 + 35 * 2 + * 74 + *$   
↔ ↔ ↔ ↔ ↔      Chains

- Three kinds of moves:
  - M1: Swap 2 adjacent operands (ignoring chains)
  - M2: Complement a chain
  - M3: Swap 2 adjacent operand and operator

**(Note: M3 can result in an invalid normalized PE, so we need to check for validity after M3.)**

## Examples of Moves



VLSI Physical Design: From Graph Partitioning to Timing Closure

Chapter 3: Chip Planning

### 3.5.3 Simulated Annealing – Algorithm

**Input:** initial solution *init\_sol*

**Output:** optimized new solution *curr\_sol*

```

 $T = T_0$                                 // initialization
 $i = 0$ 
curr_sol = init_sol
curr_cost = COST(curr_sol)
while ( $T > T_{min}$ )
    while (stopping criterion is not met)
         $i = i + 1$ 
         $(a_i, b_i) = \text{SELECT\_PAIR}(curr\_sol)$ 
        trial_sol = TRY_MOVE( $a_i, b_i$ )
        trial_cost = COST(trial_sol)
         $\Delta\text{cost} = \text{trial\_cost} - \text{curr\_cost}$ 
        if ( $\Delta\text{cost} < 0$ )
            curr_cost = trial_cost
            curr_sol = MOVE( $a_i, b_i$ )
        else
             $r = \text{RANDOM}(0,1)$ 
            if ( $r < e^{-\Delta\text{cost}/T}$ )
                curr_cost = trial_cost
                curr_sol = MOVE( $a_i, b_i$ )
         $T = \alpha \cdot T$ 
    
```

// select two objects to perturb  
// try small local change

// if there is improvement,  
// update the cost and  
// execute the move

// random number [0,1]  
// if it meets threshold,  
// update the cost and  
// execute the move  
//  $0 < \alpha < 1$ ,  $T$  reduction

## 3.6 Pin Assignment

- 3.1 Introduction to Floorplanning
- 3.2 Optimization Goals in Floorplanning
- 3.3 Terminology
- 3.4 Floorplan Representations
  - 3.4.1 Floorplan to a Constraint-Graph Pair
  - 3.4.2 Floorplan to a Sequence Pair
  - 3.4.3 Sequence Pair to a Floorplan
- 3.5 Floorplanning Algorithms
  - 3.5.1 Floorplan Sizing
  - 3.5.2 Cluster Growth
  - 3.5.3 Simulated Annealing
  - 3.5.4 Integrated Floorplanning Algorithms
- 3.6 Pin Assignment**
- 3.7 Power and Ground Routing
  - 3.7.1 Design of a Power-Ground Distribution Network
  - 3.7.2 Planar Routing
  - 3.7.3 Mesh Routing

## 3.6 Pin Assignment

During pin assignment, all nets (signals) are assigned to unique pin locations such that the overall design performance is optimized.



## 3.6 Pin Assignment – Example

Given: Two sets of pins



(1) Determine the circles



Koren, N. L.: Pin Assignment in Automated Printed Circuit Boards

## 3.6 Pin Assignment – Example

(2) Determine the points



Koren, N. L.: Pin Assignment in Automated Printed Circuit Boards

## 3.6 Pin Assignment – Example

(2) Determine the points



Koren, N. L.: Pin Assignment in Automated Printed Circuit Boards

## 3.6 Pin Assignment – Example

(3) Determine initial mapping



Koren, N. L.: Pin Assignment in Automated Printed Circuit Boards

## 3.6 Pin Assignment – Example

(3) Determine initial mapping and (4) optimize the mapping (complete rotation)



Koren, N. L.: Pin Assignment in Automated Printed Circuit Boards

## 3.6 Pin Assignment – Example

(3) Determine initial mapping and (4) optimize the mapping (complete rotation)



Koren, N. L.: Pin Assignment in Automated Printed Circuit Boards

## 3.6 Pin Assignment – Example

(4) Best mapping (shortest Euclidean distance)



Koren, N. L.: Pin Assignment in Automated Printed Circuit Boards

## 3.6 Pin Assignment – Example

(4) Best mapping



Final pin assignment



Koren, N. L.: Pin Assignment in Automated Printed Circuit Boards

## 3.6 Pin Assignment

### Pin assignment to an external block $B$



## 3.6 Pin Assignment

### Pin assignment to two external blocks $A$ and $B$



## 3.7 Power and Ground Routing

- 3.1 Introduction to Floorplanning
- 3.2 Optimization Goals in Floorplanning
- 3.3 Terminology
- 3.4 Floorplan Representations
  - 3.4.1 Floorplan to a Constraint-Graph Pair
  - 3.4.2 Floorplan to a Sequence Pair
  - 3.4.3 Sequence Pair to a Floorplan
- 3.5 Floorplanning Algorithms
  - 3.5.1 Floorplan Sizing
  - 3.5.2 Cluster Growth
  - 3.5.3 Simulated Annealing
  - 3.5.4 Integrated Floorplanning Algorithms
- 3.6 Pin Assignment
- 3.7 Power and Ground Routing
  - 3.7.1 Design of a Power-Ground Distribution Network
  - 3.7.2 Planar Routing
  - 3.7.3 Mesh Routing

## 3.7 Power and Ground Routing

Power-ground distribution for a chip floorplan

Power and ground rings per block or abutted blocks



Trunks connect rings to each other or to top-level power ring

### Planar routing



### Hamiltonian path

© 2011 Springer Verlag

### Planar routing

#### Step 1: Planarize the topology of the nets

- As both power and ground nets must be routed on one layer, the design should be split using the Hamiltonian path

#### Step 2: Layer assignment

- Net segments are assigned to appropriate routing layers

#### Step 3: Determining the widths of the net segments

- A segment's width is determined from the sum of the currents from all the cells to which it connects

### Planar routing



Generating topology  
of the two supply nets

Adjusting widths of the segments  
with regard to their current loads

© 2011 Springer Verlag

### Mesh routing

#### Step 1: Creating a ring

- A ring is constructed to surround the entire core area of the chip, and possibly individual blocks.

#### Step 2: Connecting I/O pads to the ring

#### Step 3: Creating a mesh

- A power mesh consists of a set of stripes at defined pitches on two or more layers

#### Step 4: Creating Metal1 rails

- Power mesh consists of a set of stripes at defined pitches on two or more layers

#### Step 5: Connecting the Metal1 rails to the mesh

## 3.7 Power and Ground Routing

### Mesh routing



© 2011 Springer Verlag

## 3.7 Power and Ground Routing

### Mesh routing



**M1-to-M4 connection**



**M4-to-M6 connection**



**M6-to-M8 connection**

© 2011 Springer Verlag

## Summary of Chapter 3 – Objectives and Terminology

- Traditional floorplanning
  - Assumes area estimates for top-level circuit modules
  - Determines shapes and locations of circuit modules
  - Minimizes chip area and length of global interconnect
- Additional aspects
  - Assigning/placing I/O pads
  - Defining channels between blocks for routing and buffering
  - Design of power and ground networks
  - Estimation and optimization of chip timing and routing congestion
- Fixed-outline floorplanning
  - Chip size is fixed, focus on interconnect optimization
  - Can be applied to individual chip partitions (hierarchically)
- Structure and types of floorplans
  - Slicing versus non-slicing, the wheels
  - Hierarchical
  - Packed
  - Zero-deadspace

## Summary of Chapter 3 – Data Structures for Floorplanning

- Slicing trees and Polish expressions
  - Evaluating a floorplan represented by a Polish expression
- Horizontal and vertical constraint graphs
  - A data structure to capture (non-slicing) floorplans
  - Longest paths determine floorplan dimensions
- Sequence pair
  - An array-based data structure that captures the information contained in H+V constraint graphs
  - Makes constraint graphs unnecessary in practice
- Floorplan sizing
  - Shape-function arithmetic
  - An algorithm for slicing floorplans

- Cluster growth
  - Simple, fast and intuitive
  - Not competitive in practice
- Simulated annealing
  - Stochastic optimization with hill-climbing
  - Many details required for high-quality implementation (e.g., temperature schedule)
  - Difficult to debug, fairly slow
  - Competitive in practice
- Pin assignment
  - Peripheral I/Os versus area-array I/Os
  - Given "ideal locations", project them onto perimeter and shift around, while preserving initial ordering
- Power and ground routing
  - Planar routing in channels between blocks
  - Can form rings around blocks to increase current supplied and to improve reliability
  - Mesh routing