

अङ्कीयवैद्युतक मतिबृहत्स्तरीय संयोजन परिकल्पना य

DIGITAL ELECTRONICS AND  
VLSI DESIGN

# DIGITAL ELECTRONICS

Logic High - 1

Logic Low - 0

## Logic Gates:

NOT

AND

OR

NAND

NOR

XOR

XNOR

$$\text{XOR: } Y = A\bar{B} + \bar{A}B : A \oplus B$$

Truth Table:



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

$$\text{XNOR: } A \odot B$$



$$Y = A\bar{B} + \bar{A}B \rightsquigarrow \text{sop}$$

$$Y = (\bar{A} + B) \cdot (A + \bar{B}) \rightsquigarrow \text{pos}$$

maxterm (M)

$$m = \bar{M}$$

de-Morgan's law:

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

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

## Inverter Using Transistor:



## Minimization of Logic Equations

- ① Using Boolean Axioms/Theorems / Postulation
- ② Karnaugh Map Method
- ③ Tabulation Method .

One Variable:  $A \rightarrow 0/1$

Two Variables:  $AB$

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

| $A \backslash B$ | 0 | 1 |
|------------------|---|---|
| 0                | 0 | 1 |
| 1                | 1 | 0 |

nothing in corner

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

|           |    |           |           |
|-----------|----|-----------|-----------|
| A         | B  | $\bar{B}$ | B         |
| $\bar{A}$ | O  | L         | $\bar{L}$ |
| A         | 10 | 11        | 11        |

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

$\begin{pmatrix} 1 \\ 0 \\ 1 \\ 1 \end{pmatrix}$  → 1 bit change

$$B + A \overline{B} \xrightarrow{\text{simplified form}} A + B \rightarrow \text{DR Gate}$$

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

## Three Variables

A B C



OR

|                  |     |           |     |
|------------------|-----|-----------|-----|
| $\bar{A}B$       | $C$ | $\bar{C}$ | $C$ |
| $\bar{A}\bar{B}$ | 00  | 0         | 001 |
| $\bar{A}B$       | 01  | 2         | 011 |
| $A\bar{B}$       | 11  | 6         | 111 |
| $A\bar{B}$       | 10  | 4         | 101 |

1      1  
↓      ↓ OR      ) Gray code  
1      0  
 → (carry = 1)

$$\text{Eq. } F = \sum_i (0, 2, 3, 4)$$

$$S_{OP} = \overline{A}\overline{B}\overline{C} + \overline{A}\overline{B}\overline{C} + \overline{A}BC + A\overline{B}\overline{C}$$

$$\pi \rightarrow \text{pos} = \overline{A}B + \overline{B}\overline{C}$$

| $A\backslash B$ | 00 | 01 | 11 | 10 |
|-----------------|----|----|----|----|
| 0               | 1  | 1  | 0  | 0  |
| 1               | 1  | 1  | 0  | 1  |
|                 |    |    |    |    |

→ Insert 1 at 0, 2, 3, 4 positions  
& 0 everywhere else.

Either

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

OR

are  
neighbours

11

K-Map:

A B C

↪ We can only corner  $2^n$  (even) squares.

2 squares cornered Karnaugh → 1 variable gets reduced → ~~A B C~~

4 squares cornered Karnaugh → 2 variables reduced → ~~A B C~~

8 squares cornered Karnaugh → o/p is 1 → ~~A B C~~ → AB<sup>C</sup>  
 (always; irrespective of inputs)

|   |   |   |   |
|---|---|---|---|
| 1 | 1 | 1 | 1 |
| 1 | 1 | 1 | 1 |
| 1 | 1 | 1 | 1 |
| 1 | 1 | 1 | 1 |

Eg.  $F(x, y, z) = \sum(0, 2, 3, 4, 5)$

Reduce using K-Map.

| XY\Z | $\bar{z}$ | $\bar{z}$ | $z$ |
|------|-----------|-----------|-----|
| 00   | 1         | 1         | 0   |
| 01   | 1         | 1         | 1   |
| 11   | 0         | 0         | 0   |
| 10   | 1         | 1         | 1   |

$$F = x'z' + x'zy' + x'yz + xy'z + xy'z$$

$$F = x'z' + \underbrace{x'y + xy'}_{OR}$$

$$F = y'z' + \underbrace{x'y' + xy'}_{OR}$$

→ If any of the minterm is left to be cornered, it can be overlapped.

## Four Variable Map

ABCD

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

→ Each square is called minterm.

$$m_0 = A'B'C'D'$$

No. of squares that can be reduced:

Squared      Variables Reduced to

2 — 3 variables / literals

4 — 2 variables

8 — 1 variables

16 — 0/p=1

Eg.  $F(A, B, C, D) = \sum(1, 3, 7, 11, 15, 12)$

| AB \ CD | 00 | 01 | 11 | 10 |
|---------|----|----|----|----|
| 00      | 0  | 1  | 1  | 0  |
| 01      | 0  | 0  | 1  | 0  |
| 11      | 1  | 0  | 1  | 0  |
| 10      | 0  | 0  | 1  | 0  |

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

→ 'Don't care' condition: for undefined

# In BCD code  $\rightarrow$  4 bits required  $\rightarrow$  16 variables  $\rightarrow$  But represent only possible (0 to 9)

$\left. \begin{matrix} 0 \\ 10 \\ 9 \end{matrix} \right\} \rightarrow \text{Output} = 1$

10 (to 10)  $\rightarrow$   $\underbrace{1010}_{(10 \text{ in binary})} \rightarrow \text{not defined}$

Introducing 'X' (don't care) to digital:

Logics: '0', '1', 'X'

possible values in digital

Eg.  $F(A, B, C, D) = \Sigma(1, 3, 7, 11, 12, 15)$

$D(A, B, C, D) = (4, 13)$

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

↪ 1 in  $(1, 3, 7, 11, 12, 15)$

↪ X in  $(4, 13)$

↪ 0 elsewhere.

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

OR

$$F = \bar{A}\bar{B}D + CD + ABC$$

'Don't care' can take value '0' or '1'

helps to reduce no. of literals

should be cornered with only '1'

shouldn't be cornered alone  
or with itself

#

$\times$

$\times \times$

$\times 0$

$\boxed{\times 1}$

## 5 variable Map

$$F(A \{ B, C, D, E \})$$

$A=0$

| BC \ DE | 00 | 01 | 11 | 10 |
|---------|----|----|----|----|
| 00      | 0  | 1  | 3  | 2  |
| 01      | 4  | 5  | 7  | 6  |
| 11      | 12 | 13 | 15 | 14 |
| 10      | 8  | 9  | 11 | 10 |

$A=1$

| BC \ DE | 00 | 01 | 11 | 10 |
|---------|----|----|----|----|
| 00      | 16 | 17 | 19 | 18 |
| 01      | 20 | 21 | 23 | 22 |
| 11      | 28 | 29 | 31 | 30 |
| 10      | 24 | 25 | 27 | 26 |

Eq.  $F(A, B, C, D, E) = \sum(0, 2, 4, 6, 9, 13, 21, 23, 25, 29, 31)$

$A=0$

| BC \ DE | 00 | 01 | 11 | 10 |
|---------|----|----|----|----|
| 00      | 1  |    |    | 1  |
| 01      | 1  |    |    | 1  |
| 11      |    | 1  |    |    |
| 10      |    | 1  |    |    |

$A=1$

| BC \ DE | 00 | 01 | 11 | 10 |
|---------|----|----|----|----|
| 00      |    |    |    |    |
| 01      |    | 1  | 1  |    |
| 11      |    | 1  | 1  |    |
| 10      |    | 1  |    |    |

→ (are neighbours;  
only 1 bit change)

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

## Tabulation Method (Quine McCluskey Method)

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

① convert the minterms into binary.

② Group them according to the no. of '1's.

↓  
Quine McCluskey Method

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

| <u>AB CD</u> | <u>A, B, C, D</u> | <u>AB CD</u>                                |
|--------------|-------------------|---------------------------------------------|
| 0 000 ✓      | 0,1 0 0 0 ✓       | 0,1,8,9 - 00 -                              |
| 1 0001 ✓     | 0,2 0 0 - 0 ✓     | - 0 - 0 same                                |
| 2 0010 ✓     | 0,8 - 0 0 0 ✓     | - 0 - 0                                     |
| 8 1000 ✓     | 1,5 0 - 0 1       | 0 8 1 9 - 00 -                              |
| 5 0101 ✓     | 1,9 - 0 0 1 ✓     | Essential one<br>↓<br>needs to be mentioned |
| 9 1001 ✓     | 2,10 - 0 1 0 ✓    | ↓<br>won't be included afterwards           |
| 10 1010 ✓    | 8,9 1 0 0 - ✓     |                                             |
|              | 8,10 1 0 - 0 ✓    |                                             |

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

↑  
Essential prime implicant  
(1,5)

Q)  $F(A, B, C, D) = \sum(1, 4, 6, 7, 8, 9, 10, 11, 15).$

Reduce the boolean equation using tabulation method.

(egn but given in numeric)

|     | <u>A B C D</u> | <u>A B C D</u>  | <u>AB CD</u>        |
|-----|----------------|-----------------|---------------------|
| I   | 1 0 0 0 1 ✓    | 1,9 - 0 0 1     | 8,9,10,11 1 0 - - } |
|     | 4 0 1 0 0 ✓    | 4,6 0 1 - 0     | 8,10,9,11 1 0 - - } |
|     | 8 1 0 0 0 ✓    | 8,9 1 0 0 - ✓   |                     |
|     | 6 0 1 1 0 ✓    | 8,10 1 0 - 0 ✓  |                     |
| II  | 9 1 0 0 1 ✓    | 6,7 0 1 1 -     |                     |
|     | 10 1 0 1 0 ✓   | 9,11 1 0 - 1 ✓  |                     |
|     | 7 0 1 1 1 ✓    | 10,11 1 0 1 - ✓ |                     |
| III | 11 1 0 1 1 ✓   | 7,15 - 1 1 1    |                     |
| IV  | 15 1 1 1 1 ✓   | 11,15 1 - 1 1   |                     |

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

include  
Don't care  
here

for optimal solution: Optimal / Essential Table

|                               | 1 | 4 | 6 | 7 | 8 | 9 (ES) | 10 (E) | $\Sigma = 111.5$ |
|-------------------------------|---|---|---|---|---|--------|--------|------------------|
| ✓ 1,9 $\bar{B}\bar{C}D$       | * |   |   |   |   | *      |        | $\Sigma = 10.5$  |
| ✓ 4,6 $\bar{A}\bar{B}\bar{D}$ |   | * | * |   |   |        |        |                  |
| 6,7 $\bar{A}\bar{B}C$         |   |   | * | * |   |        |        |                  |
| ✓ 7,15 $B\bar{C}D$            |   |   |   |   | * |        |        | x                |
| 11,15 $A\bar{C}D$             |   |   |   |   |   |        | x      |                  |
| ✓ 8,9,10,11 $A\bar{B}$        |   |   |   |   |   | *      | *      | x                |

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

don't include  
"Don't Care"  
Here

to get (7,15)  
included  
as none of  
7 or 15 are  
there

Horizontal line: includes only 1 value.

Vertical line: includes pair  
not already included  
e.g. (6,7) but not (7,15)

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

$$\bar{J}\bar{A} = 1.5$$

$$\text{Eq. } F(A, B, C, D) = \sum (0, 1, 2, 3)$$

$$D(A, B, C, D) = \sum (5, 7)$$

① In the first table, include 0, 1, 2, 3, 5, 7

② In Essential/optimal table, include only 0, 1, 2, 3.

| A | B | C | D |     | A    | B | C | D   |       | A          | B | C | D          |
|---|---|---|---|-----|------|---|---|-----|-------|------------|---|---|------------|
| 0 | 0 | 0 | 0 | ✓   | 0, 1 | 0 | 0 | 0   | - ✓   | 0, 1, 2, 3 | 0 | 0 | - - ↗ same |
| 1 | 0 | 0 | 0 | 1 ✓ | 0, 2 | X | 0 | 0   | - 0 ✓ | 0, 2, 1, 3 | 0 | 0 | - -        |
| 2 | 0 | 0 | 1 | 0 ✓ | 1, 3 | 0 | 0 | - 1 | ✓     | 1, 3, 5, 7 | 0 | - | - 1 ↗ same |
| 3 | 0 | 0 | 1 | 1 ✓ | 1, 5 | 0 | - | 0   | 1 ✓   | 1, 5, 3, 7 | 0 | - | - 1        |
| 5 | 0 | 1 | 0 | 1 ✓ | 2, 3 | 0 | 0 | 1   | - ✓   |            |   |   |            |
| 7 | 0 | 1 | 1 | 1 ✓ | 3, 7 | 0 | - | 1   | 1 ✓   |            |   |   |            |
|   |   |   |   |     | 5, 7 | 0 | 1 | -   | 1 ✓   |            |   |   |            |

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

Optimal Solution : ('Don't care' won't be considered here)

|                                 | 0 | 1 | 2 | 3 |
|---------------------------------|---|---|---|---|
| (0, 1, 2, 3) ✓ $\bar{A}\bar{B}$ | X | X | X | X |
| (1, 3, 5, 7) $\bar{A}D$         |   | X |   | X |

$$\therefore F = \bar{A}\bar{B}$$

# DIGITAL DESIGN

- ① Combinational Circuits
- ② Sequential Circuits

Combinational circuits: Output depends only on input.  
the present



Eg. Half Adder  $\rightarrow$  Adding without carry

$$A + B$$



A truth table for a Half Adder. The columns are labeled A, B, S (sum), and C (carry). The rows show all possible combinations of A and B:

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

$$C = AB$$

$$S = A \oplus B$$

Sequential circuits: Output depends not only on the present input  
but also on the past output.



$$\begin{aligned} & \overline{BA} \cdot \overline{AB} = \overline{BA} \cdot \overline{B} \\ & \overline{BA} \cdot \overline{B} = \overline{BA} \\ & \overline{BA} \cdot \overline{B} = \overline{B}(\overline{A} \cdot \overline{B}) \\ & \overline{B}(\overline{A} \cdot \overline{B}) = \overline{B}(\overline{A} + \overline{B}) = \end{aligned}$$

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

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

Eg. Full Adder  $\rightarrow$  Adding with carry

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

Sum:

| (S) | A | B | C |
|-----|---|---|---|
| 00  | 0 | 0 | 0 |
| 01  | 1 | 0 | 1 |
| 11  | 0 | 1 | 0 |
| 10  | 1 | 1 | 0 |

$$S = A \oplus B \oplus C$$

Carry:

| (C) | A | B | C |
|-----|---|---|---|
| 00  | 0 | 0 | 0 |
| 01  | 0 | 0 | 1 |
| 11  | 1 | 1 | 0 |
| 10  | 0 | 1 | 1 |

$$C = AB + BC + AC$$

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

Eg Use Full Adder circuit to add 2 four-bit numbers.

$$A = A_3 \underset{\text{MSB}}{A_2} A_1 \underset{\text{LSB}}{A_0}$$

$$B = B_3 \ B_2 \ B_1 \ B_0$$

$$A = A_3 \underset{\text{MSB}}{A_2} A_1 \underset{\text{LSB}}{A_0}$$

$$B = B_3 \ B_2 \ B_1 \ B_0$$

$$\begin{array}{cccc} \text{FA} & \text{FA} & \text{FA} & \text{HA} \\ \hline \end{array}$$

$$C_3 \ S_3 \ S_2 \ S_1 \ S_0$$

2 HA circuits = 1 FA circuit



→ 4 bit Parallel Adder  
(Ripple Carry Adder)

In 10 ns, carry will be available for it.

→ For fast result, increase carry part efficiency.

→ Propagation Delay:

Time taken by circuit to acknowledge the change in state.

OR  
finite time required to respond the change in state.

• Inverter is BJT or MOSFET takes finite time to change from cutoff to saturation



→ ABC

Full Adder:  $S = A \oplus B \oplus C$

$$C = AB + BC + AC$$

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

$$\begin{aligned} C &= AB + AB'C + A'BC \\ &= AB + C(AB' + A'B) \\ \Rightarrow C &= AB + C(A \oplus B) \end{aligned}$$

Half Adder:

$$S = A \oplus B$$

$$C = AB$$



$$t_{CPD} = 4 \text{ AND} + 4 \text{ OR} + (\text{extra})$$

XOR or AND

parallel

5ns      3ns      5ns

- Gates responsible for giving propagation delay: AND & OR

Propagation delay for the 8-bit adder

$$\begin{aligned} &= 8 \times 5\text{ns} + 8 \times 3\text{ns} + 5\text{ns} \\ &= 69\text{ns} \end{aligned}$$

## Carry Lookahead Adder

- ↳ Aim: To reduce the propagation delay
  - ↳ Area will increase.
  - ↳ All the carries are generated simultaneously.



$$S_i = P_i \oplus C_i$$

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

$$C_2 = G_1 + P_1 C_1$$

$$C_3 = G_2 + P_2 C_2$$

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

$$C_4 = G_3 + P_3 C_3$$

$$= G_3 + P_3 (G_2 + P_2 (G_1 + P_1 C_1))$$

$P_i = A_i \oplus B_i$  : carry propagator  
 $G_i = A_i B_i$  : carry generator



Q) Design a 4-bit gray to binary code converter and obtain the reduced boolean equation using K-Map.

Soln:



| <u>Gray</u> |       |       |       | <u>Binary</u> |       |       |       |
|-------------|-------|-------|-------|---------------|-------|-------|-------|
| $A_3$       | $A_2$ | $A_1$ | $A_0$ | $a_3$         | $a_2$ | $a_1$ | $a_0$ |
| 0           | 0     | 0     | 0     | 0             | 0     | 0     | 0     |
| 0           | 0     | 0     | 1     | 0             | 0     | 0     | 1     |
| 0           | 0     | 1     | 0     | 0             | 0     | 1     | 1     |
| 0           | 0     | 1     | 1     | 0             | 0     | 1     | 0     |
| 0           | 1     | 0     | 0     | 0             | 1     | 1     | 1     |
| 0           | 1     | 0     | 1     | 0             | 1     | 1     | 0     |
| 0           | 1     | 1     | 0     | 0             | 1     | 0     | 0     |
| 0           | 1     | 1     | 1     | 0             | 1     | 0     | 1     |
| 1           | 0     | 0     | 0     | 1             | 1     | 1     | 1     |
| 1           | 0     | 0     | 1     | 1             | 1     | 1     | 0     |
| 1           | 0     | 1     | 0     | 1             | 1     | 0     | 0     |
| 1           | 0     | 1     | 1     | 1             | 1     | 0     | 1     |
| 1           | 1     | 0     | 0     | 1             | 0     | 0     | 0     |
| 1           | 1     | 0     | 1     | 1             | 0     | 0     | 1     |
| 1           | 1     | 1     | 0     | 1             | 0     | 1     | 0     |
| 1           | 1     | 1     | 1     | 1             | 0     | 1     | 0     |

For  $a_3$ :

| $A_3 A_2$ | $A_1 A_0$ | 00 | 01 | 11 | 10 |
|-----------|-----------|----|----|----|----|
| 00        | 0         | 0  | 0  | 0  | 0  |
| 01        | 0         | 0  | 0  | 0  | 0  |
| 11        | 1         | 1  | 1  | 1  | 1  |
| 10        | 1         | 1  | 1  | 1  | 1  |

$$a_3 = A_3$$

For  $a_2$ :

| $A_3 A_2$ | $A_1 A_0$ | 00 | 01 | 11 | 10 |
|-----------|-----------|----|----|----|----|
| 00        | 0         | 0  | 0  | 0  | 0  |
| 01        | 1         | 1  | 1  | 1  | 1  |
| 11        | 0         | 0  | 0  | 0  | 0  |
| 10        | 1         | 1  | 1  | 1  | 1  |

$$\begin{aligned}a_2 &= \bar{A}_3 A_2 + A_3 \bar{A}_2 \\&= A_2 \oplus A_3\end{aligned}$$

For  $a_1$ :

| $A_3 A_2$ | $A_1 A_0$ | 00 | 01    | 11 | 10 |
|-----------|-----------|----|-------|----|----|
| 00        | 0         | 0  | (1) 1 | 1  | 1  |
| 01        | (1)       | 1  | 0     | 0  | 0  |
| 11        | 0         | 0  | (1) 1 | 1  | 1  |
| 10        | (1)       | 1  | 0     | 0  | 0  |

$$\begin{aligned}a_1 &= \bar{A}_3 \bar{A}_2 A_1 + \bar{A}_3 A_2 \bar{A}_1 + \\&\quad A_3 A_2 A_1 + A_3 \bar{A}_2 \bar{A}_1 \\&= A_1 \oplus A_2 \oplus A_3\end{aligned}$$

For  $a_0$ :

| $A_3 A_2$ | $A_1 A_0$ | 00  | 01  | 11  | 10  |
|-----------|-----------|-----|-----|-----|-----|
| 00        | 0         | (1) | 0   | (1) | (1) |
| 01        | (1)       | 0   | (1) | 0   | 0   |
| 11        | 0         | (1) | 0   | (1) | (1) |
| 10        | (1)       | 0   | (1) | 0   | 0   |

$$\begin{aligned}a_0 &= \bar{A}_3 \bar{A}_2 \bar{A}_1 A_0 + \bar{A}_3 \bar{A}_2 A_1 \bar{A}_0 + \\&\quad \bar{A}_3 A_2 \bar{A}_1 \bar{A}_0 + \bar{A}_3 A_2 A_1 A_0 + \\&\quad A_3 A_2 \bar{A}_1 A_0 + A_3 A_2 A_1 \bar{A}_0 + \\&\quad A_3 \bar{A}_2 \bar{A}_1 \bar{A}_0 + A_3 \bar{A}_2 A_1 A_0 \\&= A_3 \oplus A_2 \oplus A_1 \oplus A_0\end{aligned}$$

## Carry Look Ahead Adder

$$\begin{array}{r} +A \\ +B \\ \hline S = +A + B \end{array}$$

$$\begin{array}{r} +A \\ -B \\ \hline S = \dots \end{array} \quad \begin{array}{c} A \\ + \\ 2' \text{ compl. } B \\ \hline \end{array} \quad \begin{array}{c} 4\text{-bit} \\ A_3 A_2 A_1 A_0 \\ 2' \text{ comp. } (B_3 B_2 B_1 B_0) \end{array}$$



↳ 4-bit parallel Adder/Subtractor

→ If  $C_0 = 1$ ,  $B_0 \rightarrow$  complemented (act like subtractor)

If  $C_0 = 0$ ,  $B_0 \rightarrow B_0$  (act like adder)

→ If  $C_0 = 1$ , { if  $B_0 = 0$ ,  $B_0 \oplus C_0 = 1$   
if  $B_0 = 1$ ,  $B_0 \oplus C_0 = 0$  } complement  
(Subtractor)

If  $C_0 = 0$ , { if  $B_0 = 0$ ,  $B_0 \oplus C_0 = 0$   
if  $B_0 = 1$ ,  $B_0 \oplus C_0 = 1$  } same  
(Adder)

4 → 3 bits required  
+ 4 → 4-bits required  
(0100)  
std. no. of bits required

+ A, B, C → S, C4  
+ A, B, C → S, C4  
+ A, B, C → S, C4  
+ A, B, C → S, C4

A, B, C → S, C4

## Parity Generator / Parity Checker Circuit

↳ Due to noise in the system, some bits may be flipped.

$$\underline{1} \ 0 \ 0 \rightarrow \underline{0} \ 0 \ 0$$

↳ So, we send along with the original signal, an error checking signal; parity checker to check for any error in communication transmission.

**Parity checker** → Even parity: No. of '1' in the signal is even.  
→ Odd parity: No. of '1' in the signal is odd.

Checks whether  
the no. of '1' is  
even or not.

↳  $O/p=1$ , if even  
↳  $O/p=0$ , if odd

A B C  $\xrightarrow{\text{Parity}}$   

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

| A | B | C | P                                                             |
|---|---|---|---------------------------------------------------------------|
| 0 | 0 | 0 | 0 $\rightarrow$ no. of 1 = even ( $O/p=0$ )                   |
| 1 | 0 | 0 | 1 $\rightarrow$ no. of 1 = odd ( $O/p=1$ )<br>we add '1' more |
| 2 | 0 | 1 | 0 $\rightarrow$ we get even no. of 1's<br>(0 0   1 1)         |
| 3 | 0 | 1 | 1                                                             |
| 4 | 1 | 0 | 0 $\rightarrow$ P(A, B, C) = $\Sigma(1, 2, 4, 7)$             |
| 5 | 1 | 0 | 1                                                             |
| 6 | 1 | 1 | 0                                                             |
| 7 | 1 | 1 | 1                                                             |

XOR  
↓  
odd fn (for  
more than 2  
variables)

## Magnitude Comparator

↳ Compare if  $A=B$   
or  $A < B$   
or  $A > B$ .

For  $A=B$

A  $A_3 A_2 A_1 A_0$   
B  $B_3 B_2 B_1 B_0$

Logic  $\rightarrow$  if  $(A_3=B_3) \& (A_2=B_2) \&$   
 $(A_1=B_1) \& (A_0=B_0)$

$\gamma_3 \gamma_2 \gamma_1 \gamma_0 \rightarrow$  AND Gate  
 $\gamma_3 \& \gamma_2 \& \gamma_1 \& \gamma_0$

To check if  $A_3 = B_3$ , use XNOR gate:

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

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

For  $A > B$

|   |   |       |       |       |       |
|---|---|-------|-------|-------|-------|
| A | 1 | $A_3$ | $A_2$ | $A_1$ | $A_0$ |
| B | 0 | $B_3$ | $B_2$ | $B_1$ | $B_0$ |

$$Y_i = A_i B_i + \bar{A}_i \bar{B}_i$$

$$Y(A > B) = A_3 \bar{B}_3 + Y_3 A_2 \bar{B}_2$$

$$+ Y_3 Y_2 A_1 \bar{B}_1 + Y_3 Y_2 Y_1 \bar{A}_0 \bar{B}_0$$

For  $A < B$

|   |   |       |       |       |       |
|---|---|-------|-------|-------|-------|
| A | 1 | $A_3$ | $A_2$ | $A_1$ | $A_0$ |
| B | 0 | $B_3$ | $B_2$ | $B_1$ | $B_0$ |

|   |   |       |       |       |       |
|---|---|-------|-------|-------|-------|
| A | 1 | $A_3$ | $A_2$ | $A_1$ | $A_0$ |
| B | 0 | $B_3$ | $B_2$ | $B_1$ | $B_0$ |

$$Y(A < B) = \bar{A}_3 B_3 + Y_3 \bar{A}_2 B_2 +$$

$$Y_3 Y_2 \bar{A}_1 B_1 + Y_3 Y_2 Y_1 \bar{A}_0 \bar{B}_0$$

# To minimize the area (time doesn't matter)  $\rightarrow$  Iteration method.

↳ check  $A_3 > B_3 \rightarrow$  store the result

↳ check  $A_2 > B_2 \rightarrow$  store the result

} Take AND of all the results.

# COMBINATIONAL CIRCUITS

## Multiplexer

↳ Digital circuit used to ~~transmit~~ multiple signals.

↳ Accepts ~~a~~ bunch of signals but outputs only one signal based on the selection lines.

↳ Useful for control purposes.



| $S_0$ | $S_1$ | Input line taken |
|-------|-------|------------------|
| 0     | 0     | 1st              |
| 0     | 1     | 2nd              |
| 1     | 0     | 3rd              |
| 1     | 1     | 4th              |



$$F = I_0 \bar{S} + I_1 S$$

$$S = 0 \cdot I_0$$

$$S = 1 \cdot I_1$$



e.g.



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

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

$$\bar{S}_1 \bar{S}_0 I_0$$

$$\bar{S}_1 S_0 I_1$$

$$S_1 \bar{S}_0 I_2$$

$$S_1 S_0 I_3$$

$$\rightarrow 8 \times 1 \text{ circuit: } F = \bar{S}_2 \bar{S}_1 \bar{S}_0 I_0 + \bar{S}_2 \bar{S}_1 S_0 I_1 + \bar{S}_2 S_1 \bar{S}_0 I_2 + \bar{S}_2 S_1 S_0 I_3 \\ + S_2 \bar{S}_1 \bar{S}_0 I_4 + S_2 \bar{S}_1 S_0 I_5 + S_2 S_1 \bar{S}_0 I_6 + S_2 S_1 S_0 I_7$$



$\rightarrow$  Logic Circuit:

4x1 MUX:



Demux



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

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

## DeMUX



→ To have SOP (we have only AND Gate here), we can connect OR Gate externally.

→ MUX can act as a Full Adder.

Selection lines → inputs.



MUX:



0 0 0 → I<sub>0</sub> gets 5V

0 0 1 → I<sub>1</sub> gets 5V.

1 1 1 → I<sub>7</sub> gets 5V.

# Decoder

MSI  $\rightarrow$  Middle Medium Scale Integration.

↳ Transistor level is more than 10 ( $> 10$  Gates/Transistors)

( $> 10$  Gates/Transistors)

↳ Have enable pins

Enabled signal  
↳ Its output is considered



$$F = \bar{S} I_0 + S I_1$$

$$F = E \bar{S} I_0 + E S I_1$$

$$F = 0$$

24-08-2023

MUX, Adder, Magnitude  
comparator are MSI

# Decoder

↳ Decoder used to code/decode  $n$  input lines (binary information) to  $2^n$  output lines.



$2^n$  distinct output lines  
(but not necessary).

e.g.



Binary to decimal

| $A\ B$ | $D_0$ | $D_1$ | $D_2$ | $D_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     |

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

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

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

$$D_3 = A B$$



$$\text{Eg. } F(A, B) = \sum(0, 3) \\ F = \overline{A}\overline{B} + AB$$



Q1 Design a Full Adder circuit using 3 to  $8^1$  decoder and necessary gates.

$$\text{Sol: } S(A, B, C) = \sum (1, 2, 4, 7) \\ C(A, B, C) = \sum (3, 5, 6, 7)$$



## Decoder with Enable Signal



(Q) Construct a  $4 \times 16$  decoder using ~~with~~  $3 \times 8$  decoders with enable signal.

Soln:



| E | A | B | C |
|---|---|---|---|
| 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 1 |
| 0 | 1 | 1 | 1 |
| 1 | 0 | 0 | 0 |
| 1 | 0 | 0 | 1 |
| ⋮ | ⋮ | ⋮ | ⋮ |

→ To construct  $4 \times 16$  decoder using  $2 \times 4$  decoders,  
we need 4 ( $2 \times 4$ ) decoders,  
we can't use inverter (E) as with  $3 \times 8$  decoders

## Encoder

### 4 to 2 Encoder

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



↳ 2 values (1000 & 0000) are giving the same code (00)

↳ must be avoided.

↳ Ambiguity

↳ If input is (0110) it will give (11), but we wanted (01) or (10).

$$A = D_2 + D_3$$

$$B = D_1 + D_3$$

↳ ~~Prioritizing Encoders~~

More than one info shouldn't be 1.  
Don't care

