心动那啥方案

传感器

耳夹式心率传感器

控制部分

Geduino UNO

转接板

Base shield

执行机构

电机 6V

ws2812灯条

工作过程

Arduino上电后先执行校准程序,显示开机信号(彩虹慢速流动效果)

然后开始执行校准过程,累计20心跳间隔,计算出佩戴者的标准心跳。

绿色短闪一次后校准完毕。

开始监测佩戴者的心跳,如果心跳超过阈值,控制电机转动并显示彩虹快速流动。

校准和监测过程每次心跳都会触发一次红色短闪

更新下代码部分吧

#include <Adafruit_NeoPixel.h>
#ifdef __AVR__
  #include <avr/power.h>
#endif

#define STRIP_PIN 6


#define MODE_CALIBRATION 0
#define MODE_CALCULATE 1

const int time_max = 2000;//you can change it follow your system's request.


int mode = 0;

int MRRIGHT_THRESHOLD = 600;




Adafruit_NeoPixel strip = Adafruit_NeoPixel(10, STRIP_PIN, NEO_GRB + NEO_KHZ800);

unsigned long data[4];
int tail = 0;
bool succeed = true;
unsigned long time_taking;
int BPM = 0;


unsigned long data_init[21];
int data_init_tail = 0;



void setup() {

  strip.begin();
  strip.setBrightness(30);
  strip.show(); // Initialize all pixels to 'off'


 


  pinMode(8, OUTPUT);
  pinMode(7, OUTPUT);
  digitalWrite(8, LOW);
  digitalWrite(7, LOW);

  Serial.begin(9600);

  digitalWrite(8, HIGH);
  delay(1000);

  digitalWrite(8, LOW);
  


  uint16_t i, j;

  for(j=0; j<256*3; j++) { // 5 cycles of all colors on wheel
    for(i=0; i< strip.numPixels(); i++) {
      strip.setPixelColor(i, Wheel(((i * 256 / strip.numPixels()) + j) & 255));
    }
    strip.show();
    delay(10);
    
  }

  
  Serial.println("begin measure!");
  attachInterrupt(digitalPinToInterrupt(2), heartBeat, RISING);

  
}

void loop() {
  // Some example procedures showing how to display to the pixels:
  

}



void MrRightLIGHT() {
  detachInterrupt(digitalPinToInterrupt(2));
  uint16_t i, j;

  for(j=0; j<256*3; j++) { // 5 cycles of all colors on wheel
    for(i=0; i< strip.numPixels(); i++) {
      strip.setPixelColor(i, Wheel(((i * 256 / strip.numPixels()) + j) & 255));
    }
    strip.show();
    delayMicroseconds(1000);
    
  }

  attachInterrupt(digitalPinToInterrupt(2), heartBeat, RISING);

  
}

void colorWipe(uint32_t c, uint8_t wait) {
  

  for(uint16_t i=0; i<strip.numPixels(); i++) {
    strip.setPixelColor(i, c);
    strip.show();
    delay(wait);
  }
  
}

void colorWipeShort(int num){
  for(int i=0; i< num; i++){
      strip.setPixelColor(i, strip.Color(255,0,0));
      strip.show();
  }


}


// Input a value 0 to 255 to get a color value.
// The colours are a transition r - g - b - back to r.
uint32_t Wheel(byte WheelPos) {
  WheelPos = 255 - WheelPos;
  if(WheelPos < 85) {
    return strip.Color(255 - WheelPos * 3, 0, WheelPos * 3);
  }
  if(WheelPos < 170) {
    WheelPos -= 85;
    return strip.Color(0, WheelPos * 3, 255 - WheelPos * 3);
  }
  WheelPos -= 170;
  return strip.Color(WheelPos * 3, 255 - WheelPos * 3, 0);
}


void MrRight(){

    digitalWrite(7, HIGH);
    MrRightLIGHT();
    delay(5000);
    digitalWrite(7,LOW);
      
  

  succeed = true;



}




