

### Appendix A: Digital Logic

## By Miles Murdocca Internet Institute USA



### **Chapter Contents**

- A.1 Combinational Logic
- A.2 Truth Tables
- A.3 Logic Gates
- A.4 Boolean Algebra
- A.5 SOP Forms, Logic Diagrams
- A.6 POS Forms
- A.7 Positive and Negative Logic
- A.8 The Data Sheet
- A.9 Digital Components
- A.10 Simplification of Exprs.

- A.11 Speed and Performance
- A.12 Sequential Logic
- A.13 JK and T Flip Flops
- A.14 Design of Finite State Machines
- **A.15 Mealy and Moore Machines**
- A.16 Registers
- A.17 Counters



### Some Definitions

- Combinational logic: a digital logic circuit in which logical decisions are made based only on combinations of the inputs. e.g. an adder.
- Sequential logic: a circuit in which decisions are made based on combinations of the current inputs as well as the past history of inputs. e.g. a memory unit.
- Finite state machine: a circuit which has an internal state, and whose outputs are functions of both current inputs and its internal state. e.g. a vending machine controller.



### The Combinational Logic Unit

- translates a set of inputs into a set of outputs according to one or more mapping functions.
- Inputs and outputs for a CLU normally have two distinct (binary) values: high and low, 1 and 0, 0 and 1, or 5 v. and 0 v. for example.
- The outputs of a CLU are strictly functions of the inputs, and the outputs are updated immediately after the inputs change. A set of inputs i0 – in are presented to the CLU, which produces a set of outputs according to mapping functions f0 – fm

Fig A.1



## C S D

#### **Truth Tables**

Developed in 1854 by George Boole

- 2/e further developed by Claude Shannon (Bell Labs)
  - Outputs are computed for all possible input combinations (how many input combinations are there?

Consider a room with two light switches. How must they work<sup>†</sup>?





| Inp              | outs             | Output           |
|------------------|------------------|------------------|
| Α                | В                | Z                |
| 0<br>0<br>1<br>1 | 0<br>1<br>0<br>1 | 0<br>1<br>1<br>0 |

†Don't show this to your electrician, or wire your house this way. This circuit definitely violates the electric code. The practical circuit never leaves the lines to the light "hot" when the light is turned off. Can you figure how?



## Truth Tables Showing All Possible Functions of Two Binary Variables

| A | В | False | AND | $A\overline{B}$ | A | $\overline{A}B$ | В | XOR | OR |
|---|---|-------|-----|-----------------|---|-----------------|---|-----|----|
| 0 | 0 | 0     | 0   | 0               | 0 | 0               | 0 | 0   | 0  |
| 0 | 1 | 0     | 0   | 0               | 0 | 1               | 1 | 1   | 1  |
| 1 | 0 | 0     | 0   | 1               | 1 | 0               | 0 | 1   | 1  |
| 1 | 1 | 0     | 1   | 0               | 1 | 0               | 1 | 0   | 1  |

| A | В | NOR | XNOR | $\overline{B}$ | $A + \overline{B}$ | $\overline{A}$ | $\overline{A} + B$ | NAND | True |
|---|---|-----|------|----------------|--------------------|----------------|--------------------|------|------|
| 0 | 0 | 1   | 1    | 1              | 1                  | 1              | 1                  | 1    | 1    |
| 0 | 1 | 0   | 0    | 0              | 0                  | 1              | 1                  | 1    | 1    |
| 1 | 0 | 0   | 0    | 1              | 1                  | 0              | 0                  | 1    | 1    |
| 1 | 1 | 0   | 1    | 0              | 1                  | 0              | 1                  | 0    | 1    |

 The more frequently used functions have names: AND, XOR, OR, NOR, XOR, and NAND. (Always use upper case spelling.)



### Logic Gates and Their Symbols

Fig. A.5 Logic symbols for AND, OR, buffer, and NOT Boolean functions





- Note the use of the "inversion bubble."
- (Be careful about the "nose" of the gate when drawing AND vs. OR.)



## Logic symbols for NAND, NOR, XOR, and XNOR Boolean functions

Fig A.6





## Fig A. 7 Variations of Basic Logic Gate Symbols

$$\begin{array}{c}
A \\
B \\
C
\end{array}$$
(a)

$$A \longrightarrow B \longrightarrow F = \overline{A + \overline{B}}$$
**(b)**



- a) 3 inputs
- b) A Negated Input

c) Complementary Outputs



## Fig A.8 The Inverter at the Transistor Level



(a)

**Power** 

**Terminals** 



(b)

Transistor A Symbol



A Transistor Used as an Inverter



Inverter Transfer Function

