

# Übung 10, Aufgabe 2

Reaktionszeit-Spiel fuer zwei Personen

---

Simon Offenberger S2410306027@fhooe.at

18. Januar 2026

FH Hagenberg

# Agenda

- Struktur des Reaktionszeit-Spiels
- Edge Detection
- Finite State Machine
- Counter
- Hex to 7-Segment Decoder
- Simulation Reaction Time Game
- Ressource Summary

# Struktur des Reaktionszeit-Spiels



# Struktur des Reaktionszeit-Spiels



# Edge Detection

```
1      architecture RTL of EdgeDetection is
2          signal SyncPrev : std_ulegic;
3      begin
4
5          process (iClk, inResetAsync) is
6          begin
7              -- asynchronous reset
8              if (inResetAsync = not('1')) then
9                  SyncPrev <= '0';
10
11             elsif (rising_edge(iClk)) then
12                 if (iEnable = '1') then
13                     SyncPrev <= iSync;
14                 else
15                     SyncPrev <= SyncPrev;
16                 end if;
17             end if;
18         end process;
19
20         -- combinational logic for edge detection
21         oEdge <= '1' when (iSync = '1' and SyncPrev = '0') else
22             '0';
23
24     end architecture RTL;
```



# Finite State Machine Moore



# State Register

```
1  -- State Register
2  process (iClk, inResetAsync) is
3  begin
4      if (inResetAsync = not('1')) then
5          State <= Locked;
6      elsif (rising_edge(iClk)) then
7          if(iEnable = '0') then
8              State <= State; -- hold state when not enabled
9          else
10             State <= NextState;
11         end if;
12     end if;
13 end process;
```

# Next State Logic

```
1 -- State Transition Process
2 nextStateLogic : process (state,iEnable,iA_Sync,iB_Sync) is
3 begin
4
5   nextState <= state;      -- default hold state
6   oLeds <= cLEDOFF;       -- default all leds off
7   oZero <= '0';           -- default zero off
8   oEnableCounter <= '0';  -- default counter disabled
9
10 case state is
11   when Locked =>
12     if(iA_Sync = '1') then
13       nextState <= Unlocked;
14     end if;
15     oZero <= '1';          -- reset counters
16     oLeds(cLED_LOCKED_INDEX) <= '1'; -- indicate locked
17     state
18
19   when Unlocked =>
20     if(iB_Sync = '1') then
21       nextState <= CountUpTime;
22     end if;
23     oLeds(cLED_UNLOCKED_INDEX) <= '1'; -- indicate locked
state
```

```
1
2 when CountUpTime =>
3   oEnableCounter <= '1'; -- enable counter
4   if(iA_Sync = '1') then
5     nextState <= ShowResult;
6   end if;
7   oLeds(cLED_COUNTUP_INDEX) <= '1'; -- indicate locked
state
8
9 when ShowResult =>
10   if(iB_Sync = '1') then
11     nextState <= Locked;
12   end if;
13   oLeds(cLED_SHOWRESULT_INDEX) <= '1'; -- indicate locked
state
14
15 when others =>
16   nextState <= cStateAllOff;
17
18 end case;
19
20 end process;
```

# Finite State Machine RTL-Viewer



# Finite State Machine State Machine Viewer



| Source State  | Destination State | Condition                                    |
|---------------|-------------------|----------------------------------------------|
| 1 CountUpTime | ShowResult        | $(iA\_Sync).(iEnable)$                       |
| 2 CountUpTime | CountUpTime       | $(\neg iA\_Sync) + (iA\_Sync).\neg(iEnable)$ |
| 3 Locked      | Unlocked          | $(iA\_Sync).(iEnable)$                       |
| 4 Locked      | Locked            | $(\neg iA\_Sync) + (iA\_Sync).\neg(iEnable)$ |
| 5 ShowResult  | ShowResult        | $(\neg iB\_Sync) + (iB\_Sync).\neg(iEnable)$ |
| 6 ShowResult  | Locked            | $(iB\_Sync).(iEnable)$                       |
| 7 Unlocked    | CountUpTime       | $(iB\_Sync).(iEnable)$                       |
| 8 Unlocked    | Unlocked          | $(\neg iB\_Sync) + (iB\_Sync).\neg(iEnable)$ |

# Finite State Machine RTL-Viewer

|                                 |                                                |
|---------------------------------|------------------------------------------------|
| Flow Status                     | Successful - Thu Jan 8 10:21:47 2026           |
| Quartus Prime Version           | 23.1std.1 Build 993 05/14/2024 SC Lite Edition |
| Revision Name                   | ReactionGameFSM                                |
| Top-level Entity Name           | ReactionGameFSM                                |
| Family                          | Cyclone V                                      |
| Device                          | 5CSEMA5F31C6                                   |
| Timing Models                   | Final                                          |
| Logic utilization (in ALMs)     | 3 / 32,070 (< 1 %)                             |
| Total registers                 | 4                                              |
| Total pins                      | 11 / 457 (2 %)                                 |
| Total virtual pins              | 0                                              |
| Total block memory bits         | 0 / 4,065,280 (0 %)                            |
| Total DSP Blocks                | 0 / 87 (0 %)                                   |
| Total HSSI RX PCSs              | 0                                              |
| Total HSSI PMA RX Deserializers | 0                                              |
| Total HSSI TX PCSs              | 0                                              |
| Total HSSI PMA TX Serializers   | 0                                              |
| Total PLLs                      | 0 / 6 (0 %)                                    |
| Total DLLs                      | 0 / 4 (0 %)                                    |

