# CMPE 460 Laboratory Exercise 8 Heartrate Monitor

Mohammed Fareed Trent Wesley

Performed: November 8, 2023 Submitted: November 29, 2023

Lab Section: 1

Instructor: Prof. Hussin Ketout

TA: Andrew Tevebaugh

Colin Vo

Lecture Section: 1

Professor: Prof. Hussin Ketout

By submitting this report, you attest that you neither have given nor have received any assistance (including writing, collecting data, plotting figures, tables or graphs, or using previous student reports as a reference), and you further acknowledge that giving or receiving such assistance will result in a failing grade for this course.

| Your Signature: |  |  |
|-----------------|--|--|
| rour Signature: |  |  |
|                 |  |  |

#### Abstract

This laboratory exercise involved the design and construction of a heartbeat detection circuit. For the detection of a heartbeat, a OPB745 reflective optical sensor can be used. This device will emit light through a finger and ideally measure reflected light which varies with the pulse within the arteries of a finger. The signal output is then filtered with a low pass filter and a high pass filter to exclude frequencies outside an expected range of heart rates. The resulting signal is then amplified by an op amp to get a more useable signal. This circuit was designed, simulated using LTspice, constructed on a breadboard, and measured. C code was written with an MSP432 microcontroller which would measure pulse based on the output of the constructed circuit. This exercise also includes the design of a PCB with the same heartbeat detection circuit. This exercise was partially successful since the circuit constructed behaved as expected with an oscilloscope generated sinusoidal signal. The circuit output was accurately used by the MSP432 to detect frequency in beats per minute. The circuit constructed was unable to detect a heartbeat using the OPB745 and the PCB was not designed.

## Design Methodology

A PPG is an instrument used to measure changes in blood volume under the skin. One use of this is to measure heart rate. A circuit was designed with the intent to measure pulse within a finger using a OPB745 reflective optical sensor.



Figure 1: LTspice Schematic

Figure 1 shows the complete schematic designed. The 4N25 represents the OPB745. A 5V source is used to provide power to the OPB745, op amps, and a Schottky diode. Voltage division occurs between the  $10k\Omega$  rseistor and the photodetector. This signal then goes to voltage follower op amp which isolates the signal from the next stage. The signal is then filtered by a passive high pass RC filter. This filter has a cut off frequency of 0.7Hz which is 40bpm. The equation to for the high pass filter design is shown below.

$$R = \frac{1}{2 * \pi * C * f_c} = \frac{1}{2 * \pi * 220nF * 0.7Hz} = 1M\Omega$$
 (1)

With a cut off frequency of  $0.7 \mathrm{Hz}$  and a capacitor value of  $220 \mathrm{nF}$ , 1 shows that the appropriate resistor value is  $1 \mathrm{M}\Omega$ . The signal from the high pass filter then goes through another voltage follower for isolation between stages. Next, the signal is filtered by a passive low pass RC filter. This filter has a cut off frequency of  $3.5 \mathrm{Hz}$  which is  $210 \mathrm{bpm}$ . The equation to for the low pass filter design is shown below.

$$R = \frac{1}{2 * \pi * C * f_c} = \frac{1}{2 * \pi * 220nF * 3.5Hz} = 200k\Omega$$
 (2)

With a cut off frequency of 3.5Hz and a capacitor value of 220nF, 2 shows that the appropriate resistor value is  $200k\Omega$ . After passing through the low pass filter, the signal is amplified by an op amp. To make the signal scale up to about 3.3V, a gain of 101 was implemented. The calculation for resistor values is shown in Figure 3.

$$Gain = 101 = 1 + \frac{R_a}{R_b} = 1 + \frac{100,000\Omega}{1,000\Omega}$$
(3)

After amplification and filtering, the signal goes through one last stage consisting of surge protection. A  $100\Omega$  resistor was added and two Schottky diodes were placed around the output. The upper diode is attached to 2.9V from voltage division and the lower diode is attached to -0.4V. This ensures that voltages above 3.3V and below 0V will be pulled away from the output.

