標(biāo)題: 基于51單片機(jī)的心率計(jì) [打印本頁]

作者: karrychen    時(shí)間: 2017-10-18 09:32
標(biāo)題: 基于51單片機(jī)的心率計(jì)

人體的健康與心率息息相關(guān)。在中醫(yī)史上,把脈即是對心率的一種測量。為了提高測量的精準(zhǔn)度,科學(xué)家們不斷的對心率計(jì)進(jìn)行開拓;诹私饬嗽撔穆视(jì)的要求后,設(shè)計(jì)了以AT89C51單片機(jī)為核心芯片的心率計(jì)。該心率計(jì)由單片機(jī)模塊、反射式紅外光電傳感器模塊、液晶顯示模塊等構(gòu)成,并進(jìn)行相應(yīng)的軟件設(shè)計(jì)和硬件調(diào)試。利用反射式紅外光電傳感器將心跳引起的血液濃度的變化轉(zhuǎn)變?yōu)殡妷盒盘枺瑢㈦妷盒盘柼幚砗髠鹘o單片機(jī),由單片機(jī)實(shí)現(xiàn)定時(shí)計(jì)數(shù)得出心率,并由液晶顯示模塊顯示心率。經(jīng)過一系列的調(diào)試,該心率計(jì)實(shí)現(xiàn)了對心率的準(zhǔn)確測量,達(dá)到了本設(shè)計(jì)所預(yù)期的效果,具有一定的實(shí)際意義和應(yīng)用前景。

原理圖如下:
心率脈搏計(jì)-51-1602.pdf (192.9 KB, 下載次數(shù): 41)

作者: admin    時(shí)間: 2017-10-19 02:27
樓主能分享一下圖片和源碼嗎?
作者: karrychen    時(shí)間: 2017-11-8 17:05
#include<reg52.h>
#define uint unsigned int
#define uchar unsigned char
sbit rs=P1^0;                             //數(shù)據(jù)與命令選擇控制引腳
sbit rw=P1^1;                                 //讀與寫選擇控制引腳
sbit en=P1^2;                                 //使能擇控制引腳
sbit bf=P0^7;                                 //忙標(biāo)志位

sbit P32=P3^2;

unsigned char i=0,timecount=0,displayOK=0,rate=0,aa=0;
unsigned int time[6]={0};

/************ 延時(shí)函數(shù)  *****************/
void delay(uint z)
{
   while(z--);
}
/************ 忙檢測函數(shù)  *****************/
void jiance()
{
  P0=0xff;
  rs=0;rw=1;en=1;
  while(bf);                        //如果BF==1表示液晶在忙
  en=0;
}
/************ 寫命令函數(shù)  *****************/
void write_com(uchar com)
{
   jiance();
   P0=com;
   rs=0;rw=0;en=1;
   delay(2);
   en=0;
}
/************ 寫數(shù)據(jù)函數(shù)  *****************/
void write_dat(uchar dat)
{
   jiance();
   P0=dat;
   rs=1;rw=0;en=1;
   delay(2);
   en=0;
}
/************ 1602液晶初始化函數(shù)  *****************/
void init_lcd()
{
   write_com(0x38);           // 設(shè)置16*2顯示,5*7點(diǎn)陣,8位數(shù)據(jù)接口
   write_com(0x0c);           // 開顯示,不顯示光標(biāo)
   write_com(0x06);           // 地址加1,當(dāng)寫入數(shù)據(jù)的時(shí)候光標(biāo)右移
   write_com(0x01);           //清屏
}

/******************************************************************/
/*                   在指定位置寫字符                                 */
/******************************************************************/
void LCD_write_char(unsigned char x,unsigned char y,unsigned char Data)
{     
    if (y == 0)  
    write_com(0x80 + x);     
    else     
    write_com(0xC0 + x);            
    write_dat(Data);  
}
void DelayMs(unsigned int z)
{
   unsigned int x;
   for(;z>0;z--)
     for(x=110;x>0;x--);
}         
void main()
{
                P32=1;
                init_lcd();//lcd初始化
                TCON=0x01;//設(shè)置外部中斷0
                EX0=1;
                TMOD=0x01;//定時(shí)器0初始化
                TH0=(65536-50000)/256;//實(shí)測每50ms中斷的定時(shí)值
                TL0=(65536-50000)%256;
                ET0=1;//開定時(shí)器中斷
                //顯示基本文字
                LCD_write_char(3,0,'H');
                LCD_write_char(4,0,'e');
                LCD_write_char(5,0,'a');
                LCD_write_char(6,0,'r');
                LCD_write_char(7,0,'t');
                LCD_write_char(8,0,' ');
                LCD_write_char(9,0,'R');
                LCD_write_char(10,0,'a');
                LCD_write_char(11,0,'t');
                LCD_write_char(12,0,'e');

                LCD_write_char(8,1,'/');
                LCD_write_char(9,1,'m');
                LCD_write_char(10,1,'i');
                LCD_write_char(11,1,'n');
                TR0=0;//定時(shí)器停止
                EA=1;//開總中斷
                while(1)
                {
                               
                                if(displayOK==1)
                                {
                                                rate=60000/(time[1]/5+time[2]/5+time[3]/5+time[4]/5+time[5]/5);
                                                LCD_write_char(5,1,rate/100+48);
                                                LCD_write_char(6,1,(rate%100)/10+48);
                                                LCD_write_char(7,1,rate%10+48);
                                }
                                DelayMs(300);
                }
}

void ex0() interrupt 0
{
                EX0=0;//暫時(shí)關(guān)外部中斷
                if(timecount<8)   //當(dāng)連續(xù)兩次檢測時(shí)間間隔小于8*50ms=400ms不處理
                {
                                TR0=1;//開定時(shí)器
                }
                else
                {
                                time[i]=timecount*50+TH0*0.256+TL0/1000;//算出間隔時(shí)間
                                TL0=(65536-50000)%256;//重新設(shè)置定時(shí)器
                                TH0=(65536-50000)/256;
                                timecount=0;//50ms計(jì)數(shù)清零
                                i++;
                                if(i==6)//記錄到超過等于6次時(shí)間
                                {
                                                i=1;//計(jì)數(shù)從1開始
                                                displayOK=1;    //測得5次開始顯示
                                }       
                               
                }
                EX0=1;
}
void et0() interrupt 1
{
                TL0=(65536-50000)%256;
                TH0=(65536-50000)/256;
                       
                timecount++;//每50ms一次計(jì)數(shù)
                if(timecount>25)     //當(dāng)超過25*50ms=1.25s沒有檢測到信號停止顯示
                {
                                i=0;//數(shù)據(jù)個數(shù)清零
                                timecount=0;//50ms計(jì)數(shù)清零
                                displayOK=0;//顯示關(guān)
                                TR0=0;//定時(shí)器關(guān)
                                TH0=(65536-50000)/256;
                                TL0=(65536-50000)%256;
                }
}

IMG_20160430_184524.jpg (3.68 MB, 下載次數(shù): 88)

IMG_20160430_184524.jpg

作者: 半夏易水寒    時(shí)間: 2019-7-28 14:40
學(xué)習(xí)了,謝謝樓主




歡迎光臨 (http://www.torrancerestoration.com/bbs/) Powered by Discuz! X3.1