

# Unit 3

Combinational Logic Circuits

Quine-McCluskey minimization technique

Introduction to Combinational Circuits

Multiplexer

Demultiplexer

Decoder

Encoder

Binary adder

Binary adder as subtractor

Carry look ahead adder

Decimal adder

Magnitude Comparator

Problem solving session

Read –only Memory

Arithmetic Logic Unit

Programmable Logic Arrays

HDL Gate and Data Flow modeling

HDL Behavioral modeling

# Basic Logic Gates

## The Logic AND Gate

| Symbol                                                                             | Truth Table |   |   |
|------------------------------------------------------------------------------------|-------------|---|---|
|                                                                                    | A           | B | Q |
|  | 0           | 0 | 0 |
|  | 0           | 1 | 0 |
|                                                                                    | 1           | 0 | 0 |
|                                                                                    | 1           | 1 | 1 |

Boolean Expression  $Q = A \cdot B$

Read as A AND B gives Q

## The Logic OR Gate

| Symbol                                                                               | Truth Table |   |   |
|--------------------------------------------------------------------------------------|-------------|---|---|
|                                                                                      | A           | B | Q |
|  | 0           | 0 | 0 |
|  | 0           | 1 | 1 |
|                                                                                      | 1           | 0 | 1 |
|                                                                                      | 1           | 1 | 1 |

Boolean Expression  $Q = A + B$

Read as A OR B gives Q

## The Logic NOT Gate

| Symbol                                                                            | Truth Table                    |   |
|-----------------------------------------------------------------------------------|--------------------------------|---|
|  | A                              | Q |
|                                                                                   | 0                              | 1 |
|                                                                                   | 1                              | 0 |
| Boolean Expression $Q = \text{NOT } A$ or $\bar{A}$                               | Read as inversion of A gives Q |   |

## The Logic NAND Gate

| Symbol                                                                              | Truth Table                 |   |   |
|-------------------------------------------------------------------------------------|-----------------------------|---|---|
|  | A                           | B | Q |
|                                                                                     | 0                           | 0 | 1 |
|                                                                                     | 0                           | 1 | 1 |
|                                                                                     | 1                           | 0 | 1 |
|                                                                                     | 1                           | 1 | 0 |
| Boolean Expression $Q = \overline{A \cdot B}$                                       | Read as A AND B gives NOT-Q |   |   |

## The Logic NOR Gate

| Symbol                                                                            | Truth Table                |   |   |
|-----------------------------------------------------------------------------------|----------------------------|---|---|
|                                                                                   | A                          | B | Q |
|  | 0                          | 0 | 1 |
|                                                                                   | 0                          | 1 | 0 |
|                                                                                   | 1                          | 0 | 0 |
|                                                                                   | 1                          | 1 | 0 |
| Boolean Expression Q = $\overline{A+B}$                                           | Read as A OR B gives NOT-Q |   |   |

## The Logic EXOR Gate

| Symbol                                                                              | Truth Table                               |   |   |
|-------------------------------------------------------------------------------------|-------------------------------------------|---|---|
|                                                                                     | B                                         | A | Q |
|  | 0                                         | 0 | 0 |
|                                                                                     | 0                                         | 1 | 1 |
|                                                                                     | 1                                         | 0 | 1 |
|                                                                                     | 1                                         | 1 | 0 |
| Boolean Expression Q = $A \oplus B$                                                 | Read as A OR B but not BOTH gives Q (odd) |   |   |

## The Logic EXNOR Gate

| Symbol                                                                             | Truth Table                                |   |   |
|------------------------------------------------------------------------------------|--------------------------------------------|---|---|
|  | B                                          | A | Q |
|                                                                                    | 0                                          | 0 | 1 |
|                                                                                    | 0                                          | 1 | 0 |
|                                                                                    | 1                                          | 0 | 0 |
|                                                                                    | 1                                          | 1 | 1 |
| Boolean Expression $Q = \overline{A \oplus B}$                                     | Read if A AND B the SAME gives Q<br>(even) |   |   |

# Consolidation of Logic Gates

| Inputs |   | Truth Table Outputs For Each Gate |      |    |     |       |        |  |
|--------|---|-----------------------------------|------|----|-----|-------|--------|--|
| A      | B | AND                               | NAND | OR | NOR | EX-OR | EX-NOR |  |
| 0      | 0 | 0                                 | 1    | 0  | 1   | 0     | 1      |  |
| 0      | 1 | 0                                 | 1    | 1  | 0   | 1     | 0      |  |
| 1      | 0 | 0                                 | 1    | 1  | 0   | 1     | 0      |  |
| 1      | 1 | 1                                 | 0    | 1  | 0   | 0     | 1      |  |

| Logic Function | Boolean Notation                                                   |
|----------------|--------------------------------------------------------------------|
| AND            | $A \cdot B$                                                        |
| OR             | $A + B$                                                            |
| NOT            | $\bar{A}$                                                          |
| NAND           | $\overline{A \cdot B}$                                             |
| NOR            | $\overline{A + B}$                                                 |
| EX-OR          | $(A \cdot \bar{B}) + (\bar{A} \cdot B)$ or $A \oplus B$            |
| EX-NOR         | $(A \cdot B) + (\bar{A} \cdot \bar{B})$ or $\overline{A \oplus B}$ |



Buffer  
 $F = A$

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



AND  
 $F = AB$

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



OR  
 $F = A+B$

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



XOR  
 $F = A \oplus B$

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



Inverter  
 $F = \bar{A}$

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



NAND  
 $F = \overline{AB}$

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



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

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



XNOR  
 $F = \overline{A \oplus B}$

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

# Boolean Rules and Laws

| Name             | AND form                            | OR form                             |
|------------------|-------------------------------------|-------------------------------------|
| Identity law     | $1A = A$                            | $0 + A = A$                         |
| Null law         | $0A = 0$                            | $1 + A = 1$                         |
| Idempotent law   | $AA = A$                            | $A + A = A$                         |
| Inverse law      | $A\bar{A} = 0$                      | $A + \bar{A} = 1$                   |
| Commutative law  | $AB = BA$                           | $A + B = B + A$                     |
| Associative law  | $(AB)C = A(BC)$                     | $(A + B) + C = A + (B + C)$         |
| Distributive law | $A + BC = (A + B)(A + C)$           | $A(B + C) = AB + AC$                |
| Absorption law   | $A(A + B) = A$                      | $A + AB = A$                        |
| De Morgan's law  | $\overline{AB} = \bar{A} + \bar{B}$ | $\overline{A + B} = \bar{A}\bar{B}$ |

**Sum of Product (SOP)  
and  
Product of Sum (POS)**

# Minterm and Maxterm

A **minterm** is defined as the product term of n variables, in which each of the n variables will appear once either in its complemented or un-complemented form.

A **maxterm** is defined as the sum term of n variables, in which each of the n variables will appear once either in its complemented or un-complemented form.

| Variables |   |   | Min terms        | Max terms            |
|-----------|---|---|------------------|----------------------|
| A         | B | C | $m_i$            | $M_i$                |
| 0         | 0 | 0 | $A' B' C' = m_0$ | $A + B + C = M_0$    |
| 0         | 0 | 1 | $A' B' C = m_1$  | $A + B + C' = M_1$   |
| 0         | 1 | 0 | $A' B C' = m_2$  | $A + B' + C = M_2$   |
| 0         | 1 | 1 | $A' B C = m_3$   | $A + B' + C' = M_3$  |
| 1         | 0 | 0 | $A B' C' = m_4$  | $A' + B + C = M_4$   |
| 1         | 0 | 1 | $A B' C = m_5$   | $A' + B + C' = M_5$  |
| 1         | 1 | 0 | $A B C' = m_6$   | $A' + B' + C = M_6$  |
| 1         | 1 | 1 | $A B C = m_7$    | $A' + B' + C' = M_7$ |

# Sum of Product (SOP) Form

The **Sum of Product form** is a form of expression in Boolean algebra in which different product terms of inputs are being summed together.

**Example:**

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

$$F = \sum(m_1, m_2, m_3, m_5)$$

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

Canonical or  
Standard SOP form

# Product of Sum (POS) Form

The **Product of Sum form** is a form in which products of different sum terms of inputs are taken.

Example:

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

$$F = \prod (M_0, M_4, M_6, M_7)$$

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

Canonical or  
Standard POS form

# Conversion from Minimal SOP to Canonical SOP Form

Example:

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

The term  $\bar{A}B$  is missing input C. So we will multiply  $\bar{A}B$  with  $(C + \bar{C})$  because  $(C + \bar{C} = 1)$ .  
The term  $\bar{B}C$  is missing input A, so it will be multiplied with  $(A + \bar{A})$

Missing input  
variables need to  
be multiplied

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

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

# Conversion from Minimal POS to Canonical POS Form

Example:

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

( $\bar{A} + \bar{B}$ ) term is missing C input so we will add ( $C\bar{C}$ ) with it.  
( $B + C$ ) term is missing A input so we will add ( $A\bar{A}$ ) with it.

Missing input  
variables need to  
be added

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

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

# Conversion of SOP to POS

To convert the SOP form into POS form, first we should change the  $\Sigma$  to  $\Pi$  and then write the numeric indexes of missing variables of the given Boolean function.

**Example:**

$$F = \sum_{A, B, C} (0, 2, 3, 5, 7) = A' B' C' + A B' C' + A B' C + ABC' + ABC$$

Note: writing the missing indexes of the terms i.e., 1 - 001, 4 - 100 and 6 - 110.

$$001 = (A + B + C'), \quad 100 = (A' + B + C), \quad 110 = (A' + B' + C)$$

Hence,

$$F = \prod_{A, B, C} (1, 4, 6) = (A + B + C') * (A' + B + C) * (A' + B' + C)$$

# Conversion of POS to SOP

To convert the POS form into SOP form, first we should change the  $\Pi$  to  $\Sigma$  and then write the numeric indexes of missing variables of the given Boolean function.

**Example:**

$$F = \prod_{A, B, C} (2, 3, 5) = (A+B'+C) * (A+B'+C') * (A'+B+C')$$

Note: writing the missing indexes of the terms, 0 - 000, 1 - 001, 4 - 100, 6 - 110, and 7 - 111.

$$000 = A' * B' * C', 001 = A' * B' * C, 100 = A * B' * C', 110 = A * B * C', 111 = A * B * C$$

Hence,

$$\begin{aligned} F = \sum_{A, B, C} (0, 1, 4, 6, 7) = & (A' * B' * C') + (A' * B' * C) + (A * B' * C') + \\ & (A * B * C') + (A * B * C) \end{aligned}$$

# Karnaugh Map (K-Map)

# K-map

- K-Map is used to minimize the number of logic gates by minimizing the logical expression.
- The minimization will reduce cost, complexity and power consumption.
- An n-variable K-map has  $2^n$  cells with each cell corresponding to an n-variable truth table value.
  - If 2 variable – 4 cells
  - If 3 variable – 8 cells
  - If 4 variable – 16 cells
- K-map cells are arranged such that adjacent cells correspond to truth rows that differ in only one bit position.

## 2 variables K-Map

|   |           |                                                                                      |   |   |   |   |
|---|-----------|--------------------------------------------------------------------------------------|---|---|---|---|
|   | 0         | 1                                                                                    |   |   |   |   |
|   | $\bar{B}$ | $B$                                                                                  |   |   |   |   |
| 0 | $\bar{A}$ | <table border="1"><tr><td>0</td><td>1</td></tr><tr><td>2</td><td>3</td></tr></table> | 0 | 1 | 2 | 3 |
| 0 | 1         |                                                                                      |   |   |   |   |
| 2 | 3         |                                                                                      |   |   |   |   |
| 1 | $A$       |                                                                                      |   |   |   |   |

## 3 variables K-Map

|   |      | 00                     | 01                    | 11                   | 10                    |
|---|------|------------------------|-----------------------|----------------------|-----------------------|
|   |      | $y'z'$                 | $y'z$                 | $yz$                 | $yz'$                 |
|   |      | $m_0$<br>$x'y'z'$<br>0 | $m_1$<br>$x'y'z$<br>1 | $m_3$<br>$x'yz$<br>3 | $m_2$<br>$x'yz'$<br>2 |
| 0 | $x'$ | $m_0$<br>$x'y'z'$<br>0 | $m_1$<br>$x'y'z$<br>1 | $m_3$<br>$x'yz$<br>3 | $m_2$<br>$x'yz'$<br>2 |
|   | $x$  | $m_4$<br>$xy'z'$<br>4  | $m_5$<br>$xy'z$<br>5  | $m_7$<br>$xyz$<br>7  | $m_6$<br>$xyz'$<br>6  |

# 4 variables K-Map

|    |                  |                  |            |            |      |
|----|------------------|------------------|------------|------------|------|
|    |                  | 0 0              | 0 1        | 1 1        | 1 0  |
|    |                  | $\bar{C}\bar{D}$ | $\bar{C}D$ | $C\bar{D}$ | $CD$ |
| 00 | $\bar{A}\bar{B}$ | 0                | 1          | 3          | 2    |
| 01 | $\bar{A}B$       | 4                | 5          | 7          | 6    |
| 11 | $A\bar{B}$       | 12               | 13         | 15         | 14   |
| 10 | $AB$             | 8                | 9          | 11         | 10   |

# K-map Rules

1. Groups may not include any cell containing a zero.



2. Groups may be horizontal or vertical, but not diagonal.



# K-map Rules

3. Groups must contain 1, 2, 4, 8, or in general  $2^n$  cells.

| A<br>B | 0   | 1 |
|--------|-----|---|
| 0      | (1) | 1 |
| 1      | 0   | 0 |

RIGHT ✓

| AB<br>C | 00 | 01  | 11 | 10 |
|---------|----|-----|----|----|
| 0       | 0  | (1) | 1  | 1  |
| 1       | 0  | 0   | 0  | 0  |

WRONG ✗

| A<br>B | 0   | 1 |
|--------|-----|---|
| 0      | (1) | 1 |
| 1      | 1   | 1 |

RIGHT ✓

| AB<br>C | 00  | 01 | 11 | 10 |
|---------|-----|----|----|----|
| 0       | (1) | 1  | 1  | 1  |
| 1       | 0   | 0  | 0  | 1  |

WRONG ✗

# K-map Rules

4. Each group should be as large as possible.

|  |  | AB | 00 | 01  | 11  | 10  |   |
|--|--|----|----|-----|-----|-----|---|
|  |  | C  | 0  | (1) | 1   | (1) | 1 |
|  |  | 1  | 0  | 0   | (1) | 1   |   |
|  |  |    |    |     |     |     |   |
|  |  |    |    |     |     |     |   |

RIGHT ✓

|  |  | AB | 00 | 01  | 11  | 10  |   |
|--|--|----|----|-----|-----|-----|---|
|  |  | C  | 0  | (1) | 1   | (1) | 1 |
|  |  | 1  | 0  | 0   | (1) | 1   |   |
|  |  |    |    |     |     |     |   |
|  |  |    |    |     |     |     |   |

WRONG ✗

(Note that no Boolean laws broken,  
but not sufficiently minimal)

5. Each cell containing a one must be in at least one group.

◻ ◻

6. Groups may overlap.

|  |  | AB | 00 | 01  | 11  | 10  |   |
|--|--|----|----|-----|-----|-----|---|
|  |  | C  | 0  | (1) | 1   | (1) | 1 |
|  |  | 1  | 0  | 0   | (1) | 1   |   |
|  |  |    |    |     |     |     |   |
|  |  |    |    |     |     |     |   |

Groups overlapping.

# K-map Rules

7. Groups may wrap around the table.

The leftmost cell in a row may be grouped with the rightmost cell and the top cell in a column may be grouped with the bottom cell.



# K-map Rules

8. There should be as few groups as possible, as long as this does not contradict any of the previous rules.

|   |   | AB | 00 | 01  | 11  | 10  |     |
|---|---|----|----|-----|-----|-----|-----|
|   |   | C  | 0  | {1} | 1   | {1} | {1} |
|   |   | 1  | 0  | 0   | {1} | {1} |     |
| 0 | 0 |    |    |     |     |     |     |
| 1 | 1 |    |    |     |     |     |     |

RIGHT ✓

|   |   | AB | 00 | 01  | 11  | 10  |     |
|---|---|----|----|-----|-----|-----|-----|
|   |   | C  | 0  | {1} | {1} | {1} | {1} |
|   |   | 1  | 0  | 0   | {1} | {1} |     |
| 0 | 0 |    |    |     |     |     |     |
| 1 | 1 |    |    |     |     |     |     |

WRONG ×

# Example 1

For the given minterms, find the reduced logical expression using K-Map  $Z= \Sigma_{A,B,C}(1,3,6,7)$



# Example 2

For the given minterms, find the reduced logical expression using K-Map  $F(P,Q,R,S)=\sum(0,2,5,7,8,10,13,15)$



From **red** group we  
get product term—  
 $QS$

From **green** group we  
get product term—  
 $Q'S'$

$$F = QS + Q'S'$$

# K-map with Don't cares

- A “don’t care” condition is a combination of inputs for which the output may either ‘1’ or ‘0’.
- Hence “don’t care” conditions may either be included or excluded while grouping is made.
- It is usually denoted as ‘X’ in the K-Map table.

# Example 3

For the given minterms, find the reduced logical expression using K-Map

$$Z = \sum_{A,B,C}(7, 8, 9) + \sum_d(10, 11, 12, 13, 14, 15)$$



$$Z = AB'C' + A'BCD \quad (\text{without don't cares})$$

