

## Binary Codes :-

\* Digital data is represented, stored and transmitted as group of binary digits. The groups of bits is also known as binary code - which represents both numeric or alphanumeric.

### Classification of binary codes.

#### Codes :-



### Error detecting and Correcting Codes :-

#### Introduction :-

- \* When digital information in binary form is transmitted from one circuit to another circuit error may occur (ie 0 may change to 1 & viceversa) due to presence of noise.
- \* To avoid error b/w transmitter & receiver - extra bit or more than one bit are added in the data called as parity bit.
- \* The extra bit allows the detection & sometime correction of error in the data.

- \* The data along with the parity bit forms the code.
- \* Codes which allow only error detection are called error detecting codes.
- \* Codes which allows error detection & correction are called error detecting & correcting codes.

### Parity Bit :-

- \* A parity bit is used for the purpose of detecting errors during transmission of binary information.
- \* It is an extra bit included with the binary message to make the number of 1's either odd or even.
- \* The message including parity bit is transmitted & checked at the receiving end for errors.
- \* If an error is detected the receiver request the transmitter to retransmit the message again.
- \* The circuit that generates the parity bit in the transmitter is called parity generator.
- \* The circuit that checks the parity in the receiver is called parity checker.
- \* The parity can be even parity or odd parity
- \* In even parity the added parity bit will make the total numbers of 1's an even amount.
- \* In odd parity the added parity bit will make the total number of 1's an odd amount.

3 bit message.      Message with odd parity      Message with even parity.

|       |                                   |                      |                |
|-------|-----------------------------------|----------------------|----------------|
| 0 0 0 | <sup>Parity bit</sup><br><u>1</u> | <u>0 0 0</u> msg bit | 0 0 0          |
| 0 0 1 | <u>0</u>                          | <u>0 0 1</u>         | <u>1</u> 0 0 1 |
| 0 1 0 | <u>0</u>                          | <u>0 1 0</u>         | <u>1</u> 0 1 0 |
| 0 1 1 | <u>1</u>                          | <u>0 1 1</u>         | <u>0</u> 0 1 1 |
| 1 0 0 | <u>0</u>                          | <u>1 0 0</u>         | <u>1</u> 1 0 0 |
| 1 0 1 | <u>1</u>                          | <u>1 0 1</u>         | <u>0</u> 1 0 1 |
| 1 1 0 | <u>1</u>                          | <u>1 1 0</u>         | <u>0</u> 1 1 0 |
| 1 1 1 | <u>0</u>                          | <u>1 1 1</u>         | <u>1</u> 1 1 1 |

Example:-

write the message 0111001 with an even parity. place the parity bit in the M&B.

Added parity bit 00111001 (The message contains even number of 1's so the parity bit is 0)

Example:-

The received code is 1000 0001 check whether code is correctly received or not if the parity is odd.

1000 0001 - (The Message contains even number of 1's, but the parity used is odd parity - Therefore the code is not received correctly)

\* The parity error detection system just detects any odd number of error - It cannot detect even number of errors.

## Block parity :-

\* Several binary words are transmitted & received continuously. It can be regarded as block of data having rows & columns.

for example:-

- Consider a four eight bit word ( $4 \times 8$  block)
- Parity is assigned to both rows & columns. The scheme is known as Block parity.
- possible to correct single error & detect any two errors in the word.

| Data    | Data    |                                |
|---------|---------|--------------------------------|
| 1 0 1 1 | 0 1 0 1 | 1                              |
| 0 1 0 1 | 0 1 0 1 | 0                              |
| 1 1 0 0 | 1 1 0 1 | 1                              |
| 1 0 0 1 | 1 0 1 1 | 1                              |
| <hr/>   |         |                                |
| 1 0 1 1 | 0 1 1 0 | Even Parity<br>Parity columns. |

Transmitted Data

|         |         |                                     |
|---------|---------|-------------------------------------|
| 1 0 1 1 | 0 1 0 1 | 1                                   |
| 0 1 1 1 | 0 1 0 1 | 0                                   |
| 1 1 0 0 | 1 1 0 1 | 1                                   |
| 1 0 0 1 | 1 0 1 1 | 1                                   |
| <hr/>   |         |                                     |
| 1 0 1 1 | 0 1 1 0 | Parity error.<br>↓<br>Parity error. |

Received Data.

The error bit is at  
 $2^{\text{nd}}$  row -  $3^{\text{rd}}$  column.

|         |         |   |
|---------|---------|---|
| 1 0 0 0 | 0 1 0 1 | 1 |
| 0 1 0 1 | 0 1 0 1 | 0 |
| 1 1 0 0 | 1 1 0 1 | 1 |
| 1 0 0 1 | 1 0 1 1 | 1 |
| <hr/>   |         |   |
| 1 0 1 1 | 0 1 1 0 | 1 |

↑↑  
Parity error - Two errors have occurred in  
 $3^{\text{rd}}$  &  $4^{\text{th}}$  columns.

\* The parity bit checks all bit locations having 1's in the same location in the binary location numbers.

\* Therefore  $P_1$  checks for 3, 5 and 7 ---- and assigns  $P_1$  according to even or odd parity.

| Bit designation.          | $\longleftrightarrow$ | $D_5$ | $P_4$ | $D_3$ | $P_2$ | $P_1$ |
|---------------------------|-----------------------|-------|-------|-------|-------|-------|
| Bit location              | $\longleftrightarrow$ | 5     | 4     | 3     | 2     | 1     |
| Binary location number    | $\longleftrightarrow$ | 101   | 100   | 011   | 010   | 001   |
| Information bit ( $D_n$ ) | $\longleftrightarrow$ |       |       |       |       |       |
| Parity bit ( $P_n$ )      | $\longleftrightarrow$ |       |       |       |       |       |

Assignment of  $P_2$  :-

\*  $P_2$  bit has '1' in the middle bit of the binary location num n.

\*  $P_2$  checks for bits having 1 in the middle bit

\* Parity bit  $P_2$  checks bit location 2, 3, 6 & 7 -----

\* assigns  $P_2$  according to even or odd parity.

Assignment of  $P_4$  :-

\*  $P_4$  has '1' in the left most bit

\*  $P_4$  checks for bits having '1' in the LSB

\* Parity bit  $P_2$  checks bit location 5, 6, 7 -----

\* assigns  $P_4$  according to even or odd parity.

### Hamming code :-

\* R.W Hamming developed a system that provided a way to add one or more parity bits to a data character in order to detect and correct errors.

Step : 1 Number of parity bits  
 → Assign the number of parity bits depending on the number of information bits.

The no. of parity bits is determined by.

$$2^P \geq x + p + 1 \quad \text{where } x - \text{no. of information bits}$$

P - no. of parity bit.

→ The value of p is determined by trial & error method.

Step : 2 Location of parity bits in the code.

→ The bits are designated from the right most bit as bit 1, bit 2, bit 3 and so on.

----- Bit<sub>4</sub> Bit<sub>3</sub> Bit<sub>2</sub> Bit<sub>1</sub>

→ The parity bits are located in the positions corresponding to  $2^0, 2^1, 2^2, 2^3$  ----- = [1, 2, 4, 8-----]

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

P<sub>n</sub> → designation of parity bit ; D<sub>n</sub> → designation of information bit

Step : 3 Assigning values of parity bit.

→ Write the binary number of each decimal location number.

Assignment of P<sub>i</sub> :-

\* The binary location number of Parity bit P<sub>i</sub> has a '1' for its right most digit.

Problem:

U-I-(4)

Encode the binary word 1011 into seven bit even parity Hamming code.

Solution:-

Step: 1 find the number of parity bits required.

Let  $P = 2$  then

$$2^P \geq x + P + 1$$

$$2^2 \geq 4 + 2 + 1$$

$$4 \geq 7 \quad \times$$

Condition not satisfied.

So Let  $P = 3$  then

$$2^P \geq x + P + 1$$

$$2^3 \geq 4 + 3 + 1$$

$$8 \geq 8$$

Condition satisfied.

So  $\boxed{P = 3}$  Total length of encoded Message  $= x + P$   
 $= 4 + 3$

Step: 2 construct the bit location table.

| Bit designation        | $D_7$ | $D_6$ | $D_5$ | $P_4$ | $D_3$ | $P_2$ | $P_1$ |
|------------------------|-------|-------|-------|-------|-------|-------|-------|
| Bit location           | 7     | 6     | 5     | 4     | 3     | 2     | 1     |
| Binary location number | 111   | 110   | 101   | 100   | 011   | 010   | 001   |
| Information bit        | 1     | 0     | 1     |       |       | 1     |       |
| Parity bits            |       |       |       | 0     | .     | 0     | 1     |

Step: 3

Assign  $P_1 \rightarrow$  check for location 3,5,7  $\rightarrow$  The location have

3 1's & so for even parity  $\underline{P_1 = 1}$

Assign  $P_2 \rightarrow$  check for location 3,6,7  $\rightarrow$  The location have

2 1's & for even parity  $\underline{P_2 = 0}$

Assign  $P_4 \rightarrow$  check for location 5,6,7  $\rightarrow$  The location have 2 1's for even parity  $\underline{P_4 = 0}$

Step: 4

$\boxed{\text{The encoded Hamming code} = 1010101}$

(9)

Problem :- Determine the single error correcting code for the information code 10111 for odd parity.

Solution :-

Step: 1 find the number of Parity bits.

Let  $P = 3$  then

$$2^P \geq x + P + 1$$

$$2^3 \geq 5 + 3 + 1$$

$$8 \geq 9$$

Condition not satisfied.

so let  $P = 4$  then

$$2^P \geq x + P + 1$$

$$2^4 \geq 5 + 4 + 1$$

$$16 \geq 9$$

Condition satisfied

so  $P = 4$

$$\begin{aligned} \text{Total length of} \\ \text{encoded message} \\ \Downarrow \\ = x + P \\ = 5 + 4 = 9 \end{aligned}$$

Step: 2 construct the bit location table.

| Bit designation    | $D_9$ | $P_8$ | $D_7$ | $D_6$ | $D_5$ | $P_4$ | $D_3$ | $P_2$ | $P_1$ |
|--------------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| Bit location       | 9     | 8     | 7     | 6     | 5     | 4     | 3     | 2     | 1     |
| Binary location no | 1001  | 1000  | 011   | 0110  | 0101  | 0100  | 0011  | 0010  | 0001  |
| Information bit    | 1     | 0     | 1     | 1     |       |       | 1     | 1     |       |
| Parity bits        |       | 0     |       |       |       |       | 1     | 1     | 0     |

Step: 3

Assign  $P_1$  - check location 3, 5, 7, 9  $\rightarrow$  The location have 8 1's  
so odd parity  $P_1 = 0$

Assign  $P_2$  - check location 3, 6, 7  $\rightarrow$  The location have 2 1's  
for odd parity  $P_2 = 1$

Assign  $P_4$  - check location 5, 6, 7  $\rightarrow$  The location have 2 1's  
for odd parity  $P_4 = 1$

Assign  $P_8$  - check for location 9  $\rightarrow$  The location have 1 1's  
for odd parity  $P_8 = 0$

Step: 4 [The encoded Message is 10011110]

m  
U-I ⑤

Detecting & correcting an error.

- \* Each parity bit, along with its corresponding group of bits must be checked for proper parity.
- \* The correct result of individual parity check is marked by 0
- \* The wrong result is marked by 1
- \* After all parity checks, binary word is formed taking result bit for  $P_1$  as LSB - The word gives bit location where error was occurred.
- \* If word has all bits 0 there is no error in the Hamming code.

Problem:- Assume that the even parity Hamming code.

(0110011) is transmitted & that 0100011 is received.

The receiver does not know what was transmitted. Determine bit location where error has occurred using received code.

Solution:-

Step: 1 Construct the bit location table.

| Bit designation  | $D_7$ | $D_6$ | $D_5$ | $P_4$ | $D_3$ | $P_2$ | $P_1$ |
|------------------|-------|-------|-------|-------|-------|-------|-------|
| Bit location     | 7     | 6     | 5     | 4     | 3     | 2     | 1     |
| Bit location no. | 111   | 110   | 101   | 100   | 011   | 010   | 001   |
| Received code.   | 0     | 1     | 0     | 0     | 0     | 1     | 1     |

Step: 2 Check for parity bits.

for  $P_1$  :  $P_1$  checks location 1, 3, 5, & 7  
 1 0 0 0

\* Binary number - 1. since the given parity is even & there is one + in the group.

∴ Parity check for even parity is wrong ----- 1 (LSB)

for  $P_2$  :  $P_2$  checks location 2, 3, 6 & 7  
+ 0 1 0

Since the given parity is even & parity check for even parity is correct ----- 0

for  $P_4$   $P_4$  checks location 4, 5, 6, & 7  
0 0 1 0

Parity check for even parity is wrong ----- 1

Step: 3 form binary word from the result.

1 0 1 → 5 It means that bit location 5 has an error. It is 0 but it should be 1

∴ The correct code is 0 1 1 0 0 1 1

Problem:- The Hamming code 101101101 is received. Detect if any error has occurred & correct it using odd parity.

Solution:-

Step: 1 construct a bit location table.

| Bit designation  | $D_9$ | $P_8$ | $D_7$ | $D_6$ | $D_5$ | $P_4$ | $D_3$ | $P_2$ | $P_1$ |
|------------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| Bit location     | 9     | 8     | 7     | 6     | 5     | 4     | 3     | 2     | 1     |
| Bit location no. | 1001  | 1000  | 0111  | 0110  | 0101  | 0100  | 0011  | 0010  | 0001  |
| Received code    | 1     | 0     | 1     | 1     | 0     | 1     | 1     | 0     | 1     |

Step: 2 check for parity bits.

for  $P_1$  - check location 1, 3, 5, 7 & 9

1 1 0 1 . 1 → 4 1's

Parity check for odd parity is wrong ---- 1 (LSB)

for  $P_2$  - check location 2, 3, 6, 7

0 1 1 1

Parity check for odd parity is correct ---- 0

for  $P_4$  - check location 4, 5, 6, 7

1 0 1 1

Parity check for odd parity is correct ---- 0

for  $P_8$  - check location 8 & 9

0 1

Parity check for odd parity is correct ---- 0

A error had occurred in bit 0001 so change the bit

value. Therefore the transmitted message code is 101101100

Assignment :-

Given that a frame with bit sequence 1101011011 is transmitted, it has been received as 1101011010. Determine the method of detecting the error using any one error detecting code.

## Arithmetic operation :-

\* Arithmetic operations in a computer are done using binary numbers & takes place in arithmetic unit.

\* The Arithmetic operations are Addition, Subtraction, multiplication & Division.

| Addition               | Subtraction | multiplication   | Division                        |
|------------------------|-------------|------------------|---------------------------------|
| $0+0=0$                | $0-0=0$     | $0 \times 0 = 0$ | $0 \div 1 = 0$                  |
| $0+1=1$                | $1-0=1$     | $0 \times 1 = 0$ | $1 \div 1 = 1$                  |
| $1+0=1$                | $1-1=0$     | $1 \times 0 = 0$ | $0 \div 0 = \text{not allowed}$ |
| $1+1=10$<br>↑<br>carry | $10-1=1$    | $1 \times 1 = 1$ | $1 \div 0 = \text{not allowed}$ |

Binary Addition :- Two binary numbers can be added in same way as decimal number are added  $\rightarrow$  start adding from LSB.

Problem :- Add 1010 and 1111

$$\begin{array}{r}
 1010 \\
 + 1111 \\
 \hline
 11001
 \end{array}
 \quad
 \begin{array}{r}
 10 \\
 + 15 \\
 \hline
 25
 \end{array}
 \quad
 \boxed{\text{Ans : } 11001}$$

## Binary Subtraction :-

Problem : Subtract 1001 - 1101

$$\begin{array}{r}
 1101 \\
 - 1001 \\
 \hline
 0100
 \end{array}
 \quad
 \begin{array}{r}
 13 \\
 - 9 \\
 \hline
 4
 \end{array}
 \quad
 \boxed{\text{Ans : } 0100}$$

Problem : Subtract 1001 - 0111

$$\begin{array}{r}
 1010 \\
 \times 001 \\
 \hline
 0111 \\
 - 0111 \\
 \hline
 0010
 \end{array}
 \quad
 \begin{array}{r}
 9 \\
 - 7 \\
 \hline
 2
 \end{array}
 \quad
 \boxed{\text{Ans : } 0010}$$

## Binary multiplication :-

Problem: multiply the binary numbers.

$$(i) 1011 \times 1101 \quad (ii) 100110 \times 1001$$

$$(iii) 1.01 \times 10.1$$

Solution:-

$$(i) 1011 \times 1101$$

$$\begin{array}{r} 1011 \\ 1101 \\ \hline 1011 \\ 0000 \\ \hline 1011 \\ 1011 \\ \hline 10001111 \end{array}$$

$$(ii) 100110 \times 1001$$

$$\begin{array}{r} 100110 \\ 1001 \\ \hline 100110 \\ 000000 \\ 000000 \\ \hline 100110 \\ 10101010 \end{array}$$

$$(iii) 1.01 \times 10.1$$

$$\begin{array}{r} 101 \\ 101 \\ \hline 000 \\ 101 \\ \hline 11001 \end{array}$$

## Binary division :-

Problem: Divide the following

$$(i) 11001 \div 101$$

$$(i) 11001 \div 101$$

$$101 \overline{)11001}$$

$$\boxed{11001 \div 101 = 101}$$

$$\begin{array}{r} 101 \\ 101 \\ \hline 000 \end{array}$$

remainder

$$(ii) 11101 \div 1100$$

$$\begin{array}{r} 10.011 \\ 1100 \overline{)11101} \\ 1100 \\ \hline 10100 \\ 1100 \\ \hline 10000 \\ 1100 \\ \hline 0100 \end{array}$$

