

# Unit-2: COMBINATIONAL CIRCUIT

In combinational circuit, output depends upon only present state not on past output and no feedback path is connected from output to input



# DESIGN procedure to analyse any COMBINATIONAL CIRCUIT

Step 1: Determine no. of i/p and no. of o/p.

Step 2: Draw the truth table

Step 3: Now with the help of Boolean Algebra or K-Map, determine minimized value of every output which is  $f^n$  of i/p

Step 4: Now with the help of Logic Gates draw every o/p w.r.t i/p

# HALF ADDER

| i/p |   | o/p |      |
|-----|---|-----|------|
| a   | b | s   | cout |
| 0   | 0 | 0   | 0    |
| 0   | 1 | 1   | 0    |
| 1   | 0 | 1   | 0    |
| 1   | 1 | 0   | 1    |



$$S = a \oplus b$$

$$\text{cout} = a \cdot b$$



Q. Implement half adder by using min. no. of NAND gates.

5 Gates



## # HALF SUBTRACTER

| $i/p$ | $o/p$ | $i/p$ | $o/p$ | $i/p$ | $HS$ | $o/p$ | $o/p$ |
|-------|-------|-------|-------|-------|------|-------|-------|
| a     | b     | 0     | Bout  | b     |      |       | Bout  |
| 0     | 0     | 0     | 0     |       |      |       |       |
| 0     | 1     | 1     | 1     |       |      |       |       |
| 1     | 0     | 1     | 0     |       |      |       |       |
| 1     | 1     | 0     | 0     |       |      |       |       |



Q. Implement half subtracter by using min. no. of NAND gates

5 Gates



## # FULL ADDER

In half adder, it does not add carry, it simply adds 2 single bits and this problem is eliminated by full adder.

| i/p<br>a<br>b<br>c | i/p<br>S<br>cout | a<br>b<br>c | F A | i/p<br>S<br>cout |
|--------------------|------------------|-------------|-----|------------------|
| 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              |             |     |                  |

$$S = \sum m(1, 2, 4, 7) = a \oplus b \oplus c$$

$$\text{Cout} = \sum m(3, 5, 6, 7) = ab + bc + ca$$

|   | bc | 00 | 01 | 11 | 10 |
|---|----|----|----|----|----|
| a | 0  | .  | .  | 1  | 0  |
|   | 1  | 1  | 1  | 1  | 1  |
|   | 1  | 1  | 1  | 1  | 1  |
|   | 1  | 1  | 1  | 1  | 1  |

$$bc + ac + ab$$

\* sum of full adder will be high, when total no. of ~~one~~ 1's at i/p are odd. Hence XOR exp.

\* Cout will be high, when there are two or more 1's in i/p.

Minimum no. of NAND gates = 9





Q. Implement full adder by using half adder and logic gates.



$$s = a \oplus b \oplus \text{cin}$$

$$\text{cout} = \sum m(3, 5, 6, 7)$$

011 101 110 111

$$\begin{aligned}\text{cout} &= \bar{a}b\text{cin} + a\bar{b}\text{cin} + ab\bar{\text{cin}} \\ &= (\bar{a}b + \bar{b}a)\text{cin} + ab(\bar{\text{cin}} + \text{cin}) \\ &= (a \oplus b)\text{cin} + ab\end{aligned}$$

## # FULL SUBTRACTER

$a - (b + \text{bin})$

|         |              |     |                  |
|---------|--------------|-----|------------------|
| $a - b$ | $\text{bin}$ | $D$ | $B_{\text{out}}$ |
|---------|--------------|-----|------------------|

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



$$D = \sum m(1, 2, 4, 7)$$

$$= a \oplus b \oplus \text{bin}$$

$$B_{\text{out}} = \sum m(1, 2, 3, 7)$$

$$= \bar{a}b + b\text{bin} + \text{bin}\bar{a}$$

|   | bbin | 00 | 01 | 11 | 10 |
|---|------|----|----|----|----|
| a | 0    | 1  | 1  | 0  | 0  |
| b | 0    | 0  | 1  | 1  | 0  |
|   | 1    | 0  | 0  | 1  | 1  |

$$\bar{a}b + b\text{bin} + \text{bin}\bar{a}$$

Q. Implement full subtractor by using half subtracter and logic gate.



### # 4 BIT PARALLEL BINARY ADDER



