基于51单片机的脉搏测量仪—心率计

基于51单片机的脉搏测量仪

(仿真+程序+原理图+设计报告)

功能介绍

具体功能:

本系统由STC89C51/52单片机+LCD1602显示模块+5mm红外接收管+LM358运放电路+按键模块等构成

1.手指放到红外对管中,2秒内读出心率;

2.LCD1602液晶显示当前的心率(心率/分钟);

3.按键可以设置报警的上下限心率,当测得的心率值超过报警值时发出报警。

​演示视频:

基于51单片机的脉搏测量仪—心率计

添加图片注释,不超过 140 字(可选)

程序

#include <reg52.h>
#include <intrins.h>	 //	包含头文件
/***公众号:木子单片机****/
#define uint            unsigned int
#define uchar           unsigned char
#define ulong           unsigned long	 //宏定义
#define LCD_DATA        P0				 //定义P0口为LCD_DATAsbit LCD_RS =P2^5;
sbit LCD_RW =P2^6;
sbit LCD_E  =P2^7;						 //定义LCD控制引脚sbit Xintiao =P1^0 ;					 //脉搏检测输入端定义
sbit speaker =P2^4;						 //蜂鸣器引脚定义void delay5ms(void);   //误差 0us
void LCD_WriteData(uchar LCD_1602_DATA);	 /********LCD1602数据写入***********/
void LCD_WriteCom(uchar LCD_1602_COM);		 /********LCD1602命令写入***********/
void lcd_1602_word(uchar Adress_Com,uchar Num_Adat,uchar *Adress_Data); /*1602字符显示函数,变量依次为字符显示首地址,显示字符长度,所显示的字符*/
void InitLcd();//液晶初始化函数void Tim_Init();uchar Xintiao_Change=0;	   //
uint  Xintiao_Jishu;
uchar stop;
uchar View_Data[3];
uchar View_L[3];
uchar View_H[3];
uchar Xintiao_H=100;	//脉搏上限
uchar Xintiao_L=40;		//脉搏下限uchar Key_Change;
uchar Key_Value;		//按键键值
uchar View_Con;			//设置的位(0正常工作,1设置上限,2设置下限)
uchar View_Change;void main()	  //主函数
{InitLcd();Tim_Init();lcd_1602_word(0x80,16,"Heart Rate:     ");	  //初始化显示TR0=1;TR1=1;				  //打开定时器while(1)			  //进入循环{if(Key_Change)	  //有按键按下并已经得出键值{Key_Change=0;	  //将按键使能变量清零,等待下次按键按下View_Change=1;switch(Key_Value)				//判断键值{case 1:						//设置键按下{View_Con++;			//设置的位加if(View_Con==3)		//都设置好后将此变量清零View_Con=0;break;				//跳出,下同}case 2:						//加键按下{if(View_Con==2)		//判断是设置上限{if(Xintiao_H<150)	//上限数值小于150Xintiao_H++;		//上限+}if(View_Con==1)		//如果是设置下限{if(Xintiao_L<Xintiao_H-1)//下限值小于上限-1(下限值不能超过上限)Xintiao_L++;		//下限值加}break;}case 3:						//减键按下{if(View_Con==2)		//设置上限{if(Xintiao_H>Xintiao_L+1)//上限数据大于下限+1(同样上限值不能小于下限)Xintiao_H--;		//上限数据减}if(View_Con==1)		//设置下限{if(Xintiao_L>30)	//下限数据大于30时Xintiao_L--;		//下限数据减}break;} }}if(View_Change)//开始显示变量{View_Change=0;//变量清零if(stop==0)			  //心率正常时{if(View_Data[0]==0x30) //最高位为0时不显示View_Data[0]=' ';}else					  //心率不正常(计数超过5000,也就是两次信号时间超过5s)不显示数据{View_Data[0]=' ';View_Data[1]=' ';View_Data[2]=' ';}switch(View_Con){case 0: //正常显示{lcd_1602_word(0x80,16,"Heart Rate:     ");//显示一行数据lcd_1602_word(0xc0,16,"                ");//显示第二行数据lcd_1602_word(0xcd,3,View_Data);			 //第二行显示心率break;}case 1: //设置下限时显示{lcd_1602_word(0x80,16,"Heart Rate:     ");//第一行显示心率lcd_1602_word(0x8d,3,View_Data);View_L[0]=Xintiao_L/100+0x30;		//将下限数据拆字View_L[1]=Xintiao_L%100/10+0x30;View_L[2]=Xintiao_L%10+0x30;if(View_L[0]==0x30)					//最高位为0时,不显示View_L[0]=' ';lcd_1602_word(0xC0,16,"Warning L :     ");//第二行显示下限数据lcd_1602_word(0xCd,3,View_L);break;}case 2: //设置上限时显示(同上){lcd_1602_word(0x80,16,"Heart Rate:     ");lcd_1602_word(0x8d,3,View_Data);View_H[0]=Xintiao_H/100+0x30;View_H[1]=Xintiao_H%100/10+0x30;View_H[2]=Xintiao_H%10+0x30;if(View_H[0]==0x30)View_H[0]=' ';lcd_1602_word(0xC0,16,"Warning H :     ");lcd_1602_word(0xCd,3,View_H);break;}}}}
}void Time1() interrupt 3		//定时器1服务函数
{static uchar Key_Con,Xintiao_Con;TH1=0xd8;		   //10msTL1=0xf0;		   //重新赋初值switch(Key_Con)   //无按键按下时此值为0{case 0:		   //每10ms扫描此处{if((P3&0x07)!=0x07)//扫描按键是否有按下{Key_Con++;		  //有按下此值加1,值为1}break;}case 1:					  //10ms后二次进入中断后扫描此处(Key_Con为1){if((P3&0x07)!=0x07)//第二次进入中断时,按键仍然是按下(起到按键延时去抖的作用){Key_Con++;		  //变量加1,值为2switch(P3&0x07)  //判断是哪个按键按下{case 0x06:Key_Value=1;break;	 //判断好按键后将键值赋值给变量Key_Valuecase 0x05:Key_Value=2;break;case 0x03:Key_Value=3;break;}}else								 //如果10ms时没有检测到按键按下(按下时间过短){Key_Con=0;						 //变量清零,重新检测按键}break;}case 2:									 //20ms后检测按键{if((P3&0x07)==0x07)				 //检测按键是否还是按下状态{Key_Change=1;					 //有按键按下使能变量,(此变量为1时才会处理键值数据)Key_Con=0;						//变量清零,等待下次有按键按下}break;}}switch (Xintiao_Con)//此处与上面按键的检测类似{case 0:			 //默认Xintiao_Con是为0的{if(!Xintiao)//每10ms(上面的定时器)检测一次脉搏是否有信号{Xintiao_Con++;//如果有信号,变量加一,程序就会往下走了}break;}case 1:{if(!Xintiao)	   //每过10ms检测一下信号是否还存在{Xintiao_Con++;//存在就加一}else{Xintiao_Con=0;//如果不存在了,检测时间很短,说明检测到的不是脉搏信号,可能是其他干扰,将变量清零,跳出此次检测} break;}case 2:{if(!Xintiao){Xintiao_Con++;//存在就加一}else{Xintiao_Con=0;//如果不存在了,检测时间很短,说明检测到的不是脉搏信号,可能是其他干扰,将变量清零,跳出此次检测} break;}case 3:{if(!Xintiao){Xintiao_Con++;//存在就加一}else{Xintiao_Con=0;//如果不存在了,检测时间很短,说明检测到的不是脉搏信号,可能是其他干扰,将变量清零,跳出此次检测} break;}case 4:{if(Xintiao)//超过30ms一直有信号,判定此次是脉搏信号,执行以下程序{if(Xintiao_Change==1)//心率计原理为检测两次脉冲间隔时间计算心率,变量Xintiao_Change第一次脉冲时为0的,所有走下面的else,第二次走这里{View_Data[0]=(60000/Xintiao_Jishu)/100+0x30;View_Data[1]=(60000/Xintiao_Jishu)%100/10+0x30;View_Data[2]=(60000/Xintiao_Jishu)%10+0x30;if(((60000/Xintiao_Jishu)>=Xintiao_H)||((60000/Xintiao_Jishu)<=Xintiao_L))//心率不在范围内报警speaker=0;			//蜂鸣器响elsespeaker=1;			//不响View_Change=1;	   //计算出心率后启动显示Xintiao_Jishu=0;	   //心跳计数清零Xintiao_Change=0;   //计算出心率后该变量清零,准备下次检测心率stop=0;			   //计算出心率后stop清零}else//第一次脉冲时Xintiao_Change为0{Xintiao_Jishu=0;	//脉冲计时变量清零,开始计时Xintiao_Change=1;//Xintiao_Change置1,准备第二次检测到脉冲时计算心率}Xintiao_Con=0;	//清零,准备检测下一次脉冲break;}}}
}
/**定时器T0工作函数**/
void Time0() interrupt 1
{TH0=0xfc;		   //1msTL0=0x18;		   //重新赋初值Xintiao_Jishu++;  //心跳计数加if(Xintiao_Jishu==5000)//心跳计数大于5000{Xintiao_Jishu=0;		//数据清零View_Change=1;		//显示位置1Xintiao_Change=0;	//置零,准备再次检测stop=1;	   //心跳计数超过5000后说明心率不正常或者没有测出,stop置1speaker=1;  //关闭蜂鸣器}
}
/**定时器初始化函数**/
void Tim_Init()
{EA=1;			  //打开中断总开关ET0=1;			  //打开T0中断允许开关ET1=1;			  //打开T1中断允许开关TMOD=0x11;		  //设定定时器状态TH0=0xfc;		   //1msTL0=0x18;		   //赋初值TH1=0xd8;		   //10msTL1=0xf0;		   //赋初值
}
/**在指定地址显示指定数量的指定字符**/
/**Adress_Com显示地址,Num_Adat显示字符数量,Adress_Data显示字符串内容**/ 
void lcd_1602_word(uchar Adress_Com,uchar Num_Adat,uchar *Adress_Data)
{uchar a=0;uchar Data_Word;LCD_WriteCom(Adress_Com); //选中地址for(a=0;a<Num_Adat;a++)   //for循环决定显示字符个数{Data_Word=*Adress_Data;	  //读取字符串数据LCD_WriteData(Data_Word);  //显示字符串Adress_Data++;			  //显示地址加一}
}

硬件设计

使用元器件:

单片机:STC89C51;

(注意:单片机是通用的,无论51还是52、无论stc还是at都一样,引脚功能都一样。程序也是一样的。)

9*15万用板;40脚IC座

8脚座;LM358芯片;

1602液晶;16p插针;

16p单排母座;按键*4;

5mm红外接收管;

5mm红外发射管;

103可调电位器;

2.2k电阻;1k电阻;

220Ω电阻;30k电阻*2;

200k电阻;10k电阻*6;

1.5k电阻;103排阻;

9012三极管;有源蜂鸣器;

1uf电容*2;331独石电容;

10uf电容;30pf电容*2;

12m晶振;Led(5MM红色);

DC电源接口;自锁开关;

导线:若干;

设计资料

01仿真图

本设计使用proteus8.9版本设计!具体如图!

添加图片注释,不超过 140 字(可选)

02原理图

本系统原理图采用Altium Designer19设计,具体如图!

添加图片注释,不超过 140 字(可选)

03程序

本设计使用软件keil5版本编程设计!具体如图!

添加图片注释,不超过 140 字(可选)

04设计报告

一万字参考报告,仅供参考!

添加图片注释,不超过 140 字(可选)

05设计资料

        资料获取请关注同名公众号,全部资料包括仿真源文件 、AD原理图、程序(含注释)、任务书、开题报告、设计报告、实物图、元件清单、演示视频等。具体内容如下,全网最全! !

