找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 1733|回复: 0
打印 上一主题 下一主题
收起左侧

单片机人体温度脉搏设计

[复制链接]
跳转到指定楼层
楼主
基于51单片机的人体温度测量&心率脉搏测量设计!适合广大电子DIY师兄学习%%入门


单片机源程序如下:
  1. #include<reg52.h>
  2. #define uint unsigned int
  3. #define uchar unsigned char
  4. sbit rs=P1^0;                             //数据与命令选择控制引脚
  5. sbit rw=P1^1;                                 //读与写选择控制引脚
  6. sbit en=P1^2;                                 //使能择控制引脚
  7. sbit bf=P0^7;                                 //忙标志位

  8. sbit P32=P3^2;
  9. sbit dq   = P1^4;        //18b20 IO口的定义
  10. sbit beep = P1^3;
  11. unsigned char i=0,timecount=0,displayOK=0,rate=0;
  12. unsigned int time[6]={0};
  13. uint temperature ;  //
  14. /************ 延时函数  *****************/
  15. void delay(uint z)
  16. {
  17.    while(z--);
  18. }
  19. /***********************18b20初始化函数*****************************/
  20. void init_18b20()
  21. {
  22.         bit q;
  23.         dq = 1;                                //把总线拿高
  24.         delay(1);            //15us
  25.         dq = 0;                                //给复位脉冲
  26.         delay(80);                //750us
  27.         dq = 1;                                //把总线拿高 等待
  28.         delay(10);                //110us
  29.         q = dq;                                //读取18b20初始化信号
  30.         delay(20);                //200us
  31.         dq = 1;                                //把总线拿高 释放总线
  32. }

  33. /*************写18b20内的数据***************/
  34. void write_18b20(uchar dat)
  35. {
  36.         uchar i;
  37.         for(i=0;i<8;i++)
  38.         {                                         //写数据是低位开始
  39.                 dq = 0;                         //把总线拿低写时间隙开始
  40.                 dq = dat & 0x01; //向18b20总线写数据了
  41.                 delay(5);         // 60us
  42.                 dq = 1;                         //释放总线
  43.                 dat >>= 1;
  44.         }       
  45. }

  46. /*************读取18b20内的数据***************/
  47. uchar read_18b20()
  48. {
  49.         uchar i,value;
  50.         for(i=0;i<8;i++)
  51.         {
  52.                 dq = 0;                         //把总线拿低读时间隙开始
  53.                 value >>= 1;         //读数据是低位开始
  54.                 dq = 1;                         //释放总线
  55.                 if(dq == 1)                 //开始读写数据
  56.                         value |= 0x80;
  57.                 delay(5);         //60us        读一个时间隙最少要保持60us的时间
  58.         }
  59.         return value;                 //返回数据
  60. }

  61. /*************读取温度的值 读出来的是小数***************/
  62. uint read_temp()
  63. {
  64.         uint value;
  65.         uchar low;                           //在读取温度的时候如果中断的太频繁了,就应该把中断给关了,否则会影响到18b20的时序
  66.         init_18b20();                   //初始化18b20
  67.         write_18b20(0xcc);           //跳过64位ROM
  68.         write_18b20(0x44);           //启动一次温度转换命令
  69.         delay(50);                   //500us

  70.         init_18b20();                   //初始化18b20
  71.         EA = 0;
  72.         write_18b20(0xcc);           //跳过64位ROM
  73.         write_18b20(0xbe);           //发出读取暂存器命令
  74.         EA = 1;

  75.         low = read_18b20();           //读温度低字节
  76.         value = read_18b20();  //读温度高字节

  77.         value <<= 8;                   //把温度的高位左移8位
  78.         value |= low;                   //把读出的温度低位放到value的低八位中
  79.         value *= 0.625;               //转换到温度值 小数
  80.         return value;                   //返回读出的温度 带小数
  81. }
  82. /************ 忙检测函数  *****************/
  83. void jiance()
  84. {
  85.   P0=0xff;
  86.   rs=0;rw=1;en=1;
  87.   while(bf);                        //如果BF==1表示液晶在忙
  88.   en=0;
  89. }
  90. /************ 写命令函数  *****************/
  91. void write_com(uchar com)
  92. {
  93.    jiance();
  94.    P0=com;
  95.    rs=0;rw=0;en=1;
  96.    delay(2);
  97.    en=0;
  98. }
  99. /************ 写数据函数  *****************/
  100. void write_dat(uchar dat)
  101. {
  102.    jiance();
  103.    P0=dat;
  104.    rs=1;rw=0;en=1;
  105.    delay(2);
  106.    en=0;
  107. }
  108. /************ 1602液晶初始化函数  *****************/
  109. void init_lcd()
  110. {
  111.    write_com(0x38);           // 设置16*2显示,5*7点阵,8位数据接口
  112.    write_com(0x0c);           // 开显示,不显示光标
  113.    write_com(0x06);           // 地址加1,当写入数据的时候光标右移
  114.    write_com(0x01);           //清屏
  115. }
  116. /***********************lcd1602上显示特定的字符************************/
  117. void write_zifu(uchar hang,uchar add,uchar date)
  118. {
  119.         if(hang==1)   
  120.                 write_com(0x80+add);
  121.         else
  122.                 write_com(0x80+0x40+add);
  123.         write_dat(date);       
  124. }

  125. /******************************************************************/
  126. /*                   在指定位置写字符                                 */
  127. /******************************************************************/
  128. void LCD_write_char(unsigned char x,unsigned char y,unsigned char Data)
  129. {     
  130.     if (y == 0)  
  131.     write_com(0x80 + x);     
  132.     else     
  133.     write_com(0xC0 + x);            
  134.     write_dat(Data);  
  135. }
  136. void DelayMs(unsigned int z)
  137. {
  138.    unsigned int x;
  139.    for(;z>0;z--)
  140.      for(x=110;x>0;x--);
  141. }         
  142. void main()
  143. {
  144.                 P32=1;
  145.                 init_lcd();//lcd初始化
  146.                 TCON=0x01;//设置外部中断0
  147.                 EX0=1;
  148.                 TMOD=0x01;//定时器0初始化
  149.                 TH0=(65536-50000)/256;//实测每50ms中断的定时值
  150.                 TL0=(65536-50000)%256;
  151.                 ET0=1;//开定时器中断
  152.                 //显示基本文字
  153.                 LCD_write_char(3,0,'H');
  154.                 LCD_write_char(4,0,'e');
  155.                 LCD_write_char(5,0,'a');
  156.                 LCD_write_char(6,0,'r');
  157.                 LCD_write_char(7,0,'t');
  158.                 LCD_write_char(8,0,' ');
  159.                 LCD_write_char(9,0,'R');
  160.                 LCD_write_char(10,0,'a');
  161.                 LCD_write_char(11,0,'t');
  162.                 LCD_write_char(12,0,'e');

  163.                 LCD_write_char(3,1,'/');
  164.                 LCD_write_char(4,1,'m');
  165.                 LCD_write_char(5,1,'i');
  166.                 LCD_write_char(6,1,'n');
  167.                 LCD_write_char(8,1,'T');
  168.                 LCD_write_char(9,1,':');
  169.                 LCD_write_char(12,1,'.');
  170.                 LCD_write_char(15,1,'C');
  171.                 temperature = read_temp();                         //先读出温度的值
  172.                 TR0=0;//定时器停止
  173.                 EA=1;//开总中断
  174.                 while(1)
  175.                 {
  176.                                 temperature = read_temp();        //先读出温度的值
  177.                                 LCD_write_char(10,1,temperature/100%10+48);
  178.                                 LCD_write_char(11,1,temperature/10%10+48);
  179.                                 LCD_write_char(13,1,temperature%10+48);
  180.                                 write_zifu(2,14,0xdf);  //显示度
  181.                                 if(displayOK==1)
  182.                                 {
  183.                                                 rate=60000/(time[1]/5+time[2]/5+time[3]/5+time[4]/5+time[5]/5);
  184.                                                 LCD_write_char(0,1,rate/100+48);
  185.                                                 LCD_write_char(1,1,(rate%100)/10+48);
  186.                                                 LCD_write_char(2,1,rate%10+48);
  187.                                 }
  188.                                 DelayMs(300);
  189.                                 if(temperature>375)
  190.                                 beep = ~beep;
  191.                                 else beep = 1;
  192.                 }
  193. }

  194. void ex0() interrupt 0
  195. {
  196.                 EX0=0;//暂时关外部中断
  197.                 if(timecount<8)   //当连续两次检测时间间隔小于8*50ms=400ms不处理
  198.                 {
  199.                                 TR0=1;//开定时器
  200.                 }
  201.                 else
  202.                 {
  203.                                 time[i]=timecount*50+TH0*0.256+TL0/1000;//算出间隔时间
  204.                                 TL0=(65536-50000)%256;//重新设置定时器
  205.                                 TH0=(65536-50000)/256;
  206.                                 timecount=0;//50ms计数清零
  207.                                 i++;
  208.                                 if(i==6)//记录到超过等于6次时间
  209.                                 {
  210.                                                 i=1;//计数从1开始
  211.                                                 displayOK=1;    //测得5次开始显示
  212.                                 }       
  213.                                
  214.                 }
  215.                 EX0=1;
  216. }
  217. void et0() interrupt 1
  218. {
  219.                 TL0=(65536-50000)%256;
  220.                 TH0=(65536-50000)/256;
  221.                        
  222.                 timecount++;//每50ms一次计数
  223.                 if(timecount>25)     //当超过25*50ms=1.25s没有检测到信号停止显示
  224.                 {
  225.                                 i=0;//数据个数清零
  226.                                 timecount=0;//50ms计数清零
  227.                                 displayOK=0;//显示关
  228. //                                rate=0;
  229. //                                LCD_write_char(0,1,0+48);
  230. //                                LCD_write_char(1,1,0+48);
  231. //                                LCD_write_char(2,1,0+48);
  232.                                 TR0=0;//定时器关
  233.                                 TH0=(65536-50000)/256;
  234.                                 TL0=(65536-50000)%256;
  235.                 }
  236. }
复制代码

所有资料51hei提供下载:
心率温度测量程序.zip (33.94 KB, 下载次数: 16)
心率温度测量原理图.zip (128.44 KB, 下载次数: 16)

评分

参与人数 1黑币 +50 收起 理由
admin + 50 共享资料的黑币奖励!

查看全部评分

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖 顶 踩
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表