# ECE 2300 Digital Logic and Computer Organization Topic 7: Finite State Machines

http://www.csl.cornell.edu/courses/ece2300 School of Electrical and Computer Engineering Cornell University

revision: 2025-12-09-12-37

### **List of Problems**

| 1 | Control System for Multi-Cycle Quad Adder | 2  |
|---|-------------------------------------------|----|
| 2 | Modulo Counters                           | 12 |
|   | 2.A A Simple FSM                          | 12 |
|   | 2.B A Generalization                      | 13 |
|   | 2.C Gate-level implementation             | 14 |
|   | 2.D A Further Generalization              | 15 |
|   | 2.E Representing Larger Numbers           | 16 |
|   | 2.F A quick comparison                    | 17 |
|   | 2.G. One Final Optimization               | 17 |

#### Problem 1. Control System for Multi-Cycle Quad Adder

In lecture (topic 8), we will discuss a multi-cycle quad adder (module dpath in figure below), which sums up four four-bit values in multiple cycles utilizing a single adder module. In this assignment, we will design a control system (module ctrl) for such a multi-cycle quad adder. Furthermore, we will design a wrapper FSM (module wrppr), which connects this multi-cycle quad adder via the *latency insensitive valid/ready interface* to a producer and consumer.



The data path of the multi-cycle quad adder has four four-bit input ports (**A**, **B**, **C**, **D**) and one four-bit output port (**Z**). Furthermore, the data path can be controlled by a control module via three input ports. **FFI\_en** enables the registers of C and D. **mux0\_sel** and **mux1\_sel** control the two multiplexors in front of the adder.

Note: This multi-cycle quad adder is modified from lecture: For instance, input A and B are not stored in registers, the registers for C and D have additional enable logic, and the mux, which outputs X, has an additional input hardcoded to 0.

The control module itself has an input port **strt** to start the addition process and an output **done\_next**, which indicates that in the next cycle the computation will be complete. The wrapper module connects to the control module via its strt and done\_next ports. Furthermore, the wrapper module has has an irdy output and ival input for its input val/rdy interface, and an ordy input and oval output for its output val/rdy interface.

First, let us analyze the data-path module. Use the following table to list every constraint which must be satisfied to ensure correct operation of the data-path. Start by labeling the two possible constraints at the top of the table. Each path should be specified with just the start and end points of the path (feel free to name FFs yourself). Assume paths that start at an input port or end at an output port are unconstrained (for the moment, only cosider paths starting and ending at FFs). Each constraint should be expressed as an inequality. If the constraint is satisfied use  $\geq$  or  $\leq$ . If the constraint is not satisified use  $\not\geq$  or  $\not\leq$ . You must show each delay component in the inequality along with the the final sum. Circle any constraints which are not statisfied and would result in a timing violation.

|                 | $t_{pd}$ | $t_{cd}$ |
|-----------------|----------|----------|
| Mux2            | 8τ       | $2\tau$  |
| Mux4            | $15\tau$ | $3\tau$  |
| 4-Bit Adder     | $40\tau$ | $2\tau$  |
| $FF(t_{cq})$    | 9τ       | $2\tau$  |
|                 |          |          |
| $FF(t_{setup})$ | 10       | τ        |
| $FF(t_{hold})$  | 17       | τ        |
| $T_C$           | $75\tau$ |          |
|                 |          |          |

| Path Start Point | Path End Point | Constraint                                                                                    | Constraint |
|------------------|----------------|-----------------------------------------------------------------------------------------------|------------|
|                  |                |                                                                                               |            |
|                  |                |                                                                                               |            |
|                  |                |                                                                                               |            |
|                  |                |                                                                                               |            |
|                  |                |                                                                                               |            |
|                  |                | s (i.e., timing violations) within the data-<br>ald still ensure correct operation of the dat |            |
|                  |                |                                                                                               |            |
|                  |                |                                                                                               |            |

We designed the following FSM for the ctrl unit.



Is this a Moore or Mealy FSM? Explain why.

Design the next state logic of the FSM with the following kmaps; write the resulting boolean expression under each kmap:

