Update to use 24 and 8 hours worth of sensitivity
This commit is contained in:
parent
1b4d06101d
commit
6c70fd3a06
1 changed files with 117 additions and 76 deletions
|
@ -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;
|
||||||
|
|
Loading…
Reference in a new issue