

## Chapter - 6

### \* MSI and LSI Components in Combinational Logic Design

We use Boolean function simplification to obtain low cost CKT and the method is known as classical procedure.

- This classical method can be tedious and cumbersome for large number of input variable and the design may not be efficient.

Nowadays, Integrated circuit

(IC) are preferred in design of modern digital system which performs the same function of combination CKT. In other word we can say that these CKTs are available in integrated CKTs and are classified according to the number of gates.

#### 1. Small Scale Integration (SSI) : $\rightarrow$

The number of gates

in a single package is less than 10 are called small scale integration (SSI) IC.

#### 2. Medium Scale Integration (MSI) : $\rightarrow$ It has 10 to 200 gates in a single package. They perform specific digital function such as decoder, encoder, multiplexers, Demultiplexer, adder, subtractors and comparators.

#### 3. Large Scale Integration (LSI) : $\rightarrow$ It has 200 and a few thousand gates in single package. They include digital system such as processors, memory chips and programmable modules.

#### 4. Very Large Scale Integration (VLSI) : $\rightarrow$ VLSI devices contains thousand of gates. e.g. $\rightarrow$ Large memory arrays.

and complex microcomputer chips. VLSI revolutionized the computer system design technology introducing Digital Integrated Circuits.

## \* Binary parallel Adder :→

A Binary parallel Adder is a digital circuit that produces the arithmetic sum of two binary number in parallel.

It consists of full adder connected in cascade, with the output carry from one full adder connected to the input carry of the next full adder.



fig:→ Interconnection of 4-bit binary parallel Adder

The above figure shows four bit binary parallel Adder. It requires 4 full adders. The Augend bits of A and the Addend bits of B are designated by subscript numbers from right to left. The carries are connected in a chain through the full adder. The input carry to the adder is  $c_1$  and output carry is  $c_s$  and generates the required sum bit  $s_1$ .

## \* Binary subtractor (Binary Adder Subtractor)

[ As already been discussed to perform subtraction i.e  $A - B$  can be accomplished by taking the 2's complement of  $B$  and adding it to  $A$ . ]



fig: → Four bit Adder - Subtractor

Above figure shows the four bit Adder - Subtractor 'ckt' that can perform both the operation of Adder and subtractor which can be controlled by the mode input 'M'. It has two values

- 1) When  $M=0$ , it becomes  $B_1 \oplus 0 = B_1$ , the full adder receives  $B_1$  as the input carry  $C_1=0$ . Therefore the full adder performs  $A_1 + B_1$  and so operates the other Full adder.
- 2) Similarly when  $M=1$ , it becomes  $B_1 \oplus 1 = \bar{B}_1$ , the full adder receives  $\bar{B}_1$  and carry  $C_1=1$ . The input  $\bar{B}_1$  is then added 1 via input carry and result's 2's complement of  $B_1$ . This is then further added with other input  $A_1$  resulting subtraction  $A_1 - B_1$ . The same procedure is followed by other full adder ckt that performs subtraction.

The exclusive-or with output V is for detecting an overflow.

Example: Design a BCD to Excess-3 code

converter by 4-bit full adder MSI CKT.

|   | <del>A<sub>4</sub>A<sub>3</sub>A<sub>2</sub>A<sub>1</sub></del> | <del>BCD</del> | <del>S<sub>4</sub>S<sub>3</sub>S<sub>2</sub>S<sub>1</sub></del> |
|---|-----------------------------------------------------------------|----------------|-----------------------------------------------------------------|
| 0 | 0 0 0 0                                                         | 0 0 0 0        | 0 0 1 1                                                         |
| 1 | 0 0 0 1                                                         | 0 0 0 1        | 0 1 0 0                                                         |
| 2 | 0 0 1 0                                                         | 0 0 1 0        | 0 1 0 1                                                         |
| 3 | 0 0 1 1                                                         | 0 0 1 1        | 0 1 1 0                                                         |
| 4 | 0 1 0 0                                                         | 0 1 0 0        | 0 1 1 1                                                         |
| 5 | 0 1 0 1                                                         | 0 1 0 1        | 1 0 0 0                                                         |
| 6 | 0 1 1 0                                                         | 0 1 1 0        | 1 0 0 1                                                         |
| 7 | 0 1 1 1                                                         | 0 1 1 1        | 1 0 1 0                                                         |
| 8 | 1 0 0 0                                                         | 1 0 0 0        | 1 0 1 1                                                         |
| 9 | 1 0 0 1                                                         | 1 0 0 1        | 1 1 0 0                                                         |

From the truth table  
the excess-3 equivalent  
code is obtained by addition  
of binary 0011.



fig: 4 bit - Full Adder MSI CKT (BCD to Excess-3 code converter)

From the figure BCD is applied to input A.  
Input B are set to constant 0011. Therefore, S outputs  
from the CKT gives the Excess-3 code of the input  
BCD digit.

e.g. : When two numbers with  $n$  digits each are added and the sum is a number occupying  $n+1$  digit, we say overflow has occurred.

### \* Decimal Adder :

Computers or calculators performs arithmetic operation of decimal number system by Adder in binary coded decimal (BCD) form and present results in the same code. Arithmetic operation is done by Adder. Similarly, Decimal Adder requires minimum of nine inputs and five output, since four bits are required to code each decimal digit and the circuit must have an input carry and output carry.

Therefore there is wide variety of decimal adder circuits depending upon the code used to represent the decimal digit.

e.g. : Decimal adder for the BCD code

### \* BCD Adder :

Consider the arithmetic addition of two decimal digits in BCD together with an input carry from a decimal digit.

Each input digit does not exceed 9, the output sum cannot be greater than  $9+9+1 = 19$  ( $\leftarrow$  input carry).

Suppose we apply two BCD digit to four bit binary adder. The Adder will form the sum in binary and produce result  $\uparrow$  to 19.



fig : → BLOCK Diagram of BCD Adder

BCD Adder that adds two BCD digits and produces a sum digit is shown in above figure. The two decimal digits, together with the input carry are first added to produce binary sum.

When the output carry is 0, nothing is added to binary sum. But when output carry is equal to 1, (0110) binary is added to binary sum through the bottom four-bit Adder. The output carry is given by

$$C = k + z_8 z_4 + z_8 z_2$$

## \* Magnitude Comparator :→

Magnitude Comparator is a combinational circuit that compares two number A and B and determine their relative magnitude.



fig: → Four bit magnitude Comparator

The outcome of the comparison is specified by 3 binary variables that indicate whether  $A > B$ ,  $A = B$  and  $A < B$ .

Consider two 4 digit numbers  $A$  and  $B$ .

Here,  $A = A_3 A_2 A_1 A_0$   $B = B_3 B_2 B_1 B_0$ . The two numbers are equal if all pair of significant digits are equal i.e  $A_3 = B_3$ ,  $A_2 = B_2$ ,  $A_1 = B_1$  and  $A_0 = B_0$ . Therefore it can be expressed logically as

