

ECE 2050 Digital Logic and Systems

# **Chapter 9 : Finite State Machine**

Instructor: Tinghuan CHEN, Ph.D.



香港中文大學（深圳）  
The Chinese University of Hong Kong, Shenzhen

# Last Week

- Shift Registers
  - Data storage
  - Data movement
  - Serial/Parallel In - Serial/Parallel Out
- Bidirectional Shift Registers
- Shift Register Applications
  - Time Delay
  - Serial-to-Parallel Data Converter
  - UART (Universal Asynchronous Receiver Transmitter)
  - Keyboard Encoder
- Johnson Counter & Ring Counter



# Synchronous Sequential Design



# Sequential Logic

- **Sequential circuits:** all circuits that aren't combinational
- **A problematic circuit:**



- **No inputs** and 1-3 outputs
- Astable circuit, **oscillates**
- Period depends on inverter delay
- It has a **cyclic path**: output fed back to input



# Synchronous Sequential Logic Design

- Breaks cyclic paths by **inserting registers**
- Registers contain **state** of the system
- State changes at clock edge: system **synchronized** to the clock
- **Rules** of synchronous sequential circuit composition:
  - Every circuit element is either a **register** or a **combinational circuit**
  - At least **one** circuit element is a **register**
  - All registers receive the **same clock**
  - Every **cyclic path** contains at least **one register**
- **Finite State Machine (FSMs)** are common synchronous sequential circuits



# Finite State Machines



# Finite State Machine (FSM)

- **Consists of:**
  - **State register**
    - Stores current state
    - Loads next state at clock edge
  - **Combinational logic**
    - Computes the next state
    - Computes the outputs



# Finite State Machine (FSM)

- **Next state** determined by **current state** and **inputs**
- Two types of finite state machines differ in **output logic**:
  - **Moore FSM**: **outputs** depend **only** on **current state**
  - **Mealy FSM**: **outputs** depend on **current state and inputs**



# FSM Design Procedure

1. Identify **inputs** and **outputs**
2. Sketch **state transition diagram**
3. Write **state transition table** and **output table**
  - **Moore FSM**: write **separate** tables
  - **Mealy FSM**: write **combined** state transition and output table
4. Select **state encodings**
5. Rewrite state transition table and output table with state **encodings**
6. Write **Boolean equations** for next state and output logic
7. Sketch the circuit **schematic**



# Moore FSMs Examples



# FSM Example