✓  $Z = A + BCD \quad (\text{with don't cares})$

# Quine-McCluskey Method (Tabulation Method)

- A systematic simplification procedure to reduce a minterm expansion to a minimum sum of products.
- Use  $XY + XY' = X$  to eliminate as many as literals as possible.
  - The resulting terms = prime implicants.
- Use a prime implicant chart to select a minimum set of prime implicants.

# Determination of Prime Implicants

✓ Eliminate literals

Two terms can be combined if they differ in exactly one variable.

$$AB'CD' + AB'CD = AB'C$$

$$\begin{array}{cccccc} \underline{1} & \underline{0} & \underline{1} & \underline{0} & + & \underline{1} & \underline{0} & \underline{1} & \underline{1} \\ X & Y & & X & Y' & & & X \end{array} = \underline{1} & \underline{0} & \underline{1}$$

$A'BC'D + A'BCD'$  (won't combine)

$0 \ 1 \ 0 \ 1 + 0 \ 1 \ 1 \ 0$  (check # of 1's)

We need to compare and combine whenever possible.

# Sorting to Reduce Comparisons

✓ Sort into groups according to the number of 1's

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

- No need for comparisons
  - (1) Terms in nonadjacent group
  - (2) Terms in the same group

|       |   |    |      |
|-------|---|----|------|
| Group | 0 | 0  | 0000 |
| Group | 1 | 1  | 0001 |
|       | 2 |    | 0010 |
|       | 8 |    | 1000 |
| Group | 2 | 5  | 0101 |
|       |   | 6  | 0110 |
|       |   | 9  | 1001 |
|       |   | 10 | 1010 |
| Group | 3 | 7  | 0111 |
|       |   | 14 | 1110 |

# Comparison of adjacent groups

Use  $X + X = X$  repeatedly between adjacent groups

Those combined are checked off.

Combine terms that have the same dashes and differ one in the number of 1's. (for column II and column III)

Determination of Prime Implicants

|         |           | Column I      | Column II         | Column III |
|---------|-----------|---------------|-------------------|------------|
| group 0 | 0 0000 ✓  | 0, 1 000- ✓   | 0, 1, 8, 9 -00-   |            |
| group 1 | 1 0001 ✓  | 0, 2 00-0 ✓   | 0, 2, 8, 10 -0-0  |            |
|         | 2 0010 ✓  | 0, 8 -000 ✓   | 0, 8, 1, 9 -00-   |            |
|         | 8 1000 ✓  | 1, 5 0-01     | 0, 8, 2, 10 -0-0  |            |
| group 2 | 5 0101 ✓  | 1, 9 -001 ✓   | 2, 6, 10, 14 --10 |            |
|         | 6 0110 ✓  | 2, 6 0-10 ✓   | 2, 10, 6, 14 --10 |            |
|         | 9 1001 ✓  | 2, 10 -010 ✓  |                   |            |
| group 3 | 10 1010 ✓ | 8, 9 100- ✓   |                   |            |
|         | 7 0111 ✓  | 8, 10 10-0 ✓  |                   |            |
|         | 14 1110 ✓ | 5, 7 01-1     |                   |            |
|         |           | 6, 7 011-     |                   |            |
|         |           | 6, 14 -110 ✓  |                   |            |
|         |           | 10, 14 1-10 ✓ |                   |            |

# Prime Implicants

- The terms that have not been checked off are called prime implicants.

$$\begin{aligned} f &= 0\text{-}01 + 01\text{-}1+011\text{-} + -00\text{-} \\ &\quad + -0\text{-}0 + --10 \\ &= \underline{a'c'd} + a'bd + \underline{a'bc} + b'c' + \\ &\quad \underline{b'd'} + cd' \end{aligned}$$

- Each term has a minimum number of literals, but minimum SOP for f:

$$\begin{aligned} f &= a'bd + b'c' + cd' \\ (a'bd, cd') &\Rightarrow a'bc \\ (a'bd, b'c') &\Rightarrow a'c'd \\ (b'c', cd') &\Rightarrow b'd' \end{aligned}$$

# Definition of Implicant

- Definition

- Given a function of F of n variables, a product term P is an implicant of F iff for every combination of values of the n variables for which P = 1, F is also equal to 1.

- Every minterm of F is an implicant of F.
- Any term formed by combining two or more minterms is an implicant.
- If F is written in SOP form, every product term is an implicant.

- Example:  $f(a,b,c) = a'b'c' + ab'c' + ab'c + abc = b'c' + ac$

- If  $a'b'c' = 1$ , then  $F = 1$ , if  $ac = 1$ , then  $F = 1$ .  $a'b'c'$  and  $ac$  are implicants.
- If  $bc = 1$ , (but  $a = 0$ ),  $F = 0$ , so  $bc$  is not an implicant of F.

# Definition of Prime Implicant

- Definition
  - A prime implicant of a function F is a product term implicant which is no longer an implicant if any literal is deleted from it.
  - Example:  $f(a,b,c) = a'b'c' + ab'c' + ab'c + abc = b'c' + ac$ 
    - Implicant  $a'b'c'$  is not a prime implicant. Why? If  $a'$  is deleted,  $b'c'$  is still an implicant of F.
    - $b'c'$  and  $ac$  are prime implicants.
  - Each prime implicant of a function has a minimum number of literals that no more literals can be eliminated from it or by combining it with other terms.

# Quine McClusky Procedure

- QM procedure:
  - Find all product term implicants of a function
  - Combine non-prime implicants.
    - Remaining terms are prime implicants.
  - A minimum SOP expression consists of a sum of some (not necessarily all) of the prime implicants of that function.
    - We need to select a minimum set of prime implicants.
  - If an SOP expression contains a term which is not a prime implicant, the SOP cannot be minimum

# Prime Implicant Chart

- Chart layout

- Top row lists minterms of the function
- All prime implicants are listed on the left side.
- Place x into the chart according to the minterms that form the corresponding prime implicant.

- Essential prime implicant

- If a minterm is covered only by one prime implicant, that prime implicant is called essential prime implicant. (9 & 14).
  - Essential prime implicant must be included in the minimum sum of the function.

|                |         | 0 | 1 | 2 | 5 | 6 | 7 | 8 | 9   | 10 | 14  |
|----------------|---------|---|---|---|---|---|---|---|-----|----|-----|
| (0, 1, 8, 9)   | $b'c'$  | X | X |   |   |   |   | X | (X) |    |     |
| (0, 2, 8, 10)  | $b'd'$  | X | X |   |   |   |   | X | X   |    |     |
| (2, 6, 10, 14) | $cd'$   |   |   | X | X |   |   |   |     | X  | (X) |
| (1, 5)         | $a'c'd$ |   | X | X |   |   |   |   |     |    |     |
| (5, 7)         | $a'bd$  |   |   |   | X | X |   |   |     |    |     |
| (6, 7)         | $a'bc$  |   |   |   |   |   | X | X |     |    |     |

| First List |   |   |   |     |
|------------|---|---|---|-----|
|            | A | B | C | D   |
| 0          | 0 | 0 | 0 | 0 ✓ |
| 1          | 0 | 0 | 0 | 1 ✓ |
| 2          | 0 | 0 | 1 | 0 ✓ |
| 8          | 1 | 0 | 0 | 0 ✓ |
| 3          | 0 | 0 | 1 | 1 ✓ |
| 5          | 0 | 1 | 0 | 1 ✓ |
| 10         | 1 | 0 | 1 | 0 ✓ |
| 12         | 1 | 1 | 0 | 0 ✓ |
| 7          | 0 | 1 | 1 | 1 ✓ |
| 13         | 1 | 1 | 1 | 1 ✓ |
| 15         | 1 | 1 | 1 | 1 ✓ |

| Second List |   |   |   |                       |
|-------------|---|---|---|-----------------------|
|             | A | B | C | D                     |
| 0,1         | 0 | 0 | 0 | ✓                     |
| 0,2         | 0 | 0 | - | 0 ✓                   |
| 0,8         | - | 0 | 0 | 0 ✓                   |
| 1,3         | 0 | 0 | - | 1 ✓                   |
| 1,5         | 0 | - | 0 | 1 ✓                   |
| 2,3         | 0 | 0 | 1 | -✓                    |
| 2,10        | - | 0 | 1 | 0 ✓                   |
| 8,10        | 1 | 0 | - | 0 ✓                   |
| 8,12        | 1 | - | 0 | 0 A $\bar{C} \bar{D}$ |
| 3,7         | 0 | - | 1 | 1 ✓                   |
| 5,7         | 0 | 1 | - | 1 ✓                   |
| 5,13        | - | 1 | 0 | 1 ✓                   |
| 12,13       | 1 | 1 | 0 | - A B C               |
| 7,15        | - | 1 | 1 | 1 ✓                   |
| 13,15       | 1 | 1 | - | 1 ✓                   |

| Third List |   |   |   |       |
|------------|---|---|---|-------|
|            | A | B | C | D     |
| 0,1,2,3    | 0 | 0 | - | - A B |
| 0,2,1,3    | 0 | 0 | - | -     |
| 0,2,8,10   | - | 0 | - | 0 B D |
| 0,8,2,10   | - | 0 | - | 0     |
| 1,3,5,7    | 0 | - | - | 1 A D |
| 1,5,3,7    | 0 | - | - | 1     |
| 5,7,13,15  | - | 1 | - | 1 B D |
| 5,13,7,15  | - | 1 | - | 1     |

The prime implicants are:  $\bar{A}\bar{B} + \bar{B}\bar{D} + \bar{A}D + BD + A\bar{C}\bar{D} + AB\bar{C}$



Thus, one minimal solution is:  $Z = \bar{B} \bar{D} + BD + \bar{A} \bar{B} + A \bar{C} \bar{D}$

$$F(A,B,C,D) = \sum m(2,6,8,9,10,1,14,15)$$

| Group Name | Min terms | W | X | Y | Z | Group Name | Min terms | W | X | Y | Z |
|------------|-----------|---|---|---|---|------------|-----------|---|---|---|---|
| GA1        | 2         | 0 | 0 | 1 | 0 | GB1        | 2,6       | 0 | - | 1 | 0 |
|            | 8         | 1 | 0 | 0 | 0 |            | 2,10      | - | 0 | 1 | 0 |
| GA2        | 6         | 0 | 1 | 1 | 0 |            | 8,9       | 1 | 0 | 0 | - |
|            | 9         | 1 | 0 | 0 | 1 |            | 8,10      | 1 | 0 | - | 0 |
|            | 10        | 1 | 0 | 1 | 0 | GB2        | 6,14      | - | 1 | 1 | 0 |
| GA3        | 11        | 1 | 0 | 1 | 1 |            | 9,11      | 1 | 0 | - | 1 |
|            | 14        | 1 | 1 | 1 | 0 |            | 10,11     | 1 | 0 | 1 | - |
| GA4        | 15        | 1 | 1 | 1 | 1 |            | 10,14     | 1 | - | 1 | 0 |
|            |           |   |   |   |   | GB3        | 11,15     | 1 | - | 1 | 1 |
|            |           |   |   |   |   |            | 14,15     | 1 | 1 | 1 | - |

| Group Name | Min terms   | W | X | Y | Z |
|------------|-------------|---|---|---|---|
| GB1        | 2,6,10,14   | - | - | 1 | 0 |
|            | 2,10,6,14   | - | - | 1 | 0 |
|            | 8,9,10,11   | 1 | 0 | - | - |
|            | 8,10,9,11   | 1 | 0 | - | - |
| GB2        | 10,11,14,15 | 1 | - | 1 | - |
|            | 10,14,11,15 | 1 | - | 1 | - |

| Group Name | Min terms   | W | X | Y | Z |
|------------|-------------|---|---|---|---|
| GC1        | 2,6,10,14   | - | - | 1 | 0 |
|            | 8,9,10,11   | 1 | 0 | - | - |
| GC2        | 10,11,14,15 | 1 | - | 1 | - |

|                              | 2 | 6 | 8 | 9 | 10 | 11 | 14 | 15 |
|------------------------------|---|---|---|---|----|----|----|----|
| Min terms / Prime Implicants |   |   |   |   |    |    |    |    |
| $YZ'$                        | 1 | 1 |   |   | 1  |    | 1  |    |
| $WX'$                        |   |   | 1 | 1 | 1  | 1  |    |    |
| $WY$                         |   |   |   |   | 1  | 1  | 1  | 1  |

$$f(W, X, Y, Z) = YZ' + WX' + WY.$$

$$F(A,B,C,D) = \sum m(0,1,3,7,8,9,11,15)$$

| Group | Minterms | Variables<br>A B C D | Remark |
|-------|----------|----------------------|--------|
| 0     | 0        | 0000                 | ✓      |
| 1     | 1        | 0001                 | ✓      |
|       | 8        | 1000                 | ✓      |
| 2     | 3        | 0011                 | ✓      |
|       | 9        | 1001                 | ✓      |
| 3     | 7        | 0111                 | ✓      |
|       | 11       | 1011                 | ✓      |
| 4     | 15       | 1111                 | ✓      |

| Group | Minterms | Variables | Remark |
|-------|----------|-----------|--------|
|       |          | A B C D   |        |
| 0     | 0,1      | 000-      | ✓      |
|       | 0,8      | -000      | ✓      |
| 1     | 1,3      | 00-1      | ✓      |
|       | 1,9      | -001      | ✓      |
|       | 8,9      | 100-      | ✓      |
| 2     | 3,7      | 0-11      | ✓      |
|       | 3,11     | -011      | ✓      |
|       | 9,11     | 10-1      | ✓      |
| 3     | 7,15     | -111      | ✓      |
|       | 11,15    | 1-11      | ✓      |

| Group | Minterms      | Variables<br>ABCD | Remark |
|-------|---------------|-------------------|--------|
| 0     | (0,1),(8,9)   | -00-              | ✓      |
|       | (0,8),(1,9)   | -00-              | ✓      |
| 1     | (1,3),(9,11)  | -0-1              | ✓      |
|       | (1,9),(3,11)  | -0-1              | ✓      |
| 2     | (3,7),(11,15) | --11              | ✓      |
|       | (3,11),(7,15) | --11              | ✓      |

$(B'C' + CD)$ .

©myclassbook.wordpress.com

| PI terms | Group of Minterms | Minterms |   |     |     |   |     |    |
|----------|-------------------|----------|---|-----|-----|---|-----|----|
|          |                   | 0        | 1 | 3   | 7   | 8 | 9   | 11 |
| $B'C'$   | 0,1,8,9           | (X)      | X |     | (X) | X |     |    |
| $B'D$    | 1,3,9,11          |          | X | X   |     | X | X   |    |
| $CD$     | 3,7,11,15         |          | X | (X) |     | X | (X) |    |

©myclassbook.wordpress.com

$$F(w,x,y,z) = \sum m(0,4,5,7,8,11,12,15)$$



$$\bullet f(a,b,c,d) = \sum m(0,1,2,3,9,10) + \sum d(4,5,6)$$

$$f(a,b,c,d) = \sum m(0,1,2,3,9,10) + \sum d(4,5,6)$$

| a b c d | a b' c d | a b c' d | a b c d' |
|---------|----------|----------|----------|
| 0 0 0 0 | 0 0 0 0  | 0 0 0 -  | 0,1,2,3  |
| 0 0 0 1 | 0 0 0 1  | 0 0 - 0  | 0,2,4,5  |
| 0 0 1 0 | 0 0 1 0  | 0 - 0 0  | 0,2,1,3  |
| 0 0 1 1 | 0 1 0 0  | 0 0 - 1  | 0,2,4,6  |
| 0 1 0 0 | 0 0 1 1  | 0 - 0 1  | 0,4,1,5  |
| 0 1 0 1 | 0 1 0 1  | - 0 0 1  | 0,4,2,6  |
| 0 1 1 0 | 0 1 1 0  | 0 0 1 -  | 0,4,2,6  |
| 1 0 0 1 | 1 0 0 1  | 0 - 1 0  | 2,6      |
| 1 1 0 0 | 1 0 1 0  | 0 1 0 -  | 4,5      |
|         |          | 0 1 0 0  | 4,6      |
|         |          | - 1 0 0  | 4,10     |

| PI                  | Minterms   | 0 | 1 | 2 | 3 | 9 | 10 |
|---------------------|------------|---|---|---|---|---|----|
| $\bar{b}\bar{c}d$ ✓ | 1, 9       |   | ✗ |   |   | ✗ | ✗  |
| $b\bar{c}d$ ✓       | 4, 10      |   |   |   |   |   | ✗  |
| $\bar{a}\bar{b}$ ✓  | 0, 1, 2, 3 | ✗ | ✗ | ✗ | ✗ | ✗ |    |
| $\bar{a}\bar{c}$    | 0, 1, 4, 5 | ✗ | ✗ |   |   |   |    |
| $\bar{a}\bar{d}$    | 0, 2, 4, 6 | ✗ |   | ✗ |   |   |    |

$$f(a, b, c, d) = \bar{b}\bar{c}d + b\bar{c}d + \bar{a}\bar{b}$$

$$F(A, B, C, D) = \sum_m (2, 3, 7, 9, 11, 13) + \sum_d (1, 10, 15)$$

$$F(A, B, C, D) = \sum_m (2, 3, 7, 9, 11, 13) + \sum_d (1, 10, 15)$$

|                                                                    |                                                                                 |                                                                                                                                                              |                                                                                                                                               |                                                                                                             |                                                                                                                                                              |                                                                                                                                               |                                                                                                             |
|--------------------------------------------------------------------|---------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|
| $\begin{array}{r} 1 \\ 2 \\ 3 \\ 9 \\ 10 \\ \hline 10 \end{array}$ | $\begin{array}{r} 0001 \\ 0010 \\ 0011 \\ 001 \\ 010 \\ \hline 010 \end{array}$ | $\begin{array}{r} (1,3) \\ (1,9) \\ (2,3) \\ (2,10) \\ (3,7) \\ (3,11) \\ (9,11) \\ (9,13) \\ (10,11) \\ (7,15) \\ (11,15) \\ (13,15) \\ \hline \end{array}$ | $\begin{array}{r} 00-1 \\ -001 \\ 001- \\ -010 \\ 0-11 \\ -011 \\ 10-1 \\ 1-01 \\ 101- \\ -111 \\ 1-11 \\ 11-1 \\ 11-1 \\ \hline \end{array}$ | $\begin{array}{r} \checkmark \\ \checkmark \\ \checkmark \\ \checkmark \\ \checkmark \\ \hline \end{array}$ | $\begin{array}{r} (1,3) \\ (1,9) \\ (2,3) \\ (2,10) \\ (3,7) \\ (3,11) \\ (9,11) \\ (9,13) \\ (10,11) \\ (7,15) \\ (11,15) \\ (13,15) \\ \hline \end{array}$ | $\begin{array}{r} 00-1 \\ -001 \\ 001- \\ -010 \\ 0-11 \\ -011 \\ 10-1 \\ 1-01 \\ 101- \\ -111 \\ 1-11 \\ 11-1 \\ 11-1 \\ \hline \end{array}$ | $\begin{array}{r} \checkmark \\ \checkmark \\ \checkmark \\ \checkmark \\ \checkmark \\ \hline \end{array}$ |
|--------------------------------------------------------------------|---------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|

$(1,3,9,11) - 0 - 1$   
 $(2,3,10,11) - 01 -$   
 $(3,7,11,15) - - 11$   
 $(9,11,13,15) 1 - - 1$

A B C D

$$(1, 3, 9, 11) \quad -0-1$$

$$(2, 3, 10, 11) \quad -01-$$

$$\underline{(3, 2, 11, 15)} \quad - - 11$$

$$(9, 11, 13, 15) \quad 1 - - 1$$



$$F(A, B, C, D) : \bar{B}C + CD + AD$$

# Combinational Circuits

- A combinational logic circuit is one in which the present state of the combination of the logic inputs decides the output .
- The term combination logic means combining of two or more logic gates to form a required function where the output at a given time depends only on the input.

- The required output data is obtained from this process by transforming the binary information given at the input.



# Classification of Combinational Logic



# MULTIPLEXER

# Multiplexer

- It is a combinational logic circuit.
- It is a device that selects between several analog or digital input signals and forwards it to a single output line.
- Input –  $2^n$
- Output – 1
- Multiplexer –  $2^n : 1$
- The selection of particular input line is controlled by a set of selection lines.
- It is also called Data Selector.
- There is a Enable input, which is required to connect two or three multiplexer in parallel.



# Design of 4:1 Mux:

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

- Input: 4 ( $I_0, I_1, I_2$  &  $I_3$ )
- Output: 1 ( $Y$ )
- Selection Line: 2 ( $S_0$  &  $S_1$ )
- Output is,

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

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



# Design of 8:1 Mux:

| $S_2$ | $S_1$ | $S_0$ | $Y$   |
|-------|-------|-------|-------|
| 0     | 0     | 0     | $I_0$ |
| 0     | 0     | 1     | $I_1$ |
| 0     | 1     | 0     | $I_2$ |
| 0     | 1     | 1     | $I_3$ |
| 1     | 0     | 0     | $I_4$ |
| 1     | 0     | 1     | $I_5$ |
| 1     | 1     | 0     | $I_6$ |
| 1     | 1     | 1     | $I_7$ |

- Input: 8 ( $I_0, I_1, I_2, I_3, I_4, I_5, I_6, I_7$  &  $I_8$ )
- Output: 1 ( $Y$ )
- Selection Line: 3 ( $S_0, S_1$  &  $S_2$ )
- Output is,

$$Y = I_0 \bar{S}_2 \bar{S}_1 \bar{S}_0 + I_1 \bar{S}_2 \bar{S}_1 S_0 + I_2 \bar{S}_2 S_1 \bar{S}_0 + I_3 \bar{S}_2 S_1 S_0 + I_4 S_2 \bar{S}_1 \bar{S}_0 + I_5 S_2 \bar{S}_1 S_0 + I_6 S_2 S_1 \bar{S}_0 + I_7 S_2 S_1 S_0$$



# Design of 16:1 MUX using 8:1 MUX

| $S_3$ | $S_2$ | $S_1$ | $S_0$ | $Y$ |
|-------|-------|-------|-------|-----|
| 0     | 0     | 0     | 0     |     |
| 0     | 0     | 0     | 1     |     |
| 0     | 0     | 1     | 0     |     |
| 0     | 0     | 1     | 1     |     |
| 0     | 1     | 0     | 0     |     |
| 0     | 1     | 0     | 1     |     |
| 0     | 1     | 1     | 0     |     |
| 0     | 1     | 1     | 1     |     |
| 0     | 0     | 0     | 0     |     |
| 0     | 0     | 0     | 1     |     |
| 0     | 0     | 1     | 0     |     |
| 0     | 0     | 1     | 1     |     |
| 0     | 1     | 0     | 0     |     |
| 0     | 1     | 0     | 1     |     |
| 0     | 1     | 1     | 0     |     |
| 0     | 1     | 1     | 1     |     |



Implement the following function using 8:1 MUX

$$f(A, B, C, D) = \sum_m(0, 2, 4, 6, 8, 10, 12, 14)$$

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



Implement the following function using 8:1 MUX

$$f(A, B, C, D) = \sum_m(0, 2, 6, 10, 11, 12, 13) + d(3, 8, 14)$$

|   |   |    |    |    |    |    |    |  |
|---|---|----|----|----|----|----|----|--|
|   |   |    |    |    |    |    |    |  |
| 0 | 1 | 2  | 3  | 4  | 5  | 6  | 7  |  |
| 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |  |
| 1 | 0 | 1  | 1  | A  | A  | 1  | 0  |  |



Implement the following function using 8:1 MUX

$$f(A, B, C, D) = \prod_M(0, 3, 5, 6, 8, 9, 10, 12, 14)$$

PoS function should be converted into SoP function,

$$f(A, B, C, D) = \sum_m(1, 2, 4, 7, 11, 13, 15)$$

|  |   |   |    |    |    |    |    |    |
|--|---|---|----|----|----|----|----|----|
|  |   |   |    |    |    |    |    |    |
|  | 0 | 1 | 2  | 3  | 4  | 5  | 6  | 7  |
|  | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |
|  | 0 |   |    | A  |    | A  | 0  | 1  |



Implement the following function using 8:1 MUX  
and 4:1 MUX

$$f(A, B, C, D) = \sum_m(0, 1, 3, 4, 8, 9, 15)$$

## Using 8:1 Mux

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

  

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



Implement the following function using 8:1 MUX  
and 4:1 MUX

$$f(A, B, C, D) = \sum_m(0, 1, 3, 4, 8, 9, 15)$$

## Using 4:1 Mux

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

  

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



# **Application of Multiplexer**

- It is used as a data selector to select one out of many data inputs.
- It is used to implement combinational logic circuit.
- It is used in time multiplexing systems.
- It is used in ADC and DAC converter.
- It is used in data acquisition systems.

**THANK YOU...**

**ANY QUERIES???**

# **DEMULTIPLEXER**

PREPARED BY  
Mr.P.KANAKARAJ  
AP/EEE  
SRMIST-KTR

# Demultiplexer

- It is a combinational logic circuit.
- It is a circuit that receives information on a single line and transmits this information on one of  $2^n$  possible output lines.
- The selection of specific output line is controlled by the values of  $n$  selection lines.
- Input – 1
- Output –  $2^n$
- Selection lines –  $n$
- De-Multiplexer –  $1 : 2^n$
- There is a Enable input, which is required to connect two or three multiplexer in parallel.



# Design of 1:4 DEMUX:

## Truth Table

| Selection Lines |   | Outputs |     |     |     |
|-----------------|---|---------|-----|-----|-----|
| 0               | 0 | $I$     | 0   | 0   | 0   |
| 0               | 1 | 0       | $I$ | 0   | 0   |
| 1               | 0 | 0       | 0   | $I$ | 0   |
| 1               | 1 | 0       | 0   | 0   | $I$ |

- Input: 1 ( $I$ )
- Output: 4 ( $Y_0, Y_1, Y_2$  &  $Y_3$ )
- Selection Line: 2 ( $S_0$  &  $S_1$ )
- Outputs are,

$$Y_0 = I\bar{S}_1\bar{S}_0 = I$$

$$Y_1 = I\bar{S}_1S_0 = I$$

$$Y_2 = IS_1\bar{S}_0 = I$$

$$Y_3 = IS_1S_0 = I$$

# Logic Diagram of 1:4 DEMUX:

Outputs are,

$$Y_0 = I\bar{S}_1\bar{S}_0 = I$$

$$Y_1 = I\bar{S}_1S_0 = I$$

$$Y_2 = IS_1\bar{S}_0 = I$$

$$Y_3 = IS_1S_0 = I$$



# 1:4 DEMUX



# Design of 1:8 DEMUX

**Truth Table**

| Selection Lines |   |   | Outputs |   |   |   |   |   |   |   |
|-----------------|---|---|---------|---|---|---|---|---|---|---|
| 0               | 0 | 0 | I       | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| 0               | 0 | 1 | 0       | I | 0 | 0 | 0 | 0 | 0 | 0 |
| 0               | 1 | 0 | 0       | 0 | I | 0 | 0 | 0 | 0 | 0 |
| 0               | 1 | 1 | 0       | 0 | 0 | I | 0 | 0 | 0 | 0 |
| 1               | 0 | 0 | 0       | 0 | 0 | 0 | I | 0 | 0 | 0 |
| 1               | 0 | 1 | 0       | 0 | 0 | 0 | 0 | I | 0 | 0 |
| 1               | 1 | 0 | 0       | 0 | 0 | 0 | 0 | 0 | I | 0 |
| 1               | 1 | 1 | 0       | 0 | 0 | 0 | 0 | 0 | 0 | I |

- Input: 1 ( $I$ )
- Output: 8 ( $Y_0, Y_1, Y_2, Y_3, Y_4, Y_5, Y_6, Y_7$ )
- Selection Line: 3 ( $S_0, S_1$  &  $S_2$ )
- Outputs are,

$$Y_0 = I\bar{S}_2\bar{S}_1\bar{S}_0$$

$$Y_4 = IS_2\bar{S}_1\bar{S}_0$$

$$Y_1 = I\bar{S}_2\bar{S}_1S_0$$

$$Y_5 = IS_2\bar{S}_1S_0$$

$$Y_2 = I\bar{S}_2S_1\bar{S}_0$$

$$Y_6 = IS_2S_1\bar{S}_0$$

$$Y_3 = I\bar{S}_2S_1S_0$$

$$Y_7 = IS_2S_1S_0$$

# Logic Diagram of 1:8 DEMUX:

Outputs are,

$$Y_0 = I\bar{S}_2\bar{S}_1\bar{S}_0$$

$$Y_4 = I\bar{S}_2\bar{S}_1\bar{S}_0$$

$$Y_1 = I\bar{S}_2\bar{S}_1S_0$$

$$Y_5 = I\bar{S}_2\bar{S}_1S_0$$

$$Y_2 = I\bar{S}_2S_1\bar{S}_0$$

$$Y_6 = I\bar{S}_2S_1\bar{S}_0$$

$$Y_3 = I\bar{S}_2S_1S_0$$

$$Y_7 = I\bar{S}_2S_1S_0$$



# 1:8 DEMUX



# Design of 1:8 DEMUX Using 1:4 DEMUX



# Implementation of Full Adder using Demultiplexer

Truth Table

| Decimal | Inputs |   |   | Outputs |       |
|---------|--------|---|---|---------|-------|
|         | A      | B | C | Sum     | Carry |
| 0       | 0      | 0 | 0 | 0       | 0     |
| 1       | 0      | 0 | 1 | 1       | 0     |
| 2       | 0      | 1 | 0 | 1       | 0     |
| 3       | 0      | 1 | 1 | 0       | 1     |
| 4       | 1      | 0 | 0 | 1       | 0     |
| 5       | 1      | 0 | 1 | 0       | 1     |
| 6       | 1      | 1 | 0 | 0       | 1     |
| 7       | 1      | 1 | 1 | 1       | 1     |

Output Expressions are,

$$\text{Sum} = \sum_m(1,2,4,7)$$

$$\text{Carry} = \sum_m(3,5,6,7)$$



# Implementation of Full Subtractor using Demultiplexer

Truth Table

| Decimal | Inputs |   |   | Outputs    |        |
|---------|--------|---|---|------------|--------|
|         | A      | B | C | Difference | Borrow |
| 0       | 0      | 0 | 0 | 0          | 0      |
| 1       | 0      | 0 | 1 | 1          | 1      |
| 2       | 0      | 1 | 0 | 1          | 1      |
| 3       | 0      | 1 | 1 | 0          | 1      |
| 4       | 1      | 0 | 0 | 1          | 0      |
| 5       | 1      | 0 | 1 | 0          | 0      |
| 6       | 1      | 1 | 0 | 0          | 0      |
| 7       | 1      | 1 | 1 | 1          | 1      |

Output Expressions are,

$$\text{Difference} = \sum_m(1,2,4,7)$$

$$\text{Borrow} = \sum_m(1,2,3,7)$$



# **Applications of Demultiplexer:**

- Clock demultiplexer
- Security monitoring system
- Synchronous data transmission system

**THANK YOU...**

**ANY QUERIES???**

# **DECODER**

PREPARED BY  
Mr.P.KANAKARAJ  
AP/EEE  
SRMIST-KTR

# Decoder:

- It is a combinational logic circuit.
- It has an  $n$ -bit binary input code and a one activated output out of  $2^n$  output code is called binary decoder.
- A binary decoder is used when it is necessary to activate exactly one of  $2^n$  outputs based on an  $n$ -bit input value.
- It is similar to demultiplexer, with only one exception that it has no data input.
- Input –  $n$
- Output –  $2^n$
- Decoder –  $n : 2^n$
- There is a Enable input, which is required to connect two or three decoder in parallel.



# **Decoder Vs Demultiplexer**

- **Decoder**

- Decoder is a many inputs to many outputs device.
- There are no selection lines.

- **Demultiplexer**

- Demultiplexer is a one input to many outputs device.
- The selection of specific output line is controlled by the value of selection lines.

# Design of 2:4 DECODER

## Truth Table

| Input |     |     | Output |   |   |   |
|-------|-----|-----|--------|---|---|---|
| 1     | $X$ | $X$ | 0      | 0 | 0 | 0 |
| 0     | 0   | 0   | 1      | 0 | 0 | 0 |
| 0     | 0   | 1   | 0      | 1 | 0 | 0 |
| 0     | 1   | 0   | 0      | 0 | 1 | 0 |
| 0     | 1   | 1   | 0      | 0 | 0 | 1 |

- Input: 1 ( $I$ )
- Output: 4 ( $Y_0, Y_1, Y_2$  &  $Y_3$ )
- Selection Line: 2 ( $S_0$  &  $S_1$ )
- Outputs are,

$$Y_0 = \bar{E} \bar{S}_1 \bar{S}_0$$

$$Y_1 = \bar{E} \bar{S}_1 S_0$$

$$Y_2 = \bar{E} S_1 \bar{S}_0$$

$$Y_3 = \bar{E} S_1 S_0$$

# Logic Diagram of 2:4 Decoder

Outputs are,

$$Y_0 = \bar{E}\bar{S}_1\bar{S}_0$$

$$Y_1 = \bar{E}\bar{S}_1S_0$$

$$Y_2 = \bar{E}S_1\bar{S}_0$$

$$Y_3 = \bar{E}S_1S_0$$



# 2 to 4 Line Decoder



# Three to Eight line Decoder

## Truth Table

| Input |   |   |   | Output |   |   |   |   |   |   |   |
|-------|---|---|---|--------|---|---|---|---|---|---|---|
| 0     | 0 | 0 | I | 0      | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| 0     | 0 | 1 | 0 | I      | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| 0     | 1 | 0 | 0 | 0      | I | 0 | 0 | 0 | 0 | 0 | 0 |
| 0     | 1 | 1 | 0 | 0      | 0 | I | 0 | 0 | 0 | 0 | 0 |
| 1     | 0 | 0 | 0 | 0      | 0 | 0 | I | 0 | 0 | 0 | 0 |
| 1     | 0 | 1 | 0 | 0      | 0 | 0 | 0 | I | 0 | 0 | 0 |
| 1     | 1 | 0 | 0 | 0      | 0 | 0 | 0 | 0 | I | 0 | 0 |
| 1     | 1 | 1 | 0 | 0      | 0 | 0 | 0 | 0 | 0 | I | 0 |

- Input: 3 ( $S_0'$ ,  $S_1'$ ,  $S_2'$ )
- Output: 8 ( $Y_0'$ ,  $Y_1'$ ,  $Y_2'$ ,  $Y_3'$ ,  $Y_4'$ ,  $Y_5'$ ,  $Y_6'$ ,  $Y_7'$ )
- Outputs are,

$$Y_0 = \overline{S_2} \overline{S_1} \overline{S_0}$$

$$Y_4 = S_2 \overline{S_1} \overline{S_0}$$

$$Y_1 = \overline{S_2} \overline{S_1} S_0$$

$$Y_5 = S_2 \overline{S_1} S_0$$

$$Y_2 = \overline{S_2} S_1 \overline{S_0}$$

$$Y_6 = S_2 S_1 \overline{S_0}$$

$$Y_3 = \overline{S_2} S_1 S_0$$

$$Y_7 = S_2 S_1 S_0$$

# Logic Diagram of 3 to 8 line Decoder

Outputs are,

$$Y_0 = \overline{S_2} \overline{S_1} \overline{S_0}$$

$$Y_4 = S_2 \overline{S_1} \overline{S_0}$$

$$Y_1 = \overline{S_2} \overline{S_1} S_0$$

$$Y_5 = S_2 \overline{S_1} S_0$$

$$Y_2 = \overline{S_2} S_1 \overline{S_0}$$

$$Y_6 = S_2 S_1 \overline{S_0}$$

$$Y_3 = \overline{S_2} S_1 S_0$$

$$Y_7 = S_2 S_1 S_0$$



# 3 to 8 Line Decoder



# Design of 3 to 8 line Decoder Using 2 to 4 line Decoder



# Implementation of Full Adder using Decoder

Truth Table

| Decimal | Inputs |   |   | Outputs |       |
|---------|--------|---|---|---------|-------|
|         | A      | B | C | Sum     | Carry |
| 0       | 0      | 0 | 0 | 0       | 0     |
| 1       | 0      | 0 | 1 | 1       | 0     |
| 2       | 0      | 1 | 0 | 1       | 0     |
| 3       | 0      | 1 | 1 | 0       | 1     |
| 4       | 1      | 0 | 0 | 1       | 0     |
| 5       | 1      | 0 | 1 | 0       | 1     |
| 6       | 1      | 1 | 0 | 0       | 1     |
| 7       | 1      | 1 | 1 | 1       | 1     |

Output Expressions are,

$$\text{Sum} = \sum_m(1,2,4,7)$$

$$\text{Carry} = \sum_m(3,5,6,7)$$



# Implementation of Full Subtractor using Demultiplexer

Truth Table

| Decimal | Inputs |   |   | Outputs    |        |
|---------|--------|---|---|------------|--------|
|         | A      | B | C | Difference | Borrow |
| 0       | 0      | 0 | 0 | 0          | 0      |
| 1       | 0      | 0 | 1 | 1          | 1      |
| 2       | 0      | 1 | 0 | 1          | 1      |
| 3       | 0      | 1 | 1 | 0          | 1      |
| 4       | 1      | 0 | 0 | 1          | 0      |
| 5       | 1      | 0 | 1 | 0          | 0      |
| 6       | 1      | 1 | 0 | 0          | 0      |
| 7       | 1      | 1 | 1 | 1          | 1      |

Output Expressions are,

$$\text{Difference} = \sum_m(1,2,4,7)$$

$$\text{Borrow} = \sum_m(1,2,3,7)$$



# Implementation of given Boolean function using Decoder

$$f_1 = \sum_m(0,1,4,5,7)$$

$$f_2 = \sum_m(0,1,5,6)$$

Given Expressions are,

$$f_1 = \sum_m(0,1,4,5,7)$$

$$f_2 = \sum_m(0,1,5,6)$$



# Implementation of given Boolean function using Decoder

$$f_1 = \sum_m(0,1,3,5,6)$$

$$f_2 = \sum_m(0,2,4,7)$$

Given Expressions are,

$$f_1 = \sum_m(0,1,3,5,6)$$

$$f_2 = \sum_m(0,2,4,7)$$



# Applications of Decoder

- It can be used to implement combinational circuit
- It can be used to convert BCD into 7-segment code
- It is used in memories to select particular register

**THANK YOU...**

**ANY QUERIES???**

# **ENCODER**

**Prepared By**

**Mr.P.KANAKARAJ**

**AP/EEE**

**SRMIST-KTR**

# Encoder:

- It is a combinational logic circuit.
- An encoder has  $2^n$  input lines and n output lines.
- The n output lines generate the binary code for the possible  $2^n$  input lines.
- Input –  $2^n$
- Output – n
- Encoder –  $2^n : n$



# Four to Two Line Binary Encoder

## Truth Table

| Decimal Value | Input |   |   |   | Output |   |
|---------------|-------|---|---|---|--------|---|
| 0             | 0     | 0 | 0 | 1 | 0      | 0 |
| 1             | 0     | 0 | 1 | 0 | 0      | 1 |
| 2             | 0     | 1 | 0 | 0 | 1      | 0 |
| 3             | 1     | 0 | 0 | 0 | 1      | 1 |

- Input – 4
- Output – 2
- Outputs are,

$$B_0 = I_2 + I_3$$

$$B_1 = I_1 + I_3$$



# Eight to Three Line Binary Encoder (Octal to Binary Encoder)

**Truth Table**

| Decimal Value | Input |   |   |   |   |   |   |   | Output |   |   |
|---------------|-------|---|---|---|---|---|---|---|--------|---|---|
| 0             | 0     | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0      | 0 | 0 |
| 1             | 0     | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0      | 0 | 1 |
| 2             | 0     | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0      | 1 | 0 |
| 3             | 0     | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0      | 1 | 1 |
| 4             | 0     | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 1      | 0 | 0 |
| 5             | 0     | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 1      | 0 | 1 |
| 6             | 0     | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1      | 1 | 0 |
| 7             | 1     | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1      | 1 | 1 |

- Input – 8                                   $B_0 = I_1 + I_3 + I_5 + I_7$
- Output – 3                                   $B_1 = I_2 + I_3 + I_6 + I_7$
- Outputs are,                                 $B_2 = I_4 + I_5 + I_6 + I_7$



# Priority Encoder:

- It is an encoder circuit that includes the priority function.
- In that priority encoder, if two or more inputs are equal to 1 at the same time, the input having the highest priority will take precedence.

**Truth Table**

| Input |   |   |   | Output |   |
|-------|---|---|---|--------|---|
| 0     | 0 | 0 | 0 |        | 0 |
| 1     | 0 | 0 | 0 | 0      | 1 |
|       | 1 | 0 | 0 | 0      | 1 |
|       | 1 | 0 | 1 | 0      | 1 |
|       | 1 | 1 | 1 | 1      | 1 |

**$B_1$ : K-Map Simplification**



**$B_0$ :**



$$B_1 = D_2 + D_3$$

**V:**

$$B_0 = D_3 + D_1 \overline{D_2}$$



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

# Logic Diagram for Priority Encoder

- Expressions are,

$$B_1 = D_2 + D_3$$

$$B_0 = D_3 + D_1 \overline{D}_2$$

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



**THANK YOU...**

**ANY QUERIES???**

# Unit - 3

## Combinational Logic Circuits

# Contents

- ❖ Binary adder
- ❖ Binary adder as subtractor
- ❖ Carry look ahead adder
- ❖ Decimal adder
- ❖ Magnitude Comparator

## Binary Adder

# Binary adder



**Half Adder:** is a combinational circuit that performs the addition of two bits, this circuit needs two binary inputs and two binary outputs.

| Inputs | Outputs |   |   |
|--------|---------|---|---|
| X      | Y       | C | S |
| 0      | 0       | 0 | 0 |
| 0      | 1       | 0 | 1 |
| 1      | 0       | 0 | 1 |
| 1      | 1       | 1 | 0 |

**Truth table**

The simplified Boolean function from the truth table:

$$\begin{cases} S = \bar{X}Y + X\bar{Y} \\ C = XY \end{cases} \quad 1 \} \text{ (Using sum of product form)}$$

Where **S** is the sum and **C** is the carry.

$$\begin{cases} S = X \oplus Y \\ C = XY \end{cases} \quad 2 \} \text{ (Using XOR and AND Gates)}$$

# Binary Adder

## Half adder

### K-map for half adder

|        | Y<br>0 | Y<br>1 |
|--------|--------|--------|
| X<br>0 | 0      | 1      |
| X<br>1 | 2      | 3      |

K-map for Carry

|        | Y<br>0 | Y<br>1 |
|--------|--------|--------|
| X<br>0 | 0      | 1      |
| X<br>1 | 1      | 2      |

K-map for Sum



$$\left. \begin{cases} S = X \oplus Y \\ C = XY \end{cases} \right\} \text{(Using XOR and AND Gates)}$$

# Binary Adder

- Full Adder
  - Adds 1-bit plus 1-bit plus 1-bit
  - Produces Sum and Carry



| x | y | z | C | S |
|---|---|---|---|---|
| 0 | 0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 0 | 1 |
| 0 | 1 | 0 | 0 | 1 |
| 0 | 1 | 1 | 1 | 0 |
| 1 | 0 | 0 | 0 | 1 |
| 1 | 0 | 1 | 1 | 0 |
| 1 | 1 | 0 | 1 | 0 |
| 1 | 1 | 1 | 1 | 1 |

$$\begin{array}{cccc|c}
 & & & & y \\
 & 0 & 1 & 0 & 1 \\
 x & 1 & 0 & 1 & 0 \\
 \hline
 & & & & z \\
 \end{array}$$
  

$$S = xy'z' + x'yz' + x'y'z + xyz = x \oplus y \oplus z$$

$$\begin{array}{cccc|c}
 & & & & y \\
 & 0 & 0 & 1 & 0 \\
 x & 0 & 1 & 1 & 1 \\
 \hline
 & & & & z \\
 \end{array}$$
  

$$C = xy + xz + yz$$

# Binary Adder

- Full Adder



$$S = xy'z' + x'yz' + x'y'z + xyz = x \oplus y \oplus z$$
$$C = xy + xz + yz$$



# Binary Adder

Full adder design from two half adder

**The sum:**

$$\begin{aligned} S &= \bar{X}\bar{Y}C_{in} + \bar{X}Y\bar{C}_{in} + X\bar{Y}\bar{C}_{in} + XYC_{in} \\ &= \bar{C}_{in}(\bar{X}Y + X\bar{Y}) + C_{in}(\bar{X}\bar{Y} + XY) \\ &= \bar{C}_{in}(\bar{X}Y + X\bar{Y}) + C_{in}\overline{(\bar{X}Y + XY)} \\ S &= C_{in} \oplus (X \oplus Y) \end{aligned}$$

**The carry output:**

$$\begin{aligned} C_{out} &= \bar{X}Y\bar{C}_{in} + X\bar{Y}C_{in} + XY\bar{C}_{in} + X\bar{Y}\bar{C}_{in} \\ &= C_{in}(\bar{X}Y + X\bar{Y}) + XY(C_{in} + \bar{C}_{in}) \\ C_{out} &= C_{in} \cdot (X \oplus Y) + XY \end{aligned}$$

# Binary Adder

- Full Adder



# Binary Adder

## Binary Adder (Asynchronous Ripple-Carry Adder)

- A binary adder is a digital circuit that produces the *arithmetic sum of two binary numbers*.
- A binary adder can be constructed with *full adders connected in cascade* with the output carry from each full adder connected to the input carry of the next full adder in the chain.
- The *four-bit adder* is a typical example of a *standard component*. It can be used in many applications involving arithmetic operations.



$$\begin{array}{r}
 & \mathbf{c}_3 & \mathbf{c}_2 & \mathbf{c}_1 & \\
 + & \mathbf{x}_3 & \mathbf{x}_2 & \mathbf{x}_1 & \mathbf{x}_0 \\
 + & \mathbf{y}_3 & \mathbf{y}_2 & \mathbf{y}_1 & \mathbf{y}_0 \\
 \hline
 \mathbf{Cy} & \mathbf{s}_3 & \mathbf{s}_2 & \mathbf{s}_1 & \mathbf{s}_0
 \end{array}$$

*Example:*

$$A + B \quad (A = 1011) \text{ and } (B = 0011)$$

| Subscript <i>i</i>  | 3 | 2 | 1 | 0 |           |
|---------------------|---|---|---|---|-----------|
| <i>Input Carry</i>  | 0 | 1 | 1 | 0 | $c_i$     |
| <i>A</i>            | 1 | 0 | 1 | 1 | $A_i$     |
| <i>+</i>            |   |   |   |   |           |
| <i>B</i>            | 0 | 0 | 1 | 1 | $B_i$     |
| <i>Sum</i>          | 1 | 1 | 1 | 0 | $S_i$     |
| <i>Output Carry</i> | 0 | 0 | 1 | 1 | $c_{i+1}$ |

$$c_0 = 0$$

# Binary Adder

- The input carry to the adder is  $C_0$  and it ripples through the full adders to the output carry  $C_4$ .
- $n$ -bit binary adder requires  $n$  full adders.



# Binary Subtractor

Block schematic of half-subtractor



Logical expression

Truth table

| Input |   | Output         |               |
|-------|---|----------------|---------------|
| A     | B | Difference (D) | Borrow (Bout) |
| 0     | 0 | 0              | 0             |
| 0     | 1 | 1              | 1             |
| 1     | 0 | 1              | 0             |
| 1     | 1 | 0              | 0             |



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

$$\text{Borrow} = \bar{A} \cdot B$$

Logical design



# Binary Subtractor

## Block schematic of full-subtractor



## Truth table

| Inputs |   |                 | Outputs       |                           |
|--------|---|-----------------|---------------|---------------------------|
| A      | B | B <sub>in</sub> | Difference(D) | Borrow(B <sub>out</sub> ) |
| 0      | 0 | 0               | 0             | 0                         |
| 0      | 0 | 1               | 1             | 1                         |
| 0      | 1 | 0               | 1             | 1                         |
| 0      | 1 | 1               | 0             | 1                         |
| 1      | 0 | 0               | 1             | 0                         |
| 1      | 0 | 1               | 0             | 0                         |
| 1      | 1 | 0               | 0             | 0                         |
| 1      | 1 | 1               | 1             | 1                         |

## Logical expression

| For Difference |                  |    |    |    |
|----------------|------------------|----|----|----|
| A              | BB <sub>in</sub> | 00 | 01 | 11 |
| 0              | 0                | 0  | 1  | 0  |
| 1              | 1                | 1  | 0  | 0  |

| For Borrow |                  |    |    |    |
|------------|------------------|----|----|----|
| A          | BB <sub>in</sub> | 00 | 01 | 11 |
| 0          | 0                | 0  | 1  | 1  |
| 1          | 0                | 0  | 1  | 0  |

$$\text{Difference, } D = A'B'B_{\text{in}} + A'BB'_{\text{in}} + AB'B'_{\text{in}} + ABB_{\text{in}}$$

$$\text{Borrow, } B_{\text{out}} = A'B + A'B_{\text{in}} + BB_{\text{in}}$$

# Binary Subtractor

## Logical design



# Binary Subtractor

## ◆ 1's Complement of a Binary Number

There is a simple algorithm to convert a binary number into 1's complement. To get 1's complement of a binary number, simply invert the given number.

## ◆ 2's Complement of a Binary Number

There is a simple algorithm to convert a binary number into 2's complement. To get 2's complement of a binary number, simply invert the given number and add 1 to the least significant bit (LSB) of given result.

### Example

Binary representation of 3 is: 0 0 1 1

1's Complement of 3 is: 1 1 0 0

2's Complement of 3 is: (1's Complement + 1) i.e.

