

## REVIEW OF NUMBER SYSTEMS & CODES.

### Number Systems :-

- Number systems are used to represent data in digital form.
- Number system is nothing more than a code that uses symbols to represent a number.
- In general, in any number system, there is an ordered set of symbols known as digits.
- A number is made up of a collection of digits and it has two parts
  - integer and fraction part.
- Both are separated by a radix point (.). The number is represented as,

$$(d_{n-1}, d_{n-2}, \dots, d_1, d_0 \cdot d_{-1}, d_{-2}, \dots, d_m)_r$$

Integer part                                      Radix point                              Fractional part                      Radix.

Number systems are classified as.

1. Decimal number system
2. Binary number system
3. Octal number system
4. Hexadecimal number system.

### Decimal number system :-

- The decimal number system is a radix 10. It has 10 different digits or symbols to represent a number.
- These are 0, 1, 2, 3, 4, 5, 6, 7, 8 and 9.

①

→ The radix point is known as the decimal point.

→ The value of any mixed decimal number is

$$d_n, d_{n-1}, d_{n-2}, \dots, d_1, d_0, d_{-1}, d_{-2}, d_{-3}, \dots, d_{-m}$$

is given by.

$$(d_n \times 10^n) + (d_{n-1} \times 10^{n-1}) + \dots + (d_1 \times 10^1) + (d_0 \times 10^0) + (d_{-1} \times 10^{-1}) + \\ (d_{-2} \times 10^{-2}) + \dots$$

Consider the decimal number.

$$(135.56)_{10} = 1 \times 10^2 + 3 \times 10^1 + 5 \times 10^0 + 5 \times 10^{-1} + 6 \times 10^{-2} \\ = 100 + 30 + 5 + 0.5 + 0.06 \\ = 135.56.$$

### Binary number system:-

→ The Binary number system is a radix 2. It has two independent digits.

→ Binary numbers are represented in terms of '0' and '1'.

→ The radix point is known as the Binary point.

'0' & '1' is a bit.

Four number bits → Nibble

8 bits. → byte

Group of <sup>16</sup> bits → word

→ The binary number system is used in digital computers because the switching circuits used in these computers use two-state devices such as transistors, diodes, etc.

## Octal number system :-

- The octal number system is a radix 8.
- It has 8 different digits or symbols to represent a number.
- They are 0, 1, 2, 3, 4, 5, 6, and 7.
- The radix point is known as the octal point.
- Octal number system is more efficient for us to write the number in octal rather than binary.
- Electronically, it is easier and cheaper.

## Hexadecimal number system :-

- The Hexadecimal number system is a radix 16.
- It has 16 different digits or symbols to represent a number.
- They are 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, A, B, C, D, E and F.
- The radix point is known as the Hexadecimal point.
- The decimal equivalent of A, B, C, D, E and F are 10, 11, 12, 13, 14 and 15.
- In hexadecimal number system easier way of representing large binary numbers stored and processed inside the computer.
- The contents of the memory when represented in hexadecimal form are very convenient to handle.

Radix - NO of symbols presented in a respective number system is called radix.

LSB - Least Significant bit.

The bit which having the least position weight bit is called LSB.

MSB - most significant bit

The bit which having the most significant position weight is called MSB.



MSD - most significant digit.

LSD - least significant digit.

Conversion from one radix to another radix :-

In computer systems process binary data, but the information given by the user may be in the form of decimal number, hexadecimal number, & octal number.

- |                          |                         |
|--------------------------|-------------------------|
| → Binary to decimal      | → octal to binary       |
| → octal to decimal       | → binary to octal       |
| → Hexadecimal to decimal | → Hexadecimal to binary |
| → decimal to binary      | → binary to Hexadecimal |
| → decimal to octal       | → octal to Hexadecimal  |
| → decimal to Hexadecimal | → Hexadecimal to octal. |

Binary to decimal :-

$$(101101.0110)_2 = ( \quad )_{10}$$

$$\begin{aligned}
 (101101.0110)_2 &= (1 \times 2^5) + (0 \times 2^4) + (1 \times 2^3) + (1 \times 2^2) + (0 \times 2^1) + (1 \times 2^0) \\
 &\quad + (0 \times 2^{-1}) + (1 \times 2^{-2}) + (1 \times 2^{-3}) + (0 \times 2^{-4}) \\
 &= 32 + 0 + 8 + 4 + 0 + 1 + 0 + 0.25 + 0.125 + 0 \\
 &= (45.375)_{10}.
 \end{aligned}$$

Octal to decimal :-

$$\rightarrow (4053.03)_8 = (2091)_{10}$$

$$\begin{aligned}
 (4053.03)_8 &= 4 \times 8^3 + 0 \times 8^2 + 5 \times 8^1 + 3 \times 8^0 + 0 \times 8^{-1} + 3 \times 8^{-2} \\
 &= 2048 + 0 + 40 + 3 + 0 + \\
 &= 2091
 \end{aligned}$$

$$(532.78)_8 = ( \quad )_{10}$$

In this given number system is octal. but the value in the given problem 8 is not a octal number.

$$\begin{aligned}
 (753.63)_8 &= (491.79)_{10} \\
 &= 7 \times 8^2 + 5 \times 8^1 + 3 \times 8^0 + 6 \times 8^{-1} + 3 \times 8^{-2} \\
 &= 448 + 40 + 3 + 0.75 + 0.046 \\
 &= 491.79
 \end{aligned}$$

## Hexadecimal to decimal:-

$$\rightarrow (5A3)_{16} = (1443)_{10}$$

$$\begin{aligned}(5A3)_{16} &= (5 \times 16^2) + (10 \times 16^1) + (3 \times 16^0) \\&= 1280 + 160 + 3 \\&= (1443)_{10}\end{aligned}$$

$$\rightarrow (64D)_{16} = (1613)_{10}$$

$$\begin{aligned}(64D)_{16} &= (6 \times 16^2) + (4 \times 16^1) + (13 \times 16^0) \\&= 1536 + 64 + 13 \\&= (1613)_{10}\end{aligned}$$

## Decimal to binary :-

→ To convert a decimal number to a binary number is known as repeated division and multiplication method.

→ The integer and fractional parts of a decimal number are treated separately for the conversion and then the results are combined.

### Integer part conversion

To convert the integer part by using the repeated division method, the given decimal number is divided by 2.

The remainder is found after each division until the quotient 0.

The remainder read from bottom to top give the equivalent binary integer number.

$$(62)_{10} = (\quad)_2$$



$$(62)_{10} = (111110)_2$$

### Fractional part conversion.

To convert the fractional part by using the repeated multiplication method, the given decimal number is multiplied by 2.

The integer part of the multiplication is found after each multiplication operation until the fractional part of a decimal number becomes zero. The integers read from top to bottom gives the equivalent binary fraction.

$$(0.625)_{10} = (\quad)_2$$

$$0.625 \times 2 = 1.25$$

$$0.25 \times 2 = 0.5$$

$$0.5 \times 2 = 1.0$$

$$(0.625)_{10} = (101)_2$$

$$\rightarrow (105.15)_{10} = (\quad)_2$$

$$\begin{array}{r} 2 \mid 105 \\ 2 \boxed{52-1} \uparrow \\ 2 \boxed{26-0} \\ 2 \boxed{13-0} \\ 2 \boxed{6-1} \\ 2 \boxed{3-0} \\ 1-1 \end{array}$$

integer part.

$$105_{10} = 1101001_2$$

$$\begin{array}{r}
 0.15 \times 2 = 0.30 & 0 \\
 0.30 \times 2 = 0.60 & 0 \\
 0.60 \times 2 = 1.20 & 1 \\
 0.20 \times 2 = 0.40 & 0 \\
 0.40 \times 2 = 0.80 & 0 \\
 0.80 \times 2 = 1.60 & 1 \downarrow
 \end{array}$$

Fractional part

$$0.15_{10} = 0.001001_2$$

$$(105.15)_{10} = (1101001.001001)_2$$

decimal to octal :-

Decimal conversion is same as decimal to binary except that in this case repeated multiplication and division are by 8 which is the base of octal number system.

$$(183.62)_{10} = (\quad)_8 = (276.475)_8$$

$$\begin{array}{r} 8 \mid 183 \\ 8 \boxed{22-7} \\ 2-6 \end{array}$$

$$\begin{array}{r}
 0.62 \times 8 = 4.96 & 4 \\
 0.96 \times 8 = 7.68 & 7 \\
 0.68 \times 8 = 5.44 & 5
 \end{array}$$

$$(145.93)_{10} = ( \quad )_8 = (221.734)_8$$

$$\begin{array}{r} 145 \\ 8 \boxed{18-1} \\ 8 \boxed{2-2} \\ 0-2 \end{array}$$

$$\begin{aligned} 0.93 \times 8 &= 7.44 \\ 0.44 \times 8 &= 3.52 \\ 0.52 \times 8 &= 4.16. \end{aligned}$$

Decimal to Hexadecimal :-

decimal to hexadecimal conversion is same as decimal to octal except that in this case repeated multiplication and division are by 16 which is the base of Hexadecimal number system.

$$\rightarrow (138.58)_{10} = (80A.947)_{16}$$

$$\begin{array}{r} 16 \times 0 = 128 \\ 138 - 128 = 10 \end{array}$$

$$\begin{array}{r} 16 \boxed{138} \\ 16 \boxed{128-10} \\ \cancel{8} \cancel{-0} \end{array}$$

$$\begin{aligned} 0.58 \times 16 &= 9.28 \\ 0.28 \times 16 &= 4.48 \\ 0.48 \times 16 &= 7.68. \end{aligned}$$

$$\begin{array}{r} 16 \boxed{138} \\ 16 \boxed{8-10} \\ 0-8 \end{array}$$

$$\rightarrow (256.26)_{10} = (100.428F)_{16}$$

$$\begin{array}{r} 16 \boxed{256} \\ 16 \boxed{16-0} \\ 0-0 \end{array}$$

$$\begin{aligned} 0.26 \times 16 &= 4.16 \\ 0.16 \times 16 &= 2.56 \\ 0.56 \times 16 &= 8.96 \\ 0.96 \times 16 &= 15.36. \end{aligned}$$

## Octal to binary conversion :-

To convert octal to binary, just replace each octal digit by its 3-bit binary equivalent.

$$\rightarrow (563)_8 \rightarrow (101110011)_2$$

$$\rightarrow (725)_8 \rightarrow (111010101)_2$$

$$\rightarrow (326)_8 \rightarrow \begin{array}{ccc} 3 & 2 & 6 \\ 011 & 010 & 110 \\ (011010110)_2 \end{array}$$

## Binary to octal conversion :-

To convert binary to octal, just replace.

each group of 3 bits by equivalent octal number.

→ Splitting the integer and fractional parts into Groups of three bits, starting from the binary point on both sides.

→ In integer part to making group of 3-bits from right to left

→ In fractional part to making group of 3-bits from left to right.

→ If needed add 0's on the extreme left of the integer part and extreme right of the fractional part.

$$\rightarrow (1101101.01101)_2 \rightarrow (155.327)_8$$

001|101|101|.011|010  
 1 | 5 | 5 | . 3 | 2.

$$\rightarrow (101101010.1101010)_2 \rightarrow (552.650)_8$$

101|101|010|.110101000  
 5 | 5 | 2 | 6 | 5 | 0

### Hexadecimal to Binary conversion

To convert a hexadecimal number to binary,  
 replace each digit by its 4-bit binary equivalent.

Example:-

$$\rightarrow (6A3)_{16} \rightarrow ( )_2$$

6 | A | 3 |  
 0110 | 1010 | 0011 |

A - 10

B - 11

C - 12

D - 13

E - 14

F - 15

$$\rightarrow (6A3)_{16} \rightarrow (011010100011)_2$$

$$\rightarrow (58C.26)_{16} \rightarrow ( )_2$$

5 | 8 | C | 2 | 6 |  
 0101 | 1000 | 1100 | 0010 | 0110 |

$$(58C.26)_{16} \rightarrow (010110001100.00100110)_2$$

→ Binary to Hexadecimal conversion :-

To convert binary to Hexadecimal number by splitting the integer and fractional parts into Groups of 4-bits. Replace each 4-bit binary group by the equivalent hexadecimal digit.

$$\rightarrow (1001011010101)_2 \rightarrow ( )_{16}$$

0001|0010|1101|010  
1 | 2 | 0 | 5.

$$(1001011010101)_2 \rightarrow (12D5)$$

$$\rightarrow (1101101010101.10101010)_2 \rightarrow ( )_{16}$$

0001|1011|0101|0101|1010|0101|000  
1 | B | 5 | 5 | A | A | 8.

$$(1101101010101.10101010)_2 \rightarrow (1B55.AA8)_{16}$$

$$\rightarrow (110101101.001101)_2$$

0011|0110|1101|0011|0100  
3 | 6 | D | 3 | 4.

## → octal to Hexadecimal conversion

To convert an octal number to hexadecimal, first convert the given octal number to binary and then the binary number to hexadecimal.

$$\rightarrow (356.63)_8 \rightarrow ( \quad )_{16}$$

1. octal to binary

2. binary to hexadecimal

$$\begin{array}{r} 3 | 5 | 6 | . | 6 | 3 \\ (011 | 101 | 110 | 110 | 011)_2 \end{array}$$

$$\begin{array}{r} 0000 | 110 | 110 | . | 1100 | 1100 \\ 0 | E | E | . | C | C \end{array}$$

$$(356.63)_8 \rightarrow (0EE.CC)_{16}$$

## → Hexadecimal to octal conversion

To convert a hexadecimal number to octal, first convert the given Hexadecimal number to binary and then the binary number to octal.

$$\rightarrow (B9F.AE)_{16} \rightarrow ( \quad )_8$$

1. Hexadecimal to binary

2. binary to octal

|      |      |      |   |      |      |  |
|------|------|------|---|------|------|--|
| B    | 9    | F    | . | A    | E    |  |
| 1011 | 1001 | 1111 | . | 1010 | 1110 |  |

|      |      |      |   |      |      |   |
|------|------|------|---|------|------|---|
| 1011 | 1001 | 1111 | . | 1010 | 1110 |   |
| 5    | 6    | 3    | . | 7    | 5    | 3 |

$$(B9F.AE)_{16} \rightarrow (5637.534)_8.$$

Conversion from any system to any system.

$$(1321)_5 \rightarrow (\quad )_{12}.$$

To convert any system to any system, first convert the given number to decimal number and then the decimal number to any system.

$$\text{Step1: } (1321)_5 \rightarrow (211)_{10}.$$

$$= 1 \times 5^3 + 3 \times 5^2 + 2 \times 5^1 + 1 \times 5^0$$

$$= 125 + 75 + 10 + 1$$

$$= (211)_{10}$$

$$\text{Step2: } (211)_{10} \rightarrow (157)_{12}.$$

$$\begin{array}{r} 12 | 211 \\ 12 | 17 - 12 \\ \hline 12 | 5 - 12 \\ \hline 0 - 1 \end{array}$$

$$(1321)_5 \rightarrow (157)_{12}$$

r-1's complements and r's complements :-

Complements are used in digital systems to simplify the subtraction operation base (radix)  $r$  system there are two useful types of complements, the  $r$ 's-complement (Radix complement) and the  $(r-1)$ 's-complement (Diminished Radix Complement).

i's and 2's complements :-

The i's complement of a binary number is obtained by complementing all its bits, that is, by replacing all 0's by 1's and all 1's by 0's. For

$$\text{Example} \rightarrow 011010101 \quad 101010101100$$

