#### EE434

## **ASIC and Digital Systems**

### **Final Exam**

## May 2, 2023. (1:30pm – 3:30pm)

## Instructor: Dae Hyun Kim

#### Name:

### WSU ID:

| Problem | Points |  |
|---------|--------|--|
| 1       | 100    |  |
| 2       | 90     |  |
| 3       | 100    |  |
| 4       | 90     |  |
| Total   | 380    |  |

\* Allowed: Books, cheat sheets, class notes, notebooks, calculators, watches, laptops, smartphones, tablet PCs, etc.

\* Not allowed: Chatting apps, iMessage, etc. (basically, don't talk to anyone)

# Problem #1 (Interconnect Optimization, 100 points)

The following figure shows a net optimized by a buffer.



Notice that (R, C) is the (output resistance, input capacitance) of the corresponding cell. x is the optimal location of the buffer ( $0 < x < L_1$ ). We ignore the internal delay of the buffer. Use the PI model for each wire segment for delay estimation. We want to minimize the delay from the source to Sink 1 in this problem.

(1) Express the delay from the source to Sink 1 before the buffer insertion. (10 points)

 $d_{1,before} =$ 

(2) Express the delay from the source to Sink 1 after the buffer insertion. (10 points)

 $d_{1,after} =$ 

(3) Assuming the buffer insertion reduces the delay from the source to Sink 1, find the optimal location x of the buffer. (10 points)

(4) Answer the following questions. Correct: +5 points. Wrong: -5 points. Min: 0 points.

- If *L*<sub>1</sub> increases, then *x* increases too. (True / False)
- If  $L_2$  increases, then x increases too. (True / False)
- If  $L_3$  increases, then x increases too. (True / False)
- If  $R_A$  increases, then x increases too. (True / False)
- If  $R_D$  increases, then x increases too. (True / False)
- If  $C_B$  increases, then x increases too. (True / False)
- If C<sub>c</sub> increases, then x increases too. (True / False)
- If  $C_D$  increases, then x increases too. (True / False)

(5) Answer the following questions. Correct: +5 points. Wrong: -5 points. Min: 0 points.

Assume  $R_D < R_A$ . Assume  $C_D$  is negligible.

- If *r*<sub>1</sub> increases, then *x* increases too. (True / False)
- If r<sub>2</sub> increases, then x increases too. (True / False)
- If  $r_3$  increases, then x increases too. (True / False)
- If *c*<sub>1</sub> increases, then *x* increases too. (True / False)
- If c<sub>2</sub> increases, then x increases too. (True / False)
- If  $c_3$  increases, then x increases too. (True / False)

# Problem #2 (Interconnect Optimization, 90 points)

The following figure shows a net optimized by a buffer.



Notice that (R, C) is the (output resistance, input capacitance) of the corresponding cell. x is the optimal location of the buffer  $(0 < x < L_2)$ . We ignore the internal delay of the buffer. Use the PI model for each wire segment for delay estimation. We want to minimize the delay from the source to Sink 1 in this problem.

(1) Express the delay from the source to Sink 1 after the buffer insertion. (10 points)

 $d_{1,after} =$ 

(2) Assuming the buffer insertion reduces the delay from the source to Sink 1, find the optimal location x of the buffer. (10 points)

(3) Answer the following questions. Correct: +5 points. Wrong: -5 points. Min: 0 points.

- If  $L_1$  increases, then x increases too. (True / False)
- If  $L_2$  increases, then x increases too. (True / False)
- If  $R_A$  increases, then x increases too. (True / False)
- If  $R_D$  increases, then x increases too. (True / False)
- If  $C_B$  increases, then x increases too. (True / False)
- If C<sub>D</sub> increases, then x increases too. (True / False)

(4) Answer the following questions. Correct: +10 points. Wrong: -10 points. Min: 0 points.

Notice that the optimal location x of the buffer found above (in Problem 2-2) is independent of  $L_3$  and  $C_c$  (i.e., x does not have  $L_3$  and  $C_c$ ). In fact, however, the optimal location x is also dependent on  $L_3$  and  $C_c$ . Answer the following questions NOT based on x you found above, BUT based on your intuition and knowledge considering the real-world factors.

- If  $L_3$  increases, then x increases too. (True / False)
- If *C<sub>C</sub>* increases, then *x* increases too. (True / False)

(5) Answer the following questions. Correct: +5 points. Wrong: -5 points. Min: 0 points.

Assume  $R_D < R_A$ . Assume  $C_D$  is negligible.

- If *r*<sub>1</sub> increases, then *x* increases too. (True / False)
- If r<sub>2</sub> increases, then x increases too. (True / False)
- If *c*<sub>1</sub> increases, then *x* increases too. (True / False)
- If *c*<sub>2</sub> increases, then *x* increases too. (True / False)

# Problem #3 (Interconnect Optimization, 100 points)

The following figure shows a net optimized by three buffers.



Notice that (R, C) is the (output resistance, input capacitance) of the corresponding cell. x, y, z are the optimal locations of Buffer 1, 2, 3, respectively ( $0 < x < L_1, 0 < y < L_2, 0 < z < L_3$ ). We ignore the internal delays of the buffers. We want to minimize both the delay from the source to Sink 1 and the delay from the source to Sink 2 in this problem.

Do not use the mathematical models we studied in the class. Instead, use your intuition to answer the following questions.

(1) Answer the following questions. Correct: +5 points. Wrong: -5 points. Min: 0 points.

- If  $L_1$  increases, then x increases too. (True / False)
- If  $L_1$  increases, then y increases too. (True / False)
- If L<sub>2</sub> increases, then x increases too. (True / False)
- If L<sub>2</sub> increases, then y increases too. (True / False)
- If  $L_2$  increases, then z increases too. (True / False)

(2) Answer the following questions. Correct: +5 points. Wrong: -5 points. Min: 0 points.

- If  $R_A$  increases, then x increases too. (True / False)
- If  $R_A$  increases, then y increases too. (True / False)
- If R<sub>D</sub> increases, then x increases too. (True / False)
- If R<sub>D</sub> increases, then y increases too. (True / False)

- If  $R_E$  increases, then x increases too. (True / False)
- If  $R_E$  increases, then y increases too. (True / False)
- If  $R_E$  increases, then z increases too. (True / False)

(3) Answer the following questions. Correct: +5 points. Wrong: -5 points. Min: 0 points.

- If  $C_D$  increases, then x increases too. (True / False)
- If *C*<sub>D</sub> increases, then *y* increases too. (True / False)
- If  $C_E$  increases, then x increases too. (True / False)
- If  $C_E$  increases, then y increases too. (True / False)
- If  $C_E$  increases, then z increases too. (True / False)
- If  $C_B$  increases, then x increases too. (True / False)
- If  $C_B$  increases, then y increases too. (True / False)
- If  $C_B$  increases, then z increases too. (True / False)

### Problem #4 (Coupling, 90 points)



This figure shows a bus composed of five nets. The following shows the data we are going to transfer through the bus:

 $0(initial) \rightarrow 5 \rightarrow 11 \rightarrow 4$ 

We compute the power consumption for a signal transition as follows:

$$P = C_{t,eff} V_{DD}^2$$

where  $V_{DD} = 1V$  and  $C_{t,eff}$  is the sum of the effective capacitances.

(1) Compute the power consumption of the data transfer using the conventional 5-bit binary codes for the data. (20 points)

(2) Compute the power consumption of the data transfer using the 5-bit forbidden pattern free crosstalk avoidance code. Ignore the power consumption of the encoder/decoder. (20 points)

(3) Let's estimate the efficiency of the forbidden pattern free crosstalk avoidance code (FPF-CAC). (50 points)

- The Fibonacci sequence is defined as follows:
  - $\begin{array}{l} \circ & f_1 = 1 \\ \circ & f_2 = 1 \end{array}$
  - $\circ \quad f_{k+2} = f_{k+1} + f_k$
- Complete the following. (10 points)
  - $\circ f_3 =$
  - $\circ f_4 =$
  - $\circ f_5 =$
  - $\circ \quad f_6 =$
  - $\circ f_7 =$
  - $\circ f_8 =$
  - $\circ f_9 =$
  - $\circ f_{10} =$
  - $\circ f_{11} =$
  - $\circ f_{12} =$
  - $\circ f_{13} =$
  - $\circ f_{14} =$
- In page 33 of the interconnect lecture note, the # bits we need to represent a number in FPF-CAC is determined by the "MSB stage". For a given data (number) v, we should find the max.  $f_{m+1}$  satisfying  $v \ge f_{m+1}$ . For example, if v = 19,  $f_1 \le \cdots \le f_7 \le 19 < f_8$ , so the max.  $f_{m+1}$  satisfying the above condition is  $f_7$ . Thus, m + 1 = 7, so m = 6, so we need 6 bits to represent 19 in FPF-CAC.
- The max. data (number) that an *m*-bit FPF-CAC code can represent is as follows (Complete the following from m = 7 to 12) (20 points):
  - *m* = 1: 1
  - o *m* = 2: 2
  - $\circ m = 3:4$
  - $\circ m = 4:7$
  - *m* = 5: 12
  - o *m* = 6: 20
  - $\circ m = 7$ :
  - $\circ$  m = 8:
  - $\circ m = 9$ :
  - $\circ m = 10:$
  - $\circ$  m = 11:
  - $\circ$  m = 12:
- Similarly, the max. data (number) that an *m*-bit conventional binary code (e.g.,  $20 = 10100_2$ ) can represent is as follows (Complete the following from m = 7 to 12) (10 points):
  - $\circ m = 1:1$
  - $\circ m = 2:3$

- o *m* = 3: 7
- o *m* = 4: 15
- *m* = 5: 31
- *m* = 6: 63
- $\circ$  m = 7:
- $\circ m = 8:$
- $\circ$  m = 9:
- $\circ m = 10:$
- $\circ$  m = 11:
- m = 12:
- Thus, the efficiency is estimated as follows (Complete the following from m = 7 to 12) (10 points):
  - *m* = 1: 1/1 = 1.0
  - $\circ$  m = 2: 2/3 = 0.67
  - $\circ$  m = 3: 4/7 = 0.57
  - $\circ$  m = 4: 7/15 = 0.47
  - *m* = 5: 12/31 = 0.39
  - $\circ$  m = 6: 20/63 = 0.32
  - $\circ$  m = 7:
  - $\circ$  m = 8:
  - $\circ$  m = 9:
  - $\circ m = 10:$
  - $\circ m = 11:$
  - m = 12: