欧美极品高清xxxxhd,国产日产欧美最新,无码AV国产东京热AV无码,国产精品人与动性XXX,国产传媒亚洲综合一区二区,四库影院永久国产精品,毛片免费免费高清视频,福利所导航夜趣136
標題:
單片機人體溫度脈搏設計
[打印本頁]
作者:
benben0101
時間:
2019-11-21 16:06
標題:
單片機人體溫度脈搏設計
基于51單片機的人體溫度測量&心率脈搏測量設計!適合廣大電子DIY師兄學習%%入門
0.jpg
(57.68 KB, 下載次數: 21)
下載附件
2019-11-23 23:26 上傳
單片機源程序如下:
#include<reg52.h>
#define uint unsigned int
#define uchar unsigned char
sbit rs=P1^0; //數據與命令選擇控制引腳
sbit rw=P1^1; //讀與寫選擇控制引腳
sbit en=P1^2; //使能擇控制引腳
sbit bf=P0^7; //忙標志位
sbit P32=P3^2;
sbit dq = P1^4; //18b20 IO口的定義
sbit beep = P1^3;
unsigned char i=0,timecount=0,displayOK=0,rate=0;
unsigned int time[6]={0};
uint temperature ; //
/************ 延時函數 *****************/
void delay(uint z)
{
while(z--);
}
/***********************18b20初始化函數*****************************/
void init_18b20()
{
bit q;
dq = 1; //把總線拿高
delay(1); //15us
dq = 0; //給復位脈沖
delay(80); //750us
dq = 1; //把總線拿高 等待
delay(10); //110us
q = dq; //讀取18b20初始化信號
delay(20); //200us
dq = 1; //把總線拿高 釋放總線
}
/*************寫18b20內的數據***************/
void write_18b20(uchar dat)
{
uchar i;
for(i=0;i<8;i++)
{ //寫數據是低位開始
dq = 0; //把總線拿低寫時間隙開始
dq = dat & 0x01; //向18b20總線寫數據了
delay(5); // 60us
dq = 1; //釋放總線
dat >>= 1;
}
}
/*************讀取18b20內的數據***************/
uchar read_18b20()
{
uchar i,value;
for(i=0;i<8;i++)
{
dq = 0; //把總線拿低讀時間隙開始
value >>= 1; //讀數據是低位開始
dq = 1; //釋放總線
if(dq == 1) //開始讀寫數據
value |= 0x80;
delay(5); //60us 讀一個時間隙最少要保持60us的時間
}
return value; //返回數據
}
/*************讀取溫度的值 讀出來的是小數***************/
uint read_temp()
{
uint value;
uchar low; //在讀取溫度的時候如果中斷的太頻繁了,就應該把中斷給關了,否則會影響到18b20的時序
init_18b20(); //初始化18b20
write_18b20(0xcc); //跳過64位ROM
write_18b20(0x44); //啟動一次溫度轉換命令
delay(50); //500us
init_18b20(); //初始化18b20
EA = 0;
write_18b20(0xcc); //跳過64位ROM
write_18b20(0xbe); //發出讀取暫存器命令
EA = 1;
low = read_18b20(); //讀溫度低字節
value = read_18b20(); //讀溫度高字節
value <<= 8; //把溫度的高位左移8位
value |= low; //把讀出的溫度低位放到value的低八位中
value *= 0.625; //轉換到溫度值 小數
return value; //返回讀出的溫度 帶小數
}
/************ 忙檢測函數 *****************/
void jiance()
{
P0=0xff;
rs=0;rw=1;en=1;
while(bf); //如果BF==1表示液晶在忙
en=0;
}
/************ 寫命令函數 *****************/
void write_com(uchar com)
{
jiance();
P0=com;
rs=0;rw=0;en=1;
delay(2);
en=0;
}
/************ 寫數據函數 *****************/
void write_dat(uchar dat)
{
jiance();
P0=dat;
rs=1;rw=0;en=1;
delay(2);
en=0;
}
/************ 1602液晶初始化函數 *****************/
void init_lcd()
{
write_com(0x38); // 設置16*2顯示,5*7點陣,8位數據接口
write_com(0x0c); // 開顯示,不顯示光標
write_com(0x06); // 地址加1,當寫入數據的時候光標右移
write_com(0x01); //清屏
}
/***********************lcd1602上顯示特定的字符************************/
void write_zifu(uchar hang,uchar add,uchar date)
{
if(hang==1)
write_com(0x80+add);
else
write_com(0x80+0x40+add);
write_dat(date);
}
/******************************************************************/
/* 在指定位置寫字符 */
/******************************************************************/
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;//設置外部中斷0
EX0=1;
TMOD=0x01;//定時器0初始化
TH0=(65536-50000)/256;//實測每50ms中斷的定時值
TL0=(65536-50000)%256;
ET0=1;//開定時器中斷
//顯示基本文字
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(3,1,'/');
LCD_write_char(4,1,'m');
LCD_write_char(5,1,'i');
LCD_write_char(6,1,'n');
LCD_write_char(8,1,'T');
LCD_write_char(9,1,':');
LCD_write_char(12,1,'.');
LCD_write_char(15,1,'C');
temperature = read_temp(); //先讀出溫度的值
TR0=0;//定時器停止
EA=1;//開總中斷
while(1)
{
temperature = read_temp(); //先讀出溫度的值
LCD_write_char(10,1,temperature/100%10+48);
LCD_write_char(11,1,temperature/10%10+48);
LCD_write_char(13,1,temperature%10+48);
write_zifu(2,14,0xdf); //顯示度
if(displayOK==1)
{
rate=60000/(time[1]/5+time[2]/5+time[3]/5+time[4]/5+time[5]/5);
LCD_write_char(0,1,rate/100+48);
LCD_write_char(1,1,(rate%100)/10+48);
LCD_write_char(2,1,rate%10+48);
}
DelayMs(300);
if(temperature>375)
beep = ~beep;
else beep = 1;
}
}
void ex0() interrupt 0
{
EX0=0;//暫時關外部中斷
if(timecount<8) //當連續兩次檢測時間間隔小于8*50ms=400ms不處理
{
TR0=1;//開定時器
}
else
{
time[i]=timecount*50+TH0*0.256+TL0/1000;//算出間隔時間
TL0=(65536-50000)%256;//重新設置定時器
TH0=(65536-50000)/256;
timecount=0;//50ms計數清零
i++;
if(i==6)//記錄到超過等于6次時間
{
i=1;//計數從1開始
displayOK=1; //測得5次開始顯示
}
}
EX0=1;
}
void et0() interrupt 1
{
TL0=(65536-50000)%256;
TH0=(65536-50000)/256;
timecount++;//每50ms一次計數
if(timecount>25) //當超過25*50ms=1.25s沒有檢測到信號停止顯示
{
i=0;//數據個數清零
timecount=0;//50ms計數清零
displayOK=0;//顯示關
// rate=0;
// LCD_write_char(0,1,0+48);
// LCD_write_char(1,1,0+48);
// LCD_write_char(2,1,0+48);
TR0=0;//定時器關
TH0=(65536-50000)/256;
TL0=(65536-50000)%256;
}
}
復制代碼
所有資料51hei提供下載:
心率溫度測量程序.zip
(33.94 KB, 下載次數: 16)
2019-11-21 16:03 上傳
點擊文件名下載附件
下載積分: 黑幣 -5
心率溫度測量原理圖.zip
(128.44 KB, 下載次數: 16)
2019-11-21 16:04 上傳
點擊文件名下載附件
下載積分: 黑幣 -5
歡迎光臨 (http://m.raoushi.com/bbs/)
Powered by Discuz! X3.1