

# Finite State Machines with Quartus State Machine Editor

Muhammad Mun'im Ahmad Zabidi, Musa Mohd Mokji, Izam Kamisian, Norhafizah Ramli

#### Abstract

This articles introduces the reader to the concepts of finite state machines and their rapid implementation using Quartus state machine editor.

<sup>1</sup> Department of Electronic and Computer Engineering, School of Electrical Engineering, Faculty of Engineering \*Corresponding author: munim@utm.my

# 1. Introduction

Designing a finite state machine (FSM) is a common task for a digital logic engineer. The two basic types of FSM are Moore and Mealy, shown in Figure 1 and 2. Any FSM contains three basic components: state register, next state logic and output logic.



Figure 1. Basic Moore type state machine.



Figure 2. Basic Mealy type state machine.

# **State Register**

The state register is simply a few flip-flops which store the present state. The **present state** is the value of the flip-flop at any given time while the **next state** is the value after receiving a clock edge. A FSM with *n* flip-flops has  $2^n$  different states. The number of states is limited or finite, thus the name *finite* state machine. For example, an FSM with 2 flip-flops are limited to 4 states because they can only have 4 values: 00, 01, 10 and 11.

#### **Next State Logic**

The next state logic determines what the next state will be when a clock pulse arrives. The decision is based on the present state and input received from the outside world.

#### **Output Logic**

Output logic controls the outside world. Moore type FSM determines the system output based only on the present state (or the current value of flips-flops). Mealy type FSM determines the output based on present state and the present input. Due to this difference, Moore type FSM is easier to design, while Mealy type FSM is usually more efficient. Both types are widely used. Advanced FSMs may have both kinds of outputs such as in Figure 3.



Figure 3. FSM with both Moore and Mealy outputs.

Finite state machines are modeled by state diagrams which describe the state changes that happen as inputs are received.

## 2. Moore-type Vending Machine

The vending machine in Figure 4 is a very common example used to demonstrate the concept of finite state machines. The vending machine releases a package of product (gum, soda, etc) after it has received 15 cents in coins [1].

The machine has a single coin slot that accepts *nickels*  $(5^{\circ})$  and *dimes*  $(10^{\circ})$ , one coin at a time. A mechanical sensor indicates whether a dime or a nickel has been inserted into the coin slot. The controller's output causes a item of product to be released down a chute to the customer. The machine does not give change.



Figure 4. Vending machine abstract view.

The Moore machine symbolic state diagram for the vending machine is shown in Fig. 5. Each state represents how much money has been deposited into the vending machine.



Figure 5. The state diagram for vending machine.

The FSM starts at initial state  $S_0$  which means no money has been deposited. If a nickel (*N*)) was inserted, the FSM goes to state  $S_5$ . This is shown by the arrow labeled *N*. If a dime (*D*) was inserted in state  $S_0$ , the FSM goes to state  $S_{10}$ , represented by the arrow labeled *D*. If nothing was received, the FSM stays at state  $S_0$ , represented by the arrow looping to itself labeled D'N'.

The state machine assumes N and D can never occur at the same time. Although this assumption may simplify manual design of the state machine, it may cause conflicts.

Table 1. State description.

| Symbol          | Meaning           |  |
|-----------------|-------------------|--|
| S <sub>0</sub>  | No money received |  |
| $S_5$           | 5¢ received       |  |
| $S_{10}$        | 10¢ received      |  |
| S <sub>15</sub> | 15¢ received      |  |

More on this later.

From either state  $S_5$  or state  $S_{10}$ , more coins can be inserted. A nickel causes the FSM to advance to the immediately succeeding state. A dime causes the FSM to advance two states ahead. At state  $S_{10}$ , either a dime or a nickel advances the FSM to state  $S_{15}$ , represented by the arrow labeled N + D.

At state  $S_{15}$ , the FSM outputs the *Release* (R) signal which causes the gum to be delivered. Then the FSM is restored to the initial condition by an unconditional transition to state  $S_0$ . This unconditional action is represented by the arrow labeled 1 (or unlabeled).

An enhanced vending machine state diagram is shown in Figure 6. In this version, only arrows representing state transitions are shown. An unlabeled arrow is assumed to be an unconditional transition, e.g.  $S_{15} \rightarrow S_0$ . The enhanced state diagram updates the labels for  $S_0 \rightarrow S_5$  and  $S_5 \rightarrow S_{10}$ transitions to resolve conflicts.



Figure 6. Enhanced state diagram for vending machine.

The next step in the design process is to enter the design using Quartus State Machine Editor.

# 3. Create a New Project

Launch the new project wizard in Quartus.

| 💱 New Project Wizard                                                                                                                                     | × |
|----------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| Directory, Name, Top-Level Entity [page 1 of 5]                                                                                                          |   |
| What is the working directory for this project?                                                                                                          |   |
| C:\quartusprojects\vending                                                                                                                               |   |
| What is the name of this project?                                                                                                                        |   |
| vending                                                                                                                                                  |   |
| What is the name of the top-level design entity for this project? This name is case sensitive and must exactly match the entity name in the design file. |   |
| vending                                                                                                                                                  |   |
| Use Existing Project Settings                                                                                                                            |   |
| < Back Next > Finish Cancel Help                                                                                                                         | , |

Figure 7. New project wizard Page 1.

After entering the folder name and project name, click Finish.

You can skip all the other pages. For this experiment, the device type is not important.

- 4. Design Entry
- From the top menu, choose File → New → State Machine File.

| New O                     | Institute III Deceloret    | _         |
|---------------------------|----------------------------|-----------|
| V Design                  | Files                      |           |
| AH                        | ) File                     |           |
| Blog                      | k Diagram/Schematic F      | le        |
| EDI                       | F File                     |           |
| Qsy                       | s System File              |           |
| Stat                      | te Machine File            |           |
| Sys                       | temVerilog HDL File        |           |
| Td                        | Script File                |           |
| Ver                       | ilog HDL File              |           |
| VHE                       | DL File                    |           |
| <ul> <li>Memor</li> </ul> | y Files                    |           |
| Hex                       | adecimal (Intel-Format)    | File      |
| Mer                       | nory Initialization File   |           |
| ✓ Verifica                | tion/Debugging Files       |           |
| In-S                      | system Sources and Pro     | bes File  |
| Log                       | ic Analyzer Interface File | t<br>Tile |
| Sigi                      | ersiby Program VM/E        | rile      |
| V Other F                 | ilee                       |           |
| AHD                       | )I. Include File           |           |
|                           |                            |           |

Figure 8. New state machine.

2. From the toolbar, select the **State Tool**.



Figure 9. State tool.

3. When the icon changes, click four times to get four states. These are placeholders. You can place them any way, any where in the editor.



Figure 10. Four placeholder states.

You can skip Step 2 and 3. You can always add or delete states during Step 8.

4. From the toolbar, select the **State Machine Wizard** tool. Confirm editing of an existing design then click OK.

| ÷ | <u>چ</u> ا           |
|---|----------------------|
|   | State Machine Wizard |

Figure 11. Select the State Machine Wizard.

| 뤚 State Machine Wizard                                                    | × |
|---------------------------------------------------------------------------|---|
| State Machine Wizard helps you create or modify a state<br>machine design | 2 |
| Which action do you want to perform?                                      |   |
| • Edit an existing state machine design                                   |   |
| OK Cancel Help                                                            |   |

Figure 12. Confirm edit of current state machine.

5. In dialog box that appears, choose the General tab. Make sure the bottom checkbox is checked. This allows you to simplify the state diagram by not showing arrows pointing back to the source state.

| n State Machine Wizard                                                                                                                       | $\times$ |
|----------------------------------------------------------------------------------------------------------------------------------------------|----------|
| <ul> <li>✓ General \ Inputs \ Outputs \/ States \/ Transitions \ Actions \</li> <li>Which reset mode do you want to use?</li> <li></li></ul> |          |
| Tansition to source state if not all transition conditions are specified                                                                     |          |
|                                                                                                                                              |          |

Figure 13. General tab of State Machine Wizard.

6. In the Inputs tab, click once on the <New> cell.

| 🔓 State Mac | thine Wizard      |
|-------------|-------------------|
| General     | Inputs / Output   |
| Input Port  | Controlled Signal |
| reset       | Reset             |
| dock        | Clock             |
| < New >     |                   |

Figure 14. The Inputs tabs initial condition.

Add two new inputs, *N* and *D*.