$$x_i = A_i B_i + A'_i B'_i \quad \text{where } i = 0, 1, 2, 3$$

For  $A = B$  the

output of the combinational ckt is given by AND operation for all variable, therefore  $A = B = x_3 x_2 x_1 x_0$

IF  $A = 1$  and  $B = 0$

$$A > B = A_3 B'_3 + x_3 A_2 B'_2 + x_3 x_2 A_1 B'_1 + x_3 x_2 x_1 A_0 B'_0.$$

IF  $A = 0$  and  $B = 1$

$$A < B = A'_3 B_3 + x_3 A'_2 B_2 + x_3 x_2 A'_1 B_1 + x_3 x_2 x_1 A'_0 B_0$$

## \* Decoder

A decoder is a combinational circuit that converts binary information from  $n$  input lines to maximum of  $2^n$  unique output lines. But if the decoder has unused or don't care combination the output will be less than  $2^n$  combination.



Here, input  $n = 3$   
output  $= 2^n = 2^3 = 8$

fig: → Block Diagram of 3 input Decoder

## \* Design 3 to 8 line Decoder

If  $x, y, z$  are three input to the Decoder it has  $2^3 = 8$  output  $D_0, D_1, D_2, D_3, D_4, D_5, D_6, D_7$ .

The truth table for 3 to 1 line Decoder is

| $x \ y \ z$ | $D_0 \ D_1 \ D_2 \ D_3 \ D_4 \ D_5 \ D_6 \ D_7$ |
|-------------|-------------------------------------------------|
| 0 0 0       | 1 0 0 0 0 0 0 0                                 |
| 1 0 1       | 0 1 0 0 0 0 0 0                                 |
| 0 1 0       | 0 0 1 0 0 0 0 0                                 |
| 0 1 1       | 0 0 0 1 0 0 0 0                                 |
| 1 0 0       | 0 0 0 0 1 0 0 0                                 |
| 1 0 1       | 0 0 0 0 0 1 0 0                                 |
| 1 1 0       | 0 0 0 0 0 0 1 0                                 |
| 1 1 1       | 0 0 0 0 0 0 0 1                                 |

The operation of decoder has seven output equal to '0' and one output equal to '1'.

$$\begin{aligned}
 D_0 &= x'y'z', \quad D_1 = x'y'z, \quad D_2 = x'yz', \quad D_3 = x'yz, \quad D_4 = \underline{x'yz}, \quad D_5 = xy'z \\
 D_6 &= xy'z', \quad D_7 = xyz
 \end{aligned}$$



\* Design a BCD to decimal decoder:

to represent BCD  
four inputs and ten outputs to represent decimal.  
The decoder consists

ginput      output (decimal)

|   | w | x | y | z | D <sub>0</sub> | D <sub>1</sub> | D <sub>2</sub> | D <sub>3</sub> | D <sub>4</sub> | D <sub>5</sub> | D <sub>6</sub> | D <sub>7</sub> | D <sub>8</sub> | D <sub>9</sub> |   |
|---|---|---|---|---|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|---|
| 0 | 0 | 0 | 0 | 0 | 1              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 0 |
| 1 | 0 | 0 | 0 | 1 | 0              | 1              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 0 |
| 2 | 0 | 0 | 1 | 0 | 0              | 0              | 1              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 0 |
| 3 | 0 | 0 | 1 | 1 | 0              | 0              | 0              | 1              | 0              | 0              | 0              | 0              | 0              | 0              | 0 |
| 4 | 0 | 1 | 0 | 0 | 0              | 0              | 0              | 0              | 1              | 0              | 0              | 0              | 0              | 0              | 0 |
| 5 | 0 | 1 | 0 | 1 | 0              | 0              | 0              | 0              | 0              | 1              | 0              | 0              | 0              | 0              | 0 |
| 6 | 0 | 1 | 1 | 0 | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 1              | 0              | 0              | 0 |
| 7 | 0 | 1 | 1 | 1 | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 1              | 0              | 0              | 0 |
| 8 | 1 | 0 | 0 | 0 | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 1              | 0 |
| 9 | 1 | 0 | 0 | 1 | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 1              | 0 |

|    |      |   |   |   |   |   |     |     |    |  |  |  |  |  |  |
|----|------|---|---|---|---|---|-----|-----|----|--|--|--|--|--|--|
| 10 | 1010 | X | X | X | X | X | X-X | X-X | XX |  |  |  |  |  |  |
| 11 | 1011 | X | X | X | X | X | X-X | X-X | XX |  |  |  |  |  |  |
| 12 | 1100 | X | X | X | X | X | X-X | X-X | XX |  |  |  |  |  |  |
| 13 | 1101 | X | X | X | X | X | X-X | X-X | XX |  |  |  |  |  |  |
| 14 | 1110 | X | X | X | X | X | X-X | X-X | XX |  |  |  |  |  |  |
| 15 | 1111 | X | X | X | X | X | X-X | X-X | XX |  |  |  |  |  |  |

w x y z y' z' y' z' y' z' y' z' y' z'

|     |    |   |   |   |   |
|-----|----|---|---|---|---|
| w x | 00 | 1 | 1 | 1 | 1 |
| w x | 01 | 1 | 1 | 1 | 1 |
| w x | 11 | X | X | X | X |
| w x | 10 | 1 | 1 | X | X |

$$D_0 = w'x'y'z'$$

$$D_1 = w'x'y'z$$

$$D_2 = x'y'z'$$

$$D_3 = x'yz$$

$$D_4 = xy'z'$$

$$D_5 = xy'z$$

$$D_6 = xy'z'$$

$$D_7 = xyz$$

$$D_8 = w \cdot z'$$

$$D_9 = wz$$



$$\begin{array}{ccccccc}
 & 15 & 22 & 27 & 29 & 30 & 0 \\
 \bar{x}\bar{w}xyz + \bar{v}\bar{w}xyz + v\bar{w}xyz + v\bar{w}xyz + v\bar{w}xyz + v\bar{w}xyz & 10111 & 11011 & 11102 & 11110 & 00000 & 00000 \\
 1\bar{v}\bar{w}\bar{x}\bar{y}\bar{z} + \bar{v}\bar{w}xy\bar{z} + \bar{v}w\bar{x}\bar{y}\bar{z} & 00010 & 00100 & 01000 & & & 
 \end{array}$$

|             | 2                   | 4                   | 8                   |                     |   |
|-------------|---------------------|---------------------|---------------------|---------------------|---|
| $\bar{v}w$  | $x'y'z'$<br>$x'y'z$ | $x'y'z$<br>$x'y'z'$ | $x'y'z'$<br>$x'y'z$ | $x'y'z$<br>$x'y'z'$ |   |
| $\bar{v}w'$ | 1                   | 1                   |                     |                     | 1 |
| $\bar{v}w$  | 1                   |                     |                     | 1                   |   |
| $vw$        |                     | 1                   | 1                   |                     | 1 |
| $vw'$       |                     |                     |                     | 1                   |   |

\* Implement a full Adder CKT with the decoders and two OR Gates.

of full Adder CKT

If  $x, y$  are two input bits, and  $z$  previous carry produces two bits, of sum and carry

| $x$ | $y$ | $z$ | Sum (S) | Carry (C) |
|-----|-----|-----|---------|-----------|
| 0   | 0   | 0   | 0       | 0         |
| 1   | 0   | 1   | 1       | 0         |
| 2   | 0   | 0   | 1       | 0         |
| 3   | 0   | 1   | 0       | 1         |
| 4   | 1   | 0   | 1       | 0         |
| 5   | 1   | 0   | 0       | 1         |
| 6   | 1   | 1   | 0       | 1         |
| 7   | 1   | 1   | 1       | 1         |

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

$$C = \sum (3, 5, 6, 7)$$



Design  $2 \times 8$  Decoder using two  $2 \times 4$  Decoder



$1 \times 8$  Decoder using two  $2 \times 4$  decoder

## \* Demultiplexer :→

It is a combinational logic CKT with one input and many output along with some control signals. It takes digital information from single line and distributes them to given number of output lines. It is also known as data distributor or one into many which means transmitting single information over a large number of channel or lines.



fig: → Block Diagram of 1 to 4 Demultiplexer

| Input                |   |   | Output         |                |                |                |
|----------------------|---|---|----------------|----------------|----------------|----------------|
| E or D <sub>in</sub> | A | B | D <sub>0</sub> | D <sub>1</sub> | D <sub>2</sub> | D <sub>3</sub> |
| 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              | 0              | 1              |

$$D_0 = A'B'E \quad D_1 = A'BE \quad D_2 = ABE \quad D_3 = ABE$$



Logic circuit of 1x4 Demultiplexer

1) Design 1 to 8 Demultiplexer



