



KTU  
**NOTES**  
The learning companion.

**KTU STUDY MATERIALS | SYLLABUS | LIVE  
NOTIFICATIONS | SOLVED QUESTION PAPERS**

## MODULE 3- Binary Adders and Subtractors

### Combinational circuit

Combinational circuit is a circuit in which we combine the different gates in the circuit. Some of the characteristics of combinational circuits are following –

- The output of combinational circuit at any instant of time, depends only on the levels present at input terminals.
- The combinational circuit do not use any memory. The previous state of input does not have any effect on the present state of the circuit.
- A combinational circuit can have an n number of inputs and m number of outputs.
- Examples of Combinational Circuits: Half Adder, Full Adder, Half Subtractor, Full Subtractor



### Half Adder

- Half adder is a combinational logic circuit with two inputs and two outputs.
- The half adder circuit is designed to add two single bit binary numbers.
- It is the basic building block for addition of two single bit numbers.
- This circuit has two outputs carry and sum.
- Block Diagram



## Design of a Half Adder

### Step-01:

Identify the input and output variables-

- Input variables = A, B (either 0 or 1)
- Output variables = S, C where S = Sum and C = Carry
- 

### Step-02:

Draw the truth table-

| Inputs |   | Outputs   |         |
|--------|---|-----------|---------|
| A      | B | C (Carry) | S (Sum) |
| 0      | 0 | 0         | 0       |
| 0      | 1 | 0         | 1       |
| 1      | 0 | 0         | 1       |
| 1      | 1 | 1         | 0       |

Truth Table

### Step-03:

Draw K-maps using the above truth table and determine the simplified Boolean expressions-

For S:



For C:



K Maps

eri

**Step-04:**

Draw the logic diagram.

Implementation of half adder using XOR gate and AND gate is as shown below-



Or



Half Adder Logic Diagram

Implementation of half adder using NAND gates



Implementation of half adder using NOR gates



### Full Adder

- Full adder is developed to overcome the drawback of Half Adder circuit.
- It can add three one-bit numbers.
- The full adder is a three input and two output combinational circuit.
- Block diagram



Full adder is designed in the following steps-

#### Step-01:

Identify the input and output variables-

- Input variables = A, B, C<sub>in</sub> (either 0 or 1)
- Output variables = S, C<sub>out</sub> where S = Sum and C<sub>out</sub> = Carry

#### Step-02:

Draw the truth table-

| Inputs |   |                 | Outputs                  |         |
|--------|---|-----------------|--------------------------|---------|
| A      | B | C <sub>in</sub> | C <sub>out</sub> (Carry) | S (Sum) |
| 0      | 0 | 0               | 0                        | 0       |
| 0      | 0 | 1               | 0                        | 1       |
| 0      | 1 | 0               | 0                        | 1       |
| 0      | 1 | 1               | 1                        | 0       |
| 1      | 0 | 0               | 0                        | 1       |
| 1      | 0 | 1               | 1                        | 0       |
| 1      | 1 | 0               | 1                        | 0       |
| 1      | 1 | 1               | 1                        | 1       |

Truth Table

**Step-03:**

Draw K-maps using the above truth table and determine the simplified Boolean expressions-

**For S:**



$$S = A' B' C_{IN} + A' B C'_{IN} + A B' C'_{IN} + A B C_{IN}$$

$$= C_{IN} (A' B' + A B) + C'_{IN} (A' B + A B')$$

$$= C_{IN} (A \text{ Ex-NOR } B) + C'_{IN} (A \text{ Ex-OR } B)$$

$$= C_{IN} (A \oplus B)' + C_{IN} (A \oplus B)$$

$$= C_{IN} \oplus (A \oplus B)$$

**For  $C_{in}$ :**



**Step-04:**

Draw the logic diagram.

The implementation of full adder using 1 XOR gate, 3 AND gates and 1 OR gate is as shown below-



Implementation of Full Adder using Half Adders is as shown below-

$$C_{OUT} = A B + A C_{IN} + B C_{IN}$$