## Fig A.9 Allowable Voltages in Transistor-Transistor-2/e Logic (TTL)







## A.10 Transistor-Level Circuits For 2-Input a) NAND and b)NOR Gates





## Tbl A.1 The Basic Properties of Boolean Algebra

| 8        |                                               |                              |                       | dual of a Danisan                                             |
|----------|-----------------------------------------------|------------------------------|-----------------------|---------------------------------------------------------------|
| <b>;</b> | Relationship                                  | Dual                         | Property              | dual of a Boolean function is gotten by replacing AND with OR |
|          | A B = B A                                     | A + B = B + A                | Commutative           | and OR with AND,<br>constant 1s by 0s, and                    |
|          | A (B + C) = A B + A C                         | A + B C = (A + B) (A + C)    | Distributive          | 0s by 1s                                                      |
|          | 1 A = A                                       | 0 + A = A                    | Identity              | Postulates                                                    |
|          | $A\overline{A} = 0$                           | $A + \overline{A} = 1$       | Inverse               | <b>↑</b>                                                      |
|          | 0A = 0                                        | 1 + A = 1                    | Null                  |                                                               |
|          | A A = A                                       | A + A = A                    | Idempotence           | <b>*</b>                                                      |
| - 1      | A(BC) = (AB)C                                 | A + (B+C) = (A+B) + C        | Associative           | Theorems                                                      |
|          | $\overline{\overline{A}} = A$                 |                              | Complement            |                                                               |
|          | $\overline{AB} = \overline{A} + \overline{B}$ |                              | DeMorgan's<br>Theorem | A, B, etc. are<br>Literals; 0 and                             |
|          | $AB + \overline{AC} + BC$                     | $(A+B)(\overline{A}+C)(B+C)$ | Consensus             | 1 are                                                         |
|          | = AB + AC                                     | = (A+B)(A+C)                 | Theorem               | constants.                                                    |

Principle of duality: The



### A.11 and A. 12 DeMorgan's Theorem

| A B | $\overline{AB} =$ | $\overline{A} + \overline{B}$ | $\overline{A + B}$ | $=\overline{A}\overline{B}$ |
|-----|-------------------|-------------------------------|--------------------|-----------------------------|
| 0 0 | 1                 | 1                             | 1                  | 1                           |
| 0 1 | 1                 | 1                             | 0                  | 0                           |
| 1 0 | 1                 | 1                             | 0                  | 0                           |
| 1 1 | 0                 | 0                             | 0                  | 0                           |

DeMorgan's theorem:  $A + B = \overline{A + B} = \overline{A} \overline{B}$ 

Discuss: Applying DeMorgan's theorem by "pushing the bubbles," and "bubble tricks."



### The Sum-of-Products (SOP) Form

Fig. A.14—Truth
Table for The
Majority Function

| Minterm | А | В | С | F |
|---------|---|---|---|---|
| Index   |   |   |   |   |
| 0       | 0 | 0 | 0 | 0 |
| 1       | 0 | 0 | 1 | 0 |
| 2<br>3  | 0 | 1 | 0 | 0 |
| 3       | 0 | 1 | 1 | 1 |
| 4       | 1 | 0 | 0 | 0 |
| 5<br>6  | 1 | 0 | 1 | 1 |
| 6       | 1 | 1 | 0 | 1 |
| 7       | 1 | 1 | 1 | 1 |
| ,       |   |   |   |   |



A balance tips to the left or right depending on whether there are more 0's or 1's.

- transform the function into a two-level AND-OR equation
- implement the function with an arrangement of logic gates from the set {AND, OR, NOT}
- M is true when A=0, B=1, and C=1, or when A=1, B=0, and C=1, and so on for the remaining cases.
- Represent logic equations by using the sum-of-products (SOP) form

### The SOP Form of the Majority Gate

The SOP form for the 3-input majority gate is:

• 
$$M = ABC + ABC + ABC + ABC = m3 + m5 + m6 + m7 = \Sigma (3, 5, 6, 7)$$

- Each of the 2<sup>n</sup> terms are called minterms, running from 0 to 2<sup>n</sup> 1
- Note the relationship between minterm number and boolean value.
- Discuss: common-sense interpretation of equation.



## Fig A.15 A 2-Level AND-OR Circuit that Implements the Majority Function



**Discuss: What is the Gate Count?** 



## Fig A.16 Notation Used at Circuit Intersections





## Fig A.17 A 2-Level OR-AND Circuit that Implements the Majority Function



## C S D

### Positive vs. Negative Logic

Positive logic: truth, or assertion is represented by logic 1, higher voltage; 2/e falsity, de- or unassertion, logic 0, is represented by lower voltage.