| $D_{in} A \wedge C$ | $D_0$ | $D_1$ | $D_2$ | $D_3$ | $D_4$ | $D_5$ | $D_6$ | $D_7$ |
|---------------------|-------|-------|-------|-------|-------|-------|-------|-------|
| 1 0 0 0             | 1     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| 1 0 0 1             | 0     | 1     | 0     | 0     | 0     | 0     | 0     | 0     |
| 1 0 1 0             | 0     | 0     | 1     | 0     | 0     | 0     | 0     | 0     |
| 1 0 1 1             | 0     | 0     | 0     | 1     | 0     | 0     | 0     | 0     |
| 1 1 0 0             | 0     | 0     | 0     | 0     | 1     | 0     | 0     | 0     |
| 1 1 0 1             | 0     | 0     | 0     | 0     | 0     | 1     | 0     | 0     |
| 1 1 1 0             | 0     | 0     | 1     | 0     | 0     | 0     | 1     | 0     |
| 1 1 1 1             | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 1     |

$$D_0 = A'B'C' \quad D_1 = A'B'C \quad D_2 = A'BC' \quad D_3 = A'BC \quad D_4 = AB'C' \quad D_5 = AB'C \quad D_6 = ABC' \quad D_7 = ABC$$



### \*Encoder :

An Encoder is a combinational logic circuit that performs reverse operation of a Decoder. It has  $2^n$  input lines and converts to  $n$  output lines.

### \* Design octal to binary encoder

Input lines = 8 Output lines = 3

| Input                                                                                                                   | Output |
|-------------------------------------------------------------------------------------------------------------------------|--------|
| D <sub>0</sub> D <sub>1</sub> D <sub>2</sub> D <sub>3</sub> D <sub>4</sub> D <sub>5</sub> D <sub>6</sub> D <sub>7</sub> | x y z  |
| 1 0 0 0 0 0 0 0                                                                                                         | 0 0 0  |
| 0 1 0 0 0 0 0 0                                                                                                         | 0 0 1  |
| 0 0 1 0 0 0 0 0                                                                                                         | 0 1 0  |
| 0 0 0 1 0 0 0 0                                                                                                         | 0 1 1  |
| 0 0 0 0 1 0 0 0                                                                                                         | 1 0 0  |
| 0 0 0 0 0 1 0 0                                                                                                         | 1 0 1  |
| 0 0 0 0 0 0 1 0                                                                                                         | 1 1 0  |
| 0 0 0 0 0 0 0 1                                                                                                         | 1 1 1  |

The octal to binary encoder consist of 8 inputs and 3 outputs that generate the corresponding binary number. It is constructed with OR gates whose inputs can be determined

from the truth table. Here the output

$x = 1$  for 4, 5, 6, 7 octal digit

$y = 1$  for 2, 3, 6, 7 octal digit

$z = 1$  for 1, 3, 5, 7 octal digit

It can be expressed as

$$x = D_4 + D_5 + D_6 + D_7$$

$$y = D_2 + D_3 + D_6 + D_7$$

$$z = D_1 + D_2 + D_5 + D_7$$

D<sub>0</sub> D<sub>1</sub> D<sub>2</sub> D<sub>3</sub> D<sub>4</sub> D<sub>5</sub> D<sub>6</sub> D<sub>7</sub>



\* Design Decimal to BCD Encoder  
 This type of encoder has ten inputs and four outputs corresponding to BCD code.

| input (decimal)                                                                                                                                       | output (BCD) |
|-------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|
| D <sub>0</sub> D <sub>1</sub> D <sub>2</sub> D <sub>3</sub> D <sub>4</sub> D <sub>5</sub> D <sub>6</sub> D <sub>7</sub> D <sub>8</sub> D <sub>9</sub> | w x y z      |
| 1 0 0 0 0 0 0 0 0 0                                                                                                                                   | 0 0 0 0      |
| 0 1 0 0 0 0 0 0 0 0                                                                                                                                   | 0 0 0 1      |
| 0 0 1 0 0 0 0 0 0 0                                                                                                                                   | 0 0 1 0      |
| 0 0 0 1 0 0 0 0 0 0                                                                                                                                   | 0 0 1 1      |
| 0 0 0 0 1 0 0 0 0 0                                                                                                                                   | 0 1 0 0      |
| 0 0 0 0 0 1 0 0 0 0                                                                                                                                   | 0 1 0 1      |
| 0 0 0 0 0 0 1 0 0 0                                                                                                                                   | 0 1 1 0      |
| 0 0 0 0 0 0 0 1 0 0                                                                                                                                   | 0 1 1 1      |
| 0 0 0 0 0 0 0 0 1 0                                                                                                                                   | 1 0 0 0      |
| 0 0 0 0 0 0 0 0 0 1                                                                                                                                   | 1 0 0 1      |

w = 1 for 8, 9 decimal digit

x = 1 for 4, 5, 6, 7 decimal digit

y = 1 for 2, 3, 6, 7 " "

z = 1 for 1, 3, 5, 7, 9 " "

g + can be expressed as

$$w = D_8 + D_9$$

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

~~$$x = D_4 + D_5 + D_6 + D_7$$~~

~~$$y = D_2 + D_3 + D_6 + D_7$$~~

Design 8x1 MUX using two 4x1 MUX



fig:  $\Rightarrow$  8x1 MUX using two 4x1 MUX

(Decoder with OR Gate)

### \* Multiplexer

Multiplexer is a combinational CKT that allows digital information from several sources to be routed onto single line for transmission. It is also known as many to one. Multiplexer selects binary information from one of many input lines and direct it to a single output line. The control and selection is done by selection line. Normally there are  $2^n$  input lines and 'n' selection lines whose bit combination determines which input is to be selected.



fig:  $\Rightarrow$  Multiplexer (BLOCK Diagram)

Q. Design and explain (4 to 1) 4 input multiplexer.

L) 4 input multiplexer has four data input lines and two data select bits  $s_1, s_0$ .  
designated by  $D_0, D_1, D_2, D_3$ .



| Data select inputs                   | Output selected |
|--------------------------------------|-----------------|
| s <sub>1</sub> s <sub>0</sub><br>0 0 | D <sub>0</sub>  |
| 0 1                                  | D <sub>1</sub>  |
| 1 0                                  | D <sub>2</sub>  |
| 1 1                                  | D <sub>3</sub>  |

Truth table  
Now, we can derive output terms of the data input and the select inputs.

$$Y = D_0 s_0' s_1' \text{ for } s_1 = 0, s_0 = 0$$

$$Y = D_1 s_0 s_1' \text{ for } s_1 = 0, s_0 = 1$$

$$Y = D_2 s_0' s_1 \text{ for } s_1 = 1, s_0 = 0$$

$$Y = D_3 s_0 s_1 \text{ for } s_1 = 1, s_0 = 1$$

Therefore the logic expression is



Q Design and explain (8+0) 8 input multiplexer.

8 input multiplexer has eight data input lines designated by D<sub>0</sub>, D<sub>1</sub>, D<sub>2</sub>, D<sub>3</sub>, D<sub>4</sub>, D<sub>5</sub>, D<sub>6</sub>, D<sub>7</sub> and three data select bits s<sub>0</sub>, s<sub>1</sub>, s<sub>2</sub>.



fig: → Block Diagram of 8x1 Multiplexer

| Input data     |                |                |                |                |                |                |                | select data output |                |                |   |
|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|--------------------|----------------|----------------|---|
| D <sub>0</sub> | D <sub>1</sub> | D <sub>2</sub> | D <sub>3</sub> | D <sub>4</sub> | D <sub>5</sub> | D <sub>6</sub> | D <sub>7</sub> | S <sub>2</sub>     | S <sub>1</sub> | S <sub>0</sub> | Y |
| 1              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 0                  | 0              | 0              | 1 |
| 0              | 1              | 0              | 0              | 0              | 0              | 0              | 0              | 0                  | 0              | 1              | 1 |
| 0              | 0              | 1              | 0              | 0              | 0              | 0              | 0              | 0                  | 1              | 0              | 1 |
| 0              | 0              | 0              | 1              | 0              | 0              | 0              | 0              | 0                  | 1              | 1              | 1 |
| 0              | 0              | 0              | 0              | 1              | 0              | 0              | 0              | 1                  | 0              | 0              | 1 |
| 0              | 0              | 0              | 0              | 0              | 1              | 0              | 0              | 1                  | 0              | 1              | 1 |
| 0              | 0              | 0              | 0              | 0              | 0              | 1              | 0              | 1                  | 1              | 0              | 1 |
| 0              | 0              | 0              | 0              | 0              | 0              | 0              | 1              | 1                  | 1              | 1              | 1 |

Therefore logic

expression is,

$$\begin{aligned}
 Y = & D_0 S_2' S_1' S_0' + D_1 S_2' S_1' S_0 + D_2 S_2' S_1 S_0' + D_2 S_2' S_1 S_0 \\
 & + D_4 S_2 S_1' S_0' + D_5 S_2 S_1' S_0 + D_6 S_2 S_1 S_0' + D_7 S_2 S_1 S_0
 \end{aligned}$$



\* B and C for selection lines  $s_1$  and  $s_0$  and variable A for the input of multiplexer

### Boolean function implementation

For n-variable we implement  $2^{n-1}$  to 1 multiplexer.

e.g.: For 4-variable we implement 8 to 1 multiplexer. ( $8 \times 1$  MUX)

For 3-variable we implement

$4 \times 1$  Multiplexer ( $4 \times 1$  MUX). If  $A, B, C$  are three variables, we list all the minterms in two rows. It has given minterms are 8. We list all the minterms in two rows. Each column is inspected separately.

1. If the two minterms in a column are not circled, apply 0 to the corresponding multiplexer input.
2. If the two minterms are circled, apply 1 to the corresponding multiplexer input.
3. If the top is circled and the bottom is not circled, apply  $A'$  to the corresponding multiplexer input.
4. If the top minterm is not circled and

bottom is circled, apply A to the corresponding multiplexer input.

1. Implement the following Boolean function using  $4 \times 1$  MUX:  $F = \sum(1, 3, 5, 6)$
- We can draw implementation table for the above minterms

|      | $I_0$ | $I_1$ | $I_2$ | $I_3$ |
|------|-------|-------|-------|-------|
| $A'$ | 0     | ①     | 2     | ②     |
| A    | 4     | ⑤     | ⑥     | 7     |

$0 \quad 1 \quad A \quad A'$

Here, we take three variables  $A, B, C$ . B and C are the selection lines ( $s_0, s_1$ ) and  $A, A'$  are the inputs of multiplexer.

| Minterm | A | B | C | F |
|---------|---|---|---|---|
| 0       | 0 | 0 | 0 | 0 |
| 1       | 0 | 0 | 1 | 1 |
| 2       | 0 | 1 | 0 | 0 |
| 3       | 0 | 1 | 1 | 1 |
| 4       | 1 | 0 | 0 | 0 |
| 5       | 1 | 0 | 1 | 1 |
| 6       | 1 | 1 | 0 | 1 |
| 7       | 1 | 1 | 1 | 0 |



$$[2^{3-1} = 8]$$

2. Implement the following Boolean function using  $8 \times 1$  MUX :  $F = \sum(0, 1, 3, 4, 8, 9, 15)$

|      | $I_0$ | $I_1$ | $I_2$ | $I_3$ | $I_4$ | $I_5$ | $I_6$ | $I_7$ |  |
|------|-------|-------|-------|-------|-------|-------|-------|-------|--|
| $A'$ | (0)   | (1)   | 2     | (3)   | (4)   | 5     | 6     | 7     |  |
| $A$  | (8)   | (9)   | 10    | 11    | 12    | 13    | 14    | (15)  |  |
|      | 1     | 1     | 0     | $A'$  | $A'$  | 0     | 0     | $A$   |  |