$$\begin{aligned}
 &= A B + A C_{IN} + B C_{IN} (A + A') \\
 &= A B + A C_{IN} + A B C_{IN} + A' B C_{IN} \\
 &= A B (1 + C_{IN}) + A C_{IN} + A' B C_{IN} \\
 &= A B + A C_{IN} + A' B C_{IN} \\
 &= A B + A C_{IN} (B + B') + A' B C_{IN} \\
 &= A B + A B C_{IN} + A B' C_{IN} + A' B C_{IN} \\
 &= A B (1 + C_{IN}) + C_{IN} (A B' + A' B) \\
 &= A B + C_{IN} (A B' + A' B) \\
 &= A B + C_{IN} (A \text{ Ex-OR } B) \\
 &= A B + C_{IN} (A \oplus B)
 \end{aligned}$$



Implementation of Full Adder using NAND gates



Implementation of Full Adder using NOR gates



### Half Subtractor

- Half Subtractor is a combinational logic circuit.
- It is used for the purpose of subtracting two single bit numbers.
- It contains 2 inputs and 2 outputs (difference and borrow).



### Designing a Half Subtractor

#### Step-01:

Identify the input and output variables-

- Input variables = A, B (either 0 or 1)
- Output variables = D, b where D = Difference and b = borrow

#### Step-02:

Draw the truth table-

| Inputs |   | Outputs        |                    |
|--------|---|----------------|--------------------|
| A      | B | D (Difference) | $B_{out}$ (Borrow) |
| 0      | 0 | 0              | 0                  |
| 0      | 1 | 1              | 1                  |
| 1      | 0 | 1              | 0                  |
| 1      | 1 | 0              | 0                  |

**Truth Table**

#### Step-03:

Draw K-maps using the above truth table and determine the simplified Boolean expressions-

**For D:****For  $B_{out}$ :**

$$D = A \oplus B$$

$$B_{out} = \bar{A} \cdot B$$

**K Maps****Step-04:**

Draw the logic diagram

The implementation of half subtractor using 1 XOR gate, 1 NOT gate and 1 AND gate is as shown below-



implementation of half subtractor using NAND gates



implementation of half subtractor using NOR gates



### **Full Subtractor**

- Full Subtractor is a combinational logic circuit.
- It is used for the purpose of subtracting two single bit numbers. It also takes into consideration borrow of the lower significant stage.
- Thus, full subtractor has the ability to perform the subtraction of three bits.
- Full subtractor contains 3 inputs and 2 outputs (Difference and Borrow) as shown-



### **Designing a Full Subtractor-**

Full subtractor is designed in the following steps-

#### **Step-01:**

Identify the input and output variables-

- Input variables = A, B, B<sub>in</sub> (either 0 or 1)
- Output variables = D, B<sub>out</sub> where D = Difference and B<sub>out</sub> = Borrow

#### **Step-02:**

Draw the truth table-

| Inputs |   |                 | Outputs                   |                |
|--------|---|-----------------|---------------------------|----------------|
| A      | B | B <sub>in</sub> | B <sub>out</sub> (Borrow) | D (Difference) |
| 0      | 0 | 0               | 0                         | 0              |
| 0      | 0 | 1               | 1                         | 1              |
| 0      | 1 | 0               | 1                         | 1              |
| 0      | 1 | 1               | 1                         | 0              |
| 1      | 0 | 0               | 0                         | 1              |
| 1      | 0 | 1               | 0                         | 0              |
| 1      | 1 | 0               | 0                         | 0              |
| 1      | 1 | 1               | 1                         | 1              |

**Truth Table**

**Step-03:**

Draw K-maps using the above truth table and determine the simplified Boolean expressions-

**For D:**

|           | $BB_{in}$ | $\bar{B}\bar{B}_{in}$ | $\bar{B}B_{in}$ | $BB_{in}$ | $B\bar{B}_{in}$ |
|-----------|-----------|-----------------------|-----------------|-----------|-----------------|
| $A$       | $\bar{A}$ |                       | (1)             |           | (1)             |
| $\bar{A}$ | (1)       |                       |                 | (1)       |                 |
| $A$       |           |                       |                 |           |                 |

$$D = A \oplus B \oplus B_{in}$$

$$\begin{aligned}
 D &= \bar{A} \bar{B} B_{in} + \bar{A} B \bar{B}_{in} + A \bar{B} \bar{B}_{in} + A B B_{in} \\
 &= B_{in} (\bar{A} \bar{B} + AB) + \bar{B}_{in} (\bar{A} B + A \bar{B}) \\
 &= B_{in} (A \ominus B) + \bar{B}_{in} (A \oplus B) \\
 &= B_{in} (\overline{A \oplus B}) + \bar{B}_{in} (A \oplus B) \\
 &= B_{in} \oplus (A \oplus B)
 \end{aligned}$$

**For  $B_{out}$ :**

|           | $BB_{in}$ | $\bar{B}\bar{B}_{in}$ | $\bar{B}B_{in}$ | $BB_{in}$ | $B\bar{B}_{in}$ |
|-----------|-----------|-----------------------|-----------------|-----------|-----------------|
| $A$       | $\bar{A}$ |                       | (1)             | (1)       | (1)             |
| $\bar{A}$ |           |                       |                 |           |                 |
| $A$       |           |                       |                 |           |                 |

$$B_{out} = \bar{A} B + (\bar{A} + B) B_{in}$$

**Step-04:**

Draw the logic diagram.



Full Subtractor using Half Subtractor

**For  $B_{in}$ :**

|           | $BB_{in}$ | $\bar{B}\bar{B}_{in}$ | $\bar{B}B_{in}$ | $BB_{in}$ | $B\bar{B}_{in}$ |
|-----------|-----------|-----------------------|-----------------|-----------|-----------------|
| $A$       |           |                       | 1               | 1         | 1               |
| $\bar{A}$ |           |                       |                 |           |                 |
| $A$       |           |                       |                 | 1         |                 |

$$D = (A \text{ XOR } B) \text{ XOR } B_{in}$$

$$\begin{aligned} B_{in} &= A'B'B_{in} + A'B'B_{in} + A'BB'_{in} + ABB_{in} \\ &= A'B(B_{in} + B'_{in}) + B_{in}(A'B' + AB) \\ &= A'B + B_{in}(A \text{ XOR } B)' \end{aligned}$$



Full Subtractor using NAND gates



Full Subtractor using NAND gates



## Binary to BCD Code Convertor

Input variables are B3, B2, B1, B0 representing a 4 bit Binary number.

Output variables are D4, D3, D2, D1, D0, representing its equivalent BCD.

Since highest decimal value of 4 bit binary number is 15, 5 bits are required to represent its BCD. D4 for the first digit, and D3D2D1D0 for the second digit

### Truth Table

| Decimal Number | Binary code (Input) |    |    |    | BCD code (Output) |    |    |    |    |
|----------------|---------------------|----|----|----|-------------------|----|----|----|----|
|                | B3                  | B2 | B1 | B0 | D4                | D3 | D2 | D1 | D0 |
| 0              | 0                   | 0  | 0  | 0  | 0                 | 0  | 0  | 0  | 0  |
| 1              | 0                   | 0  | 0  | 1  | 0                 | 0  | 0  | 0  | 1  |
| 2              | 0                   | 0  | 1  | 0  | 0                 | 0  | 0  | 1  | 0  |
| 3              | 0                   | 0  | 1  | 1  | 0                 | 0  | 0  | 1  | 1  |
| 4              | 0                   | 1  | 0  | 0  | 0                 | 0  | 1  | 0  | 0  |
| 5              | 0                   | 1  | 0  | 1  | 0                 | 0  | 1  | 0  | 1  |
| 6              | 0                   | 1  | 1  | 0  | 0                 | 0  | 1  | 1  | 0  |
| 7              | 0                   | 1  | 1  | 1  | 0                 | 0  | 1  | 1  | 1  |
| 8              | 1                   | 0  | 0  | 0  | 0                 | 1  | 0  | 0  | 0  |
| 9              | 1                   | 0  | 0  | 1  | 0                 | 1  | 0  | 0  | 1  |
| 10             | 1                   | 0  | 1  | 0  | 1                 | 0  | 0  | 0  | 0  |
| 11             | 1                   | 0  | 1  | 1  | 1                 | 0  | 0  | 0  | 1  |
| 12             | 1                   | 1  | 0  | 0  | 1                 | 0  | 0  | 1  | 0  |
| 13             | 1                   | 1  | 0  | 1  | 1                 | 0  | 0  | 1  | 1  |
| 14             | 1                   | 1  | 1  | 0  | 1                 | 0  | 1  | 0  | 0  |
| 15             | 1                   | 1  | 1  | 1  | 1                 | 0  | 1  | 0  | 1  |

**K-maps**

4 input variables, so 4 variable K map with 16 cells.

Separate Kmaps for 5 output variables

|    |    | For $D_4$ output |                |                |                      |
|----|----|------------------|----------------|----------------|----------------------|
|    |    | $B_3B_2$         | $B_3\bar{B}_2$ | $\bar{B}_3B_2$ | $\bar{B}_3\bar{B}_2$ |
|    |    | 00               | 01             | 11             | 10                   |
| 00 | 00 | 0                | 0              | 0              | 0                    |
| 01 | 01 | 0                | 0              | 0              | 0                    |
| 11 | 11 | 1                | 1              | 1              | 1                    |
| 10 | 10 | 0                | 0              | 1              | 1                    |

$$D_4 = B_3B_2 + B_3\bar{B}_2$$

|    |    | For $D_3$ output |                |                |                      |
|----|----|------------------|----------------|----------------|----------------------|
|    |    | $B_3B_2$         | $B_3\bar{B}_2$ | $\bar{B}_3B_2$ | $\bar{B}_3\bar{B}_2$ |
|    |    | 00               | 01             | 11             | 10                   |
| 00 | 00 | 0                | 0              | 0              | 0                    |
| 01 | 01 | 0                | 0              | 0              | 0                    |
| 11 | 11 | 0                | 0              | 0              | 0                    |
| 10 | 10 | 1                | 1              | 0              | 0                    |

$$D_3 = B_3\bar{B}_2\bar{B}_1$$

|    |    | For $D_2$ output |                |                |                      |
|----|----|------------------|----------------|----------------|----------------------|
|    |    | $B_3B_2$         | $B_3\bar{B}_2$ | $\bar{B}_3B_2$ | $\bar{B}_3\bar{B}_2$ |
|    |    | 00               | 01             | 11             | 10                   |
| 00 | 00 | 0                | 0              | 0              | 0                    |
| 01 | 01 | 1                | 1              | 1              | 1                    |
| 11 | 11 | 0                | 0              | 1              | 1                    |
| 10 | 10 | 0                | 0              | 0              | 0                    |

$$D_2 = \bar{B}_3B_2 + B_3B_1$$

|    |    | For $D_1$ output |                |                |                      |
|----|----|------------------|----------------|----------------|----------------------|
|    |    | $B_3B_2$         | $B_3\bar{B}_2$ | $\bar{B}_3B_2$ | $\bar{B}_3\bar{B}_2$ |
|    |    | 00               | 01             | 11             | 10                   |
| 00 | 00 | 0                | 0              | 1              | 1                    |
| 01 | 01 | 0                | 0              | 1              | 1                    |
| 11 | 11 | 1                | 1              | 0              | 0                    |
| 10 | 10 | 0                | 0              | 0              | 0                    |

$$D_1 = B_3B_2\bar{B}_1 + \bar{B}_3B_1$$

|    |    | For $D_0$ output |                |                |                      |
|----|----|------------------|----------------|----------------|----------------------|
|    |    | $B_3B_2$         | $B_3\bar{B}_2$ | $\bar{B}_3B_2$ | $\bar{B}_3\bar{B}_2$ |
|    |    | 00               | 01             | 11             | 10                   |
| 00 | 00 | 0                | 1              | 1              | 0                    |
| 01 | 01 | 0                | 1              | 1              | 0                    |
| 11 | 11 | 0                | 1              | 1              | 0                    |
| 10 | 10 | 0                | 1              | 1              | 0                    |

$$D_0 = B_0$$

### Logic Circuit Diagram



$$D_4 = B_3 B_2 + B_3 \overline{B}_1$$

$$D_3 = B_3 \overline{B}_2 \overline{B}_1$$

$$D_2 = \overline{B}_3 B_2 + B_2 B_1$$

$$D_1 = B_3 B_2 \overline{B}_1 + \overline{B}_3 B_1$$

$$D_0 = B_0$$

# Ktunotes.in

## BCD to Excess 3 Converter

Valid BCD is only from 0 to 9 (10 to 15 are invalid BCD)

Excess 3 code is obtained by adding 3 (0011) to the BCD code. Since BCD 10 to 15 are invalid, corresponding entries in kmap are marked with don't cares (X)

### Truth Table:

| Decimal Number | BCD code (Input) |                |                |                | Excess-3 code (Output) |                |                |                |
|----------------|------------------|----------------|----------------|----------------|------------------------|----------------|----------------|----------------|
|                | D <sub>3</sub>   | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | E <sub>3</sub>         | E <sub>2</sub> | E <sub>1</sub> | E <sub>0</sub> |
| 0              | 0                | 0              | 0              | 0              | 0                      | 0              | 1              | 1              |
| 1              | 0                | 0              | 0              | 1              | 0                      | 1              | 0              | 0              |
| 2              | 0                | 0              | 1              | 0              | 0                      | 1              | 0              | 1              |
| 3              | 0                | 0              | 1              | 1              | 0                      | 1              | 1              | 0              |
| 4              | 0                | 1              | 0              | 0              | 0                      | 1              | 1              | 1              |
| 5              | 0                | 1              | 0              | 1              | 1                      | 0              | 0              | 0              |
| 6              | 0                | 1              | 1              | 0              | 1                      | 0              | 0              | 1              |
| 7              | 0                | 1              | 1              | 1              | 1                      | 0              | 1              | 0              |
| 8              | 1                | 0              | 0              | 0              | 1                      | 0              | 1              | 1              |
| 9              | 1                | 0              | 0              | 1              | 1                      | 1              | 0              | 0              |

**K-maps**

4 input variables, so 4 variable K map with 16 cells.

Separate Kmaps for 4 output variables

|  |  | For $E_3$ output |    |    |    |   |
|--|--|------------------|----|----|----|---|
|  |  | 00               | 01 | 11 | 10 |   |
|  |  | 00               | 0  | 0  | 0  | 0 |
|  |  | 01               | 0  | 1  | 1  | 1 |
|  |  | 11               | X  | X  | X  | X |
|  |  | 10               | 1  | 1  | X  | X |

$E_3 = D_3 + D_2 D_0 + D_2 D_1$

|  |  | For $E_2$ output |    |    |    |   |
|--|--|------------------|----|----|----|---|
|  |  | 00               | 01 | 11 | 10 |   |
|  |  | 00               | 0  | 1  | 1  | 1 |
|  |  | 01               | 1  | 0  | 0  | 0 |
|  |  | 11               | X  | X  | X  | X |
|  |  | 10               | 0  | 1  | X  | X |

$E_2 = D_2 \bar{D}_1 \bar{D}_0 + \bar{D}_2 D_0 + \bar{D}_2 D_1$

|  |  | For $E_1$ output |    |    |    |   |
|--|--|------------------|----|----|----|---|
|  |  | 00               | 01 | 11 | 10 |   |
|  |  | 00               | 1  | 0  | 1  | 0 |
|  |  | 01               | 1  | 0  | 1  | 0 |
|  |  | 11               | X  | X  | X  | X |
|  |  | 10               | 1  | 0  | X  | X |

$E_1 = \bar{D}_1 \bar{D}_0 + D_1 D_0$

|  |  | For $E_0$ output |    |    |    |   |
|--|--|------------------|----|----|----|---|
|  |  | 00               | 01 | 11 | 10 |   |
|  |  | 00               | 1  | 0  | 0  | 1 |
|  |  | 01               | 1  | 0  | 0  | 1 |
|  |  | 11               | X  | X  | X  | X |
|  |  | 10               | 1  | 0  | X  | X |

$E_0 = \bar{D}_0$

### Logic Circuit Diagram



Ktunotes.in

## Implementation of Boolean function in multiplexer

### Problem #1

Implement the boolean expression  $F(A, B, C) = \sum m(2, 3, 6, 7)$  using a multiplexer

### Solution

- There are 3 variables in the given expression, hence  $2^n = 2^3 = 8 : 1$  multiplexer.
- So, the mux has 8 input lines, 3 selection lines, and one output.
- The inputs, corresponding to the minterms (2, 3, 6, 7) are connected to logic 1 and the remaining terms to logic 0(grounded).
- The given input variables are connected as three selection lines



### Problem #2

Implement the boolean expression  $F(A, B, C) = \sum m(0, 1, 3, 5, 7)$  using a multiplexer.

### Solution

- there are 3 variables and hence 8 : 1 multiplier is used to solve the expression.
- The three input variables(A, B, C) are connected as three selection lines.
- The inputs, corresponding to the minterms (0, 1, 3, 5, 7) are connected to logic 1 and the remaining terms to the logic 0(grounded).



**Problem #3**

**Implement the boolean expression  $F(A, B, C) = \sum m(1, 2, 4, 7)$  using 4 : 1 multiplexer.**

**Solution**

- In the given boolean expression, there are 3 variables. We should use  $2^3 : 1 = 8 : 1$  multiplexer. But as per the question, it is to be implemented with 4 : 1 mux.
- For 4 : 1 multiplexer, there should be 2 selection lines. So from the given 3 variables, the 2 variables(A, B) are used as selection line inputs.
- Let us derive the four inputs of 4 : 1 multiplexer using the implementation table

| A | B | C | F |          |
|---|---|---|---|----------|
| 0 | 0 | 0 | 0 | $F = C$  |
| 0 | 0 | 1 | 1 |          |
| 0 | 1 | 0 | 1 | $F = C'$ |
| 0 | 1 | 1 | 0 |          |
| 1 | 0 | 0 | 1 | $F = C'$ |
| 1 | 0 | 1 | 0 |          |
| 1 | 1 | 0 | 0 |          |
| 1 | 1 | 1 | 1 |          |



**Problem #4****Implement the**

$$F(A, B, C) = \sum m(0, 1, 2, 3, 4, 10, 11, 14, 15)$$

**using 16 : 1 multiplexer.****Solution**

| Minterm | A | B | C | D | F |
|---------|---|---|---|---|---|
| 0       | 0 | 0 | 0 | 0 | 1 |
| 1       | 0 | 0 | 0 | 1 | 1 |
| 2       | 0 | 0 | 1 | 0 | 1 |
| 3       | 0 | 0 | 1 | 1 | 1 |
| 4       | 0 | 1 | 0 | 0 | 1 |
| 5       | 0 | 1 | 0 | 1 | 0 |
| 6       | 0 | 1 | 1 | 0 | 0 |
| 7       | 0 | 1 | 1 | 1 | 0 |
| 8       | 1 | 0 | 0 | 0 | 0 |
| 9       | 1 | 0 | 0 | 1 | 0 |
| 10      | 1 | 0 | 1 | 0 | 1 |
| 11      | 1 | 0 | 1 | 1 | 1 |
| 12      | 1 | 1 | 0 | 0 | 0 |
| 13      | 1 | 1 | 0 | 1 | 0 |
| 14      | 1 | 1 | 1 | 0 | 1 |
| 15      | 1 | 1 | 1 | 1 | 1 |

**Problem #4****Implement the**

$$F(A, B, C) = \sum m(0, 1, 2, 3, 4, 10, 11, 14, 15)$$

**using 8 : 1 multiplexer.****Solution**

| MINTERM | A | B | C | D | F |
|---------|---|---|---|---|---|
| 0       | 0 | 0 | 0 | 0 | 1 |
| 1       | 0 | 0 | 0 | 1 | 1 |
| 2       | 0 | 0 | 1 | 0 | 1 |
| 3       | 0 | 0 | 1 | 1 | 1 |
| 4       | 0 | 1 | 0 | 0 | 1 |
| 5       | 0 | 1 | 0 | 1 | 0 |
| 6       | 0 | 1 | 1 | 0 | 0 |
| 7       | 0 | 1 | 1 | 1 | 0 |
| 8       | 1 | 0 | 0 | 0 | 0 |
| 9       | 1 | 0 | 0 | 1 | 0 |
| 10      | 1 | 0 | 1 | 0 | 1 |
| 11      | 1 | 0 | 1 | 1 | 1 |
| 12      | 1 | 1 | 0 | 0 | 0 |
| 13      | 1 | 1 | 0 | 1 | 0 |
| 14      | 1 | 1 | 1 | 0 | 1 |
| 15      | 1 | 1 | 1 | 1 | 1 |

**Problem #5**

**For the given multiplexer circuit, determine the logic function.**



Solution:

- In the given multiplexer circuit, B and C are the selection inputs. Hence the possible input combinations are 00, 01, 10 and 11.
- if BC = 00, D<sub>0</sub> = A is selected as the output.
- if BC = 01, D<sub>1</sub> = A, is selected as the output.
- If BC = 10, D<sub>2</sub> = 0, is selected as the output.
- If BC = 11, D<sub>3</sub> = A' is selected as the output.

| B | C | F  |
|---|---|----|
| 0 | 0 | A  |
| 0 | 1 | A  |
| 1 | 0 | 0  |
| 1 | 1 | A' |

- From the truth table, the output expression can be written as  $F = AB'C' + AB'C + A'BC$   
 $= AB'(C' + C) + A'BC$   
 $= AB' + A'BC$

