Finite State Machines (FSM)

Chapter 8
State Machines
Introduction

- From the previous chapter we can make simple memory elements.
  - Latches as well as latches with control signals
  - Flip-flops
  - Registers
- The goal now is to use the memory elements to hold the running state of the machine.
  - The state of the machine can be used to perform sequential operations.
  - This chapter will discuss how to represent the state of the machine for design and communication purposes.
State Machines
Mealy and Moore Machines

- **Mealy machine**
  - Sequential system where output depends on current input and state.

- **Moore machine**
  - Sequential system where output depends only on current state.
State Machines
Synchronous & Asynchronous Systems

- **Synchronous sequential system**
  - Behaviour depends on the inputs and outputs at discrete instants of time.
  - Flip-flops, registers, and latches that are enabled/controlled with a signal derived from clock form a synchronous sequential system.

- **Asynchronous sequential system**
  - Behaviour depends on inputs at any instant of time.
  - Latches without control signals behave in an asynchronous manner.

- The state machines discussed in this chapter will be synchronous sequential systems (i.e. controlled by a clock)
  - This allows us to form timed Boolean functions such as
    - \( N(t) = D_A(t+1) \) where \( N \) is the next state of a D flip-flop \( D_A \).
State Diagrams
Elements of Diagrams

- A state diagram represents a finite state machine (FSM) and contains
  - **Circles**: represent the machine states
    - Labelled with a binary encoded number or $S_k$ reflecting state.
  - **Directed arcs**: represent the transitions between states
    - Labelled with input/output for that state transition.

State Diagram:

```
State: $S_k$  State: $S_j$

Input/Output:
- $a/p$ in state $S_k$
- $b/q$ in state $S_j$

Input: $x(t) \in \{a, b\}$
Output: $z(t) \in \{p, q\}$
State: $s(t) \in \{S_k, S_j\}$
Initial state: $s(0) = S_k$
```
State Diagrams
Properties

- Some restrictions that are placed on the state diagrams:
  - FSM can only be in **one state at a time**!
    - Therefore, only in one state, or one circle, at a time.
  - State transitions are followed only **on clock cycles**. (synchronous!)

