

# DIGITAL SYSTEM DESIGN

- MANVITH PRABHU

# EC200

## Basic Logic gates

1) AND:   $y = a \cdot b$

Truth Table :

| Input |   | Output |
|-------|---|--------|
| a     | b | y      |
| 0     | 0 | 0      |
| 0     | 1 | 0      |
| 1     | 0 | 0      |
| 1     | 1 | 1      |

2) OR:   $y = a + b$

Truth Table :

| Input |   | Output |
|-------|---|--------|
| a     | b | y      |
| 0     | 0 | 0      |
| 0     | 1 | 1      |
| 1     | 0 | 1      |
| 1     | 1 | 1      |

3) NOT:   $y = \bar{a}$

| a | y |
|---|---|
| 0 | 1 |
| 1 | 0 |

## Derived gates

1) NAND:   $y = \overline{a \cdot b}$

Truth table:

| Input |   | Output |
|-------|---|--------|
| a     | b | y      |
| 0     | 0 | 1      |
| 0     | 1 | 1      |
| 1     | 0 | 1      |
| 1     | 1 | 0      |

2>

NOR:   $y = \overline{a+b}$

Truth table

| Input |   | Output |
|-------|---|--------|
| a     | b | y      |
| 0     | 0 | 1      |
| 0     | 1 | 0      |
| 1     | 0 | 0      |
| 1     | 1 | 0      |

- NAND and NOR are universal gates.
- If number of gate counts are similar, we use NAND or NOR.



## Designing basic gates using universal gates.

1) Using NAND gate: i) NOT:  $a \rightarrow \square \rightarrow \bar{a}$

ii) AND:  $\begin{array}{c} a \\ b \end{array} \rightarrow \square \rightarrow \square \rightarrow a \cdot b$

iii) OR:  $\begin{array}{c} a \\ b \end{array} \rightarrow \square \rightarrow \bar{a} \quad \begin{array}{c} \bar{a} \\ \bar{b} \end{array} \rightarrow \square \rightarrow a + b$  i.e.  $\overline{\bar{a} \cdot \bar{b}} = a + b$

2) Using NOR gate: i) NOT:  $a \rightarrow \square \rightarrow \bar{a}$

ii) AND:  $\begin{array}{c} a \\ b \end{array} \rightarrow \square \rightarrow \bar{a} \quad \begin{array}{c} \bar{a} \\ \bar{b} \end{array} \rightarrow \square \rightarrow a \cdot b$  i.e.  $\overline{\bar{a} + \bar{b}} = a \cdot b$

iii) OR:  $\begin{array}{c} a \\ b \end{array} \rightarrow \square \rightarrow \square \rightarrow a + b$

## Exclusive gates

i) XOR gate:  $\begin{array}{c} a \\ b \end{array} \rightarrow \square \rightarrow a \oplus b = y$ ,  $a \oplus b = \bar{a}b + a\bar{b}$

Truth table :

| Input |   | Output |
|-------|---|--------|
| a     | b | y      |
| 0     | 0 | 0      |
| 0     | 1 | 1      |
| 1     | 0 | 1      |
| 1     | 1 | 0      |

ii) XNOR gate:  $\begin{array}{c} a \\ b \end{array} \rightarrow \square \rightarrow y = a \odot b$ ,  $a \odot b = ab + \bar{a}\bar{b}$

Truth table:

| Input |   | Output |
|-------|---|--------|
| a     | b | y      |
| 0     | 0 | 1      |
| 0     | 1 | 0      |
| 1     | 0 | 0      |
| 1     | 1 | 1      |

Implementation of XOR using NAND:

NOTE: Du Morgan's law:  
 1)  $\overline{a \cdot b} = \overline{a} + \overline{b}$   
 2)  $\overline{a+b} = \overline{a} \cdot \overline{b}$

$$\text{We have } y = a \oplus b = \overline{\overline{ab} + a\overline{b}} = \overline{(\overline{ab}) \cdot (\overline{a}\overline{b})}$$



$$\begin{aligned} \text{Also we have } y &= a \oplus b = \overline{a \oplus b} = \overline{ab + \overline{ab}} \\ &= \overline{ab} \cdot \overline{\overline{ab}} \\ &= \overline{ab} \cdot (a + b) \\ &= \overline{ab} \cdot a + \overline{ab} \cdot b \\ &= (\overline{ab} \cdot a) \cdot (\overline{ab} \cdot b) \end{aligned}$$

$\Rightarrow$



## Conversion of number systems

1)  $(17)_{10} = (?)_2$

$$\begin{array}{r}
 2 \Big| 17 \\
 2 \Big| 8 - 1 \\
 2 \Big| 4 - 0 \\
 2 \Big| 2 - 0 \\
 1 - 0
 \end{array}
 \Rightarrow (10001)_2$$

2)  $(0.17)_{10} = (?)_2$

$$0.17 \times 2 = 0.34 \rightarrow 0$$

$$0.34 \times 2 = 0.68 \rightarrow 0$$

$$0.68 \times 2 = 1.36 \rightarrow 1$$

$$0.36 \times 2 = 0.72 \rightarrow 0$$

$$0.72 \times 2 = 1.44 \rightarrow 1$$

$$\Rightarrow (0.00101\dots)_2 //$$

## Representation of negative numbers

Sigm magnitude method: MSB = 1  $\Rightarrow$  -ve number  
MSB = 0  $\Rightarrow$  +ve number

$$\begin{aligned}(-7)_{10} &= (111)_2 \\(6)_{10} &= (0110)_2\end{aligned}$$

compliment system: Radix complement  $\rightarrow$  2's complement  
Diminished Radix complement  $\rightarrow$  1's complement.

Boolean laws:

- 1)  $X + 0 = X \quad X \cdot 1 = X$   
 $X + 1 = 1 \quad X \cdot 0 = 0$
- 2) Idempotent laws:  $X + X = X \quad X \cdot X = X$
- 3) Involution law:  $(\overline{\overline{X}}) = X$
- 4) Laws of complementarity:  $X + \overline{X} = 1 \quad X \cdot \overline{X} = 0$
- 5) Commutative law:  $X + Y = Y + X \quad XY = YX$
- 6) Distributive laws:  $X(Y+Z) = XY + XZ \quad X+YZ = (X+Y)(X+Z)$
- 7) Simplification theorem:  $XY + X\overline{Y} = X \quad (X+Y)(X+\overline{Y}) = X$   
 $X + XY = X$   
 $(X + \overline{Y})Y = XY$   
 $X\overline{Y} + Y = X+Y$
- 8) De Morgan's laws:  $\overline{(XYZ\dots)} = \overline{X} + \overline{Y} + \overline{Z} + \dots$   
 $\overline{(X+Y+Z+\dots)} = \overline{X}\overline{Y}\overline{Z}\dots$
- 9) Duality:  $(X+Y+Z+\dots)^D = XYZ\dots \quad (XYZ\dots)^D = X+Y+Z+\dots$

10) Consensus theorem:

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

ii)  $(X+Y)(Y+Z)(X'+Z) = (X+Y)(X'+Z)$

iii) Proof:  $XY + X'Z + (X+X')YZ$   
=  $XY + X'Z + XYZ + X'YZ$   
=  $XY(1+Z) + X'Z(1+Y)$   
=  $XY + X'Z$ ,

11) Theorem for multiplying out and factoring out  
 $(X+Y)(X'+Z) = XZ + X'Y$   
 $XY + X'Z = (X+Z)(X'+Y)$

# Laws and Theorems of Boolean Algebra

Operations with 0 and 1:

$$1. X + 0 = X$$

$$2. X + 1 = 1$$

$$1D. X \cdot 1 = X$$

$$2D. X \cdot 0 = 0$$

Idempotent laws:

$$3. X + X = X$$

$$3D. X \cdot X = X$$

Involution law:

$$4. (X')' = X$$

Laws of complementarity:

$$5. X + X' = 1$$

$$5D. X \cdot X' = 0$$

Commutative laws:

$$6. X + Y = Y + X$$

$$6D. XY = YX$$

Associative laws:

$$7. (X + Y) + Z = X + (Y + Z) \\ = X + Y + Z$$

$$7D. (XY)Z = X(YZ) = XYZ$$

Distributive laws:

$$8. X(Y + Z) = XY + XZ$$

$$8D. X + YZ = (X + Y)(X + Z)$$

Simplification theorems:

$$9. XY + XY' = X$$

$$9D. (X + Y)(X + Y') = X$$

$$10. X + XY = X$$

$$10D. X(X + Y) = X$$

$$11. (X + Y')Y = XY$$

$$11D. XY' + Y = X + Y$$

DeMorgan's laws:

$$12. (X + Y + Z + \dots)' = X'Y'Z' \dots$$

$$12D. (XYZ \dots)' = X' + Y' + Z' + \dots$$

Duality:

$$13. (X + Y + Z + \dots)^D = XYZ \dots$$

$$13D. (XYZ \dots)^D = X + Y + Z + \dots$$

Theorem for multiplying out and factoring:

$$14. (X + Y)(X' + Z) = XZ + X'Y$$

$$14D. XY + X'Z = (X + Z)(X' + Y)$$

Consensus theorem:

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

$$15D. (X + Y)(Y + Z)(X' + Z) \\ = (X + Y)(X' + Z)$$

## EC200 - DIGITAL SYSTEM DESIGN

### Tutorial 1

1. For each of the following circuits, find the output and design a simpler circuit having the same output. (*Hint:* Find the circuit output by first finding the output of each gate, going from left to right, and simplifying as you go.)



2. Factor each of the following expressions to obtain a product-of-sums:

(a)  $AB + C'D'$

(b)  $WX + WY'X + ZYX$

(c)  $A'BC + EF + DEF' = (A' + E)(B + E)(C + E)(A' + F + D)(B + F + D)(C + F + D)$

(d)  $XYZ + W'Z + XQ'Z = Z(W' + X)(W' + Q' + Y)$

(e)  $ACD' + C'D' + A'C = (A' + D')(C + D')$

(f)  $A + BC + DE$

2a)  $(AB + C) \cdot (AB + D') = (C' + A)(C' + B) \cdot (D' + A) \cdot (D' + B)$

b)  $WX(1 + Y') + ZYX = WX + ZYX = X(W + ZY) = X \cdot (W + Y) \cdot (W + Z)$

f)  $(A + B + D)(A + B + E)(A + C + D)(A + C + E)$

3a&gt;



3. Draw a circuit that uses only one AND gate and one OR gate to realize each of the following functions:

$$(a) (A + B + C + D)(A + B + C + E)(A + B + C + F) = (\bar{A} + \bar{B} + \bar{C}) \cdot DEF$$

$$(b) WXYZ + VXYZ + UXYZ = XYZ \cdot (W + V + U)$$

4. Simplify the following expressions to a minimum sum of products

$$(a) [(AB)' + C'D]' = (\bar{A}\bar{B}' + \bar{C}'\bar{D})' = ((\bar{A}\bar{B}))' \cdot (\bar{C}'\bar{D})' = AB \cdot (\bar{C} + \bar{D}) = ABC + ABD,$$

$$(b) [A + B(C' + D)]' = \bar{A} \cdot \bar{B}(C + D)$$

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

5. Find F and G and simplify:



(a)



(b)

6. For each of the following Boolean (or switching) algebra expressions, indicate which, if any, of the following terms describe the expression: product term, sum-of-products, sum term, and product-of-sums. (More than one may apply.)

- $$(a) X'Y = \text{Product, SOP}$$
- $$(b) XY' + YZ = \text{SOP}$$
- $$(c) (X' + Y)(WX + Z) = \text{None}$$
- $$(d) X + Z = \text{Sum, POS, SOP}$$
- $$(e) (X' + Y)(W + Z)(X + Y' + Z') = \text{POS}$$

7. In the following circuit,  $F = (A' + B)C$ . Give a truth table for G so that H is as specified in its truth table. If G can be either 0 or 1 for some input combination, leave its value unspecified (x).

$$H = F + G$$



| A | B | C | H | F | G |
|---|---|---|---|---|---|
| 0 | 0 | 0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 1 | 1 | x |
| 0 | 1 | 0 | 1 | 0 | 1 |
| 0 | 1 | 1 | 1 | 1 | x |
| 1 | 0 | 0 | 0 | 0 | 0 |
| 1 | 0 | 1 | 1 | 0 | 1 |
| 1 | 1 | 0 | 0 | 0 | 0 |
| 1 | 1 | 1 | 1 | 1 | x |

8. Implement the Boolean function  $Y = AB + CD$  using minimum number of 2-input NAND gates.  $\rightarrow 3$  NAND gates.

$$4b> \bar{A} \cdot \overline{B(C'D)} = \bar{A} \cdot (\bar{B} + C \cdot \bar{D}) = \bar{A}\bar{B} + \bar{A}C\bar{D},$$

9. Find out all possible input combinations of A, B and C that give output  $F = 1$  for the logic circuit shown below.



| A | B | C | $A \oplus B$ | $A \otimes B$ | F |
|---|---|---|--------------|---------------|---|
| 0 | 0 | 0 | 0            | 0             | 0 |
| 0 | 0 | 1 | 0            | 0             | 1 |
| 0 | 1 | 0 | 1            | 0             | 0 |
| 0 | 1 | 1 | 1            | 1             | 1 |
| 1 | 0 | 0 | 1            | 0             | 0 |
| 1 | 0 | 1 | 1            | 0             | 0 |
| 1 | 1 | 0 | 0            | 1             | 1 |
| 1 | 1 | 1 | 0            | 0             | 0 |

10. Eliminate the redundant terms and minimize the following expressions

$$\begin{aligned}
 (a) XY + X'Z + YZ &= XY + X'Z \\
 (b) A'B' + AC + BC' + B'C + AB &= A'B' + AC + AB + BC' = A'B' + AC + BC' \\
 (c) (X + Y)(X' + Z)(Y + Z) &= (X+Y)(X'+Z) \\
 (d) (a + b + c')(a + b + d')(b + c + d') &= (a+b+c')(a+b+d') \\
 (e) A'C'D + A'BD + BCD + ABC + ACD' &= A'C'D + BCD + ABC + ACD' = (A'C'D + BCD + ACD')
 \end{aligned}$$

11. Digital input signals A, B, C with A as the MSB and C as the LSB are used to realize the Boolean function  $F = m_0 + m_2 + m_3 + m_5 + m_7$ , where  $m_i$  denotes the  $i^{th}$  minterm. In addition, F has a don't care for  $m_1$ . Find a simplified expression for F.

12. Find the minimal expression of the output Z of the logic circuit shown below



13. The output of a majority circuit is 1 if a majority (more than half) of its inputs are equal to 1, and the output is 0 otherwise. Construct a truth table for a three-input majority circuit and derive a simplified sum-of-products expression for its output.

14. Obtain the truth table of the following functions, and express each function in sum-of-minterms and product-of-maxterms form:

$$\begin{aligned}
 (a) (b + c'd)(a' + cd') &= a'b + bcd' + a'c'd \\
 (b) (ad + b'c + bd')(b + d) & \\
 (c) (b + d)(b + d')(a + c) & \\
 (d) ad + bcd + ab'c' + b'c'd' &
 \end{aligned}$$

15. Determine whether the following Boolean equation is true or false.

$$\begin{aligned}
 (a) y'z' + yz' + x'z &= x' + xz' \quad \text{True} \\
 (b) x'y' + xz' + yz &= y'z' + xy + x'z' \quad \text{False, } \text{as } x=0, y=1, z=1
 \end{aligned}$$

16. How many switching functions of two variables (x and y) are there? Give each function in truth table form and in reduced algebraic form.  $2^4$

17. Simplify the following Boolean functions to sum-of-products form using Karnaugh maps

$$\begin{aligned}
 (a) F(x, y, z) &= \sum(0, 2, 6, 7) \quad 11 \\
 (b) F(x, y, z) &= \sum(0, 2, 3, 4, 6)
 \end{aligned}$$

$$y = \bar{a} + c \leftarrow$$

|   |   | bc | $\bar{b}\bar{c}$ | $\bar{b}c$ | bc | $b\bar{c}$ |  |
|---|---|----|------------------|------------|----|------------|--|
|   |   | 00 | 01               | 11         | 10 |            |  |
| a | 0 | 1  | X                | 1          | 1  | 1          |  |
|   | 1 | 0  | 1                | 1          | 1  | 0          |  |
| a | 0 | 1  | X                | 1          | 1  | 1          |  |
|   | 1 | 0  | 1                | 1          | 1  | 0          |  |

- (c)  $F(x, y, z) = \sum(3, 5, 6, 7)$   
 (d)  $F(x, y, z) = \sum(0, 1, 3, 4, 5)$   
 (e)  $F(x, y, z) = \sum(1, 3, 5, 7)$   
 (f)  $F(x, y, z) = xy + x'y'z' + x'yz'$   
 (g)  $F(A, B, C, D) = A'B'C'D' + AC'D' + B'CD' + A'BCD + BC'D$   
 (h)  $F(A, B, C, D) = C'D + A'B'C + ABC' + AB'C$   
 (i)  $F(w, x, y, z) = x'z + w'xy' + w(x'y + xy')$

18. Find all the prime implicants for the following Boolean functions, and determine which are essential  
 (a)  $F(w, x, y, z) = \sum(0, 2, 4, 5, 6, 7, 8, 10, 13, 15)$   
 (b)  $F(A, B, C, D) = \sum(0, 2, 3, 5, 7, 8, 10, 11, 14, 15)$   
 (c)  $F(w, x, y, z) = \sum(1, 3, 6, 7, 8, 9, 12, 13, 14, 15)$   
 (d)  $F(A, B, C, D) = \sum(0, 2, 3, 5, 7, 8, 10, 11, 13, 15)$
19. Simplify the following expressions to (i) sum-of-products (ii) product-of-sums  
 (a)  $F = x'z' + y'z' + yz' + xy$   
 (b)  $F = ACD' + C'D + AB' + ABCD$   
 (c)  $F = (A + C' + D')(A' + B' + D')(A' + B + D')(A' + B + C')$   
 (d)  $F = ABC + AB'D + BCD$
20. Simplify the following Boolean functions  $F$ , together with don't-care conditions  $d$ , and then express the simplified function in sum-of-minterms form  
 (a)  $F(x, y, z) = \sum(0, 1, 3, 5, 7); d(x, y, z) = \sum(2, 4, 6)$   
 (b)  $F(A, B, C, D) = \sum(0, 4, 8, 10, 14); d(x, y, z) = \sum(2, 6, 12)$   
 (c)  $F(A, B, C, D) = \sum(5, 6, 7, 11, 14, 15); d(x, y, z) = \sum(3, 9, 13)$   
 (d)  $F(A, B, C, D) = \sum(2, 4, 7, 10, 12, 14); d(x, y, z) = \sum(0, 3, 6, 8, 13)$
21. Simplify the following functions using K-map, and implement them with NAND gate circuits:  
 (a)  $F(A, B, C, D) = A'B'C + AC' + ACD + ACD' + A'B'C'$   
 (b)  $F(A, B, C, D) = A'B'C'D + CD' + AC'D$   
 (c)  $F(A, B, C, D) = (A' + C' + D')(A' + C')(C' + D')$   
 (d)  $F(A, B, C, D) = A' + AB + B'C + ACD$
22. Implement the following Boolean function  $F$ , together with the don't-care conditions  $d$ , using no more than two NOR gates  
 $F(A, B, C, D) = \sum(2, 4, 10, 12, 14); d(A, B, C, D) = \sum(0, 1, 5, 8)$
- SOP - NAND gates  
POS - NOR gates
23. Draw a logic diagram using only two-input ~~NAND~~ NOR gates to implement the following function:  
 $F(A, B, C, D) = (A \oplus B)'(C \oplus D)$
24. Obtain a minimal sum-of-products expression for the output  $F$  of the logic circuit shown below

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

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

$$= x'+z'$$

$$\text{RHS} = (x'+x)(x'+z')$$

$$= x'+z'$$

$$\therefore \text{LHS} = \text{RHS} //$$

22)

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

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



23)

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

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

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



30>

| Flow rate       | A | B | C | D | E | Y | Z |
|-----------------|---|---|---|---|---|---|---|
| < 10 gal/min    | 0 | 0 | 0 | 0 | 0 | 1 | 0 |
| 10 - 20 gal/min | 1 | 0 | 0 | 0 | 0 | 1 | 0 |
| 20 - 30 gal/min | 1 | 1 | 0 | 0 | 0 | 1 | 1 |
| 30 - 40 gal/min | 1 | 1 | 1 | 0 | 0 | 0 | 1 |
| 40 - 50 gal/min | 1 | 1 | 1 | 1 | 0 | 0 | 1 |
| > 50 gal/min    | 1 | 1 | 1 | 1 | 1 | 0 | 0 |

$Y = \overline{A}\overline{B}\overline{C}\overline{D}\overline{E} + A\overline{B}\overline{C}\overline{D}\overline{E} + AB\overline{C}\overline{D}\overline{E}$

$$Z = ABC\overline{D}\overline{E} + A\overline{B}C\overline{D}\overline{E} + ABCDE$$



25. Convert the Boolean expression  $F(A, B, C) = X'YZ' + ZY'Z' + XYZ' + XYZ$  to canonical product-of-sums form.
26. All the logic gates shown in the figure have a propagation delay of  $20 \text{ ns}$ . Let  $A = C = 0$  and  $B = 1$  until time  $t = 0$ . At  $t = 0$ , all the inputs flip (i.e.,  $A = C = 1$  and  $B = 0$ ) and remain in that state. Find the duration (in  $\text{ns}$ ) for which the output  $Z = 1$ , for  $t > 0$ .



27. A digital system is required to amplify a binary-encoded audio signal. The user should be able to control the gain of the amplifier from a minimum to a maximum in 100 increments. Find the minimum number of bits required to encode the control signals.
28. In a 7-segment display, each of the seven segments is activated for various digits. For example, segment  $a$  is activated for the digits 0, 2, 3, 5, 6, 7, 8, and 9, as illustrated in Figure below. Since each digit can be represented by a BCD code, derive an SOP expression for segment  $a$  using the variables  $ABCD$  and then minimize the expression using a Karnaugh map.



29. Two products are sold from a vending machine, which has two push buttons  $P_1$  and  $P_2$ . When a button is pressed, the price of the corresponding product is displayed in a 7 - segment display.

If no buttons are pressed, '0' is displayed signifying 'Rs 0'.

If only  $P_1$  is pressed, '2' is displayed, signifying 'Rs. 2'.

If only  $P_2$  is pressed '5' is displayed, signifying 'Rs. 5'.

If both  $P_1$  and  $P_2$  are pressed, 'E' is displayed, signifying 'Error'.

The names of the segments in the 7 - segment display, and the glow of the display for '0', '2', '5' and 'E' are shown below.

28>

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

$$a = C + A + BD + \bar{B}\bar{D}$$



Push buttons pressed/not pressed in equivalent to logic 1/0 respectively. A segment glowing/not glowing in the display is equivalent to logic 1/0 respectively.

- (a) Write the Boolean functions corresponding to each segment (a to g) in terms of the inputs  $P_1$  and  $P_2$ .
  - (b) What are the minimum number of NOT gates and 2-input OR gates required to design the logic of the driver for this 7-segment display?
30. A flow rate sensing device used on a liquid transport pipeline functions as follows. The device provides a 5-bit output where all five bits are zero if the flow rate is less than 10 gallons per minute. The first bit is 1 if the flow rate is at least 10 gallons per minute; the first and second bits are 1 if the flow rate is at least 20 gallons per minute; the first, second, and third bits are 1 if the flow rate is at least 30 gallons per minute; and so on. The five bits, represented by the logical variables  $A$ ,  $B$ ,  $C$ ,  $D$ , and  $E$ , are used as inputs to a device that provides two outputs  $Y$  and  $Z$ .
  - (a) Write an equation for the output  $Y$  if we want  $Y$  to be 1 iff the flow rate is less than 30 gallons per minute.
  - (b) Write an equation for the output  $Z$  if we want  $Z$  to be 1 iff the flow rate is at least 20 gallons per minute but less than 50 gallons per minute.
31. Each of three coins has two sides, heads and tails. Represent the heads or tails status of each coin by a logical variable ( $A$  for the first coin,  $B$  for the second coin, and  $C$  for the third) where the logical variable is 1 for heads and 0 for tails. Write a logic function  $F(A, B, C)$  which is 1 iff exactly one of the coins is heads after a toss of the coins. Express  $F$ 
  - (a) as a minterm expansion.
  - (b) as a maxterm expansion.
32. A priority encoder circuit has four inputs,  $x_3, x_2, x_1$  and  $x_0$ . The circuit has three outputs:  $z, y_1, y_0$ . If one of the inputs is 1,  $z$  is 1 and  $y_1$  and  $y_0$  represent a 2-bit, binary number whose value equals the index of the highest numbered input that is 1. For example, if  $x_2$  is 1 and  $x_3$  is 0, then the outputs are  $z = 1$ , and  $y_1 = 1$  and  $y_0 = 0$ . If all inputs are 0,  $z = 0$  and  $y_1$  and  $y_0$  are don't-cares.
  - (a) List in decimal form the minterms and don't-care minterms of each output.
  - (b) List in decimal form the maxterms and don't-care maxterms of each output.
33. A bank vault has three locks with a different key for each lock. Each key is owned by a different person. To open the door, at least two people must insert their keys into the assigned locks. The signal lines  $A$ ,  $B$ , and  $C$  are 1 if there is a key inserted into lock 1, 2, or 3, respectively. Write an equation for the variable  $Z$  which is 1 iff the door should open.

$$Z = AB + BC + CA,$$

1/p

0/p

32

|   | $x_3$ | $x_2$ | $x_1$ | $x_0$ | $z$ | $y_1$ | $y_0$ |
|---|-------|-------|-------|-------|-----|-------|-------|
|   | 0     | 0     | 0     | 0     | 0   | X     | X     |
|   | 0     | 0     | 0     | 1     | 1   | 0     | 0     |
|   | 0     | 0     | 1     | 0     | 1   | 0     | 1     |
|   | 0     | 0     | 1     | 1     | 1   | 0     | 1     |
|   | 0     | 1     | 0     | 0     | 1   | 1     | 0     |
|   | 0     | 1     | 0     | 1     | 1   | 1     | 0     |
|   | 0     | 1     | 1     | 0     | 1   | 1     | 0     |
|   | 0     | 1     | 1     | 1     | 1   | 1     | 0     |
| 1 | 0     | 0     | 0     | 0     | 1   | 1     | 1     |
| 1 | 0     | 0     | 0     | 1     | 1   | 1     | 1     |
| 1 | 0     | 1     | 0     | 0     | 1   | 1     | 1     |
| 1 | 0     | 1     | 0     | 1     | 1   | 1     | 1     |
| 1 | 1     | 0     | 0     | 0     | 1   | 1     | 1     |
| 1 | 1     | 0     | 0     | 1     | 1   | 1     | 1     |
| 1 | 1     | 1     | 0     | 0     | 1   | 1     | 1     |
| 1 | 1     | 1     | 0     | 1     | 1   | 1     | 1     |
| 1 | 1     | 1     | 1     | 0     | 1   | 1     | 1     |

$$z = \sum m(1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15)$$

$$y_1 = \sum_{d=0} m(4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15)$$

$$y_0 = \sum m(2, 3, 8, 9, 10, 11, 12, 13, 14, 15) \quad d=0$$

34. Design a logic circuit to produce a HIGH output only if the input, represented by a 4-bit binary number, is greater than twelve or less than three. First develop the truth table and then draw the logic diagram.

35. Develop the logic circuit necessary to meet the following requirements:

A battery-powered lamp in a room is to be operated from two switches, one at the back door and one at the front door. The lamp is to be on if the front switch is on and the back switch is off, or if the front switch is off and the back switch is on. The lamp is to be off if both switches are off or if both switches are on. Let a HIGH output represent the on condition and a LOW output represent the off condition.

XOR

(3)

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

| A         | $\bar{B}\bar{C}$ | $\bar{B}C$ | $\bar{B}\bar{C}$ | $BC$ | $B\bar{C}$ |
|-----------|------------------|------------|------------------|------|------------|
| 0         | 00               | 01         | 11               | 10   |            |
| $\bar{A}$ | 0                | 0          | 1                | 0    |            |
| 1         | 4                | 5          | 7                | 6    |            |
| A         | 0                | 1          | 1                | 1    |            |

$$AB + BC + AC,$$

| A         | $B+C$ | $B+C$ | $B+\bar{C}$ | $\bar{B}+\bar{C}$ | $\bar{B}+C$ |
|-----------|-------|-------|-------------|-------------------|-------------|
| 0         | 00    | 01    | 11          | 10                |             |
| $\bar{A}$ | 0     | 0     | 1           | 0                 |             |
| 1         | 4     | 5     | 7           | 6                 |             |
| A         | 0     | 1     | 1           | 1                 |             |

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

1's complement: change 0 to 1 and 1 to 0.

$$0110 \leftrightarrow 1001$$

2's complement: Add 1 to LSB of 1's complement.

$$0110 \leftrightarrow 1001$$

$$\begin{array}{r} + 1 \\ \hline 1010 // \end{array}$$

$$(5)_{10} \rightarrow 0101 \xrightarrow{\text{1's complement}} 1010 \xrightarrow{\text{2's}} 1011, (-5)$$

Range of numbers:

unsigned: 0 to  $2^n - 1$

signed:  $-2^{n-1}$  to  $2^{n-1} - 1$  (2's complement)

$-2^{n-1} + 1$  to  $2^{n-1} - 1$  (1's complement)

Because in 1's complement (0000 & 1111 represent 0)

Addition & Subtraction of binary numbers

$$\begin{array}{r} 5 + 2 \Rightarrow 0101 \\ 0011 \\ \hline 0111 // \end{array}$$

$$5 - 2 \Rightarrow 5 + (-2) \Rightarrow \begin{array}{r} 0101 \\ 1110 \\ \hline \end{array}$$

$$\begin{array}{r} -2 \Rightarrow 0010 \\ 1101 \\ \hline 1110 // \end{array} \quad \begin{array}{r} 10011 \\ = 3 // \end{array}$$

Number after MSB is ignored.

$$-5 + 2 \Rightarrow 1011$$
$$\begin{array}{r} 0010 \\ - 1 \\ \hline 1101 \end{array}$$
$$1101$$
$$\begin{array}{r} - 1 \\ \hline 1100 \end{array}$$
$$\rightarrow 0011 // \Rightarrow (-3)_{10}$$

$$-5 - 2 \Rightarrow 1011$$
$$\begin{array}{r} 1110 \\ - 1100 \\ \hline 1001 \end{array}$$
$$1001 // (-7)_{10}$$

$$+4 + 2 \Rightarrow 0100$$
$$\begin{array}{r} 0010 \\ + 0110 \\ \hline 0110 \end{array}$$
$$0110 //$$

In compliment addition

$$5 + (-2) \Rightarrow 0100$$
$$\begin{array}{r} 1101 \\ + 10001 \\ \hline 10010 \end{array}$$
$$0001$$
$$+ 1$$
$$\hline 0010 //$$

- In 1's compliment method carry is added.
- In 2's compliment method carry is ignored.

Literals: All input variables and their compliments are called literals.

Sum terms: Sum of literals

Ex:  $x+z$ ,  $z+y$  etc.

Product term: Product of literals.

Ex:  $\bar{x}\bar{y}$ ,  $\bar{x}yz$  etc.

Sum of product: Ex:  $x\bar{y} + yz + \bar{z}x$

Product of sum: Ex:  $(x+\bar{y})(\bar{x}+y+z)$

Normal terms: In this kind of terms every literal occurs only once.

Minterms and maxterms

| <u>x</u> | <u>y</u> | <u>z</u> | <u>minterms</u>                   | <u>Maxterms</u>                     |
|----------|----------|----------|-----------------------------------|-------------------------------------|
| 0        | 0        | 0        | $m_0 \quad \bar{x}\bar{y}\bar{z}$ | $M_0 \quad x+y+z$                   |
| 0        | 0        | 1        | $m_1 \quad \bar{x}\bar{y}z$       | $M_1 \quad x+y+\bar{z}$             |
| 0        | 1        | 0        | $m_2 \quad \bar{x}y\bar{z}$       | $M_2 \quad x+\bar{y}+z$             |
| 0        | 1        | 1        | $m_3 \quad \bar{x}yz$             | $M_3 \quad x+\bar{y}+\bar{z}$       |
| 1        | 0        | 0        | $m_4 \quad x\bar{y}\bar{z}$       | $M_4 \quad \bar{x}+y+z$             |
| 1        | 0        | 1        | $m_5 \quad x\bar{y}z$             | $M_5 \quad \bar{x}+y+\bar{z}$       |
| 1        | 1        | 0        | $m_6 \quad xy\bar{z}$             | $M_6 \quad \bar{x}+\bar{y}+z$       |
| 1        | 1        | 1        | $m_7 \quad xyz$                   | $M_7 \quad \bar{x}+\bar{y}+\bar{z}$ |

Canonical form: Output written in terms of minterms (SOP) or canonical form or Maxterms (POS) is called

K-Mah (Karnaugh Mah) : It is used to get simplified expression

1>

| a | b | y |
|---|---|---|
| 0 | 0 | 0 |
| 0 | 1 | 1 |
| 1 | 0 | 1 |
| 1 | 1 | 0 |

| a         | $\bar{a}$ | a |
|-----------|-----------|---|
| b         | 0         | 2 |
| $\bar{b}$ | 0         | 1 |
| 1         | 1         | 3 |
| b         | 1         | 0 |

$$= \bar{a}b + a\bar{b},$$

2>

| a | b | c | y |
|---|---|---|---|
| 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 | 1 |
| 1 | 1 | 1 | 1 |

| ab        | $\bar{a}\bar{b}$ | $\bar{a}b$ | ab | $\bar{a}\bar{b}$ |
|-----------|------------------|------------|----|------------------|
| c         | 00               | 01         | 11 | 10               |
| $\bar{c}$ | 0                | 0          | 0  | 0                |
| 1         | 0                | 0          | 1  | 0                |
| c         | 1                | 0          | 1  | 0                |

$$y = ab,$$

3>

$$\sum(m_1, m_2, m_7, m_8, m_{10}, m_{12}, m_{13})$$

| ab               | $\bar{a}\bar{b}$ | $\bar{a}b$ | ab | $\bar{a}\bar{b}$ |
|------------------|------------------|------------|----|------------------|
| cd               | 00               | 01         | 11 | 10               |
| $\bar{c}\bar{d}$ | 0                | 0          | 1  | 1                |
| cd               | 1                | 0          | 1  | 0                |
| $\bar{c}d$       | 1                | 1          | 0  | 0                |
| cd               | 0                | 1          | 0  | 0                |
| $c\bar{d}$       | 0                | 0          | 0  | 1                |
| $\bar{c}\bar{d}$ | 1                | 0          | 0  | 1                |

$$= abc\bar{c} + a\bar{c}\bar{d} + \bar{b}c\bar{d} + \bar{a}bcd + \bar{a}\bar{b}\bar{c}d$$

Parallel address



Ripple carry address

| a | b | $C_{in}$ | $C_{out}$ |
|---|---|----------|-----------|
| 0 | 0 | 0        | 0         |
| 0 | 0 | 1        | 0         |
| 0 | 1 | 0        | 0         |
| 0 | 1 | 1        | 1         |
| 1 | 0 | 0        | 0         |
| 1 | 0 | 1        | 1         |
| 1 | 1 | 0        | 1         |
| 1 | 1 | 1        | 1         |

$$G_i = ab$$

$$P_i = (\bar{a}b + a\bar{b})$$

$$\therefore C_i = G_i + P_i C_{i-1}$$

$$C_0 = G_0 + P_0 C_{-1}$$

$$C_1 = G_1 + P_1 C_0 = G_1 + P_1 (G_0 + P_0 C_{-1})$$

$$\therefore C_1 = G_1 + P_1 G_0 + P_1 P_0 C_{-1}$$

$$\text{by } C_2 = G_2 + P_2 G_1 + P_2 P_1 G_0 + P_2 P_1 P_0 C_{-1}$$

Binary codes

→ Used for representing discrete elements of information in binary.

Ex: Decimal numbers

→ Binary coded decimals (BCD)

• A set of  $n$  elements can be coded with  $(\log_2 n)$  distinct codes.

i.e.  $n$  bit binary code can distinctly represent one element in a set of  $2^n$  elements.

BCD:  $\underbrace{0 \rightarrow 9}_{4 \text{ bits}}$  i.e. 10 elements which needs minimum

|              | <u>BCD</u>     | <u>Binary</u> |
|--------------|----------------|---------------|
| $(12)_{10}$  | 0001 0010      | 1100          |
| $(734)_{10}$ | 0111 0011 0100 | 101101110     |

BCD addition: We have to correct result if the result  $\underbrace{\text{is out}}_{\text{of range}}$  of range.

$$8 + 4 = 12$$

$$\begin{array}{r} 1000 \\ 0100 \\ \hline 1100 \end{array} \qquad \begin{array}{r} 1100 \\ 0110 \\ \hline 0001 \ 0010 \end{array}$$

correction factor (add 6)  
if  $s > 9$  or  $C_{out} = 1$

**Table 1.5***Four Different Binary Codes for the Decimal Digits*

| <b>Decimal<br/>Digit</b>           | <b>BCD<br/>8421</b>                          | <b>2421</b>                                  | <b>Excess-3</b>                              | <b>8, 4, -2, -1</b>                          |
|------------------------------------|----------------------------------------------|----------------------------------------------|----------------------------------------------|----------------------------------------------|
| 0                                  | 0000                                         | 0000                                         | 0011                                         | 0000                                         |
| 1                                  | 0001                                         | 0001                                         | 0100                                         | 0111                                         |
| 2                                  | 0010                                         | 0010                                         | 0101                                         | 0110                                         |
| 3                                  | 0011                                         | 0011                                         | 0110                                         | 0101                                         |
| 4                                  | 0100                                         | 0100                                         | 0111                                         | 0100                                         |
| 5                                  | 0101                                         | 1011                                         | 1000                                         | 1011                                         |
| 6                                  | 0110                                         | 1100                                         | 1001                                         | 1010                                         |
| 7                                  | 0111                                         | 1101                                         | 1010                                         | 1001                                         |
| 8                                  | 1000                                         | 1110                                         | 1011                                         | 1000                                         |
| 9                                  | 1001                                         | 1111                                         | 1100                                         | 1111                                         |
|                                    |                                              |                                              |                                              |                                              |
| Unused<br>bit<br>combi-<br>nations | 1010<br>1011<br>1100<br>1101<br>1110<br>1111 | 0101<br>0110<br>0111<br>1000<br>1001<br>1010 | 0000<br>0001<br>0010<br>1101<br>1110<br>1111 | 0001<br>0010<br>0011<br>1100<br>1101<br>1110 |

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

Binary      to      gray

| $B_2$ | $B_1$ | $B_0$ | $G_{r_2}$ | $G_{r_1}$ | $G_{r_0}$ |
|-------|-------|-------|-----------|-----------|-----------|
| 0     | 0     | 0     | 0         | 0         | 0         |
| 0     | 0     | 1     | 0         | 0         | 1         |
| 0     | 1     | 0     | 0         | 1         | 1         |
| 0     | 1     | 1     | 0         | 1         | 0         |
| 1     | 0     | 0     | 1         | 1         | 0         |
| 1     | 0     | 1     | 1         | 1         | 1         |
| 1     | 1     | 0     | 1         | 0         | 1         |
| 1     | 1     | 1     | 1         | 0         | 0         |

$$G_{r_2} = B_2$$

$$G_{r_1} = B_2 \oplus B_1$$

$$G_{r_0} = B_1 \oplus B_0$$

Gray      to      Binary:     $B_2 = G_{r_2}$        $B_1 = G_{r_1} \oplus G_{r_2}$   
 $B_0 = G_{r_1} \oplus G_{r_2} \oplus G_{r_3}$

Multiplexer: A digital switch

2-1 Multiplexer (2:1 MUX)



Function      Table:

| S | Y  |
|---|----|
| 0 | I0 |
| 1 | I1 |

## Truth table

| S | I <sub>0</sub> | I <sub>1</sub> | y |
|---|----------------|----------------|---|
| 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 |

| I <sub>1</sub> | SI <sub>0</sub> | $\bar{S}I_0$ | $\bar{S}I_0$ | SI <sub>0</sub> | $\bar{S}I_0$ |
|----------------|-----------------|--------------|--------------|-----------------|--------------|
| 0              | 0               | 1            | 1            | 0               | 0            |
| 1              | 0               | 0            | 1            | 1               | 0            |
| 0              | 1               | 0            | 1            | 0               | 1            |
| 1              | 1               | 1            | 1            | 1               | 1            |

$$\therefore y = \bar{S}I_0 + SI_1$$



4:1 MUX



NOTE:  $2^n:1$  MUX has n switch

| $s_1$ | $s_0$ | $y$   |
|-------|-------|-------|
| 0     | 0     | $I_o$ |
| 0     | 1     | $I_1$ |
| 1     | 0     | $I_2$ |
| 1     | 1     | $I_3$ |

$$y = \bar{s}_1 \bar{s}_0 I_o + \bar{s}_1 s_0 I_1 + s_1 \bar{s}_0 I_2 + s_1 s_0 I_3 //$$

Circuit:



Multiplexer tree

4:1 MUX using 2:1 MUX



8:1 MUX using 2:1 MUX



Logic design with MUX

1> Implement XOR function using MUX  
Note that n variable function has  $2^n:1$  MUX

| a | b | y |
|---|---|---|
| 0 | 0 | 0 |
| 0 | 1 | 1 |
| 1 | 0 | 1 |
| 1 | 1 | 0 |



2)  $f(x, y, z) = \sum m(0, 2, 3, 5)$  using 4:1 MUX

| IP | OP |   |   |
|----|----|---|---|
| x  | y  | z | f |
| 0  | 0  | 0 | 1 |
| 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 | 0 |



3)  $f(w, x, y, z) = \sum m(0, 1, 5, 6, 7, 9, 12, 15)$  using 4:1 MUX

| IP | OP |   |   |   |
|----|----|---|---|---|
| w  | x  | y | z | f |
| 0  | 0  | 0 | 0 | 1 |
| 0  | 0  | 0 | 1 | 1 |
| 0  | 0  | 1 | 0 | 0 |
| 0  | 0  | 1 | 1 | 0 |
| 0  | 1  | 0 | 0 | 0 |
| 0  | 1  | 0 | 1 | 1 |
| 0  | 1  | 1 | 0 | 1 |
| 0  | 1  | 1 | 1 | 1 |
| 1  | 0  | 0 | 0 | 0 |
| 1  | 0  | 0 | 1 | 1 |
| 1  | 0  | 1 | 0 | 0 |
| 1  | 0  | 1 | 1 | 0 |
| 1  | 1  | 0 | 0 | 0 |
| 1  | 1  | 0 | 1 | 0 |
| 1  | 1  | 1 | 0 | 0 |
| 1  | 1  | 1 | 1 | 0 |



## Decoders

- 1) Encoder: encode information : Many lines to few lines.
- 2) Decoder: decode information : Few to many lines.

Only one output line will be high for a given input combination.

2 to 4 (2:4) decoder



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

with enable



| E | A | B | $Y_0$ | $Y_1$ | $Y_2$ | $Y_3$ |
|---|---|---|-------|-------|-------|-------|
| 1 | 0 | 0 | 1     | 0     | 0     | 0     |
| 1 | 0 | 1 | 0     | 1     | 0     | 0     |
| 1 | 1 | 0 | 0     | 0     | 1     | 0     |
| 1 | 1 | 1 | 0     | 0     | 0     | 1     |
| 0 | X | X | 0     | 0     | 0     | 0     |

Decoder with enable as demultiplexer:

$A \rightarrow S_1$      $B \rightarrow S_0$      $E \rightarrow \text{data}$

| A              | B              | E       | $y_0$ | $y_1$ | $y_2$ | $y_3$ |
|----------------|----------------|---------|-------|-------|-------|-------|
| S <sub>1</sub> | S <sub>0</sub> | data in |       |       |       |       |
| 0              | 0              | 0       | 0     | 0     | 0     | 0     |
| 0              | 0              | 1       | 1     | 0     | 0     | 0     |
| 0              | 1              | 0       | 0     | 0     | 0     | 0     |
| 0              | 1              | 1       | 0     | 1     | 0     | 0     |
| 1              | 0              | 0       | 0     | 0     | 0     | 0     |
| 1              | 0              | 1       | 0     | 0     | 1     | 0     |
| 1              | 1              | 0       | 0     | 0     | 0     | 0     |
| 1              | 1              | 1       | 0     | 0     | 0     | 1     |

3- 8 decoder

| Input |   |   | Output |       |       |       |       |       |       |       |
|-------|---|---|--------|-------|-------|-------|-------|-------|-------|-------|
| A     | B | C | $y_0$  | $y_1$ | $y_2$ | $y_3$ | $y_4$ | $y_5$ | $y_6$ | $y_7$ |
| 0     | 0 | 0 | 1      | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| 0     | 0 | 1 | 0      | 1     | 0     | 0     | 0     | 0     | 0     | 0     |
| 0     | 1 | 0 | 0      | 0     | 1     | 0     | 0     | 0     | 0     | 0     |
| 0     | 1 | 1 | 0      | 0     | 0     | 1     | 0     | 0     | 0     | 0     |
| 1     | 0 | 0 | 0      | 0     | 0     | 0     | 1     | 0     | 0     | 0     |
| 1     | 0 | 1 | 0      | 0     | 0     | 0     | 0     | 1     | 0     | 0     |
| 1     | 1 | 0 | 0      | 0     | 0     | 0     | 0     | 0     | 1     | 0     |
| 1     | 1 | 1 | 0      | 0     | 0     | 0     | 0     | 0     | 0     | 1     |



4 to 16 decoder using 2-to-4 decoder:



Construction of 2-to-4 decoder using basic gates

| E | A | B | $y_0$ | $y_1$ | $y_2$ | $y_3$ |
|---|---|---|-------|-------|-------|-------|
| 1 | 0 | 0 | 1     | 0     | 0     | 0     |
| 1 | 0 | 1 | 0     | 1     | 0     | 0     |
| 1 | 1 | 0 | 0     | 0     | 1     | 0     |
| 1 | 1 | 1 | 0     | 0     | 0     | 1     |
| 0 | X | X | 0     | 0     | 0     | 0     |

$$\Rightarrow y_0 = \bar{E} \bar{A} \bar{B}$$

$$y_1 = \bar{E} \bar{A} B$$

$$y_2 = E \bar{A} \bar{B}$$

$$y_3 = E A \bar{B}$$



IC  $\sim$  74139  $\rightarrow$  active low  $\sim$  2-4 decoder

active low signal: These signals are active when their value is in low i.e zero.

| $\bar{G}_1$ | $\bar{Y}_1$ |
|-------------|-------------|
| $\bar{A}$   | $\bar{Y}_2$ |
| $\bar{B}$   | $\bar{Y}_3$ |
| $\bar{G}_1$ | $\bar{Y}_4$ |
| $\bar{A}$   | $\bar{Y}_1$ |
| $\bar{B}$   | $\bar{Y}_2$ |
| $\bar{G}_1$ | $\bar{Y}_3$ |
| $\bar{A}$   | $\bar{Y}_4$ |
| $\bar{B}$   | $\bar{Y}_1$ |
| $\bar{G}_1$ | $\bar{Y}_2$ |
| $\bar{A}$   | $\bar{Y}_3$ |
| $\bar{B}$   | $\bar{Y}_4$ |

| $\bar{G}_1$ | $\bar{A}$ | $\bar{B}$ | $\bar{Y}_0$ | $\bar{Y}_1$ | $\bar{Y}_2$ | $\bar{Y}_3$ |
|-------------|-----------|-----------|-------------|-------------|-------------|-------------|
| 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           |

Half adder using 2-4 decoder

| i/p |   |   | o/p |
|-----|---|---|-----|
| a   | b | s | c   |
| 0   | 0 | 0 | 0   |
| 0   | 1 | 1 | 0   |
| 1   | 0 | 1 | 0   |
| 1   | 1 | 0 | 1   |

active high



active low:



Seven segment display



To glow any segment open terminal should be connected to 0.

Common cathode



BCD to seven segment decoder



For common anode display:

| Decimal | B3 | B2 | B1 | B0 | a | b | c | d | e | f | g |
|---------|----|----|----|----|---|---|---|---|---|---|---|
| 0       | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 1 |
| 1       | 0  | 0  | 0  | 1  | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
| 2       | 0  | 0  | 1  | 0  | 0 | 0 | 1 | 0 | 0 | 1 | 0 |
| 3       | 0  | 0  | 1  | 1  | 0 | 0 | 0 | 0 | 1 | 1 | 0 |
| 4       | 0  | 1  | 0  | 0  | 1 | 0 | 0 | 1 | 1 | 0 | 0 |
| 5       | 0  | 1  | 0  | 1  | 0 | 1 | 0 | 0 | 1 | 0 | 0 |
| 6       | 0  | 1  | 1  | 0  | 0 | 1 | 0 | 0 | 0 | 0 | 0 |
| 7       | 0  | 1  | 1  | 1  | 0 | 0 | 0 | 1 | 1 | 1 | 1 |

| Decimal | $B_3$ | $B_2$ | $B_1$ | $B_0$ | a | b | c | d | e | f | g |
|---------|-------|-------|-------|-------|---|---|---|---|---|---|---|
| 8       | 1     | 0     | 0     | 0     | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| 9       | 1     | 0     | 0     | 1     | 0 | 0 | 0 | 0 | 1 | 0 | 0 |
| 10      | 1     | 0     | 1     | 0     | x | x | x | x | x | x | x |
| 11      | 1     | 0     | 1     | 1     | x | x | x | x | x | x | x |
| 12      | 1     | 1     | 0     | 0     | x | x | x | x | x | x | x |
| 13      | 1     | 1     | 0     | 1     | x | x | x | x | x | x | x |
| 14      | 1     | 1     | 1     | 0     | x | x | x | x | x | x | x |
| 15      | 1     | 1     | 1     | 1     | x | x | x | x | x | x | x |

$$a =$$

$$b = B_2 \bar{B}_1 B_0 + B_2 B_1 \bar{B}_0$$

Encoder: Encodes data into binary code

Priority encoder: Priority given to inputs to generate o/p code.

4 to 2 priority encoder

$D_3 \rightarrow$  highest priority,  $D_0 \rightarrow$  least priority

| $D_3$ | $D_2$ | $D_1$ | $D_0$ | x | y | v |
|-------|-------|-------|-------|---|---|---|
| 0     | 0     | 0     | 0     | x | x | 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 |



For  $x =$

03 D2

| $D_1, D_0$ | 00     | 01     | 11      | 10      |
|------------|--------|--------|---------|---------|
| 00         | 0<br>0 | 4<br>0 | 12<br>1 | 8<br>1  |
| 01         | 1<br>0 | 5<br>1 | 13<br>1 | 9<br>1  |
| 11         | 3<br>0 | 7<br>1 | 15<br>1 | 11<br>1 |
| 10         | 2<br>0 | 6<br>1 | 14<br>1 | 10<br>1 |

$$\chi = D_3 + D_2$$

$D_1 D_0$

|    | 00      | 01      | 11      | 10      |
|----|---------|---------|---------|---------|
| 00 | 0<br>X  | 1<br>0  | 3<br>1. | 2<br>J  |
| 01 | 4<br>0  | 5<br>0  | 7<br>0  | 6<br>0  |
| 11 | 12<br>1 | 13<br>1 | 15<br>1 | 14<br>1 |
| 10 | 8<br>1  | 9<br>1  | 11<br>1 | 10<br>1 |

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

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

## Parity generator / checker

(One of the error detection method.

Based on number of ones in the sequence.  
 Odd number - odd parity, even number - even parity



$$y = a_3 \oplus a_2 \oplus a_1 \oplus a_0$$



Parity generator: Parity generator will add parity. i.e. it maintains parity at the end of the sequence. Odd parity generator will add 0 for even parity and 1 for odd parity.



$$z = \bar{y} = a_3 \oplus a_2 \oplus a_1 \oplus a_0$$

5 variable K-map

$$f(A, B, C, D, E)$$

Ex:  $F(A, B, C, D, E) = \sum m(0, 1, 4, 8, 11, 12, 13, 15, 16, 17, 20, 23, 24, 28, 29, 31)$

| $\bar{B}\bar{C}$ | $\bar{B}C$ | $\bar{B}C$ | $BC$ | $B\bar{C}$ |
|------------------|------------|------------|------|------------|
| $\bar{D}\bar{E}$ | 0          | 4          | 12   | 8          |
| $\bar{D}E$       | 1          | 5          | 13   | 9          |
| $\bar{D}\bar{E}$ | 3          | 7          | 15   | 11         |
| $D\bar{E}$       | 2          | 6          | 14   | 10         |
| $D\bar{E}$       | 0          | 0          | 0    | 0          |

$\bar{A}$

| $\bar{B}C$       | $\bar{B}\bar{C}$ | $\bar{B}C$ | $BC$ | $B\bar{C}$ |
|------------------|------------------|------------|------|------------|
| $\bar{D}\bar{E}$ | 16               | 20         | 28   | 24         |
| $\bar{D}E$       | 17               | 21         | 29   | 25         |
| $\bar{D}\bar{E}$ | 19               | 23         | 31   | 27         |
| $D\bar{E}$       | 18               | 22         | 30   | 26         |
| $D\bar{E}$       | 0                | 0          | 0    | 0          |

$A$

$$\begin{aligned}
 F &= \bar{A}\bar{D}\bar{E} + A\bar{D}\bar{E} + \bar{A}BCE + ABCE + \bar{A}\bar{B}\bar{C}\bar{D} + A\bar{B}\bar{C}\bar{D} \\
 &\quad + \bar{A}BD\bar{E} + ACDE \\
 &= \bar{D}\bar{E} + BCE + \bar{B}\bar{C}\bar{D} + \bar{A}BDE + ACDE
 \end{aligned}$$

Ans

$$\begin{aligned}
 F(A, B, C, D, E) &= \sum m(2, 4, 6, 7, 8, 9, 12, 13, 15 \\
 &\quad 16, 23, 24, 25, 28, 29, 31)
 \end{aligned}$$

|                  |    | $\bar{B}\bar{C}$ | $\bar{B}C$ | $BC$ | $B\bar{C}$ |
|------------------|----|------------------|------------|------|------------|
|                  |    | 00               | 01         | 11   | 10         |
| $\bar{D}\bar{E}$ | 00 | 0                | 1          | 1    | 1          |
|                  | 01 | 0                | 0          | 1    | 1          |
| $\bar{D}E$       | 11 | 0                | 1          | 1    | 0          |
|                  | 10 | 1                | 1          | 0    | 0          |

$\bar{A}$

|                  |    | $\bar{B}\bar{C}$ | $\bar{B}C$ | $BC$    | $B\bar{C}$ |
|------------------|----|------------------|------------|---------|------------|
|                  |    | 00               | 01         | 11      | 10         |
| $\bar{D}\bar{E}$ | 00 | 16<br>1          | 20<br>0    | 28<br>1 | 25<br>1    |
|                  | 01 | 17<br>0          | 21<br>0    | 29<br>1 | 25<br>1    |
| $\bar{D}E$       | 11 | 19<br>0          | 23<br>1    | 31<br>1 | 27<br>0    |
|                  | 10 | 19<br>0          | 22<br>0    | 30<br>0 | 26<br>0    |

$A$

$$F = B\bar{D} + \bar{A}C\bar{D}\bar{E} + CDE + \bar{A}B\bar{D}\bar{E} + A\bar{C}\bar{D}E$$

Variable      entered      map

- Variable & its complement are entered in the map.
- It reduces the map order by 1
- Useful when some variables occur less frequently

Ex:  $f(x, y, z) = \sum m(0, 1, 2, 5)$

| x | y | z | f |
|---|---|---|---|
| 0 | 0 | 0 | 1 |
| 0 | 0 | 1 | 1 |
| 0 | 1 | 0 | 1 |
| 0 | 1 | 1 | 0 |
| 1 | 0 | 0 | 0 |
| 1 | 0 | 1 | 1 |
| 1 | 1 | 0 | 0 |
| 1 | 1 | 1 | 0 |



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

→ Variables are grouped with itself or 1

Ex2:  $F(w, x, y, z) = \sum m(4, 5, 11, 12, 13, 15)$

| $w$ | $x$ | $y$ | $z$ | $f$ |
|-----|-----|-----|-----|-----|
| 0   | 0   | 0   | 0   | 0   |
| 0   | 0   | 0   | 1   | 0   |
| 0   | 0   | 1   | 0   | 0   |
| 0   | 0   | 1   | 1   | 0   |
| 0   | 1   | 0   | 0   | 1   |
| 0   | 1   | 0   | 1   | 1   |
| 0   | 1   | 1   | 0   | 0   |
| 0   | 1   | 1   | 1   | 0   |
| 1   | 0   | 0   | 0   | 0   |
| 1   | 0   | 0   | 1   | 0   |
| 1   | 0   | 1   | 0   | 0   |
| 1   | 0   | 1   | 1   | 1   |
| 1   | 1   | 0   | 0   | 1   |
| 1   | 1   | 0   | 1   | 1   |
| 1   | 1   | 1   | 0   | 0   |
| 1   | 1   | 1   | 1   | 1   |

$\bar{w} \quad xy \quad \bar{x}\bar{y} \quad \bar{x}y \quad xy \quad x\bar{y}$

|           |    |    |    |    |
|-----------|----|----|----|----|
| $w$       | 00 | 01 | 11 | 10 |
| 0         | 0  | 1  | 3  | 2  |
| $\bar{w}$ | 0  | 0  | 0  | 1  |
| 1         | 4  | 5  | 7  | 6  |
| $w$       | 0  | 2  | 1  | 2  |

$$f = wyz + \bar{x}\bar{y}z,$$

## Introduction to Verilog

layout → Transistor level → Gate level → Architectural level  
→ System level.

Design flow: customer requirements



specifications



Architectural level synthesis

verification



RTL design (Register transfer logic)

Front end ←



Logic synthesis



verification

Back-end ← Physical Layout



Test planning



Fabrication



Test → chip to customer

Synthesis: process of transforming one representation  
in the design abstraction hierarchy to  
another representation.

## Hardware descriptive language (HDL)

- Textual description of a circuit
- Used for design entry in computers
- High level programming language used to model hardware for simulation verification and synthesis
- Have special hardware related constructs.
- Standard description for exchange of designs.
- Concurrent statement execution. (Parallel execution)

Ex: Verilog , VHDL (But verilog is used mostly)

### Verilog code (2:1 MUX)

- Module - basic unit . It describes ports & functionality.

```
module mux2to1 (Y, S, I0, I1);
    input I0;
    input I1;
    input S;
    output Y;
```

```
wire sbar, tmph1, tmph2;
not (sbar, S);
and (tmph1, sbar, I0);
and (tmph2, S, I1);
or (Y, tmph1, tmph2);
endmodule;
```

## Syntax

module module\_name (port-list);

### declarations:

reg, wire, parameter,  
input, output, inout,  
function, task, ... .

### Statements:

initial statement  
always statement  
Module instantiation  
Gate instantiation  
continuous assignment  
VDP instantiation  
---

endmodule;

## Test bench

### Syntax for mvr 2:] -

module Tb-mvr ()  
reg s,a,b;  
wire y;

`mux2to1 (s, a, b, y);`

`initial`

`begin`

`s=0; a=0; b=0;`

`#1`

`s=0; a=0; b=1;`

`#1`

`s=0; a=1; b=0;`

`#1`

`:`

`:`

`s=1; a=1; b=1;`

`#1`

`$finish.`

`end.`

`endmodule;`

2nd method :

`module tb_mux2to1();`

`reg s, a, b;`

`reg {2:0} i;`

`wire y;`

`mux2to1 (s, a, b, y);`

`initial begin`

`for (i=0; i<8; i=i+1) begin`

`#1 {s, a, b} = i;`

`end`

`$finish; end endmodule;`

4:1 MUX using 2:1 MUX

```
module mux4to1 (
    input [1:D] Sel,
    input [3:D] I,
    output Y
);
wire st10, st11;
MUX2to1 M1(Sel[0], I[0], I[1], st10),
M2(Sel[0], I[2], I[3], st11),
M3(Sel[1], st10, st11, Y);
endmodule
```

- This is structural model.

### Data flow representation

- Represented as a set of continuous assignments.
- Use keyword 'assign'.
- Mostly for describing the Boolean equation of combinational logic.
- Use operators that act on binary operands to produce a binary result.
- Bitwise & logical operator -  $\sim(1010)$  is 0101;  
 $!(1010)$  is 0.

# Test bench for 4:1 MUX

```
module mux4to1( );
reg [1:0] s;
reg [3:0] imp;
integer i,j;
wire y;
mux4to1(s, imp, y)
initial begin
for (i=0; i<4; i=i+1) begin
    S=i ;
    for (j=0; j<16; j=j+1) begin
        #1 imp=j
    end
end
$finish;
end
endmodule
```

# Verilog Operators

|            |                    |
|------------|--------------------|
| { }        | concatenation      |
| + - * / ** | arithmetic         |
| %          | modulus            |
| > >= < <=  | relational         |
| !          | logical NOT        |
| &&         | logical AND        |
|            | logical OR         |
| ==         | logical equality   |
| !=         | logical inequality |
| ====       | case equality      |
| !==        | case inequality    |
| ? :        | conditional        |

|       |                |
|-------|----------------|
| ~     | bit-wise NOT   |
| &     | bit-wise AND   |
|       | bit-wise OR    |
| ^     | bit-wise XOR   |
| ^~ ~^ | bit-wise XNOR  |
| &     | reduction AND  |
|       | reduction OR   |
| ~&    | reduction NAND |
| ~     | reduction NOR  |
| ^     | reduction XOR  |
| ~^ ~~ | reduction XNOR |
| <<    | shift left     |
| >>    | shift right    |

2.1 MUX in dataflow modul:

```
module mux2to1 (
    input s,
    input I0,
    input I1,
    output Y );
    assign Y = (!s && I0) || (s && I1);
endmodule;
```

## Structural Representation

- Use gate level primitives, user defined primitives, module instances (hierarchy)
- Representation similar to interconnected hardware
- Ports - data type - net - connection
- Named port assignments and ordered port assignments
- Port name of sub module (port name of outer module)

## Net & Variable types

- Predefined by language - user defined types not allowed.
- Net - node in a circuit.
- Commonly used net - wire and tri.

- Variable - abstract data storage element
- Commonly used variable - integer & reg

Net:

- Wire - connect output of logic element to input of other logic element.
- Scalar wire declaration:
  - wire x;
  - wire cin, sout ;
- Vector wire declaration:      wire [3:0] s;  
                                        wire [1:2] arr;

Wire: Bit selection operation -  $f = s[0]$  - index can be variable  
Part selection operation - arr = s[2:0]

Tri: • Represents nodes connected in tristate form.

Eg: tri z;      tri [7:0] dt;

• Used to enhance readability of codes involving tri state gates.

Variables: Commonly used for behavioral modelling

Eg: reg [2:0] cnt;      integer k;

→ Memory - 2D array :- Eg: Reg [7:0] Reg [3:0]

R - 4 8-bit variable - R[1] - 8 bit variable - R[3][7]

## Behavioral Representation

- structural representation using gate level primitives - difficult of large designs
- Use verilog procedural statement.
- used inside always block
- Procedural statement ex: if-else : case : loop
- Datatype - Variable (reg) - assigned a value inside always block and retains value till a new value is assigned.

### Syntax of always statement

always @ (sensitivity-list)  
[begin]  
[procedural assignment statements]  
[if - else statements]  
[case statements]  
[while, repeat & for loops]  
[task and function calls]  
[end]

### 2:1 MUX in behavioral style:

```
1> module mux21(s, a, b, y)
  input s, a, b;
  output y;
  reg y;
```

```
always @ (s, a, b) begin // ←---- Sensitivity list
    if (s == 1'b0)
        Y <= a;
    else
        Y <= b;
end
endmodule
```

2) module mux21 (s, a, b, y)

input s, a, b;

output y;

reg y;

always @ (s, a, b) begin

case (s)

0: y <= a;

1: y <= b;

endcase

end

endmodule

### Loop Statements

1) for:-

```
for (initial_index; terminal_index; increment)
begin
    statement;
end
```

2) repeat:

repeat ( constant value)  
begin  
    Statement;  
end

3) while:

while ( condition)  
begin  
    Statement;  
end

Test bench    verification

'timescale 1ns / 1ps // Here 1ns is scale & 1ps is precision.  
module mux2lfb();  
 reg s;  
 reg I0;  
 reg I1;  
 wire Y;  
 integer i;  
 mux2 ml(s, I0, I1, Y)  
initial begin  
 for (i=0; i<8; i=i+1)  
begin  
 {s, I0, I1} = i;  
 # 5

```
if ((s=1'b0) && (y1=IO)) fail();
else if ((s=1'b1) && (y1=I1)) fail();
else pass();
end
```

```
$ display ("Design verified successfully");
$ finish();
end
```

```
task fail();
```

```
begin
```

```
    $ display ("When, S,a,b = 1.b, 1.b, 1.b, output  
= 1.b is wrong", s, IO, I1, y);
```

```
    $ finish();
end
```

```
endtask
```

```
task pass();
```

```
    $ display ("When S, a, b = 1.b, 1.b, 1.b , output = 1.b",
S, IO, I1, y);
endtask
```

```
endmodule
```

## Blocking versus Non-blocking Procedural assignments

- Blocking (=) or Non blocking (<=)
- LHS - register type variable (reg, integer, time, real)
  - Bit select (a[3]) or part select (b[3:1]) of variable
  - concatenation of any of the above ({s, a[3]}, b[3:1])
- RHS - any expression consisting of net or reg that evaluates to

## Blocking procedural assignments

- Sequential execution
- LHS variable updated before next statement is executed
- Sequential execution limited to that procedural block.
- Recommended style for combinational circuits.

## Non blocking assignments

- Schedule events on LHS variable without blocking any other assignment within the block.
- Variables updated simultaneously at the end of that simulation time.
- Concurrent procedural assignment
- Recommended style for sequential circuits.

## Sequential network



## Types of sequential network.

Asynchronous network: output is shown immediately whenever there is a change in input.

Synchronous network: output is shown after some time whenever there is a change in input. Clock signal is used to create a delay.

## Latch: - Fundamental building block

### 1) SR latch:

(S-R = Set - Reset)

| not |   |   |
|-----|---|---|
| a   | b | y |
| 0   | 0 | 1 |
| 0   | 1 | 0 |
| 1   | 0 | 0 |
| 1   | 1 | 0 |



| R | S | Q         | $\bar{Q}$       |
|---|---|-----------|-----------------|
| 0 | 0 | $Q_{n-1}$ | $\bar{Q}_{n-1}$ |
| 0 | 1 | 1         | 0               |
| 1 | 0 | 0         | 1               |
| 1 | 1 | 0         | 0               |

→ Function table

But invalid combination as  $Q \& \bar{Q}$  both are 0

If R, S changes from 11 to 00 it becomes metastable.



| R | S | Q         | $\bar{Q}$       |
|---|---|-----------|-----------------|
| 0 | 0 | 0         | 0               |
| 0 | 1 | 0         | 1               |
| 1 | 0 | 1         | 0               |
| 1 | 1 | $Q_{n-1}$ | $\bar{Q}_{n-1}$ |

Symbol:



Switch      debounce



→ Switch debounce

Timing      diagram



gated      SR      latch



## Function table

| i/p |   |   | o/p       |                 |
|-----|---|---|-----------|-----------------|
| C   | S | R | Q         | $\bar{Q}$       |
| 0   | x | x | $Q_{n-1}$ | $\bar{Q}_{n-1}$ |
| 1   | 0 | 0 | $Q_{n-1}$ | $\bar{Q}_{n-1}$ |
| 1   | 0 | 1 | 0         | 1               |
| 1   | 1 | 0 | 1         | 0               |
| 1   | 1 | 1 | 0         | 0               |

→ not valid

## Data latch (D-latch)



## Function table

| i/p |   | o/p       |                 |
|-----|---|-----------|-----------------|
| C   | D | Q         | $\bar{Q}$       |
| 0   | 0 | $Q_{n-1}$ | $\bar{Q}_{n-1}$ |
| 0   | 1 | $Q_{n-1}$ | $\bar{Q}_{n-1}$ |
| 1   | 0 | 0         | 1               |
| 1   | 1 | 1         | 0               |



Flipflops → Output changes with change in control line:  
 MasterSlave (pulse triggered) or edge triggered.



$t < t_1 \quad \& \quad t > t_4 \rightarrow$  slave enabled  
 $t_2 < t < t_3 \rightarrow$  master enabled  
 $t_1 < t < t_2 \quad \& \quad t_3 < t < t_4 \rightarrow$  both are disabled.

Function table

| i/p |   | o/p     |           |                 |
|-----|---|---------|-----------|-----------------|
| S   | R | C       | Q         | $\bar{Q}$       |
| 1   | 0 | [Pulse] | 1         | 0               |
| 0   | 1 | [Pulse] | 0         | 1               |
| 0   | 0 | [Pulse] | $Q_{n-1}$ | $\bar{Q}_{n-1}$ |
| 1   | 1 | [Pulse] | 0         | 0               |

→ not allowed

Output is shown only after complete pulse ( $\sqcap L$ )

Timing diagram:



O/P depends on  $S, R$  as well as  $\uparrow, \downarrow$  & duration of  $\text{clk}$   $\Rightarrow$  Pulse triggered.

### **5-Variable K Map**

Simplify the Boolean function using K Map

$$1. F(A, B, C, D, E) = \sum m(0, 2, 4, 6, 9, 11, 13, 15, 17, 21, 25, 27, 29, 31)$$

$$2. F(x_1, x_2, x_3, x_4, x_5) = \sum m(1, 2, 3, 6, 8, 9, 14, 17, 24, 25, 26, 27, 30, 31) + \sum d(4, 5)$$

$$3. F(P, Q, R, S, T) = \prod M(0, 5, 6, 8, 9, 10, 11, 16, 20, 22, 24, 25, 26, 27)$$

### **VEM Method**

Simplify the Boolean function using VEM Method

$$1. F(A, B, C) = \sum m(0, 1, 4, 5, 7)$$

$$2. F(P, Q, R, S) = \sum m(1, 5, 6, 12, 13, 14) + \sum d(2, 4)$$

$$3. F(P, Q, R, S, T) = \sum m(0, 2, 4, 6, 7, 9, 12, 13, 15, 18, 21, 22, 23, 24, 25, 26, 27)$$

Q15  $F(A, B, C, D, E) = \sum m(0, 2, 4, 6, 9, 11, 13, 15, 17, 21, 25, 27, 29, 31)$

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

$\bar{A}$

| $D\bar{E}$ | $\bar{B}\bar{C}$ | $\bar{B}C$ | $BC$ | $B\bar{C}$ |
|------------|------------------|------------|------|------------|
| $00$       | 16               | 20         | 28   | 24         |
| $01$       | 0                | 0          | 0    | 0          |
| $10$       | 17               | 21         | 29   | 25         |
| $11$       | 1                | 1          | 1    | 1          |
| $D\bar{E}$ | 19               | 23         | 31   | 27         |
| $D\bar{E}$ | 0                | 0          | 1    | 1          |
| $D\bar{E}$ | 18               | 22         | 30   | 26         |
| $D\bar{E}$ | 0                | 0          | 0    | 0          |

$A$

$$F = BE + A\bar{D}\bar{E} + \bar{A}\bar{D}\bar{E}$$

$$2) F(A, B, C, D, \bar{E}) = \sum m(1, 2, 3, 6, 8, 9, 14, 17, 24, 25, 26, 27, 30, 31) + \sum d(0)$$

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

|            |    | $\bar{B}\bar{C}$ | $\bar{B}C$ | $BC$ | $B\bar{C}$ |
|------------|----|------------------|------------|------|------------|
|            |    | 00               | 01         | 11   | 10         |
| $\bar{D}E$ | 00 | 16               | 0          | 0    | 1          |
|            | 01 | 17               | 21         | 29   | 25         |
| $\bar{D}E$ | 11 | 19               | 23         | 31   | 27         |
|            | 10 | 18               | 22         | 30   | 26         |
| $A$        |    |                  |            |      |            |

$$F = \bar{A}\bar{B}\bar{C} + B\bar{C}\bar{D} + \bar{A}C\bar{D}\bar{E} + ABD + \bar{C}\bar{D}\bar{E}$$

$$3) F(A, B, C, D, E) = \sum m(1, 2, 3, 6, 8, 9, 14, 17, 24, 25, 26, 27, 30, 31) + \sum d(4, 5)$$

→

|                  |    | $\bar{B}\bar{C}$ | $\bar{B}C$ | $BC$ | $B\bar{C}$ |
|------------------|----|------------------|------------|------|------------|
|                  |    | 00               | 01         | 11   | 10         |
| $\bar{D}\bar{E}$ | 00 | 0                | 4          | X    | 12         |
|                  | 01 | 1                | 5          | X    | 13         |
| $\bar{D}E$       | 00 | 1                | 5          | X    | 13         |
|                  | 01 | 3                | 7          | 0    | 15         |
| $D\bar{E}$       | 00 | 1                | 3          | 0    | 11         |
|                  | 01 | 2                | 6          | 14   | 10         |
| $D\bar{E}$       | 00 | 1                | 6          | 14   | 10         |
|                  | 01 | 1                | 1          | 1    | 0          |

$\bar{A}$

|                  |    | $\bar{B}\bar{C}$ | $\bar{B}C$ | $BC$ | $B\bar{C}$ |
|------------------|----|------------------|------------|------|------------|
|                  |    | 00               | 01         | 11   | 10         |
| $\bar{D}\bar{E}$ | 00 | 16               | 0          | 0    | 0          |
|                  | 01 | 17               | 1          | 0    | 0          |
| $\bar{D}E$       | 00 | 17               | 21         | 29   | 25         |
|                  | 01 | 19               | 23         | 31   | 27         |
| $D\bar{E}$       | 00 | 0                | 0          | 1    | 1          |
|                  | 01 | 19               | 22         | 30   | 26         |
| $D\bar{E}$       | 00 | 0                | 0          | 1    | 1          |
|                  | 01 | 1                | 1          | 1    | 0          |

$A$

$$F = \bar{A}\bar{B}\bar{C}D + \bar{C}\bar{D}E + \bar{A}C\bar{D}\bar{E} + ABD + B\bar{C}\bar{D}$$

$$\hookrightarrow F(P, Q, R, S, T) = \pi M(0, 5, 6, 8, 9, 10, 11, 16, 20, 22, 24, 25, 26, 27)$$

|             |    | $Q+R$  | $\bar{Q}+R$ | $Q+\bar{R}$ | $\bar{Q}+\bar{R}$ | $\bar{Q}+R$ |
|-------------|----|--------|-------------|-------------|-------------------|-------------|
|             |    | 00     | 01          | 11          | 10                | 10          |
| $S+T$       | 00 | 0<br>0 | 4<br>       | 12<br>      | 8<br>0            |             |
| $S+T$       | 01 | 1<br>  | 5<br>0      | 13<br>      | 9<br>0            |             |
| $S+\bar{T}$ | 11 | 3<br>  | 7<br>       | 15<br>      | 11<br>0           |             |
| $\bar{S}+T$ | 10 | 2<br>  | 6<br>0      | 14<br>      | 10<br>0           |             |
| $\bar{S}+T$ | 10 |        |             |             |                   |             |

$P$

|             |    | $Q+R$   | $\bar{Q}+R$ | $Q+\bar{R}$ | $\bar{Q}+\bar{R}$ | $\bar{Q}+R$ |
|-------------|----|---------|-------------|-------------|-------------------|-------------|
|             |    | 00      | 01          | 11          | 10                | 10          |
| $S+T$       | 00 | 16<br>0 | 20<br>0     | 28<br>      | 25<br>0           |             |
| $S+T$       | 01 | 17<br>  | 21<br>      | 29<br>      | 25<br>0           |             |
| $S+\bar{T}$ | 11 | 19<br>  | 23<br>      | 31<br>      | 27<br>0           |             |
| $\bar{S}+T$ | 10 | 18<br>  | 22<br>0     | 30<br>      | 26<br>0           |             |
| $\bar{S}+T$ | 10 |         |             |             |                   |             |

$\bar{P}$

$$F = (\bar{Q}+R) \cdot (Q+R+S+T) \cdot (Q+\bar{R}+\bar{S}+\bar{T}) \cdot (\bar{P}+Q+S+T) \cdot (P+Q+\bar{R}+\bar{S}+\bar{T})$$

JK flipflop

At '11' in JK flipflop will toggle o/p.



Function table

| J | K | C | Q         | $\bar{Q}$       |
|---|---|---|-----------|-----------------|
| X | X | 0 | $Q_{n-1}$ | $\bar{Q}_{n-1}$ |
| 0 | 0 | — | $Q_{n-1}$ | $\bar{Q}_{n-1}$ |
| 0 | 1 | — | 0         | 1               |
| 1 | 0 | — | 1         | 0               |
| 1 | 1 | — | Toggle    |                 |

JK latch



# Timing diagram for JK flipflop



$\overset{1}{\underset{\sim}{J}}$   $\overset{0}{\underset{\sim}{K}}$  catch:

$$J = 0 \rightarrow 1 \rightarrow 0$$

$$K = 0$$

$$\text{clk} = 1$$

$$Q = 0 \rightarrow 1$$

$\overset{0}{\underset{\sim}{Q}}$   $\overset{1}{\underset{\sim}{K}}$  catch

$$Q = 1$$

$$\text{clk} = 1$$

$$J = 0$$

$$K \rightarrow 0 \rightarrow 1$$

Flipflops: (JK, SR, D, T (toggle))

| T | C         | $Q_n$           | $\bar{Q}_n$     | $\leftarrow$ T flipflop |
|---|-----------|-----------------|-----------------|-------------------------|
| 0 | $\square$ | $Q_{n-1}$       | $\bar{Q}_{n-1}$ |                         |
| 1 | $\square$ | $\bar{Q}_{n-1}$ | $Q_{n-1}$       |                         |

- MS flipflop : • 0's & 1's catching will have  
 $\sim T/2$  delay in o/p.  
 • So edge triggered flipflops are used.  
 • only one clock edge to control.

+ve edge triggered D - flipflops



when  $C = 0$

$$P_1 = 1 \quad P_2 = 1 \quad \Rightarrow \quad Q_n = Q_{n-1} \quad \bar{Q}_n = \bar{Q}_{n-1}$$

when  $C = 1$

- If  $P_3 = 0$  :  $P_1 = 1$        $P_2 = 0$ ,  $P_4 = 1$
- If  $P_3 = 1$  :  $P_1 = 0$        $P_2 = 1$

Function table :

| OP: | gate | i/p     |                 | o/p     |         |
|-----|------|---------|-----------------|---------|---------|
|     |      | $C = 0$ | $D = 0$         | $C = 1$ | $D = 0$ |
| 1   |      | 0       |                 | 0       |         |
| 2   |      | 1       |                 | 1       |         |
| 3   |      |         | 1               |         | 0       |
| 4   |      |         | 1               |         | 1       |
| 5   |      |         | $Q_{n-1}$       |         | 0       |
| 6   |      |         | $\bar{Q}_{n-1}$ |         | 1       |

| gate | $C=0$ | $D=1$                | $C=1$ | $D=1$ |
|------|-------|----------------------|-------|-------|
| 1    |       | 1                    |       | 0     |
| 2    |       | 1                    |       | 1     |
| 3    |       | 1                    |       | 1     |
| 4    |       | 0                    |       | 0     |
| 5    |       | $\overline{Q_{n-1}}$ |       | 1     |
| 6    |       | $\overline{Q_{n-1}}$ |       | 0     |

Asynchronous      preset      and      clear

Preset



clear





Function table

| i/p |     |   |     | o/p |           |
|-----|-----|---|-----|-----|-----------|
| Pre | clr | D | clk | Q   | $\bar{Q}$ |
| 0   | 1   | x | x   | 1   | 0         |
| 1   | 0   | x | x   | 0   | 1         |
| 1   | 1   | 0 | ↑   | 0   | 1         |
| 1   | 1   | 1 | ↑   | 1   | 0         |

Registers :- collection of flipflops capable of storing and modifying multiple data bits

shift register : A register capable of shifting its content with clock

4 bit register:



types: Serial in - Serial out - SISO  
Serial in - Parallel out - SIPD

- 3) Parallel in serial out - PISO
- 4) Parallel in parallel out - PIPO

SISO unidirection shift register ( $\downarrow$  bit)



Serial input - SI

## SO - Serial output

Right shift ↑

$$SI = 010$$

$$S0 = 0110\ 000 \quad (7 \text{ clock pulses})$$



Left Shift

↑ 0  
↑ 0  
↑ 0  
↑ 0  
↑ 1  
↑ 1  
↑ 0

2) S1 P0:



Data i/p  $\xi$  O/p ( $i/p - 0110$ )



3) P1 P0:





Universal

bidirectional

shift registers

select lines

|       |       |
|-------|-------|
| $S_0$ | $S_1$ |
| 0     | 0     |
| 0     | 1     |
| 1     | 0     |
| 1     | 1     |

Rig operation

hold  
shift right  
shift left  
parallel load



Counters: (Pattern generator)

Simpli counters: Increment / decrement count with the application of clock

Module ' $M$ ' counter  $\Rightarrow$  has ' $M$ ' distinct states / counts

State diagram:



Binary Ripple counter

count sequence in Hexadecimal:

$0 \rightarrow 1 \rightarrow 2 \rightarrow 3 \rightarrow \dots \rightarrow 8 \rightarrow 9 \rightarrow A \rightarrow B \rightarrow \dots \rightarrow F \rightarrow 0$



T flipflops are used

count sequence in binary:

| clk | $Q_3$ | $Q_2$ | $Q_1$ | $Q_0$ |
|-----|-------|-------|-------|-------|
| ↑   | 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     |



Timing diagram :



Down counter



Decade counter ; (use of preset & clear inputs  
to control start & end count)



clear when  
 $Q_3 Q_2 Q_1 Q_0 = 1010$



Ripple counter to count from 2 to 6

when count = 7  $\rightarrow$  preset to 2

$$Q_2 Q_1 Q_0 = 111$$

$\rightarrow$



clear



IC 7490:

input A NC  $Q_A$   $Q_D$  GND  $Q_B$   $Q_C$



input B  $R_{Q(1)}$   $R_{Q(2)}$  NC  $V_{CC}$   $R_{Q(1)}$   $R_{Q(2)}$

Block diagram



Reset / count function table :

| Reset    | inputs   | outputs  |          |       |       |       |       |
|----------|----------|----------|----------|-------|-------|-------|-------|
| $R_0(1)$ | $R_0(2)$ | $R_q(1)$ | $R_q(2)$ | $Q_D$ | $Q_C$ | $Q_B$ | $Q_A$ |
| 1        | 1        | 0        | x        | 0     | 0     | 0     | 0     |
| 1        | 1        | x        | 0        | 0     | 0     | 0     | 0     |
| x        | x        | 1        | 1        | 1     | 0     | 0     | 1     |
| x        | 0        | x        | 0        | count |       |       |       |
| 0        | x        | 0        | x        | count |       |       |       |
| 0        | x        | x        | 0        | count |       |       |       |
| x        | 0        | 0        | x        | count |       |       |       |

Next state table & characteristic equation

D flipflop

| D | Q | $Q^+$ |
|---|---|-------|
| 0 | 0 | 0     |
| 0 | 1 | 0     |
| 1 | 0 | 1     |
| 1 | 1 | 1     |

$$Q^+ = D$$

T flipflop

| T | Q | $Q^+$ |
|---|---|-------|
| 0 | 0 | 0     |
| 0 | 1 | 1     |
| 1 | 0 | 1     |
| 1 | 1 | 0     |

$$Q^+ = T \oplus Q$$

JK flipflop

| J | K | Q | $Q^+$ |
|---|---|---|-------|
| 0 | 0 | 0 | 0     |
| 0 | 0 | 1 | 1     |
| 0 | 1 | 0 | 0     |
| 0 | 1 | 1 | 0     |
| 1 | 0 | 0 | 1     |
| 1 | 0 | 1 | 1     |
| 1 | 1 | 0 | 1     |
| 1 | 1 | 1 | 0     |

$$Q^+ = J\bar{Q} + \bar{K}Q$$

SR flipflop

| S | R | Q | $Q^+$ |
|---|---|---|-------|
| 0 | 0 | 0 | 0     |
| 0 | 0 | 1 | 1     |
| 0 | 1 | 0 | 0     |
| 0 | 1 | 1 | 0     |
| 1 | 0 | 0 | 1     |
| 1 | 0 | 1 | 1     |
| 1 | 1 | 0 | X     |
| 1 | 1 | 1 | X     |

$$Q^+ = S + \bar{R}Q$$

## Tutorial 3

1) How many 2:1 MUX are required to implement  
i) AND      ii) OR      iii) XOR