| $D_0$ | $D_1$ | $D_2$ | $D_3$ | A | B | V |
|-------|-------|-------|-------|---|---|---|
| 0     | x     | x     | x     | 0 | 0 | 1 |
| 0     | 1     | x     | x     | 0 | 1 | 1 |
| 0     | 0     | 1     | x     | 1 | 0 | 1 |
| 0     | 0     | 0     | 1     | 1 | 1 | 1 |

↳ verification determines if we should consider the info  
↳ consider, if  $V=1$  & not, if  $V=0$ .

↳  $V=0$ , if  $D_0, D_1, D_2, D_3 = 0000$   
 $=1$ , else

↳ we should consider only if one of info ( $D_0, D_1, D_2, D_3$ ) is 1.

↳ Priority Encoder

↳ Giving priority to MSB or LSB.

# Tri State Buffer/Inverter



$Z \rightarrow$  High Impedance state  
 $\hookrightarrow$  floating  
 $\hookrightarrow$  no connection in output section

| A | E | Y   |
|---|---|-----|
| X | 0 | 'Z' |
| 0 | 1 | 1   |
| 1 | 1 | 0   |

Active High:  $E=1$   
 Active Low:  $E=0$



| A | E | Y        |
|---|---|----------|
| X | 1 | High 'Z' |
| 0 | 0 | 1        |
| 1 | 0 | 0        |



Q) Use tristate buffer to make 2x1 Mux.

Soln:



$$Y = I_0 \bar{S} + I_1 S$$

| S | Y     |
|---|-------|
| 0 | $I_0$ |
| 1 | $I_1$ |



### Application:

(4-bit adder of only one input line)

<sup>data line</sup> BUS →



| AB | E <sub>0</sub> E <sub>1</sub> E <sub>2</sub> E <sub>3</sub> |    |    |    |
|----|-------------------------------------------------------------|----|----|----|
|    | 00                                                          | 01 | 10 | 11 |
| 00 | 1                                                           | 0  | 0  | 0  |
| 01 | 0                                                           | 1  | 0  | 0  |
| 10 | 0                                                           | 0  | 1  | 0  |
| 11 | 0                                                           | 0  | 0  | 1  |

→ Buffer can also be like  
(Bidirectional switch)



## Combinational Circuit Design using MUX/DECODER

Eg.  $F(A, B, C, D) = \sum m(0, 1, 3, 4, 8, 9, 15)$

- For  $n$  variable Boolean function, the no. of select lines would be  $(n-1)$ .
- Variables,  $n=4$  ( $A, B, C, D$ )
- No. of select lines =  $n-1 = 3$

|      | $B'C'D'$ | $B'CD$ | $BC'D'$ | $BCD$ | $B'CD'$ | $BCD$ | $BCD'$ | $BCD$ |
|------|----------|--------|---------|-------|---------|-------|--------|-------|
|      | $I_0$    | $I_1$  | $I_2$   | $I_3$ | $I_4$   | $I_5$ | $I_6$  | $I_7$ |
| $A'$ | 0        | 1      | 2       | 3     | 4       | 5     | 6      | 7     |
| $A$  | 8        | 9      | 10      | 11    | 12      | 13    | 14     | 15    |
|      | 1        | 1      | 0       | $A'$  | $A'$    | 0     | 0      | $A$   |

$(A+A)$   
 $(A^1$  for circled)



Eg. 4-input function with a multiplexer :  $F(A, B, C, D) = \sum (1, 3, 4, 11, 12, 13, 14, 15)$ .

Soln:

|      | 000   | 001   | 010   | 011   | 100   | 101   | 110   | 111   |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
|      | $I_0$ | $I_1$ | $I_2$ | $I_3$ | $I_4$ | $I_5$ | $I_6$ | $I_7$ |
| $A'$ | 0     | 1     | 2     | 3     | 4     | 5     | 6     | 7     |
| $A$  | 8     | 9     | 10    | 11    | 12    | 13    | 14    | 15    |
|      | 0     | $A'$  | 0     | 1     | 1     | $A$   | $A$   | $A$   |



Eg. Implement  $F(A, B, C, D) = \sum(1, 3, 4, 11, 12, 13, 14, 15)$  using  $4 \times 1$  MUX.

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

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

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

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

Implementation



## Combinational Circuit Using DECODER

Any combinational circuit with  $n$  inputs and  $m$  outputs can be implemented with an  $n \times 2^n$  line decoder and  $m$  OR gates.

$$\text{Eq. } S = (x, y, z) = \sum(1, 2, 4, 7)$$

$$C(x, y, z) = \sum(3, 5, 6, 7)$$



Full adder using decoder

## Multiplexer Circuit

### The Binary Multiplication:

$$\begin{array}{r}
 & 1 & 0 & 1 & 0 & 1 & 0 & \text{Multiplicand} \\
 & \times & & & 1 & 0 & 1 & 1 \\
 \hline
 & 1 & 0 & 1 & 0 & 1 & 0 & \\
 & 1 & 0 & 1 & 0 & 1 & 0 & \text{Multiplier} \\
 & 0 & 0 & 0 & 0 & 0 & 0 & \\
 + & 1 & 0 & 1 & 0 & 1 & 0 & \\
 \hline
 & 1 & 1 & 1 & 0 & 0 & 1 & . & 1 & 0 & \text{Result}
 \end{array}$$

} Partial products

$$\begin{array}{r}
 x_2 \quad x_1 \quad x_0 \\
 \times \quad y_1 \quad y_0 \\
 \hline
 x_2 y_0 \quad x_1 y_0 \quad x_0 y_0 \\
 \times \quad x_2 y_1 \quad x_1 y_1 \quad x_0 y_1 \\
 \hline
 s_3 \quad s_2 \quad s_1 \quad s_0
 \end{array}$$





→ Optimally, only  $(2 \text{ HA} + 1 \text{ FA})$  are required.

# PALs AND PLAs

Programmable logic array (PLA) → can program both AND and OR gates.

- ↳ what we've seen so far
- ↳ Unconstrained fully-general AND and OR arrays.

Programmable array logic (PAL) → only AND is programmable, fixed no. of OR gates.

↳ constrained topology of the OR array

↳ Innovation by Monolithic memories

↳ faster and smaller (cheaper) OR plane.

→ A given column of the OR array has access to only a subset of the possible product terms.



Eg. Design FA using programmable logic devices.  
(PLA)



6 x 8 x 3  
Input lines      AND Gates      Output lines  
3 A,B,C      3 complements

• Loading: current driving capability to turn a gate.



# load/power driving capability  
(needed to drive 4 pins)



Eg. BCD to gray code converter

| BCD |   |   |   | Gray |   |   |   |
|-----|---|---|---|------|---|---|---|
| A   | B | C | D | w    | x | y | z |
| 0   | 0 | 0 | 0 | 0    | 0 | 0 | 0 |
| 0   | 0 | 0 | 1 | 0    | 0 | 0 | 1 |
| 0   | 0 | 1 | 0 | 0    | 0 | 1 | 1 |
| 0   | 0 | 1 | 1 | 0    | 0 | 1 | 0 |
| 0   | 1 | 0 | 0 | 0    | 1 | 1 | 0 |
| 0   | 1 | 0 | 1 | 0    | 1 | 1 | 1 |
| 0   | 1 | 1 | 0 | 0    | 1 | 0 | 1 |
| 0   | 1 | 1 | 1 | 0    | 1 | 0 | 0 |
| 1   | 0 | 0 | 0 | 1    | 1 | 0 | 0 |
| 1   | 0 | 0 | 1 | 1    | 1 | 0 | 1 |

$$W = \sum m(8, 9) + d(10, 11, 12, 13, 14, 15)$$

$$X = \sum m(4, 5, 6, 7, 8, 9) + d(10, 11, 12, 13, 14, 15)$$

$$Y = \sum m(2, 3, 4, 5) + d(10, 11, 12, 13, 14, 15)$$

$$Z = \sum m(1, 2, 5, 6, 9) + d(10, 11, 12, 13, 14, 15)$$

W:

| AB | CD | 00 | 01 | 11 | 10 |
|----|----|----|----|----|----|
| 00 |    | 0  | 0  | 0  | 0  |
| 01 |    | 0  | 0  | 0  | 0  |
| 11 |    | X  | X  | X  | X  |
| 10 |    | 1  | 1  | X  | X  |

$$W = A$$

X:

| AB | CD | 00 | 01 | 11 | 10 |
|----|----|----|----|----|----|
| 00 |    | 0  | 0  | 0  | 0  |
| 01 |    | 1  | 1  | 1  | 1  |
| 11 |    | X  | X  | X  | X  |
| 10 |    | 1  | 1  | X  | X  |

$$X = A + B$$

y:

| AB | CD | 00 | 01 | 11 | 10 |
|----|----|----|----|----|----|
| 00 |    | 0  | 0  | 1  | 1  |
| 01 |    | 1  | 1  | 0  | 0  |
| 11 |    | X  | X  | X  | X  |
| 10 |    | 0  | 0  | X  | X  |

$$y = B\bar{C} + \bar{B}C$$

Z:

| AB | CD | 00 | 01 | 10 |
|----|----|----|----|----|
| 00 |    | 0  | 1  | 0  |
| 01 |    | 0  | 1  | 0  |
| 11 |    | X  | X  | X  |
| 10 |    | 0  | 1  | X  |

$$Z = \bar{C}D + CD$$



## Code Converter : NAND Gate implementation

- loss of regularity, harder to understand
- harder to make changes.



## Magnitude 2bit (AB ? CD) comparator

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

K-Map for EQ

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

K-Map for NE

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

K-map for LT

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

K-map for GT



# READ-ONLY MEMORIES (ROM)

Two dimensional array of 1s and 0s

- entry (row) is called a "word"
- width of row = word-size
- index is called an "address".
- address is input
- selected word output

- One-time programmable
- To store 16-bit information, we need 16 input lines.
- To store Mega, Giga, Terra bits, we require decoder.



## Internal organization:



## ROM

- Read-only memory (can only be read)
- OTP (One Time Programmable)
- made of static cells
- consist of decoder and memory array.

## RAM

- can be re-programmed.
- made of flip-flops.

Eg. 64-bit ROM



# Combinational logic implementation (two-level canonical form)

## using a ROM

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

$$F_1 = \bar{A}\bar{B}C + \bar{A}\bar{B}\bar{C} + ABC$$

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

$$F_3 = \bar{A}BC + A\bar{B}\bar{C} + AB\bar{C}$$



block diagram

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



## Memory

- Volatile → Erases data on power off (e.g., RAM, cache)
- Non-volatile → Remains even after power is off (e.g., ROM, USB drives)
  - ↳ static.

## Programmable Devices:

- PROM (Programmable Read-only Memory)
- PLA (Programmable Logic Array)
- PAL (Programmable Array logic)
- CPLD (Complex Programmable Logic Device)
- FPGA (Field Programmable Gate Array)

# RAM

↳ erases memory when power is off.

ROM

↳ stores memory even ~~when~~ if power is off.

AND-OR-array  
↓  
programmable

# ELECTRICAL CHARACTERISTICS OF LOGIC GATES

- ① Power dissipation
- ② Propagation delay
- ③ Noise margin
- ④ (loading) Fan in/Fan out

Figure of merit

$$= \frac{\text{Power} \times \text{delay}}{\text{Constant}}$$

- BJT supports frequency  $f$  below radiofrequency
- For analog, figure of merit = Gain  $\times$  Bandwidth range of freq. in which device works properly.



Power dissipation,

$$P_D = P_{DP} + P_{SP}, \quad P_{DP}: \text{dynamic power}$$

$$P_{SP} = V_{CC} I_C \quad P_{SP}: \text{static power}$$

$$i(t) = C \frac{dV}{dt}; \quad \Delta V = \frac{V_{CC}}{t_d} \xrightarrow{\text{max. } V \text{ which } C \text{ can be charged with}} \xrightarrow{\text{max. time } t_d}$$

$$\Rightarrow i(t) = C \frac{V_{CC}}{t_d}$$

$$P_D = V_{CC} i(t) = \frac{V_{CC} \cdot C \cdot V_{CC}}{t_d} = \frac{V_{CC}^2 C}{t_d} \Rightarrow P_D \cdot t_d = \underbrace{\frac{V_{CC}^2 C}{t_d}}_{\text{fixed (based on device)}} \xrightarrow{\text{fixed}}$$

$$\Rightarrow P_D = V_{CC}^2 C \cdot f, \quad f: \text{frequency of switching} = \frac{1}{t_d}$$

#  $f \uparrow \Rightarrow P_D \uparrow \Rightarrow$  Less control over  $P_D$ . (Using high frequency switches).  
 $\rightarrow P_D \propto V_{CC} \Rightarrow V_{CC} \downarrow \Rightarrow P_D \downarrow$

## Propagation Delay

$$t_p = \frac{t_{LH} + t_{HL}}{2}$$

## Noise Margin

Only two levels in digital electronics:



→ Some gap is added b/w High & Low to avoid signal flipping due to noise.



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

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

## ROM structure:

- similar to a PLA structure but with a fully decoded AND array
- completely flexible OR array (unlike PAL)



## ROM vs. PLA

- ROM approach advantageous when:
  - design time is short (no need to minimize output functions)
  - most output combinations are needed (e.g., code converters)
  - little sharing of product terms among output functions
- ROM problems:
  - size doubles for each additional input
  - can't exploit don't cares
- PLA approach advantageous when:
  - design tools are available for multi-output minimization.
  - there are relatively few unique minterm combinations.
  - many minterms are shared among the output functions.
- PAL problems:
  - constrained fan-ins on OR plane.

## Regular logic structures for two-level logic:

- ROM: full AND plane, general OR plane
  - cheap (high-volume component)
  - can implement any function of  $n$  inputs.
  - medium speed.