1 1 0 0 (1's Compliment)

+ 1

1 1 0 1 (2's Complement i.e. -3)

Now  $2 + (-3) = 0 0 1 0$  (2 in binary)

+ 1 1 0 1 (-3)

1 1 1 1 (-1)

Now, to check whether it is -1 or not simply. takes 2's Complement of -1 and kept -ve sign as it is.

-1 = 1 1 1 1

2's Complement = -(0 0 0 0)

+ 1

-(0 0 0 1) i.e. -1

# Binary Subtractor

- Use 2's complement with binary adder

$$-x - y = x + (-y) = x + y' + 1$$

## Binary Subtractor

- To perform the subtraction  $-B$ , we can use the **2's complements**, so the subtraction can be converted to addition.
- **2's complement** can be obtained by taking the **1's complement** and adding **1** to the **LSD** bit.
  - 1) **1's complement** can be implemented with invertors.
  - 2) **1** can be added to the sum through the input carry.
- The circuit for subtracting  $A - B$  consists of an adder with inverters placed between each data input  $B$  and the corresponding input of the full adder. The input carry  $C_0$  must be equal to **1**.



# Binary Subtractor



# Binary Adder/Subtractor

- $M$ : Control Signal (Mode)

- $- M=0 \quad \square \quad F = x + y$