Ans

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

i) AND



ii) OR:

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



iii)

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



2) Identify function Y:



$$\begin{aligned}
 Y &= \bar{S_1} \bar{S_0} \bar{Z} + S_1 \bar{S_0} + S_1 S_0 Z \\
 &= S_0 (\bar{S_1} \bar{Z} + S_1 Z) + S_1 \bar{S_0} \\
 &= S_0 (S_1 \odot Z) + S_1 \bar{S_0}
 \end{aligned}$$

or  $Y = \sum m(2, 4, 5, 7)$

3) Implement  $f(x, y, z) = \prod M(2, 3, 4, 7)$  using 4:1 MUX

Ans

| x | y | z | f |
|---|---|---|---|
| 0 | 0 | 0 | 1 |
| 0 | 0 | 1 | 1 |
| 0 | 1 | 0 | 0 |
| 0 | 1 | 1 | 0 |
| 1 | 0 | 0 | 0 |
| 1 | 0 | 1 | 1 |
| 1 | 1 | 0 | 1 |
| 1 | 1 | 1 | 0 |



4) Implement  $Y(A, B, C, D) = \sum (2, 4, 6, 14)$  using 4:1 MUX and gates

Ans

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

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



5> Implement 3:8 decoder using 2:4 decoders



6> Implement  $F(A, B) = \sum m(0, 2, 3)$  using a decoder  
with i> active high output  
ii> active low output