- PAL: programmable AND plane, fixed OR plane
  - intermediate cost
  - can implement functions limited by no. of terms.
  - high speed (only one programmable plane that is much smaller than ROM's decoder).
- PLA: programmable AND and OR planes
  - most expensive (most complex in design, need more sophisticated tools).
  - can implement any function upto a product term limit.
  - slow (two programmable planes).

## Regular logic structures for multi-level logic:

- Difficult to devise a regular structure for arbitrary connections b/w a large set of different types of gates.
  - efficiency/speed concerns for such a structure.
  - ~~such~~ field programmable gate arrays (FPGAs) are just such programmable multi-level structures.
    - programmable multiplexers for wiring
    - lookup table for logic functions (programming fills in the table).
    - multi-purpose cells (utilization is the big issue).
- Use multiple levels of PALs/PLAs/ROMs:
  - output intermediate result.
  - make it an input to be used in further logic.

# SEQUENTIAL CIRCUITS

12-09-2023



## Sequential Circuits:

① Synchronous Sequential circuit  $\rightarrow$  clock is used

② Asynchronous Sequential Circuit

## Memory Element:

### Latch / Flip-Flop (1 bit)

- ↳ Holds information indefinitely till power is given, or until input signal is disturbed.
- ↳ NOR or NAND Gate used
- ↳ To hold the info. indefinitely, a feedback is required.





NOR Gate Characteristics:

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

⇒ O/p = 0, if one of the i/p = 0!  
(doesn't check other i/p)  
↳ Responds quickly

| S.  | R                           | Q | $\bar{Q}$ |
|-----|-----------------------------|---|-----------|
| 0 0 | 0 1                         | 0 | 1         |
| 1 0 | 1 0                         | 1 | 0         |
| 0 1 | 0 1                         | 0 | 1         |
| 1 1 | Indetermined state<br>(1 0) |   |           |

| S   | R            | Q | $\bar{Q}$ |
|-----|--------------|---|-----------|
| 0 0 | 0 1          | 0 | 1         |
| 1 0 | 1 0          | 1 | 0         |
| 0 0 | 1 0          | 1 | 0         |
| 0 1 | 0 1          | 0 | 1         |
| 0 0 | 0 1          | 0 | 1         |
| 1 1 | Undetermined |   |           |

### NAND charts:

| I/P | O/P |
|-----|-----|
| 0 0 | 1   |
| 1 0 | 1   |
| 0 1 | 1   |
| 1 1 | 0   |



| S | R | Q(t)         | $\bar{Q}(t)$ |
|---|---|--------------|--------------|
| 1 | 1 | $Q(t)$       | $\bar{Q}(t)$ |
| 0 | 1 | 1            | 0            |
| 1 | 0 | 0            | 1            |
| 0 | 0 | Indetermined |              |

~~undetermined~~  $\rightarrow$  Maintains the previous state



## D-Latch / D-FF

↳ Data-Latch

↳ Data Selector / Data Transmitter



Enable/control signal



↳ Basic element of memory  
↳ Back-to-back NOT/NAND gates. (SR)

A device that works on levels → Latch

↳ Level-sensitive device

A device working on ~~at~~ edge → Flip-flop

↳ Edge-sensitive device

| E            | D | $Q(t)$ | $Q$ | $\bar{Q}$ |
|--------------|---|--------|-----|-----------|
| P<br>(=1)    | 0 | $Q(t)$ | 0   | 1         |
| Indetermined | 1 | $Q(t)$ | 1   | 0         |



## J K FlipFlop

$\downarrow S$      $\downarrow J$   
 $\downarrow R$      $\downarrow K$



Truth Table:

| S | J | K | $Q(t)$ | $Q(t+1)$ | $\bar{Q}(t+1)$                        |
|---|---|---|--------|----------|---------------------------------------|
| 0 | 0 | 0 | 0      | 0        | 1                                     |
| 0 | 0 | 1 | 0      | 1        | 0                                     |
| 0 | 1 | 0 | 0      | 0        | 1 } Reset                             |
| 0 | 1 | 1 | 0      | 0        | 1 } doesn't depend on $Q(t)$ .        |
| 1 | 0 | 0 | 1      | 0        | 1                                     |
| 1 | 0 | 1 | 1      | 0        | 1                                     |
| 1 | 1 | 0 | 1      | 0        | 1 } Toggle the present state $Q(t)$ . |
| 1 | 1 | 1 | 0      | 0        | 1 } $Q(t+1) = \bar{Q}(t)$ .           |

→ 2 input SR FF disadvantages are overcome by JK FF by toggling the present state when input = (1,1).

## Toggle FF (TFF)

$\leftarrow$  Toggle

| T | $Q(t)$ | Q | $\bar{Q}$ |
|---|--------|---|-----------|
| 0 | 0      | 0 | 1         |
| 0 | 1      | 1 | 0         |
| 1 | 0      | 1 | 0         |
| 1 | 1      | 0 | 1         |



## JK FF characteristics Table:

| J | K | $Q(t)$ | $Q(t+1)$     |
|---|---|--------|--------------|
| 0 | 0 | $Q(t)$ | $Q(t)$       |
| 0 | 1 | $Q(t)$ | 0            |
| 1 | 0 | $Q(t)$ | 1            |
| 1 | 1 | $Q(t)$ | $\bar{Q}(t)$ |

K-Map:

| JK | $Q(t)$ |   |
|----|--------|---|
| 00 | 0      | 1 |
| 01 | 0      | 0 |
| 10 | 1      | 0 |
| 11 | 1      | 1 |

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

## T FF characteristics Table:

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

| T | $Q(t)$ |   |
|---|--------|---|
| 0 | 0      | 1 |
| 1 | 1      | 0 |

$$\therefore Q(t+1) = T \oplus Q \\ = TQ' + T'Q$$

## D FF characteristics Table:

| D | $Q(t)$ | $Q(t+1)$ |
|---|--------|----------|
| 0 | $Q(t)$ | 0        |
| 1 | $Q(t)$ | 1        |

| D | $Q(t)$ |   |
|---|--------|---|
| 0 | 0      | 0 |
| 1 | 1      | 1 |

$$\therefore Q(t+1) = D$$

## Edge Triggered Latch (FF)



→ Using Master and Slave

↳ 2 Latches required; one act as master, other as slave.  
Positive level latch  
(Assume  $t_p = 0$ )



↳ Becomes Edge sensitive  
(Negative Edge Trigger)  
Latch

Device is sensitive  
at ~~one-to-one~~ edge  
~~edge~~ (ON → OFF)  
Device senses  
the latest  
input here

Positive Edge Trigger Latch:

→ Output should be stable  
irrespective of the input  
coming

→ Timing ( $t_p$ ) is important.



# Sequential Circuit Design

- ① State equation  $\rightarrow$  Equation contains inputs and present state.
- ② State Table  $\rightarrow$  One of the inputs is the present state.
- ③ State Diagram  $\rightarrow$  Two states for inputs (of FF): 0 and 1.

①  $\rightarrow$  zero state ;      ②  $\rightarrow$  one state

JK FF:  
state diagram:



For state 0, if  $JK = (0,0)$  or  $(0,1)$ ,  
the output is again 0;  
if  $JK = (1,0)$ , the next state is 1.



## Mooore Machine

→ Mooore machine output depends on the states only.



## Mealy Machine

→ Mealy machine output depends not only on the states but also on the external ~~point~~ input.



Eg.,



- To get controlled output, Moore machine is used.  
(We don't get output immediately; we have to wait.)
- To get uncontrolled output, Mealy machine is used.  
(We get output immediately after giving input.)

Q1 We have a new FF with 3 inputs S, R and T. No more than one of these inputs may be 1 at anytime. The S and R inputs behave exactly as they do in an S.R. T input behaves as it does in T flip flop. Show the state diagram. Obtain the logic equation of the flip flop.

Soln:

| S | R | T | $Q(t)$ | $Q(t+1)$     |
|---|---|---|--------|--------------|
| 0 | 0 | 0 | $Q(t)$ | $\bar{Q}(t)$ |
| 0 | 0 | 1 | $Q(t)$ | $\bar{Q}(t)$ |
| 0 | 1 | 0 | $Q(t)$ | 0            |
| 1 | 0 | 0 | $Q(t)$ | 1            |



| SR | $T Q(t)$ |    |    |    |
|----|----------|----|----|----|
|    | 00       | 01 | 11 | 10 |
| 00 | 0        | 1  | 0  | 1  |
| 01 | 0        | 0  | x  | x  |
| 11 | x        | x  | x  | x  |
| 10 | 1        | 1  | x  | x  |

$$Q(t+1) = \bar{S} \bar{R} \bar{T} + \bar{R} T Q(t) + \bar{S} R T \bar{Q}(t)$$

$$Q(t+1) = S + \bar{R} \bar{T} Q(t) + T \bar{Q}(t)$$

| SRT | Present State | Next State | D |
|-----|---------------|------------|---|
| 000 | 0             | 0          | 0 |
| 000 | 1             | 1          | 1 |
| 001 | 0             | 0          | 1 |
| 001 | 1             | 1          | 0 |
| 010 | 0             | 0          | 0 |
| 010 | 1             | 1          | 0 |
| 100 | 0             | 0          | 1 |
| 100 | 1             | 1          | 1 |

22-09-2023

### SRT implementation Using D-FF:



$$D = S + T\bar{Q} + \bar{R}\bar{T}Q$$



For one SRT  
↓  
one DFF required

SRT → 2 states  
D → 2 states

For 4 state FF  
↓  
2 D FF required  
For 8 state FF  
↓  
3 D FF required

## Excitation Table for flip flops:

| $Q_n$ | $Q_{n+1}$ | S | R | $Q_n$ | $Q_{n+1}$ | D |
|-------|-----------|---|---|-------|-----------|---|
| 0     | 0         | 0 | X | 0     | 0         | 0 |
| 0     | 1         | 1 | 0 | 0     | 1         | 1 |
| 1     | 0         | 0 | 1 | 1     | 0         | 0 |
| 1     | 1         | X | 0 | 1     | 1         | 1 |

Excitation table for SR FF

Excitation table for D FF

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

Excitation table for JK FF

| $Q$ | $Q_{n+1}$ | T |
|-----|-----------|---|
| 0   | 0         | 0 |
| 0   | 1         | 1 |
| 1   | 0         | 1 |
| 1   | 1         | 0 |

Excitation table for T FF

## SRT implementation using JK FF:

| SRT | Present state | Next state | J | K |
|-----|---------------|------------|---|---|
| 000 | 0             | 0          | 0 | X |
| 000 | 1             | 1          | X | 0 |
| 001 | 0             | 1          | 1 | X |
| 001 | 1             | 0          | X | 1 |
| 010 | 0             | 0          | 0 | X |
| 010 | 1             | 0          | X | 1 |
| 100 | 0             | 1          | 1 | X |
| 100 | 1             | 1          | X | 0 |

K-Map for J:

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

$$J = S + T$$

K-Map for K:

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

$$K = T + R$$



- ① The word description of the circuit is stated. This may be accomplished accompanied by a state diagram, a timing diagram, or other pertinent information.
- ② From the given information about the circuit, obtain the state table.
- ③ The no. of states may be reduced by state-reduction methods if the sequential circuit can be characterized by input-output relationships independent.

Eg.

State Table:

| <u>Present State</u> | <u>Next State</u> |       | <u>Output</u> |       | <u>Inputs</u> |
|----------------------|-------------------|-------|---------------|-------|---------------|
|                      | $x=0$             | $x=1$ | $x=0$         | $x=1$ |               |
| a                    | a                 | b     | 0             | 0     |               |
| b                    | c                 | d     | 0             | 0     |               |
| c                    | a                 | d     | 0             | 0     |               |
| d                    | e                 | f     | 0             | 1     |               |
| e                    | a                 | f     | 0             | 1     |               |
| f                    | g                 | f     | 0             | 1     |               |
| g                    | a                 | f     | 0             | 1     |               |

- Two states are said to be equivalent if, for each member of the set of inputs, they give exactly the same output and send the circuit either to the same state or to an equivalent state.
- When two states are equivalent, one of them can be removed without altering the input-output relationships.

b & c are equivalent, provided a & c are eq.

a & c are equivalent, provided b & d are eq. → can't be made equivalent  
b/c o/p are different.

e & g are eq.

d & f are eq.

## Reduced state Table

| <u>Present state</u> | <u>Next State</u> |       | <u>Output</u> |       |
|----------------------|-------------------|-------|---------------|-------|
|                      | $x=0$             | $x=1$ | $x=0$         | $x=1$ |
| a                    | a                 | b     | 0             | 0     |
| b                    | c                 | d     | 0             | 0     |
| c                    | a                 | d     | 0             | 0     |
| d                    | e                 | d     | 0             | 1     |
| e                    | a                 | d     | 0             | 1     |

## Three Possible Binary state Assignments

| <u>state</u> | <u>Assignment 1</u> | <u>Assignment 2</u> | <u>Assignment 3</u> |
|--------------|---------------------|---------------------|---------------------|
| a            | 001                 | 000                 | 000                 |
| b            | 010                 | 010                 | 100                 |
| c            | 011                 | 011                 | 010                 |
| d            | 100                 | 101                 | 101                 |
| e            | 101                 | 111                 | 011                 |

One hot assignment: Only one bit is High.

One cold assignment: Only one bit is Low.

| <u>State</u> | <u>one hot assignment</u> |
|--------------|---------------------------|
| a            | 00001                     |
| b            | 00010                     |
| c            | 00100                     |
| d            | 01000                     |
| e            | 10000                     |

Assigning  $a, b, c, d, e = 001, 010, 011, 100, 101$ , in the reduced state-table,

| <u>Present State</u> | <u>Next state</u> |       | <u>Output</u> |       |
|----------------------|-------------------|-------|---------------|-------|
|                      | $x=0$             | $x=1$ | $n=0$         | $n=1$ |
| 001                  | 001               | 010   | 0             | 0     |
| 010                  | 011               | 100   | 0             | 0     |
| 011                  | 001               | 100   | 0             | 1     |
| 100                  | 101               | 100   | 0             | 1     |
| 101                  | 001               | 100   | 0             | 1     |

| <u>PS</u><br>$A B C$ | <u><math>x</math></u> | <u>NS</u><br>$A' B' C'$ | <u>O/P</u> | $T_A$ | $T_B$ | $T_C$ |
|----------------------|-----------------------|-------------------------|------------|-------|-------|-------|
| 001                  | 0                     | 001                     | 0          | 0     | 0     | 0     |
| 001                  | 1                     | 010                     | 0          | 0     | 1     | 1     |
| 001                  | 0                     | 011                     | 0          | 0     | 0     | 1     |
| 010                  | 0                     | 100                     | 0          | 1     | 1     | 0     |
| 010                  | 01                    | 001                     | 0          | 0     | 1     | 0     |
| 011                  | 0                     | 100                     | 0          | 1     | 1     | 1     |
| 011                  | 01                    | 100                     | 0          | 0     | 0     | 1     |
| 100                  | 0                     | 101                     | 0          | 0     | 0     | 1     |
| 100                  | 1                     | 100                     | 1          | 0     | 0     | 0     |
| 101                  | 0                     | 001                     | 0          | 1     | 0     | 0     |
| 101                  | 1                     | 100                     | 1          | 0     | 0     | 1     |

K-Map for  $Q, T_A, T_B, T_C$  ..

K-Map for  $Q$ :

| $A\backslash B\backslash C\backslash x$ | 00 | 01 | 11 | 10 |
|-----------------------------------------|----|----|----|----|
| 00                                      | X  | X  | 0  | 0  |
| 01                                      | 0  | 0  | 0  | 0  |
| 11                                      | X  | X  | X  | X  |
| 10                                      | 0  | 1  | 0  | 0  |

010001000100

$$O/P = Ax$$

### K-Map for TA:

| AB \ Cx | 00 | 01 | 11 | 10 |
|---------|----|----|----|----|
| 00      | X  | X  | 0  | 0  |
| 01      | 0  | 1  | 1  | 0  |
| 11      | X  | X  | X  | X  |
| 10      | 0  | 0  | 0  | 1  |

$$T_A = Bx + A\bar{c}\bar{x}$$

### K-Map for TB:

| AB \ Cx | 00 | 01 | 11 | 10 |
|---------|----|----|----|----|
| 00      | X  | X  | 1  | 0  |
| 01      | 0  | 1  | 1  | 1  |
| 11      | X  | X  | X  | X  |
| 10      | 0  | 0  | 0  | 0  |

$$T_B = \bar{A}x + BC$$

### K-Map for TC:

| AB \ Cx | 00 | 01 | 11 | 10 |
|---------|----|----|----|----|
| 00      | X  | X  | 1  | 0  |
| 01      | 1  | 0  | 1  | 0  |
| 11      | X  | X  | X  | X  |
| 10      | 1  | 0  | 1  | 0  |

$$T_C = \bar{c}\bar{x} + cx$$

Step 3:

- State Table
- ↓
- State Diagram
- ↓
- Reduced state table
- ↓
- Assignment
- ↓
- Decide no. of flip flops required
- ↓
- Excitation table
- ↓
- K-Map
- ↓
- Logic circuit

### Logic Diagram: Mealy Machine — Finite State Machine (FSM)



# Sequence Detector

Detecting the sequence 101 using Mealy machine

↳ output = 1, if detected/encountered.

↳ output = 0, otherwise.

1 0 1 (non-overlapping)

$x \ 1\ 0\ 1\ 1\ 1\ 0\ 1\ 0\ 1$  ← Input

$\Sigma \ 0\ 0\ 1\ 0\ 0\ 0\ 0\ 1\ 0\ 0$  ← Output

non-overlapping → 10101  
overlapping → 00100  
overlapping → 00101

## State Diagram:



- No useful info → Reset → 0 (same state)
- When a useful info comes, force to a new state

## State Table:

| PS    | NS    |       | Output |       |
|-------|-------|-------|--------|-------|
|       | $x=0$ | $x=1$ | $x=0$  | $x=1$ |
| $S_0$ | $S_0$ | $S_1$ | 0      | 0     |
| $S_1$ | $S_2$ | $S_1$ | 0      | 0     |
| $S_2$ | $S_0$ | $S_0$ | 0      | 1     |
| $S_3$ | $S_0$ | $S_1$ | 0      | 0     |

| PS    | $x$ | NS    | O/P |
|-------|-----|-------|-----|
| $S_0$ | 0   | $S_0$ | 0   |
| $S_0$ | 1   | $S_1$ | 0   |
| $S_1$ | 0   | $S_2$ | 0   |
| $S_1$ | 1   | $S_1$ | 0   |
| $S_2$ | 0   | $S_0$ | 0   |
| $S_2$ | 1   | $S_0$ | 1   |

## State Assignment:

$S_0$       00  
 $S_1$       01  
 $S_2$       10

| PS<br>A B | x | N S |   | O/P<br>x | J <sub>A</sub> K <sub>A</sub> |                | J <sub>B</sub> K <sub>B</sub> | (Using JK FF) |
|-----------|---|-----|---|----------|-------------------------------|----------------|-------------------------------|---------------|
|           |   | A   | B |          | J <sub>A</sub>                | K <sub>A</sub> |                               |               |
| 00        | 0 | 00  |   | 0        | 0                             | X              | 0 X                           |               |
| 00        | 1 | 01  |   | 0        | 0                             | X              | 1 X                           |               |
| 01        | 0 | 10  |   | 0        | 1                             | X              | X 1                           |               |
| 01        | 1 | 01  |   | 0        | 0                             | X              | X 0                           |               |
| 10        | 0 | 00  |   | 0        | X                             | 1              | 0 X                           |               |
| 10        | 1 | 00  |   | 1        | X                             | 1              | 0 X                           |               |

K-Map for O/P(Q):



$$Q = Ax$$

K-Map for J<sub>A</sub>:



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

K-Map for J<sub>A</sub>:



$$\therefore J_A = 1$$

K-Map for J<sub>B</sub>:



$$J_B = \bar{A}x$$

K-Map for K<sub>B</sub>:



$$K_B = \bar{x}$$



Q) Design a sequence detector which detects 1101 in overlapping mode using D-flip-flop (Use binary assignment).

