OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 15262|回复: 22

本人小白,刚买了一个心率传感器,想用stm32做一个便携式心率仪,有高手能指教一下具体怎么做吗

[复制链接]

9

主题

25

帖子

0

精华

初级会员

Rank: 2

积分
81
金钱
81
注册时间
2014-3-4
在线时间
0 小时
发表于 2014-3-23 10:48:51 | 显示全部楼层 |阅读模式
本人小白,刚买了一个心率传感器,想用stm32做一个便携式心率仪,有高手能指教一下具体怎么做吗




相关文档:
使用手册:[url=]http://pulse-sensor.googlecode.com/files/PulseSensorAmpedGettingStartedGuide.pdf[/url]
Arduino 库文件:https://pulse-sensor.googlecode.com/files/PulseSensorAmped_Arduino_1dot2.zip
Processing 演示文件:https://pulse-sensor.googlecode.com/files/PulseSensorAmped_HRV_PoncairePlot.zip
求大神指教~
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

0

主题

1

帖子

0

精华

新手入门

积分
7
金钱
7
注册时间
2019-10-30
在线时间
2 小时
发表于 2020-4-19 13:58:33 | 显示全部楼层
老窝老徐 发表于 2016-11-1 11:27
/**************************adc.c文件**********************************/
#include "adc.h"
#include  ...

老哥 能不能把你的工程文件发一份?有c8t6的就更完美了
回复 支持 2 反对 0

使用道具 举报

0

主题

15

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
359
金钱
359
注册时间
2016-10-31
在线时间
50 小时
发表于 2016-11-1 11:27:36 | 显示全部楼层
/**************************adc.c文件**********************************/
#include "adc.h"
#include "delay.h"                 
////////////////////////        


//初始化ADC                                                                                                                          
void  Adc_Init(void)
{   
  GPIO_InitTypeDef  GPIO_InitStructure;
        ADC_CommonInitTypeDef ADC_CommonInitStructure;
        ADC_InitTypeDef       ADC_InitStructure;
       
  RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOA, ENABLE);//使能GPIOA时钟
  RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1, ENABLE); //使能ADC1时钟

  //先初始化ADC1通道5 IO口
  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_5;//PA5 通道5
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AN;//模拟输入
  GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL ;//不带上下拉
  GPIO_Init(GPIOA, &GPIO_InitStructure);//初始化  

        //RCC_APB2PeriphResetCmd(RCC_APB2Periph_ADC1,ENABLE);          //ADC1复位
        //RCC_APB2PeriphResetCmd(RCC_APB2Periph_ADC1,DISABLE);        //复位结束         

       
  ADC_CommonInitStructure.ADC_Mode = ADC_Mode_Independent;//独立模式
  ADC_CommonInitStructure.ADC_TwoSamplingDelay = ADC_TwoSamplingDelay_5Cycles;//两个采样阶段之间的延迟5个时钟
  ADC_CommonInitStructure.ADC_DMAAccessMode = ADC_DMAAccessMode_Disabled; //DMA失能
  ADC_CommonInitStructure.ADC_Prescaler = ADC_Prescaler_Div4;//预分频4分频。ADCCLK=PCLK2/4=84/4=2j1Mhz,ADC时钟最好不要超过36Mhz
  ADC_CommonInit(&ADC_CommonInitStructure);//初始化
       
  ADC_InitStructure.ADC_Resolution = ADC_Resolution_10b;//12位模式
  ADC_InitStructure.ADC_ScanConvMode = DISABLE;//非扫描模式       
  ADC_InitStructure.ADC_ContinuousConvMode = DISABLE;//关闭连续转换
  ADC_InitStructure.ADC_ExternalTrigConvEdge = ADC_ExternalTrigConvEdge_None;//禁止触发检测,使用软件触发
  ADC_InitStructure.ADC_DataAlign = ADC_DataAlign_Right;//右对齐       
  ADC_InitStructure.ADC_NbrOfConversion = 1;//1个转换在规则序列中 也就是只转换规则序列1
  ADC_Init(ADC1, &ADC_InitStructure);//ADC初始化
       

        ADC_Cmd(ADC1, ENABLE);//开启AD转换器       

}                                  
//获得ADC值
//ch: @ref ADC_channels
//通道值 0~16取值范围为:ADC_Channel_0~ADC_Channel_16
//返回值:转换结果
u16 Get_Adc(u8 ch)   
{
                  //设置指定ADC的规则组通道,一个序列,采样时间
        ADC_RegularChannelConfig(ADC1, ch, 1, ADC_SampleTime_480Cycles );        //ADC1,ADC通道,480个周期,提高采样时间可以提高精确度                            
  
        ADC_SoftwareStartConv(ADC1);                //使能指定的ADC1的软件转换启动功能       
         
        while(!ADC_GetFlagStatus(ADC1, ADC_FLAG_EOC ));//等待转换结束

        return ADC_GetConversionValue(ADC1);        //返回最近一次ADC1规则组的转换结果
}
//获取通道ch的转换值,取times次,然后平均
//ch:通道编号
//times:获取次数
//返回值:通道ch的times次转换结果平均值
u16 Get_Adc_Average(u8 ch,u8 times)
{
        u32 temp_val=0;
        u8 t;
        for(t=0;t<times;t++)
        {
                temp_val+=Get_Adc(ch);
                delay_ms(5);
        }
        return temp_val/times;
}
         