•Negative logic: truth, or assertion is represented by logic 0, lower voltage; falsity, de- or unassertion, logic 1, is represented by lower voltage

**Gate Logic: Positive vs. Negative Logic** 

**Normal Convention: Postive Logic/Active High** 

Low Voltage = 0; High Voltage = 1

Alternative Convention sometimes used: Negative Logic/Active Low



**Dual Operations** 



## Fig A.18 Positive and Negative Logic (Cont'd.)

#### Voltage levels

| Α    | В    | F    |
|------|------|------|
| low  | low  | low  |
| low  | high | low  |
| high | low  | low  |
| high | high | high |



#### Voltage levels

| Α    | В    | F    |
|------|------|------|
| low  | low  | high |
| low  | high | high |
| high | low  | high |
| high | high | low  |



#### Positive logic levels

| Α | В | F |
|---|---|---|
| 0 | 0 | 0 |
| 0 | 1 | 0 |
| 1 | 0 | 0 |
| 1 | 1 | 1 |

#### Positive logic levels

| Α | В | F |
|---|---|---|
| 0 | 0 | 1 |
| 0 | 1 | 1 |
| 1 | 0 | 1 |
| 1 | 1 | 0 |



#### Negative logic levels

| Α | В | F |
|---|---|---|
| 1 | 1 | 1 |
| 1 | 0 | 1 |
| 0 | 1 | 1 |
| 0 | 0 | 0 |

$$A \longrightarrow F = A + B$$

#### Negative logic levels

| Α | В | F |
|---|---|---|
| 1 | 1 | 0 |
| 1 | 0 | 0 |
| 0 | 1 | 0 |
| 0 | 0 | 1 |

$$A \longrightarrow B \longrightarrow C + B$$



### **Bubble Matching**

- Active low signals are signified by a prime or overbar or /.
- Active high: enable \_\_\_\_\_
- Active low: enable', enable, enable/
- Discuss microwave oven control:
- Active high: Heat = DoorClosed Start
- Active low: ? (hint: begin with AND gate as before.)



## Fig. A.19 Bubble Matching (Cont'd.)











### **Digital Components**

- High level digital circuit designs are normally made using collections of logic gates referred to as components, rather than using individual logic gates. The majority function can be viewed as a component.
- Levels of integration (numbers of gates) in an integrated circuit (IC):
- small scale integration (SSI): 10-100 gates.
- medium scale integration (MSI): 100 to 1000 gates.
- Large scale integration (LSI): 1000-10,000 logic gates.
- Very large scale integration (VLSI): 10,000-upward.
- These levels are approximate, but the distinctions are useful in comparing the relative complexity of circuits.
- Let us consider several useful MSI components:



#### **SN7400 QUADRUPLE 2-INPUT POSITIVE-NAND GATES**

#### description

These devices contain four independent 2-input NAND gates.

schematic (each gate)

 $1 \text{ k}\Omega$ 

- V<sub>cc</sub>

 $130 \Omega$ 

**GND** 

#### function table (each gate)

| INP | UTS | OUTPUT |
|-----|-----|--------|
| Α   | В   | Υ      |
| Н   | Н   | L      |
| L   | Χ   | Н      |
| Х   | L   | Н      |



## package (top view) $1.6~\mathrm{k}\Omega$

Fig A.20 The **Data Sheet** 

absolute maximum ratings

Supply voltage, VCC Input voltage:

Operating free-air temperature range: Storage temperature range

7 V 5.5 V 0°C to 70°C - 65°C to 150°C

#### recommended operating conditions

#### logic diagram (positive logic)



|                 |                                | MIN  | NOM | MAX   | UNIT |
|-----------------|--------------------------------|------|-----|-------|------|
| v <sub>cc</sub> | Supply voltage                 | 4.75 | 5   | 5.25  | V    |
| V <sub>IH</sub> | High-level input voltage       | 2    |     |       | V    |
| V <sub>IL</sub> | Low-level input voltage        |      |     | 0.8   | V    |
| Іон             | High-level output current      |      |     | - 0.4 | mA   |
| I <sub>OL</sub> | Low-level output current       |      |     | 16    | mA   |
| TA              | Operating free-air temperature | 0    |     | 70    | °C   |

#### electrical characteristics over recommended operating free-air temperature range

