

## UNIT-4

# DIGITAL ELECTRONICS

## NUMBER SYSTEMS

The various number systems are as follows

- i) Decimal number system
- ii) Binary number system
- iii) Octal number system
- iv) Hexadecimal number system.

## DECIMAL NUMBER SYSTEM

\* Decimal number system has base '10'

\* The number starts from 0 to 9 [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]

## BINARY NUMBER SYSTEM

\* Binary number system has base '2'

\* It composed of only two digits 0 and 1

## OCTAL NUMBER SYSTEM

\* Octal number system has base '8'

\* The octal number system uses the digits 0, 1, 2, 3, 4, 5, 6 & 7

## HEXADECIMAL NUMBER SYSTEM

\* Hexadecimal number system has base '16'

\* The number includes 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, A, B, C, D, E, F

\* A, B, C, D, E, F represents the decimals 10, 11, 12, 13, 14, 15 respectively

## DECIMAL TO BINARY CONVERSION

### PROCEDURE

- \* Given decimal number is divided by 2 progressively.
- \* When each division is performed, the remainder either '0' or '1' should write in side.
- \* The process ends when the quotient becomes zero.

Eg: 1

$$\begin{array}{r} 2 | 52 \\ 2 | 26 - 0 \\ 2 | 13 - 0 \\ 2 | 6 - 1 \\ 2 | 3 - 0 \\ \hline 1 - 1 \end{array}$$

$$(110100)_2$$

\* Writing the remainders after each division in the reverse order, the binary number is obtained.

\* This method is called as double-dabble method

Eg : 2

$$(76.36)_{10} \rightarrow ( \quad )_2$$

$$\begin{array}{r} 2 | 76 \\ 2 | 38 - 0 \\ 2 | 19 - 0 \\ 2 | 9 - 1 \\ 2 | 4 - 1 \\ 2 | 2 - 0 \\ \hline 1 - 0 \end{array}$$

|                       | Carry |
|-----------------------|-------|
| $36 \times 2 = 0.72$  | : 0   |
| $72 \times 2 = 1.44$  | : 1   |
| $44 \times 2 = 0.88$  | : 0   |
| $88 \times 2 = 1.76$  | : 1   |
| $76 \times 2 = 1.52$  | : 1   |
| $52 \times 2 = 1.04$  | : 1   |
| $0.4 \times 2 = 0.08$ | : 0   |

$$(1001100)$$

$$(0101110)$$

$$(76.36)_{10} \rightarrow (1001100.0101110)_2$$

\* Right hand side of decimal point is taken and multiplied by 2.  
From the obtained value the carry is written separately.

\* The process continues till the product is zero

\* If zero not obtained do upto 5 iteration.

## BINARY To DECIMAL CONVERSION

Convert the binary number  $1010110_2$  to the decimal equivalent

1 0 1 0 1 1 0  
 |  
 0 x 2<sup>0</sup> = 0  
 |  
 1 x 2<sup>1</sup> = 2  
 |  
 1 x 2<sup>2</sup> = 4  
 |  
 0 x 2<sup>3</sup> = 0  
 |  
 1 x 2<sup>4</sup> = 16  
 |  
 0 x 2<sup>5</sup> = 0  
 |  
 1 x 2<sup>6</sup> = 64  
 |  
 0 (crossed out)  
 \_\_\_\_\_  
 86

Convert the binary number  $(1001100.0101110)_2$  into decimal equivalent.

1 0 0 0 1 1 0 0 . 0 ! 0 , 1 1 0

$0 \times 2^{-7} = 0$

$1 \times 2^{-6} =$

$1 \times 2^{-5}$

$1 \times 2^{-4}$

$0 \times 2^{-3}$

$1 \times 2^{-2}$

$0 \times 2^{-1}$

$0 \times 2^0 =$

$0 \times 2^1 =$

$1 \times 2^2 =$

$1 \times 2^3 =$

$0 \times 2^4 =$

$0 \times 2^5 =$

$1 \times 2^6 =$

= 0

0.015625

0.03125

0.0625

0.25 -

0

0

0

4.0

8.0

0

0

64

---

76.359375

---

## OCTAL To BINARY SYSTEM

1) Convert  $(634)_8$  to binary

$$\begin{array}{ccc} 6 & 3 & 4 \\ (110) & (011) & (100) \end{array}$$

Equivalent binary  $(110011100)_2$

2) Convert  $(725.63)_8$  to binary

$$\begin{array}{ccccc} 7 & 2 & 5 & . & 6 & 3 \\ 111 & 010 & 101 & . & 110 & 011 \end{array}$$

Binary equivalent  $[111010101.110011]_2$

## BINARY To OCTAL SYSTEM

$[11101110]_2 \rightarrow$  to equivalent octal.

$$\begin{array}{ccccc} 0 & 1 & 1 & 1 & 0 \\ \underbrace{\quad\quad\quad}_{3} & \underbrace{0}_{5} & \underbrace{1}_{6} & \underbrace{111}_{15} & 0 \end{array}$$



$$(356)_8$$

## OCTAL to DECIMAL

$(567)_8$  is to decimal equivalent

$$\begin{array}{r}
 5 \quad 6 \quad 7 \\
 | \quad | \quad | \\
 7 \times 8^0 = 7 \\
 6 \times 8^1 = 48 \\
 5 \times 8^2 = \underline{\underline{320}} \\
 \hline
 375
 \end{array}$$

$(235.56)_8$  in to decimal equivalent

2 35 . 56

$$\begin{array}{r}
 | \quad | \quad | \\
 6 \times 8^{-2} = 0.09375 \\
 5 \times 8^{-1} = 0.625 \\
 5 \times 8^0 = 5 \\
 3 \times 8^1 = 24 \\
 2 \times 8^2 = \underline{\underline{128}} \\
 \hline
 [157.71875]_{10}
 \end{array}$$

## DECIMAL To OCTAL

$(489)_{10}$  to octal

$$\begin{array}{r}
 8 \overline{)489} \\
 8 \overline{)61} - 1 \\
 \hline
 7 - 5
 \end{array}$$

$(751)_8$

Convert  $(157.71875)_{10}$  to Octal.

$$\begin{array}{r} 157 \\ 8 \overline{) 19 - 5} \\ 2 - 3 \end{array}$$

$$\begin{aligned} 71875 &\times 8 = 575 & : 5 \\ 0.75 &\times 8 = 6.0 & : 6 \end{aligned}$$

$[235.56]_8$

HEXADECIMAL To BINARY SYSTEM

Convert  $[8D]_{16}$  to binary

Equivalent binary }  $\rightarrow 1000 \downarrow \begin{array}{c} D \\ (13) \\ \downarrow \end{array} 1101 \Rightarrow (10001101)_2$

BINARY To HEXADECIMAL

Convert  $[1110\ 1110]_2$  to Hexadecimal

$$\begin{array}{cc} \underbrace{1110} & \underbrace{1110} \\ 14 & 14 \\ \downarrow & \downarrow \\ E & E \end{array} \rightarrow \text{Equivalent decimal.}$$

$[EE]_{16}$

HEXADECIMAL

To

DECIMAL

Convert

$(5F)_{16}$  to decimal.

5 F

$$\begin{array}{r} \boxed{15 \times 16^0 = 15} \\ \boxed{5 \times 16^1 = \frac{80}{95}} \end{array}$$

