Darien Figueroa / Mbed OS Final_Program

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
darienf 3:36de8b9e4b1a 41 using Maxim.MAX30101GUI;
darienf 3:36de8b9e4b1a 42 using HealthSensorPlatform.View;
darienf 3:36de8b9e4b1a 43 using HealthSensorPlatform.CustomControls;
darienf 3:36de8b9e4b1a 44 using RPCSupport;
darienf 3:36de8b9e4b1a 45 using RPCSupport.Streaming;
darienf 3:36de8b9e4b1a 46
darienf 3:36de8b9e4b1a 47 namespace HealthSensorPlatform.Presenter
darienf 3:36de8b9e4b1a 48 {
darienf 3:36de8b9e4b1a 49 class OpticalAlgorithmPresenter
darienf 3:36de8b9e4b1a 50 {
darienf 3:36de8b9e4b1a 51 private MaximAlgorithmClass algorithm;
darienf 3:36de8b9e4b1a 52 private IOpticalAlgorithmView view;
darienf 3:36de8b9e4b1a 53
darienf 3:36de8b9e4b1a 54 private bool streaming;
darienf 3:36de8b9e4b1a 55 private int count;
darienf 3:36de8b9e4b1a 56
darienf 3:36de8b9e4b1a 57 private bool validRed = false;
darienf 3:36de8b9e4b1a 58 private bool validGreen = false;
darienf 3:36de8b9e4b1a 59 private bool validIR = false;
darienf 3:36de8b9e4b1a 60
darienf 3:36de8b9e4b1a 61 public OpticalAlgorithmPresenter(RPCClient rpcClient, MaximAlgorithmClass algorithm, IOpticalAlgorithmView view)
darienf 3:36de8b9e4b1a 62 {
darienf 3:36de8b9e4b1a 63 this.algorithm = algorithm;
darienf 3:36de8b9e4b1a 64 this.view = view;
darienf 3:36de8b9e4b1a 65
darienf 3:36de8b9e4b1a 66 //((OpticalView)view).StreamingStartStop += new OpticalView.StreamingStartStopEventHandler(OnStreamingStartStop);
darienf 3:36de8b9e4b1a 67 ((OpticalView)view).StreamingStartStop += new EventHandler<StreamingStartStopEventArgs>(OnStreamingStartStop);
darienf 3:36de8b9e4b1a 68 rpcClient.streaming.PartialArrayIntAvailable += new EventHandler<PartialArrayIntAvailableEventArgs>(OnPartialArrayIntAvaible);
darienf 3:36de8b9e4b1a 69 algorithm.OnHeartRateSpO2dataAvailable += OnHeartRateSpO2DataAvailable; // view.DisplayAlgorithmResult;
darienf 3:36de8b9e4b1a 70 }
darienf 3:36de8b9e4b1a 71
darienf 3:36de8b9e4b1a 72 public void OnHeartRateSpO2DataAvailable(double heartRateBPM, bool heartRateBPMValid, double heartRateBPMSignalStrength,
darienf 3:36de8b9e4b1a 73 double spO2Percent, bool spO2PercentValid, double spO2PercentSignalStrength)
darienf 3:36de8b9e4b1a 74 {
darienf 3:36de8b9e4b1a 75 view.DisplayAlgorithmResult(heartRateBPM, heartRateBPMValid, heartRateBPMSignalStrength,
darienf 3:36de8b9e4b1a 76 spO2Percent, spO2PercentValid, spO2PercentSignalStrength);
darienf 3:36de8b9e4b1a 77 }
darienf 3:36de8b9e4b1a 78
darienf 3:36de8b9e4b1a 79 public void OnStreamingStartStop(object sender, StreamingStartStopEventArgs e)
darienf 3:36de8b9e4b1a 80 {
darienf 3:36de8b9e4b1a 81 streaming = e.state;
darienf 3:36de8b9e4b1a 82 count = 0;
darienf 3:36de8b9e4b1a 83 if (streaming)
darienf 3:36de8b9e4b1a 84 {
darienf 3:36de8b9e4b1a 85 algorithm.Clear();
darienf 3:36de8b9e4b1a 86 view.DisplayAlgorithmReset();
darienf 3:36de8b9e4b1a 87 switch (((OpticalView)view).ModeConfiguration)
darienf 3:36de8b9e4b1a 88 {
darienf 3:36de8b9e4b1a 89 case OpticalView.eStreamMode.eHR:
darienf 3:36de8b9e4b1a 90 validRed = true;
darienf 3:36de8b9e4b1a 91 validIR = false;
darienf 3:36de8b9e4b1a 92 validGreen = false;
darienf 3:36de8b9e4b1a 93 break;
darienf 3:36de8b9e4b1a 94 case OpticalView.eStreamMode.eSPO2:
darienf 3:36de8b9e4b1a 95 validRed = true;
darienf 3:36de8b9e4b1a 96 validIR = true;
darienf 3:36de8b9e4b1a 97 validGreen = false;
darienf 3:36de8b9e4b1a 98 break;
darienf 3:36de8b9e4b1a 99 case OpticalView.eStreamMode.eMulti:
darienf 3:36de8b9e4b1a 100 validRed = true;
darienf 3:36de8b9e4b1a 101 validIR = true;
darienf 3:36de8b9e4b1a 102 validGreen = true;
darienf 3:36de8b9e4b1a 103 break;
darienf 3:36de8b9e4b1a 104 }
darienf 3:36de8b9e4b1a 105 }
darienf 3:36de8b9e4b1a 106 }
darienf 3:36de8b9e4b1a 107
darienf 3:36de8b9e4b1a 108 public void OnPartialArrayIntAvaible(object sender, PartialArrayIntAvailableEventArgs e)
darienf 3:36de8b9e4b1a 109 {
darienf 3:36de8b9e4b1a 110 int numSamples;
darienf 3:36de8b9e4b1a 111
darienf 3:36de8b9e4b1a 112 if (streaming)
darienf 3:36de8b9e4b1a 113 {
darienf 3:36de8b9e4b1a 114 if ((e.reportID & 0xF0) == PartialArrayIntAvailableEventArgs.PACKET_MAX30101)
darienf 3:36de8b9e4b1a 115 {
darienf 3:36de8b9e4b1a 116 numSamples = e.array1.Length;
darienf 3:36de8b9e4b1a 117
darienf 3:36de8b9e4b1a 118 for (int i = 0; i < numSamples; i++)
darienf 3:36de8b9e4b1a 119 {
darienf 3:36de8b9e4b1a 120 int red = 0, ir = 0, green = 0;
darienf 3:36de8b9e4b1a 121
darienf 3:36de8b9e4b1a 122 if (e.array1.Length != 0)
darienf 3:36de8b9e4b1a 123 {
darienf 3:36de8b9e4b1a 124 red = e.array1[i];
darienf 3:36de8b9e4b1a 125 }
darienf 3:36de8b9e4b1a 126 if (e.array2.Length != 0)
darienf 3:36de8b9e4b1a 127 {
darienf 3:36de8b9e4b1a 128 ir = e.array2[i];
darienf 3:36de8b9e4b1a 129 }
darienf 3:36de8b9e4b1a 130 if (e.array3.Length != 0)
darienf 3:36de8b9e4b1a 131 {
darienf 3:36de8b9e4b1a 132 green = e.array3[i];
darienf 3:36de8b9e4b1a 133 }
darienf 3:36de8b9e4b1a 134
darienf 3:36de8b9e4b1a 135 algorithm.ConsumeRedIRGreenLEDdata(count, ir, red, green, validIR, validRed, validGreen);
darienf 3:36de8b9e4b1a 136 count++;
darienf 3:36de8b9e4b1a 137 }
darienf 3:36de8b9e4b1a 138 }
darienf 3:36de8b9e4b1a 139 }
darienf 3:36de8b9e4b1a 140 }
darienf 3:36de8b9e4b1a 141 }
darienf 3:36de8b9e4b1a 142 }