

# Homework 4.

1. Draw logic circuit diagram  
that circuit specified by No. 1.  
Verilog description.

Module Circuit A (A, B, C, D, E)

Input A, B, C, D

Output E

Wire w, X, Y, Z, a, b;

1 OR X, B, C, D;

5 AND Y, a, b;

3 AND (w, z, b);

4 NOT z, Y, D;

2 NOT f, v, u;

not(a, b);

not(c, d);

combinative

! Here first is output letter in all of terms



b) module circuit B (y<sub>1</sub>, y<sub>2</sub>, y<sub>3</sub>, a, b)

Output y<sub>1</sub>, y<sub>2</sub>, y<sub>3</sub>;

Input a, b;

assign y<sub>1</sub> = a || b;

and (y<sub>2</sub>, a, b);

assign y<sub>3</sub> = a & b;

end module

Here we assign right hand side expression to y<sub>3</sub>.

It's data flow.



2. a) Write a Verilog description of the circuit shown below.



```
module something(F, A, B', A', B, C, D');
    input A, A', B, B', C, D';
    output F;
    wire X, Y, Z, W;
    and U1(X, A, B');
    and U2(Y, A', B);
    or U3(W, C, D');
    or U4(Z, X, Y);
    and U5(F, Z, W);
endmodule
```

b) write a Verilog description of the circuit specified by the following Boolean function:  $Z = (A + B') C' (C + D)$

```
module h(Z, A, B', C', C, D);
    input A, B', C', C, D;
    output Z;
    assign Z = (A | B') & C' & (C | D);
endmodule
```

Do Now

3: The adder-subtractor has the following

c)  $M=0$     A  $1100 = 12$   
 B  $1000 = 8$   
 $\underline{1000} = 20$

d)  $M=1$     A  $0111 = 7$   
 B  $0110 = 6$   
 $\underline{101} = 13$

c)  $M=1$     A  $0000$   
 B  $0001$   
 $\underline{1110}$

d)  $M=0$     0101  
 1010  
 $\underline{1111} \quad \boxed{0001} = -1$



|    | $S_4$ | $S_3$ | $S_2$ | $S_1$ | $S_0$ |
|----|-------|-------|-------|-------|-------|
| a) | 1     | 0     | 1     | 0     | 0     |
| b) | 0     | 0     | 0     | 0     | 1     |
| c) | 1     | 1     | 1     | 1     | 1     |
| d) | 1     | 1     | 1     | 1     | 1     |

4) Propogation delay: XOR = 15 ns

- AND and OR = 10 ns.
- What is propagation delay time of following 1-bit full adder,
  - 4-bit ripple carry adder build using 1-bit full adder;
  - 4 bit carry lookahead adder



Total Propagation Delay for Sum output =  $(n-i)t_c + t_s$   
 Total Propagation Delay for Carry Output =  $n t_c$ .



$$t_s = 4 \cdot 30 = 120 \text{ ns}$$

$$t_c = 3 \cdot 35 + 35 = 140 \text{ ns}$$

$$S_2 = (t_{\text{xor}} + 2t_p) + t_{\text{xor}}, \quad C_2 = (t_{\text{xor}} + 2t_p) + 2t_p$$

$$\text{Stable Carry output } C_4 = t_{\text{xor}} + 2 \cdot 4 \cdot t_p = 15 + 80 = 95$$

$$\text{Stable Sum output } S_4 = 2t_{\text{xor}} + 2(n-i) \cdot t_p = 30 + 60 = 90$$

c) Propagation Delay of Look Ahead Adder is faster than Ripple Adder because it is only 2 level gates.



Based on RGA logic circuit we gettings S out Cout and multiplying by 2.

$$t_s = 2 \cdot S = 2 \cdot 30 = 60 \text{ ns}$$

$$t_c = 2 \cdot \text{Cout} = 2 \cdot 35 = 70 \text{ ns}$$

$$5) F = \bar{A}' \cdot \bar{A} \cdot \bar{D} - (\bar{A} + BC)$$

$$F = \bar{A}' \cdot (\bar{A} + D') \cdot (\bar{A} + BC)$$

$$F = \bar{A} \cdot \bar{A} + \bar{A} \cdot \bar{D} \cdot (\bar{A} + BC)$$

$$F = \bar{A} \bar{A} \bar{D} + \bar{A} \bar{D} BC$$

$$F = \bar{A} \bar{D} + \bar{A} B C \bar{D}$$

$$F = \bar{A} \bar{D} (1 + BC)$$

$$F = \bar{A} \bar{D}$$

| AB | 00 | 01 | 11 | 10 |
|----|----|----|----|----|
| 00 | 1  |    |    |    |
| 01 | 1  |    |    |    |
| 11 |    |    | 1  |    |
| 10 |    |    |    | 1  |

$\bar{A} \bar{D}$

$$G = (\bar{A} + BC)(\bar{A} \bar{D})$$

$$G = \bar{A} \bar{A} \bar{D} + \bar{A} \bar{D} BC$$

$$G = \bar{A}(A + \bar{D}) + (A + \bar{D})BC$$

$$G = 0 + \bar{A} \bar{D} + ABC + BC \bar{D}$$

$$G = \bar{A} \bar{D} + ABC$$

