Например TDA7294

Форум РадиоКот • Просмотр темы - Arduino и 2 датчика
Форум РадиоКот
Здесь можно немножко помяукать :)



Текущее время: Вт авг 04, 2020 14:31:59

Часовой пояс: UTC + 3 часа


ПРЯМО СЕЙЧАС:



Начать новую тему Ответить на тему  [ Сообщений: 11 ] 
Автор Сообщение
Не в сети
 Заголовок сообщения: Arduino и 2 датчика
СообщениеДобавлено: Пн июн 08, 2020 13:33:01 
Родился

Зарегистрирован: Сб дек 15, 2018 11:31:57
Сообщений: 5
Рейтинг сообщения: 0
Здравствуйте, есть плата Arduino uno , датчик пульса Pulse sensor, датчик ЭКГ Ad8232 и дисплей 1602.

Есть программа, которая принимает данные с СОМ порта. С помощью скетча можно вывести частоту пульса на дисплей и в программу, датчик пульса подключен к А0.
Датчик экг подключен к А1, но я не знаю как его обработать, чтобы работали 2 датчика по типу снимаю измерения с датчика пульса и вывожу на дисплей и в программу, экг пока что не работает, потом снимаю экг и вывожу на дисплей и экран, пульс не работает. Экг хочу выводить словами хорошо, плохо, в норме, т.к. символьный дисплей, а в программе будет выводиться график. Примеров никаких не нашёл, может кто, что знает и подскажет?
Код:
#include <LiquidCrystal.h>

//  Variables
int pulsePin = 0;                 // Pulse Sensor purple wire connected to analog pin 0
int blinkPin = 13;                // pin to blink led at each beat
int fadePin = 8;                  // pin to do fancy classy fading blink at each beat
int fadeRate = 0;                 // used to fade LED on with PWM on fadePin

LiquidCrystal lcd(4, 5, 6, 7, 8, 9);

// Volatile Variables, used in the interrupt service routine!
volatile int BPM;                   // int that holds raw Analog in 0. updated every 2mS
volatile int Signal;                // holds the incoming raw data
volatile int IBI = 600;             // int that holds the time interval between beats! Must be seeded!
volatile boolean Pulse = false;     // "True" when User's live heartbeat is detected. "False" when not a "live beat".
volatile boolean QS = false;        // becomes true when Arduoino finds a beat.

// Regards Serial OutPut  -- Set This Up to your needs
static boolean serialVisual = true;   // Set to 'false' by Default.  Re-set to 'true' to see Arduino Serial Monitor ASCII Visual Pulse

volatile int rate[10];                      // array to hold last ten IBI values
volatile unsigned long sampleCounter = 0;          // used to determine pulse timing
volatile unsigned long lastBeatTime = 0;           // used to find IBI
volatile int P = 512;                      // used to find peak in pulse wave, seeded
volatile int T = 512;                     // used to find trough in pulse wave, seeded
volatile int thresh = 525;                // used to find instant moment of heart beat, seeded
volatile int amp = 100;                   // used to hold amplitude of pulse waveform, seeded
volatile boolean firstBeat = true;        // used to seed rate array so we startup with reasonable BPM
volatile boolean secondBeat = false;      // used to seed rate array so we startup with reasonable BPM

void setup()
{
  pinMode(blinkPin,OUTPUT);         // pin that will blink to your heartbeat!
  pinMode(fadePin,OUTPUT);          // pin that will fade to your heartbeat!
  Serial.begin(9600);             // we agree to talk fast!
  interruptSetup();                 // sets up to read Pulse Sensor signal every 2mS
                                    // IF YOU ARE POWERING The Pulse Sensor AT VOLTAGE LESS THAN THE BOARD VOLTAGE,
                                    // UN-COMMENT THE NEXT LINE AND APPLY THAT VOLTAGE TO THE A-REF PIN
                                    //   analogReference(EXTERNAL);   
}