$$i\text{'s complement} \rightarrow 100101010 \quad 01010101001$$

The 2's complement of a binary number is obtained by adding '1' to its i's complement.

$$\text{Example} \quad 011010101 \quad 10101101011$$

$$i\text{'s complement} \quad 100101010 \quad 01010010100$$

$$\begin{array}{r} +1 \\ \hline \end{array} \quad \begin{array}{r} +1 \\ \hline \end{array}$$

$$\text{2's complement} \quad \underline{\underline{100101011}} \quad \underline{\underline{01010010101}}$$

## I's complement :-

In I's complement subtraction, add the I's complement of the subtrahend to the minuend. If there is a carry out, bring the carry around and add it to the LSB. This is called the end around carry. If the MSB is 0, the result is positive and is in true binary. If the MSB is 1, the result is negative and is in its I's complement form.

### Example:-

Subtract 20 from 36 using the 8-bit I's complement form

$$36 - 20$$

$$36 - 00100100 \rightarrow 00100100$$

$$20 - 00010100 \rightarrow +11101011 \quad (I's \text{ complement form})$$

$$\boxed{0000111}$$

$$\begin{array}{r} & \swarrow & \downarrow & \searrow \\ & 1 & 1 & 1 \\ \hline 00010000 \\ \hline \overline{\text{MSB}} \end{array} \quad \begin{array}{l} \text{(Add the end around} \\ \text{carry)} \end{array}$$

$$36 - 20 = 16$$

The MSB is 0. The result is positive.

In I's complement addition, add the I's complement form of subtrahend and minuend. If there is a carry out add the carry in LSB position.

If the MSB of the result 0, then the answer is positive and MSB of the result 1, then the answer is negative.

### Example 2

Add +36 to +20 using 8 bit i's complement form.

$$36 \rightarrow 00100100 \rightarrow 11011011$$

$$20 \rightarrow 00010100 \rightarrow \begin{array}{r} 11101011 \\ \hline 11000110 \end{array}$$

$$\boxed{11000110}$$



[add the end around carry].

$$\overline{11000111}$$

MSB is 1, then the answer is negative.

$$00111000 = 56$$

$$36+20=56$$

### Example 3

Add -36 to -20 using 8 bit i's complement form.

$$36 \rightarrow 00100100 \rightarrow 11011011$$

$$00010100 \rightarrow \begin{array}{r} 11101011 \\ \hline 11000110 \end{array}$$

$$\boxed{11000110}$$

↑

11000111 → negative.

$$00111000 = 56$$

$$-36-20=-56 \quad (11000111)$$

### Example 4

Add ~~-36~~ -36 to +20 using 8-bit i's complement form.

$$+36 \rightarrow 00100100$$

$$-36 \rightarrow 11011011$$

$$+20 \quad 00010100$$

$$\hline 11101111$$

$$00010000$$

$$+20$$

$$-36$$

$$\hline -16$$

## 2's complement

In 2's complement subtraction, add the 2's complement of the subtrahend to the minuend. If there is a carry out, ~~being~~ ignore it. If the msb is 0, the result is positive and is in true binary. If the msb is '1' the result is negative and is in its 2's complement form.

### Example 1 :-

Subtract 20 from 36 using the 8-bit 2's complement form.

$$36 - 20,$$

→ Take subtrahend. 20.

$$20 \rightarrow 00010100$$

$$1's \text{ complement} \rightarrow \underline{\hspace{2cm}} 1110101$$

$$2's \text{ complement} \rightarrow \underline{\hspace{2cm}} 00101100$$

$$36 \rightarrow 00100100$$

$$20 \rightarrow \underline{\hspace{2cm}} 11101100 \quad (\text{2's complement form of } 20).$$

$$\underline{\hspace{2cm}} 00010000 \quad (\text{ignore the carry}).$$

### Example 2 :-

Add -36 to +20 using the 8-bit 2's complement form.

$$+36 \rightarrow 00100100$$

$$\underline{\hspace{2cm}} 11011011 \quad (1's \text{ complement}).$$

$$-36 \rightarrow \underline{\hspace{2cm}} 11011100 \quad (2's \text{ complement}).$$

$$20 \rightarrow 00010100$$

$$-36 \rightarrow \underline{\hspace{2cm}} 11011100$$

$$-16 = \underline{\hspace{2cm}} 11110000$$

$$\begin{array}{r}
 11110000 \\
 00001111 \\
 \hline
 11111111 \\
 00010000 \\
 \hline
 (+16)
 \end{array}$$

MSB is 1, then result is negative,

Example 3 :-

Add -45.75 to +87.5 using the 12-bit 2's complement arithmetic.

$$+87.5 \rightarrow 01010111.1000$$

$$+45.75 \rightarrow 00101101.1100$$

11010010.0011 (is complement form)

$$\begin{array}{r} & & 1 \\ & & 11 \\ \hline 11010010.0100 \end{array}$$

(2's complement form)

$$\begin{array}{r} 128 \cdot 64 \cdot 32 \cdot 16 \cdot 8 \cdot 4 \cdot 2 \cdot 1 \\ 0 \quad 0 \quad 1 \quad 0 \quad 1 \quad 0 \quad 0 \end{array}$$

$$+87.5 \rightarrow 01010111.1000$$

$$11010010.0100$$

$$\boxed{\begin{array}{r} 11 \\ 00101001.1100 \\ \downarrow \quad \downarrow \\ 41.75 \end{array}}$$

Ignore the carry.

Example 4 :-

Add -45.75 to -87.5 using the 12-bit 2's complement form.

$$+87.5 \rightarrow 01010111.1000$$

$$(\text{is comple}) 10101000.0111$$

$$\begin{array}{r} (\text{add 1}) \quad \quad \quad 1111 \\ \hline (\text{2's comp}). \quad 10101000.1000 \\ -87.5 \end{array}$$

$$+45.75 \rightarrow 00101101.1100$$

$$(\text{iscomp}) 11010010.0011$$

$$\begin{array}{r} 11 \\ \hline (\text{2'scomp}). \quad 11010010.0100 \\ -45.75 \end{array}$$

$$-87.5. \quad 10101000.1000$$

$$-45.75 \quad 11010010.0100$$

$$\boxed{\begin{array}{r} 1111010.1100 \\ \hline 10000101.0011 \end{array}}$$

Ignore the carry.

$$\begin{array}{r} 11 \\ \hline 10000101.0100 \end{array}$$

## 9's Complement:-

In 9's complement subtraction.

- find the 9's complement of the subtrahend.
- Add 9's complement of subtrahend to the minuend.
- if there is a carry it indicates that the answer is positive. Add the carry to the LSD of this result to get answer.
- If there is no carry, it indicates that the answer is negative and the result obtained is its 9's complement.
- Find the 9's complement of the following decimal numbers.

$$\rightarrow 4986$$

$$\rightarrow 738.65$$

$$\rightarrow 4526.075$$

$$9999$$

$$999.99$$

$$9999.999$$

$$4986$$

$$738.65$$

$$4526.075$$

$$\underline{5013}$$

$$\underline{261.34}$$

$$\underline{5473.924}$$

## 9's Complement method of subtraction :-

$$\rightarrow 745.86 - 436.62$$

$$\text{Step 1:- } 999.99$$

$$\underline{436.62}$$

$$\underline{563.37}$$

$$\text{Step 2:- }$$

$$745.86$$

$$\underline{563.37}$$

$$1) \underline{309.23}$$

$$\underline{309.24}$$

$$+ 309.24$$

The carry indicates the answer is positive.

$$436.62 - 745.86.$$

Step 1 :- 999.99

$$\begin{array}{r} 745.86 \\ \hline 254.13 \end{array}$$

Step 2 :- 436.62

$$\begin{array}{r} 254.13 \\ \hline 690.75 \end{array}$$

Step 3 :- If there is no carry, the answer is negative.

Step 4 :- 999.99

$$\begin{array}{r} 690.75 \\ \hline 309.24 \end{array}$$

answer is -309.24.

10's complement :-

The 10's complement of a decimal number is obtained by adding a 1 to its 9's complement.

Find the 10's complement of the following decimal number.

$$\rightarrow 4986$$

$$9999$$

$$4986$$

$$\hline 5013$$

$$1$$

$$\hline 5014$$

$$\rightarrow 738.65.$$

$$999.99$$

$$738.65$$

$$\hline 261.34$$

$$1$$

$$\hline 261.35$$

$$\rightarrow 4526.075$$

$$9999.999$$

$$4526.075$$

$$\hline 5473.924$$

$$\hline 5473.925$$

## 10's complement method of subtraction :-

$$\rightarrow 745.86 - 436.62$$

999.99

436.62

563.37

563.38 (10's complement)

745.86

563.38

① 309.24 (ignore the carry)

$$\rightarrow 436.62 - 745.86$$

999.99

745.86

254.13

1

254.14

436.62

254.14

690.76 (no carry, negative answer)

999.99

690.76

309.23

1

309.24

- 309.24.

### 15's complement method:-

Find the 15's complement of the following decimal number.

$$\rightarrow 6A36$$

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

$$\rightarrow 9AD.3A$$

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

### 15's complement method of subtraction

$$69B - C14$$

$$\rightarrow \begin{array}{r} 15 \ 15 \ 15 \\ C \ 1 \ 4 \\ \hline 3 \ E \ B. \end{array}$$

$$\rightarrow \begin{array}{r} 69B \\ 3E B \\ \hline A8.6 \end{array}$$

$$F - 15$$

$$10 - 16$$

$$11 - 17$$

$$12 - 18$$

$$13 - 19$$

$$14 - 20$$

$$15 - 21$$

$$16 - 20$$

$$17 - 28$$

$$18 - 14$$

$$19 - 17$$

$$20$$

$$21$$

$$22$$

$$\begin{array}{r} 16 \\ 12 \\ \hline 6 \end{array}$$

$$16$$

$\rightarrow$  No carry, it indicates answer is negative.

$$\begin{array}{r} 15 \ 15 \ 15 \\ A \ 8 \ 6 \\ \hline -5 \ 7 \ 9 \end{array}$$

$$69B_{16} - C14_{16} = -579_{16}$$

### 16's complement method :-

Find the 16's complement of the following decimal number.

→ A8C

$$\begin{array}{r}
 15 \quad 15 \quad 15 \\
 - A \quad 8 \quad C \\
 \hline
 5 \quad 7 \quad 3 \quad \text{--- (15's complement)} \\
 0 \quad 0 \quad 1 \quad (\text{add 1}) \\
 \hline
 5 \quad 7 \quad 4 \quad \text{--- (16's complement).}
 \end{array}$$

### 16's complement method of subtraction :-

C9B - C14

$$\begin{array}{r}
 15 \quad 15 \quad 15 \\
 - C \quad 1 \quad 4 \\
 \hline
 3 \quad E \quad B \quad \text{--- (15's complement).} \\
 1
 \end{array}$$

3 E C (16's complement)

$$\begin{array}{r}
 1 \quad 1 \\
 C \quad 9 \quad B \\
 3 \quad E \quad C \\
 \hline
 1 \quad 0 \quad 8 \quad 7 \quad (\text{ignore it})
 \end{array}$$

If carry present, the answer is positive.

$$C9B - C14 \rightarrow (087)_{16}$$

7's complement methode :-

Find the 7's complement of the following decimal number.

$$\rightarrow 536$$

$$\begin{array}{r} 777 \\ - 536 \\ \hline \end{array}$$

$$\begin{array}{r} 777 \\ - 536 \\ \hline 241 \end{array}$$

241 (7's complement).

7's complement methode of subtraction :-

$$623 - 352.$$

$$\begin{array}{r} 777 \\ - 352 \\ \hline \end{array}$$

$$\begin{array}{r} 777 \\ - 352 \\ \hline 425 \end{array}$$

425 (7's complement).

$$623 \rightarrow \begin{array}{r} 623 \\ 1 \\ \hline \end{array}$$

$$- 352 \rightarrow \begin{array}{r} 425 \\ 1250 \\ \hline \end{array}$$

5 1 (add carry)

$$\begin{array}{r} 251 \\ \hline \end{array}$$

$$352 - 623$$

$$\begin{array}{r} 777 \\ - 623 \\ \hline \end{array}$$

$$\begin{array}{r} 777 \\ - 623 \\ \hline 154 \end{array}$$

$$\begin{array}{r} 777 \\ - 623 \\ \hline 154 \\ - 154 \\ \hline 0 \end{array}$$

$$\begin{array}{r} 352 \\ 154 \\ \hline \end{array}$$

$$\begin{array}{r} 352 \\ 154 \\ \hline 206 \end{array}$$

$$\begin{array}{r} 352 \\ 154 \\ \hline 206 \\ - 206 \\ \hline 0 \end{array}$$

(No carry, answer is negative)

$$\begin{array}{r} 777 \\ - 526 \\ \hline \end{array}$$

$$\begin{array}{r} 777 \\ - 526 \\ \hline 251 \end{array}$$

$$\begin{array}{r} 777 \\ - 810 \\ \hline \end{array}$$

$$\begin{array}{r} 777 \\ - 911 \\ \hline \end{array}$$

$$\begin{array}{r} 777 \\ - 1012 \\ \hline \end{array}$$

$$\begin{array}{r} 777 \\ - 1113 \\ \hline \end{array}$$

$$\begin{array}{r} 777 \\ - 1214 \\ \hline \end{array}$$

$$\begin{array}{r} 777 \\ - 1315 \\ \hline \end{array}$$

## 8's complement method

Find the 8's complement of the following decimal number

$$\rightarrow 536.$$

$$\begin{array}{r}
 777 \\
 536 \\
 \hline
 241 \text{ (7's complement)} \\
 + 1 \text{ (add 1)} \\
 \hline
 242 \text{ (8's complement).}
 \end{array}$$

## 8's complement method of subtraction :-

$$623 - 352$$

$$\begin{array}{r}
 777 \\
 352 \\
 \hline
 425 \text{ (7's complement)} \\
 + 1 \text{ (add 1)} \\
 \hline
 426 \text{ (8's complement).}
 \end{array}$$

$$\begin{array}{r}
 623 \\
 426 \\
 \hline
 1251 \text{ (ignore the carry).}
 \end{array}$$

$$\begin{array}{r}
 623 \\
 - 352 \\
 \hline
 271
 \end{array}$$

If carry present, the answer is positive.

$$623 - 352 = (251)_8$$

## Number Representation in binary :-

There two types of numbers

- unsigned numbers
- signed numbers

The numbers without positive or negative signs are known as unsigned numbers. The unsigned numbers are always positive numbers (considered).

In signed number system, the number may be positive or negative. Different formats are used for representation of signed binary numbers. They are

- sign-magnitude representation
- 1's complement representation
- 2's complement representation

### Sign-magnitude Representation :-

In sign-magnitude representation the MSB represents the sign and the remaining bits represents the magnitude. The MSB bit is 1, it indicates the sign is negative, and MSB bit is 0, it indicates the sign is positive.

In eight bit representation, MSB indicates the sign and remaining seven bits represent the magnitude.

Consider the number +6 and -6 represented in binary.

sign bit

+6 = 

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

-6 = 

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

i's complement representation:-

In the i's complement representation, the positive numbers remain unchanged. i's complement representation of next number can be obtained by the i's complement of the binary number.

+6 → 

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

 msb=0 for positive

-6 → 

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

 msb = 1 for negative.

2's complement Representation:-

In the 2's complement representation, the positive numbers remain unchanged, 2's complement representation of negative number can be obtained by

→ find the i's complement of the number (by replacing 0 by 1 and 1 by 0)

→ find the 2's complement of the number by adding 1 to i's complement of the number.

$+6 \rightarrow$ 

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

$-6 \rightarrow$ 

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

| Decimal | Signed magnitude | Signed - 1's Complement | Signed - 2's Complement |  |
|---------|------------------|-------------------------|-------------------------|--|
| +7      | 0111             | 0111                    | 0111                    |  |
| +6      | 0110             | 0110                    | 0110                    |  |
| +5      | 0101             | 0101                    | 0101                    |  |
| +4      | 0100             | 0100                    | 0100                    |  |
| +3      | 0011             | 0011                    | 0011                    |  |
| +2      | 0010             | 0010                    | 0010                    |  |
| +1      | 0001             | 0001                    | 0001                    |  |
| +0      | 0000             | 0000                    | 0000                    |  |
| -0      | 1000             | 1111                    | -                       |  |
| -1      | 1001             | 1110                    | 1111                    |  |
| -2      | 1010             | 1101                    | 1110                    |  |
| -3      | 1011             | 1100                    | 1101                    |  |
| -4      | 1100             | 1011                    | 1100                    |  |
| -5      | 1101             | 1010                    | 1011                    |  |
| -6      | 1110             | 1001                    | 1010                    |  |
| -7      | 1111             | 1000                    | 1001                    |  |
| -8      | -                | -                       | 1000                    |  |

## Binary codes



## → Numeric codes

Numeric codes are codes which represent numeric information that is only numbers as a series of 0s and 1s. Numeric codes used to represent the decimal digits are called Binary Coded Decimal (BCD).

8421, 2421, 5211 are BCD codes.

8421, X5-3, Gray code are numeric codes.

## → Alphanumeric codes

Alphanumeric codes are binary codes which represent alphanumeric data. This code includes alphanumeric data, letters of the Alphabet, numbers, mathematical symbols and punctuation marks. ASCII and EBCDIC are commonly used Alphanumeric codes.

ASCII (American Standard code for Information Interchange).  
EBCDIC (Extended Binary Coded Decimal Interchange code).

Alphanumeric codes are used to interface input-output devices such as keyboards, printers, VDU's.  
→ weighted and non-weighted codes :-

The weighted codes are those which obey the position-weighting principle. Each position of the number represents a specific weight.

Ex:- 8421, 2421, 84-2-1.

In decimal code, if number is 637 then weight of 6 is 100, weight of 3 is 10, and weight of 7 is 1.

Non-weighted codes are codes which are not assigned with any weight to each digit position.

Ex:- Ex-3 (Excess-3) and Gray code.

→ Error detecting and correcting codes :-

Codes which allows only error detection are called error detecting codes. Codes which allows error detection and correction are called error-detecting error-correction codes. Error detection and correction involves the addition of extra bits, called check bits, to the transmitted data. These extra bits allows the detection and some time correction of errors in data.

Ex:- parity and Hamming codes.

→ Self-complementing codes :-

A code is said to be a self-complementing if the code word of the 9's complement of  $N$ , of  $9-N$  can be obtained by the 1's complement of the word of  $N$ . Therefore in a self complementing code, the code word for 9 is the complement for the code 0, 8 for 1, 7 for 2, 6 for 3 5 for 4.

Excess-3 code is example of self-complementary code.

→ Sequential codes :-

In sequential codes, each succeeding code is one binary number greater than its preceding code.

Ex:- 8421 and excess-3 codes.

## Cyclic codes :-

cyclic codes are also called unit distance codes.

The name itself indicates that there is unit distance between two consecutive codes. The unit distance codes have special advantages in that they minimize transitional errors or flashing.

Ex:- Gray code.

## Reflective codes :-

A Reflective code is a binary code in which the  $n$  least significant bits for code words  $2^n$  through  $2^{n+1}-1$  are the mirror images of those for 0 through  $2^n-1$ .

Ex:- Gray code.

## Binary coded decimal (BCD) code 81 8421 code :-

In this code, each decimal digit, 0 through 9, is coded by a 4-bit binary number. It is also called the natural binary code. For example, the decimal number 15 can be represented as 1111 in binary but in BCD, 0001 0101.

It is useful for mathematical operations. The main advantage of this code is its ease of conversion to and from decimal.

disadvantage of the BCD code is that, arithmetic operations are more complex and it requires more bits.

## BCD addition :-

- Convert the decimal numbers into their equivalent BCD codes.
- Add the two BCD numbers, using the basic rules for Binary addition.
- Check the result. If sum is equal to 8 or less than 9, it is a valid BCD number.
- If the result is greater than 9 or if a carry generated from the 4-bit sum, the sum is invalid.
- To correct the sum, add (0110)<sub>6</sub> to the sum term of that group.
- If carry results when 6 is added, simply add the carry to the next 4-bit group.

## Example :-

$$683.5 + 256.2$$

$$23 + 13$$

$$23 \rightarrow 0010\ 0011$$

$$13 \rightarrow 0001\ 0011$$

$$\underline{36} \quad \underline{0011\ 0110}$$

$$683.5 \rightarrow 0110\ 1000\ 0011\ .0101$$

$$256.2 \rightarrow 0010\ 0101\ 0110\ .0010$$

$$\underline{+ 39.7} \quad \underline{1000\ 1101\ 1001\ .0111}$$

$$0110$$

$$\underline{1000\ 0001\ 11001\ .0111}$$

(C)

$$\underline{1001\ 0011\ 1001\ .0111}$$

BCD Subtraction :-

- Each 4-bit Group of subtrahend from the corresponding 4-bit Group of the minuend.
- if there is no borrow from the next higher Group then no correction.
- if there is a borrow from the next group, then 6(0110) is subtracted from the difference term of group.

Example:-

$$23 - 13$$

$$23 \rightarrow 0010\ 0011$$

$$13 \rightarrow 0001\ 0011$$

$$\begin{array}{r} 10 \\ \hline 0000\ 0000 \\ 1 \quad 0 \end{array}$$

$$236.8 - 142.5$$

$$236.8 \rightarrow 0010\ 0011\ 0110.\ 1000$$

$$142.5 \rightarrow 0001\ 0100\ 0010.\ 0101$$

$$\begin{array}{r} 94.3 \\ \hline 0000\ 1111\ 0100. 0011 \\ 0110 \\ \hline 0000\ 1001\ 0100. 0011 \end{array}$$

BCD Subtraction using 9's complement 4. 3.

$$236.8 - 142.5$$

$$999.9$$

$$142.5$$

$$857.4$$

$$236.8 \rightarrow 0010\ 0011\ 0110.\ 1000$$

$$857.4 \rightarrow 1000\ 0101\ 0111.\ 0100$$

$$\begin{array}{r} 1010\ 1001\ 0100. 0010 \\ 0110 \\ \hline 1] 0000\ 1001\ 0100. 0010 \end{array}$$

$$1010\ 1001\ 0100. 0010$$

$$0110$$

$$\begin{array}{r} 1] 0000\ 1001\ 0100. 0010 \\ 0110 \\ \hline 0000\ 1001\ 0100. 0010 \end{array}$$

$$0000\ 1001\ 0100. 0010$$

$$\begin{array}{r} 0000\ 1001\ 0100. 0010 \\ 0110 \\ \hline 0000\ 1001\ 0100. 0010 \end{array}$$

$$0000\ 1001\ 0100. 0010$$

$$\begin{array}{r} 0000\ 1001\ 0100. 0010 \\ 0110 \\ \hline 0000\ 1001\ 0100. 0010 \end{array}$$

$$0000\ 1001\ 0100. 0010$$

$$\begin{array}{r} 0000\ 1001\ 0100. 0010 \\ 0110 \\ \hline 0000\ 1001\ 0100. 0010 \end{array}$$

$$0000\ 1001\ 0100. 0010$$

## BCD Subtraction using 10's Complement :-

1) 236.8 - 142.5.

236.8 → 0010 0011 0110. 1000

999.9

$$857.5 \rightarrow 1000 \underline{0101} \underline{0111} \cdot \underline{0101}$$

142-5

1010 · 1000 1101 · 1101

857.4

0110 0110

11

~~1111~~ 1001 0100 . 0011

857.5

0000 1001 0100.

9 4 . 3

• 6

In 10's complement ignore the carry.

236.8

142.5

094.3

## EXCESS THREE CODE ( $X_5 = 3$ ) :-

The excess-3 code for a given decimal number is determined by adding 3 (0011) to each decimal digit in the given number. It is a non-weighted BCD code, sequential and self-complementing code.

It can be used for arithmetic operations.

XS-3 Addition:-

$$\underline{23+13} \quad 23 \rightarrow 56 \rightarrow 0101\ 0110$$

$$13 \rightarrow 46 \rightarrow 0100\ 0110$$

$$\begin{array}{r} 23 \\ 33 \\ \hline 56 \end{array} \quad \begin{array}{r} 13 \\ 33 \\ \hline 46 \end{array}$$

$$\begin{array}{r} 1001\ 1100 \\ +0011 \\ \hline 0110\ 1001 \end{array}$$

(Answer in XS-3)

If carry generated add +0011

If carry not generated subtract -0011

$$\rightarrow 236.8 + 142.5$$

$$236.8 \rightarrow 569.B \rightarrow 0101\ 0110\ 1001\ 1011$$

$$142.5 \rightarrow 475.8 \rightarrow 0100\ 0111\ 0101\ 1000$$

$$\begin{array}{r} 1001\ 1101\ 1100\ 0011 \\ -0011\ 1101\ 1111\ 0011 \\ \hline 1001\ 0010\ 0110\ 0011 \end{array}$$

(Answer in XS-3)

$$\begin{array}{r} 1001\ 1101\ 1111\ 0011 \\ -0011\ 1101\ 1111\ 0011 \\ \hline 0110\ 0010\ 0110\ 0011 \end{array}$$

(Answer in XS-3)

3      7      9. 3

### X5 - 3 Subtraction :-

- if borrow generated subtract 3 (0011)
- if borrow not generated add 3(0011).
- $25.3 - 16.5$

$$25.3 \rightarrow 58.6 \rightarrow 0101 \quad 1000. \quad 0110$$

$$16.5 \rightarrow 49.8 \rightarrow 0100 \quad \underline{1001} \quad 1000$$

$$\begin{array}{r}
 0000 \quad 1110 \quad 1110 \\
 +0011 \quad -0011 \quad -0011 \\
 \hline
 0011 \quad 1011 \quad 1011
 \end{array}$$

Answer in X5-3.

$$\begin{array}{r}
 3 \quad B \quad B \\
 -3 \quad -3 \quad -3 \\
 \hline
 0 \quad 8 - 8
 \end{array}$$

$$\rightarrow 267 - 175$$

$$267 \rightarrow 5 \quad 9 \quad 10 \rightarrow 0101 \quad 1001 \quad 1010$$

$$175 \rightarrow 4 \quad 10 \quad 8 \rightarrow 0100 \quad 1010 \quad 1000$$

$$\begin{array}{r}
 0000 \quad 1111 \quad 0010 \\
 +0011 \quad -0011 \quad +0011 \\
 \hline
 0011 \quad 1100 \quad 0101
 \end{array}$$

Answer in X5-3).

$$\begin{array}{r}
 3 \quad C . 5 \\
 -3 \quad -3 \quad -3 \\
 \hline
 0 \quad 9 . 2
 \end{array}$$

### XS-3 Subtraction using 9's complement

$$\rightarrow 687 - 348$$

$$348 \rightarrow 999$$

$$\underline{348}$$

651. (9's complement form)

$$\underline{333}$$

984 (XS-3 form)

$$687 \rightarrow 1001\ 1011\ 1010 \quad (\text{XS-3 form of } 687)$$

$$984 \rightarrow 1001\ 1000\ 0100$$

$$\begin{array}{r} \\ \underline{10000\ 00011\ 1110} \\ \downarrow \end{array}$$

$$\begin{array}{r} \\ \underline{10001\ 00111\ 1110} \\ \downarrow \end{array}$$

$$\begin{array}{r} \\ \underline{0001\ 00111\ 1111} \\ + 0011\ \quad + 0011\ - 0011 \\ \hline \end{array}$$

0110\ 0110\ 1100 (answer in XS-3).

$$\begin{array}{r} \\ \underline{\begin{array}{r} 6\ 6\ 9 \\ -3\ -3\ -3 \\ \hline 3\ 3\ 9 \end{array}} \end{array}$$

If borrow generated subtract 3 (0011)

If borrow not generated add 3 (0011)

### Xs-3 Subtraction using 10's complement :-

$$\rightarrow 687 - 348$$

$$\begin{array}{r}
 999 \\
 348 \\
 \hline
 651 \quad (\text{9's complement form})
 \end{array}$$

1 (+ add'')

$$\begin{array}{r}
 652 \quad (\text{10's complement form})
 \end{array}$$

$$\begin{array}{r}
 652 \\
 +333 \\
 \hline
 985 \quad (\text{Xs-3 form})
 \end{array}$$

$$\begin{array}{r}
 687 \rightarrow \text{Xs-3} \rightarrow 1001\ 1011\ 1010 \\
 1001\ 1000\ 0101 \\
 \hline
 1100\ 1010011\ 1111 \\
 \text{[A]} \\
 \hline
 110011\ 0011\ 1111 \\
 \text{[B]} \qquad \text{Ignore the carry}
 \end{array}$$

$$\begin{array}{r}
 0011\ 0011\ 1111 \\
 +0011\ 0011\ -0011 \\
 \hline
 0110\ 0110\ 1100
 \end{array}$$

Answer in Xs-3.

$$\begin{array}{r}
 -3 \quad -3 \quad -3 \\
 \hline
 3 \quad 3 \quad 9
 \end{array}$$

## Gray Code :-

(21)

Gray code is a 4-bit numeric code. It is a unit distance code because successive code words in this code differ in one bit position only. It is also a reflective code, it is both reflective and unit distance.

| Decimal digit | Gray Binary Code | Decimal digit | Gray code. |
|---------------|------------------|---------------|------------|
| 0             | 0000             | 8             | 1100       |
| 1             | 0001             | 9             | 1101       |
| 2             | 0011             | A             | 1111       |
| 3             | 0010             | B             | 1110       |
| 4             | 0110             | C             | 1010       |
| 5             | 0111             | D             | 1011       |
| 6             | 0101             | E             | 1001       |
| 7             | 0100             | F             | 1000       |

## Binary to Gray code conversion

- Record the msb of the binary as the msb of the Gray code.
- Add the msb of the binary to the next bit in binary ignore the carry.
- Add the 2nd bit of binary to the 3rd bit of the binary, the 3rd bit to the 4th bit.

Convert binary 0110 to the Gray code.

$$0 \oplus 1 \oplus 1 \oplus 0$$

$$11 \quad 11 \quad 11$$

$$0 \quad 1 \quad 0 \quad 1$$

Convert binary 1001 to the Gray code.

$$1 \oplus 0 \oplus 0 \oplus 1$$

$$11 \quad 11 \quad 11 \quad 11$$

$$1 \quad 1 \quad 0 \quad 1$$

## Gray to Binary conversion :-

- The msb of the binary number is the same as the msb of the Gray code.
- Add the msb of the binary to the next significant bit of the Gray code, ignore the carry.
- Add the 2nd bit of the binary to the 3rd bit of the Gray; the 3rd bit of the binary to the 4th bit of the Gray code.
- convert Gray to Binary.

$$\begin{array}{r} 11011 \\ | \quad | \quad 0 \quad 1 \quad 1 \\ \downarrow \swarrow \uparrow \uparrow \uparrow \uparrow \uparrow \\ 1 \quad 0 \quad 0 \quad 1 \quad 0 \end{array}$$

$$\begin{array}{r} 1011 \\ | \quad | \quad | \quad | \\ \downarrow \uparrow \uparrow \uparrow \downarrow \\ 1 \quad 1 \quad 0 \quad 1 \end{array}$$

$$\begin{array}{r} 1 \quad 0 \quad 1 \quad 1 \quad 0 \quad 1 \\ | \quad \downarrow \quad | \quad | \quad | \quad | \\ \downarrow \uparrow \uparrow \uparrow \uparrow \uparrow \downarrow \\ 1 \quad 1 \quad 0 \quad 1 \quad 1 \quad 0 \end{array}$$

## Applications of Gray code :-

- Gray code is used in the transmission of digital signals as it minimizes the occurrence of errors.
- The Gray code is better than the binary code in angle measuring devices.
- The Gray code is used for labelling the axes of Karnaugh maps.
- The use of Gray codes to address program memory in computers minimizes power consumption.
- Another application of Gray code is position indication in rotating disk.

## Logic Gates:-

The logic Gates are the fundamental blocks of digital systems. The logic Gate is ability to make decisions (output). logic gate are electronic circuits because they are made up of a number of electronic devices and components.

Inputs and outputs of logic Gates can occur only in two levels.

## Positive logic:-



## Negative logic



## Mixed logic:-

Mixed logics provides a simplified mechanism for the analysis and design of digital circuits. In mixed logic, the assignment of logical values to voltage values is not fixed, and it can be decided by the logic designer.

## Logic design:-

The interconnection of gates to perform a variety of logical operations is called logic design.

## Truth table:-

A table which lists all the possible combinations of input variables and the corresponding outputs is called a truth table.

## Types of logic gates:-

1. AND Gate }
2. OR Gate }
3. NOT Gate }
4. NAND Gate } Basic Gates.
5. NOR Gate } universal Gates.
6. EXCLUSIVE OR Gate
7. EXCLUSIVE NOR Gate

### AND Gate:-

An AND gate is a logic circuit with two or more inputs and one output that performs ANDing operation. The output of an AND gate is high only when all of its inputs are in the high state. In all other conditions the output is low.



Logic symbol

Truth table

| X | Y | $Z = X \cdot Y$ |
|---|---|-----------------|
| 0 | 0 | 0               |
| 0 | 1 | 0               |
| 1 | 0 | 0               |
| 1 | 1 | 1               |

### OR Gate:-

An OR gate is a logic circuit with two or more inputs and one output that performs ORing operation. The output of an OR gate is high when any one of the input is high state. In all other conditions the output is low.

NOT gate :-

Symbol



Truth table

| x | y | $z = x + y$ |
|---|---|-------------|
| 0 | 0 | 0           |
| 0 | 1 | 1           |
| 1 | 0 | 1           |
| 1 | 1 | 1           |

NOT Gate :-

A NOT gate is also called an inverter. is a single input, single output logic circuit whose output is always the complement of the input. That is a low input produces a high output, high input produces a low output.



Truth table

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

Symbol

NAND gate :-

A NAND gate is equivalent to AND gate followed by a NOT gate. The output of NAND gate is low when all inputs are in high state. In all other conditions the output is high.



Symbol

| x | y | $z = \overline{xy}$ |
|---|---|---------------------|
| 0 | 0 | 1                   |
| 0 | 1 | 1                   |
| 1 | 0 | 1                   |
| 1 | 1 | 0                   |

## NOR Gate :-

The term NOR implies OR Gate followed by a NOT Gate. The output of a NOR Gate is logic 1 when all the inputs are logic '0'. In remaining all other conditions the output is logic '0'.



Truth table

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

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

## EX-OR Gate :- (Exclusive-OR Gate)

The output of an EX-OR Gate is a logic 1 when the two inputs are different logic and logic '0' when the two inputs are at the same logic.

$$\text{Truth table } Y = \overline{AB} + A\overline{B}$$



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

## EX-NOR Gate :- (Exclusive-NOR)

The output of an EX-NOR Gate is a logic 1 when the two inputs are same and logic 0 when the two inputs are different. EX-NOR Gate is EX-OR

Gate followed by NOT Gate



Truth table

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

### Error-detecting codes:

When the digital information in the binary form is transmitted from one system to another system an error may occur.

This means a signal '0' may change to '1' or '1' change to '0'.

### Parity bit:-

To maintain data integrity between transmitter and receiver, extra bit or more than one bit are added in the data. These extra bits allow the detection and sometimes correction of errors in the data. These extra bits are called parity bits.

- There are two types of parity - odd and even parity.
- For odd parity, the parity bit is set to a 0 or 1 at the transmitter such that the total number of '1's in the word including the parity bit is an odd number.
- For even parity, the parity bit is set to a 0 or 1 at the transmitter such that the total number of '1's in the word including the parity bit is an even number.

| decimal | Binary | odd parity | even parity |
|---------|--------|------------|-------------|
| 0       | 0000   | 1          | 0           |
| 1       | 0001   | 0          | 1           |
| 2       | 0010   | 0          | 0           |
| 3       | 0011   | 1          | 1           |
| 4       | 0100   | 0          | 0           |
| 5       | 0101   | 1          | 0           |
| 6       | 0110   | 1          | 0           |
| 7       | 0111   | 0          | 1           |

→ In an even - parity scheme, which of the following words contain an error.

(a) 10110110

The no. of 1's in the word is odd (5). So, there is an error.

(b) 11011011

The no. of 1's in the word is even (6), so, there is no error.

(c) 10101000

The no. of 1's in the word is odd (3), so there is an error.

→ In an odd - parity scheme, which of the following words contain an error.

(a). 11011101

The no. of 1's in the word is even(6). So, there is an error.

(b) 11011010

The no. of 1's in the word is odd (5). So there is no error.

(c) 11011000

The no. of 1's in the word is even(4), so there is ~~no error~~ an error.

## Hamming code :- (Error-correcting codes).

A code is said to be an error-correcting code, which allow error detection and correction are called error detecting and correcting codes.

- Hamming code not only provides the detection of a bit error, but also identifies which bit is in error.
- The code uses a number of parity bits located at certain positions in the code group.

### 1-bit Hamming code :-

To transmit four data bits, three parity bits located at positions  $2^0$ ,  $2^1$  and  $2^2$  from left are added to make a 7-bit code word which is then transmitted. The word format is.

$P_1 \ P_2 \ D_3 \ D_4 \ D_5 \ D_6 \ D_7$

D for the data bits

P for the parity bits.

$P_1$  is to be set to a '0' or a '1' so that it establishes even parity over bits 1,3,5 and 7 ( $P_1, D_3, D_5, D_7$ )

$P_2$  is to be set to a '0' or a '1' so that it establishes even parity over bits 2,3,6,7 ( $P_2, D_3, D_6, D_7$ )

$P_4$  is to be set to a '0' or a '1' so that it establishes even parity over bits 4,5,6,7 ( $P_4, D_5, D_6, D_7$ )

At the receiving end, the message received in the Hamming code is decoded to see if any errors have occurred.

Bits 1, 3, 5, 7, bits 2, 3, 6, 7, and bits 4, 5, 6, 7 are all checked for even parity.

→ If they all check out, there is no error.

→ if there is an error, the error bit can be located by forming a 3-bit binary number.

$$C_1 = P_1 \oplus D_3 \oplus D_5 \oplus D_7$$

$$C_2 = P_2 \oplus D_3 \oplus D_5 \oplus D_7$$

$$C_3 = P_4 \oplus D_5 \oplus D_6 \oplus D_7$$

Ex:- Encode data bits 1010 into the 7-bit even-parity hamming code.

The bit pattern

| $P_1$ | $P_2$ | $D_3$ | $P_4$ | $D_5$ | $D_6$ | $D_7$ |
|-------|-------|-------|-------|-------|-------|-------|
| 1     | 0     | 0     | 1     | 0     | 1     | 0     |

Bits 1, 3, 5, 7 ( $P_1 111$ ) must have even parity. so  $P_1$  must be a '1'

Bits 2, 3, 6, 7 ( $P_2 110$ ) must have even parity. so  $P_2$  must be a '1'

Bits 4, 5, 6, 7 ( $P_4 010$ ) must have even parity. so  $P_4$  must be a '1'.

The final code with parity bits is

| $P_1$ | $P_2$ | $D_3$ | $P_4$ | $P_5$ | $D_6$ | $D_7$ |
|-------|-------|-------|-------|-------|-------|-------|
| 1     | 0     | 1     | 1     | 0     | 1     | 0     |

→ This data transmitted through a noisy channel.

The code is

1010010 (error occurred).

$P_1 P_2 D_3 P_4 D_5 D_6 D_7$

To correct the code by using.

$$C_1 = 1 \oplus 1 \oplus 0 \oplus 0 = 0 \text{ put a '0' in the 1's position.}$$

$$C_2 = 0 \oplus 1 \oplus 1 \oplus 0 = 0 \text{ put a '0' in the 2's position.}$$

$$C_3 = 0 \oplus 0 \oplus 1 \oplus 0 = 1 \text{ put a '1' in the 4's position.}$$

Error in the 4<sup>th</sup> position.

1011010

12-bit hamming code :-

To transmit eight data bits, four parity bits located at positions  $2^0, 2^1, 2^2$  and  $2^3$  from left are added to make a 12-bit code word which is then transmitted.

P<sub>1</sub> P<sub>2</sub> D<sub>3</sub> P<sub>4</sub> D<sub>5</sub> D<sub>6</sub> D<sub>7</sub> P<sub>8</sub> D<sub>9</sub> D<sub>10</sub> D<sub>11</sub> P<sub>12</sub>

P<sub>1</sub> is set to a '0' 811 (P<sub>1</sub>, D<sub>3</sub>, D<sub>5</sub>, D<sub>7</sub>, D<sub>9</sub>, D<sub>11</sub>)

Similarly. P<sub>2</sub> (P<sub>2</sub>, D<sub>3</sub>, D<sub>6</sub>, D<sub>7</sub>, D<sub>10</sub>, D<sub>11</sub>)

P<sub>4</sub> (P<sub>4</sub>, D<sub>5</sub>, D<sub>6</sub>, P<sub>7</sub>, D<sub>12</sub>)

P<sub>8</sub> (P<sub>8</sub>, D<sub>9</sub>, D<sub>10</sub>, D<sub>11</sub>, D<sub>12</sub>).

Example:- gives - 01011010, generate the 12-bit code.

P<sub>1</sub> P<sub>2</sub> D<sub>3</sub> P<sub>4</sub> D<sub>5</sub> D<sub>6</sub> D<sub>7</sub> P<sub>8</sub> D<sub>9</sub> D<sub>10</sub> D<sub>11</sub> P<sub>12</sub>  
0 1 0 1 0 1 1 0 1 0 1 0

P<sub>1</sub> (P<sub>1</sub>, D<sub>3</sub>, D<sub>5</sub>, D<sub>7</sub>, D<sub>9</sub>) even parity, S<sub>0</sub> = P<sub>1</sub> = 0.

P<sub>2</sub> (P<sub>2</sub>, D<sub>3</sub>, D<sub>6</sub>, D<sub>7</sub>, D<sub>10</sub>) even parity, S<sub>0</sub> = P<sub>2</sub> = 0.

P<sub>4</sub> (P<sub>4</sub>, D<sub>5</sub>, D<sub>6</sub>, D<sub>7</sub>, D<sub>11</sub>) even parity, S<sub>0</sub> = P<sub>4</sub> = 0.

P<sub>8</sub> (P<sub>8</sub>, D<sub>9</sub>, D<sub>10</sub>, D<sub>11</sub>, D<sub>12</sub>) even parity, S<sub>0</sub> = P<sub>8</sub> = 0.

000010101010 (final data).

## 15-bit hamming code :-

To transmit eleven data bits, four parity bits located at positions  $2^0, 2^1, 2^2$  and  $2^3$  from left are added to make a 15-bit code word which is then transmitted.

|       |       |       |       |       |       |       |       |       |          |          |          |          |          |          |
|-------|-------|-------|-------|-------|-------|-------|-------|-------|----------|----------|----------|----------|----------|----------|
| $P_1$ | $P_2$ | $D_3$ | $P_4$ | $D_5$ | $D_6$ | $D_7$ | $P_8$ | $D_9$ | $D_{10}$ | $D_{11}$ | $D_{12}$ | $D_{13}$ | $D_{14}$ | $D_{15}$ |
|-------|-------|-------|-------|-------|-------|-------|-------|-------|----------|----------|----------|----------|----------|----------|

$P_1$  is set to be '0' 81 '1' ( $P_1, D_3, D_5, D_7, D_9, D_{11}, D_{13}, D_{15}$ )

$P_2$  is set to be '0' 81 '1' ( $P_2, D_3, P_6, D_7, D_{10}, D_{11}, D_{14}, D_{15}$ )

$P_4$  is set to be '0' 81 '1' ( $P_4, D_5, D_6, D_7, D_{12}, D_{13}, D_{14}, D_{15}$ )

$P_8$  is set to be '0' 81 '1' ( $P_8, D_9, D_{10}, D_{11}, D_{12}, D_{13}, D_{14}, D_{15}$ )

### Example :-

11-bit group 01101110101 find out the final code.

|       |       |       |       |       |       |       |       |       |          |          |          |          |          |          |
|-------|-------|-------|-------|-------|-------|-------|-------|-------|----------|----------|----------|----------|----------|----------|
| $P_1$ | $P_2$ | $D_3$ | $P_4$ | $D_5$ | $D_6$ | $D_7$ | $P_8$ | $D_9$ | $D_{10}$ | $D_{11}$ | $D_{12}$ | $D_{13}$ | $D_{14}$ | $D_{15}$ |
| 0     | 1     | 1     | 0     | .     | .     | .     | 1     | 1     | 1        | 0        | 1        | 0        | 1        | .        |

$P_1$  ( $P_1, 0, 1, 0, 1, 1, 1, 1$ ) even parity  $P_1 = 1$

$P_2$  ( $P_2, 0, 1, 0, 1, 1, 0, 1$ ) even parity  $P_2 = 0$

$P_4$  ( $P_4, 1, 1, 0, 0, 1, 0, 1$ ) even parity  $P_4 = 0$

$P_8$  ( $P_8, 1, 1, 1, 0, 1, 0, 1$ ) even parity  $P_8 = 1$

|       |       |       |       |       |       |       |       |       |          |          |          |          |          |          |
|-------|-------|-------|-------|-------|-------|-------|-------|-------|----------|----------|----------|----------|----------|----------|
| $P_1$ | $P_2$ | $D_3$ | $P_4$ | $D_5$ | $D_6$ | $D_7$ | $P_8$ | $D_9$ | $D_{10}$ | $D_{11}$ | $D_{12}$ | $D_{13}$ | $D_{14}$ | $D_{15}$ |
| 1     | 0     | 0     | 0     | 1     | 1     | 0     | 1     | 1     | 1        | 1        | 0        | 1        | 0        | 1        |

The final code is

100011011110101

## Standard SOP and POS :-

SOP (sum of products):-

product term → multiplying two or more variable is called product term. (Ex:-  $ABC$ ,  $\bar{ABC}$ ,  $AB$ ,  $\bar{ABC}\bar{D}\bar{E}$ )  
 SOP → summation of product term is called SOP.

$$\text{Ex: } AB + \bar{B}A + \bar{A}C$$

It is also called the Disjunctive normal form (DNF).

## Standard SOP :-

It is also called Disjunctive canonical form (DCF)

It is also called the Expanded sum of products form or canonical sum-of-products form. In this form, the function is the sum of a number of product terms where each product term contains all variables either in complemented or uncomplemented form.

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

## SOP to Standard SOP :-

→ write down all the terms

→ If one or more variables are missing in any term, expand that term by multiplying it with the sum of each one of the missing variable and its complement.

→ drop out the redundant term

→ Replace the variables by 1's or 0's:

complemented variables by 0's

non-complemented variables by 1's.

$$* \text{Expand } f(A, B) = \overline{AB} + B.$$

The given expression is a two-variable function.  
In second term, the variable A is missing. So multiply it by  $(A + \overline{A})$ .

$$\begin{aligned}\overline{AB} + B &= \overline{AB} + B(A + \overline{A}) \\ &= \underline{\overline{AB}} + AB + \underline{\overline{AB}} \rightarrow \text{Drop out redundant} \\ &= \overline{AB} + AB \\ &= 01 + 11 \rightarrow \text{non-complemented} \rightarrow '1' \\ &= m_1 + m_3 \rightarrow \text{Complemented} \rightarrow '0' \\ &= \sum m(1, 3).\end{aligned}$$

$$* f(A, B, C) = ABC + A\overline{B}C + AB + BC$$

$$= ABC + A\overline{B}C + AB(C + \overline{C}) + BC(A + \overline{A})$$

$$= \underline{ABC} + \underline{A\overline{B}C} + \underline{AB(C + \overline{C})} + \underline{BC(A + \overline{A})}$$

$$= \overline{ABC} + ABC + \overline{ABC}$$

$$= 011 + 111 + 101$$

$$= m_3 + m_7 + m_5$$

$$= \sum m(3, 5, 7)$$

$$* f(A, B, C) = A + AB + BCA.$$

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

$$= AB + A\overline{B}(C + \overline{C}) + ABC + A\overline{B}\overline{C} + ABC.$$

$$= \underline{ABC} + \underline{A\overline{B}C} + \underline{A\overline{B}\overline{C}} + \underline{ABC} + \underline{ABC} + \underline{ABC}$$

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

$$= 000111 + 101 + 100 + 110 = m_7 + m_5 + m_4 + m_6$$

$$= \sum m(4, 5, 6, 7).$$

POS (product of sum) :-

Sum term :- Sum of two or more variable is called sum term. (Ex:-  $(A+B)$ ,  $(A+B+C)$ ).

POS  $\rightarrow$  product of sum terms is called pos.

$$\text{Ex: } (\bar{A}+B)(\bar{B}+A+C).$$

It is also called conjunctive normal form (CNF).

Standard pos :-

It is also called conjunctive canonical form (CCF). It is also called the expanded product of sum form & canonical product of sum form. In this form, the function is product of a number of sum terms where each sum term contains all variables either in complemented or uncomplemented form.

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

Pos to standard pos :-

$\rightarrow$  write down all the terms.

$\rightarrow$  If one or more variables are missing in any term expand that term by adding the product of each of the missing variable and its complement.

$\rightarrow$  drop out the redundant one.

$\rightarrow$  Replace the complemented variables by 1's and the non-complemented variables by 0's.

$$* \text{Expand } f(AB) = (\bar{A}+B)(A).$$

The given expression is a two-variable function.  
In second term, the variable B is missing. So add it by  $(B + \bar{B})$ .

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

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

$$= (10)(11)(01\bar{0})$$

$$= M_1, M_2, M_3$$

$$= \prod M(1, 2, 3).$$

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

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

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

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

$$(000)(001)(010)(011)(100)(101)$$

$$= M_0, M_1, M_2, M_3, M_4, M_5.$$

$$= \prod M(0, 1, 2, 3, 4, 5).$$

## NAND - PVNAND Realization :-

1) NOT Gate



using NAND gate.



2) AND Gate.

Step :- 1 add bubble on output



Step :- 2 add one NOT gate



3) OR Gate



Step :- 1 add bubble on input



Step 2:- add NOT gate



4) NAND gate



5) NOR Gate



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



Step :- 2



Step 3:-



6) EX-OR Gate



$$Y = (\overline{A} + B)(A + \overline{B}) \\ = (\overline{A} + B) + (A + \overline{B}) \\ = (A \cdot \overline{B}) + (\overline{A} \cdot B)$$

Step 1 :-



Step 2 :-



Step 3 :-

$$\overline{A \cdot C} = \overline{A} + \overline{C}$$

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

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

$$\begin{aligned}
 Y &= (\overline{A} + \overline{C})(\overline{A} + B)(\overline{A} + \overline{B} + \overline{C}) \\
 &= (\overline{A} + \overline{C}) + (\overline{A} + B) + (\overline{A} + \overline{B} + \overline{C}) \\
 &= AC + A\overline{B} + \overline{A} \cdot \overline{B} \cdot \overline{C} \\
 &= AC + A\overline{B} + ABC
 \end{aligned}$$

7) EX-NOR Gate :-



$$Y = \overline{AB} + AB.$$



Step 1 :-



$$\begin{aligned} Y &= \overline{(A+B)}(\overline{\bar{A}+\bar{B}}) \\ &= (\overline{A+B}) + (\overline{\bar{A}+\bar{B}}) \\ &= \overline{A}\cdot\overline{B} + (A\cdot B) \end{aligned}$$

\* Implement a given Boolean expression by using NAND gate.

$$Y = AC + \overline{AB} + ABC.$$



## NOR - NOR Realization

1) NOT Gate



2) AND Gate.



Step 2



Step 3



3) OR Gate



Step :- 1



Step :- 2



4) NAND Gate



Step :- 1



Step 2 :-



Step 3



Step 4 :-



5) NOR Gate :-



6) EX-OR Gate :-

Step :- 1



Step :- 2



Step :- 3



Step 4 :-



7) EX-NOR gate:-

Step 1 :-



Step 2 :-



Step 3 :-



Step 4 :-



\*  $y = AC + BC + AB + D$ , implement Boolean Expression by using NOR Gate.

$$y = AC + BC + AB + D$$



Step :- 1

Step :- 2



Step :- 2



Step 3 :-



\* implement the Boolean Expression  
 $(A + \bar{B} + C) (\bar{A} + C) (\bar{B} + C)$ .

by using NOR Gate.



Step 2 :-



Step 3 :-



Step 4 :-



## MINIMIZATION TECHNIQUES

- Binary Logic is used in all of today's digital computers and devices, the cost of the circuits that implement it is an important factor.
- Finding simpler and cheaper, but equivalent, realizations of a circuit must be good. To reducing the overall cost of the design.
- 

Boolean theorems :-1. Complementation laws :-

Complement means, to change 0's to 1's and 1's to 0's.

$$\text{Law 1} : \overline{0} = 1$$

$$\text{Law 2} : \overline{1} = 0$$

$$\text{Law 3} : \overline{\overline{A}} = A \rightarrow \overline{A} = \overline{1}$$

$$\text{Law 4} : \overline{A} = 1 \rightarrow A = 0$$

$$\text{Law 5} : \overline{\overline{A}} = A \quad (\text{Double complementation does not change the function}).$$

2. AND laws :-

$$\text{Law 1} : A \cdot 0 = 0$$

$$\text{Law 2} : A \cdot 1 = A$$

$$\text{Law 3} : A \cdot A = A$$

$$\text{Law 4} : A \cdot \overline{A} = 0$$

3. OR laws :-

$$\text{Law 1} : A + 1 = 1$$

$$\text{Law 2} : A + 0 = A$$

$$\text{Law 3} : A + A = A$$

$$\text{Law 4} : A + \overline{A} = 1$$

#### 4. Commutative laws:-

Law 1 :-  $A+B = B+A$



| A | B | $A+B$ |
|---|---|-------|
| 0 | 0 | 0     |
| 0 | 1 | 1     |
| 1 | 0 | 1     |
| 1 | 1 | 1     |

| A | B | $B+A$ |
|---|---|-------|
| 0 | 0 | 0     |
| 0 | 1 | 1     |
| 1 | 0 | 1     |
| 1 | 1 | 1     |

Law 2 :-  $A \cdot B = B \cdot A$



| A | B | $A \cdot B$ |
|---|---|-------------|
| 0 | 0 | 0           |
| 0 | 1 | 0           |
| 1 | 0 | 0           |
| 1 | 1 | 1           |

| A | B | $B \cdot A$ |
|---|---|-------------|
| 0 | 0 | 0           |
| 0 | 1 | 0           |
| 1 | 0 | 0           |
| 1 | 1 | 1           |

#### 5. Associate laws:-

Law 1:  $(A+B)+C = A+(B+C)$



| A | B | C | $A+B$ | $(A+B)+C$ |
|---|---|---|-------|-----------|
| 0 | 0 | 0 | 0     | 0         |
| 0 | 0 | 1 | 0     | 1         |
| 0 | 1 | 0 | 1     | 1         |
| 0 | 1 | 1 | 1     | 1         |
| 1 | 0 | 0 | 1     | 1         |
| 1 | 0 | 1 | 1     | 1         |
| 1 | 1 | 0 | 1     | 1         |
| 1 | 1 | 1 | 1     | 1         |

| A | B | C | $B+C$ | $A+(B+C)$ |
|---|---|---|-------|-----------|
| 0 | 0 | 0 | 0     | 0         |
| 0 | 0 | 1 | 1     | 1         |
| 0 | 1 | 0 | 1     | 1         |
| 0 | 1 | 1 | 1     | 1         |
| 1 | 0 | 0 | 0     | 0         |
| 1 | 0 | 1 | 1     | 1         |
| 1 | 1 | 0 | 1     | 1         |
| 1 | 1 | 1 | 1     | 1         |

Law 2:  $(A \cdot B)C = A(B \cdot C)$ .



| A | B | C | $AB$ | $(AB)C$ |
|---|---|---|------|---------|
| 0 | 0 | 0 | 0    | 0       |
| 0 | 0 | 1 | 0    | 0       |
| 0 | 1 | 0 | 0    | 0       |
| 0 | 1 | 1 | 0    | 0       |
| 1 | 0 | 0 | 0    | 0       |
| 1 | 0 | 1 | 0    | 0       |
| 1 | 1 | 0 | 1    | 0       |
| 1 | 1 | 1 | 1    | 1       |

| A | B | C | $B \cdot C$ | $A(B \cdot C)$ |
|---|---|---|-------------|----------------|
| 0 | 0 | 0 | 0           | 0              |
| 0 | 0 | 1 | 0           | 0              |
| 0 | 1 | 0 | 0           | 0              |
| 0 | 1 | 1 | 1           | 0              |
| 1 | 0 | 0 | 0           | 0              |
| 1 | 0 | 1 | 0           | 0              |
| 1 | 1 | 0 | 0           | 0              |
| 1 | 1 | 1 | 1           | 1              |

## 6. Distributive Laws:-

Law 1 :  $A(B+C) = AB+AC$



| A | B | C | $(B+C)$ | $A(B+C)$ |
|---|---|---|---------|----------|
| 0 | 0 | 0 | 0       | 0        |
| 0 | 0 | 1 | 1       | 0        |
| 0 | 1 | 0 | 1       | 0        |
| 0 | 1 | 1 | 1       | 0        |
| 1 | 0 | 0 | 0       | 0        |
| 1 | 0 | 1 | 1       | 1        |
| 1 | 1 | 0 | 1       | 1        |
| 1 | 1 | 1 | 1       | 1        |

| A | B | C | AB | AC | $AB+AC$ |
|---|---|---|----|----|---------|
| 0 | 0 | 0 | 0  | 0  | 0       |
| 0 | 0 | 1 | 0  | 0  | 0       |
| 0 | 1 | 0 | 0  | 0  | 0       |
| 0 | 1 | 1 | 0  | 0  | 0       |
| 1 | 0 | 0 | 0  | 0  | 0       |
| 1 | 0 | 1 | 0  | 1  | 1       |
| 1 | 1 | 0 | 1  | 0  | 1       |
| 1 | 1 | 1 | 1  | 1  | 1       |

Law 2 :  $A+BC = (A+B)(A+C)$



| A | B | C | $BC$ | $A+BC$ |
|---|---|---|------|--------|
| 0 | 0 | 0 | 0    | 0      |
| 0 | 0 | 1 | 0    | 0      |
| 0 | 1 | 0 | 0    | 0      |
| 0 | 1 | 1 | 1    | 1      |
| 1 | 0 | 0 | 0    | 1      |
| 1 | 0 | 1 | 0    | 1      |
| 1 | 1 | 0 | 0    | 1      |
| 1 | 1 | 1 | 1    | 1      |

| A | B | C | $A+B$ | $A+C$ | $(A+B)(A+C)$ |
|---|---|---|-------|-------|--------------|
| 0 | 0 | 0 | 0     | 0     | 0            |
| 0 | 0 | 1 | 0     | 1     | 0            |
| 0 | 1 | 0 | 1     | 0     | 0            |
| 0 | 1 | 1 | 1     | 1     | 1            |
| 1 | 0 | 0 | 1     | 1     | 1            |
| 1 | 0 | 1 | 1     | 1     | 1            |
| 1 | 1 | 0 | 1     | 1     | 1            |
| 1 | 1 | 1 | 1     | 1     | 1            |

## 7. Redundant Literal Rule :-

Law 1:  $A(\bar{A} + B) = AB$ .



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

$$= A \cdot \bar{A} + AB$$

$$= \underline{AB}$$



$$Y = AB$$

| A | B | $\bar{A} + B$ | $A(\bar{A} + B)$ |
|---|---|---------------|------------------|
| 0 | 0 | 1             | 0                |
| 0 | 1 | 1             | 0                |
| 1 | 0 | 0             | 0                |
| 1 | 1 | 1             | 1                |

| A | B | $AB$ |
|---|---|------|
| 0 | 0 | 0    |
| 0 | 1 | 0    |
| 1 | 0 | 0    |
| 1 | 1 | 1    |

Law 2:  $A + \bar{A}B = A + B$ .

$$\begin{aligned} &= A + \bar{A}B \\ &= (A + \bar{A})(A + B) \\ &= (A + B) \end{aligned}$$

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

| A | B | $A + B$ |
|---|---|---------|
| 0 | 0 | 0       |
| 0 | 1 | 1       |
| 1 | 0 | 1       |
| 1 | 1 | 1       |

## 8. Idempotence Laws:-

Idempotence means the same value.

$$\text{Law 1: } A \cdot A = A$$

$$\text{if } A=0 \text{ then } 0 \cdot 0 = 0$$

$$\text{if } A=1 \text{ then } 1 \cdot 1 = 1$$

$$\text{Law 2: } A + A = A$$

$$\text{if } A=0 \text{ then } 0 + 0 = 0$$

$$\text{if } A=1 \text{ then } 1 + 1 = 1$$

## 9. Absorption Laws :-

$$\text{Law 1} = A + A \cdot B = A$$



| A | B | A · B | A + A · B |
|---|---|-------|-----------|
| 0 | 0 | 0     | 0         |
| 0 | 1 | 0     | 0         |
| 1 | 0 | 0     | 1         |
| 1 | 1 | 1     | 1         |

$$= A + A \cdot B$$

$$= A(1 + B) \quad \because 1 + B = 1$$

$$= A \cdot 1$$

$$= A.$$

$$\text{Law 2: } A(A + B) = A$$



| A | B | A + B | A(A + B) |
|---|---|-------|----------|
| 0 | 0 | 0     | 0        |
| 0 | 1 | 1     | 0        |
| 1 | 0 | 1     | 1        |
| 1 | 1 | 1     | 1        |

$$= A \cdot A + A \cdot B$$

$$= A + A \cdot B$$

$$= A(1 + B)$$

$$= A.$$

$= A(A + \text{any term})$

$$= A$$

## 10. Consensus Theorem :-

$$\text{Theorem 1: } AB + \overline{A}C + BC = AB + \overline{A}C.$$

$$\text{L.H.S} \rightarrow AB + \overline{A}C + BC$$

$$= AB + \overline{A}C + BC (A + \overline{A})$$

$$= AB + \overline{A}C + ABC + \overline{A}BC$$

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

$$= AB(1) + \overline{A}C = AB + \overline{A}C.$$

$$AB + \overline{AC} + BCD = AB + \overline{AC}$$

$$\text{L.H.S} \rightarrow AB + \overline{AC} + BCD$$

$$AB + \overline{AC} + BCD(A + \overline{A})$$

$$AB + \overline{AC} + ABCD + \overline{ABC}D$$

$$AB(1 + CD) + \overline{AC}(1 + CD)$$

$$AB + \overline{AC}$$

$$\text{Theorem 2 : } (A+B)(\overline{A}+C)(B+C) = (A+B)(\overline{A}+C)$$

$$\text{L.H.S} : (A+B)(\overline{A}+C)(B+C)$$

$$(A\overline{A} + AC + \overline{A}B + BC)(B+C)$$

$$(AC + BC + \overline{A}B)(B+C)$$

$$ABC + BC + \overline{A}BC + AC + BC + \overline{A}B$$

$$= BC + AC + \overline{A}B(1 + C) + ABC$$

$$= BC + \overline{A}B + AC(1 + B)$$

$$= AC + BC + \overline{A}B$$

$$\text{R.H.S} = (A+B)(\overline{A}+C)$$

$$\therefore = A\cdot\overline{A} + AC + \overline{A}B + BC$$

$$= \overline{A}B + AC + BC$$

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

If a sum of products comprises a term containing A and a term containing  $\overline{A}$ , and a third term containing the left out literals of the first two terms, then the third term is redundant.

$\rightarrow$  The function remains the same with or without the third term removed or retained.

## Transposition Theorem :-

Theorem :  $AB + \overline{A}C = (A+C)(\overline{A}+B)$

$$\begin{aligned}
 \text{R.H.S.} &= (A+C)(\overline{A}+B) \\
 &= A\cdot\overline{A} + AB + \overline{A}C + BC \\
 &= AB + \overline{A}C + BC \\
 &= AB + \overline{A}C + BC(A+\overline{A}) \\
 &= AB + \overline{A}C + ABC + \overline{A}BC \\
 &= AB(1+C) + \overline{A}C(1+B) \\
 &= AB + \overline{A}C
 \end{aligned}$$

## Demorgan's Theorem :-

Law 1  $A+B = \overline{\overline{A}\cdot\overline{B}}$

The complement of a sum of variables is equal to the product of their individual complements.



| A | B | $A+B$ | $\overline{A+B}$ |
|---|---|-------|------------------|
| 0 | 0 | 0     | 1                |
| 0 | 1 | 1     | 0                |
| 1 | 0 | 1     | 0                |
| 1 | 1 | 1     | 0                |

| A | B | $\overline{A}$ | $\overline{B}$ | $\overline{A}\cdot\overline{B}$ |
|---|---|----------------|----------------|---------------------------------|
| 0 | 0 | 1              | 1              | 1                               |
| 0 | 1 | 1              | 0              | 0                               |
| 1 | 0 | 0              | 1              | 0                               |
| 1 | 1 | 0              | 0              | 0                               |

$$\text{Similarly } \rightarrow A + B + C + D + E = \overline{\overline{A} \cdot \overline{B} \cdot \overline{C} \cdot \overline{D} \cdot \overline{E}}$$

$$\rightarrow \overline{\overline{AB} + \overline{CD} + \overline{ED}} = (\overline{AB})(\overline{CD})(\overline{ED})$$

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

$$\text{Law 2 } \overline{AB} = \overline{A} + \overline{B}$$

The complement of the product of variables is equal to the sum of their individual complements.



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

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

### Duality:-

when changing from one logic system to another, '0' becomes '1' and '1' becomes '0'. An AND gate becomes an OR gate, and an OR gate becomes an AND gate. Given a Boolean identity, we can produce a dual identity by changing all '+' signs to '·' signs, all '·' signs to '+' signs. The variables are not complemented.

$$\rightarrow A \cdot (A \cdot B) = A \cdot B \rightarrow \overline{A + A} + B = A + B.$$

$$\rightarrow \overline{AB} + \overline{A} + AB = 0 \rightarrow \overline{A + B} \cdot \overline{A} \cdot (A + B) = 1$$

$$\rightarrow A + B = AB + \overline{A}B + A\overline{B} \rightarrow AB = (A + B)(\overline{A} + B)(A + \overline{B})$$

Reducing Boolean expressions by using Boolean theorems :-

$$* f = A[B + \bar{C}(\bar{A}B + \bar{A}\bar{C})]$$

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

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

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

$$= A[B + \bar{C}[\bar{A}\bar{A} + \bar{A}\bar{C} + \bar{A}\bar{B} + \bar{B}\bar{C}]] \quad \bar{A}\cdot\bar{A} = 0$$

$$= A[B + \bar{C}[\bar{A} + \bar{A}\bar{C} + \bar{A}\bar{B} + \bar{B}\bar{C}]]$$

$$= A[B + \bar{C}\bar{A} + \underline{\bar{A}\bar{C}} + \underline{\bar{A}\bar{B}} + \underline{\bar{B}\bar{C}}] \quad C\cdot\bar{C} = 0$$

$$= A[B + \bar{A}\bar{C} + \bar{A}\bar{B}\bar{C}]$$

$$= AB + A\bar{A}\bar{C} + A\bar{A}\bar{B}\bar{C} \quad A\cdot\bar{A} = 0.$$

$$= AB$$

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

$$= \bar{A}\bar{B} + \bar{A}\bar{C} + B\bar{B} + BC + AB + C \quad B\cdot\bar{B} = 0$$

$$= \bar{A}\bar{B} + \underline{\bar{A}\bar{C}} + BC + AB + C$$

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

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

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

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

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

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

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

$$= \overline{A} + \overline{B} + A + \overline{C} = A + \overline{A} + \overline{B} + \overline{C} = 1 + \overline{B} + \overline{C} = 1$$

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

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

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

$$= \underline{\overline{A}\overline{A}} + \underline{\overline{A}\overline{B}\overline{A}} + \underline{\overline{A}\overline{C}\overline{A}} + \underline{\overline{A}\overline{B}\overline{A}} + \underline{B\overline{C}\overline{A}} + \underline{\overline{B}\overline{C}\overline{A}} + \underline{AB} + \underline{\overline{A}\overline{B}\overline{B}} + \underline{\overline{A}\overline{C}\overline{B}} + \underline{\overline{A}\overline{B}\overline{B}}$$

$$\underline{B\cdot\overline{B}\overline{C}} + \underline{\overline{B}\overline{C}\overline{B}} + \underline{A\overline{C}} + \underline{A\overline{B}\overline{C}} + \underline{\overline{A}\overline{C}\overline{C}} + \underline{A\overline{B}\overline{C}} + \underline{\overline{B}\overline{C}\overline{C}} + \underline{\overline{B}\overline{C}\overline{C}} (\overline{A} + \overline{B} + \overline{C})$$

$$= \overline{ABC} + \overline{ABC} + \overline{ABC} + AB + ABC + AB + \overline{BC} + A\overline{C} + A\overline{B}\overline{C} + A\overline{C} + A\overline{B}\overline{C}$$

$$+ B\overline{C} + \overline{BC}(\overline{A} + \overline{B} + \overline{C}).$$

$$= \overline{ABC} + \overline{ABC} + \overline{ABC} + \overline{ABA} + \overline{ABC\overline{A}} + \overline{ABA} + \overline{B\overline{C}\overline{A}} + \overline{AC\overline{A}} + \overline{A\overline{B}\overline{C}\overline{A}} + \overline{A\overline{C}\overline{A}}$$

$$+ \overline{A\overline{A}\overline{B}\overline{C}} + \overline{B\overline{C}\overline{A}} + \overline{B\overline{C}\overline{A}} + \overline{A\overline{B}\overline{C}\overline{B}} + \overline{A\overline{B}\overline{C}\overline{B}} + \overline{A\overline{B}\overline{C}\overline{B}} + \overline{A\overline{B}\overline{C}\overline{B}}$$

$$+ \overline{A\overline{B}\overline{B}} + \overline{B\overline{C}\overline{B}} + \overline{A\overline{B}\overline{C}} + \overline{A\overline{B}\overline{C}\overline{B}} + \overline{A\overline{C}\overline{B}} + \overline{A\overline{B}\overline{B}} + \overline{B\overline{C}\overline{B}} + \overline{B\overline{C}\overline{B}} + \overline{A\overline{B}\overline{C}}$$

$$+ \overline{ABC} + \overline{ABC} + ABC + ABC + \overline{BCC} + \overline{ACC} + \overline{ABC} + \overline{ACC}$$

$$+ \overline{ABC} + \overline{BCC} + \overline{BCC}.$$

$$= \overline{ABC} + \overline{ABC} + \overline{ABC} + \overline{ABC} + \overline{BC} + \overline{ABC} + \overline{BC} + \overline{AC} +$$

$$= \overline{BC}(1 + \overline{A} + A) + \overline{ABC} + \overline{ABC} + \overline{BC} + \overline{AC}$$

$$= \overline{BC} + \overline{ABC} + \overline{ABC} + \overline{BC} + \overline{AC}$$

$$= \overline{BC}(1 + A) + \overline{BC} + \overline{ABC} + \overline{ABC}$$

$$= \overline{BC} + \overline{BC} + \overline{ABC} + \overline{AC}$$

$$= \overline{BC}(1 + \overline{A}) + \overline{BC} + \overline{AC}$$

$$= \overline{BC} + \overline{BC} + \overline{AC}$$

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

$$\begin{aligned}
 * f &= A \cdot \overline{(A \oplus B) \oplus C} \\
 \rightarrow f &= A \cdot \overline{\underbrace{[A \oplus B]}_{\substack{A \\ B}} \oplus C} \\
 &= A \left[ \overline{A \oplus B} \cdot C + (A \oplus B) \cdot \overline{C} \right] \\
 &= A \left[ (\overline{AB} + \overline{BA}) \cdot C + ((\overline{AB} + \overline{BA}) \cdot \overline{C}) \right] \\
 &= A \left[ (\overline{AB})(\overline{BA}) + \overline{C} \right] \cdot \left[ (\overline{AB} + \overline{BA}) + \overline{C} \right] \\
 &= A \left[ (\overline{A} + \overline{B})(\overline{B} + \overline{A}) + \overline{C} \right] \cdot \left[ (\overline{AB} + \overline{BA}) + \overline{C} \right] \\
 &= A \left[ (AB + \overline{A}\overline{A} + \overline{B}\overline{B} + \overline{A}\overline{B} + \overline{C}) \right] \cdot \left[ (\overline{AB} + \overline{BA} + \overline{C}) \right] \\
 &= A \left[ AB + \overline{A}\overline{B} + \overline{C} \right] \cdot \left[ (\overline{AB} + \overline{BA} + \overline{C}) \right] \\
 &= A \left[ \overline{AB}\overline{AB} + \overline{AB}\overline{BA} + \overline{ABC} + \overline{AB}\overline{AB} + \overline{AB}\overline{BA} + \overline{ABC} + \overline{ABC} + \overline{BAC} \right. \\
 &\quad \left. + \overline{C.C} \right] \\
 &= A \left[ ABC + \overline{ABC} + \overline{ABC} + \overline{ABC} \right] \\
 &= A \cdot ABC + A \cdot \overline{ABC} + A \cdot \overline{ABC} + A \cdot \overline{ABC} \\
 &= ABC + \overline{ABC} \\
 &= A [BC + \overline{BC}] \\
 &= A [B \odot C].
 \end{aligned}$$
  

$$\begin{aligned}
 * f &= (B+BC)(B+\overline{BC})(B+D) \\
 f &= (B \cdot B + B \cdot \overline{B}C + BC \cdot B + BC \cdot \overline{B}C)(B+D) \\
 &= (B+BC)(B+D) \\
 &= B \cdot B + BD + B \cdot BC + BCD \\
 &= B + BD + \underline{BC} + BCD \\
 &= B(1+C) + BD(1+C) \\
 &= B + BD \Rightarrow B(1+D) = \underline{B}
 \end{aligned}$$

$$* f(A, B, C, D) = \overline{AB} + \overline{BC} + \overline{AD} + CD$$

Applying the consensus theorem to 2<sup>nd</sup> and 4<sup>th</sup> terms.

$$\overline{AB} + \overline{BC} + \overline{AD} + CD + \overline{BD} \quad (\overline{BC} + CD + \overline{BD} = \overline{BC} + CD)$$

3<sup>rd</sup> and 5<sup>th</sup> terms, the term  $\overline{AB}$  becomes redundant.

$$\overline{BC} + \overline{AD} + CD \quad (\overline{BD} + \overline{AD} + \overline{AB} = \overline{BD} + \overline{AD})$$

$$f_{\min} = \overline{AD} + \overline{BC} + CD$$

K-map (Karnaugh-map) :-

The K-map method, on the other hand, is a systematic method of (simplification dep) simplifying the Boolean Expressions. The K-map is a chart or a graph, composed of an arrangement of adjacent cells, each representing a particular combination of variables in sum or product form.

→ An n variable function can have  $2^n$  possible combinations of product terms in SOP form, or  $2^n$  possible combinations of sum terms in POS form.

→ A two-variable K-map will have  $2^2 = 4$  cells or squares,

→ A three-variable K-map will have  $2^3 = 8$  cells or squares

→ A four-variable K-map will have  $2^4 = 16$  cells or squares.

→ Any boolean Expression can be expressed in a standard or expanded Sum of products form or in a standard or canonical or expanded product of sums form.

→ Each of the product terms in the standard SOP form is called minterms and each of the sum terms in the standard POS form is called maxterms.

## Two-Variable K-map :- (Mapping of SOP Expressions)

A two-variable K-map has  $2^2 = 4$  cells or squares.  
4 possible combinations of the input variables A and B:

$$(\bar{A}\bar{B}, \bar{A}B, A\bar{B}, AB).$$

$$m_0 = \bar{A}\bar{B}, m_1 = \bar{A}B, m_2 = A\bar{B}, m_3 = AB.$$

\*  $f = A\bar{B} + AB$  simplify by using K-map.

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

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

The minterms of a two-variable K-map.

$$f = B.$$

\* Reduce the expression by using K-map.

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

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

logic diagram



$$f = A + B$$

## mapping of POS Expressions

$$M_0 = A + B, M_1 = A + \bar{B}, M_2 = \bar{A} + B, M_3 = \bar{A} + \bar{B}$$

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

The maxterms of a two-variable K-map.

→ Reduce the expression by using K-map

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



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

### Three-variable K-map

A function in three variable (A,B,C) expressed in the standard SOP form can have  $2^3 = 8$  possible combinations. They are  $\bar{A}\bar{B}\bar{C}$ ,  $\bar{A}\bar{B}C$ ,  $\bar{A}B\bar{C}$ ,  $A\bar{B}\bar{C}$ ,  $A\bar{B}C$ ,  $AB\bar{C}$ ,  $ABC$ , and  $A\bar{B}C$ . In the standard POS form can have  $2^3 = 8$  possible combinations. They are  $A+B+C$ ,  $A+B+\bar{C}$ ,  $A+\bar{B}+C$ ,  $A+\bar{B}+\bar{C}$ ,  $\bar{A}+B+C$ ,  $\bar{A}+B+\bar{C}$ ,  $\bar{A}+\bar{B}+C$  and  $\bar{A}+\bar{B}+\bar{C}$ .

|   |   | BC                                           | 00                                     | 01                                     | 11                                     | 10 |
|---|---|----------------------------------------------|----------------------------------------|----------------------------------------|----------------------------------------|----|
|   |   | A                                            | 0                                      | 1                                      | 1                                      | 0  |
| 0 | 0 | $\bar{A}\bar{B}\bar{C}$<br>(M <sub>0</sub> ) | $\bar{A}\bar{B}C$<br>(M <sub>1</sub> ) | $\bar{A}B\bar{C}$<br>(M <sub>2</sub> ) | $A\bar{B}\bar{C}$<br>(M <sub>3</sub> ) |    |
|   | 1 | $ABC$<br>(M <sub>4</sub> )                   | $A\bar{B}\bar{C}$<br>(M <sub>5</sub> ) | $ABC$<br>(M <sub>6</sub> )             | $A\bar{B}\bar{C}$<br>(M <sub>7</sub> ) |    |

|                                    |                                          |                                                |                                          |
|------------------------------------|------------------------------------------|------------------------------------------------|------------------------------------------|
| $A+B+C$<br>(M <sub>0</sub> )       | $A+B+\bar{C}$<br>(M <sub>1</sub> )       | $A+\bar{B}+\bar{C}$<br>(M <sub>3</sub> )       | $A+\bar{B}+C$<br>(M <sub>2</sub> )       |
| $\bar{A}+B+C$<br>(M <sub>4</sub> ) | $\bar{A}+B+\bar{C}$<br>(M <sub>5</sub> ) | $\bar{A}+\bar{B}+\bar{C}$<br>(M <sub>7</sub> ) | $\bar{A}+\bar{B}+C$<br>(M <sub>6</sub> ) |

max terms.

minterms

\* Reduce the expression  $f = \bar{A}\bar{B}\bar{C} + \bar{A}\bar{B}C + \bar{A}B\bar{C} + AB\bar{C} + ABC$ .

$$\bar{A}\bar{B}\bar{C} = 001 = M_1$$

$$\bar{A}\bar{B}C = 101 = M_5$$

$$\bar{A}B\bar{C} = 010 = M_2$$

$$AB\bar{C} = 110 = M_6$$

$$ABC = 111 = M_7$$



$$f_1 = m_1 + m_5 = \overline{A}\overline{B}C + A\overline{B}C = \overline{B}C(A + \overline{A}) = \overline{B}C.$$

$$f_2 = m_5 + m_7 = A\overline{B}C + ABC = AC(B + \overline{B}) = AC$$

$$f_3 = m_7 + m_6 = ABC + AB\overline{C} = AB(C + \overline{C}) = AB$$

$$f_4 = m_2 + m_6 = ABC + \overline{A}B\overline{C} = \overline{B}\overline{C}(A + \overline{A}) = \overline{B}\overline{C}$$

$$f = f_1 + f_2 + f_3 + f_4$$

$$= \overline{B}C + AC + AB + \overline{B}\overline{C}$$



logic diagram

\* Reduce the Expression.  $f = (A+B+C)(\overline{A}+\overline{B}+\overline{C})(\overline{A}+\overline{B}+\overline{C})$

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

$$A+B+C = 000 = M_0$$

$$\overline{A}+\overline{B}+\overline{C} = 101 = M_5$$

$$\overline{A}+\overline{B}+\overline{C} = 011 = M_7$$

$$A+\overline{B}+\overline{C} = 011 = M_3$$

$$\overline{A}+\overline{B}+C = 110 = M_6$$

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

$$f_1 = M_0 = A + B + C$$

$$f_2 = M_5 \cdot M_7 = (\bar{A} + B + \bar{C}) (\bar{A} + \bar{B} + \bar{C})$$

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

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

$$f_3 = M_3 \cdot M_7$$

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

$$\begin{aligned} &= A\bar{A} + A\bar{B} + A\bar{C} + \bar{A}\bar{B} + \bar{B}\bar{B} + \bar{B}\bar{C} + \bar{A}\bar{C} + \bar{B}\bar{C} + \bar{C}\bar{C} \\ &= A\bar{B} + A\bar{C} + \bar{A}\bar{B} + \bar{B} + \bar{B}\bar{C} + \bar{A}\bar{C} + \bar{C} \end{aligned}$$

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

$$\therefore f_3 = \bar{B} + \bar{C}$$

$$f_4 = M_7 \cdot M_6$$

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

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

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

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

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

$$F = f_1 \cdot f_2 \cdot f_3 \cdot f_4$$

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



Four-variable K-map :-

A four-variable ( $A, B, C, D$ ) expression can have  $2^4 = 16$  possible combinations.

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

| CD \ AB | 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+D$ | $\bar{A}+\bar{B}+C+\bar{D}$ | $\bar{A}+\bar{B}+\bar{C}+\bar{D}$ | $\bar{A}+\bar{B}+\bar{C}+D$ |

SOP form :-

POS form :-

\* Reduce the expression  $f = \sum m(0,1,2,3,5,7,8,9,10,12,13)$  and implement the expression by using universal logic.

$$f = \sum m(0,1,2,3,5,7,8,9,10,12,13)$$

| AB\CD | 00 | 01 | 11 | 10 |
|-------|----|----|----|----|
| 00    | 1  | 1  | 1  | 1  |
| 01    |    | 1  | 1  |    |
| 11    | 1  | 1  | 12 | 13 |
| 10    | 1  | 1  | 14 | 15 |

$$f_1 = m_0 + m_2 + m_3 + m_5 = \overline{A}B\overline{D}$$

$$f_2 = m_1 + m_3 + m_5 + m_7 = \overline{A}D$$

$$f_3 = m_{12} + m_{13} + m_8 + m_9 = A\overline{C}$$

$$f_4 = m_8 + m_{10} + m_0 + m_2 = \overline{B}\overline{D}$$

$$\begin{aligned} f_{min} &= f_1 + f_2 + f_3 \\ &= \overline{B}\overline{D} + A\overline{C} + \overline{A}D. \end{aligned}$$



\* Reduce the expression  $f = \prod M(2,8,9,10,11,12,14)$  and implement the expression by using universal logic.

$$f = \prod M(2,8,9,10,11,12,14).$$

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

$$f_1 = M_8 \cdot M_9 \cdot M_{11} \cdot M_{10} \quad f_2 = M_8 \cdot M_{12} \cdot M_{10} \cdot M_{14}$$

$$= (\bar{A} + B) \quad = (\bar{A} + D)$$

$$f_3 = M_2 \cdot M_{10}$$

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

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



### prime implicants :- [PI]

Each square or rectangle made up of the bunch of adjacent minterms is called a subcube. Each of these subcubes is called a prime implicants.

### essential prime implicants:-

The prime implicant which contains at least one 1 which cannot be covered by any other prime implicant is called an essential prime implicant [EPI].

### Redundant prime implicants:-

The prime implicant whose each 1 is covered at least by one EPI is called a redundant prime implicants. (RPI).

### Selective prime implicants:-

A prime implicant which is neither an essential prime implicant nor a redundant prime implicant is called a selective prime implicant (SPI).

| AB\CD | 00 | 01 | 11 | 10 |                             |
|-------|----|----|----|----|-----------------------------|
| 00    | 0  | 1  | 1  | 2  | → essential prime implicant |
| 01    | 14 | 1  | 1  | 6  | → redundant prime implicant |
| 11    | 12 | 13 | 15 | 14 | prime implicant             |
| 10    | 8  | 9  | 11 | 10 |                             |

$$f = \sum m(5, 7, 13, 15, 9, 14, 4)$$

$$f(A,B,C,D) = \Sigma m(0,4,5,10,11,13,15).$$

|     | AB\CD | 00 | 01 | 11 | 10 |
|-----|-------|----|----|----|----|
| EPI | 00    | 1  |    | 3  | 2  |
|     | 01    | 1  | 1  | 7  | 5  |
| SPI | 11    | 1  | 1  | 7  | 14 |
|     | 10    | 8  | 9  | 11 | 10 |

False prime implicants :- (FPI)

The prime implicants obtained by using the maxterms are called False prime implicants.

Essential false prime implicants:-

The FPI's which contains at least one '0' which cannot be covered by any other FPI is called Essential False prime implicants [EFPI].

|      | AB\CD | 00 | 01 | 11 | 10 |
|------|-------|----|----|----|----|
| EFP1 | 00    | 0  | 1  | 3  | 2  |
|      | 01    | 0  | 0  | 0  | 0  |
| EFP1 | 11    | 0  | 0  | 0  | 0  |
|      | 10    | 0  | 0  | 0  | 0  |

  

|      | AB\CD | 00 | 01 | 11 | 10 |
|------|-------|----|----|----|----|
| EFP1 | 00    | 0  | 0  | 0  | 0  |
|      | 01    | 0  | 0  | 0  | 0  |
| EFP1 | 11    | 0  | 0  | 0  | 0  |
|      | 10    | 0  | 0  | 0  | 0  |

The four corner 0's form the largest cluster of adjacent 0's, which is an FPI whose 0's are covered by essential FPI's and hence is a redundant false prime implicant (RFPI).

$$F(A, B, C, D) = (A + \bar{C})(A + B + \bar{D})[A \rightarrow B \rightarrow C](\bar{A} + \bar{B} + D)$$



The function has in all seven FPI's marked in figure.

The FPI is an essential FPI as it contains 0's at locations 2 and 7 which cannot be covered by any other FPI.

The remaining FPI are all SFP's.

Five-variable K-map :-

A five-variable ( $A, B, C, D, E$ ) expression can have  $2^5 = 32$  possible combinations of input variables.

The 32 squares of the K-map are divided into 2 blocks of 16 squares each. One block taken as  $A=1$ , and another one taken as  $A=0$ .

\* Reduce the following expression in SOP and POS form.

$$f = \sum m(0, 2, 3, 10, 11, 12, 13, 16, 17, 18, 19, 20, 21, 26, 27)$$



$$f_{\text{min}} = \overline{ABC}\bar{D} + \overline{AB}\bar{D} + A\bar{B}\bar{D} + \overline{A}\bar{C}\bar{D}$$

$$f_1, f_2, f_3, f_4.$$

$$f = \prod M(1, 4, 5, 6, 7, 8, 9, 14, 15, 22, 23, 24, 25, 28, 29, 30, 31)$$



$$f_1 = (A+B+\bar{D}+\bar{E}) \quad f_3 = \bar{C}+\bar{D} \quad f_5 = (\bar{B}+C+\bar{D})$$

$$f_2 = (A+B+\bar{C}) \quad f_4 = \bar{A}+\bar{B}+\bar{D}$$

$$F_{\text{min}} = f_1 \cdot f_2 \cdot f_3 \cdot f_4 \cdot f_5$$

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

## Six-Variable K-map :-

A six-variable ( $A, B, C, D, E, F$ ) expression can have  $2^6 = 64$  possible combinations of input variables.

The 64 squares of the K-map are divided into 4 blocks of 16 squares each. One block taken as  $AB = "00"$  and remaining are " $01$ ", " $10$ ", and " $11$ ".

\* Reduce the expression

$$f = \sum m(0, 2, 7, 8, 10, 13, 16, 18, 24, 26, 29, 31, 32, 34, 37, 39, 40, 42, 45, 47, 48, 50, 53, 55, 56, 58, 61, 63)$$



$$f_1 = \overline{B}\overline{C}DEF$$

$$f_2 = C\overline{D}EF$$

$$f_3 = \overline{D}\overline{F}$$

$$f_4 = ADF$$

$$f_5 = BCDF$$

$$F_{\min} = f_1 + f_2 + f_3 + f_4 + f_5$$

$$F_{\min} = \overline{B}\overline{C}DEF + C\overline{D}\overline{E}F + \overline{D}\overline{F} + ADF + BCDF.$$

Don't care combinations :-

The combinations for which the values of the expression are not specified are called don't care combinations or optional combinations and such expressions, therefore incompletely specified. The don't care terms are denoted by d, x or q. During the process of design using an SOP map each don't care is treated as a 1 if it is helpful in map reduction. During the process of design using an POS map each don't care is treated as a 0 if it is helpful in map reduction.

→ A standard SOP expression with don't cares can be converted into a standard POS form by keeping the don't cares as they are, and writing the missing minterms of the SOP form as the maxterms of the POS form.

→ A standard POS expression with don't cares can be converted into a standard SOP form by keeping the don't cares as they are, and writing the missing maxterms of the POS form as the min terms of the SOP form.

$$F(w,x,y,z) = \sum m(1,3,7,11,15) + \sum d(0,2,5).$$



$$F_{min} = f_1 + f_2$$

$$= \overline{wx} + yz$$

$$F(A,B,C,D) = \prod M[0,3,7,8,9,10,11,15] + \prod d[2,4]$$



$$F_{min} = f_1 \cdot f_2 \cdot f_3 = (\overline{c} + \overline{d})(\overline{a} + b)(b+d)$$

### Limitations of K-map:-

- K-maps are not suitable when the number of variables involved exceed four. It may be used with difficulty up to five and six variable systems. But beyond 'six variable' K-maps cannot be physically visualized.
- The K-map simplification is a manual technique and simplification process is heavily dependent on the abilities of the designer. It cannot be programmed.

→ Reduce the expression  $f = \sum m(1, 5, 6, 12, 13, 14) + d(2, 4)$  by using k-map in POS form and implement by using universal logic

$$f = \sum m(1, 5, 6, 12, 13, 14) + d(2, 4) \rightarrow \text{SOP form.}$$

$$f = \prod M(0, 3, 7, 8, 9, 10, 11, 15), \prod d(2, 4).$$



$$f_1 = \overline{C} + \overline{D}$$

$$f_2 = (B + D)$$

$$f_3 = (\overline{A} + B)$$

$$f_{\min} = (\overline{C} + \overline{D})(B + D)(\overline{A} + B).$$



## Aune McCluskey or tabular method :-

W.V. Aune and E.J. McCluskey developed an exact tabular method to simplify the Boolean Expression. This method is called the Aune McCluskey or tabular method.

The procedure for the minimization of a Boolean expression by the tabular method

Step 1. List all the minterms.

Step 2. Arrange all minterms in groups of the same number of 1's in their binary representation in column 1.

Step 3. Compare each term of the lowest index group with every term in the succeeding group.

Step 4 : compare the terms generated in step 2 in the same fashion combine two terms which differ by only a single 1 and whose dashes are in the same position to generate a new term.

Step 5 :- list all the prime implicants and draw the implicant chart. (The don't cares if any should not appear in the prime implicant chart).

Step 6 :- obtain essential prime implicants and write the minimal expression.

\* obtain the minimal expression for  $f = \sum m(1, 2, 3, 5, 6, 7, 8, 9, 12, 13, 15)$  using tabular method.

| Step 1                                                                | Step 2                                                                                                                                 | Step 3                                                                   |
|-----------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------|
| index 1<br>1 000 ✓<br>2 001 0 ✓<br>8 1000 ✓                           | $\cancel{(1,3)(2)00-1}$<br>$\cancel{(1,5)(4)0-01}$<br>$\checkmark(1,9)(8)-001$                                                         | $(1,3,5,7)(2,4)0-1-T$<br>$(1,5,9,13)(4,8)-01-S$<br>$(2,3,6,7)(1,4)0-1-R$ |
| index 2<br>3 001 1 ✓<br>5 010 ✓<br>6 011 0 ✓<br>9 100 ✓<br>12 110 0 ✓ | $\cancel{(2,3)(1)001-}$<br>$\cancel{(2,6)(4)0-10}$<br>$\cancel{(8,9)(1)100-}$<br>$\checkmark(8,12)(4)1-00$<br>$\checkmark(3,7)(4)0-11$ | $(8,9,12,13)(3,4)1-0-S$<br>$(5,7,13,15)(2,8)-1-1-P$                      |
| index 3<br>7 011 1 ✓<br>13 110 1 ✓                                    | $\checkmark(5,7)(2)01-1$<br>$\cancel{(5,13)(8)-101}$<br>$\cancel{(6,7)(1)011-}$                                                        |                                                                          |
| index 4<br>15 111 1 ✓                                                 | $\checkmark(9,13)(4)1-01$<br>$\checkmark(12,13)(1)110-$<br>$(7,15)(8)-111$<br>$(5,15)(2)-11-1$                                         |                                                                          |

Prime implicant chart

|                                     | 1 | 2 | 3 | 5 | 6 | 7 | 8 | 9 | 12 | 13 | 15 |
|-------------------------------------|---|---|---|---|---|---|---|---|----|----|----|
| P $\rightarrow 5, 7, 13, 15 \{28\}$ |   |   |   | x |   | x |   |   |    | x  | x  |
| Q $\rightarrow 8, 9, 12, 13$        |   |   |   |   |   |   | x | x | x  | x  |    |
| R $\rightarrow 2, 3, 6, 7$          |   | x | x |   |   | x |   |   |    |    |    |
| S $\rightarrow 1, 5, 9, 13$         | x |   |   | x | x |   |   | x |    |    |    |
| T $\rightarrow 1, 3, 5, 7$          | x |   | x | x | x | x | x | x | x  |    |    |

$$P + Q + R + S \rightarrow BD + A\bar{C} + \bar{A}C + \bar{C}D$$

$$P + Q + R + T \rightarrow BD + A\bar{C} + \bar{A}C + \bar{A}D.$$

Simplify the following function using the branching method:

$$f(A, B, C, D, E) = \sum m(0, 4, 12, 16, 19, 24, 28, 29, 31)$$

Index 0 0 0000 ✓

(0, 4) (4) 00 - 00 W ✓

index 1 4 00100 ✓  
16 10000 ✓

(0, 16) (16) - 0000 V

index 2 12 01100 ✓  
24 11000 ✓

(4, 12) (8) 0 - 100 U  
(16, 24) (8) 1 - 000 T

index 3 19 10011 X.  
28 11100 ✓

(12, 28) (16) - 1100 S ✓  
(24, 28) (4) 11 - 00 R ✓

index 4 29 11101 ✓

(28, 29) (1) 1110 - W

index 5 31 11111 ✓

(29, 31) (2) 111 - 1 P \*

Prime implicant chart

| 0 | 4 | 12 | 16 | 19 | 24 | 28 | 29 | 31 |
|---|---|----|----|----|----|----|----|----|
|---|---|----|----|----|----|----|----|----|

\* P(29, 31).

X (X)

Q(28, 29)

X X

R (24, 28)

X X

S (12, 28)

X

X

T (16, 24)

X

X

U (4, 12)

X

V (0, 16)

X

W (0, 4)

X X

\* X (19)

(X)

In table x and p are essential prime implicants.

|               | 0 | 4 | 12 | 16 | 24 | 28 |
|---------------|---|---|----|----|----|----|
| w(0,4) (4)    | x | x |    |    |    |    |
| v(0,16) (16)  | x |   |    | x  |    |    |
| u(4,12) (8)   |   | x | x  |    | x  | x  |
| t(16,24) (8)  |   |   |    | x  | x  | x  |
| s(12,28) (16) |   |   |    | x  |    |    |
| r(24,28) (4)  |   |   |    |    | x  | x  |
| q(28,29) (1)  |   |   |    |    |    | x  |

In the reduced PI chart, there were no essential

PIS, dominated rows: 8) dominating columns in column 0.  
it is covered by rows w and v. First select row w.

|          | 12 | 16 | 24 | 28 |
|----------|----|----|----|----|
| v(0,16)  |    | x  |    |    |
| u(4,12)  | x  |    | x  | x  |
| t(16,24) |    | x  |    |    |
| s(12,28) | x  |    | x  | x  |
| r(24,28) |    |    |    | x  |
| q(28,29) |    |    |    |    |

In this row v is dominated by row t, row u and row  
w are dominated by row s. So rows v, u, w can be reduced.

|            | 12 | 16 | 24 | 28 |
|------------|----|----|----|----|
| * t(16,24) |    | x  | x  |    |
| * s(12,28) | x  |    | x  | x  |
| r(24,28)   |    |    | x  | x  |

In this, T and S are the secondary essential prime  
implicants. So R is redundant.

$$f_{min} = w + s + t + x + p$$

$$= \overline{AB}\overline{D}\overline{E} + BC\overline{D}\overline{E} + A\overline{C}\overline{D}\overline{E} + A\overline{B}\overline{C}DE + ABCE$$

## Code converters :-

Design a circuit 4-bit binary to Gray code converter.

| 4-bit binary |       |       |       | 4-bit Gray |          |          |          |
|--------------|-------|-------|-------|------------|----------|----------|----------|
| $B_4$        | $B_3$ | $B_2$ | $B_1$ | $G_{14}$   | $G_{13}$ | $G_{12}$ | $G_{11}$ |
| 0            | 0     | 0     | 0     | 0          | 0        | 0        | 0        |
| 0            | 0     | 0     | 1     | 0          | 0        | 0        | 1        |
| 0            | 0     | 1     | 0     | 0          | 0        | 1        | 1        |
| 0            | 0     | 1     | 1     | 0          | 0        | 1        | 0        |
| 0            | 1     | 0     | 0     | 0          | 1        | 0        | 0        |
| 0            | 1     | 0     | 1     | 0          | 1        | 1        | 1        |
| 0            | 1     | 1     | 0     | 0          | 1        | 0        | 0        |
| 0            | 1     | 1     | 1     | 0          | 1        | 0        | 0        |
| 1            | 0     | 0     | 0     | 1          | 1        | 0        | 0        |
| 1            | 0     | 0     | 1     | 1          | 1        | 0        | 1        |
| 1            | 0     | 1     | 0     | 1          | 1        | 1        | 1        |
| 1            | 0     | 1     | 1     | 1          | 1        | 1        | 0        |
| 1            | 1     | 0     | 0     | 1          | 0        | 1        | 0        |
| 1            | 1     | 0     | 1     | 0          | 1        | 0        | 1        |
| 1            | 1     | 1     | 0     | 0          | 0        | 1        | 0        |
| 1            | 1     | 1     | 1     | 0          | 0        | 0        | 0        |

$B_4 \rightarrow G_{14}$

$B_3 \rightarrow G_{13}$

$B_2 \rightarrow G_{12}$

$B_1 \rightarrow G_{11}$

logic diagram

K-map for  $G_{14}$



$$G_{14} = B_4$$

K-map for  $G_{13}$



$$G_{13} = B_4 \bar{B}_3 + B_3 B_4 \\ = B_3 \oplus B_4$$

K-map for  $G_{12}$



$$G_{12} = B_3 \oplus B_2$$

K-map for  $G_{11}$



$$G_{11} = B_2 \oplus B_1$$

## Design of a BCD to Gray Code converter :-

| BCD Code<br>B <sub>3</sub> B <sub>2</sub> B <sub>1</sub> B <sub>0</sub> | Gray Code<br>G <sub>3</sub> G <sub>2</sub> G <sub>1</sub> G <sub>0</sub> |
|-------------------------------------------------------------------------|--------------------------------------------------------------------------|
| 0 0 0 0                                                                 | 0 0 0 0                                                                  |
| 0 0 0 1                                                                 | 0 0 0 1                                                                  |
| 0 0 1 0                                                                 | 0 0 1 1                                                                  |
| 0 0 1 1                                                                 | 0 0 1 0                                                                  |
| 0 1 0 0                                                                 | 0 1 0 0                                                                  |
| 0 1 0 1                                                                 | 0 1 1 1                                                                  |
| 0 1 1 0                                                                 | 0 1 0 1                                                                  |
| 0 1 1 1                                                                 | 0 1 0 0                                                                  |
| 1 0 0 0                                                                 | 1 1 0 0                                                                  |
| 1 0 0 1                                                                 | 1 1 0 1                                                                  |



$$G_3 = B_3.$$



$$G_2 = B_2 \oplus B_3.$$



$$G_1 = B_2 \oplus B_1.$$



$$G_0 = B_1 \oplus B_0.$$



Design an SOP circuit to detect the decimal numbers 0, 2, 4, 6 and 8 in a 4-bit 5211 BCD code input.

| Decimal number | 5211 Code A B C D | Output f |
|----------------|-------------------|----------|
| 0              | 0 0 0 0           | 1        |
| 1              | 0 0 0 1           | 0        |
| 2              | 0 0 1 1           | 1        |
| 3              | 0 1 0 1           | 0        |
| 4              | 0 1 1 1           | 1        |
| 5              | 1 0 0 0           | 0        |
| 6              | 1 0 0 1           | 1        |
| 7              | 1 0 1 1           | 0        |
| 8 x            | 1 1 1 0           | 1        |
| 9              | 1 1 1 1           | 0        |

$$f = \Sigma m(0, 3, 7, 10, 14) +$$

$$\bar{d}(2, 4, 6, 9, 11, 13)$$

K-map



$$f_{min} = \bar{A}\bar{D} + \bar{A}\bar{C} + \bar{C}\bar{D}$$

Logic diagram



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

| Inputs |   |   | Outputs        |                |                |                |                |
|--------|---|---|----------------|----------------|----------------|----------------|----------------|
| A      | B | C | X <sub>6</sub> | X <sub>5</sub> | X <sub>4</sub> | X <sub>3</sub> | X <sub>2</sub> |
| 0      | 0 | 0 | 0              | 0              | 0              | 0              | 0              |
| 0      | 0 | 1 | 0              | 0              | 0              | 0              | 1              |
| 0      | 1 | 0 | 0              | 0              | 1              | 0              | 0              |
| 0      | 1 | 1 | 0              | 0              | 0              | 0              | 1              |
| 1      | 0 | 0 | 0              | 1              | 0              | 0              | 0              |
| 1      | 0 | 1 | 0              | 1              | 0              | 0              | 1              |
| 1      | 1 | 0 | 1              | 0              | 0              | 1              | 0              |
| 1      | 1 | 1 | 1              | 0              | 0              | 0              | 1              |



K-map for X<sub>5</sub> = AC + BC



K-map for X<sub>4</sub> =  $\bar{A}\bar{B}C + A\bar{B}C$



K-map for  $x_3 = BC$



K-map for  $x_2 = 0$



K-map for  $x_1 = C$



\* Design a logic circuit with

4 inputs A, B, C, D that will

produce output '1' only whenever two adjacent input variables

are 1 (is A and D are also to be treated as adjacent implement

it using universal logic

| input |   |   |   |
|-------|---|---|---|
| A     | B | C | D |
| 0     | 0 | 0 | 0 |
| 0     | 0 | 0 | 1 |
| 0     | 0 | 1 | 0 |
| 0     | 0 | 1 | 1 |
| 0     | 1 | 0 | 0 |
| 0     | 1 | 0 | 1 |
| 0     | 1 | 1 | 0 |
| 0     | 1 | 1 | 1 |

| output |    |    |    |
|--------|----|----|----|
| f      | 00 | 01 | 11 |
| 0      | 0  | 0  | 1  |
| 0      | 0  | 0  | 0  |
| 0      | 0  | 1  | 1  |
| 1      | 1  | 1  | 1  |
| 0      | 0  | 1  | 0  |
| 0      | 0  | 0  | 1  |
| 1      | 1  | 0  | 0  |
| 1      | 1  | 1  | 1  |



$$F = AB + AD + BC + CD$$



$$f = (A+C)(B+D)$$



$$F_{\text{min}} = (A+C)(B+D)$$

logic circuits for digital systems may be combinational or sequential. In combinational circuits, the output variables at any instant of time are dependent only on the present input variables. In sequential circuits, the output variables at any instant of time are dependent on the present and past input variables.



### Adders :-

The most basic arithmetic operation is the addition of two binary digits. A combinational circuit that performs the addition of two bits is called a "half-adder". One that performs the addition of three bits (two bits and previous carry) is called a "full-adder".

### Half-adder

A half adder is a combinational circuit with two binary inputs. (augend and addend bits) and two outputs. sum and carry.

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



K-map for S.



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

K-map for C



$$C = A \cdot B$$

(a) Truth table.

$$= A \oplus B$$



NAND logic

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

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

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

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

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

$$= \overline{A \cdot \overline{AB}}, \overline{B \cdot \overline{AB}}$$

$$C = AB = \overline{\overline{AB}}$$



NOR logic

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

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

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

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

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

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

$$C = AB = \overline{\overline{AB}} = \overline{AB}$$

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



Simple logic diagram is.



## Full adder :-

A full adder is a combinational circuit that adds two bits and a carry and outputs are sum and carry. The full-adder adds the bits A and B and the carry from the previous column called the carry-in Cin.



K-map for S.

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

$$S = \overline{ABC} \text{in} + \overline{AB}\overline{C} \text{in} + A\overline{B}\overline{C} \text{in} + ABC \text{in}.$$

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

$$\text{Cout} = AB + BC \text{in} + AC \text{in}.$$

| inputs |   |     | outputs |      |
|--------|---|-----|---------|------|
| A      | B | Cin | S       | Cout |
| 0      | 0 | 0   | 0       | 0    |
| 0      | 0 | 1   | 1       | 0    |
| 0      | 1 | 0   | 1       | 0    |
| 0      | 1 | 1   | 0       | 1    |
| 1      | 0 | 0   | 1       | 0    |
| 1      | 0 | 1   | 0       | 1    |
| 1      | 1 | 0   | 0       | 1    |
| 1      | 1 | 1   | 1       | 1    |

Truth table



Full adder (By using two half adders and one OR gate).

$$S = \overline{ABC} \text{in} + \overline{AB}\overline{C} \text{in} + A\overline{B}\overline{C} \text{in} + ABC \text{in}$$

$$= \text{Cin} (AB + \overline{A}\overline{B}) + \overline{\text{Cin}} (\overline{AB} + A\overline{B})$$

$$= \overline{A} \oplus B \text{ Cin} + \overline{\text{Cin}} (A \oplus B)$$

$$= A \oplus B \oplus C \text{in}.$$

$$\begin{aligned}
 C_{out} &= \overline{ABC}_{in} + ABC_{in} + \overline{ABC}_{in} + ABC_{in} \\
 &= AB(C_{in} + \overline{C}_{in}) + \overline{ABC}_{in} + \overline{ABC}_{in} \\
 &= AB + C_{in}(\overline{AB} + A\overline{B}) \\
 &= AB + C_{in}(A \oplus B).
 \end{aligned}$$



### Subtractor:-

In subtraction, each subtrahend bit of the number is subtracted from its corresponding significant minuend bit to form a difference position.

### Half-subtractor:-

A half-subtractor is a combinational circuit that subtracts one bit from the other and produces the difference. It also has an output to specify if a 1 has been borrowed.



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

$$= A \oplus B$$

| inputs |   | outputs |   |
|--------|---|---------|---|
| A      | B | d       | b |
| 0      | 0 | 0       | 0 |
| 0      | 1 | 1       | 1 |
| 1      | 0 | 1       | 0 |
| 1      | 1 | 0       | 0 |

| K-map for d |   |   |   |
|-------------|---|---|---|
| A           | B | 0 | 1 |
| 0           | 0 | 0 | 1 |
| 1           | 0 | 1 | 0 |

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

| K-map for b |   |   |   |
|-------------|---|---|---|
| A           | B | 0 | 1 |
| 0           | 0 | 0 | 1 |
| 1           | 0 | 1 | 0 |

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



Logic diagrams of a half-subtractor.

### NAND logic :-

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

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

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

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

$$= \underline{\underline{A \cdot \bar{A}B \cdot B \cdot \bar{A}B}}$$

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

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

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

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



### NOR logic

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

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

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

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

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

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

$$= \underline{\underline{A(A+B)}}$$

$$= \underline{\underline{A + (A+B)}}$$



### Full - Subtractor :-

The half-subtractor can be used only for LSB subtraction. If there is a borrow during the subtraction of the LSBs, it affects the subtraction in the next higher column. the subtractend bit is subtracted from the minuend bit, considering the borrow from that column used for the subtraction in the preceding column.

In full subtractor the inputs are A, B, borrow in  $b_i$ , and outputs are difference bit (d) and borrow ( $b$ ).

| inputs |   |       |   |   |
|--------|---|-------|---|---|
| A      | B | $b_i$ | d | b |
| 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 |

K-map for difference

| $Bb_i$ | 00 | 01 | 11 | 10 |
|--------|----|----|----|----|
| A      | 0  | 0  | 1  | 1  |
| 1      | 1  | 0  | 1  | 0  |

$$\begin{aligned}
 d &= \bar{A}\bar{B}b_i + \bar{A}B\bar{b}_i + A\bar{B}\bar{b}_i + ABb_i \\
 &= b_i(AB + \bar{A}\bar{B}) + \bar{b}_i(\bar{A}B + A\bar{B}) \\
 &= b_i(\overline{A \oplus B}) + \bar{b}_i(A \oplus B) \\
 &= A \oplus B \oplus b_i
 \end{aligned}$$

K-map for borrow.

| $Bb_i$ | 00 | 01 | 11 | 10 |
|--------|----|----|----|----|
| A      | 0  | 0  | 1  | 1  |
| 1      | 1  | 0  | 1  | 0  |

$$\begin{aligned}
 b &= \bar{A}\bar{B}b_i + \bar{A}B\bar{b}_i + A\bar{B}b_i + AB\bar{b}_i \\
 &= \bar{A}B(b_i + \bar{b}_i) + (AB + \bar{A}\bar{B})b_i \\
 &= \bar{A}B + (\overline{A \oplus B})b_i
 \end{aligned}$$

full-subtractor by using  
two half-subtractors



NAND logic:-

$$d = A \oplus B \oplus b_i = \overline{(A \oplus B) \oplus b_i} = \overline{(A \oplus B)} \cdot \overline{(A \oplus B) b_i} \cdot b_i \cdot \overline{(A \oplus B) b_i}$$

$$\begin{aligned}
 b &= \overline{A}B + b_i \cdot \overline{(A \oplus B)} = \overline{A}B + b_i \cdot \overline{(A \oplus B)} \\
 &= \overline{\overline{A}B \cdot b_i \cdot \overline{(A \oplus B)}} = \overline{B(\overline{A} + \overline{B}) \cdot b_i \cdot \overline{(b_i + (A \oplus B))}} \\
 &= \overline{B \cdot \overline{A} \cdot \overline{B} \cdot b_i \cdot \overline{(b_i \cdot (A \oplus B))}}
 \end{aligned}$$



full subtractor by using only NOR Gate.

NOR logic.

$$d = \overline{A \oplus B \oplus b_i}$$

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

$$= [ \overline{(A \oplus B)} + \overline{(A \oplus B)} \overline{b_i} ] [ b_i + \overline{(A \oplus B)} \overline{b_i} ]$$

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

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

$$b = \overline{A} \overline{B} + b_i (\overline{A \oplus B})$$

$$= \overline{A} (A + B) + (\overline{A \oplus B}) [ A \oplus B + b_i ]$$

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



Full subtractor by using only NOR Gate

## Applications of full adders:-

### Binary parallel adder:-

A Binary parallel adder is a digital circuit that adds two binary numbers in parallel form and produces the arithmetic sum of those numbers in parallel form. It consists of full adders connected in a chain, with the output carry from each full-adder connected to the input carry of the next full-adder in the chain.



Logic diagram of 4-bit binary parallel adder.

The inter-connection of full-adder (FA) circuits to provide a 4-bit parallel adder. The augend bits of A and addend bits of B are designated by subscript numbers from right to left, with subscript 1 denoting the lower-order bit. The input carry to the adder is  $c_{in}$  and the output carry is  $c_4$ . The S outputs generate the required sum bits. When the 4-bit full adder circuit is enclosed within an IC package, it has four terminals for the augend bits, four terminals for the addend bits, four terminals for the sum bits, and two input terminals for the input and output carries.

The parallel adder in which the carry-out of each full adder is the carry-in to the next most significant adder is called a ripple carry adder. In the parallel adder, the carry-out of each stage is connected to the carry-in of the next stage. The sum and carry out bits of any stage cannot be produced, until some time after the carry-in of that stage occurs. This is due to the propagation delays in the logic circuitry, which lead to a time delay in the addition process.

#### 4-bit parallel subtractor:-

The subtraction of binary numbers can be carried out most conveniently by means of complements. The subtraction  $A - B$  can be done by taking the 2's complement of  $B$  and adding it to  $A$ . The 2's complement can be obtained by taking the 1's complement and adding 1 to the least significant pair of bits. The 1's complement can be implemented with not gate (inverters).



Logic diagram of 4-bit parallel subtractor.

## Binary adder - Subtractor :-

The addition and subtraction operations are combined into one circuit with one common binary adder. This is done by including an X-OR gate with each full adder. The M mode input controls the operation.

→ when  $M=0$ , the circuit is an adder.

→ when  $M=1$ , the circuit is an subtractor.

Each XOR gate receives input M and one of the inputs of B.

→ when  $M=0$ ,  $B \oplus 0 = B$ . The full adder receives the value of B, the input carry is '0' and the circuit performs  $A+B$ .

→ when  $M=1$ ,  $B \oplus 1 = \bar{B}$ . The full adder receives the value of  $\bar{B}$ , the input carry is '1' and the circuit performs  $A-\bar{B}$ .



Logic diagram of a 4-bit binary - adder - subtractor.

## LOOK-A-HEAD-CARRY ADDER :-

The parallel adder, the speed with which an addition can be performed is governed by the time required for the carries to propagate or ripple through all of the stages of the adder.

The look-ahead-carry adder speeds up the process by eliminating this ripple carry delay. It examines all the input bits simultaneously. The method of speeding up the process is based on the two additional functions of the full adder, called the carry generate and carry propagate functions.



### carry generate :-

consider one full adder stage,  $n^{th}$  stage of a parallel adder. carry is generated only if both the input bits are 1, that is, if both the bits A and B are 1, or whether the input carry  $c_{in}$  is a 0 or a 1. If  $G_i$  is a carry-generation function.

$$G_i = A \cdot B$$

The present bit as the  $n$ th bit, then  $G_1$  rewrite as a

$$G_n = A_n \cdot B_n.$$

carry propagation:

A carry is propagated if any one of the two input bits  $A$  &  $B$  are 1, a carry will never be propagated. On the other hand, if both  $A$  and  $B$  are 1, then it will not propagate the carry but will generate the carry.

If  $P$  is taken as a

$$P = A \oplus B.$$

The present bit as the  $n$ th bit, then  $P$  rewrite as a

$$P_n = A_n \oplus B_n.$$

For the final sum and carry outputs of the  $n$ th stage,

$$S_n = P_n \oplus C_n$$

$$( \because P_n = A_n \oplus B_n )$$

$$\begin{aligned} C_n &= C_{n+1} = G_n + P_n C_n \\ &= A_n \cdot B_n + P_n C_n \\ &= A_n \cdot B_n + (A_n \oplus B_n) C_n. \end{aligned}$$

Based on these, the expression for the carry-outs of various full-adders are

$$\begin{aligned} n=1, \quad C_1 &= G_0 + P_0 C_0 \\ &= G_0 + (A_0 \oplus B_0) C_0 \\ &= A_0 \cdot B_0 + (A_0 \oplus B_0) C_0. \end{aligned}$$

$n=2$

$$C_2 = G_{11} + P_1 \cdot C_1 = G_{11} + P_1 \cdot G_{10} + P_1 \cdot P_0 \cdot C_0$$

$n=3$

$$C_3 = G_{12} + P_2 \cdot C_2 = G_{12} + P_2 \cdot G_{11} + P_2 \cdot P_1 \cdot G_{10} + P_2 \cdot P_1 \cdot P_0 \cdot C_0$$

$n=4$

$$C_4 = G_{13} + P_3 \cdot C_3 = G_{13} + P_3 \cdot G_{12} + P_3 \cdot P_2 \cdot G_{11} + P_3 \cdot P_2 \cdot P_1 \cdot G_{10} + P_3 \cdot P_2 \cdot P_1 \cdot P_0 \cdot C_0$$

The general expression for  $n$ -stages.

$$C_n = G_{n-1} + P_{n-1} \cdot C_{n-1}$$

$$= G_{n-1} + P_{n-1} \cdot G_{n-2} + P_{n-1} \cdot P_{n-2} \cdot G_{n-3} + \dots + P_{n-1} \cdot P_0 \cdot C_0$$

$$G_0 \quad P_0 \quad C_0 \quad G_{11} \quad P_1 \quad G_{12} \quad P_2 \quad G_{13} \quad P_3$$



The block diagram of a 4-stage look-ahead carry parallel adder is shown in the below figure.



Basic logic diagram of a 4-bit look-ahead carry adder.

## BCD Adder :-



- In BCD adder, Add the 4-bit BCD code groups for each decimal digit position using binary binary addition.
- For those positions where the sum is 9 or less, the sum is in proper BCD form and no correction is needed.
- where the sum of two digits is greater than 9, a correction of 0110 should be added to that sum, to produce the proper BCD result.
- In above figure 4-bit parallel adder (using IC 74LS83). The two BCD groups  $A_3, A_2, A_1, A_0$  and  $B_3, B_2, B_1, B_0$  are applied to a 4-bit parallel adder.

The adder output will be  $C_4, S_3, S_2, S_1, S_0$ . where  $C_4$  is taken as a  $S_4$ .

→ when both the inputs are 1001. The sum output  $S_4, S_3, S_2, S_1, S_0$  can range from 00000 to 10010.

→ The circuitry for a BCD adder must include the logic needed to detect whenever the sum is greater than 01001.

| $S_4$ | $S_3$ | $S_2$ | $S_1$ | $S_0$ | Decimal number |
|-------|-------|-------|-------|-------|----------------|
| 0     | 1     | 0     | 1     | 0     | 10             |
| 0     | 1     | 0     | 1     | 1     | 11             |
| 0     | 1     | 1     | 0     | 0     | 12             |
| 0     | 1     | 1     | 0     | 1     | 13             |
| 0     | 1     | 1     | 1     | 0     | 14             |
| 0     | 1     | 1     | 1     | 1     | 15             |
| 1     | 0     | 0     | 0     | 0     | 16             |
| 1     | 0     | 0     | 0     | 1     | 17             |
| 1     | 0     | 0     | 1     | 0     | 18             |

→ In above Table shows the cases for greater than 1001.

The sum will be high → whenever  $S_4 = 1$ ,

→ whenever  $S_3 = 1$  and either  $S_2$  &  $S_1$  or both are 1.

$$\text{Then } X = S_4 + S_3(S_2 + S_1)$$

whenever  $X = 1$ , it is necessary to add the 0110 to the sum bits.

The circuit consists of three basic parts. The BCD code groups  $A_3, A_2, A, A_0$  and  $B_3, B_2, B, B_0$  are added together in upper 4-bit parallel adder to produce the sum  $s_4 s_3 s_2 s_1 s_0$ . The logic gates shown implement the expression for  $x$ . The lower 4-bit adder will add the carry correction 0110 to the sum bits only when  $x=1$ , producing final BCD sum output represented by  $E_3 E_2 E_1 E_0$ .

when  $x=0$ , there is no carry and no correction.

In such cases  $E_3 E_2 E_1 E_0 = s_3 s_2 s_1 s_0$ . Two or more BCD adders can be connected in cascade when two or more digit decimal numbers are to be added. The carry-out of the first BCD adder is connected as the carry-in of the second BCD adder.

### Excess-3 Adder :-

→ In excess-3 addition.

1. Add two xs-3 code groups.

2. If carry = 1 add 0011

If carry = 0 subtract 0011, & add 1101 (13 in decimal).

In figure The augend ( $A_3, A_2, A, A_0$ ) and addend ( $B_3, B_2, B, B_0$ ) in xs-3 added using the 4-bit parallel adder. If the carry is a 1, then 0011 is added to the sum bits  $s_3 s_2 s_1 s_0$  of the upper adder in the lower 4-bit parallel adder. If the carry is a '0' then 1101 is added to the sum bits.



The final Answer in XS-3 form.

### Multiplexers (data selector).

multiplexing means sharing. A multiplexer or data selector is a logic circuit that accepts several data inputs and allows only one of them at a time to get through to the output. The routing of the desired data inputs to the output is controlled by SELECT inputs. Normally there are  $2^n$  input lines and  $n$  select lines and one output.

## Basic 2-input multiplexer :-

In 2-input multiplexer have 2 inputs they are  $D_0$  and  $D_1$ . and one select line  $S$ , and output is  $Z$ .



Block diagram.

| S | Z     |
|---|-------|
| 0 | $D_0$ |
| 1 | $D_1$ |

Truth table.



$$Z = \overline{S}D_0 + SD_1$$

logic diagram

The logic levels applied to the  $S$  inputs determines which AND gate is enabled. So that its data input passes through the OR gate to the output.

when  $S = 0$ , AND gate 1 is enabled and AND gate 2 is disabled,  $S_0, Z = D_0$

$S = 1$ , AND gate 2 is enabled and AND gate 1 is disabled,  $S_0, Z = D_1$ .

## Basic 4-input multiplexer :-

Block diagram



Truth table

| $S_1$ | $S_0$ | Z     |
|-------|-------|-------|
| 0     | 0     | $D_0$ |
| 0     | 1     | $D_1$ |
| 1     | 0     | $D_2$ |
| 1     | 1     | $D_3$ |



$$Z = \overline{S_0}\overline{S_1}D_0 + \overline{S_0}S_1D_1 + S_0\overline{S_1}D_2 + S_0S_1D_3$$

The 16-input multiplexor from Two 8-input multiplexors:-

To use two 8-inputs multiplexors to get a 16-inputs multiplexor, one OR gate and one inverter are also required. The four select inputs  $S_3, S_2, S_1$ , and  $S_0$  and will select one of the 16 inputs to pass through to  $X$ . The  $S_3$  input determines which multiplexer is enabled. When  $S_3 = 0$ , the left multiplexer is enabled and  $S_2, S_1$ , and  $S_0$  inputs determine which of its data inputs will appear at its output and pass through the OR gate to  $X$ . When  $S_3 = 1$ , the right multiplexer is enabled and  $S_2, S_1$ , and  $S_0$  inputs select one of its data inputs for passage to output  $X$ .



Logic diagram for cascading of two 8x1 mux to get 16x1

Design of a  $32 \times 1$  mux using two  $16 \times 1$  muxes and one  $2 \times 1$  mux:

To obtain a  $32 \times 1$  mux using two  $16 \times 1$  muxes and one  $2 \times 1$  mux. A  $32 \times 1$  mux has 32 data inputs so it requires five data select lines. Since a  $16 \times 1$  mux has only four data select lines, the inputs B,C,D,E are connected to the data select lines of the both  $16 \times 1$  muxes and the most significant input A is connected to the single data select line of the  $2 \times 1$  mux. For the values of  $BCDE = 0000$  to 1111, inputs 0 to 15 will appear at the input terminals of the  $2:1$  mux through the output  $F_1$  of the first  $16 \times 1$  mux and inputs 16 to 31 will appear at the input terminal of the  $2:1$  mux through the output  $F_2$  of the second  $16 \times 1$  mux. For  $A=0$ , output  $F=F_1$ , for  $A=1$ , output  $F=F_2$ .



## DEMULTIPLEXERS

A demultiplexer performs the reverse operation; it takes a single input and distributes it over several outputs. so a demultiplexer is also called as a "data distributor". since it transmits the same data to different destinations. A demultiplexer is a 1-to-N device.

### 1-line to 2-line demultiplexer

The input data line goes to all of the AND gates. The select line enables only one gate at a time, and the data appearing on the input line will pass through the selected gate to the associated output lines.



Block diagram

| S | O <sub>0</sub> | O <sub>1</sub> |
|---|----------------|----------------|
| 0 | 0              | D              |
| 1 | D              | 0              |

Truth table



$$O_0 = DS$$

$$O_1 = DS$$

logic diagram

### 1-line to 4-line demultiplexer

| S <sub>1</sub> | S <sub>0</sub> | O <sub>3</sub> | O <sub>2</sub> | O <sub>1</sub> | O <sub>0</sub> |
|----------------|----------------|----------------|----------------|----------------|----------------|
| 0              | 0              | 0              | 0              | 0              | D              |
| 0              | 1              | 0              | 0              | D              | 0              |
| 1              | 0              | 0              | D              | 0              | 0              |
| 1              | 1              | D              | 0              | 0              | 0              |

Truth table



logic diagram

I-line to 8-line demultiplexer:-

| $S_2$ | $S_1$ | $S_0$ | $O_7$ | $O_6$ | $O_5$ | $O_4$ | $O_3$ | $O_2$ | $O_1$ | $O_0$ |
|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | D     |
| 0     | 0     | 1     | 0     | 0     | 0     | 0     | 0     | 0     | D     | 0     |
| 0     | 1     | 0     | 0     | 0     | 0     | 0     | 0     | D     | 0     | 0     |
| 0     | 1     | 1     | 0     | 0     | 0     | 0     | D     | 0     | 0     | 0     |
| 1     | 0     | 0     | 0     | 0     | D     | 0     | 0     | 0     | 0     | 0     |
| 1     | 0     | 1     | 0     | 0     | D     | 0     | 0     | 0     | 0     | 0     |
| 1     | 1     | 0     | 0     | D     | 0     | 0     | 0     | 0     | 0     | 0     |
| 1     | 1     | 1     | D     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

Truth table.



design of 1:32 demux using two 1:16 demux.



To obtain 1:32 demux using two 1:16 demux. A 1:32 demux has 32 data outputs. so it requires five data select lines. Since 1:16 demux has only four select inputs. the inputs B,C,D,E are connected to the data select lines of both the 1:16 demuxes and the most significant input A is connected to the single data select line of the both 1:16 demux's EN input. 1 to 16 will appear in the first demux when (A=0). 17 to 32 will appear in the second demux when A=1.

Encoders :-

An encoder is a device whose inputs are decimal digits and/or alphabetic characters and whose outputs are the coded representation of those inputs. An encoder is a device which converts familiar numbers or symbols into coded format. The encoder has  $2^n$  inputs and  $n$  outputs.

4 bit - Encoder :-

Block diagram.

| inputs | outputs<br>$A_1, A_0$ |
|--------|-----------------------|
| $D_0$  | 0 0                   |
| $D_1$  | 0 1                   |
| $D_2$  | 1 0                   |
| $D_3$  | 1 1                   |

Truth table.

$$A_1 = D_2 + D_3$$

$$A_0 = D_1 + D_3$$



## Decimal to BCD Encoder :-

In this type of encoder has 10 inputs - one for each decimal digit, and 4 outputs corresponding to the BCD code.



Block diagram

| decimal        | Binary output  |                |                |                |
|----------------|----------------|----------------|----------------|----------------|
|                | A <sub>3</sub> | A <sub>2</sub> | A <sub>1</sub> | A <sub>0</sub> |
| D <sub>0</sub> | 0              | 0              | 0              | 000            |
| D <sub>1</sub> | 1              | 0              | 0              | 001            |
| D <sub>2</sub> | 2              | 0              | 0              | 100            |
| D <sub>3</sub> | 3              | 0              | 0              | 111            |
| D <sub>4</sub> | 4              | 0              | 1              | 000            |
| D <sub>5</sub> | 5              | 0              | 1              | 011            |
| D <sub>6</sub> | 6              | 0              | 1              | 110            |
| D <sub>7</sub> | 7              | 0              | 1              | 111            |
| D <sub>8</sub> | 8              | 1              | 0              | 000            |
| D <sub>9</sub> | 9              | 1              | 0              | 001            |

Truth table.



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

$$A_1 = D_2 + D_3 + D_5 + D_7$$

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

$$A_3 = D_8 + D_9.$$

## Decoders :-

A decoder is a logic circuit that converts an  $n$ -bit binary input code into  $2^n$  output lines such that only one output line is activated for each one of the possible combinations of inputs. For each of these input combinations, only one of the output will be activated (High), all the other outputs will remain inactive (Low). Some decoders are designed to produce active low output, while all the other outputs remain high.

## 2-4 line decoder :-



| A <sub>1</sub> , A <sub>0</sub> | 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              |

Block diagram.

Truth table.



4-to-16 decoder from two 3-to-8 decoders:-

Decoders with enable inputs can be connected together to form a larger decoder. To obtain a 4-to-16 decoder it requires two 3-to-8 decoders. The most significant input bit  $A_3$  is connected through an inverter to  $\bar{E}$  on the upper decoder and directly to  $E$  on the lower decoder. Thus  $A_3$  is low, the upper decoder is enabled and the lower decoder is disabled. The bottom decoder outputs all 0's, and top 8 outputs. The bottom decoder generates minterms. When  $A_3$  is high, the lower decoder is enabled and the upper decoder is disabled. The bottom decoder generates minterms 1000 to 1111 while the outputs of the top decoder are all 0's.



logic diagram

## Seven Segment Decoders :-

This type of decoders accepts the BCD code and provides outputs to energize seven segment display devices in order to produce a decimal read out. Each segment is made up of a material that emits light when current is passed through it. The most commonly used materials include LEDs, incandescent filaments and LCDs.



| Decimal digit | BCD input      |                |                |                | Seven segment code |   |   |   |   |   |                |
|---------------|----------------|----------------|----------------|----------------|--------------------|---|---|---|---|---|----------------|
|               | A <sub>3</sub> | A <sub>2</sub> | A <sub>1</sub> | A <sub>0</sub> | a                  | b | c | d | e | f | G <sub>1</sub> |
| 0             | 0              | 0              | 0              | 0              | 1                  | 1 | 1 | 1 | 1 | 1 | 0              |
| 1             | 0              | 0              | 0              | 1              | 0                  | 1 | 1 | 0 | 0 | 0 | 0              |
| 2             | 0              | 0              | 1              | 0              | 1                  | 1 | 0 | 1 | 0 | 0 | 1              |
| 3             | 0              | 0              | 1              | 1              | 1                  | 1 | F | 1 | 0 | 0 | 1              |
| 4             | 0              | 1              | 0              | 0              | 0                  | 1 | 1 | 0 | 1 | 1 | 1              |
| 5             | 0              | 1              | 0              | 1              | 1                  | 0 | 1 | 1 | 0 | 1 | 1              |
| 6             | 0              | 1              | 1              | 0              | 1                  | 0 | 1 | 1 | 1 | 1 | 1              |
| 7             | 0              | 1              | 1              | 1              | 1                  | 1 | 1 | 1 | 0 | 0 | 0              |
| 8             | 1              | 0              | 0              | 0              | 1                  | 1 | 1 | 1 | 1 | 1 | 1              |
| 9             | 1              | 0              | 0              | 1              | 1                  | 1 | 1 | 1 | 0 | 1 | 1              |

$$a = \text{em}(0, 2, 3, 5, 6, 7, 8, 9) + d(10, 11, 12, 13, 14, 15).$$

$$b = \text{em}(0, 1, 2, 3, 4, 7, 8, 9) + d(10, 11, 12, 13, 14, 15).$$

$$c = \text{em}(0, 1, 3, 4, 5, 6, 7, 8, 9) + d(10, 11, 12, 13, 14, 15).$$

$$d = \text{em}(0, 2, 3, 5, 6, 8, 9) + d(10, 11, 12, 13, 14, 15).$$

$$e = \text{em}(0, 2, 6, 8) + d(10, 11, 12, 13, 14, 15).$$

$$f = \text{em}(0, 4, 5, 6, 8, 9) + d(10, 11, 12, 13, 14, 15).$$

$$g = \text{em}(2, 3, 4, 5, 6, 8, 9) + d(10, 11, 12, 13, 14, 15).$$

K-map for a.



K-map for b.



$$a = A_1 + A_3 + \bar{A}_2\bar{A}_0 + \bar{A}_3A_2A_0$$

$$b = \bar{A}_2 + A_1\bar{A}_0 + A_1A_0$$



K-map for c.

K-map for d.

K-map for e.

$$c = A_2 + A_3 + \bar{A}_3\bar{A}_1 + \bar{A}_3A_1A_0$$

$$d = A_3 + \bar{A}_2A_1 + A_2\bar{A}_1A_0 + A_2A_1\bar{A}_0 + \bar{A}_2\bar{A}_0$$

$$e = A_1\bar{A}_0 + \bar{A}_2\bar{A}_0$$



K-map for f.

$$f = \overline{A_1}\overline{A_0} + A_3 + \overline{A_3}A_2\overline{A_1} + A_2A_1\overline{A_0}$$

$$G_1 = A_3 + A_1\overline{A_0} + A_2\overline{A_1} + \overline{A_2}A_1$$

K-map for G<sub>1</sub>.



diagrams for seven segment display.

## Comparator :-

The comparator is a combinational logic circuit. It compares the magnitude of two n-bit numbers and provides the relative result as the output. The block diagram of an n-bit digital comparator has 2 inputs and three outputs. A and B are the n-bit inputs. The comparator outputs are  $A > B$ ,  $A = B$  and  $A < B$ . Depending upon the result of comparison, one of these outputs will be high.



## 1-bit comparator :-

The one bit comparator is a combinational logic circuit with two inputs A and B and three outputs namely  $A < B$ ,  $A = B$ ,  $A > B$ .



Block diagram.

| Inputs |       | outputs |         |         |
|--------|-------|---------|---------|---------|
| $A_0$  | $B_0$ | $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       |

Truth table

In truth table

$$A=B : \overline{A_0}B_0 + A_0\overline{B_0} = A_0 \oplus B_0$$

$$A < B : \overline{A_0}B_0$$

$$A > B : A_0\overline{B_0}$$



### 2-bit comparator :-

The logic for a 2-bit comparator. Let the two 2-bit numbers be  $A = A_1, A_0$  and  $B = B_1, B_0$ .

→ if  $A_1 = 1$  and  $B_1 = 0$ , then  $A > B$

→ if  $A_1$  and  $B_1$  are equal and  $A_0 = 1$  and  $B_0 = 0$  then  
 $A > B$ .

$$A > B : A_1\overline{B_1} + (A_1 \oplus B_1) A_0\overline{B_0}$$

→ if  $B_1 = 1$  and  $A_1 = 0$  then  $A < B$

→ if  $B_1$  and  $A_1$  are equal and  $B_0 = 1$  and  $A_0 = 0$  then  
 $A < B$

$$A < B : \overline{A_1}B_1 + (A_1 \oplus B_1)\overline{A_0}B_0$$

→ if  $A_1$  and  $B_1$  are equal and if  $A_0$  and  $B_0$  are equal then  
 $A = B$

$$A = B : (A_1 \oplus B_1) (A_0 \oplus B_0)$$



#### 4-bit comparator :-

The logic for a 4-bit comparator. Let the four bit numbers will be  $A = A_3 A_2 A_1 A_0$  and  $B = B_3 B_2 B_1 B_0$ .

- if  $A_3 = 1$  and  $B_3 = 0$ , then  $A > B$  or
- if  $A_3$  and  $B_3$  are equal, and if  $A_2 = 1$  and  $B_2 = 0$ , or
- if  $A_3$  and  $B_3$  are equal,  $A_2$  and  $B_2$  are equal, and if  $A_1 \oplus B_1 = 1$  and  $B_1 = 0$ , or
- if  $A_3$  and  $B_3$  are equal, and if  $A_2$  and  $B_2$  are equal, and if  $A_1$  and  $B_1$  are equal, and if  $A_0 = 1$  and  $B_0 = 0$ .

$$(A > B) = A_3 \bar{B}_3 + (A_3 \oplus B_3) A_3 \bar{B}_2 + (A_3 \oplus B_3) (A_2 \oplus B_2) A_3 \bar{B}_1 \\ + (A_3 \oplus B_3) (A_2 \oplus B_2) (A_1 \oplus B_1) A_3 \bar{B}_0$$

$$(A < B) = \bar{A}_3 B_3 + (A_3 \oplus B_3) \bar{A}_3 B_2 + (A_3 \oplus B_3) (A_2 \oplus B_2) \bar{A}_3 B_1 \\ + (A_3 \oplus B_3) (A_2 \oplus B_2) (A_1 \oplus B_1) \bar{A}_3 B_0$$

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



logic diagram for 4-bit comparator.

## Priority Encoders :-

It is possible that two or more inputs are active at a time. To overcome this, priority encoders are used. A priority encoder is a logic circuit that responds to just one input in accordance with some priority system, among all those that may be simultaneously high. The most common priority system is based on the relative magnitudes of the inputs.

In some practical applications, priority encoders may have several inputs that are simultaneously high at the same time, and the principal function of the encoder in those cases is to select the input with the highest priority.

## 4-input priority Encoder :-

In 4-input priority encoder in addition to the outputs A and B, 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 two outputs are not inspected when V equals 0 and are specified as don't care conditions.

Truth table

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

| $D_0$ | $D_1$ | $D_2$ | $D_3$ | A | B | 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 |

According to the truth table. the outputs A and B are.

$$A = \text{em}(1, 2, 3, 5, 6, 7, 9, 10, 11, 13, 14, 15)$$

$$B = \text{em}(1, 3, 4, 5, 7, 9, 11, 12, 13, 15)$$

K-map for A



$$A = D_3 + D_2$$

K-map for B



$$B = D_3 + \overline{D}_2 D_1$$



logic diagram for  
4-bit priority encoder.

## PROGRAMMABLE LOGIC DEVICES

- logic designers have a wide range of standard IC's available to them with numerous logic functions and logic circuit arrangements on a chip. In addition, these ICs are available from many manufacturers and at a reasonable low cost.
- PLD is an IC that contains large number of gates, flip-flops and registers that are interconnected on chip. This IC is said to be programmable because the specific function IC is determined by interconnecting required contacts.

Basically, there are three types of programmable device which are.

- Read only memory (ROM)
- programmable logic array (PLA)
- programmable Array logic (PAL)

### READ ONLY memory :-

- The read only memory is a type of semiconductor memory that is designed to hold data that is either permanent or will not change frequently.
- During operation, no new data can be written into a ROM, but data can be read from ROM. the process of entering data is called programming or burning-in the ROM.

→ Some ROM's cannot have their data changes once they have been programmed. others can be erased and reprogrammed as often as desired.

### Types of Rom's :-

1. Masked memory ROM
2. programmable read only memory (PROM)
3. Erasable programmable read only memory (EPROM)
4. Electrically Erasable programmable read only memory (EEPROM)

### Masked memory (Rom) :-

- cannot be reprogrammed
- Nonvolatile, retain data even when power is turn off.
- cheaper than programmable devices.
- useful for fixed programme instructions.

### PROM

- programmed by blowing built-in fuses.
- can not be reprogrammed.
- Non volatile.
- useful for small volume data storing
- user programmable

### EPROM :-

- Erasable, programmable ROM
- programmed by storing charge on insulated gates.
- Erasable with ultraviolet light
- non-volatile.

### EEPROM :-

- programmed by storing charges on insulated gates
- non volatile

### Programmable ROM :-

- It includes both the decoder and the OR Gates with a single IC package. The following figures shows the block diagram and logic construction using 16x2 ROM.
- It consists of n input lines and m output lines.
- Each bit combination of the input variables is called an address.
- Each bit combination that comes out of the output lines is called a word.



Block diagram.

An integrated circuit with programmable gates divided into an AND array and an OR array provide an AND-OR sum of products implementation.

## EPROM :-

- Erasable, programmable ROM
- programmed by storing charge on insulated gates.
- Erasable with ultraviolet light
- non-volatile.

## EEPROM :-

- programmed by storing charges on insulated gates
- non volatile

## Programmable ROM :-

- It includes both the decoder and the OR Gates with a single IC package. The following figures shows the block diagram and logic construction using 16x2 ROM.
- It consists of n input lines and m output lines.
- Each bit combination of the input variables is called an address.
- Each bit combination that comes out of the output lines is called a word.



Block diagram.

An integrated circuit with programmable gates divided into an AND array and an OR array to provide an AND-OR sum of products implementation.

The programmable read-only memory (PROM) has a fixed AND array constructed as a decoder and a programmable OR array. The AND gates are programmed to provide the product terms for the Boolean functions, which are logically summed in each OR gate.



→ Implement full-adder using PROM.

The number of inputs variables of a full adder are 3. The possible number of combinations are 8. So we need  $3 \times 8$  decoder. The number of outputs of full adder are 8. They are sum and carry.

(3)

Truth table

| A | B | Cin | S | C |
|---|---|-----|---|---|
| 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 |

output expression for sum & carry  
 sum =  $\sum m(1,2,4,7)$   
 carry =  $\sum m(3,5,6,7)$ .

logic diagram

→ Design BCD to Excess-3 code converter  
 using PROM.

Step:- 1 - Truth table.

| BCD   |       |       |       | EXCESS-3 |       |       |       |
|-------|-------|-------|-------|----------|-------|-------|-------|
| $B_3$ | $B_2$ | $B_1$ | $B_0$ | $E_3$    | $E_2$ | $E_1$ | $E_0$ |
| 0     | 0     | 0     | 0     | 0        | 0     | 1     | 1     |
| 0     | 0     | 0     | 1     | 0        | 1     | 0     | 0     |
| 0     | 0     | 1     | 0     | 0        | 1     | 0     | 1     |
| 0     | 0     | 1     | 1     | 0        | 1     | 1     | 0     |
| 0     | 1     | 0     | 0     | 0        | 1     | 1     | 1     |
| 0     | 1     | 0     | 1     | 1        | 0     | 0     | 0     |
| 0     | 1     | 1     | 0     | 1        | 0     | 0     | 1     |
| 0     | 1     | 1     | 1     | 1        | 0     | 1     | 0     |
| 1     | 0     | 0     | 0     | 0        | 0     | 1     | 1     |

Step 2 :-

$$E_0(B_3, B_2, B_1, B_0) = \Sigma m(0, 2, 4, 6, 8)$$

$$E_1(B_3, B_2, B_1, B_0) = \Sigma m(0, 3, 4, 7, 8)$$

$$E_2(B_3, B_2, B_1, B_0) = \Sigma m(1, 2, 3, 4, 9)$$

$$E_3(B_3, B_2, B_1, B_0) = \Sigma m(5, 6, 7, 8, 9)$$

Step 3 :- logic diagram.



→ Implement the following Boolean expression using PROM.

$$f(A, B, C) = \overline{A}B + C + BC$$

first given expression converted into a standard SOP form

$$f(A, B, C) = \overline{A}B + C + BC$$

$$\begin{aligned}
 &= \overline{AB}(C+\overline{C}) + C(A+\overline{A})(B+\overline{B}) + BC(A+\overline{A}) \\
 &= \overline{ABC} + \overline{ABC} + \underline{\overline{ABC}} + \overline{ABC} + \overline{ABC} + \overline{ABC} + \overline{ABC} \\
 &= \overline{ABC} + \overline{ABC} + ABC + \overline{ABC} + \overline{ABC} + \overline{ABC} \\
 &\quad 0\_{11}, 0\_{10}, 1\_{11}, 101, 011, 001
 \end{aligned}$$

$$f(A, B, C) = \sum m(1, 2, 3, 5, 7)$$

Logic diagram :-



PAL:- programmable Array logic:-

The programmable Array logic is a programmable device with a fixed OR array and a programmable AND array because, only the AND gates are programmable.



→ Implement the following functions using PAL.

$$F_1(a,b,c,d) = \sum m(0,1,2,3,6,9,11)$$

$$F_2(a,b,c,d) = \sum m(0,1,6,8,9)$$

Step 1 :- K-map simplification for  $F_1$  and  $F_2$

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

$$\bar{a}\bar{b} + \bar{a}cd + \bar{b}d$$

| ab | cd      | 00      | 01      | 11      | 10      |
|----|---------|---------|---------|---------|---------|
| 00 | 1 1 1 1 | 1 1 1 1 | 1 1 1 1 | 1 1 1 1 | 1 1 1 1 |
| 01 | 1 1 1 1 | 1 1 1 1 | 1 1 1 1 | 1 1 1 1 | 1 1 1 1 |
| 11 | 1 1 1 1 | 1 1 1 1 | 1 1 1 1 | 1 1 1 1 | 1 1 1 1 |
| 10 | 1 1 1 1 | 1 1 1 1 | 1 1 1 1 | 1 1 1 1 | 1 1 1 1 |

$$\bar{b}\bar{c} + \bar{a}bc\bar{d}$$

Step 2 :- PAL programming table.

| product terms | AND gate inputs<br>a b c d | outputs                                       |
|---------------|----------------------------|-----------------------------------------------|
| 1             | 0 0 - -                    |                                               |
| 2             | 0 - 1 1                    | $F_1 = \bar{a}\bar{b} + \bar{b}cd + \bar{b}d$ |
| 3             | - 0 - 1                    |                                               |
| 4             | - 0 0 -                    |                                               |
| 5             | 0 1 1 0                    | $F_2 = \bar{b}\bar{c} + \bar{a}bc\bar{d}$     |
| 6             | - - - -                    |                                               |

(5)

Step 3 :- implementation :-



→ Implement 4-bit BCD to XS-3 code conversion  
using PAL.

Step:-1

| B <sub>4</sub> | B <sub>3</sub> | B <sub>2</sub> | B <sub>1</sub> | X <sub>4</sub> | X <sub>3</sub> | X <sub>2</sub> | X <sub>1</sub> |
|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|
| 0              | 0              | 0              | 0              | 0              | 0              | 1              | 1              |
| 0              | 0              | 0              | 1              | 0              | 1              | 0              | 0              |
| 0              | 0              | 1              | 0              | 0              | 1              | 0              | 1              |
| 0              | 0              | 1              | 1              | 0              | 1              | 1              | 0              |
| 0              | 1              | 0              | 0              | 0              | 1              | 1              | 1              |
| 0              | 1              | 0              | 1              | 1              | 0              | 0              | 0              |
| 0              | 1              | 1              | 0              | 1              | 0              | 0              | 1              |
| 0              | 1              | 1              | 1              | 1              | 0              | 1              | 0              |
| 1              | 0              | 0              | 0              | 1              | 0              | 1              | 1              |
| 1              | 0              | 0              | 1              | 1              | 1              | 0              | 0              |

$$X_4 = \text{Em}(5, 6, 7, 8, 9) + d(10, 11, 12, 13, 14, 15)$$

$$X_3 = \text{Em}(1, 2, 3, 4, 9) + d(10, 11, 12, 13, 14, 15)$$

$$X_2 = \text{Em}(0, 3, 4, 7, 8) + d(10, 11, 12, 13, 14, 15)$$

$$X_1 = \text{Em}(0, 2, 4, 6, 8) + d(10, 11, 12, 13, 14, 15)$$

| $B_4\ B_3\ B_2\ B_1$ | 00       | 01       | 11       | 10       |
|----------------------|----------|----------|----------|----------|
| 00                   | 0        | 1        | 3        | 2        |
| 01                   | 4        | 1        | 7        | 6        |
| 11                   | $X_{12}$ | $X_{13}$ | $X_{14}$ | $X_{15}$ |
| 10                   | 18       | 19       | $X_{11}$ | $X_{10}$ |

| $B_4\ B_3\ B_2\ B_1$ | 00       | 01       | 11       | 10       |
|----------------------|----------|----------|----------|----------|
| 00                   | 0        | 1        | 3        | 2        |
| 01                   | 4        | 5        | 7        | 6        |
| 11                   | $X_{12}$ | $X_{13}$ | $X_{14}$ | $X_{15}$ |
| 10                   | 8        | 9        | $X_{11}$ | $X_{10}$ |

| $B_4\ B_3\ B_2\ B_1$ | 00       | 01       | 11       | 10       |
|----------------------|----------|----------|----------|----------|
| 00                   | 1        | 0        | 3        | 2        |
| 01                   | 1        | 5        | 7        | 6        |
| 11                   | $X_{12}$ | $X_{14}$ | $X_{15}$ | $X_{14}$ |
| 10                   | 18       | 9        | $X_{11}$ | $X_{10}$ |

| $B_4\ B_3\ B_2\ B_1$ | 00       | 01       | 11       | 10       |
|----------------------|----------|----------|----------|----------|
| 00                   | 10       | 1        | 3        | 2        |
| 01                   | 12       | 5        | 7        | 6        |
| 11                   | $X_{12}$ | $X_{14}$ | $X_{15}$ | $X_{14}$ |
| 10                   | 18       | 9        | $X_{11}$ | $X_{10}$ |

$$X_4 = B_4 + B_3 B_2 + B_3 B_1$$

$$X_3 = B_3 \overline{B_2} \overline{B_1} + \overline{B_3} B_1 + \overline{B_3} B_2$$

$$X_2 = \overline{B_2} \overline{B_1} + B_2 B_1$$

$$X_1 = \overline{B_1}$$

(6)  
Step 2 :- programming table.

| product terms. | AND Gate inputs.<br>$B_4 \quad B_3 \quad B_2 \quad B_1$ |   |   |   | outputs.                                                                            |
|----------------|---------------------------------------------------------|---|---|---|-------------------------------------------------------------------------------------|
| 1              | 1                                                       | - | - | - |                                                                                     |
| 2              | -                                                       | 1 | 1 | - | $X_4 = B_4 + B_3 B_2 + B_3 B_1$                                                     |
| 3              | -                                                       | 1 | - | 1 |                                                                                     |
| 4              | -                                                       | 1 | 0 | 0 |                                                                                     |
| 5              | -                                                       | 0 | - | 1 | $X_3 = B_3 \overline{B}_2 \overline{B}_1 + \overline{B}_3 B_1 + \overline{B}_3 B_2$ |
| 6              | -                                                       | 0 | 1 | - |                                                                                     |
| 7              | -                                                       | - | 0 | 0 |                                                                                     |
| 8              | -                                                       | - | 1 | 1 | $X_2 = \overline{B}_2 \overline{B}_1 + B_2 B_1$                                     |
| 9              | -                                                       | - | - | - |                                                                                     |
| 10             | -                                                       | - | - | 0 |                                                                                     |
| 11             | -                                                       | - | - | - | $X_1 = \overline{B}_1$                                                              |
| 12             | -                                                       | - | - | - |                                                                                     |

Step 3 :- logic diagram.



logic diagram.

Implement the following boolean functions using PAL with four inputs and 3-wide AND-OR structure. Also write the PAL programming table.

$$F_1(A, B, C, D) = \Sigma m(2, 12, 13)$$

$$F_2(A, B, C, D) = \Sigma m(7, 8, 9, 10, 11, 12, 13, 14, 15)$$

$$F_3(A, B, C, D) = \Sigma m(0, 2, 3, 4, 5, 6, 7, 8, 10, 11, 15)$$

$$F_4(A, B, C, D) = \Sigma m(1, 2, 8, 12, 13)$$

| AB | CD | 00   | 01   | 11   | 10   |
|----|----|------|------|------|------|
| 00 |    | 0    | 1    | 3    | 2    |
| 01 |    | 4    | 5    | 7    | 6    |
| 11 |    | 1, 2 | 1, 3 | 1, 4 | 1, 5 |
| 10 |    | 8    | 9    | 12   | 10   |

| AB | CD | 00   | 01   | 11   | 10   |
|----|----|------|------|------|------|
| 00 |    | 0    | 1    | 3    | 2    |
| 01 |    | 4    | 5    | 7    | 6    |
| 11 |    | 1, 2 | 1, 3 | 1, 4 | 1, 5 |
| 10 |    | 8    | 9    | 12   | 10   |

| AB | CD | 00   | 01   | 11   | 10   |
|----|----|------|------|------|------|
| 00 |    | 0    | 1    | 3    | 2    |
| 01 |    | 4    | 5    | 7    | 6    |
| 11 |    | 1, 2 | 1, 3 | 1, 4 | 1, 5 |
| 10 |    | 8    | 9    | 12   | 10   |

| AB | CD | 00   | 01   | 11   | 10   |
|----|----|------|------|------|------|
| 00 |    | 0    | 1    | 3    | 2    |
| 01 |    | 4    | 5    | 7    | 6    |
| 11 |    | 1, 2 | 1, 3 | 1, 4 | 1, 5 |
| 10 |    | 8    | 9    | 12   | 10   |

$$F_1 = AB\bar{C} + \bar{A}\bar{B}CD$$

$$F_2 = A + BCD$$

$$F_3 = \bar{A}B + CD + \bar{B}\bar{D}$$

$$\begin{aligned} F_4 &= \underbrace{ABC}_{1} + \underbrace{\bar{A}\bar{C}\bar{D}}_{2} + \underbrace{\bar{A}\bar{B}\bar{C}D}_{3} + \underbrace{\bar{A}\bar{B}\bar{C}\bar{D}}_{4} \\ &= F_1 + \bar{A}\bar{C}\bar{D} + \bar{A}\bar{B}\bar{C}D \end{aligned}$$

Step 2 :- programming table

| product term | AND inputs<br>A B C D | outputs<br>F <sub>1</sub>                                    |
|--------------|-----------------------|--------------------------------------------------------------|
| 1            | 1 1 0 -               | $F_1 = AB\bar{C} + \bar{A}\bar{B}CD$                         |
| 2            | 0 0 1 0 -             |                                                              |
| 3            | - - - - -             |                                                              |
| 4            | 1 - - - -             | $F_2 = A + BCD$                                              |
| 5            | 1 1 1 1 -             |                                                              |
| 6            | - - - - -             |                                                              |
| 7            | 0 1 - - -             | $F_3 = \bar{A}B + CD + \bar{B}\bar{D}$                       |
| 8            | - - 1 1 -             |                                                              |
| 9            | - 0 - 0 -             |                                                              |
| 10           | - - - - 1             |                                                              |
| 11           | 1 - 0 0 -             | $F_4 = F_1 + \bar{A}\bar{C}\bar{D} + \bar{A}\bar{B}\bar{C}D$ |
| 12           | 0 0 0 1 -             |                                                              |

Step 3 :- Implementation :-



## (6)

### PLA :- programmable logic Array

In programmable logic array where both the 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.



→ Implement the given boolean functions by using PLA.

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

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

Step 1 :- The K-maps for the functions A, B, their minimization, and the minimal expressions for both the true and complement of those in sum of products.



$$A(T) = x\bar{z} + y\bar{z} + \bar{x}\bar{y}z$$



$$A(C) \Rightarrow \bar{A} = xz + yz + \bar{x}\bar{y}z$$

$$A(C) = \overline{xz + yz + \bar{x}\bar{y}z}$$

K-map for A.

$$\begin{aligned}
 \text{Simplify } A(C) &= \overline{(x+\bar{z}) \cdot (\bar{y}+\bar{z}) \cdot (x+y+z)} \\
 &= \overline{\bar{x}+z} + \overline{\bar{y}+z} + \overline{x+y+z} \\
 &= xz + yz + \bar{x}\bar{y}z
 \end{aligned}$$

| $X^2$ | 00 | 01 | 11 | 10 |
|-------|----|----|----|----|
| 0     | 0  | 1  | 1  | 1  |
| 1     | 4  | 5  | 6  | 7  |

| $X^2$ | 00 | 01 | 11 | 10 |
|-------|----|----|----|----|
| 0     | 0  | 0  | 1  | 3  |
| 1     | 1  | 0  | 5  | 7  |

$$B(T) = \overline{XY} + Z$$

$$\overline{B} = X\bar{Z} + \bar{Y}\bar{Z}$$

$$B(C) = \overline{X\bar{Z} + \bar{Y}\bar{Z}}$$

$$\begin{aligned} \text{Simplify } B(C) &= \overline{(Y+Z)(\bar{X}+Z)} \\ &= \overline{(Y+Z)} + \overline{(\bar{X}+Z)} \\ &= \bar{Y}\bar{Z} + X\bar{Z} \end{aligned}$$

$$\begin{aligned} \checkmark A(T) &= X\bar{Z} + Y\bar{Z} + \bar{X}\bar{Y}Z & B(T) &= \bar{X}Y + Z \\ A(C) &= XZ + YZ + \bar{X}\bar{Y}\bar{Z} & B(C) &= \bar{Y}\bar{Z} + X\bar{Z} \end{aligned}$$

Step 2 :- programming table.

| product term            | inputs<br>$x$ | $y$ | $z$ | outputs<br>$A(T)$ | $A(C)$ | $B(T)$ | $B(C)$ |
|-------------------------|---------------|-----|-----|-------------------|--------|--------|--------|
| $X\bar{Z}$              | 1             | -   | 0   | 1                 | -      | -      | 1      |
| $Y\bar{Z}$              | -             | 1   | 0   | -                 | -      | -      | -      |
| $\bar{X}\bar{Y}Z$       | 0             | 0   | 1   | -                 | -      | -      | -      |
| $XZ$                    | 1             | -   | 1   | -                 | 1      | -      | -      |
| $YZ$                    | -             | 1   | 1   | -                 | 1      | -      | -      |
| $\bar{X}\bar{Y}\bar{Z}$ | 0             | 0   | 0   | -                 | 1      | -      | -      |
| $\bar{X}Y$              | 0             | 1   | -   | -                 | -      | 1      | -      |
| $Z$                     | 0             | -   | 1   | -                 | -      | 1      | -      |
| $\bar{Y}\bar{Z}$        | -             | 0   | 0   | -                 | -      | -      | 1      |
| $X\bar{Z}$              | 1             | -   | 0   | -                 | -      | -      | 1      |



logic diagram.

→ Implement the following boolean functions  $F_1$  &  $F_2$  of a combinational logic circuit using PLA.

$$F_1(A, B, C) = \text{Em}(3, 4, 5, 7)$$

$$F_2(A, B, C) = \text{Em}(1, 4, 6).$$

Step 1:- K-map for  $F_1$  (Tow form) complement form



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



$$\begin{aligned} \overline{F_1} &= (A+B)(\bar{B}+C) \\ &= (\overline{A}+B) + (\bar{B}+C) \end{aligned}$$

$$F_1(T) = AB + BC$$

$$F_1(C)$$

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

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

K-map for  $F_2$  (true form)

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

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

K-map for  $F_2$  (complement form)

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

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

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

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

$$F_1(T) = A\bar{B} + BC$$

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

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

$$F_2(C) = \bar{A}\bar{C} + BC + AC$$

when we take  $F_1(T)$  &  $F_2(T)$  get 4 product terms and also having same number of product terms while taking  $F_1(C)$ ,  $F_2(C)$ ,  $F_1(T)$  &  $F_2(T)$ . So we have to consider  $F_1(T)$  &  $F_2(T)$ .

Step 2 :- programming table

| product terms     | inputs |   |   | outputs  |          |
|-------------------|--------|---|---|----------|----------|
|                   | A      | B | C | $F_1(T)$ | $F_2(T)$ |
| $A\bar{B}$        | 1      | 0 | - | 1        | -        |
| $B\bar{C}$        | -      | 1 | 1 | 1        | 0        |
| $\bar{A}\bar{B}C$ | 0      | - | 0 | 0        | +        |
| $A\bar{C}$        | 1      | - | 1 | -        | 1        |



logic diagram.

→ Implement the following multi boolean function using  $3 \times 4 \times 2$  PLA.

$$F_1(a_2, a_1, a_0) = \text{Em}(0, 1, 3, 5)$$

$$F_2(a_2, a_1, a_0) = \text{Em}(3, 5, 7)$$

step 1:- K-maps.

|                |   | a <sub>0</sub> |    |    |    |
|----------------|---|----------------|----|----|----|
|                |   | 00             | 01 | 11 | 10 |
| a <sub>2</sub> | 0 | 1              | 0  | 1  | 0  |
|                | 1 | 4              | 5  | 7  | 6  |

$$f_1(T) = \bar{a}_1 a_0 + \bar{a}_2 \bar{a}_1 + \bar{a}_2 a_0$$

|                |   | a <sub>0</sub> |    |    |    |
|----------------|---|----------------|----|----|----|
|                |   | 00             | 01 | 11 | 10 |
| a <sub>2</sub> | 0 | 0              | 1  | 1  | 0  |
|                | 1 | 0              | 0  | 0  | 1  |

$$f_1 = (\bar{a}_2 + a_0)(\bar{a}_2 + \bar{a}_1)(\bar{a}_1 + a_0)$$

$$f_1(C) = \bar{a}_2 \cdot a_0 + \bar{a}_2 \cdot \bar{a}_1 + \bar{a}_1 \cdot \bar{a}_0 \\ = a_2 \cdot \bar{a}_0 + a_2 \cdot a_1 + a_1 \cdot \bar{a}_0$$

$f_2$  (True form)

| $a_2 \backslash a_1 \backslash a_0$ | 00 | 01 | 11 | 10 |
|-------------------------------------|----|----|----|----|
| 0                                   | 0  | 1  | 1  | 0  |
| 1                                   | 1  | 0  | 0  | 1  |

$$f_2(T) = a_2 a_0 + a_1 a_0$$

$F_2$  (complement form..)

| $a_2 \backslash a_1 \backslash a_0$ | 00 | 01 | 11 | 10 |
|-------------------------------------|----|----|----|----|
| 0                                   | 0  | 0  | 0  | 0  |
| 1                                   | 0  | 0  | 0  | 0  |

$$\bar{F}_2 = (\bar{a}_0) \cdot (a_2 + a_1)$$

$$F_2(C) = \bar{a}_0 + \bar{a}_2 \cdot \bar{a}_1$$

$$F_1(T) = \bar{a}_1 a_0 + \bar{a}_2 \bar{a}_1 + \bar{a}_2 a_0$$

$$F_1(C) = a_2 \cdot \bar{a}_0 + a_2 \cdot a_1 + a_1 \cdot \bar{a}_0$$

$$F_2(T) = a_2 a_0 + a_1 a_0$$

$$F_2(C) = \bar{a}_0 + \bar{a}_2 \cdot \bar{a}_1$$

Step 2 :- PLA programming table.

| product terms         | Inputs<br>$a_2 \ a_1 \ a_0$ | outputs<br>$F_1(T)$ | $F_2(C)$ |
|-----------------------|-----------------------------|---------------------|----------|
| $\bar{a}_1 a_0$       | — 0 1                       | 1                   | —        |
| $\bar{a}_2 \bar{a}_1$ | 0 0 —                       | 1                   | 1        |
| $\bar{a}_2 a_0$       | 0 — 1                       | 1                   | —        |
| $\bar{a}_0$           | — — 0                       | —                   | 1        |

Step 3 :- logic diagram :-



→ Implement the following using PLA.

$$A(x,y,z) = \sum m(1,2,4,6), \quad B(x,y,z) = \sum m(0,1,6,7)$$

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

Step 1 :- K-map.

K-map for A (True form).



$$A(T) = x\bar{z} + y\bar{z} + \bar{z}y\bar{z}$$

K-map for A (Complement form).

| $xz$       | 00 | 01 | 11 | 10 |
|------------|----|----|----|----|
| $y\bar{z}$ | 0  | 1  | 3  | 2  |
| $\bar{x}$  | 4  | 5  | 7  | 6  |

$$A(C) = (x+y+z) \cdot (\bar{y}+\bar{z}) \cdot (\bar{x}+\bar{z})$$

$$= \bar{x}\bar{y}\bar{z} + yz + xz.$$

K-map for  $B(T)$

| $x \backslash y$ | 00 | 01 | 10 | 11 |
|------------------|----|----|----|----|
| 0                | 1  | 1  | 3  | 2  |
| 1                | 4  | 5  | 7  | 6  |

$$B(T) = \overline{x}\overline{y} + xy$$

K-map for  $C(T)$

| $x \backslash y$ | 00 | 01 | 11 | 10 |
|------------------|----|----|----|----|
| 0                | 0  | 1  | 3  | 2  |
| 1                | 4  | 5  | 7  | 6  |

$$C(T) = y\overline{z}$$

K-map for  $B(C)$

| $x \backslash y$ | 00 | 01 | 11 | 10 |
|------------------|----|----|----|----|
| 0                | 0  | 1  | 0  | 0  |
| 1                | 0  | 0  | 1  | 0  |

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

$$= \overline{x}\overline{y} + \overline{x}\overline{y}$$

$$= xy + \overline{xy}$$

K-map for  $C(C)$

| $x \backslash y$ | 00 | 01 | 11 | 10 |
|------------------|----|----|----|----|
| 0                | 0  | 0  | 0  | 3  |
| 1                | 0  | 0  | 0  | 6  |

$$C(C) = \overline{y} \cdot \cancel{z} \cdot (\overline{y} \cdot \cancel{z})$$

$$= \overline{y} + \overline{z}$$

$$= \overline{y} + z$$

Step 2 :- programming table.

| product term                | inputs |     |     | outputs |        |        |
|-----------------------------|--------|-----|-----|---------|--------|--------|
|                             | $x$    | $y$ | $z$ | $A(T)$  | $B(T)$ | $C(T)$ |
| $x\overline{z}$             | 1      | -   | 0   | 1       | -      | -      |
| $y\overline{z}$             | -      | 1   | 0   | 1       | -      | 1      |
| $\overline{x}\overline{y}z$ | 0      | 0   | 1   | 1       | -      | -      |
| $\overline{x}\overline{y}$  | 0      | 0   | -   | -       | 1      | -      |
| $xy$                        | 1      | 1   | -   | -       | 1      | -      |

Step - 3

Logic diagram :-



Given the logic implementation of a  $3 \times 4$  bit ROM using a decoder of a suitable size.

A  $32 \times 4$  bit ROM is to be implemented. It consists of 32 words of four bits each. There must be five input lines that form the binary numbers from 0 through 31 for the address. The five inputs are decoded into 32 distinct outputs by means of a  $5 \times 32$  decoder. Each output of the decoder represents a memory address. The 32 outputs of the decoder are connected to each of the four OR gates.



$32 \times 4$  bit ROM.

$\rightarrow 16 \times 8$  ROM.



## Comparison between PROM, PLA and PAL.

| PROM                                                                          | PLA                                                               | PAL                                                               |
|-------------------------------------------------------------------------------|-------------------------------------------------------------------|-------------------------------------------------------------------|
| 1. AND array is fixed and OR array is programmable.                           | 1. Both AND and OR arrays are programmable.                       | 1. OR array is fixed and AND array is programmable.               |
| 2. cheaper and simple to use                                                  | 2. costliest and more complex than PAL and PROM.                  | 2. cheaper and simpler.                                           |
| 3. ALL minterms are decoded.                                                  | 3. AND array can be programmed to get desired minterms.           | 3. AND array can be programmed to get desired minterms.           |
| 4. only Boolean functions in standard SOP form can be implemented using PROM. | 4. Any Boolean function in SOP form can be implemented using PLA. | 4. Any Boolean function in SOP form can be implemented using PAL. |

→ Implement a Binary to BCD code converter by using PAL

→ I am taking 3-bit Binary P.

| Binary         |                |                | BCD code       |                |                |                |
|----------------|----------------|----------------|----------------|----------------|----------------|----------------|
| B <sub>3</sub> | B <sub>2</sub> | B <sub>1</sub> | C <sub>4</sub> | C <sub>3</sub> | C <sub>2</sub> | C <sub>1</sub> |
| 0              | 0              | 0              | 0              | 0              | 0              | 0              |
| 0              | 0              | 1              | 0              | 0              | 0              | 1              |
| 0              | 1              | 0              | 0              | 0              | 1              | 0              |
| 0              | 1              | 1              | 0              | 0              | 1              | 1              |
| 1              | 0              | 0              | 0              | 1              | 0              | 0              |
| 1              | 0              | 1              | 0              | 1              | 0              | 1              |
| 1              | 1              | 0              | 0              | 1              | 1              | 0              |
| 1              | 1              | 1              | 0              | 1              | 1              | 1              |

→ Scan taking 4-binary.

| $B_4\ B_3\ B_2\ B_1$ | $C_8\ C_7\ C_6\ C_5\ C_4\ C_3\ C_2\ X_1$ |
|----------------------|------------------------------------------|
| 0 0 0 0              | 0 0 0 0 0 0 0 0                          |
| 0 0 0 1              | 0 0 0 0 0 0 0 1                          |
| 0 0 1 0              | 0 0 0 0 0 0 1 0                          |
| 0 0 1 1              | 0 0 0 0 0 0 1 1                          |
| 0 1 0 0              | 0 0 0 0 0 1 0 0                          |
| 0 1 0 1              | 0 0 0 0 0 1 0 1                          |
| 0 1 1 0              | 0 0 0 0 0 1 1 0                          |
| 0 1 1 1              | 0 0 0 0 0 1 1 1                          |
| 1 0 0 0              | 0 0 0 0 1 0 0 0                          |
| 1 0 0 1              | 0 0 0 0 1 0 0 1                          |
| 1 0 1 0              | 0 0 0 1 0 0 0 0                          |
| 1 0 1 1              | 0 0 0 1 0 0 0 1                          |
| 1 1 0 0              | 0 0 0 1 0 0 1 0                          |
| 1 1 0 1              | 0 0 0 1 0 0 1 1                          |
| 1 1 1 0              | 0 0 0 1 0 1 0 0                          |
| 1 1 1 1              | 0 0 0 1 0 1 0 1                          |

$$C_5 = \text{Em}(10, 11, 12, 13, 14, 15)$$

$$C_4 = \text{Em}(8, 9)$$

$$C_3 = \text{Em}(4, 5, 6, 7, 14, 15)$$

$$C_2 = \text{Em}(2, 3, 6, 7, 12, 13)$$

$$C_1 = \text{Em}(1, 3, 5, 7, 9, 11, 13, 15)$$

Step 1:- K-map.

| K-map for $C_5$ |                      |    |    |
|-----------------|----------------------|----|----|
| $B_4\bar{B}_3$  | $\bar{B}_2\bar{B}_1$ | 00 | 01 |
| 00              | 0                    | 1  | 3  |
| 01              | 5                    | 7  | 6  |
| 11              | 14                   | 13 | 15 |
| 10              | 8                    | 9  | 11 |

| K-map for $C_4$ |                      |    |    |
|-----------------|----------------------|----|----|
| $B_4\bar{B}_3$  | $\bar{B}_2\bar{B}_1$ | 00 | 01 |
| 00              | 0                    | 1  | 3  |
| 01              | 4                    | 5  | 7  |
| 11              | 12                   | 13 | 15 |
| 10              | 18                   | 17 | 11 |

| K-map for $C_3$ |                      |    |    |
|-----------------|----------------------|----|----|
| $B_4\bar{B}_3$  | $\bar{B}_2\bar{B}_1$ | 00 | 01 |
| 00              | 0                    | 1  | 3  |
| 01              | 4                    | 5  | 7  |
| 11              | 12                   | 13 | 15 |
| 10              | 8                    | 9  | 11 |

$$B_4 B_3 + B_4 B_2$$

$$B_4 \bar{B}_3 \bar{B}_2$$

$$\bar{B}_4 B_3 + B_3 B_2$$

| K-map for $C_2$ |                      |    |    |
|-----------------|----------------------|----|----|
| $B_4\bar{B}_3$  | $\bar{B}_2\bar{B}_1$ | 00 | 01 |
| 00              | 0                    | 1  | 3  |
| 01              | 5                    | 6  |    |
| 11              | 12                   | 13 | 14 |
| 10              | 8                    | 9  | 11 |

| K-map for $C_1$ |                      |    |    |
|-----------------|----------------------|----|----|
| $B_4\bar{B}_3$  | $\bar{B}_2\bar{B}_1$ | 00 | 01 |
| 00              | 0                    | 1  | 3  |
| 01              | 4                    | 5  | 6  |
| 11              | 12                   | 13 | 15 |
| 10              | 8                    | 9  | 11 |

$$B_4 B_3 \bar{B}_2 + \bar{B}_4 B_2$$

$$B_1$$

step 2:- programming table

| product terms | inputs<br>$B_4\ B_3\ B_2\ B_1$ | output                                    |
|---------------|--------------------------------|-------------------------------------------|
| 1             | 1 - 1 -                        | $C_5 = B_4 B_3 + B_4 B_2$                 |
| 2             | 1 - 1 -                        | $B_4 B_2$                                 |
| 3             | 1 0 0 -                        | $C_4 = B_4 \bar{B}_3 \bar{B}_2$           |
| 4             | - - - -                        |                                           |
| 5             | 0 1 - -                        | $C_3 = \bar{B}_4 B_3 + B_3 B_2$           |
| 6             | - 1 1 -                        |                                           |
| 7             | 1 1 0 -                        | $C_2 = B_4 \bar{B}_3 \bar{B}_2 + B_4 B_2$ |
| 8             | 0 - 1 -                        |                                           |
| 9             | - - - 1                        | $C_1 = B_1$                               |
| 10            | - - - -                        |                                           |

Step 3 :- logic diagram



## PROGRAMMABLE LOGIC DEVICES

- logic designers have a wide range of standard IC's available to them with numerous logic functions and logic circuit arrangements on a chip. In addition, these ICs are available from many manufacturers and at a reasonably low cost.
- PLD is an IC that contains large number of gates, flip-flops and registers that are interconnected on chip. This IC is said to be programmable because the specific function IC is determined by interconnecting required contacts.

Basically, there are three types of programmable device which are.

- Read only memory (ROM)
- programmable logic array (PLA)
- programmable Array logic (PAL).

### READ ONLY memory :-

- The read only memory is a type of semiconductor memory that is designed to hold data that is either permanent or will not change frequently.
- During operation, no new data can be written into a ROM, but data can be read from ROM. the process of entering data is called programming or burning-in the ROM.

→ Some ROM's cannot have their data changes once they have been programmed. others can be erased and reprogrammed as often as desired.

### Types of ROM's :-

1. Masked memory ROM
2. programmable read only memory (PROM)
3. Erasable programmable read only memory (EPROM)
4. Electrically Erasable programmable read only memory (EEPROM)

### Masked memory (Rom) :-

- cannot be reprogrammed
- Nonvolatile, retain data even when power is turn off.
- cheaper than programmable devices.
- useful for fixed programme instructions.

### PROM

- programmed by blowing built-in fuses.
- can not be reprogrammed.
- Non volatile.
- useful for small volume data storing
- user programmable

### EPROM :-

- Erasable, programmable ROM
- programmed by storing charge on insulated gates.
- Erasable with ultraviolet light
- non-volatile.

### EEPROM :-

- programmed by storing charges on insulated gates
- Non volatile

### Programmable ROM :-

- It includes both the decoder and the OR Gates with a single IC package. The following figures shows the block diagram and logic construction using 16x2 ROM.
- It consists of n input lines and m output lines.
- Each bit combination of the input variables is called an address.
- Each bit combination that comes out of the output lines is called a word.



Block diagram.

An integrated circuit with programmable gates divided into an AND array and an OR array provide an AND-OR sum of products implementation.

EPROM :-

- Erasable, programmable ROM
- programmed by storing charge on insulated gates.
- Erasable with ultraviolet light
- non-volatile.

EEPROM :-

- programmed by storing charges on insulated gates.
- Non volatile

Programmable ROM :-

- It includes both the decoder and the OR Gates with a single IC package. The following figures shows the block diagram and logic construction using 16x2 ROM.
- It consists of n input lines and m output lines.
- Each bit combination of the input variables is called an address.
- Each bit combination that comes out of the output lines is called a word.



Block diagram.

An integrated circuit with programmable gates divided into an AND array and an OR array to provide an AND-OR sum of products implementation.

The programmable read-only memory (PROM) has a fixed AND array constructed as a decoder and a programmable OR array. The AND gates are programmed to provide the product terms for the Boolean functions, which are logically summed in each OR gate.

Orate:



→ Implement full-adder using PROM.

The number of inputs variables of a full adder are 3. The possible number of combinations are 8. So we need 3x8 decoder. The number of outputs of full adder are 3. They are sum and carry.

(3)

Truth table

| A | B | Cin | S | C |
|---|---|-----|---|---|
| 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 |

output expression for sum & carry  
 carry = 18    sum =  $\sum m(1,2,4,7)$   
 carry =  $\sum m(3,5,6,7)$ .

logic diagram

→ Design BCD to Excess-3 code converter  
 using PRDM.

Step:- 1 - Truth table.

| BCD   |       |            |  | EXCESS-3 |       |            |   |
|-------|-------|------------|--|----------|-------|------------|---|
| $B_3$ | $B_2$ | $B_1, B_0$ |  | $E_3$    | $E_2$ | $E_1, E_0$ |   |
| 0     | 0     | 00         |  | 0        | 0     | 1          | 1 |
| 0     | 0     | 01         |  | 0        | 1     | 0          | 0 |
| 0     | 0     | 10         |  | 0        | 1     | 0          | 1 |
| 0     | 0     | 11         |  | 0        | 1     | 1          | 0 |
| 0     | 1     | 00         |  | 0        | 1     | 1          | 1 |
| 0     | 1     | 01         |  | 1        | 0     | 0          | 0 |
| 0     | 1     | 10         |  | 1        | 0     | 0          | 1 |
| 0     | 1     | 11         |  | 1        | 0     | 1          | 0 |
| 1     | 0     | 00         |  | 0        | 1     | 1          | 1 |

Step 2 :-

$$E_0(B_3, B_2, B_1, B_0) = \Sigma m(0, 2, 4, 6, 8)$$

$$E_1(B_3, B_2, B_1, B_0) = \Sigma m(0, 3, 4, 7, 8)$$

$$E_2(B_3, B_2, B_1, B_0) = \Sigma m(1, 2, 3, 4, 9)$$

$$E_3(B_3, B_2, B_1, B_0) = \Sigma m(5, 6, 7, 8, 9)$$

Step 3 :- logic diagram.



→ Implement the following Boolean expression using PROM.

$$f(A, B, C) = \overline{A}B + C + BC$$

first given expression converted into a standard SOP form

$$f(A, B, C) = \overline{A}B + C + BC$$

$$\begin{aligned}
 &= \overline{AB}(C + \overline{C}) + C(A + \overline{A})(B + \overline{B}) + BC(A + \overline{A}) \\
 &= \overline{ABC} + \overline{ABC} + \underline{\overline{ABC}} + \underline{\overline{ABC}} + \overline{ABC} + \overline{ABC} + \underline{\overline{ABC}} + \underline{\overline{ABC}} \\
 &= \overline{ABC} + \overline{ABC} + ABC + \overline{ABC} + \overline{ABC} + \overline{ABC} \\
 &\quad 0, 11, 0\cancel{1}0, 1\cancel{1}, 101, 011, 001 \\
 f(A, B, C) &= \text{m}(1, 2, 3, 5, 7)
 \end{aligned}$$

Logic diagram :-



PAL :- programmable Array logic

The programmable Array logic is a programmable device with a fixed OR array and a programmable AND array because only the AND gates are programmable.



→ Implement the following functions using PAL.

$$F_1(a,b,c,d) = \text{sum}(0,1,2,3,6,9,11)$$

$$F_2(a,b,c,d) = \text{sum}(0,1,6,8,9)$$

Step 1:- K-map simplification for  $F_1$  and  $F_2$



$$\bar{a}\bar{b} + \bar{a}cd + \bar{b}d$$

$$\bar{b}\bar{c} + \bar{a}bc\bar{d}$$

Step 2 :- PAL programming table.

| product terms | AND gate inputs<br>a b c d | outputs                                       |
|---------------|----------------------------|-----------------------------------------------|
| 1             | 0 0 - -                    |                                               |
| 2             | 0 - 1 1                    | $F_1 = \bar{a}\bar{b} + \bar{a}cd + \bar{b}d$ |
| 3             | - 0 - 1                    |                                               |
| 4             | - 0 0 -                    | $F_2 = \bar{b}\bar{c} + \bar{a}bc\bar{d}$     |
| 5             | 0 1 1 0                    |                                               |
| 6             | - - - -                    |                                               |

Step 3 :- implementation :-



→ Implement 4-bit BCD to XS-3 code conversion  
using PAL.

Step :- 1

| B <sub>4</sub> | B <sub>3</sub> | B <sub>2</sub> | B <sub>1</sub> | X <sub>4</sub> | X <sub>3</sub> | X <sub>2</sub> | X <sub>1</sub> |
|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|
| 0              | 0              | 0              | 0              | 0              | 0              | 1              | 1              |
| 0              | 0              | 0              | 1              | 0              | 1              | 0              | 0              |
| 0              | 0              | 1              | 0              | 0              | 1              | 0              | 1              |
| 0              | 0              | 1              | 1              | 0              | 1              | 1              | 0              |
| 0              | 1              | 0              | 0              | 0              | 1              | 1              | 1              |
| 0              | 1              | 0              | 1              | 1              | 0              | 0              | 0              |
| 0              | 1              | 1              | 0              | 1              | 0              | 0              | 1              |
| 0              | 1              | 1              | 1              | 1              | 0              | 1              | 0              |
| 1              | 0              | 0              | 0              | 1              | 0              | 1              | 1              |
| 1              | 0              | 0              | 1              | 1              | 1              | 0              | 0              |

$$x_4 = \text{Em}(5, 6, 7, 8, 9) + d(10, 11, 12, 13, 14, 15)$$

$$x_3 = \text{Em}(1, 2, 3, 4, 9) + d(10, 11, 12, 13, 14, 15)$$

$$x_2 = \text{Em}(0, 3, 4, 7, 8) + d(10, 11, 12, 13, 14, 15)$$

$$x_1 = \text{Em}(0, 2, 4, 6, 8) + d(10, 11, 12, 13, 14, 15)$$

| $B_4\ B_3\ B_2\ B_1$ | 00       | 01       | 11       | 10       |
|----------------------|----------|----------|----------|----------|
| 00                   | 0        | 1        | 3        | 2        |
| 01                   | 4        | 5        | 7        | 6        |
| 11                   | $x_{12}$ | $x_{13}$ | $x_{15}$ | $x_{14}$ |
| 10                   | 8        | 9        | $x_{11}$ | $x_{10}$ |

| $B_4\ B_3\ B_2\ B_1$ | 00       | 01       | 11       | 10       |
|----------------------|----------|----------|----------|----------|
| 00                   | 0        | 1        | 3        | 2        |
| 01                   | 4        | 5        | 7        | 6        |
| 11                   | $x_{12}$ | $x_{13}$ | $x_{15}$ | $x_{14}$ |
| 10                   | 8        | 9        | $x_{11}$ | $x_{10}$ |

| $B_4\ B_3\ B_2\ B_1$ | 00       | 01       | 11       | 10       |
|----------------------|----------|----------|----------|----------|
| 00                   | 0        | 1        | 3        | 2        |
| 01                   | 4        | 5        | 7        | 6        |
| 11                   | $x_{12}$ | $x_{14}$ | $x_{15}$ | $x_{14}$ |
| 10                   | 8        | 9        | $x_{11}$ | $x_{10}$ |

| $B_4\ B_3\ B_2\ B_1$ | 00       | 01       | 11       | 10       |
|----------------------|----------|----------|----------|----------|
| 00                   | 0        | 1        | 3        | 2        |
| 01                   | 4        | 5        | 7        | 6        |
| 11                   | $x_{12}$ | $x_{14}$ | $x_{15}$ | $x_{14}$ |
| 10                   | 8        | 9        | $x_{11}$ | $x_{12}$ |

$$x_4 = B_4 + B_3 B_2 + B_3 B_1$$

$$x_3 = B_3 \overline{B_2} \overline{B_1} + \overline{B_3} B_1 + \overline{B_3} B_2$$

$$x_2 = \overline{B_2} \overline{B_1} + B_2 B_1$$

$$x_1 = \overline{B_1}$$

Step 2 :- programming table.

| product terms. | AND Gate Inputs. |                |                |                | outputs.                                                        |
|----------------|------------------|----------------|----------------|----------------|-----------------------------------------------------------------|
|                | B <sub>4</sub>   | B <sub>3</sub> | B <sub>2</sub> | B <sub>1</sub> |                                                                 |
| 1              | 1                | -              | -              | -              |                                                                 |
| 2              | -                | 1              | 1              | -              | $X_4 = B_4 + B_3 B_2 + B_3 B_1$                                 |
| 3              | -                | 1              | -              | 1              |                                                                 |
| 4              | -                | 1              | 0              | 0              | $X_3 = B_3 \bar{B}_2 \bar{B}_1 + \bar{B}_3 B_1 + \bar{B}_3 B_2$ |
| 5              | -                | 0              | -              | 1              |                                                                 |
| 6              | -                | 0              | 1              | -              |                                                                 |
| 7              | -                | -              | 0              | 0              | $X_2 = \bar{B}_2 \bar{B}_1 + B_2 B_1$                           |
| 8              | -                | -              | 1              | 1              |                                                                 |
| 9              | -                | -              | -              | -              |                                                                 |
| 10             | -                | -              | -              | 0              |                                                                 |
| 11             | -                | -              | -              | -              | $X_1 = B_1$                                                     |
| 12             | -                | -              | -              | -              |                                                                 |

Step 3 :- logic diagram.



logic diagram.

(7)

Implement the following boolean functions using PAL with four inputs and 3-wide AND-OR structure. Also write the PAL programming table.

$$F_1(A, B, C, D) = \Sigma m(2, 12, 13)$$

$$F_2(A, B, C, D) = \Sigma m(7, 8, 9, 10, 11, 12, 13, 14, 15)$$

$$F_3(A, B, C, D) = \Sigma m(0, 2, 3, 4, 5, 6, 7, 8, 10, 11, 15)$$

$$F_4(A, B, C, D) = \Sigma m(1, 2, 8, 12, 13)$$



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

$$F_2 = A + BCD$$

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

$$F_4 = \underbrace{ABC\bar{C}}_{= F_1} + \bar{A}\bar{C}\bar{D} + \bar{A}\bar{B}\bar{C}D + \bar{A}B\bar{C}\bar{D}$$

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

Step 2 :- programming table

| product term | AND inputs<br>A B C D F1 | outputs                                                      |
|--------------|--------------------------|--------------------------------------------------------------|
| 1            | 1 1 0 --                 | $F_1 = ABC\bar{C} + \bar{A}\bar{B}CD$                        |
| 2            | 0 0 1 0 -                |                                                              |
| 3            | - - - - -                |                                                              |
| 4            | 1 - - - -                | $F_2 = A + BCD$                                              |
| 5            | - 1 - - -                |                                                              |
| 6            | - - = - -                |                                                              |
| 7            | 0 1 - - -                | $F_3 = \bar{A}B + \bar{C}D + \bar{B}\bar{D}$                 |
| 8            | - - 1 1 -                |                                                              |
| 9            | - 0 - 0 -                |                                                              |
| 10           | - - - - 1                |                                                              |
| 11           | 1 - 0 0 -                | $F_4 = F_1 + \bar{A}\bar{C}\bar{D} + \bar{A}\bar{B}\bar{C}D$ |
| 12           | 0 0 0 1 -                |                                                              |

Step 3 :- Implementation



## PLA :- programmable logic Array

In programmable logic array where both the 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.



→ implement the given boolean functions by using PLA.

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

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

Step 1 :- The K-maps for the functions A, B, their minimization, and the minimal expressions for both the true and complement of those in sum of products.

|   |   | Y <sup>2</sup> | 00 | 01 | 11 | 10 |
|---|---|----------------|----|----|----|----|
|   |   | X              | 0  | 1  | 3  | 2  |
|   |   | 0              | 0  | 1  | 3  | 2  |
| 1 | 0 | 1              | 0  | 1  | 0  | 1  |
| 1 | 1 | 0              | 1  | 0  | 1  | 0  |

|   |   | Y <sup>2</sup> | 00 | 01 | 11 | 10 |
|---|---|----------------|----|----|----|----|
|   |   | X              | 0  | 1  | 3  | 2  |
|   |   | 0              | 0  | 1  | 3  | 2  |
| 1 | 0 | 1              | 0  | 1  | 0  | 1  |
| 1 | 1 | 0              | 1  | 0  | 1  | 0  |

$$A(T) = x\bar{z} + y\bar{z} + \bar{x}\bar{y}z$$

$$A(C) \rightarrow \bar{A} = xz + yz + \bar{x}\bar{y}z$$

$$A(C) = \overline{xz + yz + \bar{x}\bar{y}z}$$

K-map for A.

$$\text{Simplify } A(C) = \overline{(x+\bar{z}) \cdot (\bar{y}+\bar{z}) \cdot (x+y+z)}$$

$$= \overline{(x+\bar{z})} + \overline{(\bar{y}+\bar{z})} + \overline{(x+y+z)}$$

$$= xz + yz + \bar{x}\bar{y}z$$

|   | Y2 | 00 | 01 | 11 | 10 |
|---|----|----|----|----|----|
| X | 00 | 01 | 11 | 10 |    |
| 0 | 0  | 1  | 1  | 1  | 1  |
| 1 | 4  | 5  | 7  | 6  |    |

|   | Y2 | 00 | 01 | 11 | 10 |
|---|----|----|----|----|----|
| X | 00 | 01 | 11 | 10 |    |
| 0 | 0  | 0  | 1  | 3  | 2  |
| 1 | 0  | 0  | 5  | 4  |    |

$$B(T) = \overline{XY} + Z$$

$$\overline{B} = X\bar{Z} + \bar{Y}\bar{Z}$$

$$B(C) = \overline{X\bar{Z} + \bar{Y}\bar{Z}}$$

$$\text{Simplify } B(C) = \overline{(Y+Z)(\bar{X}+Z)}$$

$$= \overline{(Y+Z)} + (\overline{\bar{X}+Z})$$

$$= \overline{Y\bar{Z}} + X\bar{Z}$$

$$\checkmark A(T) = X\bar{Z} + Y\bar{Z} + \overline{XY\bar{Z}} \quad B(T) = \overline{XY} + Z$$

$$A(C) = XZ + YZ + \overline{XYZ} \quad B(C) = \overline{Y\bar{Z}} + X\bar{Z}$$

Step 2 :- programming table.

| product term        | inputs |   | outputs |      |      |      |      |
|---------------------|--------|---|---------|------|------|------|------|
|                     | X      | Y | Z       | A(T) | A(C) | B(T) | B(C) |
| $\{ X\bar{Z}$       | 1      | - | 0       | 1    | -    | -    | 1    |
| $\{ Y\bar{Z}$       | -      | 1 | 0       | 1    | -    | -    | -    |
| $\{ \overline{XY}Z$ | 0      | 0 | 1       | 1    | -    | -    | -    |
| $XZ$                | 1      | - | 1       | -    | 1    | -    | -    |
| $YZ$                | -      | 1 | 1       | -    | 1    | -    | -    |
| $\overline{XYZ}$    | 0      | 0 | 0       | -    | 1    | -    | -    |
| $\overline{XY}$     | 0      | 1 | -       | -    | -    | 1    | -    |
| $Z$                 | 0      | - | 1       | -    | -    | 1    | 1    |
| $\{ Y\bar{Z}$       | -      | 0 | 0       | -    | -    | -    | -    |
| $\{ X\bar{Z}$       | 1      | - | 0       | -    | -    | -    | -    |



logic diagram.

→ Implement the following boolean functions  $F_1$  &  $F_2$  of a combinational logic circuit using PLA.

$$F_1(A, B, C) = \text{Em}(3, 4, 5, 7)$$

$$F_2(A, B, C) = \text{Em}(1, 4, 6).$$

Step 1:- K-map for  $F_1$  (True form) complement form



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



$$\begin{aligned} F_1 &= (A+B)(\bar{B}+C) \\ &= (A+B) + (\bar{B}+C) \end{aligned}$$

$$F_1(T) = AB + BC$$

$$\begin{aligned} &= (\bar{A} \cdot \bar{B}) + \bar{B} \cdot \bar{C} \\ F_1(C) &= \bar{A} \cdot \bar{B} + B \cdot \bar{C} \end{aligned}$$

K-map for  $F_2$  (true form)

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

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

K-map for  $F_2$  (complement form)

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

$$\begin{aligned} F_2 &= (\bar{A} + C) \cdot (\bar{B} + \bar{C}) \cdot (\bar{A} + \bar{C}) \\ &= (\bar{A} + C) + (\bar{B} + \bar{C}) + (\bar{A} + \bar{C}) \\ &= \bar{A} \cdot \bar{C} + B \cdot C + A \cdot C. \end{aligned}$$

$$F_1(T) = AB + BC$$

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

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

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

when we take  $F_1(T) \& F_2(T)$  get 4 product terms and also having same number of product terms while taking  $F_1(C) \& F_2(C)$ ,  $F_1(T) \& F_2(C)$ . So we have to consider  $F_1(T) \& F_2(T)$ .

Step 2 :- programming table

| product terms       | inputs |   |   | outputs  |          |
|---------------------|--------|---|---|----------|----------|
|                     | A      | B | C | $F_2(T)$ | $F_2(C)$ |
| $A \bar{B}$         | 1      | 0 | - | 1        | -        |
| $B \bar{C}$         | -      | 1 | 1 | 1        | 0        |
| $\bar{A} \bar{B} C$ | 0      | - | 0 | 0        | +        |
| $A \bar{C}$         | 1      | - | 1 | -        | 1        |



logic diagram.

→ Implement the following multi boolean function using  
3x4x2 PLA.

$$F_1(a_2, a_1, a_0) = \text{Em}(0, 1, 3, 5)$$

$$F_2(a_2, a_1, a_0) = \text{Em}(3, 5, 7)$$

step 1:- K-maps.



$$f_1(T) = \bar{a}_1a_0 + \bar{a}_2\bar{a}_1 + \bar{a}_2a_0$$

$f_1$  (complement form)

|       |    |    |    |    |   |
|-------|----|----|----|----|---|
| $a_2$ | 00 | 01 | 11 | 10 |   |
| 0     | 0  | 1  | 0  | 3  | 2 |
| 1     | 0  | 0  | 1  | 0  | 0 |

$$f_1 = (\bar{a}_0 + a_0)(\bar{a}_2 + \bar{a}_1)(\bar{a}_1 + a_0)$$

$$f_1(C) = \bar{a}_2 \cdot a_0 + \bar{a}_2 \cdot \bar{a}_1 + \bar{a}_1 \cdot \bar{a}_0 \\ = a_2 \cdot \bar{a}_0 + a_2 \cdot a_1 + a_1 \cdot \bar{a}_0$$

$f_2$  (True f8m)

|       |   | $a_2 \cdot a_0$ | $\bar{a}_2 \cdot a_0$ | $a_2 \cdot \bar{a}_1$ | $\bar{a}_2 \cdot \bar{a}_1$ | $\bar{a}_1 \cdot \bar{a}_0$ | $a_1 \cdot \bar{a}_0$ |
|-------|---|-----------------|-----------------------|-----------------------|-----------------------------|-----------------------------|-----------------------|
|       |   | 00              | 01                    | 11                    | 10                          | 00                          | 01                    |
| $a_2$ | 0 | 0               | 1                     | 1                     | 0                           | 1                           | 0                     |
| 0     | 0 | 1               | 1                     | 0                     | 1                           | 0                           | 1                     |

$$f_2(T) = a_2 a_0 + a_1 a_0$$

$F_2$  (complement f8m..)

|       |   | $a_2 \cdot a_0$ | $\bar{a}_2 \cdot a_0$ | $a_2 \cdot \bar{a}_1$ | $\bar{a}_2 \cdot \bar{a}_1$ | $\bar{a}_1 \cdot \bar{a}_0$ | $a_1 \cdot \bar{a}_0$ |
|-------|---|-----------------|-----------------------|-----------------------|-----------------------------|-----------------------------|-----------------------|
|       |   | 00              | 01                    | 11                    | 10                          | 00                          | 01                    |
| $a_2$ | 0 | 0               | 0                     | 0                     | 0                           | 0                           | 0                     |
| 0     | 0 | 0               | 0                     | 0                     | 0                           | 0                           | 0                     |

$$F_2 = (\bar{a}_0) \cdot (a_2 + a_1)$$

$$F_2(C) = \bar{a}_0 + \bar{a}_2 \cdot \bar{a}_1$$

$$F_1(T) = \bar{a}_1 a_0 + \bar{a}_2 \bar{a}_1 + \bar{a}_2 a_0$$

$$F_1(C) = a_2 \cdot \bar{a}_0 + a_2 \cdot a_1 + a_1 \cdot \bar{a}_0$$

$$F_2(T) = a_2 a_0 + a_1 a_0$$

$$F_2(C) = \bar{a}_0 + \bar{a}_2 \cdot \bar{a}_1$$

Step 2 :- PLA programming table.

| product terms         | Inputs |       |       | outputs  |          |
|-----------------------|--------|-------|-------|----------|----------|
|                       | $a_2$  | $a_1$ | $a_0$ | $F_1(T)$ | $F_2(C)$ |
| $\bar{a}_1 a_0$       | -      | 0     | 1     | 1        | -        |
| $\bar{a}_2 \bar{a}_1$ | 0      | 0     | -     | 1        | 1        |
| $\bar{a}_2 a_0$       | 0      | -     | 1     | 1        | -        |
| $\bar{a}_0$           | -      | -     | 0     | -        | 1        |

Step 3 :- logic diagram:-



→ Implement the following using PLA

$$A(x,y,z) = \sum m(1,2,4,6), \quad B(x,y,z) = \sum m(0,1,6,7)$$

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

Step 1 :- K-map.

K-map for A (True form).

|     | Y\Z | 00 | 01 | 11 | 10 |
|-----|-----|----|----|----|----|
| X\Z | 0   | 1  | 0  | 1  | 0  |
| 1   | 1   | 0  | 1  | 0  | 1  |
|     | x   | z  | y  | yz | xy |

$$A(T) = x\bar{z} + y\bar{z} + \bar{x}\bar{y}z$$

K-map for A (Complement form).

|     | Y\Z | 00 | 01 | 11 | 10 |
|-----|-----|----|----|----|----|
| X\Z | 0   | 0  | 1  | 0  | 2  |
| 1   | 4   | 0  | 0  | 5  | 6  |
|     | x   | z  | y  | yz | xy |

$$A(C) = (x+y+z) \cdot (\bar{y}+\bar{z}) (\bar{x}+\bar{z})$$

$$= \bar{x}\bar{y}\bar{z} + yz + xz.$$

K-map for  $B(T)$ 

| $x \backslash y$ | 00 | 01 | 10 | 11 |
|------------------|----|----|----|----|
| 0                | 1  | 0  | 1  | 3  |
| 1                | 4  | 5  | 7  | 6  |

$$B(T) = \bar{x}\bar{y} + xy$$

K-map for  $C(T)$ 

| $x \backslash y$ | 00 | 01 | 11 | 10 |
|------------------|----|----|----|----|
| 0                | 0  | 1  | 3  | 2  |
| 1                | 4  | 5  | 7  | 6  |

$$C(T) = y\bar{z}$$

K-map for  $B(C)$ 

| $x \backslash y$ | 00 | 01 | 11 | 10 |
|------------------|----|----|----|----|
| 0                | 0  | 1  | 0  | 0  |
| 1                | 0  | 0  | 1  | 0  |

$$B(C) = (\bar{x}+y)(x+\bar{y})$$

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

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

K-map for  $C(C)$ 

| $x \backslash y$ | 00 | 01 | 11 | 10 |
|------------------|----|----|----|----|
| 0                | 0  | 0  | 0  | 2  |
| 1                | 0  | 0  | 0  | 6  |

$$C(C) = \bar{y} \bullet z (\bar{y} \cdot \bar{z})$$

$$= \bar{y} + \bar{z}$$

$$= \bar{y} + z$$

Step 2:- programming table.

| product term      | inputs |   |   | outputs |      |      |
|-------------------|--------|---|---|---------|------|------|
|                   | x      | y | z | A(T)    | B(T) | C(T) |
| $x\bar{z}$        | 1      | — | 0 | 1       | —    | —    |
| $\bar{y}\bar{z}$  | —      | 1 | 0 | 1       | —    | 1    |
| $\bar{x}\bar{y}z$ | 0      | 0 | 1 | 1       | —    | —    |
| $\bar{x}\bar{y}$  | 0      | 0 | — | —       | 1    | —    |
| $xy$              | 1      | 1 | — | —       | 1    | —    |

Step - 3

Logic diagram :-



→ Give the logic implementation of a  $32 \times 4$  bit ROM using a decoder of a suitable size.

A  $32 \times 4$  bit ROM is to be implemented. It consists of 32 words of four bits each. There must be five input lines that form the binary numbers from 0 through 31 for the address. The five inputs are decoded into 32 distinct outputs by means of a  $5 \times 32$  decoder. Each output of the decoder represent a memory address. The 32 outputs of the decoder are connected to each of the four OR gates.



→ 32 x 4 bit ROM.  
→ 16 x 8 ROM.



## Comparison between PROM, PLA and PAL.

| PROM                                                                          | PLA                                                                | PAL                                                               |
|-------------------------------------------------------------------------------|--------------------------------------------------------------------|-------------------------------------------------------------------|
| 1. AND array is fixed and OR array is programmable.                           | 1. Both AND and OR arrays are programmable.                        | 1. OR array is fixed and AND array is programmable.               |
| 2. cheaper and simple to use                                                  | 2. costliest and more complex than PAL and PROM.                   | 2. cheaper and simpler.                                           |
| 3. All minterms are decoded.                                                  | 3. AND array can be programmed to get desired minterms.            | 3. AND array can be programmed to get desired minterms.           |
| 4. only Boolean functions in Standard SOP form can be implemented using PROM. | 4. Any Boolean function in SOP form can be implemented using PROM. | 4. Any Boolean function in SOP form can be implemented using PAL. |

→ Implement a Binary to BCD code converter by using PAL

→ I am taking 3-bit Binary P.

| Binary         |                |                | BCD code       |                |                |                |
|----------------|----------------|----------------|----------------|----------------|----------------|----------------|
| B <sub>3</sub> | B <sub>2</sub> | B <sub>1</sub> | C <sub>4</sub> | C <sub>3</sub> | C <sub>2</sub> | C <sub>1</sub> |
| 0              | 0              | 0              | 0              | 0              | 0              | 0              |
| 0              | 0              | 1              | 0              | 0              | 0              | 1              |
| 0              | 1              | 0              | 0              | 0              | 1              | 0              |
| 0              | 1              | 1              | 0              | 0              | 1              | 1              |
| 1              | 0              | 0              | 0              | 1              | 0              | 0              |
| 1              | 0              | 1              | 0              | 1              | 0              | 1              |
| 1              | 1              | 0              | 0              | 1              | 1              | 0              |
| 1              | 1              | 1              | 0              | 1              | 1              | 1              |

→ I am taking 4-binary

| $B_4\ B_3\ B_2\ B_1$ | $C_8\ C_7\ C_6\ C_5\ C_4\ C_3\ C_2\ X_1$ |
|----------------------|------------------------------------------|
| 0 0 0 0              | 0 0 0 0 0 0 0 0                          |
| 0 0 0 1              | 0 0 0 0 0 0 0 1                          |
| 0 0 1 0              | 0 0 0 0 0 0 1 0                          |
| 0 0 1 1              | 0 0 0 0 0 0 1 1                          |
| 0 1 0 0              | 0 0 0 0 0 1 0 0                          |
| 0 1 0 1              | 0 0 0 0 0 1 0 1                          |
| 0 1 1 0              | 0 0 0 0 0 1 1 0                          |
| 0 1 1 1              | 0 0 0 0 0 1 1 1                          |
| 1 0 0 0              | 0 0 0 0 1 0 0 0                          |
| 1 0 0 1              | 0 0 0 0 1 0 0 1                          |
| 1 0 1 0              | 0 0 0 1 0 0 0 0                          |
| 1 0 1 1              | 0 0 0 1 0 0 0 1                          |
| 1 1 0 0              | 0 0 0 1 0 0 1 0                          |
| 1 1 0 1              | 0 0 0 1 0 0 1 1                          |
| 1 1 1 0              | 0 0 0 1 0 1 0 0                          |
| 1 1 1 1              | 0 0 0 1 0 1 0 1                          |

$$C_5 = \text{Em}(10, 11, 12, 13, 14, 15)$$

$$C_4 = \text{Em}(8, 9)$$

$$C_3 = \text{Em}(4, 5, 6, 7, 11, 15)$$

$$C_2 = \text{Em}(2, 3, 6, 7, 12, 13)$$

$$C_1 = \text{Em}(1, 3, 5, 7, 9, 11, 13, 15)$$

Step 1:- K-map.

(4)

| K-map for $C_5$ |                      |                |                | K-map for $C_4$ |                      |                |                | K-map for $C_3$ |                      |                |                |    |
|-----------------|----------------------|----------------|----------------|-----------------|----------------------|----------------|----------------|-----------------|----------------------|----------------|----------------|----|
| $B_4\bar{B}_3$  | $\bar{B}_2\bar{B}_1$ | $B_2\bar{B}_1$ | $\bar{B}_2B_1$ | $B_4\bar{B}_3$  | $\bar{B}_2\bar{B}_1$ | $B_2\bar{B}_1$ | $\bar{B}_2B_1$ | $B_4\bar{B}_3$  | $\bar{B}_2\bar{B}_1$ | $B_2\bar{B}_1$ | $\bar{B}_2B_1$ |    |
| 00              | 0                    | 1              | 3              | 2               | 0                    | 1              | 3              | 2               | 0                    | 1              | 3              | 2  |
| 01              | u                    | 5              | 7              | 6               | 01                   | 4              | 5              | 7               | 6                    | 14             | 15             | 13 |
| 11              | 12                   | 13             | 15             | 14              | 11                   | 12             | 13             | 15              | 14                   | 12             | 15             | 11 |
| 10              | 8                    | 9              | 11             | 10              | 10                   | 11             | 10             | 11              | 10                   | 8              | 9              | n  |

$$B_4\bar{B}_3 + B_4B_2$$

$$B_4\bar{B}_3\bar{B}_2$$

$$\bar{B}_4B_3 + B_3B_2$$

K-map for  $C_2$

| $B_4\bar{B}_3$ | 00 | 01 | 11 | 10 |
|----------------|----|----|----|----|
| 00             | 0  | 1  | 1  | 1  |
| 01             | u  | 5  | 1  | 1  |
| 11             | 1  | 1  | 13 | 15 |
| 10             | 8  | 9  | 11 | 10 |

K-map for  $C_1$

| $B_4\bar{B}_3$ | 00 | 01 | 11 | 10 |
|----------------|----|----|----|----|
| 00             | 0  | 1  | 1  | 2  |
| 01             | 4  | 5  | 1  | 6  |
| 11             | 12 | 13 | 15 | 14 |
| 10             | 8  | 1  | 11 | 0  |

$$B_4\bar{B}_3\bar{B}_2 + \bar{B}_4B_2$$

$$B_1$$

step 2 :- programming table

| product terms | inputs<br>$B_4\bar{B}_3\bar{B}_2B_1$ | output                                       |
|---------------|--------------------------------------|----------------------------------------------|
| 1             | 1 1 - -                              | $C_5 = B_4\bar{B}_3 + B_4B_2$                |
| 2             | 1 - 1 -                              |                                              |
| 3             | 1 0 0 -                              | $C_4 = \bar{B}_4\bar{B}_3\bar{B}_2$          |
| 4             | - - - -                              |                                              |
| 5             | 0 1 - -                              | $C_3 = \bar{B}_4B_3 + B_3B_2$                |
| 6             | - 1 1 -                              |                                              |
| 7             | 1 1 0 -                              | $C_2 = B_4\bar{B}_3\bar{B}_2 + \bar{B}_4B_2$ |
| 8             | 0 - 1 -                              |                                              |
| 9             | - - - 1                              | $C_1 = B_1$                                  |
| 10            | - - - -                              |                                              |

Step 3 :- logic diagram.



## Sequential circuits I.

In sequential logic circuits, the output is a function of the present inputs as well as the past inputs and outputs. Sequential circuit include memory element to store the past data. The flip-flop is a basic element of sequential logic circuits.



Block diagram of sequential circuit.

There are two types of sequential circuits.

- Synchronous circuit :- The sequential circuits which are controlled by a clock are called synchronous sequential circuits. These circuits get activated only clock signal is present.
- Asynchronous circuit :- The sequential circuits which are not controlled by a clock are called a synchronous sequential circuits, that is the sequential circuits in which events can take place any time the inputs are applied are called A synchronous sequential circuits.

## Comparison between Synchronous & Asynchronous sequential circuit

### Synchronous Sequential Circuit

1. In synchronous circuits, the change in input signals can affect memory elements upon activation of clock signal.
2. In synchronous circuits, memory elements are clocked FF's.
3. The maximum operating speed of clock depends on time delays involved.
4. They are easier to design.

### A Synchronous Sequential Circuit

1. In asynchronous circuits, change in input signals can affect memory elements at any instant of time.
2. In asynchronous circuits, memory elements are either unclocked FF's or time delay elements.
3. Since the clock is not present, asynchronous circuits can operate faster than synchronous circuits.
4. more difficult to design.

## → Latches & Flip flops :-

- The most important memory element is the flip-flop which is made up of an assembly of logic gates.
- even though a logic gate by itself has no storage capability, several logic gates can be connected together in ways that permit information to be stored.
- Flip-flops are the basic building blocks of most sequential circuits. Actually, flip-flop is an one-bit

(2)

memory device and it can store either 1 or 0.

- latch is a sequential device that checks all its inputs continuously and changes its outputs accordingly at any time independent of a clock signal.
- It refers to non-clocked flip-flops, because these flip-flops 'latch on' to a 1 or 0 immediately upon receiving the input pulse.
- Difference between latches & flip-flops.

| Latch                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Flip-flop                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <ol style="list-style-type: none"><li>1. A latch is an electronic sequential logic circuit used to store information in an asynchronous arrangement.</li><li>2. one latch can store one bit information, but output state changes only in response to data input.</li><li>3. latch is an asynchronous device and it has no clock input.</li><li>4. latch holds a bit value and it remains constant until new inputs force it to change.</li><li>5. latches are level-sensitive and the output tracks the input when the level is high. Therefore as long as the level is logic level 1, the output can change if the input changes.</li></ol> | <ol style="list-style-type: none"><li>1. A flip flop is an electronic sequential logic circuit used to store information in an asynchronous arrangement.</li><li>2. one flip-flop can store one bit-data, but output state changes with clock pulse only.</li><li>3. flip-flop has clock input and its output is synchronized with clock pulse.</li><li>4. flip-flops holds a bit value and it remains constant until a clock pulse is received.</li><li>5. flip-flops are edge-sensitive. They can store the input only when there is either a rising or falling edge of the clock.</li></ol> |

Difference between combinational, sequential circuits.

| Combinational circuit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Sequential circuits.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <ol style="list-style-type: none"> <li>1. The digital logic circuit where outputs can be determined using the logic function of current state input are combinational logic circuits.</li> <li>2. It contains no memory element.</li> <li>3. Its behaviour is described by the set of output functions.</li> <li>4. The combinational logic circuits are independent of the clock.</li> <li>5. The combinational digital logic circuit don't require any feed back.</li> <li>6. combinational circuits are easy to design.</li> <li>7. combinational circuits are faster because the delay between the input and the output is due to propagation delay of gates only.</li> <li>8. Block diagram</li> </ol>  | <ol style="list-style-type: none"> <li>1. The digital logic circuits whose outputs can be determined using the logic function of current state inputs and past state inputs are called as Sequential logic circuits.</li> <li>2. It contains memory elements.</li> <li>3. Its behaviour is described by the set of next state functions and the set of output functions.</li> <li>4. The maximum sequential logic circuits are uses a clock for triggering the flip-flop operation.</li> <li>5. The sequential digital logic circuits utilize the feedbacks from outputs to inputs.</li> <li>6. Sequential circuits are complex to design.</li> <li>7. Sequential circuits are slower than combinational circuits.</li> <li>8. Block diagram.</li> </ol>  |

## S-R latch :-

The S-R latch has two inputs, namely SET(S) and RESET(R), and two outputs  $a$  and  $\bar{a}$ , where  $\bar{a}$  is the complement of  $a$ .



Logic symbol of S-R latch

## S-R latch using NOR Gates :- [Active-high S-R latch].

The logic diagram of the S-R latch composed of two cross-coupled NOR gates. S and R are two inputs of S-R latch.

→ S stands for set, it means that when S is 1, it stores 1.

→ R stands for reset, and if R=1, latch Reset and it's output will be 0. This circuit is called as NOR gate latch or S-R latch.



simplified truth table.

| S | R | $a_{n+1}$ | State         |
|---|---|-----------|---------------|
| 0 | 0 | 0         | No change     |
| 0 | 1 | 0         | Reset         |
| 1 | 0 | 1         | Set           |
| 1 | 1 | X         | invalid state |

| S | R | $a_n$ | $a_{n+1}$ | State                  |
|---|---|-------|-----------|------------------------|
| 0 | 0 | 0     | 0         | No change              |
| 0 | 0 | 1     | 1         |                        |
| 0 | 1 | 0     | 0         | RESET                  |
| 0 | 1 | 1     | 0         |                        |
| 1 | 0 | 0     | 1         | SET                    |
| 1 | 0 | 1     | 1         |                        |
| 1 | 1 | 0     | X         | indetermined (invalid) |
| 1 | 1 | 1     | X         |                        |

Truth table.

- SET=0, RESET=0 : This is the normal resting state of the NOR latch and it has no effect on the output state.  $Q$  and  $\bar{Q}$  will remain in whatever state they were prior to the occurrence of this input condition.
- SET=0, RESET=1, This will always reset  $Q=0$ , where it will remain even after RESET returns to 0.
- SET=1, RESET=0, This will always set  $Q=1$ , where it will remain even after SET returns to 0.
- SET=1, RESET=1, This condition tries to SET and Reset the latch at the same time, and it produces  $Q=\bar{Q}=0$ . If the inputs are returned to zero simultaneously, the resulting output state is erratic and unpredictable. This input condition should not be used. It is indetermined state or invalid state.

S-R latch using NAND Gates :- (active low S-R latch)

→ The logic diagram of the S-R latch composed of two cross-coupled NAND gates.



logic diagram.

| S | R | $Q_{n+1}$ | State   |
|---|---|-----------|---------|
| 0 | 0 | X         | invalid |
| 0 | 1 | 1         | Set     |
| 1 | 0 | 0         | Reset   |
| 1 | 1 | N.C.      | N.C.    |

| S | R | $Q_n$ | $Q_{n+1}$ | State                     |
|---|---|-------|-----------|---------------------------|
| 0 | 0 | 0     | X         | indetermined<br>(invalid) |
| 0 | 0 | 1     | X         |                           |
| 0 | 1 | 0     | 1         | Set                       |
| 0 | 1 | 1     | 1         |                           |
| 1 | 0 | 0     | 0         | Reset                     |
| 1 | 0 | 1     | 0         |                           |
| 1 | 1 | 0     | 0         | No change                 |
| 1 | 1 | 1     | 1         |                           |

Truth table.

← Simplified truth table.

## Gated latches :-

The gated S-R latch :- The output can change state any time the input conditions are changed, so they are called Asynchronous latches. A gated S-R latch requires an enable (EN) input. Its S and R inputs will control the state of latch only when the enable is high. When the enable is low, the inputs become ineffective and no change of state can take place.



logic symbol.



logic diagram.

| EN | S | R | Q <sub>in</sub> | Q <sub>out</sub> | State                   |
|----|---|---|-----------------|------------------|-------------------------|
| 1  | 0 | 0 | 0               | 0                | No change               |
| 1  | 0 | 0 | 1               | 1                |                         |
| 1  | 0 | 1 | 0               | 0                | Reset                   |
| 1  | 0 | 1 | 1               | 0                |                         |
| 1  | 1 | 0 | 0               | 1                | Set                     |
| 1  | 1 | 0 | 1               | 1                |                         |
| 1  | 1 | 1 | 0               | X                | Indeterminate (invalid) |
| 1  | 1 | 1 | 1               | X                |                         |
| 0  | X | X | 0               | 0                | No change               |
| 0  | X | X | 1               | 1                |                         |



waveforms for Gated S-R latch

The Gated D-latch: - In many applications, it is not necessary to have separate S and R inputs to a latch. If the input combinations  $S=R=0$  and  $S=R=1$  are never needed, the S and R are always the complement of each other. So, to construct a latch with a single input (S) and obtain the R input by inverting it. This single input is labelled D (for data), and the device is called a D-latch.

- when  $D=1$ ,  $S=1$  and  $R=0$ , causing the latch to set when enabled. when  $D=0$ ,  $S=0$  and  $R=1$ , causing the latch to reset when enabled. when EN is low, the latch is ineffective, and any change in the value of D input does not affect the output at all.
- when EN is high, a low D-input makes Q low, i.e. resets the latch and high D input makes Q high, that is sets the latch.
- The output Q follows the D-input when EN is high. so this latch is said to be transparent.

Logic symbol



| EN | D | $Q_m$ | $Q_{m+1}$ | State          |
|----|---|-------|-----------|----------------|
| 1  | 0 | 0     | 0         | Reset          |
| 1  | 0 | 1     | 0         |                |
| 1  | 1 | 0     | 1         | Set            |
| 1  | 1 | 1     | 1         |                |
| X  | X | 0     | 0         | NO change (NC) |
| 0  | X | 1     | 1         |                |

Truth table



logic diagram.



waveforms for Gated D-latch.

Flip-flops :-

Types of flip-flops :-

- S-R flip-flop
- D flip-flop
- J-K flip-flop
- T flip-flop.

## S-R flip-flop:-

logic diagram



symbol of +ve edge trigger.



symbol of - ve edge trigger



Truth table :-

| clk | S | R | Q <sub>n</sub> | Q <sub>n+1</sub> | state         |
|-----|---|---|----------------|------------------|---------------|
| ↑   | 0 | 0 | 0              | 0                | no change     |
| ↑   | 0 | 0 | 1              | 1                |               |
| ↑   | 0 | 1 | 0              | 0                | Reset         |
| ↑   | 0 | 1 | 1              | 0                |               |
| ↑   | 1 | 0 | 0              | 1                | set           |
| ↑   | 1 | 0 | 1              | 1                |               |
| ↑   | 1 | 1 | 0              | X                | invalid state |
| ↑   | 1 | 1 | 1              | X                |               |
| 0   | X | X | 0              | 0                | no change     |
| 0   | X | X | 1              | 1                |               |

Characteristic equation :- The characteristic equation of a flip-flop is the equation expressing the next state of a flip-flop in terms of its present state and present excitations. To obtain the characteristic equation of a.

flip-flop write the excitation requirements of the flip-flop, draw a K-map for the next state of the flip-flop in terms of its present state and inputs and simplify it



$$Q_{n+1} = S + \bar{R}Q_n$$

Truth Table:-

| S | R | $Q_{n+1}$ |
|---|---|-----------|
| 0 | 0 | $Q_n$     |
| 0 | 1 | 0         |
| 1 | 0 | 1         |
| 1 | 1 | X         |

Excitation table :- A table which lists the present state, the next state and the excitations of a flip-flop is called the excitation table.

→ A table which indicates the excitations required to take the flip-flop from the present state to the next state.

| Present State $Q_n$ | next state $Q_{n+1}$ | Required S R |
|---------------------|----------------------|--------------|
| 0                   | 0                    | 0 X          |
| 0                   | 1                    | 1 0          |
| 1                   | 0                    | 0 1          |
| 1                   | 1                    | X 0          |

## Timing diagram



waveforms for S-R flip-flop.

## D- flip - flop:-

### logic diagram



Symbol of +ve edge trigger



Symbol of -ve trigger



Truth table :-

| D | $Q_{n+1}$ |
|---|-----------|
| 0 | 0         |
| 1 | 1         |

Characteristic Table.

| CLK | D | $Q_n$ | $Q_{n+1}$ | State     |
|-----|---|-------|-----------|-----------|
| ↑   | 0 | 0     | 0         | Reset     |
| ↑   | 0 | 1     | 0         |           |
| ↑   | 1 | 0     | 1         | Set       |
| ↑   | 1 | 1     | 1         |           |
| ↑   | X | 0     | 0         | No change |
| ↑   | X | 1     | 1         |           |

Characteristic equation :-

| D | $Q_n$ | 0 | 1 |
|---|-------|---|---|
| 0 | 0     | 0 | 1 |
| 1 | 1     | 1 | 1 |

$$Q_{n+1} = D$$

waveforms

Excitation table :-

| Present state<br>$Q_n$ | Next state<br>$Q_{n+1}$ | D |
|------------------------|-------------------------|---|
| 0                      | 0                       | 0 |
| 0                      | 1                       | 1 |
| 1                      | 0                       | 0 |
| 1                      | 1                       | 1 |



(Positive - edge trigger CLK).



(negative - edge trigger CLK).

(J-K - flip flops)  
logic diagram



logic symbol



(negative-edge)

Truth table :-

| J | K | $Q_{n+1}$ |
|---|---|-----------|
| 0 | 0 | $Q_n$     |
| 0 | 1 | 0         |
| 1 | 0 | 1         |
| 1 | 1 | Toggle    |

characteristic table

| clk | J | K | $Q_n$ | $Q_{n+1}$ | State     |
|-----|---|---|-------|-----------|-----------|
| 0   | 0 | 0 | 0     | 0         | No change |
| 0   | 0 | 1 | 1     | 1         |           |
| 1   | 0 | 0 | 0     | 0         | Reset     |
| 1   | 0 | 1 | 1     | 0         |           |
| 1   | 1 | 0 | 0     | 1         | Set       |
| 1   | 1 | 1 | 0     | 1         |           |
| 1   | 1 | 1 | 1     | 0         | Toggle    |
| 0   | X | X | 0     | 0         | No change |
| 0   | X | X | 1     | 1         |           |

Characteristic equation

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

$$Q_{n+1} = \bar{K}Q_n + J\bar{Q}_n$$

excitation table

| Present state | next state | inputs |
|---------------|------------|--------|
| J             | K          |        |
| 0             | 0          | 0 X    |
| 0             | 1          | 1 X    |
| 1             | 0          | X 1    |
| 1             | 1          | X 0    |

(8)

Waveforms for Positive-edge triggering | negative-edge triggering



T-flip flop :-



Truth table

| T | $Q_{n+1}$   |
|---|-------------|
| 0 | $\bar{Q}_n$ |
| 1 | 0           |

Characteristic table

| CK | T | $Q_n$ | $Q_{n+1}$ | State     |
|----|---|-------|-----------|-----------|
| ↓  | 0 | 0     | 0         | No change |
| ↓  | 0 | 1     | 1         | No change |
| ↓  | 1 | 0     | 1         | Toggle    |
| ↓  | 1 | 1     | 0         | Toggle    |
| ↓  | x | 0     | 0         | No change |
| ↓  | x | 1     | 1         | No change |

Characteristic equation



$$Q_{n+1} = T \bar{Q}_n + \bar{T} Q_n$$

## Excitation table

waveforms.

| $Q_n$ | $Q_{n+1}$ | T |
|-------|-----------|---|
| 0     | 0         | 0 |
| 0     | 1         | 1 |
| 1     | 0         | 1 |
| 1     | 1         | 0 |



## Race - Around condition:-

If the width of the clock pulse  $t_p$  is too long, the state of the flip-flop will keep on changing from 0 to 1, 1 to 0, 0 to 1 and so on, and at the end of the clock pulse, its state will be uncertain. This phenomenon is called the race around condition. The outputs  $q$  and  $\bar{q}$  will change on their own if the clock pulse width  $t_p$  is too long compared with the propagation delay  $T$  of each NAND Gate.

$$t_p > T$$

$t_p \rightarrow$  pulse width

$T \rightarrow$  propagation delay

The clock pulse width should be such as to allow only one change to complement the state and not too long to allow many changes resulting in uncertainty about the final state. This is a stringent requirement which cannot be ensured in practice. Thus problem is eliminated using master-slave flip-flop or edge triggered flip-flop.

## master-slave J-K flip-flop :-

logic diagram :-



Symbol :-



The master-slave flip flop was developed to make the synchronous operation more predictable, that is, to avoid the problems of logic race in clocked flip-flops. This improvement is achieved by introducing a known time delay between the time that the flip-flop responds to a clock pulse and the time the response appears at its output. A master-slave flip-flop is also called a pulse-triggered flip-flop because the length of the time required for its output to change state equals the width of one clock pulse.

In master-slave J-K flip-flop actually contains two flip-flops - a master flip-flop and a slave flip-flop. The control inputs are applied to the master flip-flop and master output is given as input to the

Slave flip-flop: on the rising edge of the clock pulse, the levels on the control inputs are used to determine the output of the master. on the falling edge of the clock pulse, the state of the master is transferred to the slave, whose outputs are quadra.

The master-slave flip-flops function very much like the negative-edge triggered flip-flops except for one more disadvantage. The control inputs must be held stable while CLK is high, otherwise an unpredictable operation may occur. This problem with the master-slave flip-flop is overcome with an improved master-slave version called the master-slave with data lock-out.

waveforms :-



in slave accept the negative edge triggered signal only. master accept the positive-edge triggered signal only.

## master-slave S-R flip-flop :-



| S | R | clk | Q | state   |
|---|---|-----|---|---------|
| 0 | 0 | ↑   | 0 | N.C     |
| 0 | 1 | ↑   | 0 | Reset   |
| 1 | 0 | ↑   | 1 | Set     |
| 1 | 1 | ↑   | 1 | invalid |

Truth table

## master-slave D flip flop :-



Truth table

| D | clk | Q | state |
|---|-----|---|-------|
| 0 | ↑   | 0 | Reset |
| 1 | ↑   | 1 | Set   |

→ Asynchronous inputs (PRESET and CLEAR).

The S-R, D, and J-K inputs are called synchronous inputs, because their effect on the flip-flop output is synchronized with the clock input.

most IC flip-flops also have one or more asynchronous inputs. These asynchronous inputs affect the flip-flop output independently of the synchronous inputs and the clock input. These asynchronous inputs can be used to SET the flip-flop to the 1 state or RESET the flip-flop to the 0 state at any time regardless of the conditions at the other inputs. They are normally labelled PRESET or direct SET or DC SET, and CLEAR or direct RESET or DC CLEAR.

## J-K flip-flop with Active-high Asynchronous inputs :-



Logic diagram.



- When  $\text{PRE} = 0, \text{CLR} = 0$  then  $\text{DC SET} = 1$  and  $\text{DC CLEAR} = 1$ ,  
The Asynchronous inputs are inactive and the flip-flop responds freely to J, K and CLK inputs in the normal way. In other words, the clocked operation can take place.
- When  $\text{PRE} = 0, \text{CLR} = 1$  then  $\text{DC SET} = 0$  and  $\text{DC CLEAR} = 1$
- When  $\text{PRE} = 0, \text{CLR} = 0$  then Asynchronous inputs are inactive and the flip-flop responds freely to J, K and CLK inputs.
- When  $\text{PRE} = 0, \text{CLR} = 1$  then Asynchronous input clear is active then flip flop output is '0'.
- When  $\text{PRE} = 1, \text{CLR} = 0$  then Asynchronous input PRESET is active the flip flop output is '1'.
- When  $\text{PRE} = 1, \text{CLR} = 1$ . This condition should not be used since it can result in an invalid state.

| DC SET<br>(PRE) | DC RESET<br>(CLR) | FF response     |
|-----------------|-------------------|-----------------|
| 0               | 0                 | clock operation |
| 0               | 1                 | $Q = 0$         |
| 1               | 0                 | $Q = 1$         |
| 1               | 1                 | not used.       |

Truth table

## (11)

### J-K flip-flop with Active-low Asynchronous inputs



- When  $\overline{PRE} = 0$  and  $\overline{CLR} = 0$ , this condition should not be used. Since it can result in an invalid state.
- When  $\overline{PRE} = 0$  and  $\overline{CLR} = 1$ , then Asynchronous input PRESET is active then output is '1'.
- When  $\overline{PRE} = 1$  and  $\overline{CLR} = 0$ , then Asynchronous input CLEAR is active then output is '0'.
- When  $\overline{PRE} = 1$  and  $\overline{CLR} = 1$ , Then Asynchronous inputs are inactive the and the flip responds freely to J, K and CLK inputs.

| DC SET<br>(PRE) | DC RESET<br>(CLR) | FF response     |
|-----------------|-------------------|-----------------|
| 0               | 0                 | not used        |
| 0               | 1                 | $Q = 1$         |
| 1               | 0                 | $Q = 0$         |
| 1               | 1                 | clock operation |

Truth table

Truth table for J-K flip-flop (both Asynchronous & Synchronous inputs).

| PRE | CLR | CLK | J | K | $Q$     | $\bar{Q}$ |
|-----|-----|-----|---|---|---------|-----------|
| 1   | 1   | X   | X | X | invalid |           |
| 1   | 0   | X   | X | X | 1       | 0         |
| 0   | 1   | X   | X | X | 0       | 1         |
| 0   | 0   | ↓   | 0 | 0 | 0       | 1         |
| 0   | 0   | ↑   | 0 | 1 | 0       | 1         |
| 0   | 0   | ↓   | 0 | 0 | 1       | 0         |
| 0   | 0   | ↑   | 1 | 1 | 0       | 1         |

X - don't care  
means either '0'  
or '1'.

Similarly S-R flip-flop

| PRE | CLR | CLK | S | R | $Q$     | $\bar{Q}$ |
|-----|-----|-----|---|---|---------|-----------|
| 1   | 1   | X   | X | X | invalid |           |
| 1   | 0   | X   | X | X | 1       | 0         |
| 0   | 1   | X   | X | X | 0       | 1         |
| 0   | 0   | ↓   | 0 | 0 | 0       | 1         |
| 0   | 0   | ↑   | 0 | 1 | 0       | 1         |
| 0   | 0   | ↓   | 1 | 0 | 1       | 0         |
| 0   | 0   | ↑   | 1 | 1 | invalid |           |
| 0   | 0   | 0   | X | X | N.C.    |           |



Similarly for D - flip-flop.

| PRE | CLR | CLK | D | $Q$     | $\bar{Q}$ |
|-----|-----|-----|---|---------|-----------|
| 0   | 1   | X   | X | invalid |           |
| 1   | 0   | X   | X | 1       | 0         |
| 0   | 1   | X   | X | 0       | 1         |
| 0   | 0   | ↓   | 0 | 0       | 1         |
| 0   | 0   | ↑   | 1 | 1       | 0         |



Truth table

## Flip-flop conversions:-

Step 1:- obtain the characteristic table of required flip-flop.

Step 2:- And also obtain the excitation table of available flip-flop.

Step 3:- obtain the expressions for the inputs of the existing flip-flop in terms of the inputs of the required flip-flop and the present state variables of the existing flip-flop and implement them.

Conversion of T-flip-flop to S-R flip flop

Available flip-flop  $\rightarrow$  T-flip flop (Excitation table)

Required flip-flop  $\rightarrow$  S-R flip flop (Characteristic table)

| S | R | $Q_n$ | $Q_{n+1}$ | T |
|---|---|-------|-----------|---|
| 0 | 0 | 0     | 0         | 0 |
| 0 | 0 | 1     | 1         | 0 |
| 0 | 1 | 0     | 0         | 0 |
| 0 | 1 | 1     | 0         | 1 |
| 1 | 0 | 0     | 1         | 1 |
| 1 | 0 | 1     | 1         | 0 |
| 1 | 1 | 0     | X         | X |
| 1 | 1 | 1     | X         | X |



$$T = S \cdot \bar{Q}_n + R \cdot Q_n$$

Logic diagram



→ Conversion of T-flip-flop to D-flip-flop.  
 Available → T-flip-flop → excitation table  
 Required → D-flip-flop → characteristic table.

| D | $\bar{Q}_n$ | $Q_{n+1}$ | T |
|---|-------------|-----------|---|
| 0 | 0           | 0         | 0 |
| 0 | 1           | 0         | 1 |
| 1 | 0           | 1         | 1 |
| 1 | 1           | 1         | 0 |

K-map for T

$$T = D \bar{Q}_n + \bar{D} Q_n$$

logic diagram



→ Construct a D-flip-flop by ~~using~~ using S-R flip-flop.  
 Available → S-R flip-flop → excitation table.  
 Required → D flip-flop → characteristic table.

| D | $\bar{Q}_n$ | $Q_{n+1}$ | S | R |
|---|-------------|-----------|---|---|
| 0 | 0           | 0         | 0 | X |
| 0 | 1           | 0         | 0 | 0 |
| 1 | 0           | 1         | 1 | 0 |
| 1 | 1           | 1         | X | 0 |

K-map for S

$$S = D$$

K-map for R

$$R = \bar{D}$$

logic diagram.



Realize the S-R flip-flop by using J-K flip-flop.

Available  $\rightarrow$  S-R  $\rightarrow$  excitation table

Required  $\rightarrow$  J-K  $\rightarrow$  characteristic table

| J | K | $Q_n$ | $Q_{n+1}$ | S | R |
|---|---|-------|-----------|---|---|
| 0 | 0 | 0     | 0         | 0 | X |
| 0 | 0 | 1     | 1         | X | 0 |
| 0 | 1 | 0     | 0         | 0 | X |
| 0 | 1 | 1     | 0         | 0 | 1 |
| 1 | 0 | 0     | 1         | 1 | 0 |
| 1 | 0 | 1     | 1         | X | 0 |
| 1 | 1 | 0     | 1         | 1 | 0 |
| 1 | 1 | 1     | 0         | 0 | 1 |



$$S = J\bar{Q}_n$$

K-map for R

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

$$R = K\bar{Q}_n$$

Logic diagram:-



Convert J-K flip-flop to T flip-flop

| T | $Q_n$ | $Q_{n+1}$ | J | K |
|---|-------|-----------|---|---|
| 0 | 0     | 0         | 0 | X |
| 0 | 1     | 1         | X | 0 |
| 1 | 0     | 1         | 1 | X |
| 1 | 1     | 0         | X | 1 |

Logic diagram



K-map for J



K-map for K



→ conversion of D-flip flop to T flip-flop.

\* Available  $\rightarrow$  D-flip flop  $\rightarrow$  excitation table

\* Available  $\rightarrow$  T-flip flop  $\rightarrow$  characteristic table

| T | $Q_n$ | $Q_{n+1}$ | D |
|---|-------|-----------|---|
| 0 | 0     | 0         | 0 |
| 0 | 1     | 1         | 1 |
| 1 | 0     | 1         | 0 |
| 1 | 1     | 0         | 1 |

K-map for D.



$$D = T.$$

logic diagram



Counters :- A digital counter is a set of flip-flops whose states change in response to pulses applied at the input to the counter.

- The name itself it indicates, a counter is used to count pulses.
  - counters may be asynchronous counters or synchronous counters. Asynchronous counters are also called ripple counters.
  - In a synchronous counters flip-flops are not triggered simultaneously. The clock does not directly control the time at which every stage changes state.
  - In synchronous counters are clocked such that each FF in the counter is triggered at the same time.
- b) comparison of Synchronous and Asynchronous counters

#### A Synchronous counters

1. In this type of counter FF's are connected in such a way that the output of first FF drives the clock for the second FF, the output of the second FF to the third FF.
2. All the FF's are not clocked simultaneously.
3. Design and implementation is very simple even for more number of states.
4. main drawback of these counters is their low speed as the clock is propagated through a number of FFs before it reaches the last FF.

#### Synchronous counters

1. In this type of counter there is no connection between the output of first FF and clock input of next FF and so on.
2. All the FF's are clocked simultaneously.
3. Design and implementation becomes tedious and complex as the number of states increases.
4. since clock is applied to all the FF's simultaneously the total propagation delay is equal to the propagation delay of only one FF. Hence they are faster.

## Synchronous counters

→ Synchronous counters have the advantages of high speed and less severe decoding problems but the disadvantage of having more circuitry than that of Asynchronous counters.

### Design steps of synchronous counters :-

1. number of flip-flops
2. state diagram
3. choice of flip-flops and excitation table.
4. minimal expression for excitations
5. logic diagram.

→ Design of a synchronous 3-bit up-down counter using J-K FF's

Step 1:- A 3-bit counter requires 3-FRS. It has 8 states.

(000, ..., 111) and all the states are valid.

Step 2:- State diagram



$m=0$  down counting

$m=1$  up counting

Step 3:- Excitation table

| mode ( $m$ ) | Present State<br>$a_3\ a_2\ a_1$ | Next State<br>$a'_3\ a'_2\ a'_1$ | $J_3$ | $K_3$ | $J_2$ | $K_2$ | $J_1$ | $K_1$ |
|--------------|----------------------------------|----------------------------------|-------|-------|-------|-------|-------|-------|
| 0            | 0 0 0                            | 1 1 1                            | 1     | X     | 1     | X     | 1     | X     |
| 0            | 0 0 1                            | 0 0 0                            | 0     | X     | 0     | X     | 0X    | 1     |
| 0            | 0 1 0                            | 0 0 1                            | 0     | X     | X     | 1     | 1     | X     |
| 0            | 0 1 1                            | 0 1 0                            | 0     | X     | X     | 0     | X     | 1     |
| 0            | 1 0 0                            | 0 1 1                            | X     | 1     | 1     | X     | 1     | X     |
| 0            | 1 0 1                            | 1 0 0                            | X     | 0     | 0     | X     | X     | 1     |
| 0            | 1 1 0                            | 1 0 1                            | X     | 0     | X     | 1     | 1     | X     |
| 0            | 1 1 1                            | 1 1 0                            | X     | 0     | X     | 0     | X     | 1     |

| model(m) | PS<br>$\bar{a}_3 \bar{a}_2 \bar{a}_1$ | N.S<br>$a_3 a_2 a_1$ | J <sub>3</sub> | K <sub>3</sub> | J <sub>2</sub> | K <sub>2</sub> | J <sub>1</sub> | K <sub>1</sub> |
|----------|---------------------------------------|----------------------|----------------|----------------|----------------|----------------|----------------|----------------|
| 1..      | 000                                   | 0 0 1                | 0 X            | 0 X            | 1              | X              |                |                |
| 1..      | 001                                   | 0 1 0                | 0 X            | 1 X            | X              | 1              |                |                |
| 1..      | 010                                   | 0 1 1                | 0 X            | X 0            | 1              | X              |                |                |
| 1..      | 011                                   | 1 0 0                | 1 X            | X 1            | X              | 1              |                |                |
| 1..      | 100                                   | 1 0 1                | X 0            | 0 X            | 1              | X              |                |                |
| 1..      | 101                                   | 1 1 0                | X 0            | 1 X            | X              | 1              |                |                |
| 1..      | 110                                   | 1 1 1                | X 0            | X 0            | 1              | X              |                |                |
| 1..      | 111                                   | 0 0 0                | X 1 X          | 1              | X              |                |                |                |

Step 4:- obtain the minimal expression.

| $\bar{a}_3 \bar{a}_2 \bar{a}_1 M$ | 00 | 01 | 11 | 10 |
|-----------------------------------|----|----|----|----|
| $\bar{a}_3 \bar{a}_2$             | 1  |    |    |    |
| 00                                | 0  | 1  | 3  | 2  |
| 01                                | 4  | 5  | 7  | 6  |
| 11                                | X  | X  | X  | X  |
| 10                                | X  | X  | X  | X  |

| $\bar{a}_3 \bar{a}_2 \bar{a}_1 M$ | 00             | 01             | 11             | 10             |
|-----------------------------------|----------------|----------------|----------------|----------------|
| $\bar{a}_3 \bar{a}_2$             | 00             | 01             | 11             | 10             |
| 00                                | X <sub>6</sub> | X <sub>1</sub> | X <sub>3</sub> | X <sub>2</sub> |
| 01                                | X <sub>4</sub> | X <sub>5</sub> | X <sub>7</sub> | X <sub>6</sub> |
| 11                                |                |                | 1              | 14             |
| 10                                | 1              | 13             | 15             | 10             |

$$\bar{a}_3 \bar{a}_2 \bar{a}_1 M J_3 = \bar{a}_2 \bar{a}_1 \bar{M} + \bar{a}_2 \bar{a}_1 M.$$

| $\bar{a}_3 \bar{a}_2 \bar{a}_1 M$ | 00              | 01              | 11              | 10              |
|-----------------------------------|-----------------|-----------------|-----------------|-----------------|
| $\bar{a}_3 \bar{a}_2$             | 1               |                 |                 |                 |
| 00                                | 1               | 1               | X <sub>3</sub>  | X <sub>2</sub>  |
| 01                                | 1               | 1               | X <sub>7</sub>  | X <sub>6</sub>  |
| 11                                | 1 <sub>12</sub> | 1 <sub>13</sub> | X <sub>15</sub> | X <sub>14</sub> |
| 10                                | 1 <sub>8</sub>  | 1 <sub>9</sub>  | X <sub>11</sub> | X <sub>10</sub> |

| $\bar{a}_3 \bar{a}_2 \bar{a}_1 M$ | 00              | 01              | 11              | 10              |
|-----------------------------------|-----------------|-----------------|-----------------|-----------------|
| $\bar{a}_3 \bar{a}_2$             | 00              | 01              | 11              | 10              |
| 00                                | X               | X               | 1 <sub>3</sub>  | 1 <sub>2</sub>  |
| 01                                | X <sub>4</sub>  | X <sub>5</sub>  | 1 <sub>7</sub>  | 1 <sub>6</sub>  |
| 11                                | X <sub>14</sub> | X <sub>15</sub> | 1 <sub>15</sub> | 1 <sub>14</sub> |
| 10                                | X <sub>8</sub>  | X <sub>9</sub>  | 1 <sub>11</sub> | 1 <sub>10</sub> |

| $\bar{a}_3 \bar{a}_2 \bar{a}_1 M$ | 00              | 01              | 11              | 10              |
|-----------------------------------|-----------------|-----------------|-----------------|-----------------|
| $\bar{a}_3 \bar{a}_2$             | 00              | 01              | 11              | 10              |
| 00                                | 1               | 1               | X <sub>3</sub>  | X <sub>2</sub>  |
| 01                                | 1               | 1               | X <sub>7</sub>  | X <sub>6</sub>  |
| 11                                | 1 <sub>12</sub> | 1 <sub>13</sub> | X <sub>15</sub> | X <sub>14</sub> |
| 10                                | 1 <sub>8</sub>  | 1 <sub>9</sub>  | X <sub>11</sub> | X <sub>10</sub> |

$$J_1 = 1$$

| $\bar{a}_3 \bar{a}_2 \bar{a}_1 M$ | 00              | 01              | 11              | 10              |
|-----------------------------------|-----------------|-----------------|-----------------|-----------------|
| $\bar{a}_3 \bar{a}_2$             | 00              | 01              | 11              | 10              |
| 00                                | X               | X               | 1 <sub>3</sub>  | 1 <sub>2</sub>  |
| 01                                | X <sub>4</sub>  | X <sub>5</sub>  | 1 <sub>7</sub>  | 1 <sub>6</sub>  |
| 11                                | X <sub>14</sub> | X <sub>15</sub> | 1 <sub>15</sub> | 1 <sub>14</sub> |
| 10                                | X <sub>8</sub>  | X <sub>9</sub>  | 1 <sub>11</sub> | 1 <sub>10</sub> |

$$K_1 = 1$$

Step 5 :- The logic diagram.



→ design of a synchronous modulo-6 Gray code counter.

Step 1 :- number of flip flops - 3 FF's

Step 2 :- state diagram



Step 3 :-

| Present state                | next state                   | Required excitations      |
|------------------------------|------------------------------|---------------------------|
| $\alpha_3 \alpha_2 \alpha_1$ | $\alpha_3 \alpha_2 \alpha_1$ | $T_3 \quad T_2 \quad T_1$ |
| 0 0 0                        | 0 0 1                        | 0 0 1                     |
| 0 0 1                        | 0 1 1                        | 0 1 0                     |
| 0 1 1                        | 0 1 0                        | 0 0 1                     |
| 0 1 0                        | 1 1 0                        | 0 0 0                     |
| 1 1 0                        | 1 1 1                        | 0 0 1                     |
| 1 1 1                        | 0 0 0                        | 1 1 1                     |

Step 4 :- minimal Expressions :-

| $a_3$ | $a_2$ | $a_1$ | 01 | 11 | 10  |
|-------|-------|-------|----|----|-----|
| 0     |       |       |    |    | (1) |
| 1     | X     | X     | 1  |    |     |

| $a_3$ | $a_2$ | $a_1$ | 00 | 01 | 11 | 10 |
|-------|-------|-------|----|----|----|----|
| 0     |       |       |    |    |    |    |
| 1     | X     | X     | 1  | 1  |    |    |

| $a_3$ | $a_2$ | $a_1$ | 00 | 01 | 11 | 10 |
|-------|-------|-------|----|----|----|----|
| 0     |       |       |    |    |    |    |
| 1     | X     | X     | 1  | 1  | 1  | 1  |

$$T_3 = a_3 a_1 + \bar{a}_3 a_2 \bar{a}_1$$

$$T_2 = a_3 a_1 + \bar{a}_2 a_1$$

$$T_1 = a_3 + a_2 a_1 + \bar{a}_2 \bar{a}_1$$

logic diagram :-



→ Design a synchronous (mod-9) BCD counter using J-K FF's.

Step 1 :- 4 FF's

Step 2 :- State diagram:



Step 3 :- excitation table.

| Present state<br>$\omega_4 \omega_3 \omega_2 \omega_1$ | next state<br>$\omega_4 \omega_3 \omega_2 \omega_1$ | $J_4$ | $K_4$ | $J_3$ | $K_3$ | $J_2$ | $K_2$ | $J_1$ | $K_1$ |
|--------------------------------------------------------|-----------------------------------------------------|-------|-------|-------|-------|-------|-------|-------|-------|
| 0 0 0 0                                                | 0 0 0 1                                             | 0     | X     | 0     | X     | 0     | X     | X     | X     |
| 0 0 0 1                                                | 0 0 1 0                                             | 0     | X     | 0     | X     | 1     | X     | X     | 1     |
| 0 0 1 0                                                | 0 0 1 1                                             | 0     | X     | 0     | X     | X     | 0     | 1     | X     |
| 0 0 1 1                                                | 0 1 0 0                                             | 0     | X     | 1     | X     | X     | 1     | X     | 1     |
| 0 1 0 0                                                | 0 1 0 1                                             | 0     | X     | X     | 0     | 0     | X     | 1     | X     |
| 0 1 0 1                                                | 0 1 1 0                                             | 0     | X     | X     | 0     | 1     | X     | X     | 1     |
| 0 1 1 0                                                | 0 1 1 1                                             | 0     | X     | X     | 0     | X     | 0     | 1     | X     |
| 0 1 1 1                                                | 1 0 0 0                                             | 1     | X     | X     | 1     | X     | 1     | X     | 1     |
| 1 0 0 0                                                | 1 0 0 1                                             | X     | 0     | 0     | X     | 0     | X     | 1     | X     |
| 1 0 0 1                                                | 0 0 0 0                                             | X     | 1     | 0     | X     | 0     | X     | X     | 1     |

Step 4:-

| $\omega_4 \omega_3$ | 00             | 01             | 11              | 10              | $\omega_4 \omega_3$ | 00 | 01 | 11 | 10 | $\omega_4 \omega_3$ | 00 | 01 | 11 | 10 |
|---------------------|----------------|----------------|-----------------|-----------------|---------------------|----|----|----|----|---------------------|----|----|----|----|
| 00                  | 0              | 1              | 3               | 2               | 00                  | X  | X  | X  | X  | 00                  |    |    |    |    |
| 01                  | 4              | 5              | 1               | 6               | 01                  | X  | X  | X  | X  | 01                  | X  | X  | X  | X  |
| 11                  | X <sub>2</sub> | X <sub>3</sub> | X <sub>15</sub> | X <sub>14</sub> | 11                  | X  | X  | X  | X  | 11                  | X  | X  | X  | X  |
| 10                  | X <sub>8</sub> | X <sub>9</sub> | X <sub>11</sub> | X <sub>10</sub> | 10                  |    |    | X  | X  | 10                  |    |    | X  | X  |

$$J_4 = \omega_3 \omega_2 \omega_1$$

$$K_4 = \omega_1$$

$$J_3 = \omega_2 \omega_1$$

| $\omega_4 \omega_3$ | 00 | 01    | 11 | 10 |
|---------------------|----|-------|----|----|
| 00                  |    | (1 X) | X  |    |
| 01                  |    | (1 X) | X  |    |
| 11                  | X  | X     | X  | X  |
| 10                  |    | X     | X  |    |

| $\omega_4 \omega_3$ | 00 | 01 | 11 | 10 |
|---------------------|----|----|----|----|
| 00                  | X  | X  | 1  |    |
| 01                  | X  | X  | 1  |    |
| 11                  | X  | X  | X  | X  |
| 10                  | X  | X  | X  | X  |

| $\omega_4 \omega_3$ | 00 | 01 | 11 | 10 |
|---------------------|----|----|----|----|
| 00                  | X  | X  | X  | X  |
| 01                  |    |    | 1  |    |
| 11                  | X  | X  | X  | X  |
| 10                  | X  | X  | X  | X  |

$$J_2 = \overline{\omega_4} \omega_1$$

$$K_2 = \omega_1$$

$$K_3 = \omega_2 \omega_1$$

Step 4 :- The minimal expression.

| $\bar{Q}_2 Q_1$ | 00 | 01 | 11 | 10 |
|-----------------|----|----|----|----|
| $\bar{Q}_3$     | X  | X  | X  | X  |
| 0               | X  | X  | 1  |    |
| 1               |    | X  | 1  | 0  |

| $\bar{Q}_2 Q_1$ | 00 | 01 | 11 | 10 |
|-----------------|----|----|----|----|
| $\bar{Q}_3$     | X  | X  | 1  | X  |
| 0               | X  | X  |    |    |
| 1               |    | X  | X  | X  |

| $\bar{Q}_2 Q_1$ | 00 | 01 | 11 | 10 |
|-----------------|----|----|----|----|
| $\bar{Q}_3$     | X  | X  | 1  | X  |
| 0               | X  | X  | 1  | X  |
| 1               |    | X  | X  | X  |

$$K_3 = \bar{Q}_1$$

$$K_2 = \bar{Q}_3$$

$$J_3 = 1$$

| $\bar{Q}_2 Q_1$ | 00 | 01 | 11 | 10 |
|-----------------|----|----|----|----|
| $\bar{Q}_3$     | X  | X  | X  | X  |
| 0               | X  | X  |    |    |
| 1               |    | X  | X  | 1  |

$$J_1 = \bar{Q}_2$$

$$K_1 = \bar{Q}_3$$

$$J_2 = 1$$

Step 5 :- logic diagram



logic diagram of the J-K counter.



logic diagram

→ Design a J-K counter that goes through states 3, 4, 6, 7 and 3...  
is the counter self-starting (take remaining states as invalid)

Step 1 :- number of flip-flops - 3 flip-flops

Step 2 :- State diagram



state-diagram

Step 3 :- excitation table

| Present state<br>$\omega_3 \ \omega_2 \ \omega_1$ | next state<br>$\omega_3 \ \omega_2 \ \omega_1$ | Required inputs |                |                |                |                |                |                |                |
|---------------------------------------------------|------------------------------------------------|-----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|
|                                                   |                                                | J <sub>3</sub>  | K <sub>3</sub> | J <sub>2</sub> | K <sub>2</sub> | J <sub>1</sub> | K <sub>1</sub> | J <sub>3</sub> | K <sub>3</sub> |
| 0 1 1                                             | 1 0 0                                          | X               | X              | X              | 1              | X              | 1              | X              | 1              |
| 1 0 0                                             | 1 1 0                                          | X               | 0              | 1              | X              | 0              | X              | 0              | X              |
| 1 1 0                                             | 1 1 1                                          | X               | 0              | X              | 0              | 1              | X              | 1              | X              |
| 1 1 1                                             | 0 1 1                                          | X               | 1              | X              | 0              | X              | 0              | X              | 0              |

| $\bar{Q}_3$ | $\bar{Q}_2$ | $\bar{Q}_1$ | $\bar{Q}_0$ | R =    |
|-------------|-------------|-------------|-------------|--------|
| 0           | 0           | 0           | 1           | 11, 10 |
| 1           | 1           | 1           | X           | 00, 01 |

$$R = \bar{Q}_3 \bar{Q}_2$$



logic diagram.

mod -10 Asynchronous Counter :-

| R | After pulses | Count<br>$Q_3 Q_2 Q_1 Q_0$ |
|---|--------------|----------------------------|
| 0 | 0            | 0 0 0 0                    |
| 0 | 1            | 0 0 0 1                    |
| 0 | 2            | 0 0 1 0                    |
| 0 | 3            | 0 0 1 1                    |
| 0 | 4            | 0 1 0 0                    |
| 0 | 5            | 0 1 0 1                    |
| 0 | 6            | 0 1 1 0                    |
| 0 | 7            | 0 1 1 1                    |
| 0 | 8            | 1 0 0 0                    |
| 0 | 9            | 1 0 0 1                    |
| 1 | 10           | 1 0 1 0                    |



K-map for R

| $\bar{Q}_3 \bar{Q}_2 \bar{Q}_1 \bar{Q}_0$ | 00 01 11 10 |
|-------------------------------------------|-------------|
| 00                                        | 0 1 1 1     |
| 01                                        | 1 0 1 1     |
| 11                                        | X X X K     |
| 10                                        | X K X 1     |

$$R = 0 \text{ for } 0000 \text{ to } 1001$$

$$R = 1 \text{ for } 1010$$

$$R = X \text{ for } 1011 \text{ to } 1111$$

$$R = \bar{Q}_3 \bar{Q}_2$$

## A Synchronous counters :-

- Design a mod-6 Asynchronous counter using T FF's
- A mod-6 counter has six stable states 000, 001, 010, 011, 100, and 101. When six pulse is applied, the counter temporarily goes to 110 state but immediately reset to 000.
- It requires three FF's, because the smallest value of  $n$  satisfying the condition  $N \leq 2^n$  is  $n=3$ . Three FF's can have eight possible states, out of which only six are utilized and remaining two states 110 and 111.
- For the design, To write a truth table with the present state outputs  $a_3, a_2$  and  $a_1$  as the variables, and Reset R as the output.

$R = 0$  for 000 to 101,  $R = 1$  for 110, and  $R = X$  for 111.

Table for R

Timing diagram.

| After pulses | State<br>$a_3\ a_2\ a_1$ | R |
|--------------|--------------------------|---|
| 0            | 0 0 0                    | 0 |
| 1            | 0 0 1                    | 0 |
| 2            | 0 1 0                    | 0 |
| 3            | 0 1 1                    | 0 |
| 4            | 1 0 0                    | 0 |
| 5            | 1 0 1                    | 0 |
| 6            | 1 1 0                    | 1 |
| ↓ ↓ ↓        | 0 0 0                    |   |
| 7            | 1 1 1                    | X |
|              | 0 0 1                    | 1 |





logic-diagram

Asynchronous mod-10 counter using T flip-flops.

- Two-bit ripple up-counter using negative edge-triggered flip-flops.
- The 2-bit up-counter counts in the states  $01, 10, 11, 00, 01, \dots$  etc. A 2-bit ripple up-counter, using negative edge-triggered J-K FFs, The counter initially reset to 00 when first clock pulse is applied, FF<sub>1</sub> toggles at the negative-going edge of this pulse, therefore, Q<sub>1</sub> goes from low to high. This becomes a positive-going signal at the clock input of FF<sub>2</sub>.
- So FF<sub>2</sub> is not affected, and hence, the state of the counter after one clock pulse is Q<sub>1</sub> = 1 and Q<sub>2</sub> = 0.
- So next clock pulse, FF<sub>1</sub> is change to 1 to 0. then negative going edge of this pulse FF<sub>2</sub> is change to 0 to 1. Q<sub>1</sub> = 0 and Q<sub>2</sub> = 1
- So next clock pulse FF<sub>1</sub> is change to 0 to 1. then positive going edge of this pulse FF<sub>2</sub> is no change Q<sub>1</sub> = 1, Q<sub>2</sub> = 1.



logic-diagram



Timing diagram

### 3-bit down - counter using negative - edge triggered J-K flip-flops.



logic diagram

A 3-bit down counter counts in order 0, 1, 2, 3, 4, 5, 6, 7. For down counting  $\bar{Q}_1$  to FF1 is connected to the clock of FF2. the  $\bar{Q}_2$  to FF2 is connected to the clock of FF3. output taken from  $Q_1$ ,  $Q_2$  and  $Q_3$ .



### 3-bit updown counter using negative edge-triggered flip-flops :-

As the name indicates an up-down counter is a counter which can count both in upward and downward directions. An up-down counter is also called a forward/backward counter or a bi-directional counter.

→ So control signal M or mode signal is required to choose the direction of count.

→ When  $M=1$  for up counting,  $M=0$  for down counting. For up-counting  $Q_1$  is transmitted to clock FF2 and for down-counting  $\bar{Q}_1$  is transmitted to clock FF2.

→ This is achieved by using two AND gates and one OR gate.



### Shift registers :-

- As a flip-flop can store only one bit of data, a '0' or a '1', it is referred to as a single-bit register. When more bits of data are to be stored, a number of a number of FF's are used.
- A register is a set of FF's used to store binary data. The storage capacity of a register is the number of bits of digital data it can retain.
- Shift-registers are a type of logic circuits closely related to counters.
- They are used basically for the storage and transfer of digital data. The basic difference between a shift register and counter is that a shift register has no specified sequence of states except in certain very specialized applications.
- whereas a counter has a specified sequence of states.

### Data - Transmission in Shift Registers :-

- A number of flip-flops connected together such that data may be shifted into and shifted out of them is called a shift-register.
- Data may be shifted into & out of the register either in serial form or in parallel form. So, there are four types of shift-registers. They are

1. Serial - in, Serial - out



2. Serial - in, parallel - out



3. parallel - in, serial - out



4. parallel - in, parallel - out



a) shift-right



b) shift-left

Serial - in, serial - out



c) parallel - in, serial output



d) serial - in, serial output



e) serial - in, parallel out shift reg.



f) parallel - in, parallel - out, shift reg.



g) bi-directional shift register.



h) rotate - left shift register.

→ serial - in, serial - out Shift register:-

serial  
input



4-bit serial - in, serial - out, shift right shift register



a) using J-K FF's



b) using S-R FF's



A 4-bit serial-in, serial-out, shift-left shift register.

→ Serial-in, parallel-out, shift register



logic diagram for serial-in, parallel-out



→ Parallel - in, parallel - out, Shift - register:-



→ Parallel - in, serial - out, Shift - register:-

For a parallel - in, serial - out, shift register, the data bits are entered simultaneously into their respective stages on parallel lines, rather than on a bit - by - bit basis over a single line. A 4-bit parallel - in, serial - out, shift register using D-FFs. There are four data lines A, B, C and D through which the data is entered into the register in parallel form.



The signal Shift / Load allows (a) the data to be entered into the register in parallel form. (b) the data to be shifted out serially from terminal  $a_4$ .

- when Shift / Load line is high, gates  $G_1, G_2$  and  $G_3$  are disabled, but  $G_4, G_5, G_6$  are enabled allowing the data bits to shift right from one-stage to the next.
- when Shift / Load line is low, gates  $G_4, G_5$  and  $G_6$  are disabled whereas gates  $G_1, G_2$  and  $G_3$  are enabled allowing the data input to appear at the D inputs of the respective FFs.
- when clock pulse is applied, these data bits are shifted to the  $a$  output terminals of the FFs and, therefore, data is inputted in one step.
- The OR Gate allows either the normal shifting operation or the parallel data entry depending on which AND gates are enabled by the level on the Shift / Load input.

→ Bi-directional shift register :-



4-bit bi-directional shift register.

- A bi-directional shift register is one in which the data bits can be shifted from left to right or from right to left.
- In above figure 4-bit serial-in, serial-out, bi-directional (Shift left, Shift right) shift register.

- when Right/Left is a '1', the logic circuit works as a shift-right shift register.
- when Right/Left is a '0', the logic circuit works as a shift-left shift register.
- The bi-directional operation is achieved by using the mode signal and two AND gates and one OR gate for each stage.
- when mode signal Right/Left is a '1' the 6 AND Gates G<sub>1</sub>, G<sub>2</sub>, G<sub>3</sub> and G<sub>4</sub> are enabled and disables the AND Gates G<sub>5</sub>, G<sub>6</sub>, G<sub>7</sub> and G<sub>8</sub>. and the state of Q output of each FF is passed through the gate to the D input of the following FF.
- when mode signal Right/Left is a '0' the AND Gates G<sub>1</sub>, G<sub>2</sub>, G<sub>3</sub> and G<sub>4</sub> are disabled, and enables the AND gates G<sub>5</sub>, G<sub>6</sub>, G<sub>7</sub> and G<sub>8</sub>. and the state of Q output of each FF is passed through the gate to the D input of the preceding FF.

### Universal shift registers:-



- A register capable of shifting in one direction only is a uni-directional shift register. one that can shift in both directions is a bi-directional shift register.
- If the register has both shifts and parallel load capabilities, it is referred to as a universal shift register.
- A universal shift - register has both shifts as it means whose input can be either in serial form or in parallel form and whose output also can be either in serial form or in parallel form.
- A universal shift register can be realized using multiplexers. it consists of four D- flip flops and four multiplexers.
- The four multiplexers have two common selection inputs  $S_1$  and  $S_0$ . Input 0 in each multiplexer is selected when  $S_1S_0 = 00$  Input 1 is selected when  $S_1S_0 = 01$ , and input 2 is selected when  $S_1S_0 = 10$  and input 3 is selected when  $S_1S_0 = 11$ .
- When  $S_1S_0 = 0$ , the present value of the register is applied to the D - input of flip-flops. This condition forms a path from the output of each flip-flop into the input of the same flip-flop.
- When  $S_1S_0 = 01$ , terminal 1 of the multiplexer inputs have a path to the D inputs of the flip flops. This causes a shift-right operation, with the serial input transferred into flip-flop A4.
- When  $S_1S_0 = 10$ , a shift-left operation results with the other serial input going into flip-flop A1.
- Finally  $S_1S_0 = 11$  the binary information on the parallel

| mode control |       | Register operation |
|--------------|-------|--------------------|
| $S_1$        | $S_0$ |                    |
| 0            | 0     | no change          |
| 0            | 1     | shift right        |
| 1            | 0     | shift left         |
| 1            | 1     | parallel load.     |

input lines is transformed into the register simultaneously during the next clock edge.

### Buffer Register :-

Some registers do nothing more than storing a binary word. The buffer register is the simplest of registers. It simply stores the binary word. The buffer may be a controlled buffer. most of the buffer registers use D-flip flops.

The binary word to be stored is applied to the data terminals. On the application of clock pulse, the output word becomes the same as the word applied at the input terminals. The input word is loaded into the register by the application of clock pulse.



logic diagram of a 4-bit buffer register.

$$a_4 \ a_3 \ a_2 \ a_1 = x_4 \ x_3 \ x_2 \ x_1$$

$$a_i = x_i$$

### Controlled buffer Register :-

In Buffer register is too primitive to be of any use. it needs some control over the  $x$  bits, that is some way of holding them off until we are ready to store them.

- If  $\overline{CLR}$  goes low, all the FFs are RESET and the output becomes,  $a_i = 0000$ .
- When  $\overline{CLR}$  goes high, the register is ready for action.

Load is the control input. When load is high, the data bits  $x$  can reach the  $D$  inputs of FF's. At the positive-going edge of the next clock pulse, the register is loaded.



logic diagram of a 4-bit controlled buffer register.

when Load is low, the  $x$  bits cannot reach the FF's. At the same time, the inverted signal  $\overline{\text{load}}$  is high. This forces each flip-flop output to feed back to its data input. Therefore, data is circulated or retained on each clock pulse arrives. In other words, the contents of the register remain unchanged in spite of the clock pulses.  
 → longer buffer registers can be built by adding more FFs.

→ Shift Register counters :-

Shift register counters are obtained from serial-in serial-out shift-registers by providing feedback from the output of the last FF to the input of the first FF. These devices are called counters because they exhibit a specified sequence of states. The most widely used Shift Register

counter is the ring counter (simple ring counter)

twisted ring counter (Johnson counter or the switch-tail counter)

### Ring counter :-

This is the simplest shift register counter. The basic ring counter using D-FFs. The realization of this counter using J-K FFs is shown below figure. Its flip-flops are arranged as in a normal shift register, that is the  $Q$ -output of each stage is connected to the D-input of the next stage, but the  $Q$ -output of the last FF is connected back to the D-input of the first FF such that the array of FFs is arranged in ring and, therefore, the name ring counter.



logic diagram of a 4-bit ring counter using D-flip-flops.



logic-diagram of 4-bit ring counter using J-K flip-flops.

In most instances, only a single 1 is in the register and it moves to circulate around the register as long as clock pulses are applied. Initially, the first FF is preset to a 1. So, the initial state is 1000, that is  $Q_1=1, Q_2=0, Q_3=0$ .

80

and  $Q_4 = 0$ . After each clock pulse, the contents of the register are shifted to the right by one bit and  $Q_4$  is shifted back to  $Q_1$ . The sequence repeats after four clock pulses. The number of distinct states in the ring counter.

### Twisted Ring Counter :-



|   | $Q_1$ | $Q_2$ | $Q_3$ | $Q_4$ | After clock pulse |
|---|-------|-------|-------|-------|-------------------|
| 1 | 1     | 0     | 0     | 0     | 0                 |
| 2 | 0     | 1     | 0     | 0     | 1                 |
| 3 | 0     | 0     | 1     | 0     | 2                 |
| 4 | 0     | 0     | 0     | 1     | 3                 |
| 5 | 1     | 0     | 0     | 0     | 4                 |
| 6 | 0     | 1     | 0     | 0     | 5                 |
| 7 | 0     | 0     | 1     | 0     | 6                 |
|   | 0     | 0     | 0     | 1     | 7                 |

### Twisted Ring Counter :-

The counter is obtained from a serial-in, serial-out shift register by providing feedback from the inverted output of the last FF to the D input of the first FF. The  $Q_1$  output of each stage is connected to the D input of the next stage, but the  $\bar{Q}_1$  output of the last stage is connected to the D input of first stage, therefore, the name twisted ring counter.



(Q-FF). logic-diagram of 4-bit twisted ring counter



logic-diagram of 4-bit bi-directional ring counter (J-K FF)



waveforms

|   | $Q_1$ | $Q_2$ | $Q_3$ | $Q_4$ | After clk pulse |
|---|-------|-------|-------|-------|-----------------|
| 0 | 0     | 0     | 0     | 0     | 0               |
| 1 | 0     | 0     | 0     | 0     | 1               |
| 2 | 1     | 0     | 0     | 0     | 2               |
| 3 | 1     | 1     | 0     | 0     | 3               |
| 4 | 1     | 1     | 1     | 0     | 4               |
| 5 | 0     | 1     | 1     | 1     | 5               |
| 6 | 0     | 0     | 1     | 1     | 6               |
| 7 | 0     | 0     | 0     | 1     | 7               |
| 8 | 0     | 0     | 0     | 0     | 8               |
| 9 | 1     | 0     | 0     | 0     | 9               |

Sequence table.



state diagram

Let initially all the FFS be reset, that is the state of the counter be 0000. After each clock pulse, the level of  $\alpha_1$  is shifted to  $\alpha_2$ , the level of  $\alpha_2$  to  $\alpha_3$ ,  $\alpha_3$  to  $\alpha_4$  and the level of  $\alpha_4$  to  $\alpha_1$ , and the sequence is repeated after every eight clock pulses.

→ An n FF Johnson counter can have  $2^n$  unique states and can count up to  $2^n$  pulses. So, it is a mod- $2^n$  counter.

### Applications of flip flop :-

1. parallel data storage
2. serial data storage
3. Transfer of data.
4. serial - to - parallel conversion
5. parallel - to - serial conversion
6. counting
7. frequency division.

### Applications of shift register :-

1. Time delays
2. serial / parallel data conversion
3. Ring counters
4. universal Asynchronous receiver transmitter.



## Flip-flop operating characteristics

propagation delay time :- The output of a flip-flop will not change state immediately after the application of the clock signal & of synchronous inputs. The time interval between the time of application of the triggering edge of asynchronous inputs and the time at which the output actually makes a transition is called the "propagation delay" time of the flip-flop. It is usually in the range of a few ns to 1μs.

- propagation delay  $t_{PLH}$  measured from the triggering of the clock pulse to the low-to-high transition of the output.
- propagation delay  $t_{PHL}$  measured from the triggering of the clock pulse to the high-to-low transition of the output.



propagation delays  $t_{PLH}$  and  $t_{PHL}$  w.r.t clk.

- Propagation delay  $t_{PLH}$  measured from the PRESET input to the low-to-high transition of the output
- propagation delay  $t_{PHL}$  measured from the CLEAR input to the high-to-low transition of the output



propagation delays  $t_{PLH}$ ,  $t_{PHL}$  w.r.t. PRESET and CLEAR

Set-up-time :- The set-up-time ( $t_s$ ) is the minimum time for which the control levels need to be maintained constant on the input terminals of the flip-flop, prior to the arrival of the triggering edge of the clock pulse.

hold time :- The hold time ( $t_h$ ) is the minimum time for which the control signals need to be maintained constant at the input terminals of the flip flop, after the arrival of the triggering edge of the clock pulse.

maximum clock frequency :- The maximum clock frequency ( $f_{max}$ ) is the highest frequency at which a flip flop can be reliably triggered. If the clock frequency is above this maximum, the flip-flop would be unable to respond quickly enough and its operation will be unreliable. The  $f_{max}$  limit will vary from one flip flop to another.

pulse widths :- The manufacturer usually specifies the minimum pulse widths for the clock and asynchronous inputs. For the clock signal, the minimum High time  $t_{w(H)}$  and the minimum Low time  $t_{w(L)}$  are specified and for asynchronous inputs,



a) CLK.

minimum pulse widths.

PRE  
S1  
CLR



(b) PRESET & CLEAR

Clock transition times:- For reliable triggering, the clock waveform transition times (rise and fall times) should be kept very short. If the clock signal takes too long to make the transitions from one level to other, the flip-flop may either trigger erratically or not trigger at all.

power dissipation:- The power dissipation of a flip-flop is the total power consumption of the device. It is

$$P = V_{CC} \cdot I_{CC}$$

$V_{CC}$  = supply voltage

$I_{CC}$  = current

The power dissipation of a flip-flop is usually in mW.

If a digital system has  $N$ -flip flops and if each flip-flop dissipates  $P$  mW of power, the total power requirements

$$\begin{aligned} P_{TOT} &= N \cdot V_{CC} \cdot I_{CC} \\ &= \underline{(N \cdot P) \text{ mW}} \end{aligned}$$

