

# UNIT - III

## Digital Electronics

### \* Introduction :-

- Now a days digital systems are used in wide variety of industrial and consumer products such as automated industrial machinery, pocket calculators, microprocessors, digital computers, digital watches, TV games, signal processing and so on. The area of applications of digital systems have been increasing every day.

### ⇒ Analog Vs Digital system :-

- Analog system process information that varies continuously i.e., they process time varying signals that can take on any value across a continuous range of voltage, current or any physical parameter. Ex: voice sig., light.
- Digital systems use discrete quantities to represent information. Discrete means distinct or separated as opposed to continuous or connected.



(a) Continuous signal  
(Analog)



(b) Discrete slg  
(Digital)

### \* Advantages of Digital system:-

- Ease of Design
- Speed
- Camera
- Reproducibility of result
- Economy
- TV, etc., mobiles
- Flexibility
- Upgrading Technology
- Audio Recording & Video

## \* Number system:

- In digital electronics the number system is used for representing the information. The number system has different bases and the most common of them are the decimal, binary, octal and hexadecimal.
- The base or radix of the number system is the total number of the digit used in the number system.
- Ex: Base of system is 10, it represents the digit 0 - 9.

## Type of Number Systems:-

1. Decimal Number System
2. Binary Number System
3. Octal Number System
4. Hexadecimal Number System

LSB - least significant bit  
MSB - Most

| Number System | Base/<br>Radix | All digits / characters                        |
|---------------|----------------|------------------------------------------------|
| Binary        | 2              | 0, 1                                           |
| Octal         | 8              | 0, 1, 2, 3, 4, 5, 6, 7                         |
| Decimal       | 10             | 0, 1, 2, 3, 4, 5, 6, 7, 8, 9                   |
| Hexadecimal   | 16 (or)<br>H   | 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, A, B, C, D, E, F |

Note: A=10, B=11, C=12, D=13, E=14, F=15

## 1. Decimal Number System:-

- The total number of digits or symbols represented in a decimal number system are 10.
- The base or radix of decimal number system is 10.
- The digits or symbols in decimal number system starts with '0' and end with base -1 i.e.,  $(10-1)$  is 9)  
i.e., 0, 1, 2, 3, 4, 5, 6, 7, 8, 9

Ex:-  $(443)_{10}$  in decimal

$$= 4 \times 10^2 + 4 \times 10^1 + 3 \times 10^0 \\ = 400 + 40 + 3 = \underline{\underline{(443)_{10}}}$$



- The decimal number system is positional weighted system and its weights are expressed as power of 10.
- In floating point representation the left hand side digits have +ve powers and right hand side digits have -ve powers.



Fig:- Decimal Position Values or Powers of 10.

Ex:- 198.72

$$\begin{aligned}
 &= 1 \ 9 \ 8 \ . \ 7 \ 2 \\
 &\quad 10^3 \ 10^2 \ 10^1 \ 10^0 \quad \text{with digit-2 last} \\
 &= (1 \times 10^3) + (9 \times 10^2) + (8 \times 10^1) + 7 \times 10^0 + 2 \times 10^{-2} \\
 &= 100 + 90 + 8 + 0.7 + 0.02 \\
 &= (198.72)_{10}
 \end{aligned}$$

## 2. Binary Number System :-

- The total no. of digits or symbols represented in a binary No. system are 2.
- The base or radix of binary no. system is 2.
- The digits or symbols in binary No. system starts with '0' and end with base -1 i.e. ( $2-1 = 1$ ) the digits are 0, 1.

|             | <u>Ex:-</u> 1000 = 8                                          |
|-------------|---------------------------------------------------------------|
| 0 - 0 0 0   | $= 1 \times 2^3 + 0 \times 2^2 + 0 \times 2^1 + 0 \times 2^0$ |
| 1 - 0 0 1   | $= 8 + 0 + 0 + 0$                                             |
| 2 - 0 1 0   |                                                               |
| 3 - 0 0 1 1 | $= 8$                                                         |
| 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 |                                                               |

- In floating point representation the left hand side digit +ve Powers and Right hand side digits are -ve powers.



fig: Binary position values as power of 2

$$\text{Ex: } ① (1101.101)_2 = (?)_{10}$$

$$\begin{aligned}
 & 1101.101 \\
 & \begin{array}{cccccc} 3 & 2 & 1 & 0 & -1 & -2 & -3 \end{array} \\
 & = (1 \times 2^3) + (1 \times 2^2) + (0 \times 2^1) + (1 \times 2^0) + (0 \times 2^{-1}) + (1 \times 2^{-2}) + (1 \times 2^{-3}) \\
 & = 8 + 4 + 0 + 1 + 0.5 + 0 + 0.125 \\
 & = (13.625)_{10}
 \end{aligned}$$

### 3. Octal Number System:-

- the total no. of digits or symbols presents in the octal no. system.

- If '8'?
- the base or radix of the system is '8'. The digits are

0, 1, 2, 3, 4, 5, 6, 7

- In floating point representation the left hand side digit +ve Powers and right hand side digits are -ve powers.



fig: Octal position values as powers of '8'.

$$\text{Ex: } ① (567)_8 = (?)_{10}$$

$$\begin{aligned}
 & 5 \ 6 \ 7 \\
 & \begin{array}{ccc} 8^2 & 8^1 & 8^0 \end{array} \\
 & = (5 \times 8^2) + (6 \times 8^1) + (7 \times 8^0) \\
 & = (5 \times 64) + 48 + 7 = (375)_{10} \\
 & = (\cancel{5}\cancel{6}\cancel{7})
 \end{aligned}$$

$$② 47.3 = (?)_{10}$$

$$\begin{aligned}
 & \begin{array}{ccc} 8^1 & 8^0 & 8^{-1} \end{array} \\
 & = (4 \times 8^1) + (7 \times 8^0) + (3 \times 8^{-1}) \\
 & = 32 + 7 + 0.375 \\
 & = (39.375)_{10}
 \end{aligned}$$

#### 4. Hexadecimal Number System:

- The total No. system of digits or symbols present in the hexadecimal is 16.
- The base or radix of the system is '16' or 'H'.  
the digits are 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, A, B, C, D, E, F  
(A=10, B=11, C=12, D=13, E=14, F=15).
- In floating point representation, the left hand side digits have +ve powers and right hand side digits have -ve powers.



fig:- hexadecimal position values in a powers of 16.

| Decimal | Binary | Hexadecimal |
|---------|--------|-------------|
| 0       | 0000   | 0           |
| 1       | 0001   | 1           |
| 2       | 0010   | 2           |
| 3       | 0011   | 3           |
| 4       | 0100   | 4           |
| 5       | 0101   | 5           |
| 6       | 0110   | 6           |
| 7       | 0111   | 7           |
| 8       | 1000   | 8           |
| 9       | 1001   | 9           |
| 10      | 1010   | A           |
| 11      | 1011   | B           |
| 12      | 1100   | C           |
| 13      | 1101   | D           |
| 14      | 1110   | E           |
| 15      | 1111   | F           |

Ex:-

$$\textcircled{1} (2A1)_{16} = (\underline{\underline{\quad}})_{10}$$

$$\begin{array}{r}
 2 \ A \ 1 \\
 16^2 \ 16^1 \ 16^0 \\
 \hline
 = (2 \times 16^2) + (A \times 16^1) + (1 \times 16^0) \\
 = 512 + 16A + 1 \\
 = (573)_{10}
 \end{array}$$

$$\textcircled{2} (1B.2)_{16} = (\underline{\underline{\quad}})_{10}$$