|                  |                                                                       | 5   |     |       |      |
|------------------|-----------------------------------------------------------------------|-----|-----|-------|------|
| VALUE            | OPERATING CONDITIONS                                                  | MIN | TYP | MAX   | UNIT |
| V <sub>OH</sub>  | $V_{CC}$ = MIN, $V_{IL}$ = 0.8 V, $I_{OH}$ = -0.4 mA                  | 2.4 | 3.4 |       | V    |
| V <sub>OL</sub>  | V <sub>CC</sub> = MIN, V <sub>IH</sub> = 2 V, I <sub>OL</sub> = 16 mA |     | 0.2 | 0.4   | V    |
| I <sub>IН</sub>  | V <sub>CC</sub> = MAX, V <sub>I</sub> = 2.4 V                         |     |     | 40    | μΑ   |
| I <sub>IL</sub>  | $V_{CC} = MAX, V_I = 0.4 V$                                           |     |     | - 1.6 | mA   |
| I <sub>CCH</sub> | $V_{CC} = MAX, V_I = 0 V$                                             |     | 4   | 8     | mA   |
| I <sub>CCL</sub> | V <sub>CC</sub> = MAX, V <sub>I</sub> = 4.5 V                         |     | 12  | 22    | mA   |

#### switching characteristics, $V_{CC} = 5 \text{ V}$ , $T_A = 25^{\circ} \text{ C}$

| PARAMETER        | FROM (input) | TO (output) | TEST CONDITIONS        | MIN NOM | MAX | UNIT |
|------------------|--------------|-------------|------------------------|---------|-----|------|
| t <sub>PLH</sub> | A or B       | Υ           | $R_L = 400 \Omega$     | 11      | 22  | ns   |
| t <sub>PHL</sub> | 1.5.2        | •           | C <sub>L</sub> = 15 pF | 7       | 15  | ns   |



## Figs A.21, A.22 The Multiplexer



| А                | В                | F                       |
|------------------|------------------|-------------------------|
| 0<br>0<br>1<br>1 | 0<br>1<br>0<br>1 | $D_0$ $D_1$ $D_2$ $D_3$ |

$$\mathsf{F} = \overline{\mathsf{A}} \; \overline{\mathsf{B}} \; \mathsf{D}_0 + \overline{\mathsf{A}} \; \mathsf{B} \; \mathsf{D}_1 + \mathsf{A} \; \overline{\mathsf{B}} \; \mathsf{D}_2 + \mathsf{A} \; \mathsf{B} \; \mathsf{D}_3$$





## Fig A.23 Implementing the Majority Function with an 8-1 Mux

| Α | В | С | М |
|---|---|---|---|
| 0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 0 |
| 0 | 1 | 0 | 0 |
| 0 | 1 | 1 | 1 |
| 1 | 0 | 0 | 0 |
| 1 | 0 | 1 | 1 |
| 1 | 1 | 0 | 1 |
| 1 | 1 | 1 | 1 |



Principle: Use the mux select to pick out the selected minterms of the function.



Fig. A.24 More Efficiency: Using a 4-1 Mux to Implement the Majority F'n.



Principle: Use the A and B inputs to select a pair of minterms. The value applied to the MUX input is selected from {0, 1, C, C} to pick the desired behavior of the minterm pair.



## Fig. A.25 The Demultiplexer (DEMUX)



$$F_0 = D \overline{A} \overline{B}$$
  $F_2 = D A \overline{B}$   
 $F_1 = D \overline{A} B$   $F_3 = D A B$ 

| D | Α | В | $F_0$ | F <sub>1</sub> | $F_2$ | $F_3$ |
|---|---|---|-------|----------------|-------|-------|
| 0 | 0 | 0 | 0     | 0              | 0     | 0     |
| 0 | 0 | 1 | 0     | 0              | 0     | 0     |
| 0 | 1 | 0 | 0     | 0              | 0     | 0     |
| 0 | 1 | 1 | 0     | 0              | 0     | 0     |
| 1 | 0 | 0 | 1     | 0              | 0     | 0     |
| 1 | 0 | 1 | 0     | 1              | 0     | 0     |
| 1 | 1 | 0 | 0     | 0              | 1     | 0     |
| 1 | 1 | 1 | 0     | 0              | 0     | 1     |

# D

## g's. A.26 and A.27: The Demultiplexer is a Decoder with an Enable Input

**Compare to Fig A.28** 





| Enable = 1 |   |                |       |       |       |  |
|------------|---|----------------|-------|-------|-------|--|
| Α          | В | D <sub>0</sub> | $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 = \overline{A} \overline{B}$$

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

$$D_0 = \overline{A} \overline{B}$$
  $D_1 = \overline{A} B$   $D_2 = A \overline{B}$ 

$$D_3 = A B$$

Enable = 0

A B

0

 $D_0$   $D_1$   $D_2$   $D_3$ 

0



Enable



## Fig A.29 Using a Decoder to Implement the Majority Function





## Figs A.30, 31, The Priority Encoder

An encoder translates a set of inputs into a binary encoding,

