From 96bfb857f7322e9ab3ab939b0285b5cad218e95c Mon Sep 17 00:00:00 2001 From: jbr7rr Date: Tue, 27 Dec 2022 12:18:27 +0100 Subject: [PATCH 01/10] Set module of timestamp to 1 minute instead of 5 --- .../iob/iobCobCalculator/data/AutosensDataStoreObject.kt | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/plugins/main/src/main/java/info/nightscout/plugins/iob/iobCobCalculator/data/AutosensDataStoreObject.kt b/plugins/main/src/main/java/info/nightscout/plugins/iob/iobCobCalculator/data/AutosensDataStoreObject.kt index a31c28441e..60e2e0dc86 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/iob/iobCobCalculator/data/AutosensDataStoreObject.kt +++ b/plugins/main/src/main/java/info/nightscout/plugins/iob/iobCobCalculator/data/AutosensDataStoreObject.kt @@ -222,7 +222,9 @@ class AutosensDataStoreObject : AutosensDataStore { return } val newBucketedData = ArrayList() - var currentTime = bgReadings[0].timestamp - bgReadings[0].timestamp % T.mins(5).msecs() + + // Round time to 1 minute, This sets timestamp a bit in the past, but not much longer that it is noticable + var currentTime = bgReadings[0].timestamp - bgReadings[0].timestamp % T.mins(1).msecs() val adjustedTime = adjustToReferenceTime(currentTime) // after adjusting time may be newer. In this case use T-5min currentTime = if (adjustedTime > currentTime) adjustedTime - T.mins(5).msecs() else adjustedTime From dfdb7857f673056995af4660b5a8624623341221 Mon Sep 17 00:00:00 2001 From: jbr7rr Date: Tue, 27 Dec 2022 16:48:53 +0100 Subject: [PATCH 02/10] No delay at all for initial timestamp --- .../iob/iobCobCalculator/data/AutosensDataStoreObject.kt | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/plugins/main/src/main/java/info/nightscout/plugins/iob/iobCobCalculator/data/AutosensDataStoreObject.kt b/plugins/main/src/main/java/info/nightscout/plugins/iob/iobCobCalculator/data/AutosensDataStoreObject.kt index 60e2e0dc86..8f2ccb99ab 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/iob/iobCobCalculator/data/AutosensDataStoreObject.kt +++ b/plugins/main/src/main/java/info/nightscout/plugins/iob/iobCobCalculator/data/AutosensDataStoreObject.kt @@ -222,9 +222,7 @@ class AutosensDataStoreObject : AutosensDataStore { return } val newBucketedData = ArrayList() - - // Round time to 1 minute, This sets timestamp a bit in the past, but not much longer that it is noticable - var currentTime = bgReadings[0].timestamp - bgReadings[0].timestamp % T.mins(1).msecs() + var currentTime = bgReadings[0].timestamp val adjustedTime = adjustToReferenceTime(currentTime) // after adjusting time may be newer. In this case use T-5min currentTime = if (adjustedTime > currentTime) adjustedTime - T.mins(5).msecs() else adjustedTime From 2559b7cce70c91d8d2ae473c32807d1d0e7c136e Mon Sep 17 00:00:00 2001 From: jbr7rr Date: Wed, 28 Dec 2022 12:27:06 +0100 Subject: [PATCH 03/10] Added testing of adjusting to referenceTime --- .../plugins/iob/AutosensDataStoreTest.kt | 55 +++++++++++++++++++ 1 file changed, 55 insertions(+) diff --git a/plugins/main/src/test/java/info/nightscout/plugins/iob/AutosensDataStoreTest.kt b/plugins/main/src/test/java/info/nightscout/plugins/iob/AutosensDataStoreTest.kt index 861534e11d..f6285cca37 100644 --- a/plugins/main/src/test/java/info/nightscout/plugins/iob/AutosensDataStoreTest.kt +++ b/plugins/main/src/test/java/info/nightscout/plugins/iob/AutosensDataStoreTest.kt @@ -643,6 +643,61 @@ class AutosensDataStoreTest : TestBase() { Assertions.assertEquals(90.0, autosensDataStore.bucketedData!![1].value, 1.0) Assertions.assertEquals(50.0, autosensDataStore.bucketedData!![5].value, 1.0) Assertions.assertEquals(40.0, autosensDataStore.bucketedData!![6].value, 1.0) + + // non 5min data not aligned to referenceTime should be recalculated to referenceTime + autosensDataStore.referenceTime = T.mins(5).msecs() + bgReadingList.clear() + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(48).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 98.0, + timestamp = T.mins(42).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 90.0, + timestamp = T.mins(40).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 40.0, + timestamp = T.mins(18).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + autosensDataStore.bgReadings = bgReadingList + Assertions.assertEquals(false, autosensDataStore.isAbout5minData(aapsLogger)) + autosensDataStore.createBucketedData(aapsLogger, dateUtil) + Assertions.assertEquals(T.mins(45).msecs(), autosensDataStore.bucketedData!![0].timestamp) + Assertions.assertEquals(T.mins(35).msecs(), autosensDataStore.bucketedData!![2].timestamp) + Assertions.assertEquals(T.mins(20).msecs(), autosensDataStore.bucketedData!![5].timestamp) + Assertions.assertEquals(6, autosensDataStore.bucketedData!!.size.toLong()) + Assertions.assertEquals(99.0, autosensDataStore.bucketedData!![0].value, 1.0) // Recalculated data to 45min + Assertions.assertEquals(90.0, autosensDataStore.bucketedData!![1].value, 1.0) // Recalculated data to 40min + Assertions.assertEquals(67.0, autosensDataStore.bucketedData!![3].value, 1.0) // Recalculated data to 30min + Assertions.assertEquals(45.0, autosensDataStore.bucketedData!![5].value, 1.0) // Recalculated data to 20min } @Test From e0c8039d319d5ccdfc8b8a8c7d3b1650f5f4f889 Mon Sep 17 00:00:00 2001 From: jbr7rr Date: Wed, 28 Dec 2022 12:58:36 +0100 Subject: [PATCH 04/10] Fix calculation in adjustToReferenceTime() --- .../plugins/iob/iobCobCalculator/data/AutosensDataStoreObject.kt | 1 + 1 file changed, 1 insertion(+) diff --git a/plugins/main/src/main/java/info/nightscout/plugins/iob/iobCobCalculator/data/AutosensDataStoreObject.kt b/plugins/main/src/main/java/info/nightscout/plugins/iob/iobCobCalculator/data/AutosensDataStoreObject.kt index 8f2ccb99ab..1843492345 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/iob/iobCobCalculator/data/AutosensDataStoreObject.kt +++ b/plugins/main/src/main/java/info/nightscout/plugins/iob/iobCobCalculator/data/AutosensDataStoreObject.kt @@ -153,6 +153,7 @@ class AutosensDataStoreObject : AutosensDataStore { var diff = abs(someTime - referenceTime) diff %= T.mins(5).msecs() if (diff > T.mins(2).plus(T.secs(30)).msecs()) diff -= T.mins(5).msecs() + diff = abs(diff) return someTime + diff } From a81447ed2ec9d593e9b39c5a23e9114a6be1c04f Mon Sep 17 00:00:00 2001 From: jbr7rr Date: Wed, 28 Dec 2022 12:59:25 +0100 Subject: [PATCH 05/10] Added test alignment set referenceTime --- .../plugins/iob/AutosensDataStoreTest.kt | 56 +++++++++++++++++++ 1 file changed, 56 insertions(+) diff --git a/plugins/main/src/test/java/info/nightscout/plugins/iob/AutosensDataStoreTest.kt b/plugins/main/src/test/java/info/nightscout/plugins/iob/AutosensDataStoreTest.kt index f6285cca37..320855aac0 100644 --- a/plugins/main/src/test/java/info/nightscout/plugins/iob/AutosensDataStoreTest.kt +++ b/plugins/main/src/test/java/info/nightscout/plugins/iob/AutosensDataStoreTest.kt @@ -698,6 +698,62 @@ class AutosensDataStoreTest : TestBase() { Assertions.assertEquals(90.0, autosensDataStore.bucketedData!![1].value, 1.0) // Recalculated data to 40min Assertions.assertEquals(67.0, autosensDataStore.bucketedData!![3].value, 1.0) // Recalculated data to 30min Assertions.assertEquals(45.0, autosensDataStore.bucketedData!![5].value, 1.0) // Recalculated data to 20min + + // non 5min data without referenceTime set, shoud allign the data to the time of the last reading + autosensDataStore.referenceTime = -1 + bgReadingList.clear() + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(48).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 98.0, + timestamp = T.mins(42).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 90.0, + timestamp = T.mins(40).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 40.0, + timestamp = T.mins(18).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + autosensDataStore.bgReadings = bgReadingList + Assertions.assertEquals(false, autosensDataStore.isAbout5minData(aapsLogger)) + autosensDataStore.createBucketedData(aapsLogger, dateUtil) + Assertions.assertEquals(T.mins(48).msecs(), autosensDataStore.bucketedData!![0].timestamp) + Assertions.assertEquals(T.mins(43).msecs(), autosensDataStore.bucketedData!![1].timestamp) + Assertions.assertEquals(T.mins(33).msecs(), autosensDataStore.bucketedData!![3].timestamp) + Assertions.assertEquals(T.mins(18).msecs(), autosensDataStore.bucketedData!![6].timestamp) + Assertions.assertEquals(7, autosensDataStore.bucketedData!!.size.toLong()) + Assertions.assertEquals(100.0, autosensDataStore.bucketedData!![0].value, 1.0) // Recalculated data to 48min + Assertions.assertEquals(98.0, autosensDataStore.bucketedData!![1].value, 1.0) // Recalculated data to 43min + Assertions.assertEquals(67.0, autosensDataStore.bucketedData!![3].value, 1.0) // Recalculated data to 33min + Assertions.assertEquals(40.0, autosensDataStore.bucketedData!![6].value, 1.0) // Recalculated data to 18min } @Test From d863f5d660407b1c69c19413a6f27cf87b41bc61 Mon Sep 17 00:00:00 2001 From: jbr7rr Date: Wed, 28 Dec 2022 13:02:36 +0100 Subject: [PATCH 06/10] Corrected calculation in assert --- .../java/info/nightscout/plugins/iob/AutosensDataStoreTest.kt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/main/src/test/java/info/nightscout/plugins/iob/AutosensDataStoreTest.kt b/plugins/main/src/test/java/info/nightscout/plugins/iob/AutosensDataStoreTest.kt index 320855aac0..7cdc9c0eec 100644 --- a/plugins/main/src/test/java/info/nightscout/plugins/iob/AutosensDataStoreTest.kt +++ b/plugins/main/src/test/java/info/nightscout/plugins/iob/AutosensDataStoreTest.kt @@ -752,7 +752,7 @@ class AutosensDataStoreTest : TestBase() { Assertions.assertEquals(7, autosensDataStore.bucketedData!!.size.toLong()) Assertions.assertEquals(100.0, autosensDataStore.bucketedData!![0].value, 1.0) // Recalculated data to 48min Assertions.assertEquals(98.0, autosensDataStore.bucketedData!![1].value, 1.0) // Recalculated data to 43min - Assertions.assertEquals(67.0, autosensDataStore.bucketedData!![3].value, 1.0) // Recalculated data to 33min + Assertions.assertEquals(74.0, autosensDataStore.bucketedData!![3].value, 1.0) // Recalculated data to 33min Assertions.assertEquals(40.0, autosensDataStore.bucketedData!![6].value, 1.0) // Recalculated data to 18min } From 0e357d968cf5206ec63f25eb04db02f70660e0b5 Mon Sep 17 00:00:00 2001 From: jbr7rr Date: Wed, 28 Dec 2022 13:33:54 +0100 Subject: [PATCH 07/10] Better fix for adjustToReferenceTime() --- .../iob/iobCobCalculator/data/AutosensDataStoreObject.kt | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/plugins/main/src/main/java/info/nightscout/plugins/iob/iobCobCalculator/data/AutosensDataStoreObject.kt b/plugins/main/src/main/java/info/nightscout/plugins/iob/iobCobCalculator/data/AutosensDataStoreObject.kt index 1843492345..3718cb934f 100644 --- a/plugins/main/src/main/java/info/nightscout/plugins/iob/iobCobCalculator/data/AutosensDataStoreObject.kt +++ b/plugins/main/src/main/java/info/nightscout/plugins/iob/iobCobCalculator/data/AutosensDataStoreObject.kt @@ -152,9 +152,11 @@ class AutosensDataStoreObject : AutosensDataStore { } var diff = abs(someTime - referenceTime) diff %= T.mins(5).msecs() - if (diff > T.mins(2).plus(T.secs(30)).msecs()) diff -= T.mins(5).msecs() - diff = abs(diff) - return someTime + diff + if (diff > T.mins(2).plus(T.secs(30)).msecs()){ + return someTime + abs(diff - T.mins(5).msecs()) // Adjust to the future + } else { + return someTime - diff // adjust to the past + } } fun isAbout5minData(aapsLogger: AAPSLogger): Boolean { From 07684a1e14ed577f79ae9307870b662dfe146da0 Mon Sep 17 00:00:00 2001 From: jbr7rr Date: Wed, 28 Dec 2022 13:48:45 +0100 Subject: [PATCH 08/10] Moved tests for referenceTime to separate function. Added additional testcase --- .../plugins/iob/AutosensDataStoreTest.kt | 282 +++++++++++------- 1 file changed, 171 insertions(+), 111 deletions(-) diff --git a/plugins/main/src/test/java/info/nightscout/plugins/iob/AutosensDataStoreTest.kt b/plugins/main/src/test/java/info/nightscout/plugins/iob/AutosensDataStoreTest.kt index 7cdc9c0eec..a2cce6fc68 100644 --- a/plugins/main/src/test/java/info/nightscout/plugins/iob/AutosensDataStoreTest.kt +++ b/plugins/main/src/test/java/info/nightscout/plugins/iob/AutosensDataStoreTest.kt @@ -643,117 +643,6 @@ class AutosensDataStoreTest : TestBase() { Assertions.assertEquals(90.0, autosensDataStore.bucketedData!![1].value, 1.0) Assertions.assertEquals(50.0, autosensDataStore.bucketedData!![5].value, 1.0) Assertions.assertEquals(40.0, autosensDataStore.bucketedData!![6].value, 1.0) - - // non 5min data not aligned to referenceTime should be recalculated to referenceTime - autosensDataStore.referenceTime = T.mins(5).msecs() - bgReadingList.clear() - bgReadingList.add( - GlucoseValue( - raw = 0.0, - noise = 0.0, - value = 100.0, - timestamp = T.mins(48).msecs(), - sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, - trendArrow = GlucoseValue.TrendArrow.FLAT - ) - ) - bgReadingList.add( - GlucoseValue( - raw = 0.0, - noise = 0.0, - value = 98.0, - timestamp = T.mins(42).msecs(), - sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, - trendArrow = GlucoseValue.TrendArrow.FLAT - ) - ) - bgReadingList.add( - GlucoseValue( - raw = 0.0, - noise = 0.0, - value = 90.0, - timestamp = T.mins(40).msecs(), - sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, - trendArrow = GlucoseValue.TrendArrow.FLAT - ) - ) - bgReadingList.add( - GlucoseValue( - raw = 0.0, - noise = 0.0, - value = 40.0, - timestamp = T.mins(18).msecs(), - sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, - trendArrow = GlucoseValue.TrendArrow.FLAT - ) - ) - autosensDataStore.bgReadings = bgReadingList - Assertions.assertEquals(false, autosensDataStore.isAbout5minData(aapsLogger)) - autosensDataStore.createBucketedData(aapsLogger, dateUtil) - Assertions.assertEquals(T.mins(45).msecs(), autosensDataStore.bucketedData!![0].timestamp) - Assertions.assertEquals(T.mins(35).msecs(), autosensDataStore.bucketedData!![2].timestamp) - Assertions.assertEquals(T.mins(20).msecs(), autosensDataStore.bucketedData!![5].timestamp) - Assertions.assertEquals(6, autosensDataStore.bucketedData!!.size.toLong()) - Assertions.assertEquals(99.0, autosensDataStore.bucketedData!![0].value, 1.0) // Recalculated data to 45min - Assertions.assertEquals(90.0, autosensDataStore.bucketedData!![1].value, 1.0) // Recalculated data to 40min - Assertions.assertEquals(67.0, autosensDataStore.bucketedData!![3].value, 1.0) // Recalculated data to 30min - Assertions.assertEquals(45.0, autosensDataStore.bucketedData!![5].value, 1.0) // Recalculated data to 20min - - // non 5min data without referenceTime set, shoud allign the data to the time of the last reading - autosensDataStore.referenceTime = -1 - bgReadingList.clear() - bgReadingList.add( - GlucoseValue( - raw = 0.0, - noise = 0.0, - value = 100.0, - timestamp = T.mins(48).msecs(), - sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, - trendArrow = GlucoseValue.TrendArrow.FLAT - ) - ) - bgReadingList.add( - GlucoseValue( - raw = 0.0, - noise = 0.0, - value = 98.0, - timestamp = T.mins(42).msecs(), - sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, - trendArrow = GlucoseValue.TrendArrow.FLAT - ) - ) - bgReadingList.add( - GlucoseValue( - raw = 0.0, - noise = 0.0, - value = 90.0, - timestamp = T.mins(40).msecs(), - sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, - trendArrow = GlucoseValue.TrendArrow.FLAT - ) - ) - bgReadingList.add( - GlucoseValue( - raw = 0.0, - noise = 0.0, - value = 40.0, - timestamp = T.mins(18).msecs(), - sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, - trendArrow = GlucoseValue.TrendArrow.FLAT - ) - ) - autosensDataStore.bgReadings = bgReadingList - Assertions.assertEquals(false, autosensDataStore.isAbout5minData(aapsLogger)) - autosensDataStore.createBucketedData(aapsLogger, dateUtil) - Assertions.assertEquals(T.mins(48).msecs(), autosensDataStore.bucketedData!![0].timestamp) - Assertions.assertEquals(T.mins(43).msecs(), autosensDataStore.bucketedData!![1].timestamp) - Assertions.assertEquals(T.mins(33).msecs(), autosensDataStore.bucketedData!![3].timestamp) - Assertions.assertEquals(T.mins(18).msecs(), autosensDataStore.bucketedData!![6].timestamp) - Assertions.assertEquals(7, autosensDataStore.bucketedData!!.size.toLong()) - Assertions.assertEquals(100.0, autosensDataStore.bucketedData!![0].value, 1.0) // Recalculated data to 48min - Assertions.assertEquals(98.0, autosensDataStore.bucketedData!![1].value, 1.0) // Recalculated data to 43min - Assertions.assertEquals(74.0, autosensDataStore.bucketedData!![3].value, 1.0) // Recalculated data to 33min - Assertions.assertEquals(40.0, autosensDataStore.bucketedData!![6].value, 1.0) // Recalculated data to 18min } @Test @@ -1261,6 +1150,177 @@ class AutosensDataStoreTest : TestBase() { Assertions.assertEquals(false, autosensDataStore.isAbout5minData(aapsLogger)) } + @Test + fun createBucketedData5minTest3() { + val bgReadingList: MutableList = ArrayList() + + // non 5min data not aligned to referenceTime should be recalculated to referenceTime + autosensDataStore.referenceTime = T.mins(5).msecs() + bgReadingList.clear() + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(48).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 98.0, + timestamp = T.mins(42).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 90.0, + timestamp = T.mins(40).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 40.0, + timestamp = T.mins(18).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + autosensDataStore.bgReadings = bgReadingList + Assertions.assertEquals(false, autosensDataStore.isAbout5minData(aapsLogger)) + autosensDataStore.createBucketedData(aapsLogger, dateUtil) + Assertions.assertEquals(T.mins(45).msecs(), autosensDataStore.bucketedData!![0].timestamp) + Assertions.assertEquals(T.mins(35).msecs(), autosensDataStore.bucketedData!![2].timestamp) + Assertions.assertEquals(T.mins(20).msecs(), autosensDataStore.bucketedData!![5].timestamp) + Assertions.assertEquals(6, autosensDataStore.bucketedData!!.size.toLong()) + Assertions.assertEquals(99.0, autosensDataStore.bucketedData!![0].value, 1.0) // Recalculated data to 45min + Assertions.assertEquals(90.0, autosensDataStore.bucketedData!![1].value, 1.0) // Recalculated data to 40min + Assertions.assertEquals(67.0, autosensDataStore.bucketedData!![3].value, 1.0) // Recalculated data to 30min + Assertions.assertEquals(45.0, autosensDataStore.bucketedData!![5].value, 1.0) // Recalculated data to 20min + + // non 5min data not aligned to referenceTime should be recalculated to referenceTime + autosensDataStore.referenceTime = T.mins(5).msecs() + bgReadingList.clear() + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(46).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 98.0, + timestamp = T.mins(42).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 90.0, + timestamp = T.mins(40).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 40.0, + timestamp = T.mins(18).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + autosensDataStore.bgReadings = bgReadingList + Assertions.assertEquals(false, autosensDataStore.isAbout5minData(aapsLogger)) + autosensDataStore.createBucketedData(aapsLogger, dateUtil) + Assertions.assertEquals(T.mins(45).msecs(), autosensDataStore.bucketedData!![0].timestamp) + Assertions.assertEquals(T.mins(35).msecs(), autosensDataStore.bucketedData!![2].timestamp) + Assertions.assertEquals(T.mins(20).msecs(), autosensDataStore.bucketedData!![5].timestamp) + Assertions.assertEquals(6, autosensDataStore.bucketedData!!.size.toLong()) + Assertions.assertEquals(99.0, autosensDataStore.bucketedData!![0].value, 1.0) // Recalculated data to 45min + Assertions.assertEquals(90.0, autosensDataStore.bucketedData!![1].value, 1.0) // Recalculated data to 40min + Assertions.assertEquals(67.0, autosensDataStore.bucketedData!![3].value, 1.0) // Recalculated data to 30min + Assertions.assertEquals(45.0, autosensDataStore.bucketedData!![5].value, 1.0) // Recalculated data to 20min + + // non 5min data without referenceTime set, shoud allign the data to the time of the last reading + autosensDataStore.referenceTime = -1 + bgReadingList.clear() + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 100.0, + timestamp = T.mins(48).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 98.0, + timestamp = T.mins(42).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 90.0, + timestamp = T.mins(40).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + bgReadingList.add( + GlucoseValue( + raw = 0.0, + noise = 0.0, + value = 40.0, + timestamp = T.mins(18).msecs(), + sourceSensor = GlucoseValue.SourceSensor.UNKNOWN, + trendArrow = GlucoseValue.TrendArrow.FLAT + ) + ) + autosensDataStore.bgReadings = bgReadingList + Assertions.assertEquals(false, autosensDataStore.isAbout5minData(aapsLogger)) + autosensDataStore.createBucketedData(aapsLogger, dateUtil) + Assertions.assertEquals(T.mins(48).msecs(), autosensDataStore.bucketedData!![0].timestamp) + Assertions.assertEquals(T.mins(43).msecs(), autosensDataStore.bucketedData!![1].timestamp) + Assertions.assertEquals(T.mins(33).msecs(), autosensDataStore.bucketedData!![3].timestamp) + Assertions.assertEquals(T.mins(18).msecs(), autosensDataStore.bucketedData!![6].timestamp) + Assertions.assertEquals(7, autosensDataStore.bucketedData!!.size.toLong()) + Assertions.assertEquals(100.0, autosensDataStore.bucketedData!![0].value, 1.0) // Recalculated data to 48min + Assertions.assertEquals(98.0, autosensDataStore.bucketedData!![1].value, 1.0) // Recalculated data to 43min + Assertions.assertEquals(74.0, autosensDataStore.bucketedData!![3].value, 1.0) // Recalculated data to 33min + Assertions.assertEquals(40.0, autosensDataStore.bucketedData!![6].value, 1.0) // Recalculated data to 18min + } + @Test fun bgReadingsTest() { val bgReadingList: List = ArrayList() From b25204dfe1fc634a77197735f7c17210c908b18c Mon Sep 17 00:00:00 2001 From: jbr7rr Date: Wed, 28 Dec 2022 15:17:25 +0100 Subject: [PATCH 09/10] Fix typo --- .../java/info/nightscout/plugins/iob/AutosensDataStoreTest.kt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/main/src/test/java/info/nightscout/plugins/iob/AutosensDataStoreTest.kt b/plugins/main/src/test/java/info/nightscout/plugins/iob/AutosensDataStoreTest.kt index a2cce6fc68..6120952f34 100644 --- a/plugins/main/src/test/java/info/nightscout/plugins/iob/AutosensDataStoreTest.kt +++ b/plugins/main/src/test/java/info/nightscout/plugins/iob/AutosensDataStoreTest.kt @@ -1264,7 +1264,7 @@ class AutosensDataStoreTest : TestBase() { Assertions.assertEquals(67.0, autosensDataStore.bucketedData!![3].value, 1.0) // Recalculated data to 30min Assertions.assertEquals(45.0, autosensDataStore.bucketedData!![5].value, 1.0) // Recalculated data to 20min - // non 5min data without referenceTime set, shoud allign the data to the time of the last reading + // non 5min data without referenceTime set, should allign the data to the time of the last reading autosensDataStore.referenceTime = -1 bgReadingList.clear() bgReadingList.add( From 5c432c350cf3f782dd2db39896dbc6fa6b173194 Mon Sep 17 00:00:00 2001 From: Andries Smit Date: Wed, 28 Dec 2022 19:18:29 +0100 Subject: [PATCH 10/10] chore: update docs base URL --- .github/ISSUE_TEMPLATE/custom.md | 2 +- CONTRIBUTING.md | 4 +- ISSUE_TEMPLATE.md | 2 +- .../src/main/res/values/strings.xml | 2 +- .../constraints/src/main/res/values/exam.xml | 52 +++++++++---------- .../src/main/res/values/objectives.xml | 10 ++-- pump/combo/src/main/res/values/strings.xml | 2 +- 7 files changed, 37 insertions(+), 37 deletions(-) diff --git a/.github/ISSUE_TEMPLATE/custom.md b/.github/ISSUE_TEMPLATE/custom.md index 665cb66fba..9f30207094 100644 --- a/.github/ISSUE_TEMPLATE/custom.md +++ b/.github/ISSUE_TEMPLATE/custom.md @@ -15,5 +15,5 @@ Reporting bugs upper-right corner). - Obtain the app's log files, which can be found on the phone in _/storage/emulated/0/Android/data/info.nightscout.androidaps/_ - See https://androidaps.readthedocs.io/en/latest/Usage/Accessing-logfiles.html + See https://wiki.aaps.app/en/latest/Usage/Accessing-logfiles.html - Open an issue at https://github.com/nightscout/AndroidAPS/issues/new diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index 2723505db5..ffdc496f2d 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -7,9 +7,9 @@ General rules ============= * There are plenty of ways you can help, some of them are listed on wiki: - https://androidaps.readthedocs.io/en/latest/EN/Getting-Started/How-can-I-help.html + https://wiki.aaps.app/en/latest/EN/Getting-Started/How-can-I-help.html * If you wish to help with documentation or translating: - https://androidaps.readthedocs.io/en/latest/EN/translations.html + https://wiki.aaps.app/en/latest/EN/translations.html Development guidelines ====================== diff --git a/ISSUE_TEMPLATE.md b/ISSUE_TEMPLATE.md index 53a1ed2e9c..d75803147c 100644 --- a/ISSUE_TEMPLATE.md +++ b/ISSUE_TEMPLATE.md @@ -6,5 +6,5 @@ Reporting bugs upper-right corner). - Obtain the app's log files, which can be found on the phone in _/storage/emulated/0/Android/data/info.nightscout.androidaps/_ - See https://androidaps.readthedocs.io/en/latest/EN/Usage/Accessing-logfiles.html + See https://wiki.aaps.app/en/latest/EN/Usage/Accessing-logfiles.html - Open an issue at https://github.com/nightscout/AndroidAPS/issues/new diff --git a/plugins/configuration/src/main/res/values/strings.xml b/plugins/configuration/src/main/res/values/strings.xml index 08c1597fb8..5d4775d22f 100644 --- a/plugins/configuration/src/main/res/values/strings.xml +++ b/plugins/configuration/src/main/res/values/strings.xml @@ -41,7 +41,7 @@ Press the button below to enable AAPS to suggest/make basal changes startupwizard_processed Sensitivity plugin is used for sensitivity detection and COB calculation. For more info visit: - https://androidaps.readthedocs.io/en/latest/Configuration/Sensitivity-detection-and-COB.html + https://wiki.aaps.app/en/latest/Configuration/Sensitivity-detection-and-COB.html Select one from availables algorithms. They are sorted from oldest to newest. Newer algorithm is usually more powerful and more aggressive. Thus if you are new looper you may probably start with AMA and not with latest one. Do not forget to read the OpenAPS documentation and configure it before use. Please configure your RileyLink below. After selecting a RileyLink, it will be possible to continue setup once the RileyLink status is \"Connected\". This might take a minute.\n Note: You can continue setup once the pump has been set up.\n diff --git a/plugins/constraints/src/main/res/values/exam.xml b/plugins/constraints/src/main/res/values/exam.xml index b3b23643b8..4226c779d1 100644 --- a/plugins/constraints/src/main/res/values/exam.xml +++ b/plugins/constraints/src/main/res/values/exam.xml @@ -4,7 +4,7 @@ Duration of Insulin Action (DIA) You should set the value for DIA in your profile. The minimum allowed value is 5 hours. - https://androidaps.readthedocs.io/en/latest/EN/Configuration/Config-Builder.html?#insulin + https://wiki.aaps.app/en/latest/EN/Configuration/Config-Builder.html?#insulin If you are satisfied that the value for DIA that you used in your pump prior to AAPS worked well, there is no need to change this when you start looping. You should determine for yourself the appropriate value for DIA. Hypo Temp-Target @@ -13,18 +13,18 @@ To prevent AAPS from overcorrecting for a blood glucose rise caused by the fast acting carbs used to treat a hypo. To correct for a hypo induced as a result of exercise. To prevent blood glucose from going low if there is already a 0% temporary basal rate running. - https://androidaps.readthedocs.io/en/latest/EN/Usage/temptarget.html + https://wiki.aaps.app/en/latest/EN/Usage/temptarget.html Which profile can be used and configured offline? Topic: Offline Profile NS Profile can be used, but not configured. - https://androidaps.readthedocs.io/en/latest/EN/Configuration/Config-Builder.html#profile + https://wiki.aaps.app/en/latest/EN/Configuration/Config-Builder.html#profile Reasons for applying "Disconnect pump" in AAPS What should be done when disconnecting the pump? This is unnecessary as insulin will not be delivered if the pump is physically disconnected. It prevents AAPS from accounting for insulin that was not delivered whilst the pump is physically disconnected.  It will not stop insulin delivery if the pump remains connected. It will send AAPS into open loop mode. - https://androidaps.readthedocs.io/en/latest/EN/Getting-Started/FAQ.html#other-settings + https://wiki.aaps.app/en/latest/EN/Getting-Started/FAQ.html#other-settings AAPS Settings AAPS Settings What are the best practices for backing up your settings? @@ -36,29 +36,29 @@ Your settings file is found in the folder Internal Storage/AAPS/preferences on your phone. Copy your preferences file to a safe location outside of your phone (e.g. by using a cloud drive, connecting a cable to a computer, email, etc.) If your phone is damaged or lost, there are easy ways to remotely recover your settings without a backup. - https://androidaps.readthedocs.io/en/latest/EN/Usage/ExportImportSettings.html - https://androidaps.readthedocs.io/en/latest/EN/Getting-Started/FAQ.html#what-emergency-equipment-is-recommended-to-take-with-me + https://wiki.aaps.app/en/latest/EN/Usage/ExportImportSettings.html + https://wiki.aaps.app/en/latest/EN/Getting-Started/FAQ.html#what-emergency-equipment-is-recommended-to-take-with-me Noisy CGM Readings What should be done if CGM data is noisy? Do nothing - AAPS will deal with it. Disable the closed loop to avoid possible over or underdosing. Replace consistently noisy or inaccurate sensors. Verify that your CGM app provides smoothed data. - https://androidaps.readthedocs.io/en/latest/EN/Usage/Smoothing-Blood-Glucose-Data-in-xDrip.html#smoothing-blood-glucose-data + https://wiki.aaps.app/en/latest/EN/Usage/Smoothing-Blood-Glucose-Data-in-xDrip.html#smoothing-blood-glucose-data Exercise and Profiles How can you use profiles to best help the system deal with aerobic exercise? Do a profile switch to less than 100%. Do a profile switch to more than 100%. Leave the profile set to 100%. Suspend the loop. - https://androidaps.readthedocs.io/en/latest/EN/Usage/temptarget.html#activity-temp-target + https://wiki.aaps.app/en/latest/EN/Usage/temptarget.html#activity-temp-target Exercise and Temporary Targets How can you use temporary targets to best help the system deal with aerobic exercise? Set an activity blood glucose target starting a suitable time before beginning exercise. Set an activity blood glucose target after finishing exercise. Leave your blood glucose target unchanged. Wait until blood glucose drops below your hypo temp target and then eat 15 g of fast acting carbohydrates. - https://androidaps.readthedocs.io/en/latest/EN/Usage/temptarget.html#activity-temp-target + https://wiki.aaps.app/en/latest/EN/Usage/temptarget.html#activity-temp-target Do I receive insulin when the loop is disabled/suspended? Yes, basal insulin continues to be delivered. No, delivery of insulin is stopped. @@ -68,7 +68,7 @@ When experiencing frequent high or low blood glucose. At least once per week. Once set and validated, these values should not change over time. - https://androidaps.readthedocs.io/en/latest/EN/Getting-Started/FAQ.html#androidaps-settings + https://wiki.aaps.app/en/latest/EN/Getting-Started/FAQ.html#androidaps-settings Prerequisites What is essential to set up and use AAPS? Validated profile information (Basal, IC, ISF, DIA). @@ -81,7 +81,7 @@ A Github account. Experience in programming or editing code. A MiniMed 670G pump. - https://androidaps.readthedocs.io/en/latest/EN/Module/module.html + https://wiki.aaps.app/en/latest/EN/Module/module.html A Smartwatch. A Supported CGM. Prerequisites @@ -90,7 +90,7 @@ A compatible Android device (e.g. mobile/cell phone, full Android watch, or tablet). AAPS requires an internet connection in order to run in closed loop. A supported CGM and appropriate app to receive blood glucose values on the phone/device. - https://androidaps.readthedocs.io/en/latest/EN/Module/module.html + https://wiki.aaps.app/en/latest/EN/Module/module.html Updating AAPS Check all correct answers. You need to have Git installed and configured on your computer. @@ -98,14 +98,14 @@ You should save and note the location of your keystore and use the same signing key for updates as for your previous installation. Never update if the system is working well. If you have difficulty building the apk, you can install an apk that has been built by a friend. - https://androidaps.readthedocs.io/en/latest/EN/Installing-AndroidAPS/Update-to-new-version.html#update-to-a-new-version-or-branch + https://wiki.aaps.app/en/latest/EN/Installing-AndroidAPS/Update-to-new-version.html#update-to-a-new-version-or-branch Troubleshooting Where can you look for help with AAPS? You can ask for advice in the AAPS Users Facebook group. You should read (and re-read) the AAPS documentation. You can ask for advice and log technical problems or issues in the AAPS Discord. You should ask your diabetes clinic/endocrinologist. - https://androidaps.readthedocs.io/en/latest/EN/Installing-AndroidAPS/Update-to-new-version.html#troubleshooting + https://wiki.aaps.app/en/latest/EN/Installing-AndroidAPS/Update-to-new-version.html#troubleshooting https://www.facebook.com/groups/AndroidAPSUsers/ https://discord.gg/4fQUWHZ4Mw Insulin Plugins @@ -114,15 +114,15 @@ NovoRapid®/Novolog® Humalog® Actrapid®/Humalin R®/"regular" human insulin. - https://androidaps.readthedocs.io/en/latest/EN/Configuration/Config-Builder.html#insulin + https://wiki.aaps.app/en/latest/EN/Configuration/Config-Builder.html#insulin Sensitivity Plugins Check all correct answers. Sensitivity plugins allow AAPS to adjust for temporary or short-lived changes in insulin sensitivity (for example hormonal changes or issues with absorption at the infusion site). Sensitivity plugins provide the user with suggested changes to basal rates, I:C ratios and ISF that can be used to edit profile. Logging a cannula change will reset Autosens ratio back to 100%. Some of the plugin options have configurable time ranges that can be set by the user. - https://androidaps.readthedocs.io/en/latest/EN/Configuration/Sensitivity-detection-and-COB.html - https://androidaps.readthedocs.io/en/latest/Usage/Open-APS-features.html?highlight=Autosens#autosens + https://wiki.aaps.app/en/latest/EN/Configuration/Sensitivity-detection-and-COB.html + https://wiki.aaps.app/en/latest/Usage/Open-APS-features.html?highlight=Autosens#autosens Carb Entry Errors What should you do if you’ve made an incorrect carb entry? Delete the incorrect entry in Treatments and enter the correct new carb value. @@ -157,29 +157,29 @@ Carbohydrates consumed can be recorded using an appropriate exchange system (e.g. DAFNE "CHO" exchanges or European "Bread Units"). AAPS uses a dynamic model to estimate carb “decay” and calculate COB. If blood glucose levels are outside acceptable values (too low or too high) the bolus calculator can be used to provide suggestions for carb or insulin corrections. - https://androidaps.readthedocs.io/en/latest/EN/Getting-Started/FAQ.html#insulin-to-carb-ratio-ic-g-u + https://wiki.aaps.app/en/latest/EN/Getting-Started/FAQ.html#insulin-to-carb-ratio-ic-g-u e-carbs What could you use e-carbs (extended carbs) for? To schedule carbs in the future, possibly distributed over an interval (similar to an extended bolus distributing insulin over an interval). For logging \'free\' exercise carbs you want to hide from AAPS. e-carbs (distributed in the future) can assist AAPS in dealing with high fat/protein meals. For logging rescue carbs you use to treat low blood glucose.  - https://androidaps.readthedocs.io/en/latest/EN/Usage/Extended-Carbs.html + https://wiki.aaps.app/en/latest/EN/Usage/Extended-Carbs.html Remote Monitoring How can you monitor AAPS (for example for your child) remotely? AAPSClient app, Nightscout app and Nightscout webpage all allow you to follow AAPS remotely. Other apps (e.g. Dexcom follow, xDrip running in follow mode) allow you to follow some parameters (e.g. blood glucose/sensor values) remotely, but use different algorithms so may have inaccurate IOB or COB values. To follow AAPS remotely, both devices must have internet access (e.g. via Wi-Fi or mobile/cellular network data). AAPSClient used as a remote follower will both monitor and provide full control of AAPS. - https://androidaps.readthedocs.io/en/latest/EN/Children/Children.html + https://wiki.aaps.app/en/latest/EN/Children/Children.html Insulin Sensitivity Factor (ISF) Raising ISF values will lead to more insulin delivery to cover a specific amount of carbs. Reducing ISF values lead to more insulin delivery to correct for an above target blood glucose. Raising or lowering ISF has no effect on insulin delivery when blood glucose levels are below target. ISF should be entered in your AAPS Preferences. Changing the ISF value in your profile is enough to apply the change. - https://androidaps.readthedocs.io/en/latest/EN/Getting-Started/FAQ.html#insulin-sensitivity-factor-isf-mmol-l-u-or-mg-dl-u - https://androidaps.readthedocs.io/en/latest/EN/Usage/Profiles.html + https://wiki.aaps.app/en/latest/EN/Getting-Started/FAQ.html#insulin-sensitivity-factor-isf-mmol-l-u-or-mg-dl-u + https://wiki.aaps.app/en/latest/EN/Usage/Profiles.html You can use more than one value for I:C ratio in your profile. If you change your ISF in your profile you should always change your I:C ratio too. Insulin to Carbohydrate Ratio (I:C ratio) @@ -188,14 +188,14 @@ If you have 0 COB, changing the IC ratio will lead to a different amount of insulin to correct a given BG value. IC will be different if you count bread (exchange) unit as 10g or 12g. IC meaning is: How many bread (exchange) units are covered by 1U of insulin. - https://androidaps.readthedocs.io/en/latest/EN/Getting-Started/FAQ.html#carbohydrate-to-insulin-ratio-cr-g-u + https://wiki.aaps.app/en/latest/EN/Getting-Started/FAQ.html#carbohydrate-to-insulin-ratio-cr-g-u Profile Switching When specifying a 90% profile switch, which answers are true? Basal rates will be 10% lower. ISF will be 10% higher. The value of the I:C ratio will be a 10% lower number. ISF and I:C ratios will be unchanged. - https://androidaps.readthedocs.io/en/latest/EN/Usage/Profiles.html?highlight=profile%20switch#profile-switch + https://wiki.aaps.app/en/latest/EN/Usage/Profiles.html?highlight=profile%20switch#profile-switch Profile Switching When specifying a 120% profile switch, which answers are true? Target blood glucose will be 20% higher. @@ -208,13 +208,13 @@ Initiate a profile switch with a timeshift of -2 Set an eating soon temporary target. Do a profile switch to more than 100%.  - https://androidaps.readthedocs.io/en/latest/EN/Usage/Profiles.html?highlight=profile%20switch#timeshift + https://wiki.aaps.app/en/latest/EN/Usage/Profiles.html?highlight=profile%20switch#timeshift Changes to profiles Basal rates, ISF, I:C ratios, etc., should be set in profiles. Activating changes to your Nightscout Profile requires your AAPS phone to have an internet connection. Editing profiles to change values is sufficient to enact any changes made. Multiple profiles can be set up and selected to accommodate changing circumstances (e.g. hormonal changes, shift working, weekdays/weekend lifestyle). - https://androidaps.readthedocs.io/en/latest/EN/Module/module.html#good-individual-dosage-algorithm-for-your-diabetes-therapy + https://wiki.aaps.app/en/latest/EN/Module/module.html#good-individual-dosage-algorithm-for-your-diabetes-therapy Help with basal rates Where to go for help with basalrate etc. Your diabetes team diff --git a/plugins/constraints/src/main/res/values/objectives.xml b/plugins/constraints/src/main/res/values/objectives.xml index 93d034d549..a3e07238a9 100644 --- a/plugins/constraints/src/main/res/values/objectives.xml +++ b/plugins/constraints/src/main/res/values/objectives.xml @@ -29,7 +29,7 @@ You must read the wiki and rise maxIOB to get SMBs working fine! A good start is maxIOB=average mealbolus + 3 x max daily basal Using SMB is your goal. Oref1 algorithm was designed to help you with your boluses as well. You should not give full bolus for your food but only part of it and let AAPS give you the rest if needed. This way you have more space for miscalculated carbs. Did you know that you can set a percentage of bolus calculator result to reduce the size of bolus? Enabling automation - Read the docs on how automation works. Set up your first simple rules. Instead of action let AAPS display only notification. When you are sure automation is triggered at the right time replace notification by real action. (https://androidaps.readthedocs.io/en/latest/EN/Usage/Automation.html) + Read the docs on how automation works. Set up your first simple rules. Instead of action let AAPS display only notification. When you are sure automation is triggered at the right time replace notification by real action. (https://wiki.aaps.app/en/latest/EN/Usage/Automation.html) Automation can be a good servant but a bad master. Don\'t overuse it. Do not try to replace underlying algorithm. Test the rule with message only before use. It depends on order. BG available in NS Pump status available in NS @@ -76,10 +76,10 @@ Next unfinished Request code: %1$s (check all correct answers) - https://androidaps.readthedocs.io/en/latest/EN/Getting-Started/FAQ.html#what-to-do-when-taking-a-shower-or-bath - https://androidaps.readthedocs.io/en/latest/EN/Getting-Started/Screenshots.html#the-homescreen - https://androidaps.readthedocs.io/en/latest/EN/Getting-Started/Screenshots.html#config-builder - https://androidaps.readthedocs.io/en/latest/EN/Getting-Started/Screenshots.html#the-homescreen + https://wiki.aaps.app/en/latest/EN/Getting-Started/FAQ.html#what-to-do-when-taking-a-shower-or-bath + https://wiki.aaps.app/en/latest/EN/Getting-Started/Screenshots.html#the-homescreen + https://wiki.aaps.app/en/latest/EN/Getting-Started/Screenshots.html#config-builder + https://wiki.aaps.app/en/latest/EN/Getting-Started/Screenshots.html#the-homescreen Not connected to the internet Failed retrieve time Objective requirements not met diff --git a/pump/combo/src/main/res/values/strings.xml b/pump/combo/src/main/res/values/strings.xml index d107602291..d9d248cebc 100644 --- a/pump/combo/src/main/res/values/strings.xml +++ b/pump/combo/src/main/res/values/strings.xml @@ -46,7 +46,7 @@ Basal rate changed on pump, but reading it failed Checking for history changes Multiple boluses with the same amount within the same minute were just imported. Only one record could be added to treatments. Please check the pump and manually add a bolus record using the Careportal tab. Make sure to create a bolus with a time no other bolus uses. - \n\ndocumentation:\nhttps://androidaps.readthedocs.io\n\nfacebook:\nhttps://www.facebook.com/groups/AndroidAPSUsers + \n\ndocumentation:\nhttps://wiki.aaps.app\n\nfacebook:\nhttps://www.facebook.com/groups/AndroidAPSUsers The last bolus is older than 24 hours or is in the future. Please check the date on the pump is set correctly. Time/date of the delivered bolus on pump seems wrong, IOB is likely incorrect. Please check pump time/date. Bolus count