$[95]_{10}$

Convert

$(7F.8E)_{16}$  to decimal.

7 F . 8 E

$$\begin{array}{r} \boxed{\boxed{14 \times 16^{-2} = 0.0546875}} \\ \boxed{\boxed{8 \times 16^{-1} = 0.5}} \\ \boxed{\boxed{15 \times 16^0 = 15}} \\ \boxed{\boxed{7 \times 16^1 = 112}} \\ \hline 127.5546875 \end{array}$$

DECIMAL

To

HEXADECIMAL

Convert  $(189)_{10}$  to Hex

$$16 \Big| \begin{array}{r} 189 \\ \hline 11 - 13 \uparrow \end{array}$$

$$\begin{array}{l} 11 \rightarrow B \\ 13 \rightarrow D \end{array}$$

$[B D]_{16}$

Convert  $[127.5546875]_{10}$  to Hex

$$16 \overline{)127} \\ \underline{7 - 15}$$

$$0.5546875 \times 16 = 8.875 : 8$$

$$0.875 \times 16 = 14.0 : 14(E)$$

7 15

$\downarrow$   $\downarrow$

7 F

8 E

$[7F.8E]_{16}$

OCTAL To HEXA DECIMAL

Convert  $(675)_8$  to Hex

6 7 5

110 111 101

$\Downarrow$

000110111101

1 11 13

$\downarrow$   $\downarrow$   $\downarrow$

1 B D

$[1BD]_{16}$

Hexa DECIMAL To OCTAL

Convert  $(AF5)_{16}$  to Octal

A F 5  
 $\Downarrow$   $\Downarrow$   $\Downarrow$

1010 1111 0101

$\Downarrow$

101011110101

5 3 6 5

$[5365]_8$

## BINARY ARITHMETICS

## BINARY ADDITION

## RULES

| A | B | SUM | CARRY |
|---|---|-----|-------|
| 0 | 0 | 0   | 0     |
| 0 | 1 | 1   | 0     |
| 1 | 0 | 1   | 0     |
| 1 | 1 | 0   | 1     |

## EXAMPLE

Add  $(1010)_2$  and  $(0011)_2$

## SOLUTION

$$\begin{array}{r} 1010 \\ 0011 \\ \hline 1101 \end{array} \rightarrow \begin{array}{r} 10 \\ 03 \\ \hline 13 \end{array}$$

Add  $(28)_{10}$  and  $(15)_{10}$  with binary equivalent.

$$\begin{array}{r}
 \begin{array}{c} ① & ① \\ 1 & 1 & 1 & 0 & 0 \end{array} \\
 (28)_{10} \rightarrow
 \end{array}$$
  

$$\begin{array}{r}
 \begin{array}{ccccc} 0 & 1 & 1 & 1 & 1 \end{array} \\
 \hline
 (15)_{10} \rightarrow
 \end{array}$$
  

$$\begin{array}{r}
 \begin{array}{ccccc} 10 & 1 & 0 & 1 & 1 \end{array} \\
 \hline
 (43)_{10} \rightarrow
 \end{array}$$

$$\begin{array}{r}
 2 \overline{)43} \\
 2 \overline{)21} -1 \\
 2 \overline{)10} -1 \\
 2 \overline{)5} \quad 0 \\
 2 \overline{)2} \quad -1 \\
 \hline
 1 \quad 0
 \end{array}$$

$$\begin{array}{r}
 2 | 28 \\
 2 | 14 -0 \\
 2 | 7 -0 \\
 2 | 3 -1 \\
 \hline
 1 -1
 \end{array}$$

$$\begin{array}{r}
 2 \overline{)15} \\
 2 \overline{)7 - 1} \\
 2 \overline{)3 - 1} \\
 \hline
 1 - 1
 \end{array}$$

$$\begin{pmatrix} 4 & 3 \\ 1 & 0 \end{pmatrix}_6 \Rightarrow \begin{pmatrix} 1 & 0 & 1 & 0 & 1 & 1 \end{pmatrix}_2$$

BINARYSUBTRACTIONRULES

| A | B | Digit | Borrow |
|---|---|-------|--------|
| 0 | 0 | 0     | 0      |
| 0 | 1 | 1     | 1      |
| 1 | 0 | 1     | 0      |
| 1 | 1 | 0     | 0      |

EXAMPLE:

Subtract  $(0101)_2$  from  $(1011)_2$

$$\cancel{\begin{array}{r} 1 \\ 0 \end{array}} \begin{array}{r} \xrightarrow{\text{borrow}} \\ 11 \end{array} \rightarrow \frac{\text{Decimal}}{11}$$

$$\begin{array}{r} 0101 \\ - 110 \\ \hline \end{array} \rightarrow \frac{5}{6}$$

Subtract  $(110001)_2$  from  $(1101101)_2$

$$\cancel{\begin{array}{r} 1 \\ 1 \\ 10 \end{array}} \begin{array}{r} 10 \\ 1101 \end{array} \rightarrow 109$$

$$\begin{array}{r} 0110001 \\ - 111100 \\ \hline \end{array} \rightarrow \frac{049}{060}$$

Subtract 01111001 from 11000010

$$\begin{array}{r}
 \begin{array}{ccccccc}
 & 0 & 0 & & & & \\
 & 0 & 1 & 0 & 1 & 0 & 1 \\
 & 0 & 0 & 1 & 0 & 0 & 1 \\
 \hline
 & 1 & 9 & 4 & & & \\
 \end{array} \\
 \hline
 \begin{array}{c}
 0 \quad 1 \quad 1 \quad 1 \quad 0 \quad 0 \quad 1 \\
 \hline
 0 \quad 0 \quad 1 \quad 0 \quad 0 \quad 1 \\
 \hline
 7 \quad 3
 \end{array}
 \end{array}$$

## BINARY

## MULTIPLICATION

$$\underline{9 \times 6}$$

$$\begin{array}{r}
 9 \Rightarrow 1001 \\
 6 \Rightarrow 0110 \\
 \hline
 & 0000 \\
 & 1001x \\
 & 1001xx \\
 & 0000xxx \\
 \hline
 & 110110 \Rightarrow 54
 \end{array}$$

Multiply

$$1011.01 \times 110.1$$

$$\begin{array}{r}
 & 1 & 0 & 11 & . & 01 \\
 & 11 & 0 & . & 1 \\
 \hline
 & 1 & 0 & 11 & 01 \\
 10 & | & 0 & 0 & 000 & x \\
 0 & 0 & 0 & 000 & x \\
 \hline
 & 1 & 0 & 11 & 01 & xx \\
 & 1 & 0 & 11 & 01 & xxx \\
 \hline
 & 100 & 1001.001 & // \\
 \hline
 \end{array}$$

## 1's Complement Representation

Find 1's Complement of  $(1101)_2$  and  $(10111001)_2$

SOLUTION

1101 ← Binary number

0010 ← 1's Complement

10111001 ← Binary number

01000110 ← 1's complement

2's Complement of  $(1001)_2$  and  $(10100011)_2$

\* 1's Complement + 1 will give 2's Complement

SOLUTION

1001

0110 1's complement

