

# FUNDAMENTALS OF DIGITAL ELECTRONICS

## FIRST SEMESTER

### CORE PAPER I - FUNDAMENTALS OF DIGITAL ELECTRONICS

#### DIGITAL ELECTRONICS LAB

#### DIGITAL ELECTRONICS LAB :-

**UNIT I:** Digital Computers and Digital Systems. Number Systems & Codes: Number System - Base Conversion - Binary Codes - Code Conversion. **Digital Logic:** Logic Gates - Truth Tables - Universal Gates.

**UNIT II: Boolean algebra:** Laws & Theorems - SOP, POS Methods - Simplification of Boolean Functions using theorems - Simplification of Boolean Functions using K-Map (Two, Three and Four variables).

**UNIT III: Binary Arithmetic:** Binary Addition - Binary Subtraction - Arithmetic Building Blocks. **Adders:** Half Adder and Full Adder. **Subtractors:** Half Subtractor and Full Subtractor. **Combinational Logic:** Multiplexers - Demultiplexers - Decoders - Encoders.

**UNIT IV: Sequential Logic:** RS, JK, D and T Flip-Flops. **Registers:** Shift Registers - Types of Shift Registers - Implementation of Serial-In Serial-Out Shift Register and Serial-In Parallel-Out Shift Register.

**UNIT V: Counters:** Asynchronous Counters Ripple, Mod, Up-Down Counters- Synchronous Counters - Types of ROM and RAM.

**TEXT BOOK:**  
1. V.Rajaraman and T.Radhakrishnan, "Digital Computer Design", Fifth Edition, 2012,  
Prentice Hall of India.

#### REFERENCE BOOKS:

1. D.P.Leach and A.P.Malvino, "Digital Principles and Applications", Seventh Edition, 2011, TMH.
2. T.C.Bartee, "Digital Computer Fundamentals", Sixth Edition, Tata McGraw Hill.
3. Floyd and Jain, "Digital Fundamentals", Ninth Edition, Pearson Education.

#### E-REFERENCES:

1. <http://nptel.iitm.ac.in/video.php?subjectId=117106086>
2. <http://nptel.iitm.ac.in/Onlinecourses/Srinivasan/>

## UNIT - I

- \* **DIGITAL COMPUTER AND DIGITAL SYSTEM -**
- \* computers are used for scientific calculations, commercial and business data processing, air-traffic control, space guide, educational field and many other areas.
- \* Digital computers made possible in many commercial and scientific advancements.
- \* Digital computers are in a flow of sequencing the instructions called **program**, that operates on a given data.
- \* The user can change program/ data according to specific need. so that it can perform information-processing tasks.
- \* The digital computer includes telephone switching exchanges, digital voltmeters, calculating machines.
- \* Discrete elements may be electric impulses, decimal digits, the letters of an alphabet, arithmetic operations, punctuation marks and other symbols
- Ex: the letters A, O, D from GOD
- Sequence of discrete elements forms a language.

It conveys an information.

- \* Early digital computers used with Numerical computations and used only with numbers. So it has been emerged with digital computers.
- \* Discrete elements of information are represented in a digital system by physical quantities called **signals**.

- \* Voltages and current are most common electrical signals.
- \* It has two discrete values called as binary (i.e. 0 or 1).
- \* Analog computers perform a direct simulation of a physical system. (Mathematically by differential equation)
- \* It operates with continuous variables.

BLOCK DIAGRAM OF DIGITAL COMPUTER :-



(3)

The control unit supervises the flow of information between various units. The control unit retrieves the instructions one by one from the program which is stored in a memory. The control unit supervises the program instructions and processor manipulates the data specified by the program.

The memory unit stores programs as well as input / output and the data.

The processor unit performs arithmetic and data processing task specified by the program.

The input and output devices are specified in digital systems and controlled by electronic digital circuits. The I/O devices are punch card reader and O/P devices are printers. A digital computer is a interconnection of digital modules which is necessary to have a basic knowledge of digital system and general behaviour NUMBER SYSTEM:-

### Decimal Number System:-

The decimal number system makes use of ten digits namely 0, 1, 2, 3, 4, 5, 6, 7, 8, 9. The decimal number system has a base or radix of 10. All the digits in decimal number system are expressed in powers of 10 like  $10^0, 10^1, 10^2, \dots$

The quantities  $10^{-1}, 10^0, 10^1, 10^2, 10^3$  are called weights. The integer part and fractional part are separated by a decimal point.

### Binary Number System:

A binary number system uses only two symbols 0 and 1. It has a base or radix of  $2^{10}$ . A binary digit 0 or 1 is called as bit. All the bits have the power of 2 like  $2^0, 2^1, 2^2$  etc.. BH is an abbreviation of binary digit.

$$\begin{aligned} \rightarrow 4 \text{ bit} &= 1 \text{ nibble} \\ \rightarrow 8 \text{ bit} &= 1 \text{ byte} \\ \rightarrow 32 \text{ bit} &= \text{Double word} \end{aligned}$$

### Required to Binary conversion:-

\* Popular method used is double dabble. \* In this, divide the decimal number by 2, writing down the remainder after each division.

\* The remainders take in reverse order ('down' top) to form binary numbers.

Ex :  $(19)_{10} \rightarrow (?)_2$

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

MSB

MSB  $\rightarrow$  Most Significant bit  
LSB  $\rightarrow$  Least Significant bit

$$\textcircled{5}) (101)_10 \rightarrow (1101011)_2$$

$$3) (52)_10 \rightarrow (11010)_2$$

$$4) (19 \cdot 625)_10 \rightarrow (?)_2$$

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

$0.625 \times 2 = 1.250 \rightarrow \text{carry } 1$

$0.250 \times 2 = 0.500 \rightarrow \text{carry } 0$

$0.500 \times 2 = 1.000 \rightarrow \text{carry } 1$

$(10011)_2$

$$\therefore [C(10011 \cdot 101)_2]$$

- \* The fractional part has to be multiplied by 2 by collecting the ~~zeros~~ from ~~top~~ to bottom.
- \* The multiplication can be repeated till the fractional part becomes zero.

- \* If the fractional part is not zero after 4 or 5 steps, it can be stopped at 4th step and take nearest value.

$$5) (13.7)_10 \rightarrow (?)_2$$

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

$0.7 \times 2 = 1.4 \rightarrow 1$

$0.4 \times 2 = 0.8 \rightarrow 0$

$0.8 \times 2 = 1.6 \rightarrow 1$

$0.6 \times 2 = 1.2 \rightarrow 1$

$\boxed{(1101 \cdot 1011)_2}$

$$\begin{array}{r} 1011010 \\ \hline 1x2^0 = 1 \\ 0x2^1 = 0 \\ 1x2^2 = 4 \\ 0x2^3 = 0 \\ 1x2^4 = 8 \\ 0x2^5 = 0 \\ \hline 45 \end{array}$$

2)  $(101101 \cdot 101)_2 \rightarrow (?)_{10}$

$$\begin{array}{r} 1011010 \\ \hline 1x2^0 = 1 \\ 0x2^1 = 0 \\ 1x2^2 = 4 \\ 0x2^3 = 0 \\ 1x2^4 = 8 \\ 0x2^5 = 0 \\ 1x2^6 = 32 \\ \hline 45 \end{array}$$

$$\begin{array}{r} 1011010 \\ \hline 1x2^{-1} = \frac{1}{2} \\ 0x2^{-2} = 0 \\ 1x2^{-3} = \frac{1}{8} \\ 0x2^{-4} = 0 \\ 1x2^{-5} = \frac{1}{32} \\ 0x2^{-6} = 0 \\ \hline 0.625 \end{array}$$

6)  $(125)_10 \rightarrow (11110)_2$

Binary to Decimal Conversion :-

Ex  $(1011)_2 \rightarrow (?)_{10}$  (OR)

$$\begin{array}{r} 11011 \\ \hline 1x2^4 + 1x2^3 + 0x2^2 + 1x2^1 + 1x2^0 \\ 16 + 8 + 0 + 2 + 1 = 27 \end{array}$$

$$\begin{array}{r} 1011010 \\ \hline 1x2^0 = 1 \\ 0x2^1 = 0 \\ 1x2^2 = 4 \\ 0x2^3 = 0 \\ 1x2^4 = 8 \\ 0x2^5 = 0 \\ 1x2^6 = 32 \\ \hline 45 \end{array}$$

$$\begin{array}{r} 1011010 \\ \hline 2^{-1} = \frac{1}{2} \\ 2^{-2} = \frac{1}{4} \\ 2^{-3} = \frac{1}{8} \\ 2^{-4} = \frac{1}{16} \\ 2^{-5} = \frac{1}{32} \\ 2^{-6} = \frac{1}{64} \\ \hline 0.625 \end{array}$$

1. Steps  
write Binary number
2. Directly write  $2^0, 2^1, 2^2, \dots$  from right to left for indices
3. write  $2^{-1}, 2^{-2}, 2^{-3}$  from left to right for fractions
4. Add the weights.

## OCTAL NUMBER SYSTEM:-

The numbers system with base 8 is known as octal.

In this eight symbols 0, 1, 2, 3, 4, 5, 6, 7. As in decimal & binary, it also has integer and fractional part. Since  $2^3 = 8$ . It is a group of 3-bit binary sequence.

| Decimal | Octal | Binary |
|---------|-------|--------|
| 0       | 0     | 000    |
| 1       | 1     | 001    |
| 2       | 2     | 010    |
| 3       | 3     | 011    |
| 4       | 4     | 100    |
| 5       | 5     | 101    |
| 6       | 6     | 110    |
| 7       | 7     | 111    |

Decimal to Octal conversion: - Octal double method to convert a decimal number to octal, divide the number by 8, and collect the remainders from bottom to top.

$$\text{Ex: } (68)_{10} \rightarrow (?)_8$$

$$\begin{array}{r} 8 \\ \overline{68} \\ 8 \\ \hline 4 \end{array}$$

$$\boxed{(104)_8}$$

$$\boxed{(104)_8}$$

$$6) (186)_{10} \rightarrow (?)_8$$

$$7) (19.5)_{10} \rightarrow (?)_8$$

$$8) (49.625)_{10} \rightarrow (?)_8$$

$$\hat{(11.5)}_8$$

$$\begin{array}{r} 8 \\ \overline{186} \\ 16 \\ \hline 26 \\ 24 \\ \hline 2 \end{array}$$

$$\boxed{(272)_8}$$

$$\begin{array}{r} 8 \\ \overline{19.5} \\ 16 \\ \hline 3.5 \\ 3 \\ \hline 0.5 \\ 0.4 \\ \hline 0.1 \\ 0.05 \\ \hline 0.025 \end{array}$$

$$\boxed{(19.75)_8}$$

$$\begin{array}{r} 8 \\ \overline{49.625} \\ 48 \\ \hline 1.625 \\ 1.6 \\ \hline 0.025 \\ 0.02 \\ \hline 0.005 \\ 0.005 \\ \hline 0.000 \end{array}$$

$$4) (18.58)_{10} \rightarrow (?)_8$$

$$\boxed{(142.5)_8}$$

$$\boxed{(142.5)_8}$$

$$0.625 \times 8 = 5.000 \rightarrow \text{carry } 5$$

$$\begin{array}{r} 8 \\ \overline{12-2} \\ 12 \\ \hline 2 \\ 1-4 \\ \hline 4 \end{array}$$

$$3) (98.625)_{10} \rightarrow (?)_8$$

(5)



## HEXADECIMAL NUMBER SYSTEM:-

The computers requires a large number of bits to represent biggest numbers. It has a base of 16 and requires 16 distinct symbols to represent the numbers. These are numerals 0 to 9 and alphabets A, B, C, D, E, F. As numbers and alphabets are used, this system is also known as 'Alphanumeric number system'. Since  $2^4 = 16$ , it follows four bit binary sequence.

| Hex Decimal | Hexadecimal | Binary                  |
|-------------|-------------|-------------------------|
| 0           | 0           | $2^3 + 2^2 + 2^1 + 2^0$ |
| 1           | 1           | $2^3 + 2^2 + 2^1 + 2^0$ |
| 2           | 2           | $2^3 + 2^2 + 2^1 + 2^0$ |
| 3           | 3           | $2^3 + 2^2 + 2^1 + 2^0$ |
| 4           | 4           | $2^3 + 2^2 + 2^1 + 2^0$ |
| 5           | 5           | $2^3 + 2^2 + 2^1 + 2^0$ |
| 6           | 6           | $2^3 + 2^2 + 2^1 + 2^0$ |
| 7           | 7           | $2^3 + 2^2 + 2^1 + 2^0$ |
| 8           | 8           | $2^3 + 2^2 + 2^1 + 2^0$ |
| 9           | 9           | $2^3 + 2^2 + 2^1 + 2^0$ |
| A           | A           | $2^3 + 2^2 + 2^1 + 2^0$ |
| B           | B           | $2^3 + 2^2 + 2^1 + 2^0$ |
| C           | C           | $2^3 + 2^2 + 2^1 + 2^0$ |
| D           | D           | $2^3 + 2^2 + 2^1 + 2^0$ |
| E           | E           | $2^3 + 2^2 + 2^1 + 2^0$ |
| F           | F           | $2^3 + 2^2 + 2^1 + 2^0$ |

(1) Decimal to hexadecimal conversion  
The method used is "Hex divide". This method is to divide successively by 16 and writing the remainders from down to top.

$$1) (256)_{10} \rightarrow (?)_{16} \quad 2) (1397)_{10} \rightarrow (?)_{16}$$

$$\begin{array}{r} 16 \\ \overline{)256} \\ 16 - 0 \\ \hline 1 - 0 \end{array}$$

$(100)_{16}$

$$3) (1020)_{10} \rightarrow (?)_{16}$$

$$\begin{array}{r} 16 \\ \overline{)1020} \\ 16 - 12 \\ \hline 3 - 15 \end{array}$$

$(3F0)_{16}$

$$4) (213)_{10} \rightarrow (?)_{16}$$

$$\begin{array}{r} 16 \\ \overline{)213} \\ 16 - 13 \\ \hline 5 \end{array}$$

$(D5)_{16}$

$$5) (98.625)_{10} \rightarrow (?)_{16}$$

$$\begin{array}{r} 16 \\ \overline{)98} \\ 6 - 2 \\ \hline \end{array}$$

$$0.625 \times 16 = \frac{10}{16} .000$$

$(62.A)_{16}$

$$39 \cdot 5)_0 \rightarrow (?)_{16}$$

$$\begin{array}{r} 16 \\ \overline{)39} \\ 2 - \cancel{3} \\ \hline 16 \\ (23)_{16} \end{array} \cdot 5 \times 16 = 8.0$$

$$(23.8)_{16}$$

$$45 \cdot 65)_0 \rightarrow (?)_{16}$$

$$\begin{array}{r} 16 \\ \overline{)45} \\ 2 - \cancel{4} \\ \hline 13 - \cancel{5} \\ 0.40 \times 16 = 6.4 \rightarrow \text{carry } 6 \\ (2D)_{16} \end{array}$$

$$(2D.A66)_{16}$$

$$88 \cdot 525)_0 \rightarrow (58.866)_{16}.$$

Hexadecimal to decimal conversion :-  
In this case the weights used are

$$16^3, 16^2, 16^1, 16^{-1}, 16^{-2}, 16^{-3}.$$

$$5) (CD5)_{16} \rightarrow (?)_{10}$$

$$\begin{array}{r} 16^3 = 16 \\ 16^2 = 256 \\ 16^3 = 4096 \\ 16^4 = 65536 \\ \hline 213 \end{array}$$

$$(213)_{10}$$

$$\begin{array}{r} 0.5 \\ \times 16 \\ \hline 30 \\ 0 \end{array}$$

$$4) (3FC.8)_4 \rightarrow (?)_{10}$$

$$\begin{array}{r} 3 \ 15 \ 12 \\ \hline 12 \times 16^0 = 12 \\ 15 \times 16^1 = 240 \\ 3 \times 16^2 = 768 \\ \hline 1020 \end{array}$$

$$(65,535)_{10}$$

$$(1020.5)_{10}$$

$$5) (9A.4)_{16} \rightarrow (?)_{10}$$

$$\begin{array}{r} 9 \ 10 \\ \hline 10 \times 16^0 = 10 \\ 9 \times 16^1 = 144 \\ \hline 154 \end{array}$$

$$(154.625)_{10}$$

$$6) (56.48)_{16} \rightarrow (?)_{10}$$

$$\begin{array}{r} 5 \ 6 \\ 48 \times 16^0 = 6 \\ 5 \times 16^1 = 80 \\ \hline 86 \end{array}$$

$$(86.48)_{10}$$

$$\begin{array}{r} 15 \ 15 \ 15 \\ \hline 15 \times 16^0 = 15 \\ 15 \times 16^1 = 240 \\ 15 \times 16^2 = 3840 \\ 15 \times 16^3 = 61440 \\ \hline 65,535 \end{array}$$

$$\begin{array}{r} 14 \ 9 \\ 9 \times 16^0 = 9 \\ 14 \times 16^1 = 224 \\ \hline 233 \end{array}$$

$$2) (E9)_{16} \rightarrow (?)_{10}$$

$$\begin{array}{r} 14 \ 9 \\ 9 \times 16^0 = 9 \\ 14 \times 16^1 = 224 \\ \hline 233 \end{array}$$

$$(233)_{10}$$

$$\begin{array}{r} 15 \ 15 \ 15 \\ \hline 15 \times 16^0 = 15 \\ 15 \times 16^1 = 240 \\ 15 \times 16^2 = 3840 \\ 15 \times 16^3 = 61440 \\ \hline 65,535 \end{array}$$

$$\begin{array}{r} 0.5 \\ \times 16 \\ \hline 30 \\ 0 \end{array}$$

$$3) (FFFF)_{16} \rightarrow (?)_{10}$$

$$\begin{array}{r} 15 \ 15 \ 15 \\ \hline 15 \times 16^0 = 15 \\ 15 \times 16^1 = 240 \\ 15 \times 16^2 = 3840 \\ 15 \times 16^3 = 61440 \\ \hline 65,535 \end{array}$$

$$(65,535)_{10}$$

$$\begin{array}{r} 0.5 \\ \times 16 \\ \hline 30 \\ 0 \end{array}$$

$$(65,535)_{10}$$

Octal to Binary conversion :-

To convert an octal to binary, we have to do & replace each octal digit with its equivalent 3-bit binary. The weights required are  $2^2, 2^1, 2^0$

$(CH_{12,1})$

| Octal     | Binary         | Decimal  |
|-----------|----------------|----------|
| $(13)8$   | $(1101)_2$     | $13$     |
| $(543)8$  | $(10101001)_2$ | $93$     |
| $(101)8$  | $(101)_2$      | $5$      |
| $(45.5)8$ | $(100.101)_2$  | $37.625$ |

Binary to Octal conversion :-

To convert a binary number to octal, we have to arrange the bits into group of 3 bits starting from LSB. If the final group has less than 3 bits, just include zeros to make it group of 3 bits.

Ex :  $(10101)_2 \rightarrow (?)_8$

$$(10101)_2 = (01010)_2 = (25)_8$$

- \* For integer part, 3 bits groups are formed starting from point and moving towards left.
- \* For fractional part, from point and moving towards right.

right.

$\Rightarrow (110.101)_2 \rightarrow (?)_8$

$$\left( \frac{110}{6} \cdot \frac{101}{5} \right) = (16.5)_8$$

