

## 1.1 Solution

| Row | SOUT | CIN | $S = CIN \oplus SOUT$ | $COUT = CIN \cdot SOUT$ |
|-----|------|-----|-----------------------|-------------------------|
| 0   | 0    | 0   | 0                     | 0                       |
| 1   | 0    | 1   | 1                     | 0                       |
| 2   | 1    | 0   | 1                     | 0                       |
| 3   | 1    | 1   | 0                     | 1                       |

## 1.2 Solution

| Cycle | RST | CIN | SOUT<br>(at<br>start of<br>cycle) | $S = CIN \oplus SOUT$ | $COUT = CIN \cdot SOUT$ | $D = NAND(S, RS T)$ | Notes /<br>Truth-table row<br>hit                    |
|-------|-----|-----|-----------------------------------|-----------------------|-------------------------|---------------------|------------------------------------------------------|
| 0     | 0   | 0   | X<br>(unkno<br>wn)                | -                     | -                       | 1                   | Init: force next<br>SOUT=0                           |
| 1     | 1   | 0   | 0                                 | 0                     | 0                       | 1                   | <b>Row 0:</b><br>(SOUT=0,<br>CIN=0)                  |
| 2     | 1   | 1   | 0                                 | 1                     | 0                       | 0                   | <b>Row 1:</b><br>(SOUT=0,<br>CIN=1) → next<br>SOUT=1 |
| 3     | 1   | 0   | 1                                 | 1                     | 0                       | 0                   | <b>Row 2:</b><br>(SOUT=1,<br>CIN=0) → next<br>SOUT=1 |
| 4     | 1   | 1   | 1                                 | 0                     | 1                       | 1                   | <b>Row 3:</b><br>(SOUT=1,<br>CIN=1) → next<br>SOUT=0 |

### 1.3 Solution

Per instructions, **annotate the first cycle** that exercises each truth-table row:

- Row 0 → **Cycle 1**
- Row 1 → **Cycle 2**
- Row 2 → **Cycle 3**
- Row 3 → **Cycle 4**

### 2.1 Solution



## 2.2 Solution



NOT GATE



NOT GATE



XOR gate



NAND gate



NOR GATE



Latches



LAST inverter

### 3.1 Solution



Measured 50% crossing of PHI at 1.015 ns (first rising edge) and 2.015 ns (second rising edge), matching theoretical values for  $t_{clk} = 1$  ns,  $t_r = 30$  ps

### 3.2 Solution



### 3.3 Solution



The annotated waveform shows correct operation of the half-adder accumulator bitslice. Each cycle matches the expected truth-table outputs for SOUT and COUT given the applied CIN and RST inputs. Inputs were delayed 100 ps after PHI's rising edge, and PHI has a 1 ns period.

Step 4.1 solution





## 4.2 solution



## Step 4.3



## 4.4 solution



## 4.5 solution

Lab 2 step 1-6  
Due: Thu Oct 23, 2025 11:59pm

Submitted on Oct 24, 2025 11:31pm  
NEXT UP: Review Feedback

How To Guides ▾

Late 75 Points Possib

Attempt 2 Score: N/A Add Comm

Unlimited Attempts Allowed  
Available until Dec 10, 2025 11:59pm

ts h

▼ Details  
No additional details were added for this assignment.

| File Name                             | Size      |
|---------------------------------------|-----------|
| <a href="#">XOR_schematic-1.spice</a> | 4.32 KB   |
| <a href="#">step3_jayakishan.vec</a>  | 163 Bytes |
| <a href="#">step3_jayakishan-1.sp</a> | 1.44 KB   |

New At

## 5.1 solution

The purpose of this step was to measure the post-layout average power of the extracted XOR\_X1 cell at different clock frequencies and analyze how the power scales with frequency. The extracted netlist used was named XOR\_X1-post-layout.sp, whose subcircuit declaration is

“.SUBCKT XOR\_X1 CIN COUT GND PHI RST SOUT VDD.”

The transistor models from the gpdk045 process library were included using  
.include '/opt/cadence/gpdk045/gpdk045\_v\_6\_0/models/hspice/g45n1svt.inc'"  
and