$$\begin{array}{r}
 1 \ B \ . \ 2 \\
 16^1 \ 16^0 \ 16^{-1} \\
 \hline
 = (1 \times 16^1) + (B \times 16^0) + (2 \times 16^{-1}) \\
 = 16 + 11 + 0.125 \\
 = (27.125)_{10}
 \end{array}$$

### \* Binary to octal conversion :-

- the base for octal number is 8 and the base for binary number is 2. The base for octal number is the third power of the base for binary numbers.
- Therefore by grouping 3 digits of binary numbers and then converting each group digit to its octal equivalent, we can convert binary to octal equivalent.

| Decimal | octal digit                                                              |
|---------|--------------------------------------------------------------------------|
|         | $\begin{array}{l} 3 \text{ bit} \\ 2^2 \ 2^1 \ 2^0 \\ 4+2+1 \end{array}$ |
| 0       | 0 0 0                                                                    |
| 1       | 0 0 1                                                                    |
| 2       | 0 1 0                                                                    |
| 3       | 0 1 1                                                                    |
| 4       | 1 0 0                                                                    |
| 5       | 1 0 1                                                                    |
| 6       | 1 1 0                                                                    |
| 7       | 1 1 1                                                                    |

Ex  $\textcircled{1} (101001110)_2 = (\underline{\underline{\quad}})_8$

$$\begin{array}{r}
 \boxed{1} \boxed{0} \boxed{1} \boxed{0} \boxed{0} \boxed{1} \boxed{1} \boxed{1} \boxed{0} \\
 \text{MSB} \qquad \qquad \qquad \text{LSB}^2 \\
 \hline
 5 \qquad 1 \qquad 6
 \end{array}
 \text{ - Grouping 3 bits}$$

$$(516)_8$$

$\textcircled{2} (\underline{\underline{11101011}})_2 = (\underline{\underline{\quad}})_8$

$$\begin{array}{r}
 \boxed{0} \boxed{1} \boxed{1} \boxed{0} \boxed{1} \boxed{0} \boxed{1} \\
 \text{3} \qquad \text{5} \qquad \text{3}
 \end{array}$$

$$(353)_8$$

## \* Octal to Binary conversion :-

Conversion from octal to binary is a reversal of the process explained in the binary to octal conversion. Each digit of the octal number is individually converted to its binary equivalent to get octal to binary conversion of the number.

Ex:- ① Convert  $(634)_8$  to binary.

6 3 4  
1 1 1 1 1 0

110 011 100

Binary number =  $\underline{(110\ 011\ 100)}_2$

② Convert  $(725.63)_8$  to binary

7 2 5 . 6 3

↓ ↓ ↓ \ 110 011  
111 010 101

binary number =  $\underline{(111\ 010\ 101\ ,\ 11001)}_2$

## \* Binary to Hexadecimal conversion :-

- The base for hexadecimal number is the fourth power of the base for binary numbers. Therefore, by grouping 4 digits of binary numbers and then converting each group digit to its hexadecimal equivalent, we can convert binary numbers to its hexadecimal equivalent.

Ex:- ① convert  $\underline{(1101100101011001)}_2$  to hexadecimal

1101 | 1001 | 0101 | 1001  
13 9 5 9  
(D) 9 5 9

=  $\underline{(D\ 9\ 5\ 9)}_4$

② convert  $\underline{1100\ 0001\ 11000\ 1111}$

0001 | 1000 | 0011 | 1000 | 1111  
1 8 3 8 F

$\underline{(1838F)}_4$

## \* Hexadecimal to Binary conversion :-

Conversion from hexadecimal to binary is a reversal of the process explained in the previ binary to hexa conversion. Each digit of the hexadecimal number is individually converted to its binary equivalent to get hexadecimal to binary conversion of the number.

Ex: ① Convert  $(3FD)_{16}$  to binary

3 FD  
1 1 1  
0011 1111 1101

$$\text{binary number} = (0011111101)_2$$

② convert  $(5A9.B4)_{16}$  to binary

5 A 9 . B 4  
0101 1010 1001 . 1011 0100

$$\text{binary number} = (010110101001.10110100)_2$$

## \* Octal to Hexadecimal conversion :-

The easiest way to convert octal number to hexadecimal number is given below.

1. convert octal number to its binary equivalent.

2. convert binary number to hexadecimal equivalent

Ex:- ① convert  $(615)_8$  to its hexadecimal equivalent

step 1: Octal to binary

6 1 5  
110 001 101

step 2: binary number to hexadecimal

0001 | 1000 | 1101

1 8 D

$(18D)_{16}$

② convert  $(443)_8$  to Hexadecimal

step 1: 4 4 3  
1 1 \

100 100 011

$(123)_{16}$



## \* Hexadecimal to octal conversion :-

the easiest way to convert hexadecimal number to octal number is given below.

1. convert hexadecimal number to its binary equivalent.
2. convert binary number to its octal equivalent.

Ex ① convert  $(25B)_{16}$  to octal equivalent

Sol: step 1: Hexadecimal to binary

$$\begin{array}{r} 2 \quad 5 \quad B \\ 0010 \quad 0101 \quad 1011 \end{array}$$

$$\text{binary number} = (0010\ 0101\ 1011)$$

step 2: binary to octal equivalent

$$\begin{array}{r} 0 \quad 0 \quad 1 \quad | \quad 0 \quad 0 \quad 1 \quad | \quad 0 \quad 1 \quad 1 \\ 0010 \quad 0101 \quad 1011 \end{array}$$

$$\text{octal number} = (1133)_8$$

Ex ② Convert  $(1F3)_{16}$  to octal

Sol:  $1 \quad F \quad 3$

$$\Rightarrow 0001 \quad 1111 \quad 0011$$

$$\Rightarrow 0 \quad 0 \quad 0 \quad | \quad 1 \quad 1 \quad 1 \quad | \quad 0 \quad 0 \quad 1 \quad 1$$

$$\Rightarrow 0 \quad 0 \quad 7 \quad | \quad 6 \quad 3$$

$$\Rightarrow (0763)_8$$

## \* Conversion of Decimal to other Radix number :-

① Decimal to binary conversion

② Binary to Decimal " (Reverse process)

③ Decimal to Octal "

④ Octal to Decimal " (Reverse)

⑤ Decimal to hexa decimal "

⑥ Hexadecimal to decimal " (Reverse)



## \* Decimal to binary conversion :- (Successive division Method)

① Convert decimal number 37 to its binary equivalent.

$$(37)_{10} = (?)_2$$

|          |                   |
|----------|-------------------|
| <u>Q</u> | 37 - R            |
| 2        | 18 - 1 <u>LSB</u> |
| 2        | 9 - 0             |
| 2        | 4 - 1             |
| 2        | 2 - 0             |
| 2        | 1 - 0             |

when get small number  $\overset{200}{\cancel{0}}$  compare b/w  
stop the process.

$$\text{Binary equivalent} = (100101)_{2}$$

③ Convert decimal number

24.6 to binary

$$(24.6)_{10} = (?)_2$$

step 1: separate fraction part

integer part

integer part = 24.

Step 2:

|   |        |
|---|--------|
| 2 | 24     |
| 2 | 12 - 0 |
| 2 | 6 - 0  |
| 2 | 3 - 0  |
| 2 | 1 - 1  |

$$(11000)_2$$

∴ The binary equivalent is

$$② (55)_{10} = (?)_2$$

|          |        |
|----------|--------|
| <u>Q</u> | 55     |
| 2        | 27 - 1 |
| 2        | 13 - 1 |
| 2        | 6 - 1  |
| 2        | 3 - 0  |
| 2        | 1 - 1  |

|            |   |
|------------|---|
| <u>MSB</u> | ↑ |
| 1          | 1 |
| 1          | 1 |
| 0          | 1 |
| 1          | 1 |

$$(110111)_2$$

Recheck:

$$\begin{aligned} & 1 \cdot 2^6 + 1 \cdot 2^5 + 0 \cdot 2^4 + 1 \cdot 2^3 + 1 \cdot 2^2 + 1 \cdot 2^1 \\ & = 64 + 32 + 0 + 8 + 4 + 2 + 1 = 127 \end{aligned}$$

Fraction part = 0.6

Recorded  
Carries

Fraction Radix Result

$$0.6 \times 2 = 1.2 = 1 \quad \text{MSB}$$

$$0.2 \times 2 = 0.4 = 0$$

$$0.4 \times 2 = 0.8 = 0$$

$$0.8 \times 2 = 1.6 = 1$$

$$0.6 \times 2 = 1.2 = 1 \quad \text{LSB}$$

$$0.6 \times 2 = 1.2 = 1 \quad \text{Fraction}$$

$$(1100.1001)_2$$



$$\textcircled{2} \quad (43.7)_{10} = (-)_{10}$$

integer part = 43

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

Fraction = 0.7

$$\begin{aligned} 0.7 \times 2 &= 1.4 \Rightarrow 1 \text{ MSB} \\ 0.4 \times 2 &= 0.8 \Rightarrow 0 \\ 0.8 \times 2 &= 1.6 \Rightarrow 1 \\ 0.6 \times 2 &= 1.2 \Rightarrow 1 \\ 0.2 \times 2 &= 0.4 = 0 \text{ LSB} \end{aligned}$$

101011

$$\therefore (43.7)_{10} = (101011.10110)_2$$

### \* Binary to Decimal conversion:-

by using successive multiplication method

$$a^0 = 1$$

$$\textcircled{1} \quad (1101)_2 = (-)_{10}$$

$$\begin{array}{r} \text{MSB} \quad \text{LSB} \\ 1 \quad 1 \quad 0 \quad 1 \\ \downarrow \quad \downarrow \quad \downarrow \quad \downarrow \\ 2^3 \quad 2^2 \quad 2^1 \quad 2^0 \end{array} \quad (\text{powers})$$

$$\begin{aligned} &\Rightarrow (1 \times 2^3) + (1 \times 2^2) + (0 \times 2^1) + (1 \times 2^0) \\ &\Rightarrow (1 \times 8) + (1 \times 4) + (0 \times 2) + (1 \times 1) \\ &\Rightarrow 8 + 4 + 0 + 1 \\ &= 13 \\ &= \underline{\underline{13}}_{10} \end{aligned}$$

$$\therefore (1101)_2 = \underline{\underline{13}}_{10}$$

$$\textcircled{2} \quad (10011)_2 = (-)_{10}$$

$$\begin{array}{r} 1 \quad 0 \quad 0 \quad 1 \quad 1 \\ \downarrow \quad \downarrow \quad \downarrow \quad \downarrow \quad \downarrow \\ 2^4 \quad 2^3 \quad 2^2 \quad 2^1 \quad 2^0 \end{array}$$

$$\begin{aligned} &= (1 \times 2^4) + (0 \times 2^3) + (0 \times 2^2) + (1 \times 2^1) + (1 \times 2^0) \\ &= (1 \times 16) + (0 \times 8) + (0 \times 4) + (1 \times 2) + (1 \times 1) \\ &= 16 + 0 + 0 + 2 + 1 \\ &= 19 \\ &= \underline{\underline{19}}_{10} \end{aligned}$$

$$\therefore (10011)_2 = \underline{\underline{19}}_{10}$$

$$\textcircled{3} \quad (110.101)_2 = (-)_{10}$$

$$\begin{array}{r} 1 \quad 1 \quad 0 \quad . \quad 1 \quad 0 \quad 1 \\ \downarrow \quad \downarrow \quad \downarrow \quad \downarrow \quad \downarrow \quad \downarrow \quad \downarrow \\ 2^2 \quad 2^1 \quad 2^0 \quad 2^{-1} \quad 2^{-2} \quad 2^{-3} \end{array}$$

$$\begin{aligned} &= (1 \times 2^2) + (1 \times 2^1) + (0 \times 2^0) + (1 \times 2^{-1}) + (0 \times 2^{-2}) + (1 \times 2^{-3}) \\ &= 4 + 2 + 0 + 0.5 + 0.25 + 0.125 \\ &= \underline{\underline{6.875}}_{10} \end{aligned}$$

$$\begin{array}{r} 0.125 \\ 0.25 \\ 0.5 \\ \hline 0.875 \end{array}$$



\* Decimal to Octal conversion :- Successive division by 8

$$\textcircled{1} \quad (443)_{10} = (\underline{\underline{\quad}})_8$$

$$\begin{array}{r} 8 | 443 \\ 8 | 55 - 3 \end{array}$$

LSB  
MSB

$$\begin{array}{r} 8 | 443 (55) \\ 8 | 55 - 6 \\ 8 | 6 - 7 \end{array}$$

$$\underline{\underline{(673)}_8}$$

$$\textcircled{2} \quad (35.45)_{10} = (\underline{\underline{\quad}})_8$$

Integer part = 35

$$\begin{array}{r} 8 | 35 \\ 8 | 4 - 1 \end{array}$$

$$\begin{array}{r} 8 | 35 (34) \\ 8 | 34 - 1 \end{array}$$

$$\underline{\underline{(41)}_8}$$

Base - 8

Recheck! -

$$(673)_8$$

$$6 \begin{smallmatrix} 7 \\ 2 \end{smallmatrix} 3$$

$$8^2 8^1 8^0$$

$$(6 \times 8^2) + (7 \times 8^1) + (3 \times 8^0)$$

$$= 384 + 56 + 3$$

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

Fraction part = 0.45

$$0.45 \times 8 = 3.60 \rightarrow 3 \text{ HSB}$$

$$0.6 \times 8 = 4.8 \rightarrow 4$$

$$0.8 \times 8 = 6.4 \rightarrow 6$$

$$0.4 \times 8 = 3.2 \rightarrow 3$$

$$0.2 \times 8 = 1.6 = 1 \text{ LSB}$$

$$\therefore (35.45)_{10} = \underline{\underline{(41.34631)}_8}$$

\* Octal to Decimal conversion :- Successive multiplication with  $(8)$ .

$$\textcircled{1} \quad (673)_8 = (\underline{\underline{\quad}})_{10}$$

$$6 \begin{smallmatrix} 7 \\ 2 \end{smallmatrix} 3$$

$$8^2 8^1 8^0$$

$$(6 \times 8^2) + (7 \times 8^1) + (3 \times 8^0)$$

$$= (6 \times 64) + (7 \times 8) + (3 \times 1)$$

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

$$\textcircled{2} \quad (35.61)_8 = (\underline{\underline{\quad}})_{10}$$

$$= \frac{35}{8^1 8^0} \cdot \frac{61}{8^1 8^2}$$

$$= (3 \times 8^1) + (5 \times 8^0) + (6 \times 8^{-1}) + (1 \times 8^{-2})$$

$$= 24 + 5 + 0.75 + 0.0125$$

$$= \underline{\underline{(29.79)}_{10}}$$



## \* Decimal to Hexadecimal conversion :- successive division by '16'

base = 16 or H

$$0-9 \quad a=10, b=11 \\ A-F \quad c=12, d=13 \\ e=14, f=15$$

$$\textcircled{1} \quad (1005)_{10} = (?)_{16}$$

