

# Combinational Circuits

Combinational circuits:-

The o/p of a combinational circuit depends on present inputs only.

A combinational circuit consists of input variables, logic gates and output variables.

When logic gates are connected together to produce a specified output for certain specified combination of input variables with no storage involved. The resulting circuit is called combinational logic circuits.

In combinational logic the output variables are at all times dependent on the combination of input variables.



Analysis procedures:-

The analysis procedure of combinational circuits involves two major steps they are

- 1) To determine the boolean function
- 2) To construct the truth table.

To determine the boolean function:-

The sequence of steps involved in obtaining the boolean function is

Step-1:- Initially analyze the circuit based on logic gates. If the circuit consists of logic gates with absence of feedback path then the circuit is combinational circuit otherwise the circuit is a sequential circuit.

Step-2 :- Based on the input variables label the respective gate outputs with symbols and determine their boolean function.

Step-3 :- Step-2 is repeated until the boolean function for all the outputs are obtained

Step-4 :- finally determine the output boolean function in terms of input variables by substituting all the previously obtained boolean function.

To construct the truth table:-

The various steps involved in the construction of truth table.

Step-1 :- List the binary numbers based on the no. of input variables

Step-2 :- indicate the symbols labelled at the respective gates in the truth table.

Step-3 :- construct the truth table for the outputs of those gates that are the function of input variables.

Step-4 :- finally step-3 is repeated until the truth table for all the output is determined.

1. Obtain the boolean function for outputs of the given circuit.



| A | B | C | $y_1$ | $y_2$ | $y_3$ | $y_4$ | $y_5$ | $y_6$ | $y_7$ | $y_8$ | $F_1$ | $F_2$ |
|---|---|---|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| 0 | 0 | 0 | 0     | 0     | 0     | 0     | 1     | 0     | 1     | 1     | 0     | 0     |
| 0 | 0 | 1 | 0     | 1     | 0     | 0     | 1     | 1     | 1     | 1     | 0     | 1     |
| 0 | 1 | 0 | 0     | 0     | 1     | 1     | 0     | 1     | 1     | 0     | 1     | 0     |
| 0 | 1 | 1 | 0     | 0     | 1     | 0     | 1     | 1     | 1     | 0     | 1     | 0     |
| 1 | 0 | 0 | 0     | 0     | 0     | 0     | 1     | 1     | 1     | 1     | 0     | 1     |
| 1 | 0 | 1 | 0     | 1     | 1     | 1     | 0     | 1     | 1     | 1     | 0     | 1     |
| 1 | 1 | 0 | 0     | 0     | 1     | 1     | 1     | 1     | 1     | 1     | 0     | 1     |
| 1 | 1 | 1 | 1     | 0     | 1     | 1     | 0     | 1     | 0     | 0     | 0     | 0     |

## Design procedure:

The design of combinational circuit starts from the outline of the problem statement and ends in a logic circuit diagram on set of boolean functions from which the logic diagram can be easily obtain. The design procedure of the combinational circuit involved following steps.

- \* The problem definition.
  - \* The determination of number of available input variables and required output variables.
  - \* Assigning letter symbols to input and output variables.
  - \* The derivation of truth table indicating the relation between input and output variables.
  - \* Obtain simplified boolean expression for each output.
  - \* Obtain the logic diagram.
1. Design a combinational logic circuit variable that work with 3 input variables that will produce a logic one output when more than one input variables are logic one.

| A | B | C | y |
|---|---|---|---|
| 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 |



$$y = AC + AB + BC$$



### Adders:-

Digital computers perform various of information processing tasks one is arithmetic operation and the most basic arithmetic operation is the addition of two binary digits.

$$0+0=0$$

$$0+1=1$$

$$1+0=1$$

$$1+1=10$$

### Half Adder:-

It is a combinational circuit with two binary inputs (augend and addend) and two binary outputs (sum and carry). It adds the two inputs A and B and produces the sum (S) and the carry (C) bits.

| A | B | S | C |
|---|---|---|---|
| 0 | 0 | 0 | 0 |
| 0 | 1 | 1 | 0 |
| 1 | 0 | 1 | 0 |
| 1 | 1 | 0 | 1 |

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

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

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

$$C = AB$$

A half adder can be realized by using one ~~one~~ OR gate and AND gate



### Full Adder:

It is a combinational circuit that adds two bits and a carry and outputs are sum and carry.

A B C<sub>in</sub> Sum C<sub>out</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 |

|           |                 |                  |                  | Sum              |
|-----------|-----------------|------------------|------------------|------------------|
| B         | C <sub>in</sub> | BC <sub>in</sub> | BC <sub>in</sub> | BC <sub>in</sub> |
| A         |                 | 1                | 3                | 1                |
| $\bar{A}$ |                 | 0                | 1                | 2                |
| A         |                 | 1                | 1                | 1                |
|           |                 | 4                | 5                | 6                |

Sum :-

$$\bar{A} \bar{B} C_{in} + \bar{A} B \bar{C}_{in} + A \bar{B} \bar{C}_{in}$$

$$+ A B C_{in}$$

$$= C_{in} (\bar{A} \bar{B} + A B) + \bar{C}_{in} (\bar{A} B + A \bar{B})$$

$$= C_{in} (A \oplus B) + \bar{C}_{in} (A \oplus B)$$

$$\text{Sum} = A \oplus B \oplus C$$

Carry

|           |                 |                  |                  | Carry            |
|-----------|-----------------|------------------|------------------|------------------|
| B         | C <sub>in</sub> | BC <sub>in</sub> | BC <sub>in</sub> | BC <sub>in</sub> |
| A         |                 | 1                | 3                | 2                |
| $\bar{A}$ |                 | 0                | 1                | 4                |
| A         |                 | 1                | 1                | 5                |
|           |                 | 4                | 7                | 6                |

$$\text{Carry} = BC_{in} + AC_{in} + AB$$

$$\text{Carry} = \bar{A} B C_{in} + A \bar{B} C_{in} + A B \bar{C}_{in} + A B C_{in}$$

$$= C_{in} (\bar{A} B + A \bar{B}) + AB (\bar{C}_{in} + C_{in})$$

$$= C_{in} (A \oplus B) + AB$$



$$\text{Carry} = (A \oplus B)C_{in} + AB$$

$$\text{Cout} = (A \oplus B)C_{in} + AB$$



Logic diagram of a full adder using two half adders.

The block diagram of a full adder using two half adders.

Even though a full adder can be constructed using two half adders, the disadvantage is that the bits must propagate through several gates in succession, which makes the total propagation delay greater than that of the full adder circuit using AND-OR logic.

The full adder neither can also be realized using universal gates.

Using NAND logic

$$A \oplus B = \overline{\overline{A} \cdot \overline{B}} + \overline{A} \cdot \overline{\overline{B}}$$

$$\text{Sum} = A \oplus B \oplus C_{in}$$

$$= \overline{A \oplus B} \cdot \overline{A \oplus B} \cdot C_{in} + C_{in} \cdot \overline{(A \oplus B)C_{in}}$$



NOR gate

$$S = A \oplus B \oplus C_{in} = \overline{A \oplus B + C_{in}} + \overline{(A \oplus B)} + \overline{C_{in}}$$