Soln: State Diagram:



## State Table:

| PS    | NS    |       | O/P   |       |
|-------|-------|-------|-------|-------|
|       | $x=0$ | $x=1$ | $x=0$ | $x=1$ |
| $S_0$ | $S_0$ | $S_1$ | 0     | 0     |
| $S_1$ | $S_0$ | $S_2$ | 0     | 0     |
| $S_2$ | $S_3$ | $S_1$ | 0     | 0     |
| $S_3$ | $S_0$ | $S_1$ | 0     | 1     |

## State Assignment:

$$S_0 \rightarrow 00$$

$$S_1 \rightarrow 01$$

$$S_2 \rightarrow 10$$

$$S_3 \rightarrow 11$$

| PS                    | x |   | (D <sub>A</sub> D <sub>B</sub> ) |   |
|-----------------------|---|---|----------------------------------|---|
|                       | A | B | A                                | B |
| (S <sub>0</sub> ) 0 0 | 0 | 0 | 0 0                              | 0 |
| (S <sub>0</sub> ) 0 0 | 1 | 0 | 0 1                              | 0 |
| (S <sub>1</sub> ) 0 1 | 0 | 0 | 0 0                              | 0 |
| (S <sub>1</sub> ) 0 1 | 1 | 0 | 1 0                              | 0 |
| (S <sub>2</sub> ) 1 0 | 0 | 0 | 1 1                              | 0 |
| (S <sub>2</sub> ) 1 0 | 1 | 0 | 0 1                              | 0 |
| (S <sub>3</sub> ) 1 1 | 0 | 0 | 0 0                              | 0 |
| (S <sub>3</sub> ) 1 1 | 1 | 0 | 0 1                              | 1 |

## K-Map:

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

$$O/P = ABx$$

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

$$D_A = \bar{A}Bx + A\bar{B}\bar{x}$$

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

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

Circuit diagram:



# Moore Machine

Sequence: 1101

$x: 1011110 \downarrow 1101X$   
 $z: 00000000 \downarrow 000 \quad \begin{matrix} \text{non-overlapping} \\ \text{for overlapping} \end{matrix}$

$x: 1101X$   
 $z: 0000$

State Diagram:



State Table:

| <u>PS</u> | <u>NS</u> |       | <u>O/P</u> |       |
|-----------|-----------|-------|------------|-------|
|           | $x=0$     | $x=1$ | $x=0$      | $x=1$ |
| $S_0$     | $S_0$     | $S_1$ | 0          | 0     |
| $S_1$     | $S_0$     | $S_2$ | 0          | 0     |
| $S_2$     | $S_3$     | $S_2$ | 0          | 0     |
| $S_3$     | $S_0$     | $S_4$ | 0          | 0     |
| $S_4$     | $S_0$     | $S_1$ | 01         | 01    |

# To convert a Mealy machine to Moore, add a DFF to o/p.



State Assignment : (Binary)

|       |     |       |
|-------|-----|-------|
| $S_0$ | 000 | (ABC) |
| $S_1$ | 001 |       |
| $S_2$ | 010 |       |
| $S_3$ | 011 |       |
| $S_4$ | 100 |       |

| <u>PS(ABC)</u> | <u>X</u> | <u>(DA DB DC)</u> |            | <u>O/P</u> | <u>DA</u> | <u>DB</u> | <u>DC</u> |
|----------------|----------|-------------------|------------|------------|-----------|-----------|-----------|
|                |          | <u>NS</u>         | <u>O/P</u> |            |           |           |           |
| (S0) 000       | 0        | 000               | 0          | 0          | 0         | 0         | 0         |
| (S0) 000       | 1        | 001               | 0          | 0          | 0         | 0         | 1         |
| (S1) 001       | 0        | 000               | 0          | 0          | 0         | 0         | 0         |
| (S1) 001       | 1        | 010               | 0          | 0          | 0         | 1         | 0         |
| (S2) 010       | 0        | 011               | 0          | 0          | 0         | 1         | 1         |
| (S2) 010       | 1        | 010               | 0          | 0          | 0         | 1         | 0         |
| (S3) 011       | 0        | 000               | 0          | 0          | 0         | 0         | 0         |
| (S3) 011       | 1        | 100               | 0          | 1          | 0         | 0         | 0         |
| (S4) 100       | 0        | 000               | 01         | 0          | 0         | 0         | 0         |
| (S4) 100       | 1        | 001               | 01         | 0          | 0         | 0         | 1         |

K-Map for O/p:

| AB\CX | 00 | 01 | 11 | 10 |
|-------|----|----|----|----|
| 00    | 0  | 0  | 0  | 0  |
| 01    | 0  | 0  | 0  | 0  |
| 11    | X  | X  | X  | X  |
| 10    | 1  | 1  | X  | X  |

O/p = A (Z)

K-Map for DA PA:

| AB\CX | 00 | 01 | 11 | 10 |
|-------|----|----|----|----|
| 00    | 0  | 0  | 0  | 0  |
| 01    | 0  | 0  | 1  | 0  |
| 11    | X  | X  | X  | X  |
| 10    | 0  | 0  | X  | X  |

DA =  $\overline{B}C\bar{X}$  +  $B\bar{C}X$

K-Map for DB:

| AB\CX | 00 | 01 | 11 | 10 |
|-------|----|----|----|----|
| 00    | 0  | 0  | 0  | 0  |
| 01    | 1  | 1  | 0  | 0  |
| 11    | X  | X  | X  | X  |
| 10    | 0  | 0  | X  | X  |

DB =  $B\bar{C}$  +  $\bar{B}CX$

K-Map for DC:

| AB\CX | 00 | 01 | 11 | 10 |
|-------|----|----|----|----|
| 00    | 0  | 1  | 0  | 0  |
| 01    | 1  | 0  | 0  | 0  |
| 11    | X  | X  | X  | X  |
| 10    | 0  | 1  | X  | X  |

DC =  $B\bar{C}\bar{X}$  +  $\bar{B}\bar{C}X$



Sequence is NOT overlapping

Q1 obtain a sequence detector to detect the sequences 111 and 011 using JK FF (overlapping) in Moore Machine.

Soln:



State Table:

| PS    | NS    |       | O/P   |       |
|-------|-------|-------|-------|-------|
|       | $x=0$ | $x=1$ | $x=0$ | $x=1$ |
| $S_0$ | $S_2$ | $S_1$ | 0     | 0     |
| $S_1$ | $S_2$ | $S_3$ | 0     | 0     |
| $S_2$ | $S_2$ | $S_3$ | 0     | 0     |
| $S_3$ | $S_2$ | $S_4$ | 0     | 0     |
| $S_4$ | $S_2$ | $S_4$ | 1     | 1     |

State Assignment

|       |     |
|-------|-----|
| $S_0$ | 000 |
| $S_1$ | 001 |
| $S_3$ | 010 |
| $S_4$ | 11  |

| PS(AB)    | $x$ | NS | O/P | $J_A$ | $K_A$ | $J_B$ | $K_B$ |
|-----------|-----|----|-----|-------|-------|-------|-------|
| $S_0$ 000 | 0   | 01 | 0   | 0     | X     | 1     | X     |
| $S_0$ 00  | 1   | 01 | 0   | 0     | X     | 1     | X     |
| $S_1$ 01  | 0   | 01 | 0   | 0     | X     | X     | 0     |
| $S_1$ 01  | 1   | 10 | 0   | 1     | X     | X     | 1     |
| $S_3$ 10  | 0   | 01 | 0   | X     | 1     | 1     | X     |
| $S_3$ 10  | 1   | 11 | 0   | X     | 0     | 1     | X     |
| $S_4$ 11  | 0   | 01 | 1   | X     | 1     | X     | 0     |
| $S_4$ 11  | 1   | 11 | 1   | X     | 0     | X     | 0     |

K-Map:

O/P:

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

$$O/P = AB$$

JA :

| AB | x | 0 | 1 |
|----|---|---|---|
| 00 | 0 | 0 |   |
| 01 | 0 | 0 | 1 |
| 11 | X | X |   |
| 10 | X | X |   |

KA:

| AB | x | 0 | 1 |
|----|---|---|---|
| 00 | X | X |   |
| 01 | X | X |   |
| 11 | T | 0 |   |
| 10 | L | 0 |   |

$$JA = BX \quad K_A = X$$

J<sub>B</sub>:

| AB | x | 0 | 1 |
|----|---|---|---|
| 00 | 1 | 1 |   |
| 01 | X | X |   |
| 11 | X | X |   |
| 10 | 1 | 1 |   |

$$J_B = 1$$

K<sub>B</sub>:

| AB | x | 0 | 1 |
|----|---|---|---|
| 00 | X | X |   |
| 01 | 0 | 0 |   |
| 11 | 0 | 0 |   |
| 10 | X | X |   |

$$K_B = \bar{A}x$$



# REGISTERS AND COUNTERS

## Registers

- A group of binary cells suitable for holding binary info.
- Group of FF constitutes a register which is a sequential circuit.
- Registers handle simple data storage and data movement during processing operations.
- A counter is essentially a register that goes through a predetermined sequence of binary states.

Eg 2 bit Register



1 bit register  
↓  
requires  
8 FFs

## Register Storage

- A register can store information for multiple clock cycles.
- External control signals used to load and store information in registers.
- Load signal controls register storage and loading
  - Load = 1: Load the values on the data inputs.
  - Load = 0: Store the values in the register.

Load = 0: holding past info  
Load = 1: Ready to store new info.

2-bit register with Load Control:

For Load=0, loads Load Register contents In1 (holds current values)

For Load=1, loads input values In0 (load new values)



Eg. For  $\oplus$ ve Edge-Triggered or  $\ominus$ ve Pulse Master-Slave FF:



## Registers with Clock Gating

- The Load Signal enables the clock signal to load pass through if 1 and prevents the clock signal from passing through if 0.



Eg

## Shift Register

- A register capable of shifting its binary information in one or both directions
- All flip-flops receive common clock pulses, which activate the shift from one stage to the next.
- The simplest possible shift register is one that uses only flip-flops.

### Shift Register Types:

- A register capable of shifting its binary information either to the right or to the left is called shift register.
- Serial in serial out Register (SISO)

The data is shifted serially "IN" and "OUT" of the register, one bit at a time in either a left or right direction under clock control.

Eg. 3 bit SISO using D FF. → Requires 3 D FFs



→ Shift Registers move data laterally within the register toward its MSB or LSB position.

→ In the simplest case, the shift register is simply a set of D flip-flops connected in a row like this:



3-bit SISO:

$C = O/P$   
IN: 1010101



- Data input, In, is called a serial input or shift right input.
- Data output, Out, is often called the serial output.



## Parallel IN serial OUT:



## Shift registers:

- serial IN serial Out
- serial In Parallel out
- Parallel In Serial out
- Parallel In Parallel Out

## SISO:

- Each clock pulse shifts the contents of the register one bit position to the right.
- The serial input determines what goes into the leftmost FF during the shift.
- The serial output is taken from the output of the rightmost flip-flop.
  
- Serial-in to Parallel-out (SIPO): The register is loaded with serial data, one bit at a time, with the stored data being available at the output in parallel form.
- Parallel-in to Parallel-out (PIPO): The parallel data is loaded simultaneously into the register, and transferred together to their respective outputs by the same clock pulse.
- Parallel-in Serial-out register (PISO): The parallel data is loaded into the register simultaneously and is shifted out of the register serially one bit at a time under clock control.

## PIPO:



## SIPo:



# PISO



→ IC's include the 74HC166 8-bit Parallel-In/serial-out Shift Registers.



## Serial Transfer

- A digital system is said to operate in a serial mode when information is transferred and manipulated one bit at a time.
- This is in contrast to parallel transfer where all the bits of the register are transferred at the same time.
- The serial transfer is done with shift registers.

# Shift Register with Parallel Load



function Table for the Register

| <u>Shift</u> | <u>Load</u> | <u>Operation</u>                  |
|--------------|-------------|-----------------------------------|
| 0            | 0           | No change                         |
| 0            | 1           | load parallel data                |
| 1            | X           | Shift down<br>from $Q_0$ to $Q_3$ |

# 4 bit (4+4) Serial (Full) Adder



| A | B | (Carry)<br>PS | Sum | (C)out<br>NS | Jc | Kc |
|---|---|---------------|-----|--------------|----|----|
| 0 | 0 | 0             | 0   | 0            | 0  | x  |
| 0 | 0 | 1             | 1   | 0            | x  | 1  |
| 0 | 1 | 0             | 1   | 0            | 0  | x  |
| 0 | 1 | 1             | 0   | 1            | x  | 0  |
| 1 | 0 | 0             | 1   | 0            | 0  | x  |
| 1 | 0 | 1             | 0   | 1            | x  | 0  |
| 1 | 1 | 0             | 0   | 1            | 1  | x  |
|   |   |               |     |              |    | 0  |

K-Map:  $I_1 I_2 I_3 I_4$



$$J_c = AB$$

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

$$S = A \oplus B \oplus C$$

## Shift Registers with Additional Functions

- By placing a 4-input multiplexer in front of each D flip-flop in a shift register, we can implement a circuit with shifts right, shifts left, parallel load, hold.
- Shift registers can also be designed to shift more than a shift bit position right or left.
- Shift registers can be designed to shift a variable number of bit positions specified by a variable called a shift amount.

### Universal Shift Register



### Shift Register with Parallel Load and Shift Direction (Universal)