| 👆 State Mao | chine Wizard      |
|-------------|-------------------|
|             |                   |
| General V   | Inputs / Outputs  |
| Input Port  | Controlled Signal |
| reset       | Reset             |
| clock       | Clock             |
| N           | No                |
| D           | No                |
| < New >     |                   |

Figure 15. Inputs N and D are added.

7. In the Outputs tab, click on the <New> cell and add the output *R*.

| é | 🔓 State Mach | ine Wizard   |                               |         |
|---|--------------|--------------|-------------------------------|---------|
| 1 | General / I  | inputs / Out | puts / States / Transitions / | Actions |
|   | Output Port  | Registered   | Output State                  |         |
|   | R            | No           | Current dock cycle            |         |
|   | <new></new>  |              |                               |         |
|   |              |              |                               |         |

Figure 16. The output R is added.

8. The States tab defines all states in the machine. Here, rename all states to S0, S5, S10 and S15. The table should appear as in Figure.

| General |       | uts Outputs States Transitions Actions |
|---------|-------|----------------------------------------|
| State   | Reset |                                        |
| S0      | Yes   |                                        |
| S5      | No    |                                        |
| S10     | No    |                                        |
| S15     | No    |                                        |
| < New > |       |                                        |

Figure 17. States tab of State Machine Wizard.

9. The Transitions tab define state-to-state transitions. Enter the transitions to get the table in Figure 18.

| 뤆 State Machi | ne Wizard           |                                          |
|---------------|---------------------|------------------------------------------|
| General / Ir  | nputs \/ Outputs \/ | States / Transitions / Actions /         |
| Source State  | Destination State   | Transition (In Verilog or VHDL 'OTHERS') |
| S0            | S5                  | N & ~D                                   |
| SO            | S10                 | D                                        |
| S5            | S10                 | N & ~D                                   |
| S5            | S15                 | D                                        |
| S10           | S15                 | NID                                      |
| S15           | SO                  |                                          |
| <new></new>   |                     |                                          |

Figure 18. Transitions tab of State Machine Wizard.

The vending machine has only six transitions. Each row in the table represents one transition with a source state, destination state and the Verilog expression representing the Boolean equation. In Verilog, AND, OR and NOT use the operators &, | and  $\sim$ , respectively.

From  $S_0$  in the original state diagram, the arrow labeled N goes to  $S_5$  and the arrow labeled D goes to  $S_{10}$ . In the original design, we assume N and D are never active together. Quartus does not accept this assumption. The State Machine Editor will give an error unless we label the transitions as D and N &  $\sim$ D (Boolean ND'). Alternatively, we can label the transitions as N and D &  $\sim$ N (Boolean DN').

The non-ambiguity rule for  $S_0$  is also applied to transitions from state  $S_5$ .

For the  $S_{10}$  to  $S_{15}$  transition, the expression  $\mathbb{N} \mid \mathbb{D}$  represents Boolean N + D.

The transition from  $S_{15}$  to  $S_0$  is unconditional. It is labeled "1" in the state diagram (or unlabeled). In the Transitions table, leave the cell blank.

10. The Actions tab defines the outputs. In the original state diagram, the output R is active in state  $S_{15}$ . Enter the actions like in Figure 19. The value "1" in the Output Value cell means the output is active unconditionally during  $S_{15}$ . This is also called a Moore output.

(To create a Mealy output, enter the Boolean expression the Output Value cell.)

| State Mach  | ine Wizard                                                |                                                                                                 |                                                                                                                       |                                                                                                                                                                      |
|-------------|-----------------------------------------------------------|-------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| General / I |                                                           | ts \/ Stat                                                                                      | es / Transitions / Act                                                                                                | ions                                                                                                                                                                 |
| Output Port | Output Value                                              | In State                                                                                        | Additional Conditions                                                                                                 |                                                                                                                                                                      |
| ι           | 1                                                         | S15                                                                                             |                                                                                                                       |                                                                                                                                                                      |
| <new></new> |                                                           |                                                                                                 |                                                                                                                       |                                                                                                                                                                      |
|             | State Mach<br>General \/ I<br>Output Port<br>R<br>< New > | State Machine Wizard<br>General / Inputs / Output<br>Output Port Output Value<br>R 1<br>< New > | State Machine Wizard<br>General / Inputs / Outputs / State<br>Output Port Output Value In State<br>R 1 S15<br>< New > | State Machine Wizard         General \/ Inputs \/ Outputs \/ States \/ Transitions \/ Act         Output Port       Output Value         I       S15         < New > |

Figure 19. Actions tab defines state machine outputs.

11. All information have been entered. Click OK ! We should get Figure 20.



Figure 20. Quartus rearranged states.

12. Save the state machine file.

| Save As                                         |                             |                                             |                                   | ×                   |
|-------------------------------------------------|-----------------------------|---------------------------------------------|-----------------------------------|---------------------|
| Save in:                                        | 📜 vending                   | -                                           | + 🖻 💣 🖬 ▼                         |                     |
| Cuick access<br>Desktop<br>Libraries<br>This PC | Name                        | ^                                           | Date modified<br>4/2/2019 7:49 AM | Type<br>File folder |
|                                                 | <                           |                                             |                                   | >                   |
|                                                 | File name:<br>Save as type: | Vendingmoore<br>State Machine Files (*.smf) | •                                 | Save<br>Cancel      |
|                                                 |                             |                                             |                                   | 1                   |

Figure 21. Save the file.

13. From the toolbar, click **Generate HDL File**. A dialog box will appear. The choice would not make any difference, so choose Verilog HDL anyway.



Figure 22. Generate HDL.

| 🖧 Generate HDL File 🛛 🗙              |             |  |  |  |  |
|--------------------------------------|-------------|--|--|--|--|
| Specify the hardware design language |             |  |  |  |  |
| Verilog HD                           | Verilog HDL |  |  |  |  |
|                                      |             |  |  |  |  |
| <ul> <li>System Verilog</li> </ul>   |             |  |  |  |  |
| OK Cancel Help                       |             |  |  |  |  |
|                                      |             |  |  |  |  |

Figure 23. Choose any language you like.

13. After the HDL file is generated, add the file to the project.

| Text Editor - C:/quartusprojects/vending/vending |              |               |                 |                         |               |        |  |
|--------------------------------------------------|--------------|---------------|-----------------|-------------------------|---------------|--------|--|
| <u>F</u> ile                                     | <u>E</u> dit | <u>V</u> iew  | <u>P</u> roject | P <u>r</u> ocessing     | <u>T</u> ools | Window |  |
|                                                  | 孡            | <b>≜</b> ∎ () | Ad              | d Curre <u>n</u> t File | to Proje      | ct     |  |

Figure 24. Add the Verilog file to current project.

14. Set the state machine file as the top-level entity. Note: you can do this step any time after creating a new state machine file but it must be before compiling the HDL file.

| Project Navigator |   | д                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | ₽×    |      |
|-------------------|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|------|
| Files             |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |       | **** |
| vendingmoore.sm   |   | <u>O</u> pen                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |      |
|                   |   | Remove File from Project                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |       |      |
|                   | 2 | Set as Top-Level Entity $\begin{subarray}{c} \begin{subarray}{c} $ | Ctrl+ | ⊦Sł  |

Figure 25. Set vendingmoore.smf as top level entity.

15. Compile the generated HDL code.

| Compilation Report - C:/quartusp                                                                                                                                                                                                                                         | rojects/vending/vending                                                                                                                                                     | - vending                                                                                                                                                     | -           |                        | $\times$ |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|------------------------|----------|
| <u>F</u> ile <u>E</u> dit <u>T</u> ools <u>W</u> indow <u>H</u> elp 🐬                                                                                                                                                                                                    |                                                                                                                                                                             |                                                                                                                                                               | Search al   | tera.com               | •        |
| Table of Contents 7 8                                                                                                                                                                                                                                                    | Flow Summary                                                                                                                                                                |                                                                                                                                                               |             |                        |          |
| Flow Summary     Flow Settings     Flow Non-Default Clobal Settings     Flow Non-Default Clobal Settings     Flow Lapsed Time     Flow Log     Analysis & Synthesis     Fitter     Assembler     TimeQuest Timing Analyzer     Flow Messages     Flow Supressed Messages | Flow Status<br>Quartus II 64-Bit Version<br>Revision Name<br>Top-level Entity Name<br>Family<br>Device<br>Timing Models<br>Total Jogic elements<br>Total pins<br>UFM blocks | Successful - Mon I<br>13.0.0 Build 156 0<br>vending<br>vendingmore<br>MAX II<br>EPM240T100C5<br>Final<br>9 / 240 (4 % )<br>5 / 80 (6 % )<br>0<br>0 / 1 (0 % ) | ≕eb 04 08:0 | 1:12 2019<br>5) Web Ed | ition    |
| < >                                                                                                                                                                                                                                                                      |                                                                                                                                                                             |                                                                                                                                                               |             |                        |          |
|                                                                                                                                                                                                                                                                          |                                                                                                                                                                             |                                                                                                                                                               | 100%        | 6 00:0                 | 0:11 🕾   |

Figure 26. Compilation report.

After a successful compilation, you are now ready to simulate the vending machine.

# 5. Simulation

In order to simulate the design, we will enter the input simulation waveform.

1. Choose **File → New → University Program VWF** to create a new file (see Figure 27) then click OK.

| 😫 New                                            |                   |           | × |  |
|--------------------------------------------------|-------------------|-----------|---|--|
| New Quartus                                      | II Project        |           | ^ |  |
| ✓ Design Files                                   |                   |           |   |  |
| AHDL File                                        | •                 |           |   |  |
| Block Dia                                        | gram/Schematic    | File      |   |  |
| EDIF File                                        |                   |           |   |  |
| Qsys Sys                                         | tem File          |           |   |  |
| State Ma                                         | chine File        |           |   |  |
| SystemV                                          | erilog HDL File   |           |   |  |
| Tcl Scrip                                        | File              |           |   |  |
| Verilog H                                        | Verilog HDL File  |           |   |  |
| VHDL File                                        | •                 |           |   |  |
| <ul> <li>Memory File</li> </ul>                  | 5                 |           |   |  |
| Hexadeci                                         | mal (Intel-Format | t) File   |   |  |
| Memory Initialization File                       |                   |           |   |  |
| <ul> <li>Verification/Debugging Files</li> </ul> |                   |           |   |  |
| In-Syster                                        | n Sources and Pr  | obes File |   |  |
| Logic Analyzer Interface File                    |                   |           |   |  |
| SignalTap II Logic Analyzer File                 |                   |           |   |  |
| University Program VWF                           |                   |           |   |  |
| <ul> <li>Other Files</li> </ul>                  |                   | 45        |   |  |
| AHDL Inc                                         | lude File         |           | ~ |  |
| ОК                                               | Cancel            | Help      |   |  |
|                                                  |                   |           |   |  |

Figure 27. Create new waveform file.

2. Simulation waveform editor window will appear such shown in Figure 28.

| G : | Simulation Wave    | form Editor - C:/ | 'quartuspro | jects/vending/vending | I - vending - [vending.v | wf]*        | -            |             |
|-----|--------------------|-------------------|-------------|-----------------------|--------------------------|-------------|--------------|-------------|
|     | و at <u>1</u> 00 م | , 프 Xī Xī         | E 385 \€    | X3 X7 X8 📌 👯          | 為 副 影                    |             | Search alter | s.com       |
| Mas | ster Time Bar: 0 p | s [               | • •         | Pointer: 259.99 ns    | Interval: 259.99 ns      | Start: 0 ps | End:         | 0 ps        |
|     | Name               | Value at          | 0 ps        | 160.0 ns              | 320.0 ns                 | 480.0 ns    | 640.0 ns     | 800.0 ns ^  |
| <   |                    |                   | <<br>7.     |                       | \$                       |             |              |             |
|     |                    |                   |             |                       |                          |             |              | 0% 00:00:00 |

Figure 28. Blank waveform.

3. Choose Edit ➡ Grid Size...

| 🌒 Grid Size                            | ×          |
|----------------------------------------|------------|
| Base grid on time peri<br>Period: 40.0 | od<br>ns 🔻 |
| ок                                     | Cancel     |

Figure 29. Set Grid size to 40 ns.

4. Choose Edit 🗢 Set End Time...

| 🔮 End Time           | × |
|----------------------|---|
| Set End Time         |   |
| End Time: 800.0 ns 🔻 |   |
| OK Cancel            |   |

Figure 30. Set end time to 800 ns.

- 5. Go to **View → Fit in Window** to get the Vector Waveform at the workspace. We can also adjust the view at our convenience through Zoom In and Zoom Out tool.
- 6. Go to **Edit** → **insert** and click insert node or bus. A pop-up dialog box will appear as shown in Figure 31.

| 🅞 Insert I                              | Node or Bus | ×           |  |  |  |  |
|-----------------------------------------|-------------|-------------|--|--|--|--|
| Name:                                   |             | ОК          |  |  |  |  |
| Type:                                   | INPUT -     | Cancel      |  |  |  |  |
| Value type                              | 9-Level 🔻   |             |  |  |  |  |
| Radix:                                  | Binary -    | Node Finder |  |  |  |  |
| Bus width:                              | 1           |             |  |  |  |  |
| Start index                             | 0           |             |  |  |  |  |
| Display gray code count as binary count |             |             |  |  |  |  |

Figure 31. Insert node dialog.

7. Click Node Finder...). A pop-up box will appear as shown in Figure 32.