|   | Fmax       | Restricted Fmax | Clock Name |
|---|------------|-----------------|------------|
| 1 | 651.89 MHz | 645.99 MHz      | iClk       |

# Counter

```
1 entity Counter is
2   generic(
3     gCounterOverflowVal : natural := 10
4   );
5   port (
6     iClk      : in  std_ulogic;
7     iEnable    : in  std_ulogic;
8     inResetAsync : in  std_ulogic;
9     iZero      : in  std_ulogic;
10    oOverflow   : out std_ulogic;
11    oCount      : out unsigned(LogDualis(gCounterOverflowVal)0
12                                downto 1));
13 end Counter;
```

```
1 architecture RTL of Counter is
2 begin
3
4   -- combinational logic for overflow output
5   oOverflow <= '1' when (iEnable = '1' and iZero = '0' and
6                           oCount = gCounterOverflowVal - 1) else '0';
7
8   process(iClk, inResetAsync) is
9   begin
10     if inResetAsync = not('1') then
11       oCount    <= (others => '0');
12     elsif rising_edge(iClk) then
13       if iZero = '1' then
14         oCount <= (others => '0');
15       elsif iEnable = '1' then
16         if oCount = gCounterOverflowVal - 1 then
17           oCount    <= (others => '0');
18         else
19           oCount <= oCount + 1;
20         end if;
21       end if;
22     end if;
23   end process;
24 end architecture RTL;
```

# Counter RTL Viewer



# Hex to 7-Segment Decoder

```
1 architecture Rtl of Hex2SevenSegment is
2
3     function ToSevSeg(cValue : std_ulegic_vector(3 downto 0)) return std_ulegic_vector is
4
5         begin
6             case cValue(3 downto 0) is
7                 when "0000" => return "0111111";
8                 when "0001" => return "0000110";
9                 when "0010" => return "1011011";
10                when "0011" => return "1001111";
11                when "0100" => return "1100110";
12                when "0101" => return "1101101";
13                when "0110" => return "1111101";
14                when "0111" => return "0000111";
15                when "1000" => return "1111111";
16                when "1001" => return "1101111";
17                when "1010" => return "1110111";
18                when "1011" => return "1111100";
19                when "1100" => return "0111001";
20                when "1101" => return "1011110";
21                when "1110" => return "1111001";
22                when "1111" => return "1110001";
23                when others => return "XXXXXXX";
24            end case;
25        end ToSevSeg;
```

```
1 begin
2
3     o7SegCode <= ToSevSeg(iHexValue);
4
5 end Rtl;
```

# Simulation Reaction Time Game



# Simulation Reaction Time Game



# PCB Adapter



# Ressource Summary

- SyncStage: 2 x 2 Flip-Flops
- EdgeDetection: 2 x 1 Flip-Flops
- StrobeGen: 17 Flip-Flops
- FSM: 4 Flip-Flops
- Counter: 3 x 4 Flip-Flops

Gesamt Anzahl Flip-Flops: 39

# Ressource Summary

| Flow Summary                    |                                                |
|---------------------------------|------------------------------------------------|
| <<Filter>>                      |                                                |
| Flow Status                     | Successful - Tue Jan 13 09:35:01 2026          |
| Quartus Prime Version           | 23.1std.1 Build 993 05/14/2024 SC Lite Edition |
| Revision Name                   | ReactionGameOnDE1SOC                           |
| Top-level Entity Name           | ReactionGameOnDE1SOC                           |
| Family                          | Cyclone V                                      |
| Device                          | 5CSEMA5F31C6                                   |
| Timing Models                   | Final                                          |
| Logic utilization (in ALMs)     | 36 / 32,070 ( < 1 % )                          |
| Total registers                 | 39                                             |
| Total pins                      | 29 / 457 ( 6 % )                               |
| Total virtual pins              | 0                                              |
| Total block memory bits         | 0 / 4,065,280 ( 0 % )                          |
| Total DSP Blocks                | 0 / 87 ( 0 % )                                 |
| Total HSSI RX PCSs              | 0                                              |
| Total HSSI PMA RX Deserializers | 0                                              |
| Total HSSI TX PCSs              | 0                                              |
| Total HSSI PMA TX Serializers   | 0                                              |
| Total PLLs                      | 0 / 6 ( 0 % )                                  |
| Total DLLs                      | 0 / 4 ( 0 % )                                  |

|   | Fmax       | Restricted Fmax | Clock Name |
|---|------------|-----------------|------------|
| 1 | 187.02 MHz | 187.02 MHz      | iClk       |

# Test am DE1 SOC FPGA Board

▶ Video öffnen

# Fragen?