From ae58355632df76d3a342e54f3ddc6f765b245edd Mon Sep 17 00:00:00 2001 From: Pete Schwamb Date: Mon, 15 Jul 2024 19:36:09 -0500 Subject: [PATCH] Fix issue with target override application (#685) --- .../LoopDataManager+CarbAbsorption.swift | 30 +++++++------------ Loop/Managers/LoopDataManager.swift | 20 +++---------- 2 files changed, 14 insertions(+), 36 deletions(-) diff --git a/Loop/Managers/LoopDataManager+CarbAbsorption.swift b/Loop/Managers/LoopDataManager+CarbAbsorption.swift index d5ea04cba..8f532a4e0 100644 --- a/Loop/Managers/LoopDataManager+CarbAbsorption.swift +++ b/Loop/Managers/LoopDataManager+CarbAbsorption.swift @@ -50,41 +50,31 @@ extension LoopDataManager { let sensitivity = try await settingsProvider.getInsulinSensitivityHistory(startDate: sensitivityStart, endDate: end) - var overrides = temporaryPresetsManager.overrideHistory.getOverrideHistory(startDate: sensitivityStart, endDate: end) + let overrides = temporaryPresetsManager.overrideHistory.getOverrideHistory(startDate: sensitivityStart, endDate: end) guard !sensitivity.isEmpty else { throw LoopError.configurationError(.insulinSensitivitySchedule) } - let sensitivityWithOverrides = overrides.apply(over: sensitivity) { (quantity, override) in - let value = quantity.doubleValue(for: .milligramsPerDeciliter) - return HKQuantity( - unit: .milligramsPerDeciliter, - doubleValue: value / override.settings.effectiveInsulinNeedsScaleFactor - ) - } + let sensitivityWithOverrides = overrides.applySensitivity(over: sensitivity) guard !basal.isEmpty else { throw LoopError.configurationError(.basalRateSchedule) } - let basalWithOverrides = overrides.apply(over: basal) { (value, override) in - value * override.settings.effectiveInsulinNeedsScaleFactor - } + let basalWithOverrides = overrides.applyBasal(over: basal) guard !carbRatio.isEmpty else { throw LoopError.configurationError(.carbRatioSchedule) } - let carbRatioWithOverrides = overrides.apply(over: carbRatio) { (value, override) in - value * override.settings.effectiveInsulinNeedsScaleFactor - } + let carbRatioWithOverrides = overrides.applyCarbRatio(over: carbRatio) let carbModel: CarbAbsorptionModel = FeatureFlags.nonlinearCarbModelEnabled ? .piecewiseLinear : .linear // Overlay basal history on basal doses, splitting doses to get amount delivered relative to basal - let annotatedDoses = doses.annotated(with: basal) + let annotatedDoses = doses.annotated(with: basalWithOverrides) let insulinEffects = annotatedDoses.glucoseEffects( - insulinSensitivityHistory: sensitivity, + insulinSensitivityHistory: sensitivityWithOverrides, from: start.addingTimeInterval(-CarbMath.maximumAbsorptionTimeInterval).dateFlooredToTimeInterval(GlucoseMath.defaultDelta), to: nil) @@ -94,15 +84,15 @@ extension LoopDataManager { // Carb Effects let carbStatus = carbEntries.map( to: insulinCounteractionEffects, - carbRatio: carbRatio, - insulinSensitivity: sensitivity + carbRatio: carbRatioWithOverrides, + insulinSensitivity: sensitivityWithOverrides ) let carbEffects = carbStatus.dynamicGlucoseEffects( from: end, to: end.addingTimeInterval(InsulinMath.defaultInsulinActivityDuration), - carbRatios: carbRatio, - insulinSensitivities: sensitivity, + carbRatios: carbRatioWithOverrides, + insulinSensitivities: sensitivityWithOverrides, absorptionModel: carbModel.model ) diff --git a/Loop/Managers/LoopDataManager.swift b/Loop/Managers/LoopDataManager.swift index 330210ace..c92c6eacf 100644 --- a/Loop/Managers/LoopDataManager.swift +++ b/Loop/Managers/LoopDataManager.swift @@ -349,34 +349,22 @@ final class LoopDataManager: ObservableObject { throw LoopError.configurationError(.insulinSensitivitySchedule) } - let sensitivityWithOverrides = overrides.apply(over: sensitivity) { (quantity, override) in - let value = quantity.doubleValue(for: .milligramsPerDeciliter) - return HKQuantity( - unit: .milligramsPerDeciliter, - doubleValue: value / override.settings.effectiveInsulinNeedsScaleFactor - ) - } + let sensitivityWithOverrides = overrides.applySensitivity(over: sensitivity) guard !basal.isEmpty else { throw LoopError.configurationError(.basalRateSchedule) } - let basalWithOverrides = overrides.apply(over: basal) { (value, override) in - value * override.settings.effectiveInsulinNeedsScaleFactor - } + let basalWithOverrides = overrides.applyBasal(over: basal) guard !carbRatio.isEmpty else { throw LoopError.configurationError(.carbRatioSchedule) } - let carbRatioWithOverrides = overrides.apply(over: carbRatio) { (value, override) in - value * override.settings.effectiveInsulinNeedsScaleFactor - } + let carbRatioWithOverrides = overrides.applyCarbRatio(over: carbRatio) guard !target.isEmpty else { throw LoopError.configurationError(.glucoseTargetRangeSchedule) } - let targetWithOverrides = overrides.apply(over: target) { (range, override) in - override.settings.targetRange ?? range - } + let targetWithOverrides = overrides.applyTarget(over: target, at: baseTime) // Create dosing strategy based on user setting let applicationFactorStrategy: ApplicationFactorStrategy = UserDefaults.standard.glucoseBasedApplicationFactorEnabled