$$\begin{array}{r} 16 \mid 1005 \\ 16 \mid 62 - 13(D) \\ \hline 3 - 14(E) \end{array} \quad \begin{array}{r} 16) 1005(62 \\ 96 \\ \hline 45 \\ 36 \\ \hline 19 \\ 16) 19(3 \\ 16 \\ \hline 3 \\ 14 \end{array}$$

$$(3E\textcircled{D})_{16}$$

Recheck:

$$(3E\textcircled{D})_{16}$$

$$16^2 + 16^1 + 16^0$$

$$(3 \times 16^2) + (E \times 16^1) + (3 \times 16^0)$$

$$= 768 + 224 + 3$$

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

$$\textcircled{2} \quad (22.64)_{10} = (?)_{16}$$

integer = 22

$$\begin{array}{r} 16 \mid 22 \\ 16 \mid 1 - 6 \\ \hline 16 \end{array} \quad \begin{array}{r} 16) 22(1 \\ 16 \\ \hline 6 \end{array}$$

fractional = 0.64

$$0.64 \times 16 = 10.24 \quad \text{--- MSB (A)}$$

$$0.24 \times 16 = 3.84 \quad \text{--- 3}$$

$$0.84 \times 16 = 13.44 \quad \text{--- 13 (D)}$$

$$0.44 \times 16 = 7.04 \quad \text{--- .7}$$

$$\therefore (22.64)_{10} = (16. A3.D7)_{16}$$

## \* Hexadecimal to decimal conversion:-

$$\textcircled{1} \quad (A1)_{16} = (?)_{10}$$

$$\begin{array}{r} A \\ 16^1 \\ 16^0 \end{array}$$

$$(A \times 16^1) + (1 \times 16^0)$$

$$(10 \times 16) + (1 \times 1)$$

$$= 160 + 1$$

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

$$\textcircled{2} \quad 2D.6A$$

$$2 \quad D \quad . \quad 6 \quad A \\ 16^2 \quad 16^1 \quad 16^0 \quad 16^{-1} \quad 16^{-2}$$

$$= (2 \times 16^2) + (D \times 16^1) + (6 \times 16^0) + (A \times 16^{-2})$$

$$= 32 + (13 \times 1) + (6 \times 16^0) + (10 \times 16^{-2})$$

$$= 32 + 13 + 0.37 + 0.03$$

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

## \* Logic Gates :-

- Logic gates are the basic elements that make up a digital system. The logic gates allow or delays the logic signals (input signals).
- The gate is a digital circuit with one or more i/p and single output. The operation of a logic gate can be easily understood with the help of "Truth-table".
- The Truth Table indicates the relationship between i/p and o/p.



## \* NOT Gate :- (Inverter)

- The Inverter or NOT Gate performs a basic logic function called 'inversion' or 'complementation'. NOT Gate consists of single i/p and single o/p. The output of NOT Gate is complement of input signal.

### Truth table :-



Fig:- NOT Gate symbol

### Inverter operation:-

- if the input of NOT Gate is '0' (Low) then o/p of NOT Gate is '1' (High).
- if the input of NOT Gate is '1' (High) the output of NOT Gate is '0' (Low).

| i/p<br>A | o/p<br>y = A-bar |
|----------|------------------|
| 0        | 1                |
| 1        | 0                |

## \* AND Gate :-

- The AND Gate performs logical multiplication of inputs signals. The AND Gate consists of two or more than two inputs and single output.
- The output of AND Gate is product of input signals. (IC 7408)



fig:- symbol of 2-input AND Gate



fig:- multiplexed O/P AND Gate



fig:- symbol of 3-input AND Gate

Truth table :-  $y = A \cdot B$

| input |   | output          |
|-------|---|-----------------|
| A     | B | $y = A \cdot B$ |
| 0     | 0 | 0               |
| 0     | 1 | 0               |
| 1     | 0 | 0               |
| 1     | 1 | 1               |

AND Gate operation:-

- if both or two inputs of AND Gate is '1' (high) then output of AND Gate is '1' (high).
- if any one of the input of AND Gate is '0' (zero) then output of AND Gate is '0' (Low).

## \* OR Gate:

- The OR Gate performs logical addition of input signals.
- The OR Gate consists of two or more than two inputs and single output.
- The output of OR Gate is addition of inputs.



fig: symbol of 2-input OR Gate



fig: symbol of 3-input OR Gate

fig: symbol of multiple input OR Gate

### OR operation:

- If both inputs of OR Gate is '0' (Low), then output of OR Gate is '0' (Low).
- If any one of the input is 1 (High), then O/P of OR Gate is 1 (High).

### Truth Table:

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

## \* UNIVERSAL GATES:

→ The universal gates are two NAND Gate and NOR gate.

By using universal gates we can design all other gates. So that NAND and NOR gates are universal gates. So that universal gates consists of two or more than two inputs and single output.

1) NAND Gate - (AND Gate + NOT Gate)

2) NOR Gate - (OR Gate + NOT Gate)

## \* NAND Gate :-

- The NAND Gate is combination of AND Gate and NOT Gate. The NAND gate output is AND Gate function with a inverted (complemented) output.



For equivalent ckt of NAND Gate

Truth table :-

| input |   | AND O/P<br>A.B | NOT O/P<br>$\overline{AB}$ |
|-------|---|----------------|----------------------------|
| A     | B | 0              | 1                          |
| 0     | 1 | 0              | 1                          |
| 1     | 0 | 0              | 1                          |
| 1     | 1 | 1              | 0                          |

Truth table :-

| Input |   | output              |
|-------|---|---------------------|
| A     | B | $Y = \overline{AB}$ |
| 0     | 0 | 1                   |
| 0     | 1 | 1                   |
| 1     | 0 | 1                   |
| 1     | 1 | 0                   |

NAND Gate operation :-

- If both inputs of NAND Gate is '1' (High) then output of NAND gate is '0' (Low).
- If any one of the input of NAND Gate is '0' (Low) the output of NAND Gate is '1' (High).

## \* NOR Gate :-

- The NOR Gate is combination of OR Gate and NOT Gate. The NOR gate output is OR Gate function with a inverted (complemented) output.



fig: symbol of NOR Gate

fig: NOR + NOT Gate

### Truth Table:-

| Inputs | OR<br>A+B | NOT<br>$\bar{A+B}$ |
|--------|-----------|--------------------|
| A . B  |           |                    |
| 0 0    | 0         | 1                  |
| 0 1    | 1         | 0                  |
| 1 0    | 1         | 0                  |
| 1 1    | 1         | 0                  |

| Inputs | NOR<br>O/P<br>$\bar{A+B}$ |
|--------|---------------------------|
| A . B  |                           |
| 0 0    | 1                         |
| 0 1    | 0                         |
| 1 0    | 0                         |
| 1 1    | 0                         |

### NOR Gate operation:-

- If both inputs of NOR Gate is '0' (Low) then output of NOR Gate is '1' (High).
- If any of the input of NOR Gate is '1' the output of NOR gate is '0' (Low).

### \* Ex-OR Gate (or) X-OR Gate

- The Ex-OR gate is an abbreviation for Exclusive-OR gate. An Ex-OR gate has two or more than two inputs and one output.



fig: 2-<sup>i/p</sup> Ex-OR Gate

$$y = A \oplus B = AB + \bar{A}\bar{B}$$



fig: symbol of 3-<sup>i/p</sup> Ex-OR Gate

- if both inputs are same that means 0,0 or 1,1 then output of Ex-OR gate is '0' (Low).
- if both inputs of Ex-OR Gate is different (or) odd no. of ones then output of Ex-OR Gate is '1' (High).

Truth table:

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

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



(or)

| Inputs |   | Output           |
|--------|---|------------------|
| A      | B | $Y = A \oplus B$ |
| 0      | 0 | 0                |
| 0      | 1 | 1                |
| 1      | 0 | 1                |
| 1      | 1 | 0                |

### \* Ex-NOR Gate :-