/***********************adc.h文件**********************************/
#ifndef __ADC_H
#define __ADC_H       
#include "sys.h"
//////////          
                                                          
void Adc_Init(void);                                 //ADC通道初始化
u16  Get_Adc(u8 ch);                                 //获得某个通道值
u16 Get_Adc_Average(u8 ch,u8 times);//得到某个通道给定次数采样的平均值  
#endif



/*************************main.c文件**************************/
#include "sys.h"
#include "delay.h"
#include "usart.h"
#include "led.h"
#include "lcd.h"
#include "adc.h"
#include "timer.h"
//ADC转换实验

//

#define true 1
#define false 0
int BPM;            //心率值 每分钟跳动多少次       // used to hold the pulse rate
int Signal;         //采样的值,即adc值       // holds the incoming raw data
int IBI = 600;      //两次心跳间隔时间 单位 毫秒       // holds the time between beats, must be seeded!
unsigned char Pulse = false; //脉冲     // true when pulse wave is high, false when it's low
unsigned char QS = false;   //QS为真时候表示一次真正的心跳     // becomes true when Arduoino finds a beat.
int rate[10];       //该数组用于保存最后10次IBI的值             // array to hold last ten IBI values
unsigned long sampleCounter = 0; //脉搏跳动启动时间         // used to determine pulse timing
unsigned long lastBeatTime = 0;  //结束时间,即IBI的时间         // used to find IBI
int P =512;        //用于统计峰值              // used to find peak in pulse wave, seeded
int T = 512;       //用于统计低谷值              // used to find trough in pulse wave, seeded
int thresh = 512;  //峰值和低谷分界时间              // used to find instant moment of heart beat, seeded
int amp = 100;     //震幅长度              // used to hold amplitude of pulse waveform, seeded
int Num;             //时间
unsigned char firstBeat = true;        // used to seed rate array so we startup with reasonable BPM
unsigned char secondBeat = false;      // used to seed rate array so we startup with reasonable BPM
//用于确定心跳时间  IBI




