## Digital Signal Processing

For a wireless ECG solution

Bachelor thesis K. Khalili & S. Speekenbrink

adhalaanna



Delft University of Technology

Delft Uni

## Digital Signal Processing

### For a wireless ECG solution

by

## K. Khalili & S. Speekenbrink

Student Name Student Number

Keyvan Khalili 5118190 Sebastian Speekenbrink 5038324

Supervisor: Prof. Dr. Ir. W.A Serdijn Project Duration: Apr, 2022 - Jun, 2022 Faculty: Faculty of Electrical Engineering, Mathematics and Computer Science (EEMCS), Delft

Style: TU Delft Report Style, with modifications by Daan Zwaneveld



### Abstract

<span id="page-2-0"></span>The goal of the WiECG project is to create a prototype device that makes it possible to perform a 12-lead ECG measurement on patients without wires from the patient to a monitor. The solution consists of a transmitter and receiver, one of which is close or on the patients body and the other is connected to a monitor.

This thesis describes the design and implementation of a subsystem of the prototype device that performs digitization, digital processing and reconstruction of the measured 12-lead ECG signal. This concerns converting nine 0 to 3.3V analog signals to the digital domain by using Analog-to-Digital converters, real-time filtering of nine signals with multiple digital IIR filters and reconstructing nine digital signals to the analog domain using Digital-to-Analog converters. Furthermore, component selection, design decisions and the implementation process will be detailed in this document.

The subsystem proposed in this paper is able to successfully sample, efficiently filter and reconstruct nine signals in real time. Recommendations on improving the implementation to better adhere to the lower power requirements for a longer battery life are provided as future research prospects.

## Preface

<span id="page-3-0"></span>This thesis is written in context of the Bachelor Graduation Project. The project was proposed by S. Speekenbrink who originally got the idea for this project by working closely together with ambulance personnel during his minor project.

This thesis was completed in cooperation with two other groups, Hardware: R. van Krieken and P. Wiersma and Protocol: Geert Custers and Stefan Loen, all together under the supervisement of Prof. Dr. Ir. W.A. Serdijn.

As all different groups worked together very closely, documenting the work in a logical flow was quite the challenge. **It is therefore recommend to read the theses in the following order: Protocol, Digital Signal Processing and Hardware.**

We would like to thank our supervisor Wouter Serdijn for providing invaluable insights and great starting points, Asli Boru and Francesc Varkevisser for the incredible feedback and of course the other members of the WiECG group for their hard work in completing the project. Furthermore we also would like to thank Martin Schumacher for providing us with all the components needed to manufacture the WiECG system.

> *K. Khalili & S. Speekenbrink Delft, July 2022*

## **Contents**





## Nomenclature

#### <span id="page-6-1"></span><span id="page-6-0"></span>**Abbreviations**



### Introduction