**Problem #6**

Implement the functions  $F_1 = \sum m(0, 3, 7)$ ,  $F_2 = \sum m(1, 2, 5)$  using demultiplexer.

**Solution**

- Largest term in the functions is 7 =  $(111)_2$ . Hence we require 3 selection lines and a 1:8 demultiplexer.
- Consider A, B, C as the three variables used as selection lines.



**Problem #7**

**Implement the functions  $F_1 = \sum m(1, 5, 7)$ ,  $F_2 = \sum m(0, 3)$ ,  $F_3 = \sum m(2, 4, 5)$  using demultiplexer.**

**Solution**

- Largest term in the functions is 7 =  $(111)_2$ . Hence we require 3 selection lines and a 1:8 demultiplexer.
- Consider  $x, y, z$  as the three variables used as selection lines.

**Problem #8**

Configure an 8:1 Multiplexer using 4 : 1 MUX and 2 : 1 MUX

Solution

| D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | S2 | S1 | S0 | Y  |
|----|----|----|----|----|----|----|----|----|----|----|----|
| 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 0  | D0 |
| 0  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 0  | 1  | D1 |
| 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 0  | 1  | 0  | D2 |
| 0  | 0  | 0  | 0  | 1  | 0  | 0  | 0  | 0  | 1  | 1  | D3 |
| 0  | 0  | 0  | 1  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | D4 |
| 0  | 0  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 1  | D5 |
| 0  | 1  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 0  | D6 |
| 1  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 1  | D7 |