int main(void)
{
        u16 adcx;
//        float temp;
        NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);//设置系统中断优先级分组2
        delay_init(168);    //初始化延时函数
        uart_init(115200);        //初始化串口波特率为115200
        LED_Init();                                        //初始化LED
        LCD_Init();         //初始化LCD接口
        Adc_Init();         //初始化ADC
        POINT_COLOR=RED;
        TIM3_Int_Init(2000-1,84-1);  //2ms
        LCD_ShowString(30,50,200,16,16,"Explorer STM32F4");       
        LCD_ShowString(30,70,200,16,16,"ADC TEST");       
        LCD_ShowString(30,90,200,16,16,"UPLOOKING");
        LCD_ShowString(30,110,200,16,16,"2015/5/6");          
        POINT_COLOR=BLUE;//设置字体为蓝色
        LCD_ShowString(30,130,200,16,16,"ADC1_CH5_VAL:");             
        LCD_ShowString(30,150,200,16,16,"ADC1_CH5_VOL:0.000V");        //先在固定位置显示小数点      
        while(1)
        {
                //adcx=Get_Adc_Average(ADC_Channel_5,20);//获取通道5的转换值,20次取平均
                //adcx = Get_Adc(ADC_Channel_5);
                //LCD_ShowxNum(134,130,adcx,4,16,0);    //显示ADCC采样后的原始值
                //temp=(float)adcx*(3.3/4096);          //获取计算后的带小数的实际电压值,比如3.1111
                //adcx=temp;                            //赋值整数部分给adcx变量,因为adcx为u16整形
                //LCD_ShowxNum(134,150,adcx,1,16,0);    //显示电压值的整数部分,3.1111的话,这里就是显示3
                //temp-=adcx;                           //把已经显示的整数部分去掉,留下小数部分,比如3.1111-3=0.1111
                //temp*=1000;                           //小数部分乘以1000,例如:0.1111就转换为111.1,相当于保留三位小数。
                //LCD_ShowxNum(150,150,temp,3,16,0X80); //显示小数部分(前面转换为了整形显示),这里显示的就是111.
               
               
                //和上位机用串口通信,  
                //S   ADC的值用于绘制心率的图像
                //B  用于计算心率值
                //Q  用于计算IBI的值
                printf("S%d\r\n", Signal);
               
                if (QS == true)
                {
                        printf("B%d\r\n", BPM);
                        printf("Q%d\r\n", IBI);
                        //sendDataToProcessing('B',BPM);   // send heart rate with a 'B' prefix
                        //        sendDataToProcessing('Q',IBI);   // send time between beats with a 'Q' prefix
                       
                        QS = false;                      // reset the Quantified Self flag for next time
                }
               
               
                LED0=!LED0;
                //printf("adcx = %d\r\n", adcx);
                delay_ms(20);       
        }
}


/*我用的是STM32F4的,
希望有所帮助*/
回复 支持 1 反对 0

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165377
金钱
165377
注册时间
2010-12-1
在线时间
2111 小时
发表于 2014-3-23 11:01:08 | 显示全部楼层
帮顶。
回复 支持 反对

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165377
金钱
165377
注册时间
2010-12-1
在线时间
2111 小时
发表于 2014-3-23 11:01:25 | 显示全部楼层
这个貌似是国产的。。。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复 支持 反对

使用道具 举报

39

主题

2026

帖子

1

精华

论坛大神

Rank: 7Rank: 7Rank: 7

积分
2020
金钱
2020
注册时间
2013-5-1
在线时间
87 小时
发表于 2014-3-23 11:14:43 | 显示全部楼层
我们这边有人在做这个,貌似那个小信号挺难搞定的,不稳定
博观而约取,厚积而薄发。
回复 支持 反对

使用道具 举报

9

主题

25

帖子

0

精华

初级会员

Rank: 2

积分
81
金钱
81
注册时间
2014-3-4
在线时间
0 小时
 楼主| 发表于 2014-3-23 11:33:06 | 显示全部楼层
回复【4楼】745021926:
---------------------------------
好吧。。我先看看资料吧 就坐等大神指导了 哈哈~
回复 支持 反对

使用道具 举报

9

主题

25

帖子

0

精华

初级会员

Rank: 2

积分
81
金钱
81
注册时间
2014-3-4
在线时间
0 小时
 楼主| 发表于 2014-3-23 12:19:21 | 显示全部楼层
回复【3楼】正点原子:
---------------------------------
这个传感器说是design for Arduino的 能在STM32上用吗。。
回复 支持 反对

使用道具 举报

233

主题

958

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1796
金钱
1796
注册时间
2011-10-9
在线时间
223 小时
发表于 2014-3-23 13:11:45 | 显示全部楼层
初略看了下pdf 貌似这个东西  直接  ttl   232输出的啊    
回复 支持 反对

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165377
金钱
165377
注册时间
2010-12-1
在线时间
2111 小时
发表于 2014-3-23 13:39:56 | 显示全部楼层
回复【6楼】ahszss0511:
---------------------------------
当然可以。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复 支持 反对

使用道具 举报

9

主题

25

帖子

0

精华

初级会员

Rank: 2

积分
81
金钱
81
注册时间
2014-3-4
在线时间
0 小时
 楼主| 发表于 2014-3-23 16:48:51 | 显示全部楼层
回复【7楼】simms01:
---------------------------------
看了手册,感觉好鸡肋啊。。 没什么帮助的感觉。。
回复 支持 反对