|   |   |   |
|---|---|---|
| 1 | 1 | 1 |
| 1 | 1 | 1 |
| 1 | 1 | 1 |
| 1 | 1 | 1 |

6)



7)

| A | B | XOR | XNOR |
|---|---|-----|------|
| 0 | 0 | 0   | 1    |
| 0 | 1 | 1   | 0    |
| 1 | 0 | 1   | 0    |
| 1 | 1 | 0   | 1    |



$$E = (a_3 \oplus b_3)' (a_2 \oplus b_2)' (a_1 \oplus b_1)' + (a_0 \oplus b_0)',$$

8) half subtractor

| X | Y | D | B |
|---|---|---|---|
| 0 | 0 | 0 | 0 |
| 0 | 1 | 1 | 1 |
| 1 | 0 | 1 | 0 |
| 1 | 1 | 0 | 0 |

$$\begin{aligned} D &= X'Y + XY' \\ &= X \oplus Y \end{aligned}$$



$$B = X'Y$$

|   |   |
|---|---|
| 0 | 1 |
| 0 | 0 |

# b) Full Subtractor

|   | <del>B<sub>in</sub></del> | <del>D</del> | <del>B<sub>out</sub></del> | <del>x</del> | <del>y</del> | <del>Bin</del> |
|---|---------------------------|--------------|----------------------------|--------------|--------------|----------------|
| 0 | 0                         | 0            | 0                          | 0            | 0            | 00             |
| 0 | 0                         | 1            | 1                          | 1            | 0            | 01             |
| 0 | 1                         | 0            | 1                          | 0            | 1            | 10             |
| 0 | 1                         | 1            | 0                          | 1            | 1            | 11             |
| 1 | 0                         | 0            | 1                          | 0            | 0            | 10             |
| 1 | 0                         | 1            | 0                          | 0            | 0            | 11             |
| 1 | 1                         | 0            | 0                          | 0            | 0            | 00             |
| 1 | 1                         | 1            | 1                          | 1            | 1            | 01             |

$$D = x'y'B_{in} + x'yB_{in} + x'y'B_{in}' + x'yB_{in}' = x \oplus y \oplus B_{in}$$

|   |   |   |   |   |
|---|---|---|---|---|
| 0 | 1 | 1 | 1 | 1 |
| 0 | 0 | 1 | 1 | 0 |

$$B_{out} = x'B_{in} \rightarrow x'y + yB_{in} = x'y + B_{in}(x \oplus y)$$



| X | Y | Z | A | B | C | <del>D</del> | <del>B<sub>out</sub></del> | <del>C<sub>out</sub></del> |
|---|---|---|---|---|---|--------------|----------------------------|----------------------------|
| 0 | 0 | 0 | 0 | 1 | 0 | 00           | 11                         | 1                          |
| 0 | 0 | 1 | 0 | 1 | 1 | 01           | 11                         | 1                          |
| 0 | 1 | 0 | 1 | 0 | 0 | 11           | 11                         | 1                          |
| 0 | 1 | 1 | 1 | 0 | 1 | 10           | 11                         | 1                          |
| 1 | 0 | 0 | 0 | 0 | 1 | A = x'y +    | B = x'y' +                 | C = xz + x'y'z             |
| 1 | 0 | 1 | 0 | 1 | 0 | +yz          | +y'z + xyz                 | = x ⊕ z                    |
| 1 | 1 | 0 | 0 | 1 | 1 |              |                            |                            |
| 1 | 1 | 1 | 1 | 0 | 0 |              |                            |                            |

$$X = D - A$$

$$Y = D - Z$$

$$Z = D - C$$

$$X = D - C$$

$$X = D - A$$

$$Y = D - Z$$

$$Z = D - C$$

$$X = D - A$$

$$Y = D - Z$$

$$Z = D - C$$

Input

Output

| A | B | C | D | w x y z |
|---|---|---|---|---------|
| 0 | 0 | 0 | 0 | 0 0 0 0 |
| 0 | 0 | 0 | 1 | 1 1 1 1 |
| 0 | 0 | 1 | 0 | 1 1 1 0 |
| 0 | 0 | 1 | 1 | 1 1 0 1 |
| 0 | 1 | 0 | 0 | 1 1 0 0 |
| 0 | 1 | 0 | 1 | 1 0 1 1 |
| 0 | 1 | 1 | 0 | 1 0 1 0 |
| 0 | 1 | 1 | 1 | 1 0 0 1 |
| 1 | 0 | 0 | 0 | 1 0 0 0 |
| 1 | 0 | 0 | 1 | 0 1 1 1 |
| 1 | 0 | 1 | 0 | 0 1 1 0 |
| 1 | 0 | 1 | 1 | 0 1 0 1 |
| 1 | 1 | 0 | 0 | 0 1 0 0 |
| 1 | 1 | 0 | 1 | 0 0 1 1 |
| 1 | 1 | 1 | 0 | 0 0 1 0 |
| 1 | 1 | 1 | 1 | 0 0 0 1 |



w

$$w = \bar{A}D + \bar{A}'C + A'B + AB'C'D$$



x

$$x = \bar{B}D + \bar{B}C + B\bar{C}D$$



y

$$y = \bar{C}D + C\bar{D} = C \oplus D$$

Input +1

Z = D

A [3:0]

A [3:0]