//  Where the Magic Happens
void loop()
{
   serialOutput(); 
   
  if (QS == true) // A Heartbeat Was Found
    {     
      // BPM and IBI have been Determined
      // Quantified Self "QS" true when arduino finds a heartbeat
      fadeRate = 255; // Makes the LED Fade Effect Happen, Set 'fadeRate' Variable to 255 to fade LED with pulse
      serialOutputWhenBeatHappens(); // A Beat Happened, Output that to serial.     
      QS = false; // reset the Quantified Self flag for next time   
    }
     
  ledFadeToBeat(); // Makes the LED Fade Effect Happen
  delay(20); //  take a break
}

void ledFadeToBeat()
{
   fadeRate -= 15;                         //  set LED fade value
   fadeRate = constrain(fadeRate,0,255);   //  keep LED fade value from going into negative numbers!
   analogWrite(fadePin,fadeRate);          //  fade LED
}

void interruptSetup()
{     
  // Initializes Timer2 to throw an interrupt every 2mS.
  TCCR2A = 0x02;     // DISABLE PWM ON DIGITAL PINS 3 AND 11, AND GO INTO CTC MODE
  TCCR2B = 0x06;     // DON'T FORCE COMPARE, 256 PRESCALER
  OCR2A = 0X7C;      // SET THE TOP OF THE COUNT TO 124 FOR 500Hz SAMPLE RATE
  TIMSK2 = 0x02;     // ENABLE INTERRUPT ON MATCH BETWEEN TIMER2 AND OCR2A
  sei();             // MAKE SURE GLOBAL INTERRUPTS ARE ENABLED     
}

void serialOutput()
{   // Decide How To Output Serial.
 if (serialVisual == true)
  { 
     arduinoSerialMonitorVisual('-', Signal);   // goes to function that makes Serial Monitor Visualizer
  }
 else
  {
      sendDataToSerial('S', Signal);     // goes to sendDataToSerial function
   }       
}

void serialOutputWhenBeatHappens()
{   
 if (serialVisual == true) //  Code to Make the Serial Monitor Visualizer Work
   {           
     Serial.println(BPM);
     lcd.clear();
     lcd.print("BPM: ");
     lcd.print(BPM);
   }
 else
   {
     sendDataToSerial('B',BPM);   // send heart rate with a 'B' prefix
     sendDataToSerial('Q',IBI);   // send time between beats with a 'Q' prefix
   }   
}

void arduinoSerialMonitorVisual(char symbol, int data )
{   
  const int sensorMin = 0;      // sensor minimum, discovered through experiment
  const int sensorMax = 1024;    // sensor maximum, discovered through experiment
  int sensorReading = data; // map the sensor range to a range of 12 options:
  int range = map(sensorReading, sensorMin, sensorMax, 0, 11);
}


void sendDataToSerial(char symbol, int data )
{
   Serial.print(symbol);
   Serial.println(data);               
}