$$(2010111 \cdot 100)_2 = (27.4)_8$$

4)  $(11 \cdot 1)_2 \rightarrow (?)_8$  5)  $(1010110.01)_2$

$$(011 \cdot 100)_2 = (3 \cdot 4)_8$$

$$(126 \cdot 2)_8$$

$$001010 \ 110. \ 010$$

Hexadecimal to Binary conversion :-

To convert a hexadecimal to binary, we have to do & replace each hex digit with equivalent 4-bit binary.

Ex  $(25)_{16} \rightarrow (?)_2$

$$(0010 \ 0101)_2$$

$$(0011 \ 1010)_2$$

$$(0011 \cdot 1010 \cdot 0111)_2$$

4)  $(CD.E8)_{16} \rightarrow (?)_2$

$$(1101 \ 1100 \ 1000)_2$$

$$(1111 \ 1111 \cdot 1110 \ 0110)_2$$

5)  $(FF.E6)_{16} \rightarrow (?)_2$

$$(1111 \ 1111 \ 1101 \ 0110)_2$$

$$(1111 \ 1111 \cdot 1100 \ 0110)_2$$

Binary to Hexadecimal conversion :-

To convert a binary number to hexadecimal, arranging the bits into group of 4 bits from LSB. If it has less than 4 bits just include zeros.

$$\begin{aligned} 6) (100101)_2 &= (?)_{16} \\ (0010 \ 0101)_2 &= (A5)_{16} \end{aligned}$$

$$2) (1010.101)_2 = (?)_{16}$$

$$0110 \ 1010 = (6 \cdot A)_{16}$$

$$4) (1110.11)_2 = (?)_{16}$$

$$(1110 \cdot 1100)_2 = (E \cdot C)_{16}$$

$$5) (110111.1)_2 = (?)_{16}$$

$$0111 \ 0111 \cdot 1000$$

Q

(2)  
**BINARY ARITHMETIC**

We know how to perform arithmetic operations like addition, subtraction, in decimal systems. Now we have to know in binary number system which help us to understand arithmetic digital circuits like adder, subtractor etc.

(101)<sub>57</sub>

10100

$$\begin{array}{r} 2 \\ \times 20 \\ \hline 10 - 0 \end{array}$$

when the decimal numbers are converted to binary.

## Binary Addition

The addition of two binary numbers is very much similar to addition of two decimal numbers. The following rules are followed while adding two binary numbers.

$$\begin{array}{r}
 0+1 = -1 \\
 1+0 = 1 \\
 1+1 = 0 \\
 1+1+1 = 11
 \end{array}$$

(Read as 0 with a carry.)

Ex: Adding  $1011_2$  and  $1101_2$

$$\text{Subject 3} = 0.11$$

agent 3 - 011  
Addend 4 - 100

100

34

$$\begin{array}{r}
 & & & 1 \\
 & & & 0.111 \\
 & & 0 & 111 \cdot 11 \\
 & 0 & 100 \cdot 01 \\
 \hline
 1 & 100 \cdot 00
 \end{array}$$

$$\begin{array}{l}
 \begin{array}{r}
 4.25 \cdot 0.25x_2 = 0.50 \rightarrow 0 \\
 7.75 \cdot 0.50x_2 = 1.00 - 1
 \end{array} \\
 \hline
 \underline{12.00}
 \end{array}$$
  

$$\begin{array}{r}
 0.25x_2 = 0.50 \\
 0.50x_2 = \underline{1.00} \\
 \hline
 \end{array}
 \quad
 \begin{array}{r}
 01^{\circ} 0.75x_2 = 0.50 \\
 0.50x_2 = \underline{1.00} \\
 \hline
 \end{array}$$
  

$$\begin{array}{r}
 01^{\circ} 0.50x_2 = 1.00 \\
 \hline
 0111^{\circ} 2
 \end{array}$$
  

$$\begin{array}{r}
 (4.25)_1 = (0100 \cdot 01)_2 \\
 (7.75)_1 = (0111 \cdot 11)_2
 \end{array}$$
  

$$\begin{array}{r}
 (1100 \cdot 00)_2 = (12)_10 \\
 \hline
 \end{array}$$

5) Decimal

$$\begin{array}{r}
 \text{Binary} \\
 \overline{1011} \\
 -10 \\
 \hline
 11 \\
 -10 \\
 \hline
 1
 \end{array}
 \quad
 \begin{array}{r}
 6) \\
 \text{Binary} \\
 \overline{10100} \\
 -10 \\
 \hline
 00
 \end{array}$$

15 5 5 pure

2) Add 5 and 6

3) Add 13 and 7

Augend 5 - 101  
Addend 6 - 110

一一〇一

$$\begin{array}{r} 2 \\ \hline 2 | 20 \\ \hline 10 - 0 \end{array}$$

Scanned by CamScanner

### Binary addition :-

1) Add  $9_4$  and  $12_5$

$$16 \overline{)9H} \quad (5E)_6 \quad 16 \overline{)125} \\ \underline{5-E} \quad \underline{7-13} \quad \underline{7D}_6.$$

$$(94)_10 = 5E = 0101 \ 1110 \rightarrow \text{augend}$$

$$(125)_10 = 7D = 0111 \ 110 \rightarrow \text{addend}$$

$$(219)_6 = (\text{DB})_6 = \underline{\underline{1101 \ 1011}} \rightarrow (\text{DB})_6$$

2) Add  $5.125$  and  $7.15$

$$(5.125)_10 = (0101 \cdot 0001 \ 0010 \ 0101)_2 \rightarrow \text{augend}$$

$$(7.15)_10 = (0111 \cdot 0111 \ 0101 \dots)_2 \rightarrow \text{addend}$$

$$\begin{array}{r} 1100 \cdot 1000 \ 0111 \ 0101 \\ \hline (12 \cdot 8 \cdot 7 \cdot 5) \end{array}$$

Binary subtraction :-  
The following rules are used in subtracting two binary numbers.

|                                                  |
|--------------------------------------------------|
| $0 - 0 = 0$                                      |
| $0 - 1 = 1$ (Read as difference 1 with a borrow) |
| $1 - 0 = 1$                                      |
| $1 - 1 = 0$                                      |

3) Subtract 5 from 7  
7 - Minuend  
5 - Subtrahend

$$\begin{array}{r} 111 \\ 101 \\ \hline 010 = 2. \end{array}$$

2) Subtract 8 from 13

13 - Minuend  
8 - Subtrahend

$$\begin{array}{r} 110 \\ 100 \\ \hline 1010 = 10. \end{array}$$

3) Subtract 14 from 17

17 - Minuend  
14 - Subtrahend

$$\begin{array}{r} 11001 \\ 10001 \\ \hline 00011 = 3. \end{array}$$

Binary multiplication:  
The following rules are used to multiply two binary numbers.

|                   |
|-------------------|
| $0 \times 0 = 0$  |
| $0 \times 1 = 0$  |
| $1 \times 0 = 0$  |
| $1 \times 1 = 1.$ |

Multiplication of binary is same as that of decimal.

(11)

$\Rightarrow$  multiply 7 and 3

$\rightarrow$  multiplicand  
 $\rightarrow$  multiplier

$$\begin{array}{r} \underline{\underline{3}} \\ \times \underline{\underline{1}} \\ \hline \end{array}$$

2) Multiply 13 and 11

$$\begin{array}{r} 13 \\ \times 11 \\ \hline \underline{\underline{143}} \end{array}$$

1101

$$\begin{array}{r} 10 \\ \times 4 \\ \hline \underline{\underline{40}} \end{array} = (20)_0.$$

$$\begin{array}{r} 16 \\ \times 15 \\ \hline \underline{\underline{160}} \end{array}$$

$$\begin{array}{r} 1000111 \\ \times 10 \\ \hline \underline{\underline{8}} \end{array} = (87)_A = (143)_0$$

Binary Division:-  
Binary division has only two rules

$$\boxed{\begin{array}{l} 0 \div 1 = 0 \\ 1 \div 1 = 1 \end{array}}$$

Example: Divide 6 by 3

$$\begin{array}{r} 3 \sqrt{6} \\ \underline{\underline{3}} \\ 0 \end{array}$$

$$011 \begin{array}{r} 10 \\ \times 1 \\ \hline 00 \end{array} \rightarrow (2)$$

2) Divided 10 by 4

$$\begin{array}{r} 10 \\ \times 4 \\ \hline \underline{\underline{20}} \\ 20 \\ \hline 0 \end{array} \quad (2)^0$$

1's and 2's complement:  
is complement of the bit is defined as  
the 1's complement of the bit.

1 minus that bit.  
i.e. 1's complement of 1 is  $1 - 1 = 0$   
1's complement of 0 is  $1 - 0 = 1$

It is easy to say that 1's complement of 1 is 0  
and 0 is 1.

$$\begin{array}{r} \text{Ex: } 1011 \rightarrow 0100 \\ 10100 \rightarrow 01101 \\ 1010101 \rightarrow 01010010 \end{array}$$

2's complement:-  
2's complement is formed by adding 1 to  
the 1's complement.

Ex Find 2's complement of 1010

$$1's \text{ complement of } 1010 = 0101$$

$$(+) \quad \begin{array}{r} 1 \\ 0110 \end{array}$$

$$2's \text{ complement of } 1010 = 0110$$

q's complement and 10's complement :-  
q's complement is obtained by subtracting the decimal number from 9. For more numbers subtract each digit from 9.

$$\text{Ex q's complement of } 4 \text{ is } 9-4 = 5$$

$$\text{q's complement of } 7 \text{ is } 9-7 = 2$$

$$\text{q's complement of } 123 \text{ is } 999 - 123 = 876$$

q's complement of 5647 is  $9999 - 5647 = 4352$   
10's complement  $\rightarrow$  It is obtained by adding 1 to the q's complement.

$$\text{Ex 10's complement of } 4 \text{ is } 9-4 = 5+1 = 6.$$

$$10's \text{ complement of } 25 \text{ is } 99 - 25 = 74 + 1 = 75$$

Subtraction using complements :-  
1) q's complement subtraction :-  
Steps:

- ① take the minuend in binary form as  $M$ .
- ② take 1's complement of subtrahend and add

It to the minuend.

3) If a carry is produced add the carry to the sum (B)

Ex : Subtract 4 from 13.

$$4 \rightarrow 0100 \rightarrow \text{subtrahend.} \quad 13 \rightarrow 1101$$

$$\begin{array}{r} 13 \\ 0100 \\ \hline 9 \end{array}$$

$$1's \text{ comp of } 1011 \rightarrow 1100$$

$$0110 \quad \boxed{1100} \rightarrow 0010$$

$$\begin{array}{r} 1001 \\ 1100 \\ \hline 1000 \\ 1000 \\ \hline 0010 \end{array}$$

$$0110 \quad \boxed{1000} \rightarrow 0010$$

2's complement subtraction :-

Step 1 : Take the minuend in binary form as  $M$  is

2) Take 2's complement of subtrahend and add to the minuend.

3) If carry produces ignore the carry.

Ex : Subtract 13 from 13      2) subtract 14 from 17

$$\begin{array}{r} 13 \rightarrow 1101 \\ 14 \rightarrow 1100 \\ \hline 1100 \end{array} \quad \begin{array}{r} 13 \rightarrow 1000 \\ 14 \rightarrow 1001 \\ \hline 1001 \end{array}$$

$$13 \rightarrow 1000 \quad \boxed{1001} \rightarrow 0011$$

$$13 \rightarrow 1000 \quad \boxed{1001} \rightarrow 0011$$

(13)

9's complement subtraction:

- Take the minuend as it is. (not in binary)
- Take 9's complement of subtrahend and add to minuend.

- If a carry is produced add carry to minuend.

Ex: subtract 5 from 8

$$\begin{array}{r} 8 \\ - 5 \\ \hline 3 \end{array}$$

9's 9-5 12+1 = 3

10's complement subtraction:

- Take the minuend as it is
- Take 10's complement of subtrahend and add to minuend

- Ignore the carry.

Ex: Subtract 5 from 8.

$$8 \rightarrow \text{sub} \rightarrow 8$$

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

10's 4+1 = 5 13 = 3

Signed Binary numbers:-

In a decimal number system we use '+' sign to denote positive number and '-' to denote -ve number. The digit 0 is used to represent positive number and 1 is used to represent negative number. The bit is used to represent the sign is called sign bit. It is always MSB of binary numbers.

Ex: sign -1's complement.

To represent a negative number in 1's complement form the following two steps are used.

1) write a positive binary form of the number

2) invert each bit including the sign bit (ie) take 1's complement.

Ex: the sign -1's complement representation for

$$\begin{array}{r} -12. + 12 = 00001100 \\ - 12 = 11110011 \end{array}$$

Sign -2's complement:

1) write a positive binary form of the number including sign bit.

2) Invert each bit including the sign bit (ie)

take 1's complement.

3) Add 1 to the result.

Ex: the sign -2's complement for 12.

$$\begin{array}{r} + 12 = 00001100 \\ - 12 = 1110011 + \\ 1's \end{array}$$

111 0100

Ex: 10000000000000000000000000000000 (8 bits)

-5

00000000000000000000000000000001

(8 bits)

## UNIT - 1

### BINARY CODES

All digital circuits operate with only two states and some binary codes are required to represent alphabets and special characters. Digital calculators frequently makes prefer 4-bit code to represent decimal numbers 0 to 9.

BCD codes - 8421 codes :-

A group of bits (usually four) which are used to represent decimal numbers 0 to 9 are called binary coded decimal codes or BCD codes.

The most popular BCD code is 8421 code. The 8421 indicates the binary weights of four bits ( $2^3, 2^2, 2^1, 2^0$ ). The four bits with weights 8, 4, 2, 1 can be easily represent the decimal numbers 0-9. The four bit binary combination can be represented for first ten combination. The six remaining combinations 1010, 1011, 1100, 1101, 1110, 1111 are invalid BCD codes.

| Decimal | 8421 | Decimal | 8421 |
|---------|------|---------|------|
| 0       | 0000 | 6       | 0110 |
| 1       | 0001 | 7       | 0111 |
| 2       | 0010 | 8       | 1000 |
| 3       | 0011 | 9       | 1001 |
| 4       | 0100 |         |      |
| 5       | 0101 |         |      |

| Decimal | 8421 BCD code    |
|---------|------------------|
| 15      | 0001 0101        |
| 29      | 0010 1001        |
| 468     | 0100 0110 1000   |
| 475     | 1001 0111 . 0101 |

Note: Each digit must be represented by 4-bit BCD code.

BCD (8421) Addition :-

\* The general rule for Binary Addition is 0+0=0, 0+1=1, 1+0=1, 1+1=10. (0 with carry 1)

The rules for BCD addition

1) Add the two numbers using rules of binary addition  
2) If a valid BCD number.

3) If the 4-bit sum is greater than 9, or if a carry out of a BCD group is generated, the result is invalid BCD. To get correct BCD result add (06) to the 1st group and take carry to next group.

Ex 2 Add 5 and 2.

Ex 2 Add 7 + 6.

Add 5 and 2  
 $5 + 0101$   
 $2 + 0010$   
 $\overline{7 = 0111} \rightarrow$  valid BCD

$7 - 0111$   
 $6 - 0110$   
 $\overline{13 = 1101} \rightarrow$  generated, it exceeds

$7 + 0110 \rightarrow$  Add (06)  
 $6 + 0110 \rightarrow$  Add (06)  
 $\overline{12 = 1001}$   
 $1001 + 0001 \rightarrow$  Add (06)  
 $\overline{11 = 1011}$

## 2421 codes and 4221 codes:-

The 8421 code is very useful code. we have seen how to add two BCD numbers. But there is a difficulty in this code. we know that subtraction operation is done in computers, by adding the complement of the subtrahend. This method is not useful in 8421 BCD code.

Ex Subtrahend is  $0010_{(2)}$   
1's complement is  $1101$

and  $1101$  is not a valid BCD number because it is greater than 9.

To solve this problem, the codes are designed in such a way that when the binary code representing a decimal number is complemented, the binary code representing the 9's complement of the decimal number is obtained. Such codes are called self-complementing codes. Two such codes are 2421 and 4221 codes.

| Decimal | 2421 | 4221 | Decimal | 2421 | 4221 |
|---------|------|------|---------|------|------|
| 0       | 0000 | 0000 | 7       | 1101 | 1101 |
| 1       | 0001 | 0001 |         | 1110 | 1110 |
| 2       | 0010 | 0010 | 8       | 1111 | 1111 |
| 3       | 0011 | 0011 |         |      |      |
| 4       | 0100 | 0100 |         |      |      |
| 5       | 1011 | 1001 |         |      |      |
| 6       | 1100 | 1100 |         |      |      |

## 2421 code.

Ex D' Binary code for  $2 = 0110$   
Taking 1's complement  $1101$  and this represents 7 which is 9's complement of 2.

$$9's \text{ complement} : 9 - 2 = 7$$

### 4221 code :-

Ex D' binary code for  $1 = 0001$   
Taking 1's complement  $1110$  and this code represents 8, which is 9's complement of 1.

$$9's \text{ comp } 9 - 1 = 8$$

### 2) Binary code for 4 = 0110

1's complement =  $1001 \rightarrow 5$  of 4221  
9's compd  $4 = 9 - 4 = 5$

### Excess-3 code :-

The Excess-3 code is another BCD code. The Excess-3 code for decimal digit 8 is obtained by adding 0011 (3) in 4221.

Conversion methods. Two types of conversions are needed

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

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

The Excess-3 code has 10 valid codes and 6 invalid codes are 0000, 0001, 0010, 1101, 1110 and

iii. Like in 8421 code, In excess-3 code also if the number is greater than 9, the code is given separately for each digit.

| Decimal | Excess-3 code  |
|---------|----------------|
| 26      | 0101 1001      |
| 97      | 1100 1010      |
| 853     | 1011 1000 0110 |

Excess-3 addition:-  
The addition in Excess-3 code is also not straight forward and requires inclusion of 8421 and the next group will be 0...1

$$\begin{array}{r}
 \text{Ex} \quad 2 + \\
 32 \\
 \hline
 47 \\
 \hline
 79
 \end{array}
 \rightarrow 0011 \quad 0011 \quad \text{Excess-3 ad 92} \\
 \begin{array}{r}
 0110 \quad 0101 \quad \text{Ex-3 ad 92} \\
 0111 \quad 1010 \quad \text{ex-3 ad 42} \\
 \hline
 1101 \quad 1111 \quad \text{Excess-6 ad 79}
 \end{array} \\
 \rightarrow 0011 \quad 0011 \quad \text{Subtract 9 from} \\
 \begin{array}{r}
 1010 \quad 1100 \quad \text{Ex-3 ad 79 which} \\
 \hline
 1010 \quad 1100 \quad \text{is correct result}
 \end{array}$$

Case 2: A carry is produced.  
when the sum of two decimal digit represented in Excess-3 exceeds 9, there will be a carry from one group into next. when it happens, the group that produced the carry will be 8421 and the next group will be 0...1

To get the result in proper excess-3 form, we have to add 3 to the group that has produced the carry and subtract from next group.

$$\text{Ex } 29 +$$

$$\begin{array}{r} 49 \\ \hline 78 \end{array}$$

$$\begin{array}{r} 0101 \\ 0111 \\ \hline 1101 \end{array} \quad \text{Ex-3 for 49}$$

$$\begin{array}{r} 1000 \\ 0011 \\ \hline 1011 \end{array}$$