- $- M=1 \quad \square \quad F = x - y$



# Binary Subtractor

## Binary Adder–Subtractor

- The addition and subtraction operations can be combined into one circuit with one common binary adder by including an *exclusive-OR* gate with each full-adder.



The mode input  $M$  controls the operation as the following:

- ( $M = 0 \rightarrow$  adder.)
- ( $M = 1 \rightarrow$  subtractor.)
- Each *XOR* gate receives  $M$  signal and  $B$ 
  - When  $M = 0$  then  $B \oplus 0 = B$  and the carry = 0, then the circuit performs the operation  $A + B$ .
  - When  $M = 1$  then  $B \oplus 1 = \bar{B}$  and the carry = 1, then the circuit performs the operation  $A - B$ .
- The *exclusive-OR* with output  $V$  is for detecting an overflow.

# Carry look ahead Adder

- The **carry propagation time** is an important attribute of the adder because it limits the speed with which two numbers are added.
- To reduce the carry propagation delay time:
  - 1) Employ faster gates with reduced delays.
  - 2) Employ the principle of **Carry Lookahead Logic**.

**Proof:** (using carry lookahead logic)

$$P_i = A_i \oplus B_i$$

$$G_i = A_i B_i$$

The output sum and carry are:

$$S_i = P_i \oplus C_i$$

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