| $\begin{array}{c} \text{next\_s[1]} \\ S_1 S_0 \end{array}$ |    |    |    |    |  |  |
|-------------------------------------------------------------|----|----|----|----|--|--|
| strt                                                        | 00 | 01 | 11 | 10 |  |  |
| 0                                                           |    |    |    |    |  |  |
| 1                                                           |    |    |    |    |  |  |



Design the output logic of the FSM with the following kmaps; write the resulting boolean expression under each kmap:



| strt | 00 | 01 | 11 | 10 |  |  |
|------|----|----|----|----|--|--|
| 0    |    |    |    |    |  |  |
| 1    |    |    |    |    |  |  |





| $\begin{array}{c} \text{done\_next} \\ \searrow S_1 S_0 \end{array}$ |    |    |    |    |  |
|----------------------------------------------------------------------|----|----|----|----|--|
| strt                                                                 | 00 | 01 | 11 | 10 |  |
| 0                                                                    |    |    |    |    |  |
| 1                                                                    |    |    |    |    |  |

Draw the gate network and registers of the ctrl module in the its box below.



Next, let us analyze the ctrl module. Use the following table to list every constraint which must be satisfied to ensure correct operation of the control unit. Start by labeling the two possible constraints at the top of the table. Each path should be specified with just the start and end points of the path (feel free to name FFs yourself). Assume paths that start at an input port or end at an output port are unconstrained (for the moment, only cosider paths starting and ending at FFs within the control unit). Each constraint should be expressed as an inequality. If the constraint is satisfied use  $\geq$  or  $\leq$ . You must show each delay component in the inequality along with the the final sum. Circle any constraints which are not statisified and would result in a timing violation.

| $t_{pd}$ | $t_{cd}$             |
|----------|----------------------|
| $1\tau$  | $1\tau$              |
| $3\tau$  | $1\tau$              |
| $4\tau$  | $1\tau$              |
| 9τ       | $2\tau$              |
|          |                      |
| $10\tau$ |                      |
| $1\tau$  |                      |
| 75τ      |                      |
|          | 1τ<br>3τ<br>4τ<br>9τ |

| Path Start Point | Path End Point | Constraint                                                                                      | Constraint |
|------------------|----------------|-------------------------------------------------------------------------------------------------|------------|
|                  |                |                                                                                                 |            |
|                  |                |                                                                                                 |            |
|                  |                |                                                                                                 |            |
|                  |                | es (i.e., timing violations) within the control ould still ensure correct operation of the cont |            |
|                  |                |                                                                                                 |            |

| NetID: |  |
|--------|--|
|--------|--|

Next, we will design the wrapper FSM of the wrppr unit. It lets the multi-cycle quad adder accept a set of four four-bit inputs (A, B, C, D of the data-path) with its latency insensitive valid/ready input interface. After the computation is complete, the module transfers the sum via its output valid/ready interface to a subsequent consumer. The wrapper module communicates with the control unit of the data-path via the strt and done\_next port.

The latency insensitive valid/ready interface works like this: The producer sets its valid signal when its data is ready for the consumer. The consumer sets its ready signal, when it is ready to accept incoming data. When at the end of a clock cycle both ready and valid signals are set, producer and consumer know that the data was transferred.

#### Draw the FSM diagram according to the following features:

- 1. The FSM should have the following three states: WS0, WS1, WS2.
- 2. It should reset to state WS0.
- 3. In state WS0, output irdy needs to be set and oval not set.
- 4. The FSM should move from state WS0 to WS1 when ival is set. In this case, the FSM should set strt. Otherwise the FSM would remain in WS0 and strt would be unset.
- 5. In state WS1, all its outputs (strt, irdy, oval) should not be set.
- 6. The system should move from WS1 to WS2 when done\_next is set. Otherwise it should remain in WS1.
- 7. In state WS2, the FSM needs to set oval, while keeping strt and irdy unset.
- 8. The FSM needs to move from WS2 to WS0 when ordy is set. Otherwise it should remain in WS2.