Ans



ii>



7) Output of given logic circuit is :



Ans

$$Y = \left( \sum_{\overline{B}\overline{C}} m(0, 1, 2, 4, 7) \right) \cdot D$$

$$Y = (\overline{A}\overline{B} + \overline{A}\overline{C} + \overline{B}\overline{C} + ABC) \cdot D$$

|   | 0 | 1 | 3 | 2 |
|---|---|---|---|---|
| 0 | 1 |   | 0 |   |
| 1 |   | 1 | 0 | 1 |
| A |   |   | 1 | 0 |

8) Implement high o/p  $Y(X_0, X_1, X_2) = \sum(1, 2, 4, 5, 7)$  using active 3:8 decoder



## Synchronous counter design



## Application table

| $Q$ | $Q^+$ | $D$ | $D$ |
|-----|-------|-----|-----|
| 0   | 0     | 0   |     |
| 0   | 1     | 1   |     |
| 1   | 0     | 0   |     |
| 1   | 1     | 1   |     |

| $Q$ | $Q^+$ | $T$ | $T$ |
|-----|-------|-----|-----|
| 0   | 0     | 0   |     |
| 0   | 1     | 1   |     |
| 1   | 0     | 1   |     |
| 1   | 1     | 0   |     |

JK:

| $Q$ | $Q^+$ | $J$ | $K$ |
|-----|-------|-----|-----|
| 0   | 0     | 0   | X   |
| 0   | 1     | 1   | X   |
| 1   | 0     | X   | 1   |
| 1   | 1     | X   | 0   |

