beliefppg


Namebeliefppg JSON
Version 0.3.1 PyPI version JSON
download
home_pagehttps://github.com/eth-siplab/BeliefPPG
SummaryTaking multi-channel PPG and Accelerometer signals as input, BeliefPPG predicts the instantaneous heart rate and provides an uncertainty estimate for the prediction.
upload_time2024-08-28 15:07:13
maintainerNone
docs_urlNone
authorPaul Streli
requires_python>=3.9
licenseNone
keywords ppg heart rate signal processing uncertainty estimation biomedical signals
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            ## BeliefPPG: Uncertainty-aware Heart Rate Estimation from PPG signals via Belief Propagation

BeliefPPG is a novel learning-based method that achieves state-of-the-art performance on several heart rate estimation benchmarks extracted from photoplethysmography signals (PPG). It considers the evolution of the heart rate in the context of a discrete-time stochastic process that is represented as a hidden Markov model. It derives a distribution over possible heart rate values for a given PPG signal window through a trained neural network. Using belief propagation, it incorporates the statistical distribution of heart rate changes to refine these estimates in a temporal context. From this, it obtains a quantized probability distribution over the range of possible heart rate values that captures a meaningful and well-calibrated estimate of the inherent predictive uncertainty.

Install
----------
You can install the pip package using:
```bash
pip install beliefppg
```

Quick Start
----------
To start inferring heart rate from PPG and accelerometer data, you first need to import the `infer_hr` function from the `beliefppg` package.
The function `infer_hr` returns the estimated heart rate and the corresponding midpoint indices of the windows used for heart rate inference.
```python
from beliefppg import infer_hr

# Example of a simple function call (adjust 'ppg' and 'sampling_rate' as per your data)
hr, idxs = infer_hr(ppg, sampling_rate)
```

The accuracy of BeliefPPG can be enhanced by incorporating accelerometer data alongside the PPG signals.
```python
from beliefppg import infer_hr

ppg_sampling_rate = 128  # Hz (sampling rate of ppg sensor)
acc_sampling_rate = 128 # Hz (sampling rate of accelerometer)

# Load data item containing the PPG, HR, and IMU signals --- challenging custom dataset
data = np.load('Data/example.npy', allow_pickle=True).item()

ppg = data['PPG head'].reshape((-1,1)) # reshape ppg to (n_samples, n_channels)
IMU_X = data['IMU X head']
IMU_Y = data['IMU Y head']
IMU_Z = data['IMU Z head']
acc = np.stack([IMU_X,IMU_X, IMU_Z], axis=-1)

hr, idxs = infer_hr(
    ppg, # PPG signal data with shape (n_samples, n_channels)
    ppg_sampling_rate, # Sampling frequency of the PPG signal in Hz
    acc=acc, # Accelerometer signal data with shape (n_samples, n_channels). BeliefPPG to function without accelerometer signal data, but its accuracy may be reduced.
    acc_freq=acc_sampling_rate, # Sampling frequency of the accelerometer signal in Hz
)
```