## Universal Shift Register



### Register Operation

| $S_1$ | $S_0$ | Register Operation |
|-------|-------|--------------------|
| 0     | 0     | No change          |
| 0     | 1     | Shift right        |
| 1     | 0     | Shift left         |
| 1     | 1     | Parallel load      |

## Barrel Shift Register

- Shifting and rotating data is required in several applications including arithmetic operations.
- Shift right logical, shift right operation arithmetic, rotate right, shift left logical, shift left arithmetic, and rotate left.



If  $c=0$ , then it's a shift,  $c=1$  a rotate

| $S_0$ | $S_1$ |                          |
|-------|-------|--------------------------|
| 0     | 0     | no change                |
| 0     | 1     | shift left 1 (or rotate) |
| 1     | 0     | shift left 2 (or rotate) |
| 1     | 1     | shift left 3 (or rotate) |

→ Serial Adder using a JK flip-flop use 2 shift registers to store two numbers and one JK flip-flop to store the carry out.

→ Bits are added one pair at a time using a full adder.

- The carry out is transferred to a JK FF.
  - The result will be stored in shift register A.
  - The circuit can be used to sum a set of numbers.
  - Register B can be used to transfer a new binary number.
  - Initially, register A and carry flip-flop are cleared to 0.

# COUNTERS

→ Counters are sequential circuits which "count" through a specific state sequence. They can count up, count down, or count through other specific fixed sequences.

Two distinct types are in common usage:

## ① Ripple Counters / Asynchronous Counters:

- Clock connected to the flip-flop clock input on the LSB bit flip-flop.
- For all other bits, a flip-flop output is connected on the clock input, thus circuit is not truly synchronous!
- Output change is delayed more for each bit towards the MSB.
- Reversible because of low power consumption.

## ② Synchronous Counters:

- Clock is directly connected to the flip-flop clock inputs.
- Logic is used to implement the desired state sequencing.
- Faster than asynchronous counters.

Eg: Design 0 to 9 counters using D FF.

State diagram:



## State table:

|                   | PS |   |   |   | NS |   |   |   |
|-------------------|----|---|---|---|----|---|---|---|
|                   | A  | B | C | D | A  | B | C | D |
| (S <sub>0</sub> ) | 0  | 0 | 0 | 0 | 0  | 0 | 0 | 1 |
| (S <sub>1</sub> ) | 0  | 0 | 0 | 1 | 0  | 0 | 1 | 0 |
| (S <sub>2</sub> ) | 0  | 0 | 1 | 0 | 0  | 0 | 1 | 1 |
| (S <sub>3</sub> ) | 0  | 0 | 1 | 1 | 0  | 1 | 0 | 0 |
| (S <sub>4</sub> ) | 0  | 1 | 0 | 0 | 0  | 1 | 0 | 1 |
| (S <sub>5</sub> ) | 0  | 1 | 0 | 1 | 0  | 1 | 1 | 0 |
| (S <sub>6</sub> ) | 0  | 1 | 1 | 0 | 0  | 1 | 1 | 1 |
| (S <sub>7</sub> ) | 0  | 1 | 1 | 1 | 1  | 0 | 0 | 0 |
| (S <sub>8</sub> ) | 1  | 0 | 0 | 0 | 1  | 0 | 0 | 1 |
| (S <sub>9</sub> ) | 1  | 0 | 0 | 1 | 0  | 0 | 0 | 0 |

## K-Map:



## Circuit Diagram:



Eg 3-bit ( $0 \rightarrow 7$ ) Counter with Enable Pin



### Clock frequency divider (Divide-by-two Counter)

↪ A useful feature of the D-type FF is as a binary divider, for frequency division or as a "divide-by-2" counter



↪ Divides the clock frequency by 2:  $\left(\frac{f_{CLK}}{2}\right)$

Eg. 2-bit signal

MSB    LSB



$f_{clk}/2$



Ripple Counter ← Asynchronous Counter



|             | $\bar{A}$ | A | B |
|-------------|-----------|---|---|
| Initial     | 1         | 0 | 0 |
| 1           | 0         | 1 | 0 |
| 2           | 1         | 0 | 1 |
| 3           | 0         | 1 | 1 |
| $f_{clk}/2$ |           |   |   |
| $f_{clk}/4$ |           |   |   |

(Clock is Positive transition  
B changes its value)



### Ripple Counter

- These circuits are called ripple counters because each edge sensitive transition (positive in the example) causes a change in the next flip-flop's state.
- The changes "ripple" upward through the chain of flip-flops, i.e., each transition occurs after a clock-to-output delay from the stage before.

→ A different way of making a 4-bit "up" counter.



## Synchronous Counter

- To eliminate the "ripple" effects, use a common clock for each flip-flop and a combinational circuit to generate the next state.
- For an up-counter, use an incrementer.



Note: Synchronous counter design is same as that of sequential circuit design.

- Internal details: Incrementer



- Internal logic:

- XOR complements each bit.
- AND chain ~~causes~~ causes complement of a bit if all bits towards LSB is equal 1.

- Count Enable:
  - Forces all outputs of AND chain to 0 to "hold" the state.
- Carry Out:
  - Added as part of incrementer
  - Connect to Count Enable of additional 4-bit counters to form larger counters.

13-10-2023

### Mod N Counter

- A modulo N counter goes through a repeated sequence of N counts which required  $N \geq$  number of flip flops.
- The "Modulo" or "Modulus of a counter is the number of states the counter counts or sequences through before repeating itself.
- Eg. A 3-bit binary counter is a Mod 8.  
A BCD counter is a Mod 10 counter.
- MOD counters have a modulus value that is an integral power of 2.

$$2^n \geq N$$

for Mod 10 counter,

$$\text{min}^m \text{ no. of FF Required} = 4 \\ (2^4 = 16 \geq 10)$$

### Mod-5 counter:





### Arbitrary Count

→ Counter goes through an arbitrary sequence.

E.g.

| Present State |   |   | Next State     |                |                |
|---------------|---|---|----------------|----------------|----------------|
| A             | B | C | $D_A = A(t+1)$ | $D_B = B(t+1)$ | $D_C = C(t+1)$ |
| 0             | 0 | 0 | 0              | 0              | 1              |
| 0             | 0 | 1 | 0              | 1              | 0              |
| 0             | 1 | 0 | 1              | 0              | 0              |
| 1             | 0 | 0 | 1              | 0              | 1              |
| 1             | 0 | 1 | 1              | 1              | 0              |
| 1             | 1 | 0 | 0              | 0              | 0              |



### Circuit:

$$D_A = (A \oplus B)$$

$$D_B = C$$

$$D_C = (\bar{B} \cdot \bar{C})$$



### Design example: Synchronous BCD

- Use the sequential logic model to design a synchronous BCD counter with D flip-flops.
- State Table:

| Current State<br>Q <sub>3</sub> Q <sub>2</sub> Q <sub>1</sub> | Next state<br>Q <sub>3</sub> Q <sub>2</sub> Q <sub>1</sub> |
|---------------------------------------------------------------|------------------------------------------------------------|
| 0 0 0 0                                                       | 0 0 0 1                                                    |
| 0 0 0 1                                                       | 0 0 1 0                                                    |
| 0 0 1 0                                                       | 0 0 1 1                                                    |
| 0 0 1 1                                                       | 0 1 0 0                                                    |
| 0 1 0 0                                                       | 0 1 0 1                                                    |
| 0 1 0 1                                                       | 0 1 1 0                                                    |
| 0 1 1 0                                                       | 0 1 1 1                                                    |
| 0 1 1 1                                                       | 1 0 0 0                                                    |
| 1 0 0 0                                                       | 1 0 0 1                                                    |
| 1 0 0 1                                                       | 0 0 0 0                                                    |

- Input combinations 1010 through 1111 are don't cares.

- Use K-Maps to two-level optimize the next state equations and manipulate its form containing XOR gates:

$$D_1 = \overline{Q_1}$$

$$D_2 = Q_2 \oplus Q_1 \overline{Q_3}$$

$$D_4 = Q_4 \oplus Q_1 Q_2$$

$$D_8 = Q_8 \oplus (Q_1 Q_8 + Q_1 Q_2 Q_4)$$

- The logic diagram can be drawn from these equations.  
An asynchronous or synchronous reset should be added.
- What happens if the counter is perturbed by a power disturbance or other interference and it enters a state other than 000 through 1001?
- For the BCD counter design, if an invalid state is entered, return to a valid state occurs within two clock cycles.
- Is this adequate? If not:
  - Is a signal needed that indicates that an invalid state has been entered? What is the equation for such a signal?
  - Does the design need to be modified to return from an invalid state to a ~~specific~~ state ~~in one clock cycle~~? (such as 0)?
  - Does the design need to be modified to return from an invalid state to a valid state in one clock cycle?
- The action to be taken depends on:
  - the application of the circuit.
  - design group policy.

## Ring Counter

→ A standard shift register circuit into a ring counter by looping the output back to the input. (Initially Q/P is set 1)

Eg: 4-bit Ring Counter:



## Rotational Movement of Shift Register

→ It has 4 distinct states

→ Also known as "modulo-4" or "mod-4" counter with each flip-flop output having a frequency value equal to one-fourth or a quarter ( $\frac{1}{4}$ ) that of the main clock frequency.



## Johnson Ring Counter / Twisted Ring Counter

- In this, the inverted output  $\bar{Q}$  of the last flip-flop is now connected to the input D of the first flip-flop.
- Advantage: It only needs half the no. of flip-flops compared to the standard ring counter, then its modulo number is halved.
- A "n-stage" Johnson counter will circulate a single data bit giving sequence of  $2^n$  different states and can therefore be considered as a "mod- $2^n$  counter".

Eg:



| Clock Pulse No. | FFA | FFB | FFC | FFD |
|-----------------|-----|-----|-----|-----|
| 0               | 0   | 0   | 0   | 0   |
| 1               | 1   | 0   | 0   | 0   |
| 2               | 1   | 1   | 0   | 0   |
| 3               | 1   | 1   | 1   | 0   |
| 4               | 1   | 1   | 1   | 1   |
| 5               | 0   | 1   | 1   | 1   |
| 6               | 0   | 0   | 1   | 1   |
| 7               | 0   | 0   | 0   | 1   |

Application: To divide the frequency of the clock signal by varying their feedback connections — Mod-3, Mod-5 counters.

## → 2-bit Quadrature Generator:



- A to D are phase shifted by  $90^\circ$  with each other
- can be used to position control or the ability to rotate a motor to a particular location with some additional circuitry.

→ Duty cycle =  $\frac{t_{on} + t_{off}}{2}$ ,  $t_{on}$  &  $t_{off}$ : same for symmetric waveforms.

# TIME ANALYSIS IN SEQUENTIAL CIRCUITS

- The correct functioning of the sequential circuit involves several timing issues:
- Circuits don't respond instantaneously to input changes.  
Predictable delay in transferring inputs to outputs — propagation delay.
- Sequential circuits require certain amount of time the input need to be stable after the clock edge.
- Sequential circuits require a periodic clock whose period need to be obtained by satisfying the timing needs of the components in the sequential circuit.

## Sequential Circuits:

- Sequential circuits can contain both combinational logic and edge-triggered flip-flops.
- A clock signal determines when data is stored in flip-flops.
- Goal: How fast can the circuit operate?  
Minimum clock period :  $T_{\min}$   
Maximum clock frequency:  $f_{\max}$ .
- Maximum clock frequency is the inverse of the minimum clock period.

$$\frac{1}{T_{\min}} = f_{\max}$$



## Input Timing Constraints

- Setup time:  $t_{\text{setup}} = \text{time before}$  the clock edge that data must be ~~stat~~ stable (i.e., not changing).
- Hold time:  $t_{\text{hold}} = \text{time after}$  the clock edge that data must be stable.
- Aperture time:  $t_a = \text{time around clock edge}$  that data must be stable.

$$t_a = t_{\text{setup}} + t_{\text{hold}}$$



## Output Timing Constraints

- Propagation delay:  $t_{\text{pq}} = \text{max}^m \text{ time after clock edge by which output } Q \text{ is guaranteed to have stabilized}$  (i.e., not changing anymore).
  - Propagation delays for transition from Low to High and High to Low are different/same.  
 $t_{\text{ph}}$  is the propagation delay during output transition from high to low.
- Any sequential circuit has minimum and maximum propagation delay  
Min<sup>m</sup> propagation delay is called as contamination delay.



- Contamination delay:  $t_{\text{ccq}} = \text{min}^m \text{ time after clock edge during which } Q \text{ will not have started changing yet.}$

## Dynamic Discipline

- The input to a synchronous sequential circuit must be stable during the aperturable (setup and hold) time around the clock edge.
- Specifically, the input must be stable.
  - at least  $t_{\text{setup}}$  before the clock edge.
  - at least until  $t_{\text{hold}}$  after the clock edge.

## Maximum Clock Frequency

- The clock frequency for a synchronous sequential circuit is limited by the timing parameters of its flip-flops and gates.  
This limit is called the maximum clock frequency for the circuit.
- The minimum clock frequency is the reciprocal of this frequency.
- Relevant timing parameters:
  - Gates :
    - ↳ Propagation delays : min  $t_{PLH}$ , min  $t_{PHL}$ , max  $t_{PLH}$ , max  $t_{PHL}$ .
  - flip-flops:
    - Propagation delays : min  $t_{PHL}$ , min  $t_{PLH}$ , max  $t_{PLH}$ , max  $t_{PHL}$ .
    - Setup Time :  $t_{su}$ .
    - Hold Time :  $t_h$ .

## # 4-timing parameters:

- Setup time → time allocated to make the input stable before the application of clock.
- Hold time
- Aperture time
- propagation delay ( $t_{pd}$ ).

$$\text{Min}^m \text{ clock period} = \text{Setup time} + t_{pd}$$

Eg. Analyze this sequential circuit



$T_w$ : clock period

$t_{su}$ : setup time of the FF

$t_h$ : hold time of the FF

$t_{phL}, t_{phH}$ : propagation delays.

$$T_w \geq \max t_{PFF} + t_{su}$$

For the 7474,  $\max t_{PLH} = 25 \text{ ns}$ ,  $\max t_{PHL} = 40 \text{ ns}$ ,  $t_{su} = 20 \text{ ns}$ .

$$\therefore T_w \geq \max(\max t_{PLH} + t_{su}, \max t_{PHL} + t_{su})$$

$$\Rightarrow T_w \geq \max(25 + 20, 40 + 20) = 60.$$

Eg. Analyze the sequential circuit with the combination circuit.



$t_{PFF}$ : propagation delay of FF (crossover)

$t_{su}$ : setup time of FF

$t_{INV}$ : propagation delay of inverter

Min<sup>m</sup> clock period required,

$$(T_w)_{\min} = \max t_{PFF} + \max t_{INV} + t_{su}$$

$$\therefore T_w \geq \max t_{PFF} + \max t_{INV} + t_{su}$$

Eg. Obtain the min<sup>m</sup> clock period of the logic circuit or digital system.



$$T_w \geq \max t_{PFF} + \max t_{PMUX} + t_{SU}$$

Eg.



|              | $t_p$         | $t_{SU}$      |
|--------------|---------------|---------------|
| D Flip-flop  | $20\text{ns}$ | $5\text{ns}$  |
| JK Flip-flop | $25\text{ns}$ | $10\text{ns}$ |
| AND Gate     | $12\text{ns}$ |               |
| OR Gate      | $10\text{ns}$ |               |

Paths from  $Q_1$  to  $Q_1$ : None

Paths from  $Q_1$  to  $Q_2$ :  $T_w \geq \max t_{PDFF} + t_{JK8U} = 20 + 10 = 30\text{ns}$

