repo time

Dependencies:   mbed MAX14720 MAX30205 USBDevice

HspGuiSourceV301/HSPGui/Algorithm/MaximAlgorithmClass.cs

Committer:
darienf
Date:
2021-04-06
Revision:
20:6d2af70c92ab

File content as of revision 20:6d2af70c92ab:

/*******************************************************************************
* 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;

//------------------------------------------------------------------------------------------
// OS24EVK-59 split into HeartRateApp EXE and MAX30101 DLL.
// Moved all MAX30101 DLL classes into namespace Maxim.MAX30101GUI
// Moved all HeartRateApp GUI classes into namespace Maxim.MAX30101
// OS24EVK-59 Create separate project that builds Maxim.MAX30101GUI DLL library

namespace Maxim.MAX30101GUI
{
    /// <summary>
    /// Base class common to any HeartRate / SpO2 algorithm.
    /// Input is Red / IR / Green LED data, output is Heart Rate and SpO2.
    /// </summary>
    public class MaximAlgorithmClass : InterfaceRedIRGreenLEDdataConsumer
    {
        public MaximAlgorithmClass() 
        {
            Name = "Maxim Generic Algorithm Base Class";
        }

        public string Name;
        public int _sampleNumber;
        public int _sampleNumberLastValidHR;
        public int _sampleNumberLastValidSpO2;

        public double _heartRateBPM;
        public bool   _heartRateBPMValid;
        public double _heartRateBPMSignalStrength;
        public double _spO2Percent;
        public bool   _spO2PercentValid;
        public double _spO2PercentSignalStrength;

        /// <summary>
        /// Clear any internal class members,
        /// in response to startMonitorToolStripMenuItem
        /// </summary>
        public virtual void Clear()
        {
        }

        /// <summary>
        /// <para>InterfaceRedIRGreenLEDdataConsumer</para>
        /// <para>Producer-Consumer data sink for
        /// raw Red/IR/Green LED data.
        /// Produced by MAX30101, consumed by algorithm.
        /// </para>
        /// </summary>
        /// <param name="sampleNumber"></param>
        /// <param name="rawIR"></param>
        /// <param name="rawRed"></param>
        /// <param name="rawGreen"></param>
        /// <param name="rawIRvalid"></param>
        /// <param name="rawRedvalid"></param>
        /// <param name="rawGreenvalid"></param>
        public virtual void ConsumeRedIRGreenLEDdata(
                int sampleNumber,
                int rawIR,
                int rawRed,
                int rawGreen,
                bool rawIRvalid,
                bool rawRedvalid,
                bool rawGreenvalid
            )
        {
            _sampleNumber = sampleNumber;
        }

        // prepare for OS24EVK-37 by adding SensorTemperatureDegreesC(double) to InterfaceRedIRGreenLEDdataConsumer
        public double _temperatureDegreesC;

        /// <summary>
        /// <para>Temperature measured at MAX30101, optionally used by algorithm to estimate actual Red LED wavelength.</para>
        /// </summary>
        /// <param name="temperatureDegreesC"></param>
        public void SensorTemperatureDegreesC(double temperatureDegreesC)
        {
            _temperatureDegreesC = temperatureDegreesC;
        }

        /// <summary>
        /// <para>Delegate type for event <see cref="OnHeartRateSpO2dataAvailable"/></para>
        /// </summary>
        /// <param name="heartRateBPM"></param>
        /// <param name="heartRateBPMValid"></param>
        /// <param name="heartRateBPMSignalStrength"></param>
        /// <param name="spO2Percent"></param>
        /// <param name="spO2PercentValid"></param>
        /// <param name="spO2PercentSignalStrength"></param>
        public delegate void OnHeartRateSpO2dataAvailableHandler(
                double heartRateBPM,
                bool   heartRateBPMValid,
                double heartRateBPMSignalStrength,
                double spO2Percent,
                bool   spO2PercentValid,
                double spO2PercentSignalStrength
            );

        /// <summary>
        /// <para>Occurs when HeartRate Data Available Event happens.
        /// </para>
        /// <para>An algorithm reports its results by invoking
        /// <code>OnHeartRateSpO2dataAvailable(heartRateBPM, heartRateBPMValid, heartRateBPMSignalStrength, spO2Percent, spO2PercentValid, spO2PercentSignalStrength);</code>
        /// </para>
        /// </summary>
        public event OnHeartRateSpO2dataAvailableHandler OnHeartRateSpO2dataAvailable;

        /// <summary>
        /// Report the results of running the algorithm,
        /// by firing the OnHeartRateSpO2dataAvailable event.
        /// </summary>
        /// <param name="heartRateBPM"></param>
        /// <param name="heartRateBPMValid"></param>
        /// <param name="heartRateBPMSignalStrength"></param>
        /// <param name="spO2Percent"></param>
        /// <param name="spO2PercentValid"></param>
        /// <param name="spO2PercentSignalStrength"></param>
        public void ReportResultsHeartRateSpO2dataAvailable(
                double heartRateBPM,
                bool heartRateBPMValid,
                double heartRateBPMSignalStrength,
                double spO2Percent,
                bool spO2PercentValid,
                double spO2PercentSignalStrength
            )
        {
            _heartRateBPM = heartRateBPM;
            _heartRateBPMValid = heartRateBPMValid;
            _heartRateBPMSignalStrength = heartRateBPMSignalStrength;
            _spO2Percent = spO2Percent;
            _spO2PercentValid = spO2PercentValid;
            _spO2PercentSignalStrength = spO2PercentSignalStrength;
            if (heartRateBPMValid)
            {
                _sampleNumberLastValidHR = _sampleNumber;
            }
            if (spO2PercentValid)
            {
                _sampleNumberLastValidSpO2 = _sampleNumber;
            }
            if (OnHeartRateSpO2dataAvailable != null)
            {
                OnHeartRateSpO2dataAvailable(heartRateBPM, heartRateBPMValid, heartRateBPMSignalStrength, spO2Percent, spO2PercentValid, spO2PercentSignalStrength);
            }
        }

    }
}