標題: 用89c51和max30100模塊測量心率 [打印本頁]

作者: 1245463159    時間: 2018-7-1 22:07
標題: 用89c51和max30100模塊測量心率
網(wǎng)絡(luò)上只有stm32的代碼,自己改編失敗了,求溫度代碼改編為心率測試的代碼
//RCWL-0530模塊與51接口連接:
// 1:VCC   --〉   1.8V-5.5V電源
// 2:SCL   --〉   P3.5
// 3:SDA   --〉   P3.7
// 4:INT   --〉   NC
// 5:IRD   --〉   NC
// 6:RD    --〉   NC
// 7:GND   --〉   地
//-------------------------------------------------------------------------------------//
# include <reg52.h>
# include <stdio.h>
# include <intrins.h>
//定義IIC接口
sbit IIC_SCL    =P3^5;     //IIC的SCL
sbit IIC_SDA    =P3^7;     //IIC的SDA
bit  IIC_ACK;              //IIC的ACK
int  rda;                  //IIC讀出
//-------------------------------------------------------------------------------------//
//函數(shù):    delayms()
//功能:    延時程序
//-------------------------------------------------------------------------------------//
void delayms(unsigned int ms)
{
        unsigned char i=100,j;
        for(;ms;ms--)
        {
                while(--i)
                {
                        j=10;
                        while(--j);
                }
        }
}
//-------------------------------------------------------------------------------------//
//函數(shù):    void iic_start();
//功能:    I2C總線開始
//-------------------------------------------------------------------------------------//
//   SCL   --- --- ___
//   SDA   --- ___ ___
void iic_start()
{  
IIC_SDA=1;
_nop_();
_nop_();
IIC_SCL=1;         
_nop_();
_nop_();
IIC_SDA=0;
_nop_();
_nop_();
IIC_SCL=0;
_nop_();
_nop_();
}
//-------------------------------------------------------------------------------------//
//函數(shù):    void iic_stop();
//功能:    I2C總線結(jié)束
//需定義:
//-------------------------------------------------------------------------------------//
//   SCL   ___ --- ---
//   SDA   ___ ___ ---
void iic_stop()
{  
IIC_SCL=0;
_nop_();
_nop_();
IIC_SDA=0;
_nop_();
_nop_();
IIC_SCL=1;
_nop_();
_nop_();
IIC_SDA=1;
_nop_();
_nop_();
}
//-------------------------------------------------------------------------------------//
//函數(shù):    void iic_sendbyte(unsigned char c);
//功能:    發(fā)送 8_BIT 數(shù)據(jù)
//-------------------------------------------------------------------------------------//
void iic_sendbyte(unsigned char c)
{
unsigned char bitcnt;
for(bitcnt=0;bitcnt<8;bitcnt++)
{
if((c<<bitcnt)&0x80)
IIC_SDA=1;
else
IIC_SDA=0;
_nop_();
_nop_();
IIC_SCL=1;
_nop_();
_nop_();
IIC_SCL=0;
}
_nop_();
_nop_();
IIC_SDA=1;
_nop_();
_nop_();
IIC_SCL=1;
_nop_();
_nop_();
if(IIC_SDA==0)
IIC_ACK=0;
else
IIC_ACK=1;
IIC_SCL=0;
_nop_();
_nop_();
}
//-------------------------------------------------------------------------------------//
//函數(shù):    int iic_rcvbyte_nack();
//功能:    接收 8_BIT 數(shù)據(jù)  最后ack信號
//-------------------------------------------------------------------------------------//
int iic_rcvbyte_nack()
{
unsigned char retc;
unsigned char bitcnt;
retc=0;
IIC_SDA=1;
for(bitcnt=0;bitcnt<8;bitcnt++)
{
_nop_();
_nop_();
IIC_SCL=0;
_nop_();
_nop_();
IIC_SCL=1;
_nop_();
_nop_();
retc=retc<<1;
if(IIC_SDA==1)
retc=retc+1;
_nop_();
_nop_();
}
//給出NACK信號
_nop_();
_nop_();
IIC_SCL=0;
_nop_();
_nop_();
IIC_SDA=1;
_nop_();
_nop_();
IIC_SCL=1;
_nop_();
_nop_();
IIC_SCL=0;
_nop_();
_nop_();
return(retc);
}
//-------------------------------------------------------------------------------------//
//函數(shù):    int iic_rcvbyte_ack();
//功能:    接收 8_BIT 數(shù)據(jù) 最后ack信號
//-------------------------------------------------------------------------------------//
int iic_rcvbyte_ack()
{
unsigned char retc;
unsigned char bitcnt;
retc=0;
IIC_SDA=1;
for(bitcnt=0;bitcnt<8;bitcnt++)
{
_nop_();
_nop_();
IIC_SCL=0;
_nop_();
_nop_();
IIC_SCL=1;
_nop_();
_nop_();
retc=retc<<1;
if(IIC_SDA==1)
retc=retc+1;
_nop_();
_nop_();
}
//給出ACK信號
_nop_();
_nop_();
IIC_SCL=0;
_nop_();
_nop_();
IIC_SDA=0;
_nop_();
_nop_();
IIC_SCL=1;
_nop_();
_nop_();
IIC_SCL=0;
_nop_();
_nop_();
return(retc);
}
//-------------------------------------------------------------------------------------//
//函數(shù):      wr_max30100_one_data()
//功能:      寫一位max30100數(shù)據(jù)
//address:   芯片從地址
//saddress:  寫寄存器地址
//w_data:    待寫數(shù)據(jù)
//-------------------------------------------------------------------------------------//
void wr_max30100_one_data(int address,int saddress,int w_data )
{
_nop_();
iic_start();
_nop_();
iic_sendbyte(address);
_nop_();
iic_sendbyte(saddress);
_nop_();
iic_sendbyte(w_data);
_nop_();
iic_stop();
_nop_();
}
//-------------------------------------------------------------------------------------//
//函數(shù):      rd_max30100_one_data()
//功能:      讀一位max30100數(shù)據(jù)
//address:   芯片從地址
//saddress:  讀寄存器地址
//rda:       讀出的數(shù)據(jù)
//-------------------------------------------------------------------------------------//
void rd_max30100_one_data(int address,int saddress)
{
iic_start();
_nop_();
iic_sendbyte(address);
_nop_();
iic_sendbyte(saddress);
_nop_();
address=address+1;
_nop_();
iic_start();
_nop_();
iic_sendbyte(address);
_nop_();
rda=iic_rcvbyte_nack();
_nop_();
iic_stop();
}
//-------------------------------------------------------------------------------------//
//函數(shù):      主程序
//功能:      讀max30100內(nèi)部溫度
//-------------------------------------------------------------------------------------//
main()
{
double temp,temp1,temp2;
//temp       測量溫度
//temp1      30100整數(shù)部分溫度
//temp2      30100小數(shù)部分溫度
TMOD=0x21;                  
SCON=0x50;
TH1=0xE6;
TL1=0xE6;
TR1=1;                          
TI=1;   
//設(shè)置51的波特率為 1200 N 8 1
//51主頻為12MHz STC的MCU注意要選擇外部晶體振蕩
while(1)
{
//復(fù)位芯片,設(shè)置模式
wr_max30100_one_data(0xae,0x06,0x0b);  
//讀芯片ID
rd_max30100_one_data(0xae,0xff);            // 讀出芯片ID
printf("MAX30100 ID =%d\n",rda);            // 串口顯示
//點亮芯片LED
wr_max30100_one_data(0xae,0x07,0x43);       // 設(shè)置電流,點亮LED
delayms(10);   
//溫度功能測試
wr_max30100_one_data(0xae,0x09,0x66);       // 0X06地址B3位TEMP_EN置1
delayms(50);                                // 等待溫度轉(zhuǎn)換完成,不等待,讀出數(shù)據(jù)有誤
rd_max30100_one_data(0xae,0x16);            // 讀出溫度信號
printf("temp1=%d\n",rda);                   // 串口顯示
temp1=rda;
rd_max30100_one_data(0xae,0x17);            // 讀出溫度小數(shù)部分數(shù)據(jù)
printf("temp2=%d\n",rda);                   // 串口顯示
temp2=rda;
temp=temp1+(temp2*0.0625);                  // 計算溫度,小數(shù)部分最小溫度值0.0625
printf("當前溫度=%.4f\n",temp);             // 串口顯示當前溫度
delayms(100);  
printf("\n");                               // 串口顯示當前溫度
}
}