- Can be thought of as the converse of a decoder.
- A priority encoder imposes an order on the inputs.
- A<sub>i</sub> has a higher priority than A<sub>i+1</sub>



$$F_0 = \overline{A}_0 \overline{A}_1 A_3 + \overline{A}_0 \overline{A}_1 A_2$$
$$F_1 = \overline{A}_0 \overline{A}_2 A_3 + \overline{A}_0 A_1$$

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





## Fig A.32 Programmable Logic Arrays (PLAs)

A PLA is a
 customizable AND
 matrix followed by a
 customizable OR
 matrix:





## Fig. A.33 Using a PLA to Implement the Majority Function





### Using PLAs to Implement an Adder

Carry Sum

Out

Carry In 
$$\longrightarrow$$
 0 0 0 0 1 1 1 1 1 1 Operand A  $\longrightarrow$  0 0 1 1 1 0 0 1 1 1 1  $\longrightarrow$  0 1 1  $\longrightarrow$  0 1 1  $\longrightarrow$  0

Example:

Figs A.34-36



| Α | <sub>i</sub> B <sub>i</sub> | $C_{i}$ | S <sub>i</sub> | $C_{i+1}$ |
|---|-----------------------------|---------|----------------|-----------|
| 0 | 0                           | 0       | 0              | 0         |
| 0 | 0                           | 1       | 1              | 0         |
| 0 | 1                           | 0       | 1              | 0         |
| 0 | 1                           | 1       | 0              | 1         |
| 1 | 0                           | 0       | 1              | 0         |
| 1 | 0                           | 1       | 0              | 1         |
| 1 | 1                           | 0       | 0              | 1         |
| 1 | 1                           | 1       | 1              | 1         |





### Fig A.38 PLA Realization of a FA







# Reduction (Simplification) of Boolean Expressions

- It may be possible to simplify the canonical SOP or POS forms.
- A smaller Boolean equation translates to a lower gate count in the target circuit.
- We discuss two methods: algebraic reduction and Karnaugh map reduction.



#### The Algebraic Method

#### Consider the majority function, F:

$$F = \overline{A}BC + A\overline{B}C + AB\overline{C} + ABC$$

$$F = \overline{A}BC + A\overline{B}C + AB(\overline{C} + C)$$
 Distributive Property

$$F = \overline{A}BC + A\overline{B}C + AB(1)$$
 Complement Property

$$F = \overline{A}BC + A\overline{B}C + AB$$
 Identity Property

$$F = \overline{A}BC + A\overline{B}C + AB + ABC$$
 Idempotence

$$F = \overline{A}BC + AC(\overline{B} + B) + AB$$
 Identity Property

$$F = \overline{A}BC + AC + AB$$
 Complement and Identity

$$F = \overline{A}BC + AC + AB + ABC$$
 Idempotence

$$F = BC(\overline{A} + A) + AC + AB$$
 Distributive

$$F = BC + AC + AB$$
 Complement and Identity



#### Fig A.40 Venn Diagrams





Each distinct region in the "Universe" represents a minterm. This diagram can be transformed into a Karnaugh Map.



#### Fig A.41 A K-Map of the Majority Function

Place a "1" in each cell that has a that minterm. Cells on the outer edge of the map "wrap around"



The map contains all the minterms. Adjacent 1's in the K-Map satisfy the Complement property of Boolean Algebra.



# Fig A.42 Adjacency Groupings for the Majority Function



M = BC + AC + AB



# A.43 Minimized AND OR Circuit for the Majority Function



M = BC + AC + AB



#### Fig A.44 Minimal and not Minimal Groupings



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



$$F = BD + \overline{A}B\overline{C} + \overline{A}CD + ABC + A\overline{C}D$$



### Fig A.45 The Corners are Logically Adjacent





#### A.46 Two Different Minimized Equations







### **Speed and Performance**

- The speed of a digital system is governed by
  - the propagation delay through the logic gates and
  - the propagation across interconnections.



# Fig A.47 Propagation Delay for a NOT Gate (From Hamacher et. al. 1990)





### Circuit Depth Affects Propagation Delay—Fig A.48



$$F(ABCD) = \overline{A}\overline{B}\overline{C}\overline{D} + \overline{A}\overline{B}CD + \overline{A}B\overline{C}D + \overline{A}BC\overline{D} + A\overline{B}\overline{C}D + ABCD$$
$$= (\overline{B}\overline{C} + BC)AD + (\overline{B}C + B\overline{C})\overline{A}D + (\overline{B}\overline{C} + BC)$$



#### Fig A.49 Fanin may Affect Circuit Depth

C D





Associative law of Boolean algebra:

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

$$((A + B) + C) + D$$
  