The `infer_hr_uncertainty` function from the `beliefppg` package returns the estimated heart rate, uncertainty estimates about the heart rate values, and the bounds [start_ts, end_ts] of the corresponding windows used for heart rate inference in seconds.
Additionally, users can choose between belief propagation and Viterbi decoding, specify the uncertainty measure, and decide whether to disable the time-domain backbone of the network architecture. Detailed explanations of these features can be found in our [paper](https://static.siplab.org/papers/uai2023-beliefppg.pdf) and [supplementary material](https://static.siplab.org/papers/uai2023-beliefppg-supplementary.pdf).
```python
from beliefppg import infer_hr_uncertainty

ppg_sampling_rate = 128  # Hz (sampling rate of ppg sensor)
acc_sampling_rate = 128 # Hz (sampling rate of accelerometer)

# Load data item containing the PPG, HR, and IMU signals --- challenging custom dataset
data = np.load('Data/example.npy', allow_pickle=True).item()

ppg = data['PPG head'].reshape((-1,1)) # reshape ppg to (n_samples, n_channels)
IMU_X = data['IMU X head']
IMU_Y = data['IMU Y head']
IMU_Z = data['IMU Z head']
acc = np.stack([IMU_X,IMU_X, IMU_Z], axis=-1)

hr, uncertainty, time_intervals = infer_hr_uncertainty(
    ppg, # PPG signal data with shape (n_samples, n_channels)
    ppg_sampling_rate, # Sampling frequency of the PPG signal in Hz
    acc=acc, # Accelerometer signal data with shape (n_samples, n_channels). BeliefPPG to function without accelerometer signal data, but its accuracy may be reduced.
    acc_freq=acc_sampling_rate, # Sampling frequency of the accelerometer signal in Hz
    decoding='sumproduct', # Decoding method to use, either "sumproduct" or "viterbi"
    use_time_backbone=True, # Whether to use the time-domain backbone or not
    uncertainty='std' # Measure for predictive uncertainty, either "entropy" or "std"
)
# The function returns predicted heart rates in BPM, uncertainties (entropy or std), and time intervals in seconds.
```
For a complete example demonstrating how to use BeliefPPG for heart rate inference, see the [tutorial notebook](https://github.com/eth-siplab/BeliefPPG/blob/master/tutorial.ipynb).

Citation
----------
If your find our paper or codes useful, please cite our work:

    @InProceedings{uai2023-beliefppg,
        author={Bieri, Valentin and Streli, Paul and Demirel, Berken Utku and Holz, Christian},
        title = {BeliefPPG: Uncertainty-aware Heart Rate Estimation from PPG signals via Belief Propagation},
        year = {2023},
        organization={PMLR},
        booktitle = {Conference on Uncertainty in Artificial Intelligence (UAI)}
    }

License and Acknowledgement
----------
This project is released under the MIT license.




            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/eth-siplab/BeliefPPG",
    "name": "beliefppg",
    "maintainer": null,
    "docs_url": null,
    "requires_python": ">=3.9",
    "maintainer_email": null,
    "keywords": "PPG, heart rate, signal processing, uncertainty estimation, biomedical signals",
    "author": "Paul Streli",
    "author_email": "paul.streli@inf.ethz.ch",
    "download_url": "https://files.pythonhosted.org/packages/3c/7f/3387f20d4f2aae6087bb8df9d8b1432604c19839e31d4c9f762541d93808/beliefppg-0.3.1.tar.gz",
    "platform": null,
    "description": "## BeliefPPG: Uncertainty-aware Heart Rate Estimation from PPG signals via Belief Propagation\n\nBeliefPPG is a novel learning-based method that achieves state-of-the-art performance on several heart rate estimation benchmarks extracted from photoplethysmography signals (PPG). It considers the evolution of the heart rate in the context of a discrete-time stochastic process that is represented as a hidden Markov model. It derives a distribution over possible heart rate values for a given PPG signal window through a trained neural network. Using belief propagation, it incorporates the statistical distribution of heart rate changes to refine these estimates in a temporal context. From this, it obtains a quantized probability distribution over the range of possible heart rate values that captures a meaningful and well-calibrated estimate of the inherent predictive uncertainty.\n\nInstall\n----------\nYou can install the pip package using:\n```bash\npip install beliefppg\n```\n\nQuick Start\n----------\nTo start inferring heart rate from PPG and accelerometer data, you first need to import the `infer_hr` function from the `beliefppg` package.\nThe function `infer_hr` returns the estimated heart rate and the corresponding midpoint indices of the windows used for heart rate inference.\n```python\nfrom beliefppg import infer_hr\n\n# Example of a simple function call (adjust 'ppg' and 'sampling_rate' as per your data)\nhr, idxs = infer_hr(ppg, sampling_rate)\n```\n\nThe accuracy of BeliefPPG can be enhanced by incorporating accelerometer data alongside the PPG signals.\n```python\nfrom beliefppg import infer_hr\n\nppg_sampling_rate = 128  # Hz (sampling rate of ppg sensor)\nacc_sampling_rate = 128 # Hz (sampling rate of accelerometer)\n\n# Load data item containing the PPG, HR, and IMU signals --- challenging custom dataset\ndata = np.load('Data/example.npy', allow_pickle=True).item()\n\nppg = data['PPG head'].reshape((-1,1)) # reshape ppg to (n_samples, n_channels)\nIMU_X = data['IMU X head']\nIMU_Y = data['IMU Y head']\nIMU_Z = data['IMU Z head']\nacc = np.stack([IMU_X,IMU_X, IMU_Z], axis=-1)\n\nhr, idxs = infer_hr(\n    ppg, # PPG signal data with shape (n_samples, n_channels)\n    ppg_sampling_rate, # Sampling frequency of the PPG signal in Hz\n    acc=acc, # Accelerometer signal data with shape (n_samples, n_channels). BeliefPPG to function without accelerometer signal data, but its accuracy may be reduced.\n    acc_freq=acc_sampling_rate, # Sampling frequency of the accelerometer signal in Hz\n)\n```\n\nThe `infer_hr_uncertainty` function from the `beliefppg` package returns the estimated heart rate, uncertainty estimates about the heart rate values, and the bounds [start_ts, end_ts] of the corresponding windows used for heart rate inference in seconds.\nAdditionally, users can choose between belief propagation and Viterbi decoding, specify the uncertainty measure, and decide whether to disable the time-domain backbone of the network architecture. Detailed explanations of these features can be found in our [paper](https://static.siplab.org/papers/uai2023-beliefppg.pdf) and [supplementary material](https://static.siplab.org/papers/uai2023-beliefppg-supplementary.pdf).\n```python\nfrom beliefppg import infer_hr_uncertainty\n\nppg_sampling_rate = 128  # Hz (sampling rate of ppg sensor)\nacc_sampling_rate = 128 # Hz (sampling rate of accelerometer)\n\n# Load data item containing the PPG, HR, and IMU signals --- challenging custom dataset\ndata = np.load('Data/example.npy', allow_pickle=True).item()\n\nppg = data['PPG head'].reshape((-1,1)) # reshape ppg to (n_samples, n_channels)\nIMU_X = data['IMU X head']\nIMU_Y = data['IMU Y head']\nIMU_Z = data['IMU Z head']\nacc = np.stack([IMU_X,IMU_X, IMU_Z], axis=-1)\n\nhr, uncertainty, time_intervals = infer_hr_uncertainty(\n    ppg, # PPG signal data with shape (n_samples, n_channels)\n    ppg_sampling_rate, # Sampling frequency of the PPG signal in Hz\n    acc=acc, # Accelerometer signal data with shape (n_samples, n_channels). BeliefPPG to function without accelerometer signal data, but its accuracy may be reduced.\n    acc_freq=acc_sampling_rate, # Sampling frequency of the accelerometer signal in Hz\n    decoding='sumproduct', # Decoding method to use, either \"sumproduct\" or \"viterbi\"\n    use_time_backbone=True, # Whether to use the time-domain backbone or not\n    uncertainty='std' # Measure for predictive uncertainty, either \"entropy\" or \"std\"\n)\n# The function returns predicted heart rates in BPM, uncertainties (entropy or std), and time intervals in seconds.\n```\nFor a complete example demonstrating how to use BeliefPPG for heart rate inference, see the [tutorial notebook](https://github.com/eth-siplab/BeliefPPG/blob/master/tutorial.ipynb).\n\nCitation\n----------\nIf your find our paper or codes useful, please cite our work:\n\n    @InProceedings{uai2023-beliefppg,\n        author={Bieri, Valentin and Streli, Paul and Demirel, Berken Utku and Holz, Christian},\n        title = {BeliefPPG: Uncertainty-aware Heart Rate Estimation from PPG signals via Belief Propagation},\n        year = {2023},\n        organization={PMLR},\n        booktitle = {Conference on Uncertainty in Artificial Intelligence (UAI)}\n    }\n\nLicense and Acknowledgement\n----------\nThis project is released under the MIT license.\n\n\n\n",
    "bugtrack_url": null,
    "license": null,
    "summary": "Taking multi-channel PPG and Accelerometer signals as input, BeliefPPG predicts the instantaneous heart rate and provides an uncertainty estimate for the prediction.",
    "version": "0.3.1",
    "project_urls": {
        "Homepage": "https://github.com/eth-siplab/BeliefPPG"
    },
    "split_keywords": [
        "ppg",
        " heart rate",
        " signal processing",
        " uncertainty estimation",
        " biomedical signals"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "49b9797e61624a2759a203a85bfcae646a736986525f966f3c7311f1bea6467c",
                "md5": "989c8d85ab3d5b41c916e41451015d7b",
                "sha256": "bff58de1538f476632063afc627fb1de4fd6937ad3225e2cf79ebb1f6b9cb615"
            },
            "downloads": -1,
            "filename": "beliefppg-0.3.1-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "989c8d85ab3d5b41c916e41451015d7b",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.9",
            "size": 801067,
            "upload_time": "2024-08-28T15:07:11",
            "upload_time_iso_8601": "2024-08-28T15:07:11.073261Z",
            "url": "https://files.pythonhosted.org/packages/49/b9/797e61624a2759a203a85bfcae646a736986525f966f3c7311f1bea6467c/beliefppg-0.3.1-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "3c7f3387f20d4f2aae6087bb8df9d8b1432604c19839e31d4c9f762541d93808",
                "md5": "ec4ba213f8c3a52354e3a2ecf6d667bd",
                "sha256": "673b6a20540e9751596b9473a3b2852a4b2ca8554bc31bc38737cff90f49baab"
            },
            "downloads": -1,
            "filename": "beliefppg-0.3.1.tar.gz",
            "has_sig": false,
            "md5_digest": "ec4ba213f8c3a52354e3a2ecf6d667bd",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.9",
            "size": 800039,
            "upload_time": "2024-08-28T15:07:13",
            "upload_time_iso_8601": "2024-08-28T15:07:13.050432Z",
            "url": "https://files.pythonhosted.org/packages/3c/7f/3387f20d4f2aae6087bb8df9d8b1432604c19839e31d4c9f762541d93808/beliefppg-0.3.1.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-08-28 15:07:13",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "eth-siplab",
    "github_project": "BeliefPPG",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": false,
    "requirements": [],
    "lcname": "beliefppg"
}
        
Elapsed time: 0.52898s