- The Ex-NOR Gate is combination of Ex-OR Gate and NOT Gate. The Ex-NOR Gate consists of two or more than two inputs and single output.
- Ex-NOR Gate output is compliment of Ex-OR Gate.



fig: symbol of 2-I/P  
Ex-NOR Gate



fig: symbol of 3-I/P ExNOR Gate

Expression:  $Y = A \oplus B$  (or)  $\overline{A \oplus B}$

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

(0,0)(1,1)

- If both inputs are same, then output of Ex-NOR Gate is 1 (High).

- If both inputs of EX-NOR gate are different, then output of EX-NOR gate is '0' (Low).

### Truth Table:-

$$Y = A \oplus B \quad (\text{or}) \quad Y = \overline{A \bar{B} + AB}$$

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

(or)

| INPUTS | O/P Y = A $\oplus$ B |
|--------|----------------------|
| A   B  |                      |
| 0   0  | 1                    |
| 0   1  | 0                    |
| 1   0  | 0                    |
| 1   1  | 1                    |

NOTE :- The logic expression for all the logic gates.



NOT Gate



AND Gate



OR Gate



NAND Gate



NOR Gate



Y = A  $\oplus$  B

(or)

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



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

(or)

AB + \bar{A}\bar{B}

- NOT Gate consists single I/P and single O/P.
- All other Gates consists of two or more than two I/Ps and single O/P.
- Universal gates are NAND and NOR Gate.

## \* NOT, AND, OR Gates Using Universal Gates

- The NAND and NOR gates are known as universal gates.
- Any logic gate or logic function can be implemented using NAND or NOR Gates, so that NAND and NOR gates are called as universal gates.

### NOT Gate Using NAND Gate:



### NOT Gate using NOR Gate



### AND Gate using NAND Gate



### AND Gate using NOR Gate



### OR Gate using NAND Gate



### OR Gate using NOR Gate



## \* Binary codes:-

1) Weighted code - currl, 24.11.5211

2) Non-weighted code - excus-3, Hamming code

3) Reflective code - (0,0)(0,1)(1,0)(1,1)(2,0)(2,1)(2,2)(3,0)(3,1)(3,2)(3,3)

4) Sequential code - 8421, excus-3

5) Alphanumeric code - ASCII, EBCDIC

6) Error detecting and correcting codes

Theoretical  
sketch  
code for  
introduction  
to computer  
and its applications

\* BCD code = [Binary coded Decimal 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.

| Decimal digit | BCD code |   |   |   |
|---------------|----------|---|---|---|
|               | 8        | 4 | 2 | 1 |
| 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: 8-4-2-1 BCD code

NOTE:-  
Addition

| A | B | sum | Carry |
|---|---|-----|-------|
| 0 | 0 | 0   | 0     |
| 0 | 1 | 1   | 0     |
| 1 | 0 | 1   | 0     |
| 1 | 1 | 0   | 1     |

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

Ex: sub (0101) from (1011)<sub>2</sub>

$$\begin{array}{r} 1001 \rightarrow 9 \\ 0011 \rightarrow 3 \\ \hline 1100 \rightarrow 12 \end{array}$$

$$\begin{array}{r} 1011 \rightarrow 11 \\ 0101 \rightarrow 5 \\ \hline 0110 \rightarrow 6 \end{array}$$



## BCD Addition :-

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.

Ex:- ① Addition of 3 and 6 in BCD | ② Addition of 6 and 8 in BCD

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

$$\begin{array}{r} 6 \\ + 8 \\ \hline 14 \end{array} \quad \begin{array}{r} 0110 \\ 1000 \\ \hline 1110 \end{array} \leftarrow \text{invalid so add '6'}$$

$$\begin{array}{r} 3 \\ + 9 \\ \hline 12 \end{array} \quad \begin{array}{r} 1000 \\ 1001 \\ \hline 00010001 \end{array} \leftarrow \text{invalid add '6'}$$

$$\begin{array}{r} 00010001 \\ + 00010000 \\ \hline 00010010 \end{array} \quad \begin{array}{r} 1 \\ 4 \end{array}$$

$$\begin{array}{r} 00010010 \\ + 17 \\ \hline 00010111 \end{array} \quad \text{BCD for } 17$$

$$\begin{array}{r} 24 \\ + 18 \\ \hline 42 \end{array}$$

$$\begin{array}{r} 00100100 \\ + 00011000 \\ \hline 00000110 \\ + 00010000 \\ \hline 01000010 \end{array} \quad \begin{array}{l} > 9 \text{ so add '6'} \\ \text{BCD for } 42 \end{array}$$

## \* BCD subtraction :-

Addition of signed BCD numbers can be performed by using 9's or 10's complement methods. The 9's complement of a decimal number is found by subtracting each digit in the number from 9. The 9's complement of each the decimal digit is as follows

| Digit | 9's complement |
|-------|----------------|
| 0     | 9              |
| 1     | 8              |
| 2     | 7              |
| 3     | 6              |
| 4     | 5              |
| 5     | 4              |
| 6     | 3              |
| 7     | 2              |
| 8     | 1              |
| 9     | 0              |

Ex:-

$$\begin{array}{r} ① \quad 8 - 8 \\ - 2 - 7 \quad \text{- 9's complement of 2} \\ \hline 6 + 1 \\ \hline 6 \end{array}$$

$$\begin{array}{r} ② \quad 28 - 13 \\ \hline 15 \end{array} \quad \begin{array}{l} 28 - 13 = 15 \\ \text{- 86 - 9's complement of 13} \\ \hline 14 \end{array}$$

$$\begin{array}{r} ③ \quad 79 - 26 \\ - 26 \quad \text{- 9's complement of 26} \\ \hline 53 \end{array}$$

$$\begin{array}{r} 0110 \quad 0110 \\ (+) 0111 \quad 1100 \\ \hline 10101 \quad 0010 \end{array}$$

$\xrightarrow{\text{+1}}$

$$\begin{array}{r} 0101 \quad 0011 \\ \hline \text{BCD } 53 \end{array}$$

\* Excess-3 code = [self complementing code]

Excess-3 code is a modified form of a BCD Number.  
The Excess-3 code can be derived from the natural BCD code by adding '3' to each coded number.  
Excess-3 codes to represent single decimal digit.

| Decimal digit | Excess-3 code |
|---------------|---------------|
| 0             | 0011          |
| 1             | 0100          |
| 2             | 0101          |
| 3             | 0110          |
| 4             | 0111          |
| 5             | 1000          |
| 6             | 1001          |
| 7             | 1010          |
| 8             | 1011          |
| 9             | 1100          |

Ex 9 → 1001  
$$\begin{array}{r} 0011 \\ + 0011 \\ \hline 1100 \end{array}$$

9 - 1100 - Excess-3 code

\* 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 code (or) reflector code.

\* Binary to Gray conversion

Let us assume 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, \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} + B_n$$

| EX-70R |   |     |
|--------|---|-----|
| A      | B | O/P |
| 0      | 0 | 0   |
| 0      | 1 | 1   |
| 1      | 0 | 1   |
| 1      | 1 | 0   |

Ex: ① Convert 1011101 in binary into its gray code equivalent  
sol:  $\begin{array}{ccccccc} \oplus & \oplus & \oplus & \oplus & \oplus \\ 1 & 0 & 1 & 1 & 1 & 0 & 1 \\ \downarrow & \downarrow & \downarrow & \downarrow & \downarrow & \downarrow \\ 1 & 1 & 1 & 0 & 0 & 1 & 1 \end{array}$  - Gray code

② Convert 111001 in binary into its Gray code

sol:  $\begin{array}{ccc} \oplus & \oplus & \oplus \\ \text{binary} & \rightarrow & 1 & 1 & 1 & 0 & 0 & 1 \\ \downarrow & & & & & & \\ \text{Gray code} & \rightarrow & 1 & 0 & 0 & 1 & 0 & 1 \end{array}$

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



Table:- Gray code

## \* Gray to binary conversion

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

1. The most significant bit (MSB) 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.

Ex :- ① Convert gray code 101011 into its binary equivalent

Gray code : 1 0 1 0 1 1  
↓  
Binary code : 1 1 0 0 1 0

| EX-OR |   |
|-------|---|
| 0     | 0 |
| 0     | 1 |
| 1     | 0 |
| 1     | 1 |

② Convert gray code 11001 into its binary

Gray code : 1 1 0 0 1  
↓  
Binary code : 1 0 0 0 1

## \* Hamming code

- The Hamming code method is a network technique designed by R.W. Hamming for damage and error detection during data transmission between multiple network channels.
- The hamming code method is one of the most effective ways to detect single-data bit errors in the original data at the receiver end.

- it is not only used for error detection but is also for correcting errors in the data bit

1. Redundant Bits :- These are the extra binary bits added externally into the original data bit to prevent damage to the transmitted data and are also needed to recover the original data. The expression applied to deduce the redundant value is

$$2^r = d + r + 1$$

Here  $d$  - data bits

$r$  = redundant bits  $r = (1, 2, 3 \dots n)$

Ex :- Assuming the number of data bits as 7, find the no. of redundant bits

$$2^r = 7 + 1$$

$$2^r \geq 8$$

$$\boxed{r = 4}$$

2. Parity bit :- The parity bit is the method to append binary bits to ensure that the total count of 1's in the original data is even bit or odd. It is also applied to detect errors on the receiver side and correct them.

Type of Parity bit :-  
① Odd Parity bit  
② Even Parity bit

① Odd Parity Bit :- In this parity type, the total no. of 1's in the data bit should be odd in count, then the parity value is '0' and the value is '1'.

② Even Parity bit :- In this parity type, the total number of 1's in the data bit should be even in count, then the parity value is '0', and the value is '1'.

- \* → In even parity the added parity bit will make the total no. of 1's an even count.
- In odd parity the added parity bit will make the total no. of 1's an odd count.
- The table shows the 3-bit message with odd parity and even parity.

| 3-bit Message |   |   | Message with odd parity |        | Message with even parity |        |
|---------------|---|---|-------------------------|--------|--------------------------|--------|
| A             | B | C | Message                 | Parity | Message                  | Parity |
| 0             | 0 | 0 | 000                     | 1      | 000                      | 0      |
| 0             | 0 | 1 | 001                     | 0      | 001                      | 1      |
| 0             | 1 | 0 | 010                     | 0      | 010                      | 1      |
| 0             | 1 | 1 | 011                     | 1      | 011                      | 0      |
| 1             | 0 | 0 | 100                     | 0      | 100                      | 1      |
| 1             | 0 | 1 | 101                     | 1      | 101                      | 0      |
| 1             | 1 | 0 | 110                     | 0      | 110                      | 0      |
| 1             | 1 | 1 | 111                     | 0      | 111                      | 1      |

\* 1's complement: In the 1's complement representation, '0' are replaced by 1 (or) 1's are replaced by 0.

Ex: If find 1's complement of  $(1001)_2$ ,   
 $\begin{array}{r} ② \cdot 100110 \\ 100110 \\ +1 \\ \hline 011001 \end{array}$  → 1's complement

1's compl → 0110

\* 2's complement: 1's complement + 1

Ex: ① find 2's complement of  $(10010)_2$

1's complement → 01101

+1

2's complement → 01110

## \* Boolean Algebra :-

- In 1854, George Boole introduced a systematic treatment of logic and developed for the purpose an algebraic system, now it's called as Boolean Algebra.
- In 1938 C.E. Shannon introduced a two-valued boolean algebra called switching algebra. Boolean algebra is a system of mathematical logic. It differs from both ordinary algebra and the binary number system.

## \* Rules in Boolean Algebra :-

1. The symbol which represent an arbitrary elements of an boolean algebra is known as variable. Any single variable or a function of several variables can have either a 1 or 0 value.

Ex :-  $y = A + B + C$

here A, B, C are variables

it values 0 or 1, value

y is function it value 0 or 1.

2. A complement of a variable is represented by a "bar" over the letter.

Ex :- Variable is if  $A \rightarrow \bar{A}$

3. The logical AND operator of two variables is represented either by writing a dot(.) between two variables

Ex :-  $A \cdot B$ ,  $A \cdot B \cdot C$  or  $AB$ ,  $ABC$

4. The logical OR operator of two variables is represented by writing a '+' sign between the two variables.

Ex :-  $A + B$ ,  $A + B + C$

## \* Rules :-

i)  $A+0 = 0+A = A$

| A | 0 | $A+0$   |
|---|---|---------|
| 0 | 0 | $0+0=0$ |
| 1 | 0 | $1+0=1$ |

ii)  $A+1 = 1+A = 1$

iii)  $A+A = A$

