

## Carry Look Ahead Adder: (16m) ① Q.B

In parallel adder the carry output of each full adder stage is connected to the carry input of the next higher order stage. Therefore the sum and the carry outputs of any stage cannot be produced until the ~~carry~~ input carry occurs. This leads to a time delay in the addition process. This delay is called carry propagation delay.

(eg):

$$\begin{array}{r} \text{① ① ①} \\ 0 1 0 1 \\ 0 0 1 1 \\ \hline 1 0 0 0 \end{array}$$

Addition LSB (Least significant Bit) produces carry into second and then second to third and so on. From this the sum bit generated in the last position (MSB) most significant bit. Depends on the carry that was generated by the addition of the previous position.

This means adder will not produce correct result until LSB has carry propagated through intermediate full adders. One method of speeding up this process by eliminating interstage carry delay is called Look ahead carry addition.

(eg): Implement full adder using 2 half adder:



$$P_i = A_i \oplus B_i$$

$$G_i = A_i B_i$$

If  $i=1$ ,  $C_2 = G_1 + P_1 C_1$

$$i=2, C_3 = G_2 + P_2 C_2 \\ = G_2 + P_2 (G_1 + P_1 C_1)$$

$$C_3 = G_2 + P_2 G_1 + P_1 P_2 C_1$$

$$i=3, C_4 = G_3 + P_3 C_3 \\ = G_3 + P_3 (G_2 + P_2 G_1 + P_1 P_2 C_1)$$

$$C_4 = G_3 + P_3 G_2 + P_3 P_2 G_1 + P_3 P_2 P_1 C_1$$



Using a carry look ahead generator we can easily construct 4-bit parallel adder with a look ahead carry scheme. In this each sum output requires two EX-OR gate. The output of first EX-OR gate generates  $P_i$  and the AND gate generates  $G_i$ . The carry that of generator using look ahead carry generator and applied as inputs to the second EX-OR gate and the input to the EX-OR gate is  $P_i$ . Thus second EX-OR gate generates the sum output and each output generated after a delay of two levels of gate.



ENCODER: 2Q.B 8m

An encoder is a digital circuit that performs the inverse operation of a decoder, that is input will be more number when compare to that of output. It is in the order of  $2^n : n$

i) 8:3 Encoder (Or) Octal to Binary encoder:

Block diagram



| D <sub>0</sub> | D <sub>1</sub> | D <sub>2</sub> | D <sub>3</sub> | D <sub>4</sub> | D <sub>5</sub> | D <sub>6</sub> | D <sub>7</sub> | A | B | C |
|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|---|---|---|
| 1              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 0 | 0 | 0 |
| 0              | 1              | 0              | 0              | 0              | 0              | 0              | 0              | 0 | 0 | 1 |
| 0              | 0              | 1              | 0              | 0              | 0              | 0              | 0              | 0 | 1 | 0 |
| 0              | 0              | 0              | 1              | 0              | 0              | 0              | 0              | 1 | 0 | 1 |
| 0              | 0              | 0              | 0              | 1              | 0              | 0              | 0              | 0 | 1 | 0 |
| 0              | 0              | 0              | 0              | 0              | 0              | 1              | 0              | 0 | 1 | 0 |
| 0              | 0              | 0              | 0              | 0              | 0              | 0              | 1              | 0 | 0 | 1 |
| 0              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 1 | 1 | 1 |

equation :

$$A = D_4 + D_5 + D_6 + D_7$$

$$B = D_2 + D_3 + D_6 + D_7$$

$$C = D_1 + D_3 + D_5 + D_7$$

Logic circuit



08/08/2024

Decoder:

(8m)

2. Q.B.C

A decoder is a multiple input and multiple output logic circuit which converts coded inputs into decoded outputs where input and output codes are different. Input code generally has fewer codes than output codes.

## 3:8 Decoder

Block diagram



Truth table

| A | B | C | $Y_0$ | $Y_1$ | $Y_2$ | $Y_3$ | $Y_4$ | $Y_5$ | $Y_6$ | $Y_7$ |
|---|---|---|-------|-------|-------|-------|-------|-------|-------|-------|
| 0 | 0 | 0 | 1     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| 0 | 0 | 1 | 0     | 1     | 0     | 0     | 0     | 0     | 0     | 0     |
| 0 | 1 | 0 | 0     | 0     | 1     | 0     | 0     | 0     | 0     | 0     |
| 0 | 1 | 1 | 0     | 0     | 0     | 1     | 0     | 0     | 0     | 0     |
| 1 | 0 | 0 | 0     | 0     | 0     | 0     | 1     | 0     | 0     | 0     |
| 1 | 0 | 1 | 0     | 0     | 0     | 0     | 0     | 1     | 0     | 0     |
| 1 | 1 | 0 | 0     | 0     | 0     | 0     | 0     | 0     | 1     | 0     |
| 1 | 1 | 1 | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 1     |

