28-基于stm32单片机心率监测计步智能蓝牙手环源程序、原理图、元件清单实物制作

功能介绍:采用stm32单片机作为主控CPU,采用MAX30102采集心率,采用红外接触传感器来进行计步,OLED显示相关数据,并且将数据通过蓝牙HC-05模块发送到手机APP,完美实现了智能蓝牙手环的相关功能,文末有资料分享:

28-基于stm32单片机心率监测计步智能蓝牙手环(程序+原理图+元件清单全套资料)

程序部分展示,有中文注释,新手容易看懂
//血液检测信息更新
void blood_data_update(void)
{
	//标志位被使能时 读取FIFO
	g_fft_index=0;
	while(g_fft_index < FFT_N)
	{
		while(MAX30102_INTPin_Read()==0)
		{
			if(KEY0==0) 
			{
				while(KEY0!=1);
				adcx++;
				OLED_Printf_EN(6,0,"STEPS:%d  ",adcx);	
			}
		
	
			//读取FIFO
			max30102_read_fifo();  //read from MAX30102 FIFO2
			//将数据写入fft输入并清除输出
			if(g_fft_index < FFT_N)
			{
				//将数据写入fft输入并清除输出
				s1[g_fft_index].real = fifo_red;
				s1[g_fft_index].imag= 0;
				s2[g_fft_index].real = fifo_ir;
				s2[g_fft_index].imag= 0;
				g_fft_index++;
			}
		}
	}
}

//血液信息转换
void blood_data_translate(void)
{	
	float n_denom;
	uint16_t i;
	// 4 pt Moving Average
//	printf("****************red******************************************************************\r\n");
//	for(i = 0;i < FFT_N;i++) 
//	{
//		printf("%f\r\n",s1[i].real);	
//	}
//	printf("***************** ir*****************************************************************\r\n");
//	for(i = 0;i < FFT_N;i++) 
//	{
//		printf("%f\r\n",s2[i].real);	
//	}
	//直流滤波
	float dc_red =0; 
	float dc_ir =0;
	float ac_red =0; 
	float ac_ir =0;
	
	for (i=0 ; i<FFT_N ; i++ ) 
	{
		dc_red += s1[i].real ;
		dc_ir +=  s2[i].real ;
	}
		dc_red =dc_red/FFT_N ;
		dc_ir =dc_ir/FFT_N ;
	for (i=0 ; i<FFT_N ; i++ )  
	{
		s1[i].real =  s1[i].real - dc_red ; 
		s2[i].real =  s2[i].real - dc_ir ; 
	}
	
	//移动平均滤波
	//printf("***********8 pt Moving Average red******************************************************\r\n");
	for(i = 1;i < FFT_N-1;i++) 
	{
			n_denom= ( s1[i-1].real + 2*s1[i].real + s1[i+1].real);
			s1[i].real=  n_denom/4.00; 
			
			n_denom= ( s2[i-1].real + 2*s2[i].real + s2[i+1].real);
			s2[i].real=  n_denom/4.00; 			
	}
	//八点平均滤波
	for(i = 0;i < FFT_N-8;i++) 
	{
			n_denom= ( s1[i].real+s1[i+1].real+ s1[i+2].real+ s1[i+3].real+ s1[i+4].real+ s1[i+5].real+ s1[i+6].real+ s1[i+7].real);
			s1[i].real=  n_denom/8.00; 
			
			n_denom= ( s2[i].real+s2[i+1].real+ s2[i+2].real+ s2[i+3].real+ s2[i+4].real+ s2[i+5].real+ s2[i+6].real+ s2[i+7].real);
			s2[i].real=  n_denom/8.00; 
		
	//		printf("%f\r\n",s1[i].real);		
	}
	//printf("************8 pt Moving Average ir*************************************************************\r\n");
//	for(i = 0;i < FFT_N;i++) 
//	{
//	//	printf("%f\r\n",s2[i].real);	
//	}
	//printf("**************************************************************************************************\r\n");
	//开始变换显示	
	g_fft_index = 0;	
	//快速傅里叶变换
	FFT(s1);
	FFT(s2);
	
	//解平方
//	printf("开始FFT算法****************************************************************************************************\r\n");
	for(i = 0;i < FFT_N;i++) 
	{
		s1[i].real=sqrtf(s1[i].real*s1[i].real+s1[i].imag*s1[i].imag);
		s1[i].real=sqrtf(s2[i].real*s2[i].real+s2[i].imag*s2[i].imag);
	}
	//计算交流分量
	for (i=1 ; i<FFT_N ; i++ ) 
	{
		ac_red += s1[i].real ;
		ac_ir +=  s2[i].real ;
	}

 下面是原理图展示:

 百度云盘资料分享链接

DIY制作运动心率手表概述: 该运动心率手表基于microduino的BM模块、心率传感器模块、OLED显示模块构成。虽然第一版体积有些大(表盘达到了62mm,使用了一个切割的配件)。 一、OLED显示心率 二、与商业心率表、苹果的iwatch进行了比对,精度令人满意,这一点在跑步中已经得到测试。 三、LED跳动与脉搏同步。 视频展示: 所需模块及元器件: microduino core(328)一块 microduino TTL-USB 一块 microduino BM(电源管理套件,含电源管理板、开关接口小板以及600mah锂电一块) microduino 心率传感器模块(芯片SON7015超低功耗心率传感器) 电阻:220 欧姆 (三只,LED限流) OLED:0.61寸(32*96,来自某宝,支持u8glib) 参考库及例程:来自github,https://github.com/WorldFamousEl ... nsor_Amped_Arduino/ 关于BM模块: 便于安装、电源管理和充电及锂电池与一体。 一是开关接口小板与电源管理板分离,而且带安装孔(直径2mm),所以很方便用于DIY当中。 二是去掉了显示充电进度的分立led,欠压时,红色led显示即可。能耗降低。三是上电后,直接供电,不需要usb激活,这一点是 我最满意的,大大点赞。 从目前看,充电接口和小开关引出来,方便充电、开关电源。带了一块0.61寸的oled和一颗全彩5mm led,加上core。玩了几个小时, 表现还不错。 关于心率模块: 低功耗,厂家介绍耗电为0.2毫安。 从百度中引用:https://baike.baidu.com/link?url= ... ff9_ojMOGAvHug_tUu_ 利用特定波长红外线对血管末端血液微循环产生的血液容积的变化的敏感特性,检测由于心脏的跳动,引起指尖的血液变化, 经过信号放大、调整等电路处理。其中SON1303输出同步于脉搏跳动的脉冲信号,从而计算出脉率, SON7015输出反映指尖血容积变化的完整的脉搏波电压信号。主要应用于临床上脉率的测量、监测和脉搏波的病理分析。 简而言之:一块光电原理的心率传感器,和运行手表常用的电极式(感知皮肤电阻变化)原理不同。 详细的制作,详见附件内容。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值