$$11101 \div 1100 = 10.011$$

Signed Binary Numbers :-

- \* + sign  $\rightarrow$  positive number & - sign  $\rightarrow$  negative number.
- \* Due to hardware limitations both +ve & -ve numbers are represented in binary numbers.

\* The left most bit represents the sign of the number



Sign bit 0  $\rightarrow$  no. is positive  
1  $\rightarrow$  no. is negative:

\* unsigned 8-bit binary number ranges from 0 to 255

\* signed 8-bit binary number ranges from +127 to -128

Complements :-

- \* 1's complement
  - \* 2's complement
  - \* 9's complement
  - \* 10's complement
  - \* 15's complement
  - \* 16's complement
- \* In digital computers to simplify the subtraction operation complements are used.

\* There are two types of complement.

- $\rightarrow$  radix complement -  $R$  complement
- $\rightarrow$  diminished radix -  $R-1$  complement.

\* Binary number  $\rightarrow$  base 2  $\rightarrow$  2's complement - radix  
 $(2-1) \rightarrow 1$ 's complement - diminished.

\* decimal number  $\rightarrow$  base 10  $\rightarrow$  10's complement  
 $(10-1) \rightarrow 9$ 's complement.

\* hexadecimal  $\rightarrow$  base 16  $\rightarrow$  16's complement  
 $(16-1) \rightarrow 15$ 's complement.

1's complement :-

\* can be obtained by changing all 0's to 1 and all 1's to 0.

example:- find 1's complement of 0110

$$0110 \rightarrow 1001$$

2's complement :-

\* can be obtained by adding 1 to its 1's complement.

example:- find 2's complement of 1010

$$\begin{array}{r} 1010. \rightarrow 1 \text{'s complement} \rightarrow 0101 \\ + 1 \\ \hline 2 \text{'s complement} \rightarrow \underline{\underline{0110}} \end{array}$$

9's complement :-

\* obtained by subtracting each digit in the number from "9".

example:- find the 9's complement of 4397

$$\begin{array}{r} 9999 \\ - 4397 \\ \hline 5602 \end{array}$$

4397  $\rightarrow$  9's complement  $\rightarrow$  5602.

## 10's complement

\* 10's complement is equal to its 9's complement + 1

example:- find the 10's complement of 739

