Analysis package for single-lead clinical EKG data
Project description
Cardiopy
A flexibile package for R-peak detection and heart rate variability analysis of single-lead EKG data.
Full documentation is available here. If you use CardioPy or a derivative in your work, please cite:
Gottshall, J. L., Recoder, N., Schiff, N. D. (2020). CardioPy: An open-source heart rate variability analysis toolkit for single-lead EKG. boiRxv. doi: 10.1101/2020.10.06.328856
How to use Cardiopy
Cardiopy can be used in two ways:
- As a preprocessing module for the import and cleaning of clinical EKG data in conjuction
with HRV analyses by standard software packages. For this use, run through feature sets 1 and 2 (listed below). The exported '_nn.txt' file is compatible with all major HRV software packages
- As a stand-alone HRV analysis toolkit. For this use, continue through the workflow from feature set 1 through 4 (listed below). To ensure analytic reproducibilty, we highly recommend exporting cleaned nn detections at feature set 2.
Features
1. Data preprocessing and cleaning
- Load single-lead EKG data
- Detect R-peaks using the Pan Tompkins method
- Option to detect R-peaks with flexible thresholding parameters for adjustment to noisy data and varying amplitudes
- Option to filter especially noisy data prior to peak detection
- Option to filter especially noisy data prior to peak detection
- Option to detect R-peaks with flexible thresholding parameters for adjustment to noisy data and varying amplitudes
- Built-in detection visualization methods
- Simple artifact removal methods for manual inspection of detected peaks
2. Export methods for cleaned peak detections
- Compatible with commonly used software such as Kubios HRV and Artiifact
3. HRV analysis methods
- Standard time-domain statistics
- Standard frequency domain statistics
- Option for Multitaper or Welch power spectral estimates
- Option for Multitaper or Welch power spectral estimates
4. HRV statistics export
- Single-file report exports in json format
- Multi-file exports into .csv spreadsheets for group statistics
Installation
Use the package manager pip to install CardioPy.
pip install cardiopy
Usage
Best when run with jupyter notebook. For detailed instructions download the example jupyter notebook file and the example jupyter notebook file for manual cleaning, as well as the de-identified data segment from github
For optimal performance, close figure interactions ('off' button on the top right corner) when finished with each window.
Parameter Optimization & Cleaning Tips
-
Remove false interbeat intervals LAST, after all cleaning (addition/removal of peaks) has been done.
-
To maintain integrity of the artifact logs:
- Only remove incorrectly added peaks with EKG.undo_add_peak NOT with EKG.rm_peak.
- Only re-add incorrectly removed peaks with EKG.undo_rm_peak NOT with EKG.add_peak.
-
If R peak detections are not accurate, try:
- changing the moving window size
- changing the upshift percentage
- both
Contributing
Pull requests are welcome! For major changes, please open an issue first to discuss what you would like to change.
License
BSD 3-Clause
Roadmap
The authors plan for future versions of CardioPy to include:
- Support for additional commonly used data formats
- A graphical user interface
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distributions
Built Distribution
File details
Details for the file cardiopy-1.0.0-py3-none-any.whl
.
File metadata
- Download URL: cardiopy-1.0.0-py3-none-any.whl
- Upload date:
- Size: 17.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.2 importlib_metadata/3.10.0 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.59.0 CPython/3.8.8
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 34f73f52c14da7a89c4921de67431e87107248867669ff128293cff15d84e145 |
|
MD5 | 3f8cca719b5d50ce7349ef6e47c25d47 |
|
BLAKE2b-256 | b8fe2576579ee868b19abd9f138565dcecfc07f3a59db0350a0166c884802f23 |