var freeaps_determineBasal;(()=>{var e={5546:(e,t,a)=>{var r=a(6880);function o(e,t){t||(t=0);var a=Math.pow(10,t);return Math.round(e*a)/a}function n(e,t){return"mmol/L"===t.out_units?o(.0555*e,1):Math.round(e)}e.exports=function(e,t,a,i,s,l,m,u,d,c,g,h,p,f,v){var B=0,b="",M="",_="",y="",x="",D=0,w=(f=0,0),S=0,T=0,U=0;const C=v.weightedAverage,G=i.weightPercentage,O=v.average_total_data;function A(e,t){var a=e.getTime();return new Date(a+36e5*t)}function R(e){var t=i.bolus_increment;.05!=t&&(t=.1);var a=e/t;return a>=1?o(Math.floor(a)*t,5):0}function I(e){function t(e){return e<10&&(e="0"+e),e}return t(e.getHours())+":"+t(e.getMinutes())+":00"}function j(e,t){var a=new Date("1/1/1999 "+e),r=new Date("1/1/1999 "+t);return(a.getTime()-r.getTime())/36e5}function F(e,t){var a=0,r=t,o=(e-t)/36e5,n=0,i=o,s=0;do{if(o>0){var l=I(r),m=p[0].rate;for(let e=0;e
=(s=j(p[e+1].start,p[e].start))?n=s:o=(s=24-j(p[e].start,t))?n=s:ou)if(e+1=(s=j(d,l))?n=s:o=(s=j("23:59:59",l))?n=s:o0&&o21)T=F(P,(q=24-B,k=P.getTime(),new Date(k-36e5*q))),y="24 hours of data is required for an accurate tdd calculation. Currently only "+B.toPrecision(3)+" hours of pump history data are available. Using your pump scheduled basals to fill in the missing hours. Scheduled basals added: "+T.toPrecision(5)+" U. ";else B<21?(K=!1,enableDynamicCR=!1):y=""}else console.log("Pumphistory is empty!"),K=!1,enableDynamicCR=!1;var q,k;for(let e=0;e0){D=e,U=g[e].rate;var E=g[e-1]["duration (min)"]/60,L=E,z=new Date(g[e-1].timestamp),N=z;do{if(e--,0==e){N=new Date;break}if("TempBasal"==g[e]._type||"PumpSuspend"==g[e]._type){N=new Date(g[e].timestamp);break}}while(e>0);var Z=(N-z)/36e5;Z0&&(--r,"TempBasal"==g[r]._type)){a=new Date(g[r].timestamp);break}}while(r>0);(a-t)/36e5>0&&(T+=F(a,t))}for(let e=g.length-1;e>0;e--)if("TempBasalDuration"==g[e]._type){let t=g[e]["duration (min)"]/60,a=new Date(g[e].timestamp);var H=a;let r=e;do{if(--r,r>=0&&("TempBasal"==g[r]._type||"PumpSuspend"==g[r]._type)){H=new Date(g[r].timestamp);break}}while(r>0);if(0==e&&"TempBasalDuration"==g[0]._type&&(H=new Date,t=g[e]["duration (min)"]/60),(H-a)/36e5-t>0){T+=F(H,A(a,t))}}var $=f=S+w+T;B>21?(M=". Bolus insulin: "+S.toPrecision(5)+" U",_=". Temporary basal insulin: "+w.toPrecision(5)+" U",b=". Insulin with scheduled basal rate: "+T.toPrecision(5)+" U",x=y+(" TDD past 24h is: "+f.toPrecision(5)+" U")+M+_+b,tddReason=C>0&&O>0?", TDD: "+o(f,1)+" U, Weighted avg: "+o(C,1)+" U, Total data avg: "+o(O,1)+" U":", TDD: "+o(f,2)):tddReason=", TDD: Not enough pumpData (< 21h)";const J=e.glucose;var K=h.useNewFormula;const Q=h.enableDynamicCR,V=Math.min(i.autosens_min,i.autosens_max),X=Math.max(i.autosens_min,i.autosens_max),Y=h.adjustmentFactor,ee=i.min_bg;var te=!1,ae="",re=1,oe="";O>0&&(re=C/O),oe=re>1?"Basal adjustment with a 24 hour to total average (up to 14 days of data) TDD ratio (limited by Autosens max setting). Basal Ratio: "+(re=o(re=Math.min(re,i.autosens_max),2))+". Upper limit = Autosens max ("+i.autosens_max+")":re<1?"Basal adjustment with a 24 hour to to total average (up to 14 days of data) TDD ratio (limited by Autosens min setting). Basal Ratio: "+(re=o(re=Math.max(re,i.autosens_min),2))+". Lower limit = Autosens min ("+i.autosens_min+")":"Basal adjusted with a 24 hour to total average (up to 14 days of data) TDD ratio: "+re,oe=", Basal ratio: "+re,(i.high_temptarget_raises_sensitivity||i.exercise_mode)&&(te=!0),ee>=118&&te&&(K=!1,ae="Dynamic ISF temporarily off due to a high temp target/exercising. Current min target: "+ee);var ne=", Dynamic ratios log: ",ie=", AF: "+Y,se="BG: "+J+" mg/dl ("+(.0555*J).toPrecision(2)+" mmol/l)",le="",me="";const ue=h.curve,de=h.insulinPeakTime,ce=h.useCustomPeakTime;var ge=55,he=65;switch(ue){case"rapid-acting":he=65;break;case"ultra-rapid":he=50}ce?(ge=120-de,console.log("Custom insulinpeakTime set to :"+de+", insulinFactor: "+ge)):(ge=120-he,console.log("insulinFactor set to : "+ge)),$=f,G<1&&C>0&&(f=C,console.log("Using weighted TDD average: "+o(f,2)+" U, instead of past 24 h ("+o($,2)+" U), weight: "+G),me=", Weighted TDD: "+o(f,2)+" U");const pe=h.sigmoid;var fe="";if(K){var ve=i.sens*Y*f*Math.log(J/ge+1)/1800;le=", Logarithmic formula"}var Be="";if(K&&pe){const e=V,t=X-e,a=.0555*(J-i.min_bg);var be=re;Be=", tdd_factor: "+o(be,1);const r=X-1,n=Math.log10(1/r-e/r)/Math.log10(Math.E),s=a*Y*be+n;ve=t/(1+Math.exp(-s))+e,le=", Sigmoid function"}var Me=i.carb_ratio,_e="",ye="";if(K&&f>0){if(_e=", Dynamic ISF/CR: On/",ve>X?(ae=", Dynamic ISF limited by autosens_max setting: "+X+" ("+o(ve,2)+"), ",ye=", Autosens/Dynamic Limit: "+X+" ("+o(ve,2)+")",ve=X):ve1&&(xe=(ve-1)/2+1);var De=" CR: "+(Me=o(Me/xe,2))+" g/U";i.carb_ratio=Me}else De=" CR: "+Me+" g/U",_e+="Off";const e=i.sens/ve;fe=". Using Sigmoid function, the autosens ratio has been adjusted with sigmoid factor to: "+o(s.ratio,2)+". New ISF = "+o(e,2)+" mg/dl ("+o(.0555*e,2)+" (mmol/l). CR adjusted from "+o(Me,2)+" to "+o(i.carb_ratio,2)+" ("+o(.0555*i.carb_ratio,2)+" mmol/l).",ae+=pe?fe:", Dynamic autosens.ratio set to "+o(ve,2)+" with ISF: "+e.toPrecision(3)+" mg/dl/U ("+(.0555*e).toPrecision(3)+" mmol/l/U)",s.ratio=ve,x+=ne+se+ie+le+ae+_e+De+me}else x+=ne+"Dynamic Settings disabled";console.log(x),K||Q?K&&i.tddAdjBasal?tddReason+=_e+le+ye+ie+oe:K&&!i.tddAdjBasal&&(tddReason+=_e+le+ye+ie):tddReason+="";var we={},Se=new Date;if(c&&(Se=c),void 0===i||void 0===i.current_basal)return we.error="Error: could not get current basal rate",we;var Te=r(i.current_basal,i),Ue=Te,Ce=new Date;c&&(Ce=c);var Ge,Oe=new Date(e.date),Ae=o((Ce-Oe)/60/1e3,1),Re=e.glucose,Ie=e.noise;Ge=e.delta>-.5?"+"+o(e.delta,0):o(e.delta,0);var je=Math.min(e.delta,e.short_avgdelta),Fe=Math.min(e.short_avgdelta,e.long_avgdelta),Pe=Math.max(e.delta,e.short_avgdelta,e.long_avgdelta);(Re<=10||38===Re||Ie>=3)&&(we.reason="CGM is calibrating, in ??? state, or noise is high");if(Re>60&&0==e.delta&&e.short_avgdelta>-1&&e.short_avgdelta<1&&e.long_avgdelta>-1&&e.long_avgdelta<1&&("fakecgm"==e.device?(console.error("CGM data is unchanged ("+n(Re,i)+"+"+n(e.delta,i)+") for 5m w/ "+n(e.short_avgdelta,i)+" mg/dL ~15m change & "+n(e.long_avgdelta,2)+" mg/dL ~45m change"),console.error("Simulator mode detected ("+e.device+"): continuing anyway")):!0),Ae>12||Ae<-5?we.reason="If current system time "+Ce+" is correct, then BG data is too old. The last BG data was read "+Ae+"m ago at "+Oe:0===e.short_avgdelta&&0===e.long_avgdelta&&(e.last_cal&&e.last_cal<3?we.reason="CGM was just calibrated":we.reason="CGM data is unchanged ("+n(Re,i)+"+"+n(e.delta,i)+") for 5m w/ "+n(e.short_avgdelta,i)+" mg/dL ~15m change & "+n(e.long_avgdelta,i)+" mg/dL ~45m change"),Re<=10||38===Re||Ie>=3||Ae>12||Ae<-5||0===e.short_avgdelta&&0===e.long_avgdelta)return t.rate>=Ue?(we.reason+=". Canceling high temp basal of "+t.rate,we.deliverAt=Se,we.temp="absolute",we.duration=0,we.rate=0,we):0===t.rate&&t.duration>30?(we.reason+=". Shortening "+t.duration+"m long zero temp to 30m. ",we.deliverAt=Se,we.temp="absolute",we.duration=30,we.rate=0,we):(we.reason+=". Temp "+t.rate+" <= current basal "+Ue+"U/hr; doing nothing. ",we);var We,qe,ke,Ee,Le=i.max_iob;if(void 0!==i.min_bg&&(qe=i.min_bg),void 0!==i.max_bg&&(ke=i.max_bg),void 0!==i.enableSMB_high_bg_target&&(Ee=i.enableSMB_high_bg_target),void 0===i.min_bg||void 0===i.max_bg)return we.error="Error: could not determine target_bg. ",we;We=(i.min_bg+i.max_bg)/2;var ze=i.exercise_mode||i.high_temptarget_raises_sensitivity,Ne=100,Ze=160;if(i.half_basal_exercise_target&&(Ze=i.half_basal_exercise_target),ze&&i.temptargetSet&&We>Ne||i.low_temptarget_lowers_sensitivity&&i.temptargetSet&&We=We&&sensitivityRatio1)){qe=o((qe-60)/s.ratio)+60,ke=o((ke-60)/s.ratio)+60;var $e=o((We-60)/s.ratio)+60;We===($e=Math.max(80,$e))?process.stderr.write("target_bg unchanged: "+$e+"; "):process.stderr.write("target_bg from "+We+" to "+$e+"; "),We=$e}var Je=200,Ke=200,Qe=200;if(e.noise>=2){var Ve=Math.max(1.1,i.noisyCGMTargetMultiplier);Math.min(250,i.maxRaw);Je=o(Math.min(200,qe*Ve)),Ke=o(Math.min(200,We*Ve)),Qe=o(Math.min(200,ke*Ve)),process.stderr.write("Raising target_bg for noisy / raw CGM data, from "+We+" to "+Ke+"; "),qe=Je,We=Ke,ke=Qe}var Xe=qe-.5*(qe-40),Ye=i.threshold_setting;Ye>Xe&&Ye<=120&&Ye>=65?(console.error("Threshold changed in settings from "+n(Xe,i)+" to "+n(Ye,i)+". "),Xe=Ye):console.error("Current threshold: "+n(Xe,i));var et="",tt=o(i.sens,1),at=i.sens;if(void 0!==s&&s&&((at=o(at=i.sens/sensitivityRatio,1))!==tt?process.stderr.write("ISF from "+n(tt,i)+" to "+n(at,i)):process.stderr.write("ISF unchanged: "+n(at,i)),et+="Autosens ratio: "+o(sensitivityRatio,2)+", ISF: "+n(tt,i)+"→"+n(at,i)),console.error("CR:"+i.carb_ratio),void 0===a)return we.error="Error: iob_data undefined. ",we;var rt,ot=a;if(a.length,a.length>1&&$>0&&(a=ot[0]),void 0===a.activity||void 0===a.iob)return we.error="Error: iob_data missing some property. ",we;var nt=((rt=void 0!==a.lastTemp?o((new Date(Ce).getTime()-a.lastTemp.date)/6e4):0)+t.duration)%30;if(console.error("currenttemp:"+t.rate+" lastTempAge:"+rt+"m, tempModulus:"+nt+"m"),we.temp="absolute",we.deliverAt=Se,u&&t&&a.lastTemp&&t.rate!==a.lastTemp.rate&&rt>10&&t.duration)return we.reason="Warning: currenttemp rate "+t.rate+" != lastTemp rate "+a.lastTemp.rate+" from pumphistory; canceling temp",m.setTempBasal(0,0,i,we,t);if(t&&a.lastTemp&&t.duration>0){var it=rt-a.lastTemp.duration;if(it>5&&rt>10)return we.reason="Warning: currenttemp running but lastTemp from pumphistory ended "+it+"m ago; canceling temp",m.setTempBasal(0,0,i,we,t)}var st=o(-a.activity*at*5,2),lt=o(6*(je-st));lt<0&&(lt=o(6*(Fe-st)))<0&&(lt=o(6*(e.long_avgdelta-st)));var mt=Re,ut=(mt=a.iob>0?o(Re-a.iob*at):o(Re-a.iob*Math.min(at,i.sens)))+lt;if(void 0===ut||isNaN(ut))return we.error="Error: could not calculate eventualBG. Sensitivity: "+at+" Deviation: "+lt,we;var dt=function(e,t,a){return o(a+(e-t)/24,1)}(We,ut,st);we={temp:"absolute",bg:Re,tick:Ge,eventualBG:ut,insulinReq:0,reservoir:d,deliverAt:Se,sensitivityRatio,TDD:$};var ct=[],gt=[],ht=[],pt=[];ct.push(Re),gt.push(Re),pt.push(Re),ht.push(Re);var ft=function(e,t,a,r,o,i){return t?!e.allowSMB_with_high_temptarget&&e.temptargetSet&&o>100?(console.error("SMB disabled due to high temptarget of "+o),!1):!0===a.bwFound&&!1===e.A52_risk_enable?(console.error("SMB disabled due to Bolus Wizard activity in the last 6 hours."),!1):!0===e.enableSMB_always?(a.bwFound?console.error("Warning: SMB enabled within 6h of using Bolus Wizard: be sure to easy bolus 30s before using Bolus Wizard"):console.error("SMB enabled due to enableSMB_always"),!0):!0===e.enableSMB_with_COB&&a.mealCOB?(a.bwCarbs?console.error("Warning: SMB enabled with Bolus Wizard carbs: be sure to easy bolus 30s before using Bolus Wizard"):console.error("SMB enabled for COB of "+a.mealCOB),!0):!0===e.enableSMB_after_carbs&&a.carbs?(a.bwCarbs?console.error("Warning: SMB enabled with Bolus Wizard carbs: be sure to easy bolus 30s before using Bolus Wizard"):console.error("SMB enabled for 6h after carb entry"),!0):!0===e.enableSMB_with_temptarget&&e.temptargetSet&&o<100?(a.bwFound?console.error("Warning: SMB enabled within 6h of using Bolus Wizard: be sure to easy bolus 30s before using Bolus Wizard"):console.error("SMB enabled for temptarget of "+n(o,e)),!0):!0===e.enableSMB_high_bg&&null!==i&&r>=i?(console.error("Checking BG to see if High for SMB enablement."),console.error("Current BG",r," | High BG ",i),a.bwFound?console.error("Warning: High BG SMB enabled within 6h of using Bolus Wizard: be sure to easy bolus 30s before using Bolus Wizard"):console.error("High BG detected. Enabling SMB."),!0):(console.error("SMB disabled (no enableSMB preferences active or no condition satisfied)"),!1):(console.error("SMB disabled (!microBolusAllowed)"),!1)}(i,u,l,Re,We,Ee),vt=i.enableUAM,Bt=0,bt=0;Bt=o(je-st,1);var Mt=o(je-st,1);csf=at/i.carb_ratio,console.error("profile.sens:"+n(i.sens,i)+", sens:"+n(at,i)+", CSF:"+o(csf,1));var _t=o(30*csf*5/60,1);Bt>_t&&(console.error("Limiting carb impact from "+Bt+" to "+_t+"mg/dL/5m (30g/h)"),Bt=_t);var yt=3;sensitivityRatio&&(yt/=sensitivityRatio);var xt=yt;if(l.carbs){yt=Math.max(yt,l.mealCOB/20);var Dt=o((new Date(Ce).getTime()-l.lastCarbTime)/6e4),wt=(l.carbs-l.mealCOB)/l.carbs;xt=o(xt=yt+1.5*Dt/60,1),console.error("Last carbs "+Dt+" minutes ago; remainingCATime:"+xt+"hours; "+o(100*wt,1)+"% carbs absorbed")}var St=Math.max(0,Bt/5*60*xt/2)/csf,Tt=90,Ut=1;i.remainingCarbsCap&&(Tt=Math.min(90,i.remainingCarbsCap)),i.remainingCarbsFraction&&(Ut=Math.min(1,i.remainingCarbsFraction));var Ct=1-Ut,Gt=Math.max(0,l.mealCOB-St-l.carbs*Ct),Ot=(Gt=Math.min(Tt,Gt))*csf*5/60/(xt/2),At=o(l.slopeFromMaxDeviation,2),Rt=o(l.slopeFromMinDeviation,2),It=Math.min(At,-Rt/3);bt=0===Bt?0:Math.min(60*xt/5/2,Math.max(0,l.mealCOB*csf/Bt)),console.error("Carb Impact:"+Bt+"mg/dL per 5m; CI Duration:"+o(5*bt/60*2,1)+"hours; remaining CI ("+xt/2+"h peak):"+o(Ot,1)+"mg/dL per 5m");var jt,Ft,Pt,Wt,qt,kt=999,Et=999,Lt=999,zt=Re,Nt=999,Zt=999,Ht=999,$t=999,Jt=ut,Kt=Re,Qt=Re,Vt=0,Xt=[],Yt=[];try{ot.forEach((function(e){var t=o(-e.activity*at*5,2),a=o(-e.iobWithZeroTemp.activity*at*5,2),r=mt,n=Bt*(1-Math.min(1,gt.length/12));if(!0===(K&&!pe))Jt=gt[gt.length-1]+o(-e.activity*(1800/(f*Y*Math.log(Math.max(gt[gt.length-1],39)/ge+1)))*5,2)+n,r=pt[pt.length-1]+o(-e.iobWithZeroTemp.activity*(1800/(f*Y*Math.log(Math.max(pt[pt.length-1],39)/ge+1)))*5,2),console.log("Dynamic ISF (Logarithmic Formula) )adjusted predictions for IOB and ZT: IOBpredBG: "+o(Jt,2)+" , ZTpredBG: "+o(r,2));else Jt=gt[gt.length-1]+t+n,r=pt[pt.length-1]+a;var i=Math.max(0,Math.max(0,Bt)*(1-ct.length/Math.max(2*bt,1))),s=Math.min(ct.length,12*xt-ct.length),l=Math.max(0,s/(xt/2*12)*Ot);i+l,Xt.push(o(l,0)),Yt.push(o(i,0)),COBpredBG=ct[ct.length-1]+t+Math.min(0,n)+i+l;var m=Math.max(0,Mt+ht.length*It),u=Math.max(0,Mt*(1-ht.length/Math.max(36,1))),d=Math.min(m,u);if(d>0&&(Vt=o(5*(ht.length+1)/60,1)),!0===(K&&!pe))UAMpredBG=ht[ht.length-1]+o(-e.activity*(1800/(f*Y*Math.log(Math.max(ht[ht.length-1],39)/ge+1)))*5,2)+Math.min(0,n)+d,console.log("Dynamic ISF (Logarithmic Formula) adjusted prediction for UAM: UAMpredBG: "+o(UAMpredBG,2));else UAMpredBG=ht[ht.length-1]+t+Math.min(0,n)+d;gt.length<48&>.push(Jt),ct.length<48&&ct.push(COBpredBG),ht.length<48&&ht.push(UAMpredBG),pt.length<48&&pt.push(r),COBpredBG18&&JtKt&&(Kt=Jt),(bt||Ot>0)&&ct.length>18&&COBpredBG0)&&COBpredBG>Kt&&(Qt=COBpredBG),vt&&ht.length>12&&UAMpredBGKt&&UAMpredBG}))}catch(e){console.error("Problem with iobArray. Optional feature Advanced Meal Assist disabled")}l.mealCOB&&(console.error("predCIs (mg/dL/5m):"+Yt.join(" ")),console.error("remainingCIs: "+Xt.join(" "))),we.predBGs={},gt.forEach((function(e,t,a){a[t]=o(Math.min(401,Math.max(39,e)))}));for(var ea=gt.length-1;ea>12&>[ea-1]===gt[ea];ea--)gt.pop();for(we.predBGs.IOB=gt,Pt=o(gt[gt.length-1]),pt.forEach((function(e,t,a){a[t]=o(Math.min(401,Math.max(39,e)))})),ea=pt.length-1;ea>6&&!(pt[ea-1]>=pt[ea]||pt[ea]<=We);ea--)pt.pop();if(we.predBGs.ZT=pt,o(pt[pt.length-1]),l.mealCOB>0&&(Bt>0||Ot>0)){for(ct.forEach((function(e,t,a){a[t]=o(Math.min(401,Math.max(39,e)))})),ea=ct.length-1;ea>12&&ct[ea-1]===ct[ea];ea--)ct.pop();we.predBGs.COB=ct,Wt=o(ct[ct.length-1]),ut=Math.max(ut,o(ct[ct.length-1]))}if(Bt>0||Ot>0){if(vt){for(ht.forEach((function(e,t,a){a[t]=o(Math.min(401,Math.max(39,e)))})),ea=ht.length-1;ea>12&&ht[ea-1]===ht[ea];ea--)ht.pop();we.predBGs.UAM=ht,qt=o(ht[ht.length-1]),ht[ht.length-1]&&(ut=Math.max(ut,o(ht[ht.length-1])))}we.eventualBG=ut}console.error("UAM Impact:"+Mt+"mg/dL per 5m; UAM Duration:"+Vt+"hours"),kt=Math.max(39,kt),Et=Math.max(39,Et),Lt=Math.max(39,Lt),jt=o(kt);var ta=l.mealCOB/l.carbs;Ft=o(Lt<999&&Et<999?(1-ta)*UAMpredBG+ta*COBpredBG:Et<999?(Jt+COBpredBG)/2:Lt<999?(Jt+UAMpredBG)/2:Jt),$t>Ft&&(Ft=$t),zt=o(zt=bt||Ot>0?vt?ta*Nt+(1-ta)*Zt:Nt:vt?Zt:Ht);var aa=Lt;if($tLt&&(aa=(Lt+$t)/2);if(aa=o(aa),l.carbs)if(!vt&&Et<999)jt=o(Math.max(kt,Et));else if(Et<999){var oa=ta*Et+(1-ta)*aa;jt=o(Math.max(kt,Et,oa))}else jt=vt?aa:zt;else vt&&(jt=o(Math.max(kt,aa)));jt=Math.min(jt,Ft),process.stderr.write("minPredBG: "+jt+" minIOBPredBG: "+kt+" minZTGuardBG: "+$t),Et<999&&process.stderr.write(" minCOBPredBG: "+Et),Lt<999&&process.stderr.write(" minUAMPredBG: "+Lt),console.error(" avgPredBG:"+Ft+" COB/Carbs:"+l.mealCOB+"/"+l.carbs),Qt>Re&&(jt=Math.min(jt,Qt)),we.COB=l.mealCOB,we.IOB=a.iob,we.BGI=n(st,i),we.deviation=n(lt,i),we.ISF=n(at,i),we.CR=o(i.carb_ratio,2),we.target_bg=n(We,i),we.TDD=o($,2),we.reason=et+", COB: "+we.COB+", Dev: "+we.deviation+", BGI: "+we.BGI+", CR: "+we.CR+", Target: "+we.target_bg+", minPredBG "+n(jt,i)+", minGuardBG "+n(zt,i)+", IOBpredBG "+n(Pt,i),Wt>0&&(we.reason+=", COBpredBG "+n(Wt,i)),qt>0&&(we.reason+=", UAMpredBG "+n(qt,i)),we.reason+=tddReason+Be,we.reason+="; ";var na=mt;na<40&&(na=Math.min(zt,na));var ia,sa=Xe-na,la=240,ma=240;if(l.mealCOB>0&&(Bt>0||Ot>0)){for(ea=0;eaia*Re&&(console.error("maxDelta "+n(Pe,i)+" > "+100*ia+"% of BG "+n(Re,i)+" - disabling SMB"),we.reason+="maxDelta "+n(Pe,i)+" > "+100*ia+"% of BG "+n(Re,i)+" - SMB disabled!, ",ft=!1),console.error("BG projected to remain above "+n(qe,i)+" for "+la+"minutes"),(ma<240||la<60)&&console.error("BG projected to remain above "+n(Xe,i)+" for "+ma+"minutes");var ua=ma,da=i.current_basal*at*ua/60,ca=Math.max(0,l.mealCOB-.25*l.carbs),ga=(sa-da)/csf-ca;da=o(da),ga=o(ga),console.error("naive_eventualBG:",mt,"bgUndershoot:",sa,"zeroTempDuration:",ua,"zeroTempEffect:",da,"carbsReq:",ga),"Could not parse clock data"==l.reason?console.error("carbsReq unknown: Could not parse clock data"):ga>=i.carbsReqThreshold&&ma<=45&&(we.carbsReq=ga,we.reason+=ga+" add'l carbs req w/in "+ma+"m; ");var ha=0;if(Re0&&je>dt)we.reason+="IOB "+a.iob+" < "+o(20*-i.current_basal/60,2),we.reason+=" and minDelta "+n(je,i)+" > expectedDelta "+n(dt,i)+"; ";else if(Re=55)return we.reason+="; Canceling temp at "+we.deliverAt.getMinutes()+"m past the hour. ",m.setTempBasal(0,0,i,we,t);var pa=0,fa=Ue;if(utdt&&je>0&&!ga)return mt<40?(we.reason+=", naive_eventualBG < 40. ",m.setTempBasal(0,30,i,we,t)):(e.delta>je?we.reason+=", but Delta "+n(Ge,i)+" > expectedDelta "+n(dt,i):we.reason+=", but Min. Delta "+je.toFixed(2)+" > Exp. Delta "+n(dt,i),t.duration>15&&r(Ue,i)===r(t.rate,i)?(we.reason+=", temp "+t.rate+" ~ req "+Ue+"U/hr. ",we):(we.reason+="; setting current basal of "+Ue+" as temp. ",m.setTempBasal(Ue,30,i,we,t)));pa=o(pa=2*Math.min(0,(ut-We)/at),2);var va=Math.min(0,(mt-We)/at);if(va=o(va,2),je<0&&je>dt)pa=o(pa*(je/dt),2);if(fa=r(fa=Ue+2*pa,i),t.duration*(t.rate-Ue)/605&&fa>=.8*t.rate)return we.reason+=", temp "+t.rate+" ~< req "+fa+"U/hr. ",we;if(fa<=0){if((ha=o(60*((sa=We-mt)/at)/i.current_basal))<0?ha=0:(ha=30*o(ha/30),ha=Math.min(120,Math.max(0,ha))),ha>0)return we.reason+=", setting "+ha+"m zero temp. ",m.setTempBasal(fa,ha,i,we,t)}else we.reason+=", setting "+fa+"U/hr. ";return m.setTempBasal(fa,30,i,we,t)}if(je "+n(qe,i)+" but Delta "+n(Ge,i)+" < Exp. Delta "+n(dt,i):we.reason+="Eventual BG "+n(ut,i)+" > "+n(qe,i)+" but Min. Delta "+je.toFixed(2)+" < Exp. Delta "+n(dt,i),t.duration>15&&r(Ue,i)===r(t.rate,i)?(we.reason+=", temp "+t.rate+" ~ req "+Ue+"U/hr. ",we):(we.reason+="; setting current basal of "+Ue+" as temp. ",m.setTempBasal(Ue,30,i,we,t));if(Math.min(ut,jt)15&&r(Ue,i)===r(t.rate,i)?(we.reason+=", temp "+t.rate+" ~ req "+Ue+"U/hr. ",we):(we.reason+="; setting current basal of "+Ue+" as temp. ",m.setTempBasal(Ue,30,i,we,t));if(ut>=ke&&(we.reason+="Eventual BG "+n(ut,i)+" >= "+n(ke,i)+", "),a.iob>Le)return we.reason+="IOB "+o(a.iob,2)+" > max_iob "+Le,t.duration>15&&r(Ue,i)===r(t.rate,i)?(we.reason+=", temp "+t.rate+" ~ req "+Ue+"U/hr. ",we):(we.reason+="; setting current basal of "+Ue+" as temp. ",m.setTempBasal(Ue,30,i,we,t));(pa=o((Math.min(jt,ut)-We)/at,2))>Le-a.iob?(console.error("SMB limited by maxIOB: "+Le-a.iob+" (. insulinReq: "+pa+" U)"),we.reason+="max_iob "+Le+", ",pa=Le-a.iob):console.error("SMB not limited by maxIOB ( insulinReq: "+pa+" U)."),fa=r(fa=Ue+2*pa,i),pa=o(pa,3),we.insulinReq=pa;var Ba=o((new Date(Ce).getTime()-a.lastBolusTime)/6e4,1);if(u&&ft&&Re>Xe){var ba=o(l.mealCOB/i.carb_ratio,3),Ma=0;void 0===i.maxSMBBasalMinutes?(Ma=o(30*i.current_basal/60,1),console.error("profile.maxSMBBasalMinutes undefined: defaulting to 30m"),pa>Ma&&console.error("SMB limited by maxBolus: "+Ma+" ( "+pa+" U)")):a.iob>ba&&a.iob>0?(console.error("IOB"+a.iob+"> COB"+l.mealCOB+"; mealInsulinReq ="+ba),i.maxUAMSMBBasalMinutes?(console.error("profile.maxUAMSMBBasalMinutes: "+i.maxUAMSMBBasalMinutes+", profile.current_basal: "+i.current_basal),Ma=o(i.current_basal*i.maxUAMSMBBasalMinutes/60,1)):(console.error("profile.maxUAMSMBBasalMinutes undefined: defaulting to 30m"),Ma=o(30*i.current_basal/60,1)),pa>Ma?console.error("SMB limited by maxUAMSMBBasalMinutes [ "+i.maxUAMSMBBasalMinutes+"m ]: "+Ma+"U ( "+pa+"U )"):console.error("SMB is not limited by maxUAMSMBBasalMinutes. ( insulinReq: "+pa+"U )")):(console.error("profile.maxSMBBasalMinutes: "+i.maxSMBBasalMinutes+", profile.current_basal: "+i.current_basal),pa>(Ma=o(i.current_basal*i.maxSMBBasalMinutes/60,1))?console.error("SMB limited by maxSMBBasalMinutes: "+i.maxSMBBasalMinutes+"m ]: "+Ma+"U ( insulinReq: "+pa+"U )"):console.error("SMB is not limited by maxSMBBasalMinutes. ( insulinReq: "+pa+"U )"));var _a=i.bolus_increment,ya=1/_a,xa=i.smb_delivery_ratio;xa>.5&&console.error("SMB Delivery Ratio increased from default 0.5 to "+o(xa,2));var Da=Math.min(pa*xa,Ma);Da=Math.floor(Da*ya)/ya,ha=o(60*((We-(mt+kt)/2)/at)/i.current_basal),pa>0&&Da<_a&&(ha=0);var wa=0;ha<=0?ha=0:ha>=30?(ha=30*o(ha/30),ha=Math.min(60,Math.max(0,ha))):(wa=o(Ue*ha/30,2),ha=30),we.reason+=" insulinReq "+pa,Da>=Ma&&(we.reason+="; maxBolus "+Ma),ha>0&&(we.reason+="; setting "+ha+"m low temp of "+wa+"U/h"),we.reason+=". ";var Sa=3;i.SMBInterval&&(Sa=Math.min(10,Math.max(1,i.SMBInterval)));var Ta=o(Sa-Ba,0),Ua=o(60*(Sa-Ba),0)%60;if(console.error("naive_eventualBG "+mt+","+ha+"m "+wa+"U/h temp needed; last bolus "+Ba+"m ago; maxBolus: "+Ma),Ba>Sa?Da>0&&(we.units=Da,we.reason+="Microbolusing "+Da+"U. "):we.reason+="Waiting "+Ta+"m "+Ua+"s to microbolus again. ",ha>0)return we.rate=wa,we.duration=ha,we}var Ca=m.getMaxSafeBasal(i);return fa>Ca&&(we.reason+="adj. req. rate: "+fa+" to maxSafeBasal: "+o(Ca,2)+", ",fa=r(Ca,i)),t.duration*(t.rate-Ue)/60>=2*pa?(we.reason+=t.duration+"m@"+t.rate.toFixed(2)+" > 2 * insulinReq. Setting temp basal of "+fa+"U/hr. ",m.setTempBasal(fa,30,i,we,t)):void 0===t.duration||0===t.duration?(we.reason+="no temp, setting "+fa+"U/hr. ",m.setTempBasal(fa,30,i,we,t)):t.duration>5&&r(fa,i)<=r(t.rate,i)?(we.reason+="temp "+t.rate+" >~ req "+fa+"U/hr. ",we):(we.reason+="temp "+t.rate+"<"+fa+"U/hr. ",m.setTempBasal(fa,30,i,we,t))}},6880:(e,t,a)=>{var r=a(6654);e.exports=function(e,t){var a=20;void 0!==t&&"string"==typeof t.model&&(r(t.model,"54")||r(t.model,"23"))&&(a=40);return e<1?Math.round(e*a)/a:e<10?Math.round(20*e)/20:Math.round(10*e)/10}},2705:(e,t,a)=>{var r=a(5639).Symbol;e.exports=r},9932:e=>{e.exports=function(e,t){for(var a=-1,r=null==e?0:e.length,o=Array(r);++a{e.exports=function(e,t,a){return e==e&&(void 0!==a&&(e=e<=a?e:a),void 0!==t&&(e=e>=t?e:t)),e}},4239:(e,t,a)=>{var r=a(2705),o=a(9607),n=a(2333),i=r?r.toStringTag:void 0;e.exports=function(e){return null==e?void 0===e?"[object Undefined]":"[object Null]":i&&i in Object(e)?o(e):n(e)}},531:(e,t,a)=>{var r=a(2705),o=a(9932),n=a(1469),i=a(3448),s=r?r.prototype:void 0,l=s?s.toString:void 0;e.exports=function e(t){if("string"==typeof t)return t;if(n(t))return o(t,e)+"";if(i(t))return l?l.call(t):"";var a=t+"";return"0"==a&&1/t==-Infinity?"-0":a}},7561:(e,t,a)=>{var r=a(7990),o=/^\s+/;e.exports=function(e){return e?e.slice(0,r(e)+1).replace(o,""):e}},1957:(e,t,a)=>{var r="object"==typeof a.g&&a.g&&a.g.Object===Object&&a.g;e.exports=r},9607:(e,t,a)=>{var r=a(2705),o=Object.prototype,n=o.hasOwnProperty,i=o.toString,s=r?r.toStringTag:void 0;e.exports=function(e){var t=n.call(e,s),a=e[s];try{e[s]=void 0;var r=!0}catch(e){}var o=i.call(e);return r&&(t?e[s]=a:delete e[s]),o}},2333:e=>{var t=Object.prototype.toString;e.exports=function(e){return t.call(e)}},5639:(e,t,a)=>{var r=a(1957),o="object"==typeof self&&self&&self.Object===Object&&self,n=r||o||Function("return this")();e.exports=n},7990:e=>{var t=/\s/;e.exports=function(e){for(var a=e.length;a--&&t.test(e.charAt(a)););return a}},6654:(e,t,a)=>{var r=a(9750),o=a(531),n=a(554),i=a(9833);e.exports=function(e,t,a){e=i(e),t=o(t);var s=e.length,l=a=void 0===a?s:r(n(a),0,s);return(a-=t.length)>=0&&e.slice(a,l)==t}},1469:e=>{var t=Array.isArray;e.exports=t},3218:e=>{e.exports=function(e){var t=typeof e;return null!=e&&("object"==t||"function"==t)}},7005:e=>{e.exports=function(e){return null!=e&&"object"==typeof e}},3448:(e,t,a)=>{var r=a(4239),o=a(7005);e.exports=function(e){return"symbol"==typeof e||o(e)&&"[object Symbol]"==r(e)}},8601:(e,t,a)=>{var r=a(4841),o=1/0;e.exports=function(e){return e?(e=r(e))===o||e===-1/0?17976931348623157e292*(e<0?-1:1):e==e?e:0:0===e?e:0}},554:(e,t,a)=>{var r=a(8601);e.exports=function(e){var t=r(e),a=t%1;return t==t?a?t-a:t:0}},4841:(e,t,a)=>{var r=a(7561),o=a(3218),n=a(3448),i=/^[-+]0x[0-9a-f]+$/i,s=/^0b[01]+$/i,l=/^0o[0-7]+$/i,m=parseInt;e.exports=function(e){if("number"==typeof e)return e;if(n(e))return NaN;if(o(e)){var t="function"==typeof e.valueOf?e.valueOf():e;e=o(t)?t+"":t}if("string"!=typeof e)return 0===e?e:+e;e=r(e);var a=s.test(e);return a||l.test(e)?m(e.slice(2),a?2:8):i.test(e)?NaN:+e}},9833:(e,t,a)=>{var r=a(531);e.exports=function(e){return null==e?"":r(e)}}},t={};function a(r){var o=t[r];if(void 0!==o)return o.exports;var n=t[r]={exports:{}};return e[r](n,n.exports,a),n.exports}a.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"==typeof window)return window}}();var r=a(5546);freeaps_determineBasal=r})();