Equation

$$Y_0 = \bar{A}\bar{B}\bar{C}$$

$$Y_1 = \bar{A}\bar{B}C$$

$$Y_2 = \bar{A}BC$$

$$Y_3 = \bar{A}B\bar{C}$$

$$Y_4 = A\bar{B}\bar{C}$$

$$Y_5 = A\bar{B}C$$

$$Y_6 = AB\bar{C}$$

$$Y_7 = ABC$$

Explanation logic circuit



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

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

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

thus circuit

b) full adder: 10m  
Block diagram



Truth Table

| A | B | C | S | C <sub>e</sub> |
|---|---|---|---|----------------|
| 0 | 0 | 0 | 0 | 0              |
| 0 | 0 | 1 | 1 | 0              |
| 0 | 1 | 0 | 1 | 0              |
| 0 | 1 | 1 | 0 | 1              |
| 1 | 0 | 0 | 1 | 0              |
| 1 | 0 | 1 | 0 | 1              |
| 1 | 1 | 0 | 0 | 1              |
| 1 | 1 | 1 | 1 | 1              |

equation:

K-map

|     |       | BC | 00   | 01   | 11   | 10   |
|-----|-------|----|------|------|------|------|
|     |       | A  | 0    | 1    | 0    | 1    |
| Sum | Carry | 0  | 0, 0 | 1, 0 | 0, 1 | 1, 1 |
|     |       | 1  | 1, 1 | 0, 1 | 1, 0 | 0, 0 |

$$\text{Sum} = \bar{A}\bar{B}C + \bar{A}B\bar{C} + A\bar{B}C + ABC //$$

carry

|     |       | BC | 00   | 01   | 10   | 10   |
|-----|-------|----|------|------|------|------|
|     |       | A  | 0    | 1    | 0    | 1    |
| Sum | Carry | 0  | 0, 0 | 0, 1 | 1, 0 | 0, 1 |
|     |       | 1  | 0, 1 | 1, 1 | 1, 1 | 1, 0 |

$$\text{carry} = \bar{A}BC + ABC + ABC + \bar{ABC} + ABC + ABC$$

$$= BC + AC + AB //$$

logic circuit:

sum



$$\bar{A}f_1 + B\bar{A} = f_1f_2$$

$$B\bar{A} = \text{sum}$$



sum

carry:

worror



carry

worror



full adder circuit using 2  $\pi$ -T half adder.



Truth Table

## 2) Subtractors

a) Half subtractor: (3)

Block diagram:



Truth Table

| A | B | D | B |
|---|---|---|---|
| 0 | 0 | 0 | 0 |
| 0 | 1 | 1 | 0 |
| 1 | 0 | 1 | 0 |
| 1 | 1 | 0 | 0 |

Equation:

$$\begin{aligned} \text{Diff} &= \bar{A}B + A\bar{B} \\ &= A \oplus B \end{aligned}$$

$$\text{Borrow} = \bar{A}B$$

Logic circuit



full subtractor circuit using 2 half subtractor:



12/08/2024

MAGNITUDE COMPARATOR:

④ Q.B

16m

It is a combinational circuit designed to compare the relative magnitude of two binary numbers ( $A$  &  $B$ ) and generates one of the following outputs:

- i)  $A = B$
- ii)  $A \geq B$
- iii)  $A < B$

Types: i) Two bit magnitude comparator

four bit magnitude comparator

Magnitude

i) 2 bit comparator:

Block diagram

Truth Table4<sup>2</sup> method

| $A_1, A_0$ | $B_1, B_0$ | $A < B$ | $A = B$ | $A > B$ |
|------------|------------|---------|---------|---------|
| 0 0        | 0 0        | 0       | 1       | 0       |
| 0 0        | 0 1        | 1       | 0       | 0       |
| 0 0        | 1 0        | 1       | 0       | 0       |
| 0 0        | 1 1        | 1       | 0       | 0       |
| 0 1        | 0 0        | 0       | 0       | 1       |
| 1 0        | 1 0        | 0       | 1       | 0       |
| 0 1        | 1 0        | 1       | 0       | 0       |
| 0 1        | 1 1        | 1       | 0       | 0       |

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

k-map  $A < B$

| $A_1 A_0$ | $B_1 B_0$ | 00 | 01 | 11 | 10 |
|-----------|-----------|----|----|----|----|
| 00        | 0         | 1  | 1  | 1  |    |
| 01        | 0         | 0  | 1  | 1  |    |
| 11        | 0         | 0  | 0  | 0  |    |
| 10        | 0         | 0  | 1  |    | 0  |

