## SEE 3243

# FSM Modelling \& Systematic Realization II 

```
Lecturers:
Muhammad Mun'im Ahmad Zabidi
Muhammad Nadzir Marsono
Kamal Khalil
```

Week 10

- Vending Machine Example
■Finite String Pattern Recognizer
-Traffic Light Controller
■Digital Combination Lock


## FINITE STATE MACHINE WORD PROBLEMS

Mapping English Language Description to Formal Specifications
This Week we'll cover applications of FSM as controller:
Two part design: Data Path + Controller
Four Case Studies:
Vending Machine
Finite String Pattern Recognizer
Traffic Light Controller
Digital Combination Lock

## REVIEW OF DESIGN STEPS

Obtain specification of the desired circuit.
Create a state diagram from specification.
Create a state table from state diagram.
Perform state minimization.
Perform state assignment.
Derive the next-state logic expressions.
Implement circuit described by logic.

## Example: Vending Machine FSM

## General Machine Concept:

$\square$ deliver package of gum after 15 cents deposited
$\square$ single coin slot for dimes, nickels
$\square$ no change

Step 1. Understand the problem: Draw a picture!

Block Diagram


## Vending Machine Example



Tabulate typical input sequences three nickels nickel, dime dime, nickel two dimes two nickels, dime

Draw state diagram:
Inputs: N, D, reset
Output: open


## Vending Machine Controller

reuse states whenever possible


| Present State | Inputs |  | Next State | $\begin{array}{\|l\|} \hline \text { Output } \\ \hline \text { OPEN } \\ \hline \end{array}$ |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | D | N |  |  |  |
| 0¢ | 0 | 0 | 0¢ | 0 |  |
|  | 0 | 1 | 5¢ | 0 |  |
|  | 1 | 0 | 10¢ | 0 |  |
|  | 1 | 1 | X | 0 |  |
| $5 ¢$ | 0 | 0 | 5¢ | 0 |  |
|  | 0 | 1 | 10¢ | 0 |  |
|  | 1 | 0 | 15¢ | 0 |  |
|  | 1 | 1 | X | 0 |  |
| 10¢ | 0 | 0 | 10¢ | 0 |  |
|  | 0 | 1 | 15¢ | 0 |  |
|  | 1 | 0 | 15¢ | 0 |  |
|  | 1 | 1 | 15¢ | 0 | We can assume X for Next State actually |
| 15¢ | X | X | 15¢ | 1 |  |

## Vending Machine Controller

"simple" binary easiest to understand

| Present State |  | Inputs |  | Next State |  | Output |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $Q_{1}$ | $Q_{0}$ | D | N | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ | OPEN |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 |
|  |  | 0 | 1 | 0 | 1 | 0 |
|  |  | 1 | 0 | 1 | 0 | 0 |
|  |  | 1 | 1 | X | X | 0 |
| 0 | 1 | 0 | 0 | 0 | 1 | 0 |
|  |  | 0 | 1 | 1 | 0 | 0 |
|  |  | 1 | 0 | 1 | 1 | 0 |
|  |  | 1 | 1 | X | X | 0 |
| 1 | 0 | 0 | 0 | 1 | 0 | 0 |
|  |  | 0 | 1 | 1 | 1 | 0 |
|  |  | 1 | 0 | 1 | 1 | 0 |
|  |  | 1 | 1 | 1 | 1 | 0 |
| 1 | 1 | X | X | 1 | 1 | 1 |

## Vending Machine Example

D FF easiest to use





$$
\begin{aligned}
& \mathrm{D} 1=\mathrm{Q} 1+\mathrm{D}+\mathrm{Q}_{0} \bullet \mathrm{~N} \\
& \mathrm{D} 0=\mathrm{N} \bullet \mathrm{Q}_{0}^{\prime}+\mathrm{Q}_{0} \bullet \mathrm{~N}^{\prime}+\mathrm{Q}_{1} \bullet \mathrm{~N}+\mathrm{Q}_{1} \bullet \mathrm{D} \\
& \mathrm{OPEN}=\mathrm{Q}_{1} \bullet \mathrm{Q}_{0}
\end{aligned}
$$

## Vending Machine Controller

$\square$ In FPGA/VLSI, DFF is most efficient.
$\square$ JKFF must be constructed using DFF plus a few gates.
$\square$ Run away from JKFF if possible!
$\square$ Different story when using discrete chips (BUT WHO DOES?)

| Excitation Table |  |  |  |
| :---: | :---: | :---: | :---: |
| Q | Q+ | J | K |
| 0 | 0 | 0 | X |
| 0 | 1 | 1 | X |
| 1 | 0 | X | 1 |
| 1 | 1 | X | 0 |