Degenerate tree



#### Sequential Logic

- The combinational logic circuits we have been studying so far have no memory. The outputs always follow the inputs.
- There is a need for circuits with a memory, which behave differently depending upon their previous state.
- An example is the vending machine, which must remember how many and what kinds of coins have been inserted, and which behave according to not only the current coin inserted, but also upon how many and what kind of coins have been deposited previously.
- These are referred to as finite state machines, because they can have at most a finite number of states.



## Fig A.50 Classical Model of a Finite State Machine (FSM)





#### A.51 A NOR Gate with a Lumped Delay





Timing behavior

This delay between input and output is at the basis of the functioning of an important memory element, the *flip-flop*.



#### A.52 The S-R (Set-Reset) Flip-Flop



| $Q_t$ | S <sub>t</sub> | $R_t$ | Q <sub>i+1</sub> |
|-------|----------------|-------|------------------|
| 0     | 0              | 0     | 0                |
| 0     | 0              | 1     | 0                |
| 0     | 1              | 0     | 1                |
| 0     | 1              | 1     | (disallowed)     |
| 1     | 0              | 0     | 1                |
| 1     | 0              | 1     | 0                |
| 1     | 1              | 0     | 1                |
| 1     | 1              | 1     | (disallowed)     |



Timing behavior

The S-R flip-flop is an active high (positive logic) device.



# Fig A.53 Converting a NOR S-R to an NAND S-R

Active High NOR Impl.

