

## FSM encoding

as truth table ↴

| Input state |   |       | next state output |   |    |
|-------------|---|-------|-------------------|---|----|
| 000         | 0 | $s_0$ | $s_3$             | 0 | 00 |
| 001         | 1 | $s_0$ | $s_1$             | 1 | 01 |
| 010         | 0 | $s_1$ | $s_2$             | 1 | 10 |
| 011         | 1 | $s_1$ | $s_3$             | 0 | 00 |
| 100         | 0 | $s_2$ | $s_3$             | 0 | 00 |
| 101         | 1 | $s_2$ | $s_1$             | 1 | 01 |
| 110         | 0 | $s_3$ | $s_3$             | 0 | 00 |
| 111         | 1 | $s_3$ | $s_3$             | 0 | 00 |

{ Input      }      { Output }

Output :

|       |   |                                                                        |
|-------|---|------------------------------------------------------------------------|
| $s_1$ | 1 | { 2 bits<br>↓<br>Some other<br>output doesn't<br>exist, e.g.: $s_2, 0$ |
| $s_2$ | 1 |                                                                        |
| $s_3$ | 0 |                                                                        |

Input :

{ Input bit }      { 4 states = 2 bits }

|   |       |                                                         |
|---|-------|---------------------------------------------------------|
| 0 | $s_0$ | { $H_2 =$<br>3 bits<br>in total to<br>encode<br>$I + S$ |
| 1 | $s_0$ |                                                         |
| 0 | $s_1$ |                                                         |
| 1 | $s_1$ |                                                         |
| 0 | $s_2$ |                                                         |
| 1 | $s_2$ |                                                         |
| 0 | $s_3$ |                                                         |
| 1 | $s_3$ |                                                         |

# FSM as ROM



implemented as ROM

fsm is a truth table

| $i_1, i_2, i_3$ | $O_1, O_2$ |
|-----------------|------------|
| 000             | 00         |
| 001             | 01         |
| 010             | 10         |
| 011             | 00         |
| 100             | 00         |
| 101             | 01         |
| 110             | 00         |
| 111             | 00         |

input      output

## Another FSM Example



$L/R = 0 \rightarrow$  white

$L/R = 1 \rightarrow$  black



# Another FSM Example



$L/R = 0 \rightarrow$  white

$L/R = 1 \rightarrow$  black

| Input             | State | Output | state |
|-------------------|-------|--------|-------|
| $L+R$             | $S_0$ | TR     | $S_1$ |
| $\bar{L}+\bar{R}$ | $S_0$ | F      | $S_0$ |
| $\bar{L}+R$       | $S_0$ | H      | $S_2$ |
| $L+\bar{R}$       | $S_0$ | H      | $S_2$ |
| $L+R$             | $S_1$ | TR     | $S_1$ |
| $\bar{L}+R$       | $S_1$ | H      | $S_2$ |
| $\bar{L}+\bar{R}$ | $S_1$ | TL     | $S_1$ |
| $L+\bar{R}$       | $S_1$ | F      | $S_1$ |
| any               | $S_2$ | H      | $S_2$ |



# Another FSM Example

$S_0$  00  
 $S_1$  01  
 $S_2$  10

| Input  | State               | Output state |    |             |
|--------|---------------------|--------------|----|-------------|
| 00 00  | L + R               | $S_0$        | TR | $S_1$ 01 01 |
| 11 00  | $\bar{L} + \bar{R}$ | $S_0$        | F  | $S_0$ 00 00 |
| 10 00  | $\bar{L} + R$       | $S_0$        | H  | $S_2$ 11 10 |
| 01 00  | $L + \bar{R}$       | $S_0$        | H  | $S_2$ 11 10 |
| 00 01  | L R                 | $S_1$        | TR | $S_1$ 01 01 |
| 10 01  | $\bar{L} + R$       | $S_1$        | H  | $S_2$ 11 10 |
| 11 01  | $\bar{L} + \bar{R}$ | $S_1$        | TL | $S_1$ 10 01 |
| 01 01  | $L + \bar{R}$       | $S_1$        | F  | $S_1$ 00 01 |
| 00 {0} | any                 | $S_2$        | H  | $S_2$ 11 10 |
| 01 10  |                     |              |    | 111 0       |
| 10 10  |                     |              |    | 111 0       |
| 11 10  |                     |              |    | 111 0       |

$L + R$  00  
 $L + \bar{R}$  01  
 $\bar{L} + R$  10  
 $\bar{L} + \bar{R}$  11  
  
 F 00  
 TR 01  
 TL 10  
 H 11

# Another FSM Example

4 bits input selector

|       | Input | State          |    | Output state         |
|-------|-------|----------------|----|----------------------|
| 00 00 | L + R | S <sub>0</sub> | TR | S <sub>1</sub> 01 01 |
| 11 00 | L + R | S <sub>0</sub> | F  | S <sub>0</sub> 00 00 |
| 10 00 | L + R | S <sub>0</sub> | H  | S <sub>2</sub> 11 10 |
| 01 00 | L + R | S <sub>0</sub> | H  | S <sub>2</sub> 11 10 |
| 00 01 | L + R | S <sub>1</sub> | TR | S <sub>1</sub> 01 01 |
| 10 01 | L + R | S <sub>1</sub> | H  | S <sub>2</sub> 11 10 |
| 11 01 | L + R | S <sub>1</sub> | TL | S <sub>1</sub> 00 01 |
| 11 01 | L + R | S <sub>1</sub> | F  | S <sub>1</sub> 00 01 |
| 01 01 | L + R | S <sub>1</sub> | H  | S <sub>2</sub> 11 10 |
| 00 10 | any   | S <sub>2</sub> |    | 11 10                |
| 01 10 |       |                |    | 11 10                |
| 10 10 |       |                |    | 11 10                |
| 11 11 |       |                |    | 11 10                |

4 output bits

4  
bits  
input  
selector



Task: take input N  
add 1 in binary  
can overwrite \$ if overflow



| Sin | Input | Snext | write | move |
|-----|-------|-------|-------|------|
|     |       |       |       |      |

Case 1

Task: take input N  
add 1 in binary  
can overwrite \$ if overflow



| Sin | Input | Snext | write | move |
|-----|-------|-------|-------|------|
|     |       |       |       |      |

Case 2



Case 1:  
LSB is 0

| Sin            | Input | Snext          | write | move |
|----------------|-------|----------------|-------|------|
| S <sub>0</sub> | \$    | S <sub>R</sub> | \$    | R    |
| S <sub>R</sub> | 0/1   | S <sub>R</sub> | 0/1   | R    |
| S <sub>R</sub> | E     | S <sub>W</sub> | E     | L    |
| S <sub>A</sub> | 0     | S <sub>L</sub> | 1     | L    |
| S <sub>L</sub> | 0/1   | S <sub>L</sub> | 0/1   | L    |
| S <sub>L</sub> | \$    | HALT           | \$    | R    |



case 2:  
LSB is 1

| Sin            | Input | Snext          | write | move |
|----------------|-------|----------------|-------|------|
| S <sub>0</sub> | \$    | S <sub>R</sub> | \$    | R    |
| S <sub>R</sub> | 0/1   | S <sub>R</sub> | 0/1   | R    |
| S <sub>R</sub> | E     | S <sub>A</sub> | E     | L    |
| S <sub>A</sub> | I     | S <sub>A</sub> | O     | L    |
| S <sub>A</sub> | \$    | HALT           | I     | R    |

# lets run it !



lets run it !



lets run it !



lets run it !

$t=9$



move R,

Halt

(task finished)



$t = 10$

What about other cases ?

| Sim            | Input | Snext          | wire | more |
|----------------|-------|----------------|------|------|
| S <sub>0</sub> | \$    | S <sub>R</sub> | \$   | R    |
| S <sub>R</sub> | 0/1   | S <sub>R</sub> | 0/1  | R    |
| S <sub>R</sub> | E     | S <sub>A</sub> | E    | L    |
| S <sub>A</sub> | 1     | S <sub>A</sub> | 0    | L    |
| S <sub>A</sub> | \$    | HALT           | 1    | R    |
| S <sub>A</sub> | 0     | S <sub>R</sub> | 1    | L    |
| S <sub>L</sub> | 0/1   | S <sub>L</sub> | 0/1  | L    |
| S <sub>L</sub> | \$    | HALT           | \$   | R    |

case 2:  
LSB is 1

case 1: LSB is 0

So with input % or E?

S<sub>R</sub> with input \$?

S<sub>A</sub> with Input E?

etc ...

These will all result in  
HALT(), basically  
because it is an  
invalid input