| $\begin{aligned} & \hline \text { Present } \\ & \text { State } \end{aligned}$ |  | Inputs |  | Next State |  | $\mathrm{J}_{1}$ | $\mathrm{K}_{1}$ | $\mathrm{J}_{0}$ | $\mathrm{K}_{0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{Q}_{1}$ | $\mathrm{Q}_{0}$ | D | N | $\mathrm{Q}^{+}{ }_{1}$ | $\mathrm{Q}^{+}{ }_{0}$ |  |  |  |  |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | X | 0 | X |
|  |  | 0 | 1 | 0 | 1 | 0 | X | 1 | X |
|  |  | 1 | 0 | 1 | 0 | 1 | X | 0 | X |
|  |  | 1 | 1 | X | X | X | X | X | X |
| 0 | 1 | 0 | 0 | 0 | 1 | 0 | X | X | 0 |
|  |  | 0 | 1 | 1 | 0 | 1 | X | X | 1 |
|  |  | 1 | 0 | 1 | 1 | 1 | X | X | 0 |
|  |  | 1 | 1 | X | X | X | X | X | X |
| 1 | 0 | 0 | 0 | 1 | 0 | X | 0 | 0 | X |
|  |  | 0 | 1 | 1 | 1 | X | 0 | 1 | X |
|  |  | 1 | 0 | 1 | 1 | X | 0 | 1 | X |
|  |  | 1 | 1 | X | X | X | X | X | X |
| 1 | 1 | X | X | 1 | 1 | X | 0 | X | 0 |

Remapped encoded state transition table

## Vending Machine Example



$$
\begin{aligned}
& \mathrm{J} 1=\mathrm{D}+\mathrm{Q}_{0} \bullet \mathrm{~N} \\
& \mathrm{~K} 1=0 \\
& \mathrm{~K} 0=\mathrm{Q}_{0} \cdot \mathrm{~N}+\mathrm{Q}_{1} \bullet \mathrm{D} \\
& \mathrm{~K} 1=\mathrm{Q}_{1} \cdot \mathrm{~N} \\
& \text { OPEN }=\mathrm{Q}_{1} \bullet \mathrm{Q}_{0}
\end{aligned}
$$



## Moore \& Mealy State Diagram Equivalents

Back to Vending Machine Example

Moore
Machine


Outputs are associated with State


Mealy
Machine

Outputs are associated with Transitions

## Finite String Pattern Recognizer

- A finite string recognizer has one input ( X ) and one output ( $Z$ ). The output is asserted whenever the input sequence ...010... has been observed, as long as the sequence 100 has never been seen.
- Step 1. Understanding the problem statement
- Sample input/output behavior:

X: 00101010010...
Z: 00010101000...
X: 11011010010...
Z: 00000001000...

## Finite String Pattern Recognizer

Step 2. Draw State Diagrams/ASM Charts for the strings that must be recognized. i.e., 010 and 100.


## Finite String Pattern Recognizer

Exit conditions from state S3: have recognized ... 010
if next input is 0 then have ... 0100 !
if next input is 1 then have $. .0101=\ldots 01$ (state S2)


## Finite String Pattern Recognizer

Exit conditions from S 1 : recognizes strings of form ... 0 (no 1 seen) loop back to S 1 if input is 0

Exit conditions from S4: recognizes strings of form ... 1 (no 0 seen) loop back to S4 if input is 1


## Finite String Pattern Recognizer

S2, S5 with incomplete transitions
$\mathrm{S} 2=\ldots 01$; If next input is 1 , then string could be prefix of (01)1(00) S4 handles just this case!

S5 = ...10; If next input is 1 , then string could be prefix of (10)1(0) S 2 handles just this case!


Final State Diagram

## Finite String Pattern Recognizer

- Review of Process:
- Write down sample inputs and outputs to understand specification
- Write down sequences of states and transitions for the sequences to be recognized
- Add missing transitions; reuse states as much as possible
- Verify I/O behavior of your state diagram to insure it functions like the specification


## Traffic Light Controller

- A busy highway is intersected by a little used farmroad. Detectors C sense the presence of cars waiting on the farmroad. With no car on farmroad, light remain green in highway direction. If vehicle on farmroad, highway lights go from Green to Yellow to Red, allowing the farmroad lights to become green. These stay green only as long as a farmroad car is detected but never longer than a set interval.
- When these are met, farm lights transition from Green to Yellow to Red, allowing highway to return to green. Even if farmroad vehicles are waiting, highway gets at least a set interval as green.
- Assume you have an interval timer that generates a short time pulse (TS) and a long time pulse ( TL ) in response to a set (ST) signal. TS is to be used for timing yellow lights and TL for green lights.


## Traffic Light Controller

Picture of Highway/Farmroad Intersection:


## Traffic Light Controller

- Tabulation of Inputs and Outputs:

```
Input Signal
reset
C
TS
TL
```

Output Signal
HG, HY, HR
FG, FY, FR
ST

Description
place FSM in initial state detect vehicle on farmroad short time interval expired long time interval expired

Description
assert green/yellow/red highway lights assert green/yellow/red farmroad lights start timing a short or long interval

- Tabulation of Unique States: Some light configuration imply others

State
SO
S1
S2
S3

Description
Highway green (farmroad red)
Highway yellow (farmroad red)
Farmroad green (highway red)
Farmroad yellow (highway red)

## Traffic Light Controller



## Door combination lock

- General specs:
- punch in 3 values in sequence and the door opens; if there is an error the lock must be reset; once the door opens the lock must be reset
- Inputs:
- sequence of input values, reset
- Outputs:
- door open/close
- Memory:
- must remember combination or always have it available as an input


## Door combination lock: initial STD

- State diagram
- States: 5 states
- represent point in execution of machine
- each state has outputs
- Transitions: 6 from state to state, 5 self transitions, 1 global
- changes of state occur when clock says it's ok
- based on value of inputs
- Inputs: reset, new, results of comparisons
- Output: open/closed



## Door comb. lock : data-path vs. control

- Internal structure
- data-path
- storage for combination
- comparators
- control
- finite-state machine controller
- control for data-path
- state changes controlled by clock



## Door combination lock: Final STD

- Finite-state machine
- refine state diagram to include internal structure



## Door combination lock: STT

- Finite-state machine
- generate state table (much like a truth-table)


| reset | new | equal | state | next |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| state | mux | open/closed |  |  |  |  |
| 1 | - | - | - | S1 | $C 1$ | closed |
| 0 | 0 | - | S1 | S1 | $C 1$ | closed |
| 0 | 1 | 0 | S1 | ERR | - | closed |
| 0 | 1 | 1 | S1 | S2 | $C 2$ | closed |
| 0 | 0 | - | S2 | S2 | $C 2$ | closed |
| 0 | 1 | 0 | S2 | ERR | - | closed |
| 0 | 1 | 1 | S2 | S3 | $C 3$ | closed |
| 0 | 0 | - | S3 | S3 | $C 3$ | closed |
| 0 | 1 | 0 | S3 | ERR | - | closed |
| 0 | 1 | 1 | S3 | OPEN | - | open |
| 0 | - | - | OPEN | OPEN | - | open |
| 0 | - | - | ERR | ERR | - | closed |

## Door combination lock: encoding

- Encode state table
- state can be: S1, S2, S3, OPEN, or ERR
- needs at least 3 bits to encode: 000, 001, 010, 011, 100
- and as many as 5: 00001, 00010, 00100, 01000, 10000
- choose 4 bits: 0001, 0010, 0100, 1000, 0000
- output mux can be: C1, C2, or C3
- needs 2 to 3 bits to encode
- choose 3 bits: 001, 010, 100
- output open/closed can be: open or closed
- needs 1 or 2 bits to encode
- choose 1 bits: 1, 0


## Door combination lock: encoding

- Encode state table
- state can be: S1, S2, S3, OPEN, or ERR
- choose 4 bits: 0001, 0010, 0100, 1000, 0000
- output mux can be: C1, C2, or C3
- choose 3 bits: 001, 010, 100
- output open/closed can be: open or closed
- choose 1 bits: 1, 0

| reset | new | equal | state | next <br> state | mux | open/closed |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | - | - | - | 0001 | 001 | 0 |  |
| 0 | 0 | - | 0001 | 0001 | 001 | 0 |  |
| 0 | 1 | 0 | 0001 | 0000 | - | 0 | good choice of encoding! |
| 0 | 1 | 1 | 0001 | 0010 | 010 | 0 |  |
| 0 | 0 | - | 0010 | 0010 | 010 | 0 | mux is identical to |
| 0 | 1 | 0 | 0010 | 0000 | - | 0 | last 3 bits of state |
| 0 | 1 | 1 | 0010 | 0100 | 100 | 0 |  |
| 0 | 0 | - | 0100 | 0100 | 100 | 0 | open/closed is |
| 0 | 1 | 0 | 0100 | 0000 | - | 0 | identical to first bit |
| 0 | 1 | 1 | 0100 | 1000 | - | 1 | of state |
| 0 | - | - | 1000 | 1000 | - | 1 |  |
| 0 | - | - | 0000 | 0000 | - | 0 |  |

## Door combination lock: controller implementation

- Implementation of the controller


| special circuit element, |
| :--- |
| called a register, for |
| remembering inputs |
| when told to by clock |



## Design hierarchy



## Chapter Review

- Word Problems
- understand I/O behavior; draw diagrams
- enumerate states for the "goal"; expand with error conditions
- reuse states whenever possible
- First Two Steps of the Six Step Procedure for FSM Design
- understanding the problem
- abstract representation of the FSM