iv)  $A+\bar{A} = 1$

v)  $A \cdot 0 = 0 \cdot A = 0$

vi)  $A \cdot 1 = 1 \cdot A = A$

vii)  $A \cdot A = A$

viii)  $A \cdot \bar{A} = 0$

ix)  $\bar{\bar{A}} = A$

## \* Laws of Boolean Algebra :-

i) commutative Law : a)  $A+B = B+A$

b)  $A \cdot B = B \cdot A$

a)  $A+B = B+A$ : This states that the order in which the variables are ORed makes no difference in the OR.

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

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

b)  $A \cdot B = B \cdot A$

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

=

| B | A | $BA$ |
|---|---|------|
| 0 | 0 | 0    |
| 0 | 1 | 0    |
| 1 | 0 | 0    |
| 1 | 1 | 1    |

## Additional Rules :-

$A+A \cdot B = A$

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

$(A+B)(A+C) = A+BC$

ii) Associate law:- a)  $A + (B+C) = (A+B)+C$

b)  $(A \cdot B)C = A(BC)$

iii) Distributive law: a)  $A(B+C) = AB+AC$   
 $A(B+C)$

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

### \* DeMorgan's Theorems :-

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

The complement of a product is equal to the sum of the complements. This is illustrated by truth table

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

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

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

Theorem 2: The complement of a sum is equal to the product of the complements.

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

| 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 | $\bar{A}$ | $\bar{B}$ | $\bar{A} \cdot \bar{B}$ |
|---|---|-----------|-----------|-------------------------|
| 0 | 0 | 1         | 1         | 1                       |
| 0 | 1 | 1         | 0         | 0                       |
| 1 | 0 | 0         | 1         | 0                       |
| 1 | 1 | 0         | 0         | 0                       |

NOTE :- Boolean functions are constructed by connecting the boolean constants and variables with the boolean operations. These boolean expressions are also known as boolean formulae. We use boolean expressions to describe boolean functions.

- A variable in either a complemented or uncomplemented form is called a literal.

① SOP (sum of products)

② POS (product of sums)

① Sum of Product Form = (SOP) (Minterms)

A sum of products (SOP) is a group of product terms ORed together.

Ex:  $f(A,B,C) = \overbrace{A\bar{B}\bar{C} + ABC + \bar{A}\bar{B}C}^{\text{sum (OR)}} + \overbrace{\bar{A}\bar{B}\bar{C}}^{\text{product (AND)}}$

② Product of Sum Form = (POS) (Maxterms)

A product of sums is any group of sum terms ANDed together.

Ex:  $f(A,B,C) = \overbrace{(A+B+C)}^{\text{sum terms}} \cdot \overbrace{(A+\bar{B}+C)}^{\text{sum terms}} \cdot \overbrace{(\bar{A}+B+\bar{C})}^{\text{sum terms}}$