$$\begin{array}{r} + 1 \\ \hline 0111 \end{array} \leftarrow 2\text{'s complement}$$

10100011

01011100 1's complement

$$\begin{array}{r} + 1 \\ \hline 01011101 \end{array} \leftarrow 2\text{'s complement}$$

## 1's Complement Subtraction

### CASE:1

Subtraction of smaller number from larger number

#### Method

1. Determine the 1's complement of the smaller number
2. Add the 1's complement to the larger number
3. Remove the carry and add it to the result.

Problem : Subtract  $10101_2$  from  $11100_2$  using 1's complement method

$$\begin{array}{r}
 11100_2 \quad \rightarrow \text{larger number} \\
 010100_2 \quad \rightarrow \text{1's complement of smaller number} \\
 \hline
 1001101 \\
 \text{---} + 1 \quad \rightarrow \text{Add the carry.} \\
 \hline
 001110
 \end{array}$$

### CASE:2

Subtraction of larger number from Smaller number.

#### Method

1. Determine the 1's complement of larger number.
2. Add the 1's complement to the smaller number.
3. The answer is in ones complement form to get the true value find 1's complement again.

### Example:

Subtract  $111001$  from  $101011$  using 1's

Complement method.

$$\begin{array}{r}
 1 \overset{1}{0} \overset{1}{1} 0 \overset{1}{1} \rightarrow \text{smaller number} \\
 0 0 0 1 1 0 \rightarrow 1\text{'s complement of larger} \\
 \hline
 1 1 0 0 0 1 \\
 \end{array}$$

$\Downarrow \Rightarrow$  Finding 1's complement

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

### 2's Complement Subtraction

CASE: I Subtraction of smaller number from larger number.

- Method :
- 1) Determine the 2's complement of the smaller number.
  - 2) Add the 2's complement to the larger number
  - 3) Discard the carry.

EXAMPLE: Subtract  $101011_2$  from  $111001_2$  using 2's complement

$$\begin{array}{r}
 1 1 1 0 \overset{1}{0} \overset{1}{1} \rightarrow \text{smaller number} \\
 0 1 0 1 0 1 \rightarrow 2\text{'s complement} \\
 \hline
 1 0 0 1 1 1 0 \quad \text{of larger number}
 \end{array}$$

2's complement  
of  $101011$   
(1)  $010100$   
1 +  
 $\hline$   
 $010101$

discard the carry

001110 //

CASE: 2 Subtraction of larger number from smaller number using 2's complement.

- Method :
- 1) Determine 2's complement of larger number
  - 2) Add the 2's complement to the smaller number
  - 3) The answer is in 2's complement form, to get the true value find 2's complement again.

Example Subtract  $111001_2$  from  $101011_2$  using 2's complement method.

|                                                                                                                                                                           |                                                                                                                |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|
| $\begin{array}{r} 101011 \\ - 000111 \\ \hline 110010 \end{array}$ <p>↓ Find 2's complement</p> $\begin{array}{r} 001101 \\ + 1 \\ \hline 001110 \end{array}$ <p>← //</p> | <p>2's complement<br/>of larger number,</p> $\begin{array}{r} 111001 \\ + 000110 \\ \hline 000111 \end{array}$ |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|



**Fig. 1.6 Classification of various binary codes**

## 12.2 BCD (8-4-2-1)

BCD is an abbreviation for binary-coded-decimal. BCD is a numeric code in which each digit of a decimal number is represented by a separate group of bits. The most common BCD code is 8-4-2-1 BCD, in which each decimal digit is represented by a 4-bit binary number. It is called 8-4-2-1 BCD because the weights associated with 4 bits are 8-4-2-1 from left to right. This means that, bit 3 has weight 8, bit 2 has weight 4, bit 1 has weight 2 and bit 0 has weight 1.

The Table 1.5 shows the 4-bit 8-4-2-1 BCD code used to represent a single decimal digit. The 8-4-2-1 BCD code is so widely used that it is common practice to refer to it simply as BCD.

| Decimal |   | 8(8) 4(4) 2(2) 1(1) |   |   |  |
|---------|---|---------------------|---|---|--|
| Digit   | 0 | 1                   | 2 | 3 |  |
| 0       | 0 | 0                   | 0 | 0 |  |
| 1       | 0 | 0                   | 0 | 1 |  |
| 2       | 0 | 0                   | 1 | 0 |  |
| 3       | 0 | 0                   | 1 | 1 |  |
| 4       | 0 | 1                   | 0 | 0 |  |
| 5       | 0 | 1                   | 0 | 1 |  |

|   |   |   |   |   |
|---|---|---|---|---|
| 6 | 0 | 1 | 1 | 0 |
| 7 | 0 | 1 | 1 | 1 |
| 8 | 1 | 0 | 0 | 0 |
| 9 | 1 | 0 | 0 | 1 |

Table 1.5 8-4-2-1 BCD code

In multidigit coding, each decimal digit is individually coded with 8-4-2-1 BCD code. For example, 58 in decimal can be encoded in 8-4-2-1 BCD as :



As seen from the above example, in multidigit coding of 8-4-2-1 BCD numbers we require 4-bits per decimal digit. Therefore, total 8-bits are required to encode  $58_{10}$  in 8-4-2-1 BCD. When we represent the same number (58) in binary :  $111010_2$ , we require only 6 digits. This means that, for representing numbers, 8-4-2-1 BCD is less efficient than pure binary number system. The advantage of a BCD code is that it is easy to convert between it and decimal. The principle disadvantage of a BCD, besides its low efficiency, is that arithmetic operations are more complex than they are in pure binary. Let us see the arithmetic operations using 8-4-2-1 BCD.

### 1.12.2.1 BCD Addition

The addition of two BCD numbers can be best understood by considering the three cases that occur when two BCD digits are added.

#### Sum equals 9 or less with carry 0

Let us consider additions of 3 and 6 in BCD.

$$\begin{array}{r}
 6 \quad 0 \ 1 \ 1 \ 0 \quad \leftarrow \text{BCD for 6} \\
 + 3 \quad 0 \ 0 \ 1 \ 1 \quad \leftarrow \text{BCD for 3} \\
 \hline
 9 \quad 1 \ 0 \ 0 \ 1 \quad \leftarrow \text{BCD for 9}
 \end{array}$$

The addition is carried out as in normal binary addition and the sum is 1 0 0 1, which is BCD code for 9.

#### Sum greater than 9 with carry 0

Let us consider addition of 6 and 8 in BCD

$$\begin{array}{r}
 6 \quad 0 \ 1 \ 1 \ 0 \quad \leftarrow \text{BCD for 6} \\
 + 8 \quad 1 \ 0 \ 0 \ 0 \quad \leftarrow \text{BCD for 8} \\
 \hline
 1 \ 4 \quad 1 \ 1 \ 1 \ 0 \quad \leftarrow \text{Invalid BCD number (1110) } > 9
 \end{array}$$

The sum 1 1 1 0 is an invalid BCD number. This has occurred because the sum of the two digits exceeds 9. Whenever this occurs the sum has to be corrected by the addition of six (0110) in the invalid BCD number, as shown below