- 8. Follow these steps:
  - (a) Set the Filter to Pins:all
  - (b) Click List
  - (c) Click the >> button
  - (d) Click OK on the Node Finder window

| Named: *                     |                                            |      | Filter: | Pins: all | l                                     |                                            | •    | OK     |
|------------------------------|--------------------------------------------|------|---------|-----------|---------------------------------------|--------------------------------------------|------|--------|
| Look in: *                   |                                            |      |         |           |                                       | . List                                     |      | Cancel |
| Nodes Found:                 |                                            |      |         | Se        | elected No                            | des:                                       |      |        |
| Name<br>D<br>N<br>R<br>clock | Input<br>Input<br>Output<br>Input<br>Input | Туре |         |           | Name<br>D<br>N<br>R<br>clock<br>reset | Input<br>Input<br>Output<br>Input<br>Input | Туре | 3      |

Figure 32. Node finder dialog.

9. We will be brought back at the Insert Node or Bus box as shown in Figure 33, click OK.

| 💱 Insert Node or Bus 🛛 🗙                |                                 |             |  |  |  |  |
|-----------------------------------------|---------------------------------|-------------|--|--|--|--|
| Name:                                   | **Multiple Items**              | ОК          |  |  |  |  |
| Type:                                   | **Multiple Items** $\checkmark$ | Cancel      |  |  |  |  |
| Value type                              | 9-Level 👻                       |             |  |  |  |  |
| Radix:                                  | Binary -                        | Node Finder |  |  |  |  |
| Bus width:                              | 1                               |             |  |  |  |  |
| Start inde>                             | 0                               |             |  |  |  |  |
| Display gray code count as binary count |                                 |             |  |  |  |  |

Figure 33. Adding multiple nodes.

10. At this stage we will see five signals on the waveform editor.

|         | Name  | Value at<br>0 ps | 0 ps<br>0 ps | 160.0 ns | 320.0 ns | 480.0 ns | 640.0 ns | 800.0 ns |
|---------|-------|------------------|--------------|----------|----------|----------|----------|----------|
| 3-      | dock  | в 0              |              |          |          |          |          |          |
| 3-      | reset | B 0              |              |          |          |          |          |          |
| 3-      | D     | B 0              |              |          |          |          |          |          |
| }_      | N     | в 0              |              |          |          |          |          |          |
| ut<br>Ö | R     | вх               |              |          | *****    |          |          |          |

Figure 34. Waveform after inserting nodes.

11. Click on the clock signal, then the Overwrite Clock tool. Next, set the clock period to 40 ns.

|           | Name  | Value at<br>0 ps | 0 ps<br>0 ps | 160.0 ns                                                                              | 320.0 ns     | 480.0 ns | 640.0 ns | 800.0 ns ^ |
|-----------|-------|------------------|--------------|---------------------------------------------------------------------------------------|--------------|----------|----------|------------|
| in-       | dock  | в 0              |              |                                                                                       |              |          |          |            |
| <u>in</u> | reset | B 0              |              |                                                                                       |              |          |          |            |
| in_       | N     | B 0              |              | 😫 Clock                                                                               | ×            |          |          |            |
| in_       | D     | B 0              |              | Base waveform on time perio                                                           | d            |          |          |            |
| eut.      | R     | ВX               | ×××          | Period:         40           Offset:         0.0           Duty cycle (%):         50 | ns V<br>ns V | ******   | ******   | *****      |
|           |       |                  |              | OK L                                                                                  | Cancel       |          |          |            |

