找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 6313|回復(fù): 18
打印 上一主題 下一主題
收起左側(cè)

用89c51和max30100模塊測量心率

  [復(fù)制鏈接]
回帖獎勵 100 黑幣 回復(fù)本帖可獲得 10 黑幣獎勵! 每人限 1 次
跳轉(zhuǎn)到指定樓層
樓主
網(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);            // 串口顯示
//點(diǎn)亮芯片LED
wr_max30100_one_data(0xae,0x07,0x43);       // 設(shè)置電流,點(diǎn)亮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ù)部分?jǐn)?shù)據(jù)
printf("temp2=%d\n",rda);                   // 串口顯示
temp2=rda;
temp=temp1+(temp2*0.0625);                  // 計(jì)算溫度,小數(shù)部分最小溫度值0.0625
printf("當(dāng)前溫度=%.4f\n",temp);             // 串口顯示當(dāng)前溫度
delayms(100);  
printf("\n");                               // 串口顯示當(dāng)前溫度
}
}



max30100.pdf

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

分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復(fù)

使用道具 舉報(bào)

沙發(fā)
ID:363209 發(fā)表于 2018-7-5 09:33 | 只看該作者
樓主得到心率代碼了嗎,我也需要一份

評分

參與人數(shù) 1黑幣 +20 收起 理由
admin + 20 回帖助人的獎勵!

查看全部評分

回復(fù)

使用道具 舉報(bào)

板凳
ID:393021 發(fā)表于 2018-9-3 16:46 | 只看該作者
用max30100模塊測量心率 的STM32代碼還在嗎

評分

參與人數(shù) 1黑幣 +20 收起 理由
admin + 20 回帖助人的獎勵!

查看全部評分

回復(fù)

使用道具 舉報(bào)

地板
ID:401559 發(fā)表于 2018-9-23 14:00 | 只看該作者
樓主,請問測心率代碼還在嗎?
回復(fù)

使用道具 舉報(bào)

5#
ID:404915 發(fā)表于 2018-10-2 19:02 | 只看該作者
感謝樓主分享
回復(fù)

使用道具 舉報(bào)

6#
ID:63090 發(fā)表于 2018-10-4 21:56 | 只看該作者
上淘寶,有很多帶51例程的現(xiàn)在
回復(fù)

使用道具 舉報(bào)

7#
ID:405466 發(fā)表于 2018-10-5 07:34 | 只看該作者

感謝樓主分享
回復(fù)

使用道具 舉報(bào)

8#
ID:557637 發(fā)表于 2019-6-8 11:56 | 只看該作者
樓主有測心率代碼嗎?
回復(fù)

使用道具 舉報(bào)

9#
ID:425825 發(fā)表于 2019-6-9 10:12 | 只看該作者

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


回復(fù)

使用道具 舉報(bào)

10#
ID:93224 發(fā)表于 2019-6-9 17:26 | 只看該作者
這個模塊很不好用,就算你出來數(shù)據(jù)了,大部分還是錯誤的
回復(fù)

使用道具 舉報(bào)

11#
ID:545795 發(fā)表于 2019-7-18 09:05 | 只看該作者
溫度測量不準(zhǔn)確
回復(fù)

使用道具 舉報(bào)

12#
ID:420213 發(fā)表于 2019-7-18 09:27 | 只看該作者
謝謝樓主分享的資料
回復(fù)

使用道具 舉報(bào)

13#
ID:501451 發(fā)表于 2019-12-12 15:46 | 只看該作者
感謝樓主分享
回復(fù)

使用道具 舉報(bào)

14#
ID:627214 發(fā)表于 2019-12-14 20:07 | 只看該作者
基于51單片機(jī)心率測量電路設(shè)計(jì) - 百度文庫 https://wenku.baidu.com/view/0ca ... 86bceb19e8ed42.html
網(wǎng)上找的,希望對你有幫助
回復(fù)

使用道具 舉報(bào)

15#
ID:507688 發(fā)表于 2020-2-19 19:26 | 只看該作者
求51單片機(jī)測心率的代碼
回復(fù)

使用道具 舉報(bào)

16#
ID:589541 發(fā)表于 2020-3-19 17:59 | 只看該作者
學(xué)習(xí)了,感謝樓主
回復(fù)

使用道具 舉報(bào)

17#
ID:541522 發(fā)表于 2020-5-1 15:54 | 只看該作者
求51單片機(jī)測心率的代碼,哪位大神搞出來了,幫忙發(fā)一下啊
回復(fù)

使用道具 舉報(bào)

18#
ID:896118 發(fā)表于 2021-3-24 17:43 | 只看該作者
樓主樓主,可以分享一下代碼嗎?
回復(fù)

使用道具 舉報(bào)

19#
ID:139866 發(fā)表于 2021-3-26 10:58 | 只看該作者
你用示波器看一下SDA和SCL的波形是不是符合Max30100的要求,一般都是SCL的延時出問題,主要是因?yàn)椴煌膯纹瑱C(jī)頻率基本不一樣,你需要看波形起伏的時間,過長過短都不行
回復(fù)

使用道具 舉報(bào)

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規(guī)則

手機(jī)版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表