$$\begin{array}{r} 1010 \\ 1011 \\ \hline 0011 \end{array} \quad \text{Sub 3 from 1st group and add 3 to 2nd}$$

$$\begin{array}{r} 1010 \\ 1011 \\ \hline 0010 \end{array} \quad \rightarrow \text{correct result in ex-3}$$

Gray codes:-

This code can be used in sequence counting when the count advances by one, to reduce error, the number of changes in the bits has to be kept minimum.

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

Binary to Gray conversion:-  
To convert a binary number to its equivalent Gray code, the following rules are applied.

The MSB of the Gray code is the same as the MSB of the binary.

Coding from left to right, add each adjacent pair of bits to get the next bit of the Gray code. Omit the carries if occurs.

Ex: Let us convert the binary number 1011 to Gray code.

Binary number  $1011 = 1110$  in Gray code.

Step 1: The left most bit (MSB) in Gray code is the same as MSB of the binary.

1011 Binary

Step 2:   
 1 + 0 11  
 11 → ignore the carry.

1011 → 1110 (Gray)

Ex 2: Represent  $(45)_{10}$  in binary and Gray code.

$$\begin{array}{r} 45 \\ \hline 22 \\ 11 \\ 5 \\ 2 \\ 1 \\ \hline 0 \end{array}$$

$$(10101)_{10} = (11101)_{\text{Gray}}$$

## ASCII code

ASCII stands for American Standard Code for Information Interchange. This is 7-bit code used to represent decimal digits 0 to 9, alphabets A to Z both lower case and upper case and some special characters. That's ASCII is an alpha numeric code.

Since ASCII is a 7-bit code there are  $2^7 = 128$  possible binary combinations.

| ASCII symbol | Decimal | Hex | 7-binary |
|--------------|---------|-----|----------|
| 0            | 48      | 30  | 011 0000 |
| 1            | 49      | 31  | 011 0001 |
| 2            | 50      | 32  | 011 0010 |
| 3            | 57      | 3A  | 011 1001 |
| 4            | 58      | 3B  | 011 1010 |
| 5            | 63      | 3F  | 011 1111 |
| A            | 65      | 41  | 100 0001 |
| B            | 66      | 42  | 100 0010 |
| Z            | 90      | 5A  | 100 0110 |
| a            | 97      | 61  | 100 0111 |
| b            | 98      | 62  | 100 1000 |
| Z            | 122     | 7A  | 110 0010 |
| DEL          | 127     | 7F  | 111 1111 |

Note:  
Another alphanumeric code commonly used in IBM machine is called as Extended Binary Coded Decimal Interchange code - EBCDIC

Basic logic gates  
NOT, OR, AND:  
Gate is an electronic circuit with one or more inputs but only output. All the gates are digital because the input and output signals are either in or out.

## DIGITAL LOGIC

### Logic Gates:-

The binary number system uses only two bits '0' and '1'. The digital circuits use only two states ON and OFF, HIGH and LOW, TRUE or FALSE. The Boolean algebra is developed by Boole. The digital circuits, which use binary number system are also called as logic circuits. The electronic switching circuits are called as logic gates. Logic gates form the fundamental building blocks for all the digital circuits. A low voltage is represented by '0' and high voltage is represented by '1'.

### Analog and Digital Signals:-

Analog signal is continuous in nature and takes all possible values within a limit. A sample of analog signal has values with time.  
A digital signal has only two values. High (H) and Low (L). It requires a power supply of 5 Volts & marked as Vcc. 

## NOT GATE OR INVERTER :-

A NOT gate has only one input and one output.

For the NOT gate, when the input is low (logic 0), and the output is high (logic 1), and when the input is high the output is low. (ie) the complement of the input is high or inverse of the input. the input is marked as  $\bar{A}$  and the output is marked as  $\bar{A}$ .

and the output  $y = \bar{A}$  marked as  $\bar{A}$ .

The output  $y = \bar{A}$  can be read as complement of A or inverse of A or not A or simply A bar.

Truth Table :-

A truth table gives the output state for each possible input state combination. For the NOT gate, there is only one input and can have two possible combinations namely 0 and 1. The truth table for NOT gate is as follows:

| $A$ | $y = \bar{A}$ | $A$  | $y = \bar{A}$ |
|-----|---------------|------|---------------|
| 0   | 1             | Low  | High          |
| 1   | 0             | High | Low           |

$A$  is the input binary variable and  $y$  is the output binary variable. The binary variable is also called as logical variable. In the symbol of the NOT gate, the small circle usually called as the bubble at the end

of the triangle is used to indicate inversion. If the bubble is removed, the gate is called as the buffer. For the buffer the output is equal to the input.



OR Gate :-

An OR gate performs logical addition. An OR gate has two or more inputs and the output is one. If any input signal is HIGH, the output signal goes HIGH. The output is LOW only when all the inputs are LOW. For two inputs there are  $2^2 = 4$  combinations.



Here A and B are input logical variables and Y is the output. The output Y is given by the expression  $y = A + B$ .

for 2<sup>2</sup> input 2<sup>2</sup> = 8 combinations.  $y = A + B + C$ .

| $A$ | $B$ | $C$ | $y = A + B + C$ |
|-----|-----|-----|-----------------|
| 0   | 0   | 0   | 0               |
| 0   | 0   | 1   | 1               |
| 0   | 1   | 0   | 1               |
| 0   | 1   | 1   | 1               |
| 1   | 0   | 0   | 1               |
| 1   | 0   | 1   | 1               |
| 1   | 1   | 0   | 1               |
| 1   | 1   | 1   | 1               |



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

### AND GATE:-

An AND gate performs logical multiplication. An AND gate has two or more inputs and one output. If any input signal is low, the output signal goes low. The output is high only when all the inputs are high.



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

The logic symbol and truth table for 3-inputs are



| A | B | C | $y = ABC$ |
|---|---|---|-----------|
| 0 | 0 | 0 | 0         |
| 0 | 0 | 1 | 0         |
| 0 | 1 | 0 | 0         |
| 0 | 1 | 1 | 0         |
| 1 | 0 | 0 | 0         |
| 1 | 0 | 1 | 0         |
| 1 | 1 | 0 | 0         |
| 1 | 1 | 1 | 1         |

### Logic Circuits and Logic Expressions:-

The logic expression are also called as Boolean expression. we must learn to construct digital circuits for a given problem, using

- \* A set of statements (or)
- \* Boolean expression (or)
- \* Truth table.

for the given logic circuit, obtain the logic expression for the output and form the truth table

Solution:-  
The input to the AND gate is A and B and C as input to the OR gate.  
Therefore, the output is  $A \cdot B$ . The output is given as  $y = AB + C$ .  
Therefore, the final output is



There are 8 binary combinations.

| A | B | C | AB | $y = AB + C$ |
|---|---|---|----|--------------|
| 0 | 0 | 0 | 0  | 0            |
| 0 | 0 | 1 | 0  | 1            |
| 0 | 1 | 0 | 0  | 0            |
| 0 | 1 | 1 | 0  | 1            |
| 1 | 0 | 0 | 0  | 0            |
| 1 | 0 | 1 | 0  | 1            |
| 1 | 1 | 0 | 1  | 1            |
| 1 | 1 | 1 | 1  | 1            |

Ex 2) For the given logic circuit obtain, the logic expression for the output and from truth table.



Solution:-

The Input to the top AND gate is A and B therefore the output is A · B. The input to the bottom AND gate is A and B and therefore its output is A · B. Therefore two outputs act as input to an OR gate and the output of OR gate is

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

Ex 3) For the logic expression  $y = AB + \bar{B}C$ , draw the logic circuit using only AND, OR and NOT gates.

Solution:-

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



| A | B | $\bar{B}$ | $\bar{B}C$ | $AB$ | $\bar{A}\bar{B}$ | $Y = AB + \bar{B}C$ |
|---|---|-----------|------------|------|------------------|---------------------|
| 0 | 0 | 1         | 0          | 0    | 1                | 0                   |
| 0 | 1 | 0         | 0          | 0    | 0                | 0                   |
| 1 | 0 | 1         | 0          | 0    | 0                | 0                   |
| 1 | 1 | 0         | 1          | 1    | 0                | 1                   |

4) For the logic expression  $y = \bar{A}B + A\bar{B}$  draw the logic gate using AND, OR and NOT.

Solution:-

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



(OR)



These are two methods widely used to convert the truth table to a logical expression. They are

- Sum of product (SOP)
- Product of sum (POS)

Sum of products (SOP) :-

In SOP, the expression consists of number of terms (depending on the problem). Each term is a logical product of input variables. All the terms are logically summed up to give the output and hence the name sum of product.

$$Ex: Y = \bar{A}\bar{B}C + \bar{A}B\bar{C} + A\bar{B}C$$

The expression is said to be sum of product form. The first term is a logical product of  $\bar{A}$ ,  $\bar{B}$  and  $C$ . The second term is a logical product of  $\bar{A}$ ,  $B$  and  $C$ . The third term is a logical product of  $A$ ,  $B$  and  $C$ . The products  $\bar{A}\bar{B}C$ ,  $\bar{A}B\bar{C}$  and  $A\bar{B}C$  are logically summed up to give the sum of product expression. This expression is also called as standard sum of product or standard SOP. The products  $\bar{A}\bar{B}C$ ,  $\bar{A}B\bar{C}$ ,  $A\bar{B}C$  are called fundamental or standard products. These fundamental products are also called as minterms.

For two variables  $A$  and  $B$  there are four possible combinations.  $\bar{A}\bar{B}$ (00),  $\bar{A}B$ (01),  $A\bar{B}$ (10),  $AB$ (11) and therefore there are 4 standard products or 4 minterms.

Truth table:

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

Product of sum:-  
In this method each term is a logical sum (OR) of input variables. All the terms are logically multiplied to give the output and hence the name Product of sums (POS).

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

(using Boolean algebra this expression can be simplified to give  $Y = \bar{B}$ ) (ie  $A + \bar{A} = 1$ )

$$\begin{array}{|c|c|c|c|c|} \hline A & B & C & Y \\ \hline 0 & 0 & 0 & 0 \\ 0 & 0 & 1 & 1 \\ 0 & 1 & 0 & 0 \\ 0 & 1 & 1 & 0 \\ \hline \end{array}$$

when  $A=0, B=0, C=1$  SOP  $A\bar{B}C$   
 $A=1, B=0, C=0$  SOP  $A\bar{B}C$   
 $A=1, B=1, C=1$  SOP  $ABC$

$\therefore$  Standard SOP expression  
 $\therefore$   $\bar{A}B + A\bar{B}C$

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

To write the standard SOP expression for the truth table, select the rows whose output is 1.  
In 1st row  $Y=1$ , when  $A=0$  and  $B=0$ . Both are complemented  $\bar{A}=1, \bar{B}=1$  so that logical product  $\bar{A}\bar{B}$  gives 1. In 3rd row  $Y=1$ ,  $A=1, B=0$ . In this case only  $B$  needs to be complemented and  $A\bar{B}$  gives a 1. Therefore the two standard products are  $\bar{A}\bar{B}$  and  $A\bar{B}$ . These two standard products are logically summed to give the standard SOP.

In SOP each term is logical product and gives a logical 1. In POS each term is a logical sum and produces a logical 0. Therefore, the product of the sums also gives a zero.

$$\text{Ex: } f(A, B, C) = (\bar{A} + \bar{B} + \bar{C}) (A + \bar{B} + C) (\bar{A} + B + \bar{C})$$

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

is said to be in product of sum form.

The sums of  $(A+B+C)$ ,  $(\bar{A}+\bar{B}+\bar{C})$  are called

fundamental or standard sums.

\* The term  $(\bar{A} + \bar{B} + C)$  corresponds to  $A=1, B=1$  and

$$C=0$$

so that  $(\bar{A} + \bar{B} + \bar{C}) = 0$ .

\* The term  $(\bar{A} + B + \bar{C})$  corresponds to  $A=1, B=0, C=1$

$$C=0$$

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

\* The term  $(A + B + C)$  corresponds to  $A=0, B=0, C=0$   
 $\therefore$  The terms put together gives  $y = 0 \cdot 0 \cdot 0 = 0$   
 These fundamental/standard sums are also called as Max terms.

| A | B | C | y |
|---|---|---|---|
| 0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 1 |
| 0 | 1 | 0 | 1 |
| 0 | 1 | 1 | 0 |
| 1 | 0 | 0 | 1 |
| 1 | 0 | 1 | 0 |
| 1 | 1 | 0 | 0 |
| 1 | 1 | 1 | 1 |



$$\text{Ex Gate for POS :-}$$

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



$$\text{The expression is in POS form.}$$

$$\text{Ex Gate for POS :-}$$

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

$y=0$ , when  $A=0, B=0$ , and  $C=0$ , the standard sum is  $(A+B+C)$  when  $A=0, B=1$  and  $C=0$ , the standard sum is  $(A+\bar{B}+C)$   $A=0, B=1, C=1$ , the standard sum is  $(A+\bar{B}+\bar{C})$   $A=1, B=0, C=0$ , the standard sum is  $(\bar{A}+B+C)$   $A=1, B=0, C=1$ , the standard sum is  $(\bar{A}+B+\bar{C})$   $A=1, B=1, C=0$ , the standard sum is  $(\bar{A}+\bar{B}+C)$   $A=1, B=1, C=1$ , the standard sum is  $(\bar{A}+\bar{B}+\bar{C})$ . Therefore, the standard POS expression is

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

$$\text{Ex: Draw the circuit for,}$$

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

$$\text{The expression is in POS form.}$$

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

The POS representation is realized using OR-AND configuration. This is a two-level realization. The first level consists of OR gates and the second level consists of AND gate.

Boolean functions expressed as sum of minterms or product of maxterms are said to be in canonical form.

NAND and NOR express:-



Sum and Product :-

A

B

C

f = A + AB' + A'B'

A'BC'

When a logical circuit is designed, we take two sets of known values into consideration. They are

- 1) The different states that the inputs to the logical network can assume.

- 2) The desired output for each input values.

Derivation of a Boolean Expression:- (SOP)

A binary variable  $x$  can exist either in its normal form ( $x$ ) or in its complement form ( $\bar{x}$ ).

| Minterms for three variables |     |     | Designation |
|------------------------------|-----|-----|-------------|
| $x$                          | $y$ | $z$ |             |
| 0                            | 0   | 0   | $m_0$       |
| 0                            | 0   | 1   | $m_1$       |
| 0                            | 1   | 0   | $m_2$       |
| 0                            | 1   | 1   | $m_3$       |
| 1                            | 0   | 0   | $m_4$       |
| 1                            | 0   | 1   | $m_5$       |
| 1                            | 1   | 0   | $m_6$       |
| 1                            | 1   | 1   | $m_7$       |

A Boolean function  $f$  may be expressed algebraically from a truth table by forming a minterm for each combination of the variables that produces 1 in the function and then take the OR of all those terms.

Any Boolean function can be expressed as a product of minterms. Boolean function expressed as a sum of minterms or product of minterms are said to be canonical form. There are two types of canonical forms

- \* Sum of minterms
- \* Product of minterms.

| Maxterms for three variables |     |     |              |
|------------------------------|-----|-----|--------------|
| $x$                          | $y$ | $z$ | Product term |
| 0                            | 0   | 0   | $x+y+z'$     |
| 0                            | 0   | 1   | $x+y'+z$     |
| 0                            | 1   | 0   | $x+y'+z'$    |
| 0                            | 1   | 1   | $x+y+z$      |
| 1                            | 0   | 0   | $x'+y+z$     |
| 1                            | 0   | 1   | $x'+y'+z$    |
| 1                            | 1   | 0   | $x'+y'+z'$   |
| 1                            | 1   | 1   | $x+y+z'$     |

These are called as standard product or minterms. If we OR these variables, we will obtain standard sum or minterms.

Sum of minterms :-

For a function with  $n$  binary variable, a sum of  $2^n$  distinct minterms can be obtained.

If the given Boolean function is not in the sum of minterms form, it should be converted by expanding the expression into a sum of AND terms. If any of these terms misses any one of the variables, then that particular term in the expression should be ANDed with  $(x+x)$  where  $x$  is missing variable.

Ex Express the Boolean function  $f = A' + BC$  in a sum of minterms.

Solution: The given function  $A' + BC$  contains three variables  $A$ ,  $B$  and  $C$ . The 1<sup>st</sup> term contains only one variable and 2<sup>nd</sup> term contains 2 variables. We should include the missing variables.

$$\text{1st term: } A' = \boxed{A' C B + A' B'}$$

$$\text{2nd term: } A' = \boxed{A' B (C+C') + A' B' (C+C')}$$

Now we shall perform the same for 2<sup>nd</sup> variable.

$$\begin{aligned} \text{1st term} \\ \hline B \\ \text{BC} &= \boxed{BC(A+A')} \\ &= \boxed{BCA + BCA'} \\ &= \boxed{ABC + A'BC} \end{aligned}$$

Hence the function  $f$  can be written as

$$f = A' + BC = \boxed{\underline{A'BC} + A'BC' + A'B'C + A'B'C' + ABC + A'BC}$$

(omit the repeated terms once)

$$\therefore f = A'BC + A'BC' + A'B'C + A'B'C' + ABC.$$

From the truth table, we can obtain the minterms as  $f = A'B'C + A'B'C' + A'BC' + ABC$ .

$$f = m_0 + m_1 + m_2 + m_3 + m_7$$

2)  $f(A, B, C) = AB + \overline{BC}$  into product of maxterms :-

To express a Boolean function as a product of maxterms, it should appear in the form of OR terms. To do so, we can make use of the distributive law  $ab = (a+b)(a+c)$ . If any of the term misses any variable, should be included in the missing term with  $x^2$ , where  $x$  is the missing variable for that term.

Ex: Express the Boolean function  $f = AC + B'C'$  as a product of maxterms.

Solution: First we should convert the function

$$f = AC + B'C' \text{ into OR terms}$$

using distributive law.

$$\begin{aligned}
 f &= A^c + B'^c \\
 &= (A^c + B') (A^c + c') \\
 &= (A + B') (C + B') (A + c') (C + c') \\
 &= (A + B') (C + B') (A + c') (C + c' = 1)
 \end{aligned}$$

We have converted the given function into OR form. Now we include the missing variable.