max30100.pdf

881.84 KB, 下載次數(shù): 51


作者: yueliang359    時間: 2018-7-5 09:33
樓主得到心率代碼了嗎,我也需要一份

作者: 下一個原點    時間: 2018-9-3 16:46
用max30100模塊測量心率 的STM32代碼還在嗎
作者: 小阿LO    時間: 2018-9-23 14:00
樓主,請問測心率代碼還在嗎?
作者: qmby919    時間: 2018-10-2 19:02
感謝樓主分享
作者: lzb1989666    時間: 2018-10-4 21:56
上淘寶,有很多帶51例程的現(xiàn)在
作者: fhj228    時間: 2018-10-5 07:34

感謝樓主分享
作者: GEXPEC    時間: 2019-6-8 11:56
樓主有測心率代碼嗎?
作者: 來51學(xué)習(xí)    時間: 2019-6-9 10:12

你好!可以采用心電芯片,實現(xiàn)心電圖檢測和心率顯示;
測量精度滿足實驗要求,有 PCB板 和 萬用板兩種版本;
也可以按照不同需求完成定制修改,請注明:來自51黑



作者: lele5211314    時間: 2019-6-9 17:26
這個模塊很不好用,就算你出來數(shù)據(jù)了,大部分還是錯誤的
作者: 1715092042    時間: 2019-7-18 09:05
溫度測量不準確
作者: DddAa    時間: 2019-7-18 09:27
謝謝樓主分享的資料
作者: 萌新求罩    時間: 2019-12-12 15:46
感謝樓主分享
作者: 無敵小杰杰    時間: 2019-12-14 20:07
基于51單片機心率測量電路設(shè)計 - 百度文庫 https://wenku.baidu.com/view/0ca ... 86bceb19e8ed42.html
網(wǎng)上找的,希望對你有幫助
作者: Clancy123    時間: 2020-2-19 19:26
求51單片機測心率的代碼
作者: user2402163    時間: 2020-3-19 17:59
學(xué)習(xí)了,感謝樓主
作者: 1135009346    時間: 2020-5-1 15:54
求51單片機測心率的代碼,哪位大神搞出來了,幫忙發(fā)一下啊
作者: jsjdjdjdj    時間: 2021-3-24 17:43
樓主樓主,可以分享一下代碼嗎?
作者: 天ノ憶    時間: 2021-3-26 10:58
你用示波器看一下SDA和SCL的波形是不是符合Max30100的要求,一般都是SCL的延時出問題,主要是因為不同的單片機頻率基本不一樣,你需要看波形起伏的時間,過長過短都不行




歡迎光臨 (http://www.torrancerestoration.com/bbs/) Powered by Discuz! X3.1