From 457aa2277d73614e8148ae4d8e8f353de75f4b34 Mon Sep 17 00:00:00 2001 From: Yihui Cai Date: Wed, 23 Aug 2023 17:55:39 +0800 Subject: [PATCH] Parameterize window length --- simglucose/analysis/report.py | 16 ++++++++-------- tests/test_report.py | 3 +-- 2 files changed, 9 insertions(+), 10 deletions(-) diff --git a/simglucose/analysis/report.py b/simglucose/analysis/report.py index ed8251d4..d38d2778 100644 --- a/simglucose/analysis/report.py +++ b/simglucose/analysis/report.py @@ -92,10 +92,11 @@ def percent_stats(BG, ax=None): return p_stats, fig, ax -def risk_index_trace(df_BG, sample_rate, visualize=False): - chunk_BG = [df_BG.iloc[i:i + sample_rate, :] for i in range(0, len(df_BG), sample_rate)] +def risk_index_trace(df_BG, sample_time=3, window_length=60, visualize=False): + step_size = int(window_length / sample_time) # window size set to 1 hour for calculating Risk Index + chunk_BG = [df_BG.iloc[i:i + step_size, :] for i in range(0, len(df_BG), step_size)] - if len(chunk_BG[-1]) != sample_rate: # Remove the last chunk which is not full + if len(chunk_BG[-1]) != step_size: # Remove the last chunk which is not full chunk_BG.pop() fBG = [ @@ -250,13 +251,12 @@ def CVGA(BG_list, label=None): def report(df, cgm_sensor=None, save_path=None): BG = df.unstack(level=0).BG - sample_rate = 20 # Use 20 as default sample rate in one hour - if cgm_sensor is not None: - sample_rate = int(60 / cgm_sensor.sample_time) - fig_ensemble, ax1, ax2, ax3 = ensemblePlot(df) pstats, fig_percent, ax4 = percent_stats(BG) - ri_per_hour, ri_mean, fig_ri, ax5 = risk_index_trace(BG, sample_rate, visualize=False) + if cgm_sensor is not None: + ri_per_hour, ri_mean, fig_ri, ax5 = risk_index_trace(BG, sample_time=cgm_sensor.sample_time, visualize=False) + else: + ri_per_hour, ri_mean, fig_ri, ax5 = risk_index_trace(BG, visualize=False) zone_stats, fig_cvga, ax6 = CVGA(BG, label='') axes = [ax1, ax2, ax3, ax4, ax5, ax6] figs = [fig_ensemble, fig_percent, fig_ri, fig_cvga] diff --git a/tests/test_report.py b/tests/test_report.py index 64792516..9e12c8d3 100644 --- a/tests/test_report.py +++ b/tests/test_report.py @@ -18,8 +18,7 @@ def setUp(self): def test_risk_index_trace(self): BG = self.df.unstack(level=0).BG sample_time = CGMSensor.withName("Dexcom").sample_time - sample_rate = int(60 / sample_time) - ri_per_hour, ri_mean, fig, axes = risk_index_trace(BG, sample_rate) + ri_per_hour, ri_mean, fig, axes = risk_index_trace(BG, sample_time=sample_time) LBGI = ri_per_hour.transpose().LBGI HBGI = ri_per_hour.transpose().HBGI