max30102问题-Arduino中文社区 - Powered by Discuz!

Arduino中文社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 23032|回复: 17

[未解决] max30102问题

[复制链接]
发表于 2018-10-26 15:37 | 显示全部楼层 |阅读模式
最近网上买了个max30102的心率血氧模块,用卖家给的单个例程的时候数据还算准确,但是我自己把心率和血氧功能整合到了一起,过来的数据就波动比较大了,想请大神们看看,如何修改。 程序如下:#include <Wire.h>#include "MAX30105.h"
#include "heartRate.h"
#include "spo2_algorithm.h"


MAX30105 particleSensor;


#define MAX_BRIGHTNESS 255


#if defined(__AVR_ATmega328P__) || defined(__AVR_ATmega168__)
//Arduino Uno doesn't have enough SRAM to store 100 samples of IR led data and red led data in 32-bit format
//To solve this problem, 16-bit MSB of the sampled data will be truncated. Samples become 16-bit data.
uint16_t irBuffer[100]; //infrared LED sensor data
uint16_t redBuffer[100];  //red LED sensor data
#else
uint32_t irBuffer[100]; //infrared LED sensor data
uint32_t redBuffer[100];  //red LED sensor data
#endif


int32_t bufferLength; //data length
int32_t spo2; //SPO2 value
int8_t validSPO2; //indicator to show if the SPO2 calculation is valid
int32_t heartRate; //heart rate value
int8_t validHeartRate; //indicator to show if the heart rate calculation is valid


byte pulseLED = 11; //Must be on PWM pin
byte readLED = 13; //Blinks with each data read


const byte RATE_SIZE = 4; //Increase this for more averaging. 4 is good.
byte rates[RATE_SIZE]; //Array of heart rates
byte rateSpot = 0;
long lastBeat = 0; //Time at which the last beat occurred


float beatsPerMinute;
int beatAvg;


void setup()
{
  Serial.begin(115200); // initialize serial communication at 115200 bits per second:


  pinMode(pulseLED, OUTPUT);
  pinMode(readLED, OUTPUT);


  // Initialize sensor
  if (!particleSensor.begin(Wire, I2C_SPEED_FAST)) //Use default I2C port, 400kHz speed
  {
    Serial.println(F("MAX30105 was not found. Please check wiring/power."));
    while (1);
  }


  Serial.println(F("Attach sensor to finger with rubber band. Press any key to start conversion"));
  while (Serial.available() == 0) ; //wait until user presses a key
  Serial.read();


  byte ledBrightness = 60; //Options: 0=Off to 255=50mA
  byte sampleAverage = 4; //Options: 1, 2, 4, 8, 16, 32
  byte ledMode = 2; //Options: 1 = Red only, 2 = Red + IR, 3 = Red + IR + Green
  byte sampleRate = 100; //Options: 50, 100, 200, 400, 800, 1000, 1600, 3200
  int pulseWidth = 411; //Options: 69, 118, 215, 411
  int adcRange = 4096; //Options: 2048, 4096, 8192, 16384
  
  particleSensor.setup(ledBrightness, sampleAverage, ledMode, sampleRate, pulseWidth, adcRange); //Configure sensor with these settings


// particleSensor.setup(); //Configure sensor with default settings
  particleSensor.setPulseAmplitudeRed(0x0A); //Turn Red LED to low to indicate sensor is running
  particleSensor.setPulseAmplitudeGreen(0); //Turn off Green LED
}


void loop()
{
  
  bufferLength = 100; //buffer length of 100 stores 4 seconds of samples running at 25sps


  //read the first 100 samples, and determine the signal range
  for (byte i = 0 ; i < bufferLength ; i++)
  {
    while (particleSensor.available() == false) //do we have new data?
      particleSensor.check(); //Check the sensor for new data


    redBuffer = particleSensor.getRed();
    irBuffer = particleSensor.getIR();
   
    particleSensor.nextSample(); //We're finished with this sample so move to next sample
  }
  
  //calculate heart rate and SpO2 after first 100 samples (first 4 seconds of samples)
  maxim_heart_rate_and_oxygen_saturation(irBuffer, bufferLength, redBuffer, &spo2, &validSPO2, &heartRate, &validHeartRate);


  //Continuously taking samples from MAX30102.  Heart rate and SpO2 are calculated every 1 second
  while (1)
  {
    //dumping the first 25 sets of samples in the memory and shift the last 75 sets of samples to the top
  
        for (byte i = 25; i < 100; i++)
    {
      redBuffer[i - 25] = redBuffer;
      irBuffer[i - 25] = irBuffer;
    }


    //take 25 sets of samples before calculating the heart rate.
    for (byte i = 75; i < 100; i++)
    {
      while (particleSensor.available() == false) //do we have new data?
        particleSensor.check(); //Check the sensor for new data


      digitalWrite(readLED, !digitalRead(readLED)); //Blink onboard LED with every data read


      redBuffer = particleSensor.getRed();
      irBuffer = particleSensor.getIR();
   
            long irValue = particleSensor.getIR();
      if (checkForBeat(irValue) == true)
  {
    //We sensed a beat!
    long delta = millis() - lastBeat;
    lastBeat = millis();
    beatsPerMinute = 60 / (delta / 1000.0);
  }
      particleSensor.nextSample(); //We're finished with this sample so move to next sample
      //send samples and calculation result to terminal program through UART
//     Serial.print(F("red="));
//     Serial.print(redBuffer, DEC);
//     Serial.print(F(", ir="));
//     Serial.print(irBuffer, DEC);


//     Serial.print(F(", HR="));
//     Serial.print(heartRate, DEC);


//     Serial.print(F(", HRvalid="));
//     Serial.print(validHeartRate, DEC);

        Serial.print(", BPM=");
        Serial.print(beatsPerMinute);
         Serial.print(F(", SPO2="));
      Serial.print(spo2, DEC);
      Serial.print(F(", SPO2Valid="));
      Serial.println(validSPO2, DEC);
     //    if (irValue < 50000)
//    Serial.println(" No finger?");
    }
    //After gathering 25 new samples recalculate HR and SP02
    maxim_heart_rate_and_oxygen_saturation(irBuffer, bufferLength, redBuffer, &spo2, &validSPO2, &heartRate, &validHeartRate);
  }
}