SR:

| $Q$ | $Q^+$ | $S$ | $R$ |
|-----|-------|-----|-----|
| 0   | 0     | 0   | X   |
| 0   | 1     | 1   | 0   |
| 1   | 0     | 0   | 1   |
| 1   | 1     | X   | 0   |

# Design mod-6 gray code counter (synchronous)



Excitation table for DFF

| Present state |       |       | Next state |         |         | flipflop inputs |       |       |
|---------------|-------|-------|------------|---------|---------|-----------------|-------|-------|
| $Q_3$         | $Q_2$ | $Q_1$ | $Q_3^+$    | $Q_2^+$ | $Q_1^+$ | $D_3$           | $D_2$ | $D_1$ |
| 0             | 0     | 0     | 0          | 1       | 0       | 0               | 1     | 0     |
| 0             | 1     | 0     | 0          | 1       | 1       | 0               | 1     | 1     |
| 0             | 1     | 1     | 1          | 1       | 1       | 1               | 1     | 1     |
| 1             | 1     | 1     | 1          | 0       | 1       | 1               | 0     | 1     |
| 1             | 0     | 1     | 0          | 0       | 1       | 0               | 0     | 1     |
| 0             | 0     | 1     | 0          | 0       | 0       | 0               | 0     | 0     |

| $\bar{Q}_2 \bar{Q}_1$ | $\bar{Q}_2 Q_1$ | $Q_2 Q_1$ | $Q_2 \bar{Q}_1$ |
|-----------------------|-----------------|-----------|-----------------|
| 0                     | 1               | 3         | 2               |
| 0                     | 0               | 1         | 0               |
| 1                     | X               | 0         | X               |

| $\bar{Q}_2 \bar{Q}_1$ | $\bar{Q}_2 Q_1$ | $Q_2 Q_1$ | $Q_2 \bar{Q}_1$ |
|-----------------------|-----------------|-----------|-----------------|
| 0                     | 1               | 3         | 2               |
| 0                     | 1               | 0         | 1               |
| 1                     | X               | 0         | X               |

$$D_3 = Q_2 Q_1$$

$$D_2 = \bar{Q}_1 + \bar{Q}_3 Q_2$$

| $\bar{Q}_3$ | $\bar{Q}_2 \bar{Q}_1$ | $\bar{Q}_2 Q_1$ | $Q_2 Q_1$ | $Q_2 \bar{Q}_1$ |
|-------------|-----------------------|-----------------|-----------|-----------------|
| $\bar{Q}_3$ | 0                     | 1               | 3         | 2               |
| $Q_3$       | 0                     | 0               | 1         | 1               |
| $\bar{Q}_3$ | X                     | 1               | 1         | X               |
| $Q_3$       | 1                     |                 |           |                 |

$$D_1 = Q_2 + Q_3$$



Using JK flip-flop

| Present state |       |       | Next state |         |         | flip flop inputs |       |       |       |       |       |
|---------------|-------|-------|------------|---------|---------|------------------|-------|-------|-------|-------|-------|
| $Q_3$         | $Q_2$ | $Q_1$ | $Q_3^+$    | $Q_2^+$ | $Q_1^+$ | $J_3$            | $K_3$ | $J_2$ | $K_2$ | $J_1$ | $K_1$ |
| 0             | 0     | 0     | 0          | 1       | 0       | 0                | X     | 1     | X     | 0     | X     |
| 0             | 1     | 0     | 0          | 1       | 1       | 0                | X     | X     | 0     | 1     | X     |
| 0             | 1     | 1     | 1          | 1       | 1       | 1                | X     | X     | 0     | X     | 0     |
| 1             | 1     | 1     | 1          | 0       | 1       | X                | 0     | X     | 1     | X     | 0     |
| 1             | 0     | 1     | 0          | 0       | 1       | X                | 1     | 0     | X     | X     | 0     |
| 0             | 0     | 1     | 0          | 0       | 0       | 0                | X     | 0     | X     | X     | 1     |

| $\bar{Q}_3$ | $\bar{Q}_2 \bar{Q}_1$ | $\bar{Q}_2 Q_1$ | $Q_2 Q_1$ | $Q_2 \bar{Q}_1$ |
|-------------|-----------------------|-----------------|-----------|-----------------|
| $\bar{Q}_3$ | 0                     | 1               | 3         | 2               |
| $Q_3$       | 0                     | 0               | 1         | 1               |
| $\bar{Q}_3$ | X                     | X               | X         | X               |
| $Q_3$       | 1                     |                 |           |                 |

$$J_3 = Q_1 Q_2$$

$$K_3 = \bar{Q}_2$$

$$J_2 = \bar{Q}_1$$

$$K_2 = Q_3$$

$$J_1 = Q_2$$

$$K_1 = \bar{Q}_3 \bar{Q}_2$$



counter design using shift register

non binary counters:



Ring counter  $\rightarrow$  N-bit counter

only one bit is set at a given count.

Hence n bit shift register  $\Rightarrow$  N distinct count.



It needs initialisation before counting

|   | $Q_3$ | $Q_2$ | $Q_1$ | $Q_0$ |
|---|-------|-------|-------|-------|
| 0 | 0     | 0     | 0     | 1     |

|            |   |   |   |   |
|------------|---|---|---|---|
| $\uparrow$ | 1 | 0 | 0 | 0 |
| $\uparrow$ | 0 | 1 | 0 | 0 |
| $\uparrow$ | 0 | 0 | 1 | 0 |
| $\uparrow$ | 0 | 0 | 0 | 1 |

4 counts

Johnson counter:

If we give input to 1st flip flop from  $\bar{Q}$

we get 2n states for n flip flops

i, l

|   | $Q_3$ | $Q_2$ | $Q_1$ | $Q_0$ |  |
|---|-------|-------|-------|-------|--|
| ↑ | 1     | 0     | 0     | 0     |  |
| ↑ | 1     | 1     | 0     | 0     |  |
| ↑ | 1     | 1     | 1     | 0     |  |
| ↑ | 1     | 1     | 1     | 1     |  |
| ↑ | 0     | 1     | 1     | 1     |  |
| ↑ | 0     | 0     | 1     | 1     |  |
| ↑ | 0     | 0     | 0     | 1     |  |
| ↑ | 0     | 0     | 0     | 0     |  |

8 states

universal    shift    register

IC74194:



## Function table

| Clk\A | Inputs         |                |        |   |          |   |   |   | Outputs        |                 |                 |                 |
|-------|----------------|----------------|--------|---|----------|---|---|---|----------------|-----------------|-----------------|-----------------|
|       | Mode           | Clock          | Serial |   | Parallel |   |   |   | Q <sub>A</sub> | Q <sub>B</sub>  | Q <sub>C</sub>  | Q <sub>D</sub>  |
|       | S <sub>1</sub> | S <sub>0</sub> |        | L | R        | A | B | C | D              |                 |                 |                 |
| L     | X              | X              | X      | X | X        | X | X | X | X              | L               | L               | L               |
| H     | X              | X              | ↓      | X | X        | X | X | X | X              | Q <sub>A0</sub> | Q <sub>B0</sub> | Q <sub>C0</sub> |
| H     | H              | H              | ↑      | X | X        | a | b | c | d              | a               | b               | c               |
| H     | L              | H              | ↑      | X | H        | X | X | X | X              | H               | Q <sub>An</sub> | Q <sub>Bn</sub> |
| H     | L              | H              | ↑      | X | L        | X | X | X | X              | L               | Q <sub>An</sub> | Q <sub>Cn</sub> |
| H     | H              | L              | ↑      | H | X        | X | X | X | X              | Q <sub>Bn</sub> | Q <sub>Cn</sub> | Q <sub>Dn</sub> |
| H     | H              | L              | ↑      | L | X        | X | X | X | X              | Q <sub>Bn</sub> | Q <sub>Cn</sub> | Q <sub>Dn</sub> |
| H     | L              | L              | X      | X | X        | X | X | X | X              | Q <sub>A0</sub> | Q <sub>B0</sub> | Q <sub>C0</sub> |
|       |                |                |        |   |          |   |   |   |                |                 |                 | Q <sub>D0</sub> |

S<sub>1</sub>, S<sub>0</sub> = 00 → hold

S<sub>1</sub>, S<sub>0</sub> = 01 → Shift right

S<sub>1</sub>, S<sub>0</sub> = 10 → Shift left

S<sub>1</sub>, S<sub>0</sub> = 11 → Parallel load



| clk | Q <sub>A</sub> | Q <sub>B</sub> | Q <sub>C</sub> | Q <sub>D</sub> |
|-----|----------------|----------------|----------------|----------------|
| ↑   | 0              | 0              | 0              | 1              |
| ↑   | 0              | 0              | 1              | 0              |
| ↑   | 0              | 1              | 0              | 0              |
| ↑   | 1              | 0              | 0              | 0              |
| ↑   | 0              | 0              | 0              | 1              |

Arbitrary counter using shift registers

Based on present state choose S<sub>IL</sub>, S<sub>IR</sub>, S<sub>I</sub>, S<sub>O</sub>  
which produce required next states

In: count sequence: 0 → 8 → 12 → 6 → 13 → 11 → 7 → 3 → 1 → 0

| Present state  |                |                |                | Next state                  |                             |                             |                             | Shift reg       |                 | inputs         |                |
|----------------|----------------|----------------|----------------|-----------------------------|-----------------------------|-----------------------------|-----------------------------|-----------------|-----------------|----------------|----------------|
| Q <sub>A</sub> | Q <sub>B</sub> | Q <sub>C</sub> | Q <sub>D</sub> | Q <sub>A</sub> <sup>+</sup> | Q <sub>B</sub> <sup>+</sup> | Q <sub>C</sub> <sup>+</sup> | Q <sub>D</sub> <sup>+</sup> | S <sub>IL</sub> | S <sub>IR</sub> | S <sub>I</sub> | S <sub>O</sub> |
| 0              | 0              | 0              | 0              | 1                           | 0                           | 0                           | 0                           | 0               | 1               | 0              | 1              |
| 8              | 1              | 0              | 0              | 0                           | 1                           | 0                           | 0                           | 0               | 1               | 0              | 1              |
| 12             | 1              | 1              | 0              | 0                           | 1                           | 1                           | 0                           | 0               | 0               | 0              | 1              |
| 6              | 0              | 1              | 1              | 0                           | 1                           | 1                           | 0                           | 1               | 0               | 1              | 0              |
| 13             | 1              | 1              | 0              | 1                           | 1                           | 0                           | 1                           | 1               | 0               | 1              | 0              |
| 11             | 1              | 0              | 1              | 1                           | 0                           | 1                           | 1                           | 1               | 0               | 1              | 0              |
| 7              | 0              | 1              | 1              | 1                           | 0                           | 0                           | 1                           | 0               | 0               | 0              | 1              |
| 3              | 0              | 0              | 1              | 1                           | 0                           | 0                           | 0                           | 1               | 0               | 0              | 1              |
| 1              | 0              | 0              | 0              | 1                           | 0                           | 0                           | 0                           | 0               | 0               | 0              | 1              |

$$S_1 = \overline{Q_D} Q_C Q_B \overline{Q_A} + Q_D Q_A (Q_C \oplus Q_B)$$

$$S_0 = \overline{Q_C} \overline{Q_D} \overline{Q_A} + \overline{Q_D} Q_B Q_A + Q_D \overline{Q_B} \overline{Q_A}$$

$$S_{IL} = S_1$$

$$S_{IR} = \overline{Q_C} \overline{Q_B} \overline{Q_D}$$

## Sequence detector

Detect the occurrence of a pattern in the input sequence:

Detect  $111$  in input of 0's & 1's, example:  
 $011011010001111101 \dots$  using DFF



Function table

| Present state       | I/P | Next state          | Output (Z) | D <sub>1</sub> | D <sub>0</sub> |
|---------------------|-----|---------------------|------------|----------------|----------------|
| S <sub>0</sub> (00) | 0   | S <sub>0</sub> (00) | 0          | 0              | 0              |
| S <sub>0</sub> (00) | 1   | S <sub>1</sub> (01) | 0          | 0              | 1              |
| S <sub>1</sub> (01) | 0   | S <sub>0</sub> (00) | 0          | 0              | 0              |
| S <sub>1</sub> (01) | 1   | S <sub>2</sub> (10) | 0          | 1              | 0              |
| S <sub>2</sub> (10) | 0   | S <sub>0</sub> (00) | 0          | 0              | 0              |
| S <sub>2</sub> (10) | 1   | S <sub>2</sub> (10) | 1          | 1              | 0              |

K Map for D<sub>1</sub>

|   |   | Q <sub>1</sub> Q <sub>0</sub> | 00 | 01 | 11 | 10 |
|---|---|-------------------------------|----|----|----|----|
|   |   | 0                             | 0  | 1  | 3  | 2  |
|   |   | 1                             | 0  | 5  | 7  | 6  |
| 0 | 0 |                               |    | X  |    |    |
| 1 | 0 | 1                             |    | X  |    | 0  |
| χ |   |                               |    |    |    |    |

$$D_1 = \chi Q_0 + \chi Q_1 = \chi (Q_1 + Q_0)$$

K Map for D<sub>0</sub>

|   |   | Q <sub>1</sub> Q <sub>0</sub> | 00 | 01 | 11 | 10 |
|---|---|-------------------------------|----|----|----|----|
|   |   | 0                             | 0  | 1  | 3  | 2  |
|   |   | 1                             | 0  | 5  | 7  | 6  |
| 0 | 0 |                               |    | X  |    |    |
| 1 | 0 | 1                             |    | X  |    | 0  |
| χ |   |                               |    |    |    |    |

$$D_0 = \chi \bar{Q}_1 \bar{Q}_0$$

K Map for Z

|   |   | Q <sub>1</sub> Q <sub>0</sub> | 00 | 01 | 11 | 10 |
|---|---|-------------------------------|----|----|----|----|
|   |   | 0                             | 0  | 1  | 3  | 2  |
|   |   | 1                             | 0  | 5  | 7  | 6  |
| 0 | 0 |                               |    | X  |    |    |
| 1 | 0 | 1                             |    | X  |    | 1  |
| χ |   |                               |    |    |    |    |

$$Z = \chi Q_1 //$$



### Self correcting counters

All unused states eventually leading to normal counting sequence after one or more count.

- Design a synchronous mod 6 counter with counting sequence  $0 \rightarrow 1 \rightarrow 4 \rightarrow 6 \rightarrow 7 \rightarrow 5 \rightarrow 0$  using positive edge triggered T flip-flop.



## Excitation Table

| Present state |       |       | Next state |         |         | Flipflop inputs |       |       |
|---------------|-------|-------|------------|---------|---------|-----------------|-------|-------|
| $Q_2$         | $Q_1$ | $Q_0$ | $Q_2^+$    | $Q_1^+$ | $Q_0^+$ | $T_2$           | $T_1$ | $T_0$ |
| 0             | 0     | 0     | 0          | 0       | 1       | 0               | 0     | 1     |
| 0             | 0     | 1     | 1          | 0       | 0       | 1               | 0     | 1     |
| 1             | 0     | 0     | 1          | 1       | 0       | 0               | 1     | 0     |
| 1             | 1     | 0     | 1          | 1       | 1       | 0               | 0     | 1     |
| 1             | 1     | 1     | 1          | 0       | 1       | 0               | 1     | 0     |
| 1             | 0     | 1     | 0          | 0       | 0       | 1               | 0     | 1     |