- Mealy machines and Moore machines can be labelled differently.
  - **Mealy machine**: Since output depends on state and inputs:
    - Label directed arcs with **input/output** for that state transition.
  - **Moore machine**: Since output depends only on state:
    - Label directed arcs with **input** for that state transition.
    - Label state circles with $S_k$/**output**.
State Diagrams
State Diagram Examples

- The following is a simple example. What does this state machine do?

![State Diagram](image)

- Here is a simplified way of forming the above state machine.

![Simplified State Diagram](image)

- An input of 0 or 1 causes the transition with output 1 and 0, respectively.
State Diagrams

Bit Flipper Examples

- Consider the simple bit flipper looked at in previous chapter. How would a state diagram be formed?
- Below is one possible way of drawing the state diagram for the bit flipper.

- Since the bit flipper is a Moore machine, the state diagram can also be
State Diagrams
Pattern Detection Examples

• Suppose we want a sequential system that has the following behaviour

  Input: \( x(t) \in \{0, 1\} \)

  Output: \( z(t) \in \{0, 1\} \)

  Function: \( z(t) = \begin{cases} 1 & \text{if } x(t - 3, t) = 1101 \\ 0 & \text{otherwise} \end{cases} \)

• Effectively, the system should output a 1 when the last set of four inputs have been 1101.

• For instance, the following output \( z(t) \) is obtained for the input \( x(t) \)

<table>
<thead>
<tr>
<th>( t )</th>
</tr>
</thead>
<tbody>
<tr>
<td>0123456789...</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>( x(t) )</th>
<th>100100100100110101101101001101001</th>
</tr>
</thead>
<tbody>
<tr>
<td>( z(t) )</td>
<td>???00000000000001000010010000001000</td>
</tr>
</tbody>
</table>
The following state diagram gives the behaviour of the desired 1101 pattern detector.

Consider $S_0$ to be the initial state, $S_1$ when first symbol detected (1), $S_2$ when subpattern 11 detected, and $S_3$ when subpattern 110 detected.
State Tables

Introduction

- State tables also express a systems behaviour and consists of
  - Present state
    - The present state of the system, typically given in binary encoded form or with $S_k$. So, a state of $S_5$ in our state diagram with 10 states would be represented as 0101 since we require 4 bits.
  - Inputs
    - Whatever external inputs used to cause the state transitions.
  - Next state
    - The next state, generally in binary encoded form.
  - Outputs
    - Whatever outputs, other then the state, for the system. Note that there would be no outputs in a Moore machine.
State Tables
Bit Flipper Example

- Consider again the bit flipper example with state diagram

![State Diagram]

- The state table for this state diagram would be

<table>
<thead>
<tr>
<th>Present State</th>
<th>Input</th>
<th>Next State</th>
<th>Output</th>
</tr>
</thead>
<tbody>
<tr>
<td>$S_0$ or 0</td>
<td>-</td>
<td>1</td>
<td>-</td>
</tr>
<tr>
<td>$S_1$ or 1</td>
<td>-</td>
<td>0</td>
<td>-</td>
</tr>
</tbody>
</table>
State Tables
Translate From Diagram

- From a state diagram, a state table is fairly easy to obtain.
  - Determine the number of states in the state diagram.
  - If there are $m$ states and $n$ 1-bit inputs, then there will be $m2^n$ rows in the state table.
    - Example: If there are 3 states and 2 1-bit inputs, each state will have $2^2 = 4$ possible inputs, for a total of 3*4=12 rows.
  - Write out for each state, the $2^n$ possible input rows.
  - For each state/input pair, follow the directed arc in the state diagram to determine the next state and the output.
State Tables
Pattern Detect Example

- If we consider the pattern detection example previously discussed, the following would be the state table.

<table>
<thead>
<tr>
<th>Present State</th>
<th>Input X</th>
<th>Next State</th>
<th>Output Z</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>P₁  P₀</td>
<td></td>
<td></td>
</tr>
<tr>
<td>S₀ or</td>
<td>0  0</td>
<td>0</td>
<td>S₀ or 0</td>
</tr>
<tr>
<td>S₀ or</td>
<td>0  0</td>
<td>1</td>
<td>S₁ or 0</td>
</tr>
<tr>
<td>S₁ or</td>
<td>0  1</td>
<td>0</td>
<td>S₀ or 0</td>
</tr>
<tr>
<td>S₁ or</td>
<td>0  1</td>
<td>1</td>
<td>S₂ or 1</td>
</tr>
<tr>
<td>S₂ or</td>
<td>1  0</td>
<td>0</td>
<td>S₃ or 1</td>
</tr>
<tr>
<td>S₂ or</td>
<td>1  0</td>
<td>1</td>
<td>S₂ or 1</td>
</tr>
<tr>
<td>S₃ or</td>
<td>1  1</td>
<td>0</td>
<td>S₀ or 0</td>
</tr>
<tr>
<td>S₃ or</td>
<td>1  1</td>
<td>1</td>
<td>S₁ or 0</td>
</tr>
</tbody>
</table>
State Tables
Translate to Diagram

- If given a state table, the state diagram can be developed as follows.
  - Determine the number of states in the table and draw a state circle corresponding to each one.
    - Label the circle with the state name for a Mealy machine.
    - Label the circle with the state name/output for a Moore machine.
  - For each row in the table, identify the present state circle and draw a directed arc to the next state circle.
    - Label the arc with the input/output pair for a Mealy machine.
    - Label the arc with the input for a Moore machine.
Sequential Circuits
Introduction

- With the descriptions of a FSM as a state diagram and a state table, the next question is how to develop a sequential circuit, or logic diagram from the FSM.
- Effectively, we wish to form a circuit as follows.
Sequential Circuits
From State Table

- The procedure for developing a logic circuit from a state table is the same as with a regular truth table.
- Generate Boolean functions for
  - each external outputs using external inputs and present state bits
  - each next state bit using external inputs and present state bits
- Use Boolean algebra, Karnaugh maps, etc. as normal to simplify.
- Draw a register for each state bit.
- Draw logic diagram components connecting external outputs to external inputs and outputs of state bit registers (which have the present state).
- Draw logic diagram components connecting inputs of state bits (for next state) to the external inputs and outputs of state bit registers (which have the present state).
Sequential Circuits
Pattern Detect Example

- Following the procedure outlined, Boolean functions for the pattern detector state table can be formed using Karnaugh maps as follows.

\[
\begin{align*}
N_1 &= X\overline{P_1} + \overline{X}P_1P_0 \\
N_0 &= \overline{X}\overline{P_1}P_0 + XP_1P_0 + \overline{X}P_1\overline{P_0} = \overline{X}\overline{P_1}P_0 + X(\overline{P_1} \oplus \overline{P_0}) \\
Z &= XP_1P_0
\end{align*}
\]
Sequential Circuits
Pattern Detect Example

• Notice that the previous Boolean functions can also be expressed with time as follows.

\[ N_1(t) = P_1(t+1) = X(t) \cdot \overline{P_1(t)} + \overline{X(t)} \cdot P_1(t) \cdot P_0(t) \]
\[ N_0(t) = P_0(t+1) = \overline{X(t)} \cdot \overline{P_1(t)} \cdot P_0(t) + X(t) \cdot P_1(t) \cdot P_0(t) \]
\[ \quad \quad \quad \quad \quad \quad \quad \quad \quad \quad \quad \quad \quad + X(t) \cdot \overline{P_1(t)} \cdot \overline{P_0(t)} \]
\[ \quad \quad \quad \quad \quad \quad \quad \quad \quad \quad \quad \quad \quad = \overline{X(t)} \cdot \overline{P_1(t)} \cdot P_0(t) + X(t) \cdot \overline{P_1(t)} \oplus P_0(t) \]
\[ Z(t) = X \cdot P_1(t) \cdot P_0(t) \]

• An important thing to note in these equations is the relation between the present states P and the next states N.
Sequential Circuits
Pattern Detect Example

- The following logic circuit implements the pattern detect example.
FSM Examples
Example #1

- Consider the following system description.
  - A sequential system has
    - One input = \{a, b, c\}
    - One output = \{p, q\}
  - Output is
    - q when input sequence has even # of a’s and odd # of b’s
    - p otherwise
FSM Examples
Example #1

• We can begin forming a state machine for the system description by reviewing the possible states. In addition, assign each state a state name.
  • $S_{EE}$: even # of a's and even # of b's / output is $p$
  • $S_{EO}$: even # of a's and odd # of b's / output is $q$
  • $S_{OO}$: odd # of a's and odd # of b's / output is $p$
  • $S_{OE}$: odd # of a's and even # of b's / output is $p$

• Note that this machine can be a Moore machine. So, we can associate the output with each state.
FSM Examples

Example #1

- Now draw a circle with each state.

$S_{EE}/p$  $S_{EO}/q$  $S_{OO}/p$  $S_{OE}/p$
Finally, for each state, consider the effect for each possible input.

For instance, starting with state $S_{EE}$, the next state for the three input $a$, $b$, and $c$ are determined as follows.

```
$S_{EE}/p$ -- b --> $S_{EO}/q$

$S_{EO}/p$ -- a --> $S_{OE}/p$
```

$S_{OO}/p$
FSM Examples
Example #1

- Finishing the state diagram, the following is obtained.
FSM Examples
Example #1

- A state table can also be formed for this state diagram as follows.
  - First, assign a binary number to each state
    - $S_{EE} = 00$, $S_{EO} = 01$, $S_{OO} = 10$, $S_{OE} = 11$
  - Assign a binary number to each input
    - $a = 00$, $b = 01$, $c = 10$
  - Assign a binary number to each output
    - $p = 0$, $q = 1$
  - Then for each state, find the next state for each input. In this case there are three possible input values, so, three possible state transitions from each state.
  - The state table on the following slide shows the results for this example.
**FSM Examples**

**Example #1**

<table>
<thead>
<tr>
<th>Present State $P_0$</th>
<th>Input $X$</th>
<th>Next State $N_1$</th>
<th>Output $Z$</th>
</tr>
</thead>
<tbody>
<tr>
<td>$S_{EE} = 0$</td>
<td>$a = 00$</td>
<td>$S_{OE} = 1$</td>
<td>$p = 0$</td>
</tr>
<tr>
<td>$S_{EE} = 0$</td>
<td>$b = 01$</td>
<td>$S_{EO} = 0$</td>
<td>$p = 0$</td>
</tr>
<tr>
<td>$S_{EE} = 0$</td>
<td>$c = 10$</td>
<td>$S_{EE} = 0$</td>
<td>$p = 0$</td>
</tr>
<tr>
<td>$S_{EO} = 0$</td>
<td>$a = 00$</td>
<td>$S_{OO} = 1$</td>
<td>$q = 1$</td>
</tr>
<tr>
<td>$S_{EO} = 0$</td>
<td>$b = 01$</td>
<td>$S_{EE} = 0$</td>
<td>$q = 1$</td>
</tr>
<tr>
<td>$S_{EO} = 0$</td>
<td>$c = 10$</td>
<td>$S_{EO} = 0$</td>
<td>$q = 1$</td>
</tr>
<tr>
<td>$S_{EO} = 0$</td>
<td>$a = 00$</td>
<td>$S_{OO} = 1$</td>
<td>$q = 1$</td>
</tr>
<tr>
<td>$S_{EO} = 0$</td>
<td>$b = 01$</td>
<td>$S_{OE} = 1$</td>
<td>$p = 0$</td>
</tr>
<tr>
<td>$S_{EO} = 0$</td>
<td>$c = 10$</td>
<td>$S_{EE} = 0$</td>
<td>$p = 0$</td>
</tr>
<tr>
<td>$S_{EO} = 0$</td>
<td>$a = 00$</td>
<td>$S_{EO} = 0$</td>
<td>$p = 0$</td>
</tr>
<tr>
<td>$S_{EO} = 0$</td>
<td>$b = 01$</td>
<td>$S_{OE} = 1$</td>
<td>$p = 0$</td>
</tr>
<tr>
<td>$S_{EO} = 0$</td>
<td>$c = 10$</td>
<td>$S_{EO} = 0$</td>
<td>$p = 0$</td>
</tr>
<tr>
<td>$S_{OE} = 1$</td>
<td>$a = 00$</td>
<td>$S_{EE} = 0$</td>
<td>$p = 0$</td>
</tr>
<tr>
<td>$S_{OE} = 1$</td>
<td>$b = 01$</td>
<td>$S_{OE} = 0$</td>
<td>$p = 0$</td>
</tr>
<tr>
<td>$S_{OE} = 1$</td>
<td>$c = 10$</td>
<td>$S_{OE} = 0$</td>
<td>$p = 0$</td>
</tr>
</tbody>
</table>
FSM Examples
Example #1

- The Boolean function for the output can be determined from a Karnaugh map as follows.
- Note that an input of 11 is not possible since we only have three inputs that we have assigned to 00, 01, and 10. We can therefore use don’t cares for this possible input.

\[
\begin{array}{c|cccc}
X_1X_0 & 00 & 01 & 11 & 10 \\
\hline
00 & 0 & 1 & 0 & 0 \\
01 & 0 & 1 & 0 & 0 \\
11 & X & X & X & X \\
10 & 0 & 1 & 0 & 0 \\
\end{array}
\]

\[Z = \overline{P_1}P_0\]
FSM Examples
Example #1

- The Boolean function for the next state bit can also be determined from Karnaugh maps as follows.

\[ N_1 = \overline{P_1} \oplus X_1 \oplus X_0 \]

\[ N_0 = P_0 \overline{X_1} + P_0 X_1 = \overline{P_0} \oplus X_1 \]
FSM Examples

Example #1

- The following logic circuit can be made with these Boolean functions.

\[
N_1 = P_1 \oplus X_1 \oplus X_0 \\
N_0 = \overline{P_0} \oplus X_1 \\
Z = \overline{P_1}P_0
\]
FSM Examples
Example #2

- A sequential circuit is defined by the following Boolean functions with input $X$, present states $P_0$, $P_1$, and $P_2$, and next states $N_0$, $N_1$, and $N_2$.
- $N_2 = X(P_1 \oplus P_0) + \overline{X}(P_1 \oplus P_0)$
- $N_1 = P_2$
- $N_0 = P_1$
- $Z = XP_1P_2$
- Derive the state table.
- Derive the state diagram.
FSM Examples
Example #2

- The state table is formed as follows.

<table>
<thead>
<tr>
<th>Present State</th>
<th>Input X</th>
<th>Next State</th>
<th>Output Z</th>
</tr>
</thead>
<tbody>
<tr>
<td>P₂  P₁  P₀</td>
<td></td>
<td>N₂  N₁  N₀</td>
<td></td>
</tr>
<tr>
<td>0   0   0</td>
<td>0</td>
<td>1   0   0</td>
<td>0</td>
</tr>
<tr>
<td>0   0   0</td>
<td>1</td>
<td>0   0   0</td>
<td>0</td>
</tr>
<tr>
<td>0   0   1</td>
<td>0</td>
<td>1   0   0</td>
<td>0</td>
</tr>
<tr>
<td>0   0   1</td>
<td>1</td>
<td>0   0   0</td>
<td>0</td>
</tr>
<tr>
<td>0   1   0</td>
<td>0</td>
<td>0   0   1</td>
<td>0</td>
</tr>
<tr>
<td>0   1   0</td>
<td>1</td>
<td>1   0   1</td>
<td>0</td>
</tr>
<tr>
<td>0   1   1</td>
<td>0</td>
<td>1   0   1</td>
<td>0</td>
</tr>
<tr>
<td>0   1   1</td>
<td>1</td>
<td>0   0   1</td>
<td>0</td>
</tr>
<tr>
<td>1   0   0</td>
<td>0</td>
<td>0   1   0</td>
<td>0</td>
</tr>
<tr>
<td>1   0   0</td>
<td>1</td>
<td>1   1   0</td>
<td>0</td>
</tr>
<tr>
<td>1   0   1</td>
<td>0</td>
<td>0   1   0</td>
<td>0</td>
</tr>
<tr>
<td>1   0   1</td>
<td>1</td>
<td>1   1   0</td>
<td>0</td>
</tr>
<tr>
<td>1   1   0</td>
<td>0</td>
<td>0   1   1</td>
<td>0</td>
</tr>
<tr>
<td>1   1   0</td>
<td>1</td>
<td>1   1   1</td>
<td>0</td>
</tr>
<tr>
<td>1   1   1</td>
<td>0</td>
<td>0   1   1</td>
<td>1</td>
</tr>
<tr>
<td>1   1   1</td>
<td>1</td>
<td>1   1   1</td>
<td>0</td>
</tr>
</tbody>
</table>
FSM Examples
Example #2

- The state diagram can be drawn as follows.