Next, we will design the next state logic for the WRPPR unit. Is this a moore or mealy FSM? Why can we not minimize it with kmaps?

Instead, write the next state logic without major minimization in sum of products form from the FSM diagram.

**However, we will minimize the output logic with kmaps.** We won't consider done\_next and ordy for minimization, since they don't have any impact on the outputs of the wrppr FSM. **Complete the kmaps for strt, irdy, and oval.** 



| $S_1$ | $S_0$ | irdy |    |    |
|-------|-------|------|----|----|
| ival  | 00    | 01   | 11 | 10 |
| 0     |       |      |    |    |
| 1     |       |      |    |    |

| $S_1$ | <b>5</b> 0 | oval |    |    |
|-------|------------|------|----|----|
| ival  | 00         | 01   | 11 | 10 |
| 0     |            |      |    |    |
| 1     |            |      |    |    |

Draw the gate network and registers of the wrppr module in its box of the previous figure (the same figure, in which you drew the gate network of the control unit).

| NetID: |
|--------|
|--------|

Let us analyze the timing constraints of the wrppr module. Use the following table to list every constraint which must be satisfied to ensure correct operation of the control unit. Start by labeling the two possible constraints at the top of the table. Each path should be specified with just the start and end points of the path (feel free to name FFs yourself). Assume paths that start at an input port or end at an output port are unconstrained (for the moment, only cosider paths starting and ending at FFs within the control unit). Each constraint should be expressed as an inequality. If the constraint is satisfied use  $\geq$  or  $\leq$ . If the constraint is not satisfied use  $\not\geq$  or  $\not\leq$ . You must show each delay component in the inequality along with the the final sum. Circle any constraints which are not statisfied and would result in a timing violation. *Note: Depending on your implementation, you might not need all rows of the table.* 

|                                                                                | $t_{pd}$ | $t_{cd}$ |  |  |
|--------------------------------------------------------------------------------|----------|----------|--|--|
| NOT                                                                            | $1\tau$  | $1\tau$  |  |  |
| AND2                                                                           | $3\tau$  | $1\tau$  |  |  |
| OR2                                                                            | $4\tau$  | $1\tau$  |  |  |
| $FF(t_{cq})$                                                                   | 9τ       | 2τ       |  |  |
| $\begin{array}{c} \text{FF } (t_{setup}) \\ \text{FF } (t_{hold}) \end{array}$ |          | )τ<br>τ  |  |  |
| $T_C$                                                                          | 75       | 5τ       |  |  |

| Path Start Point | Path End Point                                                      | Constraint                                                                                   | Constraint                   |
|------------------|---------------------------------------------------------------------|----------------------------------------------------------------------------------------------|------------------------------|
|                  |                                                                     |                                                                                              |                              |
|                  |                                                                     |                                                                                              |                              |
|                  |                                                                     |                                                                                              |                              |
|                  |                                                                     |                                                                                              |                              |
|                  |                                                                     |                                                                                              |                              |
|                  |                                                                     |                                                                                              |                              |
|                  |                                                                     |                                                                                              |                              |
|                  |                                                                     |                                                                                              |                              |
|                  |                                                                     |                                                                                              |                              |
| Are there ar     | ny unsatisfied constraints<br>lock period (T <sub>C</sub> ) that wo | s (i.e., timing violations) within the control uld still ensure correct operation of the con | unit? What is the trol unit? |
|                  |                                                                     |                                                                                              |                              |
|                  |                                                                     |                                                                                              |                              |
|                  |                                                                     |                                                                                              |                              |

| F.<br>d |
|---------|
|         |
|         |
| _       |
| ee      |
|         |
|         |
|         |
|         |
|         |
|         |
|         |
|         |
|         |
|         |
|         |
|         |
|         |
|         |

#### Anthony's Solution

https://vod.video.cornell.edu/id/1\_8oa6z69v

#### Problem 2. Modulo Counters

#### Part 2.A A Simple FSM

Consider the following sequential gate-level network. Fill in the truth table (i.e. the next state and output table). Note that this is not a simulation table.