串口数据

串口数据

实物图

实物图
发表于 2019-2-22 17:07 | 显示全部楼层
楼主问题解决了吗
同款模块 技术交流下
发表于 2019-3-19 17:59 | 显示全部楼层
同想要技术交流
发表于 2019-3-19 18:00 | 显示全部楼层
wanniu 发表于 2019-2-22 17:07
楼主问题解决了吗
同款模块 技术交流下

加一下qq呗2643263647
发表于 2019-3-21 13:43 | 显示全部楼层
楼主这段代码好像支持的是stm32
发表于 2019-3-21 13:46 | 显示全部楼层
#include <Wire.h>
#include "MAX30105.h"

#include "heartRate.h"

MAX30105 particleSensor;

const byte RATE_SIZE = 4; //Increase this for more averaging. 4 is good.
byte rates[RATE_SIZE]; //Array of heart rates
byte rateSpot = 0;
long lastBeat = 0; //Time at which the last beat occurred

float beatsPerMinute;
int beatAvg;

void setup()
{
  Serial.begin(115200);
  Serial.println("Initializing...");

  // Initialize sensor
  if (!particleSensor.begin(Wire, I2C_SPEED_FAST)) //Use default I2C port, 400kHz speed
  {
    Serial.println("MAX30105 was not found. Please check wiring/power. ");
    while (1);
  }
  Serial.println("Place your index finger on the sensor with steady pressure.");

  particleSensor.setup(); //Configure sensor with default settings
  particleSensor.setPulseAmplitudeRed(0x0A); //Turn Red LED to low to indicate sensor is running
  particleSensor.setPulseAmplitudeGreen(0); //Turn off Green LED
}

void loop()
{
  long irValue = particleSensor.getIR();

  if (checkForBeat(irValue) == true)
  {
    //We sensed a beat!
    long delta = millis() - lastBeat;
    lastBeat = millis();

    beatsPerMinute = 60 / (delta / 1000.0);

    if (beatsPerMinute < 255 && beatsPerMinute > 20)
    {
      rates[rateSpot++] = (byte)beatsPerMinute; //Store this reading in the array
      rateSpot %= RATE_SIZE; //Wrap variable

      //Take average of readings
      beatAvg = 0;
      for (byte x = 0 ; x < RATE_SIZE ; x++)
        beatAvg += rates[x];
      beatAvg /= RATE_SIZE;
    }
  }

  Serial.print("IR=");
  Serial.print(irValue);
  Serial.print(", BPM=");
  Serial.print(beatsPerMinute);
  Serial.print(", Avg BPM=");
  Serial.print(beatAvg);
  Serial.println();
}

我这段可以使用但是有数据上的问题但是,ir值是对的,注意仅在uno板测试成功过。
发表于 2019-7-12 10:44 | 显示全部楼层
可以发一下库吗?
发表于 2019-9-3 17:44 | 显示全部楼层
UMRI 发表于 2019-3-21 13:46
#include
#include "MAX30105.h"

请问库在哪里下载?谢谢
发表于 2020-4-15 16:11 | 显示全部楼层
UMRI 发表于 2019-3-21 13:46
#include
#include "MAX30105.h"

Arduino:1.6.5 (Windows 8.1), 板:"Arduino/Genuino Uno"

sketch_apr15a.ino:6:22: fatal error: MAX30102.h: No such file or directory
compilation terminated.
编译有误。

  报告将会包含更多的信息
  "在编译时,输出详细信息"
  在 文件>首选项 中启用

出现这种错误是什么问题呢
发表于 2020-5-8 23:00 | 显示全部楼层
张小云 发表于 2020-4-15 16:11
Arduino:1.6.5 (Windows 8.1), 板:"Arduino/Genuino Uno"

sketch_apr15a.ino:6:22: fatal error: MAX30 ...

你没库啊.......找买家要库
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|Archiver|手机版|Arduino中文社区

GMT+8, 2024-11-29 07:49 , Processed in 0.084445 second(s), 18 queries .

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表