Skip to main content

ReplayBG is a digital twin-based methodology to assess new strategies for type 1 diabetes management.

Project description

ReplayBG

License: GPL v3 GitHub commit

ReplayBG is a digital twin-based methodology to develop and assess new strategies for type 1 diabetes management.

Reference

G. Cappon, M. Vettoretti, G. Sparacino, S. Del Favero, A. Facchinetti, "ReplayBG: a digital twin-based methodology to identify a personalized model from type 1 diabetes data and simulate glucose concentrations to assess alternative therapies", IEEE Transactions on Biomedical Engineering, 2023, DOI: 10.1109/TBME.2023.3286856.

Get started

Installation

ReplayBG can be installed via pypi by simply

pip install py-replay-bg

Requirements

  • Python >= 3.11
  • List of Python packages in requirements.txt

Preparation: imports, setup, and data loading

First of all import the core modules:

import os
import numpy as np
import pandas as pd

from multiprocessing import freeze_support

Here, os will be used to manage the filesystem, numpy and pandas to manipulate and manage the data to be used, and multiprocessing.freeze_support to enable multiprocessing functionalities and run the twinning procedure in a faster, parallelized way.

Then, we will import the necessary ReplayBG modules:

from py_replay_bg.py_replay_bg import ReplayBG
from py_replay_bg.visualizer import Visualizer
from py_replay_bg.analyzer import Analyzer

Here, ReplayBG is the core ReplayBG object (more information in the The ReplayBG Object page), while Analyzer and Visualizer are utility objects that will be used to respectively analyze and visualize the results that we will produce with ReplayBG (more information in the (Visualizing Replay Results and Analyzing Replay Results pages).

Next steps consist of setting up some variables that will be used by ReplayBG environment. First of all, we will run the twinning procedure in a parallelized way so let's start with:

if __name__ == '__main__':
    freeze_support()

Then, we will set the verbosity of ReplayBG:

    verbose = True
    plot_mode = False

Then, we need to decide what blueprint to use for twinning the data at hand.

    blueprint = 'multi-meal'
    save_folder = os.path.join(os.path.abspath(''),'..','..','..')
    parallelize = True

For more information on how to choose a blueprint, please refer to the Choosing Blueprint page.

Now, let's load some data to play with. In this example, we will use the data stored in example/data/data_day_1.csv which contains a day of data of a patient with T1D:

data = pd.read_csv(os.path.join(os.path.abspath(''), '..', 'data', 'data_day_1.csv'))
data.t = pd.to_datetime(data['t'])

::: warning Be careful, data in PyReplayBG must be provided in a .csv. file that must follow some strict requirements. For more information see the Data Requirements page. :::

Let's also load the patient information (i.e., body weight and basal insulin u2ss) stored in the example/data/patient_info.csv file.

patient_info = pd.read_csv(os.path.join(os.path.abspath(''), '..', 'data', 'patient_info.csv'))
p = np.where(patient_info['patient'] == 1)[0][0]
# Set bw and u2ss
bw = float(patient_info.bw.values[p])
u2ss = float(patient_info.u2ss.values[p])

Finally, instantiate a ReplayBG object:

rbg = ReplayBG(blueprint=blueprint, save_folder=save_folder,
               yts=5, exercise=False,
               seed=1,
               verbose=verbose, plot_mode=plot_mode)

Step 1: Creation of the digital twin

To create the digital twin, i.e., run the twinning procedure, using the MCMC method, use the rbg.twin() method:

rbg.twin(data=data, bw=bw, save_name='data_day_1',
         twinning_method='mcmc',
         parallelize=parallelize,
         n_steps=5000,
         u2ss=u2ss)

For more information on the twinning procedure see the Twinning Procedure page.

Step 2: Run replay simulations

Now that we have the digital twin created, it's time to replay using the rbg.replay() method. For more details see the Replaying page.

The possibilities are several, but for now let's just see what happens if we run a replay using the same input data used for twinning:

replay_results = rbg.replay(data=data, bw=bw, save_name='data_day_1',
                            twinning_method='mcmc',
                            save_workspace=True,
                            save_suffix='_step_2a')

It is possible to visualize the results of the simulation using:

Visualizer.plot_replay_results(replay_results, data=data)

and analyzing the results using:

analysis = Analyzer.analyze_replay_results(replay_results, data=data)
print('Fit MARD: %.2f %%' % analysis['median']['twin']['mard'])
print('Mean glucose: %.2f mg/dl' % analysis['median']['glucose']['variability']['mean_glucose'])

As a second example, we can simulate what happens with different inputs, for example when we reduce insulin by 30%. To do that run:

data.bolus = data.bolus * .7
replay_results = rbg.replay(data=data, bw=bw, save_name=save_name,
                            twinning_method='mcmc',
                            save_workspace=True,
                            save_suffix='_step_2b')

# Visualize results
Visualizer.plot_replay_results(replay_results)
# Analyze results
analysis = Analyzer.analyze_replay_results(replay_results)

# Print, for example, the average glucose
print('Mean glucose: %.2f mg/dl' % analysis['median']['glucose']['variability']['mean_glucose'])

A .py file with the full code of the get started example can be found in example/code/get_started.py.

Documentation

Full documentation at https://gcappon.github.io/py_replay_bg/.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

py_replay_bg-1.3.3.tar.gz (68.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

py_replay_bg-1.3.3-py3-none-any.whl (103.4 kB view details)

Uploaded Python 3

File details

Details for the file py_replay_bg-1.3.3.tar.gz.

File metadata

  • Download URL: py_replay_bg-1.3.3.tar.gz
  • Upload date:
  • Size: 68.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.11

File hashes

Hashes for py_replay_bg-1.3.3.tar.gz
Algorithm Hash digest
SHA256 719ff1278a4817c176ca9fe9daddc2e98cdecc42ff3b73deede146b8f3dc3837
MD5 dd4c20301466e96c20a4d7fddbca7a73
BLAKE2b-256 56cad89eca49bafcbe1314ae14f044bb53accd968d3cf6d71632afaec17bd71b

See more details on using hashes here.

File details

Details for the file py_replay_bg-1.3.3-py3-none-any.whl.

File metadata

  • Download URL: py_replay_bg-1.3.3-py3-none-any.whl
  • Upload date:
  • Size: 103.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.11

File hashes

Hashes for py_replay_bg-1.3.3-py3-none-any.whl
Algorithm Hash digest
SHA256 390c6748c7c838c65a37c1f878179fe8e685914c06c871744f7fb12eb96545bb
MD5 cab2e808de1611edfdc044e2b3cf37e3
BLAKE2b-256 e47a864bebaa0e66bef2258186544a993f21e11b68093dcd75ea897e202d0578

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page