gmp.

\* To implement n-bit full adder we require  $(n-1)$  full adder and 1 half adder or  $n$  full adders



If  $\text{sub/add} = 0$ , it works as 4 bit 11el adder  
 $= 1$ , it works as 4 bit 11el sub

Q. Minimum no. of half adder and or gates to implement 8 bit 1's complement subtracter.

$8 \text{ FA} \Rightarrow 16 \text{ HA} + 8 \text{ OR Gate}$

## # BCD ADDER

In this if  $\text{sum} > g$  add 6

| $s_1$ | $(cout)$ | $s_3$ | $s_2$ | $s_1$ | $s_0$ |
|-------|----------|-------|-------|-------|-------|
| 0     | 0        | 0     | 0     | 0     | 0     |
| 1     | 0        | 0     | 0     | 0     | 1     |
| 2     | 0        | 0     | 0     | 1     | 0     |
| 3     | 0        | 0     | 0     | 1     | 1     |
| 4     | 0        | 0     | 1     | 0     | 0     |
|       |          | 0     | 1     | 0     | 1     |

|    |   |   |   |   |
|----|---|---|---|---|
| 8  | 0 | 1 | 0 | 0 |
| 9  | 0 | 1 | 0 | 1 |
| 10 | 1 | 0 | 0 | 0 |
| 11 | 1 | 0 | 0 | 1 |
| 12 | 1 | 0 | 0 | 1 |
| 13 | 1 | 0 | 0 | 1 |
| 14 | 1 | 0 | 1 | 0 |
| 15 | 1 | 0 | 1 | 0 |

$$S = \sum m(10, 11, 12, 13, 14, 15)$$

$$S = f(S_3, S_2, S_1, S_0)$$



$$S = S_3 S_2 + S_3 S_1$$