$T_2 : Q_2 \swarrow Q_1 Q_0$

|       |           | 00 | 01 | 11 | 10 |
|-------|-----------|----|----|----|----|
|       |           | 0  | 1  | 3  | 2  |
| $Q_2$ | $Q_1 Q_0$ | 0  | 0  | X  | X  |
|       |           | 1  | 0  | 1  | 0  |

$$T_2 = \bar{Q}_1 Q_0$$

$T_1 : Q_2 \swarrow Q_1 Q_0$

|       |           | 00 | 01 | 11 | 10 |
|-------|-----------|----|----|----|----|
|       |           | 0  | 1  | 3  | 2  |
| $Q_2$ | $Q_1 Q_0$ | 0  | 0  | 0  | X  |
|       |           | 1  | 1  | 0  | 1  |

$$T_1 = Q_1 Q_0 + Q_2 \bar{Q}_1 \bar{Q}_0$$

$T_0 : Q_2 \swarrow Q_1 Q_0$

|       |           | 00 | 01 | 11 | 10 |
|-------|-----------|----|----|----|----|
|       |           | 0  | 1  | 3  | 2  |
| $Q_2$ | $Q_1 Q_0$ | 0  | 1  | 1  | X  |
|       |           | 1  | 0  | 1  | 1  |

$$T_0 = \bar{Q}_2 + Q_1 \bar{Q}_0 + \bar{Q}_1 Q_0$$

Unused states      010       $\xi$       011

| $Q_2$ | $Q_1$ | $Q_0$ | $T_2$ | $T_1$ | $T_0$ | $Q_2^+$ | $Q_1^+$ | $Q_0^+$ |
|-------|-------|-------|-------|-------|-------|---------|---------|---------|
| 0     | 1     | 0     | 0     | 0     | 1     | 0       | 1       | 1       |
| 0     | 1     | 1     | 0     | 1     | 1     | 0       | 0       | 0       |

QS Detect 101 without overlap



QS Detect 101 with overlap



Synchronous

Sequential

Networks

General structure: Mealy machine



Elements of state machine

State memory - memory element - set of 'N' flipflops  
- clocked synchronously

Next state logic: (current state decoder) - next state as a function of present state & input - combinational network.

$$Q^+ = F(X, Q)$$

Output logic (output decoder); combinational network  
 $Z = G_1(X, Q)$  - Mealy machine / class A machine

Moore machine / Machine B



Analysis of clocked sequential networks



Excitation and output variables of them (Assign state of algebraic expressions for thus variables)

$$D_1 = \bar{x}\bar{Q}_2 + \bar{Q}_1Q_2$$

$$Z = \bar{x}Q_1 + \bar{Q}_1\bar{Q}_2x$$

$$D_2 = \bar{Q}_1Q_2 + x\bar{Q}_1$$

Transition equations : Next state as a function of present state & input

- Use characteristic equations & excitation equations.

$$\text{DFF} \rightarrow \text{char equation} \rightarrow Q^+ = D$$

$$\therefore Q_1^+ = D_1 = \bar{x} \bar{Q}_2 + \bar{Q}_1 Q_2$$

$$Q_2^+ = D_2 = \bar{Q}_1 Q_2 + x \bar{Q}_1$$

Transition tables : Tabular form representation:

→ 3 actions → present state, next state, output

| Present State<br>$Q_1$ $Q_2$ |   | Next State |         | Output        |   |
|------------------------------|---|------------|---------|---------------|---|
|                              |   | $Q_1^+$    | $Q_2^+$ | Input ( $x$ ) |   |
| 0                            | 0 | 1          | 0       | 0             | 1 |
| 0                            | 1 | 1          | 1       | 0             | 0 |
| 1                            | 0 | 1          | 0       | 1             | 0 |
| 1                            | 1 | 0          | 0       | 1             | 0 |

Alternative way: excitation table (ps, ns, input to FF)

State table: Alphanumeric symbols assigned to states instead of binary codes

$$00 \rightarrow A$$

$$01 \rightarrow B$$

$$10 \rightarrow C$$

$$11 \rightarrow D$$

| Present State |       | Next State |         | Output        |   |
|---------------|-------|------------|---------|---------------|---|
| $Q_1$         | $Q_2$ | $Q_1^+$    | $Q_2^+$ | Input ( $x$ ) |   |
|               |       | i/P( $x$ ) | 0       | 1             |   |
| A             |       | C          | B       | 0             | 1 |
| B             |       | D          | D       | 0             | 0 |
| C             |       | C          | A       | 1             | 0 |
| D             |       | A          | A       | 1             | 0 |

State diagram: graphical representation of state table



Network terminal behavior

Input sequence: 0011011101  
 State sequence: A C C A B D A B D A  
 Output sequence: 0101001011

# Synthesis of synchronous sequential circuits



Serial adder



Mealy machine:

$$A \rightarrow C=0$$

$$B \rightarrow C=1$$

00/0

01/1

10/1



A

| $x$ | $y$ | $s$ | $c$ |
|-----|-----|-----|-----|
| 0   | 0   | 0   | 0   |
| 0   | 1   | 1   | 0   |
| 1   | 0   | 1   | 0   |
| 1   | 1   | 0   | 0   |

B

| $x$ | $y$ | $s$ | $c$ |
|-----|-----|-----|-----|
| 0   | 0   | 1   | 0   |
| 0   | 1   | 0   | 1   |
| 1   | 0   | 0   | 1   |
| 1   | 1   | 1   | 1   |

| Present state |   | Next state<br>input (xy) |    |    |    | Output S<br>input (xy) |    |    |    |
|---------------|---|--------------------------|----|----|----|------------------------|----|----|----|
|               |   | 00                       | 01 | 10 | 11 | 00                     | 01 | 10 | 11 |
| A             | A | A                        | A  | A  | B  | 0                      | 1  | 1  | 0  |
| B             | A | B                        | B  | B  | B  | 1                      | 0  | 0  | 1  |

| Present state |    | Input<br>(xy) | Next state | flipflop input |
|---------------|----|---------------|------------|----------------|
| Q             | Q  |               |            | T              |
| A (0)         | 00 |               | A (0)      | 0              |
| A (0)         | 01 |               | A (0)      | 0              |
| A (0)         | 10 |               | A (0)      | 0              |
| A (0)         | 11 |               | B (1)      | 1              |
| B (1)         | 00 |               | A (0)      | 1              |
| B (1)         | 01 |               | B (1)      | 0              |
| B (1)         | 10 |               | B (1)      | 0              |
| B (1)         | 11 |               | B (1)      | 0              |

Kmap for T : PS \ xy

|   |   | 00 | 01 | 11 | 10 |
|---|---|----|----|----|----|
|   |   | 0  | 1  | 3  | 2  |
| Q | 0 | 0  | 0  | 1  | 0  |
|   | 1 | 4  | 1  | 5  | 0  |
| A | 0 | 0  | 0  | 0  | 0  |
|   | 1 | 4  | 1  | 5  | 0  |

$$T = \bar{Q}xy + Q\bar{x}\bar{y} = \bar{Q}xy + \bar{Q} + x + y$$

K map for S : PS \ xy

|   |   | 00 | 01 | 11 | 10 |
|---|---|----|----|----|----|
|   |   | 0  | 1  | 3  | 2  |
| Q | 0 | 0  | 0  | 1  | 0  |
|   | 1 | 4  | 1  | 5  | 0  |
| A | 0 | 0  | 0  | 0  | 0  |
|   | 1 | 4  | 1  | 5  | 0  |
| B | 0 | 0  | 0  | 0  | 0  |
|   | 1 | 4  | 1  | 5  | 0  |

$$Z = Q \oplus x \oplus y$$

Mealy machine:



Moore machine:

|                 |       |       |
|-----------------|-------|-------|
| $A \rightarrow$ | $S=0$ | $C=0$ |
| $B \rightarrow$ | $S=1$ | $C=0$ |
| $C \rightarrow$ | $S=0$ | $C=1$ |
| $D \rightarrow$ | $S=1$ | $C=1$ |

State  
output



| Present State | Next State  | Output (z) | flip flop ip ( $T_2, T_1$ ) |
|---------------|-------------|------------|-----------------------------|
| $Q_2, Q_1$    | 00 01 10 11 |            | 00 01 10 11                 |
| A (00)        | A B B C     | 0          | 00 01 01 10                 |
| B (01)        | A B B C     | 1          | 01 00 00 11                 |
| C (10)        | B C C D     | 0          | 11 00 00 01                 |
| D (11)        | B C C D     | 1          | 10 01 01 00                 |

K map for  $T_2$ :

|    |    | 00 | 01 | 11 | 10 |
|----|----|----|----|----|----|
|    |    | 00 | 01 | 11 | 10 |
|    |    | 00 | 01 | 11 | 10 |
| PS |    | 0  | 1  | 3  | 2  |
| A  | 00 | 0  | 0  | 1  | 0  |
| B  | 01 | 0  | 0  | 1  | 0  |
| D  | 11 | 1  | 0  | 0  | 0  |
| C  | 10 | 1  | 0  | 0  | 0  |

$$T_2 = \bar{Q}_2 xy + Q_2 \bar{x}y = \bar{Q}_2 xy + \overline{\bar{Q}_2 + x + y}$$

K map for  $T_1$ :

|    |    | 00 | 01 | 11 | 10 |
|----|----|----|----|----|----|
|    |    | 00 | 01 | 11 | 10 |
|    |    | 00 | 01 | 11 | 10 |
| PS |    | 0  | 1  | 3  | 2  |
| A  | 00 | 0  | 1  | 0  | 1  |
| B  | 01 | 1  | 0  | 1  | 0  |
| D  | 11 | 0  | 1  | 0  | 1  |
| C  | 10 | 1  | 0  | 1  | 0  |

$$T_1 = Q_1 \oplus Q_2 \oplus x \oplus y$$

$$S = Q_1$$

$$C = Q_2$$



### Tutorial:

Q1) Convert from decimal to BCD.

$$\text{i} > 35 - 0011 \ 0101$$

$$\text{iii} > 170 - 0001 \ 0111 \ 0000$$

$$\text{ii} > 98 - 1001 \ 1000$$

$$\text{iv} > 2469 - 0010 \ 0100 \ 0110 \ 1001$$

Q2) Convert BCD to decimal

$$\text{i} > 1000 \ 0110 - 86$$

$$\text{ii} > 0011 \ 0101 \ 0001 - 351$$

$$\text{iii} > 1001 \ 0100 \ 0111 \ 1000 - 9478$$

Q3) Add the following BCD numbers -

$$\text{i} > 1001$$

$$1101$$

$$\begin{array}{r} + 0100 \\ \hline 1101 \end{array} > 9$$

$$\begin{array}{r} + 0110 \\ \hline 0001 \ 0011 \end{array}$$

$$= 13_{\frac{1}{2}}$$

ii)  $\begin{array}{r}
 1001 \\
 + 1001 \\
 \hline
 10010 > 9
 \end{array}
 \quad
 \begin{array}{r}
 10010 \\
 + 0110 \\
 \hline
 00011000
 \end{array}
 \quad
 = 18$

iii)  $\begin{array}{r}
 00010110 \\
 + 00010101 \\
 \hline
 00101011
 \end{array}
 \quad
 \begin{array}{r}
 00101011 \\
 + 00000110 \\
 \hline
 00110001
 \end{array}
 \quad
 = 31$

iv)  $\begin{array}{r}
 01100111 \\
 01010011 \\
 \hline
 10111010
 \end{array}
 \quad
 \begin{array}{r}
 10111010 \\
 00000110 \\
 \hline
 11000000
 \end{array}
 \quad
 \begin{array}{r}
 11000000 \\
 + 01100000 \\
 \hline
 000100100000
 \end{array}
 \quad
 = 120$

Q4) Perform BCD addition of 8765 3943

Ans

|      |       |      |      |        |
|------|-------|------|------|--------|
| 1000 | 0111  | 0110 | 0101 |        |
| 0011 | 1001  | 0100 | 0011 | + 1011 |
| 1011 | 10000 | 1010 | 1000 | 0000   |

$$\begin{array}{r}
 1100000100001000 \\
 + 0110011000000000 \\
 \hline
 00010010011100001000
 \end{array}
 \Rightarrow 12708$$

Q5) Find  $984 - 599$  using 10's complement BCD subtraction

Ans 9's complement

$$\begin{array}{r}
 999 \\
 - 599 \\
 \hline
 400
 \end{array}$$

10's complement = 9's complement + 1 = 401

$$\begin{array}{r}
 984 + 401 \Rightarrow \\
 \begin{array}{r}
 1001 \quad 1000 \quad 0100 \\
 + 0100 \quad 0000 \quad 0001 \\
 \hline
 1101 \quad 1000 \quad 0101
 \end{array} \\
 \times 1) \begin{array}{r}
 + 0110 \quad 0000 \quad 0000 \\
 \hline
 0011 \quad 1000 \quad 0101
 \end{array} = 385,
 \end{array}$$

Q6) Show how 2 74HC283 address can be connected to form an 8-bit parallel addr.

Ans



Q7) If an octal to binary priority encoder has 0, 2, 4, 6 input at active high level, active high binary output is ?

Am



Q 8) what functions of A, B, C & D are realized by  $Z_3, Z_2, Z_1, Z_0$ .



Am

| $I_3$ | $I_2$ | $I_1$ | $I_0$ | $G_1$ | $Y_1$ | $Y_0$ |
|-------|-------|-------|-------|-------|-------|-------|
| 0     | 0     | 0     | 0     | 0     | X     | X     |
| 0     | 0     | 0     | 1     | 1     | 0     | 0     |
| 0     | 0     | 1     | X     | 1     | 0     | 1     |
| 0     | 1     | X     | X     | 1     | 1     | 0     |
| 1     | X     | X     | X     | 1     | 1     | 1     |

$$Y_1 = I_3 + I_2 = A + B$$

$$Y_0 = I_3 + I_2 I_1 = A + B C = A + \bar{A} B + \bar{A} \bar{B} C = A + \bar{A} (B + C)$$

$$Z_3 = Y_1 Y_0 G_1 = (A+B) (\overline{A+\bar{B}C}) (A+B+C+D)$$

$$Z_2 = \overline{Y_1} \overline{Y_0} G_1 = (A+B) (\overline{A+\bar{B}C}) (A+B+C+D)$$

$$Z_1 = \overline{Y_1} Y_0 G_1 = (\overline{A+B}) (\overline{A+\bar{B}C}) (A+B+C+D)$$

$$Z_0 = \overline{Y_1} \overline{Y_0} G_1 = (\overline{A+B}) (\overline{A+\bar{B}C}) (A+B+C+D)$$

$$\therefore G_1 = A+B+C+D$$

Q10) A priority encoder has 4 inputs  $X_3, X_2, X_1, X_0$ . The circuit has 3 output  $Z, Y_1, Y_0$ . If one of the input is 1,  $Z$  is 1, &  $Y_1, Y_0$  represent 2 bit binary number whose value equals the index the highest numbered i/p i.e 1. If all the i/p are 0,  $Z=0$  &  $Y_1$  &  $Y_0$  are don't care

- a) List in decimal form the min terms & don't care min terms of each o/p.
- b) List in decimal terms, the max terms & don't care max terms.

Ans

| $X_3$ | $X_2$ | $X_1$ | $X_0$ | $Z$ | $Y_1$ | $Y_0$ |
|-------|-------|-------|-------|-----|-------|-------|
| 0     | 0     | 0     | 0     | 0   | x     | x     |
| 0     | 0     | 0     | 1     | 1   | 0     | 0     |
| 0     | 0     | 1     | x     | 1   | 0     | 1     |
| 0     | 1     | x     | x     | 1   | 1     | 0     |
| 1     | x     | x     | x     | 1   | 1     | 1     |

$$Y_1 = \sum (4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15) + \sum_d(0)$$

$$Y_0 = \sum (2, 3, 8, 9, 10, 11, 12, 13, 14, 15) + \sum_d(0)$$

$$Z = \sum (1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15)$$

$$Y_1 = \pi(1, 2, 3) + \pi_d(0)$$

$$Y_0 = \pi(1, 4, 5, 6, 7) + \pi_d(0)$$

$$Z = \pi(0)$$

Q11) Determine the o/p frequency if clock frequency is

5 kHz

a)



Ans

$$T' = 2T$$

$$f' = \frac{f}{2} = \frac{S}{2} = 2.5 \text{ kHz}$$

b)



$$f_o = \frac{f}{2} = 2.5 \text{ kHz}$$

Q12) In the following shift register, the number of clock pulses to bring initial value of 1001 to 0000 is?



Ans

|                     | $Q_3$ | $Q_2$ | $Q_1$ | $Q_0$ |
|---------------------|-------|-------|-------|-------|
| start $\rightarrow$ | 1     | 0     | 0     | 1     |
|                     | 1     | 1     | 0     | 0     |
|                     | 1     | 1     | 1     | 0     |
|                     | 0     | 1     | 1     | 1     |
|                     | 1     | 0     | 1     | 1     |
|                     | 0     | 1     | 0     | 1     |
|                     | 0     | 0     | 1     | 0     |
|                     | 1     | 0     | 0     | 1     |

} 7 clocks //

Q) Create a many machine sequence detector for '1011' without overlap. using JKFF

Ans.



Excitation table

| Present state       | Next state     |                | O/p |   | flip flop input |                | J <sub>0</sub> | K <sub>0</sub> |
|---------------------|----------------|----------------|-----|---|-----------------|----------------|----------------|----------------|
|                     | i/p (x)        | i/p (x)        | 0   | 1 | J <sub>1</sub>  | K <sub>1</sub> |                |                |
| S <sub>0</sub> (00) | S <sub>0</sub> | S <sub>1</sub> | 0   | 0 | 0               | X              | 0 X            | 0 X            |
| S <sub>1</sub> (01) | S <sub>2</sub> | S <sub>1</sub> | 0   | 0 | 1               | X              | X 1            | 0 X            |
| S <sub>2</sub> (10) | S <sub>0</sub> | S <sub>3</sub> | 0   | 0 | X               | 1              | 0 X            | X 0            |
| S <sub>3</sub> (11) | S <sub>2</sub> | S <sub>0</sub> | 0   | 1 | X               | 0              | X 1            | X 1            |

J<sub>1</sub>:

|           |  | 00 | 01 | 11 | 10 |
|-----------|--|----|----|----|----|
|           |  | 0  | 1  | 3  | 2  |
|           |  | 0  | 1  | X  | X  |
| 0         |  | 0  | 1  | 3  | 2  |
| 1         |  | 4  | 5  | 7  | 6  |
| $\bar{x}$ |  | 0  | 0  | X  | X  |

$$J_1 = Q_0 \bar{x}$$

K<sub>1</sub>:

|           |  | 00 | 01 | 11 | 10 |
|-----------|--|----|----|----|----|
|           |  | 0  | 1  | 3  | 2  |
|           |  | 0  | X  | X  | 1  |
| 0         |  | 0  | X  | X  | 1  |
| 1         |  | 4  | X  | X  | 0  |
| $\bar{x}$ |  | 5  | X  | 1  | 6  |

$$K_1 = Q_0 \oplus x$$

$$J_0 = \chi$$

$$K_0 = \bar{\chi} + Q_1$$

$$Z = Q_1 Q_0 \chi$$

Moore machine using DFF



$$S_0 = 000$$

$$S_1 = 001$$

$$S_2 = 010$$

$$S_3 = 011$$

$$S_4 = 100$$

$$Z = Q_2$$

$$D_2 = \chi Q_1 Q_0$$

$$D_1 = Q_2 Q_0 + \bar{\chi} Q_0 + \chi Q_1 Q_0$$

$$D_0 = \chi \bar{Q}_0 + \bar{Q}_1 \chi$$

Q) Detect 1001 or 010 with overlap as mealy machine.

A:



$S_0 \rightarrow \text{start}$   
 $S_1 \rightarrow 0$   
 $S_2 \rightarrow 1$   
 $S_3 \rightarrow 01$   
 $S_4 \rightarrow 10$   
 $S_5 \rightarrow 100$

State assignment

1) one-hot assignment: At a time only one bit is high. Advantage: No decoder required.  
 Eg:  $S_0 = 001$        $S_1 = 010$        $S_2 = 100$

Disadvantages: More flipflops are required.