Figure 35. Set the clock period to 40 ns.

12. For the remaining signals, set the values according to Figure 36.

|           |       | Value at | 0 ps | 160.0 ns | 320.0 ns | 480.0 ns | 640.0 ns | 800.0 ns |
|-----------|-------|----------|------|----------|----------|----------|----------|----------|
|           | Name  | 0 ps     | 0 ps |          |          |          |          |          |
| in_       | clock | В 0      |      |          |          |          |          | vv       |
| in_       | reset | B 1      |      |          |          |          |          |          |
| in_       | N     | в 0      |      |          |          |          |          |          |
| <u>in</u> | D     | B 0      |      |          |          |          |          |          |
| eut 🍮     | R     | вх       |      |          | ****     | *******  | *******  | *****    |

Figure 36. Simulation input waveform.

13. Choose **File → Save as...** A pop-up box will appear as shown in Figure 37, click Save.

| Save Vector Wave                                | form File                                    |         |                                                                                                                                     | ×                                                                            |
|-------------------------------------------------|----------------------------------------------|---------|-------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|
| Save in:                                        | 📜 vending                                    |         |                                                                                                                                     |                                                                              |
| Quick access<br>Desktop<br>Libraries<br>This PC | Name db incremental_ output_files simulation | Ĉ ₽     | <ul> <li>Date modified</li> <li>10/2/2019 6:45</li> <li>4/2/2019 7:57 /</li> <li>10/2/2019 6:45</li> <li>4/2/2019 8:50 /</li> </ul> | Type<br>PM File folder<br>AM File folder<br>PM File folder<br>AM File folder |
|                                                 | <                                            | vonding | -                                                                                                                                   | ><br>                                                                        |
|                                                 | riie name:<br>Save as type:                  | Cancel  |                                                                                                                                     |                                                                              |

Figure 37. Save the vector waveform.

14. Click run functional simulation icon on the toolbar. If the simulation is successful, a new window will appear showing the result of simulated waveforms.

|     | Name  | Value at<br>0 ps | 0 ps<br>0 ps | 160.0 ns | 320.0 ns | 480.0 ns | 640.0 ns | 800.0 ns |
|-----|-------|------------------|--------------|----------|----------|----------|----------|----------|
| ₿-  | dock  | B0               | Глл          | лллл     | נינינינ  |          | ллл      | 55       |
| in_ | reset | B 1              |              |          |          |          |          |          |
| in_ | N     | B 0              |              |          |          |          |          |          |
| ₽-  | D     | B 0              |              |          |          |          |          |          |
| ᅄ   | R     | B 0              |              |          |          |          |          |          |

Figure 38. Simulation output waveform.

## 6. Mealy-type Vending Machine

The Mealy type vending machines solves the same task using only three states (Figure 39). This section of the application note only points the differences. Unless otherwise mentioned, use the same settings as the Moore machine.



Figure 39. The state diagram for vending machine.

- From the top menu, choose File → New → State Machine File.
- 2. In the State Machine Wizard, use the same settings in General and Inputs tabs as the Moore type vending machine.
- 3. In the Outputs tab, enter the *R* as output. Make sure the output is registered.



Figure 40. Mealy output must be registered.

4. In the States tab, enter the following states.

| 🖧 State Machine Wizard |        |                                                      |  |  |  |  |  |
|------------------------|--------|------------------------------------------------------|--|--|--|--|--|
| General                | \/ Inp | uts \/ Outputs \/ States \/ Transitions \/ Actions \ |  |  |  |  |  |
| State                  | Reset  |                                                      |  |  |  |  |  |
| S0                     | Yes    |                                                      |  |  |  |  |  |
| S5                     | No     |                                                      |  |  |  |  |  |
| S10                    | No     |                                                      |  |  |  |  |  |
| < New >                |        |                                                      |  |  |  |  |  |
|                        |        |                                                      |  |  |  |  |  |

Figure 41. Mealy states.

5. In the Transitions tab, enter the following states.

