

# Chapter 1. Sequential Circuits

**Last Week**

Excitation tables of flip-flops

Analysis of sequential circuits

Implementation of sequential circuits from given state tables

**This Week**

Steps of sequential circuit design

# Steps of Synchronous Sequential Circuit Design

---

1. Define the states or memory element values based on the problem's description.
2. Develop a state table and diagram to represent system behavior.
3. Choose flip-flops (if unspecified) and prepare excitation tables.
4. Generate logical expressions and design the circuit using output and excitation tables.

# Steps of Synchronous Sequential Circuit Design

**Example:** Consider a Mealy-type circuit with one input and one output. The circuit outputs 1 if and only if the last three inputs are all 1.

This system requires 3 states, which are stored in memory components:

State A: Represents the condition where the most recent input is 0.

State B: Represents the condition where the last two inputs are "01".

State C: Represents the condition where the last two inputs are "11".



## Example (2<sup>nd</sup> Page)



State Diagram

Since the state table has 3 states, we need to use 2 flip-flops.

Let's assign letters as follows:

$$A = 00$$

$$B = 01$$

$$C = 10$$

| Present<br>State<br>(q) | Next State<br>(Q) |     | Output<br>(z) |     |
|-------------------------|-------------------|-----|---------------|-----|
|                         | x=0               | x=1 | x=0           | x=1 |
| A                       | A                 | B   | 0             | 0   |
| B                       | A                 | C   | 0             | 0   |
| C                       | A                 | C   | 0             | 1   |

State table of the circuit

↓

| Present<br>State<br>q <sub>1</sub> q <sub>2</sub> | Next State<br>(Q <sub>1</sub> Q <sub>2</sub> ) |     | Output<br>(z) |     |
|---------------------------------------------------|------------------------------------------------|-----|---------------|-----|
|                                                   | x=0                                            | x=1 | x=0           | x=1 |
| 0 0                                               | 0 0                                            | 0 1 | 0             | 0   |
| 0 1                                               | 0 0                                            | 1 0 | 0             | 0   |
| 1 0                                               | 0 0                                            | 1 0 | 0             | 1   |

## Example (3<sup>rd</sup> Page)

---

Let's implement the circuit with JK flip-flops.

Next step is to derive the inputs of the flip-flops.

| Present State<br>$q_1 q_2$ | Next State<br>( $Q_1 Q_2$ )<br>$x=0 \quad x=1$ | Flip-Flop Inputs |           |     |     | Output<br>(z)<br>$x=0 \quad x=1$ |
|----------------------------|------------------------------------------------|------------------|-----------|-----|-----|----------------------------------|
|                            |                                                | x=0              |           | x=1 |     |                                  |
| $J_1 K_1$                  | $J_2 K_2$                                      | $J_1 K_1$        | $J_2 K_2$ |     |     |                                  |
| 0 0                        | 0 0    0 1                                     | 0 x              | 0 x       | 0 x | 1 x | 0    0                           |
| 0 1                        | 0 0    1 0                                     | 0 x              | x 1       | 1 x | x 1 | 0    0                           |
| 1 0                        | 0 0    1 0                                     | x 1              | 0 x       | x 0 | 0 x | 0    1                           |



| $q$ | $Q$ | $J$ | $K$ |
|-----|-----|-----|-----|
| 0 0 |     | 0 x |     |
| 0 1 |     | 1 x |     |
| 1 0 |     | x 1 |     |
| 1 1 |     | x 0 |     |

## Example (4<sup>th</sup> Page)

Let's draw a Karnaugh map for each flip-flop input ( $J_1$ ,  $K_1$ ,  $J_2$ ,  $K_2$ ) and the output ( $z$ ) to determine the equations.

| Present State<br>$q_1q_2$ | Next State<br>( $Q_1Q_2$ ) |       | Flip-Flop Inputs |       |          |          | Output<br>( $z$ ) |          |       |       |
|---------------------------|----------------------------|-------|------------------|-------|----------|----------|-------------------|----------|-------|-------|
|                           | $x=0$                      | $x=1$ | $x=0$            | $x=1$ | $J_1K_1$ | $J_2K_2$ | $J_1K_1$          | $J_2K_2$ | $x=0$ | $x=1$ |
| <b>0 0</b>                | 0 0                        | 0 1   | 0 x              | 0 x   | 0 x      | 0 x      | 1 x               | 1 x      | 0     | 0     |
| <b>0 1</b>                | 0 0                        | 1 0   | 0 x              | x 1   | 1 x      | x 1      | x 1               | x 1      | 0     | 0     |
| <b>1 0</b>                | 0 0                        | 1 0   | x 1              | 0 x   | x 0      | 0 x      | x 0               | 0 x      | 0     | 1     |