~~$$T_w \geq \max t_{PDFF} + t_{AND} + t_{JK8U}$$~~

$$= 20 + 12 + 10 = 42\text{ns}$$

Paths from  $Q_2$  to  $Q_1$ :  $T_w \geq \max t_{PJKFF} + t_{OR} + t_{DSU}$

$$= 25 + 10 + 5 = 40\text{ns}$$

Paths from  $Q_2$  to  $Q_2$ :  $T_w \geq \max t_{PJKFF} + \max t_{AND} + t_{JK8U}$

$$= 25 + 12 + 10 = 47\text{ns}$$

$$\therefore T_w \geq 47\text{ns}$$

## Setup Time Constraint



$$T_c \geq t_{\text{tpcq}} + t_{\text{tpd}} + t_{\text{tsetup}}$$

$$t_{\text{tpd}} \leq T_c - (t_{\text{tpcq}} + t_{\text{tsetup}})$$

## Hold Time Constraint

- Depends on the minimum delay from register  $R_1$  through the combinational logic.
- The input to register  $R_2$  must be stable for atleast  $t_{\text{hold}}$  after the clock edge.



$$t_{\text{hold}} < t_{\text{coq}} + t_{\text{cd}}$$

$$t_{\text{cd}} > t_{\text{hold}} - t_{\text{coq}}$$

## Clock Skew

- If a clock edge does not arrive at different flip-flops at exactly the same time, then the clock is said to be skewed between these flip-flops.
- The difference between the times of arrival at the flip-flops is said to be the amount of clock skew.
- Spatial variation in temporally equivalent clock edges.
- Clock skew is due to different delays on different paths from the clock generator to the various flip-flops.
  - Different length wires (wires have delay).
  - Gates (buffers) on the paths.
  - flip-flops that clock on different edges (need to invert clock for some flip-flops).
  - Gating the clock to control loading of registers (a very bad idea).

Eg. Effect of clock skew on clock state.

→ Clock  $c_2$  skewed after  $c_1$ .



$$T_w \geq \max t_{PFF_1} + \max t_{OR} + t_{SU_{FF_2}}$$

(if clock not skewed, i.e.,  $t_{INV} = 0$ )

$$T_w \geq \max t_{PFF} + \max t_{OR} + t_{SU} -$$

$$\min t_{INV}$$

(if clock skewed, i.e.,  $t_{INV} > 0$ )

$$T_w + \min t_{INV} \geq \max t_{PFF} + \max t_{OR} + t_{SU}$$

→ clock  $C_2$  skewed after  $C_1$ .

→ There is a change in clock period when there is skew.



$$T_W \geq \max T_{PFF} + \max t_{OR} + t_{SU}$$

(if clock not skewed, i.e.,  $t_{INV} = 0$ )

$$T_W \geq \max T_{PFF} + \max t_{OR} + t_{SU}$$

$$+ \max t_{INV}$$

(if clock skewed, i.e.,  $t_{INV} > 0$ )

→ Summary of maximum clock frequency calculations.



$$C_2 \text{ skewed after } C_1: T_W \geq \max T_{PFF} + \max t_{NET} + t_{SU} - \min t_{INV}$$

$$C_2 \text{ skewed before } C_1: T_W \geq \max T_{PFF} + \max t_{NET} + t_{SU} + \max t_{INV}$$

→ Positive clock skew: If data path and clock path are in same forward direction. ↳ clock period gets reduced (due to inverter at  $C_2$ ).

→ Negative clock skew: If data path and clock path are in opposite dirn. ↳ clock period gets increased.

## Maximum Allowable Clock Skew

↳ The clock skew can be positive or negative depending upon the routing direction and position of the clock source.



Positive clock skew  $Q_1 = D_2$



$$T_w \geq \max T_{PFF} + t_{SU} + t_{SK}$$

$$T_w + t_{SK} \geq \max t_{PFF} + t_{SU}$$

$$t_{PFF} > t_h + t_{SK}$$

$$t_{SK} < \min t_{PFF} - t_h$$

$$t_h < t_{PFF} - t_{SK}$$

→ Improves performance (Clock Period Reduces), but makes the hold harder to meet.

If t hold is not met (race conditions), the circuit malfunctions independent of the clock period!

Case-2:  $C_1$  delayed from  $C_2$



Negative clock skew



→ Degrades performance (Clock Period increases) but hold is easier to meet (eliminating race conditions).

$$T_w \geq \max T_{PFF} + t_{SU} + t_{SK} \quad (\text{if clock skewed, i.e., } t_{INV} > 0)$$

$$T_w - t_{SK} \geq \max T_{PFF} + t_{SU}$$

$$t_h < t_{PFF} + t_{SK}$$

## Race Conditions

If input In is sampled on the rising edge of  $C_1$  at edge 1 into  $D_1$ . The new value at the output  $D_1$  ( $Q_1$ ) propagates through the combinational logic and should be valid before edge 4 at  $C_2$ . However, if the minimum delay of the combinational logic block is small, the inputs to  $D_2$  may change before the clock edge 2, resulting in incorrect evaluation.



### How to avoid races:

One must ensure that the minimum propagation delay through the register and logic is long enough that the inputs to  $D_2$  are valid for a ~~hold~~ hold time after edge  $D_2$ .

- To overcome skew problems, it is necessary to satisfy the hold-time constraints at ~~design~~ design-time.
- How does additional delay between the flip-flops affect the skew calculations?



$$t_{SK} \leq \min t_{PFF} - t_h$$

$$t_{SK} \leq \min t_{PFF} + \min t_{MUX} - t_h$$

## HOLD Time Constraint for Clock skew



In the worst case, CLK2 is later than CLK1



$$t_{ccq} + t_{cd} > t_{hold} + t_{skew}$$

$$t_{cd} > t_{hold} + t_{skew} - t_{ccq}$$

## Summary of allowable clock skew calculations



$$t_{sk} + t_h \leq t_{PFF} + t_{NET}$$

$$t_{sk} \leq \min t_{PFF} + \min t_{NET} - t_h$$

## Summary:

- Maximum clock frequency is a fundamental parameter in sequential computer systems.
- Possible to determine clock frequency from propagation delays and setup time.
- The longest path determines the clock frequency.
- All flip-flop to flip-flop paths must be checked.

# VERY LARGE SCALE INTEGRATION (VLSI)

## CMOS (Complementary Metal Oxide Semiconductor)

Logic family:

- CMOS → All digital designs are made using CMOS. → Uses MOSFET
- BJT → TTL (Transistor-Transistor logic)
- Hybrid CMOS + BJT

Schottky  
MS (Metal semiconductor)



→ Zener diode

# In BJT, Reverse saturation current ↑  
for every  $10^{\circ}\text{C}$  rise in temperature.

→ OFF to ON → due to forward current  
ON to OFF

CMOS

→ memory

→ Easy to manufacture (sophisticated fabs)

→ CMOS advantages:

27-10-2023

→ Density ↑ (No. of transistors per unit area)

→ Miniaturization is possible

→ Low power consumption

→ Sophisticated fabs



MOSFET

→ NMOS → n-type material used in Drain & Source

→ conduction due to majority charge carrier only.

→ Gate is made of metal.

→ separated from D & S by a dielectric ( $\text{SiO}_2$ ).

# n-type material: Taking a ~~less~~ lightly-doped ( $p^{+}n$ ) semiconductor (doping) and implanting ions to make n- (or p-) type material in a controlled manner.

# Diffusion: Implanting free-electrons to semiconductor to make n- or p-type material.

CMOS:



$$\rightarrow V_{GS} < 0$$



$$V_{GS} = +ve$$



Threshold voltage: Minimum voltage required ( $V_T$ ) to form the channel (negative voltage).



- $V_{GS} = +ve$  is applied.

$V_{GS} < V_T$  : No channel is formed (cutoff region)

$V_{GS} = V_T$  : Channel starts to form.

$V_{GS} \geq V_T$  : Channel is formed.  
L  $\rightarrow$  ON

- $V_{GD}$  is applied.

↳ channel gets ~~amplified~~ pinched off.



CMOS operation:

- ①  $V_{GS} \geq V_T$
- ②  $V_{DS} \geq V_{GS} - V_T$

$$\rightarrow I_{DS} = \frac{1}{2} \underbrace{(V_{GS} - V_T)^2}_{\text{Overdrive voltage}}$$



→ When input voltage,  $V_{GS} < V_T$ , then also there is some current (due to minority charge carrier) called as subthreshold leakage.

↳ Not a good thing in digital electronics.

→ Channel length: Separation b/w drain and source.

↳ plays important role in conduction of current.

- channel length  $> 1 \mu m$  : long channel

↳ When channel is too small, there may be conduction through the gate.

→ Channel length defines technology node.

N MOS: Threshold voltage:  $V_T$



S: Ground

D: HIGH

Body (B)/Substrate: Source

PMOS:

Threshold voltage:  $|V_T|$



$R_D \rightarrow$  very low

Pull Down:  $\xrightarrow{\text{(N MOS)}} \text{Active}$

Pull Up: Circuit responsible for driving output go to zero.



Dynamic power: Power consumption during switching:



Static power: Power consumption during steady state.

→ To reduce static power dissipation:

Replace resistive Pull Up circuit (Passive) to Active circuit which is complement of the Pull Down circuit.

[Complement of NMOS: PMos]



# sink current: Current into the device.

source current: Current out from the device.

CMOS

Realisation:

NAND  
NOR

$$\text{NAND: } Y = \overline{AB}$$

$$\overline{Y} = AB$$

NMOS

series connection

[NMOS + PMOS]



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



Realisation ~~using~~ <sup>ab</sup> NAND Gate:

$$\begin{array}{c} A \\ \underline{\quad} \\ 0 \end{array} \quad \begin{array}{c} B \\ \underline{\quad} \\ 0 \end{array} \quad \begin{array}{c} Y \\ \underline{\quad} \\ 1 \end{array}$$

PMOS: OFF  
NMOS: OFF

$$\begin{array}{c} A \\ \underline{\quad} \\ 0 \end{array} \quad \begin{array}{c} B \\ \underline{\quad} \\ 1 \end{array} \quad \begin{array}{c} Y \\ \underline{\quad} \\ 1 \end{array}$$

$$\begin{array}{c} A \\ \underline{\quad} \\ 1 \end{array} \quad \begin{array}{c} B \\ \underline{\quad} \\ 0 \end{array} \quad \begin{array}{c} Y \\ \underline{\quad} \\ 1 \end{array}$$

$$\begin{array}{c} A \\ \underline{\quad} \\ 1 \end{array} \quad \begin{array}{c} B \\ \underline{\quad} \\ 1 \end{array} \quad \begin{array}{c} Y \\ \underline{\quad} \\ 0 \end{array}$$

$$T = \frac{\tau_{dp}}{2} Q$$

$$T = 2\tau_{dn} Q$$

$$T = \tau_{dp} C_L$$

$$T = \tau_{dp} C_L$$

| A | B | MAP | MBP | MAN | MBN | Y |
|---|---|-----|-----|-----|-----|---|
| 0 | 0 | ON  | ON  | OFF | OFF | 1 |
| 0 | 1 | ON  | OFF | OFF | ON  | 1 |
| 1 | 0 | OFF | ON  | ON  | OFF | 1 |
| 1 | 1 | OFF | OFF | ON  | ON  | 0 |

Eg Draw the CMOS logic circuit for NOR.

NOR:

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

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



PMOS  
+  
NMOS } CMOS

Two Types:

Seried : AB → AND

Parallel: A+B → OR

1-11-2023

Eg Implement  $Y = \overline{(A+B+C)D}$  using CMOS logic.

Sofn:

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

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

X  
NMOS ((NMOS || D) sum D).





Eg Implement  $Y = A + B$ .

$$Y = A + B$$

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

CMOS

- ↳ implements NAND, NOR
- ↳ To realise AND, OR  
we require extra inverter

[Speed  $\uparrow \Rightarrow$  Power  $\uparrow$ ]



↳ Requires extra inverter



OR



Q) Realise 2x4 decoder using NAND.

Soln:



## Transfer Characteristics



## CMOS FABRICATION

# **Moores Law:** Every 24 months, no. of transistors available in a chip gets doubled.

↳ Not applicable after 7nm technology.

→ **Technology node:** The length b/w drain and source (channel length)

NMOS:



- CMOS transistors are fabricated on silicon wafer.
- Lithography process similar to printing press.
- On each step, different materials are deposited or etched.
- Easiest to understand by viewing both top and cross-section of wafer in a simplified manufacturing process.
- chips are built in huge factories called fabs.
  - ↳ contain clean rooms as large as football fields, costing billions of dollars.

# n-well: n-substrate required to house the PMOS.

## Fabrication Steps

- Start with blank wafer.
- Build inverter from the bottom up.
- ~~first~~ first step will be to form the n-well.
  - ↪ Cover wafer with protective layer of  $\text{SiO}_2$  (oxide).
  - ↪ Remove layer where n-well should be built.
  - ↪ Implant or diffuse n dopants into exposed wafer.
  - ↪ Strip off  $\text{SiO}_2$ .

### Oxidation:

- ↪ Grow  $\text{SiO}_2$  on top of Si wafer.
- ↪  $900^\circ\text{--}1200^\circ\text{C}$  with  $\text{H}_2\text{O}$  or  $\text{O}_2$  in oxidation furnace.

### Photoresist:

- ↪ Spin on photoresist.
- ↪ Photoresist is a light-sensitive organic polymer.
- ↪ Softens where exposed to light.



### Lithography:

- ↪ Expose photoresist through n-well mask.
- ↪ Strip off exposed photoresist.



### Etch:

- ↪ Etch oxide with hydrofluoric acid
  - ↪ seeps through skin and eats bone; nasty stuff!!!
- ↪ Only attacks oxide where resist has been exposed.



### Strip Photoresist:

- ↪ Strip off remaining photoresist.
  - ↪ Use mixture of acids called piranah etch.
- ↪ Necessary so resist doesn't melt in next step.



### n-well:

- ↳ n-well is formed with diffusion or ion implantation.
- ↳ Diffusion:
  - ↳ Place wafer in furnace with arsenic gas.
  - ↳ Heat until As atoms diffuse into exposed Si.
- ↳ Ion Implantation:
  - ↳ Blast wafer with beam of As ions.
  - ↳ Ions blocked by  $\text{SiO}_2$ , only enter exposed Si.



### Strip Oxide:

- ↳ Strip off the remaining oxide using HF.
- ↳ Back to bare wafer with n-well.
- ↳ Subsequent steps involve similar series of steps.



### Polysilicon:

- ↳ Deposit very thin layer of gate oxide ( $< 20\text{\AA}$ ; 6-7 atomic layers).
- ↳ Chemical vapour deposition (CVD) of silicon layer.
  - ↳ Place wafer in furnace with Silane gas ( $\text{SiH}_4$ ).
  - ↳ Forms many small crystals called polysilicon.
  - ↳ Heavily doped to be good conductor.



## PolySilicon Patterning:

- ↪ Use same lithography process to pattern polysilicon.



## Self-Aligned Process:

- ↪ Use oxide and masking to expose where  $n^+$  dopants should be diffused or implanted.
- ↪ N-diffusion forms nMOS source, drain, and n-well contact.



## N-diffusion:

- ↪ Pattern oxide and form  $n^+$  regions.
- ↪ Self-aligned process where gate blocks diffusion.
- ↪ Polysilicon is better than metal for self-aligned gates because it doesn't melt during later processing.



- ↪ Historically, dopants were diffused.
- ↪ Usually ion implantation today.
- ↪ But regions are still called diffusion.



→ Strip off oxide to complete patterning oxide.



### P-diffusion:

→ Similar set of steps form p+ diffusion regions for PMOS source and drain and substrate contact.



### Contacts:

→ Now, we need to wire together the devices.