$$\text{carry} = AB + C_{in}(A \oplus B)$$

$$= \overline{\overline{A} + \overline{B}} + \overline{C_{in}}(\overline{A} \oplus \overline{B})$$



## Subtractors:-

### Half Subtractor:-

It is a combinational circuit that subtract one bit from the other and produces the difference if it has also has an output to specify if a one has been borrowed. It has two inputs  $A$  and  $B$  and two outputs  $d$  and  $b$ .  $d$  indicates the difference and  $b$  is borrow.

| $A$ | $B$ | $d$ | $b$ |
|-----|-----|-----|-----|
| 0   | 0   | 0   | 0   |
| 0   | 1   | 1   | 1   |
| 1   | 0   | 1   | 0   |
| 1   | 1   | 0   | 0   |

| $A$ | $B$ | $\bar{B}$ | $B$ |
|-----|-----|-----------|-----|
| 0   | 0   | 1         | 0   |
| 1   | 0   | 0         | 1   |

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

| $\bar{A}$ | $\bar{B}$ | $B$ |
|-----------|-----------|-----|
| 0         | 0         | 1   |
| 1         | 2         | 3   |

$$b = \bar{A}B$$

$$d = \bar{A}B + A\bar{B} = A \oplus B, \quad b = \bar{A}B$$



NAND logic :-



NOR logic :-



Full Subtraction:-

It is a combinational circuit used to perform subtraction among 3 bits.



K-map for borrow:-

|           | Bbin         | $\bar{B}bin$ | $\bar{B}bin$ | Bbin |
|-----------|--------------|--------------|--------------|------|
| A         | $\bar{B}bin$ | 1            | 1            | 1    |
| $\bar{A}$ | 0            | 1            | 3            | 2    |
| A         | 4            | 5            | 7            | 6    |

$$\bar{A}bin + \bar{A}\bar{B} + Bbin$$

Based on truth tables :-  
(Borrow)

$$= \bar{A}\bar{B}bin + \bar{A}B\bar{bin} + A\bar{B}bin + ABbin$$

$$= bin(\bar{A}\bar{B} + AB) + \bar{A}B(bin + \bar{bin})$$

$$= bin(\bar{A} \oplus B) + \bar{A}B,$$

$$Diff = \bar{A}\bar{B}bin + \bar{A}B\bar{bin} + A\bar{B}bin + ABbin$$

Logic gate:-



Using Nand logic:-



K-map for diff :-

|           | Bbin         | $\bar{B}bin$ | Bbin | $\bar{B}bin$ |
|-----------|--------------|--------------|------|--------------|
| A         | $\bar{B}bin$ | 1            | 1    | 1            |
| $\bar{A}$ | 0            | 1            | 3    | 2            |
| A         | 1            | 4            | 5    | 6            |

$$\begin{aligned}
 & \bar{A}Bbin + \bar{A}B\bar{bin} + A\bar{B}bin + ABbin \\
 &= bin(\bar{A}\bar{B} + AB) + \bar{B}bin(\bar{A}B + A\bar{B}) \\
 &= bin(A \oplus B) + \bar{B}bin(A \oplus B) \\
 &= A \oplus B \oplus bin.
 \end{aligned}$$

NOR



## Binary adder :- / parallel adder

A single full adder is capable of adding two one bit numbers and an input carry in order to add binary numbers with more than one bit additional full adders must be employed. A n-bit parallel adder can be constructed using number of full adder circuit connected in parallel.



Block diagram of n-bit parallel adder.

It shows the block diagram of n-bit parallel adder using number of full adder circuits connected in cascade i.e. the carry output of each adder is connected to the carry input of the next higher order adder. It should be noted that either a half adder can be used for the least significant position or the carry input of a full adder is made zero because there is no carry into the least significant bit position.

1. Design a 4-bit parallel adder using full adder





Binary parallel adder ( $\sum$ ) (IC 74LS83, 74LS283)

Many high speed adders available in integrated circuit form utilize the look ahead carry or a similar technique for reducing overall propagation delays. It contains 4 interconnected full adders and the look ahead carry circuit is needed for high speed operation.



The 7483 and 74283 are a TTL (transistor to transistor logic) medium scale integrated circuit with same pin configuration. The inputs to this IC are two 4-bit numbers  $A_3, A_2, A_1, A_0$  and  $B_3, B_2, B_1, B_0$  and the carry  $C_{in}$  into the least significant bit position (LSB). The outputs are  $S_0, S_1, S_2, S_3$  and  $C_{out}$  output of the most significant bit position (MSB).

Design an 8-bit adder using two 74283



### Binary Subtractor (parallel subtractor):

The subtraction of binary numbers can be done most conveniently by means of complements. The subtraction of  $A+B$  can be done by taking the 2's complement of B and adding it to A.

The 2's complement can be obtained by adding the taking the 1's complement and adding 1 to the least significant pair of bits. The 1's complement can be implemented with invertors and a '1' can be added to the sum through the input carry as shown in the figure.



### Parallel adder/subtractor:-

The addition and subtraction operation can be combined into one circuit with one common binary adder. This is done by including an X-OR gate with each full adder.

The mode input 'M' controls the operation of the circuit. When  $M=0$ , the circuit is an adder and when  $M=1$ , the circuit becomes a subtractor. Each X-OR gate receives input M and one of the inputs of B. When  $M=0$ ,

We have  $B \oplus 0 = B$  the full adder receives the value of  $B$ . The input carry is '0' and the circuit performs  $A+B$ . When  $M=1$  we have  $B \oplus 1 = \bar{B}$  and  $C_{in}=1$  the B inputs are all complemented and a '1' is added through the input carry. The circuit performs the operation  $A$  plus the 2's complement of  $B$  i.e.  $A-B$



### Carry look ahead adder:-

In ripple carry adder as the number of bits increases the speed of the adder is decreased since the carry generated at LSB should be transmitted to MSB which causes delay in producing output, while in carry look ahead adder the adder does not wait for the previous of carry for calculation of sum bit so the speed reduces the delay in producing the output. Hence carry look ahead adder is faster than a ripple carry adder.

### Operation of carry look ahead adder:-

The circuit used to speedup the addition process by reducing the time during intermediate stage is referred as carry look ahead adder. The carry look ahead adder employs two functions namely 1) carry propagate  
2) carry generate

In order to define these functions the circuit of full adder is considered as shown in figure.



Carry propagate ( $P_i$ ) :-

The function of  $P_i$  is to determine whether a carry into stage ' $i$ ' propagates into stage  $i+1$ . From figure the expression of  $P_i$  can be written as  $A_i \oplus B_i = P_i$ .

Carry generate ( $G_i; G_i$ ) :-

The function of  $G_i$  is to generate a carry when inputs  $A_i, B_i$  are 1 from figure. The expression of  $G_i$  can be written as  $G_i = A_i \cdot B_i$ . The carry out  $C_{i+1}$  can be expressed as  $C_{i+1} = G_i + P_i C_i$  and output sum  $S_i$  if  $S_i = P_i \oplus C_i$  for different stages the boolean functions for carry outputs are

Stage ( $i$ )

