ReSurfEMG is an open source collaborative python library for analysis of respiratory electromyography (EMG). On the same site as the repository for this library we keep related resources.
ReSurfEMG includes a main code library where the user can access the code to change various filter and analysis settings directly and/or in our researcher interface notebooks. In addition, ReSurfEMG has a dashboard interface which contains default settings for preprocessing and analysis which can be changed through a graphical (no code) interface. We have some functionality available through a command line interface as well.
The library was initially built for surface EMG, however many functions will also work for invasively measured respiratory EMG. This library supports the ongoing research at University of Twente on respiratory EMG.
The core functions of ReSurfEMG are in the folder resurfemg:
- cli: Scripts for the command line interface
- data_connector: Converter functions for discovering, loading, simulating and handling data.
- helper_functions: General functions to support the functions in this repository
- preprocessing: Process the raw respiratory EMG signal
- filtering: low-, high- and bandpass filters, notch filter, computer power loss
- ecg-removal: gating and wavelet denoising
- envelope: root-mean-square (RMS), average rectified (ARV)
- postprocessing: Aspects of pre-processed the respiratory EMG data:
- moving baselines
- event detection: find pneumatic and EMG breaths, on- and offset detection
- features: amplitude, area under the curve, slope, area under the baseline, respiratory rate
- quality assessment: signal-to-noise ratio, end-expiratory occlussion manoeuvre quality, interpeak distance, area under the baseline, consecutive manoeuvres, bell-curve error, relative peak timing, relative area under the baseline, relative ETP
Our guide to notebooks is under construction. To look around keep in mind the following distinction on folders:
dev:
- These notebooks are used in feature development and debugging by core members of the ReSurfEMG team. They can provide a basic example how to use some of the functionality.
open_work:
- This folder contains experimental work by core members of the ReSurfEMG team that is not deployed yet.
researcher_interface:
- These are a growing series of interactive notebooks that allow researchers to investigate questions about their own EMG data
The notebooks are configured to run on various datasets. Contact Dr. Eline Mos-Oppersma( 📫 [email protected]) to discuss any questions on data configuration for your datasets.
If you want to use a standardized dataset for any purpose we recommend the data in the ReSurfEMG/test_data, which is also used in testing the ReSurfEMG functions. Data there can be used with any respiratory EMG algorithms in any program. Thus that data can function as a benchmarking set to compare algorithms across different programs.
Alternatively, the data in the ReSurfEMG/synthetic_data repository:
In order to preprocess and/or to train models the code needs to be able to locate the raw data you want it to find.
There are several ways to specify the location of the following directories:
- root_data: Special directory. The rest of the directory layout can be derived from its location.
- preprocessed_data: The directory that will be used by preprocessing code to output to.
- test_data: The directory for running sanity tests.
You can store this information persistently in several locations.
- In the same directory where you run the script (or the notebook).
e.g.
./config.json
. - In home directory, e.g.
~/.resurfemg/config.json
. - In global directory, e.g.
/etc/resurfemg/config.json
.
However, we highly recommend using the home directory. This file can have this or similar contents:
{
"root_data": "/mnt/data",
"patient_data": "/mnt/patient_data",
"simulated_data": "/mnt/simulated_data",
"preprocessed_data": "/mnt/data/preprocessed",
"output_data": "/mnt/data/output",
}
The file is read as follows: if the files specifies root_data
directory, then the missing entries are assumed to be relative to
the root. You do not need to specify all entries.
Test data is provided in the repository in the test_data folder.
ReSurfEMG is a pure Python package. Below is the list of platforms that should work. Other platforms may work, but have had less extensive testing. Please note that where python.org Python stated as supported, it means that versions 3.9 - 3.12 are supported.
Linux | Win | OSX | |
---|---|---|---|
Supported | Supported | Supported | |
Discontinued | Discontinued | Discontinued |
Installation with Anaconda/conda and/or mamba are the preffered methods. They are covered in the "Getting Started" section. If you wish to install with pip:
- Create and activate a virtual environment (see developer setup section for more details)
- Install ResurfEMG package by running
pip install resurfemg
.
How to get the notebooks running? Assuming the raw data set and metadata is available.
python3 -m venv .venv
This might require the python3-venv.
python -m venv .venv
source .venv/bin/activate
pip install resurfemg[dev]
.venv\Scripts\activate.bat
pip install resurfemg[dev]
Start a local Jupyter Notebook server by running the jupyter notebook
command in your terminal. This opens a browser window where you can browse,
open and run the notebooks. (We use Jupyter notebooks)
The ReSurfEMG notebooks are located in the notebooks folder. Navigate there
and open a notebook of interest. The basic_emg_analysis
notebook can be used to understand how to use the package.
We distinguish between people who want to use this library in their own code and/or analysis, and people who also want to develop this library who we call developers, be it as members of our team or independent contributors. People who simply want to use our library need to install the packaged version from one of the package indexes to which we publish released versions (eg. PyPI). This section of the readme is for advanced developers who want to modify the library code (and possibly contribute their changes back or eventually publish thier own modified fork). NB: You can accomplish modifications of the code, submit pull-requests (PRs) and soforth without a 'developer's setup' but we feel this setup will make advanced contributions easier.
We have transitioned to a fully Python 3.9+ environment.
(For older instructions with venv
please see versions below 0.2.0, and
adapt them if using Windows and/or a different Python version than
Python.org Python. e.g. you may need to use .venv\Scripts\activate.bat
in
place of .venv/bin/activate
)
The instructions below are for our newer versions above 1.0.0. This will create
a distributable package from the source code, then install it in the currently
active environment. This will also install development tools we use
s.a. pytest
and codestyle
and will also install tools we use for
working with the library, such as jupyter
.
python3 -m venv .venv
source .venv/bin/activate
pip install -e .[dev]
python -m venv .venv
.venv\Scripts\activate.bat
pip install -e .[dev]
These installs differ in two ways from the regular install: 1) The .[dev]
(as compared to resurfemg[dev]
)
installs the library as it currently is including all your local changes,
instead of pulling it from the PyPI repository. 2) The -e
flag ensures an
editable install, such that any changes to the library are automatically
applied to your environment.
Now you should have everything necessary to start working on the source code.
Online documentation can be found at https://resurfemg.github.io/ReSurfEMG/ or on https://readthedocs.org/ by searching for ReSurfEMG. Up-to-date documentation can be generated in command-line as follows in terminal:
python3 -m venv .venv
source .venv/bin/activate
pip install -e .[docs]
python setup.py apidoc
python setup.py build_sphinx
python -m venv .venv
.venv\Scripts\activate.bat
pip install -e .[docs]
python setup.py apidoc
python setup.py build_sphinx
The project comes with several modifications to the typical default setup.py
.
The project has a sub-project of a related dashboard. Dashboard is a GUI that exposes some of the project's functionality. In the past, we kept a a legacy dashboard in the same repository with ReSurfEMG code but we have deleted it. The current version of the dashboard into it's own repository: https://github.com/ReSurfEMG/ReSurfEMG-dashboard
isort resurfemg --check --diff
checks that the imports are properly formatted and sorted.python setup.py apidoc
generates RST outlines necessary to generate documentation.
The project includes testing data. This test data is synthetic and generated by the ReSurfEMG data_connector.synthetic_data
methods.
python3 -m venv .venv
source .venv/bin/activate
pip install -e .[tests]
pytest
python -m venv .venv
.venv\Scripts\activate.bat
pip install -e .[tests]
pytest
You will be able to preprocess data using command-line interface. You can also, in some cases, create files in the correct format for our Dashboard in a per folder batch process.
You can make synthetic data. To explore this start with
`python -m resurfemg simulate_emg --help`
`python -m resurfemg simulate_ventilator --help`
✨Copyright 2022 Netherlands eScience Center and U. Twente Licensed under the Apache License, version 2.0. See LICENSE for details.✨