$I_0 - I_7$  are  
the input  
of the  
multiplexer

Here, we take four variable  $A, A', C, D$ .  
 $B, C, D$  all the selection lines ( $s_0, s_1, s_2$ )  
which has the value of 0, 1, 2, 3,  $A$  and  $A'$ .  
From above given value we can draw  
the implementation table of minterm.



4. Implement the following Boolean function  
 $F(w, x, y, z) = \sum(1, 2, 5, 7, 11, 12, 15)$  using  
 8 to 1 MUX.

5. Implement a full Adder CKT using  
 two 4:1 MUX.

The addition of three binary bit is called Full Adder. If the three binary bits are  $A, B, C$ . The truth table for full adder CKT is

|   | $A$ | $B$ | $C$ | sum(s) | carry(c) |
|---|-----|-----|-----|--------|----------|
| 0 | 0   | 0   | 0   | 0      | 0        |
| 1 | 0   | 0   | 1   | 1      | 0        |
| 2 | 0   | 1   | 0   | 1      | 0        |
| 3 | 0   | 1   | 1   | 0      | 1        |
| 4 | 1   | 0   | 0   | 1      | 0        |
| 5 | 1   | 0   | 1   | 0      | 1        |
| 6 | 1   | 1   | 0   | 0      | 1        |
| 7 | 1   | 1   | 1   | 1      | 1        |

$$f = \sum(1, 2, 4, 7) \quad c = \sum(3, 5, 6, +)$$

Implementation table of minterm for full Adder CKT

|      | $I_0$ | $I_1$ | $I_2$ | $I_3$ |
|------|-------|-------|-------|-------|
| $A'$ | 0     | 1     | 2     | 3     |
| $A$  | 4     | 5     | 6     | 7     |
|      | A     | A'    | A'    | A     |

full Adder CKT.

Implementation table of minterm for carry of n

|      | $I_0$ | $I_1$ | $I_2$ | $I_3$ |
|------|-------|-------|-------|-------|
| $A'$ | 0     | 1     | 2     | 3     |
| $A$  | 4     | 5     | 6     | 7     |
|      | O     | A     | A     | 1     |



Application :  $\rightarrow$  Digital computer system.  
control units in digital system.

#### \* Read-only Memory (ROM) : $\rightarrow$

Read only Memory (ROM) is a memory device which stores data permanently i.e. binary fixed set of information is stored. To load data into the binary information must first be specified by the user and is then embedded in the unit to form the required interconnection pattern which is done by programming. Programming specifies links that has to be fused or broken and provides required circuit path. Once a pattern is established for a ROM it remains fixed when power is turned off. ROM is used to implement a complex combinational circuit which will eliminate interconnecting wires.



fig:  $\rightarrow$  Block diagram of ROM

Above figure shows the block diagram of Read only memory (ROM). It consists of 'm' input lines and 'n' output lines.

lines. The combination of input variable lines is called address and the combination from output lines is called a word.

that comes out

- \* Combination of  $2^n$  distinct address is  $2^n$  for  $n$  variable.
  - \* The output will have  $2^m$  word. [ $m=2^n$ ]
  - \*  $m$  will be the number of bits per word.
- ROM is the combination of decoder and OR Gates i.e. decoder outputs are connected with OR Gates.

#### \* Types of ROM

There are two methods for manufacturing ROM

- 1) Mask programming: Format is prepared according to the requirement of customer. Manufacturer prepares the mask and are configured according to the requirement. For mass production it is economical.
- 2) ~~Programmable ROM~~ is hardware procedure which is programmed by electrically and is economical for ~~producing~~ small quantity.

1. Programmable Read Only Memory (PROM): This type of ROM is irreversible which is permanent type and cannot be changed.

#### 2. Erasable PROM:

Erasable PROM (EPROM) can be reconstructed to the initial state of ROM by placing under a special ultraviolet light for a given period of time.

#### 3. Electrically Alterable ROM (EAROM):

ROM's that can be erased with electrical signals are called EAROM. Also known as (EEPROM)

2048

$$\begin{aligned} 2^{\log_2 2048} &= 2^9 \times 4 = 2048 \\ 2^{\log_2 1024} &= 2^9 \times 4 = 1024 \end{aligned}$$

output 4

\*example construct  $32 \times 4$  ROM  
Here,  $2^n = 32$  |  $m = \frac{32}{4} = 8$   
 $n = 5$  numbers of output lines



2. Construct a ROM for

$$F_1(A_1, A_0) = \sum(1, 2, 3)$$

$$F_2(A_1, A_0) = \sum(0, 2)$$

$$2^n = 4 \quad n = 2 \quad | \quad m = 2^m = 4$$

$2^n \times n$

1111  
8421



Fig: Implementation of 9x2 ROM

3. Implement the following function using ROM.

$$F_1 = \sum_m (0, 2, 5) \quad F_2 = \sum_m (3, 4, 7) \quad F_3 = \sum_m (0, 2, 5)$$

$$2^n = 8 \quad n = 3 \quad m = 8$$

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



Fig. Implementation of

3x8 dec

F<sub>3</sub>      F<sub>2</sub>      F<sub>1</sub>

- Q. Design a combinational circuit that accepts 3-bit number and generates an output binary number equal to the square of the input number using ROM.

| Input |       | Output |       |       |       |       |       |       |       |       |
|-------|-------|--------|-------|-------|-------|-------|-------|-------|-------|-------|
|       |       | $A_2$  | $A_1$ | $A_0$ | $B_5$ | $B_4$ | $B_3$ | $B_2$ | $B_1$ | $B_0$ |
| 0     | 0 0 0 | 0      | 0     | 0     | 0 0 0 | 0     | 0     | 0     | 0     | 0     |
| 1     | 0 0 1 | 0      | 0     | 0     | 0 0 1 | 1     | 0     | 0     | 0     | 0     |
| 2     | 0 1 0 | 0      | 0     | 0     | 1 0 0 | 0     | 0     | 0     | 0     | 0     |
| 3     | 0 1 1 | 0      | 0     | 1     | 0 0 1 | 1     | 0     | 0     | 0     | 0     |
| 4     | 1 0 0 | 0      | 1 0   | 0     | 0 0 0 | 0     | 1     | 0     | 0     | 0     |
| 5     | 1 0 1 | 0      | 1 1   | 0     | 0 0 0 | 1     | 1     | 0     | 0     | 0     |
| 6     | 1 1 0 | 1      | 0 0   | 1     | 0 0 0 | 0     | 1     | 0     | 0     | 0     |
| 7     | 1 1 1 | 1      | 1 0   | 0     | 0 0 0 | 1     | 0     | 1     | 0     | 0     |

for Combinational ckt

By examining the above truth table, we have output  $B_0$  is equal to input  $A_0$ , so there is no need to generate  $B_0$ . Output  $B_1$  is always '0', so this output is always known. Therefore only four output need to be generated with the ROM. By observation ROM needs three input and four output.