$$\begin{array}{r}
 6 \quad 0 \ 1 \ 1 \ 0 \quad \leftarrow \text{BCD for } 6 \\
 + 8 \quad 1 \ 0 \ 0 \ 0 \quad \leftarrow \text{BCD for } 8 \\
 \hline
 1 \ 4 \quad 1 \ 1 \ 1 \ 0 \quad \leftarrow \text{Invalid BCD number} \\
 + \quad 0 \ 1 \ 1 \ 0 \quad \leftarrow \text{Add 6 for correction} \\
 \hline
 0 \ 0 \ 0 \ 1 \quad \underbrace{0 \ 1 \ 0 \ 0} \quad \leftarrow \text{BCD for } 14
 \end{array}$$

After addition of 6 carry is produced into the second decimal position.

### Sum equals 9 or less with carry 1

Let us consider addition of 8 and 9 in BCD

$$\begin{array}{r}
 8 \quad 1 \ 0 \ 0 \ 0 \quad \leftarrow \text{BCD for } 8 \\
 + 9 \quad 1 \ 0 \ 0 \ 1 \quad \leftarrow \text{BCD for } 9 \\
 \hline
 17 \quad 0 \ 0 \ 0 \ 1 \ 0 \ 0 \ 0 \ 1 \quad \leftarrow \text{Incorrect BCD result}
 \end{array}$$

In this, case, result (0001 0001) is valid BCD number, but it is incorrect. To get the correct BCD result correction factor of 6 has to be added to the least significant digit sum, as shown.

$$\begin{array}{r}
 8 \quad 1 \ 0 \ 0 \ 0 \quad \leftarrow \text{BCD for } 8 \\
 + 9 \quad 1 \ 0 \ 0 \ 1 \quad \leftarrow \text{BCD for } 9 \\
 \hline
 17 \quad 0 \ 0 \ 0 \ 1 \ 0 \ 0 \ 0 \ 1 \quad \leftarrow \text{Incorrect BCD result} \\
 + \quad 0 \ 0 \ 0 \ 0 \ 0 \ 1 \ 1 \ 0 \quad \leftarrow \text{Add 6 for correction} \\
 \hline
 0 \ 0 \ 0 \ 1 \ 0 \ 1 \ 1 \ 1 \quad \leftarrow \text{BCD for } 17
 \end{array}$$

Going through these three cases of BCD addition we can summarise the BCD addition procedure as follows :

1. Add two BCD numbers using ordinary binary addition.
2. If four-bit sum is equal to or less than 9, no correction is needed. The sum is in proper BCD form.
3. If the four-bit sum is greater than 9 or if a carry is generated from the four-bit sum, the sum is invalid.
4. To correct the invalid sum, add  $0110_2$  to the four-bit sum. If a carry results from this addition, add it to the next higher-order BCD digit.

### 1.12.5 Gray Code

Gray code is a special case of unit-distance code. In unit-distance code, bit patterns for two consecutive numbers differ in only one bit position. These codes are also called cyclic codes. The Table 1.10 shows the bit patterns assigned for gray code from decimal 0 to decimal 15.

| Decimal Code | Gray code |
|--------------|-----------|
| 0            | 0000      |
| 1            | 0001      |
| 2            | 0011      |
| 3            | 0010      |
| 4            | 0110      |
| 5            | 0111      |
| 6            | 0101      |
| 7            | 0100      |
| 8            | 1100      |
| 9            | 1101      |
| 10           | 1111      |
| 11           | 1110      |
| 12           | 1010      |
| 13           | 1011      |
| 14           | 1001      |
| 15           | 1000      |



Table 1.10 Gray code

As shown in the Table 1.10 for gray code any two adjacent code groups differ only in one bit position. The gray code is also called reflected code. Notice that the two least significant bits for  $4_{10}$  through  $7_{10}$  are the mirror images of those for  $0_0$  through  $3_{10}$ . Similarly, the three least significant bits for  $8_{10}$  through  $15_{10}$  are the mirror images of those for  $0_{10}$  through  $7_{10}$ . In general, the  $n$  least significant bits for  $2^n$  through  $2^{n+1} - 1$  are the mirror images of those for 0 through  $2^n - 1$ . This observation gives us a method for counting in gray code.

Another property of gray code is that the gray-coded number corresponding to the decimal number  $2^n - 1$ , for any  $n$ , differs from gray coded 0 (0000) in one bit position only. For example, for  $n = 2, 3$  and  $4$ , we see that

$$2^2 - 1 = 3_{10} = 0010 \text{ in gray}$$

$$2^3 - 1 = 7_{10} = 0100 \text{ in gray and}$$

$$2^4 - 1 = 15_{10} = 1000 \text{ in gray}$$

Each differ from 0000 in one bit position only. This property places the gray code for the largest n-bit binary number at unit distance from 0.

### 1.12.5.1 Advantage of Gray Code

Let us consider an application where 3-bit binary code is provided to indicate position of the rotating disk. As shown in the Fig. 1.7, brushes are used to indicate black and white portions on the disk. When the brushes are on the black portion, they output a 1. When on the white portion, they output a 0.



Fig. 1.7 Position indication using binary and gray codes

Now consider what happens when the brushes are on the 111 sector and almost ready to enter the 000 sector. If one brush is slightly ahead of the other, say the 3<sup>rd</sup> brush, then the position is indicated by a 011 instead of a 111 or 000. This results, a 180° error in the disk position. Since it is physically impossible to have all the brushes precisely aligned, some error will always be present at the edges of the sectors.

If we use gray code to represent disk position then error due to improper brush alignment can be reduced. This is because the gray code assures that only one bit will change each time the decimal number is incremented. So in 3-bit code, error may occur due to one bit position. Other two bits positions of two adjacent sectors are always same and hence there is no possibility of error. Therefore in 3-bit code probability of error is reduced upto 66%. In case of 4-bit code it is reduced upto 75%.

### 1.12.5.2 Gray-to-Binary Conversion

The gray to binary code conversion can be achieved using following steps.

1. The most significant bit of the binary number is the same as the most significant bit of the gray code number. So write it down.

2. To obtain the next binary digit, perform an exclusive-OR-operation between the bit just written down and the next gray code bit. Write down the result.
3. Repeat step 2 until all gray code bits have been exclusive-ORed with binary digits. The sequence of bits that have been written down is the binary equivalent of the gray-code number.

Example 1.58 : Convert gray code 101011 into its binary equivalent.

**Solution :**



Fig. 1.8

#### 1.12.5.3 Binary to Gray Conversion

Let us represent binary number as

$B_1 B_2 B_3 B_4 \dots B_n$  and its equivalent gray code as

$G_1 G_2 G_3 G_4 \dots G_n$ .

With this representation gray code bits are obtained from the binary bits as follows :

$$G_1 = B_1$$

$$G_2 = B_1 \oplus B_2$$

$$G_3 = B_2 \oplus B_3$$

$$G_4 = B_3 \oplus B_4$$

:

$$G_n = B_{n-1} \oplus B_n$$

Example 1.59 : Convert 10111011 in binary into its equivalent gray code.

**Solution :**



Fig. 1.9

# BOOLEAN ALGEBRA

## RULES

RULE 1:  $0 + A = A$   
 $A + 0 = A$

RULE 2:  $1 + A = 1$   
 $A + 1 = 1$

RULE 3:  $A + A = A$

RULE 4:  $A + \bar{A} = 1$   
 $\bar{A} + A = 1$

RULE 5:  $0 \cdot A = 0$   
 $A \cdot 0 = 0$