→ Cover chip with thick field oxide.

→ Etch oxide where contacts cuts are needed.



### Metalization

→ Sputter on aluminium over whole wafer.

→ Pattern to remove excess metal, leaving wires.



### Inverter Cross-section:

→ Typically use p-type substrate for nMOS transistors.

→ Requires n-well for body of PMOS transistors.

→ So, pMOS p-type source/drain doesn't short to p-type substrate.



## Well and Substrate Taps:

- Substrate must be tied to GND and n-well to V<sub>DD</sub>.
- Metal to lightly-doped semiconductor forms p-n junction called Shottky Diode.
- Use heavily doped well and substrate contacts/taps.



## Inverter Mask Set:

- Transistors and wires are defined by masks.
- Cross section taken along dashed line.



## General CMOS Process Step:

- Define active areas  
Etch and fill trenches → Implant well → Deposit and pattern regions  
Create contact and via windows  
Deposit and pattern metal layers.      Implant source and drain regions and substrate contacts

## Inverter Layout:

- Transistor dimensions specified as width/length.
- Minimum size is  $4\lambda/\lambda$ , sometimes called 1 unit.
- In  $f=0.6\mu\text{m}$  process, this is  $1.2\mu\text{m}$  wide,  $0.6\mu\text{m}$  long,  $\lambda=f/2$ ;  $f$  is called feature dimension.



# VLSI CIRCUITS & LAYOUT

## Detailed Mask Views

Six Masks:

- n-well
- Polysilicon
- n<sup>+</sup> diffusion
- p<sup>+</sup> diffusion
- Contact
- Metal



## How to build CMOS circuits?

- CMOS Inverter
- Pull Up Network responsible for true output.
- Pull down network responsible for complementary output.



## Layout



- Chips are specified with set of masks
- Minimum dimensions of masks determine transistor size (and hence speed, cost and power).
- Feature size,  $f$  = distance between source and drain.
  - ↳ Set by minimum width of polysilicon.
  - ↳ Improved 30% every year or so

→ Normalize for feature size when describing design.

→ Express rules in terms of  $\lambda = f/2$ .

Eg.  $\lambda = 0.3\text{ m}$  in  $0.6\text{ m}$  process.

### Gate Layout

→ Layout can be very time consuming.

↳ Design gates to fit together nicely.

↳ Build a library of standard cells.

→ Standard cell design methodology

↳ VDD and GND should abut (standard height).

↳ Adjacent gates should satisfy design rules.

↳ nMOS at bottom and pMOS at top.

↳ All gates include well and substrate contacts.

### Design Rules

Two major approaches:

① Micron rules: stated as micron resolution

↳ Used for commercial purposes

↳ not scalable.

② Lambda rules: simplified micron rules with limited scaling attributes.

↳ not used in commercial applications

↳ Scalable (one technology to another).

↳ very conservative and thus waste space.

→ Design rules represents a tolerance which includes:

- very high probability of correct fabrication

- scalable design rules: lambda parameter.

- absolute dimensions (micron rules).

### CMOS ' $\lambda$ ' Design Rules

→ MOSIS: MO's Implementation Service

↳ IC fabrication service available to universities for layout, simulation, and test the completed design.

↳ MOSIS rules are scalable  $\lambda$  rules.

# MOSIS website:

[themosisservice.com](http://themosisservice.com)

## CMOS-Design Rules

↳ Based on following components:

- ① Substrates or wells: p-type for NMOS devices  
n-type for PMOS devices.
  - ② Diffusion regions: At these regions, the transistors are formed.
    - ↳ called as active layer.
    - ↳ Defined by n<sup>+</sup> for NMOS and p<sup>+</sup> for PMOS transistors.
  - ③ Polysilicon layer: Used to form the gate electrodes of the transistors.
  - ④ Metal interconnects layers: Used to form the power supply and ground rails as well as input and output rails.
  - ⑤ Connect contact and via layers: Used to form the inter-layer connections.

### Simplified Design Rules:

### Conservative rules:



NMOS/PMOS Layout based on 7-rules:



# Layout of Inverter



## Layout of NMOS:





Layout:



Connecting Poly and Diffusion  
→ can't connect poly to diffusion directly!

Layout Example:

Draw the equivalent transistor schematic.



## Transistor width and length:



Wiring Track: Space required for a wire  
 ↳ 4λ width, 4λ spacing from neighbour  
 = 8λ pitch  
 ↳ Transistors also consume one  
 wiring track  
 → Distance b/w 2 Transistors: 12λ

Well Spacing: Wells must be separated by 6λ

↳ Implies 12λ b/w opposite  
transistor flavours  
 ↳ Leaves room for one wire  
track.



Eg. Inverter



→ Body is connected to VDD, using well-tap  
(cannot be connected directly)

Eg. 2-input NAND Gate

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



## Stick diagrams

→ Help plan layout quickly.

→ Need not be to scale.

→ Draw with colour pencils or dry-erase markers.

Eg. 2-input NAND



- metal
- p diffusion
- n diffusion
- poly
- × contact

Eg. Inverter



Eg. 3-input NAND Gate

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



stick diagram:



[10-11-2023]

## Area Estimation

- Estimate area by counting wiring tracks.
- Multiply by 8 to express in  $\lambda$ .

Eg.  $Y = \overline{(A+B+C)D}$



# CMOS TRANSISTOR THEORY

## Terminal Voltages

→ Mode of operation depends on  $V_g, V_d, V_s$ .

$$V_{gs} = V_g - V_s$$

$$V_{gd} = V_g - V_d$$

$$V_{ds} = V_d - V_s = V_{gs} - V_{gd}$$



→ Source and drain are symmetric diffusion terminals.

↳ By convention, source is terminal at lower voltage.  
Hence,  $V_{ds} \geq 0$ .

→ nMOS body is grounded.

→ Three regions of operation:

- Cutoff
- Linear
- Saturation.

## nMOS Cutoff:

- $V_{gs} < V_t$
- No inversion, no channel
- $I_{ds} \approx 0$



## nMOS Linear:

- $V_{gs} > V_t$
- $V_{ds}$ : small
- Channel forms.
- Current flows from d to s. ( $\rightarrow$  from s to d)
- $I_{ds} \uparrow$  with  $V_{ds}$ .
- Similar to linear transistor.

## nMOS Saturation:

- $V_{gs} > V_t$
- $V_{ds} > V_{gs} - V_t$
- Channel pinches off.
- $I_{ds}$  is independent of  $V_{ds}$ .
- Current saturates.
- Similar to current source.

## Channel Charge

→ MOS structure looks like parallel plate capacitor while operating in inversions.

$$Q_{\text{channel}} = CV$$

$= C_g(V_{gc} - V_t)$ ;  $V_{gc} - V_t$ : amount of charge voltage attracting charge to the channel beyond the min. required to invert from p to n.

where

$$C = C_g = \frac{\epsilon_{ox} WL}{t_{ox}} = C_{ox} WL,$$

$$C_{ox} = \frac{\epsilon_{ox}}{t_{ox}}$$



$$V_{gc} = \frac{(V_{gs} + V_{gd})}{2} = V_{gs} - \frac{V_{ds}}{2} \quad [V_{ds} = V_d - V_s = V_{gs} - V_{gd}]$$

$$\Rightarrow V_{gc} - V_t = (V_{gs} - V_{ds}/2) - V_t \quad [V_{gd} = V_{gs} - V_{ds}]$$

→ Electrons are propelled by the lateral electric field b/w source and drain.

$$E = \frac{V_{ds}}{L}$$

→ Carrier velocity,  $v$ , proportional to lateral E field,  
 $v = \mu E$ ,  $\mu$ : mobility

Time for carrier to cross channel,

$$t = \frac{L}{v} = \frac{L}{\mu E}$$

$$= \frac{L^2}{\mu V_{ds}}$$

$$\therefore Q_{\text{channel}} = C_g \left[ (V_{gs} - V_{ds}/2) - V_t \right]$$

$$= C_{ox} \frac{WL}{t_{ox}} \left[ (V_{gs} - V_{ds}/2) - V_t \right]$$

$$\therefore I_{ds} = C_{ox} WL \left[ (V_{gs} - V_{ds}/2) - V_t \right] \frac{\mu V_{ds}}{L^2 t_{ox}} \quad [\because I_{ds} = \frac{Q_{\text{channel}}}{t}]$$

$$\Rightarrow I_{ds} = \mu C_{ox} \left( \frac{W}{L} \right) \left( V_{gs} - V_t - V_{ds}/2 \right) V_{ds}$$

$$= \beta \left( V_{gs} - V_t - V_{ds}/2 \right) V_{ds}, \text{ where } \beta = \mu C_{ox} \left( \frac{W}{L} \right)$$

↳ Process transconductance

If  $V_{dd} < V_t$ , channel pinched off near drain.

When  $V_{ds} > V_{dsat} = V_{gs} - V_t$ .

Now, drain voltage no longer increases current.

$$\therefore I_{ds} = \beta (V_{gs} - V_t - V_{dsat}/2) V_{dsat}$$

$$= \frac{\beta}{2} (V_{gs} - V_t)^2$$

→ Set Shockley 1st order transistor model:

$$I_{ds} = \begin{cases} 0 & , V_{gs} < V_t : \text{Cutoff} \\ \beta(V_{gs} - V_t - V_{ds}/2) V_{ds}, & V_{ds} < V_{dsat} : \text{Linear} \\ \frac{\beta}{2} (V_{gs} - V_t)^2 & , V_{ds} > V_{dsat} : \text{Saturation} \end{cases}$$

Transconductance:

$$\beta = \mu_n C_{ox} \frac{W}{L} : \text{Device transconductance } (\beta \propto \frac{W}{L})$$

$$C_{ox} = \frac{\epsilon_{ox}}{t_{ox}} : \text{Capacitance per unit area}$$

$$k_m = \mu_n \frac{\epsilon_{ox}}{t_{ox}} : \text{Process transconductance}$$

14-11-2023

Variable Resistance offered by MOSFET:



Application: Variable resistor

↓  
by changing  
transconductance

$$R_d = \frac{V_{ds}}{I_{ds}}$$

In linear region,

$$I_{ds} = \beta (V_{gs} - V_t) V_{ds}$$

$$R_d = \frac{1}{\beta (V_{gs} - V_t)} = \frac{1}{\mu C_{ox} \frac{W}{L} (V_{gs} - V_t)} = \frac{L}{\mu C_{ox} W (V_{gs} - V_t)}$$

$$\Rightarrow L(\text{technology}) \uparrow \Rightarrow R_d \uparrow \text{ & } C \uparrow$$

$$R_{D, \text{sat.}} = \frac{2 V_{DS}}{\beta (V_{GS} - V_T)^2}$$

### PMOS I-V

- All dopings and voltages are inverted for PMOS.
  - ↳ Source is more positive terminal.
- Mobility is determined by holes.
  - ↳ typically 2–3x lower than that of electrons  $\mu_n$ .
- Thus, PMOS must be wider to provide same current.  
In this class, assume  $\mu_n/\mu_p = 2$ .

### Capacitance

- Any two conductors separated by an insulator have capacitance.
- Gate to channel capacitor creates channel charge necessary for operation.
- Source and drain have capacitance to body.
  - ↳ Across reverse-biased diodes.
  - ↳ called diffusion capacitance b/c it is associated with source/drain diffusion

#### Gate capacitance:

- ↳ Depends on the region of operation.
- ↳ 3 capacitances:  $C_{GS}$ ,  $C_{GD}$ ,  $C_{GB}$ .



↳ Lateral diffusion (due to fabrication)  
↳ diffusion of D & D into G/Body.

Overlap capacitance:  $C_{OVL} = C_{GSO} + C_{GSD}$

→ Diode effect  $\Rightarrow$  Reverse bias leakage  $\Rightarrow$  Transistor model  
 (Transistor: npn)  $\rightarrow I \propto e^{-\frac{V_B}{nV_T}}$   $\rightarrow$  Junction / Reverse Bias Capacitance  
 ↳ Depends on reverse saturation current.



$C_{GS}, C_{GD}, C_{GB}$ : Contribute for G<sub>I</sub>-capacitance (input)

$C_{SD}$ : not dominant

$C_{GD}, C_{DB}$ : contribute for D-capacitance (input)

(RC Model of CMOS)

### RC Equivalent circuit of CMOS Inverter:



PMOS: S & B are connected to  $V_{DD}$ .

NMOS: S & B are connected to GND.

$$R = \frac{L}{M \text{Cox} W (V_g - V_t)} ; C_g = \frac{\epsilon WL}{t_{ox}} \quad (\because C = \epsilon A / d)$$

$$T = R C_g = \frac{\epsilon L^2}{M \text{Cox}^2 (V_g - V_t)} \propto L^2 W^0$$

$$C_L = C_{GDP} + C_{DBP} + C_{GDN} + C_{DBN} \quad | \text{(Time constant)} \quad \hookrightarrow T \text{ or propagation delay depends on } L \text{ only (not on } W)$$



$$R \propto \frac{L}{W}$$

$$C \propto WL$$



Scaling: If  $W$  changes to  $W_K$ ,

$$R \propto \frac{L}{W_K}, \quad C \propto WKL$$

( $K$ : scaling parameter)

→ Resistance (NMOS) < Resistance (PMOS).

$$\mu_N = 2 \mu_P \text{ (mobility)}$$

$$\left(\frac{W}{L}\right)_P = \frac{2}{1}; \quad \left(\frac{W}{L}\right)_N = \frac{1}{2} \quad [\text{Mobility of } e^- \text{ is twice the mobility of holes.}]$$



→ For having same current  $I_D$ , resistance should increase in n-MOS.

→ If width of NMOS is 1,  
then width of PMOS: 2.

Resistance of PMOS :  $R$

Resistance of NMOS :  $2R$ .

Eg.



→ Transistors can be used as switches.



In case of NMOS,

if we give  $V_{DD}$  to d and zero (GND) to g, then output will be zero (as MOSFET is not conducting).

So, it is strong zero.

If we give  $V_{DD}$  to g ( $g=1$ ), then ideally o/p (or s) should be 1 (i.e.,  $V_{DD}$ ).

But if  $V_s = V_{DD}$ , then  $V_s - V_g = 0 \rightarrow$  makes MOSFET non-conducting.  
So, for conducting,  $V_{sg} \geq V_t$ .

$$\therefore V_{max,s} = V_{DD} - V_t < V_{DD} \Rightarrow \text{Weak 1.}$$

So, NMOS is Strong 0 and Weak 1.

PMOS



In case of PMOS,

if we give  $V_{DD}$  to drain and  $V_{DD}$  to g ( $g=1$ ), then since  $V_g = V_{DD}$ , i.e.,  $V_{gs} = 0$ , it is not conducting.



PMOS: strong 1, weak 0

NMOS: strong 0, weak 1

Pass Transistor

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

} AND

For 2 i/p AND, in CMOS implementation,

$$\text{no. of transistors} = 6 \quad (\text{or } > 6)$$

if made separately.



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

: XNOR

Eg. 4x1 Multiplexer



: Pass Transistor logic style

## Eg. 2 i/p OR Gate

$$Y = A + B$$

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



Transmission Gate → To overcome the disadvantages of pass transistor.



Symbols of T.G. :

$2 \times 1$  MUX



Book: Neil Weste  
↳ Chapter - 1

→ To reduce area, we use pass transistor.

## Latch



CLK=1 : Pass the input  
 CLK=0 : Hold the output.

↓ Introduce a switch (as we are not able to change the o/p by giving i/p)



↓ Implement gates using CMOS (inverter)



→ Minimum ( $6+6$ ) = 12 transistors (CMOS) are required to design the edge triggered device.

→ 1 MB SRAM →  $2^{20} \times 6$  transistors.