$$(A + B') = A + B' + (C \cdot c') = (A + B + c) (A + B' + c')$$

$$C + B' = C + B' + (A \cdot A') = (A + B' + 1) (A' + B' + C)$$

$$A + c' = A + c' + (B \cdot B') = (A + c' + B) (A + c' + B')$$

We can rewrite the above function  $f$  as follows

$$f = (A + B + c) (A + B' + c') (A + B + c') (A + B' + c')$$

$$\begin{aligned}
 f &= (A + B + 2) (A + B + c') (A + B' + c') (A + B + c') \\
 &= M_6, M_1, M_2, M_3
 \end{aligned}$$

$$f(A, B, c) = \overline{\Pi(6, 1, 2, 3)}$$

Conversion of sum of minterms and product of maxterms:

To convert from one canonical form to another interchange the symbols  $\Sigma$  and  $\Pi$  and include the numbers missing from the original form.

$$\text{Ex } f(A, B, c) = \Sigma(0, 3, 5, 6)$$

The function expressed in sum of minterms can be converted to the product of maxterms as shown below

$$f(A, B, c) = \Pi(1, 2, 4, 7)$$

NAND and NOR gates:-

NAND gate can be imagined to be an AND gate followed by a NOT gate as shown below.



The symbol for NAND gate and its truth table



The output is 1 when any input goes to 0. The output is 0 only when all the inputs are 1.

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

NOR gate:-

NOR can be imagined to be an OR gate followed by a NOT gate.



The symbol for NOR gate and its truth table.

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

Ex-OR and Ex-NOR gates :-

Ex-OR gate :-

In a two input Exclusive OR (Ex-OR or XOR)

The truth table is as below

for OR gate  $A=1, B=1$  the O/P  $y=1$

For Ex-OR gate  $A=1, B=0$  the O/P  $y=0$

From the table,

\*  $y=1$  for  $A=0, B=1 \therefore$  the standard product is  $\overline{A}B$ .

\*  $y=1$  for  $A=1, B=0$ , the standard product is  $A\overline{B}$ .

The SOP expression is

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

This can be implemented using two AND gates and two NOT gates.



The symbol for Ex-OR gate is

The output is given by the

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

$$Y = A \oplus B$$

and read as A Ex-OR B.

Ex-NOR Gate :-  
Exclusive - NOR gate (XNOR) & equivalent to Ex-OR followed by an inverter (NOR) gate

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

The symbol and the truth table for Ex-NOR is as below.

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

From the truth table we can write, SOP

$y=1$  for  $A=0, B=0$  the standard product is  $\overline{AB}$ .

$y=1$  for  $A=1, B=1$  the standard product is  $AB$ .

Therefore,  $y = \overline{AB} + AB$ .

The Ex-NOR can be implemented using AND, OR and NOT gates.



As the Ex-NOR operation is derived by complementing the Ex-OR, we can prove with the help of Boolean laws that,

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

Since the output is 1 only when both inputs are equal, the Ex-NOR gate is called as equivalence gate.

## UNIT 2 BOOLEAN ALGEBRA

Hierarchy of logic operations :-

- \* While evaluating the logic circuit, the following rules with hierarchy should be followed.
- \* Parentheses have highest priority i.e. all terms within parentheses are evaluated first.
- \* Inversions have next highest priority over other operations
- (+) & single term with 0 is inverted as 1 and 1 as 0.

\* AND operations are evaluated

- \* OR operations are evaluated after AND.

\* If an expression has a bar over it, the operations should be performed first and the result should be inverted next.

Laws of Boolean Algebra :-

- 1. Boolean Algebra uses only two bits 0 and 1 and has only two operations + (OR) and . (AND).
- 2. A number of rules in Boolean algebra are similar to ordinary algebra but a number of other rules are different.

Commutative law:

The commutative law for addition

of two variables is written as

$$A+B = B+A$$



In a similar way, the commutative law for multiplication of two variables is

$$AB = BA$$



Associative law:-  
The associative law for addition of three variables is

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

This means that the result is the same regardless of the order in which the variables are grouped.



In a similar way, the associative law for multiplication of three variables is

$$ABC = CAB$$



This means that the order in which we rearrange AND OR-ed makes no difference.

Distributive Law:-

The distributive law for three variables is written as

$$A(B+C) = AB+AC$$



Rule 1a:

$$\boxed{A+0 = A}$$

when  $A=0$

$A \cdot 0 = 0$

$0 + 0 = 0$

when  $A=1$ ,  $A \cdot 0 = 1 \cdot 0 = 0$

$1 + 0 = 1$

Therefore  $A+0 = A$ .

Rule 1b:

$$\boxed{A \cdot 1 = A}$$

when  $A=0$ ,  $A \cdot 1 = 0 \cdot 1 = 0 = A$

when  $A=1$ ,  $A \cdot 1 = 1 \cdot 1 = 1 = A$

Therefore  $A \cdot 1 = A$



$$\boxed{A \cdot A = A}$$

when  $A=0$ ,  $A \cdot A = 0 \cdot 0 = 0 = A$

when  $A=1$ ,  $A \cdot A = 1 \cdot 1 = 1 = A$

$\therefore A \cdot A = A$



$$\boxed{A + A = A}$$

when  $A=0$ ,  $A+A = 0+0 = 0 = A$

when  $A=1$ ,  $A+A = 1+1 = 1 = A$

$\therefore A+A = A$



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

when  $A=0$ ,  $A \cdot \bar{A} = 0 \cdot 1 = 0$

when  $A=1$ ,  $A \cdot \bar{A} = 1 \cdot 0 = 0$

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



$$\boxed{A \cdot 0 = 0}$$

when  $A=0$ ,  $A \cdot 0 = 0 \cdot 0 = 0$

when  $A=1$ ,  $A \cdot 0 = 1 \cdot 0 = 0$

$\therefore A \cdot 0 = 0$



$$\boxed{A \cdot 1 = A}$$

when  $A=0$ ,  $A \cdot 1 = 0 \cdot 1 = 0$

when  $A=1$ ,  $A \cdot 1 = 1 \cdot 1 = 1$

$\therefore A \cdot 1 = A$



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

when  $A=0$ ,  $A(C+B+C) = 0(C+B+C) = 0$

when  $A=1$ ,  $A(C+B+C) = 1(C+B+C) = C+B+C = C+B$

$\therefore A(C+B+C) = AC+BC+AC$



Rule 5:

$$\boxed{\overline{\overline{A}} = A}$$

when  $A = 0$ ,  $\overline{A} = 1$ ,  $\overline{\overline{A}} = 0 = A$   
when  $A = 1$ ,  $\overline{A} = 0$ ,  $\overline{\overline{A}} = 1 = A$

$$\therefore \overline{\overline{A}} = A$$

This double complement rule is also called as involution.

Rule 6a:

$$\boxed{A + AB = A}$$

Method 1:

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

$$\begin{aligned} ; \text{ for } 1 + B &= 1 \\ ; \text{ for } A \cdot 1 &= A \\ \boxed{A + AB = A} \end{aligned}$$

Method 2:

using truth table

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

Comparing columns 3 & 4  
it follows that

$$\boxed{A + AB = A}$$

This method of using truth table to prove an identity is called 'Proof by Proof by induction'.

Rule 6b:

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

Method 1:

$$\begin{aligned} L.H.S. &= A(A+B) \\ &= AA + AB \\ &= A + AB \end{aligned}$$

; for  $AB = A$

$$= A$$

; Rule 6a

$\therefore$  RHS

Method 2:  
using truth table

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

Comparing column 3 & 4,  
it follows that

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

Proof 2:

$$R.H.S. = A + B$$

$$\begin{aligned} L.H.S. &= A + \overline{A}B \\ &= A \cdot 1 + \overline{A}B \\ &= A(1 + \overline{A}) + \overline{A}B \quad ; \text{ for } 1 + \overline{A} = 1 \\ &= A + AB + \overline{A}B \\ &= A + B(A + \overline{A}) \quad ; \text{ for } A + \overline{A} = 1 \\ &= A + B \quad ; \text{ for } A + \overline{A} = 1 \\ &= L.H.S. \end{aligned}$$

$$\text{Rule 7b: } \boxed{A(C\bar{A} + B) = A \cdot B}$$

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

$$= A\bar{A} + AB ; \quad \bar{A}\bar{A} = 0$$

$$\boxed{AB = AB}$$

Rule 8a:

$$\boxed{A + BC = (A+B)(A+C)} \quad \checkmark$$

Proof:  $LHS = (A+B)(A+C)$

$$= AA + AB + AC + BC$$

$$= A(A + B + AC + BC) ; \quad \text{for } AA = A$$

$$= AC(1 + B + C) + BC$$

$$\boxed{= A + BC} ; \quad \text{for } 1 + B + C = 1$$

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

Simpl.

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

$$\boxed{\bar{A}B + AC + BC = \bar{A}B + AC}$$

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

Rule 8b:

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

Proof:  $LHS = (A+B)(A+C)$    
 the is distributive law.

Rule 9a:

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

Proof:

$$\begin{aligned} LHS &= AB + \bar{A}C + BC \\ &= AB + \bar{A}C + BC. \end{aligned}$$

$$\begin{aligned} &AB + \bar{A}C + BC (A+\bar{A}) \\ &\Rightarrow AB + \bar{A}C + ABC + \bar{A}BC \\ &\Rightarrow AB(C1+C) + \bar{A}C(C1+B) \end{aligned}$$

$$\boxed{RHS = AB + \bar{A}C}$$

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

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

$$\boxed{XY + \bar{X}Z + YZ = XY + \bar{X}Z.}$$

Rule 9b:  $(A+B)(\bar{A}+C)(B+C) = (A+B)(\bar{A}+C)$

Proof:

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

$$= (\bar{A}\bar{B} + \bar{A}B + AC) (B+C) ; \quad \text{for } A\bar{A} = 0$$

$$= (\bar{A}\bar{B} + AC + BC) (B+C) ; \quad \text{for } A\bar{A} = 0, BC = C$$

$$= \bar{A}\bar{B}B + ABC + BBC + \bar{A}\bar{B}C + ACC + BCC ; \quad \text{for } AA = A, BB = B$$

$$= \bar{A}\bar{B} + ABC + BC + \bar{A}\bar{B}C + ACC + BBC ; \quad \text{for } 1 + C = 1, 1 + A$$

$$= \bar{A}\bar{B} + BC + ACC + BBC ; \quad \text{for } 1 + C = 1, 1 + A$$

$$= \bar{A}\bar{B} + AC + BC ; \quad \text{for } BC + ACC = ACC$$

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

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

$$= \bar{A}B + AC + BC ; \quad \text{for } A\bar{A} = 0$$

$$\boxed{LHS = RHS}$$

Duality principle:-

If Rule 1a is given 1b can be obtained. In all these cases, if one rule is given, the other one of the pair can be obtained by interchanging the binary operator OR and AND by replacing 0s and 1s. This property is called DUALITY.

PRINCIPLE:  $A \oplus 0 = A$  (dual of  $A \oplus 1 = A$ )

Ex:  $A \cdot 1 = A$  (dual of  $A \cdot 0 = 0$ )

Given a Boolean rule, the dual can be obtained by

- \* changing each OR sign to AND sign
- \* changing each AND sign to OR sign
- \* complementing any 0 or 1 present in expression.

Ex Simplify  $Y = \overline{A} \overline{B} + \overline{A} B$  ✓

Solution:

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

$$\therefore \boxed{Y = \overline{A}}$$

Ex 2: Show that  $\overline{A} \overline{B} C + A \overline{B} C + A B \overline{C} + A B C = A B + \overline{B} C$

solution: LHS =  $\overline{A} \overline{B} C + A \overline{B} C + A B \overline{C} + A B C$

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

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

$$RHS = \boxed{A B + \overline{B} C}$$

Simplification of logical expressions using algebra is important, because a reduced expression means less number of gates, hence reduced size and cost and more efficient.



Ex 3:  $Y = [A'BC'C + B'D] + A'B$  ]c

$$\stackrel{\text{Simpl.}}{=} Y = [A\overline{B}(C\overline{C} + BD) + A\overline{B}]c$$

$$= [A\overline{B}C + A\overline{B}BD + A\overline{B}]c ; B\overline{B} = 0$$

$$= [A\overline{B}C + A\overline{B}]c$$

$$= [A\overline{B}C + A\overline{B}C']c$$

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

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

$$= \overline{B}C$$

Ex 4: Reduce the following Boolean expression of the literals.

$$\begin{aligned} & \text{Simplifying } F(A, B, C) = ABC + \bar{A}\bar{B}C + \bar{A}B\bar{C} + A\bar{B}\bar{C} + \bar{A}\bar{B}C \\ & = ABC + AB\bar{C} + \bar{A}\bar{B}C + \bar{A}\bar{B}\bar{C} + \bar{A}B\bar{C} \\ & = AB(C + \bar{C}) + \bar{A}\bar{B}(C + \bar{C}) + \bar{A}B\bar{C} \\ & = AB + \bar{A}\bar{B} + \bar{A}B\bar{C} \\ & = \boxed{\bar{A}\bar{B} + B(CA + C)} \end{aligned}$$

(The free literals are  $A, \bar{A}, B, \bar{B}$  &  $C$ )

$$\begin{aligned} & \text{Simplifying } F(A, B, C, D) = BC + A\bar{C} + AB + BCD \\ & = BC + BCD + A\bar{C} + AB \\ & = BC(C + D) + A\bar{C} + AB \\ & = BC + A\bar{C} + AB \quad ; 1+D=1 \\ & = \boxed{BC + A\bar{C}} \quad \text{Rule 9a.} \end{aligned}$$

$$\begin{aligned} & \text{Ex 5: Simplify } AB + AB' + A'C + A'C' \\ & \text{Simplifying } AB + AB' + A'C + A'C' = AC(B+B') + A'(C+C') \\ & = A(1) + A'(1) \\ & = A + A' \\ & = \boxed{1.} \end{aligned}$$

$$\begin{aligned} & \text{Ex 6: Simplify } (A+B) \cdot (A+B') \\ & \text{Simplifying } (A+B)(A+B') = AA + AB + AB' + BB' \\ & = A + AB \cdot (\cancel{AB} + \cancel{AB'})_{BB'=0} \\ & = A(1+B) \\ & = \boxed{A.} \end{aligned}$$

Ex 8: Simplify  $xy(x'y'z' + xy'z' + x'y'z)$

$$\begin{aligned} & \text{Simplifying } = xy(x'y'z' + y'z' + x'y'z) \\ & = xy(x'y'z' + y'z') \\ & = \boxed{0.} \end{aligned}$$

Ex 9: Complement the Boolean expression  $(AB' + C'D')$

$$\begin{aligned} & \text{Simplifying } F' = (A+B') \cdot (C'+D') \\ & = \boxed{F' = A \cdot C + B \cdot D} \end{aligned}$$

Ex 10: complement  $(A + BC + AB)$

$$\begin{aligned} & F = A + BC + AB \\ & = A(C + B) + BC \\ & = A + BC \\ & \text{Dial of } F = A \cdot (B+C) \\ & \boxed{F' = A \cdot CB + C} \end{aligned}$$

### DEMORGAN'S THEOREM:-

The following two rules are known as Demorgan's theorem.

\* The + symbols (OR) are replaced with . (AND)

\* Each of the term is complemented.

$$\begin{array}{c} ((x+y)' = x'y') \\ (xy)' = x'y' \end{array}$$

NOR = Bubbled AND

$$\begin{array}{c} y = \overline{x+y} \\ y = \overline{x} \cdot \overline{y} \end{array}$$

Bubbled AND

E using demorgan theorem simplify the expression.

$$\begin{aligned} & ((A'+C) * (B+D'))' \\ &= (A'+C')' + (B+D')' \quad (\text{By DeMorgan's law}) \\ &= ((A')' \cdot C')' + B' \cdot (D')' \\ &= [A'C' + B'D]. \end{aligned}$$

Three variables Boolean theorem:

$$\begin{aligned} (x+y+z)' &= x'y'z' \\ (xyz)' &= x'+y'+z' \end{aligned}$$

Summary of Boolean Theorems:-

| Part | Classification & Definition     | S.NO | Classification & Definition   |
|------|---------------------------------|------|-------------------------------|
| I.   | <u>Single variable theorems</u> | 1.   | <u>Idempotent laws</u>        |
| a.   | <u>Laws of intersection</u>     | 2.   | <u>Commutative laws</u>       |
| b.   | <u>Laws of union</u>            | 3.   | <u>Distributive laws</u>      |
| c.   | <u>De Morgan's laws</u>         | 4.   | <u>NAND as universal gate</u> |

|    |                                           |     |                                          |
|----|-------------------------------------------|-----|------------------------------------------|
| 1. | $a+a = a$                                 | 9.  | $a+b = b+a$                              |
| 2. | $a * 1 = a$                               | 10. | $a \cdot b = b \cdot a$                  |
| 3. | $a * a = a$ (Idempotent law or tautology) | 11. | $a + (b+c) = (a+b)c = abc$               |
| 4. | $a * a' = 0$ (Complement law)             | 12. | $a(bc) = (ab)c = abc$                    |
| 5. | <u>Laws of Union</u>                      | 13. | $a(b+c) = ab+ac$                         |
| 6. | $a+0 = a$                                 | 14. | $(w+x) \cdot (y+z) = wyt + wz + xy + xz$ |
| 7. | $a+a = a$ (tautology)                     | 15. | $x+yz = (x+y) \cdot (x+z)$               |
| 8. | $a+a' = 1$ (complement law)               |     |                                          |

NAND as UNIVERSAL GATE :-  
By connecting NAND gates in different ways, it is possible to get the function of any other gate. That is, the function of NOT, AND, OR etc. can be implemented using NAND gates.

∴ The NAND gate is called as universal gate or universal building block.

;) NAND as NOT.  
A NOT gate has only one input and one output. In a two input NAND gate,

If both the inputs are marked as A, then the output is given by  $A\bar{A}$  which is equal to  $\bar{A}$ . Since the two inputs are same, the two inputs of the NAND gate can be connected together and used as a gate with single inputs.



Note: A single input,  $A$  is  $I/P$ , &  $P/O$  NAND gate can also be converted into a NOT gate by connecting all the inputs together.

ii) NAND as AND:  
The output of NAND gate is  $\bar{AB}$ . To make it as  $AB$ , the output of NAND gate is inverted once. But the inverter is also implemented using a second NAND gate.



iii) NAND as OR:-

To get the OR expression  $A+B$ , the inputs are first inverted and then pass through a NAND gate. These NAND gates are needed to get the OR function.



v) NAND as EX-OR:  
The implementation of EX-OR gate requires four NAND gates.



using DeMorgan's theorem wherever required, it can be shown the output of the circuit represents an EX-OR

$$\begin{aligned}\rightarrow \text{The o/p of } Q_1 &= \overline{AB} \\ \rightarrow \text{The o/p of } Q_2 &= \overline{A\bar{B}} \\ \rightarrow \text{The o/p of } Q_3 &= \overline{B\bar{A}} \\ \rightarrow \text{The o/p of } Q_4 &= \overline{\overline{A\bar{B}} \overline{B\bar{A}}}\\ &= \overline{A\bar{B}} + \overline{B\bar{A}}\end{aligned}$$

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

vii) NAND OR EX-NOR:

By adding an inverter to the EX-or gate, we get the EX-NOR gate. The implementation of EX-NOR requires five NAND gates.



1. The given logic function is simplified and expressed in SOP form.
2. A logic circuit is drawn using basic gates AND, OR, NOT.
3. Each basic gate is replaced by equivalent NAND circuits.
4. When two inverters are cascaded, they can be removed as double inversion does not perform a logic function.
5. If a single inverter occurs connected to an extreme input, then inverter can be removed and I/P is complemented.

$$\begin{aligned}\text{The output of } Q_4 &= \overline{AB} + \overline{AB} \\ \text{The output of } Q_5 &= \overline{\overline{AB}} + AB\end{aligned}$$

$$\begin{aligned}f_4 &= \overline{AB} + \overline{AB} \\ &= \overline{\overline{AB}} (\overline{\overline{A}} + \overline{\overline{B}}) \\ &= (\overline{A} + \overline{B})(\overline{A} + \overline{B}) \\ &= \overline{A}\overline{A} + \overline{A}\overline{B} + \overline{B}\overline{A} + \overline{B}\overline{B} \\ &= A\bar{A} = B\bar{B} = 0.\end{aligned}$$

$$\begin{aligned} f(A, B, C) &= \bar{A}\bar{B}C + A\bar{B}C + A\bar{B}\bar{C} + ABC \\ &= \bar{B}C(C+A) + ABC(C+\bar{C}) \quad \text{Two-level AND-OR circuit} \\ &= \bar{B}C + AB \\ &\Rightarrow AB + \bar{B}C \quad (\text{a}) \end{aligned}$$



we can see that gates  $g_2$  and  $g_3$  are cascaded and can be removed. Similarly  $g_4$  and  $g_5$  can be removed. This gives the final circuit as



In this the gate  $g_3$  is identical to (a) but the OR and AND gate is replaced by NAND. This is called three-level NAND-NAND circuit.

Therefore we can conclude that an AND-OR combination circuit can be directly replaced by NAND-NAND combination circuit.

$y = AB + CD$  draw the logic circuit using two level AND-OR, two level NAND-NAND combination.

$$\begin{aligned} A &\Rightarrow D \\ B &\Rightarrow D \\ C &\Rightarrow D \\ D &\Rightarrow D \\ Y = AB + CD &= \overline{AB} \cdot \overline{CD} \\ &= \overline{AB} \cdot \overline{CD} \\ &= \overline{AB} \cdot \overline{CD} \\ &= \overline{AB + CD} \\ &= \overline{AB + CD} \end{aligned}$$

NOR AS UNIVERSAL GATE:

- i) NOR AS NOT:-  
In a two input NOR gate, if both the inputs are marked as A, then the output is given by  $\overline{A+A}$ , which is equal to  $\overline{A}$ .

$$A \Rightarrow D \\ Y = \overline{A+A} = \overline{A} = A \Rightarrow D$$

- ii) NOR AS OR:-  
The output of NOR gate is  $\overline{A+B}$ . To make it  $A+B$  the output of NOR gate is inverted once. But there is also implemented using a second NOR gate.

$$\begin{aligned} A &\Rightarrow D \\ A &\Rightarrow D \\ Y = \overline{\overline{A+B}} &= A+B \end{aligned}$$

vii) NOR as AND:  
 To get AND expression  $A \cdot B$ , the inputs are first inverted and then passed through NOR gate. The NOT gates are obtained using NOR.



$$\begin{aligned} \text{The o/p of first NOT gate} &= \overline{A} \\ \text{The o/p of 2nd NOT gate} &= \overline{B} \\ \text{The o/p of NOR gate} &= \overline{\overline{A} + \overline{B}} \end{aligned}$$

$$\text{By De Morgan's theorem } \overline{\overline{A} + \overline{B}} = \overline{A} \cdot \overline{B}$$

viii) NOR as NAND:-  
 The NAND gate is obtained by simply inverting the output of the AND gate. The implementation of NAND gate using NOR gate is below.



v) NOR as EX-NOR:  
 The implementation of EX-NOR gate requires

A NOR gate.  
 Using DeMorgan's theorem, it can be shown the outputs of the circuit -

$$\begin{aligned} \text{The output of } q_1 &= \overline{A} \cdot \overline{B} \\ \text{The output of } q_2 &= \overline{A} + \overline{A} \cdot \overline{B} \\ \text{The output of } q_3 &= \overline{B} + \overline{A} \cdot \overline{B} \\ q_4 &= (\overline{A} + \overline{B})(\overline{A} + \overline{B}) \\ &= (A + B)(A + B) \\ &= AB + \overline{AB} \\ &= \overline{AB} + \overline{AB} \end{aligned}$$



ANSWER

NOR-NOR network :-

NOR is a universal gate, any logic expression can be implemented using NOR gates only. The following steps are to be followed.

1. The given logic function is simplified and expressed in POS form.

2. A logic circuit is drawn using basic gates AND, OR, NOT gates. The input variables are assumed to be available in the normal as well as in complemented form.

3. Each basic gate is replaced by equivalent NOR circuit.

4. When two inverters are cascaded, they can be removed, as double inversion does not perform a logic function.

5. If a single inverter occurs connected to an external input, then the inverter can be removed and the corresponding input is complemented.

Let us take POS expression,

$$Y = (A+B)(C+C'D)$$

The logic circuit can be drawn as two

level OR-AND combination circuit:



We can show that the above OR-AND circuit can be directly replaced by NOR-NOR circuit.

$$Y = (A \cdot B \cdot C \cdot C'D)$$



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



That is an OR-AND combination circuit can be directly replaced by a NOR-NOR combination circuit.

NOR to OR Gate Network :-

$$\begin{aligned} Y &= (\overline{A} + \overline{B}) + (\overline{C} + \overline{D}) \\ &\Rightarrow \overline{\overline{A} \cdot \overline{B}} + \overline{\overline{C} \cdot \overline{D}} \\ &= AB + CD \end{aligned}$$

NAND to AND Gate Network :-

$$\begin{aligned} Y &= (\overline{A} \cdot \overline{B}) \cdot (\overline{C} \cdot \overline{D}) \\ &\Rightarrow (\overline{A} \cdot \overline{B}) \cdot (\overline{C} \cdot \overline{D}) \\ &= (A+B) \cdot (C+D) \\ &= AB + CD \end{aligned}$$



## KARNAUGH MAP

Minterms and Maxterms.

Minterms are associated with SOP and Maxterms are associated with POS.

Minterm :-

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

The first term is a product. The second term contains all the three variables A, B and  $\bar{C}$  in its complement form. This type is called standard product. The standard product also called as minterm and is represented by ' $m$ '. The standard product should produce a logical 1.

| A | B | Term             | Designation |
|---|---|------------------|-------------|
| 0 | 0 | $\bar{A}\bar{B}$ | $m_0$       |
| 0 | 1 | $\bar{A}B$       | $m_1$       |
| 1 | 0 | $A\bar{B}$       | $m_2$       |
| 1 | 1 | $AB$             | $m_3$       |

| A | B | C | Term                    | Designation |
|---|---|---|-------------------------|-------------|
| 0 | 0 | 0 | $\bar{A}\bar{B}\bar{C}$ | $m_0$       |
| 0 | 0 | 1 | $\bar{A}\bar{B}C$       | $m_1$       |
| 0 | 1 | 0 | $\bar{A}B\bar{C}$       | $m_2$       |
| 0 | 1 | 1 | $\bar{A}BC$             | $m_3$       |
| 1 | 0 | 0 | $A\bar{B}\bar{C}$       | $m_4$       |
| 1 | 0 | 1 | $A\bar{B}C$             | $m_5$       |
| 1 | 1 | 0 | $ABC$                   | $m_6$       |
| 1 | 1 | 1 | $A\bar{B}\bar{C}$       | $m_7$       |

| A | B | C | Term                      | Designation |
|---|---|---|---------------------------|-------------|
| 0 | 0 | 0 | $A+B+C$                   | $M_0$       |
| 0 | 0 | 1 | $A+B+\bar{C}$             | $M_1$       |
| 0 | 1 | 0 | $A+\bar{B}+C$             | $M_2$       |
| 0 | 1 | 1 | $A+\bar{B}+\bar{C}$       | $M_3$       |
| 1 | 0 | 0 | $\bar{A}+B+C$             | $M_4$       |
| 1 | 0 | 1 | $\bar{A}+B+\bar{C}$       | $M_5$       |
| 1 | 1 | 0 | $\bar{A}+\bar{B}+C$       | $M_6$       |
| 1 | 1 | 1 | $\bar{A}+\bar{B}+\bar{C}$ | $M_7$       |

$$\begin{aligned} f(A, B, C) &= (\bar{A} + \bar{B})(A + B \\ &= (\bar{A} + \bar{B} + C\bar{C}) (A + B + \bar{C}) \\ &= (\bar{A} + \bar{B} + C)(\bar{A} + B + \bar{C})(A + B + C) \\ &= M_6, M_7, M_1, M_4 \\ f(A, B, C) &= \overline{\chi}(1, 6, 7) \end{aligned}$$

$$\begin{aligned} &\text{From truth table to canonical form: } \\ f &= \bar{A}\bar{B}\bar{C} + \bar{A}\bar{B}\bar{C} + \bar{A}\bar{B}C + A\bar{B}C + ABC \\ &\text{Collecting the minterms for which } F=0 \end{aligned}$$

$$\begin{aligned} F &= \bar{A}\bar{B}\bar{C} + A\bar{B}\bar{C} + ABC \\ &\text{Taking complement on both sides and using DeMorgan's theorem:} \end{aligned}$$

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

$$F = \overline{\bar{A}\bar{B}C} \cdot \overline{A\bar{B}\bar{C}} \cdot \overline{ABC}$$

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

| A | B | C | F |
|---|---|---|---|
| 0 | 0 | 0 | 1 |
| 0 | 0 | 1 | 0 |
| 0 | 1 | 0 | 0 |
| 0 | 1 | 1 | 0 |
| 1 | 0 | 0 | 0 |
| 1 | 0 | 1 | 0 |
| 1 | 1 | 0 | 1 |
| 1 | 1 | 1 | 0 |

Relationship between K-map and truth table.

The K-map can be rectangular or square shape and divided into number of square cells. The number of cells a map depends on the number of variables. (i.e.)  $2^2 = 4$  cells with 'M'. It should produce a logical 0.

Markings:

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

The second term contains all the three variables A and B and  $\bar{C}$  in the complement form. The type is called standard sum or fundamental sum. It is designated with 'M'. It should produce a logical 0.

Two variable K-map

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

Three variable K-map

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

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

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

b = 0

Four variable K-map

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

Five variable K-map

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

Five variable K-map

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

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

Here instead of using normal binary progression, Gray code format is used. That's BC is taken as 00, 01, 11, 10. This is done so that when we go from one cell to the next cell (horizontal or vertical) there is only one change in binary combination.

Ex: From 01 to 11 in Gray code - one change from 01 to 10 in binary - two changes

$$Y = f(A, B, C) = \Sigma(1', 5, 6, 7)$$

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

\* In the above example, the pair of 1's cover the minterm m<sub>1</sub> and m<sub>5</sub> or AB and AB. thus gets reduced to A.

\* In K-map we get the reduced expression

by simply examining the mapping do that we can follow simple procedure. More from cell  $\# 2$  to cell  $\# 3$ . For both the cells the variable  $A^{\alpha}$  is common with a value  $A = 1$ .

\* In this example, we find that when we move from cell 2 to cell 3 the variable B is changing from 1 to 0. The variable that changes is eliminated. therefore the simplified result from k-map is:

$$F(A, B) = \boxed{A}$$

### Overlapping of groups:

In this map the '1' in cell 1 is paired with cell 8

the 1<sup>st</sup> cell 3 helps form a pair with cell 1 and 2.

This type of grouping is known as overlapping of groups.

for both cell 2 and 3, A is constant with

where  $\beta$  changes from 0 to 1 and  $\beta = \infty$ .

demanded. The rate of B & Constants and A changes from 0 to 11.

$$y = A + B \cdot x$$

Here folding method can be used.

|   |   |   |
|---|---|---|
|   |   |   |
| 6 | 0 | 0 |
| 1 | - | 0 |
| 1 | - | 0 |
| 9 | 0 | 1 |

∴ the product obtained for the pair is AC  
 The cell 0 and cell 2 are paired only if  
 variable B changes from 0 to 1. These two  
 cells are not adjacent, they form a pair by  
 process called folding or solling the map.  
 When the map is folded, the cells 0 and 2

$P_1(5, 7)$  gives  $\frac{AC}{BC}$   
 $P_2(0, 2)$  gives  $\frac{AB}{AC}$   
 $f(0, B, C) =$  [ ]

$$\boxed{AC + \overline{AC}}$$

Ex:  $\frac{\partial}{\partial x} f(A, B, \dots) = \sum (0, 1, 2, \dots)$

Ex:  $f(A, B, C) = \sum(0, 1, 2, 3)$   
 In a three variable K-map, while forming  
 we are able to group four 1's together, then  
 arrangement is called a quad. A quad elim  
 -nates two variables and their complement.

| A | B | C | D | m <sub>00</sub> | m <sub>01</sub> | m <sub>10</sub> | m <sub>11</sub> |
|---|---|---|---|-----------------|-----------------|-----------------|-----------------|
| 0 | 0 | 0 | 0 | 1               | 1               | 1               | 1               |
| 0 | 0 | 0 | 1 | 1               | 1               | 0               | 0               |
| 0 | 0 | 1 | 0 | 1               | 0               | 1               | 0               |
| 0 | 0 | 1 | 1 | 0               | 0               | 0               | 1               |
| 0 | 1 | 0 | 0 | 0               | 0               | 0               | 0               |
| 0 | 1 | 0 | 1 | 0               | 0               | 0               | 0               |
| 0 | 1 | 1 | 0 | 0               | 0               | 0               | 0               |
| 1 | 0 | 0 | 0 | 0               | 0               | 0               | 0               |
| 1 | 0 | 0 | 1 | 0               | 0               | 0               | 0               |
| 1 | 0 | 1 | 0 | 0               | 0               | 0               | 0               |
| 1 | 0 | 1 | 1 | 0               | 0               | 0               | 0               |
| 1 | 1 | 0 | 0 | 0               | 0               | 0               | 0               |
| 1 | 1 | 0 | 1 | 0               | 0               | 0               | 0               |
| 1 | 1 | 1 | 0 | 0               | 0               | 0               | 0               |

For all the four cells only the variable A remains unchanged with A = 0. Therefore

$$f(A, B, C) = \boxed{\overline{A}}$$

Steps for K-map -

- 1) Draw the K-map and number the minterm cells.
- 2) Fill the map with 1's and 0's.
- 3) Group the 1's as quad and pairs, striking from bigger group.

- 4) Allow the groups to overlap, if necessary
- 5) Avoid redundant groups

- 6) Fold or roll the map if necessary to get bigger group.

Octet :- In 4 variable K-map besides the points and quad a bigger group called Octet. An Octet eliminates a group with eight 1's. An Octet eliminates three variables and their complements.

$$\text{Ex: } F(A, B, C, D) = \Sigma (m_0, m_1, m_4, m_5, m_8, m_9, m_{12}, m_{13})$$

| A | B | C | D | m <sub>00</sub> | m <sub>01</sub> | m <sub>10</sub> | m <sub>11</sub> |
|---|---|---|---|-----------------|-----------------|-----------------|-----------------|
| 0 | 0 | 0 | 0 | 1               | 1               | 1               | 1               |
| 0 | 0 | 0 | 1 | 1               | 1               | 0               | 0               |
| 0 | 0 | 1 | 0 | 1               | 0               | 1               | 0               |
| 0 | 0 | 1 | 1 | 0               | 0               | 0               | 1               |
| 0 | 1 | 0 | 0 | 0               | 0               | 0               | 0               |
| 0 | 1 | 0 | 1 | 0               | 0               | 0               | 0               |
| 0 | 1 | 1 | 0 | 0               | 0               | 0               | 0               |
| 1 | 0 | 0 | 0 | 0               | 0               | 0               | 0               |
| 1 | 0 | 0 | 1 | 0               | 0               | 0               | 0               |
| 1 | 0 | 1 | 0 | 0               | 0               | 0               | 0               |
| 1 | 0 | 1 | 1 | 0               | 0               | 0               | 0               |
| 1 | 1 | 0 | 0 | 0               | 0               | 0               | 0               |
| 1 | 1 | 0 | 1 | 0               | 0               | 0               | 0               |
| 1 | 1 | 1 | 0 | 0               | 0               | 0               | 0               |

$$\text{Octet 0} = \{0, 1, 4, 5, 12, 13\}$$

$$\boxed{C}$$

DON'T CARE condition :-  
The don't care condition can be used in K-map to convenience to provide bigger group and hence more simplified expression. The don't care condition is denoted with 'X'. To differentiate from 0 and 1, the X's may be assumed as 0 or 1. In K-map minterms X can be taken as 1 and 0 in maxterms X can be taken as 0. And also X can altogether be omitted.

$$Y = F(A, B, C, D) = \Sigma (2, 3, 4, 5) + \Sigma (10, 11, 12, 13, 14, 15)$$

| A | B | C | D | m <sub>00</sub> | m <sub>01</sub> | m <sub>10</sub> | m <sub>11</sub> |
|---|---|---|---|-----------------|-----------------|-----------------|-----------------|
| 0 | 0 | 0 | 0 | 1               | 1               | 1               | 1               |
| 0 | 0 | 0 | 1 | 1               | 1               | 0               | 0               |
| 0 | 0 | 1 | 0 | 1               | 0               | 1               | 0               |
| 0 | 0 | 1 | 1 | 0               | 0               | 0               | 1               |
| 0 | 1 | 0 | 0 | 0               | 0               | 0               | 0               |
| 0 | 1 | 0 | 1 | 0               | 0               | 0               | 0               |
| 0 | 1 | 1 | 0 | 0               | 0               | 0               | 0               |
| 1 | 0 | 0 | 0 | 0               | 0               | 0               | 0               |
| 1 | 0 | 0 | 1 | 0               | 0               | 0               | 0               |
| 1 | 0 | 1 | 0 | 0               | 0               | 0               | 0               |
| 1 | 0 | 1 | 1 | 0               | 0               | 0               | 0               |
| 1 | 1 | 0 | 0 | 0               | 0               | 0               | 0               |
| 1 | 1 | 0 | 1 | 0               | 0               | 0               | 0               |
| 1 | 1 | 1 | 0 | 0               | 0               | 0               | 0               |

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

$$Y = X$$

### TABULATION METHOD

When the number of variables is more than five, it is difficult to simplify because there will be a large number of terms in the expression, or too many cells. To solve this the other method called tabulation method or Quine-McCluskey method.

Procedure for Tabulation method:

The procedure involves four steps:

- \* By careful search, find out terms those are necessary and required for simplification. These terms are called prime-implicants.
- \* From among the prime implicants, choose the ones, which give the least number of literals.
- \* From given function, list all the minterms and get the binary equivalent. The minterms are arranged in different groups, the first group does not contain any 1's, the second group contains only one 1, third group contains two 1's etc. The minterms in one group are compared with minterms in immediate next group.
- \* If two terms differs in only one variable, that variable is removed and term with one less literal is found. The remaining terms and all the terms that did not match during the process form the prime implicants.

E: Simplify by tabulation method

$$f(A, B, C, D) = \sum (0, 1, 4, 5, 10, 11, 14, 15)$$

Solution: Represent each minterm in binary.

| 2) Represent each minterm in binary |        |
|-------------------------------------|--------|
| Decimal                             | Binary |
| 0                                   | 0000   |
| 1                                   | 0001   |
| 4                                   | 0100   |
| 5                                   | 0101   |
| 10                                  | 1010   |
| 11                                  | 1011   |
| 14                                  | 1110   |
| 15                                  | 1111   |

Step 2: Arrange the minterms in different groups so that first group does not contain any 1, 2nd group only one 1, 3rd group two 1's etc..

$$\begin{array}{l} 0 - 0000 \\ | \\ 1 - 0001 \end{array}$$

$$\begin{array}{l} | \\ H - 0100 \end{array}$$

2nd

$$\begin{array}{l} 5 - 0101 \\ | \\ 10 - 1010 \end{array}$$

3rd

$$\begin{array}{l} | \\ 11 - 1011 \\ | \\ 14 - 1110 \end{array}$$

4th

$$\begin{array}{l} | \\ 15 - 1111 \end{array}$$

5th

- (3) The first column contains the minterms arranged as per step 2. The minterms after in one group are compared

With the minterms in the immediate next group. Any two minterms, which differs each other by only one variable can be combined and unmatched variable removed. Two minterms falls into this category if they both have the same bit value in all positions except one.

| Column (a)   | Column (b)       | Column (c)       |
|--------------|------------------|------------------|
| A B C D      | A B C D          | A B C D          |
| 0 0000 ✓     | C, D 0 0 0 -     | C, D, 0 0 0 -    |
| - - - -      | (C, A) 0 - 0 0   | - - - -          |
| 1 0 0 0 1 ✓  | - - - -          | - - - -          |
| 4 0 1 0 0 ✓  | (1, 5) 0 - 0 1   | (1, 5) 0 0 1 -   |
| - - - -      | (4, 5) 0 1 0 -   | (4, 5) 0 1 0 -   |
| 5 0 1 0 1 ✓  | - - - -          | - - - -          |
| 10 1 0 1 0 ✓ | (10, 11) 1 0 1 - | (10, 11) 1 0 1 - |
| - - - -      | (10, 14) 1 - 1 0 | (10, 14) 1 - 1 0 |
| 11 1 0 1 1 ✓ | - - - -          | - - - -          |
| 14 1 1 1 0 ✓ | (11, 15) 1 - 1 1 | (11, 15) 1 - 1 1 |
| 15 1 1 1 1 ✓ | (14, 15) 1 1 1 - | (14, 15) 1 1 1 - |

| Column (a)   | Column (b)       | Column (c)               |
|--------------|------------------|--------------------------|
| A B C D      | A B C D          | A B C D                  |
| 0 0000 ✓     | C, D 0 0 0 -     | C, D, 0 0 0 -            |
| 1 0 0 0 1 ✓  | (C, 14) 0 - 0 0  | (C, 14, 15) 0 - 0 -      |
| 4 0 1 0 0 ✓  | - - - -          | - - - -                  |
| 5 0 1 0 1 ✓  | (C, 15) 0 0 1 -  | (C, 15) 0 1 0 -          |
| 10 1 0 1 0 ✓ | (10, 11) 1 0 1 - | (10, 11, 14, 15) 1 - 1 - |
| 11 1 0 1 1 ✓ | (10, 14) 1 - 1 0 | (10, 14, 11, 15) 1 - 1 - |
| 14 1 1 1 0 ✓ | (11, 15) 1 - 1 1 | (10, 14, 11, 15) 1 - 1 - |
| 15 1 1 1 1 ✓ | (14, 15) 1 1 1 - | (14, 15) 1 1 1 -         |

5) The unchecked terms in the table form the prime implicants.

In this example all the terms in column

(a) and (b) are checked. There are four unchecked terms in column (c). But two terms get repeated and as long as the term forms a prime implicant it is unnecessary to use the same term twice.

i.e. the prime implicants are  $\bar{A} \bar{C}$  corresponding

to  $0 - 0 -$  and  $A \bar{C}$  corresponding to

$1 - 1 -$

The minterm  $m_0$  and  $m_1$  is compared. The minterm  $m_0$  (0000) and  $m_1$  (0001) are compared and the result is  $(0, 1) 0 0 0 -$ . A check mark is placed when the comparison completes.

4) Terms in one group are compared only with terms in the immediate next group. Also terms in each group need to be compared only if they

The sum of prime implicants gives the minimized function

$$\text{In Sop } \quad f(A, B, C, D) = \overline{AC} + AC.$$

The same problem can be solved by K-map and K-map

$$f(A, B, C, D) = \sum(0, 1, 4, 5, 10, 11, 14, 15)$$

~~A~~

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

The 1st quad  $\alpha_1(0, 1, 4, 5)$  gives the reduced expression  $\overline{AC}$ .  
The 2nd quad  $\alpha_2(10, 11, 14, 15)$  gives reduced expression  $AC$ .

$$f = \overline{AC} + AC.$$

$$\text{Ex (2)} \quad f(A, B, C, D) = \sum(0, 5, 7, 8, 13, 15)$$

Solution:

First write the binary combination

$$0 \rightarrow 0000, 5 \rightarrow 0101, 7 \rightarrow 0111, 8 \rightarrow 1000, 13 \rightarrow 1101$$

$$15 \rightarrow 1111.$$

| Column (a)<br>A B C D | Column (b)<br>A B C D | Column (c)<br>A B C D |
|-----------------------|-----------------------|-----------------------|
| 0 0000                | (0, 8) - 0000         |                       |
| 8 1000                | -                     |                       |
| 5 0101                | (5, 7) 01 - 11        |                       |
| 7 0111                | (5, 7, 13, 15) - 1111 |                       |
| 11 1011               | (5, 13) - 1011        |                       |
| 13 1101               | (5, 13) - 1101        |                       |
| 15 1111               | (5, 13) - 1111        |                       |

The first term in column (b) is unchecked. Similarly the two terms in column (c) are also unchecked. From column (c), it is enough if we take any one of them since one of them is duplicate of other. The unchecked terms are - 000 which corresponds to  $\overline{BD}$  and - 11 which corresponds to  $\overline{BCD}$ . ∴ The final solution is  $f = BD + \overline{BCD}$ .

$$f(A, B, C, D) = \sum(0, 5, 7, 8, 13, 15) \text{ by K-map}$$

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

The map contains a quad and a pair

The quad  $\alpha(5, 7, 13, 15)$  gives the reduced expression  $\overline{BD}$ .

The pair  $\rho(0, 8)$  gives the reduced exprn  $\overline{BCD}$ .

∴ The final expression is  $f = BD + \overline{BCD}$

## Arithmetic building blocks:

### Introduction:-

Circuit consist of input variables, logic gate and output variables. The output of the combinational circuit depend only on the current value of the inputs.

The block diagram of combinational circuit:



### Arithmetic circuits:

- \* Binary addition
- \* Half adder and full adder
- \* Four bit binary adder
- \* BCD adder
- \* Half subtractor and full subtractor
- \* Four bit adder / subtractor circuits.

### Half-adder:

Half adder is a logic circuit that adds 2 bits and gives the result on 2 output lines as sum (S) and carry (cy). Let A and B be 2

inputs and said cy be the 2 outputs.



Block diagram of Half adder.

Since A and B can take values 0 and 1. The total number of possible input combination is 4.

Truth table:

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

From the truth table the sum of product expression for sum and carry can be written as

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

These expression can be implemented using the

input



The sum expression is directly an Ex-OR expression, the Half adder circuit can also be drawn as



Half adder using NAND gates:

NAND is a universal gate, it is possible to implement the half adder circuit using NAND gates only.



Half subtractor :-

A Half subtractor is a combinational circuit that subtracts 2 bits and generates difference D and borrow B.

Truth table :

| X | Y | D <sub>diff</sub> | B <sub>Br</sub> |
|---|---|-------------------|-----------------|
| 0 | 0 | 0                 | 0               |
| 0 | 1 | 1                 | 1               |
| 1 | 0 | 1                 | 0               |
| 1 | 1 | 0                 | 0               |



from the truth table the Boolean expression for diff and Br are found to be

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

$$B_{Br} = \overline{A}B$$

These 2 expressions can be implemented using the circuit



The difference output can be taken directly from an Ex-OR gate. The half subtractor can also be drawn as



Half subtractor using NAND gate is



full Adder :-

A full adder is a combinational circuit. It is very useful when a carry input must be added to the 2 binary digits to obtain the correct sum. It consists of 3 IP and 2 outputs. 2 input variables are denoted by A and B and the 3rd input 'c' represents the carry from the previous lower significant position. The two outputs are sum (S) and carry (Cy).

Block diagram:



Truth table of full adder

| A | B | C | S | Cy |
|---|---|---|---|----|
| 0 | 0 | 0 | 0 | 0  |
| 0 | 0 | 1 | 1 | 0  |
| 0 | 1 | 0 | 0 | 1  |
| 0 | 1 | 1 | 1 | 0  |
| 1 | 0 | 0 | 1 | 0  |
| 1 | 0 | 1 | 0 | 1  |
| 1 | 1 | 0 | 0 | 1  |
| 1 | 1 | 1 | 1 | 1  |

From the truth table the sum of product expression for sum and carry is

$$S = \overline{A}\overline{B}c + \overline{A}B\overline{c} + A\overline{B}\overline{c} + ABC$$

$$Cy = \overline{A}Bc + A\overline{B}c + AB\overline{c} + ABC$$

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

$$\text{Let } M = \overline{A}\overline{B} + AB$$

$$= \overline{AB}$$

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

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

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

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

$$\therefore S = MC + \overline{M}c$$

$$= \boxed{M \oplus c}$$

$$\text{But } M = \overline{A}\overline{B} + AB \Rightarrow A \oplus B$$

$$S = \boxed{A \oplus B \oplus c}$$

$$\text{Similarly } \underline{Cy} = \overline{A}Bc + A\overline{B}c + AB\overline{c} + ABC$$

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

$$= \boxed{(A \oplus B) \cdot c + AB}$$

From the above expression the full adder circuit is as follows.



The full adder circuit can be made up of 2 half adders and an OR gate.



First half adder sum is added with the 3rd input C using 2nd half adder. The carry of 1st and 2nd half adder are combined using an OR gate to produce a single final carry.

Full adder using AND gate:



Block diagram:



Truth table:

| A | B | C | Diff | Bo |
|---|---|---|------|----|
| 0 | 0 | 0 | 0    | 0  |
| 0 | 0 | 1 | 1    | 1  |
| 0 | 1 | 0 | 1    | 1  |
| 0 | 1 | 1 | 0    | 1  |
| 1 | 0 | 0 | 1    | 0  |
| 1 | 0 | 1 | 0    | 0  |
| 1 | 1 | 0 | 0    | 0  |
| 1 | 1 | 1 | 1    | 0  |

The SOP expression for the Diff =  $\bar{A}\bar{B}C + \bar{A}B\bar{C} + A\bar{B}C + AB\bar{C}$ .

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

The difference is same as the one for the sum expression for the full adder.

$$So \ Diff = A \oplus B \oplus C$$

$$Diff = \Sigma (1, 2, 4, 7) Bo = \Sigma (1, 2, 3, 7)$$

Full Subtractor :-

A full subtractor is a combinational circuit that performs arithmetic subtraction, of 3 inputs. It consists of 3 inputs and 2 outputs. A and B represents the 2 significant bits to be subtracted. From the 2<sup>nd</sup> input C represents the borrow taken from the next significant position. The outputs are Difference and borrow.

The K-map for  $B_1$  is

| A | B | $B_1$ |
|---|---|-------|
| 0 | 0 | 00    |
| 0 | 1 | 01    |
| 1 | 0 | 11    |
| 1 | 1 | 10    |

The 1's in the K-map for  $B_1$  combine to give 3 pairs and gives a reduced expression

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

A full adder can be converted into a full subtractor with the addition of only one NOT gate.

A full subtractor can also be implemented using 2 half subtractors and one OR gate.



The difference of the 1st half subtractor is the difference of the 1st full subtractor using 2nd Half Subtractor with the 3rd input of using 2nd Half Subtractor. The 1st and 2nd half subtractor's borrow combined using an OR gate to produce a single final Br output.

From the truth table

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

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

using the above expression we can construct the full subtractor circuit



NAND using full subtractor:



FOUR-BIT ADDER:-

A 4-bit adder adds two 4-bit numbers. This is represented as

$$\begin{array}{r} A_3 \quad A_2 \quad A_1 \quad A_0 \rightarrow \text{Augend} \\ (+) \quad B_3 \quad B_2 \quad B_1 \quad B_0 \rightarrow \text{Addend} \\ \hline S_3 \quad S_2 \quad S_1 \quad S_0 \rightarrow \text{sum} \end{array}$$

The 4-bit adder requires 4 full adders. Each full adder adds 3 bits A, B, C and produces 2 outputs as S (sum) and cy (carry).



The 1<sup>st</sup> full adder adds the  $A_0$  and  $B_0$ . It has a carry input  $c_{in}$  & it is kept in '0' state. The 1<sup>st</sup> circuit outputs sum  $S_0$  and carry  $c_0$ .

The 2<sup>nd</sup> full adder adds  $A_1$  and  $B_1$  and the carry  $c_0$  from the previous addition. Similarly the 3<sup>rd</sup> adder and 4<sup>th</sup> full adder adds their input bits and carry from the previous addition. Output is a 4-bit sum  $S_3, S_2, S_1, S_0$  and a carry  $c_{out}$ .

Example: Add 9 to 14.

$$\begin{array}{r} A_3 \ A_2 \ A_1 \ A_0 = 1 \ 0 \ 0 \ 1 \rightarrow (9)_{10} \\ B_3 \ B_2 \ B_1 \ B_0 = 1 \ 1 \ 1 \ 0 \ (\text{14})_{10} \\ \hline 1 \ 1 \ 0 \ 1 \ 1 \end{array} \rightarrow (14)_{10}$$

$$\frac{1}{16} \overline{5 \ 2 \ 2 \ 1} \rightarrow (23)_{10}$$

8-bit adder:

Combining two 4-bit adder circuits, an 8-bit adder circuit can be constructed. Then the  $c_{out}$  of the 1<sup>st</sup> 4-bit adder will act as  $c_{in}$  to the 2<sup>nd</sup> 4-bit adder.  $B_7, B_6, B_5, B_4$  are inputs to the 1<sup>st</sup> 4-bit adder.  $A_7, A_6, A_5, A_4$  are inputs to the 2<sup>nd</sup> 4-bit adder.





## Combinational Circuit Applications

- \* Multiplexor
- \* Demultiplexor
- \* Encoder
- \* Decoder

### Mux/Plucker :-

\* A multiplexer (data selector) has  $2^n$  inputs and one output. Any one of the input can be brought out to the output.

For example, a 2-input multiplexer has 2 inputs, one o/p and one select line ( $2^1 = 2$ ).

\* A 4 - I/P multiplexer has 4 input one o/p and

2 select lines ( $2^2 = 4$ ).

\* Similarly A 8 - I/P multiplexer has 8 input one o/p and

3 select lines ( $2^3 = 8$ )

2 I/P multiplexer



→ where  $I_0, I_1$  are inputs,  $Y$  is an output line.  $S_0$  is a selection line.  
 → when  $S_0 = 0$  the Input  $I_0$  is selected &  $Y = I_0$   
 → when  $S_0 = 1$  the Input  $I_1$  is selected &  $Y = I_1$ .

| Function Table |       |
|----------------|-------|
| $S_0$          | $Y$   |
| 0              | $I_0$ |
| 1              | $I_1$ |



\* In a 4 - I/P multiplexer  $I_0, I_1, I_2, I_3$  are the 4 I/Ps  
 $Y$  is the o/p.  $S_1$  &  $S_0$  are 2 select lines.

$$Y = \overline{S_0} I_0 + S_0 I_1$$

The o/p  $Y$  can be expressed as

The 2 I/P multiplexer logic circuit

Implemented using AND, OR and NOT gate



When  $S_0 = 0$  the top AND gate allows I/P to pass on while the bottom AND gate blocks the bottom AND gate.  $\therefore Y = I_0$ . Similarly when  $S_0 = 1$  the bottom AND gate allows I/P  $I_1$  to pass on while the bottom AND gate blocks the top AND gate.  $\therefore Y = I_1$ .

gives the o/p as '0'.  $\therefore Y = I_0$ .

The circuit is also called as a 2-line to 1 line data selector.

Function table:

| $S_1$ | $S_0$ | $Y$   |
|-------|-------|-------|
| 0     | 0     | $I_0$ |
| 0     | 1     | $I_1$ |
| 1     | 0     | $I_2$ |
| 1     | 1     | $I_3$ |



From the function table the boolean expression is

$$Y = \bar{S}_1 \bar{S}_0 I_0 + \bar{S}_1 S_0 I_1 + S_1 \bar{S}_0 I_2 + S_1 S_0 I_3$$



Multiplexers with Strobe / Enable Input:-  
In Multiplexer one of the input is transferred to the output. The input is selected by the select line. When we combine a number of multiplexers and enable only one of the multiplexers. Therefore a strobe/enable terminal (EN) is included in some multiplexer chips.

Logic diagram for strobe / Enable input and function table for 4-Input multiplexer is given below.

Function table:

| $EN$ | $S_1$ | $S_0$ | $Y$   |
|------|-------|-------|-------|
| 0    | X     | X     | 0     |
| 0    | 0     | 0     | $I_0$ |
| 1    | 0     | 1     | $I_1$ |
| 1    | 1     | 0     | $I_2$ |
| 1    | 1     | 1     | $I_3$ |



When the strobe terminal is in '0' state, O/p of all the AND gates becomes '0' & the o/p Y is also 0 & thus is independent of the select inputs  $S_1$  &  $S_0$ . In this condition multiplexer is disabled, when strobe & D/P is in '1' state all the AND gates are enabled and the circuit functions normally as a multiplexer.

The strobe input active high or low the multiplexer is enabled when strobe is high and disabled when strobe is low. On the other hand, if the strobe is active, then the multiplexer is enabled when strobe is low and disabled when strobe is high.

A AND gates are enabled and the circuit functions normally as a multiplexer.

The strobe input active high or low the multiplexer is enabled when strobe is high and disabled when strobe is low. On the other hand, if the strobe is active, then the multiplexer is enabled when strobe is low and disabled when strobe is high.

8-Input Multiplexer

Multiplexer



| $\bar{E}N$ | $S_2$ | $S_1$ | $S_0$ | $Y$ |
|------------|-------|-------|-------|-----|
| 1          | X     | X     | X     | 0   |
| 0          | 0     | 0     | 0     | 1   |
| 0          | 0     | 0     | 1     | 0   |
| 0          | 0     | 1     | 0     | 1   |
| 0          | 1     | 0     | 0     | 0   |
| 0          | 1     | 0     | 1     | 1   |
| 0          | 1     | 1     | 0     | 0   |
| 0          | 1     | 1     | 1     | 1   |
| 1          | 0     | 0     | 0     | 0   |
| 1          | 0     | 0     | 1     | 1   |
| 1          | 0     | 1     | 0     | 0   |
| 1          | 0     | 1     | 1     | 1   |
| 1          | 1     | 0     | 0     | 0   |
| 1          | 1     | 0     | 1     | 1   |
| 1          | 1     | 1     | 0     | 0   |
| 1          | 1     | 1     | 1     | 1   |

The multiplexer has 8  $I_{in}$ ,  $I_0, I_1, \dots, I_7$ , one exp  $Y$  and 3 selector lines  $S_0, S_1, S_2$ . It has active low enable input  $\bar{E}N$ .

16-Input Multiplexer.



DEMULTIPLEXER

It is reverse of multiplexers. It has one  $I_{in}$ ,  $2^n$  op and  $n$  select line but it is one IC many circuit.

1-line to 2-line demultiplexers.



| $S_0$ | $Y_0$ | $Y_1$ |
|-------|-------|-------|
| 0     | I     | 0     |
| 1     | 0     | I     |

When  $I$  is  $I_{in}$ ,  $Y_0, Y_1$  are 2 op lines &  $S_0$  is a

Select line.

Logic diagram



When  $S_0=0$  Input  $I$  is passed on to the op  $Y_0$ . When  $S_0=1$  Input  $I$  is passed on to the op  $Y_1$ .

A op & 2 select lines.



1-line to 4-line demultiplexer  
This type of multiplexer will have one input

## 1 line to $n$ Demultiplexer

Here the working principle is same as previous circuits. It has one input, sixteen outputs & 4 select lines.

| $s_1$ | $s_0$ | $y_0$ | $y_1$ | $y_2$ | $y_3$ |
|-------|-------|-------|-------|-------|-------|
| 0     | 0     | 1     | 0     | 0     | 0     |
| 0     | 1     | 0     | 1     | 0     | 0     |
| 1     | 0     | 0     | 0     | 1     | 0     |
| 1     | 1     | 0     | 0     | 0     | 1     |

When  $s_1 = 0$  and  $s_0 = 0$  then  $y_0 = 1$

$s_1 = 0$  and  $s_0 = 1$  then  $y_1 = 1$

$s_1 = 1$  "  $s_0 = 0$  then  $y_2 = 1$

$s_1 = 1$  "  $s_0 = 1$  then  $y_3 = 1$



It has  $n$  address lines and  $2^n$  ops for a given address only one of the output goes high and remaining ops remain in low state. In this case the decoder is said to have active high outputs. In this case only one output goes low while the remaining ops are in the high state.

2 to 4 Decoder  
A one line to 4-line multiplexer acts as a 2 to 4 decoder, with the I/P line of the demultiplexer acting as an enable input. The I/P is now taken as enable EN and the circuit is enabled from a page 1. The select lines

are  $s_3, s_2, s_1, s_0$ . The 4-line multiplexer acts as a 2 to 4 decoder, with the I/P line of the demultiplexer acting as an enable input. The I/P is now taken as enable EN and the circuit is enabled from a page 1. The select lines

$S_1, S_0$  are taken as address input A, B.

1 to 4 Demultiplexer



d to 4 Decoder



when  $EN=1$  only one of the

output goes to '1' state  
(active high), while the remaining

ops are in '0' state.

| EN | A | B | $Y_0$ | $Y_1$ | $Y_2$ | $Y_3$ |
|----|---|---|-------|-------|-------|-------|
| 1  | 0 | 0 | 1     | 0     | 0     | 0     |
| 1  | 0 | 1 | 0     | 1     | 0     | 0     |
| 1  | 1 | 0 | 0     | 0     | 1     | 0     |
| 0  | x | x | 0     | 0     | 0     | 0     |

3 to 8 Decoder

It has 3 address pins ABC and eight active low

(or) active high outputs  $Y_0, Y_1, \dots, Y_7$  from the given address pins  
one of the eight ops goes low while the remaining seven

outputs are in high state.

$\bar{Y}$  is the  
output  
 $n$  inputs =  $2^n$  outputs



ENCODER

An encoder is a logic circuit that produces a  
reverse operations of a decoder. For example a 3 to 8  
decoder has 3 inputs and 8 outputs. The encoder has 8 inputs  
and 3 outputs. The I/P level can be active high or active low.  
Depending on the I/P that is active the op produce an  
equivalent 3 bit binary equivalent.

CIRCUIT

$$B = 2^3$$

$n$  inputs =  $m$  outputs  
where  $n = 2^m$



| EN | A | B | $Y_0$ | $Y_1$ | $Y_2$ | $Y_3$ | $Y_4$ | $Y_5$ | $Y_6$ | $Y_7$ |
|----|---|---|-------|-------|-------|-------|-------|-------|-------|-------|
| 1  | 0 | 0 | 0     | 1     | 1     | 1     | 1     | 1     | 1     | 1     |
| 1  | 0 | 1 | 1     | 0     | 1     | 1     | 1     | 1     | 1     | 1     |
| 1  | 1 | 0 | 1     | 1     | 0     | 1     | 1     | 1     | 1     | 1     |
| 0  | x | x | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     |
| 1  | 1 | 1 | 0     | 1     | 1     | 1     | 1     | 1     | 1     | 1     |
| 1  | 1 | 1 | 1     | 0     | 1     | 1     | 1     | 1     | 1     | 1     |
| 1  | 1 | 1 | 1     | 1     | 0     | 1     | 1     | 1     | 1     | 1     |
| 1  | 1 | 1 | 1     | 1     | 1     | 0     | 1     | 1     | 1     | 1     |
| 1  | 1 | 1 | 1     | 1     | 1     | 1     | 0     | 1     | 1     | 1     |
| 1  | 1 | 1 | 1     | 1     | 1     | 1     | 1     | 0     | 1     | 1     |

## UNI - IV

### FLIP-FLOPS

www.naukri.com

function table

| $T_0$ | $T_1$ | $T_2$ | $T_3$ | $T_4$ | $T_5$ | $T_6$ | $T_7$ | A | B | C |
|-------|-------|-------|-------|-------|-------|-------|-------|---|---|---|
| 1     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0 | 0 | 0 |
| 0     | 1     | 0     | 0     | 0     | 0     | 0     | 0     | 0 | 0 | 0 |
| 0     | 0     | 1     | 0     | 0     | 0     | 0     | 0     | 0 | 0 | 0 |
| 0     | 0     | 0     | 1     | 0     | 0     | 0     | 0     | 0 | 0 | 0 |
| 0     | 0     | 0     | 0     | 1     | 0     | 0     | 0     | 0 | 0 | 0 |
| 0     | 0     | 0     | 0     | 0     | 1     | 0     | 0     | 0 | 0 | 0 |
| 0     | 0     | 0     | 0     | 0     | 0     | 1     | 0     | 0 | 0 | 0 |
| 0     | 0     | 0     | 0     | 0     | 0     | 0     | 1     | 0 | 0 | 0 |
| 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 1 | 0 | 0 |
| 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0 | 1 | 0 |
| 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0 | 0 | 1 |

From the function table output line A goes to '1' state

when  $T_4$ , or  $T_5$  or  $T_6$  or  $T_7$  is active. That is

$$A = T_4 + T_5 + T_6 + T_7$$

Similarly  $B = T_2 + T_3 + T_6 + T_7$

$$C = T_1 + T_3 + T_5 + T_7$$

The combination  $T_4, T_5, T_6, T_7, T_1, T_2, T_3, T_5$



### INTRODUCTION :-

A Flip-Flop is a bi-state device i.e.,

a circuit with only 2 stable states, namely, the '0' state and the '1' state. It can store a bit of information.

A basic flip-flop circuit is a basic memory circuit or a one bit memory cell. A flip-flop always complements each other.

A circuit based on flip-flops usually pauses or clocked. When the output goes from 0 to 1 state and comes back to 0 state is known as pulse. The continuous pulses are called a pulse train. The pulses are called clock pulse or clock CLK. It is denoted by  $f = \frac{1}{T}$  frequency,  $T$  = regular period.

Combinational circuits consist of finite number of input and one (or) more outputs. One circuit outputs becomes the input of another circuit is called sequential circuit. The basic building block of sequential circuit is called a flip-flop in digital electronics.

### Types of FF

- \* NAND latch
- \* SR flip flop (SET-RESET)
- \* D Flip flop - (DELAY)
- \* JK flip flop (J-SET / K-RESET)
- \* T flip flop (TOGGLE)



NAND LATCH basic flip-flop or one bit memory cell

is formed by cross coupling 2 NOT gates  $G_1$  and  $G_2$ . The op of each gate is connected to the input of the other gate.



| Truth table for NAND gate |   |                |
|---------------------------|---|----------------|
| A                         | B | $Y = \bar{AB}$ |
| 0                         | 0 | 1              |
| 0                         | 1 | 1              |
| 1                         | 0 | 1              |
| 1                         | 1 | 0              |

The op of gate 1 is  $Q$  is connected to the input of gate  $G_2$ . The op of the Gate  $G_2$  is  $\bar{Q}$ . If  $Q=0$  then  $\bar{Q}=1$  and when  $Q=1$  then  $\bar{Q}=0$ .

If store one bit of information it's called a LATCH.

or 1-bit memory cell. This circuit is called as a 1-bit memory cell. This circuit is modified using two 2-inputs NAND gates.

This circuit is modified using two 2-inputs NAND gates and input of each NAND gate is used for the feed-back connection. This circuit is called as a NAND LATCH

Let  $S$  and  $R$  be I/P of the NAND LATCH and let  $Q$ ,  $\bar{Q}$  be the op of the latch.



| S | R | Q | Forbidden state |
|---|---|---|-----------------|
| 0 | 0 | ? | Not allow       |
| 0 | 1 | 1 | Set             |
| 1 | 0 | 0 | Reset           |
| 1 | 1 | Q | No change       |

case 1:-  
 $S=0 \quad R=0$

The output  $Q$  of  $G_1$  is 1. This op is taken as input to the second NAND gate  $G_2$ . Now the 2nd NAND Gate inputs are in 1 state.  $\therefore$  The output is 0. when the op goes to 1 the latch is said to be set.

case 2:-  
 $S=1 \quad R=0$

The output  $Q$  of  $G_1$  is 1 for  $G_1$  both the ip are 1 an input to the second NAND gate  $G_2$ . Now the 2nd NAND Gate inputs are in 1 state.  $\therefore$  The output is 0. when the op goes to 1 the latch is said to be reset.

The op of  $G_1$  is 1 for  $G_1$  both the ip are 1 and the op of  $G_1$  is 0 i.e.  $Q=0$  and  $\bar{Q}=1$  when the op goes to 0 state, the latch is said to be reset.

Case 4:

$$\bar{S} = 1 \quad \bar{R} = 1$$

When both the inputs are 1 state the output is also 1 so there is no change.

SR FLIP FLOP

Add 2 NOT gates ( $G_3$  and  $G_4$ ) in front of the

NAND LATCH is known as SR flip-flop.



| S | R | Q           |
|---|---|-------------|
| 0 | 0 | Q           |
| 0 | 1 | 0           |
| 1 | 0 | set         |
| - | - | Not allowed |

No change

Reset

Set

Not allowed



| R | S | Q |
|---|---|---|
| 0 | 0 | Q |
| 0 | 1 | 1 |
| 1 | 0 | 0 |
| - | - | ? |

No change  
Set  
Reset  
Not allowed

SR flip-flop using NOR gate

An SR flip-flop can also be constructed using NOR gates with cross-coupled connections from the output of one gate to the input of the other gate.

case 1:  
When  $S=0$ ,  $R=0$  we get  $\bar{S}=1$ ,  $\bar{R}=1$  from the NAND latch truth table the output is -No change.

case 2:  
When  $S=0$ ,  $R=1$  we get  $\bar{S}=1$ ,  $\bar{R}=0$  from the NAND latch truth table output  $Q=0$ .

case 3:  
When  $S=1$ ,  $R=0$  we get  $\bar{S}=0$ ,  $\bar{R}=1$  from the NAND latch truth table output  $Q=1$ .

case 4:  
When  $S=1$ ,  $R=1$  we get  $\bar{S}=0$ ,  $\bar{R}=0$  so that no output  $Q$  is not allowed.

case 4:

$$\bar{S} = 1 \quad \bar{R} = 1$$

When both S output is 0. Now is also 1. So the reset condition



A  
N,  
R  
out  
from  
out  
in  
and

The gates go to 0 which

... make S and Q must complement

each other. Hence R=1 and S=1 is a forbidden condition.



### CLOCKED S-R FLIP FLOP

All sequential circuits operate in synchronization

with some form of clock pulses. In SR flip flop and 2 AND gates at the S and R input they are used to enable or disable the flip-flop.

One of I/P of both the AND gates are

connected together and taken as an enable or clock input (CLK). The 2<sup>nd</sup> inputs of the AND gates are again named as S and R when the CLK input is low, the output of both the AND gate is '0'. Since '0' is passed to S and R.

When S=0, R=0, the flip flop will be in 'no change' condition which makes the outputs Q and

$\bar{Q}$  to retain the previous state. SR flip flop is disabled when the CLK input is low.

when the CLK input goes high, S and R values are passed on to the SR flip flops and depending on the SR values the O/P is modified. In other words the SR flip flop is enabled when the CLK is high.

Block diagram

Logic circuit

Block dia  
of  
clock

FUNCTION TABLE

| CLK | S | R | Q |
|-----|---|---|---|
| 0   | x | x | Q |
| 1   | 0 | 0 | Q |
| 1   | 0 | 1 | 0 |
| 1   | 1 | 0 | ? |
| 1   | 1 | 1 | ? |

No change

No change

Reset

Set

Not allowed.

### EDGE TRIGGERED FLIP-FLOPS

In the design of sequential circuits, combinational circuits are combined with flip-flops. The output of a combinational circuit is given as inputs to a flip-flop like the SR flip-flop.



In this circuit the O/P of the flip flop change state depending on the S and R values only when a clock pulse is applied. The output of the flip-flop taken as input to the combinational circuit. Now this circuit gives a new output which will alter the values of S and R. The SR flip flop should respond only to the next pulse and give a new output.

The flip flops respond only during the rising edge or falling edge of the clock pulse and not during the period when the pulse remains high. The flip flops are then called as EDGE TRIGGERED FLIP FLOP



The 'rise' edge trigger responds during the rising edge of the clock pulse. A 'fall' edge triggered flip flop responds ~~to the clock pulse~~ during the falling edge of the clock pulse.

### JK FLIP FLOP

A JK flip flop is a refinement of the RS flip-flop. Inputs J and K behave like inputs S and R to set and clear the flip flop. When inputs are applied to both J and K simultaneously, the flip flop switches to its complement state, that is If  $Q=1$  it switches to  $Q=0$  and vice versa.

A clocked JK flip flop:



Output Q is AND with K and CP inputs. So that the flip-flop is cleared during a clock pulse only if a previous 1. similarly output  $\bar{Q}$  is ANDed with J and CP inputs. so that the flip-flop is set with a clock pulse only if a was previously 1.

Block diagram:



Symbol: (or)



Symbol:



Symbol:

Chorakshī

|                 |    |
|-----------------|----|
| - - - - 0 0 0 0 | P  |
| - 0 0 - - 0 0   | 4  |
| - 0 - 0 - 0 - 0 | X  |
| 0 - 0 - - 0 0   | FB |

۷۰

|   |   |   |   |   |   |     |
|---|---|---|---|---|---|-----|
| - | - | - | - | - | 0 | CJK |
| - | - | 0 | 0 | 0 | X | J   |
| - | 0 | 0 | - | 0 | X | K   |
| - | 0 | - | 0 | - | 0 | Q   |
| - | 0 | - | 0 | 0 | - | QHJ |

Racing:  $TP < t_{\text{ris}}$  ( $TP$  - propagation delay, two-pulse width). The clock pulse changes thousands of times so the output of JK can not be predicted. This is called racing or race-around. The JK flip-flop behave like an



1

|    |   |   |   |
|----|---|---|---|
| -  | - | 0 | C |
| -  | 0 | X | 1 |
| -  | 0 | X | 4 |
| -  | 0 | X | π |
| 01 | 0 | Φ | 0 |



१८४२ दिसंबर

RS Flip-flop, except when both J and K are equal to 1. The clock pulse is transmitted through one AND gate only - the one whose input is connected to the flip-flop output which is presently equal to 1.

If  $\Omega = 1$  the output of the upper AND gate becomes 1 upon application of a clock pulse, and the flip flop is cleared. If  $\Omega = 1$  the output of the lower AND gate becomes 1 and the flip-flop is set. In either case the output of the flip-flop is complemented.

When  $T = 0$ , the inputs  $J$  and  $K$  will also be equal to 1. The output of the T flip-flop will be in 'no-change' condition when a clock pulse is applied.

output of the toggle from its previous state.

A flip flop which ~~exists~~ has only one input and what.

The T-Flip-Flop is a single input version of the JK Flip Flop. It stands for a Toggle flip-flop. A JK Flip-Flop can be used to construct a T flip flop. A T flip flop has one T input which is connected to both J and K inputs of a JK flip flop.

transfers the input data to the output on application of a clock pulse is called a D-Flip-flop.

Block diagram



Function table:

| CLK | D | Q |
|-----|---|---|
| 0   | X | Q |
| 1   | 0 | 0 |
| 1   | 1 | 1 |

No change

When CLK input is '0', the output of SR flip flop is no-change. When CLK input is '1', the output of the flip flop depends on Input D.

If  $D = 0$  then  $Q = 0$  and  $\bar{Q} = 1$  which is a

reset condition that makes  $Q = 0$ .

If  $D = 1$  then  $Q = 1$  and  $\bar{Q} = 0$

condition that makes  $Q = 1$ .

MASTER-SLAVE FLIP FLOP:



A master-slave flip-flop is constructed from 2 separate flip flops. One circuit serves as a master and the other as a slave, the overall circuit is referred to as a master-slave flip flop.

Master-Slave SR flip-flop:-

SR flip-flop can be converted to master-slave SR flip flop by connecting two SR flip-flops one another so that one of them acts as a master and the other acts as a slave.

They follow SR truth table. Both SR responds when the clock applied to them goes from 0 to 1 when connected in master-slave mode, the clock is directly applied directly to master and the clock is inverted and applied to the slave.

By this arrangement, the master-SR responds when CLK pulse rises (0 to 1) and slave responds to (1 to 0). The final output is obtained from output of the slave. The final output is obtained at and after the pulse or during the negative edge of the circuit is called as negative edge triggered SR flip flop.

The output of the master  $Q_m$  and  $\bar{Q}_m$ . These output are directly connected to S and R inputs of slave. The slave, the S and R inputs always complement each other, i.e., when  $S=0, R=1$  and when  $S=1, R=0$ . There are no other combinations for the slave.

$\rightarrow$  let  $S=1$  and  $R=0$  for the master, the pulse is applied during rising edge the master respond

and its output  $\underline{Q_m=1}$  and  $\underline{\bar{Q}_m=0}$ . It is directly transferred to SR inputs of slave. The slave responds during the falling edge and final output  $\underline{Q=1}, \underline{\bar{Q}=0}$ . This is set condition.

→ when  $\underline{S=0} \underline{R=1}$  for master, A pulse is applied during rising edge the master responds and its output

$\underline{Q_m=0}$  and  $\underline{\bar{Q}_m=1}$ . It is directly transferred to

SR inputs of slave. The slave responds during

falling edge and final output  $\underline{Q=0}$  and  $\underline{\bar{Q}=1}$ .

The reset condition.

→ when  $\underline{S=0} \underline{R=0}$ ,  $\underline{Q_m}$  and  $\underline{\bar{Q}_m}$  retains the previous values and so final output from the slave also does not change.

The second SR flip-flop follows the first SR flip-flop and hence the first one is called the master and the second is slave.

→ Block diagram for positive edge triggered SR flip-flop, and negative edge triggered SR flip-flop

is shown below.



→ indicates dynamic indicator. Triangle at CLK I/P indicates the edge, triangle with bubble at front indicates +ve.

Operation:-

→ The information present at the J and K I/P is transmitted to master flip flop on the edge of a CLK. A CLK is held -ve edge of CLK pulse occurs after which is allowed to pass through slave.



JK Master-Slave flip flop :-

In the operation of JK flip-flop, it is very difficult to satisfy the requirements, which should be fulfilled to avoid sausage condition. When both the data I/Ps are high, the practical approach to overcome the problem is to use 'Master-Slave JK flip-flop'.

Logic diagram:-

This diagram contains two clocked flip-flops. One flip-flop serves as master and other as slave. → whenever the clock is high, the master is active. According to data inputs, the output of master is set or reset. At this stage, slave is inactive and its output remains in previous stage. → whenever the clock is low, the slave is active. The final output of master-slave flip flop is the O/P of slave flip-flop.

## REGISTERS

### Introduction:

When CLK I/P is low, it keeps the O/P of gates 1 and 2 at high level. This prevents the J and K I/P from activating master flip-flop. When CLK is low, the output gate is High, so that Q is equal to Y and  $\bar{Q}$  is equal to Y.

3) When the edge of a clock pulse occurs, the master flip-flop is activated and slave is isolated as long as clock pulse is at High. When CLK<sub>IP</sub> is returned to low, the master is isolated from J and K inputs and slave flip-flop goes to same state as the master flip-flop.