Problem :- Simplify the following expression  $y = (A+B)(\bar{A}+C)$

① Simplify the following expression  $y = (A+B)(\bar{A}+C)$

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

$$(A \cdot \bar{A} = 0)$$

$$y = \underline{AC + \bar{A}B + BC}$$

$$\begin{aligned}
 ② (x+\bar{y}+xy)(x+\bar{y})\bar{x}y &= 0 \\
 &= (\underline{x+\bar{y}} + \underline{xy})(x+\bar{y})(\bar{x}y) \\
 &= (x(1+y)+\bar{y})(x+\bar{y})(\bar{x}y) \\
 &= \underbrace{(x+\bar{y})}_{A} (x+\bar{y}) (\bar{x}y) \quad A \cdot \bar{A} = 0 \\
 &= (x+\bar{y})(\bar{x}y) \\
 &= \bar{x}y + \bar{y}\bar{x}y \\
 &= 0
 \end{aligned}$$

$$\begin{aligned}
 ③ \underline{\overline{A \cdot (A+C)}} &= \overline{A \cdot (A+C)} \\
 &= \overline{A} + \overline{(A+C)} \quad \overline{A \cdot B} = \overline{A} + \overline{B} \\
 &= \overline{A} + \overline{A} \cdot \overline{C} \\
 &= \overline{A}(1 + \overline{C}) \\
 &= \overline{A}(1) \\
 &= \underline{\overline{A}}
 \end{aligned}$$

### \* Combinational Circuit

- When logic gates are connected together to produce a specified o/p for certain specified combinations of i/p variables, with no storage involved, the resulting circuit is called combinational logic.
- A combinational circuit consists of i/p variables, logic gates and o/p variables. The logic gates accept sigs from the i/p variables and generate output sigs.



\* Analysis Procedure :-

1. First make sure that the given circuit is combinational circuit and not be sequential circuit. The combinational circuit has logic gates with no feedback path or memory elements.

2. Label all gate o/p's that are a function of ip variables with arbitrary symbols, and determine the boolean functions for each gate o/p.

3. Label the gates that are a function of input variables and previously labeled gates and determine the boolean function for them.

4. Repeat the step 3 until the boolean function for o/p's of the circuit are obtained.

5. Finally, substituting previously defined boolean functions obtain the o/p boolean functions in terms of ip variables.

Ex:- ① obtain the boolean functions for o/p's of the given clt.



Sol:- Labelling the gate o/p



$$\therefore Y_4 = \overline{ABC} + \overline{BC}$$

Final Boolean expression of the circuit

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

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

Truth Table for given circuit

### \* Design Procedure

1. The Problem definition.
2. The determination of no. of available OIP Variables and required OLP Variables.
3. Assigning letter symbols to OIP and OLP Variables.
4. The derivation of truth table indicating the relationships between input and output variables.
5. obtain simplified boolean expression for each OLP.
6. obtain the logic diagram.

Ex ① Design a combination logic ckt with three OIP Variables to produce a logic 1, OLP when more than one OIP variables are logic 1.

Sol: Three OIP assume A, B, C

when morethan one OIP is 1 then output is 1

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



$$Y = AB + AC + BC$$



fig: logic diagram

### \* Half adder

- Half adder is a type of digital circuit to calculate the arithmetic binary addition of two single-bit numbers.
- It is a circuit with two inputs and two O/Ps.
- For two single-bit binary numbers A and B, half adder produces two single-bit binary outputs Sum (S) and Carry (C).



fig: Block Schematic of half-adder

### Truth table



fig: Logic diagram for half-adder

| inputs |   | outputs |       |
|--------|---|---------|-------|
| A      | B | Sum     | Carry |
| 0      | 0 | 0       | 0     |
| 0      | 1 | 1       | 0     |
| 1      | 0 | 1       | 0     |
| 1      | 1 | 0       | 1     |

K-map for sum



for carry



## \* Full Adder :-

- full adder is a digital circuit that adds three single digit binary numbers. This is a three - I/P and two O/P digital circuit.
- For three single-bit binary numbers A, B and  $C_{in}$ , the full adder circuit generates two single bit binary O/Ps sum (S) and carry ( $C_{out}$ ).



Fig: Schematic of Full-Adder

Truth table:-

| Input |   |   | Output |       |
|-------|---|---|--------|-------|
| A     | B | C | Sum    | Carry |
| 0     | 0 | 0 | 0      | 0     |
| 0     | 0 | 1 | 1      | 0     |
| 0     | 1 | 0 | 1      | 0     |
| 0     | 1 | 1 | 0      | 1     |
| 1     | 0 | 0 | 1      | 0     |
| 1     | 0 | 1 | 0      | 1     |
| 1     | 1 | 0 | 0      | 1     |
| 1     | 1 | 1 | 1      | 1     |



K-map for Sum



K-map for Carry



## \* Sequential Circuits

- Sequential circuit refers to a special type of circuit.
- It consists of a series of various inputs and outputs.
- Here the O/P depends on a combination of both the present inputs as well as the previous O/Ps.
- This previous output gets treated in the form of the present state.
- The sequential circuit consists of the combinational circuit along with its memory storage elements.



### Combinational Circuits

1. In combinational circuit, the O/P variables are at all times dependent on the combination of I/P variables.
2. Memory unit is not required in combinational ckt.
3. Faster in speed.
4. Easy to design.
5. Parallel adder is a combinational circuit.

### Sequential Circuits

1. In sequential circuits, the O/P variables dependent not only on the present I/O variables but they also depend upon the past history of these I/P Variables.
2. Memory unit is required to store the past history of I/P variables in the sequential ckt.
3. It is slower than combinational circuit.
4. Harder to design.
5. Serial adder is a sequential circuit.

Basically two types of sequential circuits

① Asynchronous sequential circuit

② Synchronous sequential circuit

① The asynchronous sequential circuits don't make use of the clock signals, this type of circuit is operated through various pulses.

② The synchronous sequential circuit:- The clock sig perform the synchronization of the state of memory elements in the case of synchronous sequential circuits.

| Synchronous sequential circuit                                                                                                                                                                                                                                                                                         | Asynchronous sequential circuit                                                                                                                                                                                                                                                                                                                                          |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <ul style="list-style-type: none"><li>1. In synchronous ckt, memory elements are clocked flip-flops</li><li>2. The change in clp signals can affect memory element upon activation of clock sig.</li><li>3. The maximum operating speed of clock depends on time delays involved.</li><li>4. Easy to design.</li></ul> | <ul style="list-style-type: none"><li>1. In asynchronous ckt, memory elements are either unclocked flip-flops or time delay elements</li><li>2. change in clp sigs can affect memory element at any instant of time.</li><li>3. Because of absence of clock, asynchronous ckt's can operate faster than synchronous ckt's</li><li>4. More difficult to design.</li></ul> |

### \* Flip-Flop :-

-A flip flop in digital electronics is a circuit with two stable states that can be used to store binary data.

The stored data can be changed by applying varying inputs.

- Flip flops and latches are fundamental building blocks of digital electronics systems used in computers, communications and many other types of systems.
- Both are used as data storage elements.
- Flip flops are edge triggered and a latch is level triggered.
- There are basically 4 types of flip-flops in digital electronics
  1. SR Flip-Flop
  2. JK Flip-Flop
  3. D-Flip Flop
  4. T-Flip Flop

### 1. SR Flip-Flop :-

This is the most common flip flop among all. This simple flip flop circuit has a set input(S) and a reset input(R).

In this system, when you set "S" as active, the output "Q" would be high, and "Q̅" would be low.

Once the outputs are established, the wiring of the ckt is maintained until "S" or "R" go high, or power is turned off.

