

Logic Gates

## 1) NOT (inverter)

- one I/P, one O/P.
- Complement
- $Y = \overline{A}$ ,  $Y = A'$



Truth Table

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

(7404)

Timing diagram

## 2) OR

$$\bullet Y = A + B$$

Truth table.

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

Timing diagram

## Universal logic gate

- Logic gate which can infer any other logic gates among basic logic gates

### 3) NOR

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

#### Truth Table

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



#### Timing Diagram



### 4) AND.

$$Y = A \cdot B$$

#### Truth Table



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

5) NAND

$$\cdot Y = \overline{AB}$$



Truth Table

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

Timing Diagram



Universality of NAND and NOR

NOR

NAND

① NOT gate



② OR gate



XOR :



Date \_\_\_\_\_  
Page \_\_\_\_\_

XNOR :



NAND,

NOR

② OR gate



③ AND gate



## BOOLEAN LAWS & THEOREMS

① Identity Law

$$A \cdot 1 = A$$

$$A \cdot 0 = 0$$

$$A + 0 = A$$

$$A + 1 = 1$$

② Idempotent Law.

$$A + A = A$$

$$A \cdot A = A$$

③ Complement Law

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

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

## (4) Involution Law.

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

## (5) Associative Law

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

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

## (6) Commutative Law

$$A+B = B+A$$

$$A \cdot B = B \cdot A$$

## (7) Distributive Law

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

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

$$A + AB = A$$

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

## (8) De Morgan's Law

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

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

# NAND Realisation

CLASSMATE  
Date \_\_\_\_\_  
Page \_\_\_\_\_

~~→ NAND as NOR~~

1) NAND as NOT



2) NAND as AND



3) NAND as OR



4) NAND as NOR



## 5) NAND as XOR

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



$$Y = \left( \overline{A \cdot \overline{A \cdot B}} \cdot \overline{B \cdot \overline{A \cdot B}} \right)$$

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

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

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

$$Y = A \oplus B$$

## 6) NAND as XNOR



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

## Duality Theorem

Starting from a boolean relation, we can derive another boolean relation by

- 1) changing each OR to AND
- 2) changing each AND to OR
- 3) complementing any 0 or 1 in the expression

eg:

$$\begin{aligned} A + 0 &= A \\ A \cdot 1 &= A \end{aligned}$$

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

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

## Consensus Theorem

Finds a redundant term which is a consensus of two other terms.

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

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

In the first expression, BC is the consensus term

∴ if  $BC = 0$ ,  $B = 1$  &  $C = 1$   
 $\therefore$  any of the two terms AB and  $\bar{A}C$  will become 1 for  $A=0$  or 1.

# Conversion of Boolean Expression to NAND circuit

## Method 1

Step 1: Draw using basic gates

Step 2: Replace each gate by its  
NAND equivalent

Step 3: Eliminate double inversions

## Method 2

Step 1: Draw using basic gates

Step 2: Draw bubbles at o/p of  
each AND gate and add a  
not.

Draw not gates before OR gate  
I/Ps and add bubbles before O/P.

Step 3: Eliminate double inversions.

## Canonical Form / Standard Form

- Product of sum or sum of products
- We have only SOP (minterms)
- A boolean variable can be expressed in either true form or complemented form.
- In standard form, the boolean function will contain all variables in either true form or complemented form

## ADDERS

### i) Half-Adder

- Circuit that adds 2 single bit numbers A and B.
- Maximum sum =  $2_{10} = (10)_2$   
2 in decimal 10 in binary
- Output denoted by 2 bits: carry and sum.
- LSB of O/P : sum  
MSB of O/P : carry

Truth Table

in decimal.

| A | B | C | S | sum = |
|---|---|---|---|-------|
| 0 | 0 | 0 | 0 | 0     |
| 0 | 1 | 0 | 1 | 1     |
| 1 | 0 | 0 | 1 | 1     |
| 1 | 1 | 1 | 0 | 2     |

$$C = A \cdot B$$

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

O/P value for sum resembles XOR gate and for carry resembles AND gate.

CircuitCircuit using NAND gates

We can use the HA symbol to show the level of abstraction



## 2) Full Adder

- Adds 3 bits, where 3<sup>rd</sup> digit is it carry bit from the previous stage.

eg:

|   |   |   |         |   |   |          |   |   |   |   |             |  |
|---|---|---|---------|---|---|----------|---|---|---|---|-------------|--|
| 1 | 0 | 1 | + 1     | 1 | 0 | 0        | ↓ | ↓ | ↓ | ↓ | ← carry out |  |
|   |   |   | <hr/>   |   |   |          |   |   |   |   |             |  |
|   |   |   | 1 6 0   |   |   |          |   |   |   |   |             |  |
|   |   |   | ↑ ↑ ↑ ↑ |   |   |          |   |   |   |   |             |  |
|   |   |   |         |   |   | sum o/p. |   |   |   |   |             |  |

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