Block diagram



Logic Diagram using

Binary Counter

A single D flip-flop or D latch can be used to store a single bit. It has one I<sub>IP</sub>, one O/P and a CLK I<sub>IP</sub> or an enable I<sub>IP</sub>. The register consists of four D flip-flops. The four binary I<sub>IP</sub> are I<sub>0</sub>, I<sub>1</sub>, I<sub>2</sub>, I<sub>3</sub> and O/P Q<sub>0</sub>, Q<sub>1</sub>, Q<sub>2</sub> and Q<sub>3</sub>. The clock pulse is also applied.

(i) Temporary storage  
(ii) Shifting capability.



| Truth table |   | Outputs |                | Mode of operation |           |
|-------------|---|---------|----------------|-------------------|-----------|
| J           | K | CLK     | Q <sub>0</sub> | Q <sub>1</sub>    |           |
| 0           | 0 | 0       | 00             | 00                | No change |
| 0           | - | 0       | 00             | 01                | RESET     |
| -           | 0 | 0       | 01             | 00                | SET       |
| -           | 1 | 0       | 00             | 10                | Toggle.   |

The flip-flops are edge triggered so that data available at that instant. The transfer of data goes on till the enable I/P reaches low state. The last data received is retained as previous value.

### Shift Registers:-

A register capable of shifting its binary information either to the right or to the left is called a shift register.

