repo time

Dependencies:   mbed MAX14720 MAX30205 USBDevice

Committer:
darienf
Date:
Tue Apr 06 06:41:40 2021 +0000
Revision:
20:6d2af70c92ab
another repo

Who changed what in which revision?

UserRevisionLine numberNew contents of line
darienf 20:6d2af70c92ab 1 /*******************************************************************************
darienf 20:6d2af70c92ab 2 * Copyright (C) 2016 Maxim Integrated Products, Inc., All rights Reserved.
darienf 20:6d2af70c92ab 3 *
darienf 20:6d2af70c92ab 4 * This software is protected by copyright laws of the United States and
darienf 20:6d2af70c92ab 5 * of foreign countries. This material may also be protected by patent laws
darienf 20:6d2af70c92ab 6 * and technology transfer regulations of the United States and of foreign
darienf 20:6d2af70c92ab 7 * countries. This software is furnished under a license agreement and/or a
darienf 20:6d2af70c92ab 8 * nondisclosure agreement and may only be used or reproduced in accordance
darienf 20:6d2af70c92ab 9 * with the terms of those agreements. Dissemination of this information to
darienf 20:6d2af70c92ab 10 * any party or parties not specified in the license agreement and/or
darienf 20:6d2af70c92ab 11 * nondisclosure agreement is expressly prohibited.
darienf 20:6d2af70c92ab 12 *
darienf 20:6d2af70c92ab 13 * The above copyright notice and this permission notice shall be included
darienf 20:6d2af70c92ab 14 * in all copies or substantial portions of the Software.
darienf 20:6d2af70c92ab 15 *
darienf 20:6d2af70c92ab 16 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
darienf 20:6d2af70c92ab 17 * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
darienf 20:6d2af70c92ab 18 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
darienf 20:6d2af70c92ab 19 * IN NO EVENT SHALL MAXIM INTEGRATED BE LIABLE FOR ANY CLAIM, DAMAGES
darienf 20:6d2af70c92ab 20 * OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
darienf 20:6d2af70c92ab 21 * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
darienf 20:6d2af70c92ab 22 * OTHER DEALINGS IN THE SOFTWARE.
darienf 20:6d2af70c92ab 23 *
darienf 20:6d2af70c92ab 24 * Except as contained in this notice, the name of Maxim Integrated
darienf 20:6d2af70c92ab 25 * Products, Inc. shall not be used except as stated in the Maxim Integrated
darienf 20:6d2af70c92ab 26 * Products, Inc. Branding Policy.
darienf 20:6d2af70c92ab 27 *
darienf 20:6d2af70c92ab 28 * The mere transfer of this software does not imply any licenses
darienf 20:6d2af70c92ab 29 * of trade secrets, proprietary technology, copyrights, patents,
darienf 20:6d2af70c92ab 30 * trademarks, maskwork rights, or any other form of intellectual
darienf 20:6d2af70c92ab 31 * property whatsoever. Maxim Integrated Products, Inc. retains all
darienf 20:6d2af70c92ab 32 * ownership rights.
darienf 20:6d2af70c92ab 33 *******************************************************************************
darienf 20:6d2af70c92ab 34 */
darienf 20:6d2af70c92ab 35
darienf 20:6d2af70c92ab 36 using System;
darienf 20:6d2af70c92ab 37 using System.Collections.Generic;
darienf 20:6d2af70c92ab 38 using System.Linq;
darienf 20:6d2af70c92ab 39 using System.Text;
darienf 20:6d2af70c92ab 40
darienf 20:6d2af70c92ab 41 using HealthSensorPlatform.View;
darienf 20:6d2af70c92ab 42 using HealthSensorPlatform.CustomControls;
darienf 20:6d2af70c92ab 43
darienf 20:6d2af70c92ab 44 using RPCSupport.Streaming;
darienf 20:6d2af70c92ab 45
darienf 20:6d2af70c92ab 46 namespace HealthSensorPlatform.Presenter
darienf 20:6d2af70c92ab 47 {
darienf 20:6d2af70c92ab 48 public class OpticalFileLogPresenter
darienf 20:6d2af70c92ab 49 {
darienf 20:6d2af70c92ab 50 IRawFileLogView optical;
darienf 20:6d2af70c92ab 51 IRawFileLogView accel;
darienf 20:6d2af70c92ab 52 HspForm mainForm;
darienf 20:6d2af70c92ab 53 OpticalView opticalView;
darienf 20:6d2af70c92ab 54
darienf 20:6d2af70c92ab 55 string logFileDirectory = null;
darienf 20:6d2af70c92ab 56
darienf 20:6d2af70c92ab 57 int ppgCount = 0;
darienf 20:6d2af70c92ab 58 int accelCount = 0;
darienf 20:6d2af70c92ab 59
darienf 20:6d2af70c92ab 60 public OpticalFileLogPresenter(RPCSupport.RPCClient rpcClient, HspForm mainForm, OpticalView opticalView, IRawFileLogView optical, IRawFileLogView accel)
darienf 20:6d2af70c92ab 61 {
darienf 20:6d2af70c92ab 62 this.optical = optical;
darienf 20:6d2af70c92ab 63 this.accel = accel;
darienf 20:6d2af70c92ab 64 this.mainForm = mainForm;
darienf 20:6d2af70c92ab 65 this.opticalView = opticalView;
darienf 20:6d2af70c92ab 66
darienf 20:6d2af70c92ab 67 rpcClient.streaming.PartialArrayIntAvailable += new EventHandler<PartialArrayIntAvailableEventArgs>(OnStreamData);
darienf 20:6d2af70c92ab 68 mainForm.OpticalFileLogEnable += new EventHandler<EnableEventArgs>(OnFileLogEnable);
darienf 20:6d2af70c92ab 69 //opticalView.StreamingStartStop += new OpticalView.StreamingStartStopEventHandler(OnStreamingStartStop);
darienf 20:6d2af70c92ab 70 opticalView.StreamingStartStop += new EventHandler<StreamingStartStopEventArgs>(OnStreamingStartStop);
darienf 20:6d2af70c92ab 71 }
darienf 20:6d2af70c92ab 72
darienf 20:6d2af70c92ab 73 public void ProcessOptical(int[] red, int[] ir, int[] green)
darienf 20:6d2af70c92ab 74 {
darienf 20:6d2af70c92ab 75 double[] time = new double[red.Length];
darienf 20:6d2af70c92ab 76
darienf 20:6d2af70c92ab 77 for (int i = 0; i < time.Length; i++ )
darienf 20:6d2af70c92ab 78 {
darienf 20:6d2af70c92ab 79 time[i] = ppgCount / (double)opticalView.OpticalSampleRate;
darienf 20:6d2af70c92ab 80 ppgCount++;
darienf 20:6d2af70c92ab 81 }
darienf 20:6d2af70c92ab 82
darienf 20:6d2af70c92ab 83 optical.DisplayPpg(time, new int[][] { red, ir, green });
darienf 20:6d2af70c92ab 84 }
darienf 20:6d2af70c92ab 85
darienf 20:6d2af70c92ab 86 public void ProcessXYZ(int[] x, int[] y, int[] z)
darienf 20:6d2af70c92ab 87 {
darienf 20:6d2af70c92ab 88 int[] decimalFormatX;
darienf 20:6d2af70c92ab 89 int[] decimalFormatY;
darienf 20:6d2af70c92ab 90 int[] decimalFormatZ;
darienf 20:6d2af70c92ab 91 double[] time = new double[x.Length];
darienf 20:6d2af70c92ab 92
darienf 20:6d2af70c92ab 93 decimalFormatX = ConvertXYZBinary(x);
darienf 20:6d2af70c92ab 94 decimalFormatY = ConvertXYZBinary(y);
darienf 20:6d2af70c92ab 95 decimalFormatZ = ConvertXYZBinary(z);
darienf 20:6d2af70c92ab 96
darienf 20:6d2af70c92ab 97 for (int i = 0; i < time.Length; i++ )
darienf 20:6d2af70c92ab 98 {
darienf 20:6d2af70c92ab 99 time[i] = accelCount / (double)opticalView.AccelSampleRate;
darienf 20:6d2af70c92ab 100 accelCount++;
darienf 20:6d2af70c92ab 101 }
darienf 20:6d2af70c92ab 102
darienf 20:6d2af70c92ab 103 accel.DisplayXYZ(time, new int[][] { decimalFormatX, decimalFormatY, decimalFormatZ });
darienf 20:6d2af70c92ab 104 }
darienf 20:6d2af70c92ab 105
darienf 20:6d2af70c92ab 106 public static int[] ConvertXYZBinary(int[] data)
darienf 20:6d2af70c92ab 107 {
darienf 20:6d2af70c92ab 108 int[] decimalFormat = new int[data.Length];
darienf 20:6d2af70c92ab 109
darienf 20:6d2af70c92ab 110 for (int i = 0; i < data.Length; i++)
darienf 20:6d2af70c92ab 111 {
darienf 20:6d2af70c92ab 112 if (data[i] > 0x8000)
darienf 20:6d2af70c92ab 113 decimalFormat[i] = data[i] - 0x10000;
darienf 20:6d2af70c92ab 114 else
darienf 20:6d2af70c92ab 115 decimalFormat[i] = data[i];
darienf 20:6d2af70c92ab 116 }
darienf 20:6d2af70c92ab 117
darienf 20:6d2af70c92ab 118 return decimalFormat;
darienf 20:6d2af70c92ab 119 }
darienf 20:6d2af70c92ab 120
darienf 20:6d2af70c92ab 121 public void OnStreamData(object sender, PartialArrayIntAvailableEventArgs e)
darienf 20:6d2af70c92ab 122 {
darienf 20:6d2af70c92ab 123 if ((e.reportID & 0xF0) == PartialArrayIntAvailableEventArgs.PACKET_MAX30101)
darienf 20:6d2af70c92ab 124 {
darienf 20:6d2af70c92ab 125 if (optical.Enable)
darienf 20:6d2af70c92ab 126 ProcessOptical(e.array1, e.array2, e.array3);
darienf 20:6d2af70c92ab 127 }
darienf 20:6d2af70c92ab 128 if (e.reportID == PartialArrayIntAvailableEventArgs.PACKET_LIS2DH)
darienf 20:6d2af70c92ab 129 {
darienf 20:6d2af70c92ab 130 if (accel.Enable)
darienf 20:6d2af70c92ab 131 ProcessXYZ(e.array1, e.array2, e.array3);
darienf 20:6d2af70c92ab 132 }
darienf 20:6d2af70c92ab 133 }
darienf 20:6d2af70c92ab 134
darienf 20:6d2af70c92ab 135 void OnFileLogEnable(object sender, EnableEventArgs e)
darienf 20:6d2af70c92ab 136 {
darienf 20:6d2af70c92ab 137 optical = new RawFileLogView();
darienf 20:6d2af70c92ab 138 accel = new RawFileLogView();
darienf 20:6d2af70c92ab 139
darienf 20:6d2af70c92ab 140 if (logFileDirectory != null)
darienf 20:6d2af70c92ab 141 {
darienf 20:6d2af70c92ab 142 optical.FileDirectory = logFileDirectory;
darienf 20:6d2af70c92ab 143 //accel.FileDirectory = logFileDirectory;
darienf 20:6d2af70c92ab 144 }
darienf 20:6d2af70c92ab 145
darienf 20:6d2af70c92ab 146 if (e.Enable && e.Stream == StreamType.Optical && optical.SelectCSVFile("hsp-optical"))
darienf 20:6d2af70c92ab 147 {
darienf 20:6d2af70c92ab 148 accel.FileDirectory = optical.FileDirectory;
darienf 20:6d2af70c92ab 149 if (accel.SelectCSVFile("hsp-accel"))
darienf 20:6d2af70c92ab 150 {
darienf 20:6d2af70c92ab 151 mainForm.OpticalLogFileItem(true);
darienf 20:6d2af70c92ab 152 optical.Enable = true;
darienf 20:6d2af70c92ab 153 accel.Enable = true;
darienf 20:6d2af70c92ab 154 logFileDirectory = optical.FileDirectory;
darienf 20:6d2af70c92ab 155 }
darienf 20:6d2af70c92ab 156 }
darienf 20:6d2af70c92ab 157 else
darienf 20:6d2af70c92ab 158 {
darienf 20:6d2af70c92ab 159 mainForm.OpticalLogFileItem(false);
darienf 20:6d2af70c92ab 160 optical.Enable = false;
darienf 20:6d2af70c92ab 161 accel.Enable = false;
darienf 20:6d2af70c92ab 162 }
darienf 20:6d2af70c92ab 163 }
darienf 20:6d2af70c92ab 164
darienf 20:6d2af70c92ab 165 void OnStreamingStartStop(object sender, StreamingStartStopEventArgs e)
darienf 20:6d2af70c92ab 166 {
darienf 20:6d2af70c92ab 167 if (e.state == true)
darienf 20:6d2af70c92ab 168 {
darienf 20:6d2af70c92ab 169 View.FileLogView.FileLogHeader fileLogHeader = new View.FileLogView.FileLogHeader();
darienf 20:6d2af70c92ab 170 ppgCount = 0;
darienf 20:6d2af70c92ab 171 accelCount = 0;
darienf 20:6d2af70c92ab 172
darienf 20:6d2af70c92ab 173 if (optical.Enable == true)
darienf 20:6d2af70c92ab 174 {
darienf 20:6d2af70c92ab 175 optical.WriteLine(opticalView.SettingsString());
darienf 20:6d2af70c92ab 176 optical.WriteLine(fileLogHeader.Optical);
darienf 20:6d2af70c92ab 177 }
darienf 20:6d2af70c92ab 178 if (accel.Enable == true)
darienf 20:6d2af70c92ab 179 {
darienf 20:6d2af70c92ab 180 accel.WriteLine(opticalView.AccelSettingString());
darienf 20:6d2af70c92ab 181 accel.WriteLine(fileLogHeader.Accelerometer);
darienf 20:6d2af70c92ab 182
darienf 20:6d2af70c92ab 183 // Try to have "0" be the same on both files
darienf 20:6d2af70c92ab 184 optical.StreamStartStop();
darienf 20:6d2af70c92ab 185 accel.StreamStartStop();
darienf 20:6d2af70c92ab 186 }
darienf 20:6d2af70c92ab 187
darienf 20:6d2af70c92ab 188 }
darienf 20:6d2af70c92ab 189 else
darienf 20:6d2af70c92ab 190 {
darienf 20:6d2af70c92ab 191 optical.Enable = false;
darienf 20:6d2af70c92ab 192 accel.Enable = false;
darienf 20:6d2af70c92ab 193
darienf 20:6d2af70c92ab 194 mainForm.LogFileItem(StreamType.Optical, false);
darienf 20:6d2af70c92ab 195 }
darienf 20:6d2af70c92ab 196 }
darienf 20:6d2af70c92ab 197 }
darienf 20:6d2af70c92ab 198 }