可以关注下方公众号!

点赞分享一起学习成长。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/352716.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【Python】Redis数据库

Redis数据库 Unit01一、Redis1.1 概述1.2 安装1.3 Redis-cli1.4 数据类型1.5 字符处理1.6 键的命名规则 二、通用命令三、字符串(String)3.1 概述3.2 常用命令3.3 应用场景 四、列表(List)4.1 概述4.2 常用命令 五、集合(SET)5.1 概述5.3 常用命令 六、有序集合6.1 概述6.2 常用…

SyntaxError: EOL while scanning string literal

背景&#xff1a; 在对字符串使用in关系运算符时&#xff0c;报错SyntaxError: EOL while scanning string literal 原因&#xff1a; 这是因为${var}中有换行符\n导致的&#xff0c;通过Log ${var}可以看出换行符确实导致的字符串hello的引号位于两行&#xff0c;从而导致…

Spring Cloud 专题-前言篇(1)

引言 随着微服务架构的兴起&#xff0c;Spring Cloud 作为一套基于 Spring Boot 实现的云应用开发工具集&#xff0c;为开发者提供了在分布式系统&#xff08;如配置管理、服务发现、断路器、智能路由、微代理、控制总线等&#xff09;中快速构建一些常见模式的能力。本篇文档…

深度神经网络——什么是NLP(自然语言处理)?