The logical configuration of a shift register consisting of a chain of flip-flops connected in cascade, with the output of one flip-flop connected to the I/P of the next flip-flop. All flip-flop receives a common clock pulse.



The shift register was only flip-flops. The output of a given flip-flop is connected to the D input of the flip-flop at its right. Each clock pulse shifts the content of the registers one bit position to the right.  
The serial I/P determines what goes into the left-most flip flop during the shift. The serial O/P

is taken from the output of the right most flip-flops.

Block diagram of 4-bit shift register:-



Data movements in registers :-  
The data can be entered either in serial form (one bit at a time) or parallel form (all the bits simultaneously).

The four possible modes are

- \* Serial in - Serial out  $\rightarrow$  one bit at a time on single I/P
- \* Serial in - Parallel out  $\rightarrow$  similar I/P as serial in but Q1, Q2, Q3, Q4 taken simultaneously
- \* Parallel in - Serial out  $\rightarrow$  I/P simultaneous & Q1, Q2, Q3, Q4 taken simultaneously
- \* Parallel in - Parallel out  $\rightarrow$  Both I/P and Q1, Q2, Q3, Q4 taken simultaneously



(a) Serial-in/serial-out



(b) Parallel-in-parallel-out



(c) Parallel-in-single-out

Serial transfer :-

