repo time
Dependencies: mbed MAX14720 MAX30205 USBDevice
Diff: HspGuiSourceV301/EcgViewTest/RToRTest.cs
- Revision:
- 20:6d2af70c92ab
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/HspGuiSourceV301/EcgViewTest/RToRTest.cs Tue Apr 06 06:41:40 2021 +0000 @@ -0,0 +1,168 @@ +/******************************************************************************* +* Copyright (C) 2016 Maxim Integrated Products, Inc., All rights Reserved. +* +* This software is protected by copyright laws of the United States and +* of foreign countries. This material may also be protected by patent laws +* and technology transfer regulations of the United States and of foreign +* countries. This software is furnished under a license agreement and/or a +* nondisclosure agreement and may only be used or reproduced in accordance +* with the terms of those agreements. Dissemination of this information to +* any party or parties not specified in the license agreement and/or +* nondisclosure agreement is expressly prohibited. +* +* The above copyright notice and this permission notice shall be included +* in all copies or substantial portions of the Software. +* +* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS +* OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +* IN NO EVENT SHALL MAXIM INTEGRATED BE LIABLE FOR ANY CLAIM, DAMAGES +* OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, +* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR +* OTHER DEALINGS IN THE SOFTWARE. +* +* Except as contained in this notice, the name of Maxim Integrated +* Products, Inc. shall not be used except as stated in the Maxim Integrated +* Products, Inc. Branding Policy. +* +* The mere transfer of this software does not imply any licenses +* of trade secrets, proprietary technology, copyrights, patents, +* trademarks, maskwork rights, or any other form of intellectual +* property whatsoever. Maxim Integrated Products, Inc. retains all +* ownership rights. +******************************************************************************* +*/ + +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +using NUnit.Framework; +using HealthSensorPlatform.CustomControls; +using HealthSensorPlatform.Presenter; + +namespace EcgViewTest +{ + class RToRTest + { + [TestCase(8746, 0)] + [TestCase(9002, 1)] + [TestCase(12586, 15)] + public void RToRDetectionDelay(int expect, int rToRWndw) + { + EcgView view = new EcgView(); + + view.RToRWindowField = rToRWndw; + + Assert.AreEqual(expect, view.RToRDelay); + } + + [TestCase(650, 0, 0, 0)] + [TestCase(1034, 0, 0, 1)] + [TestCase(1034, 0, 0, 2)] + [TestCase(1034, 0, 0, 3)] + [TestCase(2922, 0, 1, 0)] + [TestCase(3370, 0, 2, 0)] + [TestCase(3370, 0, 3, 0)] + [TestCase(1242, 2, 2, 0)] + [TestCase(1242, 3, 2, 0)] + [TestCase(1242, 3, 3, 0)] + [TestCase(2202, 3, 3, 1)] + public void EcgDecimationDelay(int expect, int masterClock, int rate, int lpf) + { + EcgView view = new EcgView(); + InitArgs.EcgInitStart ecgInit = new InitArgs.EcgInitStart(); + + ecgInit.Rate = rate; + ecgInit.Dlpf = lpf; + + view.ecgArgs = ecgInit; + view.FrequencyMasterField = masterClock; + + Assert.AreEqual(expect, view.EcgDecimationDelay); + } + + /* + [TestCase(100, 118)] + public void RToRToEcgPoints(int expect, int rToR) + { + EcgView view = new EcgView(); + InitArgs.EcgInitStart ecgInit = new InitArgs.EcgInitStart(); + + ecgInit.Rate = 3; + ecgInit.Dlpf = 1; + + view.ecgArgs = ecgInit; + view.FrequencyMasterField = 0; + view.RToRWindowField = 3; + + Assert.AreEqual(expect, view.RToREcgPoints(rToR, true)); + } + + [TestCase(205, 128, 1)] + [TestCase(205, 128, 2)] + [TestCase(204, 128, 3)] + [TestCase(205, 128, 4)] + [TestCase(205, 128, 5)] + [TestCase(205, 128, 6)] + [TestCase(205, 128, 7)] + [TestCase(204, 128, 8)] + [TestCase(205, 128, 9)] + [TestCase(205, 128, 10)] + [TestCase(205, 128, 11)] + [TestCase(205, 128, 12)] + [TestCase(204, 128, 13)] + public void RToREcgPointRoundingLoop(int expect, int rToR, int loop) + { + int result = 0; + + EcgView view = new EcgView(); + InitArgs.EcgInitStart ecgInit = new InitArgs.EcgInitStart(); + + ecgInit.Rate = 3; + ecgInit.Dlpf = 1; + + view.SampleRateECG = 199.8; + + view.ecgArgs = ecgInit; + view.FrequencyMasterField = 3; + + for (int i = 0; i < loop; i++) + { + result = view.RToREcgPoints(rToR, false); + } + + Assert.AreEqual(expect, result); + } + * */ + + [TestCase(205, 128, 1)] + [TestCase(205, 128, 2)] + [TestCase(204, 128, 3)] + [TestCase(205, 128, 4)] + [TestCase(205, 128, 5)] + [TestCase(205, 128, 6)] + [TestCase(205, 128, 7)] + [TestCase(204, 128, 8)] + [TestCase(205, 128, 9)] + [TestCase(205, 128, 10)] + [TestCase(205, 128, 11)] + [TestCase(205, 128, 12)] + [TestCase(204, 128, 13)] + public void RToRCalculatorRoundingLoop(int expect, int rToR, int loop) + { + int result = 0; + + RToRCalculator rToRCalculator = new RToRCalculator(3, 3, 1, 0); + + for (int i = 0; i < loop; i++) + { + result = rToRCalculator.EcgPoints(rToR, false); + } + + Assert.AreEqual(expect, result); + } + } +}