$$A < B = \bar{A}_1 B_1 + \bar{A}_1 \bar{A}_0 B_0 + \bar{A}_0 B_1 B_0$$

| $A_1 A_0$ | $B_1 B_0$ | 00 | 01 | 11 | 10 |
|-----------|-----------|----|----|----|----|
| 00        | 1         | 0  | 0  | 0  |    |
| 01        | 0         | 1  | 0  | 0  |    |
| 11        | 0         | 0  | 1  | 0  |    |
| 10        | 0         | 0  | 0  | 1  | 1  |

$$A = B = \bar{A}_1 \bar{A}_0 \bar{B}_1 \bar{B}_0 + \bar{A}_1 A_0 \bar{B}_1 \\ B_0 + A_1 A_0 B_1 B_0 + A_1 \bar{A}_0 B_1 \bar{B}_0$$

$A > B$

| $A_1 A_0$ | $B_1 B_0$ | 00 | 01 | 11 | 10 |
|-----------|-----------|----|----|----|----|
| 00        | 0         | 0  | 0  | 0  |    |
| 01        | 1         | 0  | 0  | 0  |    |
| 11        | 1         | 1  | 0  | 1  |    |
| 10        | 1         | 1  | 0  | 0  |    |

$$A > B = A_0 \bar{B}_1 \bar{B}_0 + A_1 \bar{B}_1 + \\ A_1 A_0 \bar{B}_0$$

# LOGIC CIRCUIT:



b) full subtractor: 16m (5) Q.B.



## Truth Table

| A | B | C | D | B |
|---|---|---|---|---|
| 0 | 0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 1 | 1 |
| 0 | 1 | 0 | 1 | 1 |
| 0 | 1 | 1 | 0 | 1 |
| 1 | 0 | 0 | 1 | 0 |
| 1 | 0 | 1 | 0 | 0 |
| 1 | 1 | 0 | 0 | 0 |
| 1 | 1 | 1 | 1 | 1 |

## Equation

K-map for Diff

| A\BC |   | 00          | 01 | 11          | 10          |
|------|---|-------------|----|-------------|-------------|
|      |   | 0           | 0  | 1           | 0           |
| 1    | 1 | $\square_1$ | 0  | $\square_3$ | $\square_2$ |
|      | 0 | $\square_4$ | 1  | $\square_5$ | $\square_6$ |

$$\text{Diff} = \bar{A}\bar{B}C + \bar{A}B\bar{C} + A\bar{B}\bar{C} + AB\bar{C}$$

K-map for Borrow

| A\BC |   | 00          | 01 | 11          | 10          |
|------|---|-------------|----|-------------|-------------|
|      |   | 0           | 0  | 1           | 1           |
| 1    | 1 | $\square_1$ | 0  | $\square_3$ | $\square_2$ |
|      | 0 | $\square_4$ | 1  | $\square_5$ | $\square_6$ |

Borrow

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

$$+ \bar{A}B\bar{C} + \bar{A}B\bar{C} + ABC$$

$$= \bar{A}C + \bar{A}B + BC$$



(Borrow):



full subtractor, using 2 half subtractor:



| Y | Z |
|---|---|
| 0 | 0 |
| 1 | 1 |

$$I_2 + \bar{I}_2 = Y$$

: twos comp



⇒ Multiplexer is a combinational circuit with many inputs and single output. It is also called as Data Selector. The output also depends on number of selection lines (SL).

⑥

Q.B

2) 4 : 1 MUX

Truth Table

| $S_0$ | $S_1$ | $Y$   |
|-------|-------|-------|
| 0     | 0     | $I_0$ |
| 0     | 1     | $I_1$ |
| 1     | 0     | $I_2$ |
| 1     | 1     | $I_3$ |

Equation:

$$y = \bar{s}_0 \bar{s}_1 I_0 + \bar{s}_0 s_1 I_1 + \\ s_0 \bar{s}_1 I_2 + s_0 s_1 I_3$$

Logic circuit:



## De-Multiplexer :

It has one input and Transmits the same over several outputs. The inputs and the outputs depends on the number of selection lines. 1:8 ⑥ Q.B 8m.

| D <sub>7</sub> | S <sub>0</sub> | S <sub>1</sub> | S <sub>2</sub> |
|----------------|----------------|----------------|----------------|
| 1              | 1              | 1              | 1              |

## Block diagram