| S | A | Y |
|---|---|---|
| 0 | 0 |   |
| 0 | 1 |   |
| 1 | 0 |   |
| 1 | 1 |   |

What type of FSM is this? \_\_\_\_\_\_.

Draw the FSM diagram for this simple FSM.



Fill out the following simulation table for this FSM.

| cycle             | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 |
|-------------------|---|---|---|---|---|---|---|---|---|---|----|
| $\overline{A}$    | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 0 | 1 | 1 | 1  |
| S                 | 0 |   |   |   |   |   |   |   |   |   |    |
| S <sub>next</sub> | 0 |   |   |   |   |   |   |   |   |   |    |
| Υ                 | 1 |   |   |   |   |   |   |   |   |   |    |

What does this FSM do?

#### Part 2.B A Generalization

Generalizing this, this finite state machine can be thought of as representing a "divisibility" operator for n = 2. That is, it indicates whether a stream of bits representing a binary number is divisble by n = 2 or not.

In fact, we can create such finite state machines for any value of n. And, each of these finite state machines *only require* n *states*. Let's practice by creating another finite state machine for n = 3.

Draw a FSM diagram for a n=3 "divisibility" operator. The reset state is indicated with a double circle. The values of  $S_0$ ,  $S_1$ , Y have already been filled in for you.





$$S_1=1 \\ S_0=0 \\ Y=0$$

Complete the Karnaugh Maps for  $S_0$ ,  $S_1$ .





Part 2.C Gate-level implementation

Please implement the gate-level network for the n=3 "divisibility" operator.

|  |  |  |  |  | : |  |  |   |  |       |  | : |              |                |          |
|--|--|--|--|--|---|--|--|---|--|-------|--|---|--------------|----------------|----------|
|  |  |  |  |  |   |  |  |   |  |       |  |   | Gate         | $t_{pd}$       | $t_{cd}$ |
|  |  |  |  |  |   |  |  |   |  |       |  |   | NOT          | $1\tau$        | $1\tau$  |
|  |  |  |  |  |   |  |  |   |  |       |  |   | NAND2        | $2\tau$        | $1\tau$  |
|  |  |  |  |  |   |  |  |   |  |       |  |   | NOR2         | $3\tau$        | $1\tau$  |
|  |  |  |  |  | : |  |  |   |  | ·<br> |  |   | AND2         | $3\tau$        | $1\tau$  |
|  |  |  |  |  |   |  |  |   |  |       |  |   | OR2          | $4\tau$        | $1\tau$  |
|  |  |  |  |  |   |  |  |   |  |       |  |   | XOR2         | $7\tau$        | 6τ       |
|  |  |  |  |  |   |  |  | ! |  |       |  |   | $FF(t_{cq})$ | 9τ             | $2\tau$  |
|  |  |  |  |  |   |  |  |   |  |       |  |   |              |                |          |
|  |  |  |  |  |   |  |  |   |  |       |  |   |              | 1              | 10~      |
|  |  |  |  |  |   |  |  |   |  |       |  |   | FF           | $t_{ m setup}$ |          |
|  |  |  |  |  |   |  |  |   |  |       |  |   | FF           | $t_{ m hold}$  | $1\tau$  |
|  |  |  |  |  |   |  |  |   |  |       |  |   | $T_C$        |                | 26τ      |

Use the following table to list every constraint which must be satisfied to ensure correct operation of this gate-level network. You should specify each gate on the path. Assume output ports are unconstrained. Just write the *final sum* and constraint. Circle any constraints that are violated.

| <br>Path | 1 <sup>st</sup> Constraint | 2 <sup>nd</sup> Constraint |
|----------|----------------------------|----------------------------|
|          |                            |                            |
|          |                            |                            |
|          |                            |                            |
|          |                            |                            |
|          |                            |                            |
|          |                            |                            |
|          |                            |                            |
|          |                            |                            |
|          |                            |                            |
|          |                            |                            |