| $A_2$ | $A_1$ | $A_0$ | $F_1$ | $F_2$ | $F_3$ | $F_4$ |
|-------|-------|-------|-------|-------|-------|-------|
| 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| 0     | 0     | 1     | 0     | 0     | 0     | 0     |
| 0     | 1     | 0     | 0     | 0     | 0     | 1     |
| 0     | 1     | 1     | 0     | 0     | 1     | 0     |
| 1     | 0     | 0     | 0     | 1     | 0     | 0     |
| 1     | 0     | 1     | 0     | 1     | 0     | 0     |
| 1     | 1     | 0     | 1     | 0     | 0     | 0     |
| 1     | 1     | 1     | 1     | 1     | 0     | 0     |



### \* Programmable Logic Array (PLA)

PLA is similar to Read Only Memory (ROM) in concept. However, PLA does not provide full decoding of variable as in ROM. Don't care condition has to be left in their original state but it becomes address input to ROM which will introduce waste of available equipment.

However, PLA does not provide full decoding of variable as in ROM, it is more economical for excessive don't care condition as it does not generate all the minterms as in the ROM.

In PLA the decoder is replaced by a group of AND gates, each of which can be programmed to generate product term of the input variables. The AND and OR Gates inside the PLA are initially fabricated with links among them.



fig: → Block Diagram of PLA

The block diagram of PLA is shown above which consists of n input, m outputs K-product terms and m sum terms.

The product term constitute a group of 'K' AND Gates and the sum terms constitute a group of 'm' OR gates. The size of PLA is specified by the no of inputs, the no of product terms and the no of outputs.

Therefore the number of programmed links is  $2^n \times K + K \times m + m$ , whereas that of ROM is  $2^n \times m$ . The generated output function of PLA is in the AND-OR form and that of PLA is in the AND-OR invert form.

### \* Procedure for PLA program table

1. Construct three columns.
  - a. First column lists the product term
  - b. Second column specifies the path between AND Gates
  - c. Third column specifies the path between AND and the OR Gates.
2. For each output we write T (for true) for uncompleted output and C for

Complemented output by the inverter.

3. Each product term, the inputs are marked 1, 0 and -.
- a. If the product term appears in its normal form, mark the corresponding input variables 1.
- b. If the product term appears in its complemented form, mark the corresponding input variables 0.
- c. If the variable is absent, mark with dash (-).
7. Both the true value and the complement of function should be simplified to see which one can be expressed with fewer product term and which one provides product term that are common to other function.

1. Consider from the given truth table derive a PLA program table and show the internal connection of the unit.

| A | B | C | $F_1$ | $F_2$ |
|---|---|---|-------|-------|
| 0 | 0 | 0 | 0     | 0     |
| 0 | 0 | 1 | 0     | 0     |
| 0 | 1 | 0 | 0     | 0     |
| 0 | 1 | 1 | 0     | 1     |
| 1 | 0 | 0 | 1     | 0     |
| 1 | 0 | 1 | 1     | 1     |
| 1 | 1 | 0 | 0     | 0     |
| 1 | 1 | 1 | 1     | 1     |

From the truth table

$$F_1 = AB'C + AB'C + ABC$$

$$A \backslash \begin{matrix} BC \\ B'C \\ AC \\ A'C \end{matrix} \quad \begin{matrix} 00 \\ 01 \\ 11 \\ 10 \end{matrix}$$

|   |    |   |   |   |
|---|----|---|---|---|
| 0 | A' |   |   |   |
| 1 | A  | 1 | 1 | 1 |

$$F_1 = AC' + AC$$

|    |       |      |      |      |
|----|-------|------|------|------|
|    | $B'C$ | $AC$ | $BC$ | $AC$ |
| A' | 1     | 0    | 0    | 0    |
| A  |       |      |      | 0    |

$$F_1' = A' + BC$$

$$F_2 = A'BC + AB'C + ABC$$

$$A \backslash \begin{matrix} BC \\ A'B'C \\ AC \\ A'C \end{matrix} \quad \begin{matrix} 00 \\ 01 \\ 11 \\ 10 \end{matrix}$$

|    |   |   |   |   |
|----|---|---|---|---|
| A' |   |   | 1 |   |
| A  | 1 | 1 | 1 | 0 |

$$F_2 = AC + BC$$

$$F_2' = C' + A'B'$$

|    |      |      |         |      |      |
|----|------|------|---------|------|------|
|    | $BC$ | $AC$ | $A'B'C$ | $00$ | $01$ |
| A' | 1    | 0    | 0       | 0    | 0    |
| A  | 0    | 1    | 1       | 0    | 0    |



Implement the following three Boolean functions

with a PLA.

$$F_1(A, B, C) = \sum(0, 2, 3, 4)$$

$$F_2(A, B, C) = \sum(0, 5, 6, 7)$$

$$F_3(A, B, C) = \sum(0, 2, 5, 7)$$

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

$$F_1 = A' C + B' C + A' B' C$$

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

$$F_2 = A' C + A' B' + A' B' C$$

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

$$F_3 = A' C + A' B' C + B' C$$

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

$$F_3' = A' C' + A' B' C + B' C$$

| product term | input | output |
|--------------|-------|--------|
| $AB$         | 1     | $F_1$  |
| $AC$         | 1     | $F_2$  |
| $BC$         | 1     | $F_3$  |
| $A'B'C'$     | 0     | -      |

4. Implement the given four Boolean functions using  $8 \times 4$  PLA

$$A(x, y, z) = \sum(1, 2, 4, 6)$$

$$B(x, y, z) = \sum(0, 1, 6, 7)$$

$$C(x, y, z) = \sum(2, 6)$$

$$D(x, y, z) = \sum(1, 2, 3, 5, 7)$$

| $x$ | $y$ | $z$ | $x'$ | $y'$ | $z'$ |
|-----|-----|-----|------|------|------|
| 0   | 0   | 0   | 1    | 1    | 1    |
| 0   | 0   | 1   | 1    | 1    | 0    |
| 0   | 1   | 0   | 1    | 0    | 1    |
| 0   | 1   | 1   | 1    | 0    | 0    |
| 1   | 0   | 0   | 0    | 1    | 1    |
| 1   | 0   | 1   | 0    | 1    | 0    |
| 1   | 1   | 0   | 0    | 0    | 1    |
| 1   | 1   | 1   | 0    | 0    | 0    |

$$A = xz' + yz' + xy'z$$

| $x$ | $y$ | $z$ | $x'$ | $y'$ | $z'$ |
|-----|-----|-----|------|------|------|
| 0   | 0   | 0   | 1    | 1    | 1    |
| 0   | 0   | 1   | 1    | 1    | 0    |
| 0   | 1   | 0   | 1    | 0    | 1    |
| 0   | 1   | 1   | 1    | 0    | 0    |
| 1   | 0   | 0   | 0    | 1    | 1    |
| 1   | 0   | 1   | 0    | 1    | 0    |
| 1   | 1   | 0   | 0    | 0    | 1    |
| 1   | 1   | 1   | 0    | 0    | 0    |