Using Sum of Products

$$\begin{aligned}
 \text{Sum} &= \overline{A}\overline{B}C + \overline{A}\overline{B}\overline{C} + A\overline{B}\overline{C} + ABC \\
 &= \overline{A}(\overline{B}C + \overline{B}\overline{C}) + A(\overline{B}\overline{C} + B\overline{C}) \\
 &= \overline{A}(B \oplus C) + A(B \oplus \overline{C})
 \end{aligned}$$

Sum =  $A \oplus B \oplus C$ .  $\longrightarrow (1)$

$$\begin{aligned}
 \text{Carry} &= \overline{A}BC + A\overline{B}C + A\overline{B}\overline{C} + ABC \\
 &= (\overline{A}B + AB)C + AB
 \end{aligned}$$

Carry =  $(A \oplus B)C + AB$   $\longrightarrow (2)$ .

## Circuit Diagram



## Circuit Diagram using NAND

1) Using HA blocks.



2) Replace with NAND and remove double inversions



# Multiplexer

- Many - to - one (MUX)
- circuit with many I/Ps but one O/P.
- control signals used to connect O/P from one I/P to another
- control signals  $\rightarrow$  select lines
- Each combo of select lines selects one I/P line to display
- $n$  I/P signals,  $m$  control lines and 1 O/P
- $m$  select lines can select at most  $2^m$  I/P signals
- $n \leq 2^m$

## General Circuit



## 2:1 MUX



## Truth Table

| A | Y     |
|---|-------|
| 0 | $D_0$ |
| 1 | $D_1$ |

$$Y = \bar{A} D_0 + A D_1$$

$$Y = \bar{A} D_0 + A D_1$$

CircuitDe-Multiplexer

- Combinational circuit with 1 I/P and many O/Ps (DEMUX)
- Select lines connect I/P to one O/P
- 1 I/P,  $n$  O/P,  $m$  select lines  
 $2^m \geq n$

1:2 DEMUXTruth Table

| A | $Y_0$ | $Y_1$ |
|---|-------|-------|
| 0 | D     | 0     |
| 1 | 0     | D     |

$$Y_0 = \bar{A}D$$

$$Y_1 = AD$$

## Circuit



## (Combinational) Circuits

- Combines I/P and generates O/P
- Depends only on present value of I/P
- No memory/storage present to store previous outputs

## Block Diagram



## Sequential Circuits

- System which has sequencing / pattern in O/P
- O/P depends on present I/P and past O/P.
- Eg: counter, elevator, traffic light controller.
- Storage/memory element required to store past O/P.

## Block Diagram



There are 2 types of sequential circuits

### 1) Asynchronous

- circuit o/p can change at any time
- no clock
- Eg: Latch

### 2) Synchronous

- circuit o/p changes only at discrete instants of time
- Achieves synchronisation by using timing signal (clock)
- Eg: flip flop

- Latches and flip flops are sequential circuit elements which, with the help of Boolean logic, can create memory.
- Storage elements that store binary information (0 or 1)

## LATCH

- Simplest form of memory element
- 2 stable states: 0 and 1
- O/P is set to a stable state until something is done to change it.
- Simplest 2 inverters in series with a feedback.



To store a '1'



To store a '0'



- To store a 1,  $V_1$  is first connected to  $V_{CC} = +5V$  and then the feedback line from  $V_3$  is reconnected to  $V_1$  and  $V_1$  is disconnected from  $V_{CC}$ . This keeps  $V_3$  stable at 1.
- To store a 0,  $V_1$  is first connected to ground and then the feedback line from o/p is reconnected to  $V_1$  and the ground connection is removed from  $V_1$ . This keeps  $V_3$  stable at 0.

## More effective circuit for latch

- Replacing inverters with NAND gates or NOR gates
- We have only NAND gates.
- The extra inputs to these gates can be used to switch latch from one stable state to another.
- Not latch only one type



or



### USING NAND



Truth Table

Case 1 if  $R=0, S=1, Q=1, \bar{Q}=0$

Case 2 if  $R=0, S=0, Q=1, \bar{Q}=0$ ] memory

Case 3 if  $R=1, S=0, Q=0, \bar{Q}=1$

Case 4 if  $R=0, S=0, Q=0, \bar{Q}=1$ ] memory

Case 5 if  $S=1, R=0, Q=0, \bar{Q}=1$

if  $S=0, R=0$ , either  $Q=0, \bar{Q}=1$

$Q=1, \bar{Q}=0$

depending on  
whichever gate is  
faster.

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

Truth Table

| $Q_t$ | $S$ | $R$ | $Q_{t+1}$ | $\bar{Q}_{t+1}$ | Comments  |
|-------|-----|-----|-----------|-----------------|-----------|
| 0     | 0   | 0   | 0         | 1               | no change |
| 0     | 0   | 1   | 0         | 1               | reset     |
| 0     | 1   | 0   | 1         | 0               | set       |
| 0     | 1   | 1   | 1         | 1               | *         |
| 1     | 0   | 0   | 1         | 0               | no change |
| 1     | 0   | 1   | 0         | 1               | reset     |
| 1     | 1   | 0   | 1         | 0               | set       |
| 1     | 1   | 1   | 1         | 1               | *         |