Similar to problem 4F in topic 2, we can optimize our gate-level network to meet timing (if it currently isn't) by switching **most** ANDs and ORs to NAND gates. Think of why this is equivalent (T03).

| NetID: |  |
|--------|--|
|--------|--|

#### Part 2.D A Further Generalization

Why does your n = 3 finite state machine work? This is explained by modulo arithmetic.

Each state represents a modulo equivalence class. Let v denote the value given by the stream of A. Then, each state represents v mod n (i.e. the remainder of v when divided by n). The initial state represents when the remainder is zero. By using modulo arithmetic, we can derive all of the next state logic.

Suppose you are in module state r. Then, if we see a zero, the remainder doubles. Thus, the next state we go to is  $2r \mod n$ . If we see a one, the remainder doubles **AND** we add one. Thus, the next state we go to is  $2r + 1 \mod n$ . This may be initially confusing, but we will practice with n = 5.

| D | Draw the FSM diagram for a $n = 5$ modulo counter ("divisibility" operator). |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|---|------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
|   |                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|   |                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|   |                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|   |                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|   |                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|   |                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|   |                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|   |                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|   |                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|   |                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|   |                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|   |                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|   |                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|   |                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|   |                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|   |                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|   |                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|   |                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|   |                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|   |                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|   |                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|   |                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|   |                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|   |                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|   |                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|   |                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|   |                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|   |                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|   |                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|   |                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|   |                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|   |                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|   |                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

#### Part 2.E Representing Larger Numbers

We've explored very small n values thus far. But, what if we wanted to make a finite state machine for n = 15? Following our earlier reasoning, we would need 15 states!

This seems like (and is) a lot of work! In fact, the FSM diagram is incredibly complicated:



We should (and will) find a more intelligent approach to building such FSMs. To do so, we will need to exploit the course principles of *modularity*, *hierarchy*, *and regularity*. **Fill in the blanks below**.

If a number is divisble by 15, it must also be divisible by \_\_\_\_\_\_ and \_\_\_\_\_.

Let's try to construct a 15-counter with a 3-counter and a 5-counter. In class, you compose FSMs by having one impact the state of another. Now, we will explore a different method. Create a combinational gate-level network that utilizes the output from the 3-counter, Y<sub>3</sub>, and the output from the 5-counter, Y<sub>5</sub> to indicate when an input is divisible by 15 (i.e. Y<sub>15</sub>).

## Part 2.F A quick comparison

| Which of the two constructions of the 15-counter do you prefer? Is one definitely better, and if why? Is there any tradeoff between the two? Does this hold for all modular modulo counters? |       |            |          |       |       |        |       |       |        |       |      |        |       | so,    |       |       |       |       |               |      |       |    |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|------------|----------|-------|-------|--------|-------|-------|--------|-------|------|--------|-------|--------|-------|-------|-------|-------|---------------|------|-------|----|
| wł                                                                                                                                                                                           | ıy?   | Is th      | ere      | any   | trad  | eoff 1 | betw  | een t | the tv | vo? I | Ooes | this   | holo  | d for  | all r | nodu  | ıları | nod   | ulo d         | coun | ters? | ?  |
|                                                                                                                                                                                              |       |            |          |       |       |        |       |       |        |       |      |        |       |        |       |       |       |       |               |      |       |    |
|                                                                                                                                                                                              |       |            |          |       |       |        |       |       |        |       |      |        |       |        |       |       |       |       |               |      |       |    |
|                                                                                                                                                                                              |       |            |          |       |       |        |       |       |        |       |      |        |       |        |       |       |       |       |               |      |       |    |
|                                                                                                                                                                                              |       |            |          |       |       |        |       |       |        |       |      |        |       |        |       |       |       |       |               |      |       |    |
|                                                                                                                                                                                              |       |            |          |       |       |        |       |       |        |       |      |        |       |        |       |       |       |       |               |      |       |    |
|                                                                                                                                                                                              |       |            |          |       |       |        |       |       |        |       |      |        |       |        |       |       |       |       |               |      |       |    |
|                                                                                                                                                                                              |       |            |          |       |       |        |       |       |        |       |      |        |       |        |       |       |       |       |               |      |       |    |
|                                                                                                                                                                                              |       |            |          |       |       |        |       |       |        |       |      |        |       |        |       |       |       |       |               |      |       |    |
|                                                                                                                                                                                              |       |            |          |       |       |        |       |       |        |       |      |        |       |        |       |       |       |       |               |      |       |    |
|                                                                                                                                                                                              |       |            |          |       |       |        |       |       |        |       |      |        |       |        |       |       |       |       |               |      |       |    |
|                                                                                                                                                                                              |       |            |          |       |       |        |       |       |        |       |      |        |       |        |       |       |       |       |               |      |       |    |
|                                                                                                                                                                                              |       |            |          |       |       |        |       |       |        |       |      |        |       |        |       |       |       |       |               |      |       |    |
|                                                                                                                                                                                              |       |            |          |       |       |        |       |       |        |       |      |        |       |        |       |       |       |       |               |      |       |    |
| ъ.                                                                                                                                                                                           |       | <i>C</i> ( | <b>.</b> | г.    | 10    |        |       |       |        |       |      |        |       |        |       |       |       |       |               |      |       |    |
| ra                                                                                                                                                                                           | rt 2. | G          | Jne      | rına  | ıı Op | timi   | zatio | n     |        |       |      |        |       |        |       |       |       |       |               |      |       |    |
| Ins                                                                                                                                                                                          | stead | d, co      | nsic     | ler b | uildi | ing a  | mod   | ulo 6 | cou    | nter. |      |        |       |        |       |       |       |       |               |      |       |    |
| Ho                                                                                                                                                                                           | w r   | nan        | y sta    | tes   | do w  | e ne   | ed if | we u  | ise a  | singl | e FS | M? _   |       | _ Но   | ow al | out   | mod   | lulaı | r FSN         | Ms?  |       |    |
| In                                                                                                                                                                                           | fact  | , we       | can      | act   | uallv | buil   | d thi | s cou | ınter  | with  | iust | four   | state | s. A   | nd. i | n a s | inole | FSΛ   | <i>Л</i> . То | o do | this. | we |
|                                                                                                                                                                                              |       |            |          |       |       |        |       |       | the F  |       |      |        |       |        |       |       |       |       |               |      | ,     |    |
|                                                                                                                                                                                              |       |            |          |       |       |        |       |       |        |       |      |        |       |        |       |       |       |       |               |      |       |    |
|                                                                                                                                                                                              |       |            |          |       |       |        |       |       |        | :     |      | ·<br>· |       | ·<br>· |       |       |       |       |               |      |       |    |
|                                                                                                                                                                                              |       |            |          |       |       |        |       |       |        |       |      |        |       |        |       |       |       |       |               |      |       |    |
|                                                                                                                                                                                              |       |            |          |       |       |        |       |       |        |       |      |        |       | :<br>: |       |       |       |       |               |      |       |    |
|                                                                                                                                                                                              |       |            |          |       |       |        |       |       |        |       |      |        |       |        |       |       |       |       |               |      |       |    |
|                                                                                                                                                                                              |       |            |          |       |       |        |       |       |        |       |      |        |       |        |       |       |       |       |               |      |       |    |
|                                                                                                                                                                                              |       |            |          |       |       |        |       |       |        |       |      |        |       |        |       |       |       |       |               |      |       |    |
|                                                                                                                                                                                              |       |            |          |       |       |        |       |       |        |       |      |        |       |        |       |       |       |       |               |      |       |    |
|                                                                                                                                                                                              |       |            |          |       |       |        |       |       |        |       |      |        |       |        |       |       |       |       |               |      |       |    |
|                                                                                                                                                                                              |       |            |          |       |       |        |       |       |        |       |      |        |       |        |       |       |       |       |               |      |       |    |
|                                                                                                                                                                                              |       |            |          |       |       |        |       |       |        |       |      |        |       |        |       |       |       |       |               |      |       |    |
|                                                                                                                                                                                              |       |            |          |       |       |        |       |       |        |       |      |        |       |        |       |       |       |       |               |      |       |    |
|                                                                                                                                                                                              |       |            |          |       |       |        |       |       |        |       |      |        |       |        |       |       |       |       |               |      |       |    |