질문게시판 > 심박센서 블루투스 앱인벤터

TODAY1,051 TOTAL679,974
사이트 이용안내
Login▼/회원가입
최신글보기 질문게시판 기술자료 동영상강좌

아두이노 센서 ATMEGA128 PWM LED 초음파 AVR 블루투스 LCD UART 모터 적외선


BASIC4MCU | 질문게시판 | 심박센서 블루투스 앱인벤터

페이지 정보

작성자 상철박 작성일2019-06-07 21:53 조회224회 댓글1건

본문

	

심박센서로 받은 값이 앱에 나오지 않습니다

도와주세요 ㅜㅜ

 

***** Interrupt.ino

 

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 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      

 

 

// THIS IS THE TIMER 2 INTERRUPT SERVICE ROUTINE. 

// Timer 2 makes sure that we take a reading every 2 miliseconds

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

  cli();                                      // disable interrupts while we do this

  Signal = analogRead(0);              // 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

      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 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!

}

 

***** PulseSensorAmped.ino

 

#include

 

volatile int BPM;

volatile int Signal;

volatile int IBI = 600;

volatile boolean Pulse = false;

 

SoftwareSerial btSerial(8,9);

 

 

void setup(){

  Serial.begin(115200);

 

  btSerial.begin(115200);

  interruptSetup();

}

 

void loop(){

  int interrupt = analogRead(A0);

  btSerial.println(interrupt);

  delay(1000);

  

 

  Serial.println(BPM);

  delay(1000);

}f535e39a1a383e5e9a6a2b7975e8427b_1559911710_5114.PNG 

 

  • BASIC4MCU 작성글 SNS에 공유하기
  • 페이스북으로 보내기
  • 트위터로 보내기
  • 구글플러스로 보내기

댓글 1

조회수 224

master님의 댓글

master 작성일

int interrupt = analogRead(A0); btSerial.println(interrupt); delay(1000);
아나로그입력을 블루투스로 전송하고 있고
  Serial.println(BPM);  delay(1000);
BPM은 시리얼모니터로 출력하고 있습니다.

질문게시판HOME > 질문게시판 목록

MCU, AVR, 아두이노 등 전자공학에 관련된 질문을 무료회원가입 후 작성해주시면 전문가가 답변해드립니다.
ATMEGA128PWMLED초음파
아두이노AVR블루투스LCD
UART모터적외선ATMEGA
전체 스위치 센서
질문게시판 목록
제목 작성자 작성일 조회
공지 MCU, AVR, 아두이노 등 전자공학에 관련된 질문은 질문게시판에서만 작성 가능합니다. 스태프 19-01-15 778
공지 사이트 이용 안내댓글[10] master 17-10-29 8298
공지 [무료 공개] 소스코드 하이라이트 v2.0 beta [2013.02.07]댓글[1] 이미지첨부파일 master 18-01-23 3095
질문 아두이노 소스 다시 질문입니다! 새글 16공대생 20:18 3
답변 답변글 답변 : 아두이노 소스 다시 질문입니다! 새글 master 20:45 2
질문 아두이노 소스 질문입니다.댓글[1] 이미지새글첨부파일 16공대생 12:38 9
질문 소스에서 오류가 뜨는데... 이미지새글 asd123 12:32 7
답변 답변글 답변 : 소스에서 오류가 뜨는데... 새글 master 14:41 7
질문 아두이노 소스질문있습니다.(mega2560) 새글 asd123 10:36 8
답변 답변글 답변 : 아두이노 소스질문있습니다.(mega2560)댓글[3] 새글 master 10:44 10
질문 리튬배터리 잔량을 알려주는 코드좀 알려주세요 ㅠㅠ댓글[5] 새글 tkd2023 19-10-18 10
질문 AT89S52 (8052) 인터럽트를 이용한 LED 쉬프트 코드댓글[3] 이미지새글첨부파일 uC어려워 19-10-18 11
질문 아두이노 인터럽트댓글[1] 새글 hello 19-10-18 10
답변 답변글 답변 : 아두이노 인터럽트 새글 master 19-10-18 9
질문 아두이노 수동부저와 오실로스코프...도와주세요댓글[3] 새글 ArduKang 19-10-17 14
질문 프로그램 작성좀 도와주세요 ㅠ (ATMEGA128,도트매트릭스)댓글[4] 이미지새글첨부파일 길짱 19-10-17 14
질문 아메트가128>FND질문이 있습니다.댓글[1] 세계제일초보 19-10-17 12
질문 atmega128 인터럽트를 활용해서 State 출력하기 이미지첨부파일 jjw332 19-10-17 9
답변 답변글 답변 : atmega128 인터럽트를 활용해서 State 출력하기댓글[2] 이미지 master 19-10-17 17
질문 아트메가128 인터럽트에 의한 LED 쉬프트, 출력댓글[4] 이미지첨부파일 jjw332 19-10-17 20
질문 아두이노(초음파센서,RFID)댓글[1] hello 19-10-17 19
질문 아두이노 소스코드 mega2560 찐덕 19-10-16 15
답변 답변글 답변 : 아두이노 소스코드 mega2560댓글[5] master 19-10-17 15
질문 아두이노 아웃풋 전압 관련 질문 드립니다.댓글[1] 꺼누 19-10-16 15
질문 아트메가128>초보 LED배터리 응용 질문입니다.! 세계제일초보 19-10-16 10
답변 답변글 답변 : 아트메가128>초보 LED배터리 응용 질문입니다.! master 19-10-16 8
질문 CLCD 제어 반헬쭉 19-10-16 13
답변 답변글 답변 : CLCD 제어댓글[2] master 19-10-16 16
질문 DDRA=0xff 질문있습니다. 세계제일초보 19-10-16 14
답변 답변글 답변 : DDRA=0xff 질문있습니다.댓글[1] master 19-10-16 13
게시물 검색

2019년 1월 2월 3월 4월 5월 6월 7월 8월 9월 10월 11월 12월
2018년 1월 2월 3월 4월 5월 6월 7월 8월 9월 10월 11월 12월
Privacy Policy
MCU BASIC ⓒ 2017
모바일버전으로보기