/Atrial-Fibrillation-Detection

Data Science Project - Time Series & Data Mining

Primary LanguageJupyter Notebook

Early Detection & Monitoring of Atrial Fibrillation Cases

Data Science Project - Time Series & Data Mining

Introduction

This project aims to develop a machine learning model that can detect the presence of atrial fibrillation (AF) in RR intervals of electrocardiogram (ECG) recordings. AF is a type of irregular heartbeat, or arrhythmia, that originates in the upper chambers of the heart (the atria). In AF, the atria beat irregularly and rapidly, which can cause poor blood flow to the body and increase the risk of blood clots, stroke, heart failure, and other cardiovascular complications. Although AF is a common cause of many dangerous cardiovascular complications, it can be very difficult to detect, requiring tedious manual works. AFs are very short in the ECG signals and there are a lot of noises in the signals themselves. Therefore, an automatic early AF detection is crucial for effective treatment.

Dataset

This dataset contains electrocardiogram (ECG) data from patients who underwent coronary artery bypass graft (CABG) surgery at the Erasmus Medical Centre in Rotterdam, Department of Electrophysiology. The dataset is used for detecting atrial fibrillation (AF) using machine learning algorithms.

There are two initial datasets available: preprocessed and raw data.

  • The preprocessed data consists of 150,000 observations with 30 dependent variables and one independent variable (Control).
  • The raw data consists of ECG and class data. The ECG data is stored in 804 text files (Data1 to Data804) and analyzed using a semi-automatic program (Synescope) for R peak annotation. The ECG data is then manually audited by a physician to label AF cases. The class data is also stored in 804 text files (Control1 to Control804), where the AF and no-AF episodes were transformed into 1 and 0 in 30-second intervals by considering if more than 75% of the period was AF.

Methods

Exploratory Data Analysis (EDA): EDA was performed to understand the characteristics and patterns of the data, specifically to examine the distribution of data, outliers, and missing values.

Data Preprocessing: The raw data required significant preprocessing to be usable in machine learning models. Initially, the ECG signals and AF labels was separated in different 804 text files, and it was necessary to transform and merge both raw files. The data cleaning process was also performed.

Feature Engineering: Features were generated from the preprocessed data (including time domain, frequency domain, and other hrv-based features), and the missing data were handled through imputation. Feature selection was also performed to reduce the dimensionality of the dataset.

Model Building: Handling class imbalances was a significant challenge in this project since the AF cases were in the minority. Therefore, different sampling techniques were applied to overcome the class imbalance issue. A train-test split was performed to evaluate the performance of the models, and feature scaling was applied to normalize the data. Finally, different machine learning models were trained and tested on the preprocessed data, and the results were analyzed to select the best-performing model.

Results

The XGBoost algorithm outperformed other models and achieved the highest recall and accuracy of 0.99 in detecting AF episodes. Feature importance analysis revealed that the most important features are time and frequency domain features, especially the ones that reflect the sudden movement in the R-R interval. These findings highlight the importance of time-series-based heart rate variability features and the effectiveness of machine learning algorithms in detecting AF episodes, providing valuable insights for medical practitioners and researchers working in the field of cardiology.

Contributors