**Problem #9**

Configure an 16 : 1 Multiplexer using 4 : 1 MUX

Solution

**Problem #10**Implement the boolean expression  $F(A, B) = A'B + AB'$  using a multiplexer

Solution

| A | B | D  | F |
|---|---|----|---|
| 0 | 0 | D0 | 0 |
| 0 | 1 | D1 | 1 |
| 1 | 0 | D2 | 1 |
| 1 | 1 | D3 | 0 |



**Problem #11**Implement the boolean expression  $F(P, Q, R) = \sum m(2, 3, 5, 6)$ , using a multiplexer

Solution

**Problem #12**Implement the boolean expression  $F(P, Q, R) = P'Q' + PR + PQ$  using a multiplexer

Solution

$$F(P, Q, R) = P'Q' + PR + PQ$$

$$\begin{aligned} &= P'Q'(R+R') + PR(Q+Q') + PQ(R+R') \\ &= P'Q'R + P'Q'R' + PQR + PQ'R + PQR + PQR' \\ &= P'Q'R + P'Q'R' + PQR + PQ'R + PQR' \end{aligned}$$

| P | Q | R | f |
|---|---|---|---|
| 0 | 0 | 0 | 1 |
| 0 | 0 | 1 | 1 |
| 0 | 1 | 0 | 0 |
| 0 | 1 | 1 | 0 |
| 1 | 0 | 0 | 0 |
| 1 | 0 | 1 | 1 |
| 1 | 1 | 0 | 1 |
| 1 | 1 | 1 | 1 |

(a)



(b)

**Problem #13**

Implement a full adder using a multiplexer

$$\begin{aligned} S &= A \oplus B \oplus C \\ &= AB'C' + A'B'C + A'BC' + ABC \\ &= \sum m(1, 2, 4, 7) \end{aligned}$$

$$\begin{aligned} Cout &= AB + ACin + BCin \\ &= AB(Cin + C'in) + ACin(B + B') + BCin(A + A') \\ &= ABCin + ABC'in + ABCin + AB'Cin + ABCin + A'BCin \\ &= ABCin + ABC'in + AB'Cin + A'BCin \\ &= \sum m(3, 5, 6, 7) \end{aligned}$$

| A | B | Cin | S |
|---|---|-----|---|
| 0 | 0 | 0   | 0 |
| 0 | 0 | 1   | 1 |
| 0 | 1 | 0   | 1 |
| 0 | 1 | 1   | 0 |
| 1 | 0 | 0   | 1 |
| 1 | 0 | 1   | 0 |
| 1 | 1 | 0   | 0 |
| 1 | 1 | 1   | 1 |

| A | B | Cin | Cout |
|---|---|-----|------|
| 0 | 0 | 0   | 0    |
| 0 | 0 | 1   | 0    |
| 0 | 1 | 0   | 0    |
| 0 | 1 | 1   | 1    |
| 1 | 0 | 0   | 0    |
| 1 | 0 | 1   | 1    |
| 1 | 1 | 0   | 1    |
| 1 | 1 | 1   | 1    |

**Problem #14**

Implement a full adder using 4 : 1 multiplexers

$$\begin{aligned} S &= A \oplus B \oplus C \\ &= AB'C' + A'B'C + A'BC' + ABC \\ &= \sum m(1, 2, 4, 7) \end{aligned}$$

| A | B | Cin | S |
|---|---|-----|---|
| 0 | 0 | 0   | 0 |
| 0 | 0 | 1   | 1 |
| 0 | 1 | 0   | 1 |
| 0 | 1 | 1   | 0 |
| 1 | 0 | 0   | 1 |
| 1 | 0 | 1   | 0 |
| 1 | 1 | 0   | 0 |
| 1 | 1 | 1   | 1 |

S = Cin DO

S = C'in D1

S = C'in D2

S = Cin D3

$$\begin{aligned}
 \text{Cout} &= AB + ACin + Bcin \\
 &= AB(Cin + C'in) + ACin(B + B') + BCin(A + A') \\
 &= ABCin + ABC'in + ABCin + AB'Cin + ABCin + A'BCin \\
 &= ABCin + ABC'in + AB'Cin + A'BCin \\
 &= \sum m(3, 5, 6, 7)
 \end{aligned}$$

| A | B | Cin | Cout |      |       |
|---|---|-----|------|------|-------|
| 0 | 0 | 0   | 0    | Cout | D0    |
| 0 | 0 | 1   | 0    | Cout | = 0   |
| 0 | 1 | 0   | 0    | Cout | D1    |
| 0 | 1 | 1   | 1    | Cout | = Cin |
| 1 | 0 | 0   | 0    | Cout | D2    |
| 1 | 0 | 1   | 1    | Cout | = Cin |
| 1 | 1 | 0   | 1    | Cout | D3    |
| 1 | 1 | 1   | 1    | Cout | = 1   |



**Problem #15**Realize the boolean expression  $F(A, B, C) = \sum m(0, 1, 4, 6)$  using

- a) 8 : 1 multiplexers
- b) 4 : 1 multiplexers
- c) 2 : 1 multiplexers