| S <sub>0</sub> | S <sub>1</sub> | S <sub>2</sub> | Y <sub>0</sub> | Y <sub>1</sub> | Y <sub>2</sub> | Y <sub>3</sub> | Y <sub>4</sub> | Y <sub>5</sub> | Y <sub>6</sub> | Y <sub>7</sub> |
|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|
| 0              | 0              | 0              | I              | 0              | 0              | 0              | 0              | 0              | 0              | 0              |
| 0              | 0              | 1              | 0              | I              | 0              | 0              | 0              | 0              | 0              | 0              |
| 0              | 1              | 0              | 0              | 0              | I              | 0              | 0              | 0              | 0              | 0              |
| 0              | 1              | 1              | 0              | 0              | 0              | I              | 0              | 0              | 0              | 0              |
| 1              | 0              | 0              | 0              | 0              | 0              | 0              | I              | 0              | 0              | 0              |
| 1              | 0              | 1              | 0              | 0              | 0              | 0              | 0              | I              | 0              | 0              |
| 1              | 1              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | I              | 0              |
| 1              | 1              | 1              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | I              |

$$\text{Equation: } Y_0 = \bar{S}_0 \bar{S}_1 \bar{S}_2 I, \quad Y_1 = \bar{S}_0 \bar{S}_1 S_2 I$$

$$Y_2 = \bar{S}_0 S_1 \bar{S}_2 I, \quad Y_3 = \bar{S}_0 S_1 S_2 I$$

$$Y_4 = S_0 \bar{S}_1 \bar{S}_2 I, \quad Y_5 = S_0 \bar{S}_1 S_2 I$$

$$Y_6 = S_0 S_1 \bar{S}_2 I, \quad Y_7 = S_0 S_1 S_2 I$$

(Draw logic circuit).

2) Simplify the function  $f(w, x, y, z) = \sum(1, 4, 6, 7, 8, 9, 10, 11, 15)$  using 8:1 multiplexer. ⑦ Q.B 8m

|           | $D_0$ | $D_1$ | $D_2$ | $D_3$ | $D_4$ | $D_5$ | $D_6$ | $D_7$ |
|-----------|-------|-------|-------|-------|-------|-------|-------|-------|
| $\bar{A}$ | 0     | 1     | 2     | 3     | 4     | 5     | 6     | 7     |
| A         | 8     | 9     | 10    | 11    | 12    | 13    | 14    | 15    |



## BCD adder:

The digital systems handle the decimal number in the form of binary coded decimal numbers (BCD). A BCD adder is a circuit that adds 2 BCD digits and produces a sum in BCD. It uses 10 digits, 0-9 which are represented in Binary form as 0000 - 1001.

BCD Addition Procedure: (Q.B 8m)

- Add 2 BCD numbers using ordinary binary addition.
- If 4 bit sum is equal to or lesser than 9 then no correction is needed.
- If 4 bit sum is greater than 9 or If a carry is generated then the sum is invalid.
- To correct the invalid sum add 0110 to the 4 bit sum and If a carry results from this addition, add it to next higher order BCD digits.

$\Rightarrow$  To implement BCD adder we require :

- 4 bit adder for initial addition.
- Logic circuit to detect the sum greater than 9.
- One more 4 bit adder to add 0110 in the sum If the sum is greater than 9.

Truth Table:

| INPUTS |       |       |       | OUTPUT |     |
|--------|-------|-------|-------|--------|-----|
| $s_3$  | $s_2$ | $s_1$ | $s_0$ | $A$    | $B$ |
| 0      | 0     | 0     | 0     | 0      | 0   |
| 0      | 0     | 0     | 1     | 0      | 0   |
| 0      | 0     | 1     | 0     | 0      | 0   |
| 0      | 0     | 1     | 1     | 0      | 0   |
| 0      | 1     | 0     | 0     | 0      | 0   |
| 0      | 1     | 0     | 1     | 0      | 0   |
| 0      | 1     | 1     | 0     | 0      | 0   |
| 0      | 1     | 1     | 1     | 0      | 0   |
| 1      | 0     | 0     | 0     | 0      | 0   |
| 1      | 0     | 0     | 1     | 0      | 0   |

1. Dotted w/ 0's are given because add 3 to A (i)  
 1 0 1  
 1 0 1 0 at jumps. so max add 7 & 10 (ii)  
 1 1 0 0  
 1 0 1 0 P next step is max add 7 & 10 (iii)  
 1. Since 0 max. we next 10000000 & sum  
 at 00000000 binary we terms of (iv)  
 1. At last jumps to 10 bin. max. add & we  
 switch from 10 bits, no 10000000 max.

when it is equal to 0, binary 010 is added to the binary sum through the bottom 4 bit binary adder.

The output carry generated from the bottom binary adder can be ignored, since it supplies information already available at the output carry terminal.



Block diagram of BCD adder:



from the figure the two BCD numbers together with input carry are first adder in the top four bit binary adder to produce binary sum.

When the output carry is equal to zero nothing is added to binary sum.