Update to use 24 and 8 hours worth of sensitivity

This commit is contained in:
Tim Gunn 2020-01-03 13:12:05 +13:00
parent 1b4d06101d
commit 6c70fd3a06

View file

@ -79,8 +79,17 @@ public class SensitivityOref1Plugin extends AbstractSensitivityPlugin {
List<CareportalEvent> siteChanges = MainApp.getDbHelper().getCareportalEventsFromTime(fromTime, CareportalEvent.SITECHANGE, true); List<CareportalEvent> siteChanges = MainApp.getDbHelper().getCareportalEventsFromTime(fromTime, CareportalEvent.SITECHANGE, true);
List<ProfileSwitch> profileSwitches = MainApp.getDbHelper().getProfileSwitchEventsFromTime(fromTime, true); List<ProfileSwitch> profileSwitches = MainApp.getDbHelper().getProfileSwitchEventsFromTime(fromTime, true);
List<Double> deviationsArray = new ArrayList<>(); //[0] = 8 hour
String pastSensitivity = ""; //[1] = 24 hour
//Deviationshour has DeviationsArray
List<ArrayList> deviationshour = Arrays.asList(new ArrayList(),new ArrayList());
List<String> pastSensitivityArray = Arrays.asList("","");
List<String> sensResultArray = Arrays.asList("","");
List<Double> ratioArray = Arrays.asList(0d,0d);
List<String> ratioLimitArray = Arrays.asList("","");
List<Double> hoursDetection = Arrays.asList(8d,24d);
int index = 0; int index = 0;
while (index < autosensDataTable.size()) { while (index < autosensDataTable.size()) {
AutosensData autosensData = autosensDataTable.valueAt(index); AutosensData autosensData = autosensDataTable.valueAt(index);
@ -94,105 +103,137 @@ public class SensitivityOref1Plugin extends AbstractSensitivityPlugin {
index++; index++;
continue; continue;
} }
int hoursegment = 0;
//hoursegment = 0 = 8 hour
//hoursegment = 1 = 24 hour
while (hoursegment < deviationshour.size()){
ArrayList deviationsArray = deviationshour.get(hoursegment);
String pastSensitivity = pastSensitivityArray.get(hoursegment);
// reset deviations after site change // reset deviations after site change
if (CareportalEvent.isEvent5minBack(siteChanges, autosensData.time)) { if (CareportalEvent.isEvent5minBack(siteChanges, autosensData.time)) {
deviationsArray.clear(); deviationsArray.clear();
pastSensitivity += "(SITECHANGE)"; pastSensitivity += "(SITECHANGE)";
} }
// reset deviations after profile switch // reset deviations after profile switch
if (ProfileSwitch.isEvent5minBack(profileSwitches, autosensData.time, true)) { if (ProfileSwitch.isEvent5minBack(profileSwitches, autosensData.time, true)) {
deviationsArray.clear(); deviationsArray.clear();
pastSensitivity += "(PROFILESWITCH)"; pastSensitivity += "(PROFILESWITCH)";
} }
double deviation = autosensData.deviation; double deviation = autosensData.deviation;
//set positive deviations to zero if bg < 80 //set positive deviations to zero if bg < 80
if (autosensData.bg < 80 && deviation > 0) if (autosensData.bg < 80 && deviation > 0)
deviation = 0; deviation = 0;
if (autosensData.validDeviation) if (autosensData.validDeviation)
deviationsArray.add(deviation); if (autosensData.time > toTime - hoursDetection.get(hoursegment) * 60 * 60 * 1000L)
deviationsArray.add(deviation);
for (int i = 0; i < autosensData.extraDeviation.size(); i++) if (hoursegment == 0) {
deviationsArray.add(autosensData.extraDeviation.get(i)); for (int i = 0; i < autosensData.extraDeviation.size(); i++)
if (deviationsArray.size() > 96) deviationsArray.add(autosensData.extraDeviation.get(i));
deviationsArray.remove(0); }
if (deviationsArray.size() > hoursDetection.get(hoursegment) * 60 / 5){
deviationsArray.remove(0);
}
pastSensitivity += autosensData.pastSensitivity; pastSensitivity += autosensData.pastSensitivity;
int secondsFromMidnight = Profile.secondsFromMidnight(autosensData.time); int secondsFromMidnight = Profile.secondsFromMidnight(autosensData.time);
if (secondsFromMidnight % 3600 < 2.5 * 60 || secondsFromMidnight % 3600 > 57.5 * 60) {
pastSensitivity += "(" + Math.round(secondsFromMidnight / 3600d) + ")"; if (secondsFromMidnight % 3600 < 2.5 * 60 || secondsFromMidnight % 3600 > 57.5 * 60) {
} pastSensitivity += "(" + Math.round(secondsFromMidnight / 3600d) + ")";
index++; }
//Update the data back to the parent
deviationshour.set(hoursegment,deviationsArray);
pastSensitivityArray.set(hoursegment,pastSensitivity);
hoursegment++;
}
index++;
} }
// when we have less than 8h worth of deviation data, add up to 90m of zero deviations // when we have less than 8h worth of deviation data, add up to 90m of zero deviations
// this dampens any large sensitivity changes detected based on too little data, without ignoring them completely // this dampens any large sensitivity changes detected based on too little data, without ignoring them completely
// only apply for 8 hours of devations
ArrayList dev8h = deviationshour.get(0);
if (L.isEnabled(L.AUTOSENS)) if (L.isEnabled(L.AUTOSENS))
log.debug("Using most recent " + deviationsArray.size() + " deviations"); log.debug("Using most recent " + dev8h.size() + " deviations");
if (deviationsArray.size() < 96) { if (dev8h.size() < 96) {
int pad = (int) Math.round((1 - (double) deviationsArray.size() / 96) * 18); int pad = (int) Math.round((1 - (double) dev8h.size() / 96) * 18);
if (L.isEnabled(L.AUTOSENS)) if (L.isEnabled(L.AUTOSENS))
log.debug("Adding " + pad + " more zero deviations"); log.debug("Adding " + pad + " more zero deviations");
for (int d = 0; d < pad; d++) { for (int d = 0; d < pad; d++) { ;
//process.stderr.write("."); dev8h.add(0d);
deviationsArray.add(0d);
} }
} }
//Update the data back to the parent
deviationshour.set(0,dev8h);
Double[] deviations = new Double[deviationsArray.size()]; int hourused = 0;
deviations = deviationsArray.toArray(deviations); while (hourused < deviationshour.size()){
ArrayList deviationsArray = deviationshour.get(hourused);
double sens = profile.getIsfMgdl(); String pastSensitivity = pastSensitivityArray.get(hourused);
String sensResult = "(8 hours) ";
double ratio = 1; String senstime = sensResult;
String ratioLimit = ""; if (hourused == 1){
String sensResult = ""; senstime = "(24 hours) ";
sensResult = senstime;
if (L.isEnabled(L.AUTOSENS))
log.debug("Records: " + index + " " + pastSensitivity);
Arrays.sort(deviations);
/* Not used in calculation
for (double i = 0.9; i > 0.1; i = i - 0.01) {
if (IobCobCalculatorPlugin.percentile(deviations, (i + 0.01)) >= 0 && IobCobCalculatorPlugin.percentile(deviations, i) < 0) {
if (L.isEnabled(L.AUTOSENS))
log.debug(Math.round(100 * i) + "% of non-meal deviations negative (>50% = sensitivity)");
} }
if (IobCobCalculatorPlugin.percentile(deviations, (i + 0.01)) > 0 && IobCobCalculatorPlugin.percentile(deviations, i) <= 0) { String ratioLimit = "";
if (L.isEnabled(L.AUTOSENS))
log.debug(Math.round(100 * i) + "% of non-meal deviations positive (>50% = resistance)"); Double[] deviations = new Double[deviationsArray.size()];
deviations = (Double[]) deviationsArray.toArray(deviations);
double sens = profile.getIsf();
if (L.isEnabled(L.AUTOSENS))
log.debug(senstime + "Records: " + index + " " + pastSensitivity);
Arrays.sort(deviations);
double pSensitive = IobCobCalculatorPlugin.percentile(deviations, 0.50);
double pResistant = IobCobCalculatorPlugin.percentile(deviations, 0.50);
double basalOff = 0;
if (pSensitive < 0) { // sensitive
basalOff = pSensitive * (60 / 5) / Profile.toMgdl(sens, profile.getUnits());
sensResult+= "Excess insulin sensitivity detected";
} else if (pResistant > 0) { // resistant
basalOff = pResistant * (60 / 5) / Profile.toMgdl(sens, profile.getUnits());
sensResult+= "Excess insulin resistance detected";
} else {
sensResult+= "Sensitivity normal";
} }
}
*/
double pSensitive = IobCobCalculatorPlugin.percentile(deviations, 0.50);
double pResistant = IobCobCalculatorPlugin.percentile(deviations, 0.50);
double basalOff = 0; if (L.isEnabled(L.AUTOSENS))
log.debug(sensResult);
if (pSensitive < 0) { // sensitive double ratio = 1 + (basalOff / profile.getMaxDailyBasal());
basalOff = pSensitive * (60 / 5.0) / sens;
sensResult = "Excess insulin sensitivity detected"; //Update the data back to the parent
} else if (pResistant > 0) { // resistant sensResultArray.set(hourused,sensResult);
basalOff = pResistant * (60 / 5.0) / sens; ratioArray.set(hourused,ratio);
sensResult = "Excess insulin resistance detected"; ratioLimitArray.set(hourused,ratioLimit);
} else { hourused++;
sensResult = "Sensitivity normal";
} }
if (L.isEnabled(L.AUTOSENS)) int key = 1;
log.debug(sensResult); String comparison = " 8 h ratio " +ratioArray.get(0)+" vs 24h ratio "+ratioArray.get(1);
//use 24 hour ratio by default
ratio = 1 + (basalOff / profile.getMaxDailyBasal()); //if the 8 hour ratio is less than the 24 hour ratio, the 8 hour ratio is used
if(ratioArray.get(0) < ratioArray.get(1)){
AutosensResult output = fillResult(ratio, current.cob, pastSensitivity, ratioLimit, key = 0;
sensResult, deviationsArray.size()); }
String message = hoursDetection.get(key)+" of sensitivity used";
AutosensResult output = fillResult(ratioArray.get(key), current.cob, pastSensitivityArray.get(key), ratioLimitArray.get(key),
sensResultArray.get(key)+comparison, deviationshour.get(key).size());
if (L.isEnabled(L.AUTOSENS)) if (L.isEnabled(L.AUTOSENS))
log.debug("Sensitivity to: {} ratio: {} mealCOB: {}", log.debug(message+" Sensitivity to: {} ratio: {} mealCOB: {}",
new Date(toTime).toLocaleString(), output.ratio, current.cob); new Date(toTime).toLocaleString(), output.ratio, current.cob);
return output; return output;