**Solution:**

8 : 1 multiplexers



| A | B | C | F |
|---|---|---|---|
| 0 | 0 | 0 | 1 |
| 0 | 0 | 1 | 1 |
| 0 | 1 | 0 | 0 |
| 0 | 1 | 1 | 0 |
| 1 | 0 | 0 | 1 |
| 1 | 0 | 1 | 0 |
| 1 | 1 | 0 | 1 |
| 1 | 1 | 1 | 0 |

$$\begin{array}{ll}
 F = 1 & D_0 \\
 F = 0 & D_1 \\
 F = C' & D_2 \\
 F = C' & D_3
 \end{array}$$



$$\begin{aligned}
 F(A, B, C) &= \sum m (0, 1, 4, 6) \\
 &= A'B'C' + A'B'C + AB'C' + ABC' \\
 &= A'(B'C' + B'C) + A(B'C' + BC')
 \end{aligned}$$

**Problem #16**

Realize a full adder using a demultiplexer

$$\begin{aligned}
 S &= A \oplus B \oplus C \\
 &= AB'C' + A'B'C + A'BC' + ABC \\
 &= \sum m (1, 2, 4, 7)
 \end{aligned}$$

$$\begin{aligned}
 \text{Cout} &= AB + ACin + Bcin \\
 &= AB(Cin + C'in) + ACin(B + B') + BCin(A + A') \\
 &= ABCin + ABC'in + ABCin + AB'Cin + ABCin + A'Bcin \\
 &= ABCin + ABC'in + AB'Cin + A'Bcin \\
 &= \sum m (3, 5, 6, 7)
 \end{aligned}$$



**Problem #17**

Design a 1:8 demultiplexer using two 1:4 demultiplexers

- 1:4 demultiplexer has only 2 select lines
- 1: 8 demultiplexer requires 3 select lines
- Additional select line can be derived from the enable input



# Ktunotes.in

## N-Bit Parallel Adder

- Full Adder is capable of adding only two single digit binary number along with a carry input.
- Practically we need to add binary numbers which are much longer than just one bit.
- To add two n-bit binary numbers, we need to use the n-bit Parallel Adder.
- Parallel Adder uses a number of Full Adders in cascade.
- Carry output of the previous Full Adder is connected to carry input of the next Full Adder (hence also called ripple carry adder)

## 4-Bit Parallel Adder



$A_0$  and  $B_0$  represent the LSB of the four bit words A and B. Hence Full Adder-0 is the lowest stage. Hence its  $C_{in}$  has been permanently made 0. The rest of the connections are exactly same as those of n-bit parallel adder.

- Drawback: ripple carry implementation- increases propagation delay associated with each stage and decreases operating speed.

## Carry Look Ahead Adder

- Overcomes the drawback of Parallel adder
- Sum and carry outputs of each stage are made independent of the results of previous stages- ripple effect is eliminated
- Uses concept of look-ahead carry
- Requires additional circuitry but speed becomes independent of number of bits (or stages)
- $C_i = A_i B_i + C_{i-1} (A_i \oplus B_i)$
- Let  $P_i$  be carry propagate,  $P_i = A_i \oplus B_i$
- Let  $G_i$  be carry generate ,  $G_i = A_i B_i$
- $C_i = G_i + P_i C_{i-1}$
- $C_{i+1} = G_{i+1} + P_{i+1} C_i$
- $C_{i+1} = G_{i+1} + P_{i+1} G_i + P_{i+1} P_i C_{i-1}$

For first full adder

- Carry propagate:  $P_0 = A_0 \oplus B_0$
- Carry generate:  $G_0 = A_0 B_0$
- Carry out of first full adder:  $C_0 = G_0 + P_0 C_{-1}$

For second full adder

$$C_1 = G_1 + P_1 C_0$$

$$C_1 = G_1 + P_1 G_0 + P_1 P_0 C_{-1}$$

Continuing to other stages

$$C_2 = G_2 + P_2 G_1 + P_2 P_1 G_0 + P_2 P_1 P_0 C_{-1}$$

$$C_3 = G_3 + P_3 G_2 + P_3 P_2 G_1 + P_3 P_2 P_1 G_0 + P_3 P_2 P_1 P_0 C_{-1}$$

## 4-bit Adder with look-ahead carry(contd)



## BCD Adder

BCD addition is carried out by individually adding the corresponding 4-bit groups starting from the LSB side, and if there is any carry to the next group, or if the result belongs to any of the 6 illegal states, that we add 6 (0110) to the sum term of the group and resulting carry is added in the next group.



For partial sum outputs  
1010, 1011, 1100, 1101, 1110, 1111,  
Correction should be done by adding  
6 (0110) to the partial sum  $S_3S_2S_1S_0$

0110 is added to the partial sum if any one  
of the following occurs  
 1.  $C_{out}$  is 1  
 2.  $S_3$  and  $S_2$  simultaneously high  
 3.  $S_3$  and  $S_1$  simultaneously high

## MODULE 3 : Design of Parity Generators and Parity Checkers

### What is Parity?

- In digital systems when binary data is transmitted and processed, it may be subjected to noise and this noise can alter the data bits(1's become 0's or 0's become 1's)
- To detect errors, a parity bit is added to the word, to make the number of 1's odd or even.
- The message containing the data bits along with the parity bit is transmitted from the transmitter node to receiver node
- At the receiver node, the parity bit is checked with the number of 1's in the data and if it does not match, error is detected.
- Two types- Even Parity and Odd Parity

#### Parity Generator

It is combinational circuit that accepts an  $n-1$  bit data and generates the additional bit that is to be transmitted with the bit stream. This additional or extra bit is called as a Parity Bit.

In even parity bit scheme, the parity bit is ‘0’ if there are even number of 1s in the data stream and the parity bit is ‘1’ if there are odd number of 1s in the data stream.

In odd parity bit scheme, the parity bit is ‘1’ if there are even number of 1s in the data stream and the parity bit is ‘0’ if there are odd number of 1s in the data stream. Let us discuss both even and odd parity generators.

#### Parity Check

It is a logic circuit that checks for possible errors in the transmission. This circuit can be an even parity checker or odd parity checker depending on the type of parity generated at the transmission end. When this circuit is used as even parity checker, the number of input bits must always be even.

## Even Parity Generator

- Let us assume that a 3 bit message is to be transmitted with an even parity bit.
- Let A, B, C be the three inputs, and output Y is the parity bit.
- Output Y is 0 if the number of 1's in (A, B, C) is even.
- Output Y is 1 if the number of 1's in (A, B, C) is odd.

| 3-bit message |   |   | Even parity bit generator (P) |
|---------------|---|---|-------------------------------|
| A             | B | C | Y                             |
| 0             | 0 | 0 | 0                             |
| 0             | 0 | 1 | 1                             |
| 0             | 1 | 0 | 1                             |
| 0             | 1 | 1 | 0                             |
| 1             | 0 | 0 | 1                             |
| 1             | 0 | 1 | 0                             |
| 1             | 1 | 0 | 0                             |
| 1             | 1 | 1 | 1                             |

|    |    | BC | 00 | 01 | 11 | 10 |
|----|----|----|----|----|----|----|
|    |    | A  | 00 | 01 | 11 | 10 |
| 00 | 00 | 0  | 0  | 1  | 0  | 1  |
| 01 | 01 | 1  | 1  | 0  | 1  | 0  |

$P = \overline{A} \overline{B} C + \overline{A} B \overline{C} + A \overline{B} \overline{C} + A B C$   
 $= \overline{A} (\overline{B} C + B \overline{C}) + A (\overline{B} \overline{C} + B C)$   
 $= \overline{A} (B \oplus C) + A (\overline{B} \oplus C)$   
 $P = A \oplus B \oplus C$



$$P = A \oplus B \oplus C$$

## Odd Parity Generator

- Let us assume that a 3 bit message is to be transmitted with an odd parity bit.
- Let A, B, C be the three inputs, and output Y is the parity bit.
- Output Y is 0 if the number of 1's in (A, B, C) is odd.
- Output Y is 1 if the number of 1's in (A, B, C) is even.

| 3-bit message |   |   | Odd parity bit generator (P) |
|---------------|---|---|------------------------------|
| A             | B | C | Y                            |
| 0             | 0 | 0 | 1                            |
| 0             | 0 | 1 | 0                            |
| 0             | 1 | 0 | 0                            |
| 0             | 1 | 1 | 1                            |
| 1             | 0 | 0 | 0                            |
| 1             | 0 | 1 | 1                            |
| 1             | 1 | 0 | 1                            |
| 1             | 1 | 1 | 0                            |

| A  | BC | 00 | 01 | 11 | 10 |
|----|----|----|----|----|----|
| 00 | 0  | 0  | 1  | 3  | 2  |
| 01 | 4  | 0  | 1  | 7  | 6  |

$$\begin{aligned}
 P_{\text{od}} &= (\bar{A} \bar{B} \bar{C} + A \bar{B} C) + (\bar{A} B C + A B \bar{C}) \\
 &= \bar{C} (A B + \bar{A} \bar{B}) + B (A \bar{B} + \bar{A} B) \\
 &= \bar{C} (A \oplus B) + C (A \oplus B) \\
 &= \bar{C} \bar{X} + C X = C \odot X = C \odot A \oplus B
 \end{aligned}$$



$$P = C \odot A \oplus B$$

## Even Parity Checker

- Consider that a three input message along with an even parity bit is applied as input to an even parity checker circuit.
- This circuit checks the possibility of error.
- Parity Error Check (PEC) Output =1, if any error occurs  
i.e. there will be an odd number of 1's for the 4 bits received.
- Parity Error Check (PEC) Output =0, if no error occurs  
i.e. there will be an even number of 1's for the 4 bits received.

| 4-bit received message |   |   |   | Parity error check $C_P$ |
|------------------------|---|---|---|--------------------------|
| A                      | B | C | P |                          |
| 0                      | 0 | 0 | 0 | 0                        |
| 0                      | 0 | 0 | 1 | 1                        |
| 0                      | 0 | 1 | 0 | 1                        |
| 0                      | 0 | 1 | 1 | 0                        |
| 0                      | 1 | 0 | 0 | 1                        |
| 0                      | 1 | 0 | 1 | 0                        |
| 0                      | 1 | 1 | 0 | 0                        |
| 0                      | 1 | 1 | 1 | 1                        |
| 1                      | 0 | 0 | 0 | 1                        |
| 1                      | 0 | 0 | 1 | 0                        |
| 1                      | 0 | 1 | 0 | 0                        |
| 1                      | 0 | 1 | 1 | 1                        |
| 1                      | 1 | 0 | 0 | 0                        |
| 1                      | 1 | 0 | 1 | 1                        |
| 1                      | 1 | 1 | 0 | 1                        |
| 1                      | 1 | 1 | 1 | 0                        |

| AB | 00  | 01  | 11  | 10  |
|----|-----|-----|-----|-----|
| CP | 0   | 1   | 0   | 1   |
| 00 | 0   | (1) | 0   | (1) |
| 01 | (1) | 0   | (1) | 0   |
| 11 | 0   | (1) | 0   | (1) |
| 10 | (1) | 0   | (1) | 0   |

$$\begin{aligned}
 PEC &= \overline{A} \overline{B} (\overline{C}P + C\overline{P}) + \overline{A}B(\overline{C}\overline{P} + CP) + AB(\overline{C}P + C\overline{P}) + A\overline{B}(\overline{C}\overline{P} + CP) \\
 &= \overline{A} \overline{B} (C \oplus P) + \overline{A} B (\overline{C} \oplus P) + AB(C \oplus P) + A \overline{B} (\overline{C} \oplus P) \\
 &= (\overline{A} \overline{B} + AB)(C \oplus P) + (\overline{A} B + A \overline{B})(\overline{C} \oplus P) \\
 &= (A \oplus B) \oplus (C \oplus P)
 \end{aligned}$$



## Odd Parity Checker

- Consider that a three input message along with an odd parity bit is applied as input to an odd parity checker circuit.
- This circuit checks the possibility of error.
- Parity Error Check (PEC) Output = 1, if any error occurs  
i.e. there will be an even number of 1's for the 4 bits received.
- Parity Error Check (PEC) Output = 0, if no error occurs  
i.e. there will be an odd number of 1's for the 4 bits received.

| 4-bit received message |   |   |   | Parity error check $C_p$ |
|------------------------|---|---|---|--------------------------|
| A                      | B | C | P |                          |
| 0                      | 0 | 0 | 0 | 1                        |
| 0                      | 0 | 0 | 1 | 0                        |
| 0                      | 0 | 1 | 0 | 0                        |
| 0                      | 0 | 1 | 1 | 1                        |
| 0                      | 1 | 0 | 0 | 0                        |
| 0                      | 1 | 0 | 1 | 1                        |
| 0                      | 1 | 1 | 0 | 1                        |
| 0                      | 1 | 1 | 1 | 0                        |
| 1                      | 0 | 0 | 0 | 0                        |
| 1                      | 0 | 0 | 1 | 1                        |
| 1                      | 0 | 1 | 0 | 1                        |
| 1                      | 0 | 1 | 1 | 0                        |
| 1                      | 1 | 0 | 0 | 1                        |
| 1                      | 1 | 0 | 1 | 0                        |
| 1                      | 1 | 1 | 0 | 0                        |
| 1                      | 1 | 1 | 1 | 1                        |

| AB | 00     | 01     | 11     | 10     |
|----|--------|--------|--------|--------|
| 00 | 0<br>1 | 0<br>1 | 1<br>0 | 0<br>1 |
| 01 | 0<br>0 | 1<br>0 | 0<br>1 | 1<br>0 |
| 11 | 1<br>0 | 0<br>1 | 1<br>0 | 0<br>1 |
| 10 | 0<br>1 | 1<br>0 | 0<br>1 | 1<br>0 |

$$\text{PEC} = (\text{A XNOR B}) \text{ XNOR } (\text{C XNOR P})$$



$$\text{PEC} = (\text{A XNOR B}) \text{ XNOR } (\text{C XNOR P})$$

Ktunotes.in

## Code Converter

A code converter is a logic circuit that changes data presented in one type of binary code to another type of binary code

Examples-

- Binary to BCD
- Binary to Excess 3
- Binary to Gray Code
- Gray Code to Binary

Steps to design a code converter logic circuit

Step 1: Truth table showing relationship between input and output

Step 2 : For each output, determine the simplified Boolean expression using KMAP

Step 3: Realize the code converter using logic gates

**Ktunotes.in**

### Binary to BCD Code Convertor

Input variables are B3, B2, B1, B0 representing a 4 bit Binary number.

Output variables are D4, D3, D2, D1, D0, representing its equivalent BCD.

Since highest decimal value of 4 bit binary number is 15, 5 bits are required to represent its BCD. D4 for the first digit, and D3D2D1D0 for the second digit

**Truth Table**

| Decimal Number | Binary code (Input) |    |    |    | BCD code (Output) |    |    |    |    |
|----------------|---------------------|----|----|----|-------------------|----|----|----|----|
|                | B3                  | B2 | B1 | B0 | D4                | D3 | D2 | D1 | D0 |
| 0              | 0                   | 0  | 0  | 0  | 0                 | 0  | 0  | 0  | 0  |
| 1              | 0                   | 0  | 0  | 1  | 0                 | 0  | 0  | 0  | 1  |
| 2              | 0                   | 0  | 1  | 0  | 0                 | 0  | 0  | 1  | 0  |
| 3              | 0                   | 0  | 1  | 1  | 0                 | 0  | 0  | 1  | 1  |
| 4              | 0                   | 1  | 0  | 0  | 0                 | 0  | 1  | 0  | 0  |
| 5              | 0                   | 1  | 0  | 1  | 0                 | 0  | 1  | 0  | 1  |
| 6              | 0                   | 1  | 1  | 0  | 0                 | 0  | 1  | 1  | 0  |
| 7              | 0                   | 1  | 1  | 1  | 0                 | 0  | 1  | 1  | 1  |
| 8              | 1                   | 0  | 0  | 0  | 0                 | 1  | 0  | 0  | 0  |
| 9              | 1                   | 0  | 0  | 1  | 0                 | 1  | 0  | 0  | 1  |
| 10             | 1                   | 0  | 1  | 0  | 1                 | 0  | 0  | 0  | 0  |
| 11             | 1                   | 0  | 1  | 1  | 1                 | 0  | 0  | 0  | 1  |
| 12             | 1                   | 1  | 0  | 0  | 1                 | 0  | 0  | 1  | 0  |
| 13             | 1                   | 1  | 0  | 1  | 1                 | 0  | 0  | 1  | 1  |
| 14             | 1                   | 1  | 1  | 0  | 1                 | 0  | 1  | 0  | 0  |
| 15             | 1                   | 1  | 1  | 1  | 1                 | 0  | 1  | 0  | 1  |

K-maps

Ktunotes.in

For D<sub>4</sub> output

|    | 00 | 01 | 11 | 10 |
|----|----|----|----|----|
| 00 | 0  | 0  | 0  | 0  |
| 01 | 0  | 0  | 0  | 0  |
| 11 | 1  | 1  | 1  | 1  |
| 10 | 0  | 0  | 1  | 1  |

For D<sub>3</sub> output

|    | 00 | 01 | 11 | 10 |
|----|----|----|----|----|
| 00 | 0  | 0  | 0  | 0  |
| 01 | 0  | 0  | 0  | 0  |
| 11 | 0  | 0  | 0  | 0  |
| 10 | 1  | 1  | 0  | 0  |

For D<sub>2</sub> output

|    | 00 | 01 | 11 | 10 |
|----|----|----|----|----|
| 00 | 0  | 0  | 0  | 0  |
| 01 | 1  | 1  | 1  | 1  |
| 11 | 0  | 0  | 1  | 1  |
| 10 | 0  | 0  | 0  | 0  |

$$D_4 = B_3 B_2 + B_3 B_1$$

$$D_3 = B_2 \bar{B}_1 \bar{B}_0$$

$$D_2 = \bar{B}_3 B_2 + B_3 B_1$$

For D<sub>1</sub> output

|    | 00 | 01 | 11 | 10 |
|----|----|----|----|----|
| 00 | 0  | 0  | 1  | 1  |
| 01 | 0  | 0  | 1  | 1  |
| 11 | 1  | 1  | 0  | 0  |
| 10 | 0  | 0  | 0  | 0  |

$$D_1 = B_3 B_2 \bar{B}_1 + \bar{B}_3 B_1$$

For D<sub>0</sub> output

|    | 00 | 01 | 11 | 10 |
|----|----|----|----|----|
| 00 | 0  | 1  | 1  | 0  |
| 01 | 0  | 1  | 1  | 0  |
| 11 | 0  | 1  | 1  | 0  |
| 10 | 0  | 1  | 1  | 0  |

$$D_0 = B_0$$

## Logic Circuit Diagram



$$D_4 = B_3 B_2 + B_3 B_1$$

$$D_3 = B_3 \overline{B}_2 \overline{B}_1$$

$$D_2 = \overline{B}_3 B_2 + B_2 B_1$$

$$D_1 = B_3 B_2 \overline{B}_1 + \overline{B}_3 B_1$$

$$D_0 = B_0$$

## BCD to Excess 3 Convertor

Valid BCD is only from 0 to 9 (10 to 15 are invalid BCD)

Excess 3 code is obtained by adding 3 (0011) to the BCD code. Since BCD 10 to 15 are invalid, corresponding entries in kmap are marked with don't cares (X)

**Truth Table:**

| Decimal Number | BCD code (Input) |                |                |                | Excess-3 code (Output) |                |                |                |
|----------------|------------------|----------------|----------------|----------------|------------------------|----------------|----------------|----------------|
|                | D <sub>3</sub>   | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | E <sub>3</sub>         | E <sub>2</sub> | E <sub>1</sub> | E <sub>0</sub> |
| 0              | 0                | 0              | 0              | 0              | 0                      | 0              | 1              | 1              |
| 1              | 0                | 0              | 0              | 1              | 0                      | 1              | 0              | 0              |
| 2              | 0                | 0              | 1              | 0              | 0                      | 1              | 0              | 1              |
| 3              | 0                | 0              | 1              | 1              | 0                      | 1              | 1              | 0              |
| 4              | 0                | 1              | 0              | 0              | 0                      | 1              | 1              | 1              |
| 5              | 0                | 1              | 0              | 1              | 1                      | 0              | 0              | 0              |
| 6              | 0                | 1              | 1              | 0              | 1                      | 0              | 0              | 1              |
| 7              | 0                | 1              | 1              | 1              | 1                      | 0              | 1              | 0              |
| 8              | 1                | 0              | 0              | 0              | 1                      | 0              | 1              | 1              |
| 9              | 1                | 0              | 0              | 1              | 1                      | 1              | 0              | 0              |

**K-maps**

### Logic Circuit Diagram



## Binary to Gray Code converter



$$g_3 = b_3$$

$$g_2 = b_3 \oplus b_2$$

$$g_1 = b_2 \oplus b_1$$

$$g_0 = b_1 \oplus b_0$$



## Binary to Gray Code converter

| Binary         |                |                |                | Gray Code      |                |                |                |
|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|
| b <sub>3</sub> | b <sub>2</sub> | b <sub>1</sub> | b <sub>0</sub> | g <sub>3</sub> | g <sub>2</sub> | g <sub>1</sub> | g <sub>0</sub> |
| 0              | 0              | 0              | 0              | 0              | 0              | 0              | 0              |
| 0              | 0              | 0              | 1              | 0              | 0              | 0              | 1              |
| 0              | 0              | 1              | 0              | 0              | 0              | 1              | 1              |
| 0              | 0              | 1              | 1              | 0              | 0              | 1              | 0              |
| 0              | 1              | 0              | 0              | 0              | 1              | 1              | 0              |
| 0              | 1              | 0              | 1              | 0              | 1              | 1              | 1              |
| 0              | 1              | 1              | 0              | 0              | 1              | 0              | 1              |
| 0              | 1              | 1              | 1              | 0              | 1              | 0              | 0              |
| 1              | 0              | 0              | 0              | 1              | 1              | 0              | 0              |
| 1              | 0              | 0              | 1              | 1              | 1              | 0              | 1              |
| 1              | 0              | 1              | 0              | 1              | 1              | 1              | 1              |
| 1              | 0              | 1              | 1              | 1              | 1              | 1              | 0              |
| 1              | 1              | 0              | 0              | 1              | 0              | 1              | 0              |
| 1              | 1              | 0              | 1              | 1              | 0              | 1              | 1              |
| 1              | 1              | 1              | 0              | 1              | 0              | 0              | 1              |
| 1              | 1              | 1              | 1              | 1              | 0              | 0              | 0              |



$$g_0 = b_0 b'_1 + b_1 b'_0 = b_0 \oplus b_1$$



$$g_2 = b_2 b'_3 + b_3 b'_2 = b_2 \oplus b_3$$



$$g_1 = b_2 b'_1 + b_1 b'_2 = b_1 \oplus b_2$$



$$g_3 = b_3$$

# Ktunotes.in

## Gray Code to Binary converter



$$\begin{aligned} b_3 &= g_3 \\ b_2 &= b_3 \oplus g_2 \\ b_1 &= b_2 \oplus g_1 \\ b_0 &= b_1 \oplus g_0 \end{aligned}$$



## Gray code to Binary Converter

| Gray Code      |                |                |                | Binary         |                |                |                |
|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|
| g <sub>3</sub> | g <sub>2</sub> | g <sub>1</sub> | g <sub>0</sub> | b <sub>3</sub> | b <sub>2</sub> | b <sub>1</sub> | b <sub>0</sub> |
| 0              | 0              | 0              | 0              | 0              | 0              | 0              | 0              |
| 0              | 0              | 0              | 1              | 0              | 0              | 0              | 1              |
| 0              | 0              | 1              | 0              | 0              | 0              | 1              | 1              |
| 0              | 0              | 1              | 1              | 0              | 0              | 1              | 0              |
| 0              | 1              | 0              | 0              | 0              | 1              | 1              | 1              |
| 0              | 1              | 0              | 1              | 0              | 1              | 1              | 0              |
| 0              | 1              | 1              | 0              | 0              | 1              | 0              | 0              |
| 0              | 1              | 1              | 1              | 0              | 1              | 0              | 1              |
| 1              | 0              | 0              | 0              | 1              | 1              | 1              | 1              |
| 1              | 0              | 0              | 1              | 1              | 1              | 1              | 0              |
| 1              | 0              | 1              | 0              | 1              | 1              | 0              | 0              |
| 1              | 0              | 1              | 1              | 1              | 1              | 0              | 1              |
| 1              | 1              | 0              | 0              | 1              | 0              | 0              | 0              |
| 1              | 1              | 0              | 1              | 1              | 0              | 0              | 1              |
| 1              | 1              | 1              | 0              | 1              | 0              | 1              | 1              |
| 1              | 1              | 1              | 1              | 1              | 0              | 1              | 0              |



Gray code to Binary Converter (corresponding Boolean expressions)

$$\begin{aligned}
 b_0 &= g'_3g'_2g'_1g_0 + g'_3g'_2g_1g'_0 + g'_3g_2g'_1g'_0 + g'_3g_2g_1g_0 + g_3g'_2g'_1g'_0 + g_3g'_2g_1g_0 \\
 &\quad + g_3g_2g'_1g_0 + g_3g_2g_1g'_0 \\
 &= g'_3g'_2(g'_1g_0 + g_1g'_0) + g'_3g_2(g'_1g'_0 + g_1g_0) + g_3g'_2(g'_1g'_0 + g_1g_0) \\
 &\quad + g_3g_2(g'_1g_0 + g_1g'_0) \\
 &= g'_3g'_2(g_0 \oplus g_1) + g'_3g_2(g_0 \odot g_1) + g_3g'_2(g_0 \odot g_1) + g_3g_2(g_0 \oplus g_1) \\
 &= (g_0 \oplus g_1)(g_2 \odot g_3) + (g_0 \odot g_1)(g_2 \oplus g_3) \\
 &= g_3 \oplus g_2 \oplus g_1 \oplus g_0 \\
 b_1 &= g'_3g'_2g_1 + g'_3g_2g'_1 + g_3g_2g_1 + g_3g'_2g'_1 \\
 &= g'_3(g'_2g_1 + g_2g'_1) + g_3(g_2g_1 + g'_2g'_1) \\
 &= g'_3(g_2 \oplus g_1) + g_3(g_2 \odot g_1) \\
 &= g_3 \oplus g_2 \oplus g_1 \\
 b_2 &= g'_3g_2 + g_3g'_2 \\
 &= g_3 \oplus g_2 \\
 b_3 &= g_3
 \end{aligned}$$

## Decoders

- A decoder is a class of multiple-input, multiple-output combinational circuits
- It converts a set of input variables representing a code into a set of output variables representing a different code.
- Most common is  $n$  to  $2^n$  decoder.



### 2 to 4 Line Decoder



| Inputs |   | Output |       |       |       |
|--------|---|--------|-------|-------|-------|
| A      | B | $D_0$  | $D_1$ | $D_2$ | $D_3$ |
| 0      | 0 | 1      | 0     | 0     | 0     |
| 0      | 1 | 0      | 1     | 0     | 0     |
| 1      | 0 | 0      | 0     | 1     | 0     |
| 1      | 1 | 0      | 0     | 0     | 1     |

- Simplest form of decoder with 2 input lines and 4 output lines.
- Decoders can be used as minterm and maxterm generators.



# Encoder

- Convert one binary code to another
- Differ from decoders in that the number of input lines will be much more than the number of output lines
- Eg  $2^n : n$  encoder



## 4 : 2 Line Encoder



| Inputs         |                |                |                | Outputs        |                |
|----------------|----------------|----------------|----------------|----------------|----------------|
| Y <sub>3</sub> | Y <sub>2</sub> | Y <sub>1</sub> | Y <sub>0</sub> | A <sub>1</sub> | A <sub>0</sub> |
| 0              | 0              | 0              | 1              | 0              | 0              |
| 0              | 0              | 1              | 0              | 0              | 1              |
| 0              | 1              | 0              | 0              | 1              | 0              |
| 1              | 0              | 0              | 0              | 1              | 1              |

$$A_1 = Y_3 + Y_2$$

$$A_0 = Y_3 + Y_1$$

## 8 : 3 line encoder (Octal to Binary Encoder)



- Unlike a multiplexer that selects one individual data input line and then sends that data to a single output line or switch, **Digital Encoder** more commonly called a **Binary Encoder** takes ALL its data inputs one at a time and then converts them into a single encoded output.
- A binary encoder, is a multi-input combinational logic circuit that converts the logic level “1” data at its inputs into an equivalent binary code at its output.

## Priority Encoder

### Drawbacks of Normal Encoders –

- There is an ambiguity, when all inputs of encoder are equal to zero.
- If more than one input is active High, then the encoder produces an output, which may not be the correct code.

To overcome these difficulties, we should assign priorities to each input of encoder. Then, the output of encoder will be the code corresponding to the active High inputs, which has higher priority. This type of digital encoder is known commonly as a **Priority Encoder** or P-encoder

The priority encoder is an encoder with a priority function. If two or more inputs have the same value, then the output will be corresponding to the inputs having the highest priority.

## 4 : 2 Priority Encoder

| Inputs         |                |                |                | Output |   |
|----------------|----------------|----------------|----------------|--------|---|
| D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | B      | A |
| 0              | 0              | 0              | 0              | X      | X |
| 0              | 0              | 0              | 1              | 0      | 0 |
| 0              | 0              | 1              | X              | 0      | 1 |
| 0              | 1              | X              | X              | 1      | 0 |
| 1              | X              | X              | X              | 1      | 1 |

The four inputs D<sub>3</sub>, D<sub>2</sub>, D<sub>1</sub>, D<sub>0</sub> has a different priority.  
D<sub>3</sub> has the highest priority,  
whereas D<sub>0</sub> has the lowest priority.

When D<sub>3</sub> input is high, irrespective of other inputs,  
the output will be AB = 11.

When D<sub>3</sub> input is low, D<sub>2</sub> has the next higher priority.  
Irrespective of the other inputs, the output will be BA = 10.

When D<sub>3</sub> and D<sub>2</sub> inputs are low, D<sub>1</sub> takes the next higher priority.  
Irrespective of D<sub>0</sub> input, the output will be BA = 01.

|                               |                               | 00 | 01 | 11 | 10 |   |
|-------------------------------|-------------------------------|----|----|----|----|---|
|                               |                               | 00 | x  | 0  | 0  |   |
|                               |                               | 01 | 1  | 1  | 1  | 1 |
| D <sub>1</sub> D <sub>0</sub> | D <sub>2</sub> D <sub>1</sub> | 11 | 1  | 1  | 1  | 1 |
| D <sub>2</sub> D <sub>0</sub> | D <sub>3</sub> D <sub>2</sub> | 10 | 1  | 1  | 1  | 1 |

$B = D_2 + D_3$

|                               |                               | 00 | 01 | 11 | 10 |   |
|-------------------------------|-------------------------------|----|----|----|----|---|
|                               |                               | 00 | x  | 0  | 1  | 1 |
|                               |                               | 01 | 0  | 0  | 0  | 0 |
| D <sub>1</sub> D <sub>0</sub> | D <sub>2</sub> D <sub>1</sub> | 11 | 1  | 1  | 1  | 1 |
| D <sub>2</sub> D <sub>0</sub> | D <sub>3</sub> D <sub>2</sub> | 10 | 1  | 1  | 1  | 1 |

$A = D_3 + D_2 \bar{D}_1$



Ktunotes.in