ISR(TIMER2_COMPA_vect) //triggered when Timer2 counts to 124

  cli();                                      // disable interrupts while we do this
  Signal = analogRead(pulsePin);              // read the Pulse Sensor
  sampleCounter += 2;                         // keep track of the time in mS with this variable
  int N = sampleCounter - lastBeatTime;       // monitor the time since the last beat to avoid noise
                                              //  find the peak and trough of the pulse wave
  if(Signal < thresh && N > (IBI/5)*3) // avoid dichrotic noise by waiting 3/5 of last IBI
    {     
      if (Signal < T) // T is the trough
      {                       
        T = Signal; // keep track of lowest point in pulse wave
      }
    }

  if(Signal > thresh && Signal > P)
    {          // thresh condition helps avoid noise
      P = Signal;                             // P is the peak
    }                                        // keep track of highest point in pulse wave

  //  NOW IT'S TIME TO LOOK FOR THE HEART BEAT
  // signal surges up in value every time there is a pulse
  if (N > 250)
  {                                   // avoid high frequency noise
    if ( (Signal > thresh) && (Pulse == false) && (N > (IBI/5)*3) )
      {       
        Pulse = true;                               // set the Pulse flag when we think there is a pulse
        digitalWrite(blinkPin,HIGH);                // turn on pin 13 LED
        IBI = sampleCounter - lastBeatTime;         // measure time between beats in mS
        lastBeatTime = sampleCounter;               // keep track of time for next pulse
 
        if(secondBeat)
        {                        // if this is the second beat, if secondBeat == TRUE
          secondBeat = false;                  // clear secondBeat flag
          for(int i=0; i<=9; i++) // seed the running total to get a realisitic BPM at startup
          {             
            rate[i] = IBI;                     
          }
        }
 
        if(firstBeat) // if it's the first time we found a beat, if firstBeat == TRUE
        {                         
          firstBeat = false;                   // clear firstBeat flag
          secondBeat = true;                   // set the second beat flag
          sei();                               // enable interrupts again
          return;                              // IBI value is unreliable so discard it
        }   
      // keep a running total of the last 10 IBI values
      word runningTotal = 0;                  // clear the runningTotal variable   

      for(int i=0; i<=8; i++)
        {                // shift data in the rate array
          rate[i] = rate[i+1];                  // and drop the oldest IBI value
          runningTotal += rate[i];              // add up the 9 oldest IBI values
        }

      rate[9] = IBI;                          // add the latest IBI to the rate array
      runningTotal += rate[9];                // add the latest IBI to runningTotal
      runningTotal /= 10;                     // average the last 10 IBI values
      BPM = 60000/runningTotal;               // how many beats can fit into a minute? that's BPM!
      QS = true;                              // set Quantified Self flag
      // QS FLAG IS NOT CLEARED INSIDE THIS ISR
    }                       
  }

  if (Signal < thresh && Pulse == true)
    {   // when the values are going down, the beat is over
      digitalWrite(blinkPin,LOW);            // turn off pin 13 LED
      Pulse = false;                         // reset the Pulse flag so we can do it again
      amp = P - T;                           // get amplitude of the pulse wave
      thresh = amp/2 + T;                    // set thresh at 50% of the amplitude
      P = thresh;                            // reset these for next time
      T = thresh;
    }

  if (N > 2500)
    {                           // if 2.5 seconds go by without a beat
      thresh = 512;                          // set thresh default
      P = 512;                               // set P default
      T = 512;                               // set T default
      lastBeatTime = sampleCounter;          // bring the lastBeatTime up to date       
      firstBeat = true;                      // set these to avoid noise
      secondBeat = false;                    // when we get the heartbeat back
    }

  sei();                                   // enable interrupts when youre done!
}// end isr






Вернуться наверх
 
Не в сети
 Заголовок сообщения: Re: Arduino и 2 датчика
СообщениеДобавлено: Пн июн 08, 2020 14:24:13 
Опытный кот

Карма: 3
Рейтинг сообщений: 224
Зарегистрирован: Ср июл 17, 2013 13:55:57
Сообщений: 861
Рейтинг сообщения: 0
Наймите программиста. Если вы вообще не понимаете как делать, то каких ответов вы ожидаете? Начните для начала со считывания "ЭКГ", раз этого нет. Не получается? См. 1ое предложение.


Вернуться наверх
 
JLCPCB, всего $2 за прототип печатной платы! Цвет - любой!

Отличное качество, подтвержденное более чем 600,000 пользователей! Более 10,000 заказов в день.

Зарегистрируйтесь и получите два купона по 5$ каждый:https://jlcpcb.com/quote

Не в сети
 Заголовок сообщения: Re: Arduino и 2 датчика
СообщениеДобавлено: Пн июн 08, 2020 18:28:47 
Друг Кота
Аватар пользователя

Карма: 86
Рейтинг сообщений: 926
Зарегистрирован: Вт мар 16, 2010 22:02:27
Сообщений: 10743
Откуда: ДОНЕЦК (ЮГО-ВОСТОК ua/DPR)
Рейтинг сообщения: 0
Нормальная ЭКГ предусматривает возможность получения частоты пульса.
8)


Вернуться наверх
 
PCBWay - всего $5 за 10 печатных плат, первый заказ для новых клиентов БЕСПЛАТЕН

Сборка печатных плат от $30 + БЕСПЛАТНАЯ доставка по всему миру + трафарет