$i=0$

$i=1$

$i=2$

Carryout  $C_{i+1}$

$$C_1 = G_0 + P_0 C_0$$

$$C_2 = G_1 + P_1 C_1$$

$$= G_1 + P_1 [G_0 + P_0 C_0]$$

$$= G_1 + P_1 G_0 + P_0 P_1 C_0$$

$$C_3 = G_2 + P_2 C_2$$

$$= G_2 + P_2 (G_1 + P_1 G_0 + P_0 P_1 C_0)$$

$$= G_2 + P_2 G_1 + P_1 P_2 G_0 + P_0 P_1 P_2 C_0$$

It is observe that The  $C_3$  does not contain  $C_2$  and  $C_1$  terms i.e the propagation time of  $C_3$  collaborates with the propagation time of  $C_2$  and  $C_1$  as a result the processing time is reduced thereby increasing the speed of operation.

The logic diagram of carry look ahead adder, can be implemented by using AND and OR gates as shown in figure.

$$C_1 = G_0 + P_0 C_0$$

$$C_2 = G_1 + P_1 G_0 + P_1 P_0 C_0$$

$$C_3 = G_2 + P_2 G_1 + P_1 P_2 G_0 + P_0 P_1 P_2 C_0$$



4-bit binary carry look ahead adder :-

The 4-bit carry look ahead adder employs X-OR and AND gates. Two X-OR gates and an AND gate are required to produce a single output. For instance if  $A_i$  and  $B_i$  are given as inputs to first X-OR gate and AND gate.

The output will be  $P_i$  and  $G_i$ ; the carries are generated using carry look ahead adder and then fed as an input to the second X-OR gate. This gate produces the corresponding sum.



BCD Adder :-

The digital system handles the decimal numbers in the form of binary coded decimal numbers. A BCD adder is a circuit that adds two BCD digits and produces a sum digit also in BCD. BCD numbers use 10-digits (0-9) which are represented in the binary form to (0000 to 1001). Adding 4-bit BCD code.

In 4-bit we have a maximum value upto 9. We can add maximum value upto  $9 + 9 + 1$ . Here '1' is the input carry  $19 \Rightarrow 9 + 9 + 1$

Case i :- Total is less than or equal to 9

$$\begin{array}{r} \text{Eg :- } 1 \rightarrow 0001 \\ \quad 5 \rightarrow 0101 \\ \hline \end{array}$$

$$0110 \rightarrow 6$$

upto 9 both BCD and binary are going to be same.

Case ii :- Total is greater than 9

$$5 - 0101$$

$$\text{Add } 6 - \underline{0110}$$

$$11 - \underline{1011} \rightarrow \text{Binary '1'}$$

$$5 - 0101$$

$$\text{Add } 6 - \underline{0110}$$

$$11 - \underline{1011}$$

$$+ 0110$$

$$\underline{00010001} \rightarrow \text{BCD '11'}$$

If value is greater than 9 i.e. 1001 we have to add 0110 to that value.

| Decimal | BCD |                |                |                   |   |
|---------|-----|----------------|----------------|-------------------|---|
|         | C   | S <sub>3</sub> | S <sub>2</sub> | S, S <sub>0</sub> |   |
| 0       | 0   | 0              | 0              | 0                 | 0 |
| 1       | 0   | 0              | 0              | 0                 | 1 |
| 2       | 0   | 0              | 0              | 1                 | 0 |
| 3       | 0   | 0              | 1              | 0                 | 1 |
| 4       | 0   | 0              | 0              | 0                 | 0 |
| 5       | 0   | 0              | 1              | 0                 | 1 |
| 6       | 0   | 0              | 1              | 1                 | 0 |
| 7       | 0   | 0              | 1              | 1                 | 1 |
| 8       | 0   | 0              | 1              | 0                 | 0 |
| 9       | 0   | 1              | 0              | 0                 | 1 |
| 10      | 1   | 0              | 0              | 0                 | 0 |
| 11      | 1   | 0              | 0              | 0                 | 1 |
| 12      | 1   | 0              | 0              | 1                 | 0 |
| 13      | 1   | 0              | 0              | 1                 | 0 |
| 14      | 1   | 0              | 0              | 1                 | 1 |
| 15      | 1   | 0              | 1              | 0                 | 0 |

From truth table if C=0 comes under case i so no change is required. If C=1 comes under case (ii) we have to add 0110 to the output. To find the relation we have to

find boolean function for 'c'

| $S_3 S_0$             | $\bar{S}_3 S_0$ | $\bar{S}_3 \bar{S}_0$ | $S_3 S_1$ | $\bar{S}_3 S_1$ |
|-----------------------|-----------------|-----------------------|-----------|-----------------|
| $S_3 S_2$             |                 |                       |           |                 |
| $\bar{S}_3 \bar{S}_2$ | 0               | 1                     | 3         | 2               |
| $\bar{S}_3 S_2$       | 4               | 5                     | 7         | 6               |
| $S_3 S_2$             | 1               | 1                     | 1         | 1               |
| $S_3 \bar{S}_2$       | 12              | 13                    | 15        | 14              |
|                       | 8               | 9                     | 11        | 10              |

$y = S_3 S_2 + S_3 S_1$



### Binary Multiplier:-

Binary multiplier is used to multiply two binary numbers. It is built using binary adders. The two numbers are known as multiplicand and multiplier and the result is known as product.

A  $\rightarrow$  Multiplicand

B  $\rightarrow$  Multiplier

$A \times B \rightarrow$  product.

Eg:-

$$\begin{array}{r} 0 \ 1 \ 1 \\ \times 1 \ 0 \ 0 \\ \hline 0 \ 0 \cdot 0 \end{array}$$

$$\begin{array}{r} 0 \ 1 \ 1 \\ \times 1 \ 0 \ 0 \\ \hline 0 \ 1 \ 1 \end{array} \leftarrow \text{left shift}$$

$$\begin{array}{r} 0 \ 1 \ 1 \\ \times 1 \ 0 \ 0 \\ \hline 1 \ 0 \ 0 \ 1 \ 0 \end{array} \leftarrow \text{left shift}$$

product

Multiplicand  $A = A_0 A_1$

Multiplier  $B = B_1 B_0$

$$P_0 = A_0 B_0$$

$$P_1 = A_1 B_0 + A_0 B_1$$

$P_2 = A_1 B_1 + \text{carry of } P_1$

$P_3 = \text{carry of } P_2$

$$\begin{array}{r} A_1 \quad A_0 \\ B_1 \quad B_0 \\ \hline A_1 B_0 \quad A_0 B_1 \\ + A_1 B_1 \quad A_0 B_0 \\ \hline \end{array}$$

$$P_3 \quad P_2 \quad P_1 \quad P_0$$

\* partial product - using AND gate

\* partial product, add - full adder / Half adder



4-bit binary multiplier :-