“.include '/opt/cadence/gpdk045/gpdk045\_v\_6\_0/models/hspice/g45p1svt.inc'.”

All simulations were performed at a supply voltage of 1.1 V and a temperature of 25 °C. The rise and fall times of the input signals were set to 30 ps, with a 100 ps offset between the clock (PHI) and the input transitions. Four transient simulations were carried out for clock frequencies of 500 MHz, 667 MHz, 1 GHz, and 2 GHz.

The measured average powers were  $1.064 \times 10^{-5}$  W at 500 MHz,  $1.419 \times 10^{-5}$  W at 667 MHz,  $2.112 \times 10^{-5}$  W at 1 GHz, and  $4.187 \times 10^{-5}$  W at 2 GHz. The results show a nearly linear increase in power with frequency, indicating that dynamic switching power dominates total consumption in this CMOS design.

## 5.2 solution

The total power of the circuit can be modeled as a linear function of frequency:

$$P(f) = P_{\text{static}} + k f$$

where  $P_{\text{static}}$  represents the leakage (static) power and  $k$  is the dynamic power coefficient. Using the 500 MHz and 2 GHz results,

$$k = (P_2 - P_1) / (f_2 - f_1) = (4.187 \times 10^{-5} - 1.064 \times 10^{-5}) / (2.0 \times 10^9 - 5.0 \times 10^8) = 2.08 \times 10^{-14} \text{ W/Hz.}$$

The static power was then obtained as

$$P_{\text{static}} = P_1 - k f_1 = 1.064 \times 10^{-5} - (2.08 \times 10^{-14})(5.0 \times 10^8) = 2.3 \times 10^{-7} \text{ W.}$$

Thus, the fitted power-frequency equation becomes

$$P(f) = 2.3 \times 10^{-7} + (2.08 \times 10^{-14}) f.$$

The slope  $k$  represents the dynamic switching component of power, while the intercept corresponds to static leakage power of about  $0.23 \mu\text{W}$ . The model fits the measured data almost perfectly, confirming the expected linear relationship between power and frequency in CMOS logic.

## 5.3 solution

The frequency at which static power equals ten percent of the total power can be found from the relationship

$$P_{\text{static}} = 0.1 (P_{\text{static}} + k f),$$

which simplifies to  $f = 9 P_{\text{static}} / k$ . Substituting the calculated values gives

$$f = 9 (2.3 \times 10^{-7}) / (2.08 \times 10^{-14}) = 9.9 \times 10^7 \text{ Hz} \approx 100 \text{ MHz.}$$

At approximately 100 MHz, static leakage power contributes about ten percent of the total power. Beyond this frequency, dynamic switching power overwhelmingly

dominates, which is consistent with the expected behavior of a 45 nm CMOS circuit operating at nominal voltage.

In summary, the post-layout power analysis of the XOR\_X1 cell demonstrates a clear linear scaling of average power with clock frequency. The static power is about  $2.3 \times 10^{-7}$  W, the dynamic coefficient k is  $2.08 \times 10^{-14}$  W/Hz, and the crossover frequency where static power contributes ten percent of total power is around 100 MHz. At higher frequencies, total power is almost entirely dynamic, confirming typical CMOS operation.

## 6.1 solution

To check for hold-time failures, I varied the timing of the RST signal relative to the rising edge of the clock (PHI). Using the extracted netlist, RST was defined as a PWL source so its rising edge could be shifted earlier or later. When RST rose too soon, the stored output (SOUT) changed one cycle early, indicating a hold-time violation. I measured the timing offset between RST and PHI (50 % point) using an HSPICE `.meas` command

## 6.2 solution



When RST rose 20 ps before PHI ( $\Delta t = -20$  ps), SOUT went high one cycle too early, showing a clear hold-time failure. The waveform confirms this: the RST (purple) edge precedes PHI (green), and SOUT (cyan) switches prematurely. The measured offset of  $-20$  ps marks the violation.

### Solution 6.3



Delaying RST by +10 ps relative to PHI removes the failure. RST now rises slightly after PHI, and SOUT stays stable until the next valid cycle. The waveform shows normal behavior: no premature switching and correct data storage.