#### Results and Analysis

The circuit was simulated using LTspice, constructed on a breadboard, and then tested and compared to the simulation results. First, the high pass filter of the circuit was simulated using the schematic shown in Figure 2.



Figure 2: High-Pass Filter Schematic

The figure shows that the filter was simulated using a function generator with a 1 V, with a 220 nF capacitor and a 1 M $\Omega$  resistor. The complete circuit was then simulated using an AC sweep with a logarithmic scale from 100 mHz to 100 Hz.

Figure 3 shows the simulation of the high-pass filter of the circuit, performed using an AC sweep with a logarithmic scale from 100 mHz to 100 Hz.



Figure 3: High-Pass Filter Bode Simulation

The figure shows that the gain of the circuit is approximately 0 in the pass band, decreasing as the frequency decreases. The figure also shows that the phase shift of the circuit is approximately 90 degrees in the pass band, decreasing to 0 as the frequency decreases. The cutoff frequency of the circuit is approximately 0.7 Hz, which is equal to the calculated value. The high-pass filter of the circuit was constructed on a breadboard and tested using an oscilloscope and a function generator at different input frequencies and the resulting voltage gain and phase shift were plotted. Figure 4 shows the resulting Bode plot.



Figure 4: High-Pass Filter Bode Plot

The figure shows that the calculated cutoff frequency of 0.7 Hz is approximately correct. The cutoff frequency on the plot is slightly higher than the calculated value, using -9 dB as the cutoff point (3 dB less than the maximum gain). The plot shows that the phase shift

of the circuit is approximately 45 degrees at the cutoff frequency, decreasing to 0 degrees at higher frequencies. The phase shift has the general behavior of increasing from 75 to 0 degrees as the frequency increases.

The results show that the simulation and constructed circuit are similar, with the constructed circuit having a slightly higher cutoff frequency and a slightly lower phase shift at the cutoff frequency. The constructed circuit also has a lower maximum gain (-6 dB) than the simulated circuit (0 dB), which is approximately half of the simulated value. This decrease in gain propagates through the rest of the circuit.

The low pass filter of the circuit was simulated using the schematic shown in Figure 5.



Figure 5: Low-Pass Filter Schematic

The figure shows that the filter was simulated using a function generator with a 1 V, with a 220 nF capacitor and a 200 k $\Omega$  resistor. The complete circuit was then simulated using an AC sweep with a logarithmic scale from 100 mHz to 100 Hz.

Figure 6 shows the simulation of the low-pass filter of the circuit, performed using an AC sweep with a logarithmic scale from 100 mHz to 100 Hz.



Figure 6: Low-Pass Filter Bode Simulation

The figure shows that the gain of the circuit is approximately 0 in the pass band, increasing as the frequency increases. The figure also shows that the phase shift of the circuit is approximately 0 degrees in the pass band, decreasing to -90 degrees as the frequency increases. The cutoff frequency of the circuit is approximately 3.5 Hz, which is equal to the calculated value.

The low-pass filter of the circuit was constructed on a breadboard and tested using an oscilloscope and a function generator at different input frequencies and the resulting voltage gain and phase shift were plotted. Figure 7 shows the resulting Bode plot.



Figure 7: Low-Pass Filter Bode Plot

The figure shows that the calculated cutoff frequency of 3.5 Hz is approximately correct. The cutoff frequency on the plot falls at the calculated value, using -3 dB as the cutoff point

(3 dB less than the maximum gain). The phase shift of the circuit is approximately -38 degrees at the cutoff frequency, decreasing to -65 degrees at higher frequencies, which is the expected behavior. The phase shift has the general behavior of decreasing from 0 to -65 degrees as the frequency increases.

The results show that the simulation and constructed circuit are very similar, with no significant differences between the two.

The band pass filter of the circuit was simulated by combining the high-pass and low-pass filters. Figure 8 shows the simulation of the band-pass filter of the circuit, performed using an AC sweep with a logarithmic scale from 100 mHz to 100 Hz.