$$\begin{array}{r} A_3 \quad A_2 \quad A_1 \quad A_0 \\ B_3 \quad B_2 \quad B_1 \quad B_0 \\ \hline A_3 B_0 \quad A_2 B_0 \quad A_1 B_0 \quad A_0 B_0 \\ A_3 B_1 \quad A_2 B_1 \quad A_1 B_1 \quad A_0 B_1 \\ A_3 B_2 \quad A_2 B_2 \quad A_1 B_2 \quad A_0 B_2 \\ A_3 B_3 \quad A_2 B_3 \quad A_1 B_3 \quad A_0 B_3 \\ \hline P_7 \quad P_6 \quad P_5 \quad P_4 \quad P_3 \quad P_2 \quad P_1 \quad P_0 \end{array}$$

In order to implement  $4 \times 4$  binary multiplication we require 3 binary adders  $4 \times 4 = 16$  AND gates. The logic diagram of  $4 \times 4$  binary multiplier.

shown in figure.



### Magnitude comparators

A combinational circuit which compares magnitude of two binary numbers is called a comparator. It has 2 inputs and 3 outputs. If  $A$  and  $B$  are two inputs then there outputs are  $A > B$ ,  $A = B$ ,  $A < B$ . The truth table of 1 bit comparator as shown in below table

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

| <del>A</del> | <del>B</del> | $\bar{B}$ | B |
|--------------|--------------|-----------|---|
| $\bar{A}$    | 0            | 1         |   |
| A            | 1            | 0         | 3 |

| <del>A</del> | <del>B</del> | $\bar{B}$ | B |
|--------------|--------------|-----------|---|
| $\bar{A}$    | 0            | 1         |   |
| A            | 1            | 0         | 3 |

| <del>A</del> | <del>B</del> | $\bar{B}$ | B |
|--------------|--------------|-----------|---|
| $\bar{A}$    | 0            | 1         |   |
| A            | 2            | 3         |   |

$$A > B = A\bar{B}$$

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

$$= A\bar{B}$$

$$= \bar{A}\oplus B$$

$$A < B = \bar{A}B$$

Logic Diagram:-



Two-bit comparator.

| $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     | 0       | 0       | 1       |
| 0     | 0     | 1     | 0     | 0       | 0       | 1       |
| 0     | 0     | 1     | 1     | 0       | 0       | 1       |
| 0     | 1     | 0     | 0     | 1       | 0       | 0       |
| 0     | 1     | 0     | 1     | 0       | 1       | 0       |
| 0     | 1     | 1     | 0     | 0       | 0       | 1       |
| 0     | 1     | 1     | 1     | 0       | 0       | 1       |
| 1     | 0     | 0     | 0     | 1       | 0       | 0       |
| 1     | 0     | 0     | 1     | 0       | 1       | 0       |
| 1     | 0     | 1     | 0     | 0       | 1       | 0       |
| 1     | 0     | 1     | 1     | 0       | 0       | 1       |
| 1     | 1     | 0     | 0     | 1       | 0       | 0       |
| 1     | 1     | 0     | 1     | 0       | 1       | 0       |
| 1     | 1     | 1     | 0     | 1       | 0       | 0       |
| 1     | 1     | 1     | 1     | 0       | 1       | 0       |

$A > B$

|                       |           | $B_1 B_0$ | $\bar{B}_1 \bar{B}_0$ | $B_1 \bar{B}_0$ | $\bar{B}_1 B_0$ |
|-----------------------|-----------|-----------|-----------------------|-----------------|-----------------|
|                       |           | $A_1 A_0$ | $\bar{A}_1 \bar{A}_0$ | $\bar{A}_1 A_0$ | $A_1 \bar{A}_0$ |
| $A_1 A_0$             | $B_1 B_0$ | 0         | 1                     | 3               | 2               |
| $\bar{A}_1 \bar{A}_0$ | 1         | 4         | 5                     | 7               | 6               |
| $\bar{A}_1 A_0$       | 1         | 1         | 13                    | 15              | 14              |
| $A_1 \bar{A}_0$       | 1         | 1         | 9                     | 11              | 10              |

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

$+ \bar{B}_0 A_1 \bar{A}_0$

$A < B$

|                       |           | $B_1 B_0$ | $\bar{B}_1 \bar{B}_0$ | $B_1 \bar{B}_0$ | $\bar{B}_1 B_0$ |
|-----------------------|-----------|-----------|-----------------------|-----------------|-----------------|
|                       |           | $A_1 A_0$ | $\bar{A}_1 \bar{A}_0$ | $\bar{A}_1 A_0$ | $A_1 \bar{A}_0$ |
| $A_1 A_0$             | $B_1 B_0$ | 0         | 1                     | 3               | 2               |
| $\bar{A}_1 \bar{A}_0$ | 1         | 4         | 5                     | 7               | 6               |
| $\bar{A}_1 A_0$       | 1         | 1         | 13                    | 15              | 14              |
| $A_1 \bar{A}_0$       | 1         | 1         | 9                     | 11              | 10              |

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

$+ \bar{A}_0 B_1 B_0$

$A = B$

|                       |           | $B_1 B_0$ | $\bar{B}_1 \bar{B}_0$ | $B_1 \bar{B}_0$ | $\bar{B}_1 B_0$ |
|-----------------------|-----------|-----------|-----------------------|-----------------|-----------------|
|                       |           | $A_1 A_0$ | $\bar{A}_1 \bar{A}_0$ | $\bar{A}_1 A_0$ | $A_1 \bar{A}_0$ |
| $A_1 A_0$             | $B_1 B_0$ | 0         | 1                     | 3               | 2               |
| $\bar{A}_1 \bar{A}_0$ | 1         | 4         | 5                     | 7               | 6               |
| $\bar{A}_1 A_0$       | 1         | 1         | 13                    | 15              | 14              |
| $A_1 \bar{A}_0$       | 1         | 1         | 9                     | 11              | 10              |

$$\begin{aligned} A = B &\Rightarrow \\ &\bar{A}_1 \bar{B}_1 + \bar{B}_1 \bar{B}_0 + \bar{B}_0 \bar{A}_1 \bar{C}_0 \\ &+ A_1 A_0 B_1 B_0 + A_1 \bar{A}_0 B_1 \bar{B}_0 \\ &= \bar{A}_1 \bar{B}_1 (\bar{A}_0 B_0 + A_0 B_0) \\ &+ A_1 B_1 (A_0 B_0 + \bar{A}_0 \bar{B}_0) \\ &= \bar{A}_1 \bar{B}_1 (A_0 \odot B_0) \\ &+ A_1 B_1 (A_0 \odot B_0) \\ &= 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) \end{aligned}$$

$A_1$     $A_0$     $B_1$     $B_0$



H-bit comparator:-

| $A_3 B_3$   | $A_2 B_2$   | $A_1 B_1$   | $A_0 B_0$   | $A > B$ | $A = B$ | $A < B$ |
|-------------|-------------|-------------|-------------|---------|---------|---------|
| $A_3 = B_3$ | $A_2 > B_2$ |             |             | 1       | 0       | 0       |
| $A_3 = B_3$ | $A_2 = B_2$ | $A_1 > B_1$ |             | 1       | 0       | 0       |
| $A_3 = B_3$ | $A_2 = B_2$ | $A_1 = B_1$ | $A_0 > B_0$ | 1       | 0       | 0       |
| $A_3 = B_3$ | $A_2 = B_2$ | $A_1 = B_1$ | $A_0 = B_0$ | 0       | 1       | 0       |
| $A_3 = B_3$ | $A_2 = B_2$ | $A_1 = B_1$ | $A_0 < B_0$ | 0       | 0       | 1       |
| $A_3 < B_3$ |             |             |             | 0       | 0       | 1       |
| $A_3 = B_3$ | $A_2 < B_2$ |             |             | 0       | 0       | 1       |
| $A_3 = B_3$ | $A_2 = B_2$ | $A_1 < B_1$ |             | 0       | 0       | 1       |
| $A_3 = B_3$ | $A_2 = B_2$ | $A_1 = B_1$ | $A_0 < B_0$ | 0       | 0       | 1       |