自然语言处理&#xff08;NLP&#xff09; 是对使计算机能够处理、分析、解释和推理人类语言的技术和工具的研究和应用。 NLP 是一个跨学科领域&#xff0c;它结合了语言学和计算机科学等领域已建立的技术。 这些技术与人工智能结合使用来创建聊天机器人和数字助理&#xff0c;…

线性二次型调节器(LQR)举例

线性二次型调节器(LQR) 线性二次型调节器(LQR)是一种用于最优控制的问题,其中目标是通过最小化某个代价函数来找到最优控制策略。LQR特别适用于线性系统。为了在人形机器人上应用LQR进行建模,主要步骤包括建立系统模型、定义代价函数以及求解最优控制律。以下是详细步骤…

基于java《场馆预约MeetHere》【完整代码】和【完整测试流程报告】的资源

基于java《场馆预约MeetHere》【完整代码】和【完整测试流程报告】的资源 项目描述 MeetHere是一个场馆预约和管理的Web商务网站 普通用户&#xff1a;注册、登录、个人信息管理、查看场馆介绍和预约信息、场馆预约、场馆预约订单管理、查看新闻、留言管理&#xff08;发布、浏…

Day 25:1807. 替换字符串中的括号内容

Leetcode 1807. 替换字符串中的括号内容 给你一个字符串 s &#xff0c;它包含一些括号对&#xff0c;每个括号中包含一个 非空 的键。 比方说&#xff0c;字符串 “(name)is(age)yearsold” 中&#xff0c;有 两个 括号对&#xff0c;分别包含键 “name” 和 “age” 。 你知道…

【YOLO模型训练时,减小批次大小(Batch Size)可能会加快训练速度】

文章目录 1.在使用YOLOv8进行目标检测模型训练时&#xff0c;减小批次大小&#xff08;Batch Size&#xff09;可能会加快训练速度。2. 这种现象主要与以下几个因素有关&#xff1a;1.显存限制&#xff08;GPU Memory Constraints&#xff09;&#xff1a;2.梯度累积&#xff0…

参数搜索流形学习

目录 一、网格搜索1、介绍2、代码示例 二、HalvingGridSearch1、介绍2、代码示例 三、随机搜索1、介绍2、代码示例 三、贝叶斯搜索1、介绍2、代码示例 四、参数搜索总结五、流形学习1、LLE1、介绍2、官方代码示例 2、t-SNE1、介绍2、官方代码示例 一、网格搜索 1、介绍 网格搜…

BKP备份寄存器RTC实时时钟

