

# ENEL373: DIGITAL ELECTRONICS AND DEVICES UNIVERSITY OF CANTERBURY

# This is an Awesome Title for Our First Report

Philip Brand (15776928)

April 9, 2025

# Contents

#### Introduction

Human reaction time is the interval between the a stimulus and the response to that stimulus. There are two main types of reaction time; simple, and choice. Simple reaction involves reacting to a singular stimulus, while choice reaction involves choosing the correct response from multiple stimuli. This project aims to implement a simple reaction time recorder on an FPGA in VHDL.

The reaction stimulus is three LEDs that turn off sequentially, with a random delay between each LED turning off. Once the last LED turns off, the user must press a button, and the delay is displayed in milliseconds on 8 7-segment displays. The FPGA stores the reaction delays from the last three trials, and can display the fastest, slowest, and average reaction times. These values can be reset by the user.

### **Design Summary**

#### Design Details

#### Finite State Machine

The reaction timer was managed by a finite state machine with the following states: (change these to match the ones in the code)

- Idle: The system is waiting for the user to press the start button. The LEDs are on, and the 7-segment displays are blank.
- Countdown: The system is counting down from a random number between 1 and 5 seconds. The LEDs are off, and the 7-segment displays are blank.
- **Reaction**: The system is waiting for the user to press the button after the last LED turns off. The LEDs are off, and the 7-segment displays are blank.
- **Display**: The system is displaying the reaction time on the 7-segment displays. The LEDs are off, and the 7-segment displays show the reaction time in milliseconds.
- Store: The system is storing the reaction time in the memory. The LEDs are off, and the 7-segment displays are blank.
- **Reset**: The system is resetting the memory. The LEDs are off, and the 7-segment displays are blank.

The reaction delays were stored in a three-element circular buffer.

#### Pseudo-Random Number Generation

The pseudo-random delay between the sequential deactivation of the LEDs was generated using a linear feedback shift register (LFSR) and a clock divider. An eight-bit LFSR was used to generate pseudo-random numbers, and those eight bits were assigned to the most significant eight bits of the upper bound for the clock divider. The next pseudo-random number was generated on a rising clock edge from that clock divider, as seen in Listing ??.

- -- Set the upperbound for the variable clk based on the random number clk\_var\_hz\_divider\_bound(27 downto 20) <= rand\_num;
- -- Generate another clk square wave to trigger a new random number ff10: clk\_divider port map(CLK100MHZ\_IN => CLK100MHZ, SLOWCLK\_OUT => clk\_var\_hz,

UPPERBOUND\_IN => clk\_var\_hz\_divider\_bound);

 ${\it Code\ Listing\ 1:\ Behavioural\ VHDL\ implementation\ of\ pseudo-random\ number\ generation.}$ 

The LFSR was assigned to eight bits, which ensured the minimum delay between LEDs was 100MHz / 2 \*\* 21 - 1

# Module Testing

# Conclusions

Here is how we include a figure in the report. Figure ?? shows an example of a figure. A figure.



Figure 1: This is an example of a figure.