

# **Boolean Algebra**

# **K-Map Simplification**

# **Combinational Circuit Design**

**Dr. Shilpi Gupta**  
**Associate Professor**  
**ECED**  
**SVNIT, Surat**

# The “WHY” Boolean Algebra

- **Algebra**

When we learned numbers like 1, 2, 3, we also then learned how to add, multiply, etc. with them. Boolean Algebra covers operations that we can do with 0's and 1's. Computers do these operations ALL THE TIME and they are basic building blocks of computation inside your computer program.

## Axioms, laws, theorems

We need to know some rules about how those 0's and 1's can be operated on together. There are similar axioms to decimal number algebra, and there are some laws and theorems that are good for you to use to simplify your operation.

# How does Boolean Algebra fit into the big picture?

- It is part of the Combinational Logic topics (memoryless)
  - Different from the Sequential logic topics (can store information)
- Learning Axioms and theorems of Boolean algebra
  - Allows you to design logic functions
  - Allows you to know how to combine different logic gates
  - Allows you to simplify or optimize on the complex operations

# Boolean algebra

- A Boolean algebra comprises...
    - A set of elements B
    - Binary operators {+, •}      Boolean sum and product
    - A unary operation {'} (or  $\bar{\phantom{x}}$ )      example:  $A'$  or  $\bar{A}$
  - ...and the following axioms
    - 1. The set B contains at least two elements {a b} with  $a \neq b$
    - 2. Closure:  $a+b$  is in B       $a \bullet b$  is in B
    - 3. Commutative:  $a+b = b+a$        $a \bullet b = b \bullet a$
    - 4. Associative:  $a+(b+c) = (a+b)+c$        $a \bullet (b \bullet c) = (a \bullet b) \bullet c$
    - 5. Identity:  $a+0 = a$        $a \bullet 1 = a$
    - 6. Distributive:  $a+(b \bullet c) = (a+b) \bullet (a+c)$        $a \bullet (b+c) = (a \bullet b) + (a \bullet c)$
    - 7. Complementarity:  $a+a' = 1$        $a \bullet a' = 0$

# Digital (binary) logic is a Boolean algebra

## Substitute

- {0, 1} for B
- AND for • Boolean Product.
- OR for + Boolean Sum.
- NOT for ' Complement.

All the axioms hold for binary logic

## Definitions

- Boolean function
  - Maps inputs from the set {0,1} to the set {0,1}
- Boolean expression
  - An algebraic statement of Boolean variables and operators

# Logic Gates (AND, OR, Not) & Truth Table

AND

$X \bullet Y$

$XY$



| X | Y | Z |
|---|---|---|
| 0 | 0 | 0 |
| 0 | 1 | 0 |
| 1 | 0 | 0 |
| 1 | 1 | 1 |

OR

$X + Y$



| X | Y | Z |
|---|---|---|
| 0 | 0 | 0 |
| 0 | 1 | 1 |
| 1 | 0 | 1 |
| 1 | 1 | 1 |

NOT

$\bar{X}$

$X'$



| X | Y |
|---|---|
| 0 | 1 |
| 1 | 0 |

# Logic functions and Boolean algebra

- Any logic function that is expressible as a truth table can be written in Boolean algebra using  $+$ ,  $\bullet$ , and  $'$

| X | Y | Z |
|---|---|---|
| 0 | 0 | 0 |
| 0 | 1 | 0 |
| 1 | 0 | 0 |
| 1 | 1 | 1 |

$Z = X \bullet Y$

| X | Y | $X'$ | Z |
|---|---|------|---|
| 0 | 0 | 1    | 0 |
| 0 | 1 | 1    | 1 |
| 1 | 0 | 0    | 0 |
| 1 | 1 | 0    | 0 |

$Z = X' \bullet Y$

| X | Y | $X'$ | $Y'$ | $X \bullet Y$ | $X' \bullet Y'$ | Z |
|---|---|------|------|---------------|-----------------|---|
| 0 | 0 | 1    | 1    | 0             | 1               | 1 |
| 0 | 1 | 1    | 0    | 0             | 0               | 0 |
| 1 | 0 | 0    | 1    | 0             | 0               | 0 |
| 1 | 1 | 0    | 0    | 1             | 0               | 1 |

$Z = (X \bullet Y) + (X' \bullet Y')$

# Two key concepts

- **Duality (a meta-theorem— *a theorem about theorems*)**

- All Boolean expressions have logical duals
- Any theorem that can be proved is also proved for its dual
- Replace: • with +, + with •, 0 with 1, and 1 with 0
- Leave the variables unchanged

- **De Morgan's Theorem**

- Procedure for complementing Boolean functions
- Replace: • with +, + with •, 0 with 1, and 1 with 0
- Replace all variables with their complements

# **Universal Gate Implementation**

## **NAND Gate as Universal Gate**

OR Gate using NAND Gate

NOR Gate using NAND Gate

EXOR using NAND Gate

**NOR Gate as Universal Gate: TO DO**

**EX-OR Gate Using NOR gate**



# Boolean Functions

- Boolean function is described by an algebraic expression called Boolean expressions which consists of binary variables and logic operation symbols.
- Mathematical functions can be expressed in two ways:

An **expression** is  
finite but not unique

$$\begin{aligned}f(x,y) &= 2x + y \\&= x + x + y \\&= 2(x + y/2) \\&= \dots\end{aligned}$$

A **function table** is  
unique

| x   | y   | f(x,y) |
|-----|-----|--------|
| 0   | 0   | 0      |
| ... | ... | ...    |
| 2   | 2   | 6      |
| ... | ... | ...    |
| 23  | 41  | 87     |
| ... | ... | ...    |

We can represent logical functions in two analogous ways too:

- A finite, but non-unique **Boolean expression**.
- A **truth table**, which will turn out to be unique.

# Boolean expressions

- We can use these basic operations to form more complex expressions:

$$f(x,y,z) = (x + y')z + x'$$

- $f$  is the name of the function.
- $(x, y, z)$  are the **input variables**, each representing 1 or 0. Listing the inputs is optional, but sometimes helpful.
- A **literal** is any occurrence of an input variable or its complement. The function above has four literals:  $x$ ,  $y'$ ,  $z$ , and  $x'$ .
- Precedence is important, but not too difficult.
  - NOT has the highest precedence, followed by AND, and then OR.
  - Fully parenthesized, the function above would be kind of messy:

$$f(x,y,z) = (((x + (y'))z) + x')$$

# Useful laws and theorems

Identity:  $X + 0 = X$

Dual:  $X \bullet 1 = X$

Null:  $X + 1 = 1$

Dual:  $X \bullet 0 = 0$

Idempotent:  $X + X = X$

Dual:  $X \bullet X = X$

Involution:  $(X')' = X$

Complementarity:  $X + X' = 1$  Dual:  $X \bullet X' = 0$

Commutative:  $X + Y = Y + X$  Dual:  $X \bullet Y = Y \bullet X$

Associative:  $(X+Y)+Z=X+(Y+Z)$  Dual:  $(X\bullet Y)\bullet Z=X\bullet(Y\bullet Z)$

Distributive:  $X\bullet(Y+Z)=(X\bullet Y)+(X\bullet Z)$  Dual:  $X+(Y\bullet Z)=(X+Y)\bullet(X+Z)$

Uniting:  $X\bullet Y+X\bullet Y'=X$

Dual:  $(X+Y)\bullet(X+Y')=X$

## Proof of law with Truth table

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

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

# Useful laws and theorems (con't)

Absorption:  $X+X \bullet Y = X$       Dual:  $X \bullet (X+Y) = X$

Absorption (#2):  $(X+Y') \bullet Y = X \bullet Y$       Dual:  $(X \bullet Y') + Y = X + Y$

$$x + \bar{x}y = x + y$$

$$(x + y)(x + z) = x + yz$$

de Morgan's:  $(X+Y+\dots)' = X' \bullet Y' \bullet \dots$       Dual:  $(X \bullet Y \bullet \dots)' = X' + Y' + \dots$

Duality:  $(X+Y+\dots)^D = X \bullet Y \bullet \dots$       Dual:  $(X \bullet Y \bullet \dots)^D = X + Y + \dots$

Multiplying & factoring:  $(X+Y) \bullet (X'+Z) = X \bullet Z + X' \bullet Y$

$$\text{Dual: } X \bullet Y + X' \bullet Z = (X+Z) \bullet (X'+Y)$$

Consensus:  $(X \bullet Y) + (Y \bullet Z) + (X' \bullet Z) = X \bullet Y + X' \bullet Z$

$$\text{Dual: } (X+Y) \bullet (Y+Z) \bullet (X'+Z) = (X+Y) \bullet (X'+Z)$$

# Proofing the theorems using axioms

- Idempotency:  $x + x = x$

Proof:

$$\begin{aligned}x + x &= (x + x) \bullet 1 && \text{by identity} \\&= (x + x) \bullet (x + x') && \text{by complement} \\&= x + x \bullet x' && \text{by distributivity} \\&= x + 0 && \text{by complement} \\&= x && \text{by identity}\end{aligned}$$

- Idempotency:  $x \bullet x = x$

Proof:

$$\begin{aligned}x \bullet x &= (x \bullet x) + 0 && \text{by identity} \\&= (x \bullet x) + (x \bullet x') && \text{by complement} \\&= x \bullet (x + x') && \text{by distributivity} \\&= x \bullet 1 && \text{by complement} \\&= x && \text{by identity}\end{aligned}$$

# Theorems

Prove the uniting theorem--  $X \bullet Y + X \bullet Y' = X$

|                 |                                                   |
|-----------------|---------------------------------------------------|
| Distributive    | $X \bullet Y + X \bullet Y' = X \bullet (Y + Y')$ |
| Complementarity | $= X \bullet (1)$                                 |
| Identity        | $= X$                                             |

Prove the absorption theorem--  $X + X \bullet Y = X$

|              |                                                   |
|--------------|---------------------------------------------------|
| Identity     | $X + X \bullet Y = (X \bullet 1) + (X \bullet Y)$ |
| Distributive | $= X \bullet (1 + Y)$                             |
| Null         | $= X \bullet (1)$                                 |
| Identity     | $= X$                                             |

# To Prove

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

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

More proves

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

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

Simplify the following expression

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



# Theorems

Prove the consensus theorem--

$$(XY) + (YZ) + (X'Z) = XY + X'Z$$

Complementarity  $XY + YZ + X'Z = XY + (X + X')YZ + X'Z$

Distributive  $= XYZ + XY + X'YZ + X'Z$

- Use absorption  $\{AB + A = A\}$  with  $A = XY$  and  $B = Z$

$$= XY + X'YZ + X'Z$$

Rearrange terms  $= XY + X'ZY + X'Z$

- Use absorption  $\{AB + A = A\}$  with  $A = X'Z$  and  $B = Y$

$$XY + YZ + X'Z = XY + X'Z$$

# Logic simplification

Example:

$$Z = A'BC + AB'C' + AB'C + ABC' + ABC$$

$$= A'BC + AB'(C' + C) + AB(C' + C) \quad \text{distributive}$$

$$= A'BC + AB' + AB \quad \text{complementary}$$

$$= A'BC + A(B' + B) \quad \text{distributive}$$

$$= A'BC + A \quad \text{complementary}$$

$$= BC + A \quad \text{absorption #2 Duality}$$

$$(X \bullet Y') + Y = X + Y \text{ with } X = BC \text{ and } Y = A$$

# Algebraic manipulation

$$\begin{aligned} & x'y' + xyz + x'y \\ &= x'(y' + y) + xyz \quad [\text{Distributive; } x'y' + x'y = x'(y' + y)] \\ &= x' \bullet 1 + xyz \quad [\text{Axiom 5; } y' + y = 1] \\ &= x' + xyz \quad [\text{Axiom 2; } x' \bullet 1 = x'] \\ &= (x' + x)(x' + yz) \quad [\text{Distributive}] \\ &= 1 \bullet (x' + yz) \quad [\text{Axiom 5; } x' + x = 1] \\ &= x' + yz \quad [\text{Axiom 2; } x' \bullet 1 = x'] \end{aligned}$$

## More Problems :-

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

$$(AB + C)(AB + D)$$

$$AB + ABC + A\bar{B} = A \quad (\text{Prove})$$

# De Morgan's Theorem

Use de Morgan's Theorem to find complements

Example:  $F = (A+B) \bullet (A'+C)$ , so  $F' = (A' \bullet B') + (A \bullet C')$

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

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

# Complement of a function

- The complement of a function always outputs 0 where the original function outputted 1, and 1 where the original produced 0.
- In a truth table, we can just exchange 0s and 1s in the output column(s)

$$f(x,y,z) = x(y'z' + yz)$$

| x | y | z | f(x,y,z) |
|---|---|---|----------|
| 0 | 0 | 0 | 0        |
| 0 | 0 | 1 | 0        |
| 0 | 1 | 0 | 0        |
| 0 | 1 | 1 | 0        |
| 1 | 0 | 0 | 1        |
| 1 | 0 | 1 | 0        |
| 1 | 1 | 0 | 0        |
| 1 | 1 | 1 | 1        |



| x | y | z | f'(x,y,z) |
|---|---|---|-----------|
| 0 | 0 | 0 | 1         |
| 0 | 0 | 1 | 1         |
| 0 | 1 | 0 | 1         |
| 0 | 1 | 1 | 1         |
| 1 | 0 | 0 | 0         |
| 1 | 0 | 1 | 1         |
| 1 | 1 | 0 | 1         |
| 1 | 1 | 1 | 0         |

# Complementing a function algebraically

$$f(x,y,z) = x(y'z' + yz)$$

$$\begin{aligned} f'(x,y,z) &= (x(y'z' + yz))' \quad [\text{complement both sides}] \\ &= x' + (y'z' + yz)' \quad [\text{because } (xy)' = x' + y'] \\ &= x' + (y'z')' (yz)' \quad [\text{because } (x+y)' = x'y'] \\ &= x' + (y+z)(y'+z') \quad [\text{because } (xy)' = x'+y', \text{ twice}] \end{aligned}$$

- You can use DeMorgan's law to keep "pushing" the complements inwards
- You can also take the dual of the function, and then complement each literal
  - If  $f(x,y,z) = x(y'z' + yz)...$
  - ...the dual of  $f$  is  $x + (y' + z')(y + z)...$
  - ...then complementing each literal gives  $x' + (y + z)(y' + z')...$
  - ...so  $f'(x,y,z) = x' + (y + z)(y' + z')$

# Canonical Forms

- Any boolean function that is expressed as a **sum of minterms** or as a **product of maxterms** is said to be in its **canonical form**.
- A **minterm** is a special product of literals, in which each input variable appears exactly once.
- A function with  $n$  variables has  $2^n$  minterms (since each variable can appear complemented or not) A three-variable function, such as  $f(x,y,z)$ , has  $2^3 = 8$  minterms:

$$\begin{array}{l} x'y'z' \\ xy'z' \end{array}$$

$$\begin{array}{l} x'y'z \\ xy'z \end{array}$$

$$\begin{array}{l} x'yz' \\ xyz' \end{array}$$

$$\begin{array}{l} x'yz \\ xyz \end{array}$$

# Minterms

- Each minterm is true for exactly one combination of inputs:

| Minterm  | Is true when... | Shorthand |
|----------|-----------------|-----------|
| $x'y'z'$ | $x=0, y=0, z=0$ | $m_0$     |
| $x'y'z$  | $x=0, y=0, z=1$ | $m_1$     |
| $x'yz'$  | $x=0, y=1, z=0$ | $m_2$     |
| $x'yz$   | $x=0, y=1, z=1$ | $m_3$     |
| $xy'z'$  | $x=1, y=0, z=0$ | $m_4$     |
| $xy'z$   | $x=1, y=0, z=1$ | $m_5$     |
| $xyz'$   | $x=1, y=1, z=0$ | $m_6$     |
| $xyz$    | $x=1, y=1, z=1$ | $m_7$     |

# Sum of minterms form

- Every function can be written as a **sum of minterms**, which is a special kind of sum of products form
- The sum of minterms form for any function is *unique*
- If you have a truth table for a function, you can write a sum of minterms expression just by picking out the rows of the table where the function output is 1 (**1-minterm**).

| x | y | z | f(x,y,z) | f'(x,y,z) |
|---|---|---|----------|-----------|
| 0 | 0 | 0 | 1        | 0         |
| 0 | 0 | 1 | 1        | 0         |
| 0 | 1 | 0 | 1        | 0         |
| 0 | 1 | 1 | 1        | 0         |
| 1 | 0 | 0 | 0        | 1         |
| 1 | 0 | 1 | 0        | 1         |
| 1 | 1 | 0 | 1        | 0         |
| 1 | 1 | 1 | 0        | 1         |

$$\begin{aligned}f &= x'y'z' + x'y'z + x'yz' + x'yz + xyz' \\&= m_0 + m_1 + m_2 + m_3 + m_6 \\&= \Sigma(0,1,2,3,6)\end{aligned}$$

$$\begin{aligned}f' &= xy'z' + xy'z + xyz \\&= m_4 + m_5 + m_7 \\&= \Sigma(4,5,7)\end{aligned}$$

$f'$  contains all the minterms not in  $f$

# Sum of minterms: practise

$F = x + yz$ , how to express this in the sum of minterms?

$$\begin{aligned} &= x(y + y')(z + z') + (x + x')yz \\ &= xyz + xyz' + xy'z + xy'z' + xyz + x'yz \\ &= x'y'z + xy'z' + xy'z + xyz' + xyz \\ &= \Sigma(3,4,5,6,7) \end{aligned}$$

or, convert the expression into truth-table and then read the minterms from the table

# Maxterms

- A **maxterm** is a *sum of literals*, in which each input variable appears exactly once.
- A function with  $n$  variables has  $2^n$  maxterms

$$\begin{array}{l} x' + y' + z' \\ x + y' + z' \end{array}$$

$$\begin{array}{l} x' + y' + z \\ x + y' + z \end{array}$$

$$\begin{array}{l} x' + y + z' \\ x + y + z' \end{array}$$

$$\begin{array}{l} x' + y + z \\ x + y + z \end{array}$$

- The maxterms for a three-variable function  $f(x,y,z)$ :

| Maxterm        | Is false when... | Shorthand |
|----------------|------------------|-----------|
| $x + y + z$    | $x=0, y=0, z=0$  | $M_0$     |
| $x + y + z'$   | $x=0, y=0, z=1$  | $M_1$     |
| $x + y' + z$   | $x=0, y=1, z=0$  | $M_2$     |
| $x + y' + z'$  | $x=0, y=1, z=1$  | $M_3$     |
| $x' + y + z$   | $x=1, y=0, z=0$  | $M_4$     |
| $x' + y + z'$  | $x=1, y=0, z=1$  | $M_5$     |
| $x' + y' + z$  | $x=1, y=1, z=0$  | $M_6$     |
| $x' + y' + z'$ | $x=1, y=1, z=1$  | $M_7$     |

- Each maxterm is *false* for exactly one combination of inputs:



# Product of maxterms form

- Every function can be written as a *unique* product of maxterms
- If you have a truth table for a function, you can write a product of maxterms expression by picking out the rows of the table where the function output is 0 (**0-maxterm**).

O/P

| x | y | z | f(x,y,z) | f'(x,y,z) |
|---|---|---|----------|-----------|
| 0 | 0 | 0 | 1        | 0         |
| 0 | 0 | 1 | 1        | 0         |
| 0 | 1 | 0 | 1        | 0         |
| 0 | 1 | 1 | 1        | 0         |
| 1 | 0 | 0 | 0        | 1         |
| 1 | 0 | 1 | 0        | 1         |
| 1 | 1 | 0 | 1        | 0         |
| 1 | 1 | 1 | 0        | 1         |

*X + Y + Z*

SOP min.

$$\begin{aligned}
 f &= (x' + y + z)(x' + y + z')(x' + y' + z') \\
 &= M_4 M_5 M_7 \\
 &= \prod(4,5,7)
 \end{aligned}$$

POS Max O/P → 0

$$\begin{aligned}
 f' &= (x + y + z)(x + y + z')(x + y' + z) \\
 &\quad (x + y' + z')(x' + y' + z) \\
 &= M_0 M_1 M_2 M_3 M_6 \\
 &= \prod(0,1,2,3,6)
 \end{aligned}$$

O/P → 1

SOP  $\sum m(0,1,2)$

$f'$  contains all the maxterms not in  $f$

# Product of maxterms: practise

- $F = \underline{x'y'} + \underline{xz}$ , how to express this in the product of maxterms?

$$= (\underline{x'y'} + x)(x'y' + z)$$

$$= (\underline{x'} + x)(y' + x)(x' + z)(y' + z)$$

$$= (\underline{x} + \underline{y'})(\underline{x'} + z)(y' + z)$$

$$= (\underline{x} + \underline{y'} + \underline{zz'})(\underline{x'} + z + \underline{yy'})(\underline{xx'} + \underline{y'} + z)$$

$$= (\underline{x} + \underline{y'} + z)(x + y' + z')(x' + y + z)(x' + y' + z)(x + y' + z)(x' + y' + z)$$

$$= (\underline{x} + \underline{y'} + z)(x + y' + z')(x' + y + z)(x' + y' + z)$$

$$= \prod(2,3,4,6)$$

0 1 0

0 1 1

1 0 0

Std.

$$\begin{aligned} & xy + (z + z') \\ & xyz + xyz' \end{aligned}$$

SOP

Std SOP

Canonical

$$F(A,B,C) = \frac{(A+B)}{(A'+C)} \cdot \frac{(A'+C)}{(B'+C')}$$

or, convert the expression into truth-table and then read the minterms from the table

# Minterms and maxterms are related

- Any minterm  $m_i$  is the *complement* of the corresponding maxterm  $M_i$

| Minterm  | Shorthand | Maxterm        | Shorthand |
|----------|-----------|----------------|-----------|
| $x'y'z'$ | $m_0$     | $x + y + z$    | $M_0$     |
| $x'y'z$  | $m_1$     | $x + y + z'$   | $M_1$     |
| $x'yz'$  | $m_2$     | $x + y' + z$   | $M_2$     |
| $x'yz$   | $m_3$     | $x + y' + z'$  | $M_3$     |
| $xy'z'$  | $m_4$     | $x' + y + z$   | $M_4$     |
| $xy'z$   | $m_5$     | $x' + y + z'$  | $M_5$     |
| $xyz'$   | $m_6$     | $x' + y' + z$  | $M_6$     |
| $xyz$    | $m_7$     | $x' + y' + z'$ | $M_7$     |

$(x'y'z')' = x' + y + z$

$(m_4)' = M_4$

- For example,  $\underline{m_4}' = M_4$  because  $(xy'z')' = x' + y + z$

# Converting between canonical forms

- We can convert a sum of minterms to a product of maxterms

From before

and

complementing

so

$$f = \Sigma(0,1,2,3,6)$$

$$f' = \Sigma(4,5,7)$$

$$= m_4 + m_5 + m_7$$

$$(f')' = (m_4 + m_5 + m_7)'$$

$$f = m_4' m_5' m_7' \quad [\text{DeMorgan's law}]$$

$$= M_4 M_5 M_7 \quad [\text{By the previous page}]$$

$$= \prod(4,5,7)$$



- In general, just replace the minterms with maxterms, using maxterm numbers that **don't appear** in the sum of minterms:

$$\begin{aligned} f &= \Sigma(0,1,2,3,6) \\ &= \prod(4,5,7) \end{aligned}$$

- The same thing works for converting from a product of maxterms to a sum of minterms

# Standard Forms

- Any boolean function that is expressed as a **sum of products (SOP)** or as a **product of sums (POS)**, where each product-term or sum-term may require **fewer than (n-1) operations**, is said to be in its **standard form**.
- Standard forms are **not unique**, there can be several different SOPs and POSs for a given function.
- A SOP expression contains:
  - Only OR (sum) operations at the “outermost” level
  - Each term (**implicant**) must be a product of literals

$$\underline{f(x,y,z) = xy + x'yz + xy'z}$$

- A POS expression contains:
  - Only AND (product) operations at the “outermost” level
  - Each term (**implicate**) must be a sum of literals

$$f(x,y,z) = (x' + y')(x + y' + z')(x' + y + z')$$

# Minimization of Switching Function



$$F = X'Y'Z + XY + X'Y'$$

Algebraic manipulation  
Theorem, Laws

K'MAP

|           |   | <u>2V</u>   |            |
|-----------|---|-------------|------------|
|           |   | <u>Y</u>    | <u>Y'</u>  |
| <u>X'</u> | 0 | <u>X'Y'</u> | <u>XY'</u> |
| <u>X</u>  | 1 | <u>XY</u>   | <u>X'Y</u> |
| <u>X'</u> | 2 | <u>X'Y'</u> | <u>XY'</u> |
| <u>X</u>  | 3 | <u>XY</u>   | <u>X'Y</u> |

3 Variable

| <u>YZ</u> | 00 | 01 | 10 | 11 |
|-----------|----|----|----|----|
| <u>X'</u> | 0  | 1  | 3  | 2  |
| <u>X</u>  | 4  | 5  | 7  | 6  |
| <u>Y</u>  | 0  | 1  | 1  | 0  |
| <u>Z</u>  | 0  | 0  | 1  | 1  |





|   | A | B | C | F |
|---|---|---|---|---|
| 0 | 0 | 0 | 0 | 1 |
| 1 | 0 | 0 | 1 | 0 |
| 2 | 0 | 1 | 0 | 0 |
| 3 | 0 | 1 | 1 | 1 |
| 4 | 1 | 0 | 0 | 0 |
| 5 | 1 | 0 | 1 | 1 |
| 6 | 1 | 1 | 0 | 0 |
| 7 | 1 | 1 | 1 | 1 |

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



Mimimize Group

$= 1$

$$2^0, 2^1, 2^3, 2^3, 2^4$$

|                |
|----------------|
| 1, 2, 4, 8, 16 |
|----------------|

6

# Two variable K Map

|       |       |
|-------|-------|
| $m_0$ | $m_1$ |
| $m_2$ | $m_3$ |

(a)



(b)



(a)  $xy$



(b)  $x + y$

## 3-variable K-Map

|       |       |       |       |
|-------|-------|-------|-------|
| $m_0$ | $m_1$ | $m_3$ | $m_2$ |
| $m_4$ | $m_5$ | $m_7$ | $m_6$ |



$$F(x, y, z) = \Sigma(2, 3, 4, 5)$$



Simplify the Boolean function

$$F(x, y, z) = \Sigma(3, 4, 6, 7)$$



$$F = A'C + A'B + AB'C + BC$$



Simplify the Boolean function

$$F(x, y, z) = \Sigma(0, 2, 4, 5, 6)$$



$$\Sigma(0, 2, 4, 5, 6) = z' + xy'$$

$$A'C + A'B + AB'C + BC = C + A'B$$

# 4- Variable K-Map

|          |          |          |          |
|----------|----------|----------|----------|
| $m_0$    | $m_1$    | $m_3$    | $m_2$    |
| $m_4$    | $m_5$    | $m_7$    | $m_6$    |
| $m_{12}$ | $m_{13}$ | $m_{15}$ | $m_{14}$ |
| $m_8$    | $m_9$    | $m_{11}$ | $m_{10}$ |

(a)



(b)

Simplify the Boolean function

$$F(w, x, y, z) = \Sigma(0, 1, 2, 4, 5, 6, 8, 9, 12, 13, 14)$$



$$y' + w'z' + xz'$$

Simplify the Boolean function

$$F = A'B'C' + B'CD' + A'BCD' + AB'C'$$



$$B'D' + B'C' + A'CD'$$

# PRODUCT OF SUMS SIMPLIFICATION

Simplify the following Boolean function in (a) sum of products and (b) product of sums.

$$F(A, B, C, D) = \Sigma(0, 1, 2, 5, 8, 9, 10)$$

$$F = B'D' + B'C' + A'C'D$$

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

|    |    | CD |    | C |   |
|----|----|----|----|---|---|
|    |    | 00 | 01 |   |   |
| AB | 00 | 1  | 1  | 0 | 1 |
|    | 01 | 0  | 1  | 0 | 0 |
| A  | 11 | 0  | 0  | 0 | 0 |
|    | 10 | 1  | 1  | 0 | 1 |

$\overbrace{D}^{\phantom{D}}$

A

B

# Completely and Incompletely Specified Logic Functions

Logical functions are of two types:

1. completely specified logical function
2. incompletely specified logical function

A logical function whose output is specified for all possible input combination called completely specified logical function.

A logical function whose output may not be specified for certain input combinations/conditions or for which a certain input combinations may never occur is called incomplete specified logical function.

| Inputs |   |   | Output |
|--------|---|---|--------|
| A      | B | C | F      |
| 0      | 0 | 0 | 0      |
| 0      | 0 | 1 | 1      |
| 0      | 1 | 0 | 0      |
| 0      | 1 | 1 | 1      |
| 1      | 0 | 0 | 0      |
| 1      | 0 | 1 | 0      |
| 1      | 1 | 0 | X      |
| 1      | 1 | 1 | X      |

## Minimization of Incompletely Specified Logic Functions

- For a four bit binary 9's complementary circuit input > 9 is not possible or output for input > 9 is do not care. So, we put the do not care conditions for all  $WXYZ$  in the O/P.

$$w = \sum m(0,1) + \sum d(10,11,12,13,14,15) = f(A,B,C,D)$$

$$X = \sum m(2,3,4,5) + \sum d(10,11,12,13,14,15) = f(A,B,C,D)$$

$$Y = \sum m(2,3,6,7) + \sum d(10,11,12,13,14,15) = f(A,B,C,D)$$

$$Z = \sum m(0,2,4,6,8) + \sum d(10,11,12,13,14,15)$$

**Simplify the Boolean function**

$$F(w, x, y, z) = \Sigma(1, 3, 7, 11, 15)$$

**that has the don't-care conditions**

$$d(w, x, y, z) = \Sigma(0, 2, 5)$$

|    |    | yz |    | y  |    |
|----|----|----|----|----|----|
|    |    | 00 | 01 | 11 | 10 |
| wx |    | 00 | 1  | 1  | X  |
| w  | 00 | X  | 1  | 1  | X  |
|    | 01 | 0  | X  | 1  | 0  |
|    | 11 | 0  | 0  | 1  | 0  |
|    | 10 | 0  | 0  | 1  | 0  |

$\underbrace{\hspace{1cm}}$   $\underbrace{\hspace{1cm}}$   $\underbrace{\hspace{1cm}}$

$z$        $x$

(a)  $F = yz + w'x'$

|    |    | yz |    | y  |    |
|----|----|----|----|----|----|
|    |    | 00 | 01 | 11 | 10 |
| wx |    | 00 | 1  | 1  | X  |
| w  | 00 | X  | 1  | 1  | X  |
|    | 01 | 0  | X  | 1  | 0  |
|    | 11 | 0  | 0  | 1  | 0  |
|    | 10 | 0  | 0  | 1  | 0  |

$\underbrace{\hspace{1cm}}$   $\underbrace{\hspace{1cm}}$   $\underbrace{\hspace{1cm}}$

$z$        $x$

(b)  $F = yz + w'z$

# Combinational Logic





| Inputs |   |          | Outputs |       |
|--------|---|----------|---------|-------|
| A      | B | $C_{in}$ | Sum     | Carry |
| 0      | 0 | 0        | 0       | 0     |
| 0      | 0 | 1        | 1       | 0     |
| 0      | 1 | 0        | 1       | 0     |
| 0      | 1 | 1        | 0       | 1     |
| 1      | 0 | 0        | 1       | 0     |
| 1      | 0 | 1        | 0       | 1     |
| 1      | 1 | 0        | 0       | 1     |
| 1      | 1 | 1        | 1       | 1     |

For sum

| A\BC | 00 | 01 | 11 | 10 |
|------|----|----|----|----|
| 0    | 0  | 0  | 0  | 0  |
| 1    | 0  | 0  | 0  | 0  |

$$\begin{aligned}
 \text{Sum} &= \bar{A}\bar{B}C + \bar{A}B\bar{C} + A\bar{B}\bar{C} + ABC \\
 &= \bar{A}(\bar{B}C + B\bar{C}) + A(\bar{B}\bar{C} + BC) \\
 &= \bar{A}(B \oplus C) + A(\overline{B \oplus C}) \quad (\because \bar{x}y + x\bar{y} = x \oplus y) \\
 &= A \oplus B \oplus C
 \end{aligned}$$



For carry

| A\BC | 00 | 01 | 11 | 10 |
|------|----|----|----|----|
| 0    | 0  | 0  | 0  | 0  |
| 1    | 0  | 0  | 1  | 0  |

$$\text{Carry} = AB + BC + AC$$

# FULL ADDER Using HALF ADDERS



# Full Subtractor

| INPUT |   | OUTPUT |   |      |
|-------|---|--------|---|------|
| A     | B | Bin    | D | Bout |
| 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    |



For Bit Sequence :-

| A           | $\bar{B}Q_0, B\bar{Q}_0$ | $\bar{B}Q_1, BQ_1$ | $\bar{B}Q_2, BQ_2$ | $\bar{B}Q_3, BQ_3$ |
|-------------|--------------------------|--------------------|--------------------|--------------------|
| $\bar{A}$ 0 | 00                       | 01                 | 11                 | 10                 |
| $\bar{A}$ 1 | 01                       | 11                 | 01                 | 00                 |

$$\therefore \text{Bit Sequence} = A \oplus B \oplus C \oplus D$$

$$\begin{aligned}
 \text{Bit Sequence} &= \bar{A}B\bar{Q}_0 + \bar{A}\bar{B}Q_0 + A\bar{B}Q_1 + AB\bar{Q}_1 \\
 &= \bar{A}(B\bar{Q}_0 + \bar{B}Q_0) + A(\bar{B}Q_1 + B\bar{Q}_1) \\
 &= \bar{A}(B \oplus \bar{B}) + A(B \oplus \bar{B}) = \bar{A}(B \oplus \bar{B}) + A(\bar{B} \oplus B) \\
 &\equiv A \oplus B \oplus C \oplus D = A \oplus B \oplus C \oplus D.
 \end{aligned}$$

For Count :-

| A           | $\bar{B}Q_0, B\bar{Q}_0$ | $\bar{B}Q_1, BQ_1$ | $\bar{B}Q_2, BQ_2$ | $\bar{B}Q_3, BQ_3$ |
|-------------|--------------------------|--------------------|--------------------|--------------------|
| $\bar{A}$ 0 | 00                       | 01                 | 01                 | 10                 |
| $\bar{A}$ 1 |                          |                    | 01                 | 00                 |

$$\therefore \text{Count} = \bar{A}B + \bar{A}B\bar{Q}_0 + B\bar{Q}_0$$

$$\therefore \text{Count} = \bar{A}B + \bar{A}B\bar{Q}_0 + B\bar{Q}_0$$



# Binary to Gray Code Conversion

| Decimal Number | 4 bit Binary Number<br><u>ABCD</u> | 4 bit Gray Code<br><u>G<sub>1</sub>G<sub>2</sub>G<sub>3</sub>G<sub>4</sub></u> |
|----------------|------------------------------------|--------------------------------------------------------------------------------|
| 0              | 0 0 0 0                            | 0 0 0 0                                                                        |
| 1              | 0 0 0 1                            | 0 0 0 1                                                                        |
| 2              | 0 0 1 0                            | 0 0 1 1                                                                        |
| 3              | 0 0 1 1                            | 0 1 1 0                                                                        |
| 4              | 0 1 0 0                            | 0 1 1 1                                                                        |
| 5              | 0 1 0 1                            | 0 1 0 1                                                                        |
| 6              | 0 1 1 0                            | 0 1 0 0                                                                        |
| 7              | 0 1 1 1                            | 1 1 0 0                                                                        |
| 8              | 1 0 0 0                            | 1 1 0 1                                                                        |
| 9              | 1 0 0 1                            | 1 1 1 1                                                                        |
| 10             | 1 0 1 0                            | 1 1 1 0                                                                        |
| 11             | 1 0 1 1                            | 1 0 1 0                                                                        |
| 12             | 1 1 0 0                            | 1 0 1 1                                                                        |
| 13             | 1 1 0 1                            | 1 0 0 1                                                                        |
| 14             | 1 1 1 0                            | 1 0 0 0                                                                        |
| 15             | 1 1 1 1                            | 1 0 0 0                                                                        |

## Simplification using K-maps:

|  |  | <u><math>G_{13}</math></u> |            |    |    |    |    |
|--|--|----------------------------|------------|----|----|----|----|
|  |  | $B_3, B_2$                 | $B_1, B_0$ | 00 | 01 | 11 | 10 |
|  |  | 00                         | 0          | 0  | 0  | 0  | 0  |
|  |  | 01                         | 0          | 0  | 0  | 0  | 0  |
|  |  | 11                         | 1          | 1  | 1  | 1  | 1  |
|  |  | 10                         | 1          | 1  | 1  | 1  | 1  |

$$\boxed{G_{13} = B_3}$$

|  |  | <u><math>G_{11}</math></u> |            |    |    |    |    |
|--|--|----------------------------|------------|----|----|----|----|
|  |  | $B_3, B_2$                 | $B_1, B_0$ | 00 | 01 | 11 | 10 |
|  |  | 00                         | 0          | 0  | 1  | 1  |    |
|  |  | 01                         | 1          | 1  | 0  | 0  |    |
|  |  | 11                         | 1          | 1  | 0  | 0  |    |
|  |  | 10                         | 0          | 0  | 1  | 1  |    |

$$G_{11} = B_2 \overline{B}_1 + \overline{B}_2 B_1$$

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

|  |  | <u><math>G_{12}</math></u> |            |    |    |    |    |
|--|--|----------------------------|------------|----|----|----|----|
|  |  | $B_3, B_2$                 | $B_1, B_0$ | 00 | 01 | 11 | 10 |
|  |  | 00                         | 0          | 0  | 0  | 0  | 0  |
|  |  | 01                         | 1          | 1  | 1  | 1  | 1  |
|  |  | 11                         | 0          | 0  | 0  | 0  | 0  |
|  |  | 10                         | 1          | 1  | 1  | 1  | 1  |

$$G_{12} = \overline{B}_3 B_2 + B_3 \overline{B}_2$$

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

|  |  | <u><math>G_{10}</math></u> |            |    |    |    |    |
|--|--|----------------------------|------------|----|----|----|----|
|  |  | $B_3, B_2$                 | $B_1, B_0$ | 00 | 01 | 11 | 10 |
|  |  | 00                         | 0          | 1  | 0  | 1  |    |
|  |  | 01                         | 0          | 1  | 0  | 1  |    |
|  |  | 11                         | 0          | 1  | 0  | 1  |    |
|  |  | 10                         | 0          | 1  | 1  | 0  | 1  |

$$G_{10} = \overline{B}_1 B_0 + B_1 \overline{B}_0$$

$$\boxed{G_{10} = B_1 \oplus B_0}$$

## Logic Diagram:

Binary



Gray

# Gray Code to Binary Code Conversion

Truth Table:

| INPUT ( GRAY CODE) |    |    |    |  | OUTPUTS (BINARY) |    |    |    | Binary |
|--------------------|----|----|----|--|------------------|----|----|----|--------|
| G3                 | G2 | G1 | G0 |  | B3               | B2 | B1 | B0 |        |
| 0                  | 0  | 0  | 0  |  | 0                | 0  | 0  | 0  | 0      |
| 0                  | 0  | 0  | 1  |  | 0                | 0  | 0  | 0  | 1      |
| 0                  | 0  | 1  | 0  |  | 0                | 0  | 1  | 1  | 1      |
| 0                  | 0  | 1  | 1  |  | 0                | 0  | 1  | 0  | 0      |
| 0                  | 1  | 0  | 0  |  | 0                | 1  | 1  | 1  | 1      |
| 0                  | 1  | 0  | 1  |  | 0                | 1  | 1  | 0  | 0      |
| 0                  | 1  | 1  | 0  |  | 0                | 1  | 0  | 0  | 0      |
| 0                  | 1  | 1  | 1  |  | 0                | 1  | 0  | 1  | 1      |
| 1                  | 0  | 0  | 0  |  | 1                | 1  | 1  | 1  | 1      |
| 1                  | 0  | 0  | 1  |  | 1                | 1  | 1  | 0  | 0      |
| 1                  | 0  | 1  | 0  |  | 1                | 1  | 0  | 0  | 1      |
| 1                  | 1  | 0  | 0  |  | 1                | 0  | 0  | 0  | 0      |
| 1                  | 1  | 0  | 1  |  | 1                | 0  | 0  | 1  | 1      |
| 1                  | 1  | 1  | 0  |  | 1                | 0  | 1  | 1  | 0      |
| 1                  | 1  | 1  | 1  |  | 1                | 0  | 1  | 0  | 0      |

## Simplification using K-Maps:

|    |    | <u><math>B_3</math></u> |                 |                 |                       |
|----|----|-------------------------|-----------------|-----------------|-----------------------|
|    |    | $G_3 G_2$               | $\bar{G}_3 G_2$ | $G_3 \bar{G}_2$ | $\bar{G}_3 \bar{G}_2$ |
|    |    | 00                      | 01              | 11              | 10                    |
| 00 | 00 | 0                       | 0               | 0               | 0                     |
| 01 | 01 | 0                       | 0               | 0               | 0                     |
| 11 | "  | 1                       | 1               | 1               | 1                     |
| 10 | "  | 1                       | 1               | 1               | 1                     |

$B_3 = G_3 \oplus G_2$

|    |    | <u><math>B_2</math></u> |                 |                 |                       |
|----|----|-------------------------|-----------------|-----------------|-----------------------|
|    |    | $G_3 G_2$               | $\bar{G}_3 G_2$ | $G_3 \bar{G}_2$ | $\bar{G}_3 \bar{G}_2$ |
|    |    | 00                      | 01              | 11              | 10                    |
| 00 | 00 | 0                       | 0               | 0               | 0                     |
| 01 | 01 | 1                       | 1               | 1               | D                     |
| 11 | "  | 0                       | 0               | 0               | 0                     |
| 10 | "  | 1                       | 1               | 1               | 1                     |

$B_2 = \bar{G}_3 G_2 + G_3 \bar{G}_2$

$B_2 = G_3 \oplus G_2$

|    |    | <u><math>B_1</math></u> |                 |                 |                       |
|----|----|-------------------------|-----------------|-----------------|-----------------------|
|    |    | $G_3 G_2$               | $\bar{G}_3 G_2$ | $G_3 \bar{G}_2$ | $\bar{G}_3 \bar{G}_2$ |
|    |    | 00                      | 01              | 11              | 10                    |
| 00 | 00 | 0                       | 0               | 1               | 1                     |
| 01 | 01 | 1                       | 1               | 0               | 0                     |
| 11 | "  | 0                       | 0               | 1               | 1                     |
| 10 | "  | 1                       | 1               | 0               | 0                     |

$$\begin{aligned}
 B_1 &= \bar{G}_3 \bar{G}_2 G_1 + G_3 G_2 G_1 + \bar{G}_3 G_2 \bar{G}_1 \\
 &\quad + G_3 \bar{G}_2 \bar{G}_1 \\
 &= G_1 (\bar{G}_3 \bar{G}_2 + G_3 G_2) + \\
 &\quad \bar{G}_1 (\bar{G}_3 G_2 + G_3 \bar{G}_2) \\
 &= G_1 (\bar{G}_3 \oplus \bar{G}_2) + \bar{G}_1 (G_3 \oplus G_2) \\
 &= G_1 \oplus G_3 \oplus G_2 \\
 \boxed{B_1 = G_1 \oplus B_2}
 \end{aligned}$$

## Simplification using K-Maps:

|  |  | <u><math>B_0</math></u> |           |                 |                 |
|--|--|-------------------------|-----------|-----------------|-----------------|
|  |  | $G_3 G_2$               | $G_3 G_0$ | $\bar{G}_3 G_2$ | $\bar{G}_3 G_0$ |
|  |  | 00                      | 01        | 11              | 10              |
|  |  | 0                       | 1         | 0               | 1               |
|  |  | 1                       | 0         | 1               | 0               |
|  |  | 0                       | 1         | 0               | 1               |
|  |  | 1                       | 0         | 1               | 0               |

$$\begin{aligned}
 B_0 &= \overline{G_3} \overline{G_2} \overline{G_1} G_0 + \overline{G_3} \overline{G_2} G_1 \overline{G_0} + \overline{G_3} G_2 \overline{G_1} \overline{G_0} + \overline{G_3} G_2 G_1 G_0 \\
 &\quad + G_3 G_2 \overline{G_1} G_0 + G_3 G_2 G_1 \overline{G_0} + G_3 \overline{G_2} \overline{G_1} \overline{G_0} + G_3 \overline{G_2} G_1 G_0 \\
 &= \overline{G_3} \overline{G_2} (\overline{G_1} G_0 + G_1 \overline{G_0}) + \overline{G_3} G_2 (\overline{G_1} \overline{G_0} + G_1 G_0) \\
 &\quad + G_3 G_2 (\overline{G_1} G_0 + G_1 \overline{G_0}) + G_3 \overline{G_2} (\overline{G_1} \overline{G_0} + G_1 G_0) \\
 &= \overline{G_3} \overline{G_2} (G_1 \oplus G_0) + \overline{G_3} G_2 (\overline{G_1} \oplus \overline{G_0}) \\
 &\quad + G_3 G_2 (G_1 \oplus G_0) + G_3 \overline{G_2} (\overline{G_1} \oplus \overline{G_0}) \\
 &= (G_1 \oplus G_0) (\overline{G_3} \overline{G_2} + G_3 G_2) + (\overline{G_1} \oplus \overline{G_0}) (\overline{G_3} G_2 + G_3 \overline{G_2}) \\
 &= (G_1 \oplus G_0) (\overline{G_3} \oplus \overline{G_2}) + (\overline{G_1} \oplus \overline{G_0}) (G_3 \oplus G_2) \\
 &= G_0 \oplus G_1 \oplus G_2 \oplus G_3
 \end{aligned}$$

$B_0 = G_0 \oplus B_1$

## Logic Diagram:



# What is a Multiplexer (MUX)?

- A MUX is a digital switch that has multiple inputs (sources) and a single output (destination).
- The select lines determine which input is connected to the output.
- MUX Types
  - 2-to-1 (1 select line)
  - 4-to-1 (2 select lines)
  - 8-to-1 (3 select lines)
  - 16-to-1 (4 select lines)

Multiplexer  
Block Diagram



# Typical Application of a MUX



# Multiplexer/Demultiplexers

Multiplexing means Generally a ( $n : 1$ ) multiplexer or a data selector contains the following:

1.  $n$  number of inputs of the multiplexer
2. only one output of the multiplexer
3.  $m$  select/Address lines
4. one strobe/enable input (optional)



All inputs and outputs should be purely logical or binary input.

For  $n : 1$  multiplexer, each input will be selected at the single output at any instant of time, depends upon the input applied to the select/address inputs. Switching circuit connects a particular input to the output.

Here  $m$  and  $n$  are related by  $2^m = n$

# Design of a 2/1 Mux

- 2/1 mux Block Diagram



- Truth Table

| $S$ | $D_1$ | $D_0$ | $O$ |
|-----|-------|-------|-----|
| 0   | 0     | 0     | 0   |
| 0   | 0     | 1     | 1   |
| 0   | 1     | 0     | 0   |
| 0   | 1     | 1     | 1   |
| 1   | 0     | 0     | 0   |
| 1   | 0     | 1     | 0   |
| 1   | 1     | 0     | 1   |
| 1   | 1     | 1     | 1   |



# 4-to-1 Multiplexer (MUX)



| B | A | Y     |
|---|---|-------|
| 0 | 0 | $D_0$ |
| 0 | 1 | $D_1$ |
| 1 | 0 | $D_2$ |
| 1 | 1 | $D_3$ |

# 4-to-1 Multiplexer Waveforms



# Medium Scale Integration MUX

4-to-1 MUX

Inputs {  
Select {  
Enable ↗

} Output (Y)  
(and inverted output)

8-to-1 MUX



16-to-1 MUX



**When two or more MUX are enclosed with in single chip**

Selection and enable inputs in multiple unit IC may be common to all multiplexers. A Quadruple 2 to 1 line multiplexer IC is shown here.

It has 4 MUX each capable of selecting one of 2 input lines.

O/P Y1 can be selected to be equal to either A1 or B1..similarly others



Function table

| $E$ | $S$ | Output $Y$ |
|-----|-----|------------|
| 1   | $X$ | all 0's    |
| 0   | 0   | select $A$ |
| 0   | 1   | select $B$ |

# Boolean Function Implementation

For implementing any Boolean function of n variable with  $2^n$  to 1 MUX is possible. However more optimize way is also there.

If we have Boolean function of  $n+1$  variable then out of it 1 is used for input data and rest n are used as select I/P.

If A is a single variable then input of MUX are to be chosen either A or  $A'$  or 1 or 0.

By judicious use of these four values to inputs and others as select I/P variables one can implement any Boolean function of  $n+1$  variables using  $2^n$  to 1 MUX.

$$F(A, B, C) = \Sigma(1, 3, 5, 6)$$

|      | $I_0$ | $I_1$ | $I_2$ | $I_3$ |
|------|-------|-------|-------|-------|
| $A'$ | 0     | 1     | 2     | 3     |
| $A$  | 4     | 5     | 6     | 7     |
|      | 0     | 1     | $A$   | $A'$  |

(c) Implementation table



(a) Multiplexer implementation

| Minterm | $A$ | $B$ | $C$ | $F$ |
|---------|-----|-----|-----|-----|
| 0       | 0   | 0   | 0   | 0   |
| 1       | 0   | 0   | 1   | 1   |
| 2       | 0   | 1   | 0   | 0   |
| 3       | 0   | 1   | 1   | 1   |
| 4       | 1   | 0   | 0   | 0   |
| 5       | 1   | 0   | 1   | 1   |
| 6       | 1   | 1   | 0   | 1   |
| 7       | 1   | 1   | 1   | 0   |

(b) Truth table

$$F(A, B, C) = \Sigma(1, 2, 4, 5)$$

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

(a) Truth table



(b) Multiplexer implementation

|      | $I_0$ | $I_1$ | $I_2$ | $I_3$ |
|------|-------|-------|-------|-------|
| $C'$ | 0     | (2)   | (4)   | 6     |
| $C$  | (1)   | 3     | (5)   | 7     |
|      | $C$   | $C'$  | 1     | 0     |

(c) Implementation table

Implement the following function with a multiplexer:

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

|      | $I_0$ | $I_1$ | $I_2$ | $I_3$ | $I_4$ | $I_5$ | $I_6$ | $I_7$ |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| $A'$ | ①     | ②     | 2     | ③     | ④     | 5     | 6     | 7     |
| $A$  | ⑧     | ⑨     | 10    | 11    | 12    | 13    | 14    | ⑯     |
|      | 1     | 1     | 0     | $A'$  | $A'$  | 0     | 0     | $A$   |



# Higher order MUX 8:1 MUX using 4:1 MUXs



**GROW**

## 8:1 MUX using two 4:1 MUX



| S2 | S1 | S0 | Y              |
|----|----|----|----------------|
| 0  | 0  | 0  | I <sub>0</sub> |
| 0  | 0  | 1  | I <sub>1</sub> |
| 0  | 1  | 0  | I <sub>2</sub> |
| 0  | 1  | 1  | I <sub>3</sub> |
| 1  | 0  | 0  | I <sub>4</sub> |
| 1  | 0  | 1  | I <sub>5</sub> |
| 1  | 1  | 0  | I <sub>6</sub> |
| 1  | 1  | 1  | I <sub>7</sub> |

$$\begin{aligned} n &= 8 \\ 8/4 &= 2 \\ \downarrow 2/4 &= 0.5 \end{aligned}$$

**= 2.5**

LEARN

# 16:1 MUX using 4:1 MUX





16:1 MUX using 8:1  
MUX

# What is a Demultiplexer (DEMUX)?

- A DEMUX is a digital switch with a single input (source) and a multiple outputs (destinations).
- The select lines determine which output the input is connected to.
- DEMUX Types
  - 1-to-2 (1 select line)
  - 1-to-4 (2 select lines)
  - 1-to-8 (3 select lines)
  - 1-to-16 (4 select lines)



# Typical Application of a DEMUX



# 1: 2 Demux



| Enable | Select | Output          |                 |
|--------|--------|-----------------|-----------------|
| E      | S      | Y <sub>0</sub>  | Y <sub>1</sub>  |
| 0      | x      | 0               | 0               |
| 1      | 0      | 0               | D <sub>in</sub> |
| 1      | 1      | D <sub>in</sub> | 0               |

x = Don't care



# 1-to-4 Demultiplexer (DeMUX)



| B | A | D0 | D1 | D2 | D3 |
|---|---|----|----|----|----|
| 0 | 0 | X  | 0  | 0  | 0  |
| 0 | 1 | 0  | X  | 0  | 0  |
| 1 | 0 | 0  | 0  | X  | 0  |
| 1 | 1 | 0  | 0  | 0  | X  |

# 1-to-4 De-Multiplexer Waveforms



# 1:8 Demux with Enable Input



# Medium Scale Integration DEMUX

1-to-4 DEMUX



1-to-8 DEMUX



16-to-1 MUX



Note : Most Medium Scale Integrated (MSI) DEMUXs , like the three shown, have outputs that are inverted. This is done because it requires few logic gates to implement DEMUXs with inverted outputs rather than no-inverted outputs.

# Demultiplexer Tree 1:4 using 1:2 Demux

Truth Table

| $S_1$ | $S_0$ | $Y_3$    | $Y_2$    | $Y_1$    | $Y_0$    |
|-------|-------|----------|----------|----------|----------|
| 0     | 0     | 0        | 0        | 0        | $D_{in}$ |
| 0     | 1     | 0        | 0        | $D_{in}$ | 0        |
| 1     | 0     | 0        | $D_{in}$ | 0        | 0        |
| 1     | 1     | $D_{in}$ | 0        | 0        | 0        |



# 1:8 DeMUX Using 1:4



# Full Adder using 1:8 De MUX

GROW



$$D(x,y,z) = \Sigma m(1,2,4,7)$$

$$B(x,y,z) = \Sigma m(1,2,3,7)$$

Din = 1



LEARN

Draw 1:64 demultiplexer using 1:16 demux and 1: 4 demux

# Comparator



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



# 2-Bit Magnitude Comparator

Table 1. Truth Table of 2-Bit Magnitude Comparator

| INPUT          |                |                |                | OUTPUT |     |     |
|----------------|----------------|----------------|----------------|--------|-----|-----|
| A <sub>1</sub> | A <sub>0</sub> | B <sub>1</sub> | B <sub>0</sub> | A>B    | A=B | A<B |
| 0              | 0              | 0              | 0              | 0      | 1   | 0   |
| 0              | 0              | 0              | 1              | 0      | 0   | 1   |
| 0              | 0              | 1              | 0              | 0      | 0   | 1   |
| 0              | 0              | 1              | 1              | 0      | 0   | 1   |
| 0              | 1              | 0              | 0              | 1      | 0   | 0   |
| 0              | 1              | 0              | 1              | 0      | 1   | 0   |
| 0              | 1              | 1              | 0              | 0      | 0   | 1   |
| 0              | 1              | 1              | 1              | 0      | 0   | 1   |
| 1              | 0              | 0              | 0              | 1      | 0   | 0   |
| 1              | 0              | 0              | 1              | 1      | 0   | 0   |
| 1              | 0              | 1              | 0              | 0      | 1   | 0   |
| 1              | 0              | 1              | 1              | 0      | 0   | 1   |
| 1              | 1              | 0              | 0              | 1      | 0   | 0   |
| 1              | 1              | 0              | 1              | 1      | 0   | 0   |
| 1              | 1              | 1              | 0              | 1      | 0   | 0   |
| 1              | 1              | 1              | 1              | 0      | 1   | 0   |



|    |    | f(A>B)                        |    |    |    |    |
|----|----|-------------------------------|----|----|----|----|
|    |    | B <sub>1</sub> B <sub>0</sub> | 00 | 01 | 11 | 10 |
|    |    | A <sub>1</sub> A <sub>0</sub> | 00 | 01 | 11 | 10 |
| 00 | 00 |                               | 0  | 0  | 0  | 0  |
| 01 | 01 |                               | 1  | 0  | 0  | 0  |
| 11 | 11 |                               | 1  | 1  | 0  | 1  |
| 10 | 10 |                               | 1  | 1  | 0  | 0  |

We get the equation as f(A>B)

$$= A_1 \bar{B}_1 + A_0 \bar{B}_1 \bar{B}_0 + A_1 A_0 \bar{B}_0$$

K-Map for A<B:

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

For A<B

$$Y_1 = \overline{A_1} \overline{A_0} B_0 + \overline{A_1} B_1 + \overline{A_0} B_1 B_0$$

K-Map for A=B:

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

For A=B

$$Y_2 = \overline{A_1} \overline{A_0} \overline{B}_1 \overline{B}_0 + \overline{A_1} A_0 \overline{B}_1 B_0 + A_1 A_0 B_1 B_0 + A_1 \overline{A_0} B_1 \overline{B}_0$$

# Binary Serial Adder

Let Register-1 hold the first number and register 2 holds the other no.

The D FF is cleared initially so Q=0 and Cin= 0.

The serial o/p (SO) of the two registers will provide the LSBs of the two number. They will act bits a and b for full adder.

The FA will add these bits and produce sum and carry out Co.

Thus addition of LSB is complete.

Now a clock pulse is applied to both the shift registers.

Hence the two numbers are right shifted by one bit each.



The clock pulse gets applied to the D FF also and  $Q = Cin = Cout = 0$ .

The adder adds the two bits available at the SO outputs of the two registers

## Advantages

The addition of a pair of bits only takes place at any instant of time

(n-1) number of clock cycles are required to complete the addition

The process of addition continues until the shift right control is disabled

Sum is available in the serial form

## Drawback

- i) More time is required to complete the addition
- ii) A complicated ckt is required
- iii) The ckt contains more no of components
- iv) The Sum and Carry are available in the serial form  
hence result can't be observed at once.

Fig: Serial Adder



Serial Adder

# Binary Parallel Adder

A Binary Parallel adder is a digital function that produces the arithmetic sum of two binary numbers in parallel.



N-Bit Parallel Adder

# BCD to Excess 3 Code Converter

- Example:– BCD to excess-1 code converter



$$\begin{aligned}A &= \text{BCS Code} \\B &= 0011\end{aligned}$$

# Cascading of Adders



Fig2. Cascading of two IC 7483s

- ▶ The addition of two binary numbers in parallel implies that all the bits of the **augend** and the addend are available for computation at the same time.
- ▶ As in any combinational circuit, the signal must propagate through gates before the correct output sum is available in output terminals.
- ▶ The total propagation time is equal to the propagation delay of typical gate times the number of gate levels in the circuit.
- ▶ The longest propagation delay time in a parallel adder is the time it takes the carry to propagate through the full-adders

- ▶ The number of gate levels for the carry propagation can be found from the circuit of the full adder.
- ▶ The signal from the carry ( $C_i$ ) to the output carry ( $C_{i+1}$ ) propagates through 2 gate levels



- ▶ If there are four full-adders in the parallel adder, the output carry C5 would have  $2*4=8$  gate levels from C1 to C5.
- ▶ The total propagation time in the adder would be the propagation time in one half adder plus eight gate levels.
- ▶ For an n-bit parallel adder, there are  $2n$  gate levels for the carry to propagate through.
- ▶ The carry propagation time is a limiting factor on the speed with which two numbers are added in parallel.

- ▶ All other arithmetic operations are implemented by successive additions, the time consumed during the addition process is very critical.
- ▶ One way to reduce the carry propagation delay time is to employ faster gates with reduced delays
- ▶ Another solution is to increase the equipment complexity in such a way that the carry delay time is reduced.
- ▶ The most widely used technique employs the principle of look-ahead carry.

- ▶ Look-ahead carry
- ▶ If we define two variables:

$$P_i = A_i \oplus B_i$$
$$G_i = A_i B_i$$

- ▶  $G_i$  is called a carry generated and it produced an output carry when both  $A_i$  and  $B_i$  one.
- ▶  $P_i$  is called a carry propagate because it is the term associated with the propagation of the carry  $C_i$  to  $C_{i+1}$
- ▶ The output sum and carry can be expressed as:

$$S_i = P_i \oplus C_i$$
$$\underline{C_{i+1} = G_i + P_i C_i}$$

- The boolean functions for the carry output of each stage are:

$$C_3 = \bar{C}_2 = C_{in}$$

Look Ahead carry

$$C_2 = G_1 + P_1 C_1$$

$$C_3 = G_2 + P_2 C_2 = G_2 + P_2(G_1 + P_1 C_1) = G_2 + P_2 G_1 + P_2 P_1 C_1$$

$P_i \neq A_i, Q_i$

$$C_4 = G_3 + P_3 C_3 = G_3 + P_3 G_2 + P_3 P_2 G_1 + P_3 P_2 P_1 C_1$$

---

## ▶ Circuit diagram of a look-ahead carry generator



# Binary Parallel Subtractor



$$\begin{aligned} A - B \\ A + (-B) \end{aligned}$$

## BCD Adder

| Decimal | Binary Sum |                  |                  |                  |                  | BCD Sum |                |                |                |                |
|---------|------------|------------------|------------------|------------------|------------------|---------|----------------|----------------|----------------|----------------|
|         | C'         | S <sub>3</sub> ' | S <sub>2</sub> ' | S <sub>1</sub> ' | S <sub>0</sub> ' | C       | S <sub>3</sub> | S <sub>2</sub> | S <sub>1</sub> | S <sub>0</sub> |
| 0       | 0          | 0                | 0                | 0                | 0                | 0       | 0              | 0              | 0              | 0              |
| 1       | 0          | 0                | 0                | 0                | 1                | 0       | 0              | 0              | 0              | 1              |
| 2       | 0          | 0                | 0                | 1                | 0                | 0       | 0              | 0              | 1              | 0              |
| 3       | 0          | 0                | 0                | 1                | 1                | 0       | 0              | 0              | 1              | 1              |
| 4       | 0          | 0                | 1                | 0                | 0                | 0       | 0              | 1              | 0              | 0              |
| 5       | 0          | 0                | 1                | 0                | 1                | 0       | 0              | 1              | 0              | 1              |
| 6       | 0          | 0                | 1                | 1                | 0                | 0       | 0              | 1              | 1              | 0              |
| 7       | 0          | 0                | 1                | 1                | 1                | 0       | 0              | 1              | 1              | 1              |
| 8       | 0          | 1                | 0                | 0                | 0                | 0       | 1              | 0              | 0              | 0              |
| 9       | 0          | 1                | 0                | 0                | 1                | 0       | 1              | 0              | 0              | 1              |
| 10      | 0          | 1                | 0                | 1                | 0                | 1       | 0              | 0              | 0              | 0              |
| 11      | 0          | 1                | 0                | 0                | 1                | 1       | 1              | 0              | 0              | 1              |
| 12      | 0          | 1                | 1                | 0                | 0                | 1       | 0              | 0              | 1              | 0              |
| 13      | 0          | 1                | 1                | 0                | 1                | 1       | 0              | 0              | 1              | 1              |
| 14      | 0          | 1                | 1                | 1                | 0                | 1       | 0              | 1              | 0              | 0              |
| 15      | 0          | 1                | 1                | 1                | 1                | 1       | 0              | 1              | 0              | 1              |
| 16      | 1          | 0                | 0                | 0                | 0                | 1       | 0              | 1              | 1              | 0              |
| 17      | 1          | 0                | 0                | 0                | 1                | 1       | 0              | 1              | 1              | 1              |
| 18      | 1          | 0                | 0                | 1                | 0                | 1       | 1              | 0              | 0              | 0              |
| 19      | 1          | 0                | 0                | 1                | 1                | 1       | 1              | 0              | 0              | 1              |

Sum<9, O/P will be taken as it is  
 Sum>9, 6 is to be added in the sum  
 then final O/P will be taken,

$$C = C' + S_3'S_2' + S_3'S_1'$$



10-19



# Decoders

**Decoder** is a combinational circuit that has 'n' input lines and maximum of  $2^n$  output lines.

One of these outputs will be active High based on the combination of inputs present, when the decoder is enabled.

That means decoder detects a particular code. The outputs of the decoder are nothing but the **min terms** of 'n' input variables lines, when it is enabled.

## 2 to 4 Decoder



$$\text{MUX} \rightarrow D/P \rightarrow \underline{I}$$
$$\text{DEMUX} \rightarrow \underline{I} \cancel{\oplus} J/P$$

One of these four outputs will be '1' for each combination of inputs when enable, E is '1'.  
The **Truth table** of 2 to 4 decoder is shown below.

| Enable | Inputs |                | Outputs        |                |                |                |
|--------|--------|----------------|----------------|----------------|----------------|----------------|
|        | E      | A <sub>1</sub> | A <sub>0</sub> | Y <sub>3</sub> | Y <sub>2</sub> | Y <sub>1</sub> |
| 0      | x      | x              | 0              | 0              | 0              | 0              |
| 1      | 0      | 0              | 0              | 0              | 0              | 1              |
| 1      | 0      | 1              | 0              | 0              | 1              | 0              |
| 1      | 1      | 0              | 0              | 1              | 0              | 0              |
| 1      | 1      | 1              | 1              | 0              | 0              | 0              |

From Truth table, we can write the **Boolean functions** for each output as

$$Y_3 = E \cdot A_1 \cdot A_0$$

$$Y_2 = E \cdot A_1 \cdot A_0' \quad Y = E \cdot A_1 \cdot A_0'$$

$$Y_1 = E \cdot A_1' \cdot A_0 \quad Y_1 = E \cdot A_1' \cdot A_0$$

$$Y_0 = E \cdot A_1' \cdot A_0'$$

Each output is having one product term. So, there are four product terms in total. We can implement these four product terms by using four AND gates having three inputs each & two inverters. The **circuit diagram** of 2 to 4 decoder is shown in the following figure.



Therefore, the outputs of 2 to 4 decoder are nothing but the **min terms** of two input variables  $A_1$  &  $A_0$ , when enable, E is equal to one. If enable, E is zero, then all the outputs of decoder will be equal to zero.

Similarly, 3 to 8 decoder produces eight min terms of three input variables  $A_2$ ,  $A_1$  &  $A_0$  and 4 to 16 decoder produces sixteen min terms of four input variables  $A_3$ ,  $A_2$ ,  $A_1$  &  $A_0$ .

### **Implementation of Higher-order Decoders**

let us implement the following two higher-order decoders using lower-order decoders.

- 3 to 8 decoder
- 4 to 16 decoder

# 3 to 8 Decoder

- In this section, let us implement **3 to 8 decoder using 2 to 4 decoders**. We know that 2 to 4 Decoder has two inputs,  $A_1$  &  $A_0$  and four outputs,  $Y_3$  to  $Y_0$ . Whereas, 3 to 8 Decoder has three inputs  $A_2$ ,  $A_1$  &  $A_0$  and eight outputs,  $Y_7$  to  $Y_0$ .
- We can find the number of lower order decoders required for implementing higher order decoder using the following formula.

Required number of lower order decoders=  $m_2/m_1$

Where,

$m_1$  is the number of outputs of lower order decoder.

$m_2$  is the number of outputs of higher order decoder.

Here,  $m_1 = 4$  and  $m_2 = 8$ .

Substitute, these two values in the above formula.

Required number of 2to4 decoders= $8/4=2$

- Therefore, we require two 2 to 4 decoders for implementing one 3 to 8 decoder. The **block diagram** of 3 to 8 decoder using 2 to 4 decoders is shown in the following figure.

- 



The parallel inputs  $A_1$  &  $A_0$  are applied to each 2 to 4 decoder. The complement of input  $A_2$  is connected to Enable, E of lower 2 to 4 decoder in order to get the outputs,  $Y_3$  to  $Y_0$ . These are the **lower four min terms**. The input,  $A_2$  is directly connected to Enable, E of upper 2 to 4 decoder in order to get the outputs,  $Y_7$  to  $Y_4$ . These are the **higher four min terms**.

| Inputs |       |       | Outputs |       |       |       |       |       |       |       |       |
|--------|-------|-------|---------|-------|-------|-------|-------|-------|-------|-------|-------|
| EN     | $A_2$ | $A_1$ | $A_0$   | $Y_7$ | $Y_6$ | $Y_5$ | $Y_4$ | $Y_3$ | $Y_2$ | $Y_1$ | $Y_0$ |
| 0      | x     | x     | x       | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| 1      | 0     | 0     | 0       | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 1     |
| 1      | 0     | 0     | 1       | 0     | 0     | 0     | 0     | 0     | 0     | 1     | 0     |
| 1      | 0     | 1     | 0       | 0     | 0     | 0     | 0     | 0     | 1     | 0     | 0     |
| 1      | 0     | 1     | 1       | 0     | 0     | 0     | 0     | 1     | 0     | 0     | 0     |
| 1      | 1     | 0     | 0       | 0     | 0     | 0     | 1     | 0     | 0     | 0     | 0     |
| 1      | 1     | 0     | 1       | 0     | 0     | 1     | 0     | 0     | 0     | 0     | 0     |
| 1      | 1     | 1     | 0       | 0     | 1     | 0     | 0     | 0     | 0     | 0     | 0     |
| 1      | 1     | 1     | 1       | 1     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

## 4 to 16 Decoder

In this section, let us implement **4 to 16 decoder using 3 to 8 decoders**. We know that 3 to 8 Decoder has three inputs  $A_2$ ,  $A_1$  &  $A_0$  and eight outputs,  $Y_7$  to  $Y_0$ . Whereas, 4 to 16 Decoder has four inputs  $A_3$ ,  $A_2$ ,  $A_1$  &  $A_0$  and sixteen outputs,  $Y_{15}$  to  $Y_0$ .

formula for finding the number of lower order decoders required.

Required number of lower order decoders=  $\frac{m_2}{m_1}$

Required number of 3 to 8 decoders=  $\frac{16}{8} = 2$

$$\begin{array}{r} 2 \text{ to } 4 \\ 8 \text{ to } 16 \\ 4 \text{ to } 16 \\ \hline 4 \end{array}$$

(4) (2 to 8<sub>1</sub>) decoder



# Encoder

An **Encoder** is a combinational circuit that performs the reverse operation of Decoder. It has maximum of  $2^n$  input lines and 'n' output lines. It will produce a binary code equivalent to the input, which is active High. Therefore, the encoder encodes  $2^n$  input lines with 'n' bits. It is optional to represent the enable signal in encoders.

## 4 to 2 Encoder

Let 4 to 2 Encoder has four inputs  $Y_3, Y_2, Y_1$  &  $Y_0$  and two outputs  $A_1$  &  $A_0$ . The **block diagram** of 4 to 2 Encoder is shown in the following figure.



At any time, only one of these 4 inputs can be '1' in order to get the respective binary code at the output. The Truth table of 4 to 2 encoder is shown below.

| Inputs |       |       |       | Outputs |       |
|--------|-------|-------|-------|---------|-------|
| $Y_3$  | $Y_2$ | $Y_1$ | $Y_0$ | $A_1$   | $A_0$ |
| 0      | 0     | 0     | 1     | 0       | 0     |
| 0      | 0     | 1     | 0     | 0       | 1     |
| 0      | 1     | 0     | 0     | 1       | 0     |
| 1      | 0     | 0     | 0     | 1       | 1     |



From Truth table, we can write the **Boolean functions** for each output as

$$\cancel{A_1} = Y_3 + Y_2$$

$$A_0 = Y_3 + Y_1$$

We can implement the above two Boolean functions by using two input OR gates.



D  
L  
—  
—>

3  
2  
8 → 2 —

## Octal to Binary Encoder

Octal to binary Encoder has eight inputs, Y<sub>7</sub> to Y<sub>0</sub> and three outputs A<sub>2</sub>, A<sub>1</sub> & A<sub>0</sub>. Octal to binary encoder is nothing but 8 to 3 encoder.

The **block diagram** of octal to binary Encoder is

At any time, only one of these eight inputs can be '1' in order to get the respective binary code. The **Truth table** of octal to binary encoder is shown below.

| Inputs |       |       |       |       |       |       |       | Outputs |       |       |
|--------|-------|-------|-------|-------|-------|-------|-------|---------|-------|-------|
| $Y_7$  | $Y_6$ | $Y_5$ | $Y_4$ | $Y_3$ | $Y_2$ | $Y_1$ | $Y_0$ | $A_2$   | $A_1$ | $A_0$ |
| 0      | 0     | 0     | 0     | 0     | 0     | 0     | 1     | 0       | 0     | 0     |
| 0      | 0     | 0     | 0     | 0     | 0     | 1     | 0     | 0       | 0     | 1     |
| 0      | 0     | 0     | 0     | 0     | 1     | 0     | 0     | 0       | 1     | 0     |
| 0      | 0     | 0     | 0     | 1     | 0     | 0     | 0     | 0       | 1     | 1     |
| 0      | 0     | 0     | 1     | 0     | 0     | 0     | 0     | 1       | 0     | 0     |
| 0      | 0     | 1     | 0     | 0     | 0     | 0     | 0     | 1       | 0     | 1     |
| 0      | 1     | 0     | 0     | 0     | 0     | 0     | 0     | 1       | 1     | 0     |
| 1      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 1       | 1     | 1     |



From Truth table, we can write the **Boolean functions** for each output as

$$\cancel{A_2} = Y_7 + Y_6 + Y_5 + Y_4 \quad A_2 = Y_7 + Y_6 + Y_5 + Y_4$$

$$A_1 = Y_7 + Y_6 + Y_3 + Y_2 \quad A_1 = Y_7 + Y_6 + Y_3 + Y_2$$

$$\cancel{A_0} = Y_7 + Y_5 + Y_3 + Y_1 \quad A_0 = Y_7 + Y_5 + Y_3 + Y_1$$



# Drawbacks of Encoder

Following are the drawbacks of normal encoder.

- There is an ambiguity, when all outputs of encoder are equal to zero. Because, it could be the code corresponding to the inputs, when only least significant input is one or when all inputs are zero.
- If more than one input is active High, then the encoder produces an output, which may not be the correct code. For **example**, if both  $Y_3$  and  $Y_6$  are '1', then the encoder produces 111 at the output. This is neither equivalent code corresponding to  $Y_3$ , when it is '1' nor the equivalent code corresponding to  $Y_6$ , when it is '1'.

To overcome these difficulties, we should assign priorities to each input of encoder. Then, the output of encoder will be the binary code corresponding to the active High inputs, which has higher priority. This encoder is called as **priority encoder**.

*Y<sub>3</sub> P<sub>6</sub>* →

## Priority Encoder

A 4 to 2 priority encoder has four inputs  $Y_3$ ,  $Y_2$ ,  $Y_1$  &  $Y_0$  and two outputs  $A_1$  &  $A_0$ . Here, the input,  $Y_3$  has the highest priority, whereas the input,  $Y_0$  has the lowest priority.

In this case, even if more than one input is '1' at the same time, the output will be the binary code corresponding to the input, which is having **higher priority**.

- We considered one more **output**,  $V$  in order to know, whether the code available at outputs is valid or not.
- If at least one input of the encoder is '1', then the code available at outputs is a valid one. In this case, the output,  $V$  will be equal to 1.
- If all the inputs of encoder are '0', then the code available at outputs is not a valid one. In this case, the output,  $V$  will be equal to 0.



The **Truth table** of 4 to 2 priority encoder is shown below.

| Inputs |       |       |       | Outputs |       |     |
|--------|-------|-------|-------|---------|-------|-----|
| $Y_3$  | $Y_2$ | $Y_1$ | $Y_0$ | $A_1$   | $A_0$ | $V$ |
| 0      | 0     | 0     | 0     | 0       | 0     | 0   |
| 0      | 0     | 0     | 1     | 0       | 0     | 1   |
| 0      | 0     | 1     | x     | 0       | 1     | 1   |
| 0      | 1     | x     | x     | 1       | 0     | 1   |
| 1      | x     | x     | x     | 1       | 1     | 1   |



The simplified **Boolean functions** are

~~$$A_1 = Y_3 + Y_2 \quad A_1 = Y_3 + Y_2$$~~

~~$$A_0 = Y_3 + Y_2' \quad A_0 = Y_3 + Y_2' Y_1$$~~

Similarly, we will get the Boolean function of output,  $V$  as

~~$$V = Y_3 + Y_2 + Y_1 + Y_0$$~~

The circuit diagram contains two 2-input OR gates, one 4-input OR gate, one 2input AND gate & an inverter. Here AND gate & inverter combination are used for producing a valid code at the outputs, even when multiple inputs are equal to '1' at the same time. Hence, this circuit encodes the four inputs with two bits based on the **priority** assigned to each input.



*THANK YOU*