

1. The state transition and output tables for each FSM.

| Location FSM Truth Table |    |    |       |    |    | Sword FSM Transition Table |   |   |       |   |   | Sword FSM Truth Table |     |     |               |     |     | Sword FSM Output Table |    |   |        |   |   |   |
|--------------------------|----|----|-------|----|----|----------------------------|---|---|-------|---|---|-----------------------|-----|-----|---------------|-----|-----|------------------------|----|---|--------|---|---|---|
| Current State            |    |    | Input |    |    | Next State                 |   |   | Input |   |   | Output                |     |     | Current State |     |     | Input                  |    |   | Output |   |   |   |
| S0                       | S1 | S2 | S3    | S4 | S5 | S6                         | N | S | E     | W | V | S0'                   | S1' | S2' | S3'           | S4' | S5' | S6'                    | SW | D | WIN    |   |   |   |
| 1                        | 0  | 0  | 0     | 0  | 0  | 0                          | X | X | 0     | X | X | 1                     | 0   | 0   | 0             | 0   | 0   | 0                      | 0  | 0 | 0      | 0 | 0 | 0 |
| 1                        | 0  | 0  | 0     | 0  | 0  | 0                          | X | X | 1     | X | X | 0                     | 1   | 0   | 0             | 0   | 0   | 0                      | 0  | 0 | 0      | 0 | 0 | 0 |
| 0                        | 1  | 0  | 0     | 0  | 0  | 0                          | X | 0 | X     | 0 | X | 0                     | 1   | 0   | 0             | 0   | 0   | 0                      | 0  | 0 | 0      | 0 | 0 | 0 |
| 0                        | 1  | 0  | 0     | 0  | 0  | 0                          | X | X | 1     | X | X | 1                     | 0   | 0   | 0             | 0   | 0   | 0                      | 0  | 0 | 0      | 0 | 0 | 0 |
| 0                        | 1  | 0  | 0     | 0  | 0  | 0                          | X | 1 | X     | X | X | 0                     | 0   | 1   | 0             | 0   | 0   | 0                      | 0  | 0 | 0      | 0 | 0 | 0 |
| 0                        | 0  | 1  | 0     | 0  | 0  | 0                          | X | 0 | 0     | X | 0 | 0                     | 0   | 1   | 0             | 0   | 0   | 0                      | 0  | 0 | 0      | 0 | 0 | 0 |
| 0                        | 0  | 1  | 0     | 0  | 0  | 0                          | X | X | X     | 1 | X | 0                     | 0   | 0   | 0             | 1   | 0   | 0                      | 0  | 0 | 0      | 0 | 0 | 0 |
| 0                        | 0  | 1  | 0     | 0  | 0  | 0                          | X | X | 1     | X | X | 0                     | 0   | 0   | 0             | 0   | 1   | 0                      | 0  | 0 | 0      | 0 | 0 | 0 |
| 0                        | 0  | 1  | 0     | 0  | 0  | 0                          | X | X | 1     | X | X | 0                     | 0   | 0   | 0             | 0   | 1   | 0                      | 0  | 0 | 0      | 0 | 0 | 0 |
| 0                        | 0  | 0  | 1     | 0  | 0  | 0                          | X | X | 1     | X | X | 0                     | 0   | 0   | 0             | 0   | 0   | 1                      | 0  | 0 | 0      | 0 | 0 | 0 |
| 0                        | 0  | 0  | 0     | 1  | 0  | 0                          | X | X | X     | X | 0 | 0                     | 0   | 0   | 0             | 0   | 1   | 0                      | 0  | 0 | 0      | 0 | 0 | 0 |
| 0                        | 0  | 0  | 0     | 0  | 1  | 0                          | X | X | X     | X | 0 | 0                     | 0   | 0   | 0             | 0   | 0   | 1                      | 0  | 0 | 0      | 0 | 0 | 0 |
| 0                        | 0  | 0  | 0     | 0  | 0  | 1                          | X | X | X     | X | 0 | 0                     | 0   | 0   | 0             | 0   | 0   | 0                      | 1  | 0 | 0      | 0 | 0 | 0 |
| 0                        | 0  | 0  | 0     | 0  | 0  | 1                          | X | X | X     | X | 0 | 0                     | 0   | 0   | 0             | 0   | 0   | 0                      | 0  | 1 | 0      | 0 | 0 | 0 |

2. The Boolean expressions of the state transition and the output logics for each FSM.

Location FSM Boolean Expressions

$$\begin{aligned}
 D[0] &= S0' = S\_OE' + S\_1W \\
 D[1] &= S1' = S\_OE + S\_1'S'W' + S\_2N \\
 D[2] &= S2' = S\_1S + S\_2N'E'W' + S\_3E \\
 D[3] &= S3' = S\_2W + S\_3E' \\
 D[4] &= S4' = S\_2E \\
 D[5] &= S5' = S\_4V' + S\_5 \\
 D[6] &= S6' = S\_4V + S\_6
 \end{aligned}$$

For Reference: SW = S\_3

D = S\_5

WIN = S\_6

SO = set register

S1-6 = reset

Sword FSM Boolean Expressions

$$\begin{aligned}
 D[0] &= S0' = S\_OSW' \\
 D[1] &= S1' = S\_OSW + S\_1 \\
 V &= S\_0'S\_1
 \end{aligned}$$

3. A screenshot of the location FSM schematic (please expand the schematic).



4. A screenshot of the sword FSM schematic (please expand the schematic).



5. A screenshot of the top-level schematic of the entire system.



6. A screenshot of the post-implementation timing report showing the critical path of your design and the worst-case setup time slack.



7. A screenshot of the post-implementation timing report showing the shortest path of your design and the worst-case hold time slack.



8. Answers to the above questions about timing.

- The worst-case setup-time is 5.116 ns, and worst-case hold-slack is 0.494 ns
- Since the period is set to 10 ns, I would subtract the setup-time from the period, which would equal 4.884 ns. Taking the inverse, I conclude that the highest clock speed would be 204 MHz.

$$Max_{freq} = \frac{1}{(Actual\ period - Worst\ Negative\ Slack)}$$

- c. At 5 GHz frequency, the implementation failed the timing. WNS was -2.552 ns and TNS was -37.796 ns. It would not be able to function because the slack time needs to be greater than 0, otherwise there would be no margin. The only way to fix slack time is to reduce the clock frequency.

9. A screenshot of the simulation waveform of your location FSM (Location\_fsm\_tb.v) from behavior simulation.



10. A screenshot of the simulation waveform of your sword FSM (Sword\_fsm\_tb.v) from behavior simulation.



11. A screenshot of the simulation waveform of your entire system (final\_tb.v) from the “Post Implementation Timing Simulation” at the clock frequency of 100MHz.



12. A screenshot of the simulation waveform of your entire system (final\_tb.v) from the “Post Implementation Timing Simulation” at the clock frequency of 5GHz.