void heartBeatLight(unsigned long time_take){
  colorWipe(strip.Color(0,0,0),0);
  colorWipeShort(map(time_take, MRRIGHT_THRESHOLD, MRRIGHT_THRESHOLD+100, 10, 1));
  delay(10);


}


void heartBeat(){
  if(mode == MODE_CALCULATE){
      
  
      data[tail] = millis();
      Serial.println(tail,DEC);

      if(tail == 0){
        time_taking = data[tail] - data[3];
        Serial.println(time_taking);

          
      }else{
        time_taking = data[tail] - data[tail - 1];
        Serial.println(time_taking);
      }

      if(time_taking > time_max){
          succeed = 0;
          Serial.println("Heart rate measure error,test will restart!" );
          for(unsigned char i=0;i < 4;i ++)
          {
            data[i]=0;
          }
          data[3]=millis();
      }

      if(succeed){
        heartBeatLight(time_taking);
        if(tail >= 3){
          tail = 0;
          Serial.print("heart rate is : ");
          Serial.println(180000/(data[3]-data[0]));
          if((data[1]-data[0] < MRRIGHT_THRESHOLD)&&(data[2]-data[1] < MRRIGHT_THRESHOLD)&&(data[3]-data[2] < MRRIGHT_THRESHOLD)){
            MrRight();
            
              
          }


            
        }else{
          tail++;
          
        }

          
      }else{
        tail = 0;
        succeed = 1;

      }
    }else{
      Serial.print("calibrating now, step ");
      Serial.println(data_init_tail);

      data_init[data_init_tail] = millis();
      data_init_tail++;

      colorWipe(strip.Color(255,0,0),10);
      colorWipe(strip.Color(0,0,0),0);
      delay(10);



      if(data_init_tail >= 21){
        for(int i=0; i<20; i++){
            data_init[i] = data_init[i+1]-data_init[i];

        }

        for(int i=0; i<20; i++){
          for(int j=i+1; j<=20; j++){
            if(data_init[i] > data_init[j]){
                data_init[i] = data_init[i] ^ data_init[j];
                data_init[j] = data_init[i] ^ data_init[j];
                data_init[i] = data_init[i] ^ data_init[j];

            }
              
          }
        }

        Serial.print("data_init = ");
        for(int i=0; i<21; i++){
          Serial.print(data_init[i]);
          Serial.print(",");

            
        }
        Serial.println();


        
        
        MRRIGHT_THRESHOLD = (data_init[5]+data_init[4]+data_init[3]) / 3 - 50;
        Serial.print("Threhold is : ");
        Serial.println(MRRIGHT_THRESHOLD);
        mode = MODE_CALCULATE;

        colorWipe(strip.Color(0,255,0),10);
        colorWipe(strip.Color(0,0,0),0);

      }















    }



}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,847评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,208评论 1 292
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,587评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,942评论 0 205
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,332评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,587评论 1 218
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,853评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,568评论 0 198
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,273评论 1 242
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,542评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,033评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,373评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,031评论 3 236
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,073评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,830评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,628评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,537评论 2 269

推荐阅读更多精彩内容

  • 智能小车演示视频 摘要:该项目我会开源,大家一起参与进来,对智能小车进行完善。一定要牢记树莓派的GPIO引脚不能输...
    IT枫阅读 26,696评论 21 92
  • 今天继续让大脑熟悉快乐与感恩练习,通过21天的习惯养成练习,让大脑习惯快乐与感恩,以后就会更多接收快乐与感恩的信息...
    热爱生活的广佳阅读 107评论 0 0
  • 20岁,一个尴尬的年龄,正在上大学的我经济还不能独立,每个月靠着父母给的一千多的生活费过生活,平时吃饭买东西这些钱...
    unmi阅读 385评论 0 2
  • 租房的事情,一再强调,一再犯。 我每次找房子都各种纠结,除了价格以外,还有更重要的是所谓的房子质量。于是在网上找来...
    质子陈阅读 197评论 0 1
  • 都说爱情永远是甜蜜的!让人甜而不腻,时而想念、时而回味、时而不舍、时而苦笑不得、时而笑着笑着说莫名的流下泪来......
    苦丁茶咖阅读 450评论 1 4