A digital system is said to operate in a serial mode when information is transferred and manipulated one bit at a time. The content of one register is transferred to another by shifting the bits from one register to the other. The information is transferred one bit at a time by shifting the bit out of the source register into the destination register.

The serial transfer of information from register A to register B is done with shift register.

Serial transfer block diagram:



Timing diagram:



The time interval between the clock pulse is called bit time and the time required to shift the entire content of a shift register is called word time.

The serial output (SO) of a register A goes by the serial input (SI) of the register B. To prevent the loss of information stored in the source register by circulated its serial output to its serial inputs. The initial content of register B is shifted out through its serial output and is lost unless it is transferred to a 3rd shift register.

The Shift control input determines when and by how many times the registers are shifted. This is done by the AND Gate that allows clock pulse to pass into the CP terminals only when the shift control is 1.

Serial transfer Example:



Assume A = 1011 and the register B = 0010. The signal transfer from A to B will occur in 4 steps.

After the first pulse T, A is shifted into the leftmost bit of B and at the same time, this is circulated into the left most position of A. The other bits of A and B are shifted once to the right. The previous serial output from B is lost and its value changes from 0 to 1. After the 4th shift, the shift control goes to '0' and and have the value 1011.

| Serial Modes                                                                                                                                                                                                                                                                                                                                         | Parallel Modes                                                                                                                                                                                                                                                                                                                                                                          |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <ul style="list-style-type: none"> <li>* In serial mode, the register have a single serial I/O and a single serial O/P. One bit transferred at a time.</li> <li>* Serial operations are slower.</li> <li>* It requires less hardware to perform operation.</li> <li>* Timing sequence are generated by the control section of the system.</li> </ul> | <ul style="list-style-type: none"> <li>* In a parallel mode information is available from all bits of a register and all bits can be transferred simultaneously.</li> <li>* Shifting on clock pulse.</li> <li>* Most computers operated in a parallel mode because this is faster mode of operation.</li> <li>* Control signals are enabled during one clock pulse interval.</li> </ul> |