$$B = x'y + xy$$

| $x$ | $y$ | $z$ | $x'$ | $y'$ | $z'$ |
|-----|-----|-----|------|------|------|
| 0   | 0   | 0   | 1    | 1    | 1    |
| 0   | 0   | 1   | 1    | 1    | 0    |
| 0   | 1   | 0   | 1    | 0    | 1    |
| 0   | 1   | 1   | 1    | 0    | 0    |
| 1   | 0   | 0   | 0    | 1    | 1    |
| 1   | 0   | 1   | 0    | 1    | 0    |
| 1   | 1   | 0   | 0    | 0    | 1    |
| 1   | 1   | 1   | 0    | 0    | 0    |

$$C = yz'$$

| $x$ | $y$ | $z$ | $x'$ | $y'$ | $z'$ |
|-----|-----|-----|------|------|------|
| 0   | 0   | 0   | 1    | 1    | 1    |
| 0   | 0   | 1   | 1    | 1    | 0    |
| 0   | 1   | 0   | 1    | 0    | 1    |
| 0   | 1   | 1   | 1    | 0    | 0    |
| 1   | 0   | 0   | 0    | 1    | 1    |
| 1   | 0   | 1   | 0    | 1    | 0    |
| 1   | 1   | 0   | 0    | 0    | 1    |
| 1   | 1   | 1   | 0    | 0    | 0    |

$$D = z + xy$$

| $x$ | $y$ | $z$ | $x'$ | $y'$ | $z'$ |
|-----|-----|-----|------|------|------|
| 0   | 0   | 0   | 1    | 1    | 1    |
| 0   | 0   | 1   | 1    | 1    | 0    |
| 0   | 1   | 0   | 1    | 0    | 1    |
| 0   | 1   | 1   | 1    | 0    | 0    |
| 1   | 0   | 0   | 0    | 1    | 1    |
| 1   | 0   | 1   | 0    | 1    | 0    |
| 1   | 1   | 0   | 0    | 0    | 1    |
| 1   | 1   | 1   | 0    | 0    | 0    |

$$C = yz'$$

| $x$ | $y$ | $z$ | $x'$ | $y'$ | $z'$ |
|-----|-----|-----|------|------|------|
| 0   | 0   | 0   | 1    | 1    | 1    |
| 0   | 0   | 1   | 1    | 1    | 0    |
| 0   | 1   | 0   | 1    | 0    | 1    |
| 0   | 1   | 1   | 1    | 0    | 0    |
| 1   | 0   | 0   | 0    | 1    | 1    |
| 1   | 0   | 1   | 0    | 1    | 0    |
| 1   | 1   | 0   | 0    | 0    | 1    |
| 1   | 1   | 1   | 0    | 0    | 0    |

$$D = z + yz'$$

| Product term | Input |   |   | Output |     |   |   |
|--------------|-------|---|---|--------|-----|---|---|
|              | x     | y | z | A      | B   | C | D |
| $xz'$        | 1     | 1 | 0 | 1      | -   | - | 1 |
| $yz'$        | 2     | - | 1 | 0      | 1   | - | - |
| $x'y'z$      | 3     | 0 | 0 | 1      | 1   | - | - |
| $x'y$        | 4     | 0 | 0 | -      | 1   | - | - |
| $xy$         | 5     | 1 | 1 | -      | 1   | - | - |
| $y'z'$       | 6     | - | 0 | 0      | -   | - | 1 |
|              | T     | T | T | C      | T/C |   |   |

Q) Derive a PLA program table for the Combinational CKT that squares 2 bit number minimize the number of product term

| $\alpha_0 \alpha_1 \alpha_2$ | $x y z$ | $B_0 B_1 B_2 B_3 B_4 B_5$ |
|------------------------------|---------|---------------------------|
| 0                            | 0 0 0   | 0 0 0 0 0 0               |
| 1                            | 0 0 1   | 0 0 0 0 0 1               |
| 2                            | 0 1 0   | 0 0 0 1 0 0               |
| 3                            | 0 1 1   | 0 0 1 0 0 1               |
| 4                            | 1 0 0   | 0 1 0 0 0 0               |
| 5                            | 1 0 1   | 0 1 1 0 0 1               |
| 6                            | 1 1 0   | 1 0 0 1 0 0               |
| 7                            | 1 1 1   | 1 1 0 0 0 1               |

n=3  
m=9  
 $\alpha_0 = 2$  and  $\alpha_1 = 0$

| $\alpha_0 \alpha_1 \alpha_2$ | $x y z$ | $B_2 B_3$        |
|------------------------------|---------|------------------|
| 0                            | 0 0 0   | $x'y'z + xy'z'$  |
| 1                            | 0 0 1   | $x'y'z + x'y'z'$ |
| 2                            | 0 1 0   | $x'y'z + x'y'z'$ |
| 3                            | 0 1 1   | $x'y'z + x'y'z'$ |
| 4                            | 1 0 0   | $x'y'z + x'y'z'$ |
| 5                            | 1 0 1   | $x'y'z + x'y'z'$ |
| 6                            | 1 1 0   | $x'y'z + x'y'z'$ |
| 7                            | 1 1 1   | $x'y'z + x'y'z'$ |

| $\alpha_0 \alpha_1 \alpha_2$ | $x y z$ | $B_4 B_5$            |
|------------------------------|---------|----------------------|
| 0                            | 0 0 0   | $xy'z' + xyz + xy'z$ |
| 1                            | 0 0 1   | $xy'z' + xyz + xy'z$ |
| 2                            | 0 1 0   | $xy'z' + xyz + xy'z$ |
| 3                            | 0 1 1   | $xy'z' + xyz + xy'z$ |
| 4                            | 1 0 0   | $xy'z' + xyz + xy'z$ |
| 5                            | 1 0 1   | $xy'z' + xyz + xy'z$ |
| 6                            | 1 1 0   | $xy'z' + xyz + xy'z$ |
| 7                            | 1 1 1   | $xy'z' + xyz + xy'z$ |

| Product term | Input |     |     | Output |       |       |       |
|--------------|-------|-----|-----|--------|-------|-------|-------|
|              | $x$   | $y$ | $z$ | $B_5$  | $B_4$ | $B_3$ | $B_2$ |
| $y'z'$       | 1     | -   | 0   | -      | 1     | -     | 1     |
| $x'y'z$      | 2     | 0   | 1   | 1      | -     | -     | 1     |
| $xyz'$       | 3     | 1   | 0   | 1      | -     | -     | 1     |
| $xy$         | 4     | 1   | 1   | -      | 1     | -     | -     |
| $x'$         | 5     | 0   | -   | -      | 1     | -     | -     |
|              | T     | C   | T   | T      | T/C   |       |       |

6. Design a PLA program table for the combinational circuit that squares a 4-bit number minimize the number of product term.