| Me State Machine Wizard                                       |                                                                        |  |  |  |  |  |  |
|---------------------------------------------------------------|------------------------------------------------------------------------|--|--|--|--|--|--|
| General / Inputs / Outputs / States / Transitions / Actions \ |                                                                        |  |  |  |  |  |  |
| Destination State                                             | Transition (In Verilog or VHDL 'OTHERS')                               |  |  |  |  |  |  |
| S5                                                            | N & ~D                                                                 |  |  |  |  |  |  |
| S10                                                           | D                                                                      |  |  |  |  |  |  |
| S10                                                           | N & ~D                                                                 |  |  |  |  |  |  |
| S0                                                            | D                                                                      |  |  |  |  |  |  |
| S0                                                            | N   D                                                                  |  |  |  |  |  |  |
|                                                               |                                                                        |  |  |  |  |  |  |
|                                                               | puts / Outputs //<br>Destination State<br>S5<br>S10<br>S10<br>S0<br>S0 |  |  |  |  |  |  |

Figure 42. Mealy transitions.

6. In the Actions tab, enter the following states.

🚑 State Machine Wizard

| General / Inputs / Outputs / States / Transitions / Action |             |              |          |                       |  |  |  |  |
|------------------------------------------------------------|-------------|--------------|----------|-----------------------|--|--|--|--|
|                                                            | Output Port | Output Value | In State | Additional Conditions |  |  |  |  |
|                                                            | R           | D            | S5       |                       |  |  |  |  |
|                                                            | R           | N   D        | S10      |                       |  |  |  |  |
|                                                            | < New >     |              |          |                       |  |  |  |  |
|                                                            |             |              |          |                       |  |  |  |  |

Figure 43. Mealy actions.

7. Clicking OK aftering entering all the information above gives the following state diagram.



Figure 44. Mealy state diagram.

- 8. Save the file as **vendingmealy.smf**
- 9. Set vendingmealy.smf as Top Level Entity
- 10. General HDL.
- 11. Compile.
- 12. Simulate. You should get the same output as Figure 38.

#### Moore vs Mealy

This summary assumes the reader knows the difference between Mealy and Moore outputs.

Moore outputs are locked to the state. When asserted, Moore outputs are high as long as the FSM is in the particular state regardless of input changes. In *Actions* tab of the *State Machine Wizard*, enter 1 in the *Output Value* column. Refer Figure 19.

Mealy outputs asserted when certain conditions are met in a state. In *Actions* tab of the *State Machine Wizard*, enter the required Boolean expression in the *Output Value* column. Refer Figure 43.

Mealy outputs are glitchy. To make the outputs easier to analyze, set Mealy outputs as *Registered* in the *Outputs* tab in the *State Machine Wizard*. If you do not set it as registered, you must understand the effects of propagation delay, setup time and hold time of flip-flops to predict when the outputs are valid.

|           | Name  | Value at<br>0 ps | 0 ps<br>0 ps | 160,0 ns | 320,0 ns | 480,0 ns | 640.0 ns | 800.0 ns |
|-----------|-------|------------------|--------------|----------|----------|----------|----------|----------|
| is-       | clock | B 0              |              |          |          |          |          |          |
| <u>in</u> | reset | B 1              |              |          |          |          |          | <u> </u> |
| 5         | N     | B 0              |              |          |          |          |          | 13       |
| <u>in</u> | D     | B 0              |              |          |          |          |          |          |
| out       | R     | в 0              |              |          |          |          |          |          |

**Figure 45.** Unregistered Mealy outputs: the circles indicate valid outputs. In Quartus, zoom in to inspect actual output values during the rising edge of the clock.

#### References

- [1] Randy H. Katz and Gaetano Borriello. *Contemporary Logic Design*. 2nd ed. Pearson, 2004.
- [2] Designing State Machines for FPGAs. Application Note 130. Actel Corporation. Sept. 1997. URL: https://www. microsemi.com/document-portal/doc\_view/130043state-machine-an.
- [3] Munim Zabidi, Izam Kamisian, and Ismahani Ismail. *The Art of Digital Design.* 2019.
- [4] Introduction to the Quartus® II Software. Version 10. Altera. 2010. URL: https://www.intel.com/content/ dam/www/programmable/us/en/pdfs/literature/ manual/intro\_to\_quartus2.pdf.