Онлайн просмотровщик Gerber-файлов от PCBWay + Шестое юбилейное мероприятие в процессе
Не в сети
 Заголовок сообщения: Re: Arduino и 2 датчика
СообщениеДобавлено: Вт июн 09, 2020 01:14:38 
Потрогал лапой паяльник

Карма: 9
Рейтинг сообщений: 102
Зарегистрирован: Сб ноя 16, 2013 23:34:34
Сообщений: 393
Рейтинг сообщения: 0
Aforizm19, зачем постить простыни из кода, если можно ссылку на него привести? Ну, и удалять из чужого кода сведения об авторстве - занятие так себе...


Вернуться наверх
 
Вебинар «Каждому ключу — свой драйвер» (13.08.2020)

Компания КОМПЭЛ приглашает вас принять участие в вебинаре, который будет посвящен теме драйверов управления транзисторами компании Infineon. Мы рассмотрим четыре различных технологии изготовления микросхем драйверов, в чём их отличия и особенности.

Зарегистрироваться на вебинар>>
Не в сети
 Заголовок сообщения: Re: Arduino и 2 датчика
СообщениеДобавлено: Вт июн 09, 2020 08:14:53 
Друг Кота
Аватар пользователя

Карма: 48
Рейтинг сообщений: 646
Зарегистрирован: Вт апр 24, 2007 07:45:40
Сообщений: 4272
Откуда: Minsk
Рейтинг сообщения: 0
Ужос! ЭКГ не бывает "хорошая", "плохая" - нужен конкретный анализ её элементов, и это может сделать только опытный кардиолог вместе с очень опытным программистом, хорошо бы в одном лице, чего, как видно - не имеется. А то, что имеем в вопросе - да лучше уж совсем без ЭКГ, чем с такой.
Впрочем, это скорее всего что-то учебное и забудется после зачёта, как кошмарный сон, потому что не приведи аллах встретиться по жизни с реализацией этого опуса.

_________________
Изображение


Вернуться наверх
 
Меньше не бывает: неизолированные микро-DC/DC нового поколения R4 от Mornsun

Компания Mornsun разработала серию R4 неизолированных импульсных стабилизаторов напряжения в новом миниатюрном конструктивном исполнении. Уменьшение коснулось не только размеров, на 80% меньше существующих преобразователей, но и стоимости.

Подробнее>>
Не в сети
 Заголовок сообщения: Re: Arduino и 2 датчика
СообщениеДобавлено: Вт июн 09, 2020 11:38:47 
Родился

Зарегистрирован: Сб дек 15, 2018 11:31:57
Сообщений: 5
Рейтинг сообщения: 0
Наймите программиста. Если вы вообще не понимаете как делать, то каких ответов вы ожидаете? Начните для начала со считывания "ЭКГ", раз этого нет. Не получается? См. 1ое предложение.

Может кто-то уже работал с этим и знает как что, таких ответов я ожидал.

Добавлено after 1 minute 37 seconds:
Aforizm19, зачем постить простыни из кода, если можно ссылку на него привести? Ну, и удалять из чужого кода сведения об авторстве - занятие так себе...

Я ничего не удалял из этого кода. Про ссылку не знал.


Вернуться наверх
 


Не в сети
 Заголовок сообщения: Re: Arduino и 2 датчика
СообщениеДобавлено: Вт июн 09, 2020 11:40:34 
Друг Кота
Аватар пользователя

Карма: 86
Рейтинг сообщений: 926
Зарегистрирован: Вт мар 16, 2010 22:02:27
Сообщений: 10743
Откуда: ДОНЕЦК (ЮГО-ВОСТОК ua/DPR)
Рейтинг сообщения: 0
Если кто и занимался - то разве что с частотой пульса.
ЭКГ штука хитрая... Для аналитики ДОХТОР нужен.
А вот ЧСС получить из нее вполне можно.
8)


Вернуться наверх
 


Не в сети
 Заголовок сообщения: Re: Arduino и 2 датчика
СообщениеДобавлено: Вт июн 09, 2020 11:46:09 
Родился