Figure 8: Band-Pass Filter Bode Simulation

The figure shows that the gain of the circuit is approximately -3 and -1 in the pass band, with cutoff frequencies of 0.7 Hz and 3.5 Hz, which matches the calculated values. The figure also shows that the phase shift of the circuit is approximately 80 degrees at low frequencies (around 100 mHz) and -80 degrees at high frequencies (around 100 Hz), which is the expected behavior. The phase shift has the general behavior of decreasing from 80 to -80 degrees as the frequency increases. The phase shift is approximately 50 degrees at the lower cutoff frequency and -25 degrees at the upper cutoff frequency, which is the expected behavior. The band-pass filter of the circuit was constructed on a breadboard and tested using an oscilloscope and a function generator at different input frequencies and the resulting voltage

gain and phase shift were plotted. Figure 9 shows the resulting Bode plot.



Figure 9: Band-Pass Filter Bode Plot

The figure shows that the calculated cutoff frequencies of 0.7 Hz and 3.5 Hz are approximately correct. Using -11 dB as the cutoff point (3 dB less than the maximum gain), the lower cutoff frequency is slightly lower than the calculated value and the upper cutoff frequency is slightly higher than the calculated value. The phase shift of the circuit is approximately 30 degrees at the lower cutoff frequency, decreasing to -25 degrees at the upper cutoff frequency, which is the expected behavior. The phase shift has the general behavior of decreasing from 60 to -65 degrees as the frequency increases.

The results show that the simulation and constructed circuit are similar, with the constructed circuit having a slightly lower lower cutoff frequency and a slightly higher upper cutoff frequency. The constructed circuit also has a lower maximum gain (-8 dB) than the simulated circuit (-2 dB), which is attributed to the decreased gain of the high-pass filter of the circuit. The phase shift of the constructed circuit is also slightly lower than the simulated circuit at the lower cutoff frequency.

The PPG circuit was then constructed and simulated in LTspice. Figure 10 shows the schematic of the complete circuit constructed in LTspice.



Figure 10: LTspice Schematic

The figure shows that the OPB745 is simulated using a function generator with a 1 V amplitude and a frequency of 1 Hz, and the circuit is constructed using the appropriate components. The complete circuit was then simulated using an AC sweep with a logarithmic scale from 100 mHz to 100 Hz. Figure 11 shows the simulation of the complete circuit.



Figure 11: Complete Circuit Bode Simulation

The figure shows that the gain of the complete circuit has a maximum of around 9.5 dB at 1.5 Hz. The calculated cutoff frequencies of 0.7 Hz and 3.5 Hz are at 7.6 dB and 7.9 dB, respectively, which is approximately correct. The figure also shows that the phase shift of the circuit is approximately 80 degrees at low frequencies (around 100 mHz) and -65 degrees at high frequencies (around 100 Hz), which is close to the expected values. The phase shift

has the general behavior of decreasing from 80 to -65 degrees as the frequency increases. The phase shift is approximately 30 degrees at the lower cutoff frequency and -30 degrees at the upper cutoff frequency, which is also close to the expected values.

The final output of the circuit was then simulated using a time domain simulation with an input of a 1 V sinusoidal wave with a frequency of 1 Hz. Figure 12 shows the simulation of the complete circuit.



Figure 12: Complete Circuit Time Domain Simulation

The figure shows that the output of the circuit is a conditioned sinusoidal wave with a frequency of 1 Hz, which is the expected behavior. The amplitude of the wave is approximately 3.3 V, which correctly reflects an amplified signal from the OPB745 (in pass band).

The complete circuit was constructed on a breadboard and tested using an oscilloscope. A function generator was used to generate input waves at 200 mHz, 1 Hz, and 10 Hz to simulate a heartbeat at different BPM. Figure 13 shows the oscilloscope capture of the output of the circuit at 200 mHz (12 BPM).



