标题:
单片机人体温度脉搏设计
[打印本页]
作者:
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://www.51hei.com/bbs/)
Powered by Discuz! X3.1