→ It can be used to compare two four bit words.

→ The two 4-bits

It compare each of these bits in one number with bits in that of other number and produces one of the following outputs as  $A = B$ ,  $A < B$  and  $A > B$ . The output logic statements of this comparator are

- 1) If  $A_3 = 1$  and  $B_3 = 0$  then  $A > B$
- 2) If  $A_3$  and  $B_3$  are equal and  $A_2 = 1$ ,  $B_2 = 0$  then  $A > B$ .
- 3) If  $A_3$  and  $B_3$  are equal and  $A_2$  and  $B_2$  are equal and  $A_1 = 1$ ,  $B_1 = 0$  then  $A > B$ .
- 4) If  $A_3 = B_3$ ,  $A_2 = B_2$ ,  $A_1 = B_1$  and  $A_0 = 1$ ,  $B_0 = 0$  then  $A > B$ .

From the above statements the output logical expression can be written as

$$\text{Equal to} = (A_0 \oplus B_0) (A_1 \oplus B_1) (A_2 \oplus B_2) (A_3 \oplus B_3)$$

$$\text{Greater} = A_3 \overline{B}_3 + (A_3 \oplus B_3) A_2 \overline{B}_2 + (A_3 \oplus B_3) (A_2 \oplus B_2) A_1 \overline{B}_1$$

$$+ (A_3 \oplus B_3) (A_2 \oplus B_2) (A_1 \oplus B_1) A_0 \overline{B}_0$$

Less than =  $A_3 B_3 + (A_3 \oplus B_3) A_2 B_2 + (A_3 \ominus B_3)(A_2 \ominus B_2)$

$\bar{A}_1 B_1 + (A_3 \ominus B_3)(A_2 \ominus B_2) (A_1 \ominus B_1) \bar{A}_0 B_0$



The output of each comparator is based on the following logic:

$A > B$  if  $(A_3 \oplus B_3) A_2 B_2 + (A_3 \ominus B_3)(A_2 \ominus B_2) (A_1 \ominus B_1) \bar{A}_0 B_0$

$A = B$  if  $(A_3 \oplus B_3) (A_2 \oplus B_2) (A_1 \oplus B_1) (A_0 \oplus B_0)$

$A < B$  if  $(A_3 \ominus B_3) (A_2 \ominus B_2) (A_1 \ominus B_1) (A_0 \ominus B_0)$

Each bit comparison is based on the following logic:

$A_i > B_i$  if  $(A_i \oplus B_i) A_{i-1} B_{i-1} + (A_i \ominus B_i) (A_{i-1} \ominus B_{i-1}) \bar{A}_{i-2} B_{i-2}$

$A_i = B_i$  if  $(A_i \oplus B_i) (A_{i-1} \oplus B_{i-1}) (A_{i-2} \oplus B_{i-2}) \dots (A_1 \oplus B_1)$

$A_i < B_i$  if  $(A_i \ominus B_i) (A_{i-1} \ominus B_{i-1}) (A_{i-2} \ominus B_{i-2}) \dots (A_1 \ominus B_1)$



## Decoder:-

It is a combinational circuit that has  $n$  input lines and maximum of  $2^n$  output lines. One of these outputs will be active high based on the combination of inputs presents. When the decoder is enabled that means decoder detects a particular code. The outputs of the decoder are nothing but the minterms of  $n$  input variable lines. When it is enabled.



2-4 decoder



| Enable i/p | o/p |   |   | $Y_0$ |   |   |   |
|------------|-----|---|---|-------|---|---|---|
|            | E   | A | B | 0     | 1 | 2 | 3 |
| 0          | X   | X | X | 0     | 0 | 0 | 0 |
| 1          | 0   | 0 | 0 | 0     | 0 | 0 | 1 |
|            | 1   | 0 | 1 | 0     | 0 | 1 | 0 |
|            | 1   | 1 | 0 | 0     | 1 | 0 | 0 |
|            | 1   | 1 | 1 | 1     | 0 | 0 | 0 |

$$Y_3 = E \cdot A \cdot B$$

$$Y_2 = E \cdot A \cdot \bar{B}$$

$$Y_1 = E \cdot \bar{A} \cdot B$$

$$Y_0 = E \cdot \bar{A} \cdot \bar{B}$$

The outputs of 2 to 4 decoder are nothing but the minterms of two input variables A and B when enable is equal to 1. If enable is 0 the outputs of decoder will be equal to 0.



(74x138) 3 to 8 decoder

|   |                 | 16              | V <sub>cc</sub> |
|---|-----------------|-----------------|-----------------|
| 2 | A               | Y <sub>0P</sub> | 15              |
| 3 | B               | Y <sub>1P</sub> | 14              |
| 4 | C               | Y <sub>2P</sub> | 13              |
| 5 | enable pins     | Y <sub>3P</sub> | 12              |
| 6 | G <sub>1</sub>  | Y <sub>4P</sub> | 11              |
| 7 | G <sub>2A</sub> | Y <sub>5P</sub> | 10              |
| 8 | G <sub>2B</sub> | Y <sub>6P</sub> | 9               |
|   | GND             | Y <sub>7P</sub> | 7               |

It consists of 3 binary inputs A, B, C and when enable provides 8 individual active low outputs Y<sub>0</sub> - Y<sub>7</sub>. The device has 3 enable input pins too active low G<sub>2A</sub>, G<sub>2B</sub> that mean when ~~when~~ low signals are applied to those pins they will be active and one active high G<sub>1</sub>.

$G_{2B}$   $G_{2A}$   $G_1$

| $G_{2B}$ | $G_{2A}$ | $G_1$ | $C$ | $B$ | $A$ | $y_7$ | $y_6$ | $y_5$ | $y_4$ | $y_3$ | $y_2$ | $y_1$ | $y_0$ |
|----------|----------|-------|-----|-----|-----|-------|-------|-------|-------|-------|-------|-------|-------|
| 1        | x        | x     | x   | x   | x   | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     |
| x        | 1        | x     | x   | x   | x   | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     |
| x        | x        | 0     | x   | x   | x   | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     |
| 0        | 0        | 1     | 0   | 0   | 0   | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     |
| 0        | 0        | 1     | 0   | 0   | 1   | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 0     |
| 0        | 0        | 1     | 0   | 1   | 0   | 1     | 1     | 1     | 1     | 1     | 1     | 0     | 1     |
| 0        | 0        | 1     | 0   | 1   | 1   | 1     | 1     | 1     | 1     | 1     | 0     | 1     | 1     |
| 0        | 0        | 1     | 1   | 0   | 0   | 1     | 1     | 1     | 0     | 1     | 1     | 1     | 1     |
| 0        | 0        | 1     | 1   | 0   | 1   | 1     | 1     | 0     | 1     | 1     | 1     | 1     | 1     |
| 0        | 0        | 1     | 1   | 1   | 0   | 1     | 0     | 1     | 1     | 1     | 1     | 1     | 1     |
| 0        | 0        | 1     | 1   | 1   | 1   | 0     | 1     | 1     | 1     | 1     | 1     | 1     | 1     |