For  $C_{in}$ :



# Carry look ahead Adder

- ✓  $G_i$ -called a **carry generate**, and it produces a carry of 1 when both  $A_i$  and  $B_i$  are 1.
- ✓  $P_i$ -called a **carry propagate**, it determines whether a carry into stage  $i$  will propagate into stage  $i + 1$ .
- ✓ The **Boolean function** for the carry outputs of each stage and substitute the value of each  $C_i$  from the previous equations:

$$P_i = A_i \oplus B_i$$

$$\left\{ \begin{array}{l} C_0 = \text{input carry} \\ C_1 = G_0 + P_0 C_0 \\ C_2 = G_1 + P_1 C_1 = G_1 + P_1(G_0 + P_0 C_0) \\ \quad = G_1 + P_1 G_0 + P_1 P_0 C_0 \\ C_3 = G_2 + P_2 C_2 = G_2 + P_2(G_1 + P_1 G_0 + P_1 P_0 C_0) \\ \quad = G_2 + P_2 G_1 + P_2 P_1 G_0 + P_2 P_1 P_0 C_0 \end{array} \right\}$$

$$G_i = A_i B_i$$

The output sum and carry are:

$$S_i = P_i \oplus C_i$$

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

- The three Boolean functions  $C_1$ ,  $C_2$  and  $C_3$  are implemented in the **carry lookahead generator**.

*The two level-circuit for the output carry  $C_4$  is not shown, it can be easily derived by the equation.*

- $C_3$  does not have to wait for  $C_2$  and  $C_1$  to propagate, in fact  $C_3$  is propagated at the same time as  $C_1$  and  $C_2$ .

# Carry look ahead Adder



- The construction of a *four-bit adder with a carry lookahead scheme* is the following:



*four-bit adder with a carry lookahead scheme*

# Decimal Adder

A decimal adder requires a minimum of 9 inputs and 5 outputs

- 1 digit requires 4-bit
- Input: 2 digits + 1-bit carry
- Output: 1 digit + 1-bit carry

BCD adder

- Perform the addition of two decimal digits in BCD, together with an input carry from a previous stage.
- The output sum cannot be greater than 19 (9+9+1)

# BCD Adder

- 4-bits plus 4-bits
- Operands and Result: 0 to 9

$$\begin{array}{r}
 + x_3 \ x_2 \ x_1 \ x_0 \\
 + y_3 \ y_2 \ y_1 \ y_0 \\
 \hline
 Cy \quad s_3 \ s_2 \ s_1 \ s_0
 \end{array}$$

| $X+Y$ | $x_3 \ x_2 \ x_1 \ x_0$ | $y_3 \ y_2 \ y_1 \ y_0$ | Sum  | $Cy$ | $s_3 \ s_2 \ s_1 \ s_0$ |
|-------|-------------------------|-------------------------|------|------|-------------------------|
| $0+0$ | 0 0 0 0                 | 0 0 0 0                 | = 0  | 0    | 0 0 0 0                 |
| $0+1$ | 0 0 0 0                 | 0 0 0 1                 | = 1  | 0    | 0 0 0 1                 |
| $0+2$ | 0 0 0 0                 | 0 0 1 0                 | = 2  | 0    | 0 0 1 0                 |
|       |                         |                         |      |      |                         |
| $0+9$ | 0 0 0 0                 | 1 0 0 1                 | = 9  | 0    | 1 0 0 1                 |
| $1+0$ | 0 0 0 1                 | 0 0 0 0                 | = 1  | 0    | 0 0 0 1                 |
| $1+1$ | 0 0 0 1                 | 0 0 0 1                 | = 2  | 0    | 0 0 1 0                 |
|       |                         |                         |      |      |                         |
| $1+8$ | 0 0 0 1                 | 1 0 0 0                 | = 9  | 0    | 1 0 0 1                 |
| $1+9$ | 0 0 0 1                 | 1 0 0 1                 | = A  | 0    | 1 0 1 0                 |
| $2+0$ | 0 0 1 0                 | 0 0 0 0                 | = 2  | 0    | 0 0 1 0                 |
|       |                         |                         |      |      |                         |
| $9+9$ | 1 0 0 1                 | 1 0 0 1                 | = 12 | 1    | 0 0 1 0                 |

*Invalid Code*

*Wrong BCD Value*

0001 1000

# BCD Adder

| $X + Y$ | $x_3 x_2 x_1 x_0$ | $y_3 y_2 y_1 y_0$ | Sum  | $Cy$ | $S_3 S_2 S_1 S_0$ | Required BCD Output | Value |
|---------|-------------------|-------------------|------|------|-------------------|---------------------|-------|
|         |                   |                   |      |      |                   |                     |       |
| $9 + 0$ | 1 0 0 1           | 0 0 0 0           | = 9  | 0    | 1 0 0 1           | 0 0 0 0 1 0 0 1     | = 9   |
| $9 + 1$ | 1 0 0 1           | 0 0 0 1           | = 10 | 0    | 1 0 1 0           | 0 0 0 1 0 0 0 0     | = 16  |
| $9 + 2$ | 1 0 0 1           | 0 0 1 0           | = 11 | 0    | 1 0 1 1           | 0 0 0 1 0 0 0 1     | = 17  |
| $9 + 3$ | 1 0 0 1           | 0 0 1 1           | = 12 | 0    | 1 1 0 0           | 0 0 0 1 0 0 1 0     | = 18  |
| $9 + 4$ | 1 0 0 1           | 0 1 0 0           | = 13 | 0    | 1 1 0 1           | 0 0 0 1 0 0 1 1     | = 19  |
| $9 + 5$ | 1 0 0 1           | 0 1 0 1           | = 14 | 0    | 1 1 1 0           | 0 0 0 1 0 1 0 0     | = 20  |
| $9 + 6$ | 1 0 0 1           | 0 1 1 0           | = 15 | 0    | 1 1 1 1           | 0 0 0 1 0 1 0 1     | = 21  |
| $9 + 7$ | 1 0 0 1           | 0 1 1 1           | = 16 | 1    | 0 0 0 0           | 0 0 0 1 0 1 1 0     | = 22  |
| $9 + 8$ | 1 0 0 1           | 1 0 0 0           | = 17 | 1    | 0 0 0 1           | 0 0 0 1 0 1 1 1     | = 23  |
| $9 + 9$ | 1 0 0 1           | 1 0 0 1           | = 18 | 1    | 0 0 1 0           | 0 0 0 1 1 0 0 0     | = 24  |
|         |                   |                   |      |      |                   |                     |       |

+ 6

# BCD Adder

- Correct Binary Adder's Output (+6)
  - If the result is between 'A' and 'F'
  - If  $C_y = 1$

| $S_3 S_2 S_1 S_0$ | $yI$ |
|-------------------|------|
| 0 0 0 0           | 0    |
| 1 0 0 0           | 0    |
| 1 0 0 1           | 0    |
| 1 0 1 0           | 1    |
| 1 0 1 1           | 1    |
| 1 1 0 0           | 1    |
| 1 1 0 1           | 1    |
| 1 1 1 0           | 1    |
| 1 1 1 1           | 1    |



$$Err = S_3 S_2 + S_3 S_1$$

# BCD Adder



# BCD Adder

Fig. 1: BLOCK DIAGRAM OF BCD ADDER



# Overflow

- Unsigned Binary Numbers



- 2's Complement Numbers



# Magnitude Comparator

## 1- Bit magnitude comparator

- ❖ A comparator used to compare two bits is called a single bit comparator.
- ❖ It consists of two inputs each for two single bit numbers and three outputs to generate less than, equal to and greater than between two binary numbers.



Logic design



Truth table

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

Equation from truth table

$$A < B = A'B$$

$$A > B = AB'$$

$$A = B = A'B' + AB$$

# Magnitude Comparator

## 2- Bit magnitude comparator

A comparator used to compare two binary numbers each of two bits is called a 2-bit Magnitude comparator. It consists of four inputs and three outputs to generate less than, equal to and greater than between two binary numbers.

### Truth table

| INPUT |    |    |    | OUTPUT |     |     |
|-------|----|----|----|--------|-----|-----|
| A1    | A0 | B1 | B0 | A<B    | A=B | A>B |
| 0     | 0  | 0  | 0  | 0      | 1   | 0   |
| 0     | 0  | 0  | 1  | 1      | 0   | 0   |
| 0     | 0  | 1  | 0  | 1      | 0   | 0   |
| 0     | 0  | 1  | 1  | 1      | 0   | 0   |
| 0     | 1  | 0  | 0  | 0      | 0   | 1   |
| 0     | 1  | 0  | 1  | 0      | 1   | 0   |
| 0     | 1  | 1  | 0  | 1      | 0   | 0   |
| 0     | 1  | 1  | 1  | 1      | 0   | 0   |
| 1     | 0  | 0  | 0  | 0      | 0   | 1   |
| 1     | 0  | 0  | 1  | 0      | 0   | 1   |
| 1     | 0  | 1  | 0  | 0      | 1   | 0   |
| 1     | 0  | 1  | 1  | 1      | 0   | 0   |
| 1     | 1  | 0  | 0  | 0      | 0   | 1   |
| 1     | 1  | 0  | 1  | 0      | 0   | 1   |
| 1     | 1  | 1  | 0  | 0      | 0   | 1   |
| 1     | 1  | 1  | 1  | 0      | 1   | 0   |

## K map for 2- Bit magnitude comparator

|    |    | A > B |       |    |    |  |
|----|----|-------|-------|----|----|--|
|    |    | 00    | 01    | 11 | 10 |  |
|    |    | A1 A0 | B1 B0 |    |    |  |
| 00 | 00 | 0     | 0     | 0  | 0  |  |
| 01 | 01 | 1     | 0     | 0  | 0  |  |
| 11 | 11 | 1     | 1     | 0  | 1  |  |
| 00 | 00 | 1     | 1     | 0  | 0  |  |

|    |    | A = B |       |    |    |  |
|----|----|-------|-------|----|----|--|
|    |    | 00    | 01    | 11 | 10 |  |
|    |    | A1 A0 | B1 B0 |    |    |  |
| 00 | 00 | 1     | 0     | 0  | 0  |  |
| 01 | 01 | 0     | 1     | 0  | 0  |  |
| 11 | 11 | 0     | 0     | 1  | 0  |  |
| 00 | 00 | 0     | 0     | 0  | 1  |  |

|    |    | A < B |       |    |    |  |
|----|----|-------|-------|----|----|--|
|    |    | 00    | 01    | 11 | 10 |  |
|    |    | A1 A0 | B1 B0 |    |    |  |
| 00 | 00 | 0     | 1     | 1  | 1  |  |
| 01 | 01 | 0     | 0     | 1  | 1  |  |
| 11 | 11 | 0     | 0     | 0  | 0  |  |
| 00 | 00 | 0     | 0     | 1  | 0  |  |

## Design equations

$$A > B : A_1B_1' + A_0B_1'B_0' + A_1A_0B_0'$$

$$A = B : A_1'A_0'B_1'B_0' + A_1'A_0B_1'B_0 + A_1A_0B_1B_0 + A_1A_0'B_1B_0'$$

$$: A_1'B_1' (A_0'B_0' + A_0B_0) + A_1B_1 (A_0B_0 + A_0'B_0')$$

$$: (A_0B_0 + A_0'B_0') (A_1B_1 + A_1'B_1')$$

$$: (A_0 \text{ Ex-Nor } B_0) (A_1 \text{ Ex-Nor } B_1)$$

$$A < B : A_1'B_1 + A_0'B_1B_0 + A_1'A_0'B_0$$

## Logic design of 2 –bit magnitude comparator



# **ANALOG AND DIGITAL ELECTRONICS**

**UNIT 3 – COMBINATIONAL LOGIC CIRCUITS**

**READ ONLY MEMORY**

**-S.Vaishali**

# Read Only Memory (ROM)

- Data stored in a ROM is non-volatile, i.e. this data is permanently stored until erased or changed through re-programming (if applicable)
- The ROM has  $n$  input lines for the address and  $m$  output data lines
- Total memory capacity of a ROM is  $2^n \times m$  bits
- ROMs do not have input lines as a write operation does not exist in them
- Programmable ROMs receive data to be programmed on the output lines
- Generally, system-level programs that need to be accessed frequently and at power up access are stored in the computer's ROM, e.g. the BIOS firmware



# Read Only Memory (ROM)

## Programmable sum of (fixed) minterms

- Example: 8 X 4 PROM ( $n = 3$  input lines,  $m = 4$  output lines)
- The fixed "AND" array is a "decoder" with 3 inputs and 8 outputs implementing minterms
- The programmable "OR" array uses a single line to represent all inputs to an OR gate. An "X" in the array corresponds to attaching the minterm to the OR
- Read Example: For input  $(A_2, A_1, A_0) = 010$ , output is  $(F_3, F_2, F_1, F_0) = 1001$ .
- What are functions  $F_3, F_2, F_1$  and  $F_0$  in terms of  $(A_2, A_1, A_0)$ ?

8 X 3-input fixed ANDs give all 8 minterms



# Read Only Memory (ROM): n i/ps to m o/ps $2^n$ locations x m bits each

- Read Only Memories (ROM) have:
  - n input (address) lines  $\square$   $2^n$  locations  $\square$   $2^n$  decoded minterms
  - m output lines (word width)
- Fixed array of  $2^n$  AND gates implementing all the N-literal minterms.
- Programmable OR Array with m outputs lines to form up to  $m$  expressions, each being a sum of selected minterm.
- The program for a PROM is simply the multiple-output truth table to be implemented
  - If a 1 entry, a connection is made to the corresponding minterm for the corresponding output
  - If a 0, no connection is made
- Can be viewed as a *memory* with the inputs as *addresses* of *data* (output values), hence ROM or PROM names!  
Device on previous slide is an  $8 \times 4$  memory (8 locations, each 4 bits)
- Truth table is a listing of the memory contents

# Read Only Memory (ROM) Advantages/Limitations

Advantages:

- Can implement any function (all the minterms are available)
- Program is derived directly from the truth table (uses the canonical form)

Disadvantages:

- Becomes complex for a large number of inputs n (# of ANDs =  $2^n$ , each n-input wide)
- Does not support multi-level circuits (no outputs brought back as inputs)

# Types of ROM Devices

- Simply ROM: Programmed only once and by the manufacturer (in factory), based on the client's truth table
- PROM: A ROM programmable only once by the user (in the field). The user blows fuses to remove unwanted connections. This process is irreversible and hence device is programmed only once
- EPROM: Erasable, Programmable ROMs. Can have their data erased using Ultraviolet light and reprogrammed. The user can then reprogram the ROM many times using special programmers Off-situ.

Off-situ: Remove from computer to erase/program



Quartz  
Window

# Types of ROM, Contd.

- EEPROMs: Electrically Erasable Programmable ROMs. Have memory cells that can be erased and reprogrammed by exposure to electrical signals.  
Erasure/Programming is now much easier and in-situ. The processor can now “write” into the EEPROM.
- Flash memory devices:
  - Memory cells are erased in blocks not one-by-one as in EEPROMs □ Shorter life but faster operation

## **UNIT – IV**

**Programmable Logic devices,  
Memory and Logic Families**

# Programmable Logic Devices (PLD)

- Programmable Logic Devices (PLDs) are IC chips with internal logic gates connected by electronic fuses.
- These fuses can be ‘blown’ (by programming) to obtain different circuit configurations.
- Semi-customized chips that give high packing density at reasonable cost.
- Three classes of PLDs are :
  - ❖ Programmable Logic Array (PLA)
  - ❖ Programmable Read Only Memory (PROM)
  - ❖ Programmable Array Logic (PAL)

# Programmable Logic Devices



**Programmable Read Only Memory (PROM)**



**Programmable Array Logic (PAL)**



**Programmable Logic Array (PLA)**

# Programmable Logic Array (PLA)

- Combination of a programmable AND array followed by a programmable OR array.
- Example: Design a PLA to realise the following three logic functions and show the internal connections.

$$f_1(A,B,C,D,E) = A'.B'.D' + B'.C.D' + A'.B.C.D.E'$$

$$f_2(A,B,C,D,E) = A'.B.E + B'.C.D'.E$$

$$f_3(A,B,C,D,E) = A'.B'.D' + B'.C'.D'.E + A'.B.C.D$$

# Realising Logic Functions with PLAs

$$f_1(A,B,C,D,E) = A'.B'.D' + B'.C.D' + A'.B.C.D.E'$$

$$f_2(A,B,C,D,E) = A'.B.E + B'.C.D'.E$$

$$f_3(A,B,C,D,E) = A'.B'.D' + B'.C'.D'.E + A'.B.C.D$$





Implement the following functions using PLA.

$$F_1 = \sum m(1, 2, 4, 6); F_2 = \sum m(0, 1, 6, 7)$$

$$F_3 = \sum m(2, 6)$$

**Solution: Step 1: Truth Table for given functions:**

| A | B | C | $F_1$ | $F_2$ | $F_3$ |
|---|---|---|-------|-------|-------|
| 0 | 0 | 0 | 0     | 1     | 0     |
| 0 | 0 | 1 | 1     | 1     | 0     |
| 0 | 1 | 0 | 1     | 0     | 1     |
| 0 | 1 | 1 | 0     | 0     | 0     |
| 1 | 0 | 0 | 1     | 0     | 0     |
| 1 | 0 | 1 | 0     | 0     | 0     |
| 1 | 1 | 0 | 1     | 1     | 1     |
| 1 | 1 | 1 | 0     | 1     | 0     |

**Step 2: K map Simplification:**



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



$$F_2 = \overline{AB} + AB$$



$$F_3 = B\overline{C}$$

Step 3: PLA Program Table:

| Product Term      | Inputs |   |   | Outputs |       |       |     |
|-------------------|--------|---|---|---------|-------|-------|-----|
|                   | A      | B | C | $F_0$   | $F_1$ | $F_2$ |     |
| $\bar{A}\bar{B}C$ | 1      | 0 | 0 | 1       | -     | -     |     |
| $A\bar{C}$        | 2      | 1 | - | 0       | 1     | -     |     |
| $B\bar{C}$        | 3      | - | 1 | 0       | 1     | -     | 1   |
| $\bar{A}B$        | 4      | 0 | 0 | -       | -     | 1     | -   |
| $AB$              | 5      | 1 | 1 | -       | -     | 1     | T/C |

Step 4: Draw the PLA circuit with

3 inputs

5 product terms

3 outputs



Implement the combinational circuit with PLA having 3 inputs, 4 product terms and 2 output for the functions:

$$F_1 = \Sigma (3, 5, 6, 7), \quad F_2 = \Sigma (0, 2, 4, 7)$$

**Solution :**

**Step 1: Truth table for Boolean Functions:**

| A | B | C | F <sub>1</sub> | F <sub>2</sub> |
|---|---|---|----------------|----------------|
| 0 | 0 | 0 | 0              | 1              |
| 0 | 0 | 1 | 0              | 0              |
| 0 | 1 | 0 | 0              | 1              |
| 0 | 1 | 1 | 1              | 0              |
| 1 | 0 | 0 | 0              | 1              |
| 1 | 0 | 1 | 1              | 0              |
| 1 | 1 | 0 | 1              | 0              |
| 1 | 1 | 1 | 1              | 1              |

Step 2: K map Simplification:



$$F_1 = AC + AB + BC$$



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

With this simplification, the total number of product terms is 6. But we require only 4 product terms. Therefore find out the K map simplification for  $\bar{F}_1$  and  $\bar{F}_2$ .



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



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

Now select the functions  $F_1$  and  $\bar{F}_2$ , since the common product terms are  $(\bar{B}\bar{C}, \bar{A}\bar{C}, \bar{AB}, ABC)$

**Step 3: PLA Program Table:**

| Product Term               | Inputs |   |   | Outputs |       |
|----------------------------|--------|---|---|---------|-------|
|                            | A      | B | C | $F_1$   | $F_2$ |
| $\overline{B}\overline{C}$ | 1      | - | 0 | 0       | 1     |
| $\overline{AC}$            | 2      | 0 | - | 0       | 1     |
| $\overline{AB}$            | 3      | 0 | 0 | -       | 1     |
| $ABC$                      | 4      | 1 | 1 | 1       | -     |
|                            |        |   |   | $C$     | $T$   |
|                            |        |   |   |         | $T/C$ |

$$F_1 = (\overline{B}\overline{C} + \overline{A}\overline{C} + \overline{A}\overline{B}) ; F_2 = \overline{B}\overline{C} + \overline{A}\overline{C} + ABC$$

**Step 4: Draw the PLA circuit with**

3 inputs, 4 product terms and 2 outputs.



Fig. 5.51: PLA circuit

It should be noted that  $\overline{F}_1$  really occurs at one of the outputs of the OR-array. By programming the corresponding EX-OR gate fuse,  $\overline{F}_1 - F_1$  appears at the output of the PLA.

# **ANALOG AND DIGITAL ELECTRONICS**

**UNIT 3 – COMBINATIONAL LOGIC CIRCUITS  
ARITHMETIC LOGIC UNIT**

**-S.Vaishali**

- An **arithmetic logic unit (ALU)**
  - Performs arithmetic and logic operations
  - A fundamental building block of the Central Processing Unit (CPU) of a computer
  - Even the simplest microprocessors contain one for purposes such as maintaining timers
  - A combinational logic circuit



# Simple ALU



when  $S=00$ ,  $R=A+B$   
when  $S=01$ ,  $R=A-B$   
when  $S=10$ ,  $R=A \text{ AND } B$   
when  $S=11$ ,  $R=A \text{ OR } B$

The S input is controlled by the processor based on the op code

# A complete ALU circuit

The / and 4 on a line indicate that it's actually *four* lines.



The arithmetic and logic units share the select inputs S1 and S0, but only the arithmetic unit uses S2.

- When S3 = 0, the final output comes from the arithmetic unit.
- When S3 = 1, the output comes from the logic unit.

# Unit - 3

## Hardware Description Language

# Hardware Description Language - Introduction

- HDL is a language that describes the hardware of digital systems in a textual form.
- It resembles a programming language, but is specifically oriented to describing hardware structures and behaviors.
- The main difference with the traditional programming languages is HDL's representation of extensive parallel operations whereas traditional ones represents mostly serial operations.
- The most common use of a HDL is to provide an alternative to schematics.

# HDL – Introduction

- When a language is used for the above purpose (i.e. to provide an alternative to schematics), it is referred to as a *structural description* in which the language describes an interconnection of components.
- Such a structural description can be used as input to logic simulation just as a schematic is used.
- Models for each of the primitive components are required.
- If an HDL is used, then these models can also be written in the HDL providing a more uniform, portable representation for simulation input.

# HDL – Introduction

- HDL can be used to represent logic diagrams, Boolean expressions, and other more complex digital circuits.
- Thus, in top down design, a very high-level description of a entire system can be precisely specified using an HDL.
- This high-level description can then be refined and partitioned into lower-level descriptions as a part of the design process.

# HDL – Introduction

- As a documentation language, HDL is used to represent and document digital systems in a form that can be read by both humans and computers and is suitable as an exchange language between designers.
- The language content can be stored and retrieved easily and processed by computer software in an efficient manner.
- There are two applications of HDL processing: ***Simulation*** and ***Synthesis***

# Logic Simulation

- A simulator interprets the HDL description and produces a readable output, such as a timing diagram, that predicts how the hardware will behave before its is actually fabricated.
- Simulation allows the detection of functional errors in a design without having to physically create the circuit.

# Logic Simulation

- The stimulus that tests the functionality of the design is called a test bench.
- To simulate a digital system
  - Design is first described in HDL
  - Verified by simulating the design and checking it with a test bench which is also written in HDL.

# Logic Simulation

- Logic simulation is a fast, accurate method of analyzing a circuit to see its waveforms



# Types of HDL

- There are two standard HDL's that are supported by IEEE.
  - **VHDL** (*Very-High-Speed Integrated Circuits Hardware Description Language*) - Sometimes referred to as VHSIC HDL, this was developed from an initiative by US. Dept. of Defense.
  - **Verilog HDL** – developed by Cadence Data systems and later transferred to a consortium called *Open Verilog International* (OVI).

# Verilog

- Verilog HDL has a syntax that describes precisely the legal constructs that can be used in the language.
- It uses about 100 keywords pre-defined, lowercase, identifiers that define the language constructs.
- Example of keywords: *module, endmodule, input, output wire, and, or, not* , etc.,
- Any text between two slashes (//) and the end of line is interpreted as a comment.
- Blank spaces are ignored and names are case sensitive.

# Verilog Module

- A *module* is the building block in Verilog.
- It is declared by the keyword *module* and is always terminated by the keyword *endmodule*.
- Each statement is terminated with a semicolon, but there is no semi-colon after *endmodule*.



# Verilog Module for simple circuit

## HDL Example

```
module smpl_circuit(A,B,C,x,y);
    input A,B,C;
    output x,y;
    wire e;
    and g1(e,A,B);
    not g2(y,C);
    or  g3(x,e,y);
endmodule
```

# Verilog – Gate Delays

- Sometimes it is necessary to specify the amount of delay from the input to the output of gates.
- In Verilog, the delay is specified in terms of time units and the symbol #.
- The association of a time unit with physical time is made using ***timescale*** compiler directive.
- Compiler directive starts with the “backquote (`)” symbol.  
`***timescale*** 1ns/100ps
- The first number specifies the *unit of measurement* for time delays.
- The second number specifies the *precision* for which the delays are rounded off, in this case to 0.1ns.

# Verilog Module with Gate Delays

```
//Description of circuit with delay
module circuit_with_delay (A,B,C,x,y);
    input A,B,C;
    output x,y;
    wire e;
    and #(30) g1(e,A,B);
    or # (20) g3(x,e,y);
    not #(10) g2(y,C);
endmodule
```

# Test Bench

- In order to simulate a circuit with HDL, it is necessary to apply inputs to the circuit for the simulator to generate an output response.
- An HDL description that provides the stimulus to a design is called a **test bench**.
- The ***initial*** statement specifies inputs between the keyword ***begin*** and ***end***.
- Initially ABC=000 (A,B and C are each set to 1'b0 (one binary digit with a value 0)).
- **\$finish** is a *system task*.

# Test Bench for Simple Circuit

```
module circuit_with_delay
  (A,B,C,x,y);
  input A,B,C;
  output x,y;
  wire e;
  and #(30) g1(e,A,B);
  or  #(20) g3(x,e,y);
  not #(10) g2(y,C);
endmodule
```

```
//Stimulus for simple circuit
module stimcrct;
reg A,B,C;
wire x,y;
circuit_with_delay cwd(A,B,C,x,y);
initial
begin
  A = 1'b0; B = 1'b0; C = 1'b0;
  #100
  A = 1'b1; B = 1'b1; C = 1'b1;
  #100 $finish;
end
endmodule
```

# Verilog Module for Boolean Expressions

## Bitwise operators

- Bitwise NOT : ~
- Bitwise AND: &
- Bitwise OR: |
- Bitwise XOR: ^
- Bitwise XNOR: ~^ or ^~

# Verilog Module for Boolean Expressions

## Boolean Expressions:

- These are specified in Verilog HDL with a continuous assignment statement consisting of the keyword *assign* followed by a Boolean Expression.
- The earlier circuit can be specified using the statement:

**assign**  $x = (A \& B) | \sim C$ )

E.g.  $x = A + BC + B'D$

$y = B'C + BC'D'$

# Verilog Module for Boolean Expressions

```
//Circuit specified with Boolean equations
module circuit_bln (x,y,A,B,C,D);
    input A,B,C,D;
    output x,y;
    assign x = A | (B & C) | (~B & C);
    assign y = (~B & C) | (B & ~C & ~D);
endmodule
```

# User Defined Primitives

## User Defined Primitives (UDP):

- The logic gates used in HDL descriptions with keywords ***and***, ***or***, etc., are defined by the system and are referred to as ***system primitives***.
- The user can create additional primitives by defining them in tabular form.
- These type of circuits are referred to as ***user-defined primitives***.

# User Defined Primitives

UDP features ....

- UDP's do not use the keyword module. Instead they are declared with the keyword ***primitive***.
- There can be **only one output** and it must be listed first in the port list and declared with an *output* keyword.
- There can be any number of inputs. The order in which they are listed in the ***input*** declaration must conform to the order in which they are given values in the table that follows.
- The truth table is enclosed within the keywords ***table*** and ***endtable***.
- The values of the inputs are listed with a colon (:). The output is always the last entry in a row followed by a semicolon (;).
- It ends with the keyword ***endprimitive***.

# Verilog Module for User Defined Primitives

```
//User defined primitive(UDP)
primitive crctp (x,A,B,C);
    output x;
    input A,B,C;
//Truth table for x(A,B,C) = Minterms (0,2,4,6,7)
    table
//      A   B   C   :   x   (Note that this is only a
comment)
      0   0   0   :   1;
      0   0   1   :   0;
      0   1   0   :   1;
      0   1   1   :   0;
      1   0   0   :   1;
      1   0   1   :   0;
      1   1   0   :   1;
      1   1   1   :   1;
endtable
endprimitive
// Instantiate primitive
module declare_crctp;
    reg      x,y,z;
    wire    w;
    crctp (w,x,y,z);
endmodule
```

# Types of Modeling

- A module can be described in any one (or a combination) of the following modeling techniques.
  - **Gate-level modeling** using instantiation of primitive gates and user defined modules.
    - This describes the circuit by specifying the gates and how they are connected with each other.
  - **Dataflow modeling** using continuous assignment statements with the keyword **assign**.
    - This is mostly used for describing combinational circuits.
  - **Behavioral modeling** using procedural assignment statements with keyword **always**.
    - This is used to describe digital systems at a higher level of abstraction.

# Gate-Level Modeling

- Here a circuit is specified by its **logic gates** and their **interconnections**.
- It provides a textual description of a schematic diagram.
- Verilog recognizes 12 basic gates as predefined primitives.
  - 4 primitive gates of 3-state type.
  - Other 8 are: **and, nand, or, nor, xor, xnor, not, buf**
- When the gates are simulated, the system assigns a four-valued logic set to each gate – *0, 1, unknown (x) and high impedance (z)*

# Gate-level modeling

- When a primitive gate is incorporated into a module, we say it is *instantiated* in the module.
- In general, component instantiations are statements that reference lower-level components in the design, essentially creating unique copies (or *instances*) of those components in the higher-level module.
- Thus, a module that uses a gate in its description is said to *instantiate* the gate.

# Gate-level Modeling

- Modeling with vector data (multiple bit widths):
    - A vector is specified within square brackets and two numbers separated with a colon.  
e.g. **output** [0 : 3] D; - This declares an output vector D with 4 bits, 0 through 3.  
**wire** [7 : 0] SUM; – This declares a wire vector SUM with 8 bits numbered 7 through 0.
- The first number listed is the most significant bit of the vector.

# Gate-level Modeling

- Two or more modules can be combined to build a hierarchical description of a design.
- There are two basic types of design methodologies.
  - **Top down:** In top-down design, the top level block is defined and then sub-blocks necessary to build the top level block are identified.
  - **Bottom up:** Here the building blocks are first identified and then combine to build the top level block.
- In a top-down design, a 4-bit binary adder is defined as top-level block with 4 full adder blocks. Then we describe two half-adders that are required to create the full adder.
- In a bottom-up design, the half-adder is defined, then the full adder is constructed and the 4-bit adder is built from the full adders.

# Gate-level Modeling

- A bottom-up hierarchical description of a 4-bit adder is described in Verilog as
  - Half adder: defined by instantiating primitive gates.
  - Then define the full adder by instantiating two half-adders.
  - Finally the third module describes 4-bit adder by instantiating 4 full adders.
- **Note:** In Verilog, one module definition cannot be placed within another module description.

# 4-bit Half Adder



$$(a) S = xy' + x'y \\ C = xy$$



$$(b) S = x \oplus y \\ C = xy$$

# 4-bit Full Adder



Fig. 4-8 Implementation of Full Adder with Two Half Adders and an OR Gate



Fig. 4-9 4-Bit Adder

# 4-bit Full Adder

```
//Gate-level hierarchical description of 4-bit adder
module halfadder (S,C,x,y);
    input x,y;
    output S,C;
    //Instantiate primitive gates
    xor (S,x,y);
    and (C,x,y);
endmodule

module fulladder (S,C,x,y,z);
    input x,y,z;
    output S,C;
wire S1,D1,D2; //Outputs of first XOR and two AND
                    //gates
    //Instantiate the half adders
halfadder HA1(S1,D1,x,y), HA2(S,D2,S1,z);
    or g1(C,D2,D1);
endmodule
```

# 4-bit Full Adder

```
module _4bit_adder (S,C4,A,B,C0);
    input [3:0] A,B;
    input C0;
    output [3:0] S;
    output C4;
wire C1,C2,C3; //Intermediate carries

//Instantiate the full adder
fulladder FA0 (S[0],C1,A[0],B[0],C0),
            FA1 (S[1],C2,A[1],B[1],C1),
            FA2 (S[2],C3,A[2],B[2],C2),
            FA3 (S[3],C4,A[3],B[3],C3);
endmodule
```

# 2 to 4 Decoder



(a) Logic diagram

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

(b) Truth table

Fig. 4-19 2-to-4-Line Decoder with Enable Input

## 2 to 4 Decoder

```
//Gate-level description of a 2-to-4-line decoder
module decoder_gl (A,B,E,D);
    input A,B,E;
    output[0:3] D;
    wire Anot,Bnot,Enot;
        not
            n1 (Anot,A),
            n2 (Bnot,B),
            n3 (Enot,E);
        nand
            n4 (D[0],Anot,Bnot,Enot),
            n5 (D[1],Anot,B,Enot),
            n6 (D[2],A,Bnot,Enot),
            n7 (D[3],A,B,Enot);
    endmodule
```

# 2-to-4 Line Decoder



Fig.3-14 A 2-to-4-Line Decoder

# 2-to-4 Line Decoder

```
//2 to 4 line decoder
module decoder_2_to_4_st_v(E_n, A0, A1, D0_n, D1_n,
D2_n, D3_n);
input E_n, A0, A1;
output D0_n, D1_n, D2_n, D3_n;

wire A0_n, A1_n, E;
not g0(A0_n, A0), g1(A1_n, A1), g2(E, E_n);
nand g3(D0_n, A0_n, A1_n, E), g4(D1_n, A0, A1_n, E),
g5(D2_n, A0_n, A1, E), g6(D3_n, A0, A1, E);
endmodule
```

# Dataflow Modeling

- Dataflow modeling uses a number of operators that act on operands to produce desired results.
- Verilog HDL provides about 30 operator types.
- Dataflow modeling uses continuous assignments and the keyword **assign**.
- A continuous assignment is a statement that assigns a value to a net.
- The value assigned to the net is specified by an expression that uses operands and operators.

# Dataflow Modeling - 2-to-4-line decoder

```
//Dataflow description of a 2-to-4-line decoder
module decoder_df (A,B,E,D);
    input A,B,E;
    output [0:3] D;
assign D[0] = ~(~A & ~B & ~E),
        D[1] = ~(~A & B & ~E),
        D[2] = ~(A & ~B & ~E),
        D[3] = ~(A & B & ~E);
endmodule
```

A 2-to-1 line multiplexer with data inputs A and B, select input S, and output Y is described with the continuous assignment

```
assign Y = (A & S) | (B & ~S)
```

# Dataflow Modeling - 4-bit adder and 4-bit comparator

```
//Dataflow description of 4-bit adder
module binary_adder (A,B,Cin,SUM,Cout);
    input [3:0] A,B;
    input Cin;
    output [3:0] SUM;
    output Cout;
    assign {Cout,SUM} = A + B + Cin;
endmodule
```

```
//Dataflow description of a 4-bit comparator.
module magcomp (A,B,ALTB,AGTB,AEQB);
    input [3:0] A,B;
    output ALTB,AGTB,AEQB;
    assign ALTB = (A < B),
            AGTB = (A > B),
            AEQB = (A == B);
endmodule
```

# Dataflow Modeling - 2-to-1-line mux

- Dataflow Modeling provides the means of describing combinational circuits by their function rather than by their gate structure.
- **Conditional operator (?:)**  
condition ? true-expression : false-expression;
- A 2-to-1 line multiplexer  
**assign** OUT = select ? A : B;

```
//Dataflow description of 2-to-1-line mux
module mux2x1_df (A,B,select,OUT);
    input A,B,select;
    output OUT;
assign OUT = select ? A : B;
endmodule
```

# HDL Behavioral Modeling

# Behavioral Modeling

- Behavioral modeling represents digital circuits at a functional and algorithmic level.
- It is used mostly to describe sequential circuits, but can also be used to describe combinational circuits.
- Behavioral descriptions use the keyword **always** followed by a list of procedural assignment statements.
- The target output of procedural assignment statements must be of the **reg** data type.
- A **reg** data type retains its value until a new value is assigned.

# Behavioral Modeling 2-to-1-line mux

- The procedural assignment statements inside the **always** block are executed every time there is a change in any of the variable listed after the @ symbol. (Note that there is no “;” at the end of **always** statement)

```
//Behavioral description of 2-to-1-line multiplexer
module mux2x1_bh(A,B,select,OUT);
    input A,B,select;
    output OUT;
    reg OUT;
    always @ (select or A or B)
        if (select == 1) OUT = A;
        else OUT = B;
endmodule
```

# Behavioral Modeling - 4-to-1 line multiplexer



(a) Logic diagram

| $s_1$ | $s_0$ | $Y$   |
|-------|-------|-------|
| 0     | 0     | $I_0$ |
| 0     | 1     | $I_1$ |
| 1     | 0     | $I_2$ |
| 1     | 1     | $I_3$ |

(b) Function table

4-to-1 line  
multiplexer

# Behavioral Modeling 4-to-1 line multiplexer

```
//Behavioral description of 4-to-1 line mux
```

```
module mux4x1_bh (i0,i1,i2,i3,select,y);  
    input i0,i1,i2,i3;  
    input [1:0] select;  
    output y;  
    reg y;  
always @ (i0 or i1 or i2 or i3 or select)  
    case (select)  
        2'b00: y = i0;  
        2'b01: y = i1;  
        2'b10: y = i2;  
        2'b11: y = i3;  
    endcase  
endmodule
```

# Behavioral Modeling 4-to-1 line multiplexer

- In 4-to-1 line multiplexer, the select input is defined as a 2-bit vector and output y is declared as a reg data.
- The always block has a sequential block enclosed between the keywords **case** and **endcase**.
- The block is executed whenever any of the inputs listed after the @ symbol changes in value.

# Descriptions of Circuits

- ***Structural Description*** – This is directly equivalent to the schematic of a circuit and is specifically oriented to describing hardware structures using the components of a circuit.
- ***Dataflow Description*** – This describes a circuit in terms of function rather than structure and is made up of concurrent assignment statements or their equivalent. Concurrent assignments statements are executed concurrently, i.e. in parallel whenever one of the values on the right hand side of the statement changes.

# Descriptions of Circuits

- **Hierarchical Description** – Descriptions that represent circuits using hierarchy have multiple entities, one for each element of the Hierarchy.
- **Behavioral Description** – This refers to a description of a circuit at a level higher than the logic level. This type of description is also referred to as the *register transfers level*.

# 2-to-4 Line Decoder – Data flow description

```
//2-to-4 Line Decoder: Dataflow
module dec_2_to_4_df(E_n,A0,A1,D0_n,D1_n,D2_n,D3_n);
    input E_n, A0, A1;
    output D0_n,D1_n,D2_n,D3_n;
    assign D0_n=~ (~E_n&~A1&~A0);
    assign D1_n=~ (~E_n&~A1& A0);
    assign D2_n=~ (~E_n& A1&~A0);
    assign D3_n=~ (~E_n& A1& A0);
endmodule
```

# 4-to-1 Multiplexer



Fig. 3-19 4-to-1-Line Multiplexer

# 4-to-1 Multiplexer

```
//4-to-1 Mux: Structural Verilog
module mux_4_to_1_st_v(S,D,Y);
    input [1:0]S;
    input [3:0]D;
    output Y;
    wire [1:0]not_s;
    wire [0:3]N;
    not g0(not_s[0],S[0]),g1(not_s[1],S[1]);
    and g2(N[0],not_s[0],not_s[1],D[0]),
    g3(N[1],S[0],not_s[1],D[0]),
    g4(N[2],not_s[0],S[1],D[0]),
    g5(N[3],S[0],S[1],D[0]);
    or g5(Y,N[0],N[1],N[2],N[3]);
endmodule
```

# 4-to-1 Multiplexer – Data Flow

```
//4-to-1 Mux: Dataflow description
module mux_4_to_1(S,D,Y);
    input [1:0]S;
    input [3:0]D;
    output Y;
    assign Y = (~S[1]&~S[0]&D[0]) | (~S[1]&S[0]&D[1])
        | (S[1]&~S[0]&D[2]) | (S[1]&S[0]&D[3]);
endmodule
```

```
//4-to-1 Mux: Conditional Dataflow description
module mux_4_to_1(S,D,Y);
    input [1:0]S;
    input [3:0]D;
    output Y;
    assign Y = (S==2'b00)?D[0] : (S==2'b01)?D[1] :
        (S==2'b10)?D[2] : (S==2'b11)?D[3]:1'bx;;
endmodule
```

# 4-to-1 Multiplexer

```
//4-to-1 Mux: Dataflow Verilog Description
module mux_4_to_1(S,D,Y);
    input [1:0]S;
    input [3:0]D;
    output Y;
    assign Y=S[1]? (S[0]?D[3]:D[2]):(S[0]?D[1]:D[0]);
endmodule
```

# Adder

□ TABLE 3-7  
Truth Table of Half Adder

| Inputs |   | Outputs |   |
|--------|---|---------|---|
| X      | Y | C       | S |
| 0      | 0 | 0       | 0 |
| 0      | 1 | 0       | 1 |
| 1      | 0 | 0       | 1 |
| 1      | 1 | 1       | 0 |

Table 3-7 Truth Table of Half Adder

□ TABLE 3-8  
Truth Table of Full Adder

| Inputs |   |   | Outputs |   |
|--------|---|---|---------|---|
| X      | Y | Z | C       | S |
| 0      | 0 | 0 | 0       | 0 |
| 0      | 0 | 1 | 0       | 1 |
| 0      | 1 | 0 | 0       | 1 |
| 0      | 1 | 1 | 1       | 0 |
| 1      | 0 | 0 | 0       | 1 |
| 1      | 0 | 1 | 1       | 0 |
| 1      | 1 | 0 | 1       | 0 |
| 1      | 1 | 1 | 1       | 1 |

Table 3-8 Truth Table of Full Adder



Fig. 3-25 Logic Diagram of Half Adder



$$\begin{aligned}S &= \bar{X}\bar{Y}Z + \bar{X}Y\bar{Z} + X\bar{Y}\bar{Z} + XYZ \\&= X \oplus Y \oplus Z\end{aligned}$$



$$\begin{aligned}C &= XY + XZ + YZ \\&= XY + Z(X\bar{Y} + \bar{X}Y) \\&= XY + Z(X \oplus Y)\end{aligned}$$

Fig. 3-26 Maps for Full Adder

# 4-bit Adder



Fig. 3-27 Logic Diagram of Full Adder



Fig. 3-28 4-Bit Ripple Carry Adder

## 4-bit-Adder

```
// 4-bit Adder: Hierarchical Dataflow/Structural
// (See Figures 3-27 and 3-28 for logic diagrams)

module half_adder_v(x, y, s, c);
    input x, y;
    output s, c;
    assign s = x ^ y;
    assign c = x & y;

endmodule

module full_adder_v(x, y, z, s, c);
    input x, y, z;
    output s, c;
    wire hs, hc, tc;
    half_adder_v HA1(x, y, hs, hc),
              HA2(hs, z, s, tc);
    assign c = tc | hc;

endmodule

module adder_4_v(B, A, C0, S, C4);
    input[3:0] B, A;
    input C0;
    output[3:0] S;
    output C4;
    wire[3:1] C;
    full_adder_v Bit0(B[0], A[0], C0, S[0], C[1]),
                  Bit1(B[1], A[1], C[1], S[1], C[2]),
                  Bit2(B[2], A[2], C[2], S[2], C[3]),
                  Bit3(B[3], A[3], C[3], S[3], C4);

endmodule
```

# 4-bit Adder

```
// 4-bit adder : dataflow description
module adder_4bit (A,B,C0,S,C4);
    input [3:0] A,B;
    input C0;
    output [3:0] S;
    output C4;
    assign {C4,S} = A + B + C0;
endmodule
```