| R | S | Q <sub>n+1</sub> |
|---|---|------------------|
| 0 | 0 | Q <sub>n</sub>   |
| 0 | 1 | 1                |
| 1 | 0 | 0                |
| 1 | 1 | ↔                |

(a) RS Truth Table

| Q <sub>n</sub> | Q <sub>n+1</sub> | R | S |
|----------------|------------------|---|---|
| 0              | 0                | X | 0 |
| 0              | 1                | 0 | 1 |
| 1              | 0                | 1 | 0 |
| 1              | 1                | 0 | X |

(b) RS excitation Table



(a) symbol

## 2. J.K. flip-flop

Due to the undefined state in the SR flip flop, another flip flop is required in electronics. The JK flip-flop is an improvement on the SR flip flop where ~~case 1 is removed~~.



(a) logic symbol



JK flip-flop

- The input condition of  $J=K=1$  gives an output inverting the old state.

| $Q_n$ | J | K | $Q_{n+1}$ |
|-------|---|---|-----------|
| 0     | 0 | 0 | 0         |
| 0     | 0 | 1 | 0         |
| 0     | 1 | 0 | 1         |
| 0     | 1 | 1 | 1         |
| 1     | 0 | 0 | 1         |
| 1     | 0 | 1 | 0         |
| 1     | 1 | 0 | 1         |
| 1     | 1 | 1 | 0         |

=

| J | K | $Q_{n+1}$   |
|---|---|-------------|
| 0 | 0 | $Q_n$       |
| 0 | 1 | 0           |
| 1 | 0 | 1           |
| 1 | 1 | $\bar{Q}_n$ |

## \* D-Flip Flop :

- D flip-flop is a better alternative that is very popular with digital electronics. They are commonly used for counters and shift registers and so on.
- In the D-Flipflops the QP can only be changed at the clock edge, and if the flip changes at other times, the QP will be unaffected.



| CP | D | $Q_{n+1}$ |
|----|---|-----------|
| ↑  | 0 | 0         |
| ↑  | 1 | 1         |
| 0  | X | $Q_n$     |

(a) logic symbol

## \* T- Flip Flop : = (Toggle flip flop)

A T-flip flop is like a JK flip flop. These are basically single QP version of JK flip flops. This modified form of the JK is obtained by connecting inputs J and K together. It has only one QP along with the clock QP.



| T | $Q_{n+1}$   |
|---|-------------|
| 0 | $Q_n$       |
| 1 | $\bar{Q}_n$ |

(a) logic symbol

## \* Comparisons between Latch and flipflop :-

| <u>Latch</u>                                                                                   | <u>Flip-Flop</u>                                                                                     |
|------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| 1. Latches do not require clock signal                                                         | 1. flipflop have clock signal                                                                        |
| 2. latches are building blocks of sequential circuits and those can be built from logic gates. | 2. flipflops are also building blocks of sequential circuits but those can be built from the latches |
| 3. Latch is a level triggered                                                                  | 3. flipflop is edge triggered                                                                        |
| 4. O/P response to I/p only at sequential +ve or -ve edge clock pulse.                         | 4. O/P response to the I/p until active level is maintained                                          |
| 5. Latches are level sensitive                                                                 | 5. flipflops are edge sensitive                                                                      |



## \* Registers :-

- A flip-flop is 1-bit memory cell. To increase the storage capacity.
- A register is a group of flip-flops. A flipflop can store 1-bit information. So an n-bit register has a group of n-flipflops and is capable of storing any binary information/number containing n-bits.

## Shift Register :-

- In a digital circuit a shift register is a cascade of flipflops.
- The binary information (data) in a register can be moved from stage to stage within the register or into or out of the register upon application of clock pulses.

- This type of bit movement or shifting is essential for certain arithmetic and logic operations used in microprocessors.
- This gives rise to a group of registers called "shift registers".
- There are 4 types of shift registers
  1. Serial In serial Out shift register [SISO]
  2. Serial In parallel Out shift register [SIPO]
  3. Parallel In serial Out shift register [PISO]
  4. Parallel In parallel Out shift register [PIPO]
- 1. Serial In Serial Out shift Register [SISO]:  
Here the data is shifted in serial mode i.e., bit by bit. same op is also shifted in serial mode i.e., bit by bit.



fig:- serial in serial out shift register



## 2. Serial In: Parallel out, shift Register (SIPo)



Fig: Serial In Parallel out shift Register

Serial In →



↓ ↓ ↓ ↓ → Parallel O/P

- Here the data is shifted in serial mode i.e., bit by bit position. In order to shift data in parallel it is necessary to have all data bits at its o/p of all flip flops.
- Once data is stored o/p is collected at a time at  $Q_0, Q_1, Q_2, Q_3$ .

## 3. Parallel In: Serial out shift Register



Fig: Parallel in serial out shift register

- From flip flop output enabling A<sub>1</sub>, A<sub>2</sub>, A<sub>3</sub> gates data is shifted out in serial mode.

① Left shift / Load :- it is a control input that allows 4-bits of data D<sub>0</sub>, D<sub>1</sub>, D<sub>2</sub>, D<sub>3</sub> to enter into the register in parallel or shift the data in serial mode.

case(i) : S/I = 0, S = 0, T = 1

data is loaded in to each flip flop by enabling data the A<sub>4</sub>, A<sub>5</sub>, A<sub>6</sub> gates. Hence data is loaded in parallel mode.

case(ii) : S/I = 1, S = 1, T = 0

The loaded data is shifted in serial mode from flip flop to flip flop enabling A<sub>1</sub>, A<sub>2</sub>, A<sub>3</sub> gates, data is shifted out in serial mode.

#### 4. Parallel In Parallel Out shift Register [PIPo]



Fig:- parallel in parallel out shift register

Here the data is loaded in parallel mode i.e., all the bits are loaded at a time, and all the bits are shifted in parallel mode at a single clock pulse.

## Counter :

- A counter is a register capable of counting the number of clock pulses arriving at its clock input. Count represents the number of clock pulses arrived.
- There are two types of counters, synchronous and asynchronous.

\* In synchronous counter, the common clock input is connected to all of the flip-flops and thus they are clocked simultaneously.

\* In Asynchronous counter, commonly called Ripple counter, the first flip flop is clocked by the external clock pulse and then each successive flip flop is clocked by previous flip flop. the Q or  $\bar{Q}$  output of the

## Asynchronous counter / Ripple counter :

- The 2-bit asynchronous counter using J-K flip flops is as shown in diagram. The clock signal is connected to the clock input of only first stage flip flop.
- The clock input of the second stage flip flop is triggered by the  $\bar{Q}_A$  output of the first stage.
  - Because of the inherent propagation delay time through a flip flop, a transition of the  $\bar{Q}_B$  clock pulse and a transition of the  $\bar{Q}_A$  output of first stage can never occur at exactly the same time.

- therefore, the two flip flops are never simultaneously triggered, which results in asynchronous counter operation.



fig:- A two bit asynchronous binary counter

## \* Synchronous Counter / Binary up or down Counter

To form a parallel up/down counter the control input (up/down) is used to control whether the normal flip flop outputs or the inverted flip flop outputs are fed to the J and K inputs of the following flip flops.



Fig.: 3-bit synchronous/parallel updown counter

## \* Synchronous Vs Asynchronous counters

### Asynchronous counters

1. In this type of counter flipflops are connected in such a way that o/p of first flipflop drives the clock for the next FF.
2. All the ffs are not clocked simultaneously.
3. logic circuit is very simple even for more number of states.
4. low speed

### Synchronous counters

1. In this type there is no connection between o/p of first FF and clock of the next F.F.
2. All the FFS are clocked simultaneously.
3. design involves complex logic ckt as no. of states increases.
4. High speed.