$$\begin{array}{c} \text{1st 11cl} \\ \text{add eq} \end{array} \left\{ \begin{array}{cccc} a_3 & a_2 & a_1 & a_0 \\ b_3 & b_2 & a_1 & b_0 \end{array} \right.$$

$$\begin{array}{c}
 \text{2nd 11cl} \\
 \text{adder} \\
 \text{cout}
 \end{array}
 \left\{
 \begin{array}{ccccc}
 C_0 & S_3 & S_2 & S_1 & S_0 \\
 0 & 0 & 0 & 0 & \text{if } \\
 \text{or} & 0 & 1 & 1 & 0 \\
 \hline
 S_3' & S_2' & S_1' & S_0' & \text{if } > 9 \\
 & & & & \text{or } C_0 = 0
 \end{array}
 \right.$$



## # 3 BIT PARITY GENERATOR

We check at output either there is even parity or odd parity

| a | b | c | $P_G$ (even) |
|---|---|---|--------------|
|---|---|---|--------------|

|   |   |   |   |
|---|---|---|---|
| 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 |
|---|---|---|---|

$$P_G = \sum m(1, 2, 4, 7)$$

$$= a \oplus b \oplus c$$



## # PARITY CHECKER

1 Parity bit is added with message signal and we check whether there is any error or not at output for even parity or odd parity.

| a | b | c | p | $P_c$ (even) |
|---|---|---|---|--------------|
|---|---|---|---|--------------|

|   |   |   |   |   |
|---|---|---|---|---|
| 0 | 0 | 0 | 0 | 0 |
|---|---|---|---|---|

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

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

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

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

|   |   |   |   |   |
|---|---|---|---|---|
| 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 ✓ |
|---|---|---|---|-----|

$$P_c = \sum m(1, 2, 4, 7, 8, 11, 13, 14)$$

$$= a \oplus b \oplus c \oplus p$$



# MAGNITUDE COMPARATOR  
It compares 2 no. and gives 3 output  
 $a > b$ ,  $a = b$  and  $a < b$ .

### 1 Bit Magnitude Comparators

| i/p |   | output  |         |         |
|-----|---|---------|---------|---------|
| a   | b | $a > b$ | $a = b$ | $a < b$ |
| 0   | 0 | 0       | 1       | 0       |
| 0   | 1 | 0       | 0       | 1       |
| 1   | 0 | 1       | 0       | 0       |
| 1   | 1 | 0       | 1       | 0       |

$$f_{a>b} = a \cdot \bar{b}$$

$$f_{a=b} = a \oplus b$$

$$f_{a<b} = \bar{a} \cdot b$$

### 2 Bit Magnitude Comparator

It compares 2 bits of a + b

|    | $a_1$ | $a_0$ | $b_1$ | $b_0$ | $f_{a>b}$ | $f_{a=b}$ | $f_{a<b}$ |
|----|-------|-------|-------|-------|-----------|-----------|-----------|
| 0  | 0     | 0     | 0     | 0     | 0         | 1         | 0         |
| 1  | 0     | 0     | 0     | 1     | 0         | 0         | 1         |
| 2  | 0     | 0     | 1     | 0     | 0         | 0         | 1         |
| 3  | 0     | 0     | 1     | 1     | 0         | 0         | 1         |
| 4  | 0     | 1     | 0     | 0     | 1         | 0         | 0         |
| 5  | 0     | 1     | 0     | 1     | 0         | 1         | 0         |
| 6  | 0     | 1     | 1     | 0     | 0         | 0         | 1         |
| 7  | 0     | 1     | 1     | 1     | 0         | 0         | 1         |
| 8  | 1     | 0     | 0     | 0     | 1         | 0         | 0         |
| 9  | 1     | 0     | 0     | 1     | 1         | 0         | 0         |
| 10 | 1     | 0     | 1     | 0     | 0         | 1         | 0         |
| 11 | 1     | 0     | 1     | 1     | 0         | 0         | 1         |
| 12 | 1     | 1     | 0     | 0     | 1         | 0         | 0         |
| 13 | 1     | 1     | 0     | 1     | 1         | 0         | 0         |
| 14 | 1     | 1     | 1     | 0     | 0         | 0         | 0         |
| 15 | 1     | 1     | 1     | 1     | 0         | 0         | 0         |

$$f_{a \oplus b} = \sum m(4, 8, 9, 12, 13, 14) = \bar{a}_1 \bar{b}_1 + a_0 b_1 \bar{b}_0 + a_1 a_0 \bar{b}_0$$

$$f_{a=b} = \sum m(0, 5, 10, 15)$$

$$f_{a \otimes b} = \sum m(1, 2, 3, 6, 7, 11) = \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          |    |    |    |    |
| 01         |            |    |    |    |    |
| 11         |            | 1  |    |    |    |
| 10         | 1          | 1  |    |    |    |

| $a_1, a_0$ | $b_1, b_0$ | 00 | 01 | 11 | 10 |
|------------|------------|----|----|----|----|
| 00         | 1          |    |    |    |    |
| 01         |            |    |    |    |    |
| 11         |            | 1  |    |    |    |
| 10         |            |    |    | 1  |    |

$$f_{a=b} = \sum m = (0, 5, 10, 15)$$

$$= \bar{a}_1 \bar{a}_0 \bar{b}_1 \bar{b}_0 + \bar{a}_1 a_0 \bar{b}_1 b_0 + a_1 \bar{a}_0 b_1 \bar{b}_0 + a_1 a_0 b_1 b_0$$

$$= \bar{a}_1 \bar{b}_1 (\bar{a}_0 \bar{b}_0 + a_0 b_0) + a_1 b_1 (\bar{a}_0 \bar{b}_0 + a_0 b_0)$$

$$= \bar{a}_1 \bar{b}_1 (a_0 \odot b_0) + a_1 b_1 (a_0 \odot b_0)$$

$$= (\bar{a}_1 \bar{b}_1 + a_1 b_1) (a_0 \odot b_0)$$

$$= (a_1 \odot b_1) (a_0 \odot b_0)$$

## # MULTIPLEXER



It has many i/p and only one o/p and it connects only one i/p with o/p depending upon the value of selected lines. That's why it is also called data selector or many to one logic circuit or parallel to serial converter.

| MUX  | i/p | s-lines | o/p |
|------|-----|---------|-----|
| 2:1  | 2   | 1       | L   |
| 4:1  | 4   | 2       | L   |
| 8:1  | 8   | 3       | L   |
| 16:1 | 16  | 4       | L   |

## # 4:1 MUX

i/p      sL      o/p  
 4:1       $I_0 - I_3$        $S_1, S_0$       Y

$S_1 \quad S_0 \quad Y$

0    0     $I_0$

0    1     $I_1$

1    0     $I_2$

1    1     $I_3$

$$Y = \bar{S}_1 \bar{S}_0 I_0 + \bar{S}_1 S_0 I_1 + S_1 \bar{S}_0 I_2 + S_1 S_0 I_3$$



Q. Implement  $f = \sum m(1, 2, 3, 7)$  by using 8 to 1 MUX



$$f = \bar{A}\bar{B}C I_1 + \bar{A}B\bar{C} I_2 + \bar{A}B C I_3 + ABC I_7$$

In Multiplexer, output is in S.O.P. form and all the minterms given in  $f$  are connected to  $+5V$  and remaining terms are connected to GND and only one output is possible in one time.

Q. Implement full adder by using 8:1 MUX  
 $f(A, B, Cin) = \sum m(1, 2, 4, 7)$



$$S = ABC_{in} I_1 + A\bar{B}C_{in} I_2 + \bar{A}BC_{in} I_4 + ABC_{in} I_7$$



$$\text{cout} = A\bar{B}C_{in} I_3 + \bar{A}BC_{in} I_5 + \bar{A}B\bar{C}_{in} I_6 + ABC_{in} I_7$$

Q. Implement  $f_{a=b}$  of 2 bit Magnitude comparator by using 16:1 MUX.



Q. Implement NOT gate using 2:1 MUX



Q. Implement  $f_1 = \sum m(1, 3, 5, 7)$ ,  $f^n$  of ABC



|           |              |              |              |              |
|-----------|--------------|--------------|--------------|--------------|
| $\bar{C}$ | (0)          | 2            | 4            | 6            |
| $C$       | (1)          | (3)          | (5)          | 7            |
|           | $\uparrow L$ | $\uparrow C$ | $\uparrow C$ | $\uparrow O$ |
|           | $I_0$        | $I_1$        | $I_2$        | $I_3$        |



Q. Implement full adder by using 4:1 mux.  
(if  $B + C$  are selected lines)

$$S = \sum m(1, 2, 4, 7)$$

$$\text{Cout} = \sum m(3, 5, 6, 7)$$

|            |            |            |            |            |
|------------|------------|------------|------------|------------|
| $\bar{A}$  | 0          | (1)        | (2)        | 3          |
| A          | (4)        | 5          | 6          | (7)        |
|            | <hr/>      |            |            |            |
| A          | $\bar{A}$  | $\bar{A}$  | $\bar{A}$  | A          |
| $\uparrow$ | $\uparrow$ | $\uparrow$ | $\uparrow$ | $\uparrow$ |
| $I_0$      | $I_1$      | $I_2$      | $I_3$      |            |



Q. Implement  $f = \sum m(3, 5, 7, 9, 10, 13, 15)$  by using 8:1 MUX

|           |   |     |      |           |    |      |    |      |
|-----------|---|-----|------|-----------|----|------|----|------|
| $\bar{A}$ | 0 | 1   | 2    | (3)       | 4  | (5)  | 6  | (7)  |
| $A$       | 8 | (9) | (10) | 11        | 12 | (13) | 14 | (15) |
|           | 0 | A   | A    | $\bar{A}$ | 0  | 1    | 0  | 1    |



Q. In the following MUX circuit, what will be value of  $f^m$  in maximum



|           |     |     |     |     |      |      |    |      |
|-----------|-----|-----|-----|-----|------|------|----|------|
| $\bar{A}$ | (0) | (1) | (2) | (3) | (4)  | (5)  | 6  | 7    |
| $A$       | 8   | 9   | 10  | 11  | (12) | (13) | 14 | (15) |

$$f = \prod m(8, 9, 10, 11, 14, 6, 7)$$

Q. Minimum no. of 2: MUX req. to implement Half Adder.

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

$$S = \sum m(1, 2)$$

$$C_{out} = \sum m(3)$$



$$\begin{array}{r} 0 \quad (1) \\ (2) \quad 3 \\ \hline a \quad \bar{a} \end{array} \quad \begin{array}{r} 0 \quad 1 \\ 2 \quad (3) \\ \hline 0 \quad a \end{array}$$

3, 2: MUX required

## # MULTIPLEXER TREE

Q. Implement 16:1 MUX by using 4:1 MUX



$$\begin{aligned} 16:1 &\rightarrow 4:1 \\ \frac{16}{4} &= 4 \\ 4 &= 4:1 + 4:1 = 5 \end{aligned}$$

Date: 10/20/2023

Q. Implement 16:1 MUX by using 8:1 MUX and 2:1 MUX

$$16:1 \rightarrow 8:1$$

$$\frac{16}{8} = \frac{2}{1}$$



Q. Determine total no. of 4:1 MUX required to implement 256:1 MUX

$$\frac{256}{4} = \frac{64}{4} + \frac{16}{4} + \frac{4}{4} + \frac{1}{4} = 85, \text{ 4:1 MUX}$$

Q. Determine output  $f^m$  in the following circuit



$$S_0 = \bar{C}B + C \cdot 0 \\ = B\bar{C}$$

$$f = \bar{S}_0 \bar{A} + S_0 \cdot 1 \\ = \bar{B}\bar{C}\bar{A} + B\bar{C} \\ = (\bar{B}\bar{C} + B\bar{C})(\bar{A} + B\bar{C}) \\ = \bar{A} + B\bar{C}$$

# # DEMULTIPLEXER (DEMUX)

Reverse process of MUX. It has only one i/p and many o/p



1:4 DEMUX



| $S_1$ | $S_0$ | $Y_3$ | $Y_2$ | $Y_1$ | $Y_0$ |
|-------|-------|-------|-------|-------|-------|
| 0     | 0     | 0     | 0     | 0     | I     |
| 0     | 1     | 0     | 0     | 1     | 0     |
| 1     | 0     | 0     | 1     | 0     | 0     |
| 1     | 1     | 1     | 0     | 0     | 0     |

$$Y_0 = \bar{S}_1 \bar{S}_0 I$$

$$Y_1 = \bar{S}_1 S_0 I$$

$$Y_2 = S_1 \bar{S}_0 I$$

$$Y_3 = S_1 S_0 I$$



IMPLEMENTATION of any  $f^n$  using DMUX

Connect all the minterms (outputs) to input of OR gate which are given in  $f^n$  and leave remaining minterms and leave which are not given in  $f^n$ .

Q Implement  $Y = \sum m(1, 2, 5, 7)$  by using 1:8DMUX and this  $f^n$  is dependent upon ABC variable.



Q. Implement full adder using 1:8 DMUX

$$S = \sum m(1, 2, 4, 7)$$



Q. Implement 1:16 DMUX by using 1:4 DMUX

$$\frac{16}{4} = \frac{4}{4} + \frac{1}{4} = 1 + 1 = 2 = 1:4 \text{ DMUX required.}$$



## DECODER

It converts  $m$  lines to  $2^m$  lines. i.e.

It has  $m$  inputs and  $2^m$  outputs.

It has one enable line. Decoder will only work if enable line is activated. e.g.  $2:4, 3:8, 4:16$   
 $\uparrow$   
 $5:32$

## 2:4 DECODER

|                | E           | I <sub>0</sub> | I <sub>1</sub> | Y <sub>0</sub> | Y <sub>1</sub> | Y <sub>2</sub> | Y <sub>3</sub> |
|----------------|-------------|----------------|----------------|----------------|----------------|----------------|----------------|
| I <sub>0</sub> | 1           | 0              | 0              | 0              | 0              | 0              | 1              |
| i/p            | 2:1 Decoder | Y <sub>1</sub> | 1              | 0              | 1              | 0              | 0              |
| I <sub>1</sub> | E           | Y <sub>2</sub> | 1              | 1              | 0              | 0              | 0              |
|                |             | Y <sub>3</sub> | 1              | 1              | 1              | 1              | 0              |

Active High 2:4 Decoder  
 $0 \quad x \quad x \quad$  Not Working

$$Y_0 = \overline{I}_0 \overline{I}_1 E \quad Y_1 = \overline{I}_1 \overline{I}_0 E \quad Y_2 = I_1 \overline{I}_0 E \quad Y_3 = I_1 I_0 E$$



Q. Implement full adder by using 3:8 Decoder.



2:4 Active LOW DECODER

In this decoder will only work when value of enable line is 0.

| $\bar{E}$ | $I_1$ | $I_0$ | $y_3$       | $y_2$ | $y_1$ | $y_0$ |
|-----------|-------|-------|-------------|-------|-------|-------|
| 0         | 0     | 0     | 1           | 1     | 1     | 0     |
| 0         | 0     | 1     | 1           | 1     | 0     | 1     |
| 0         | 1     | 0     | 1           | 0     | 1     | 1     |
| 0         | 1     | 1     | 0           | 1     | 1     | 1     |
| 1         | x     | x     | not working |       |       |       |

Q. Implement  $f = \sum m(1, 2, 5, 7)$  by using 3:8 active low decoder.



$$f = \sum m(1, 2, 5, 7)$$

$$f = \overline{\overline{y}_1 + y_2 + y_5 + y_7}$$

$$= \overline{\overline{y}_1} \cdot \overline{y_2} \cdot \overline{y_5} \cdot \overline{y_7}$$

In active low decoder connect output with NAND gate

Q. Implement full subtractor by using active low  
(-ve logic) 3:8 decoder. 01/09/17



Q. What will be value of  $f_1$  and  $f_2$  in the following circuit



Q. Implement 3:8 decoder by using 2:4 and 1:2 decoder

$$\frac{8}{4} = \underset{2}{\textcircled{2}} = \underset{2}{\textcircled{1}}$$



# # ENCODER

Reverse process of decoder. It converts  
2<sup>m</sup> lines into m lines.

e.g. 4:2, 8:3 (Octal to Binary Encoder), 16:4  
(Hexadecimal to Binary Encoder).

## 8:3 ENCODER



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

$$Y_2 = I_4 + I_5 + I_6 + I_7$$

$$Y_1 = I_2 + I_3 + I_6 + I_7$$

$$Y_0 = I_1 + I_3 + I_5 + I_7$$



## # PRIORITY ENCODER

In octal to binary encoder, if at one time, more than one i/p are high or if all i/p are low we do not get any output and this problem is avoided by priority encoder. In this we set highest priority to that no. which has highest binary value.

| $D_3$ | $D_2$ | $D_1$ | $D_0$ | $Y_2$ | $Y_1$ | $\Sigma d(0)$ |
|-------|-------|-------|-------|-------|-------|---------------|
| 1     | x     | x     | x     | 1     | 1     | 1             |
| 0     | 1     | x     | x     | 1     | 0     | 1             |
| 0     | 0     | 1     | x     | 0     | 1     | 1             |
| 0     | 0     | 0     | 1     | 0     | 0     | 1             |
| 0     | 0     | 0     | 0     | x     | x     | 0             |

$$\Sigma d(0) = D_3 + D_2 + D_1 + D_0$$

$$Y_2 = \pi M(1, 2, 3) + \sum d(0)$$

$$Y_1 = \pi M(1, 4, 5, 6, 7) + \sum d(0)$$

| $D_3$ | $D_2$ | $D_1$ | $D_0$ |    |
|-------|-------|-------|-------|----|
| 00    | 00    | 01    | 11    | 10 |
| 01    | 01    | 00    | 10    | 11 |
| 11    | 12    | 13    | 15    | 14 |
| 10    | 8     | 7     | 9     | 10 |



$$Y_1 = (D_3 + D_1) (D_3 + \bar{D}_2)$$

$$= D_3 + D_1 \bar{D}_2$$

| $D_3$ | $D_2$ | $D_1$ | $D_0$ |    |
|-------|-------|-------|-------|----|
| 00    | 00    | 01    | 11    | 10 |
| 01    | 01    | 00    | 10    | 11 |
| 11    |       |       |       |    |
| 10    |       |       |       |    |

$$Y_2 = D_3 + D_2$$

## 2 BIT BINARY MULTIPLIER



PLA (Programmable LOGIC Array)

In this both AND + OR array are programmable



AND arrays are followed by OR arrays.

PAL (Programmable array LOGIC)

In this programmable AND arrays are followed by fixed OR arrays



Q. Implement the following  $f'$  by using PLA & PAL

$$f' = \bar{A}BC + ABC$$

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

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


Q. Implement  $f_1 = \sum m(0, 1, 2)$   
 $f_2 = \sum m(2, 3)$  by PLA

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

$$f_2 = A\bar{B} + AB$$

A      B

A       $\bar{A}$       B       $\bar{B}$

Using  
PLA



A      B

Using  
PAL



# E-PROM [ROM]



$m$  = total address lines  
 $N$  = length of data bus

Q. Design full adder by using ROM

In ROM both AND arrays and OR arrays are fixed and with the help of decoder we can implement any  $f^n$ .

$$S = \sum m(1, 2, 4, 7)$$

$$\text{Cont} = \sum m(2, 3, 5, 6, 7)$$



## CODE CONVERTER

Converts one code into another code.

Q. Design a code converter of 4 Bits which converts binary code into Grey code

| $B_3$ | $B_2$ | $B_1$ | $B_0$ | $G_3$ | $G_2$ | $G_1$ | $G_0$ |
|-------|-------|-------|-------|-------|-------|-------|-------|
| 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| 0     | 0     | 0     | 1     | 0     | 0     | 0     | 1     |
| 0     | 0     | 0     | 0     | 0     | 0     | 1     | 1     |
| 0     | 0     | 1     | 0     | 0     | 0     | 1     | 0     |
| 0     | 0     | 1     | 1     | 0     | 0     | 1     | 0     |
| 0     | 1     | 0     | 0     | 0     | 1     | 1     | 0     |
| 0     | 1     | 0     | 1     | 0     | 1     | 0     | 1     |
| 0     | 1     | 1     | 0     | 0     | 1     | 0     | 0     |
| 0     | 1     | 1     | 1     | 0     | 1     | 0     | 0     |
| 1     | 0     | 0     | 0     | 1     | 1     | 0     | 1     |
| 1     | 0     | 0     | 1     | 1     | 1     | 1     | 1     |
| 1     | 0     | 1     | 0     | 1     | 1     | 1     | 0     |
| 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_3 = B_3$$

$$G_2 = B_3 \oplus B_2$$

$$G_1 = B_2 \oplus B_1$$

$$G_0 = B_1 \oplus B_0$$



## SEVEN SEGMENT CODE :



| BCD  | a | b | c | d | e | f  | g |
|------|---|---|---|---|---|----|---|
| 0000 | 1 | 1 | 1 | 1 | 1 | 1  | 0 |
| 0001 | 0 | 1 | 1 | 0 | 0 | 0  | 0 |
| 0010 | 1 | 1 | 0 | 1 | 1 | 0. | 1 |
| 0011 | 1 | 1 | 1 | 1 | 0 | 0  | 1 |
| 0100 | 0 | 1 | 1 | 0 | 0 | 1  | 1 |
| 0101 | 1 | 0 | 1 | 1 | 0 | 1  | 1 |
| 0110 | 1 | 0 | 1 | 1 | 1 | 1  | 1 |
| 0111 | 1 | 1 | 1 | 0 | 0 | 0  | 0 |
| 1000 | 1 | 1 | 1 | 1 | 1 | 1  | 1 |
| 1001 | 1 | 1 | 1 | 1 | 1 | 1  | 1 |
| 1010 | 1 | 1 | 1 | 0 | 0 | 1  | 1 |

Q. Seven Segment has two push buttons  $P_1$  and  $P_2$ , when a button is pressed the penize of displayed in Seven Segment display.

If no buttons are pressed 0 is displayed.

If  $P_1$  is pressed but  $P_2$  not 2 is displayed.

If  $P_2$  is pressed only 5 is displayed.

If both are pressed there is error and it signifying by E.

\* If segment a to g are considered with option is correct

a)  $g = \bar{P}_1 + P_2$ ,  $d = c + e$

c)  $g = P_1 + P_2$   $d = c + e$

b)  $g = P_1 + P_2$ ,  $e = b + c$

\* Minimum no. of NOT & OR gates are required to design this display.

| $P_1$ | $P_2$ | a | b | c | d | e | f | g |
|-------|-------|---|---|---|---|---|---|---|
| 0     | 0     | 1 | 1 | 1 | 1 | 1 | 1 | 0 |
| 0     | 1     | 1 | 0 | 1 | 1 | 0 | 1 | 1 |
| 1     | 0     | 0 | 1 | 0 | 1 | 1 | 0 | 1 |

$$a = \underline{L}$$

$$b = \underline{P_2}$$

$$c = \underline{P_1}$$

$$e = P_1 + \bar{P}_2$$

$$f = \bar{P}_1 + P_2$$

$$g = P_1 \cap P_2$$

$$d = \underline{\bar{P}_2} + P_1 + P_2$$

$$d = 1 + P_1 = 1$$

3 NOT 3 OR