Figure 13: Oscilloscope capture at 200 mHz (stop band)

Figure 13 shows that the output of the circuit is a sinusoidal wave with a frequency of 200 mHz, which is the expected behavior. The amplitude of the wave is approximately 0.6 V,

which correctly reflects a filtered signal from the OPB745 (in stop band). Figure 14 shows the oscilloscope capture of the output of the circuit at 1 Hz (60 BPM).



Figure 14: Oscilloscope capture at 1 Hz (pass band)

Figure 14 shows that the output of the circuit is a sinusoidal wave with a frequency of 1 Hz, which is the expected behavior. The amplitude of the wave is approximately 1.53 V, which correctly reflects an amplified signal from the OPB745 (in pass band). The amplitude of the wave is also approximately half of the simulated value, which is attributed to the decreased gain of the high-pass filter of the circuit.

Figure 15 shows the oscilloscope capture of the output of the circuit at 10 Hz (600 BPM).



Figure 15: Oscilloscope capture at 10 Hz (stop band)

Figure 15 shows that the output of the circuit is a sinusoidal wave with a frequency of 10 Hz, which is the expected behavior. The amplitude of the wave is approximately 0.76 V, which correctly reflects a filtered signal from the OPB745 (in stop band).

The final output of the circuit was then fed into an MSP432 microcontroller to measure the frequency of the signal. The microcontroller was programmed to measure the frequency of the signal and output the frequency in beats per minute (BPM) to a serial monitor. The microcontroller was programmed to fire interrupts to capture the ADC value of the signal. The ADC value was then converted to a voltage and used to calculate a BPM. The following is the code used:

```
#define CAPTURE_FREQ (122)
                              // frequency of ADC data capture
#define VOLTAGE_CUTOFF (5000) // voltage cutoff for a heartbeat
unsigned int count = 10001;
unsigned int previous = 0;
double prev_bpm = -1;
static char str[100];
// Interrupt Service Routine for Timer32-1
void Timer32_1_ISR(void) {
    char str[30];
    unsigned int num = ADC_In();
    if (num >= VOLTAGE_CUTOFF && previous < VOLTAGE_CUTOFF){</pre>
        double bpm = 7320 / count;
        int abs = bpm - prev_bpm;
        if (abs < 0) abs = abs * -1;
        count = 0;
        if (bpm > 40 && bpm < 220 && abs < 11) {
            // print bpm
            sprintf(str, "Heart %d BPM\r\n", (int)bpm);
            uart0_put(str);
        }
        prev_bpm = bpm;
    }
    else { count++; }
    previous = num;
}
int main(void)
    DisableInterrupts();
    uart0_init();
    Timer32_1_Init(&Timer32_1_ISR, SystemCoreClock / CAPTURE_FREQ, T32DIV1);
    ADCO_InitSWTriggerCh6();
```

```
EnableInterrupts();
  uart0_put("Initialized\r\n");
  while (1) {}
}
```

The code shows that the BPM was calculated by counting the number of ADC values that were below a certain voltage cutoff relative to all ADC values. The ADC values were captured at a frequency of 122 Hz. The BPM was then calculated using Equation 4.

$$BPM = \frac{CAPTURE\_FREQ \times 60}{count}$$
 (4)

The code shows that the BPM was only calculated if the BPM was between 40 and 220 and the difference between the current BPM and the previous BPM was less than 11. This was done to prevent the BPM from fluctuating too much, providing a more stable reading. The microcontroller was then connected to the circuit and the circuit was tested using a function generator to generate input wave to simulate a heartbeat at different BPM. Figure 16 shows the output of the serial monitor.

| <b>₽</b> CON | M5 - PuTTY |
|--------------|------------|
| Heart        | 120 BPM    |
| Heart        | 120 BPM    |
| Heart        | 122 BPM    |
| Heart        | 59 BPM     |
| Heart        | 59 BPM     |
| Heart        | 60 BPM     |
| Heart        | 59 BPM     |
| Heart        | 60 BPM     |
| Heart        | 88 BPM     |
| Heart        | 90 BPM     |
| Heart        | 88 BPM     |
| Heart        | 91 BPM     |
| Heart        | 87 BPM     |
| Heart        | 88 BPM     |
| Heart        | 98 BPM     |
| Heart        | 116 BPM    |
| Heart        | 118 BPM    |
| Heart        | 120 BPM    |
| Heart        | 124 BPM    |
| Heart        | 120 BPM    |
| Heart        | 122 BPM    |
| Heart        | 59 BPM     |
| Heart        | 60 BPM     |
|              |            |

Figure 16: Serial Monitor Output

The figure shows that the output of the serial monitor is the BPM of the input wave, which was manually set to 2 Hz, 1 Hz, 2 Hz, and then 1 Hz. The BPM is calculated to to be 120, 60, 120, and 60, respectively, which matches the output shown in the figure. The output also shows slight fluctuations in the BPM of  $\pm 1$ , which is attributed to noise.

### Questions

- 1. What is the ERC and DRC for?
- ERC stands for Electrical Rule Check and DRC stands for Design Rule Check. The ERC checks for electrical errors in the schematic, such as unconnected pins. The DRC checks for design errors in the schematic, such as incorrect pin types.
- 2. Did your circuit cutoff frequencies match your expected/calculated values? Explain The cutoff frequency of the low-pass filter of the circuit matched the calculated values. The cutoff frequencies of the high-pass and band-pass filters were slightly different than the calculated values, but were close enough to be considered correct.
- 3. Did the gain of the circuit match the expected/calculated values? Explain
  The gain of the circuit was slightly lower than the calculated values, but was close enough to be considered correct, which is attributed to the use of a real op amp instead of an ideal op amp. The gain of the high-pass filter was approximately half of the calculated value, which propagated through the rest of the circuit, causing a decreased gain in the band-pass filter, and thus, the complete circuit.

#### Conclusion

This report details the design, simulation, construction, and testing of a heart rate monitoring circuit. The exercise achieved partial success, demonstrated by the effective performance of the constructed circuit with an oscilloscope-generated sinusoidal signal and its compatibility with the MSP432 microcontroller for heartbeat frequency detection. However, problems and limitations were encountered, such as the inability of the OPB745 sensor in the constructed circuit to detect an actual heartbeat and the gain drop in the high-pass filter stage of the circuit. The experimental results were generally consistent with the simulations, showing slight deviations in cutoff frequencies and gain values, which can be attributed to the practical limitations of real-world components versus idealized simulation models.

Exercise 8: Heartrate Monitor

Student's Name: Trent Wesley Section: 11

|      | Demo                                     | Point<br>Value | Points<br>Earned | Date     |
|------|------------------------------------------|----------------|------------------|----------|
|      | Pre-Lab<br>(Individual)                  | 10             | 10               | ATT 11/8 |
| Demo | LTspice and<br>Plots for HRM             | 10             | 10               | ATTILE   |
|      | Completed HRM                            | 20             | 20               | W31 1172 |
|      | PCB Design and<br>Layout<br>(Individual) | 10             |                  |          |

Bonus: Working HRM with OPB745 (10 pts)

To receive any grading credit students must earn points for both the demonstration and the report.

Exercise 8: Heartrate Monitor

Student's Name: Mohammed Farred Section: 1

|      | Demo                                     | Point<br>Value | Points<br>Earned | Date      |
|------|------------------------------------------|----------------|------------------|-----------|
|      | Pre-Lab<br>(Individual)                  | 10             |                  |           |
| Demo | LTspice and<br>Plots for HRM             | 10             | 10               | ATT 11/28 |
|      | Completed HRM                            | 20             | 20               | 109       |
|      | PCB Design and<br>Layout<br>(Individual) | 10             |                  |           |

Bonus: Working HRM with OPB745 (10 pts)

To receive any grading credit students must earn points for both the demonstration and the report.