BKP备份寄存器&RTC实时时钟 VDDA和VSSA是内部模拟部分的电路 VDD和VSS_1、2、3是内部数字电路的供电。系统以VDD开头的电源都是主电源。在正常使用STM32时&#xff0c;全部需要接到3.3v电源上。 VBAT备用电池供电引脚&#xff0c;如使用STM32内部的BKP和RTC&#xff0c;引…

SpringBoot修改banner

在resources目录下创建banner.txt文件 到该网站下选择banner https://www.bootschool.net/ascii-art 点击拷贝&#xff1a; 粘贴到banner.txt中&#xff0c;保存 重新运行项目即可&#xff1a;

JavaScript Window对象之(BOM、JS 执行机制、location对象、navigator对象、histroy对象、本地存储)

目录 1. BOM(浏览器对象模型)2. JS 执行机制3. location对象4. navigator对象5. histroy对象6. 本地存储6.1 localStorage6.2 sessionStorage 1. BOM(浏览器对象模型) BOM(Browser Object Model)是浏览器对象模型。其中window对象是JavaScript中一个全局的顶级对象基本的BOM属性…

MAC M1系统编译ffmpeg-gl-transition

MAC M1系统编译ffmpeg-gl-transition 1. 本人系统2. 编译&#x1f4b0;系统准备2.1. 下载【ffmpeg-gl-transition】到用户家目录下&#xff0c;并解压2.2 下载ffmpeg源码2.3. brew安装GLEW glfw32.4 复制vf_gltransition.c文件到ffmpeg2.5 修改ffmpeg源码文件2.6 设置库目录和…

SpringBoot购物网站

摘要 随着信息技术的高速发展&#xff0c;二十一世纪的网络技术和网络应用正在快速融入人们的生活&#xff0c;并且由于网络服务以及网络应用日渐普及&#xff0c;人们对于现在生活的需求也随之增长&#xff0c;而网上购物的便捷对人们的吸引力越来越大&#xff0c;购物网站可…

Redis 5种常用数据类型

目录 Redis简介 1.字符串 string 2.哈希 hash 3.列表 list 4.集合 set 5.有序集合 sorted set / zset Redis简介 Redis&#xff0c;全称Remote Dictionary Server&#xff0c;是一个开源的、内存中的数据结构存储系统。它可以用作数据库、缓存和消息中间件&#xff0c;支…

面向对象和面向过程

Python完全采用了面向对象的思想&#xff0c;是真正面向对象的编程语言&#xff0c;完全支持面向对象的基本功能&#xff0c;例如&#xff1a;继承、多态、封装等。 Python支持面向过程、面向对象、函数式编程等多种编程方式。而Java编程语言支持面向对象的编程方式&#xff0…

论文阅读Rolling-Unet,卷积结合MLP的图像分割模型

这篇论文提出了一种新的医学图像分割网络Rolling-Unet&#xff0c;目的是在不用Transformer的前提下&#xff0c;能同时有效提取局部特征和长距离依赖性,从而在性能和计算成本之间找到良好的平衡点。 论文地址&#xff1a;https://ojs.aaai.org/index.php/AAAI/article/view/2…

leetcode LRU 缓存

leetcode: LRU 缓存 LRU 全称为 Least Recently Used&#xff0c;最近最少使用&#xff0c;常常用于缓存机制&#xff0c;比如 cpu 的 cache 缓存&#xff0c;使用了 LRU 算法。LRU 用于缓存机制时&#xff0c;关键的是当缓存满的时候有新数据需要加载到缓存的&#xff0c;这个…

streamlit markdown里支持latex公式显示

参考&#xff1a; https://docs.streamlit.io/develop/api-reference/write-magic/st.write https://discuss.streamlit.io/t/streamlit-markdown-a-streaming-markdown-component-with-latex-mermaid-table-code-support/72187 也有独立支持的st.latex 接口单独显示公司&…

Python 引入中文py文件

目录 背景 思路 importlib介绍 使用方法 1.导入内置库 importlib.util 2.创建模块规格对象 spec importlib.util.spec_from_file_location("example_module", "example.py") 3.创建模块对象 module importlib.util.module_from_spec(spec) …