$$Y_7 = G_{2B}G_2 \bar{G}_{2B} \bar{G}_{2A} G_1 CBA$$

$$Y_6 = \bar{G}_{2B} \bar{G}_{2A} G_1 \bar{A}BC$$

$$Y_5 = \bar{G}_{2B} \bar{G}_{2A} G_1 A \bar{B}C$$

$$Y_4 = \bar{G}_{2B} \bar{G}_{2A} G_1 \bar{A} \bar{B}C$$

$$Y_3 = \bar{G}_{2B} \bar{G}_{2A} G_1 A B \bar{C}$$

$$Y_2 = \bar{G}_{2B} \bar{G}_{2A} G_1 \bar{A} B \bar{C}$$

$$Y_1 = \bar{G}_{2B} \bar{G}_{2A} G_1 A \bar{B} \bar{C}$$

$$Y_0 = \bar{G}_{2B} \bar{G}_{2A} G_1 \bar{A} \bar{B} \bar{C}$$

G<sub>2A</sub> G<sub>2B</sub> G<sub>1</sub> A B C



1. Design a 3-8 decoder using 2-4 decoders.  
 In these 3-8 decoders using 2-4 decoders, we know that 2-4 decoder has 2 inputs  $A_1$  and  $A_0$  and 4 outputs  $y_3$  to  $y_0$ . Where as 3-8 decoders has 3 inputs and  $A_2, A_1, A_0$  and 8 outputs  $y_7$  to  $y_0$ . We can find the no. of lower order decoders required for implementing higher order decoder using the following formula. Required number of lower ordered decoders =  $\frac{m_2}{m_1}$

Where  $m_1$  is the no. of outputs of lower order decoder,  $m_2$  is the no. of outputs of higher order decoder. Here  $m_1 = 4$  and  $m_2 = 8 \Rightarrow \frac{8}{4} = 2$



The parallel inputs  $A_1$  and  $A_0$  are applied to each 2-4 decoder. The input of  $A_2$  is connected to Enable  $E$  of lower 2-4 decoder in order to get the outputs of  $y_3$  to  $y_0$ . These are the lower 4 minterms the input  $A_2$  is directly connected to enable of upper 2-4 decoder in order to get the outputs of  $y_7$  to  $y_4$ . These are the higher 4 minterms for active high output:-

In SOP implementation in decoder we are using OR gate. POS implementation in decoder we are using NOR gate.

$$F = \sum_m (1, 2, 3, 7)$$

$$F = \prod_N (1, 3, 5, 7)$$

for active low output:-  
 In SOP implementation in decoder we are using  
 NAND gate  
 $F = \sum m(1, 2, 5, 7)$   
 In POS implementation in decoder we are using AND  
 gate  
 $F = \prod M(1, 3, 5, 7)$

Eg:- Realize a full subtractor using a 3-8 decoder

$$D(x, y, B_{in}) = \sum (1, 2, 4, 7)$$

$$B_{out}(x, y, B_{in}) = \sum (1, 2, 3, 7)$$



Encoder :-

Encoder is a combinational circuit that performs the reverse operation of decoder. It has maximum of  $2^n$  input lines and n output lines.

4-2 Encoder :-



|   | $y_3$ | $y_2$ | $y_1$ | $y_0$ | A | B |
|---|-------|-------|-------|-------|---|---|
| 0 | 0     | 0     | 0     | 1     | 0 | 0 |
| 0 | 0     | 0     | 1     | 0     | 0 | 1 |
| 0 | 1     | 0     | 0     | 0     | 1 | 0 |
| 1 | 0     | 0     | 0     | 0     | 1 | 1 |

$$A = y_2 + y_3, B = y_1 + y_3$$



Decimal to BCD encoder :-  
 This type of encoder has 10 inputs : one for each decimal digit and 4 outputs corresponding to the BCD code. as shown in figure. This is a basic 10-4 encoder.



|   | $A_3$ | $A_2$ | $A_1$ | $A_0$ |
|---|-------|-------|-------|-------|
| 0 | $D_0$ | 0     | 0     | 0     |
| 1 | $D_1$ | 0     | 0     | 1     |
| 2 | $D_2$ | 0     | 0     | 0     |
| 3 | $D_3$ | 0     | 0     | 1     |
| 4 | $D_4$ | 0     | 1     | 0     |
| 5 | $D_5$ | 0     | 1     | 0     |
| 6 | $D_6$ | 0     | 1     | 0     |
| 7 | $D_7$ | 0     | 1     | 1     |
| 8 | $D_8$ | 1     | 0     | 0     |
| 9 | $D_9$ | 1     | 0     | 1     |

$$A_3 = D_8 + D_9$$

$$A_2 = D_4 + D_5 + D_6 + D_7$$

$$A_1 = D_2 + D_3 + D_6 + D_7$$

$$A_0 = D_1 + D_3 + D_5 + D_7 + D_9$$



## Priority Encoder

A 4-to-2 priority encoder has 4 inputs  $y_3, y_2, y_1$ , and  $y_0$  and 2 outputs  $A_1$  and  $A_0$ . Here the input  $y_3$  has the highest priority whereas the input  $y_0$  has the lowest priority. In these case if more than one input is one at the same time the output will be the binary code corresponding to the input which is having

higher priority we consider one more output 'v'. In order to know whether the code available outputs is valid or not. If atleast one input of the encoder is one then the code available at outputs is a valid 1. In these case the output 'v' will be equal to 1. If all the inputs of encoder are zero then the code available at outputs is not a valid one. In this case the output 'v' will be equal to 0.

| $y_3$ | $y_2$ | $y_1$ | $y_0$ | $A_1$ | $A_0$ | $v$ |
|-------|-------|-------|-------|-------|-------|-----|
| 0     | 0     | 0     | 0     | 0     | 0     | 0   |
| 0     | 0     | 0     | 1     | 0     | 0     | 1   |
| 0     | 0     | 1     | x     | 0     | 1     | 1   |
| 0     | 1     | x     | x     | 1     | 0     | 1   |
| 1     | x     | x     | x     | 1     | 1     | 1   |

| $y_3y_0$             | $y_1y_0$ | $y_1y_0$ | $y_1y_0$ | $y_1y_0$ |
|----------------------|----------|----------|----------|----------|
| $\bar{y}_3\bar{y}_2$ | 0        | 1        | 3        | 2        |
| $\bar{y}_3y_2$       | 4        | 5        | 7        | 6        |
| $y_3\bar{y}_2$       | 12       | 13       | 15       | 14       |
| $y_3y_2$             | 1        | 11       | 1        | 10       |

