標(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)
2017-10-18 09:32 上傳
點(diǎn)擊文件名下載附件
原理圖
下載積分: 黑幣 -5
作者: 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)
下載附件
2017-11-8 17:04 上傳
作者: 半夏易水寒 時(shí)間: 2019-7-28 14:40
學(xué)習(xí)了,謝謝樓主
歡迎光臨 (http://www.torrancerestoration.com/bbs/) |
Powered by Discuz! X3.1 |