找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 1688|回复: 0
收起左侧

ESK32-360开发板的BMP085气温气压检测

[复制链接]
ID:776997 发表于 2020-8-23 08:46 | 显示全部楼层 |阅读模式
本帖最后由 jinglixixi 于 2020-8-23 08:48 编辑

BMP085是一款基于I2C接口的数字式传感器,主要用于测量气温、气压及海拔高度等,我们可以通过模拟I2C接口的方式来驱动该传感器,以进行测量。
1.jpg
整体构成

BMP085与MCU的连接关系如下:
SDA --- PC12
SCL   --- PC11

定义引脚输出高低电平的语句为:
#define SCL_Set()        HT_GPIOC->SRR = GPIO_PIN_11
#define SCL_Clr()        HT_GPIOC->RR = GPIO_PIN_11

#define SDA_Set()        HT_GPIOC->SRR = GPIO_PIN_12
#define SDA_Clr()        HT_GPIOC->RR = GPIO_PIN_12


BMP085的初始化函数为:
  1. void Init_BMP085()
  2. {
  3.          ac1 = Multiple_read(0xAA);
  4.          ac2 = Multiple_read(0xAC);
  5.          ac3 = Multiple_read(0xAE);
  6.          ac4 = Multiple_read(0xB0);
  7.          ac5 = Multiple_read(0xB2);
  8.          ac6 = Multiple_read(0xB4);
  9.          b1 = Multiple_read(0xB6);
  10.          b2 = Multiple_read(0xB8);
  11.          mb = Multiple_read(0xBA);
  12.          mc = Multiple_read(0xBC);
  13.          md = Multiple_read(0xBE);
  14. }
复制代码

读取气温与气压的函数为:
  1. void bmp085Convert()
  2. {
  3.          unsigned int ut;
  4.          unsigned long up;
  5.          long x1, x2, b5, b6, x3, b3, p;
  6.          unsigned long b4, b7;
  7.    
  8.          ut = bmp085ReadTemp();
  9.          up = bmp085ReadPressure();
  10.          x1 = (((long)ut - (long)ac6)*(long)ac5) >> 15;
  11.          x2 = ((long) mc << 11) / (x1 + md);
  12.          b5 = x1 + x2;
  13.          temperature = ((b5 + 8) >> 4);
  14.        b6 = b5 - 4000;
  15.        x1 = (b2 * (b6 * b6)>>12)>>11;
  16.        x2 = (ac2 * b6)>>11;
  17.        x3 = x1 + x2;
  18.        b3 = (((((long)ac1)*4 + x3)<<OSS) + 2)>>2;
  19.         x1 = (ac3 * b6)>>13;
  20.        x2 = (b1 * ((b6 * b6)>>12))>>16;
  21.        x3 = ((x1 + x2) + 2)>>2;
  22.        b4 = (ac4 * (unsigned long)(x3 + 32768))>>15;
  23.        b7 = ((unsigned long)(up - b3) * (50000>>OSS));
  24.        if (b7 < 0x80000000)
  25.              p = (b7<<1)/b4;
  26.        else
  27.              p = (b7/b4)<<1;   
  28.          x1 = (p>>8) * (p>>8);
  29.          x1 = (x1 * 3038)>>16;
  30.          x2 = (-7357 * p)>>16;
  31.          pressure = p+((x1 + x2 + 3791)>>4);
  32. }
复制代码

获取海拔高度的函数为:
  1. long BMP085_Get_Altitude(long Pressure)
  2. {
  3.          long altitude;
  4.          altitude=44330.0*(1-pow((double)Pressure/101325,1/5.255));
  5.          altitude*=100;
  6.          return altitude;
  7. }
复制代码

检测的主程序为:
  1. int main(void)
  2. {
  3.          SYSTICK_ClockSourceConfig(SYSTICK_SRC_STCLK);
  4.          SYSTICK_SetReloadValue(SystemCoreClock / 8 / 1000);
  5.          SYSTICK_IntConfig(ENABLE);
  6.          UxART_Configuration();
  7.          IIC_Init();
  8.          Init_BMP085();
  9.          while(1)
  10.          {
  11.                    bmp085Convert();
  12.                    ConvTemperature();
  13.                    ConvPressure();
  14.                    ConvAltitude();
  15.                    Delayms(1000);
  16.          }
  17. }
复制代码

2.jpg
检测值输出显示

评分

参与人数 1黑币 +50 收起 理由
admin + 50 共享资料的黑币奖励!

查看全部评分

回复

使用道具 举报

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

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

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