- **Traffic light controller**
  - **Traffic sensors:**  $T_A, T_B$  (TRUE when there's traffic)
  - **Lights:**  $L_A, L_B$



# FSM Block Box

- **Inputs:**  $CLK$ ,  $Reset$ ,  $T_A$ ,  $T_B$
- **Outputs:**  $L_A$ ,  $L_B$



# FSM State Transition Diagram

- **Moore FSM**: outputs labeled in each state
- **States**: Circles
- **Transitions**: Arcs



# FSM State Transition Table

| Current State<br><i>S</i> | Inputs |       | Next State<br><i>S'</i> |
|---------------------------|--------|-------|-------------------------|
|                           | $T_A$  | $T_B$ |                         |
| S0                        | 0      | X     | S1                      |
| S0                        | 1      | X     | S0                      |
| S1                        | X      | X     | S2                      |
| S2                        | X      | 0     | S3                      |
| S2                        | X      | 1     | S2                      |
| S3                        | X      | X     | S0                      |

**S** : Current State  
**S'** : Next State



# FSM Encoded State Transition Table

| Current State |       | Inputs |       | Next State |        |
|---------------|-------|--------|-------|------------|--------|
| $S_1$         | $S_0$ | $T_A$  | $T_B$ | $S'_1$     | $S'_0$ |
| S0            |       | 0      | X     | S1         |        |
| S0            |       | 1      | X     | S0         |        |
| S1            |       | X      | X     | S2         |        |
| S2            |       | X      | 0     | S3         |        |
| S2            |       | X      | 1     | S2         |        |
| S3            |       | X      | X     | S0         |        |

| State | Encoding |
|-------|----------|
| S0    | 00       |
| S1    | 01       |
| S2    | 10       |
| S3    | 11       |

# FSM Output Table

| Current State |       | Outputs  |          |          |          |
|---------------|-------|----------|----------|----------|----------|
| $S_1$         | $S_0$ | $L_{A1}$ | $L_{A0}$ | $L_{B1}$ | $L_{B0}$ |
| S0            |       | green    |          | red      |          |
| S1            |       | yellow   |          | red      |          |
| S2            |       | red      |          | green    |          |
| S3            |       | red      |          | yellow   |          |

| Output | Encoding |
|--------|----------|
| green  | 00       |
| yellow | 01       |
| red    | 10       |



# FSM Schematic



Next State Logic

$$S'_1 = S_1 \oplus S_0$$

$$S'_0 = \overline{S_1} \overline{S_0} \overline{T_A} + S_1 \overline{S_0} \overline{T_B}$$

State Register

Reset

Output Logic

$$L_{A1} = S_1$$

$$L_{A0} = \overline{S_1} S_0$$

$$L_{B1} = \overline{S_1}$$

$$L_{B0} = S_1 S_0$$



# FSM Timing Diagram



# State Encodings

- **Binary** encoding:
  - i.e., for four states, 00, 01, 10, 11
- **One-hot** encoding
  - One state bit per state
  - Only one state bit HIGH at once
  - i.e., for 4 states, 0001, 0010, 0100, 1000
  - Requires more flip-flops
  - Often next state and output logic is simpler



# 1-Hot State Encoding Example

| Current State |       |       |       | Inputs |       | Next State |        |        |        |
|---------------|-------|-------|-------|--------|-------|------------|--------|--------|--------|
| $S_3$         | $S_2$ | $S_1$ | $S_0$ | $T_A$  | $T_B$ | $S'_3$     | $S'_2$ | $S'_1$ | $S'_0$ |
| S0            |       |       |       | 0      | X     | S1         |        |        |        |
| S0            |       |       |       | 1      | X     | S0         |        |        |        |
| S1            |       |       |       | X      | X     | S2         |        |        |        |
| S2            |       |       |       | X      | 0     | S3         |        |        |        |
| S2            |       |       |       | X      | 1     | S2         |        |        |        |
| S3            |       |       |       | X      | X     | S0         |        |        |        |

| State | 1-Hot Encoding |
|-------|----------------|
| S0    | 0001           |
| S1    | 0010           |
| S2    | 0100           |
| S3    | 1000           |

$$S'_3 = S_2 \bar{T}_B$$

$$S'_2 = S_1 + S_2 T_B$$

$$S'_1 = S_0 \bar{T}_A$$

$$S'_0 = S_0 T_A + S_3$$



# Mealy FSM Examples



# Moore vs. Mealy FSMs

- Alyssa P. Hacker has a snail that crawls down a paper tape with 1's and 0's on it. The snail smiles whenever the last two digits it has crawled over are **01**. Design **Moore** and **Mealy** FSMs of the snail's brain.



# State Transition Diagrams

Moore FSM



Mealy FSM



S0: currently crawled over 1 but **no smile**  
S1: currently crawled over 0 and **no smile**  
S2: currently crawled over 1 and **smile**

S0: currently crawled over 1  
S1: currently crawled over 0

Whether encode output into state



# Moore FSM State Transition Table

| Current State |       | Inputs<br>$A$ | Next State |        |
|---------------|-------|---------------|------------|--------|
| $S_1$         | $S_0$ |               | $S'_1$     | $S'_0$ |
| 0             | 0     | 0             |            |        |
| 0             | 0     | 1             |            |        |
| 0             | 1     | 0             |            |        |
| 0             | 1     | 1             |            |        |
| 1             | 0     | 0             |            |        |
| 1             | 0     | 1             | -          |        |

| State | Encoding |
|-------|----------|
| S0    | 00       |
| S1    | 01       |
| S2    | 10       |



# Moore FSM Output Table

| Current State |       | Output |
|---------------|-------|--------|
| $S_1$         | $S_0$ | $Y$    |
| 0             | 0     |        |
| 0             | 1     |        |
| 1             | 0     |        |

| State | Encoding |
|-------|----------|
| S0    | 00       |
| S1    | 01       |
| S2    | 10       |

$$Y = S_1 \bar{S_0}$$

## Moore FSM



# Mealy State Transition & Output Table

| Current State | Input | Next State | Output |
|---------------|-------|------------|--------|
| $S_0$         | $A$   | $S'_0$     | $Y$    |
| 0             | 0     |            |        |
| 0             | 1     |            |        |
| 1             | 0     |            |        |
| 1             | 1     |            |        |

| State | Encoding |
|-------|----------|
| $S_0$ | 0        |
| $S_1$ | 1        |

$$S'_0 = \overline{A}$$
$$Y = S_0 A$$



# Moore FSM Schematic

- **Next State Equations**

- $S_1' = S_0 A$
- $S_0' = A$

- **Output Equation**
- $Y = S_1$



# Mealy FSM Schematic

- **Next State Equation**
- $S_0' = A$
- **Output Equation**
- $Y = S_0 A$



# Moore and Mealy Timing Diagram



**Mealy FSM:** asserts Y **immediately** when input pattern 01 is detected

**Moore FSM:** asserts Y one cycle **after** input pattern 01 is detected

# Timing



# Timing

- Flip-flop samples  $D$  at clock edge
- **$D$  must be stable when sampled**
- Similar to a photograph,  $D$  must be stable around clock edge



# Input Timing Constraints

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



# Output Timing Constraints

- **Propagation delay:**  $t_{pcq}$  = time after clock edge that Q is guaranteed to be stable (i.e., to stop changing): **maximum delay**
- **Contamination delay:**  $t_{ccq}$  = time after clock edge that Q might be unstable (i.e., start changing): **minimum delay**



# Dynamic Discipline

- Synchronous sequential circuit inputs must be **stable during aperture** (setup and hold) time around clock edge
- Specifically, inputs must be stable
  - at least  $t_{\text{setup}}$  before the clock edge
  - at least until  $t_{\text{hold}}$  after the clock edge



# Dynamic Discipline

- The delay between registers has a **minimum** and **maximum** delay, dependent on the delays of the circuit elements



# Setup Time Constraint

- Depends on the **maximum** delay from register R1 through combinational logic to R2
- The input to register R2 must be stable at least  $t_{\text{setup}}$  before clock edge



Also called:  
**Cycle Time Constraint**

$$T_c \geq t_{\text{pcq}} + t_{\text{pd}} + t_{\text{setup}}$$
$$T_c - (t_{\text{pcq}} + t_{\text{setup}})$$

$(t_{\text{pcq}} + t_{\text{setup}})$ :  
*sequencing overhead*



# Hold Time Constraint

- Depends on the **minimum** delay from register R1 through the combinational logic to R2
- The input to register R2 must be stable for at least  $t_{hold}$  after the clock edge



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



# Timing Analysis

- Calculate **both constraints**:
  - **Setup time** constraint (aka cycle time constraint)
  - **Hold time** constraint
- If the hold time constraint isn't met, the circuit **won't work reliably at any frequency**



# Timing Analysis Example



$$t_{pd} = 3 \times 35 \text{ ps} = 105 \text{ ps}$$

$$t_{cd} = 25 \text{ ps}$$

## Setup time constraint:

$$T_c \geq t_{pcq} + t_{pd} + t_{setup}$$

$$f_c = 1/T_c = 4.65 \text{ GHz}$$

## Timing Characteristics

|                   |             |         |
|-------------------|-------------|---------|
| <b>Flip-Flops</b> | $t_{ccq}$   | = 30 ps |
|                   | $t_{pcq}$   | = 50 ps |
|                   | $t_{setup}$ | = 60 ps |
|                   | $t_{hold}$  | = 70 ps |

|                                   |          |         |
|-----------------------------------|----------|---------|
| <b>Logic delays:<br/>per gate</b> | $t_{pd}$ | = 35 ps |
|                                   | $t_{cd}$ | = 25 ps |

## Hold time constraint:

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

$$(30 + 25) \text{ ps} > 70 \text{ ps} ?$$

Won't run reliably at any †



# Timing Analysis Example

How to fix?



$$t_{pd} = 3 \times 35 \text{ ps} = 105 \text{ ps}$$

$$t_{cd} = 25 \text{ ps}$$

Setup time constraint:

$$T_c \geq (50 + 105 + 60) \text{ ps} = 215 \text{ ps}$$

$$f_c = 1/T_c = 4.65 \text{ GHz}$$

Timing Characteristics

|            |                    |         |
|------------|--------------------|---------|
| Flip-Flops | $t_{ccq}$          | = 30 ps |
|            | $t_{pcq}$          | = 50 ps |
|            | $t_{\text{setup}}$ | = 60 ps |
|            | $t_{\text{hold}}$  | = 70 ps |

Logic delays:  
per gate

|          |         |
|----------|---------|
| $t_{pd}$ | = 35 ps |
| $t_{cd}$ | = 25 ps |

Hold time constraint:

$$t_{ccq} + t_{cd} > t_{\text{hold}} ?$$

$$(30 + 50) \text{ ps} > 70 \text{ ps} ?$$



# Chapter Review

- ❑ (Synchronous) Sequential Logic Counters

- ❑ Finite State Machine

- ❑ Moore FSM

- ❑ Mealy FSM

- ❑ Timing

- ❑ Setup time

- ❑ Hold time

- ❑ Aperture time

- ❑ Propagation delay

- ❑ Contamination delay

- ❑ Dynamic Discipline



# True/False Quiz

-  A state machine is a sequential circuit having a limited number of states occurring in a prescribed order.
-  FSM consists of a state register and combinational logic.
-  For a synchronous sequential circuit, all registers receive the same clock.
-  2-bit is required to encode 4 states by using one-hot encoding.
-  For the Moore FSM, outputs depend only on current state.
-  The setup time is the minimum amount of time that the input signal must be stable before the active clock edge to ensure that the data is correctly captured by the register.
-  The hold time is the minimum amount of time that the input signal must remain stable after the active clock edge to ensure that the data is reliably captured by the flip-flop or register.