**Bi-directional Shift Register with Parallel to Serial**

Shift registers can be used for converting serial data to parallel data and vice versa. If we have access to all the flip-flop output of a shift register, then information entered serially by shifting can be taken out parallel from the outputs of the flip-flop.

If a parallel load capability is added to a shift register, then data entered in parallel can taken out in serial fashion by shifting the data stored in the register.



Function table for the register:

| Mode control | Register operation |
|--------------|--------------------|
| S1<br>0      | 0<br>No change     |
| S1<br>0      | 1<br>Shift right   |
| S1<br>1      | 0<br>Shift left    |
| S1<br>1      | 1<br>Parallel load |

A bidirectional shift register with parallel load is a general-purpose register capable of performing  $\leftrightarrow$  operations.

- \* Shift Left
- \* Shift Right
- \* Parallel Load

Types of shift registers:-

- $\rightarrow$  Shift right shift register
- $\rightarrow$  Shift left shift register

A register capable of shifting both right and left is called a bidirectional shift register. One that can shift in only one direction is called a unidirectional shift register. If the register has both shift and parallel load capabilities, it is called a shift register with parallel load.

Shift right shift register:- In application of a clock pulse, during the rising edge, the input of each flip-flop is connected to the output, providing a shift right operation.

1. A clear control to clear the register to '0'.
2. A CP input for clock pulse to synchronize all operations.
3. A shift right control to enable the shift-right operation and the serial input and output lines associated with the shift-right.
4. Shift left control to enable the shift-left operation and serial input and serial outputs associated with the shift-left.
5. A Parallel-load control to enable a parallel transfer and the n input lines associated with the parallel transfers.
6. A Parallel output lines.
7. A control state that leaves the information in the register unchanged even though clock pulses are continuously applied.

Ex Sin data at (1011) that is given one by one from LSR.

| CLK | Sin | Q3 | Q2 | Q1 | Q0 |
|-----|-----|----|----|----|----|
| -   | -   | 0  | 0  | 0  | 0  |
| -   | 1   | 1  | 0  | 0  | 0  |
| -   | 1   | 0  | 1  | 0  | 0  |
| -   | 0   | 1  | 1  | 0  | 0  |
| -   | 0   | 0  | 0  | 1  | 0  |
| -   | 1   | 0  | 0  | 1  | 0  |
| -   | 1   | 0  | 0  | 0  | 1  |

Shift Left Register:-

It shifts each bit to the left one when a CLK pulse is applied. It can be constructed using 4 D (or) JK flip flops.



| CLK | Sin | Q3 | Q2 | Q1 | Q0 |
|-----|-----|----|----|----|----|
| -   | -   | 0  | 0  | 0  | 0  |
| -   | 0   | 0  | 0  | 0  | 0  |
| -   | 0   | 0  | 0  | 0  | 0  |
| -   | 0   | 0  | 0  | 0  | 0  |
| -   | 1   | 0  | 0  | 0  | 0  |
| -   | 1   | 0  | 0  | 0  | 0  |
| -   | 1   | 0  | 0  | 0  | 0  |

## UNIT - V Types of ROM and RAM -

### Introduction:-

Memory is a unit of computer which stores information and data and supplies the same to the computer as and when required. It also stores the results that are computed by the computer.

The memory is divided as Internal and External memory.

External memory → used for long-term storage data.

Ex: Floppy disk, hard disk.

Internal memory → It is a smaller segment of memory for temporary storage of program and data. Sometimes memory was electronic semi-conductor device called ROM and RAM.

### ROM (Read - Only Memory)

\* It is a read only memory. Program or data stored in the ROM can only be read. They cannot be altered.

\* It is non-volatile which means the contents are not changed when the power is switched off. The contents of ROM cannot be erased. The user cannot change the when he wants. To overcome this problem EPROM was introduced.

E PROM: It is an Erasable programmable Read only memory. The contents can be erased by shining ultra-violet (UV) light through a quartz window. The entire contents are erased when exposed to UV lights.

Some popular EPROMs are

2716 - 2K x 8

2732 - 4K x 8

2744 - 8K x 8



RAM (Random-access memory)  
→ Data can be readily written into and read from a RAM at any selected address in any sequence. It has the facility to read the contents of any memory location as well as write any fresh data in any memory location.

→ It is volatile which means that the contents are changed once the Power supply is switched off.

now types of RAM:

1. Static RAM (SRAM)

2. Dynamic RAM (DRAM)

Static RAM (SRAM): (Volatile memory)  
\* In SRAM binary information is stored in flip-flops. One bit for each flip-flop. A large number of flip-flops are arranged in the form of a matrix. A '0' or a '1' can be stored temporarily in a flip-flop. It is composed of storage elements such as flip-flop that are capable of retaining the information indefinitely as long as the power is on so that is known as static RAM.

Dynamic RAM (DRAM)

\* A memory having cells that tend to lose the storage information over a period of time and therefore must be refreshed. This memory is known as dynamic memory.

EEPROM: The contents can be erased using ultraviolet light.

### Static Memory

- \* Stored data is retained as long as power is on.
- \* The stored data do not change with time.
- \* Consumes more power.
- \* Expensive.
- \* These memories have less packing density.
- \* These memories are not easy to construct.

### Dynamic Memory

- \* Stored data gets lost and refreshing is required.
- \* Store data changes with time.
- \* Consumes less power.
- \* Economical
- \* High packing density
- \* Simpler in construction

Book  
NOTES FOR FUNDAMENTALS OF DIGITAL COMPUTER ELECTRONICS

No. of Pages: 75, PAGE BACK. THREE COLUMNED + 6 PAGES IN LINE COLUMNED (TO BE PRINTED)

PAPER PRINTED UNDER: RONITH KUMAR.

NOTE: BY Mrs SHIVARANJANI

MAINLY FOR: 1 BCA - A STUDENTS

DEVELOPED BY: CAM SCANNER

PAPER ~~PRINTING~~

- HAPPY DIGITAL LEARNING -

**Note:** ANY MISTYPED OR IMPROPER OR  
LINEAR NOTES IN ANY PAGE IS NOT  
OUR RESPONSIBILITY. ASK THE PRINTER TO CHECK  
FOR ANY COMPLAINTS

## UNIT - V

### Counters:

A register is used solely for storing and shifting data which is in the form of 1s and / or 0s, entered from an external source. It has no specific sequence of states except in certain very specialized applications. In digital logic and computing, a counter is a device which stores (and sometimes displays) the number of times a particular event or process has occurred, often in relationship to a clock signal. Count represents the number of clock pulses arrived. A specified sequence of states appears as the counter output. Specified set of states are different for different types of counters. In a digital circuit, counters are used to do 3 main functions.

- 1 Timing: High frequency pulse train can be used to produce low frequency pulse train (10 MHz oscillator to produce 1 MHz pulse train)
- 2 Sequencing: Applying power to large machine components in particular sequence
- 3 Counting: Total number of vehicles passing a particular road.

### Asynchronous Counters

In Asynchronous counters only the first flip-flop is clocked by an external clock. All subsequent flip-flops are clocked by the output of the preceding flip-flop. Asynchronous counters are slower than synchronous counters because of the delay in the transmission of the pulses from flip-flop to flip-flop. Asynchronous counters are also called ripple counters because of the way the clock pulses, or ripples, its way through the flip-flops.

### Synchronous Counters:

All flip-flops are clocked simultaneously by an external clock. Synchronous counters are faster than asynchronous counters because of the simultaneous clocking. Synchronous counters are an example of state machine design because they have a set of states and a set of transition rules for moving between those states after each clocked event.

### Comparison of synchronous and asynchronous counters:

| Asynchronous Counter                                                                                                                         | Synchronous Counter                                                                                                                                                            |
|----------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Flip-flops are connected in such a way that output of first flip-flop drives the clock for the next flip-flop.                               | In this type there is no connection between output of first flip-flop and clock input of the next flip-flop.                                                                   |
| All the flip-flops are not clocked simultaneously.                                                                                           | All the flip-flops are clocked simultaneously.                                                                                                                                 |
| Logic circuit is very simple even for more number of states.                                                                                 | Design involves complex logic circuit as number of states increases.                                                                                                           |
| Main drawback of these counters is their low speed as the clock is propagated through number of flip-flops before it reaches last flip-flop. | As clock is simultaneously given to all flip-flops there is no problem of propagation delay. Hence they are preferred when number of flip-flops increases in the given design. |

### Ripple Counter:

A ripple counter is an asynchronous counter where only the first flip-flop is clocked by an external clock. All subsequent flip-flops are clocked by the output of the preceding flip-flop. There are many ways to implement the ripple counter depending on the characteristics of the flip flops used and the requirements of the count sequence.

- Clock Trigger: Positive edged or Negative edged
- JK or D flip flops
- Count Direction: Up, Down, or Up/Down

### Circuit Diagram



DCBA

Clock is applied only to FF A. J and K are high in all FFs to toggle on every clock pulse. Output of FF A is CLK of FF B and so forth. FF outputs D, C, B, and A are a 4 bit binary number with D as the MSB. After the negative transition of the 15th clock pulse the counter recycles to 0000. This is an asynchronous counter because state is not changed in exact synchronism with the clock.

Frequency division: The output frequency of each FF = the clock frequency of input / 2.

Truth Table:

| Clock   | Counter Output |   |   |   | States | Dec.<br>Output |
|---------|----------------|---|---|---|--------|----------------|
|         | D              | C | B | A |        |                |
| Initial | 0              | 0 | 0 | 0 | -      | 0              |
| 1       | 0              | 0 | 0 | 1 | 1      | 1              |
| 2       | 0              | 0 | 1 | 0 | 2      | 2              |
| 3       | 0              | 0 | 1 | 1 | 3      | 3              |
| 4       | 0              | 1 | 0 | 0 | 4      | 4              |
| 5       | 0              | 1 | 0 | 1 | 5      | 5              |
| 6       | 0              | 1 | 1 | 0 | 6      | 6              |
| 7       | 0              | 1 | 1 | 1 | 7      | 7              |
| 8       | 1              | 0 | 0 | 0 | 8      | 8              |
| 9       | 1              | 0 | 0 | 1 | 9      | 9              |
| 10      | 1              | 0 | 1 | 0 | 10     | 10             |
| 11      | 1              | 0 | 1 | 1 | 11     | 11             |
| 12      | 1              | 1 | 0 | 0 | 12     | 12             |
| 13      | 1              | 1 | 0 | 1 | 13     | 13             |
| 14      | 1              | 1 | 1 | 0 | 14     | 14             |
| 15      | 1              | 1 | 1 | 1 | 15     | 15             |

| Clock Pulse | UP | Q <sub>2</sub> Q <sub>1</sub> Q <sub>0</sub> |   |   | DOWN |
|-------------|----|----------------------------------------------|---|---|------|
|             |    | 0                                            | 0 | 0 |      |
| 0           |    | 0                                            | 0 | 1 |      |
| 1           |    | 0                                            | 1 | 0 |      |
| 2           |    | 0                                            | 1 | 1 |      |
| 3           |    | 1                                            | 0 | 0 |      |
| 4           |    | 1                                            | 0 | 1 |      |
| 5           |    | 1                                            | 1 | 0 |      |
| 6           |    | 1                                            | 1 | 1 |      |
| 7           |    |                                              |   |   |      |

An examination of Q<sub>0</sub> for both the up and down sequences shows that FFO toggles on each clock pulse. So the J<sub>0</sub> and K<sub>0</sub> inputs of FFO are

$$J_0 = K_0 = 1$$

For the up sequence, Q<sub>1</sub> changes state on the next clock pulse when Q<sub>0</sub> = 1. For the down sequence, Q<sub>1</sub> changes on the next clock pulse when Q<sub>0</sub> = 0. Thus, the J<sub>1</sub> and K<sub>1</sub> inputs of FF1 must equal 1 under the conditions expressed by the following equation:

$$J_1 = K_1 = (Q_0 \cdot UP) + (\bar{Q}_0 \cdot DOWN)$$

For the up sequence, Q<sub>2</sub> changes state on the next clock pulse when Q<sub>0</sub> = Q<sub>1</sub> = 1. For the down sequence, Q<sub>2</sub> changes on the next clock pulse when Q<sub>0</sub> = Q<sub>1</sub> = 0. Thus, the J<sub>2</sub> and K<sub>2</sub> inputs of FF2 must equal 1 under the conditions expressed by the following equation:

$$J_2 = K_2 = (Q_0 \cdot Q_1 \cdot Up) + (\bar{Q}_0 \cdot \bar{Q}_1 \cdot DOWN)$$

#### Circuit Diagram:



### Mod Counter:

A mod n counter can also be termed as divide by n counter that divides the clock frequency by n. The divided frequency output is obtained from the MSB of the counter. The counter may be synchronous or asynchronous. In synchronous counter design, the clock is given simultaneously to all Flip Flops whereas in asynchronous design, the clock is given as an input to the LSB flip flop.

The 2-bit ripple counter is called as MOD-4 counter and 3-bit ripple counter is called as MOD-8 counter. So in general, an n-bit ripple counter is called as modulo-N counter. Where, MOD number =  $2^n$

Type of modulus:

- 2-bit up or down (MOD-4)
- 3-bit up or down (MOD-8)
- 4-bit up or down (MOD-16)
- ---

### - Modulo 2 counter:



### Up-Down Counters:

A synchronous binary up counter counts from 0 to  $2^N-1$ , where N is the number of bits/flip-flops in the counter. Each flip-flop is used to represent one bit. The flip-flop in the lowest-order position is complemented/toggled with every clock pulse and a flip-flop in any other position is complemented on the next clock pulse provided all the bits in the lower-order positions are equal to 1. A synchronous binary down counter counts down from  $2^N-1$  to 0, where N is the number of bits/flip-flops in the counter.

An up/down counter is one that is capable of progressing in either direction through a certain sequence. An up/down counter is sometimes called bi-directional counter, can have any specified sequence of states. A 3-bit counter that up-ward through its sequence (0,1,2,3,4,5,6,7) and then can be reversed so that it goes through the sequence (7,6,5,4,3,2,1) in reverse direction is an illustration of up/down sequential operation.

Below table shows the complete up/down sequence for a 3-bit binary counter. The arrows indicate the state-to-state movement of the counter for both its UP and its DOWN modes of operation.

### Timing Diagram:



### Ring Counter:

Ring counters are implemented using shift registers. It is essentially a circulating shift register connected so that the last flip-flop shifts its value into the first flip-flop. There is usually only a single 1 circulating in the register, as long as clock pulses are applied. 'Johnson Counter' is a special ring counter where the inverted output of the last flip flop is given as input to the first flip flop'.

### Circuit Diagram:



### Timing Diagram:



Load 1000 into 4-stage ring counter and shift