## Truth Table

| $S$ | $R$ | $Q_{t+1}$ |
|-----|-----|-----------|
| 0   | 0   | $Q_t$     |
| 0   | 1   | 0         |
| 1   | 0   | 1         |
| 1   | 1   | *         |

\* - forbidden state

$S=1$  and  $R=1$  is ~~not~~ forbidden.

as  $Q=1$  and  $\bar{Q}=1$



when  $S=0$  and  $R=0$  after this,  
O/P is indeterminant

Standard symbol



IEEE symbol

## Clock



- to regulate input
- can be added to circuits to trigger at high, leading edge trigger or falling edge trigger.

## Triggering

### 1) Level triggering

- change in circuit happens when clock is high

### 2) Positive edge trigger

- change in memory element when clock goes from low to high

### 3) Negative edge trigger

- change in memory element when clock goes from high to low

To get edge triggering, differentiator circuit.

## Flip Flop

- Latches are level sensitive
- Flip flops are sensitive to edge triggering

### I) SR Flip Flop



- Set-reset flip flop



### Truth Table

| clk | S | R | $Q$              | $\bar{Q}$ |
|-----|---|---|------------------|-----------|
| 0   | X | X | Memory           |           |
| 1   | 0 | 0 | Memory           |           |
| 1   | 0 | 1 | 0                | 1         |
| 1   | 1 | 0 | 1                | 0         |
| 1   | 1 | 1 | Forbidden state. |           |

## 2) D Flip flop

- data flip flop
- can be used to store data
- if clock off, data stored



Truth Table

| Clock | D | $Q_{t+1}$ |
|-------|---|-----------|
| 0     | X | $Q_t$     |
| 1     | 0 | 0         |
| 1     | 1 | 1         |



### 3) ~~JK~~ JK Flip Flop

- ~~toggle flip flop~~

- to use 1-1 state
- JK Flip Flop

| NAND TT. |   |   |
|----------|---|---|
| A        | B | y |
| 0        | 0 | 1 |
| 0        | 1 | 0 |
| 1        | 0 | 0 |
| 1        | 1 | 0 |



Truth Table

| clk | $Q_t$ | J | K | $Q_{t+1}$    | $\bar{Q}_{t+1}$ | Comments |
|-----|-------|---|---|--------------|-----------------|----------|
| 0   | 1     | X | X | 1            | 0               | Memory   |
| 0   | 0     | X | X | 0            | 1               | Memory   |
| 1   | 0     | 0 | 0 | 0            | 1               | Memory   |
| 1   | 0     | 0 | 1 | 0            | 1               | Reset    |
| 1   | 0     | 1 | 0 | 1            | 0               | Set      |
| 1   | 0     | 1 | 1 | 1, 0, ...    | 0, 1, 0, ...    | toggle   |
| 1   | 1     | 0 | 0 | 1            | 0               | Memory   |
| 1   | 1     | 0 | 1 | 0            | 1               | Reset    |
| 1   | 1     | 1 | 0 | 1            | 0               | Set      |
| 1   | 1     | 1 | 1 | 0, 1, 0, ... | 1, 0, 1, 0      | toggle   |

Race-around condition.

- Avoided using master-slave flip flop

#### 4) T Flip Flop

- toggle flip flop



Truth Table

| $clk$ | $T$ | $Q_{n+1}$              |
|-------|-----|------------------------|
| 0     | X   | $Q_n$ (Memory)         |
| 1     | 0   | $Q_n$ (Memory)         |
| 1     | 1   | $\bar{Q}_n$ (Toggling) |

Registers

- n-bit register capable of storing n-bit word.
- Applications: shifters & counters.

- Types of registers

SISO

SIPO

PISO

PIPO

## Shift Register (SISO) (4 D FFs)

shift-right mode



## Timing Diagram



## Counters

- Counts upto  $2^n$ , where  $n$  = no. of flip flops

### Types of Counters

Based on clock

#### 1) Ripple / Asynchronous counter

- clk applied to first ff and o/p of first ff connected to clk of next ff.
- circuit is more simple for more states.
- slow



#### 2) Synchronous counter

- clk given simultaneously
- no connection b/w o/p of first ff and clock of next ff.
- circuit more complicated
- speed high

Based on Counting Progression

##### 1) UP counters

0 - 1 - 2 - 3 - - -

##### 2) DOWN counters

7 - 6 - 5 - 4 - - -

##### 3) UP/DOWN counters combination

### 3-bit Asynchronous Up Counter (DFF)



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

### 3-bit Asynchronous Down Counter (DFF)



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