- 2) Binary assignment: States are assigned with binary numbers
- 3) Random assignment: Any random numbers can be assigned to states, but first state should be all zeros or all ones.

Sequence generator

Linear feedback shift register (LFSR)

- 2 types:
- 1) Standard LFSR
  - 2) Modular LFSR



Maximal length LFSR - LFSR that can generate nearly exhaustive states ( $2^n - 1$  distinct states)

characteristic equation:

$$f(x) = 1 + h_1x + h_2x^2 + h_3x^3 + \dots + h_{n-1}x^{n-1} + x^n$$

where  $h_i = 0 \text{ or } 1$

Q> Write characteristic equation:



Ans

$$\begin{bmatrix} X_0(t+1) \\ X_1(t+1) \\ X_2(t+1) \end{bmatrix} = \begin{bmatrix} 0 & 1 & 0 \\ 0 & 0 & 1 \\ 1 & 0 & 1 \end{bmatrix} \begin{bmatrix} X_0(t) \\ X_1(t) \\ X_2(t) \end{bmatrix}$$

$$X_0(t+1) = X_1(t)$$

$$X_1(t+1) = X_2(t)$$

$$X_2(t+1) = X_0(t) + X_2(t)$$

$$f(x) = 1 + x^3 + x^5,$$

$$h_1 = 0 \quad h_2 = 1$$

Modular LFSR

Faster than standard LFSR - one XOR gate.



Ex:



$$\begin{bmatrix} X_0(t+1) \\ X_1(t+1) \\ X_2(t+1) \\ X_3(t+1) \end{bmatrix} = \begin{bmatrix} 0 & 0 & 0 & 1 \\ 1 & 0 & 0 & 0 \\ 0 & 1 & 0 & 0 \\ 0 & 0 & 1 & 1 \end{bmatrix} \begin{bmatrix} X_0(t) \\ X_1(t) \\ X_2(t) \\ X_3(t) \end{bmatrix}$$

$$f(x) = 1 + x^3 + x^4$$

Binary sequence generator using shift register

Generate Sequence 10110110

- need 3FF

→ Use universal shift register - trace the path which passes through all the states - design logic circuit for serial in and output

Binary tree diagram:



# State diagram



→ Path going through each node only once. ( $0 \rightarrow 4 \rightarrow 6 \rightarrow 7 \rightarrow 3 \rightarrow 5 \rightarrow 2 \rightarrow 1 \rightarrow 0$ )

| PS<br>$Q_2\ Q_1\ Q_0$ | Sin | Output<br>Z |
|-----------------------|-----|-------------|
| 0 0 0                 | 1   | 1           |
| 1 0 0                 | 1   | 0           |
| 1 1 0                 | 1   | 1           |
| 1 1 1                 | 0   | 1           |
| 0 1 1                 | 1   | 0           |
| 1 0 1                 | 0   | 1           |
| 0 1 0                 | 0   | 1           |
| 0 0 1                 | 0   | 0           |

$$S_0 \rightarrow S_4 \rightarrow S_6 \rightarrow S_7 \rightarrow S_3 \rightarrow S_5 \rightarrow S_2 \rightarrow S_1$$

|      0      |      |      |      0      |      |      0

$S_{in}$ :

|   |   | Q <sub>2</sub> | Q <sub>1</sub> Q <sub>0</sub> | 00 | 01 | 11 | 10 |
|---|---|----------------|-------------------------------|----|----|----|----|
|   |   | 0              | 0                             | 1  | 3  | 2  | 0  |
|   |   | 1              | 4                             | 5  | 7  | 6  | 1  |
| 0 | 0 | 0              | 1                             | 0  | 0  | 1  | 0  |
| 1 | 0 | 0              | 0                             | 1  | 1  | 1  | 1  |

$$S_{in} = \bar{Q}_1 \bar{Q}_0 + Q_2 \bar{Q}_0 + \bar{Q}_2 Q_1 Q_0$$

$Z'$ :

|   |   | Q <sub>2</sub> | Q <sub>1</sub> Q <sub>0</sub> | 00 | 01 | 11 | 10 |
|---|---|----------------|-------------------------------|----|----|----|----|
|   |   | 0              | 0                             | 1  | 3  | 2  | 1  |
|   |   | 1              | 4                             | 5  | 7  | 6  | 1  |
| 0 | 0 | 0              | 1                             | 0  | 0  | 1  | 0  |
| 1 | 0 | 0              | 0                             | 1  | 1  | 1  | 1  |

$$Z = \bar{Q}_2 \bar{Q}_0 + Q_2 Q_0 + Q_2 Q_1$$



## FSM state reduction:

State A & B equivalent

→ Next state for A & B - same / equivalent

→ Same output

Q

- Design a vending machine which releases a chocolate for ₹3. The machine accepts money only in turns of ₹2 & ₹1. Extra money will be paid back in ₹1 coins.



D → ₹1 received

T → ₹2 received

P → Product dispensed

C → change dispensed.

Moore machine:

input → TD

output → P C



| Present state | Next state<br>I/P ( $T = 0$ ) |    |    | Output (PC) |
|---------------|-------------------------------|----|----|-------------|
|               | 00                            | 01 | 10 |             |
| A             | A                             | B  | C  | 00          |
| B             | B                             | C  | E  | 00          |
| C             | C                             | E  | G  | 00          |
| D             | D                             | E  | G  | 00          |
| E             | A                             | B  | C  | 10          |
| F             | A                             | B  | C  | 10          |
| G             | A                             | B  | C  | 11          |
| H             | A                             | B  | C  | 10          |
| I             | A                             | B  | C  | 11          |

Final table:

| Present state | Next state |    |    | Output (PC) |
|---------------|------------|----|----|-------------|
|               | 00         | 01 | 10 |             |
| A             | A          | B  | C  | 00          |
| B             | B          | C  | E  | 00          |
| C             | C          | E  | G  | 00          |
| E             | A          | B  | C  | 10          |
| G             | A          | B  | C  | 11          |



Mealy machine implementation



$$A = 0$$

$$B = 1$$

$$C = 2$$

$Q_1, Q_2$

MSB      LSB

$$J_1 = Q_1 Q_2 + \bar{Q}_2 T$$

$$K_1 = 0 + T$$

$$J_2 = \bar{Q}_1 D$$

$$K_2 = K_1$$

$$C = Q_1 T$$

Q> Design a vending machine with input of denominations ₹1, ₹2, ₹5. It should dispense product ₹ change.

## Logic families

- Digital circuits classification based on circuit technology.
  - Popular logic families:
    - Transistor-transistor logic (TTL)
    - Emitter coupled logic (ECL)
    - Metal oxide semiconductor (MOS)
    - Complementary metal oxide semiconductor (CMOS)

## Digital circuit parameters

- 1) Fanout
- 2) Power dissipation
- 3) Propagation delay
- 4) Noise margin

### 1) Fanout:

- Number of standard loads that can be connected to the output of the gate without degrading its normal operation.
- Calculated using the amount of current in the output of a gate and the amount of current needed in the input of each gate.
- Output voltage High - gate provide current to load (gates)

- Output voltage low - gate provides current sink to load (gates)

- Fanout =  $\min \left( \frac{I_{OH}}{I_{IH}}, \frac{I_{OL}}{I_{IL}} \right)$



2>

## Power dissipation

- Power delivered to the gate from supply
- Expressed in mW
- $P_D = V_{CC} \times I_C$
- Since  $I_C$  depends on logic state of the gate, average current is considered for  $P_D$  calculation
- Average power =  $V_{CC} \left( \frac{I_{CH} + I_{CL}}{2} \right)$
- $P_D$  by an IC =  $P_D$  of a gate  $\times$  number of gates in an IC.
- $P_D$  for CMOS,  $P_D = C_L \cdot V_{DD}^2 \times f$  ( $f$  - frequency)  
( $C_L$  - load capacitor)

3> Propagation delay

Input :

output :



Average propagation delay is the time for the signal to propagate from binary input to output when the value (alt: maximum crossing 50% to output crossing 50% of final value)

- Typically measured in ns or ps
- Average propagation delay =  $\frac{t_{PHL} + t_{PLH}}{2}$  (max

propagation delay may have to be considered in specific applications).

Rise time: Time taken to rise from 10% to 90% in a rise. Similarly fall time can be defined in vice versa manner.

Contamination delay:



Minimum time from input crossing 50% (of previous value) to



Critical path and short path:



- Critical path : path with max delay
- short path : path with minimum delay
- For a circuit propagation delay = sum of propagation delay in critical path .
- contamination delay = sum of contamination delay in short path .

Setup time:



- The input to flipflops must be stable for some time before the clock edge. This is called "setup time",  $t_s$ .
- The input to flipflop must be stable for some time after the clock edge. This is called "hold time",  $t_h$ .

$\therefore$  The input should be stable for time =  $t_s + t_h$

Propagation delay between clock & output is

$$t_{CQ}$$



$$T_{clk} \geq t_{CQ} + t_{pc} + t_{su}$$

$\downarrow$   
combinational propagation  
delay

$$f_{clk} = \frac{1}{T_{clk}}$$

Hazards: 1) Static 2) Dynamic

1) Static Hazard.        
                                Static '0'



Static '1'

2) Dynamic Hazard:   
                                Dynamic '0'



Dynamic '1'

static hazard example:

1) Static '1' hazard:  $111 \rightarrow 101$

2) Propagation delay



2&gt;

Static '0' hazard:

$$000 \rightarrow 010$$



Static 1:



Static 0:



Identifying static hazard in K map.

AB

|   | 00 | 01 | 11 | 10 |
|---|----|----|----|----|
| 0 | 0  | 1  | 1  | 0  |
| 1 | 0  | 0  | 1  | 1  |

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

This transition causes static '1' hazard

To prevent that we take  $y = \bar{x}B + xA + AB$



Static 0 hazard:



$$\text{eg: } Y(A, B, C, D) = \sum m(1, 3, 5, 7, 12, 13)$$

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

Add this redundant term

SOP - static '1' hazard  
POS - static '0' hazard.

Figure of merit

Higher the current, higher is the charging speed (lower charging time).

Power delay produced,  $PDP = P \times t_p$   
 $P \rightarrow$  Power dissipated,  $t_p \rightarrow$  propagation delay

Delay modulus in verilog:

- 1) Inertial delay
- 2) Transport delay

1) Inertial delay: If there are any quick changes in the input  $\leq$  inertial delay, then it ignores the change.



regular op :



inertial

delay op :



⇒ Transport delay: 



Noise margin

Maximum noise voltage that can get added to input signal that does not cause an undesirable change in the output



HSNM - High state noise margin  
 LSNM - Low state noise margin

$V_{IL}$  : Maximum input voltage recognised by gate as logic 0.

$V_{IH}$  : Minimum input voltage recognised by gate as logic 1.

$V_{OL}$  : Maximum voltage available at gate output corresponding to logic '0'

$V_{OH}$  : Minimum voltage available at gate output corresponding to logic 1.

$$NM_L = LS NM = V_{IL} - V_{OL}$$

$$NM_H = HS NM = V_{OH} - V_{IH}$$

### Logic family evolution

- Resistor Transistor logic - RTL
- Diode transistor logic - DTL
- Transistor transistor logic - TTL
  - 74 series - normal application ( $0-70^\circ C$ )
  - 54 series - military application ( $-55^\circ C - 125^\circ C$ )
  - LS - low power schottky , AS - advanced schottky , ALS - Advanced low power schottky
- MOS - metal oxide semiconductor  
CMOS , HC - high speed , HCT  $\rightarrow$  TTL compatible  
high speed , AC , ACT , BiCMOS



$$Z = A + B$$



$$Z = A \cdot B$$

→ Diode as switch

→ Simplist logic

→ Problem while cascading (voltage division)

→ Inversion not possible - needs active element.



$$Y = A + B + C$$

Voltage levels : 0.2 V (0) & 3.6 V (1)  
Fanout < 5

$$P_D = 12 \text{ mV}$$

$$t_p = 25 \text{ ns}$$

3> DTL logic



- Fanout depends on base current of transistor
- $I_{CL}$  - plays role through diode when  $R_B (V_o = 1)$



#### 4) Transistor Transistor logic



- Replace diode with multi-emitter transistor common collector junction & different emitter junction.

→ When  $A = 0, B = 0$ , base-emitter junction of  $T_1$  = forward biased,  $T_2$  is off (current cannot flow out of base),  $Y = 1$

→ When  $A = 1, B = 1$ , Base-emitter junction of  $T_1$  is reverse biased (reverse active mode),  $T_2 = \text{on}, Y = 0$

- $I_c$  of  $T_1$  support base charge removal of  $T_2$ .
- $T_2$  off - low  $R_c$  - to charge load capacitance faster.
- $T_2$  on - high  $R_c$  - have low  $I_{c\text{sat}}$  and reduce  $P_o$
- Use  $R_c$  - Totem-pole output.

a) Totem - pole output



- Phase splitter - either t<sub>3</sub> or t<sub>4</sub> on any time
- A or B = 0 : T<sub>2</sub> off T<sub>4</sub> on
- A and B = 1 : T<sub>2</sub> on T<sub>4</sub> off

b) Schottky TTL (74S00)

- Schottky diode - avoid ringing - avoids input reaching large negative voltage.
- Schottky transistor - no saturation - no charge storage - high speed.
- Active pull down
- Darlington pair - high output current
- Low resistance

## Tutorial

Q) A 4 bit shift register is configured for right shift operation.  $D \rightarrow A \rightarrow B \rightarrow C \rightarrow D$  as shown. If the present state  $ABCD = 1101$ . The no. of clock cycles to reach state 1111 is ?



Ans.

| clk | A | B | C | D |
|-----|---|---|---|---|
| -   | 1 | 1 | 0 | 1 |
| ↑   | 0 | 1 | 1 | 0 |
| ↑   | 0 | 0 | 1 | 1 |
| ↑   | 1 | 0 | 0 | 1 |
| ↑   | 0 | 1 | 0 | 0 |
| ↑   | 0 | 0 | 1 | 0 |
| ↑   | 0 | 0 | 0 | 1 |
| ↑   | 1 | 0 | 0 | 0 |
| ↑   | 1 | 1 | 0 | 0 |
| ↑   | 1 | 1 | 1 | 0 |
| ↑   | 1 | 1 | 1 | 1 |

10 clocks,

Q2) Find the state transition sequence for 2-bit string  $Q_0 Q_1$ , if the initial value of  $Q_0 Q_1 = 00$



Ans

|       | $D_0^+$     | $D_1^+$ |
|-------|-------------|---------|
| clk ↑ | $\bar{Q}_0$ | 1       |
| clk ↑ | 1           | 1       |
| clk ↑ | 0           | 0       |
| clk ↑ | 1           | 0       |
| clk ↑ | 0           | 0       |

Q3) Control signal function of a 4 bit binary counter are given below, where  $x$  is a don't care. If the counter starts at '0'. Find transition sequence cycle.



| clr | clk | load | count | Function   |
|-----|-----|------|-------|------------|
| 1   | x   | x    | x     | clear to 0 |
| 0   | x   | 0    | 0     | No change  |
| 0   | ↑   | 1    | x     | load input |
| 0   | ↑   | 0    | 1     | count next |

Ans  $0 \rightarrow 1 \rightarrow 2 \rightarrow 3 \rightarrow 4 \rightarrow 0$

Q4) A bit Johnson counter with an initial value of 0 is implemented. Find the sequence of counting.

| clk | count   |
|-----|---------|
| -   | 0 0 0 0 |
| ↑   | 1 0 0 0 |
| ↑   | 1 1 0 0 |
| ↑   | 1 1 1 0 |
| ↑   | 1 1 1 1 |
| ↑   | 0 1 1 1 |
| ↑   | 0 0 1 1 |
| ↑   | 0 0 0 1 |
| ↑   | 0 0 0 0 |

} 8 counts

Q5) For the circuit shown, clock frequency is  $f$ . and duty cycle is 25%. For the signal at output Q of flip flop, find frequency and duty cycle.



Ans.



$$\therefore f_Q = \frac{f_o}{4}$$

Duty cycle = 50% //

$$\text{Duty cycle} = \frac{T_{on}}{T_{cycle}}$$

Q6> Consider a sequential circuit shown in figure where both DFF, triggered on positive edge of state transition that have a same state on normal value of "in" is



Q7) Consider 3 bit counter implemented using T-flipflops assuming PQR at an initial state of 000, what are the next 3 states?



Q8) A new flipflop with inputs X & Y has the following property: Find the expression for next state in terms of X, Y & current state.

Ans

|  | X | Y | current state | Next state |
|--|---|---|---------------|------------|
|  | 0 | 0 | Q             | $\bar{Q}$  |
|  | 0 | 1 | Q             | $\bar{Q}$  |
|  | 1 | 0 | Q             | Q          |
|  | 1 | 1 | Q             | Q          |

Ans

| Q | X | Y | $Q^+$ |
|---|---|---|-------|
| 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 | 0     |

| $Q$         | 00 | 01 | 11 | 10 |
|-------------|----|----|----|----|
| $X \cdot Y$ | 1  | 1  | 0  | 0  |
| $Q$         | 0  | 0  | 1  | 1  |
| $Q^+$       | 1  | 1  | 0  | 0  |
| $Q^+$       | 1  | 1  | 1  | 1  |

$$Q^+ = \bar{X}\bar{Y} + \bar{Q}\bar{X} + QXY$$

7A>

| dk | P | Q | R |
|----|---|---|---|
| -  | 0 | 0 | 0 |
| ↑  | 0 | 1 | 1 |
| ↗  | 1 | 0 | 1 |
| ↑  | 0 | 0 | 0 |

6A>

5> CMOS

logic

PMOS



NMOS



Inverter

using

CMOS



Transfer characteristics



## General structure of gates using CMOS



$PU \rightarrow$  Pull up logic  
 $PD \rightarrow$  Pull down logic



NOR gate:



OR gate:



Pas transistor logic (Transmission gat logic)



$$Y = A \quad \text{if} \quad C=1$$

In transmission logic less number of gates are required.

MUX using transmission logic:

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



Tristate logic:



$Z \rightarrow$  high impedance state

$$EN = 0 \quad C = 1 \quad D = 0$$

$$out = Z$$

$$EN = 1 \quad C = \bar{A} \quad D = \bar{A}$$

$$out = A$$



wired logic



D - Data

E - Enable

NOTE: 1>



Usually node N acts like AND gate, without use of another gate.

2> Only few logic families allow use of wired high impedance state Z.

# Flipflop conversion



Q) Convert DFF to JK FF

Ans.

| J | K | Q | $Q^+$ | D |
|---|---|---|-------|---|
| 0 | 0 | 0 | 0     | 0 |
| 0 | 0 | 1 | 1     | 1 |
| 0 | 1 | 0 | 0     | 0 |
| 0 | 1 | 1 | 0     | 0 |
| 1 | 0 | 0 | 1     | 1 |
| 1 | 0 | 1 | 1     | 1 |
| 1 | 1 | 0 | 1     | 1 |
| 1 | 1 | 1 | 0     | 0 |

0:

|   |   | 00 | 01 | 11 | 10 |
|---|---|----|----|----|----|
|   |   | 0  | 1  | 3  | 2  |
| J | K | 0  | 1  | 0  | 0  |
| 0 | 0 | 0  | 0  | 3  | 2  |
| 1 | 0 | 4  | 5  | 7  | 6  |
|   |   | 1  | 1  | 0  | 1  |

$$D = J\bar{Q} + \bar{K}Q$$



FSM      implementation      in      Vorilog:



```

module FSM (rst, clk, x, y);
  input rst, clk, x;
  output y;
  Parameter SO=0, SI=1;
  reg DP;
  reg state, nextstate;
  assign y=DP;
  always @ (posedge clk)
    if (rst)
      state <= SO;
    else
      state <= nextstate;
endmodule
  
```

always @ (state or x)  
begin

case (state)

S0: begin op=x;

if (x) nextstate = S1; end

S1: begin

if (x) begin

nextstate = S1;

op=1; end

else begin

nextstate = S0;

op=0; end

end

endcase

end

endmodule

Moore machine implementation:



module FSM (rst, clk, x, y);  
input rst, clk, x;  
output y;

```

Parameter      S0=0, S1=1, S2=2;
reg  op;
reg [1:0] state;      reg [1:0] nextstate;
assign y=op;
always @ (posedge clk or rst) begin
    if (rst) state <= S0;
    else state <= nextstate;
always @ (x or state) begin
    case (state)
        S0: if (x) nextstate <= S1;
              else nextstate <= S0;
        S1: if (x) nextstate <= S2;
              else nextstate <= S0;
        S2: if (x) nextstate <= S2;
              else nextstate <= S0;
endcase
always @ (state)
    case (state)
        S0: op=0;
        S1: op=0;
        S2: op=1;
end
end
endmodule

```