RULE 6:  $1 \cdot A = A$   
 $A \cdot 1 = A$

RULE 7:  $A \cdot A = A$

RULE 8:  $A \cdot \bar{A} = 0$   
 $\bar{A} \cdot A = 0$

RULE 9:  $\bar{\bar{A}} = A$  (Involution)

## Laws

LAW 1:  $A + B = B + A$   
 $AB = BA$  } Commutative law.

LAW 2:  $A + (B + C) = (A + B) + C$   
 $(AB)C = A(BC)$  } Associative law.

LAW 3:  $A(B + C) = AB + AC$   
 $A + BC = (A + B)(A + C)$  } Distributive law.

## ADDITIONAL RULES

$$* A + AB = A$$

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

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

## THEOREMS

### DeMorgan's Theorems

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

$$2) \overline{A+B} = \bar{A}\bar{B}$$

CONSENSUS

THEOREM

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

### PROOF FOR ADDITIONAL RULES

$$1) A + AB = A$$

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

$$2) A + \bar{A}B$$

According to distributive law

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

$$3) AB + \bar{A}C + BC$$

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

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

$$= AB \underbrace{(1+C)}_{1} + \bar{A}C \underbrace{(1+B)}_{1} = AB + \bar{A}C //$$

## PROBLEMS

i) Simplify the Boolean Expression.

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

Solution

$$A + B + \bar{A}\bar{B}C + \bar{A}\bar{B}\bar{C}D \quad \left\{ \because A + \bar{A}B = A + B \right.$$

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

$$A + B + \bar{A}\bar{B}[C + D] \quad \left\{ \because C + \bar{C}D = C + D \right.$$

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

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

$$A + D + B + C$$

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

$$ii) Y = \bar{A}B + ABD + A\bar{B}C\bar{D} + BC$$

Solution

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

$$= B(\bar{A} + D) + C(B + A\bar{D}) \quad \left\{ \because A + \bar{A}B = A + B \right.$$

$$= \bar{A}B + BD + BC + AC\bar{D}$$

$$= \bar{A}B + BD + BC(A + \bar{A}) + AC\bar{D} \quad (A + \bar{A} = 1)$$

$$= \bar{A}B + BD + ABC + \bar{A}BC + AC\bar{D}$$

$$= \bar{A}B(1 + C) + BD + ABC + AC\bar{D}$$

$$= \bar{A}B + BD + AC\bar{D} + ABC$$

$$= \underline{\bar{A}B + BD + AC\bar{D}}$$

$$\left\{ \therefore 1 + C = 1 \right.$$

Consensus theorem

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

$$DB + \bar{D}AC + BAC$$

$$= DB + \bar{D}AC$$

$$= BD + AC\bar{D}$$

$$\text{iii) } A\bar{B}C + \bar{A}BC + \bar{A}\bar{B}C$$

Solution

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

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

$$\left\{ \therefore B + \bar{B} = 1 \right.$$

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

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

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

$$\therefore \left\{ \begin{array}{l} \cancel{A + \bar{A}B} = \cancel{A + B} \\ \cancel{\bar{A} + A\bar{B}} = \cancel{\bar{A} + \bar{B}} \end{array} \right.$$

$$\text{iv) } A(\bar{A} + AB)$$

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

$$\left\{ \therefore \bar{A} + AB = \bar{A} + B \right.$$

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

$$= \underbrace{A \cdot \bar{A}}_0 + A \cdot B$$

$$\left\{ \therefore A \cdot \bar{A} = 0 \right.$$

$$= AB //$$

## 2.6 Minimization of Boolean Expression

We know that Boolean functions can be realised by logic gates. The number of gates required and the number of input terminals for the gates for the implementation of a Boolean function, in general, get reduced considerably if the Boolean function can be simplified. Therefore, the simplification of Boolean function is very important as it saves the hardware required and hence the cost for design of specific Boolean function. Let us see some examples to illustrate the Boolean equation simplification.

### Examples

$$\text{Ex. 2.7 : } A \cdot \bar{A}C = 0.C \\ = 0$$

Rule 8 :  $[A\bar{A} = 0]$

Rule 5 :  $[A \cdot 0 = 0]$

$$\text{Ex. 2.8 : } ABCD + ABD = ABD(C + 1) \\ = ABD \cdot 1 \\ = ABD$$

Distributive law

Rule 2 :  $[A + 1 = 1]$

Rule 6 :  $[A \cdot 1 = A]$

$$\text{Ex. 2.9 : } ABCD + A\bar{B}CD = ACD(B + \bar{B}) \\ = ACD \cdot 1 \\ = ACD$$

Distributive law

Rule 4 :  $[B + \bar{B} = 1]$

Rule 6 :  $[A \cdot 1 = A]$

$$\text{Ex. 2.10 : } A(A + B) = AA + AB \\ = A + AB \\ = A(1 + B) \\ = A$$

Distributive law

Rule 7 :  $[A \cdot A = A]$

Distributive law

Rule 2 :  $[A + 1 = 1]$

**Ex. 2.11 :**

$$AB + ABC + AB(D + E) = AB(1 + C + D + E) \\ = AB.$$

Rule 2 :  $[A + 1 = 1]$

$$\text{Ex. 2.12 : } XY + XYZ + XY\bar{Z} + \bar{X}YZ \\ = XY(1 + Z) + XY\bar{Z} + \bar{X}YZ \\ = XY + XY\bar{Z} + \bar{X}YZ \\ = XY(1 + \bar{Z}) + \bar{X}YZ \\ = XY + \bar{X}YZ \\ = Y(X + \bar{X}Z) \\ = Y(X + Z)$$

Rule 2 :  $[A + 1 = 1]$

Rule 2 :  $[A + 1 = 1]$

Rule 11 :  $[A + \bar{A}B = A + B]$

**Ex. 2.13 :**

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

Rule 4 :  $[A + \bar{A} = 1]$

Distributive law

Rule 11 :  $[A + \bar{A}B = A + B]$

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

$$\begin{aligned} \text{L.H.S.} &= AC(\bar{B} + \bar{B}) + A\bar{B}\bar{C} \\ &= AC \cdot 1 + A\bar{B}\bar{C} \\ &= AC + AB\bar{C} \\ &= A(C + B\bar{C}) \\ &= A(C + B) \end{aligned}$$

Distributive law

Rule 4 :  $[A + \bar{A} = 1]$

Rule 6 :  $[A \cdot 1 = A]$

Distributive law

Rule 11 :  $[A + \bar{A}B = A + B]$

$$\begin{aligned} \text{Ex. 2.15 : } \bar{A}B\bar{C}\bar{D} + B\bar{C}\bar{D} + B\bar{C}D &= B\bar{C}\bar{D}(\bar{A} + 1) + B\bar{C}\bar{D} + B\bar{C}D \\ &= B\bar{C}\bar{D} + B\bar{C}\bar{D} + B\bar{C}D \\ &= B\bar{D}(C + \bar{C}) + B\bar{C}D \\ &= B\bar{D} + B\bar{C}D \\ &= B(\bar{D} + \bar{C}D) \\ &= B(\bar{D} + \bar{C}) \end{aligned}$$

Distributive law

Rule 2 :  $[A + 1 = 1]$

Distributive law

Rule 4 :  $[A + \bar{A} = 1]$

Distributive law

Rule 11 :  $[A + \bar{A}B = A + B]$

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

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

Distributive law

Rule 3 :  $[A + A = A]$

Distributive law

Rule 11 :  $A + \bar{A}B = A + B$

$$\text{Ex. 2.17 : } \bar{A}B\bar{C}\bar{D} + \bar{A}B\bar{C}D + ABD$$

$$\begin{aligned} &= \bar{A}BD(\bar{C} + C) + ABD \\ &= \bar{A}BD + ABD \\ &= BD(\bar{A} + A) \\ &= BD \end{aligned}$$

Distributive law

Rule 4 :  $[A + \bar{A} = 1]$

Distributive law

Rule 4 :  $[A + \bar{A} = 1]$

$$\text{Ex. 2.18 : } A + \bar{A}B + A\bar{B} = A + B$$

$$\begin{aligned} \text{L.H.S.} &= A + \bar{A}B + A\bar{B} \\ &= A + B + A\bar{B} \\ &= A + A + B \\ &= A + B \end{aligned}$$

Rule 11 :  $[A + \bar{A}B = A + B]$

Rule 11 :  $[A + A = A]$

Rule 5 :  $[A + A = A]$

$$\text{Ex. 2.19 : } \overline{AB} + A + AB$$

$$\begin{aligned} &= \overline{\bar{A} + \bar{B} + A + AB} \\ &= \overline{\bar{A} + \bar{B} + \bar{A} + B} \\ &= \overline{\bar{A} + 1} \end{aligned}$$

Theorem 1 :  $\overline{AB} = \bar{A} + \bar{B}$

Rule 11 :  $[A + \bar{A}B = A + B]$

Rule 3 :  $[A + A = A]$  and

Rule 4 :  $[A + \bar{A} = 1]$

$= \bar{1}$

$= 0$

Rule 2 :  $[A + 1 = 1]$

Ex. 2.20 :  $AB + \overline{AC} + A\overline{B}C (AB + C)$

$= AB + \overline{AC} + AAB\bar{B} BC + A\bar{B} CC$

Distributive law

$= AB + \overline{AC} + A\bar{B} CC$

Rule 8 :  $[A \cdot \bar{A} = 0]$

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

Rule 7 :  $[A \cdot A = A]$

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

Theorem 1 :  $[\overline{AB} = \bar{A} + \bar{B}]$

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

Rule 11 :  $[A + \bar{A}B = A + B]$

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

Commutative law

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

Rule 11 :  $[A + \bar{A}B = A + B]$

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

Here  $B = \bar{B} C$

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

Commutative law

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

Rule 11 :  $[A + \bar{A}B = A + B]$

$= 1$

Rule 4 :  $[A + \bar{A} = 1]$

Rule 2 :  $[A + 1 = 1]$

Example 2.21 : Simplify the expression  $Z = A B + A \bar{B} \cdot (\overline{A}\overline{C})$ .

Solution :

Step 1 : Apply the DeMorgan's theorem and multiply out all terms to get expression in sum of products form

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

De Morgan's theorem 1

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

Rule 9 :  $[\bar{\bar{A}} = A]$

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

Distributive law

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

Step 2 : Search for common terms for factorization and apply boolean rules

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

Rule 7 :  $[AA = A]$

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

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

Rule 2 :  $[1 + C = 1]$

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

Rule 4 :  $[A + \bar{A} = 1]$

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

$= A$

Example 2.48 : Simplify the following expression

$$\begin{aligned}
 Y &= (A + B)(\bar{A} + C)(\bar{B} + \bar{C}) \\
 \text{Solution :} &= (\bar{A}\bar{A} + A\bar{C} + \bar{A}B + BC)(\bar{B} + \bar{C}) \\
 &= (AC + \bar{A}B + BC)(\bar{B} + \bar{C}) && \text{Rule 8 : } [\bar{A}\bar{A} = 0] \\
 &= A\bar{B}C + ACC\bar{C} + \bar{A}B\bar{B} + \bar{A}B\bar{C} + B\bar{B}C + BCC\bar{C} \\
 &= A\bar{B}C + \bar{A}B\bar{C} && \text{Rule 8 : } [A\bar{A} = 0]
 \end{aligned}$$

Example 2.49 : Simplify each of the following using Demorgan's theorem

$$a) \overline{(A+B)(\bar{A}+B)}$$

$$b) \overline{\overline{ABC}D}$$

Solution :

$$\begin{aligned}
 a) &\overline{(A+B)(\bar{A}+B)} \\
 &= \overline{A+\bar{B}} + \overline{\bar{A}+B} && \text{DeMorgan's theorem 1} \\
 &= \overline{A} \cdot \overline{\bar{B}} + \overline{\bar{A}} \cdot \overline{B} && \text{DeMorgan's theorem 2} \\
 &= \overline{A} \cdot B + A \cdot \overline{B} && \text{Rule 9 : } [\overline{\overline{A}} = A] \\
 &= A \oplus B
 \end{aligned}$$

$$\begin{aligned}
 b) &\overline{\overline{ABC}D} \\
 &= \overline{\overline{ABC} + \bar{D}} && \text{DeMorgan's theorem 1} \\
 &= \overline{ABC} + \overline{\bar{D}} && \text{Rule 9 : } [\overline{\overline{A}} = A] \\
 &= (\overline{A} + \overline{B})C + \overline{D} && \text{DeMorgan's theorem 1}
 \end{aligned}$$

Example 2.50 : Verify the following Boolean algebraic manipulation. Justify each step with a reference to a postulate or theorem :

$$i) (X + \bar{Y} + XY)(X + \bar{Y})\bar{X}Y = 0$$

$$ii) (AB + C + D)(\bar{C} + D)(\bar{C} + D + E) = ABC\bar{C} + D$$

Solution : i)  $(X + \bar{Y} + XY)(X + \bar{Y})(\bar{X}Y)$

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

## EXAMPLE

Simplify the following expressions using Boolean algebra:

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

According to the rule  $A + AB = A$

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

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

According to the  $1 + A = 1$

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

$$= A (1)$$

$$= A //$$

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

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

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

$$= \bar{A}C + BC \quad \therefore A + 1 = 1$$

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

$$(c) A\bar{B}C (\bar{B}D + CDE) + A\bar{C}$$

$$= A\underbrace{\bar{B}BCD}_0 + A\bar{B}\underbrace{CCDE}_C + A\bar{C}$$

$$\because A \cdot \bar{A} = 0$$

$$A \cdot A = A$$

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

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

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

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

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

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

## 15.6 LOGIC GATES

The basic elements that make up a digital system are called as logic gates. The most common logic gates are OR, AND, NOT, NAND and NOR gates. The NAND and NOR gates are called as universal gates. Exclusive-OR gate is another logic circuit which can be constructed using AND, OR and NOT gates.

### 15.6.1 OR Gate

The OR gate performs logical addition, commonly known as OR function. The OR gate has two or more inputs and only one output. The operation of OR gate is such that a high (1) on the output is produced when any of the inputs is high (1). The output is low (0) only when all the inputs are low (0).

As shown in Fig. 15.1, A and B represent the inputs and Y the output. Resistance R is the load resistance.

If  $A = 0$  and  $B = 0$  then  $V_o = 0$  and  $Y = 0$ .

If  $A = 1$  and  $B = 0$ , diode  $D_1$  will conduct and so the output  $Y = 1$ .

If  $A = 0$  and  $B = 1$ , diode  $D_2$  will conduct and the output  $Y = 1$ .

If  $A = 1$  and  $B = 1$ , both the diodes will conduct and so the output  $Y = 1$ .



Fig. 15.1 (a) Circuit diagram of an OR gate, (b) Electrical equivalent of an OR gate, (c) Logic symbol

The electrical equivalent circuit of an OR gate is shown in Fig. 15.1(b) where switches A and B are connected in parallel with each other. If either A, B or both are closed, then the output will result. The logic symbol for OR gate is shown in Fig. 15.1(c). The logic operation of the two input OR gate is described in the truth table shown in Table 15.3.

Table 15.3 Truth table for the two-input OR gate

| Input |   | Output |
|-------|---|--------|
| A     | B | Y      |
| 0     | 0 | 0      |
| 0     | 1 | 1      |
| 1     | 0 | 1      |
| 1     | 1 | 1      |

### 15.6.2 AND Gate

The AND gate performs logical multiplication, commonly known as AND function. The AND gate has two or more inputs and a single output. The output of AND gate is high only when all the inputs are high. When any of the inputs is low, the output is low.

As shown in the Fig. 15.2(a), A and B represent the inputs and Y represents the output.

If  $A = 0$  and  $B = 0$ , both diodes conduct as they are forward biased and the output  $Y = 0$ .

If  $A = 0$  and  $B = 1$ , diode  $D_1$  conducts and  $D_2$  does not conduct, and again the output  $Y = 0$ .

If  $A = 1$  and  $B = 0$ , diode  $D_1$  does not conduct and  $D_2$  conducts, and the output  $Y = 0$ .

If  $A = 1$  and  $B = 1$ , both the diodes do not conduct as they are reverse biased and so the output  $Y = 1$ .



Fig. 15.2 (a) Circuit diagram of an AND gate, (b) Electrical equivalent of an AND gate, (c) Logic symbol

The electrical equivalent circuit of an AND gate is shown in Fig. 15.2 (b) where two switches  $A$  and  $B$  are connected in series. If both  $A$  and  $B$  are closed, then only output will result. Logic symbol of the AND gate is shown in Fig. 15.2(c). The logic operation of the two input AND gate is described in the truth table shown in Table 15.4.

Table 15.4 Truth table for a two-input AND gate

| Input |     | Output |
|-------|-----|--------|
| $A$   | $B$ | $y$    |
| 0     | 0   | 0      |
| 0     | 1   | 0      |
| 1     | 0   | 0      |
| 1     | 1   | 1      |

### 15.6.3 NOT Gate (Inverter)

The NOT gate performs a basic logic function called inversion or complementation. The purpose of the gate is to change one logic level to opposite level. It has one input and one output. When a high level is applied to an inverter input, a low level will appear at its output and vice-versa. The operation of the circuit can be explained as follows. When a high voltage is applied to the base of the transistor, base current increases and the transistor is saturated. The transistor now acts as a closed switch and conducts heavily. Thus the output voltage is logic 0. On the other hand, when a low voltage is applied at the base, the transistor is cut-off due to very low or no base current. Now, the transistor can be considered as an open switch, with no current flowing through it. The output is now clamped to the supply voltage. The transistor when operated between cut-off and saturation will act as a switch.



Fig. 15.3 (a) Circuit diagram of an INVERTER gate (b) Logic symbol

As shown in Fig. 15.3(a),  $A$  represents the input and  $y$  represents the output. If the input is high, the transistor is in ON state and the output is low. If the input is low, the transistor is in OFF state and the output is high. The symbol for the inverter is shown in Fig. 15.3(b). The truth table is given in Table 15.5.

| Input |     | Output |
|-------|-----|--------|
| $A$   | $y$ |        |
| 0     | 1   |        |
| 1     | 0   |        |

### 15.6.4 NAND Gate

NAND is a contraction of NOT-AND. It has two or more inputs and only one output. When all the inputs are high, the output is low. If any of the inputs is low, the output is high. The logic symbol for the NAND gate is shown in Fig. 15.4.

The truth-table for the NAND gate is shown in Table 15.6.

Table 15.6 Truth table for NAND gate

| Input |     | Output |
|-------|-----|--------|
| $A$   | $B$ | $y$    |
| 0     | 0   | 1      |
| 0     | 1   | 1      |
| 1     | 0   | 1      |
| 1     | 1   | 0      |



Fig. 15.4 Logic symbol for the NAND gate

The NAND gate is a very popular logic function because it is an universal function; that is, it can be used to construct an AND gate, an OR gate, and INVERTER or any combination of these functions. Figure 15.5 shows how NAND gates can be connected to realize various logic gates.



Fig. 15.5 NAND gates connected to realize (a) OR (b) AND and (c) NOT gates

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

### 15.6.5 NOR Gate

NOR is a contraction of NOT-OR. It has two or more inputs and only one output. Only when all the inputs are low, the output is high. If any of the inputs is high, the output is low. The logic symbol for the NOR gate is shown in Fig. 15.6.

The truth-table for the NOR gate is shown in Table 15.7.

**Table 15.7 Truth table for NOR gate**

| Input |   | Output<br>Y |
|-------|---|-------------|
| A     | B |             |
| 0     | 0 | 1           |
| 0     | 1 | 0           |
| 1     | 0 | 0           |
| 1     | 1 | 0           |

The NOR gate is also a very popular logic function because it is also an universal function; that is, it can be used to construct an AND gate, an OR gate, and INVERTER or any combination of these functions. Figure 15.7 shows how NOR gates can be connected to realize various logic gates.



**Fig. 15.7** NOR gates connected to realize (a) OR (b) AND and (c) NOT gates

### 15.6.6 Exclusive-OR (Ex-OR) Gate

An Exclusive-OR Gate is a gate with two or more inputs and one output. The output of a two-input Ex-OR gate assumes a HIGH state if one and only one input assumes



**Fig. 15.6 Logic symbol for NOR gate**

a HIGH state. This is equivalent to saying that the output is HIGH if either input A or input B is HIGH exclusively, and low when both are 1 or 0 simultaneously.

The logic symbol for the Ex-OR gate is shown in Fig. 15.8 (a) and the truth table for the Ex-OR operation is given in Table 15.8.



**Fig. 15.8 Ex-OR gate**

**Table 15.8 Truth table of a 2-input Ex-OR gate**

| Input |   | Output<br>$Y = A + B$ |
|-------|---|-----------------------|
| A     | B |                       |
| 0     | 0 | 0                     |
| 0     | 1 | 1                     |
| 1     | 0 | 1                     |
| 1     | 1 | 0                     |

The truth table of the Ex-OR gate shows that the output is HIGH when any one, but not all, of the inputs is at 1. This exclusive feature eliminates a similarity to the OR gate. The Ex-OR gate responds with a HIGH output only when an odd number of inputs is HIGH. When there is an even number of HIGH inputs, such as two or four, the output will always be LOW. From the truth table of a 2-input Ex-OR gate, the Ex-OR function can be written as  $Y = \overline{AB} + A\overline{B} = A \oplus B$ .

The above expression can be read as  $Y$  equals  $A$  Ex-OR  $B$ . Using the above expression, a 2-input Ex-OR gate can be implemented using basic gates like AND, OR and NOT gates as shown in Fig. 15.8.

The 2-input Ex-OR gate can also be implemented using NAND gates as shown in Fig. 15.9.

The main characteristic property of an Ex-OR gate is that it can perform modulo-2 addition. It should be noted that the same Ex-OR truth table applies when adding two *binary digits* (bits). A 2-input Ex-OR circuit is, therefore, sometimes called a *module-2-adder* or a *half-adder* without carry output. The name half-adder refers to the fact that possible carry-bit, resulting from an addition of two preceding bits, has not been taken into account. A full addition is performed by a second Ex-OR circuit



Fig. 15.9 Ex-OR gates using NAND gates



Fig. 15.10 Cascading of two Ex-OR circuits

with the output signal of the first circuit and the carry as input signals, as shown in Fig. 15.10.

The configuration of Fig. 15.10 is a cascading of two Ex-OR circuits resulting in an Ex-OR operation of three variables  $A$ ,  $B$ , and  $C$ . Consequently, the sum output of a full adder for two bits is an Ex-OR operation of the 2 bits to be added and the carry of the preceding adding stage. The logic expression of the Ex-OR operation of three variables  $A$ ,  $B$ , and  $C$  is given by

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

In general, Ex-OR operation of  $n$  variables results in a logical 1 output if an odd number of the input variables are 1s. An Ex-OR operation of  $n$  variables can be obtained by cascading 2-input Ex-OR gates.

Another important property of an Ex-OR gate is that it can be used as a *controlled inverter*, i.e. by using an Ex-OR gate, a logic variable can be complemented or allowed to pass through unchanged. This is done by using one Ex-OR input as a control input and the other as the logic variable input as shown in Fig. 15.11. When the control input is HIGH, the output  $Y = \bar{A}$  and when the control input is LOW, the output  $Y = A$ .



Fig. 15.11 Ex-OR gate as a controlled inverter

### 15.6.7 Exclusive-NOR (Ex-NOR) Gate

The exclusive-NOR gate, abbreviated Ex-NOR, is an Ex-OR gate, followed by an inverter. An Exclusive-NOR gate has two or more inputs and one output. The output of a two-input Ex-NOR gate assumes a HIGH state if both the inputs assume the same logic state or have an even number of 1s, and its output is LOW when the inputs assume different logic states or have an odd number of 1s. The logic symbol of Ex-NOR gate is shown in Fig. 15.12 and its truth table is given in Table 15.9. From the truth table, it is clear that the Ex-NOR output is the complement of the Ex-OR gate. The Boolean expression for the Ex-NOR gate is

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

Read the above expression as "Y equals A Ex-NOR B". According to DeMorgan's theorem,

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

Table 15.9 Truth table of 2-input Ex-NOR gate

| Input |     | Output                      |
|-------|-----|-----------------------------|
| $A$   | $B$ | $Y = \overline{A \oplus B}$ |
| 0     | 0   | 1                           |
| 0     | 1   | 0                           |
| 1     | 0   | 0                           |
| 1     | 1   | 1                           |



Fig. 15.12 Logic symbol of 2-input Ex-NOR gate

An important property of the Ex-NOR gate is that it can be used for bit comparison. The output of an Ex-NOR gate is 1 if both the inputs are similar, i.e. both are 0 or 1; otherwise, its output is 0. Hence, it can be used as a one-bit comparator. It is also called a *coincidence circuit*.

Another property of the Ex-NOR gate is that it can be used as an *even-parity checker*. The output of the Ex-NOR gate is 1 if the number of 1s in its inputs is even; if the number of 1s is odd, the output is 0. Hence, it can be used as an even/odd parity checker. Hence, the 2-input Ex-NOR gate is immensely useful for bit comparison and parity checking.

**Example 15.14** Realise the logic expression  $Y = \overline{B}\overline{C} + \overline{A}\overline{C} + \overline{A}\overline{B}$  using basic gates.

**Solution:** In the given expression, there are 3 product terms each with two variables which can be implemented using three 2-input AND gates, and the product terms can be OR operated together using a 3-input OR gate. The complemented form of individual variable can be obtained by 3 NOT gates. Thus, the circuit for the given expression is realised as shown in Fig. 15.13.



Fig. 15.13

**Example 15.15** Realise the logic expression  $Y = (A + B)(\overline{A} + C)(B + D)$  using basic gates.

**Solution:** In the given expression, there are 3 sum terms which can be implemented using three 2-input OR gates and their outputs are AND operated together by a 3-input AND gate. A NOT gate can be used to obtain the inverse of A. Now, the realized circuit is shown in Fig. 15.14.



Fig. 15.14

**Example 15.16** Implement  $Y = \overline{AB} + A + (\overline{B} + \overline{C})$  using NAND gates only.

**Solution:** The implementation of the given function is shown in Fig. 15.15.



Fig. 15.15

**Example 15.17** Simplify the logic circuit shown in Fig. 15.16(a)



Fig. 15.16 (a)

**Solution:** From the given logic circuit, the expression for Z can be written as

$$\begin{aligned} Z_1 &= (A + C) \cdot B\bar{D} \cdot (\bar{A} + \bar{C}) \cdot \bar{B}\bar{D} \\ &= [(A + \bar{C}) + \bar{B}\bar{D}] \cdot (\bar{A} + \bar{C}) + \bar{B}\bar{D} \\ &= [(A + \bar{C}) + \bar{B}\bar{D}] \cdot [(A + \bar{C}) + \bar{B}\bar{D}] \\ &= \bar{B}\bar{D} + (A + \bar{C})(\bar{A} + \bar{C}) \quad [\because (A + B)(A + C) = A + BC] \\ &= \bar{B}\bar{D} \\ &= \bar{B}\bar{D} \quad [\because A\bar{A} = 0] \end{aligned}$$

Therefore, the above logic circuit can be simplified as shown in Fig. 15.16 (b).



Fig. 15.16 (b)

Instead of using Boolean algebra, the logic circuit can be simplified directly as shown below. In the given logic circuit shown in Fig. 15.16 (a) the NAND gate (6) can be replaced by an OR gate with a bubble at its inputs as shown in Fig. 15.16 (c).



Fig. 15.16 (c)

Now, using  $\overline{\overline{A}} = A$ , the bubble at the outputs of gates 4 and 5 get cancelled with the bubble at the inputs of gate 6 as shown in Fig. 15.16 (d).



Fig. 15.16 (d)

In the above figure, if we assume the output of gate 1  $(A + \overline{C}) = X$  and the output of gate 2  $B\bar{D} = Y$ , then the output of gate 4 is  $XY$  and the output of gate 5 is  $\bar{X}Y$ . If  $XY$  and  $\bar{X}Y$  are OR operated in gate 6, then  $XY = \bar{X}Y = Y(X + \bar{X}) = Y = B\bar{D}$ . Therefore, the above circuit can be simplified as shown in Fig. 15.16 (e).



Fig. 15.16 (e)

~~Example 15.18~~ Realise (a)  $Y = A + BCD$  using NAND gates and (b)  $Y = (A + C)(A + \bar{D})(A + B + \bar{C})$  using NOR gates.

**Solution** Using NAND gates



Fig. 15.17 (a)

(b) Using NOR gates



Fig. 15.17 (b)