Зарегистрирован: Сб дек 15, 2018 11:31:57
Сообщений: 5
Рейтинг сообщения: 0
Ужос! ЭКГ не бывает "хорошая", "плохая" - нужен конкретный анализ её элементов, и это может сделать только опытный кардиолог вместе с очень опытным программистом, хорошо бы в одном лице, чего, как видно - не имеется. А то, что имеем в вопросе - да лучше уж совсем без ЭКГ, чем с такой.
Впрочем, это скорее всего что-то учебное и забудется после зачёта, как кошмарный сон, потому что не приведи аллах встретиться по жизни с реализацией этого опуса.

Я образно написал хорошая, плохая, чтобы было понятно. Скорее всего без экг на дисплее и оставлю, т.к. в программу уже понял как выводить график. Ну а в жизни, например, это прибор тонометр , вот нужно сделать что-то похожее.

Добавлено after 1 minute 37 seconds:
Если кто и занимался - то разве что с частотой пульса.
ЭКГ штука хитрая... Для аналитики ДОХТОР нужен.
А вот ЧСС получить из нее вполне можно.
8)

Спасибо за ответ, мне примерно так и сказали , сходить к доктору , спросить у него. Думал может, кто-то знает на форуме.


Вернуться наверх
 
Бытовой пирометр АКИП-9312 – просто удобно!

Диапазон 35 °С ...42°С (температура тела) погрешность 0,3 °С
Диапазон 0 °С ...100°С (бытовая сфера) погрешность 1,0 °С
Не в сети
 Заголовок сообщения: Re: Arduino и 2 датчика
СообщениеДобавлено: Вт июн 09, 2020 11:48:06 
Друг Кота
Аватар пользователя

Карма: 86
Рейтинг сообщений: 926
Зарегистрирован: Вт мар 16, 2010 22:02:27
Сообщений: 10743
Откуда: ДОНЕЦК (ЮГО-ВОСТОК ua/DPR)
Рейтинг сообщения: 0
А не путаете ли измерение давления и ЭКГ?
Измеритель давления всего лишь использует тензодатчик для контроля пульсовой волны.
А вторая половинка собственно датчик давления и привод компрессора/клапана сброса давления манжеты.
8)


Вернуться наверх
 


Не в сети
 Заголовок сообщения: Re: Arduino и 2 датчика
СообщениеДобавлено: Вт июн 09, 2020 12:27:51 
Опытный кот

Карма: 3
Рейтинг сообщений: 224
Зарегистрирован: Ср июл 17, 2013 13:55:57
Сообщений: 861
Рейтинг сообщения: 0
BOB51, ну написана же микруха сверху - Ad8232. Это именно для ЭКГ микруха. И на Али на базе этой микрухи находятся готовые какие-то сборки, видимо за них речь.


Вернуться наверх
 
Не в сети
 Заголовок сообщения: Re: Arduino и 2 датчика
СообщениеДобавлено: Вт июн 09, 2020 14:51:38 
Друг Кота
Аватар пользователя

Карма: 86
Рейтинг сообщений: 926
Зарегистрирован: Вт мар 16, 2010 22:02:27
Сообщений: 10743
Откуда: ДОНЕЦК (ЮГО-ВОСТОК ua/DPR)
Рейтинг сообщения: 0
[...Ну а в жизни, например, это прибор тонометр , вот нужно сделать что-то похожее....

В просторечии так называют приборчик для измерения артериального давления.
8)


Вернуться наверх
 
Показать сообщения за:  Сортировать по:  Вернуться наверх
Начать новую тему Ответить на тему  [ Сообщений: 11 ] 

Часовой пояс: UTC + 3 часа


Кто сейчас на форуме

Сейчас этот форум просматривают: нет зарегистрированных пользователей и гости: 4


Вы не можете начинать темы
Вы не можете отвечать на сообщения
Вы не можете редактировать свои сообщения
Вы не можете удалять свои сообщения
Вы не можете добавлять вложения

Найти:
Перейти:  


Powered by phpBB © 2000, 2002, 2005, 2007 phpBB Group
Русская поддержка phpBB
Extended by Karma MOD © 2007—2012 m157y
Extended by Topic Tags MOD © 2012 m157y