Push Bubbles (DeMorgan's)

Rearrange Bubbles Convert from Bubbles to Active Low Signal Names



#### Fig A.54 A Circuit with a Hazard



It is desirable to be able to "turn off" the flip-flop so it does not respond to such hazards.



Timing behavior



#### Fig A.55 The Clock Paces the System



In a positive logic system, the "action" happens when the clock is high, or positive. The low part of the clock cycle allows propagation between subcircuits, so their inputs are stable at the correct value when the clock next goes high.



#### A.56 A Clocked S-R Flip-Flop





Timing behavior

The clock signal, CLK, turns on the inputs to the flip-flop.



#### Fig A.57 The Clocked D (Data) Flip-Flop



The clocked D flip-flop, sometimes called a latch, has a potential problem: If D changes while the clock is high, the output will also change. The Master-Slave flip-flop solves this problem:



#### A.58 The Master-Slave Flip-Flop



The rising edge of the clock clocks new data into the Master, while the slave holds previous data. The falling edge clocks the new Master data into the Slave.



#### Fig A.59 The Basic J-K Flip-Flop



- •The J-L flip-flop eliminates the S=R=1 problem of the S-R flip-flop, because Q enables J while Q' disables K, and vice-versa.
- •However there is still a problem. If J goes momentarily to 1 and then back to 0 while the flip-flop is active and in the reset, the flip-flop will "catch" the 1.
- •This is referred to as "1's catching."
- •The J-K Master-Slave flip-flop solves this problem.



#### Fig A.61 The Master-Slave J-K Flip-Flop





#### Fig A.60 The T (Toggle) Flip-Flop



 The presence of a constant 1 at J and K means that the flip-flop will change its state from 0-1 or 1-0 each time it is clocked by the T (Toggle) input.



## Fig A.62 The Negative Edge-Triggered D Flip-Flop





- When the clock is high, the two input latches output 0, so the Main latch remains in its previous state, regardless of changes in D.
- When the clock goes high-low, values in the two input latches will affect the state of the Main latch.
- While the clock is low, D cannot affect the Main latch.



### Fig A.63 Finite State Machine Design Example: The Modulo-4 Counter

Counter has a clock input, CLK, and a RESET input.

 Has two output lines, which must take values of 00, 01, 10, and 11 on subsequent clock cycles.



#### C S D A

### Fig A.64 State Transition Diagram for a Modulo(4) Counter



The state diagram and state table tell "all there is to know" about the FSM, and are the basis for a provably correct design.



#### Fig A.67a

| r(t) | $s_1(t)s_0(t)$ | $s_1s_0(t+1)$ | $q_1q_0(t+1)$ |
|------|----------------|---------------|---------------|
| 0    | 00             | 01            | 01            |
| 0    | 01             | 10            | 10            |
| 0    | 10             | 11            | 11            |
| 0    | 11             | 00            | 00            |
| 1    | 00             | 00            | 00            |
| 1    | 01             | 00            | 00            |
| 1    | 10             | 00            | 00            |
| 1    | 11             | 00            | 00            |

Develop equations from this truth table for  $s_0(t+1)$ ,  $s_1(t+1)$ ,  $q_0(t+1)$ , and  $q_1(t+1)$  from inputs r(t),  $s_0(t)$  and  $s_1(t)$ 

#### Fig A.67b

$$s_0(t+1) = \overline{r(t)}s_1(t)s_0(t) + \overline{r(t)}s_1(t)\overline{s_0(t)}$$

$$s_1(t+1) = \overline{r(t)}s_1(t)\overline{s_0(t)} + \overline{r(t)}s_1(t)\overline{s_0(t)}$$

$$q_0(t+1) = \overline{r(t)}s_1(t)\overline{s_0(t)} + \overline{r(t)}s_1(t)\overline{s_0(t)}$$

$$q_1(t+1) = \overline{r(t)}s_1(t)\overline{s_0(t)} + \overline{r(t)}s_1(t)\overline{s_0(t)}$$

#### Implement these equations



#### Fig A.68

#### Circuit for a 2-bit counter:



There are many simpler techniques for implementing counters.



#### Example A.2: A Sequence Detector

- Design a machine that outputs a 1 when exactly 2 of the last 3 inputs are 1.
- e.g. input sequence of 011011100 produces an output sequence of 001111010
- Assume input is a 1-bit serial line.
- Use D flip-flops and 8-1 Multiplexers
- Begin by constructing a state transition diagram:

# Fig A.69 State Transition Diagram for Sequence Detector

Design a machine that outputs a 1 0/0 when exactly 0/0 2 of the last 3 D inputs are 1. 1/0 В 0/0 0/0 1/0 0/0 1/1 0/0 1/1 1/0 0/1 G 1/0 1/0

| •Discuss: the ' | "meaning" | of each state. |
|-----------------|-----------|----------------|
|-----------------|-----------|----------------|

| Pres.       | X            |              |  |  |  |  |
|-------------|--------------|--------------|--|--|--|--|
| State       | 0            | 1            |  |  |  |  |
| $S_2S_1S_0$ | $S_2S_1S_0Z$ | $S_2S_1S_0Z$ |  |  |  |  |
| A=000       | 001/0        | 010/0        |  |  |  |  |
| B =001      | 011/0        | 100/0        |  |  |  |  |
| C=010       | 101/0        | 110/0        |  |  |  |  |
| D=011       | 011/0        | 100/0        |  |  |  |  |
| E=100       | 101/0        | 110/1        |  |  |  |  |
| F=101       | 011/0        | 100/1        |  |  |  |  |
| G=110       | 101/1        | 110/0        |  |  |  |  |

- •Convert table to truth table (how?).
- •Solve for  $s_2 s_1 s_0$  and Z.



#### Fig A.72 Logic Diagram for Seq. Det.





#### Ex A.3 A Vending Machine Controller

- Acepts nickel, dime, and quarter. When value of money inserted equals or exceeds twenty cents, machine vends item and returns change if any, and waits for next transaction.
- Implement with PLA and D flip-flops.



### Fig A.73 State Trans. Diagram for Vending Machine Controller





#### Fig A.75b Truth Table for Vending Machine

|                    |                |       |                 |                | Dispense        |                |                |                |                |          |
|--------------------|----------------|-------|-----------------|----------------|-----------------|----------------|----------------|----------------|----------------|----------|
|                    |                | sent  |                 |                | Ne              |                | R              |                | n ni           |          |
| D 40               |                | ate   | Cc              | oin            | sta             | $\overline{}$  |                |                | Hell<br>       | ırn dime |
| Base 10 equivalent | s <sub>1</sub> | $s_0$ | 'x <sub>1</sub> | x <sub>0</sub> | 's <sub>1</sub> | s <sub>0</sub> | ż <sub>2</sub> | ż <sub>1</sub> | ż <sub>0</sub> |          |
| 0                  | 0              | 0     | 0               | 0              | 0               | 1              | 0              | 0              | 0              |          |
| 1                  | 0              | 0     | 0               | 1              | 1               | 0              | 0              | 0              | 0              |          |
| 2                  | 0              | 0     | 1               | 0              | 0               | 0              | 1              | 1              | 0              |          |
| 3                  | 0              | 0     | 1               | 1              | d               | d              | d              | d              | d              |          |
| 4                  | 0              | 1     | 0               | 0              | 1               | 0              | 0              | 0              | 0              |          |
| 5                  | 0              | 1     | 0               | 1              | 1               | 1              | 0              | 0              | 0              |          |
| 6                  | 0              | 1     | 1               | 0              | 0               | 0              | 1              | 0              | 1              |          |
| 7                  | 0              | 1     | 1               | 1              | d               | d              | d              | d              | d              |          |
| 8                  | 1              | 0     | 0               | 0              | 1               | 1              | 0              | 0              | 0              |          |
| 9                  | 1              | 0     | 0               | 1              | 0               | 0              | 1              | 0              | 0              |          |
| 10                 | 1              | 0     | 1               | 0              | 0               | 0              | 1              | 1              | 1              |          |
| 11                 | 1              | 0     | 1               | 1              | d               | d              | d              | d              | d              |          |
| 12                 | 1              | 1     | 0               | 0              | 0               | 0              | 1              | 0              | 0              |          |
| 13                 | 1              | 1     | 0               | 1              | 0               | 0              | 1              | 1              | 0              |          |
| 14                 | 1              | 1     | 1               | 0              | 0               | 1              | 1              | 1              | 1              |          |
| 15                 | 1              | 1     | 1               | 1              | d               | d              | d              | d              | d              |          |

(b)



# Fig A.75 a)FSM, b)Truth Table, c)PLA realization



| Base 10<br>equivalent |   | sent<br>ate<br>s <sub>0</sub> | Cc<br>X <sub>1</sub> | oin<br>X <sub>0</sub> | Ne.<br>sta | xt |   | etur | 1 | ckel<br>urn dime |
|-----------------------|---|-------------------------------|----------------------|-----------------------|------------|----|---|------|---|------------------|
| 0                     | 0 | 0                             | 0                    | 0                     | 0          | 1  | 0 | 0    | 0 |                  |
| 1                     | 0 | 0                             | 0                    | 1                     | 1          | 0  | 0 | 0    | 0 |                  |
| 2                     | 0 | 0                             | 1                    | 0                     | 0          | 0  | 1 | 1    | 0 |                  |
| 3                     | 0 | 0                             | 1                    | 1                     | d          | d  | d | d    | d |                  |
| 4                     | 0 | 1                             | 0                    | 0                     | 1          | 0  | 0 | 0    | 0 |                  |
| 5                     | 0 | 1                             | 0                    | 1                     | 1          | 1  | 0 | 0    | 0 |                  |
| 6                     | 0 | 1                             | 1                    | 0                     | 0          | 0  | 1 | 0    | 1 |                  |
| 7                     | 0 | 1                             | 1                    | 1                     | d          | d  | d | d    | d |                  |
| 8                     | 1 | 0                             | 0                    | 0                     | 1          | 1  | 0 | 0    | 0 |                  |
| 9                     | 1 | 0                             | 0                    | 1                     | 0          | 0  | 1 | 0    | 0 |                  |
| 10                    | 1 | 0                             | 1                    | 0                     | 0          | 0  | 1 | 1    | 1 |                  |
| 11                    | 1 | 0                             | 1                    | 1                     | d          | d  | d | d    | d |                  |
| 12                    | 1 | 1                             | 0                    | 0                     | 0          | 0  | 1 | 0    | 0 |                  |
| 13                    | 1 | 1                             | 0                    | 1                     | 0          | 0  | 1 | 1    | 0 |                  |
| 14                    | 1 | 1                             | 1                    | 0                     | 0          | 1  | 1 | 1    | 1 |                  |
| 15                    | 1 | 1                             | 1                    | 1                     | ld         | d  | d | d    | d |                  |
|                       |   |                               |                      | (l                    | o)         |    |   |      |   |                  |





#### Mealy vs. Moore Machines

Mealy Model: Outputs are functions of Inputs and Present State.

Previous FSM designs were Mealy Machines, because next state was computed from present state and inputs.



Moore Model: Outputs are functions of Present State only.



Both are equally powerful.



#### Fig A.77 Tri-state Buffers

| С | Α | F |
|---|---|---|
| 0 | 0 | Ø |
| 0 | 1 | Ø |
| 1 | 0 | 0 |
| 1 | 1 | 1 |

| С | А | F |
|---|---|---|
| 0 | 0 | 0 |
| 0 | 1 | 1 |
| 1 | 0 | Ø |
| 1 | 1 | Ø |

$$\begin{array}{c|c}
A & F = A C \\
 & or \\
 & F = \emptyset
\end{array}$$

$$\begin{array}{c|c}
A & \hline
 & F = A \overline{C} \\
 & or \\
 & F = \emptyset
\end{array}$$

**Tri-state buffer** 

Tri-state buffer, inverted control

- There is a third state: High impedance. This means the gate output is essentially disconnected from the circuit.
- This state is indicated by  $\emptyset$  in the figure.



### Fig A78, A79 Registers

**Gate-Level View** 



**Chip-Level View** 





### Fig A.80 A Left-Right Shift Register with Parallel Read and Write





#### Fig A.81 A Modulo 8 (3-bit) Ripple Counter

Note the use of the T flip-flops. They are used to toggle the input of the next flipflop when its output is 1.





