Skip to content

Python Heart Rate Analysis Package, for both PPG and ECG signals

License

Notifications You must be signed in to change notification settings

jorford/heartrate_analysis_python

 
 

Repository files navigation

A note to our friends from the Humanist 2018 conference

This is the package presented at the Humanist 2018 conference in the Hague, Netherlands. Note that it is always in active development. Whenever including it in your research, pull the latest version from this GitHub. Support is always available at: P.vanGent@tudelft.nl.

Thank you for your interest

Installation

python -m setup.py install

Alternatively, we're also on PIP:

python -m pip install heartpy

That's it!

Official Documentation

The official documentation is online! You can find the official documentation here

HeartPy - Python Heart Rate Analysis Toolkit

DOI

HeartPy, the Python Heart Rate Analysis Toolkit is a module for heart rate analysis in Python. It started as pure-python implementation to analyse physiological data taken in naturalistisch driving and cycling experiments.

The module takes a discrete heart rate signal and outputs time-domain and frequency-domain measures often found in scientific literature:

Time domain:

  • beats per minute, BPM
  • interbeat interval, IBI
  • standard deviation if intervals between adjacent beats, SDNN
  • standard deviation of successive differences between adjacent R-R intervals, SDSD
  • root mean square of successive differences between adjacend R-R intervals, RMSSD
  • proportion of differences between R-R intervals greater than 20ms, 50ms, pNN20, pNN50
  • median absolute deviation, MAD

Frequency domain

  • low frequency component (0.04-0.15Hz), LF
  • high frequency component (0.16-0.5Hz), HF
  • lf/hf ratio, Lf/HF

When using the package in your research, please cite:

van Gent, P., Farah, H., van Nes, N., & van Arem, B. (2018). Heart Rate Analysis for Human Factors: Development and Validation of an Open Source Toolkit for Noisy Naturalistic Heart Rate Data. In Proceedings of the 6th HUMANIST Conference (pp. 173–178).

van Gent, P. Van, Farah, H., Nes, N. Van, & Arem, B. Van. (manuscript submitted). Analysing Noisy Driver Physiology Real-Time Using Off-the-Shelf Sensors: Heart Rate Analysis Software from the Taking the Fast Lane Project.. Doi: doi.org/10.13140/RG.2.2.24895.56485

Documentation

You can find the official documentation here

The module is also to some extent described in my tutorial series:

License

The module is licensed under the GNU General Public License Version3, GPL-v3

Validation

Initial results of the validation have been reported in [1, 2]. Updates here are soon to follow once the papers are published.

[1]van Gent, P., Farah, H., van Nes, N., & van Arem, B. (2018). Heart Rate Analysis for Human Factors: Development and Validation of an Open Source Toolkit for Noisy Naturalistic Heart Rate Data. In Proceedings of the 6th HUMANIST Conference (pp. 173–178).

[2] van Gent, P. Van, Farah, H., Nes, N. Van, & Arem, B. Van. (manuscript submitted for publication). A Novel Heart Rate Algorithm for the Analysis of Noisy Signals.

To-do

The module is still in active development. See the changelog for past changes. The to-do for the coming months is:

to do before V1.2

  • Validate performance on Physionet datasets
  • Update threshold parameter optimization to handle cases of double peaks and large portion of signal containing little to no hr
  • Report validation performance on repo (published paper + key-points document)
  • Add R-position interpolation ('high accuracy' mode)
  • Handle cases where strong T-peak in signal is present
  • Include example data on PIP release
  • Change peak fitting to optimize locally rather than globally, to handle long signals with noisy intermediate sections better
  • Change segmented analysis method to run peak detection once on whole signal, then do segmentwise computation from working_data object (drastic speed up)

About

Python Heart Rate Analysis Package, for both PPG and ECG signals

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Python 100.0%