<span id="page-7-0"></span>This thesis was written in collaboration with 6 people. The project was divided in three subgroups, each delivering their own thesis. For this reason some parts in this thesis will mimic those of other groups (e.g. General Introduction, problem statement, proposed solution and state of the art). To preserve the logical flow of the design, the order of reading should be as follows: Protocols [\[1\]](#page-38-1), Digital Signal Processing and Hardware [\[2\]](#page-38-2).

#### <span id="page-7-1"></span>**1.1. The WiECG Project**

In the Netherlands alone, 1.3 million ambulance rides are made each year. Of these 1.3 million rides 76 % are urgent [\[3\]](#page-38-3). After interviewing Jim van Akkeren (Operational Head Witte Kruis Ambulance Zorg Den Haag) and Mirthe Ruijgrok (Ambulance operator) it was concluded that in 90% cases an [ECG](#page-6-1) is connected to the patient being transported. An ECG is used in many cases to exclude a heart related problem as the treatment of such should happen as fast as possible. Furthermore ECGs are used when any form of anaesthesia or medicine is administered, to monitor the patient's reaction.

As the deployment of an ECG requires wires, problems arise for the ambulance personnel in applying them. The Wireless ElectroCardioGram project aims to replace these wires with a wireless solution.

#### <span id="page-7-2"></span>**1.1.1. Basics of ECG**

An [ECG](#page-6-1) is a visualization of the muscle contractions produced by a heart. This is done by measuring the vector projection of the hearts' electrical field on the chest of a patient. The measurement is done using electrodes located on the body of the patient, which measure potentials that are causing heart contractions. These potentials produced by the heart are then registered and visualized on a monitor.

There are two main ECG variations health workers employ [\[4\]](#page-38-4). One with 4 electrodes and one with 6 additional ones. The first configuration is called the extremity electrodes, which can give a general electrical overview of the heart functions. In the second configuration 6 other electrodes are added: the chest electrodes. These give more detailed information of the heart on which diagnoses can be made [\[5\]](#page-38-5). With these signals 12 signatures in total can be obtained.

#### <span id="page-7-3"></span>**1.1.2. Problem statement**

<span id="page-7-4"></span>As shown before, the usage of ECGs by ambulance personnel is crucial to ensure the well-being of the patients. ECGs are currently applied by usage of electrodes attached to the chest of the patient. For regular, non emergency use, only the extremity electrodes are used. In emergency situations a full 12 lead (10 electrodes/wires) configuration is used. Currently these electrodes consist of stickers connected to wires which are connected to a heart monitor. According to the interviewed ambulance personnel, the wires are very annoying to work with in emergency situations. The wires get tangled, dirty and in the way of the ambulance personnel as it obstructs the cabin.

#### **1.1.3. Proposed Solution**

The proposed solution is a device where the same monitor can be used as before, but where the cables have been replaced by a pair of wireless devices, a transmitter device and a receiver device. The transmitter device has 10 electrodes which have to be applied to the patient like before, requiring no extra actions for the operator. The receiver side can be plugged in to the monitor, also requiring no extra actions. This plug-and-play system can be used with any [ECG](#page-6-1) monitor as long as the connector for that monitor is available. To make sure that the devices transmit and receive the right signal and not that of another pair, they can be paired easily by having the transmitter and receiver briefly connect with each other. This solution solves the problems mentioned in Chapter [1.1.2](#page-7-3) in the following way:

- The short cables tend to tangle up way less compared to the longer ones.
- Because the transmitter device is located near the patient and the receiver lies next to the [ECG](#page-6-1) monitor, no cables are suspended through the ambulance, greatly improving the comfort/workflow of the operator.

To achieve this goal, a self proposed electrical engineering bachelor graduation project was submitted to Delft University of Technology. This project will be executed with 6 people and is split up into three parts:

- Protocol [\(PROT\)](#page-6-1) The group that deals with the wireless transmission of the [ECG](#page-6-1) data
- Digital Signal Processing [\(DSP\)](#page-6-1) The group that converts, processes digitally and reconstructs the signal and forwards it to the wireless module
- Hardware [\(HW\)](#page-6-1)

The group that prepares the measured signals for digital conversion and facilitates the aforementioned groups in creating a prototype device.



**Figure 1.1:** Brief overview of the solution and the separation of tasks

#### <span id="page-8-0"></span>**1.1.4. State Of The Art**

Currently wireless heart monitoring (via ECG) is mainly used in several markets; medical and consumer. Consumer wireless ECG systems (e.g. KardiaMobile  $6L^{TM}[6]$  $6L^{TM}[6]$ ) are usually limited to 6 leads, or only one in case of wearable devices (e.g. *Apple Watch™, Galaxy Watch™*), which outputs the data to a smartphone or display. Furthermore, the sensors and workflow used to obtain the ECG differ majorly from those that the medical personnel use. (No stickers but hand**held**/wearable sensor device).

The medical market is home to devices which are purpose-made for health monitoring on a diagnostic or treatment level. Currently, the Lifepak 15™[\[7\]](#page-38-7) is in use in many ambulances to monitor the vitals of the patient. This device is part of a production line which is 12 years old and still in use - in Dutch ambulances - due to the others<sup>[1](#page-8-1)</sup> not being reliable (slow to start up, easily breakable or plainly not working). The connections to the monitor of these currently used monitors are however wired, leading to the aforementioned problems.

<span id="page-8-1"></span><sup>1</sup>Jim van Akkeren stated that since 2017 the Philips Tempus ALS™[\[8\]](#page-38-8) monitor was in use. But most ambulance regions stopped usage due to complaints of reliability

There are however medical wireless monitoring systems on the market that remove the wires between patient and monitor. Some examples are the ZOLL Heart Failure Management System (HFMS)™[\[9\]](#page-38-9) and the Corpuls3™[\[10\]](#page-38-10). However, the HFMS focusses on detection of heartattacks in a non emergency setting and the Corpuls3 simply has a detachable wireless display (the relatively bulky defibrilator/patient box of around 3 kg has to be close to the patient). None of the devices researched focused on removing the medium of the signal like the proposed solution.

#### <span id="page-9-0"></span>**1.2. Subgroup Digital Signal Processing**

The Digital Signal Processing [\(DSP\)](#page-6-1) subgroup concerns itself with the realisation of a submodule that digitizes, digitally filters and reconstructs an analog signal, received from the Hardware group.

#### <span id="page-9-1"></span>**1.2.1. Background research**

One of the most important aspects of the system is successfully capturing the important characteristics of the incoming ECG signal. Two important system features that have a big contribution to capturing the important characteristics of the incoming ECG signal are sampling resolution and sampling frequency. The research done into these two system features will be presented in this section.

#### **ECG Frequency contents**

The maximum frequency of the input signal is an important metric, as this determines the sampling frequency. Article [\[11\]](#page-38-11) states that QRS frequency content is composed of components from the minuscule to at least 700 Hz. Article [\[12\]](#page-38-12) concludes that a 250 Hz sampling frequency would be acceptable for HRV analysis and 100 Hz would already be acceptable if frequency-analysis is not needed on the signal. Furthermore, Article [\[13\]](#page-38-13) even states that virtually all of the power is contained in frequencies below 30 Hz with peak power occurring in the range of 4 to 12 Hz. On top of that, another article [\[14\]](#page-38-14) states that a sampling frequency of 100 Hz or 250 Hz is sufficient if used by convolutional network-based deep learning models for QRS detection methods.

#### **Analysis**

In order to gain a better view on these papers, an analysis was performed on the PTB Diagnostic ECG Database [\[15\]](#page-38-15) [\[16\]](#page-38-16). Fast Fourier Transform (FFT) was performed on all the patients in the data set and the absolute values of the frequency components were summed together to give a better understanding of what frequency components compose an ECG recording. Figure [1.2](#page-9-2) shows the resulting value of the frequency spectrum of all the patients summed.

Very low frequency components (0-0.5 Hz) dominate the signal, as seen in Figure [1.2a.](#page-9-2) Therefore frequencies under 0.5 Hz were left out in Figure [1.2b](#page-9-2) to give a better visualisation of the amplitude of the different frequency components.

<span id="page-9-2"></span>

**Figure 1.2:** Frequency spectrum PTB Diagnostic Database

As seen in Figure [1.2b,](#page-9-2) mostly frequency components in the range from 0 to 50 Hz are present, with little to no energy in frequencies above 50 Hz. Furthermore, the small 50 Hz peak can be accounted for due to 50 Hz noise being present in the signal.

All in all, a sampling frequency of 500 Hz was chosen to include all frequencies up to 250 Hz, but also keep the data rate to an acceptable level.

#### **ECG Resolution**

The sampling resolution is in part based on Article [\[17\]](#page-38-17). This article states that a 16 bit resolution with the [LSB](#page-6-1)  $< 10 \mu V$  is sufficient for the reliable analysis of the P-wave and will most likely suffice for the other parts of an ECG signal as well. Furthermore, an amplification [\[2\]](#page-38-2) is performed on the original signal by the Hardware group, thus theoretically increasing the minimum voltage step per [LSB](#page-6-1) and thus also the resolution. All in all, in order to stay ahead of the curve, to keep the programming simple (by choosing the bit resolution as a multiple of 8) and to not be dependent on the hardware subgroup (as this resolution is sufficient to not need an amplification circuit), a bit resolution of 16 bits was chosen as the sampling resolution, with the [LSB](#page-6-1) comprising <sup>5</sup>.<sup>0</sup> <sup>∗</sup> <sup>10</sup>−<sup>5</sup> V (see eq. [4.1\)](#page-15-4). Note that the effective resolution could theoretically exceed the resolution proposed in article [\[17\]](#page-38-17) because of the Hardware amplification circuit [\[2\]](#page-38-2).

## Program of requirements

<span id="page-11-0"></span>Here the most important requirements are listed. Throughout the report, these requirements will get referenced to ensure that the design choices that were made have value for the end result of this project. The design described in this report and the reports of the other subgroups will attempt to completely fulfill the following list:

- **G1:** The device must not employ wires from patient to monitor.
- **G2:** The device must allow the user to perform a 12 lead ECG.
- **G3:** The device must be safe for the patient
- **G4:** The data handled by the device must be safeguarded
- **G5:** The device must not induce a delay of more than 5 seconds to the workflow of the user compared to a regular ECG wire.
- **G6:** The signal transferred by the device must be indistinguishable by the eye from the signal transferred by a regular ECG wire.
- **G7:** The device must have a battery life of 2 hours.
- **G8:** The device must not be bigger than 10cm x 20cm x 5cm (a smartphone-device)
- **G9:** The device must be lighter than 500 gram
- **G10:** A prototype device must be functional within 10 weeks from the start of the project.
- **G11:** The prototype must not cost more than 500 euros.

From this list, the following requirements were specified which specifically apply to the digital signal processing part of this project.

- **G2D:** The system must be able to sample nine signals
- **G3D:** Added noise must be removed to prevent misdiagnosis due to a distorted signal
- **G5D:** The signal processing must be done in real-time
- **G6D.a:** An input signal must be sampled at 500 Hz
- **G6D.b:** An input signal must be sampled at 16 bits resolution
- **G6D.c:** The digitized input signals must be reconstructed at 16 bit resolution
- **G6D.d:** The digitized input signals must be reconstructed at 500 samples per second
- **G7D:** Signal processing must be computationally efficient to be implemented in low power microcontrollers.
- **G10D:** The digital processing submodule must be developed within the given timespan

### System Overview

<span id="page-12-0"></span>The proposed solution in the introduction [1.1.3](#page-7-4) can, in accordance to the [PoR,](#page-6-1) be further specified as shown in figure [3.1.](#page-12-3) This also depicts a high-level overview of the contributions of each subgroup. In section [3.1.1](#page-12-2) and [3.1.2,](#page-13-0) brief descriptions will be given of how the different parts of the transmitter and receiver attempt to fulfill the requirements given in chapter [2.](#page-11-0) Finally, in section [3.2,](#page-13-1) the complete system is shown where the detailed overviews are connected to the detailed overviews of other subgroups.

<span id="page-12-3"></span>

**Figure 3.1:** Block diagram of the general overview of the solution

#### <span id="page-12-1"></span>**3.1. Submodule Overview**

<span id="page-12-2"></span>In order to fulfill the requirements from chapter [2,](#page-11-0) two subsystems have been developed, a transmitter subsystem and a receiver subsystem. These subsystems have been realized on a Nucleo development board with a STM32H743ZI [MCU,](#page-6-1) now referred to as [STM32 MCU,](#page-6-1) together with extra peripherals. The subsystems are noted as the 2 Nucleo blocks in figure [3.1.](#page-12-3) The explanation for why this particular development board[/MCU](#page-6-1) was chosen can be found in chapter [4.1.3.](#page-16-0) The detailed overview of both subsystems can be seen in figure [3.2.](#page-13-2) Both subsystems, transmitter and receiver, will be discussed in chapter [3.1.1](#page-12-2) and chapter [3.1.2](#page-13-0) respectively.

<span id="page-13-2"></span>

**Figure 3.2:** DSP System Overview

#### **3.1.1. Transmitter**

The transmitter subsystem prepares the analog signal for transmission by the Protocol subgroup. The subsystem converts the analog signal to a digital format needed for the wireless transmission and is completely realised on a [STM32 MCU,](#page-6-1) placed on a Nucleo development board. The transmitter subsystem comprises 3 [ADCs](#page-6-1) and a filter system. The [ADCs](#page-6-1) take care of converting an analog signal to the digital domain. The design will be discussed in chapter [4.1.1](#page-15-2) and the implementation will be discussed in chapter [5.1.](#page-23-1)

The filter system removes certain signal artifacts, with the filter design discussed in chapter [4.2](#page-16-1) and the implementation discussed in chapter [5.2.](#page-25-0)

#### <span id="page-13-0"></span>**3.1.2. Receiver**

The receiver subsystem reconstructs 9 analog signals<sup>[1](#page-13-3)</sup> from a digital signal received from the Protocol subgroup. The receiver subsystem comprises a [STM32 MCU,](#page-6-1) placed on a Nucleo development board, and 3 external [DACs.](#page-6-1) The [STM32 MCU](#page-6-1) takes in digital data from the protocol subgroup, modifies the data to be used by [DACs](#page-6-1) and transmits the modified data to multiple [DACs](#page-6-1) where the digital signal is converted to an analog signal.

#### <span id="page-13-1"></span>**3.2. Complete overview**

Figure [3.3](#page-14-0) shows the Protocol subgroup's responsibility placed in the complete overview of the system. For complete understanding of this figure, refer to the report of [PROT\[](#page-6-1)[1\]](#page-38-1) and Hardware[\[2\]](#page-38-2)

<span id="page-13-3"></span><sup>1</sup>12 analog signals if the system is used as a stand-alone product.

<span id="page-14-0"></span>

**Figure 3.3:** Complete overview of the WiECG project

## Design

<span id="page-15-0"></span>The objective of the design is to quantize the already amplified ECG signals, received from the Hardware subgroup, and process the signal so that it is ready for wireless transmission on the transmitter side. The second part is processing the received signal and reconstructing the signal so that it may be displayed on an external display, either an oscilloscope or an ECG monitor.

#### <span id="page-15-1"></span>**4.1. Hardware**

The first aspects of the design that are considered include selection of capable hardware to assure high quality, real-time capable components. The hardware that is required to realize digital signal processing include Analog-to-Digital / Digital-to-Analog Converters [\(ADC/DAC\)](#page-6-1) and a microcontroller [\(MCU\)](#page-6-1).

#### <span id="page-15-2"></span>**4.1.1. ADC for digitization**

Before any processing can be done, the signal has to be digitized. This is done by an Analog-to-Digital Converter. There are certain requirements that are taken into account when choosing an [ADC](#page-6-1) when it comes to digitizing ECG signals. For working with ECG signals, the [ADC](#page-6-1) has to be very accurate, i.e have high enough resolution (16-bit as in **[G6D.b](#page-11-0)**) and have a fast sampling rate (minimum of 500 Hz as in **[G6D.a](#page-11-0)**) as to not hinder real-time processing of the ECG signal or consume less of the time budget (**[G10D](#page-11-0)**).

There are five different [ADC](#page-6-1) types available, namely Successive Approximation (SAR), Delta-sigma (ΔΣ), Dual Slope, Pipelined and Flash ADCs, two of which are suitable for data acquisition, Successive Approximation and Delta-sigma. These 2 technologies are able to provide an adequate resolution, sampling rate and price compared to the others and are therefore suited. The pros and cons of the possible technologies to be used is summarized in the following table [\[18\]](#page-39-0):





<span id="page-15-3"></span>A 16-bit successive approximation embedded [ADC](#page-6-1) was eventually chosen. Three of these ADCs are embedded into the [STM32 MCU](#page-6-1) and were therefore chosen, as these [ADCs](#page-6-1) satisfied the requirements (**[G6D.a](#page-11-0)** and **[G6D.b](#page-11-0)**) and are easy to interface with. These [ADCs](#page-6-1) have a 16 bit resolution, quantifying from 0V to 3.3V, with the [LSB](#page-6-1) comprising:

<span id="page-15-4"></span>
$$
3.3/2^{16} \approx 5.0 \times 10^{-6} \text{ V}
$$
 (4.1)

#### **4.1.2. DAC for reconstruction**

While selecting ADCs, its counter-part responsible for reconstruction of the digital data was also selected, a Digital-to-Analog Converter [\(DAC\)](#page-6-1). Typical architectures of the [DACs](#page-6-1) found included R-2R ladder and resistor string. The chosen [MCU,](#page-6-1) explained in section [4.1.3,](#page-16-0) is equipped with a single internal [DAC,](#page-6-1) capable of outputting two channels of data at a lower bit resolution of 12 bits. Therefore, reconstruction of the ECG data should be done using external [DACs](#page-6-1) with a minimum resolution of 16 bits. The [DACs](#page-6-1) that were considered for the prototype and their important characteristics are summarized in table [4.2.](#page-16-2)

<span id="page-16-2"></span>

| Property               | TI DAC8554IPW      | AD5675ARUZ   | <b>TI DAC8574</b> |
|------------------------|--------------------|--------------|-------------------|
| Supply Voltage         | $2.7 - 5.5V$       | $2.7 - 5.5V$ | $2.7 - 5.5V$      |
| Channels               |                    |              |                   |
| Data interface         | SPI/QSPI/Microwire | $I^2C$       | $I^2C$            |
| Integral non-linearity | ±12LSB             | $\pm 8LSB$   | ±64LSB            |
| Gain error             | $\pm 0.15$         | $\pm 0.24$   | $\pm 1.0$         |
| Output settling time   | $10\mu s$          | $8\mu s$     | $10\mu s$         |
| Output slew rate       | $1.8V/\mu s$       | $0.8V/\mu s$ | $\bar{1}V/\mu s$  |
|                        |                    |              |                   |

**Table 4.2:** Multi-channel 16-bit Digital to Analog converters [\[19\]](#page-39-1)[\[20\]](#page-39-2)[\[21\]](#page-39-3)

The chosen [MCU](#page-6-1) is equipped with both Serial Peripheral Interface [\(SPI\)](#page-6-1) and Inter-Integrated Circuit  $(I<sup>2</sup>C)$  protocol which makes implementation of all the listed [DACs](#page-6-1) possible. However, as reliability is an important aspect of the prototyne it is necessary to ensure that the data has successfully been received [impo](#page-6-1)rtant aspect of the prototype, it is necessary to ensure that the data has successfully been received by the [DACs.](#page-6-1) Normally, [SPI](#page-6-1) is implemented with a 4-wire setup with bidirectional flow of information between the Master sender and the Slave receiver. However, in Texas Instruments DAC8554 [SPI](#page-6-1) is implemented with a 3-wire setup with a one-way communication protocol, thus making confirmation of data arrival impossible. Therefore, [DAC](#page-6-1) AD5675ARUZ by Analog Devices is the most suitable [DAC](#page-6-1) for the project due to its low gain error, low integral non-linearity error and its  $I<sup>2</sup>C$  communication interface interface.

Despite AD5675ARUZ being the most suitable [DAC](#page-6-1) for the prototype, the prototype was made with TI DAC8574IPW due to lack of AD5675 availability, caused by the chip shortages. This compromise had to be made due to the requirement **[G10](#page-11-0)** which dictates the time frame the prototype has to be ready in.

#### <span id="page-16-0"></span>**4.1.3. Microcontroller**

The microcontroller is chosen based on its capability to perform intensive calculations needed for digital signal processing and its ability to store data (RAM/Memory). Unfortunately, due to the global chip shortage and the inability to solder a microcontroller by hand, it was decided to implement a development board into the system instead of using a standalone microcontroller placed on the [PCB.](#page-6-1) Therefore, only development boards with a [MCU](#page-6-1) implemented thereon will be considered as options for the microcontroller choice.

The microcontroller boards that were considered for this purpose include many different development boards. Table [4.3](#page-17-1) shows the different development boards and their pros and cons. Simply by comparing the price against performance, all of the Arduino boards are too expensive for the performance they deliver compared to the alternatives presented. Furthermore, the Protocol subgroup tested the capabilities of an Arduino Mega for filtering and deemed this development board not powerful enough for the tasks it would need to perform. Therefore, it was decided against using any Arduino board to realize the [DSP](#page-6-1) subsystem.

<span id="page-16-1"></span>At last, the Nucleo-H743ZI2 was chosen as the development board in the [DSP](#page-6-1) subsystem, as this development board already had adequate [ADCs](#page-6-1) embedded into the chip present on the board, compared to the Teensy and the NUCLEO-F411RE. Performance-wise, the Teensy 4.1 and NUCLEO-F411RE would have been more than capable in performing the calculations needed, but were not chosen as external [ADCs](#page-6-1) would have to been implemented and interfaced with, thus increasing the complexity of the system. Furthermore, the Nucleo-H743ZI2 makes use of the STM32H743ZIT6 [MCU](#page-6-1) [\[22\]](#page-39-4), a high-performance ARM Cortex-M7 chip, highly capable of the tasks it would need to perform.

<span id="page-17-1"></span>

| Board:                 | Clock Speed:<br>(MHz) | RAM/ROM:<br>(KB) | Memory:<br>(KB) | Extra:                                                                            | Price:<br>(EUR)          |
|------------------------|-----------------------|------------------|-----------------|-----------------------------------------------------------------------------------|--------------------------|
| Arduino Uno Rev3       | 16                    | 2/1              | 32              | 8 channel, 10-bit ADC                                                             | 22<br>(Arduino) [23]     |
| Arduino Mega 2560 Rev3 | 54                    | 8/4              | 256             | 8/16 channel, 10-bit ADC                                                          | 38.50<br>(Arduino) [24]  |
| Arduino Due            | 84                    | 96               | 512             | 12-bit ADC<br>12-bit DAC                                                          | 38.50<br>(Arduino) [25]  |
| Portenta H7 Lite       | 480                   | 8196             | 16384           | 3× 16-bit ADC (36 channels, 3.6 MSPS)<br>$2x$ 12-bit DAC.<br><b>DSP</b> Extension | 63<br>(Arduino) [26]     |
| Teensy 4.1             | 600                   | 1024             | 7936            | 12-bit ADC<br><b>DSP</b> Extension<br>Not available                               | 33.28<br>(Mouser) [27]   |
| NUCLEO-F411RE          | 100                   | 128              | 512             | 1×12-bit ADC (16 Channels, 2.4 MSPS)<br>DAC not available<br><b>DSP</b> Extension | 12.84<br>$(Mouser)$ [28] |
| NUCLEO-H743ZI2         | 480                   | 1024             | 2048            | 3×16-bit ADC(36 channels, 3.6 MSPS)<br>2x 12-bit DAC<br><b>DSP</b> Extension      | 26.68<br>$(Mouser)$ [29] |

**Table 4.3:** Development board specifications

#### **4.2. Noise filtering**

There are different filtering approaches available, each suited for removal of a particular type of noise. They can be divided into a few categories[\[30\]](#page-39-12):

- 1. Spatiotemporal domain method such as classical Wiener filters, median filters and adaptive filters. The disadvantage of this approach is that they are no suitable for non-stationary signals such as the cardiac signal. However they can be used for removal of frequency varying PLI[\[31\]](#page-39-13).
- 2. Frequency domain methods such as band-pass filtering and wavelet-based denoising technique. While this can not remove noise overlapping with the useful frequency of the ECG signal, it can be used for removal of out of band noise.
- 3. Statistical methods such as independent component analysis (ICA) and principle component analysis (PCA) which can be used in removing in-band noise, but might not be feasible for real-time systems.

There are different noise sources that contaminate the [ECG](#page-6-1) signal. These noise sources include [\[32\]](#page-39-14)[\[33\]](#page-39-15)[\[34\]](#page-39-16):

- Power line interference which consists of 50Hz and its higher harmonics.
- Electrode contact noise due to improper contact between patient and measuring system
- Motion artifact due to change in electrode-skin impedance caused by electrode motion
- Muscle contraction or [EMG](#page-6-1) interference (DC-10kHz)
- Baseline wander due to respiration or movement of patient (0-0.5 Hz)

Baseline wander noise is filtered in the amplifying stage by the Hardware subgroup before being digitized and thus does not need to be filtered digitally. The remaining noise sources that have to be removed are [EMG](#page-6-1) interference and [PLI](#page-6-1) plus its higher harmonics. In figure [4.1,](#page-18-1) the contribution of noise sources at low frequencies, where most of the essential information is found, can be seen.

<span id="page-17-0"></span>As noises originating from bad electrode contact noise and motion artifacts are preventable and might not occur under use of trained medical personnel, their removal is not attempted. The bulk of the noise produced by [EMG](#page-6-1) is removed in the analog domain by a low-pass filter that also acts as an anti-aliasing filter. The lower frequency components of [EMG](#page-6-1) overlap with the desired frequency band and thus its removal requires use of techniques such as PCA and ICA for in-band noise removal. However, as it can be seen in figure [4.1,](#page-18-1) it almost has a constant amplitude and thus its removal is not essential.

<span id="page-18-1"></span>

**Figure 4.1:** Contribution of noise sources in an [ECG](#page-6-1) signal [\[35\]](#page-39-17) in sub 40Hz range, excluding [PLI](#page-6-1) noise

#### **4.2.1. Power line interference**

With the baseline wander already removed, the [PLI](#page-6-1) and its harmonics are the main noise sources in the ECG signal. The [PLI](#page-6-1) interference is mainly 50Hz with some deviations depending on the power usage across the grid. The grid frequency is very stable in West-Europe with average frequency deviations below  $\pm 0.2$ Hz[\[36\]](#page-39-18)[\[37\]](#page-39-19). Additionally, extreme deviations of  $\pm 2.5$ Hz results in an automatic disconnection of all connected generation and devices from the grid[\[38\]](#page-39-20). Therefore, the frequency band of 49-51Hz is the bandwidth where the [PLI](#page-6-1) resides and should be removed in the system, with its higher harmonics being an integer multiple.

There are two main digital filtering categories that can be used for filtering, namely Finite Impulse Response [\(FIR\)](#page-6-1) and Infinite Impulse Response [\(IIR\)](#page-6-1). IIR filters have the advantage of being less computationally expensive and requiring less memory, but have non-linear phase characteristics. This is undesired as the original shape of the input signal may not be retained<sup>[1](#page-18-2)</sup>.

<span id="page-18-3"></span>[FIR](#page-6-1) filters on the other hand introduce no distortion in the time-domain but introduce a constant group delay equal to half the filter order. Additionally, they require a higher order filter to achieve the same level of attenuation as [IIR](#page-6-1) filters and thus require more memory and computation time. Important aspects differentiating FIR and IIR filters are summarized in table [4.4](#page-18-3)[2](#page-18-4).

| Aspect          | FIR       | ΠR             |  |
|-----------------|-----------|----------------|--|
| Efficiency      | Lower     | Higher         |  |
| Usage           | Difficult | Convenient     |  |
| Stability       | More      | Less           |  |
| Memory usage    | More      | Less           |  |
| Controllability | Easier    | More difficult |  |
| Sensitivity     | Less      | More           |  |

**Table 4.4:** Comparison of FIR and IIR filters

#### <span id="page-18-0"></span>**4.2.2. IIR filters**

The [IIR](#page-6-1) filters that can be implemented for [PLI](#page-6-1) removal include band-stop and notch filters. Removal of higher harmonics can be achieved by using a comb filter or cascading multiple band-stop or notch filters. First, different band-stop filters are investigated as there are different IIR filters that may be used for the band-stop filter.

- Butterworth
- Chebyshev type I/II

<span id="page-18-2"></span><sup>1</sup>source: https://www.advsolned.com/linear-phase-iir-filters-analysis-design/

<span id="page-18-4"></span><sup>2</sup>source:https://circuitglobe.com/difference-between-fir-filter-and-iir-filter.html

• Elliptic

[PLI](#page-6-1) consists of a very narrow band at around 50Hz and thus requires a very steep roll-off. Among these filters, Elliptic filters provide the steepest roll off but produce ripples in the pass-band. This unfavorably changes the important components of the ECG signal. Given same reasoning, the Chebyshev type I filter is also not suitable. However, both Butterworth and Chebyshev type II filters have a flat pass-band. Given that a Chebyshev type II filter has a faster roll-off than a Butterworth filter at the transitions and the ripple occuring at the stopband makes it a suitable candidate for implementing the band-stop filter. The advantage that a Chebyshev type II filter has over a Butterworth filter is that the same roll-off speed can be achieved with a lower order filer, making the filter computationally less intensive. Given that the ripple in the stop-band doesn't have any significance, the choice for the band-stop filters goes to Chebyshev type II. The magnitude and frequency response of these IIR band-stop filter designed with a stopband of 49-51Hz with attenuation of 20dB can be seen in figures [4.2](#page-19-0) and [A.1](#page-41-2) respectively.

<span id="page-19-0"></span>

**Figure 4.2:** Magnitude response of different IIR band-stop filters

As seen in Figure [4.2,](#page-19-0) for the same attenuation in the stop-band the Butterworth filter has a higher order than an elliptic filter or a Chebyshev type II filter. Additionally, the elliptic filter has a ripple around the corner frequency as expected and can achieve the same level of attenuation due to its high roll-off.

The main disadvantage of an [IIR](#page-6-1) filter is its frequency dependent group delay. The group delay of the Chebyshev Type II filter is added to its magnitude plot in order to estimate whether the introduced group delay will be detrimental to the time domain signal. As it can be observed in figure [4.2c,](#page-19-0) the group delay introduced to frequencies 45-48Hz and 52-55Hz is substantial and is in the order of 10 − 200ms. Given that the time interval between the P wave, QRS complex and the T wave is around 40ms [\[39\]](#page-39-21), the filtered signal is likely to suffer from distortion. However, simulations and measurements need to be done to further investigate this assumption.

The MATLAB filterDesigner application was used to make an IIR notch filter by finding an optimized transfer function that fulfills the required specifications. A notch filter is then created with a notch at 50Hz and a stopband of <sup>47</sup>.<sup>5</sup> <sup>−</sup> <sup>52</sup>.5Hz. Creating a pure notch filter, while being seen as less stable, is much simpler and can be realized with only a second order transfer function and the same roll-off as the designed band-stop filters. The disadvantage of the notch filter is that the variation [PLI](#page-6-1) will not be removed as effectively as that of the band-stop filter. The more complex band-stop option might be a better choice if there are noticeable variations in the [PLI](#page-6-1) frequency. However, this might remove useful components of the ECG signal as well.

The general transfer function of the notch filter is [\[33\]](#page-39-15):

$$
H(z) = k \frac{1 - 2\cos(\omega_0)z^{-1} + z^{-2}}{1 - 2r\cos(w_0)z^{-1} + r^2 z^{-2}}
$$
\n(4.2)

The derived transfer function with sampling frequency of 500Hz and a notch at 50Hz is as follows:

$$
H(z) = \frac{0.98426 - 1.59257z^{-1} + 0.98426z^{-2}}{1 - 1.59257z^{-1} + 0.96852z^{-2}}
$$
(4.3)

The magnitude, group delay and the phase characteristics of the designed filter can be seen in figure [4.3.](#page-20-0) As it can be seen in figure [4.3a,](#page-20-0) the notch filter has a slightly lower bandwidth but similar 50Hz attenuation as the Chebyshev Type II bandstop filter, but it has much lower group delay of 10 − 60ms. This may cause less catastrophic distortion than the bandstop filter. This, together with the notch filter's computational efficiency, makes a notch filter a more suitable [IIR](#page-6-1) filter for this system.

<span id="page-20-0"></span>

**Figure 4.3:** Important characteristics of the designed notch filter

The last [IIR](#page-6-1) filter that is considered is the comb filter. The advantage that this filter has is its ability to remove [PLI](#page-6-1) as well as its higher harmonics. The comb filter acts the same as cascaded notch filters and requires a  $10^{th}$  order filter to implement, but is theoretically much more efficient as its coefficients are mostly zero. The transfer function of the comb filter with the same bandwidth as the notch filter is:

$$
H(z) = \frac{0.85812 - 0.85812z^{-10}}{1 - 0.71625z^{-10}}
$$
\n(4.4)

The magnitude response of the comb filter can be seen in figure [4.4.](#page-21-1) The problem with the comb filter is that it will remove the essential components that are found in  $0.5 - 2Hz$  as well. One way to alleviate this issue is to reduce the bandwidth of the comb filter as to not filter this component with the downside of worse [PLI](#page-6-1) rejection. As the main goal of the filtering is to remove the [PLI,](#page-6-1) the comb filter is not applicable and is therefore not implemented in the final prototype.

<span id="page-21-1"></span>However, the same functionality of the comb filter without removal of these low frequencies can be achieved by means of cascading [IIR](#page-6-1) notch filters with each designed filter having a notch at the frequencies of the [PLI](#page-6-1) harmonics. Given the computational efficiency of the notch filter, this filter type is implemented in the final prototype.



**Figure 4.4:** Magnitude response of the Comb filter

#### <span id="page-21-0"></span>**4.2.3. FIR filters**

The non-linearity of [IIR](#page-6-1) filters in the pass-bands may introduce distortion in the time domain. Therefore it is necessary to furthermore consider FIR filters and analyze their feasibility in real-time signal processing. Here we mainly look at Hamming and Hann FIR windows which can be used for [PLI](#page-6-1) removal [\[34\]](#page-39-16).

Using the MATLAB filterDesigner application, [FIR](#page-6-1) band-stop filters are designed. In figure [4.5,](#page-22-0) the magnitude response of the Hamming and Hann window with different filter orders are shown. One of the first limitations that can be noticed is the need for a much higher order of filters to ensure the same bandwidth and roll-off as the equivalent [IIR](#page-6-1) filter. A  $250<sup>th</sup>$  order is only capable of 10dB attenuation. As we do not want to remove information carrying frequencies, the filter has to have a very sharp notch, i.e. small band-stop, with high attenuation at 50Hz. Therefore, for reaching the same level of attenuation as the [IIR](#page-6-1) filter as seen in figure [4.3a,](#page-20-0) an even higher order filter is required. This indicates that the amount of memory used for FIR filtering is considerably higher than IIR filters.

A positive aspect with respect to the FIR filter is its linear phase response. The advantage of having a linear phase response is constant group delay over the frequency range of interest. This ensures that the time domain response of the filtered signal remains distortion free.

Applying an FIR filter is not as straight forwards as an IIR filter for real time filtering. The IIR filters can be efficiently applied using convolution in the time domain, as its complexity is  $O(n)$ , but the same does not apply to a FIR filter as the order of filter increases. At some point it becomes too computationally expensive to do convolution in the time domain and more efficient to do the filtering in the frequency domain. The complexity of convolution and FFT is  $O(m \times n)$  and  $O(n \log_2 n)$  respectively.

Graphically, it can be seen in figure [4.6](#page-22-1) that the crossover point is around 40 samples, given a FIR filter of order 250. However, the execution time will differ per hardware used, as instructions per clock cycle and clock rate will differ. Therefore, this analysis has to be carried out on the chosen hardware, i.e. the microprocessor/microcontroller, as well. If an [FIR](#page-6-1) filter is to be implemented on a less power demanding [MCU](#page-6-1) for real-time filtering at a later stage, the [MCU](#page-6-1) has to be able to perform Fast Fourier and inverse Fourier Transform. However, the need for a large memory would still persist.

<span id="page-22-0"></span>

<span id="page-22-1"></span>**Figure 4.5:** Magnitude response of Hamming window (left) and Hann window (right)



**Figure 4.6:** Complexity of convolution  $[O(m \times n)]$  & FFT  $[O(n \log_2 n)]$  based on sample size n

## Implementation

<span id="page-23-0"></span>All the tasks outlined in this report are to be implemented by two [STM32 MCUs,](#page-6-1) one at the transmitter and one at the receiver. The tasks the are implemented in the prototype are as follows:

#### 1. **Transmitter:**

- (a) Sample 9 signals
- (b) Apply digital filters to the sampled signals
- (c) Relay filtered data to an ESP32 MCU to be transmitted wirelessly

#### <span id="page-23-4"></span>2. **Receiver:**

- (a) Receive data from an ESP32 MCU for further processing [1](#page-23-3)
- (b) Reconstruct digital data using DACs

#### **Development tool**

In order to program/debug the [STM32 MCU,](#page-6-1) the STM32CubeIDE [\[22\]](#page-39-4) development platform will be used. STM32CubeIDE is an advanced  $C/C++$  development platform with peripheral configuration, code generation, code compilation and debug features for STM32 microcontrollers and microprocessors. This program has everything needed to configure/program the [STM32 MCU](#page-6-1) and is therefore chosen as the prefered development tool for this project.

#### **Device configuration tool**

The STM32CubeIDE comprises a GUI for configuring the STM32 MCU. Herein, an user is able to configure settings for peripherals, clocks, timers and much more. These settings are then automatically converted to C code. If it is stated that settings are configured, it means that the settings are configured in the device configuration tool and then automatically converted to C code.

#### **Direct Memory Access**

The [STM32 MCU](#page-6-1) contains multiple Direct Memory Access [\(DMA\)](#page-6-1) controllers. Direct Memory Access controllers are used to provide high-speed data transfers between peripherals and memory and between memory and memory without any CPU action. Therefore, DMA is the preferred method for any data transfer to take as much load off the CPU as possible.

#### <span id="page-23-1"></span>**5.1. Analog to Digital Conversion**

The performance of the whole subsystem relies on the performance of the ADCs. If the ADCs digitize the signal poorly, the rest of the system will use the poorly digitized signals, resulting in a sub-optimal output. Therefore it is very important that the ADCs are set up well. This section outlines the method used to configure and run the ADCs.

<span id="page-23-3"></span><span id="page-23-2"></span><sup>1</sup>Processing in the prototype is minimal

#### **5.1.1. Settings**

In order to to use the the ADCs, they must be configured with the right settings to convert 9 signals from the analog to the digital domain. This can be done by programming the STM32 to turn on the 3 different ADCs with the following (non-default) STM32CubeIDE settings:

- Resolution: 16-bit
- Scan conversion mode: Enabled
- Conversion data management: DMA Circular Mode
- Number of conversions: 3
- External trigger conversion source: Timer 1 Trigger Out event
- External trigger conversion edge: Rising edge
- Sampling time: 810.5 cycles
- DMA: Mode circular
- ADC Clock: 150 MHz
- Other settings are left default

Taking a look at the sub module overview (Figure [3.2\)](#page-13-2), every ADC needs to digitize 3 different signals out of the 9 total signals. In order to facilitate this, 3 different inputs were enabled as Single-ended. Furthermore, the number of conversions was set to 3, to notify the ADC it needs to digitize 3 different signals. This in turn enabled Scan conversion mode automatically, telling the ADC to multiplex between the 3 different input signals. Moreover, the ADCs were set up to start the conversion with the Timer 1 Trigger Out event. Timer 1 is a timer that raises an interrupt every 2 ms, thus creating a 500 Hz timer. This makes sure the ADC samples the input signals at 500 Hz (**[G6D.a](#page-11-0)**). On top of that, the conversion data management was set to DMA circular mode. The DMA controller will fetch the conversion result from the ADC and put it in an array. This array will be overwritten every single time the ADCs digitize the signal. It is therefore crucial to gather the result in time before it is overwritten by a new sample. When the DMA controller is done with retrieving the conversion result, an interrupt is generated, so the data can be processed. At last, the Sampling time is set to 810.5 cycles, resulting in a sampling time of:

$$
\frac{1}{150 * 10^6} * 810.5 = 5.40 \mu s
$$

This sampling time makes sure the capacitor of the sample and hold circuit will be adequately charged before the ADC will start digitizing the capacitor voltage. The full derivation for the minimum sampling time can be found in the Hardware report[\[2\]](#page-38-2).

#### <span id="page-24-0"></span>**5.1.2. Code**

7

14

The functions of interest that are causing the ADC to work properly can be seen in the following code block:

```
// Calibration function
2 HAL_StatusTypeDef HAL_ADCEx_Calibration_Start (
ADC_HandleTypeDef ∗hadc, // Handle to the ADC<br>4 uint32 t CalibrationMode, // Select calibration mode, usually ADC CALIB OFFSET
5 uint32_t SingleDiff // Selection of single-ended or differential input
6 );
8 // Function to start the ADC in DMA mode
9 HAL_StatusTypeDef HAL_ADC_Start_DMA (
10 ADC_HandleTypeDef ∗hadc , // Handle to the ADC
11 uint32_t *pData, // Pointer to the array to store ADC results
12 uint 32 t Length // Length of the array used to store ADC results
13 ) ;
15 // DMA Callback function
16 void HAL_ADC_ConvCpltCallback (
17 ADC_HandleTypeDef∗ hadc // Handle to ADC
18 );
```
The *HAL\_ADCEx\_Calibration\_Start* function is used to self-calibrate the ADC to get a more precise reading. When an ADC has not been used in a while or on startup, it is recommended to call this function.

The *HAL\_ADC\_Start\_DMA* function starts an ADC in DMA mode. This is a non-blocking mode, meaning no CPU clocks are used to gather the results from the ADC, as the DMA controller, explained in Section [5,](#page-23-4) takes care of moving the data from the peripheral to memory. When the DMA controller is done transferring the data from ADC to memory, the callback function *HAL\_ADC\_ConvCpltCallback* is called. This callback function can then be used to process the data for example.

#### <span id="page-25-0"></span>**5.2. Digital Filters**

The performance of the filters depends strongly on the type of filter chosen, precision of coefficients, method of filtering and the microprocessor used. While a general function could be written to implement the digital filters, the chosen microprocessor has an extensive DSP library that can perform the filtering operation more efficiently than general code would as they are written with the available hardware in mind and use their full capability. The IIR filters are implemented using a Biquad filter in direct form II. Higher order filters can be implemented as well by means of cascading Biquad filters. The topology of the [FIR](#page-6-1) and [IIR](#page-6-1) filters implemented in the CMSIS DSP library can be seen in figure [5.1.](#page-25-1)

<span id="page-25-1"></span>

7

13

<sup>16</sup> {

21

**Figure 5.1:** Topology of FIR and IIR filters implemented in CMSIS DSP Library[\[40\]](#page-40-0)

The functions of interest, which perform filtering by convolution in the time domain, found in the CMSIS DSP library and used in prototyping can be seen in the following code block:

```
typedef struct
2 \vert3 uint8_t numStages; /**< number of 2nd order stages in the filter. */
f loat 64_t * pState; /**< points to the array of state coefficients. */<br>const float 64_t * pCoeffs; /**< points to the array of coefficients. */
                                            /**< points to the array of coefficients. */
6 } arm_biquad_cascade_df2T_instance_f64;
8 void arm_biquad_cascade_df2T_f64 ( const arm_biquad_cascade_df2T_instance_f64* S,
\frac{1}{9} const float64_t* pSrc,
10 f l o a t 64_t \ast pDst ,
11 uint32 t blockSize
\frac{12}{12} ):
14 // For FIR Filtering
15 typedef struct
17 uint16_t numTaps; /**< number of filter coefficients in the filter. */<br>float32_t *pState; /**< points to the state variable array. The array i
18 float32_t *pState; /**< points to the state variable array. The array is of length
       numTaps+blockSize -1. */
19 const float32_t *pCoeffs; /**< points to the coefficient array. */
20 } arm_fir_instance_f32;
\begin{array}{lll} \text{22} & \text{void arm\_fir\_f64 (const arm\_fir\_instance\_f64* S,} \\ \text{23} & \text{const float64\_t*} & \text{pSrc,} \end{array}23<br>
24 const float64_t * pDst.<br>
10at64_t * pDst.
24 f l o a t 6 4 _ t \star25 uint32<sub>-</sub>t blockSize
26 ):
```
The full description of the functions and how they work can be found in the CMSIS DSP Software Library[\[40\]](#page-40-0). In short they use normal convolution to apply filter "**S**" to input data "**PSrc**" of size "**blockSize**" and then store the results in "**pDst**".

Additionally, for a more efficient implementation of [FIR](#page-6-1) filters in frequency domain, the CMSIS library includes Fast Fourier Transform functions which are included for completeness but are not implemented or tested due to time constraints outlined by **[G10](#page-11-0)**.

```
typedef struct
2 \left| \right|3 uint16_t fftLen;<br>const float32_t *pTwiddle; /**< length of the FFT. */
const float32_t *pTwiddle;<br>
const uint16_t *pBitRevTable; /**< points to the bit reversal table. */
5 const uint16 t *pBitRevTable; /**< points to the bit reversal table. */
6 uint16_t bitRevLength; /**< bit reversal table length. */
7 } arm_cfft_instance_f32;
8 typedef struct
9 {
10 arm_cfft_instance_f32 Sint; /**< Internal CFFT structure. */<br>11 uint16_t fftLenRFFT; /**< length of the real sequence
11 uint16_t fftLenRFFT; /**< length of the real sequence */
12 const float32_t * pTwiddleRFFT; /**< Twiddle factors real stage */
\lim_{13} arm_rfft_fast_instance_f32 ;
14
15 arm_status arm_rfft_fast_init_f32 (
16 arm_rfft_fast_instance_f32 * S,
17 uint16_t fftLen);
18
19 void arm_rfft_fast_f32(
20 arm_rfft_fast_instance_f32 * S,
21 float 32_t * p, float 32_t * pOut,
22 uint8<sub>-</sub>t ifft\overline{F}lag);
```
#### <span id="page-26-0"></span>**5.3. Digital to Analog Conversion**

As seen in table [4.3,](#page-17-1) there is no [MCU](#page-6-1) that possesses nine DAC channels. Therefore, regardless of the chosen [MCU,](#page-6-1) the prototype requires external DACs. In figure [5.2,](#page-27-0) a simplified overview of component connections in the receiver prototype, where signals are reconstructed, can be seen[\[2\]](#page-38-2). The Nucleo would receive the wirelessly transmitted data from the ESP chip via an  $I^2C$  line. This mode of communication between the STM32 MCU and the ESP chip was discussed with PROT subgroup and chosen as the most between the [STM32 MCU](#page-6-1) and the ESP chip was discussed with [PROT](#page-6-1) subgroup and chosen as the most suitable communication protocol.

At the receiver, the Nucleo has the option to store a buffer of the received data to perform further signal processing. However, as there is minimal data processing taking place on the Nucleo on the receiver module's prototype, no buffer is held. The immediate data is prepared to be sent via a single dedicated [B.2.](#page-45-0) <sup>2</sup>C line to the three DACs. The complete communication with the DACs are documented in appendix

The  $I^2C$  protocol is implemented using the Nucleo's built-in "Hardware Abstraction Layer" (HAL) library.<br>Lising this library puts emphasis more on fast prototyning rather than the most efficient implementation. Using this library puts emphasis more on fast prototyping rather than the most efficient implementation, as the built-in functions are more complex and contain many checks to catch most of the unexpected outcomes. However, they do not cause any performance overhead in the prototype. The process of receiving data from the ESP32, preparing the data and transmission to the DACs is implemented using the following functions and simplified sequence  $[41]^{2}$  $[41]^{2}$  $[41]^{2}$  $[41]^{2}$ :

```
1 / Timer interrupt to initiate reception & transmission process
2 void HAL_TIM_PeriodElapsedCallback (timer)
3
4 // Sets I2C line 1 in reception mode
5 void HAL_I2C_Slave_Receive_IT (hi2c1, pData, Size);
6
7 // Reception is complete call back function.
8 // Data is processed here as preperation for DACs
9 void HAL_I2C_SlaveRxCpltCallback (hi2c1)
10 {
11 // Transmission to DACs is initiated
```
<span id="page-26-1"></span><sup>2</sup>Detailed workings of these functions can be found in [\[42\]](#page-40-2), chapter 47

```
12 void HAL_I2C_Mem_Write_IT (hi2c, DevAddress, MemAddress, MemAddSize, pData, Size);
13 }
14
15 // Transmission complete call back function
16 void HAL_I2C_MemTxCpltCallback (hi2c2) {
17 {
18 // Retranmission of next channels of data until all channels are updated
19 HAL_I2C_Mem_Write_IT ( hi2c2 ,  DevAddress ,  MemAddress ,  MemAddSize ,  pData ,  Size ) ;
20
```
<span id="page-27-0"></span>

**Figure 5.2:** Simplified schematic of the receiver module

### Measurements

<span id="page-28-0"></span>In this chapter, the important characteristics of the designed modules are benchmarked to ensure that they follow the requirements outlined in chapter [2.](#page-11-0) These benchmarks include both theoretical simulations and practical measurements.

#### <span id="page-28-1"></span>**6.1. Execution time**

#### <span id="page-28-2"></span>**6.1.1. Filtering time**

The benchmarks are performed on a STM32H743 board, with the STM32H743ZI2 [MCU.](#page-6-1) STM32 boards include CPU cycles counter as part of the Debug Watch and Trace (DWT) module[\[43\]](#page-40-3). This counter can be easily used to measure the execution time of a given code. The cycle counter can be enabled and used as indicated in the code block below[\[43\]](#page-40-3):

```
1 # define ARM_CM_DEMCR (* (uint32_t * )0xE000EDFC)3 \# \text{define} ARM_CM_DWT_CTRL (* ( \text{uint32}_t * ) 0 \times E0001000 )4
  # define ARM_CM_DWT_CYCCNT (* (uint32_t *) 0xE0001004)
6
    // Enabling Counter
8 if (ARM\_C\overline{M\_DWT\_CTRL}!=0) { // See if DWT is available
9
10 ARM_CM_DEMCR |= 1 \ll 24; // Set bit 24
11
12 ARM_CM_DWT_CYCCNT = 0;
13
14 ARM_CM_DWT_CTRL |= 1 \ll 0; // Set bit 0
15
16 }
17
18 start = ARM CM DWT_CYCCNT;
19
20 // Code to measure
21
22 stop = ARM CM DWT CYCCNT;
2<sub>2</sub>24 delta = stop – start;
```
Then the execution time can be derived from the recorded counter and the SystemCoreClock. The filtering performance of Nucleo-H743ZI2 and Nucleo-F411RE on a 250 sample data is summarized in tables [6.1](#page-29-1) and [6.2](#page-29-2) respectively. The results show that both microcontrollers are suitable for single precision real-time filtering. However, should double precision be used, only the MCU equipped with Cortex Arm M7 is suitable.

Furthermore, it can be seen that, on both MCUs, the execution time of the FIR filter is around 50 times slower than the IIR filter while having lower attenuation and a considerably higher stop-band <span id="page-29-1"></span>bandwidth which is not desirable.

IIR Notch 2

| Filter type      | Filter order | Precision | execution time $[\mu s]$ | Clock Cycles |
|------------------|--------------|-----------|--------------------------|--------------|
| <b>IIR</b> Notch | $2^{nd}$     | single    | 17                       | 8 0 0 0      |
| 5× IIR Notch     | $10^{th}$    | single    | 85                       | 39 600       |
| <b>IIR Comb</b>  | $10^{th}$    | single    | 438                      | 210 000      |
| FIR Bandstop     | $250^{th}$   | single    | 952                      | 453 000      |
| <b>IIR</b> Notch | 2nd          | double    | 32                       | 15 500       |
| 5× IIR Notch     | $10^{th}$    | double    | 159                      | 77 300       |
| <b>IIR Comb</b>  | $10^{th}$    | double    | 454                      | 218 000      |

**Table 6.1:** Performance of **STM32H743ZI2** with clock rate of 480MHz

<span id="page-29-2"></span>

FIR Bandstop  $\begin{array}{|c|c|c|c|c|c|c|c|}\n\hline \text{IIR Notch} & \text{250}^{\text{th}} & \text{single} & \text{2100} & \text{210 000} \\
\hline \text{IIR Notch} & \text{2}^{\text{nd}} & \text{double} & \text{1960} & \text{196.000} \\
\hline \end{array}$ 

 $5 \times$  IIR Notch  $10^{th}$  double 9700 972 000<br>IIR Comb  $10^{th}$  double 1600 160 972 000 IIR Comb  $10^{th}$  double 1600 160 500

 $\frac{nd}{100}$  double 1960 196000

**Table 6.2:** Performance of **STM32F411RE** with clock rate of 100Mhz



The 250 samples used represent half a second of data, thus the FIR filter can theoretically be used for real time signal processing of nine channels on both the ARM CORTEX M4 and M7, but this would leave less performance overhead for other functions of the microprocessor, i.e. sampling, transmission and possibly re-transmissions that ensure high reliability. This leads potentially to forming a bottleneck in the system. Additionally, this might prevent the transition of the prototype to an even more efficient [MCU](#page-6-1) to fulfill requirement **[G7D](#page-11-0)**.

Even though using [FFT/IFFT](#page-6-1) would improve performance of the FIR filter, it would not reduce the memory usage. Additionally, it will be still more computationally intensive than the IIR filter while having a larger notch and less attenuation as seen in figures [4.3a](#page-20-0) and [4.5.](#page-22-0)

The only advantage that the FIR filter has is its constant group delay which prevents distortion in the time domain. The group delay in the IIR filter occurs around the notch which is attenuated. This indicates that the distortion and hence the illegibility of the ECG signal in time domain will likely be limited. The group delay of the IIR and the FIR filter can be seen in figure [A.3.](#page-42-1)

Having a very steep notch does have a disadvantage that is present in both IIR and FIR filters and that is the time it takes for filter to reach the designed attenuation level. As it was seen in figure [4.5,](#page-22-0) a very high order FIR is needed for a top notch which results in a high group delay. While the IIR filter does not have a group delay in its pass-band due to having less delay elements, it too needs prior samples in order to properly filter out the 50Hz noise.

This delay was seen in MATLAB simulations as well as when a 50Hz sinusoidal signal was passed through the IIR filter implemented on the [STM32 MCU.](#page-6-1) It was observed that the attenuation would converge after some delay, seen in figure [A.4,](#page-42-2) which is inversely proportional to the sampling rate. This is further investigated and documented in section [6.2](#page-30-0)

#### <span id="page-29-0"></span>**6.1.2. DAC Reconstruction time**

The chosen [DAC,](#page-6-1) namley Texas Intruments DAC8574IPW, is capable of operating with wide ranges of <sup>2</sup>C bus rates ranging from 100kb/s upto 3.4Mb/s, with the upper limit of the chosen Nucleo board

being 1Mb/s. Based on the data sheet of TI DAC8574IPW, updating each output channel requires four bytes of data and an additional four is required as a broadcast signal for synchronous updating of the DAC's output channel. This results in a minimal transfer speed of ∼ 205kb/s in ideal conditions. As some overhead has be left in transmission, the highest transmission speed of 400kb/s is chosen, which does not alter the "Standard/Fast Mode" transmission protocol of TI DAC8574IPW[\[21\]](#page-39-3).

Tests performed and documented in table [6.3](#page-30-2)[1](#page-30-3) are done on the receiver prototype, designed and made by the Hardware group [\[2\]](#page-38-2). If real-time reconstruction of ECG signals is to be guaranteed, the time needed for receiving data from the ESP32 and transmitting to DACs must be below 2ms, as outlined by **[G6D.d](#page-11-0)**. It can be observed that the sequential reception and reconstruction of the nine signals are done successfully under 1.3ms in real-world operating conditions.

<span id="page-30-2"></span>

**Table 6.3:** Communication time from/to the Nucleo MCU

#### <span id="page-30-0"></span>**6.2. Filter Performance**

This section describes the performance of the filter. The theoretical performance of the filter will be looked at, realized in Matlab and on the STM32 chip, and the real-life performance will be tested on a real-life ECG signal.

#### <span id="page-30-1"></span>**6.2.1. Theoretical**

In order to test the (semi-)theoretical performance of the filter, the filter performance is tested in different environments. First, the performance of the filter is tested in Matlab. Subsequently, the performance of the filter, realized on the STM32 MCU, is tested with a pure 50 Hz sine wave. At last, the filter performance is tested on an ECG signal with 50 Hz added, output by a function generator.

#### **Matlab**

Using the MIT-BIT database [\[44\]](#page-40-4)[\[16\]](#page-38-16), the frequency content of the ECG signal is looked at. Firstly, a great peak is seen at the lower frequencies, which are due to the baseline wander noise. However, this noise would be removed in an earlier stage with analogue circuitry and is thus not the focus of this analysis. Applying the designed notch filter to the data, shows that PLI is effectively removed. The power spectral density of the ECG signals before and after filtration can be seen in figure [6.1](#page-30-4)

<span id="page-30-4"></span>

**Figure 6.1:** The power spectral density of the ECG signal from MIT-BIT data base

Testing the bandstop Chebyshev Type II filter on the same data and zooming at frequencies around

<span id="page-30-3"></span><sup>1</sup>12-channel is included in case the prototype is used as a standalone ECG monitoring device.

50Hz shows the difference in filtering capabilities of the designed filters. It can be observed in figure [6.2b](#page-31-0) that the bandstop filter is much more suited for removing a wider band as expected. Initially, a high level of distortion was expected due to a large group delay. However, testing on an ECG data signal from MIT-BIT data base did not show distortion. This indicates that despite having a large group delay, the Chebyshev bandstop filter may be used for filtering the [PLI](#page-6-1) as well.

<span id="page-31-0"></span>

**Figure 6.2:** Time domain and frequency domain comparison of notch & band stop filters

#### **Function generator 50 Hz**

To test the filter when realized on the STM32 MCU, a function generator was configured to output a pure 50 Hz sine wave with an amplitude of 3.000  $V_{pp}$  and an offset of 1.500 V. This signal is then sampled for 5 seconds at 500 Hz by an implemented [ADC.](#page-6-1) The resulting digital signal is then fed into the filter system. Figure [6.3](#page-31-1) shows the filter input and filter output in the time-domain.

<span id="page-31-1"></span>

**Figure 6.3:** Filter input and output in the time-domain

As can be seen in Figure [6.3b,](#page-31-1) the filter first needs to converge and then filters the data effectively. This is to be expected and is also explained in Chapter [6.1.1.](#page-28-2) Comparing to the input signal, shown in Figure [6.3a,](#page-31-1) the 50 Hz signal is as good as completely filtered in 1 second. A frequency spectrogram of the signal can furthermore be found in Appendix [A](#page-41-0) in Figure [A.5.](#page-43-0)

#### **Frequency generator ECG Signal**

With an eye on the end goal of this project, the filter system was tested on a repeating 2 second ECG signal, obtained from the first 2 seconds of patient 001 from the PTB Database [\[15\]](#page-38-15) [\[16\]](#page-38-16). Additionally, a 50Hz signal was added to the original signal to simulate 50Hz power line interference, with an amplitude of 0.2 \* the peak-to-peak amplitude of the original ECG signal. Both these signals can be seen in Appendix [A.1.1](#page-42-0) as Figure [A.6a](#page-43-1) and Figure [A.6b](#page-43-1) respectively. At last, this signal was loaded onto a function generator (Tektronix AFG 3021B) and output to the Nucleo, with a frequency of 0.5 Hz and its voltage ranging from 0 to 3V. The method for loading an arbitrary signal is explained in Appendix [C.](#page-46-0) The signal sampled by an [ADC](#page-6-1) and the result after the filter system can be seen in Figure [6.4.](#page-32-1) In order to filter the 50 Hz component better, two 50Hz filters have been cascaded, resulting in bigger magnitude decrease of the 50Hz signal components.

<span id="page-32-1"></span>

**Figure 6.4:** Filter input and output in the time-domain of ECG Signal

By looking at the result of the filter, Figure [6.4b,](#page-32-1) it can be seen that the signal visually already looks more clear. However, still some harmonics can be seen in the final output. By taking a look at the FFT of the input and output of the filter with the DC component removed, Figure [6.5a](#page-32-2) and Figure [6.5b](#page-32-2) respectively, it can be seen that the 50 Hz component has vastly decreased, but not completely removed. More filters could be cascaded to give an even better magnitude decrease, but this would introduce a bigger group delay, thus distorting the signal more; a trade-off has to be made between the two when deciding on the magnitude decrease.

<span id="page-32-2"></span>

**Figure 6.5:** Filter input and output FFT of ECG Signal

#### <span id="page-32-0"></span>**6.2.2. Practical**

Furthermore, to test the real-life application of the [DSP](#page-6-1) subsystem, an experiment has been performed on a male human (S. Speekenbrink) to test the incoming signal and the filter system. The time-domain and FFT results can be seen in Figure [6.6](#page-33-0) and Figure [6.7](#page-33-1) respectively. Note that the FFT Figures are without a DC component.

<span id="page-33-0"></span>

**Figure 6.6:** Time-domain real ECG signal input/output

<span id="page-33-1"></span>

**Figure 6.7:** FFT Real ECG Signal - No DC

First of all, by looking at Figure [6.7a,](#page-33-1) it can be seen that higher harmonics of [PLI](#page-6-1) are present, namely 150Hz and even 250Hz. This is most likely accounted for by the fact that these tests were performed with a power supply connected to the main grid, instead of a power supply that is not connected to the main grid, i.e. batteries. It might be possible that higher harmonics will also be present in the case when a power supply is used that is not connected to the main grid. In that case, filters for these components would have to be implemented in the final system. Unfortunately, as of the moment of writing, this has not been possible yet, because the system could not be connected to a power supply not connected to the main grid at the moment of testing the real-life ECG signal. Therefore, 100Hz, 150Hz, 200Hz and 250Hz filters have been implemented together with a 50Hz filter to filter out the 50Hz [PLI](#page-6-1) and higher order harmonics.

The [FFT](#page-6-1) of the result can be seen in Figure [6.7b.](#page-33-1) By looking at Figure [6.7b,](#page-33-1) still a minor amount of 50Hz is present in the resulting signal. However, by looking at the resulting time-domain signal in Figure [6.6b,](#page-33-0) this 50Hz component is not dominating the signal anymore and is therefore sufficiently filtered, compared to the input signal in Figure [6.6a.](#page-33-0) The result is an ECG like signal.

### Discussion

<span id="page-34-0"></span>Here the results of this thesis are discussed and an outline is given on how the prototype could be further improved, in terms of efficiency (**[G7](#page-11-0)**), size (**[G8](#page-11-0)** & **[G9](#page-11-0)**) and cost (**[G11](#page-11-0)**). Additionally, recommendations are given for further research avenues.

#### <span id="page-34-1"></span>**7.1. Micro Controller power usage**

In order to prevent bottlenecks in the development process, one of the most powerful [MCUs](#page-6-1) was chosen that not only is capable of carrying out the functions of the [DSP](#page-6-1) submodule, it does it extremely fast, as seen in table [6.1,](#page-29-1) at the cost of extra power usage. Measurements done by [HW](#page-6-1) subgroup showed that the Nucleo board uses 200-300mA which accounts for ∼ 50% of total power usage of the system. This power usage occurs when the [MCU](#page-6-1) is running at its maximum clock frequency. Many low power [MCUs](#page-6-1) do not have the hardware for double precision float computations. Therefore, if double precision is to be kept, the Nucleo has to be run at a lower and more reasonable clock frequency to ensure low power usage and double precision arithmetics.

However, if the single precision results tightly resemble ones of double precision filters, then a lower power [MCU](#page-6-1) equipped with a Cortex M4 [MCU](#page-6-1) (with Floating Point Unit) may be used to reduce power consumption drastically, but this would require addition of external peripherals, i.e. [ADCs.](#page-6-1) Due to many low power boards being equipped with [DMA,](#page-6-1) covered in start of chapter [5,](#page-23-4) the [MCU](#page-6-1) will likely have enough computation power to realize the [DSP](#page-6-1) functions.

Alternatively, all the functions implemented in the [DSP](#page-6-1) and [PROT](#page-6-1) subgroups may be implemented on a single [MCU,](#page-6-1) namly an ESP32 [MCU,](#page-6-1) as it has both [WiFi](#page-6-1) and a dual core CPU design with a generous clock rate of 240MHz. However, the feasibility of this depends on the performance of the [DSP](#page-6-1) library that is available for an ESP32 [MCU.](#page-6-1)

With these options, total number of components used in the system decreases, improving the system efficiency while reducing its costs. Additionally, this facilitates the transition into a more miniaturized system.

#### <span id="page-34-2"></span>**7.2. Filtering efficiency**

Based on both simulations performed in Matlab as well as measurements on the [STM32 MCU,](#page-6-1) the designed filters consisting of cascaded notch filters are capable of removing [PLI](#page-6-1) and its higher harmonics without distorting the ECG signal in the time domain. However, tests were not carried out on heart data of patients with arrhythmia to investigate the amount of distortion that is added. Given signals collected from patients with arrhythmia contain different frequency components, the amount of distortion cannot be predicted without being specifically tested.

Furthermore, other filter systems could be implemented to improve the Signal-to-Noise Ratio of the output signal. For example, a form of averaging could be applied to reduce the effect of white/coloured noise. Unfortunately, white noise filtering was not possible in the current system design as the RC time constant of the system at the terminal input was too high to gather enough samples quickly enough to use averaging efficiently, as a sample-and-hold circuit is used. Signal averaging could however be implemented with Article [\[45\]](#page-40-5) explaining the use on ECG signals.

#### <span id="page-35-0"></span>**7.3. DAC Integral non-linearity error**

The Texas Instruments DAC8574 that was selected for this prototype has a relatively high integral non-linearity error and was chosen only due to the long lead time of the DAC AD5675 by Analog Cicuits. DAC8574IPW, while not making the ECG signal distorted beyond recognition, should preferably not be used in further revisions of the prototype. The error introduced by DAC8574IPW before attenuation in the receiver module amounts to  $\pm 5$ mV instead of  $\pm 0.6$ mV, would the [DAC](#page-6-1) of choice be available in the early weeks of development.

#### <span id="page-35-1"></span>**7.4. Testing and experiments**

In order to verify the practical efficiency of the proposed/realized [DSP](#page-6-1) system, real-life experiments and testing have to be performed. While theoretical testing was done, not enough experiments were performed with a variety of healthy heart data and heart data with arrhythmia to conclude the realized system works as intended. Due to time constraints, these experiments could not be realized, most important experiments performed by professional medical staff. While a lot of research has been done into ECG signals, not enough knowledge had been acquired to successfully interpret an ECG signal. Therefore, experiments should be performed with professional medical staff who are able to interpret ECG data and analyse the signal to see if the proposed solution is acceptable.

## <span id="page-36-0"></span>Conclusion & Recommendation

In this thesis a digital signal processing module, which included quantization and reconstruction as well, was designed and implemented. Here the aspects of the requirements that were successfully implemented are summarized along with recommendations on future research to further improve the reliability of digital signal processing part of the prototype.

#### <span id="page-36-1"></span>**8.1. Conclusion**

The quantization of the 9 input signals was realized with 3 embedded [ADCs](#page-6-1) in the [STM32 MCU](#page-6-1) and could successfully sample a signal at 500Hz with a 16 bit resolution, thus realizing requirements **[G6D.a](#page-11-0)**, **[G6D.b](#page-11-0)** and **[G2D](#page-11-0)**.

The digital IIR filters that were implemented could successfully remove powerline interference on the transmitter module without contamination/distortion of the input signal. Additionally, the designed filters have exceptional computational efficiency which makes them well suited for real time signal processing. Therefore, requirements **[G5D](#page-11-0)** and **[G7D](#page-11-0)**, which pertain to real-time processing of data, are fulfilled.

The reconstruction of digitized signals were implemented on a Nucleo development board and was tested with the prototype receiver board. The performance of the [DACs](#page-6-1) in terms of reconstruction speed and frequency fell withing the specifications outlined by requirements **[G6D.c](#page-11-0)** and **[G6D.d](#page-11-0)**.

Unfortunately, requirement **[G3D](#page-11-0)** could not be confirmed with the utmost level of certainty. While the general shape of an ECG signal from a healthy person was not distorted, experiments on heart data with arrhythmia was not done. Further testing was required to ensure requirement **[G3D](#page-11-0)** was fully met, but was not possible due to time restrictions on the development window (**[G10D](#page-11-0)**).

#### <span id="page-36-2"></span>**8.2. Recommendations**

The prototype implemented, while adhering to the set requirements, could have been further improved. Furthermore, during the project new approaches were discovered that could not be implemented in time. These are provided here as future research prospects.

- There are filtering techniques available that make use of adaptive filters and/or neural networks that may be better at removing [\(PLI\)](#page-6-1) noise from a contaminated ECG signal. However, these methods require a deeper knowledge of the ECG signals, more specifically different types of heart arrhythmia and their time domain characteristics. A possible research product may include the creation of a proper neural network and its implementation on an [MCU](#page-6-1) such as STM32H743ZI using X-CUBE-AI.
- With the existence of optimized Fourier transforms in DSP libraries, implementing real-time signal processing on a [MCU](#page-6-1) might now be possible given advancements in the processing power of micro controller processors. Further research can be done on the feasibility of real-time FIR

filtering, as this would ensure that distortion is never added in the ECG signal which adds to the reliability of the system.

- The system can be made more tightly integrated, especially with the [PROT](#page-6-1) sub group by unifying the [MCUs](#page-6-1) used. The feasibility of data acquisition, signal processing and transmission/re transmission on a single [MCU](#page-6-1) could be a topic for future research.
- Switching noise of the [DACs](#page-6-1) may also be reduced by upscaling the reconstruction rate by linear interpolation, should it not be possible to increase the sampling rate of the complete system and keep the real-time filtering aspect of the system. While increasing the [DACs](#page-6-1) reconstruction rate will not completely remove the switching noise, it minimizes its amplitude. This will reduce the order of the filter that is required to remove it in the analog domain, reducing power usage, size and cost of the system.

### References

- <span id="page-38-1"></span><span id="page-38-0"></span>[1] S. G.A.J. Custers, "Communication protocols for a wireless ecg solution," Delft University of Technology, Tech. Rep, 2022.
- <span id="page-38-2"></span>[2] R. v. K. P.J. Wiersma, "Circuit design for a wireless ecg device," Delft University of Technology, Tech. Rep, 2022.
- <span id="page-38-3"></span>[3] Ambulancezorg nederland. "Ambulancezorg nederland sectorkompas 2020, statistieken vanuit het rivm." (2022), [Online]. Available: <https://www.ambulancezorg.nl/sectorkompas>.
- <span id="page-38-4"></span>[4] M. Sejersten, O. Pahlm, J. Pettersson,*et al.*, "Comparison of easi-derived 12-lead electrocardiograms versus paramedic-acquired 12-lead electrocardiograms using mason-likar limb lead configuration in patients with chest pain," *Journal of Electrocardiology*, vol. 39, no. 1, pp. 13–21, 2006, issn: 0022-0736. doi: [https://doi.org/10.1016/j.jelectrocard.2005.05.011](https://doi.org/https://doi.org/10.1016/j.jelectrocard.2005.05.011). [Online]. Available: <https://www.sciencedirect.com/science/article/pii/S0022073605002219>.
- <span id="page-38-5"></span>[5] M. W. Dr. B. McGraw Dr. J. Lord. "Analysis and interpretation of the electrocardiogram, elearning module, queens university of health sci." (2022), [Online]. Available: [https://elentra.](https://elentra.healthsci.queensu.ca/assets/modules/ECG/normal_ecg.html) [healthsci.queensu.ca/assets/modules/ECG/normal\\_ecg.html](https://elentra.healthsci.queensu.ca/assets/modules/ECG/normal_ecg.html).
- <span id="page-38-6"></span>[6] AliveCor. "Kardiamobile 6l." (2022), [Online]. Available: [https://www.kardia.com/kardiamobi](https://www.kardia.com/kardiamobile6l/) [le6l/](https://www.kardia.com/kardiamobile6l/).
- <span id="page-38-7"></span>[7] Physio-control. "Lifepak 12 datasheet." (2022), [Online]. Available: [https : / / www . physio](https://www.physio-control.com/uploadedFiles/Physio85/Contents/Emergency_Medical_Care/Products/Operating_Instructions/LIFEPAK15_OperatingInstructions_3306222-002.pdf)  [control . com / uploadedFiles / Physio85 / Contents / Emergency \\_ Medical \\_ Care / Products /](https://www.physio-control.com/uploadedFiles/Physio85/Contents/Emergency_Medical_Care/Products/Operating_Instructions/LIFEPAK15_OperatingInstructions_3306222-002.pdf) [Operating\\_Instructions/LIFEPAK15\\_OperatingInstructions\\_3306222-002.pdf](https://www.physio-control.com/uploadedFiles/Physio85/Contents/Emergency_Medical_Care/Products/Operating_Instructions/LIFEPAK15_OperatingInstructions_3306222-002.pdf).
- <span id="page-38-8"></span>[8] Koninklijke Philips N.V. "Philips tempus als monitor." (2022), [Online]. Available: [https://www.](https://www.philips.nl/healthcare/product/HC989706000171/tempus-als-monitordefibrillator) [philips.nl/healthcare/product/HC989706000171/tempus-als-monitordefibrillator](https://www.philips.nl/healthcare/product/HC989706000171/tempus-als-monitordefibrillator).
- <span id="page-38-9"></span>[9] ZOLL, an Ashahi Kasei Company. "Zoll heart failure management system (hfms)." (2022), [Online]. Available: [https://cardiacdiagnostics.zoll.com/products/heart-failure-arrhythmia](https://cardiacdiagnostics.zoll.com/products/heart-failure-arrhythmia-management-system)[management-system](https://cardiacdiagnostics.zoll.com/products/heart-failure-arrhythmia-management-system).
- <span id="page-38-10"></span>[10] corpuls. "Corpuls3 monitor." (2022), [Online]. Available: [https://corpuls.world/en/products/](https://corpuls.world/en/products/corpuls3/#Monitoring-unit) [corpuls3/#Monitoring-unit](https://corpuls.world/en/products/corpuls3/#Monitoring-unit).
- <span id="page-38-11"></span>[11] L. G. Tereshchenko and M. E. Josephson, "Frequency content and characteristics of ventricular conduction," en, *J. Electrocardiol.*, vol. 48, no. 6, pp. 933–937, Nov. 2015.
- <span id="page-38-12"></span>[12] O. Kwon, J. Jeong, H. B. Kim, *et al.*, "Electrocardiogram sampling frequency range acceptable for heart rate variability analysis," en, *Healthc. Inform. Res.*, vol. 24, no. 3, pp. 198–206, Jul. 2018.
- <span id="page-38-13"></span>[13] V. Murthy, T. Grove, G. Harvey, and L. Haywood, "Clinical usefulness of ecg frequency spectrum analysis," in *The Second Annual Symposium on Computer Application in Medical Care, 1978. Proceedings.*, 1978, pp. 610-612. doi: [10.1109/SCAMC.1978.679974](https://doi.org/10.1109/SCAMC.1978.679974).
- <span id="page-38-14"></span>[14] A. Habib, C. Karmakar, and J. Yearwood, *Choosing a sampling frequency for ecg qrs detection using convolutional networks*, 2020. poi: [10 . 48550 / ARXIV . 2007 . 02052](https://doi.org/10.48550/ARXIV.2007.02052). [Online]. Available: [https :](https://arxiv.org/abs/2007.02052) [//arxiv.org/abs/2007.02052](https://arxiv.org/abs/2007.02052).
- <span id="page-38-15"></span>[15] R. Bousseljot, D. Kreiseler, and A. Schnabel, "Nutzung der EKG-Signaldatenbank CARDIODAT der PTB über das internet," *Biomed. Tech. (Berl.)*, pp. 317–318, Jul. 2009.
- <span id="page-38-16"></span>[16] A. L. Goldberger, L. A. Amaral, L. Glass, *et al.*, "PhysioBank, PhysioToolkit, and PhysioNet: Components of a new research resource for complex physiologic signals," en, *Circulation*, vol. 101, no. 23, E215–20, Jun. 2000.
- <span id="page-38-17"></span>[17] F. Censi, G. Calcagnini, I. Corazza, *et al.*, "On the resolution of ECG acquisition systems for the reliable analysis of the p-wave," *Physiological Measurement*, vol. 33, no. 2, N11–N17, Jan. 2012. doi: [10.1088/0967- 3334/33/2/n11](https://doi.org/10.1088/0967-3334/33/2/n11). [Online]. Available: [https://doi.org/10.1088/0967-](https://doi.org/10.1088/0967-3334/33/2/n11) [3334/33/2/n11](https://doi.org/10.1088/0967-3334/33/2/n11).
- <span id="page-39-0"></span>[18] G. Smith. "Types of a/d converters - the ultimate guide." (2020), [Online]. Available: [https:](https://dewesoft.com/daq/types-of-adc-converters) [//dewesoft.com/daq/types-of-adc-converters](https://dewesoft.com/daq/types-of-adc-converters).
- <span id="page-39-1"></span>[19] *16-bit, quad-channel, ultra-low glitch, voltage output digital-to-analog converter*, DAC8554, Texas Instruments, Oct. 2006.
- <span id="page-39-2"></span>[20] *Octal, 16-bit nanodac+ with i2c interface*, AD5675, Rev. A, Analog Circuits, Oct. 2010.
- <span id="page-39-3"></span>[21] *Quad, 16-bit, low-power, voltage output, i2c interface digital-to-analog converter*, DAC8574, Texas Instruments, Dec. 2004.
- <span id="page-39-4"></span>[22] *Stm32cubeide*. [Online]. Available: [https://www.st.com/en/development-tools/stm32cubeide.](https://www.st.com/en/development-tools/stm32cubeide.html#:~:text=STM32CubeIDE%20is%20an%20all%2Din,for%20STM32%20microcontrollers%20and%20microprocessors.) [html#:~:text=STM32CubeIDE%20is%20an%20all%2Din, for%20STM32%20microcontrollers%](https://www.st.com/en/development-tools/stm32cubeide.html#:~:text=STM32CubeIDE%20is%20an%20all%2Din,for%20STM32%20microcontrollers%20and%20microprocessors.) [20and%20microprocessors.](https://www.st.com/en/development-tools/stm32cubeide.html#:~:text=STM32CubeIDE%20is%20an%20all%2Din,for%20STM32%20microcontrollers%20and%20microprocessors.).
- <span id="page-39-5"></span>[23] *Arduino uno rev3*. [Online]. Available: [https://store.arduino.cc/products/arduino- uno](https://store.arduino.cc/products/arduino-uno-rev3)[rev3](https://store.arduino.cc/products/arduino-uno-rev3).
- <span id="page-39-6"></span>[24] *Arduino mega 2560 rev3*. [Online]. Available: [https://store.arduino.cc/products/arduino](https://store.arduino.cc/products/arduino-mega-2560-rev3)[mega-2560-rev3](https://store.arduino.cc/products/arduino-mega-2560-rev3).
- <span id="page-39-7"></span>[25] *Arduino due*. [Online]. Available: [https://store.arduino.cc/collections/boards/products/](https://store.arduino.cc/collections/boards/products/arduino-due) [arduino-due](https://store.arduino.cc/collections/boards/products/arduino-due).
- <span id="page-39-8"></span>[26] *Portenta h7 lite*. [Online]. Available: <https://store.arduino.cc/products/portenta-h7-lite>.
- <span id="page-39-9"></span>[27] *4622 adafruit: Mouser*. [Online]. Available: [https://nl.mouser.com/ProductDetail/Adafruit/](https://nl.mouser.com/ProductDetail/Adafruit/4622?qs=7MVldsJ5UaxIlY4FBCFg7w%3D%3D) [4622?qs=7MVldsJ5UaxIlY4FBCFg7w%3D%3D](https://nl.mouser.com/ProductDetail/Adafruit/4622?qs=7MVldsJ5UaxIlY4FBCFg7w%3D%3D).
- <span id="page-39-10"></span>[28] *Nucleo-f411re stmicroelectronics: Mouser*. [Online]. Available: [https://nl.mouser.com/ProductDe](https://nl.mouser.com/ProductDetail/STMicroelectronics/NUCLEO-F411RE?qs=Zt3UNFD9mQjdEJg18RwZ2g%3D%3D) [tail/STMicroelectronics/NUCLEO-F411RE?qs=Zt3UNFD9mQjdEJg18RwZ2g%3D%3D](https://nl.mouser.com/ProductDetail/STMicroelectronics/NUCLEO-F411RE?qs=Zt3UNFD9mQjdEJg18RwZ2g%3D%3D).
- <span id="page-39-11"></span>[29] *Nucleo-h743zi2 stmicroelectronics: Mouser*. [Online]. Available: [https://nl.mouser.com/ProductD](https://nl.mouser.com/ProductDetail/STMicroelectronics/NUCLEO-H743ZI2?qs=lYGu3FyN48cfUB5JhJTnlw%3D%3D) [etail/STMicroelectronics/NUCLEO-H743ZI2?qs=lYGu3FyN48cfUB5JhJTnlw%3D%3D](https://nl.mouser.com/ProductDetail/STMicroelectronics/NUCLEO-H743ZI2?qs=lYGu3FyN48cfUB5JhJTnlw%3D%3D).
- <span id="page-39-12"></span>[30] P. Bing, W. Liu, Z. Wang, and Z. Zhang, "Noise reduction in ecg signal using an effective hybrid scheme," *IEEE Access*, vol. 8, pp. 160 790–160 801, 2020. doi: [10.1109/ACCESS.2020.3021068](https://doi.org/10.1109/ACCESS.2020.3021068).
- <span id="page-39-13"></span>[31] Y. Weiting and Z. Runjing, "An improved self-adaptive filter based on lms algorithm for filtering 50hz interference in ecg signals," in *2007 8th International Conference on Electronic Measurement and Instruments*, 2007, pp. 3-874-3-878. poi: [10.1109/ICEMI.2007.4351057](https://doi.org/10.1109/ICEMI.2007.4351057).
- <span id="page-39-14"></span>[32] H. Gholam-Hosseini, H. Nazeran, and K. Reynolds, "Ecg noise cancellation using digital filters," in *Proceedings of the 2nd International Conference on Bioelectromagnetism (Cat. No.98TH8269)*, 1998, pp. 151-152. doi: [10.1109/ICBEM.1998.666440](https://doi.org/10.1109/ICBEM.1998.666440).
- <span id="page-39-15"></span>[33] H. K. Jayant, K. Rana, V. Kumar, S. S. Nair, and P. Mishra, "Efficient iir notch filter design using minimax optimization for 50hz noise suppression in ecg," in *2015 International Conference on Signal Processing, Computing and Control (ISPCC)*, 2015, pp. 290–295. doi: [10.1109/ISPCC.2015.7375043](https://doi.org/10.1109/ISPCC.2015.7375043).
- <span id="page-39-16"></span>[34] S. L. Joshi, R. A. Vatti, and R. V. Tornekar, "A survey on ecg signal denoising techniques," in *2013 International Conference on Communication Systems and Network Technologies*, Apr. 2013, pp. 60–64. doi: [10.1109/CSNT.2013.22](https://doi.org/10.1109/CSNT.2013.22).
- <span id="page-39-17"></span>[35] E. Ajdaraga and M. Gusev, "Analysis of sampling frequency and resolution in ecg signals," in *2017 25th Telecommunication Forum (TELFOR)*, 2017, pp. 1–4. doi: [10.1109/TELFOR.2017.8249438](https://doi.org/10.1109/TELFOR.2017.8249438).
- <span id="page-39-18"></span>[36] mains frequency. "Measurement of the mains frequency." (2022), [Online]. Available: [https:](https://www.mainsfrequency.com/index.htm) [//www.mainsfrequency.com/index.htm](https://www.mainsfrequency.com/index.htm).
- <span id="page-39-19"></span>[37] swissgrid. "Frequency." (2022), [Online]. Available: [https://www.swissgrid.ch/en/home/](https://www.swissgrid.ch/en/home/operation/regulation/frequency.html) [operation/regulation/frequency.html](https://www.swissgrid.ch/en/home/operation/regulation/frequency.html).
- <span id="page-39-20"></span>[38] entsoe. "[press release] continuing frequency deviation in the continental european power system originating in serbia/kosovo: Political solution urgently needed in addition to technical." (2018), [Online]. Available: [https://www.entsoe.eu/news/2018/03/06/press-release-continuing](https://www.entsoe.eu/news/2018/03/06/press-release-continuing-frequency-deviation-in-the-continental-european-power-system-originating-in-serbia-kosovo-political-solution-urgently-needed-in-addition-to-technical/)[frequency - deviation - in - the - continental - european - power - system - originating- in](https://www.entsoe.eu/news/2018/03/06/press-release-continuing-frequency-deviation-in-the-continental-european-power-system-originating-in-serbia-kosovo-political-solution-urgently-needed-in-addition-to-technical/)[serbia-kosovo-political-solution-urgently-needed-in-addition-to-technical/](https://www.entsoe.eu/news/2018/03/06/press-release-continuing-frequency-deviation-in-the-continental-european-power-system-originating-in-serbia-kosovo-political-solution-urgently-needed-in-addition-to-technical/).
- <span id="page-39-21"></span>[39] R. Klabunde. "Cardiovascular physiology concepts." (2019), [Online]. Available: [https : / /](https://cvphysiology.com/Arrhythmias/A009) [cvphysiology.com/Arrhythmias/A009](https://cvphysiology.com/Arrhythmias/A009).
- <span id="page-40-0"></span>[40] "CMSIS DSP Software Library." (), [Online]. Available: [https://www.keil.com/pack/doc/](https://www.keil.com/pack/doc/CMSIS/DSP/html/index.html) [CMSIS/DSP/html/index.html](https://www.keil.com/pack/doc/CMSIS/DSP/html/index.html).
- <span id="page-40-1"></span>[41] *User manual: Description of stm32h7 hal and low-layer drivers*, UM2217 Rev 5, STMicroelectronics, Jul. 2020.
- <span id="page-40-2"></span>[42] *Reference manual: Stm32h742, stm32h743/753 and stm32h750 value line advanced arm®-based 32-bit mcus*, RM0433 Rev 7, STMicroelectronics, Feb. 2020.
- <span id="page-40-3"></span>[43] "Measuring code execution time on ARM Cortex-M MCUs." (2018), [Online]. Available: [https:](https://embeddedcomputing.com/technology/processing/measuring-code-execution-time-on-arm-cortex-m-mcus) [//embeddedcomputing.com/technology/processing/measuring-code-execution-time-on](https://embeddedcomputing.com/technology/processing/measuring-code-execution-time-on-arm-cortex-m-mcus)[arm-cortex-m-mcus](https://embeddedcomputing.com/technology/processing/measuring-code-execution-time-on-arm-cortex-m-mcus).
- <span id="page-40-4"></span>[44] G. Moody and R. Mark, "The impact of the mit-bih arrhythmia database," *IEEE Engineering in Medicine and Biology Magazine, vol. 20, no. 3, pp. 45-50, 2001. poi: [10.1109/51.932724](https://doi.org/10.1109/51.932724).*
- <span id="page-40-5"></span>[45] S. Narayanaswamy, "High resolution electrocardiography," en, *Indian Pacing Electrophysiol. J.*, vol. 2, no. 2, pp. 50–56, Apr. 2002.
- <span id="page-40-6"></span>[46] Tektronix. "Waveform generator software." (), [Online]. Available: [https://www.tek.com/en/](https://www.tek.com/en/products/software/arbexpress-signal-generator) [products/software/arbexpress-signal-generator](https://www.tek.com/en/products/software/arbexpress-signal-generator).

## A

## Extra figures



#### <span id="page-41-2"></span><span id="page-41-1"></span><span id="page-41-0"></span>**A.1. IIR designs**

**(c)** 6th order Chebyshev type II

**Figure A.1:** Phase response of different IIR band-stop filters



**Figure A.2:** Phase response comparison of IIR notch filter and FIR band-stop filter

<span id="page-42-1"></span>

**Figure A.3:** Group delay comparison of IIR notch fiter and FIR band-stop filter

<span id="page-42-2"></span>

**Figure A.4:** Convergence of IIR filter attenuation over time

#### <span id="page-42-0"></span>**A.1.1. ECG Signal Filter Testing**

<span id="page-43-0"></span>

**Figure A.5:** Filter input and output in the frequency-domain

<span id="page-43-1"></span>

**Figure A.6:** ECG Signal - Patient 001

## B

## <span id="page-44-0"></span>Complementary Information

#### <span id="page-44-1"></span>**B.1. Notch filter transfer functions**

In the main body of the thesis, only the transfer function for a 50Hz notch filter was included with precision up to 5 decimal points. In the implementation the precision is higher and thus, the transfer function with unrounded coefficients are included in this appendix.

• 50Hz Notch filter:

$$
H(z) = \frac{0.984260526926093116 - 1.59256698635129967z^{-1} + 0.984260526926093116z^{-2}}{1 - 1.59256698635129967z^{-1} + 0.968521053852186231z^{-2}} \tag{B.1}
$$

• 100Hz Notch filter:

$$
H(z) = \frac{0.984260526926093116 - 0.608306459425206669z^{-1} + 0.984260526926093116z^{-2}}{1 - 0.608306459425206669z^{-1} + 0.968521053852186231z^{-2}}
$$
(B.2)

• 150Hz Notch filter:

$$
H(z) = \frac{0.984260526926093116 + 0.608306459425206447z^{-1} + 0.984260526926093116z^{-2}}{1 + 0.608306459425206447z^{-1} + 0.968521053852186231z^{-2}} \tag{B.3}
$$

• 200Hz Notch filter:

$$
H(z) = \frac{0.984260526926093116 + 1.59256698635129945z^{-1} + 0.984260526926093116z^{-2}}{1 + 1.59256698635129945z^{-1} + 0.968521053852186231z^{-2}} \tag{B.4}
$$

#### <span id="page-45-0"></span>**B.2. DAC Operation**

**TRx**: Temporary Register x of channel x

**DACx**: Output channel x of a single DAC8574

**Table B.1:** 4-byte operation of TI DAC8574





**Figure B.1:** DAC generated output on Channel 2 of an osciloscope

## $\overline{\phantom{a}}$

## Signal creation

<span id="page-46-0"></span>In order to independently test different parts of the system proposed, a function generator (Tektronix AFG 3012B) was used to output an ECG signal. This appendix will outline the method followed to load an ECG signal to an arbitrary waveform of the Tektronix AFG 3012B function generator.

- 1. Obtain up to 1000 samples to form into an arbitrary waveform sampled at a constant time interval
- 2. Install ArbExpress software from Tektronix [\[46\]](#page-40-6)
- <span id="page-46-1"></span>3. Create a .csv file with a format as in Table [C.1](#page-46-1)

**Table C.1:** Waveform format

**(a)** General format



#CLOCK=1.0000000000e+08 #SIZE=1000 0.209376141 0.219020873 ... 0.736418009

**(b)** Example format

- 4. Load the .csv file into the ArbExpress software by clicking: File -> Open (Cntrl + O key shortcut) and selecting the .csv file. When loading in the example format, ArbExpress wil look like Figure [C.1](#page-47-0)
- 5. Save the waveform on an USB-device as a .tfw file by clicking: File -> Save as -> Save as type: AFG TFW(\*.tfw)
- 6. Plug in the USB device in the function generator
- 7. Load the arbitrary waveform from the USB-device: Function: Arb -> Arb Waveform Menu -> Memory: USB -> Select waveform. For the example waveform, the result can be seen in Figure [C.2](#page-47-1)
- 
- 8. Set frequency, phase, amplitude and offset on the function generator as needed

<span id="page-47-0"></span>

**Figure C.1:** ArbExpress waveform loaded

<span id="page-47-1"></span>

**Figure C.2:** Waveform loaded on Tektronix AFG 3021B