This is the latest working repository used in our demo video for the Maxim to display temperature readings on Bluetooth

Dependencies:   USBDevice

Committer:
darienf
Date:
Sun May 02 23:09:04 2021 +0000
Revision:
5:bc128a16232f
Parent:
3:36de8b9e4b1a
This is the program that was last used, that has the working temperature and some comments

Who changed what in which revision?

UserRevisionLine numberNew contents of line
darienf 3:36de8b9e4b1a 1 /*******************************************************************************
darienf 3:36de8b9e4b1a 2 * Copyright (C) 2016 Maxim Integrated Products, Inc., All rights Reserved.
darienf 3:36de8b9e4b1a 3 *
darienf 3:36de8b9e4b1a 4 * This software is protected by copyright laws of the United States and
darienf 3:36de8b9e4b1a 5 * of foreign countries. This material may also be protected by patent laws
darienf 3:36de8b9e4b1a 6 * and technology transfer regulations of the United States and of foreign
darienf 3:36de8b9e4b1a 7 * countries. This software is furnished under a license agreement and/or a
darienf 3:36de8b9e4b1a 8 * nondisclosure agreement and may only be used or reproduced in accordance
darienf 3:36de8b9e4b1a 9 * with the terms of those agreements. Dissemination of this information to
darienf 3:36de8b9e4b1a 10 * any party or parties not specified in the license agreement and/or
darienf 3:36de8b9e4b1a 11 * nondisclosure agreement is expressly prohibited.
darienf 3:36de8b9e4b1a 12 *
darienf 3:36de8b9e4b1a 13 * The above copyright notice and this permission notice shall be included
darienf 3:36de8b9e4b1a 14 * in all copies or substantial portions of the Software.
darienf 3:36de8b9e4b1a 15 *
darienf 3:36de8b9e4b1a 16 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
darienf 3:36de8b9e4b1a 17 * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
darienf 3:36de8b9e4b1a 18 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
darienf 3:36de8b9e4b1a 19 * IN NO EVENT SHALL MAXIM INTEGRATED BE LIABLE FOR ANY CLAIM, DAMAGES
darienf 3:36de8b9e4b1a 20 * OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
darienf 3:36de8b9e4b1a 21 * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
darienf 3:36de8b9e4b1a 22 * OTHER DEALINGS IN THE SOFTWARE.
darienf 3:36de8b9e4b1a 23 *
darienf 3:36de8b9e4b1a 24 * Except as contained in this notice, the name of Maxim Integrated
darienf 3:36de8b9e4b1a 25 * Products, Inc. shall not be used except as stated in the Maxim Integrated
darienf 3:36de8b9e4b1a 26 * Products, Inc. Branding Policy.
darienf 3:36de8b9e4b1a 27 *
darienf 3:36de8b9e4b1a 28 * The mere transfer of this software does not imply any licenses
darienf 3:36de8b9e4b1a 29 * of trade secrets, proprietary technology, copyrights, patents,
darienf 3:36de8b9e4b1a 30 * trademarks, maskwork rights, or any other form of intellectual
darienf 3:36de8b9e4b1a 31 * property whatsoever. Maxim Integrated Products, Inc. retains all
darienf 3:36de8b9e4b1a 32 * ownership rights.
darienf 3:36de8b9e4b1a 33 *******************************************************************************
darienf 3:36de8b9e4b1a 34 */
darienf 3:36de8b9e4b1a 35
darienf 3:36de8b9e4b1a 36 using System;
darienf 3:36de8b9e4b1a 37 using System.Collections.Generic;
darienf 3:36de8b9e4b1a 38 using System.Linq;
darienf 3:36de8b9e4b1a 39 using System.Text;
darienf 3:36de8b9e4b1a 40 using System.Threading.Tasks;
darienf 3:36de8b9e4b1a 41
darienf 3:36de8b9e4b1a 42 using NUnit.Framework;
darienf 3:36de8b9e4b1a 43 using HealthSensorPlatform.CustomControls;
darienf 3:36de8b9e4b1a 44 using HealthSensorPlatform.Presenter;
darienf 3:36de8b9e4b1a 45
darienf 3:36de8b9e4b1a 46 namespace EcgViewTest
darienf 3:36de8b9e4b1a 47 {
darienf 3:36de8b9e4b1a 48 class RToRTest
darienf 3:36de8b9e4b1a 49 {
darienf 3:36de8b9e4b1a 50 [TestCase(8746, 0)]
darienf 3:36de8b9e4b1a 51 [TestCase(9002, 1)]
darienf 3:36de8b9e4b1a 52 [TestCase(12586, 15)]
darienf 3:36de8b9e4b1a 53 public void RToRDetectionDelay(int expect, int rToRWndw)
darienf 3:36de8b9e4b1a 54 {
darienf 3:36de8b9e4b1a 55 EcgView view = new EcgView();
darienf 3:36de8b9e4b1a 56
darienf 3:36de8b9e4b1a 57 view.RToRWindowField = rToRWndw;
darienf 3:36de8b9e4b1a 58
darienf 3:36de8b9e4b1a 59 Assert.AreEqual(expect, view.RToRDelay);
darienf 3:36de8b9e4b1a 60 }
darienf 3:36de8b9e4b1a 61
darienf 3:36de8b9e4b1a 62 [TestCase(650, 0, 0, 0)]
darienf 3:36de8b9e4b1a 63 [TestCase(1034, 0, 0, 1)]
darienf 3:36de8b9e4b1a 64 [TestCase(1034, 0, 0, 2)]
darienf 3:36de8b9e4b1a 65 [TestCase(1034, 0, 0, 3)]
darienf 3:36de8b9e4b1a 66 [TestCase(2922, 0, 1, 0)]
darienf 3:36de8b9e4b1a 67 [TestCase(3370, 0, 2, 0)]
darienf 3:36de8b9e4b1a 68 [TestCase(3370, 0, 3, 0)]
darienf 3:36de8b9e4b1a 69 [TestCase(1242, 2, 2, 0)]
darienf 3:36de8b9e4b1a 70 [TestCase(1242, 3, 2, 0)]
darienf 3:36de8b9e4b1a 71 [TestCase(1242, 3, 3, 0)]
darienf 3:36de8b9e4b1a 72 [TestCase(2202, 3, 3, 1)]
darienf 3:36de8b9e4b1a 73 public void EcgDecimationDelay(int expect, int masterClock, int rate, int lpf)
darienf 3:36de8b9e4b1a 74 {
darienf 3:36de8b9e4b1a 75 EcgView view = new EcgView();
darienf 3:36de8b9e4b1a 76 InitArgs.EcgInitStart ecgInit = new InitArgs.EcgInitStart();
darienf 3:36de8b9e4b1a 77
darienf 3:36de8b9e4b1a 78 ecgInit.Rate = rate;
darienf 3:36de8b9e4b1a 79 ecgInit.Dlpf = lpf;
darienf 3:36de8b9e4b1a 80
darienf 3:36de8b9e4b1a 81 view.ecgArgs = ecgInit;
darienf 3:36de8b9e4b1a 82 view.FrequencyMasterField = masterClock;
darienf 3:36de8b9e4b1a 83
darienf 3:36de8b9e4b1a 84 Assert.AreEqual(expect, view.EcgDecimationDelay);
darienf 3:36de8b9e4b1a 85 }
darienf 3:36de8b9e4b1a 86
darienf 3:36de8b9e4b1a 87 /*
darienf 3:36de8b9e4b1a 88 [TestCase(100, 118)]
darienf 3:36de8b9e4b1a 89 public void RToRToEcgPoints(int expect, int rToR)
darienf 3:36de8b9e4b1a 90 {
darienf 3:36de8b9e4b1a 91 EcgView view = new EcgView();
darienf 3:36de8b9e4b1a 92 InitArgs.EcgInitStart ecgInit = new InitArgs.EcgInitStart();
darienf 3:36de8b9e4b1a 93
darienf 3:36de8b9e4b1a 94 ecgInit.Rate = 3;
darienf 3:36de8b9e4b1a 95 ecgInit.Dlpf = 1;
darienf 3:36de8b9e4b1a 96
darienf 3:36de8b9e4b1a 97 view.ecgArgs = ecgInit;
darienf 3:36de8b9e4b1a 98 view.FrequencyMasterField = 0;
darienf 3:36de8b9e4b1a 99 view.RToRWindowField = 3;
darienf 3:36de8b9e4b1a 100
darienf 3:36de8b9e4b1a 101 Assert.AreEqual(expect, view.RToREcgPoints(rToR, true));
darienf 3:36de8b9e4b1a 102 }
darienf 3:36de8b9e4b1a 103
darienf 3:36de8b9e4b1a 104 [TestCase(205, 128, 1)]
darienf 3:36de8b9e4b1a 105 [TestCase(205, 128, 2)]
darienf 3:36de8b9e4b1a 106 [TestCase(204, 128, 3)]
darienf 3:36de8b9e4b1a 107 [TestCase(205, 128, 4)]
darienf 3:36de8b9e4b1a 108 [TestCase(205, 128, 5)]
darienf 3:36de8b9e4b1a 109 [TestCase(205, 128, 6)]
darienf 3:36de8b9e4b1a 110 [TestCase(205, 128, 7)]
darienf 3:36de8b9e4b1a 111 [TestCase(204, 128, 8)]
darienf 3:36de8b9e4b1a 112 [TestCase(205, 128, 9)]
darienf 3:36de8b9e4b1a 113 [TestCase(205, 128, 10)]
darienf 3:36de8b9e4b1a 114 [TestCase(205, 128, 11)]
darienf 3:36de8b9e4b1a 115 [TestCase(205, 128, 12)]
darienf 3:36de8b9e4b1a 116 [TestCase(204, 128, 13)]
darienf 3:36de8b9e4b1a 117 public void RToREcgPointRoundingLoop(int expect, int rToR, int loop)
darienf 3:36de8b9e4b1a 118 {
darienf 3:36de8b9e4b1a 119 int result = 0;
darienf 3:36de8b9e4b1a 120
darienf 3:36de8b9e4b1a 121 EcgView view = new EcgView();
darienf 3:36de8b9e4b1a 122 InitArgs.EcgInitStart ecgInit = new InitArgs.EcgInitStart();
darienf 3:36de8b9e4b1a 123
darienf 3:36de8b9e4b1a 124 ecgInit.Rate = 3;
darienf 3:36de8b9e4b1a 125 ecgInit.Dlpf = 1;
darienf 3:36de8b9e4b1a 126
darienf 3:36de8b9e4b1a 127 view.SampleRateECG = 199.8;
darienf 3:36de8b9e4b1a 128
darienf 3:36de8b9e4b1a 129 view.ecgArgs = ecgInit;
darienf 3:36de8b9e4b1a 130 view.FrequencyMasterField = 3;
darienf 3:36de8b9e4b1a 131
darienf 3:36de8b9e4b1a 132 for (int i = 0; i < loop; i++)
darienf 3:36de8b9e4b1a 133 {
darienf 3:36de8b9e4b1a 134 result = view.RToREcgPoints(rToR, false);
darienf 3:36de8b9e4b1a 135 }
darienf 3:36de8b9e4b1a 136
darienf 3:36de8b9e4b1a 137 Assert.AreEqual(expect, result);
darienf 3:36de8b9e4b1a 138 }
darienf 3:36de8b9e4b1a 139 * */
darienf 3:36de8b9e4b1a 140
darienf 3:36de8b9e4b1a 141 [TestCase(205, 128, 1)]
darienf 3:36de8b9e4b1a 142 [TestCase(205, 128, 2)]
darienf 3:36de8b9e4b1a 143 [TestCase(204, 128, 3)]
darienf 3:36de8b9e4b1a 144 [TestCase(205, 128, 4)]
darienf 3:36de8b9e4b1a 145 [TestCase(205, 128, 5)]
darienf 3:36de8b9e4b1a 146 [TestCase(205, 128, 6)]
darienf 3:36de8b9e4b1a 147 [TestCase(205, 128, 7)]
darienf 3:36de8b9e4b1a 148 [TestCase(204, 128, 8)]
darienf 3:36de8b9e4b1a 149 [TestCase(205, 128, 9)]
darienf 3:36de8b9e4b1a 150 [TestCase(205, 128, 10)]
darienf 3:36de8b9e4b1a 151 [TestCase(205, 128, 11)]
darienf 3:36de8b9e4b1a 152 [TestCase(205, 128, 12)]
darienf 3:36de8b9e4b1a 153 [TestCase(204, 128, 13)]
darienf 3:36de8b9e4b1a 154 public void RToRCalculatorRoundingLoop(int expect, int rToR, int loop)
darienf 3:36de8b9e4b1a 155 {
darienf 3:36de8b9e4b1a 156 int result = 0;
darienf 3:36de8b9e4b1a 157
darienf 3:36de8b9e4b1a 158 RToRCalculator rToRCalculator = new RToRCalculator(3, 3, 1, 0);
darienf 3:36de8b9e4b1a 159
darienf 3:36de8b9e4b1a 160 for (int i = 0; i < loop; i++)
darienf 3:36de8b9e4b1a 161 {
darienf 3:36de8b9e4b1a 162 result = rToRCalculator.EcgPoints(rToR, false);
darienf 3:36de8b9e4b1a 163 }
darienf 3:36de8b9e4b1a 164
darienf 3:36de8b9e4b1a 165 Assert.AreEqual(expect, result);
darienf 3:36de8b9e4b1a 166 }
darienf 3:36de8b9e4b1a 167 }
darienf 3:36de8b9e4b1a 168 }