Quine - Mcclusky method

Q)  $f(A, B, C, D) = \sum m(0, 1, 2, 3, 5, 7, 8, 10, 12, 13, 15)$

| Value | A | B | C | D | No. of 1s | Grouping 1:          |
|-------|---|---|---|---|-----------|----------------------|
| 0     | 0 | 0 | 0 | 0 | 0         |                      |
| 1     | 0 | 0 | 0 | 1 |           | (0, 1) 000 -         |
| 2     | 0 | 0 | 1 | 0 | 1         | (0, 2) 00-0          |
| 8     | 1 | 0 | 0 | 0 |           | (0, 8) -000          |
| 3     | 0 | 0 | 1 | 1 |           | (1, 3) 00-1          |
| 5     | 0 | 1 | 0 | 1 | 2         | (1, 5) 0-01          |
| 10    | 1 | 0 | 1 | 0 |           | (2, 10) -010         |
| 12    | 1 | 1 | 0 | 0 |           | (8, 12) 1-00 → ĀC̄D |
| 7     | 0 | 1 | 1 | 1 | 3         | (3, 7) 0-11          |
| 13    | 1 | 1 | 0 | 1 |           | (5, 13) -101         |
| 15    | 1 | 1 | 1 | 1 | 4         | (7, 15) -111         |

|                    |                         |                     |                                                  |
|--------------------|-------------------------|---------------------|--------------------------------------------------|
| <u>Grouping 2:</u> | $(0, 1, 2, 3) : 00--$   | $\} \bar{A}\bar{B}$ | $\bar{A}\bar{B} \quad \bar{A}\bar{B} \leftarrow$ |
|                    | $(0, 2, 1, 3) : 00-$    | $\}$                |                                                  |
|                    | $(0, 2, 8, 10) : -0-0$  | $\}$                | $\bar{B}\bar{D}$                                 |
|                    | $(0, 8, 2, 10) : -0-0$  | $\}$                |                                                  |
|                    | $(1, 3, 5, 7) : 0--1$   | $\}$                | $\bar{A}D$                                       |
|                    | $(1, 5, 3, 7) : 0-1$    | $\}$                |                                                  |
|                    | $(5, 7, 13, 15) : -1-1$ | $\}$                | $BD$                                             |
|                    | $(5, 13, 7, 15) : -1-1$ |                     |                                                  |

Prime implicant table:

| PI                | 0 | 1 | 2 | 3 | 5 | 7 | 8 | 10  | 12 | 13  | 15 |
|-------------------|---|---|---|---|---|---|---|-----|----|-----|----|
| $\bar{A}\bar{B}$  | x | x | x | x |   |   |   |     |    |     |    |
| $\bar{B}\bar{D}$  | x |   | x |   |   |   | x | (x) |    |     |    |
| $\bar{A}D$        |   | x |   | x | x | x |   |     |    |     |    |
| $B\bar{D}$        |   |   |   | x | x |   |   |     | x  | (x) |    |
| $A\bar{C}\bar{D}$ |   |   |   |   |   | x |   |     | x  |     |    |
| $A\bar{B}\bar{C}$ |   |   |   |   |   |   |   | x   | x  | x   |    |

only 1 in  
column  
 $\Rightarrow$  Essential  
PI

$$f = \bar{B}\bar{D} + BD + \bar{A}\bar{B} + A\bar{C}\bar{D}$$

or

$$f = \bar{B}\bar{D} + BD + \bar{A}D + A\bar{B}\bar{C}$$

## Tutorial :

Q1) Determine the final Q/p states over time for the following circuit.



Ans



Q2) write state table for:

i>



Present state

Next state

Output

a  
b  
d  
f

i/p: 0

i

ip: 0

1

b

d

0

1

b

f

0

1

f

b

0

1

f

a

0

0

ii>



Present state

Next state

Output

a  
b  
c  
d  
e  
f

i/p: 0

i

ip: 0

1

d

0

1

f

0

1

b

d

0

1

e

f

0

1

f

b

0

1

e

f

0

1

f

c

0

0

Q3) Draw the state diagram for:



Ans

$$J_f = 1, \quad A = 0, \quad Q(t+1) = \bar{Q}(t)$$

$$J_f = 0, \quad A = 1, \quad Q(t+1) = Q(t)$$

$$\Rightarrow Q(t+1) = \bar{A} \bar{Q}(t) + A Q(t)$$



Q4) Determine the function of following circuit;

First input to DFF is 0



Ans Initially,  $D = 0$ ,  $Q = 0$

$$G_{13} = D \oplus b_3 = b_3$$

$$G_{12} = b_3 \oplus b_2$$

$$G_{11} = b_2 \oplus b_1$$

$$G_{10} = b_1 \oplus b_0$$

$\Rightarrow$  It is a binary to gray code converter.

Q5) Determine the function of following circuit;



Ans  $F_3 = b_0 \oplus 0 = b_0$

$$F_2 = b_1 \oplus 0 = b_1$$

$\Rightarrow$  Reverses the order of bits.

$$F_1 = b_2 \oplus 0 = b_2$$

$$F_0 = b_3 \oplus 0 = b_3$$

Q6) Identify the flipflops in following:



Ans:  $T = X \oplus Q(t)$

$$\text{In TFF, } Q(t+1) = T \oplus Q(t)$$

$$\Rightarrow Q(t+1) = X \oplus Q(t) \oplus Q(t)$$

$$= X \oplus 0$$

$$= X$$

$\Rightarrow$  D flipflop,,

i)



$$\text{Ans: } Q(t+1) = \bar{X}Q + Y\bar{Q}$$

If  $Y=J$  &  $X=K$

$$Q(t+1) = \bar{J}\bar{Q} + \bar{K}Q$$

$\Rightarrow JK$  flipflop //

NOTE: If cascaded mod  $M$  then we get mod  $N$  counters are mod ' $M \times N$ '

counter.



Q7) Find the output waveform



CT EN  $\rightarrow$  count enable



QP> Determine each of the decoder output waveform



$S_0$  on

Q9) Determine the counter sequence, initially at 000



Ans

$$Q_0(t+1) = \overline{Q_2(t)} \cdot Q_1(t)$$

$$Q_1(t+1) = Q_0(t)$$

$$Q_2(t+1) = Q_1(t)$$

000  $\rightarrow$  100  $\rightarrow$  110  $\rightarrow$  111  $\rightarrow$  011  $\rightarrow$  001  $\rightarrow$  100

Q10) Determine the counter sequence, initial at 0000



Ans

$$J_0 = K_0 = 1$$

$$Q_0(t+1) = \overline{Q_0(t)}$$

$$J_1 = K_1 = \frac{Q_0 \cdot Q_1 \cdot \overline{Q_2} \cdot Q_3}{Q_0 \cdot Q_1 \cdot Q_2 \cdot Q_3}$$

$$J_2 = K_2 = \frac{\overline{Q_1} \cdot Q_2 \cdot Q_3}{Q_1 \cdot Q_2 \cdot Q_3}$$

$$J_3 = K_3 = \frac{\overline{Q_2} \cdot Q_3}{Q_2 \cdot Q_3}$$

$0000 \rightarrow 1111 \rightarrow 1110 \rightarrow 1101 \rightarrow 1010 \rightarrow 0101$   
 $0100 \leftarrow 1011 \leftarrow 0100 \leftarrow$   
 ↓ ↑

Q) Use Quine - Mcclusky method to reduce:  
 $F(w, x, y, z) = \sum m(0, 1, 2, 3, 5, 7, 13, 15)$

|    |        |                    |                                       |
|----|--------|--------------------|---------------------------------------|
| 0  | 0000 ✓ | (0, 1) 000- ✓      | (0, 1, 2, 3) - 00- - $\bar{w}\bar{x}$ |
| 1  | 0001 ✓ | (0, 2) 00- 0 ✓     | (0, 2, 1, 3) - 00- -                  |
| 2  | 0010 ✓ | (1, 5) 0- 0 1 ✓    | (1, 5, 3, 7) - 0- - 1                 |
| 3  | 0011 ✓ | (1, 3) 0 0- 1 ✓    | (1, 3, 5, 7) - 0- - 1 $\bar{w}z$      |
| 5  | 0101 ✓ | (2, 3) 0 0 1- ✓    |                                       |
| 7  | 0111 ✓ | (3, 7) 0- 1 1 ✓    | (5, 7, 13, 15) - - 1- 1               |
| 13 | 1101 ✓ | (5, 7) 0 1- 1 ✓    | (5, 13, 7, 15) - - 1- 1 $\times z$    |
| 15 | 1111 ✓ | (5, 13) - 1 0 1 ✓  |                                       |
|    |        | (7, 15) - 1 1 1 ✓  |                                       |
|    |        | (13, 15) 1 1 - 1 ✓ |                                       |

Quine  
implicant  
table

| PI               | 0   | 1 | 2   | 3 | 5 | 7 | 13  | 15  |
|------------------|-----|---|-----|---|---|---|-----|-----|
| $\bar{w}\bar{x}$ | (X) | X | (X) | X |   |   |     |     |
| $\bar{w}z$       |     | X |     | X | X | X |     |     |
| $xz$             |     |   |     |   | X | X | (X) | (X) |

$$F = \bar{w}\bar{x} + xz$$

Q> Use Quine - McCluskey method to simplify:  
 $F(A, B, C, D) = \sum m(4, 5, 6, 8, 9, 10, 13) + d \sum (0, 7, 15)$

Ans

|     |        |           |      |                         |                  |     |            |
|-----|--------|-----------|------|-------------------------|------------------|-----|------------|
| d0  | 0000 ✓ | (d0, 4)   | 0-00 | $\bar{A}\bar{C}\bar{D}$ | (4, 5, 6, d7)    | 01- | $\bar{A}B$ |
| 4   | 0100 ✓ | (d0, 8)   | -000 | $\bar{B}\bar{C}\bar{D}$ | (4, 6, 5, d7)    | 01- |            |
| 8   | 1000 ✓ | (4, 5)    | 010- | ✓                       | (5, d7, 13, d15) | -1- | BD         |
| 5   | 0101 ✓ | (4, 6)    | 01-  | 0 ✓                     | (5, 13, d7, d15) | -1- |            |
| 6   | 0110 ✓ | (8, 9)    | 100- | $A\bar{B}C$             |                  |     |            |
| 9   | 1001 ✓ | (8, 10)   | 10-  | $A\bar{B}\bar{D}$       |                  |     |            |
| 10  | 1010 ✓ | (5, d7)   | 01-  | 1 ✓                     |                  |     |            |
| d7  | 0111 ✓ | (5, 13)   | -101 | ✓                       |                  |     |            |
| 13  | 1101 ✓ | (6, d7)   | 011- | ✓                       |                  |     |            |
| d15 | 1111 ✓ | (9, 13)   | 1-01 | $A\bar{C}D$             |                  |     |            |
|     |        | (d7, d15) | -111 | ✓                       |                  |     |            |
|     |        | (13, d15) | 11-1 | ✓                       |                  |     |            |

Prime implicant table

| PI                      | 4 | 5 | 6 | 8 | 9 | 10 | 13 |
|-------------------------|---|---|---|---|---|----|----|
| $\bar{A}B$              | ✓ | ✓ |   | ✓ |   |    |    |
| $BD$                    |   |   | ✓ |   |   |    | ✓  |
| $\bar{A}\bar{C}\bar{D}$ | ✓ |   |   |   |   |    |    |
| $\bar{B}\bar{C}\bar{D}$ |   |   |   | ✓ |   |    |    |
| $A\bar{B}C$             |   |   |   | ✓ |   |    |    |
| $A\bar{B}\bar{D}$       |   |   |   | ✓ |   |    |    |
| $A\bar{C}D$             |   |   | ✓ | ✓ | ✓ | ✓  | ✓  |

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

## Programmable Logic devices (PLD)

→ It contains a large number of gates, flipflops and used to perform a particular function.

n buffers / inverters



Blowing must be these fuses removed along in the order that obtain

the particular configuration.

Advantages: Acquires less board space, faster, lower power requirements (i.e. smaller power supplies), less costly (fewer ICs & circuit connections), higher reliability (fewer connections), easier troubleshooting)

Device

AND array

OR array

PROM

-

Programmable

PAL

Programmable

-

PLA

Programmable

Programmable

PAL - Programmable

array

logic

PLA - Programmable

logic

array

PA16L8BNC  $\rightarrow$  IC



=



unprogrammed  
AND



=



unprogrammed  
OR



=



Programmed  
AND



Programmed  
OR



Programmed  
AND



Programmed  
OR

ROM:

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

PROM:  
full adder  
OR  $\rightarrow$  Programmable  
Address is fixed

3-8 decoder

Q>  $f_1(x_2, x_1, x_0) = \sum m(0, 1, 2, 5, 7)$  using PROM  
 $f_2(x_2, x_1, x_0) = \sum m(1, 2, 4, 6)$



NOTE: •  $\rightarrow$  Non programmable  
 X  $\rightarrow$  Programmable

Always - synthesizable

Initial - not

NOTE: Always  $\rightarrow$  in a procedural construct  
Forever  $\rightarrow$  in a loop statement  
for, while, repeat are also loops.  
(in verilog)

Size of PROM

No. of inputs - m bits

No. of outputs - n bits

$\therefore$  Size of PROM =  $2^m \times n$

Eg:  $F(x) = 3x + 2$ . Draw PROM:

ip - 3 bit

op - 5 bit

| x | d/p |
|---|-----|
| 0 | 2   |
| 1 | 5   |
| 2 | 8   |
| 3 | 11  |
| 4 | 14  |

| $x_2$ | $x_1$ | $x_0$ | $z_4$ | $z_3$ | $z_2$ | $z_1$ | $z_0$ |  |  |
|-------|-------|-------|-------|-------|-------|-------|-------|--|--|
| 0     | 0     | 0     | 0     | 0     | 0     | 1     | 0     |  |  |
| 0     | 0     | 1     | 0     | 0     | 1     | 0     | 1     |  |  |
| 0     | 1     | 0     | 0     | 1     | 0     | 0     | 0     |  |  |
| 0     | 1     | 1     | 0     | 1     | 0     | 1     | 1     |  |  |
| 1     | 0     | 0     | 0     | 1     | 1     | 1     | 0     |  |  |
| 1     | 0     | 1     | 1     | 0     | 0     | 0     | 1     |  |  |
| 1     | 1     | 0     | 1     | 0     | 1     | 0     | 0     |  |  |
| 1     | 1     | 1     | 1     | 0     | 1     | 1     | 1     |  |  |

$z_4 = 5, 6, 7$

$z_3 = 2, 3, 4$

$z_2 = 1, 4, 6, 7$

$z_1 = 0, 3, 4, 7$

$z_0 = 1, 3, 5, 7$



Q2: PAL:  $f_1 = \sum m(1, 2, 4, 5, 7)$   
 $f_2 = \sum m(0, 1, 3, 5, 7)$

$$f_1 = \bar{x}y\bar{z} + x\bar{y} + xz + \bar{y}z$$

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

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

$$f_1 = f_3 + \bar{y}z + \bar{x}y\bar{z}$$



PLA:

No. of input = l  
 No. of product term = m  
 No. of output = n  
 Size of PLA =  $l \times m \times n$

NOTE:  $X$  - Programmable  
 $\circ$  - Non Programmable

$$\begin{aligned} \text{1)} \quad f_1(x, y, z) &= \sum m (0, 1, 3, 4) = \bar{x}z + \bar{y}\bar{z} \\ f_2(x, y, z) &= \sum m (1, 2, 3, 4, 5) = \bar{x}z + \bar{x}y + xy \end{aligned}$$

Ans  $l = 3 \quad m = 4 \quad n = 2$   
 $\therefore \text{Size} = 3 \times 4 \times 2 = 24$



EXOR gate with programmable fuse



PLA table

| Product term     | IP |   |   | OP    |       |
|------------------|----|---|---|-------|-------|
|                  | x  | y | z | $f_1$ | $f_2$ |
| $\bar{x}z$       | 0  | - | 1 | 1     | 1     |
| $\bar{x}y$       | 0  | 1 | - | 0     | 1     |
| $\bar{y}\bar{z}$ | -  | 0 | 0 | 1     | 0     |
| $x\bar{y}$       | 1  | 0 | - | 0     | 1     |

C T  
 (active low) (active high)



## Tutorial

Q1) Determine the excitation table for XY FF when truth table is given as:

| x | y | $Q(t+1)$     | $Q(t)$ | $Q(t+1)$ | x | y |
|---|---|--------------|--------|----------|---|---|
| 0 | 0 | 1            |        | 0        | 0 | 1 |
| 0 | 1 | $Q(t)$       |        | 0        | 1 | 0 |
| 1 | 0 | $\bar{Q}(t)$ |        | 1        | 0 | 1 |
| 1 | 1 | 0            |        | 1        | 1 | 0 |

Q2) Design a counter using JK FF that counts 0, 1, 2, 4, 5, 6, 0

| PS            | NS                  | $J_2$ | $K_2$ | $J_1$ | $K_1$ | $J_0$ | $K_0$ |
|---------------|---------------------|-------|-------|-------|-------|-------|-------|
| $Q_2 Q_1 Q_0$ | $Q_2^+ Q_1^+ Q_0^+$ |       |       |       |       |       |       |
| 0 0 0         | 0 0 1               | 0     | X     | 0     | X     | 1     | X     |
| 0 0 1         | 0 1 0               | 0     | X     | 1     | X     | X     | 1     |
| 0 1 0         | 1 0 0               | 1     | X     | X     | 1     | 0     | X     |
| 1 0 0         | 1 0 1               | X     | 0     | 0     | X     | 1     | X     |
| 1 0 1         | 1 1 0               | X     | 0     | 1     | X     | X     | 1     |
| 1 1 0         | 0 0 0               | X     | 1     | X     | 1     | 0     | X     |

| $Q_0$ | 00  | 01  | 11  | 10  |
|-------|-----|-----|-----|-----|
| $Q_1$ | 0 0 | 2 0 | 6 X | 4 1 |
| $Q_2$ | 1 X | 3 X | 7 X | 5 X |

$$J_2 = Q_1$$

||| by

$$J_1 = Q_0$$

$$J_0 = \overline{Q_1}$$

$$K_0 = 1$$

$$K_1 = 1$$

$$K_2 = Q_1$$



Q3) A synchronous counter goes to 0, 3, 5, 6, 0 and flipflops inputs are  $T_2 = Q_1$ ,  $T_1 = 1$ ,  $T_0 = \bar{Q}_1$ . Check if this self starting / self correcting counter.

Ans

Unused states

Flip flop inputs

| $T_2$ | $T_1$ | $T_0$ | Present state | Next state |
|-------|-------|-------|---------------|------------|
| 0     | 1     | 1     | 0 0 1         | 0 1 0      |
| 1     | 1     | 0     | 0 1 0         | 1 0 0      |
| 0     | 1     | 1     | 1 0 0         | 1 1 1      |
| 1     | 1     | 0     | 1 1 1         | 0 0 1      |

Not self correcting

Q4)

Redesign the above counter to avoid lockdown condition.

Ans



Q5) Determining the function of following circuit obtaining it's state diagram.



Ans

$$T_A = A + B$$

PS

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

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

| FF | i/p | T <sub>A</sub> | T <sub>B</sub> |
|----|-----|----------------|----------------|
| 0  | 1   | 0              | 1              |
| 1  | 1   | 1              | 1              |
| 1  | 0   | 1              | 0              |
| 1  | 1   | 1              | 1              |

NS

| A <sup>+</sup> | B <sup>+</sup> |
|----------------|----------------|
| 0              | 1              |
| 1              | 0              |
| 0              | 0              |
| 0              | 0              |

State diagram;



Mod - 3 self starting counter.

Verilog:



• Logic that is generated from synthesis tools depends highly on the code that is written in HDL.

• Good model - efficient optimisation during synthesis.

Coding styles for synthesis:

1) Naming convention: It should be in such a way that integration becomes easier.

2) Design partitioning: Break a complex design into smaller modules. Partition size should be between 5000 to 15000 gates. Inter block signaling should be reduced as too many of them cause congestion in layout phase.

3) Clock: Global clock - non synthesisable - it should be added as analog block at the end.

Internally generated clock should be used as little as possible. Use gated clock for control use component instantiation for controlled fanout. i.e



- 4> Reset - Can be synchronous or asynchronous.
- 5> Timing loop - It has potential to create timing glitch. It should be avoided for combinational circuits.

## Algorithmic state machine (ASM)





Flow-chart representation

1) State box:



2) Decision box



3) Conditional output box:



Example:



2) State diagram:



Input  $\rightarrow x$   
Output  $\rightarrow z_1 z_2$

The given state diagram can be represented as:

