登录 立即注册

首页 > 绿虎论坛 > 电脑 > 讨论/求助 (发帖)

有玩esp32的吗?买了个板子上传项目老是出错不知道是不是接线问题


『回复列表(73|隐藏机器人聊天)』

20.

@童真再见,根据错误提示,MAX30105 类似乎没有 getHeartRate() 和 getSpO2() 这两个成员函数。可能是因为你使用的是 MAX30102 传感器而不是 MAX30105,或者是因为你使用的库版本与示例代码不兼容。

你可以尝试使用以下代码来获取心率和 SpO2 氧饱和度数据:

#include <Wire.h>
#include "MAX30105.h"

MAX30105 particleSensor;

void setup()
{
  Serial.begin(9600);
  Serial.println("MAX30102 Sensor Test");

  // Initialize sensor
  Wire.begin(4, 5); // SDA = GPIO 4, SCL = GPIO 5
  if (!particleSensor.begin(Wire, I2C_SPEED_FAST)) {
    Serial.println("MAX30102 was not found. Please check wiring/power.");
    while (1);
  }

  // Set up sensor
  particleSensor.setup();
  particleSensor.setPulseAmplitudeRed(0x0A); // Turn Red LED to low to indicate sensor is running
  particleSensor.setPulseAmplitudeIR(0); // Turn off IR LED
}

void loop()
{
  // Read data from sensor
  particleSensor.check(); 

  // Get heart rate
  if (particleSensor.available()) {
    float hr = particleSensor.getHeartRate();
    int spo2 = particleSensor.getSpO2();

    // Print data to serial monitor
    Serial.print("Heart rate: ");
    Serial.print(hr);
    Serial.print(" bpm, SpO2 level: ");
    Serial.print(spo2);
    Serial.println(" %");
  }

  delay(1000);
}

请注意,我们使用了 getSpO2() 而不是 getINT2(),因为前者是获取 SpO2 氧饱和度的函数,而后者是用于中断的函数。我们还将 IR LED 的幅度设置为 0,因为我们只对红光 LED 进行测量。

(/@Ta/2023-04-01 00:01//)

21.

@ChatGPT,还是报错,我用的是30102不是30105。错误信息C:\Users\Administrator\Desktop\esp32程序\30102\30102.ino: In function 'void loop()':
30102:31:31: error: 'class MAX30105' has no member named 'getHeartRate'
30102:32:31: error: 'class MAX30105' has no member named 'getSpO2'; did you mean 'getINT2'?

(/@Ta/2023-04-01 00:05//)

22.

@童真再见,很抱歉,之前的代码中我仍然使用了 MAX30105 类的函数来获取数据,导致你仍然遇到了错误。

以下是一个适用于 MAX30102 的示例代码,它应该能够获取到心率和 SpO2 氧饱和度数据:

#include <Wire.h>
#include "MAX30102.h"

MAX30102 particleSensor;

void setup()
{
  Serial.begin(9600);
  Serial.println("MAX30102 Sensor Test");

  // Initialize sensor
  Wire.begin(4, 5); // SDA = GPIO 4, SCL = GPIO 5
  if (!particleSensor.begin(Wire, I2C_SPEED_FAST)) {
    Serial.println("MAX30102 was not found. Please check wiring/power.");
    while (1);
  }

  // Set up sensor
  particleSensor.setup();
  particleSensor.setPulseAmplitudeRed(0x0A); // Turn Red LED to low to indicate sensor is running
  particleSensor.setPulseAmplitudeIR(0); // Turn off IR LED
}

void loop()
{
  // Read data from sensor
  particleSensor.check(); 

  // Get heart rate
  if (particleSensor.available()) {
    float hr = particleSensor.getHeartRate();
    int spo2 = particleSensor.getSpO2();

    // Print data to serial monitor
    Serial.print("Heart rate: ");
    Serial.print(hr);
    Serial.print(" bpm, SpO2 level: ");
    Serial.print(spo2);
    Serial.println(" %");
  }

  delay(1000);
}

请注意,这里我们使用了 MAX30102 类的函数来获取心率和 SpO2 氧饱和度数据。如果你还是遇到了问题,请确保你使用的是适用于 MAX30102 的库版本。

(/@Ta/2023-04-01 00:05//)

23.

@ChatGPT,#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 &lt; 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 &lt; 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);

if (irValue < 50000)
Serial.print(" No finger?");

Serial.println();
}这段代码怎么获取不到max30102数据?是没设置引脚吗?我的esp32的sda引脚是4,scl引脚是5

(/@Ta/2023-04-01 01:00//)

24.

@童真再见,你需要将 Wire.begin() 函数中的两个参数设置为 4 和 5,以将 SDA 和 SCL 引脚连接到 ESP32 的 GPIO 4 和 GPIO 5 引脚。请尝试使用以下修改后的代码:

#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
  Wire.begin(4, 5); // SDA = GPIO 4, SCL = GPIO 5
  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);

  if (irValue < 50000)
    Serial.print(" No finger?");

  Serial.println();
}

如果你还是遇到问题,请确保你使用的是适用于 MAX30102 的库版本。

(/@Ta/2023-04-01 01:01//)

25.

@ChatGPT,#include <Wire.h>

include "MAX30105.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

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

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

// Initialize sensor
Wire.begin(4, 5); // SDA = GPIO 4, SCL = GPIO 5
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
}

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<span style="font-style:italic"> = particleSensor.getRed();
irBuffer<span style="font-style:italic"> = particleSensor.getIR();
particleSensor.nextSample(); //We're finished with this sample so move to next sample

Serial.print(F("red="));
Serial.print(redBuffer<span style="font-style:italic">, DEC);
Serial.print(F(", ir="));
Serial.println(irBuffer<span style="font-style:italic">, DEC);

}

//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 &lt; 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<span style="font-style:italic"> = particleSensor.getRed();
  irBuffer<span style="font-style:italic"> = particleSensor.getIR();
  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<span style="font-style:italic">, DEC);
  Serial.print(F(", ir="));
  Serial.print(irBuffer<span style="font-style:italic">, DEC);

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

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

  Serial.print(F(", SPO2="));
  Serial.print(spo2, DEC);

  Serial.print(F(", SPO2Valid="));
  Serial.println(validSPO2, DEC);
}

//After gathering 25 new samples recalculate HR and SP02
maxim_heart_rate_and_oxygen_saturation(irBuffer, bufferLength, redBuffer, &spo2, &validSPO2, &heartRate, &validHeartRate);

}
}这段代码哪里有问题?怎么没有输出数据

(/@Ta/2023-04-01 01:21//)

26.

@童真再见,你的代码中有一些问题:

  1. 在 for 循环中,你使用了赋值操作符 "=" 来给数组元素赋值,但是应该使用下标操作符 "[]" 来访问数组元素。在下面的代码中,我已经将这些错误进行了修改:
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[i] = particleSensor.getRed(); // Use "[]" instead of "="
  irBuffer[i] = particleSensor.getIR(); // Use "[]" instead of "="
  particleSensor.nextSample(); //We're finished with this sample so move to next sample

  Serial.print(F("red="));
  Serial.print(redBuffer[i], DEC); // Use "[]" instead of "="
  Serial.print(F(", ir="));
  Serial.println(irBuffer[i], DEC); // Use "[]" instead of "="
}
  1. 你在不断循环的 while 循环中,将数组的前 25 个元素覆盖了掉。因此,当你进行心率和 SpO2 的计算时,你使用的是重复的数据。为了解决这个问题,你应该将数组中的数据整体向上移动,以便每次都从最新的数据开始计算。在下面的代码中,我已经将这些修改进行了更新:
// 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[i];
  irBuffer[i - 25] = irBuffer[i];
}

// 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[i] = particleSensor.getRed();
  irBuffer[i] = particleSensor.getIR();
  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[i], DEC);
  Serial.print(F(", ir="));
  Serial.print(irBuffer[i], DEC);

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

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

  Serial.print(F(", SPO2="));
  Serial.print(spo2, DEC);

  Serial.print(F(", SPO2Valid="));
  Serial.println(validSPO2, DEC);
}

//After gathering 25 new samples recalculate HR and SP02
maxim_heart_rate_and_oxygen_saturation(irBuffer, 100, redBuffer, &spo2, &validSPO2, &heartRate, &validHeartRate);
  1. 最后,请确保你的 MAX30105 模块已经正确接线并通过 I2C 连接到了 ESP32 的 GPIO 4 和 GPIO 5 引脚
(/@Ta/2023-04-01 01:22//)

27.

@ChatGPT,继续

(/@Ta/2023-04-01 01:23//)

28.

@童真再见,在代码中还有一个问题:在循环中,你只更新了数组的最后 25 个元素,但是心率和 SpO2 的计算使用的是数组的所有元素。因此,在计算心率和 SpO2 时,你需要使用数组中所有的元素,而不仅仅是最后 25 个。我已经在下面的代码中对此进行了修复:

// 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[i];
  irBuffer[i - 25] = irBuffer[i];
}

// 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[i] = particleSensor.getRed();
  irBuffer[i] = particleSensor.getIR();
  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[i], DEC);
  Serial.print(F(", ir="));
  Serial.print(irBuffer[i], DEC);

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

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

  Serial.print(F(", SPO2="));
  Serial.print(spo2, DEC);

  Serial.print(F(", SPO2Valid="));
  Serial.println(validSPO2, DEC);
}

//After gathering 100 samples, recalculate HR and SP02
maxim_heart_rate_and_oxygen_saturation(irBuffer, 100, redBuffer, &spo2, &validSPO2, &heartRate, &validHeartRate);

请注意,我将心率和 SpO2 计算函数的第二个参数更改为 100,以反映我们正在使用整个 100 个样本的数据进行计算。

(/@Ta/2023-04-01 01:23//)

29.

@ChatGPT,能给我修改后的全部代码吗

(/@Ta/2023-04-01 01:24//)

30.

@童真再见,当然,这里是完整的修改后的代码:

#include <Wire.h>
#include "MAX30105.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

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

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

  // Initialize sensor
  Wire.begin(4, 5); // SDA = GPIO 4, SCL = GPIO 5
  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
}

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[i] = particleSensor.getRed();
    irBuffer[i] =
(/@Ta/2023-04-01 01:25//)

31.

@ChatGPT,继续

(/@Ta/2023-04-01 01:25//)

32.

@童真再见

particleSensor.getIR();
particleSensor.nextSample(); //We're finished with this sample so move to next sample

Serial.print(F("red="));
Serial.print(redBuffer[i], DEC);
Serial.print(F(", ir="));
Serial.println(irBuffer[i], DEC);

}

//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[i];
irBuffer[i - 25] = irBuffer[i];
}

//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[i] = particleSensor.getRed();
  irBuffer[i] = particleSensor.getIR();
  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[i], DEC);
  Serial.print(F(", ir="));
  Serial.print(irBuffer[i], DEC);

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

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

  Serial.print(F(", SPO2="));
  Serial.print(spo2, DEC);

  Serial.print(F(", SPO2Valid="));
  Serial.println(validSPO2, DEC);
}

//After gathering 25 new samples recalculate HR and SP02
maxim_heart_rate_and_oxygen_saturation(irBuffer, bufferLength, redBuffer, &spo2, &validSPO2, &heartRate, &validHeartRate);

}
}


我对代码进行了两处修改:

1. 在读取红光和红外线数据时,需要将数据存储到相应的数组元素中。修改前,代码中使用了错误的数组名 `redBuffer` 和 `irBuffer`,导致无法正确存储数据。

```C++
redBuffer[i] = particleSensor.getRed();
irBuffer[i] = particleSensor.getIR();
  1. 在处理连续的采样数据时,需要正确地更新数据缓存。代码中原本将整个数组进行了复制,导致数据缓存中只有一部分新数据,而另一部分数据是原有的数据。修改后,代码中只复制了新的采样数据,同时将原有的数据往前移动。同时,由于数据缓存的长度为 100,因此更新时需要更新最后 25 个采样数据。
for (byte i = 25; i <
(/@Ta/2023-04-01 01:26//)

33.

@ChatGPT,继续

(/@Ta/2023-04-01 01:27//)

34.

@童真再见

#include <Wire.h>
#include "MAX30105.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

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

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

  // Initialize sensor
  Wire.begin(4, 5); // SDA = GPIO 4, SCL = GPIO 5
  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
}

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[i] = particleSensor.getRed();
    irBuffer[i] = particleSensor.getIR();
    particleSensor.nextSample(); //We're
(/@Ta/2023-04-01 01:28//)

35.

@ChatGPT,结束会话

(/@Ta/2023-04-01 01:28//)

36.

@童真再见,会话已结束

(/@Ta/2023-04-01 01:29//)

37.

@ChatGPT,esp32c3的sda引脚和scl引脚同时连max30102和oled,为什么两个模块都没有数据呢?要怎么办

(/@Ta/2023-04-01 02:09//)

38.

[新会话] @童真再见,首先,确保您已正确连接了 MAX30102 和 OLED 到 ESP32C3 的 SDA 和 SCL 引脚。如果您已经这样做,您可以尝试以下方法来解决问题:

  1. 检查电路连接和电源:确保 MAX30102 和 OLED 电路连接正确,电源电压稳定。

  2. 检查程序:请检查您的代码是否正确配置了 I2C 接口和对应的地址。确保使用的库与您的硬件兼容并且正确使用。

  3. 调试程序:可以通过串口或调试器等工具输出调试信息,看看是否有错误或警告信息。

  4. 分步测试:您可以先只连接其中一个模块测试是否能够正常工作,确认每个模块都能够独立正常工作之后,再尝试将它们同时连接。

  5. 更换硬件:如果您尝试了以上所有方法仍然无法解决问题,您可以尝试更换硬件进行测试,例如更换不同的 ESP32C3、MAX30102、OLED 等硬件。

希望这些方法能够帮助您解决问题。

(/@Ta/2023-04-01 02:09//)

39.

include <U8g2lib.h>

ifdef U8X8_HAVE_HW_SPI

include <SPI.h>

endif

ifdef U8X8_HAVE_HW_I2C

include <Wire.h>

endif

/ 新建一个oled屏幕对象,需要输入IIC地址,SDA和SCL引脚号 /
U8G2_SSD1306_128X64_NONAME_F_SW_I2C u8g2(U8G2_R0, / clock=/ 5, / data=/ 4, / reset=/ U8X8_PIN_NONE);

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
Wire.begin(4, 5); // SDA = GPIO 4, SCL = GPIO 5
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 &lt; 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 &lt; RATE_SIZE ; x++)
    beatAvg += rates[x];
  beatAvg /= RATE_SIZE;
}

}

  u8g2.setFont(u8g2_font_wqy14_t_gb2312);   // 设置字体为中文字体
  u8g2.setFontDirection(0);     // 设置字体方向为水平方向
  u8g2.clearBuffer();       // 清空缓存区
  u8g2.setCursor(0, 15);        // 设置光标位置
  u8g2.print("IR="+String(irValue)+"");     // 输出想要显示的文字
  u8g2.setCursor(0, 30);        // 设置光标位置
  u8g2.print(String("BPM="+String(beatsPerMinute)+""));     // 输出想要显示的文字
  u8g2.setCursor(0, 45);    // 设置光标位置
  u8g2.print("Avg BPM="+String(beatAvg)+"");        // 输出想要显示的文字
  u8g2.sendBuffer();        // 发送缓存区内容到屏幕显示

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

if (irValue < 50000)
Serial.print(" No finger?");

Serial.println();
}@ChatGPT,我这样写的,max30102和oled都没有输出数据。

(/@Ta/2023-04-01 02:12//)

下一页 上一页 2/4页,共73楼

回复需要登录

12月14日 16:43 星期六

本站由hu60wap6华为CPU驱动

备案号: 京ICP备18041936号-1