|    | $wxyz$ | $s_0$ | $s_1$ | $s_2$ | $s_3$ | $s_4$ | $s_5$ | $s_6$ | $s_7$ | $s_8$ | $s_9$ | $s_{10}$ | $s_{11}$ | $s_{12}$ | $s_{13}$ | $s_{14}$ | $s_{15}$ |
|----|--------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|----------|----------|----------|----------|----------|----------|
| 0  | 0000   | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0        | 0        | 0        | 0        | 0        | 0        |
| 1  | 0001   | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 1     | 1     | 1     | 1        | 1        | 1        | 1        | 1        | 1        |
| 2  | 0010   | 0     | 0     | 0     | 0     | 1     | 0     | 0     | 0     | 0     | 0     | 0        | 0        | 0        | 0        | 0        | 0        |
| 3  | 0011   | 0     | 0     | 0     | 0     | 1     | 0     | 0     | 1     | 1     | 1     | 1        | 1        | 1        | 1        | 1        | 1        |
| 4  | 0100   | 0     | 0     | 0     | 1     | 0     | 0     | 0     | 0     | 0     | 0     | 0        | 0        | 0        | 0        | 0        | 0        |
| 5  | 0101   | 0     | 0     | 0     | 1     | 1     | 0     | 0     | 1     | 1     | 1     | 1        | 1        | 1        | 1        | 1        | 1        |
| 6  | 0110   | 0     | 0     | 1     | 0     | 0     | 1     | 0     | 0     | 0     | 0     | 0        | 0        | 0        | 0        | 0        | 0        |
| 7  | 0111   | 0     | 0     | 1     | 1     | 0     | 0     | 0     | 1     | 1     | 1     | 1        | 1        | 1        | 1        | 1        | 1        |
| 8  | 1000   | 0     | 1     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0        | 0        | 0        | 0        | 0        | 0        |
| 9  | 1001   | 0     | 1     | 0     | 1     | 0     | 0     | 0     | 1     | 1     | 1     | 1        | 1        | 1        | 1        | 1        | 1        |
| 10 | 1010   | 0     | 1     | 1     | 0     | 0     | 1     | 0     | 0     | 0     | 0     | 0        | 0        | 0        | 0        | 0        | 0        |
| 11 | 1011   | 0     | 1     | 1     | 1     | 1     | 0     | 0     | 1     | 1     | 1     | 1        | 1        | 1        | 1        | 1        | 1        |
| 12 | 1100   | 1     | 0     | 0     | 1     | 0     | 0     | 0     | 0     | 0     | 0     | 0        | 0        | 0        | 0        | 0        | 0        |
| 13 | 1101   | 1     | 0     | 1     | 0     | 1     | 0     | 0     | 1     | 1     | 1     | 1        | 1        | 1        | 1        | 1        | 1        |
| 14 | 1110   | 1     | 1     | 0     | 0     | 0     | 1     | 0     | 0     | 0     | 0     | 0        | 0        | 0        | 0        | 0        | 0        |
| 15 | 1111   | 1     | 1     | 1     | 0     | 0     | 0     | 1     | 0     | 0     | 0     | 0        | 0        | 0        | 0        | 0        | 0        |

$$S_0 = Z \quad S_1 = 0$$

|        |                                                                       |                                                                       |
|--------|-----------------------------------------------------------------------|-----------------------------------------------------------------------|
| $wxyz$ | $s_2 = \sum(2, 6, 10, 14)$                                            | $s_3 = \sum(3, 5, 11, 13)$                                            |
| $wxyz$ | $s_4 = \sum(4, 5, 7, 9, 11, 12)$                                      | $s_5 = \sum(6, 7, 10, 11, 13, 15)$                                    |
| $wxyz$ | $s_6 = \sum(8, 9, 10, 12, 14, 15)$                                    | $s_7 = \sum(12, 13, 14, 15)$                                          |
| $wxyz$ | $s_8 = \sum(0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15)$    | $s_9 = \sum(0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15)$    |
| $wxyz$ | $s_{10} = \sum(0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15)$ | $s_{11} = \sum(0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15)$ |
| $wxyz$ | $s_{12} = \sum(0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15)$ | $s_{13} = \sum(0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15)$ |
| $wxyz$ | $s_{14} = \sum(0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15)$ | $s_{15} = \sum(0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15)$ |
| $wxyz$ | $s_2 = yz'$                                                           | $s_3 = xy'z + x'yz$                                                   |
| $wxyz$ | $s_4 = y'z$                                                           | $s_5 = z' + x'y'z + xy'z$                                             |
| $wxyz$ | $s_6 = x'y'z + w'xz + w'xy$                                           | $s_7 = w'yz + w'xz + w'xy$                                            |
| $wxyz$ | $s_8 = x'y'z + w'xz + w'xy$                                           | $s_9 = w'yz + w'xz + w'xy$                                            |
| $wxyz$ | $s_{10} = w'yz + w'xz + w'xy$                                         | $s_{11} = w'yz + w'xz + w'xy$                                         |
| $wxyz$ | $s_{12} = w'yz + w'xz + w'xy$                                         | $s_{13} = w'yz + w'xz + w'xy$                                         |
| $wxyz$ | $s_{14} = w'yz + w'xz + w'xy$                                         | $s_{15} = w'yz + w'xz + w'xy$                                         |

| $wx' y_2$  | 00  | 01  | 11  | 10  |
|------------|-----|-----|-----|-----|
| 00 w $x_1$ | 0 0 | 0 0 | 0 0 | 0 0 |
| 01 w $x_1$ | 0 0 | 0 0 | 0 0 | 0 0 |
| 11 w $x_1$ | 0 0 | 1 1 | 1 1 | 1 1 |
| 10 w $x_1$ | 1 1 | 1 1 | 1 1 | 1 1 |

| $wx' y_2 00$ | 02  | 12  | 20  |
|--------------|-----|-----|-----|
| 00 w $x_1$   | 1 0 | 0 0 | 0 0 |
| 01 w $x_1$   | 0 0 | 0 0 | 0 0 |
| 11 w $x_1$   | 1 1 | 1 1 | 1 1 |
| 10 w $x_1$   | 0 0 | 0 0 | 0 0 |

$$S_6 = wx' + wy$$

$$S_6' = w' + xy'$$

$$S_7 = wx$$

$$S_7' = w' + x'$$

$$S_2 = yz'$$

$$S_2' = y' + z$$

$$S_3 = xy'z + x'y_2$$

$$S_3' = xy + x'y' + z'$$

$$S_4 = xy'z' + w'xz + wx'z$$

$$S_4' = x'z' + wxz + yz' + wox_1$$

$$S_5 = wx'y + wxz + wyz$$

$$S_5' = wox_1 + y'z' + x'y \\ + w'y' + wxz'$$

$$S_6 = wx' + wy$$

$$S_6' = w' + xy$$

$$S_7 = wxwz$$

$$S_7' = w' + x'$$