$$y_2 + y_3 = A_1$$

|    |    |    |    |
|----|----|----|----|
| 0  | 1  | 3  | 2  |
| 4  | 5  | -  | 6  |
| 12 | 13 | 15 | 14 |
| 1  | 11 | 1  | 10 |

$$A_0 = y_3 + \bar{y}_2 y_1$$

$$v = y_0 + y_1 + y_2 + y_3$$



# B<sub>CD</sub> to 7 segment display decoder:

| digit | A | B | C | D | a | b | c | d | e | f | g |
|-------|---|---|---|---|---|---|---|---|---|---|---|
| 0     | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 0 |
| 1     | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 0 | 0 | 0 | 0 |
| 2     | 0 | 0 | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 0 | 1 |
| 3     | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 1 |
| 4     | 0 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 |
| 5     | 0 | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 0 | 1 | 1 |
| 6     | 0 | 1 | 1 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 1 |
| 7     | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 |
| 8     | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| 9     | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 1 |

| <del>AB</del> | <del>CD</del> | <del>CD</del> | <del>CD</del> | <del>CD</del> |
|---------------|---------------|---------------|---------------|---------------|
| <del>AB</del> | 1             | 1             | 1             | 1             |
| <del>AB</del> | 1             | 1             | 1             | 1             |
| <del>AB</del> | 1             | 1             | 1             | 1             |
| <del>AB</del> | 1             | 1             | 1             | 1             |

| <del>AB</del> | <del>CD</del> | <del>CD</del> | <del>CD</del> | <del>CD</del> |
|---------------|---------------|---------------|---------------|---------------|
| <del>AB</del> | 1             | 1             | 1             | 1             |
| <del>AB</del> | 1             | 1             | 1             | 1             |
| <del>AB</del> | 1             | 1             | 1             | 1             |
| <del>AB</del> | 1             | 1             | 1             | 1             |

$$a = A + C + BD + \bar{B}\bar{D}$$

$$b = AB + \bar{B} + \bar{C}\bar{D} + CD$$

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

| <del>AB</del> | <del>CD</del> | <del>CD</del> | <del>CD</del> | <del>CD</del> |
|---------------|---------------|---------------|---------------|---------------|
| <del>AB</del> | 1             | 1             | 1             | 1             |
| <del>AB</del> | 1             | 1             | 1             | 1             |
| <del>AB</del> | 1             | 1             | 1             | 1             |
| <del>AB</del> | 1             | 1             | 1             | 1             |

| <del>AB</del> | <del>CD</del> | <del>CD</del> | <del>CD</del> | <del>CD</del> |
|---------------|---------------|---------------|---------------|---------------|
| <del>AB</del> | 1             | 1             | 1             | 1             |
| <del>AB</del> | 1             | 1             | 1             | 1             |
| <del>AB</del> | 1             | 1             | 1             | 1             |
| <del>AB</del> | 1             | 1             | 1             | 1             |

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

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

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

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

| <del>AB</del> | <del>CD</del> | <del>CD</del> | <del>CD</del> | <del>CD</del> |
|---------------|---------------|---------------|---------------|---------------|
| <del>AB</del> | 1             | 1             | 1             | 1             |
| <del>AB</del> | 1             | 1             | 1             | 1             |
| <del>AB</del> | 1             | 1             | 1             | 1             |
| <del>AB</del> | 1             | 1             | 1             | 1             |



## Combinational PLDS

It is an integrated circuit constructed with AND array and OR array. AND-OR array gives the sum of product terms. There are 3 types of combinational PLDS

- 1) PROM : (programmable ROM)
- 2) PAL : (programmable array logic)
- 3) PLA : (programmable logic array)

The block diagram for combinational PLDS as shown in below figure.



i) PROM



ii) PAL



iii) PLA

1. Implement the following boolean function using PAL

$$F_1 = \sum m(0, 1, 2, 3, 8, 10, 12, 14)$$

$$F_2 = \sum m(0, 1, 2, 3, 4, 6, 8, 10, 12, 14)$$

| AB               | CD | $\bar{C}\bar{D}$ | $\bar{C}D$ | $C\bar{D}$ | $CD$ |
|------------------|----|------------------|------------|------------|------|
| $\bar{A}\bar{B}$ | 1  | 1                | 1          | 1          | 1    |
| $\bar{A}B$       | 0  |                  |            |            |      |
| $A\bar{B}$       | 4  | 5                | 7          | 6          |      |
| $AB$             | 12 | 13               | 15         | 14         |      |
| $A\bar{B}$       | 1  |                  |            |            |      |
| $\bar{A}B$       | 8  | 9                | 11         | 10         |      |

| AB               | CD | $\bar{C}\bar{D}$ | $\bar{C}D$ | $C\bar{D}$ | $CD$ |
|------------------|----|------------------|------------|------------|------|
| $\bar{A}\bar{B}$ | 1  | 0                | 1          | 1          | 2    |
| $\bar{A}B$       | 1  |                  |            |            |      |
| $A\bar{B}$       | 1  | 4                | 5          | 7          | 6    |
| $AB$             | 1  | 12               | 13         | 15         | 14   |
| $A\bar{B}$       | 1  |                  |            |            |      |
| $\bar{A}B$       | 8  | 9                | 11         | 10         |      |

$$F_1 = \bar{A}\bar{B} + A\bar{D}$$

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

# PAL programming table

product team

AND inputs

A B C D

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

0 0 - - } F<sub>1</sub>

$A\bar{D}$

1 - - 0 } F<sub>1</sub>

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

0 0 - - } F<sub>2</sub>

$\bar{D}$

0 - - 0 } F<sub>2</sub>

A B C D



1) Design and implement the following boolean function using PLA.  $F_1(A, B, C) = \sum m(3, 5, 6, 7)$

$$f_2(A, B, C) = \sum m(0, 2, 4, 7)$$

2) Realize the boolean function  $w(a, b, c) = \sum m(1, 3, 6, 7)$

$$x(a, b, c) = \sum m(0, 2, 4, 5)$$

PLA programming table  
product team

|  |  | $\bar{B}C$ | $\bar{B}\bar{C}$ | $B\bar{C}$ | $BC$ |
|--|--|------------|------------------|------------|------|
|  |  | 0          | 1                | 2          | 3    |
|  |  | A          | 1                | 1          | 1    |
|  |  | 0          | 1                | 1          | 1    |
|  |  | 1          | 0                | 0          | 0    |
|  |  | 2          | 0                | 0          | 0    |
|  |  | 3          | 0                | 0          | 0    |
|  |  | 4          | 1                | 1          | 1    |
|  |  | 5          | 1                | 1          | 1    |
|  |  | 6          | 1                | 1          | 1    |
|  |  | 7          | 0                | 0          | 0    |

$$F_1 = BC + AC + AB$$

|  |  | $\bar{B}C$ | $\bar{B}\bar{C}$ | $B\bar{C}$ | $BC$ |
|--|--|------------|------------------|------------|------|
|  |  | 0          | 1                | 2          | 3    |
|  |  | A          | 1                | 1          | 1    |
|  |  | 0          | 1                | 1          | 1    |
|  |  | 1          | 0                | 0          | 0    |
|  |  | 2          | 0                | 0          | 0    |
|  |  | 3          | 0                | 0          | 0    |
|  |  | 4          | 1                | 1          | 1    |
|  |  | 5          | 1                | 1          | 1    |
|  |  | 6          | 1                | 1          | 1    |
|  |  | 7          | 0                | 0          | 0    |