使用道具 举报

9

主题

25

帖子

0

精华

初级会员

Rank: 2

积分
81
金钱
81
注册时间
2014-3-4
在线时间
0 小时
 楼主| 发表于 2014-3-25 10:43:20 | 显示全部楼层
没人了么。。。
回复 支持 反对

使用道具 举报

4

主题

29

帖子

0

精华

初级会员

Rank: 2

积分
66
金钱
66
注册时间
2014-4-24
在线时间
0 小时
发表于 2014-6-5 19:59:32 | 显示全部楼层
在研究    但是没有头绪
回复 支持 反对

使用道具 举报

0

主题

1

帖子

0

精华

新手入门

积分
21
金钱
21
注册时间
2015-6-13
在线时间
0 小时
发表于 2015-6-13 19:35:54 | 显示全部楼层
我移植了Arduino部分源码, 2ms由ADC获取一次数据,发现数据有误,时好时坏,好不稳定,求大神指教
回复 支持 反对

使用道具 举报

1

主题

5

帖子

0

精华

新手上路

积分
20
金钱
20
注册时间
2016-1-25
在线时间
5 小时
发表于 2016-1-27 08:10:11 | 显示全部楼层
帮顶,同问
回复 支持 反对

使用道具 举报

13

主题

276

帖子

0

精华

高级会员

Rank: 4

积分
697
金钱
697
注册时间
2014-6-20
在线时间
146 小时
发表于 2016-1-27 10:01:00 | 显示全部楼层
这个玩意儿好像就是光通量的问题,只看过,没玩过
回复 支持 反对

使用道具 举报

6

主题

279

帖子

0

精华

高级会员

Rank: 4

积分
750
金钱
750
注册时间
2015-3-27
在线时间
98 小时
发表于 2016-11-1 11:50:26 | 显示全部楼层
这个的输出是一个模拟量,所以你只需要使用ADC外设就可以了.你可以通过打印数据,查看获取的心率波形,看看对不对.如果和官方的差不多,就用心率算法算就行了,心率算法官方也有提供,你也可以用自己的想法算.
回复 支持 反对

使用道具 举报

0

主题

4

帖子

0

精华

新手上路

积分
27
金钱
27
注册时间
2018-4-27
在线时间
4 小时
发表于 2018-4-28 11:59:41 | 显示全部楼层
你的现在做出来了吗?能不能分享一下
回复 支持 反对

使用道具 举报

3

主题

27

帖子

0

精华

初级会员

Rank: 2

积分
117
金钱
117
注册时间
2014-5-22
在线时间
19 小时
发表于 2018-4-28 12:14:09 | 显示全部楼层
这个稍微动下就不准了。很不稳定
回复 支持 反对

使用道具 举报

0

主题

1

帖子

0

精华

新手入门

积分
4
金钱
4
注册时间
2018-12-4
在线时间
1 小时
发表于 2018-12-4 00:49:50 来自手机 | 显示全部楼层
老窝老徐 发表于 2016-11-1 11:27
/**************************adc.c文件**********************************/
#include "adc.h"
#include  ...

那STM32F1的可以用吗
回复 支持 反对

使用道具 举报

0

主题

5

帖子

0

精华

新手上路

积分
48
金钱
48
注册时间
2022-1-20
在线时间
15 小时
发表于 2022-1-20 10:55:21 | 显示全部楼层
starlord 发表于 2020-4-19 13:58
老哥 能不能把你的工程文件发一份?有c8t6的就更完美了

我也想看看
回复 支持 反对

使用道具 举报

0

主题

6

帖子

0

精华

新手上路

积分
36
金钱
36
注册时间
2022-3-2
在线时间
8 小时
发表于 2022-3-2 08:34:55 | 显示全部楼层

大佬,我测试很久了也没弄出来,可以让我学习一下您的C8T6的源码吗,万分感激!!!
回复 支持 反对

使用道具 举报

0

主题

3

帖子

0

精华

新手入门

积分
12
金钱
12
注册时间
2022-2-27
在线时间
3 小时
发表于 2022-3-25 15:53:53 | 显示全部楼层
starlord 发表于 2020-4-19 13:58
老哥 能不能把你的工程文件发一份?有c8t6的就更完美了

谢谢

回复 支持 反对

使用道具 举报

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

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-2-27 21:00

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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