找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 4417|回复: 2
收起左侧

基于51单片机的心率脉搏仪源程序+电路

[复制链接]
ID:573032 发表于 2019-6-27 11:18 | 显示全部楼层 |阅读模式
硬件构成:单片机+最小系统+LCD1602液晶显示模块+红外传感器+运放模块+蜂鸣器模块+LED指示灯模块+按键模块

按键可以设置心率的上下限报警值,四个按键:复位按键、设置、加、减;


1.单片机型号STC89C52。
2.本系统自带单片机上电复位电路,晶振电路,手动复位电路(即复位按键)。
3.可以用按键设置,设置心率的上、下限报警值,并具有掉电保存,保存在STC单片机的内部,上电无需重新设置。
4.当实际测到的心率次数超过上限或低于下限时,蜂鸣器报警提示心率不正常。
5.LCD1602液晶第一行显示当前的心率,单位是心率/分钟,第二行显示设定的上、下限报警值。
6.把手指放在光电传感器上,要轻轻的压在传感器上面,尽量要其他手指支撑起要测脉搏的手指头。
7.手指放上去后5秒左右指示灯会闪烁,说明已经测到您的脉搏了。
8.人脉搏跳动的时候,血液的透光性不一样会导致接收器那边接收的信号强弱不一样,因此可以把变化的信号滤波、放大、整形等系列处理后 ,单片机利用外部中断对其进行计数,最终换算成人一分钟脉搏的跳动次数显示在液晶屏上。

电路原理图如下:
QQ截图20190627111110.png

单片机源程序如下:
  1. #include<reg52.h>
  2. #include<stdio.h>
  3. #include<intrins.h>
  4. #include"lcd1602.H"
  5. #define uchar unsigned char
  6. #define uint unsigned int
  7. #define ulong unsigned long
  8. unsigned int i,n,ci,dd[11],jj,j,k,tmp;
  9. bit w=0;
  10. uchar bh;
  11. ulong time;
  12. sbit spd = P2^0;


  13. external0() interrupt 0//外部中断服务程序
  14. {
  15.           w=~w;
  16.         if(w==0)
  17.         {
  18.           EX0=0;
  19.           ET0=1;
  20.           TH0=0x0;
  21.       TL0=0x0;
  22.           n=0;
  23.         }
  24.         else
  25.         {
  26.                 time=n*65536+TH0*256+TL0;
  27.                 dd[jj]=30000000/time;
  28.                 jj++;
  29.                 if(jj>10)
  30.                 {
  31.                    jj=0;
  32.                    for(j=0;j<11;j++)
  33.                       for(k=0;k<11-j;k++)
  34.                              {
  35.                                      if(dd[k]>dd[k+1])
  36.                                           {
  37.                                                    tmp=dd[k];
  38.                                                   dd[k]=dd[k+1];
  39.                                                  dd[k+1]=tmp;
  40.                                          
  41.                                           }
  42.                                           

  43.                                  
  44.                                  }
  45.                    if(dd[5]>50&&dd[5]<200)ci=((dd[4]+dd[5]+dd[6])/3)+11;
  46.         
  47.                 }
  48.                 TH0=0x0;
  49.         TL0=0x0;
  50.                 n=0;
  51.         
  52.         }
  53. }
  54. void timer0(void) interrupt 1
  55. {
  56. n++;

  57. }

  58. void delay(void)   //误差 0us
  59. {
  60.    unsigned char a,b,c;
  61.     for(c=123;c>0;c--)
  62.         for(b=116;b>0;b--)
  63.             for(a=9;a>0;a--);
  64. }

  65. /////////////////////////////////////////////////////////////////
  66. void main(void)
  67. {
  68. InitLcd();//
  69. DelayMs(15);
  70. IT0=1;     //INT0下降沿中断
  71. EX0=1;     //允许INT1中断
  72. TMOD=0x1;
  73. TH0=0x0;
  74. TL0=0x0;
  75. TR0=1;
  76. ET0=1;
  77. EA=1;

  78. while(1)
  79. {
  80.          if(n>10)
  81.          {
  82.                  n=0;         
  83.                  jj=0;
  84.                  ci=0;
  85.                 TimeNum[0]='N';
  86.          TimeNum[1]='O' ;
  87.              TimeNum[2]=' ' ;
  88.              TimeNum[3]='I' ;        
  89.              TimeNum[4]='N' ;
  90.                  TimeNum[5]='P' ;
  91.                  TimeNum[6]='U' ;
  92.                  TimeNum[7]='T' ;
  93.                  TimeNum[8]=' ' ;
  94.                   ShowString(0,TimeNum);
  95.              ShowString(1,Test1);
  96.           }
  97.           else        
  98.           {
  99.                   if(w==0&&EX0==0)
  100.                     {
  101.                           delay();
  102.                           EX0=1;
  103.                         }  

  104.                   TimeNum[0]=' ';
  105.          TimeNum[1]=' ' ;
  106.              TimeNum[2]=' ' ;
  107.              TimeNum[3]=' ' ;        
  108.              TimeNum[4]=' ' ;         
  109.                  TimeNum[5]=' ' ;
  110.                   
  111.                   if(ci/100>0)TimeNum[6]=ci/100+'0' ; else TimeNum[6]=' ' ;
  112.                   if(ci/100==0&&ci%100/10>0)TimeNum[7]=ci%100/10+'0' ; else TimeNum[7]=' ' ;
  113.                   TimeNum[8]=ci%10+'0' ;
  114.                   ShowString(0,TimeNum);
  115.                   ShowString(1,Test1);
  116.                   if(ci>100)spd=0;else spd=1;
  117.             }
  118.   
  119.    }
  120. ;
  121. }
复制代码

所有资料51hei提供下载:
心率脉搏仪源码.zip (60.38 KB, 下载次数: 97)
回复

使用道具 举报

ID:923615 发表于 2021-5-19 19:49 | 显示全部楼层
下载后要如何打开呢?安装些什么软件,求大神告知
回复

使用道具 举报

ID:486462 发表于 2023-2-17 16:53 | 显示全部楼层
PDF的第三个,源文件有没有
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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