$$F_2 = \bar{B}\bar{C} + \bar{B}\bar{C} + AB\bar{C}$$

AND inputs

A B C

$\bar{B}C$  - 1 1 } F<sub>1</sub>

$AC$  1 - 1 } F<sub>1</sub>

$AB$  1 1 - } F<sub>2</sub>

$\bar{B}\bar{C}$  - 0 0 } F<sub>2</sub>

$\bar{A}\bar{C}$  0 - 0 } F<sub>2</sub>

$ABC$  1 1 1 }



2)  $f = \overline{B}C + \overline{B}\overline{C} + \overline{B}c + BC + B\overline{C}$

| $\overline{A}$ | $\overline{B}C$ | $\overline{B}\overline{C}$ | $\overline{B}c$ | $BC$ | $B\overline{C}$ |
|----------------|-----------------|----------------------------|-----------------|------|-----------------|
| $A$            | 0               | 1                          | 1               | 3    | 2               |
| $\overline{A}$ | 4               | 5                          | 7               | 1    | 6               |

PLA programming table

product terms

A B C

$\overline{A}C$

0

-

1

} W

$AB$

1

1

-

$\overline{A}\overline{C}$

0

-

0

$A\overline{B}$

0

-

-

$f = \overline{B}C + \overline{B}\overline{C} + \overline{B}c + BC + B\overline{C}$

| $\overline{A}$ | $\overline{B}C$ | $\overline{B}\overline{C}$ | $\overline{B}c$ | $BC$ | $B\overline{C}$ |
|----------------|-----------------|----------------------------|-----------------|------|-----------------|
| $A$            | 1               | 1                          | 3               | 1    | 2               |
| $\overline{A}$ | 1               | 1                          | 3               | 1    | 2               |
| $A$            | 1               | 1                          | 3               | 1    | 2               |

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

A B C

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



## Multiplexers :- (a) data selector

It is a combinational circuit having multiple inputs and a single output. The transfer of an input to the output is controlled by select lines. It is also called as data selector.



$4 \times 1 \text{ MUX} \quad 2^2 \rightarrow 2 \text{ selectors}$



| EN | Select lines |       | output |
|----|--------------|-------|--------|
|    | $S_1$        | $S_0$ |        |
| 0  | x            | x     | 0      |
| 1  | 0            | 0     | $I_0$  |
| 1  | 0            | 1     | $I_1$  |
| 1  | 1            | 0     | $I_2$  |
| 1  | 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$$

$S_1 \quad S_0$



$8 \times 1$  Mux  $\frac{3}{2} = 8 \Rightarrow 3$  selectors



| EN | Select lines   |                |                | Output         |
|----|----------------|----------------|----------------|----------------|
|    | S <sub>0</sub> | S <sub>1</sub> | S <sub>2</sub> | Y              |
| 0  | X              | X              | X              | 0              |
| 1  | 0              | 0              | 0              | I <sub>0</sub> |
| 1  | 0              | 0              | 1              | I <sub>1</sub> |
| 1  | 0              | 1              | 0              | I <sub>2</sub> |
| 1  | 0              | 1              | 1              | I <sub>3</sub> |
| 1  | 1              | 0              | 0              | I <sub>4</sub> |
| 1  | 1              | 0              | 1              | I <sub>5</sub> |
| 1  | 1              | 1              | 0              | I <sub>6</sub> |
| 1  | 1              | 1              | 1              | I <sub>7</sub> |

$$\begin{aligned}
 Y = & \overline{S_0} \overline{S_1} \overline{S_2} I_0 + \overline{S_0} \overline{S_1} S_2 I_1 + \overline{S_0} S_1 \overline{S_2} I_2 \\
 & + \overline{S_0} S_1 S_2 I_3 + S_0 \overline{S_1} \overline{S_2} I_4 + S_0 \overline{S_1} S_2 I_5 \\
 & + S_0 S_1 \overline{S_2} I_6 + S_0 S_1 S_2 I_7
 \end{aligned}$$



Design  $32 \times 1$  Mux using  $2 \times 1$  Mux and one



Design 32x1 MUX using four 8x1 MUX and one 2-4 Decoder



Implement the following boolean function using 4x1 mux  $f(A, B, C) = \sum m(1, 3, 5, 6)$

|           | $D_0$ | $D_1$ | $D_2$ | $D_3$     |
|-----------|-------|-------|-------|-----------|
| $\bar{A}$ | 0     | 1     | 2     | 3         |
| A         | 4     | 5     | 6     | 7         |
|           | 0     | 1     | A     | $\bar{A}$ |



Implement the following boolean function using 8x1 Mux  $F(P, Q, R, S) = \sum m(0, 1, 3, 4, 8, 9, 15)$

|           | $D_0$ | $D_1$ | $D_2$ | $D_3$     | $D_4$     | $D_5$ | $D_6$ | $D_7$ |
|-----------|-------|-------|-------|-----------|-----------|-------|-------|-------|
| $\bar{A}$ | 1     | 0     | 1     | 0         | 1         | 0     | 1     | 0     |
| A         | 1     | 1     | 0     | $\bar{A}$ | $\bar{A}$ | 0     | 0     | A     |
|           | 1     | 1     | 0     | $\bar{A}$ | $\bar{A}$ | 0     | 0     | A     |



demultiplexers (data distributor) :-

It is a combinational circuit which has single input and multiple outputs. It receives one of the output line. The selection of output depend on the value of select inputs. This circuit is also referred as data distributor.



- \* Demultiplexers are used in data transmission
- \* They are used in the implementation of Boolean functions.
- \* They are used in designing of combinational logic circuits.
- \* These are also preferred to enable signal generation.

1x8 demux:



| $S_2$ | $S_1$ | $S_0$ | $y_7$ | $y_6$ | $y_5$ | $y_4$ | $y_3$ | $y_2$ | $y_1$ | $y_0$ |
|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | D     |
| 0     | 0     | 1     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | D     |
| 0     | 1     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | D     |
| 0     | 1     | 1     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | D     |
| 1     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | D     |
| 1     | 0     | 1     | 0     | 0     | D     | 0     | 0     | 0     | 0     | 0     |
| 1     | 1     | 0     | 0     | D     | 0     | 0     | 0     | 0     | 0     | 0     |
| 1     | 1     | 1     | D     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

$$y_0 = \overline{S_2} \overline{S_1} \overline{S_0}$$

$$y_1 = \overline{S_2} \overline{S_1} S_0$$

$$y_2 = \overline{S_2} S_1 \overline{S_0}$$

$$y_3 = \overline{S_2} S_1 S_0$$

$$y_4 = S_2 \overline{S_1} \overline{S_0}$$

$$y_5 = S_2 \overline{S_1} S_0$$

$$y_6 = S_2 S_1 \overline{S_0}$$

$$y_7 = S_2 S_1 S_0$$