| $q_1q_2$<br>x | 00 | 01 | 11 | 10 |
|---------------|----|----|----|----|
| 0             |    |    | x  | x  |
| 1             |    | 1  | x  | x  |

$$J_1 = x \cdot q_2$$

| $q_1q_2$<br>x | 00 | 01 | 11 | 10 |
|---------------|----|----|----|----|
| 0             |    |    | x  | x  |
| 1             | 1  | x  | x  |    |

$$J_2 = x \cdot q_1'$$

| $q_1q_2$<br>x | 00 | 01 | 11 | 10 |
|---------------|----|----|----|----|
| 0             | x  | x  | x  | 1  |
| 1             | x  | x  | x  |    |

$$K_1 = x'$$

| $q_1q_2$<br>x | 00 | 01 | 11 | 10 |
|---------------|----|----|----|----|
| 0             | x  | 1  | x  | x  |
| 1             | x  | 1  | x  | x  |

$$K_2 = 1$$

| $q_1q_2$<br>x | 00 | 01 | 11 | 10 |
|---------------|----|----|----|----|
| 0             |    |    | x  |    |
| 1             |    |    | x  | 1  |

$$z = x \cdot q_1$$

# Steps of Synchronous Sequential Circuit Design

**Example:** Consider a Moore-type circuit with one input and one output. The circuit outputs 1 if and only if the last three inputs are all 1.



Assuming the system starts in state A, let's analyze the state transitions and the output based on a sample input sequence.

|   |          |          |          |          |          |          |          |          |          |          |          |          |          |          |
|---|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|
| A | <b>A</b> | <b>B</b> | <b>C</b> | <b>D</b> | <b>D</b> | <b>D</b> | <b>D</b> | <b>A</b> | <b>B</b> | <b>C</b> | <b>D</b> | <b>A</b> | <b>B</b> |          |
| x | 0        | 1        | 1        | 1        | 1        | 1        | 1        | 0        | 1        | 1        | 0        | 1        | 1        | 0        |
| z | 0        | <b>0</b> | <b>0</b> | <b>0</b> | <b>1</b> | <b>1</b> | <b>1</b> | <b>1</b> | <b>0</b> | <b>0</b> | <b>0</b> | <b>0</b> | <b>0</b> | <b>0</b> |

## Example (2<sup>nd</sup> Page)

---

Let's analyze the behavior of the circuit using a timing diagram.



## Example (3<sup>rd</sup> Page)

Let's assign the flip-flop outputs to represent the states as follows:

A=00, B=01, C=10, D=11.



| Present<br>State<br>$x q_1 q_2$ | Next<br>State<br>$Q_1 Q_2$ | Flip-Flop<br>Inputs |           | Output<br>$z$ |
|---------------------------------|----------------------------|---------------------|-----------|---------------|
|                                 |                            | $J_1 K_1$           | $J_2 K_2$ |               |
| 0 0 0                           | 0 0                        | 0 x                 | 0 x       | 0             |
| 0 0 1                           | 0 0                        | 0 x                 | x 1       | 0             |
| 0 1 0                           | 0 0                        | x 1                 | 0 x       | 0             |
| 0 1 1                           | 0 0                        | x 1                 | x 1       | 1             |
| 1 0 0                           | 0 1                        | 0 x                 | 1 x       | 0             |
| 1 0 1                           | 1 0                        | 1 x                 | x 1       | 0             |
| 1 1 0                           | 1 1                        | x 0                 | 1 x       | 0             |
| 1 1 1                           | 1 1                        | x 0                 | x 0       | 1             |

## Example (4<sup>th</sup> Page)

After constructing the Karnaugh maps for  $J_1$ ,  $K_1$ ,  $J_2$ ,  $K_2$ , and  $z$ , the equations for each are derived as follows:

| Present State<br>$x q_1 q_2$ | Next State<br>$Q_1 Q_2$ | Flip-Flop Inputs |           | Output<br>$z$ |
|------------------------------|-------------------------|------------------|-----------|---------------|
|                              |                         | $J_1 K_1$        | $J_2 K_2$ |               |
| 0 0 0                        | 0 0                     | 0 x              | 0 x       | 0             |
| 0 0 1                        | 0 0                     | 0 x              | x 1       | 0             |
| 0 1 0                        | 0 0                     | x 1              | 0 x       | 0             |
| 0 1 1                        | 0 0                     | x 1              | x 1       | 1             |
| 1 0 0                        | 0 1                     | 0 x              | 1 x       | 0             |
| 1 0 1                        | 1 0                     | 1 x              | x 1       | 0             |
| 1 1 0                        | 1 1                     | x 0              | 1 x       | 0             |
| 1 1 1                        | 1 1                     | x 0              | x 0       | 1             |

Karnaugh

$$\begin{aligned}J_1 &= q_2 \cdot x \\K_1 &= x' \\J_2 &= x \\K_2 &= x' + q_1' \\z &= q_1 \cdot q_2\end{aligned}$$

Since it's a Moore-type circuit, the output depends only on the current state. Given that the output is 1 only in State D (where  $q_1 q_0 = 11$ ), the output equation can be simplified as:  $z = q_1 \cdot q_0$

# Steps of Synchronous Sequential Circuit Design

## Example: Synchronous Counter Design

Counter circuits typically do not have inputs. The state transitions occur with each clock pulse. The outputs are simply the states of the flip-flops, meaning the flip-flops' outputs serve as the circuit's outputs. If control over counting direction (up or down) is needed, an input can be added for this purpose.

Design steps for a 3-bit binary counter:

Since the counter will count from 0 to 7, it requires 8 distinct states, which means 3 flip-flops. Let's name these flip-flops as  $q_C$  (MSB),  $q_B$ , and  $q_A$  (LSB).



## Example (2<sup>nd</sup> Page)

| Present State<br>$q_C q_B q_A$ | Next State<br>$Q_C Q_B Q_A$ |
|--------------------------------|-----------------------------|
| 0 0 0                          | 0 0 1                       |
| 0 0 1                          | 0 1 0                       |
| 0 1 0                          | 0 1 1                       |
| 0 1 1                          | 1 0 0                       |
| 1 0 0                          | 1 0 1                       |
| 1 0 1                          | 1 1 0                       |
| 1 1 0                          | 1 1 1                       |
| 1 1 1                          | 0 0 0                       |

| Present State<br>$q_C q_B q_A$ | Next State<br>$Q_C Q_B Q_A$ | Flip-Flop Inputs |             |             |
|--------------------------------|-----------------------------|------------------|-------------|-------------|
|                                |                             | $J_C \ K_C$      | $J_B \ K_B$ | $J_A \ K_A$ |
| 0 0 0                          | 0 0 1                       | 0 x              | 0 x         | 1 x         |
| 0 0 1                          | 0 1 0                       | 0 x              | 1 x         | x 1         |
| 0 1 0                          | 0 1 1                       | 0 x              | x 0         | 1 x         |
| 0 1 1                          | 1 0 0                       | 1 x              | x 1         | x 1         |
| 1 0 0                          | 1 0 1                       | x 0              | 0 x         | 1 x         |
| 1 0 1                          | 1 1 0                       | x 0              | 1 x         | x 1         |
| 1 1 0                          | 1 1 1                       | x 0              | x 0         | 1 x         |
| 1 1 1                          | 0 0 0                       | x 1              | x 1         | x 1         |

Using Karnaugh maps, we determine that:

$$J_C = K_C = q_B \cdot q_A$$

$$J_B = K_B = q_A$$

$$J_A = K_A = 1$$



It can be inferred that if we were to design a 4-bit counter, the equation for  $J_D$  and  $K_D$  would be as follows:

$$J_D = K_D = q_C \cdot q_B \cdot q_A$$

## Example (3<sup>rd</sup> Page)

---

$$J_C = K_C = q_B \cdot q_A$$

$$J_B = K_B = q_A$$

$$J_A = K_A = 1$$



Logic Diagram for a 3-bit Counter

## More About Counters

---

1. If we use  $q'$  instead of  $q$  as the circuit's output in an up counter, the circuit will function as a down counter, and vice versa.
2. If the counter application is not sequential, the design steps remain the same. However, if there are unused states, the next state is treated as a don't-care condition. In such cases, if the circuit starts from one of these states, it becomes impossible to predict the next state (to prevent this, flip-flops have clear and preset inputs in addition to D/T/SR/JK inputs). Preset and Clear inputs override the clock signal to set or reset the output of flip-flops, and they are used to initialize the state of the flip-flops.