$$\begin{array}{r} \text{9's complement} \rightarrow 9\ 9\ 9 \\ 7\ 3\ 9 \\ \hline 2\ 6\ 0. \end{array}$$

Add '1' with 9's complement

$$260 + 1 = 261$$

$$739 \rightarrow 10's \text{ complement} \rightarrow \underline{\underline{261}}$$

## 15's complement

\* obtained by subtracting each digit from 15

example:- find 15's complement of A9B.

$$\begin{array}{r} 15\ 15\ 15 \\ - A\ 9\ B \\ \hline 5\ 6\ 4. \end{array} \quad A9B \rightarrow 15's \text{ complement} \rightarrow 564$$

## 16's complement

\* obtained by adding .1 to the LSB of 15's complement.

example:- find the 16 complement of A9C

15's complement .16's complement

$$\begin{array}{r} 15\ 15\ 15 \\ - A\ 9\ C \\ \hline 5\ 6\ 3. \end{array}$$

$$\begin{array}{r} 563 + \\ 1 \\ \hline 564. \end{array}$$

\* A9C → 16's complement → 564.

## BCD Arithmetic Simplification:-

### Binary code decimal (BCD)

\* BCD is a numeric code in which each digit of a decimal number is represented by a separate group of bits.

\* The most common BCD code is 8-4-2-1 BCD.

\* It is represented by 4-bit binary number - BCD.

\* The numbers 8421 indicate the binary weights of the four bits.

\* In BCD binary number from 0000 to 1001 is only used [0-9].

example!- 7 is represented as 0111  
12 is represented as  $\frac{0001}{001}$      $\frac{0010}{2}$     5421 BCD.

| Decimal | 8421 BCD | 4221 BCD | 5421 BCD |
|---------|----------|----------|----------|
| 0       | 0000     | 0000     | 0000     |
| 1       | 0001     | 0001     | 0001     |
| 2       | 0010     | 0010     | 0010     |
| 3       | 0011     | 0011     | 0011     |
| 4       | 0100     | 0110     | 0100     |
| 5       | 0101     | 0111     | 0101     |
| 6       | 0110     | 1100     | 1001     |
| 7       | 0111     | 1101     | 1010     |
| 8       | 1000     | 1110     | 1011     |
| 9       | 1001     | 1111     | 1100     |
| 10      | 0001     | 0000     |          |
| 11      | 0001     | 0001     |          |

## BCD Addition :-

Step : 1 Add the two numbers using the rules for binary addition

Step : 2 If a four bit sum is equal to or less than 9  
It is a valid BCD number.

Step : 3 If a four bit sum is greater than 9 (or) if a carry out the group is generated. It is an invalid result.  
Add b (0110) to the four bit sum in order to skip the six invalid states & return to BCD.

Problem :- Add the following BCD numbers.

$$(i) \begin{array}{r} 1001 \\ + 0100 \\ \hline 1101 \end{array}$$

$$(ii) \begin{array}{r} 00011001 \\ + 00010100 \\ \hline 00101101 \end{array}$$

$$\begin{array}{r} 1001 \\ + 0100 \\ \hline 1101 \end{array} \rightarrow \text{Invalid BCD.}$$

$$\begin{array}{r} 0110 \\ + 0110 \\ \hline 10011 \end{array} \text{Valid BCD.}$$

$$\begin{array}{r} 10011 \\ - 0000 \\ \hline 10011 \end{array} \text{3}$$

$$\begin{array}{r} 00011001 \\ + 00010100 \\ \hline 00101101 \end{array}$$

$$\begin{array}{r} 0110 \\ + 0110 \\ \hline 00110 \end{array} \text{Valid BCD.}$$

$$\begin{array}{r} 00110 \\ - 0011 \\ \hline 0000 \end{array} \text{3}$$

## BCD Subtraction :-

\* Addition of 9's complement of the subtrahend to minuend.

Problem :- subtract the following using 9's complement Method.

$$(a) 649 - 387$$

$$(b) 891 - 786$$

Solution:-

(a) 9's complement of Subtrahent 387 →

$$\begin{array}{r} 999 \\ - 387 \\ \hline 612 \end{array}$$

Add the result with → 649

$$\begin{array}{r} 612 \\ + 649 \\ \hline 262 \end{array}$$

$$\boxed{649 - 387 = 262}$$

(b) 891 - 786 →

9's complement of Subtrahent 786 →

$$\begin{array}{r} 999 \\ - 786 \\ \hline 213 \end{array}$$

Add the result with → 891

$$\begin{array}{r} 213 \\ + 891 \\ \hline 104 \\ \quad \quad \quad 1 \\ \hline 105 \end{array}$$

$$\boxed{891 - 786 = 105}$$

Non-weighted codes :-

- \* Excess 3 code - The excess 3 represents a decimal number in a binary form as a number greater than 3.
- \* An excess 3 code is obtained by adding 3 to a decimal number.

Excess 3 code.

| Decimal | 8421 BCD | Excess 3 code |
|---------|----------|---------------|
| 0       | 0 0 0 0  | 0 0 1 1       |
| 1       | 0 0 0 1  | 0 1 0 0       |
| 2       | 0 0 1 0  | 0 1 0 1       |
| 3       | 0 0 1 1  | 0 1 1 0       |
| 4       | 0 1 0 0  | 0 1 1 1       |
| 5       | 0 1 0 1  | 1 0 0 0       |
| 6       | 0 1 1 0  | 1 0 0 1       |
| 7       | 0 1 1 1  | 1 0 1 0       |
| 8       | 1 0 0 0  | 1 0 1 1       |
| 9       | 1 0 0 1  | 1 1 0 0       |

Problem:- perform the addition in excess-3 code.

$$103 + 287$$

Solution :-

$$\begin{array}{r}
 & \underline{1} & \underline{0} & \underline{3} \\
 + & 0 0 0 1 & 0 0 0 0 & 0 0 1 1 \\
 + & 0 0 1 1 & 0 0 1 1 & 0 0 1 1 \\
 \hline
 & 0 1 0 0 & 0 0 1 1 & 0 1 1 0 \\
 & 0 1 0 1 & 1 0 1 1 & 1 0 1 0 \\
 \hline
 & 1 0 0 1 & 1 1 1 1 & 0 0 0 0 \\
 & 1 0 0 1 & 1 1 1 1 & 0 0 1 1 \\
 \hline
 & 1 0 0 1 & 1 1 1 1 & 0 0 1 1 \\
 & 0 0 1 1 & 0 0 1 1 & 0 0 1 1 \\
 \hline
 & 0 1 1 0 & 1 1 0 0 & 0 0 1 1
 \end{array}$$

Gray code :-

- \* The Gray code belongs to a code called minimum change codes.
- \* Only one bit in the group changes when moving from one step to the next.
- \* It is also called unit distance code:

conversion of binary number to gray code :-

Step: 1 msb of gray code is the same as the first bit of binary number.

Step: 2 The second bit of gray code equals the Exclusive OR of first & second bit of binary number.

Step: 3 The third bit of gray code equals the exclusive OR of second & third bit of binary number & so on.

Problem: Convert binary 10101101 to its gray code.

Solution:            Binary  
gray.

Conversion of gray code to binary number :-

Step: 1 msb is same as that of gray code.

Each binary bit is the exclusive OR of corresponding gray code & the previous binary bit.

Problem:- Convert 1010111 into binary.



gray

Binary.

①

## Standard Representation for logical Functions:-

- \* Logical functions are expressed in terms of logical variables.
- \* The logical functions can be represented in two forms
  - Sum of products form
  - product of sums form.

### Sum of Products (SOP) :-

- \* The form consists of two or more AND terms that are ORed together.

(eg)  $y = AB + ABC + \bar{B} \cdot A$

Minterm :- Sm

- \* product term containing all the variables  $\rightarrow$  standard sum of products form (or) canonical sum of product form  $\rightarrow$  minterm.

| A | B | C | minterm                   | * The minterm can be stated as                                                 |
|---|---|---|---------------------------|--------------------------------------------------------------------------------|
| 0 | 0 | 0 | $\bar{A} \bar{B} \bar{C}$ | $m_0 \quad y(A, B, C) = \sum m(0, 5, 6)$                                       |
| 0 | 1 | 0 | $\bar{A} B \bar{C}$       | $m_1 \quad (3+8+A) (3+\bar{B}+A) = m_0 + m_5 + m_6$                            |
| 1 | 0 | 0 | $A \bar{B} \bar{C}$       | $m_2 \quad (3+\bar{B}+A) = \bar{A} \bar{B} \bar{C} + A \bar{B} C + AB \bar{C}$ |
| 1 | 0 | 1 | $A \bar{B} C$             | $m_3 \quad * To get the standard SOP form.$                                    |
| 1 | 1 | 0 | $A B \bar{C}$             | $m_4 \quad y(A, B, C) = AB + AB \bar{C} + \bar{B} \cdot A C$                   |
| 1 | 1 | 1 | $A B C$                   | $m_5 \quad * missing terms C in 1^{st} term.$                                  |
|   |   |   |                           | $A C \text{ in } 2^{\text{nd}} \text{ term.}$                                  |

$$\Rightarrow AB(C+\bar{C}) + AB\bar{C} + \bar{B}(A+\bar{A})(C+\bar{C})$$

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

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

$m_7 \quad m_6 \quad m_5 \quad m_1 \quad m_4 \quad m_0$

$$y(A, B, C) = \sum m(0, 1, 4, 5, 6, 7)$$

(2)

Product of Sums (POS) :-  $\prod M$

\* The form consists of OR terms which are ANDed together.

$$(eg) \quad Y(A, B, C) = (A+B)(A+B+\bar{C})(\bar{B})$$

| A | B | C | Maxterm                   |
|---|---|---|---------------------------|
| 0 | 0 | 0 | $A+B+C$                   |
| 0 | 0 | 1 | $A+B+\bar{C}$             |
| 0 | 1 | 0 | $A+\bar{B}+C$             |
| 0 | 1 | 1 | $A+\bar{B}+\bar{C}$       |
| 1 | 0 | 0 | $\bar{A}+B+C$             |
| 1 | 0 | 1 | $\bar{A}+B+\bar{C}$       |
| 1 | 1 | 0 | $\bar{A}+\bar{B}+C$       |
| 1 | 1 | 1 | $\bar{A}+\bar{B}+\bar{C}$ |

\* The maxterm can be stated as

$$Y(A, B, C) = \prod M(0, 2, 4)$$

$$= M_0 * M_2 * M_4$$

$$\Rightarrow (A+B+C)(A+\bar{B}+C)(\bar{A}+\bar{B}+C)$$

To get the standard POS form

$$Y(A, B, C) = (A+B)(A+B+\bar{C})(\bar{B})$$

$$\Rightarrow (A+B+0)(A+B+\bar{C})(0+\bar{B}+0)$$

$$\Rightarrow (A+B+C\bar{C})(A+B+\bar{C})(A\bar{A}+\bar{B}+C\bar{C})$$

$$\Rightarrow (A+B+C)(A+B+\bar{C})(A+\bar{B}+C)(\bar{A}+\bar{B}+C)$$

$$(A+\bar{B}+\bar{C})(\bar{A}+\bar{B}+\bar{C})$$

$$\Rightarrow (A+B+C)(A+B+\bar{C})(A+\bar{B}+C)(\bar{A}+\bar{B}+\bar{C})(\bar{A}+\bar{B}+\bar{C})$$

$$\Rightarrow M_0 * M_1 * M_2 * M_3 * M_6 * M_7$$

$$Y(A, B, C) = \prod M(0, 1, 2, 3, 6, 7)$$

$$(5+)(\bar{A}+A)\bar{B} + \bar{5}8A + (5+)8A$$

$$\bar{5}8\bar{A} + \bar{5}8A + 5\bar{8}\bar{A} + 5\bar{8}A + 58A + \bar{5}8A + 58A + 58A =$$

$$\bar{5}8\bar{A} + \bar{5}8A + 5\bar{8}\bar{A} + 5\bar{8}A + 58A + 58A = ABC + ABC + ABC + ABC + ABC + ABC =$$

(3)

Problem :-

Convert the following Boolean function into standard SOP  
and express it in terms of minterms.

$$Y(A, B, C) = AB + A\bar{C} + BC$$

Solution :-

- \* C term is missing in 1<sup>st</sup> term. add  $C + \bar{C}$
- B term " " " 2<sup>nd</sup> term add  $B + \bar{B}$
- A term " " " 3<sup>rd</sup> term. add  $A + \bar{A}$

$$\Rightarrow AB(C + \bar{C}) + A\bar{C}(B + \bar{B}) + BC(A + \bar{A})$$

$$\Rightarrow ABC + \underline{ABC} + \underline{ABC} + \underline{ABC} + \underline{ABC} + \bar{ABC}$$

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

$\downarrow$        $\downarrow$        $\downarrow$        $\downarrow$   
 M<sub>7</sub>    M<sub>6</sub>    M<sub>4</sub>    M<sub>3</sub>

$$Y(A, B, C) = \Sigma m(3, 4, 6, 7)$$

Problem :-

Convert the following Boolean function into standard POS  
and express it in terms of maxterms.

$$Y(A, B, C) = (A+B)(B+\bar{C})(A+C)$$

Solution :-

- \* add  $C\bar{C}$  in 1<sup>st</sup> term,  $A\bar{A}$  in 2<sup>nd</sup> term &  $B\bar{B}$  in 3<sup>rd</sup> term.

$$\Rightarrow (A+B+C\bar{C})(A\bar{A}+B+\bar{C})(A+B\bar{B}+C)$$

$$\Rightarrow (A+B+C)(A+B+\bar{C})(A+B+\bar{C})(\bar{A}+B+\bar{C})(A+B+C)(A+B+\bar{C})$$

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

$\downarrow$        $\downarrow$        $\downarrow$        $\downarrow$   
 M<sub>0</sub>    M<sub>1</sub>    M<sub>5</sub>    M<sub>2</sub>

$$Y(A, B, C) = \prod M(0, 1, 2, 5)$$

(A)

## Simplification of Boolean Expression :-

- \* To reduce the requirements of hardware, it is necessary to simplify the Boolean expression.
- \* Boolean expressions can be simplified using
  - Algebraic simplification
  - Karnaugh map method. (K-map)
  - Quine - McCluskey method.

### Algebraic Simplification:-

Problem:- Simplify the three variable expression using Boolean algebra.

$$Y(A, B, C) = \bar{A}\bar{B}\bar{C} + \bar{A}\bar{B}C + \bar{A}B\bar{C} + \bar{A}BC + A\bar{B}\bar{C} + A\bar{B}C + AB\bar{C} + ABC$$

### Solution:-

$$\begin{aligned} & \Rightarrow \bar{A}\bar{B}(\bar{C}+C) + \bar{A}B(\bar{C}+C) + A\bar{B}(\bar{C}+C) + ABC(\bar{C}+C) \\ & = \bar{A}\bar{B} + \bar{A}B + A\bar{B} + AB \\ & = A(\bar{B}+B) + A(\bar{B}+B) \\ & = \bar{A} + A \\ & = 1. \end{aligned}$$

### Drawback of algebraic Simplification:-

- \* No easy way to tell whether the simplified expression is in its simplest form or it can be simplified further.

(5)

## Karnaugh map Simplification :-

\* K-map contains cell.

\* The number of cells in a K-map depends upon the number of variables

2 variables

$$2^2 = 4 \text{ cells.}$$

| A | B       | 0  | 1 |
|---|---------|----|---|
| 0 | 00<br>0 | 01 |   |
| 1 | 10      | 11 |   |

3 variables

$$2^3 = 8 \text{ cells.}$$

| A | B                     | C                     | 00                    | 01                    | 11 | 10 |
|---|-----------------------|-----------------------|-----------------------|-----------------------|----|----|
| 0 | 000<br>0              | 001<br>m <sub>0</sub> | 011<br>m <sub>2</sub> | 010<br>m <sub>1</sub> |    |    |
| 1 | 100<br>m <sub>4</sub> | 101<br>m <sub>5</sub> | 111<br>m <sub>7</sub> | 110<br>m <sub>6</sub> |    |    |

4 variables

$$2^4 = 16 \text{ cells.}$$

| AB | CD                      | 00                      | 01                      | 11                      | 10 |
|----|-------------------------|-------------------------|-------------------------|-------------------------|----|
| 00 | 0000<br>m <sub>0</sub>  | 0001<br>m <sub>1</sub>  | 0011<br>m <sub>3</sub>  | 0010<br>m <sub>2</sub>  |    |
| 01 | 0100<br>m <sub>4</sub>  | 0101<br>m <sub>5</sub>  | 0111<br>m <sub>7</sub>  | 0110<br>m <sub>6</sub>  |    |
| 11 | 1100<br>m <sub>12</sub> | 1101<br>m <sub>13</sub> | 1111<br>m <sub>15</sub> | 1110<br>m <sub>14</sub> |    |
| 10 | 1000<br>m <sub>8</sub>  | 1001<br>m <sub>9</sub>  | 1011<br>m <sub>11</sub> | 1010<br>m <sub>10</sub> |    |

Problem:-

Simplify the following expression using K-map.

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

| A | B | C | 00 | 01 | 11 | 10 |
|---|---|---|----|----|----|----|
| 0 | 0 | 1 | 0  | 3  | 2  |    |
| 1 | 1 | 0 | 4  | 5  | 7  | 6  |

$$Y(A, B, C) = \bar{B}\bar{C} + \bar{A}\bar{C}$$

Problem:- Minimize the function using K-map:-

$$Y(A, B, C, D) = \sum m(0, 1, 2, 3, 5, 7, 8, 9, 11, 14)$$

| AB | CD | 00 | 01 | 11 | 10 |
|----|----|----|----|----|----|
| 00 | 1  | 1  | 1  | 1  | 2  |
| 01 | 4  | 1  | 1  | 7  | 6  |
| 11 | 12 | 13 | 15 | 14 |    |
| 10 | 8  | 9  | 11 | 10 |    |

$$Y(A, B, C, D) = \bar{A}\bar{B} + \bar{A}D + \bar{B}\bar{C} + \bar{B}D + ABC\bar{D}$$

$$Y(A, B, C, D) = \bar{A}\bar{B} + \bar{A}D + \bar{B}\bar{C} + \bar{B}D + ABC\bar{D}$$

(6)

Problem:-

Simplify the expression  $Y = \sum m(3, 4, 5, 7, 9, 13, 14, 15)$ 

Using K map method:-

|    |    | CD | 00 | 01 | 11 | 10 |
|----|----|----|----|----|----|----|
|    |    | AB | 00 | 01 | 11 | 10 |
| 00 | 00 | 0  | 1  | 1  | 1  | 2  |
| 01 | 01 | 1  | 1  | 1  | 1  | 6  |
| 11 | 11 | 4  | 5  | 7  | 1  | 12 |
| 10 | 10 | 12 | 13 | 15 | 1  | 14 |
| 00 | 10 | 8  | 9  | 11 | 1  | 10 |

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

$$Y = \textcircled{BD} + \bar{A}\bar{B}\bar{C} + \bar{A}\bar{C}\bar{D} + A\bar{B}C + ABC$$

Redundant

Problem:- Simplify the logic function using K-map.

$$Y(A, B, C, D) = \sum m(0, 1, 2, 3, 5, 7, 8, 9, 11, 14)$$

|    |    | CD | 00 | 01 | 11 | 10 |
|----|----|----|----|----|----|----|
|    |    | AB | 00 | 01 | 11 | 10 |
| 00 | 00 | 1  | 0  | 1  | 1  | 2  |
| 01 | 01 | 1  | 1  | 1  | 1  | 6  |
| 11 | 11 | 4  | 5  | 7  | 1  | 12 |
| 10 | 10 | 12 | 13 | 15 | 1  | 14 |
| 00 | 10 | 8  | 9  | 11 | 1  | 10 |

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

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

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

(13)

(7)

### Don't care Condition:-

- \* The output level is not defined it can be either HIGH or LOW.
- \* These output levels are indicated by 'X' (cross) & called as don't care condition.

Problem:- Simplify the Boolean expressions.

$$Y = \sum m(1, 3, 7, 11, 15) + d(0, 2, 5)$$

Solution:-

| AB | CD | 00 | 01 | 11 | 10 |
|----|----|----|----|----|----|
| 00 | X  | 1  | 1  | 1  | X  |
| 01 |    | 4  | X  | 1  | 6  |
| 11 |    | 5  | 7  | 15 | 14 |
| 10 |    | 8  | 9  | 11 | 10 |

$$Y = \bar{A}\bar{B} + CD$$

Problem:- Minimize the function.

$$Y(A, B, C, D) = \sum m(1, 3, 5, 8, 9, 11, 15) + d(2, 13)$$

| AB  | CD | 00 | d1 | 11 | 10 |
|-----|----|----|----|----|----|
| 00  |    | 0  | 1  | 1  | X  |
| 01  |    | 4  | 1  |    | 6  |
| 101 |    | 12 | X  | 13 | 15 |
| 11  |    | 8  | 9  | 11 | 10 |
| 10  |    | 1  | 1  | 1  |    |

$$\bar{B} + A = (0, 8, A)Y$$

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

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

## Simplification of Product of Sums :-

4-variable

| AB\CD | 00                          | 01                                | 11                                | 10                          |
|-------|-----------------------------|-----------------------------------|-----------------------------------|-----------------------------|
| 00    | $A+B+C+D$                   | $A+B+C+\bar{D}$                   | $A+B+\bar{C}+\bar{D}$             | $A+B+\bar{C}+D$             |
| 01    | $A+\bar{B}+C+D$             | $A+\bar{B}+C+\bar{D}$             | $A+\bar{B}+\bar{C}+\bar{D}$       | $A+\bar{B}+\bar{C}+D$       |
| 11    | $\bar{A}+\bar{B}+C+D$       | $\bar{A}+\bar{B}+C+\bar{D}$       | $\bar{A}+\bar{B}+\bar{C}+\bar{D}$ | $\bar{A}+\bar{B}+\bar{C}+D$ |
| 10    | $\bar{A}+\bar{B}+C+\bar{D}$ | $\bar{A}+\bar{B}+\bar{C}+\bar{D}$ | $\bar{A}+\bar{B}+\bar{C}+D$       | $\bar{A}+\bar{B}+\bar{C}+D$ |

Problem:-

$$Y(A, B, C) = (A + \bar{B} + \bar{C})(A + \bar{B} + C)$$

Solution using Algebraic Method.

$$Y(A, B, C) = (A + \bar{B} + \bar{C})(A + \bar{B} + C)$$

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

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

$$= A(1 + \bar{B}) + A(C + \bar{C}) + \bar{B} + \bar{B}(C + \bar{C})$$

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

$$Y(A, B, C) = A + \bar{B}$$

Solution using K-map POS.



|                         |   |         |
|-------------------------|---|---------|
| $A + \bar{B} + \bar{C}$ | = | 0 0 0   |
| $A + \bar{B} + C$       | = | 0 + 0 . |

(9)

Problem :-

$$Y(A, B, C, D) = \overline{\text{IM}}(0, 1, 3, 5, 6, 7, 9, 10, 11, 12, 13, 15)$$

Simplify using K-map.

Solution :-

|    |    | CD | 00 | 01 | 11 | 10 |
|----|----|----|----|----|----|----|
|    |    | AB | 00 | 01 | 11 | 10 |
| CD | AB | 00 | 0  | 0  | 0  | 2  |
|    |    | 01 | 0  | 0  | 0  | 6  |
| CD | AB | 11 | 0  | 0  | 0  | 14 |
|    |    | 10 | 0  | 0  | 0  | 10 |
|    |    | 00 | 4  | 5  | 7  | 8  |
|    |    | 01 | 12 | 13 | 15 | 9  |
|    |    | 11 |    |    |    |    |
|    |    | 10 |    |    |    |    |

$$\begin{aligned} Y(A, B, C, D) &= \bar{D}(A+B+C)(A+\bar{B}+\bar{C}) \\ &\quad (\bar{A}+\bar{B}+C)(\bar{A}+B+\bar{C}) \end{aligned}$$

Problem :-

$$Y(A, B, C, D) = \overline{\text{IM}}(1, 2, 3, 8, 9, 10, 11, 14) \cdot d(7, 15)$$

Solution :-

|    |    | CD | 00 | 01 | 11 | 10 |
|----|----|----|----|----|----|----|
|    |    | AB | 00 | 01 | 11 | 10 |
| CD | AB | 00 | 0  | 0  | 0  | 2  |
|    |    | 01 | 0  | X  | 7  | 6  |
| CD | AB | 11 | 12 | 13 | 15 | 14 |
|    |    | 10 | 0  | 0  | 0  | 10 |
|    |    | 00 | 4  | 5  | 11 | 8  |
|    |    | 01 | 12 | 13 | 15 | 9  |
|    |    | 11 |    |    |    |    |
|    |    | 10 |    |    |    |    |

$$Y(A, B, C, D)$$

$$Y(A, B, C, D) = (\bar{A}+B)(\bar{A}+\bar{C})(B+\bar{D})(B+\bar{C})$$

## Five Variable :-

|    |  | DE |    | BC |    |  |  |
|----|--|----|----|----|----|--|--|
|    |  | 00 | 01 | 11 | 10 |  |  |
| 00 |  | 0  | 1  | 3  | 2  |  |  |
| 01 |  | 4  | 5  | 7  | 6  |  |  |
| 11 |  | 12 | 13 | 15 | 14 |  |  |
| 10 |  | 8  | 9  | 11 | 10 |  |  |

|    |  | DE |    | BC |    |  |  |
|----|--|----|----|----|----|--|--|
|    |  | 00 | 01 | 11 | 10 |  |  |
| 00 |  | 16 | 17 | 19 | 18 |  |  |
| 01 |  | 20 | 21 | 23 | 22 |  |  |
| 11 |  | 28 | 29 | 31 | 30 |  |  |
| 10 |  | 24 | 25 | 27 | 26 |  |  |

Problem:-

$$\text{Simplify } Y(A, B, C, D, E) = \sum m(0, 1, 5, 6, 9, 13, 14, 17, 21, 22, 25, 29).$$

Solution:-



$$Y(A, B, C, D) = \bar{D}E + \bar{A}\bar{B}\bar{C}\bar{D} + \bar{A}C\bar{D}\bar{E} + \bar{B}C\bar{D}\bar{E}$$

$$(0+1)(1+0)(0+\bar{A})(\bar{B}+\bar{A}) = (0, 1, 8, A)$$

## Combinational Circuits :-

\* Logic circuits for digital systems may be combinational or sequential.

\* Combinational circuit consists of an interconnection of logic gates whose o/p's at any time are determined from only the present combination of inputs.

\* Combinational circuit performs an operation that can be specified logically by a set of Boolean function.



Produced by the internal combinational logic circuit and go to an external destination.

\* for n input variables there are  $2^n$  possible combinations of the binary inputs.

\* for each possible input combination, there is one possible value for each output variable.

\* Combinational circuits can be specified with a truth table that lists the o/p values for each combinational of i/p variables.

\* The Combinational circuits also can be described by

m - Boolean function, one for each input variable.

\* Each o/p function is expressed in terms of n i/p variables

\* The n i/p binary variables come from an external source. The m output variable are

### Design Procedure:-

- \* From the specification of the circuit, determine the required no. of i/p's & o/p's and assign a symbol for each.
- \* Derive the truth table that defines the required relationship b/w i/p's and o/p's
- \* obtain the simplified Boolean function for each o/p as a function of i/p variables
- \* Draw the logic diagram & verify the correctness of the design.

### Analysis Procedure :-

- \* The diagram of a combinational circuit has logic gates with no feedback path or Memory elements.
- \* Label all gate outputs that are a function of input variables with arbitrary symbols - with meaningful names. Determine the boolean functions for each gate o/p.
- \* Label the gates that are a function of i/p variables & previously labeled gates with other arbitrary symbols. find the boolean functions for these gates.
- \* Repeat the process outlined in step-3 until the o/p's of the circuit are obtained.
- \* By repeated substitution of previously defined functions. obtain the o/p Boolean function in terms of i/p variables.

(15)

Adder.

- \* The most basic arithmetic operation is the addition of two binary digits.

- \* The simple addition consists of four possible elementary operations.

$$0 + 0 = 0$$

$$0 + 1 = 1$$

$$1 + 0 = 1$$

$$1 + 1 = 10$$

- \* The first three operations produce a sum of one digit but when both augend and addend bits are equal to 1

The binary sum consists of two digits.

- \* The higher significant bit of this result is called a **carry**

- \* When the augend & addend numbers contain more significant digits, the carry obtained from the addition of two bits is added to the next higher order pair of significant bits.

Half Adder.

- \* A combinational circuit that performs the addition of two bits is called a **half adder**.



\* I/p Variables  $\rightarrow$  augend & addend

$\rightarrow x \& y$

\* O/p Variables  $\rightarrow$  sum & carry

$\rightarrow s \& c$

### Truth Table :-

| Input |   | output |   |
|-------|---|--------|---|
| x     | y | c      | s |
| 0     | 0 | 0      | 0 |
| 0     | 1 | 0      | 1 |
| 1     | 0 | 0      | 1 |
| 1     | 1 | 1      | 0 |

K-map.



$$\text{Sum} = \bar{x}\bar{y} + x\bar{y}$$

$$\text{Sum} = x \oplus y$$

$$\text{carry} = xy$$

$$\text{carry} = xy$$

### Logic diagram



### Full Adder

\* The circuit that performs the addition of three bits is a full adder.

\* It consists of three inputs and two outputs.

I/p = A, B, Cin.

O/p = Sum, carry.



\* Addition of n-bit binary numbers requires the use of full adder & the process of addition proceeds on a bit-by-bit basis right to left. beginning with the least significant bit.

Truth table:-

28, 33, 40, 43, 46, 51, 53  
55, 67, 70, 81, 88

| A | B | Cin | Sum | Carry |
|---|---|-----|-----|-------|
| 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     |

| A | Sum         |    |    |    |
|---|-------------|----|----|----|
|   | BCin.<br>00 | 01 | 11 | 10 |
| 0 | 0           | 1  | 0  | 1  |
| 1 | 1           | 0  | 1  | 0  |

$$\text{Sum} = \underline{A' B' C_{in}} + \underline{A' B C_{in}'} + \\ A B' C_{in}' + A B C_{in}.$$

$$\Rightarrow (A' B' + AB) C_{in} + (A' B + AB') C_{in}$$

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

$$= C_{in} \oplus A \oplus B.$$

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

| A | Carry      |    |    |    |
|---|------------|----|----|----|
|   | BCin<br>00 | 01 | 11 | 10 |
| 0 | 0          | 0  | 1  | 0  |
| 1 | 0          | 1  | 1  | 1  |

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

$$\boxed{\text{carry} = AB + BC_{in} + AC_{in}.}$$

Logic diagram:-

A B Cin.



$$\text{sum.} = A \oplus B \oplus C_{in}.$$



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

## Implementation of full adder with Half adder:-

$$\text{Sum} = \text{Cin} \oplus A \oplus B.$$

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

$$= AB + (A + \bar{A})BC_{\text{in}} + A(B + \bar{B})C_{\text{in}}.$$

$$= AB + \underline{AB}C_{\text{in}} + \bar{A}\underline{B}C_{\text{in}} + \underline{A}\bar{B}C_{\text{in}} + \bar{A}\bar{B}\text{Cin}.$$

$$= AB + AB C_{\text{in}} + \bar{A}\bar{B} C_{\text{in}} + A\bar{B} C_{\text{in}}.$$

$$= AB(1 + C_{\text{in}}) + C_{\text{in}}(\bar{A}\bar{B} + A\bar{B})$$

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

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



\* A full adder can be implemented using two half adders and an OR gate.



## Carry lookahead generator :-

\* Binary adder is a digital circuit that produces arithmetic sum of two binary numbers.

\* Constructed with full adders connected in cascade, with output of carry from each full adder connected to input carry of next full adder.

\* Addition of  $n$  bit numbers require a chain of  $n$  full adders.

$B_3 \ A_3$



\* Four bit binary ripple carry adder.

\* Augent bits of A & Addend bits of B are designated by subscript numbers from right to left with subscript 0 denoting Least significant bit.

\* carries are connected in a chain through the full adders.

\* Consider the two binary numbers  $A = 1011$  and  $B = 0011$

$$\begin{array}{r} 1 \\ | \\ A \ 1 \ 0 \ 1 \ 1 \end{array}$$

$$\begin{array}{r} 1 \\ | \\ B \ 0 \ 0 \ 1 \ 1 \\ \hline 1 \ 1 \ 1 \ 0 \ \text{sum.} \end{array}$$

A      1    0    1    1    A<sub>i</sub>

B      0    0    1    1    B<sub>i</sub>

Carry in.    0    1    1    0    C<sub>i</sub>

                    ↑    ↑    ↑    ↓    sum.

0    0    1    1    carry.

### Carry propagation :-

- \* The addition of two binary numbers in parallel implies that all the bits of augend & addend are available for computation at the same time.
- \* In any combinational circuit, the signal must propagate thro' the gates before the correct output sum is available in O/p terminals.
- \* Total propagation time is equal to the propagation delay of a typical gate, times the number of gate levels in the ckt.
- \* Consider output S<sub>3</sub> → Inputs A<sub>3</sub> & B<sub>3</sub> are available as soon as Input signals are applied to the adder. However input carry C<sub>3</sub> does not settle to its final value until C<sub>2</sub> is available from previous stage.
- \* I<sup>th</sup> by. C<sub>2</sub> has to wait for C<sub>1</sub>, and so on down to C<sub>0</sub>.



- \* The carry propagation time is an important attribute of the adder bcoz it limits the speed with which two numbers are added.
- \* An solution for reducing the carry propagation delay time is to employ faster gates with reduced delays.
- \* Another solution is to increase the complexity of the equipment in such a way that carry delay time is reduced.
- \* The most widely used technique employs the principle of carry look ahead logic.

$$P_i = A_i \oplus B_i$$

$$G_i = A_i B_i$$

The output sum & carry.

$$S_i = P_i \oplus C_i$$

$$C_{i+1} = G_i + P_i C_i$$

$G_i$  is called a carry generate & it produces a carry of 1 when both  $A_i$  and  $B_i$  are 1 regardless of input carry  $C_i$

$P_i$  is called carry propagate bcoz it determines whether a carry into stage  $i$  will propagate into stage  $i+1$

$C_0$  = input carry.

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

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

$$C_3 = G_2 + P_2 C_2$$

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

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





Subtractor!:-

Half Subtractor!:-

\* Half subtractor has two inputs & two outputs.



Inputs - A & B.

~~Difference~~

Outputs - Borrow & Difference .

\* The two inputs A and B form the minuend and the subtrahend.

\* The two outputs D is the Difference output and B is the borrow output.

## TRUTH Table

| A | B | Difference | Borrow |
|---|---|------------|--------|
| 0 | 0 | 0          | 0      |
| 0 | 1 | 1          | 1      |
| 1 | 0 | 1          | 0      |
| 1 | 1 | 0          | 0      |

Difference.

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

$$\text{Difference} = A'B + AB'$$

$$\text{Difference} = A \oplus B$$

Borrow.

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

$$\text{Borrow} \neq A'B$$

A B.

Difference.



## Full Subtractor!

- \* A full subtractor has three inputs and two outputs.
- \* Inputs = A, B and  $B_{in}$  = Borrow input
- Outputs = Difference & Borrow.



Truth table:

| A | B | Bin | Difference | Borrow |
|---|---|-----|------------|--------|
| 0 | 0 | 0   | 0          | 0      |
| 0 | 0 | 1   | 1          | 1      |
| 0 | 1 | 0   | 1          | 1      |
| 0 | 1 | 1   | 0          | 1      |
| 1 | 0 | 0   | 1          | 0      |
| 1 | 0 | 1   | 0          | 0      |
| 1 | 1 | 0   | 0          | 0      |
| 1 | 1 | 1   | 1          | 1      |

| A |   | B Bin |    |    |    | Difference |   |
|---|---|-------|----|----|----|------------|---|
| 0 | 1 | 00    | 01 | 11 | 10 | 0          | 1 |
| 0 | 0 | 0     | 1  | 0  | 1  | 0          | 1 |
| 1 | 0 | 1     | 0  | 1  | 0  | 1          | 0 |

$$\text{Difference} = \overline{A} \overline{B} B_{\text{bin}} + \overline{A} B B_{\text{bin}}'.$$

$$+ A \overline{B} B_{\text{bin}}' + A B B_{\text{bin}}.$$

$$\Rightarrow B_{\text{bin}} (\overline{A} \overline{B}' + A B) + B_{\text{bin}}' (A' B + A B')$$

$$= B_{\text{bin}} (\overline{A} \oplus B) + B_{\text{bin}}' (A \oplus B).$$

$$\text{Difference} = B_{\text{bin}} \oplus A \oplus B.$$

Borrow:

| A |   | B Bin |    |    |    |
|---|---|-------|----|----|----|
| 0 | 1 | 00    | 01 | 11 | 10 |
| 0 | 0 | 1     | 1  | 1  | 1  |
| 1 | 0 | 0     | 1  | 0  | 0  |

$$\text{Borrow} = \overline{B} B_{\text{bin}} + \overline{A} \overline{B} B_{\text{bin}} + A' B.$$

A      B      Bin.



$$\text{Difference} = B_{\text{bin}} \oplus A \oplus B.$$

Borrow

## Binary Subtractor:-

- \* The addition and subtraction operations can be combined into one circuit with one common binary adder by including an exclusive OR gate with each full adder.
- \* The mode input  $M$  controls the operation. When  $m=0$  the circuit is an adder. and when  $m=1$  the circuit becomes a subtractor.



- \* Each Ex-OR gate receives input  $M$  and one of the inputs of  $B$ .
- \* when  $m=0$  we have  $B \oplus 0 = B$ . The full adders receive the value of  $B$ , the input carry is 0 and the circuit performs  $A$  plus  $B$ .

\* when  $m=1$  we have  $B \oplus 1 = B'$  and  $c_0 = 1$ . The  $B$  inputs are all complemented and a '1' is added thru' if carry.

- \* one common hardware circuit handles both types of arithmetic.

### Overflow! -

- \* when two numbers with  $n$  digits each are added and the sum is a number occupying  $n+1$  digits, then we say an overflow occurred.

\* overflow is a problem in digital computers bcoz the number of bits that hold the number is finite & a result that contains  $n+1$  bits cannot be accommodated by an  $n$ -bit word.

- \* for this reason, many computers detect the occurrence of an overflow.

\* The detection of an overflow after the addition of two binary numbers depends on whether the numbers are considered to be signed (or) unsigned.

- \* when two unsigned numbers are added, an overflow is detected

\* In the case of signed numbers - when two signed numbers are added, the sign bit is treated as part of the number & end carry does not indicate an overflow.

- \* An overflow cannot occur after an addition if one number is positive & other is negative.

\* An overflow may occur if the two numbers added are both positive (or) both negative.

\* The binary adder-subtractor circuit with outputs C and V.

\* If the two binary numbers are considered to be unsigned then the C bit detects a carry after addition (or) a borrow after subtraction.

\* If the numbers are considered to be signed, then the V bit detects an overflow.

If  $V = 0$  then no overflow occurred.

If  $V = 1$  then the result of the operation contains  $n+1$  bits.

## Encoders :-

- \* An encoder has  $2^n$  input lines and  $n$  output lines
- \* The output lines generate binary code corresponding to the input value.
- \* An example of the encoder is Octal - binary encoder.



## 8 : 3 Encoder (Octal to Binary)

- \* 8:3 Encoder consists of 8 inputs and 3 outputs.

\* I/p lines =  $D_0$  to  $D_7$

\* O/p lines =  $x \ y \ z$

\* Truth Table.



| Inputs |       |       |       |       |       |       |       | outputs. |     |     |
|--------|-------|-------|-------|-------|-------|-------|-------|----------|-----|-----|
| $y_7$  | $y_6$ | $y_5$ | $y_4$ | $y_3$ | $y_2$ | $y_1$ | $y_0$ | $x$      | $y$ | $z$ |
| 0      | 0     | 0     | 0     | 0     | 0     | 0     | 1     | 0        | 0   | 0   |
| 0      | 0     | 0     | 0     | 0     | 0     | 1     | 0     | 0        | 0   | 1   |
| 0      | 0     | 0     | 0     | 0     | 1     | 0     | 0     | 1        | 0   | 0   |
| 0      | 0     | 0     | 0     | 1     | 0     | 0     | 0     | 0        | 1   | 1   |
| 0      | 0     | 0     | 1     | 0     | 0     | 0     | 0     | 1        | 0   | 0   |
| 0      | 0     | 1     | 0     | 0     | 0     | 0     | 0     | 1        | 0   | 1   |
| 0      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 1        | 1   | 0   |
| 1      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 1        | 1   | 1   |

$$x = y_4 + y_5 + y_6 + y_7$$

$$y = y_2 + y_3 + y_6 + y_7$$

$$z = y_1 + y_3 + y_5 + y_7$$

\* The above function can be implemented using OR gates.

$$y_7 \ y_6 \ y_5 \ y_4 \ y_3 \ y_2 \ y_1 \ y_0$$



\* Encoder has the limitation that only one input can be active at any given time.

\* If two inputs are active simultaneously, the output produces an undefined combination.

### Decimal to BCD Encoder :-

\* Decimal to BCD Encoder consists of 10 Input lines and 4 output lines

\* It accepts decoded decimal data as input & encodes it to BCD output.



Truth Table :-

| Inputs |       |       |       |       |       |       |       |            | outputs |       |       |       |
|--------|-------|-------|-------|-------|-------|-------|-------|------------|---------|-------|-------|-------|
| $y_9$  | $y_8$ | $y_7$ | $y_6$ | $y_5$ | $y_4$ | $y_3$ | $y_2$ | $y_1, y_0$ | $A_3$   | $A_2$ | $A_1$ | $A_0$ |
| 0      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 1          | 0       | 0     | 0     | 0     |
| 0      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 1          | 0       | 0     | 0     | 1     |
| 0      | 0     | 0     | 0     | 0     | 0     | 0     | 1     | 0          | 0       | 0     | 1     | 0     |
| 0      | 0     | 0     | 0     | 0     | 0     | 0     | 1     | 0          | 0       | 0     | 1     | 1     |
| 0      | 0     | 0     | 0     | 0     | 0     | 1     | 0     | 0          | 0       | 0     | 0     | 1     |
| 0      | 0     | 0     | 0     | 0     | 1     | 0     | 0     | 0          | 0       | 1     | 0     | 0     |
| 0      | 0     | 0     | 0     | 1     | 0     | 0     | 0     | 0          | 0       | 1     | 0     | 1     |
| 0      | 0     | 0     | 0     | 1     | 0     | 0     | 0     | 0          | 0       | 1     | 0     | 1     |
| 0      | 0     | 0     | 1     | 0     | 0     | 0     | 0     | 0          | 0       | 1     | 1     | 0     |
| 0      | 0     | 1     | 0     | 0     | 0     | 0     | 0     | 0          | 0       | 1     | 1     | 1     |
| 0      | 1     | 0     | 0     | 0     | 0     | 0     | 0     | 0          | 1       | 0     | 0     | 0     |
| 0      | 1     | 0     | 0     | 0     | 0     | 0     | 0     | 0          | 1       | 0     | 0     | 1     |
| 1      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0          | 1       | 0     | 0     | 0     |

Logical expression:  $A_3 = y_9 + y_8$

$$A_2 = y_7 + y_6 + y_5 + y_4$$

$$A_1 = y_7 + y_6 + y_3 + y_2$$

$$A_0 = y_9 + y_7 + y_5 + y_3 + y_1$$

$y_9 \ y_8 \ y_7 \ y_6 \ y_5 \ y_4 \ y_3 \ y_2 \ y_1, y_0$



## Priority Encoder :-

- \* Priority Encoder is an encoder circuit that includes Priority function.
  - \* The operation of the priority encoder is such that if two or more inputs equal to 1 at the same time, the input having highest priority will be taken precedence.
  - \* In addition to the two outputs  $x$  and  $y$ , the circuit has a third output designated by  $v$ , this is a Valid bit indicator that is set to 1 when one or more inputs are equal to 1.
  - \* If all inputs are 0, there is no valid input and  $v$  is equal to 0.
  - \* The other outputs are not inspected when  $v$  equals 0 and are Specified as don't care conditions.

Truth table :-

| Inputs |       |       |       | outputs |     |     |
|--------|-------|-------|-------|---------|-----|-----|
| $D_0$  | $D_1$ | $D_2$ | $D_3$ | $X$     | $Y$ | $V$ |
| 0      | 0     | 0     | 0     | x       | x   | 0   |
| 1      | 0     | 0     | 0     | 0       | 0   | 1   |
| x      | 1     | 0     | 0     | 0       | 1   | 1   |
| x      | x     | 1     | 0     | 1       | 0   | 1   |
| x      | x     | x     | 1     | 1       | 1   | 1   |

- \* Input  $D_3$  has the highest priority. regardless of the values of other inputs.

\*  $D_2$  has the next priority & output is 10 if  $D_2 = 1$   
 provided  $D_3 = 0$ . regardless of the values of the other two  
 lower priority inputs.

\* The output of  $D_1$  is generated only if higher priority

Inputs are 0.

|           |    | K-map for $X \cdot D_2$ |    |    |    |    |
|-----------|----|-------------------------|----|----|----|----|
|           |    | $D_2 D_3$               | 00 | 01 | 11 | 10 |
| $D_0 D_1$ |    | 00                      | X  | 1  | 1  | 1  |
| $D_0$     | 01 | 01                      | 1  | 1  | 1  | 1  |
|           | 11 | 11                      | 1  | 1  | 1  | 1  |
| $D_1$     | 10 | 10                      | 1  | 1  | 1  | 1  |
|           |    | $D_3$                   |    |    |    |    |

$$X = D_2 + D_3$$

|           |    | K-map for $Y$ |    |    |    |    |
|-----------|----|---------------|----|----|----|----|
|           |    | $D_2 D_3$     | 00 | 01 | 11 | 10 |
| $D_0 D_1$ |    | 00            |    | 1  | 1  |    |
| $D_0$     | 01 | 01            | 1  | 1  | 1  |    |
|           | 11 | 11            | 1  | 1  | 1  | 1  |
| $D_1$     | 10 | 10            | 1  | 1  | 1  | 1  |
|           |    | $D_3$         |    |    |    |    |

$$Y = D_3 + D_1 \cdot D_2'$$

$$V = D_0 + D_1 + D_2 + D_3$$



## DECODER :-

- \* Decoder is a combinational circuit that converts binary information from  $n$  input lines to a maximum  $2^n$  unique output lines.
- \* If the  $n$ -bit coded information has unused combinations, the decoder may have fewer than  $2^n$  outputs.
- \* The decoder presented is  $n$ -to- $m$  line decoders where  $m \leq 2^n$ , Their purpose is to generate  $2^n$  minterms of  $n$  input variables
- \* Decoder is also used in conjunction with other code converters, such as BCD- to Seven segment decoder.
- \* Three-to eight line decoder:-

### 3-to-8 decoder.

- \* The 3 inputs are decoded into eight outputs each representing one of the minterms of the three input variables
- \* The three inverters provide complement of the inputs.
- \* each one of the eight <sup>AND</sup> gates generates one of the minterms.
- \* The input variables represent a binary number,
- \* the outputs represent eight digits of a number in octal number system.

\* Inputs      outputs

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



\* Application of decoder is binary to octal conversion.

\* for each possible input combination, there are seven outputs equal to 0 and only one equal to 1

\* The output whose value is equal to 1 represents the minterm equivalent of the binary number currently available in the 3 input lines.

### Decoder with Enable Input :-

\* Decoders include one or more enable inputs to control the circuit operation.

\* 2-to-4 decoder with enable input constructed with Nand gates.

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



## Combinational logic implementation:-

### Implementation of a full adder with a decoder:-

\* From the truth table of full adder.

|   | A | B | C | Sum | Carry |
|---|---|---|---|-----|-------|
| 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     |

$$\text{Sum} = F(x, y, z) = \Sigma(1, 2, 4, 7)$$

$$\text{Carry} = F(x, y, z) = \Sigma(3, 5, 6, 7)$$

\* Step 1: Boolean function for the circuit be expressed as sum of minterms.

\* A decoder is then chosen that generates all the minterms of the

i/p Variables

\* The inputs of each OR gate are selected from the decoders ~~as~~ outputs



\* The OR gate for output ① forms logical sum of minterms 1, 2, 4, and 7

\* The OR gate for output ② forms logical sum of minterms 3, 5, 6 and 7

- \* Decoder is enabled when E is equal to 0.
- \* Only one output can be equal to 0 at any given time.
- \* Circuit is disabled when E is equal to 1 regardless of two inputs.
- \* A decoder with enable input can function as a demultiplexer.
- \* Decoders with enable inputs can be connected together to form a larger decoder.
- \* Two 3 to 8 decoders with enable inputs connected to form 4 to 16 decoder.



- \* When  $w=0$  the top decoder is enabled & other is disabled.
- \* The top decoder generates minterms 000 to 111 and bottom decoder o/p's are all 0's
- \* When  $w=1$  the enable conditions are reversed. The bottom decoder generates minterms 1000 to 1111 & the top decoder o/p's are all 0's

## Magnitude Comparator :-

\* Magnitude Comparator is a combinational circuit that compares two digital or binary numbers in order to find out whether one binary number is equal, less than or greater than the other binary number.



\* Design a circuit for which we will have two inputs, one for A and other for B and have three output terminals, one for  $A > B$ , one for  $A = B$  and one for  $A < B$  condition.

## 1-Bit magnitude Comparator :-

\* A comparator used to compare two bits is called a single bit comparator.

\* It consists of two inputs each for two single bit numbers & three outputs to generate less than, equal to and greater than between two binary numbers.

Truth table :-

| A | B | $A < B$ | $A = B$ | $A > B$ |
|---|---|---------|---------|---------|
| 0 | 0 | 0       | 1       | 0       |
| 0 | 1 | 1       | 0       | 0       |
| 1 | 0 | 0       | 0       | 1       |
| 1 | 1 | 0       | 1       | 0       |

$$A < B \Rightarrow A' B.$$

$$A > B \Rightarrow A B'$$

$$A = B \Rightarrow A' B' + A B.$$

Logic Diagram :-



### 2-Bit magnitude Comparator :-

\* A comparator used to compare two binary numbers. each of two bits is called a 2-bit magnitude comparator.

It consists of four inputs & three outputs to generate less than, equal to & greater than between two binary numbers.

K-map reduction from truth table.

|                                 |    | B <sub>1</sub> , B <sub>0</sub> |    |
|---------------------------------|----|---------------------------------|----|
|                                 |    | 00                              | 01 |
| A <sub>1</sub> , A <sub>0</sub> | 00 | 0                               | 1  |
|                                 | 01 | 0                               | 1  |
| 10                              | 0  | 0                               | 0  |
| 11                              | 0  | 1                               | 1  |

|                                 |    | B <sub>1</sub> , B <sub>0</sub> |    |
|---------------------------------|----|---------------------------------|----|
|                                 |    | 00                              | 01 |
| A <sub>1</sub> , A <sub>0</sub> | 00 | 0                               | 0  |
|                                 | 01 | 1                               | 0  |
| 11                              | 0  | 1                               | 0  |
| 10                              | 1  | 1                               | 0  |

|                                 |    | B <sub>1</sub> , B <sub>0</sub> |    |
|---------------------------------|----|---------------------------------|----|
|                                 |    | 00                              | 01 |
| A <sub>1</sub> , A <sub>0</sub> | 00 | 1                               | 0  |
|                                 | 01 | 0                               | 1  |
| 11                              | 0  | 0                               | 1  |
| 10                              | 0  | 0                               | 1  |

$A < B$ .

$A > B$ .

$$A < B \Rightarrow A_1' B_1 + A_1' A_0' B_0 + A_0' B_1 B_0$$

$$A > B \Rightarrow A_1 B_1 + A_0 B_1' B_0 + A_1 A_0 B_0$$

$$A = B \Rightarrow A_1' A_0' B_1 B_0 + A_1' A_0 B_1' B_0 + A_1 A_0 B_1 B_0 + A_1 A_0' B_1' B_0$$

Truth table :-

| Input          |                  | output         |                |       |       |       |
|----------------|------------------|----------------|----------------|-------|-------|-------|
| A <sub>1</sub> | - A <sub>0</sub> | B <sub>0</sub> | B <sub>1</sub> | A < B | A = B | A > B |
| 0              | 0                | 0              | 0              | 0     | 1     | 0     |
| 0              | 0                | 0              | 1              | 1     | 0     | 0     |
| 0              | 0                | 1              | 0              | 1     | 0     | 0     |
| 0              | 0                | 1              | 1              | 1     | 0     | 0     |
| 0              | 1                | 0              | 0              | 0     | 0     | 1     |
| 0              | 1                | 0              | 1              | 0     | 1     | 0     |
| 0              | 1                | 1              | 0              | 1     | 0     | 0     |
| 0              | 1                | 1              | 1              | 1     | 0     | 0     |
| 1              | 0                | 0              | 0              | 0     | 0     | 1     |
| 1              | 0                | 0              | 1              | 0     | 0     | 1     |
| 1              | 0                | 1              | 0              | 0     | 1     | 0     |
| 1              | 0                | 1              | 1              | 1     | 0     | 0     |
| 1              | 1                | 0              | 0              | 0     | 0     | 1     |
| 1              | 1                | 0              | 1              | 0     | 0     | 1     |
| 1              | 1                | 1              | 0              | 0     | 0     | 1     |
| 1              | 1                | 1              | 1              | 0     | 1     | 0     |

be used.

$$\begin{aligned}
 A = B &= A'_1 A'_0 B'_1 B'_0 + A'_1 A_0 B'_1 B_0 + A_1 A_0 B_1 B_0 + A_1 A'_0 B_1 B'_0 \\
 &= A'_1 B'_1 (A'_0 B'_0 + A_0 B_0) + A_1 B_1 (A_0 B_0 + A'_0 B'_0) \\
 &\in \overline{A'_1 B'_1} \cap \overline{A'_0 B'_0} \cap \overline{A_1 B_1} \\
 &= (\overline{A_1 \oplus B_1}) \cap (\overline{A_0 \oplus B_0})
 \end{aligned}$$

Therefore:

|                                                                   |
|-------------------------------------------------------------------|
| $A > B = A_1 B'_1 + A_0 B'_1 B'_0 + A_1 A_0 B'_0$                 |
| $A = B = (\overline{A_0 \oplus B_0}) (\overline{A_1 \oplus B_1})$ |
| $A < B = A'_1 B_1 + A'_0 B_1 B_0 + A'_1 A'_0 B_0$                 |



## Read Only Memory :-

- \* ROM is a memory device in which permanent binary information is stored.
- \* The binary information must be specified by the designer & is then embedded in the unit to form the required interconnection pattern.
- \* Once the pattern is established, it stays within the unit even when power is turned off & on again.



\* ROM consists of  $K$  inputs &

n outputs.

\* Input gives address for memory

\* Output gives data bits of the stored word that is selected by the address.

- \* Consider a  $4 \times 4$  ROM which means that it has total of 4 addresses at which information is stored. & each address has 4-bit information.
- \* Construct the truth table.

| Inputs |   | Outputs. |   |   |   |
|--------|---|----------|---|---|---|
| X      | Y | A        | B | C | D |
| 0      | 0 | 0        | 0 | 1 | 1 |
| 0      | 1 | 1        | 1 | 0 | 0 |
| 1      | 0 | 1        | 1 | 1 | 1 |
| 1      | ∅ | 0        | 1 | 1 | 1 |

\* Truth table shows that at location 00, content to be stored is 0011 and  
location 01 - 1100  
location 10 - 1111  
location 11 - 0111

- \* Based on total no. of addresses in ROM & length of their content decide the decoder as well as no. of OR gates to be used.

\* Generally for a  $2^k \times n$  ROM, a  $k \times 2^k$  decoder is used. & the total no. of OR gates = total no. of bits stored.

\* So in case of  $4 \times 4$  ROM. The decoder to be used is  $2 \times 4$  decoder & no. of OR gates = 4.



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

\* When both the inputs are 0, then only  $D_0$  is 1 and rest are 0.

\* When Input = 01 then  $D_1 = 1$

When Input = 10 then  $D_2 = 1$

When Input = 11 then  $D_3 = 1$



## Types of ROM :-



### Mask ROM :-

- \* The specification of ROM is taken by the manufacturer from customer in tabular form
- \* Then corresponding masks for the paths are produced to get the desired output.
- \* This ROM is costly as vendor charges special fees for making a particular ROM.
- \* They are used in Network operating systems, server operating systems, storing of fonts for laser printers, sound data in electronic musical instruments .

### PROM :-

- \* It stands for programmable Read only memory.
- \* Prepared as a blank memory and then it is programmed to store the information
- \* To program PROM, a PROM programmer or PROM burner is used.
- \* Data stored in it cannot be modified  $\rightarrow$  so it is called one-time programmable.
- \* Used in cell phones, video game consoles, RFID tags medical devices ,

### E PROM :-

- \* Erasable programmable Read only memory.
- \* If a bit pattern has been established, the PROM becomes unusable if the bit pattern has to be changed.
- \* The problem has been overcome by EEPROM
- \* when EEPROM is placed under a special ultraviolet light for a length of time, the shortwave radiation makes the EEPROM return to its initial state; which then can be programmed accordingly.

### EEPROM :- Electrically erasable Programmable Read-only memory.

- \* Similar to EPROM except that EEPROM is returned to its initial state by application of an electrical signal in place of ultraviolet light.
- \* ease of erasing. It erases (or) writes one byte of data at a time.. used for storing computer system BIOS.

### Flash ROM :-

- \* enhanced version of EEPROM.
- \* In flash memory blocks of data can be deleted or written at a particular time.
- \* flash memory is faster than EEPROM.
- \* many modern PCs have their BIOS stored on a flash memory chip. called as flash BIOS.

## Programmable logic Array:-

### Combinational PLDs:

- \* The PROM is a combinational programmable logic device (PLD) an integrated circuit with programmable gates divided into an AND array and an OR Array to provide an AND-OR
- \* The three major types of combinational PLD's, differing in the placement of programmable connections in the AND-OR arrays are PROM, PAL, PLA.
- \* PROM - Programmable Read only memory has a fixed AND array constructed as a decoder and a programmable OR array. The Programmable OR gates implement Boolean function in sum-of minterms form.
- \* PAL - Programmable array logic has a programmable AND array and a fixed OR array. The AND gates are programmed to provide the product terms for the Boolean functions which are logically summed in each OR gate.
- \* PLA - Programmable logic array.
- \* The most flexible PLD is PLA, in which both AND and OR arrays can be programmed. The product terms in the AND array may be shared by any OR gate to provide the required sum-of products implementation.



### Programmable Logic Array:-

\* PLA presents the Boolean function in the form of a sum of product (SOP)

\* The designing of this PLA can be done using logic gates like AND, OR, and NOT by fabricating on the chip.

Example:-

Implement the following Boolean expression using PLA

$$X = AB + AC'$$

$$Y = AB' + BC + AC'$$

PLA Programming Table .

|     | Product term | Inputs . |   |   | outputs . |   |
|-----|--------------|----------|---|---|-----------|---|
|     |              | A        | B | C | X         | Y |
| AB  | 1            | 1        | 1 | - | 1         | - |
| Ac' | 2            | 1        | - | 0 | 1         | 1 |
| AB' | 3            | 1        | 0 | - | -         | 1 |
| BC  | 4            | -        | 1 | 1 | -         | 1 |



Problem:

Implement the following boolean functions using PROM

$$A(x, y, z) = \sum m(5, 6, 7)$$

$$B(x, y, z) = \sum m(3, 5, 6, 7)$$



Problem:

Implement the following Boolean functions using PAL

$$A = xy + xz'$$

$$A = xy' + yz'$$



## Quine-McCluskey Method :-

①

- \* Karnaugh map is an effective way to simplify switching functions which have a small number of variables.
- \* When the number of variables is large or if several functions must be simplified then Quine-McCluskey method provides the Systematic Simplification procedure.
- \* The procedure consists of two main steps.
  - \* Determination of prime implicants
  - \* Prime implicant chart.

### Determination of Prime Implicants :-

- \* Represent each term (min term) by their binary code.
- \* Define the number of 1's in binary number as the Index of the number.
- \* Group all the binary numbers of same Index into a group
- \* The binary numbers are listed in the ascending order of their decimal number equivalent
- \* Compare the terms in lower index to the set whose Index is 1 greater.
- \* Eliminate all redundant variables by applying the Theorem  $xy + xy' = x$
- \* Check off all the terms that entered into the combination. The ones that are left are prime implicants

\* Repeat steps of comparing, eliminating until no further reduction is possible.

\* We obtain the set of all prime implicants.

### Prime Implicant chart :-

\* To find the essential Prime implicants.

\* Each column carries a decimal number at the top corresponding to the minterms - The columns are signed by such a number in ascending order.

\* Make a cross under each decimal number contained in the prime implicant represented by that row.

\* Find all the columns that contain a single cross and circle them.

\* Place an asterisk or ~~strike out~~ the corresponding row of the circled cross.

\* The rows marked with an asterisk are the essential prime implicants.

\* Strike out the columns which are belonging to the essential prime implicant rows.

\* If prime implicants are left over see for minimum set of prime implicants to cover the remaining columns.

(3)

Problem:

Using Quine McCluskey method find the minimum sum of product expression for

$$f(a, b, c, d) = \sum m(0, 1, 2, 5, 6, 7, 8, 9, 10, 14)$$

Solution.

\* Arrange the decimal values in ascending order & write down the binary code

$$\begin{array}{r} 8421 \\ 0 - 0000 \\ \hline 1 - 0001 \end{array}$$

$$2 - 0010$$

$$5 - 0101$$

$$6 - 0110$$

$$7 - 0111$$

$$8 - 1000$$

$$9 - 1001$$

$$10 - 1010$$

$$14 - 1110$$

\* Now group them based on the number of 1's in the index & assign Index number accordingly - arrange them in ascending order.

|          |                | Column - I                       | Column - II               | Column - III                                                          |
|----------|----------------|----------------------------------|---------------------------|-----------------------------------------------------------------------|
| Index No | Decimal Number | Binary Representation<br>a b c d | Decimal Number<br>a b c d | Binary representation<br>a b c d                                      |
| Index 0  | 0 ✓            | 0 0 0 0                          | 0, 1 ✓ 0 0 0 -            | 0, 1, 8, 9 ✓ - 0 0 -                                                  |
|          | 1 ✓            | 0.00 1                           | 0, 2 ✓ 0 0 - 0            | 0, 2, 8, 10 ✗ - 0 - 0                                                 |
|          | 2 ✓            | 0 0 1 0                          | 0, 8 ✓ - 0 0 0            | 0, 8, 1, 9 - 0 0 -                                                    |
| Index 1  | 8 ✓            | 1 0 0 0                          | 1, 5 0 - 0 1              | 0, 8, 2, 10 - 0 - 0                                                   |
|          | 5 ✓            | 0 1 0 1                          | 2, 6 ✓ 0 - 1 0            | 2, 6, 10, 14 ✓ - - 1 0                                                |
|          | 6 ✓            | 0 1 1 0                          | 2, 10 ✓ - 0 1 0           | 2, 10, 6, 14 - - 1 0                                                  |
|          | 9 ✓            | 1 0 0 1                          | 8, 9 ✓ 1 0 0 ✗            | * The <u>struck out</u> Prime implicants are the <u>repeated ones</u> |
|          | 10 -           | 1 0 1 0                          | 8, 10 ✓ 1 0 - 0           |                                                                       |
| Index 2  | 7 ✓            | 0 1 1 1                          | 5, 7 0 1 - 1              |                                                                       |
|          | 14 ✓           | 1 1 1 0                          | 6, 7 0 1 1 -              |                                                                       |
|          |                |                                  | 6, 14 ✓ - 1 1 0           |                                                                       |
| Index 3  |                |                                  | 10, 14 ✓ 1 - 1 0          |                                                                       |
|          |                |                                  |                           |                                                                       |
|          |                |                                  |                           |                                                                       |

\* Therefore the Prime Implicants are

$$\begin{array}{lll}
 \begin{matrix} a & b & c & d \\ 0 & - & 0 & 1 \end{matrix} & \begin{matrix} a' & c' & d \\ 1 & - & 1 \end{matrix} \\
 1, 5. & & \\
 \begin{matrix} a & b & c & d \\ 0 & - & 0 & 1 \end{matrix} & \begin{matrix} a' & b & d \\ 1 & - & 1 \end{matrix} \\
 5, 7 & 0 1 - 1 & \\
 \begin{matrix} a & b & c \\ 0 & - & 1 \end{matrix} & \begin{matrix} a' & b & c \\ 1 & - & 1 \end{matrix} \\
 6, 7 & 0 1 1 - & \\
 \begin{matrix} a & b & c' \\ 0 & - & 0 \end{matrix} & \begin{matrix} b' & c' \\ 1 & - \end{matrix} \\
 0, 1, 8, 9 & - 0 0 - & \\
 \begin{matrix} a & b & d \\ 0 & - & 0 \end{matrix} & \begin{matrix} b' & d' \\ 1 & - \end{matrix} \\
 0, 2, 8, 10 & - 0 - 0 & \\
 \begin{matrix} a & c & d' \\ 0 & - & 1 \end{matrix} & \begin{matrix} c & d' \\ 1 & - \end{matrix} \\
 2, 6, 10, 14 & - - 1 0 &
 \end{array}$$

(5)

### Prime Implicant chart :-

| Decimal Number | Binary representation<br>a, b, c, d | 0 | 1 | 2 | 5 | 6 | 7 | 8 | 9 | 10 | 14 |
|----------------|-------------------------------------|---|---|---|---|---|---|---|---|----|----|
| 0, 1, 8, 9     | b'c'*                               | x | x |   |   |   |   | x | x |    | x  |
| 0, 2, 8, 10    | b'd'                                | x |   | x |   |   |   | x |   | x  |    |
| 2, 6, 10, 14   | c'd'*                               |   |   | x |   | x |   |   |   | x  | x  |
| 1, 5           | a'c'd                               |   | x |   | x |   |   |   |   |    |    |
| 5, 7           | a'b'd                               |   |   |   | x |   | x |   |   |    |    |
| 6, 7           | a'b'c                               |   |   |   |   | x | x |   |   |    |    |

Single column with x

Single column with x

Single column with x

- \* Find out the columns with single x marking & Strike out the corresponding Row.
- \* Strike out the column with x marking corresponding to the striked out Row.

- \* find out the left over implicants & Select the minimum set so as to cover all the leftover Prime Implicants.

### Essential Prime Implicants :-

If a minterm is covered by only one prime implicant then the prime implicant is called Essential Prime Implicant.

The resulting minimum sum of products is

$$f(a, b, c, d) = b'c' + c'd' + a'b'd$$

(b)

Problem : 2

Using Quine McCluskey Method find the minimum sum of product expression for

$$f(x_1, x_2, x_3, x_4, x_5) = \sum (0, 2, 4, 5, 6, 7, 8, 10, 14, 17, 18, 21, 29, 31) + \\ \sum_d (11, 20, 22)$$

Solution :-

|    | $x_1$ | $x_2$ | $x_3$ | $x_4$ | $x_5$ |
|----|-------|-------|-------|-------|-------|
| 0  | -     | 0     | 0     | 0     | 0     |
| 2  | -     | 0     | 0     | 0     | 1     |
| 4  | -     | 0     | 0     | 1     | 0     |
| 5  | -     | 0     | 0     | 1     | 0     |
| 6  | -     | 0     | 0     | 1     | 1     |
| 7  | -     | 0     | 0     | 1     | 1     |
| 8  | -     | 0     | 1     | 0     | 0     |
| 10 | -     | 0     | 1     | 0     | 1     |
| 14 | -     | 0     | 1     | 1     | 0     |
| 17 | -     | 1     | 0     | 0     | 1     |
| 18 | -     | 1     | 0     | 0     | 1     |
| 21 | -     | 1     | 0     | 1     | 0     |
| 29 | -     | 1     | 1     | 1     | 0     |
| 31 | -     | 1     | 1     | 1     | 1     |
| 11 | -     | 0     | 1     | 0     | 1     |
| 20 | -     | 1     | 0     | 1     | 0     |
| 22 | -     | 1     | 0     | 1     | 1     |

| Decimal Number | Representation of Each term<br>$x_1 x_2 x_3 x_4 x_5$ | Decimal Numbers. | Representation of Each term<br>$x_1 x_2 x_3 x_4 x_5$ | Decimal number | Representation of Each term.<br>$x_1 x_2 x_3 x_4 x_5$ |
|----------------|------------------------------------------------------|------------------|------------------------------------------------------|----------------|-------------------------------------------------------|
| 0✓             | 0 0 0 0 0                                            | 0, 2✓            | 0 0 0 - 0                                            | 0, 2, 4, 6     | 0 0 - - 0                                             |
| 2✓             | 0 0 0 1 0                                            | 0, 4✓<br>0, 8✓   | 0 0 - 0 0<br>0 - 0 0 0                               | 0, 2, 8, 10    | 0 - 0 - 0                                             |
| 4✓             | 0 0 1 0 0                                            | 2, 6✓            | 0 0 - 1 0                                            | 2, 6, 10, 14   | 0 - - 1 0                                             |
| 8✓             | 0 1 0 0 0                                            | 2, 10✓<br>2, 18✓ | 0 - 0 1 0<br>- 0 0 1 0                               | 2, 6, 18, 22   | - 0 - 1 0                                             |
| 5✓             | 0 0 1 0 1                                            | 4, 5✓            | 0 0 1 0 -                                            | 4, 5, 6, 7     | 0 0 1 - -                                             |
| 6✓             | 0 0 1 1 0                                            | 4, 6✓<br>4, 20✓  | 0 0 1 - 0<br>- 0 1 0 0                               | 4, 5, 20, 21   | - 0 1 0 -                                             |
| 10✓            | 0 1 0 1 0                                            | 8, 10✓           | 0 1 0 - 0                                            | 4, 20, 6, 22   | - 0 1 - 0                                             |
| 17✓            | 1 0 0 0 1                                            | 5, 7✓            | 0 0 1 - 1                                            |                |                                                       |
| 18✓            | 1 0 0 1 0                                            | 5, 21✓           | - 0 1 0 1                                            |                |                                                       |
| 20✓            | 1 0 1 0 0                                            | 6, 7✓<br>6, 14✓  | 0 0 1 1 -<br>0 - 1 1 0                               |                |                                                       |
| 7✓             | 0 0 1 1 1                                            | 6, 22✓           | - 0 1 1 0                                            |                |                                                       |
| 11✓            | 0 1 0 1 1                                            | 10, 14✓          | 0 1 - 1 0                                            |                |                                                       |
| 14✓            | 0 1 1 1 0                                            | 10, 11           | 0 1 0 1 -                                            |                |                                                       |
| 21✓            | 1 0 1 0 1                                            | 17, 21           | 1 0 - 0 1                                            |                |                                                       |
| 22✓            | 1 0 1 1 0                                            | 18, 22✓          | 1 0 - 1 0                                            |                |                                                       |
| 29✓            | 1 1 1 0 1                                            | 20, 21✓          | 1 0 1 0 -                                            |                |                                                       |
| 29✓            | 1 1 1 0 1                                            | 20, 22✓          | 1 0 1 - 0                                            |                |                                                       |
| 31✓            | 1 1 1 1 1                                            | 21, 29           | 1 - 1 0 1                                            |                |                                                       |
|                |                                                      | 29, 31           | 1 1 1 - 1                                            |                |                                                       |

(8)

### Prime implicant Table.

| Decimal Number | 0 | 2 | 4 | 5 | 6 | 7   | 8 | 10 | 14  | 17  | 18 | 21  | 29  | 81 |
|----------------|---|---|---|---|---|-----|---|----|-----|-----|----|-----|-----|----|
| 0, 2, 4, 6     | X | X | X |   |   | X   |   |    |     |     |    |     |     |    |
| *0, 2, 8, 10   | X | X |   |   |   |     |   |    | (X) | X   |    |     |     |    |
| *2, 6, 10, 14  |   | X |   |   | X |     |   |    | X   | (X) |    |     |     |    |
| *2, 6, 18, 22  |   | X |   |   |   | X   | X |    |     |     |    | (X) |     |    |
| *4, 5, 6, 7    |   |   | X | X | X | (X) |   |    |     |     |    |     |     |    |
| 4, 5, 20, 21   |   |   | X | X |   |     |   |    |     |     |    |     | X   |    |
| 4, 20, 6, 22   |   |   | X |   | X |     |   |    |     |     |    |     |     |    |
| 10, 11         |   |   |   |   |   |     |   |    |     | X   |    |     |     |    |
| *17, 21        |   |   |   |   |   |     |   |    |     | (X) | X  |     |     |    |
| 21, 29         |   |   |   |   |   |     |   |    |     |     |    | X   | X   |    |
| *29, 31        |   |   |   |   |   |     |   |    |     |     |    | X   | (X) |    |

\* The essential prime implicants are:

$$x_1' x_2' x_3' x_4' x_5'$$

\* don't care terms

$$\text{minterms} = 11, 20, 22$$

$$0, 2, 8, 10 \quad 0 - 0 - 0$$

are not taken

$$2, 6, 10, 14 \quad 0 - - 1 0$$

into account for

$$2, 6, 18, 22 \quad - 0 - 1 0$$

Prime implicant

$$4, 5, 6, 7 \quad 0 0 1 - -$$

$$17, 21 \quad 1 0 - 0 1$$

$$29, 31 \quad 1 1 1 - 1$$

$$\begin{aligned}
 f(x_1 x_2 x_3 x_4 x_5) = & x_1' x_2' x_3' + x_1' x_4 x_5' + x_2' x_4 x_5' + x_1' x_2' x_3 \\
 & + x_1 x_2' x_4 x_5' + x_1 x_2 x_3 x_5
 \end{aligned}$$

(9)

Problem : 3

$$f(x_1, x_2, x_3, x_4, x_5) = \Sigma (0, 1, 2, 8, 9, 15, 17, 21, 24, 25, 27, 31)$$

Solution:

$$\begin{array}{r} x_1 \ x_2 \ x_3 \ x_4 \ x_5 \\ 0 - 0 \ 0 \ 0 \ 0 \ 0 \end{array}$$

$$1 - 0 \ 0 \ 0 \ 0 \ 1$$

$$2 - 0 \ 0 \ 0 \ 1 \ 0$$

$$8 - 0 \ 1 \ 0 \ 0 \ 0$$

$$9 - 0 \ 1 \ 0 \ 0 \ 1$$

$$15 - 0 \ 1 \ 1 \ 1 \ 1$$

$$17 - 1 \ 0 \ 0 \ 0 \ 1$$

$$21 - 1 \ 0 \ 1 \ 0 \ 1$$

$$24 - 1 \ 1 \ 0 \ 0 \ 0$$

$$25 - 1 \ 1 \ 0 \ 0 \ 1$$

$$27 - 1 \ 1 \ 0 \ 1 \ 1$$

$$31 - 1 \ 1 \ 1 \ 1 \ 1$$

| Index   | Decimal Number | Binary Representation | Decimal Number | Binary Representation | Decimal Number | Binary Representation |
|---------|----------------|-----------------------|----------------|-----------------------|----------------|-----------------------|
| Index 0 | 0 ✓            | 0 0 0 0 0             | 0, 1 ✓         | 0 0 0 0 -             | 0, 1, 8, 9     | 0 - 0 0 -             |
| Index 1 | 1 ✓            | 0 0 0 0 1             | 0, 2           | 0 0 0 - 0             | 1, 9, 17, 25   | - - 0 0 1             |
|         | 2 ✓            | 0 0 0 1 0             | 0, 8 ✓         | 0 - 0 0 0             | 8, 24, 9, 25   | - 1 0 0 -             |
|         | 8 ✓            | 0 1 0 0 0             | 1, 9 ✓         | 0 - 0 0 1             | 0, 8, 1, 9     | 0 - 0 0 -             |
|         | 9 ✓            | 0 1 0 0 1             | 1, 17          | - 0 0 0 1             |                |                       |
| Index 2 | 17 ✓           | 1 0 0 0 1             | 8, 9 ✓         | 0 1 0 0 -             |                |                       |
|         | 24 ✓           | 1 1 0 0 0             | 8, 24 ✓        | - 1 0 0 0             |                |                       |
|         | 21 ✓           | 1 0 1 0 1             | 9, 25 ✓        | - 1 0 0 1             |                |                       |
| Index 3 | 25 ✓           | 1 1 0 0 1             | 17, 21         | 1 0 - 0 1             |                |                       |
| Index 4 | 15 ✓           | 0 1 1 1 1             | 17, 25 ✓       | 1 - 0 0 1             |                |                       |
|         | 27 ✓           | 1 1 0 1 1             | 24, 25         | 1 1 0 0 -             |                |                       |
| Index 5 | 31 ✓           | 1 1 1 1 1             | 15, 31         | - 1 1 1 1             |                |                       |
|         |                |                       | 27, 31         | 1 1 - 1 1             |                |                       |

Prime Implicant Table :-

| Decimal      | 0 | 1 | 2 | 8 | 9 | 15 | 17 | 21 | 24 | 25 | 27 | 31 |
|--------------|---|---|---|---|---|----|----|----|----|----|----|----|
| 0, 1, 8, 9   | x | x |   | x | x |    |    |    |    |    |    |    |
| 1, 9, 17, 25 |   | x |   |   | x | x  | x  |    |    | x  | x  |    |
| 8, 24, 9, 25 |   |   | x | x |   |    |    |    | x  | x  |    |    |
| * 0, 2       | x |   | x |   |   |    |    |    |    |    |    |    |
| 1, 17        |   | x |   |   |   |    | x  |    |    |    |    |    |
| * 17, 21     |   |   |   |   |   | x  | x  |    |    |    |    |    |
| 24, 25       |   |   |   |   |   |    |    | x  | x  |    |    |    |
| * 15, 31     |   |   |   |   | x |    |    |    |    |    |    | x  |
| * 27, 31     |   |   |   |   |   |    |    | x  | x  | x  | x  | x  |

(11)

\* The prime implicants ~~are~~ cannot be reduced further.  
 So remove the essential prime implicants from the table & draw a table with the remaining implicants.

| Decimal        | 0   | 1 | 8 | 9 | 17 | 24 | 25 |  |
|----------------|-----|---|---|---|----|----|----|--|
| a * 0, 1, 8, 9 | (X) | X | X | X |    |    |    |  |
| b 1, 9, 17, 25 |     | X |   | X | X  |    | X  |  |
| c 8, 24, 9, 25 |     |   | X | X |    | X  | X  |  |
| d 1, 17        |     | X |   |   |    | X  |    |  |
| e 24, 25       |     |   |   |   |    | X  | X  |  |

Column dominance

$$9 > 8$$

$$25 > 24$$

$$1 > 0$$

Row dominance

$$b > d$$

$$c > e$$

∴ Rows d & e can be eliminated

∴ Column 8, 24, & 0 can be eliminated

| Decimal        | 1 | 9 | 17 | 25 |                                                                                              |
|----------------|---|---|----|----|----------------------------------------------------------------------------------------------|
| 0, 1, 8, 9     | X | X |    |    | * The prime implicants are<br>x, x <sub>2</sub> x <sub>3</sub> x <sub>4</sub> x <sub>5</sub> |
| * 1, 9, 17, 25 | X | X | X  | X  | 0, 1, 8, 9 - 0 - 0 0 - -<br>1, 9, 17, 25 - - 0 0 1                                           |
| 8, 24, 9, 25   |   | X |    | X  | 0, 2<br>17, 21<br>15, 31<br>27, 31 - 1 1 1 1<br>Row dominance b > c                          |

12

$$f(x_1, x_2, x_3, x_4, x_5) = x_1^1 x_3^1 x_4^1 + x_3^1 x_4^1 x_5^1 + x_1^1 x_2^1 x_3^1 x_5^1 \\ + x_1^1 x_2^1 x_4^1 x_5^1 + x_2 x_3 x_4 x_5 + x_1 x_2 x_4 x_5$$

## Assignment

## FPGA - Basics :-

### Introduction :-

- \* Field programmable Gate Array - is a device that consists a matrix of reconfigurable gate array logic circuitry.
- \* FPGA use dedicated hardware for processing logic & do not have an operating system.
- \* FPGA based systems can literally rewire their internal circuitry to allow reconfiguration after the control system is deployed to the field.
- \* FPGA are truly parallel in nature, so different processing operations do not have to compete for the same resources.
- \* Multiple control loops can run on a single FPGA device at different rates.
- \* FPGA devices deliver the performance & reliability of dedicated hardware circuitry.

### Need for FPGA :-

- \* SSI, MSI, and LSI components required interconnections to help connect the IC in order to generate global control signals.
- \* Data signals from one subsystem to another subsystem.
- \* To solve the problem custom IC's were developed which replaced large amount of Interconnect  $\rightarrow$  Improving Performance & Reducing system complexity & manufacturing cost.
- \* Bcoz of increased design time, the custom IC's were not on time to market sensitive.

\* FPGAs were introduced as an alternative to custom IC's for implementing entire system on chip & to provide flexibility of reprogrammability to the user.

\* Another Advantage of FPGA is with the help of computer Aided design tools circuit could be implemented in a short amount of time.

### FPGA structural classification :-

\* Basic structure of an FPGA includes logic elements, Programmable interconnects and Memory.

\* On the basis of internal arrangement of blocks FPGA can be divided into three classes:

\* Symmetrical arrays

\* Row based architecture

\* Hierarchical PLD's

### Symmetrical arrays:

\* It consists of ~~no~~ <sup>Configurable</sup> logic blocks (CLB) arranged in rows and columns of a matrix and interconnect laid out between them.

\* Symmetrical matrix is surrounded by I/O blocks which connect it to outside world.

\* Each CLB consists of n-input look up table and a pair of programmable flipflops.

\* I/O blocks also control functions such as tristate control, output transition speed.

I/O Blocks

- \* Interconnects provide routing path.
- \* Direct interconnects b/w adjacent logic elements have smaller delay compared to general purpose interconnect.

### Row Based Architecture:-

- \* It consists of Alternating rows of logic modules & Programmable interconnect tracks.
- \* IOB (Input output Block) is located in the periphery of the rows.
- \* one row may be connected to adjacent rows via Vertical Interconnect. Logic modules can be implemented in various combinations.
- \* Combinational modules - only combinational elements.  
Sequential modules - both combinational elements along with Flipflops.
- \* Routing tracks are divided into smaller segments connected by anti fuse element.



## Hierarchical PLD's.

- \* Designed in hierarchical manner with top level containing only logic blocks & interconnects.
- \* Each logic ~~module~~ block contains number of logic modules.
- \* logic module has combinational as well as sequential function elements.
- \* functional elements is controlled by programmed Memory.
- \* communication b/w logic blocks is achieved by programmable interconnects arrays.
- \* Input output blocks surround this scheme of logic blocks & interconnects.



## Basic Xilinx Architecture:-

- \* The basic architecture of Spartan & earlier device families consists of array of configurable logic blocks (CLB's) & a variety of local & global routing resources, input output blocks (IOB), Programmable I/O buffers & SRAM based Configuration memory.

