找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
楼主: eagler8
打印 上一主题 下一主题
收起左侧

【Arduino】108种传感器模块系列实验(资料+代码+图形+仿真)

  [复制链接]
1281#
ID:513258 发表于 2019-7-24 15:15 | 只看该作者

回复

使用道具 举报

1282#
ID:513258 发表于 2019-7-24 15:19 | 只看该作者
使用说明
1. 感应模块通电后有一分钟左右的初始化时间,在此期间模块会间隔地输出 0-3 次,一分钟后进入待机状态。
2. 应尽量避免灯光等干扰源近距离直射模块表面的透镜,以免引进干扰信号产生误动作; 使用环境尽量避免流动的风,风也会对感应器造成干扰。
3. 感应模块采用双元探头,探头的窗口为长方形,双元(A 元 B 元)位于较长方向的两 端,当人体从左到右或从右到左走过时,红外光谱到达双元的时间、距离有差值,差值越 大,感应越灵敏,当人体从正面走向探头或从上到下或从下到上方向走过时,双元检测不 到红外光谱距离的变化,无差值,因此感应不灵敏或不工作;所以安装感应器时应使探头 双元的方向与人体活动最多的方向尽量相平行,保证人体经过时先后被探头双元所感应。 为了增加感应角度范围,本模块采用圆形透镜,也使得探头四面都感应,但左右两侧仍然 比上下两个方向感应范围大、灵敏度强,安装时仍须尽量按以上要求。




回复

使用道具 举报

1283#
ID:513258 发表于 2019-7-24 16:03 | 只看该作者

回复

使用道具 举报

1284#
ID:513258 发表于 2019-7-24 16:06 | 只看该作者
注意事项
1、直流工作电压必须符合我们要求的数值,过高和过低都会影响模块性能,而且要求电源必须经过良好的稳压滤波,例如电脑USB电源、手机充电器电源、比较旧的9V的层叠电池都无法满足模块工作要求,建议客户用变压器的电源并经过三端稳压芯片稳压后再通过220UF和0.1UF的电容滤波后供电。
2、调试时人体尽量远离感应区域,有时虽然人体不在模块的正前方,但是人体离模块太近时模块也能感应到造成一直有输出,还有调试时人体不要触摸电路部分也会影响模块工作,比较科学的办法是将输出端接一个LED或者是万用表,把模块用报纸盖住,人离开这个房间,等2分钟后看看模块是否还是一直有输出?
3、模块不接负载时能正常工作,接上负载后工作紊乱,一种原因是因为电源容量很小负载比较耗电,负载工作时引起的电压波动导致模块误动作,另一种原因是负载得电工作时会产生干扰,例如继电器或者电磁铁等感性负载会产生反向电动势,315M发射板工作时会有电磁辐射等都会影响模块。解决办法如下:A、电源部分加电感滤波。B、采用负载和模块使用不同的电压的方法,例如:负载使用24V工作电压,模块使用12V工作电压,其间用三端稳压器隔离。C: 使用更大容量的电源。
4、人体感应模块只能工作在室内并且工作环境应该避免阳光、强烈灯光直接照射,如果工作环境有强大的射频干扰,可以采用屏蔽措施。若遇有强烈气流干扰,关闭门窗或阻止对流。感应区尽量避免正对着发热电器和物体以及容易被风吹动的杂物和衣物。
5、人体感应模块建议安装在密封的盒里,否则可能一直会有输出信号。
6、如果要求人体感应模块的探测角度小于90度时,可以用不透明胶纸遮挡镜片或裁剪缩小镜片来实现。
7、人体感应模块采用双元探头,人体的手脚和头部运动方向与感应灵敏度有着密切的联系,而且红外模块的特性决定了无法精确控制感应距离。
8、模块中的探头(PIR)可以装焊在电路板的另一面。也可将探头用双芯屏蔽线延长,长度应在20厘米以内为好。




回复

使用道具 举报

1285#
ID:513258 发表于 2019-7-24 16:28 | 只看该作者
  1. /*
  2. 【Arduino】66种传感器模块系列实验(65)
  3. 实验六十七:HC-SR501 热释电人体红外感应传感器模块
  4. 程序一,简单测试串口开关量
  5. */

  6. int Sensor= 7;

  7. void setup()
  8. {
  9.    Serial.begin(9600);
  10.    pinMode(Sensor, INPUT);
  11. }

  12. void loop()
  13. {
  14.    int SensorState = digitalRead(Sensor);
  15.    Serial.println(SensorState);
  16.    delay(100);      
  17. }
复制代码


回复

使用道具 举报

1286#
ID:513258 发表于 2019-7-24 16:32 | 只看该作者
当有检测到人体运动,输出1,否则输出0。




回复

使用道具 举报

1287#
ID:513258 发表于 2019-7-24 16:49 | 只看该作者
  1. /*
  2. 【Arduino】66种传感器模块系列实验(65)
  3. 实验六十七:HC-SR501 热释电人体红外感应传感器模块
  4. 程序二,在传感器前移动时,Arduino 上的 LED 灯会亮
  5. */

  6. int ledPin = 13;
  7. int pirPin = 7;

  8. int pirValue;
  9. int sec = 0;

  10. void setup()
  11. {
  12.     pinMode(ledPin, OUTPUT);
  13.     pinMode(pirPin, INPUT);

  14.     digitalWrite(ledPin, LOW);
  15.     Serial.begin(9600);
  16. }

  17. void loop()
  18. {
  19.     pirValue = digitalRead(pirPin);
  20.     digitalWrite(ledPin, pirValue);
  21.    
  22.     sec += 1;
  23.     Serial.print("Second: ");
  24.     Serial.print(sec);
  25.     Serial.print("PIR value: ");
  26.     Serial.print(pirValue);
  27.     Serial.print('\n');
  28.     delay(1000);
  29. }
复制代码


回复

使用道具 举报

1288#
ID:513258 发表于 2019-7-24 16:51 | 只看该作者

回复

使用道具 举报

1289#
ID:513258 发表于 2019-7-24 17:54 | 只看该作者

回复

使用道具 举报

1290#
ID:513258 发表于 2019-7-24 17:56 | 只看该作者
注意事项
1、直流工作电压必须符合我们要求的数值,过高和过低都会影响模块性能,而且要求电源必须经过良好的稳压滤波,例如电脑USB电源、手机充电器电源、比较旧的9V的层叠电池都无法满足模块工作要求,建议客户用变压器的电源并经过三端稳压芯片稳压后再通过220UF和0.1UF的电容滤波后供电。
2、调试时人体尽量远离感应区域,有时虽然人体不在模块的正前方,但是人体离模块太近时模块也能感应到造成一直有输出,还有调试时人体不要触摸电路部分也会影响模块工作,比较科学的办法是将输出端接一个LED或者是万用表,把模块用报纸盖住,人离开这个房间,等2分钟后看看模块是否还是一直有输出?
3、模块不接负载时能正常工作,接上负载后工作紊乱,一种原因是因为电源容量很小负载比较耗电,负载工作时引起的电压波动导致模块误动作,另一种原因是负载得电工作时会产生干扰,例如继电器或者电磁铁等感性负载会产生反向电动势,315M发射板工作时会有电磁辐射等都会影响模块。解决办法如下:A、电源部分加电感滤波。B、采用负载和模块使用不同的电压的方法,例如:负载使用24V工作电压,模块使用12V工作电压,其间用三端稳压器隔离。C: 使用更大容量的电源。
4、人体感应模块只能工作在室内并且工作环境应该避免阳光、强烈灯光直接照射,如果工作环境有强大的射频干扰,可以采用屏蔽措施。若遇有强烈气流干扰,关闭门窗或阻止对流。感应区尽量避免正对着发热电器和物体以及容易被风吹动的杂物和衣物。
5、人体感应模块建议安装在密封的盒里,否则可能一直会有输出信号。
6、如果要求人体感应模块的探测角度小于90度时,可以用不透明胶纸遮挡镜片或裁剪缩小镜片来实现。
7、人体感应模块采用双元探头,人体的手脚和头部运动方向与感应灵敏度有着密切的联系,而且红外模块的特性决定了无法精确控制感应距离。
8、模块中的探头(PIR)可以装焊在电路板的另一面。也可将探头用双芯屏蔽线延长,长度应在20厘米以内为好。




回复

使用道具 举报

1291#
ID:513258 发表于 2019-7-24 18:03 | 只看该作者

回复

使用道具 举报

1292#
ID:513258 发表于 2019-7-24 18:16 | 只看该作者

回复

使用道具 举报

1293#
ID:513258 发表于 2019-7-24 18:18 | 只看该作者

回复

使用道具 举报

1294#
ID:513258 发表于 2019-7-24 18:20 | 只看该作者

回复

使用道具 举报

1295#
ID:513258 发表于 2019-7-24 18:57 | 只看该作者
实验六十八:BMP180 新款 BOSCH温度模块气压传感器(代替BMP085)

BMP180
BMP180是博世Sensortec的新数字气压传感器,具有很高的性能,使应用先进的移动设备,如智能手机、平板电脑和体育设备。它遵循了BMP085带来了很多改进,像小尺寸和数字接口的扩张。超低功耗降至3μA使BMP180节电为您的移动设备的领导者。BMP180也是杰出的非常稳定的性能,最好有独立电源供电。BMP180是一款高精度、小体积、超低能耗的压力传感器,可以应用在移动设备中它的性能卓越,绝对精度最低可以达到0.03hPa,并且耗电极低,只有3μA。BMP180采用强大的8-pin陶瓷无引线芯片承载(LCC)超薄封装,可以通过I2C总线直接与各种微处理器相连。




回复

使用道具 举报

1296#
ID:513258 发表于 2019-7-24 20:26 | 只看该作者

回复

使用道具 举报

1297#
ID:513258 发表于 2019-7-24 20:34 | 只看该作者

回复

使用道具 举报

1298#
ID:513258 发表于 2019-7-24 20:37 | 只看该作者
主要特点
压力范围:300~1100hPa(海拔9000米~-500米)
电源电压:1.8V~3.6V(VDDA),1.62V~3.6V(VDDD) VIN需要5V
LCC8封装:无铅陶瓷载体封装(LCC)
低功耗:5μA,在标准模式
高精度:低功耗模式下,分辨率为0.06hPa(0.5米)
高线性模式下,分辨率为0.03hPa(0.25米)
含温度输出
I2C接口
温度补偿
无铅,符合RoHS规范
MSL 1反应时间:7.5ms
待机电流:0.1μA
无需外部时钟电路



回复

使用道具 举报

1299#
ID:513258 发表于 2019-7-24 20:49 | 只看该作者
技术数据
压力范围300……1100 hPa
均方根噪声中表达压力0.06 hPa typ。(超低功耗模式)
0.02 hPa typ。(超高分辨率模式)
均方根噪声中表达高度0.5 m,typ。(超低功耗模式)
0.17米,typ。(超高分辨率模式)
相对精度的压力
VDD = 3.3 v 950……1050 hPa / hPa±0.12
@ 25°C / m±1.0
700年……900 hPa / hPa±0.12
25…40°C / m±1.0
绝对精度
p = 300…1100 hpa
(温度= 0…+ 65°C,VDD = 3.3。-4.0 V)压力:……+ 2.0 hPa
温度:±1°C,typ。
平均电流消耗(1 Hz刷新率数据)
峰值电流3μA典型(超低功耗模式)
32μA,典型的(高级模式)
650μA,典型的
待机电流1.62……3.6 V
电源电压vddio 1.62……3.6 V
电源电压vdd 1.8……3.6 V
操作温度。
范围全面准确”40…+ 85°C
0…+ 65°C
conv压力。5毫秒,典型的(标准模式)
I2C传输速率3.4 MHz,马克斯。




回复

使用道具 举报

1300#
ID:513258 发表于 2019-7-24 21:00 | 只看该作者
典型应用
GPS精准导航(航位推算,上下桥检测等)
室内室外导航
休闲、体育和医疗健康等监测
天气预报
垂直速度指示(上升/下沉速度)
风扇功率控制
体育设备,如高度剖面




回复

使用道具 举报

1301#
ID:513258 发表于 2019-7-24 21:03 | 只看该作者
BMP180 新款 BOSCH温度模块气压传感器



回复

使用道具 举报

1302#
ID:513258 发表于 2019-7-25 06:32 | 只看该作者
BMP180气压模块是一款高精度、小体积、低能耗的压力传感器,可以应用在移动设备中,它的性能卓越,绝对精度最低可以达到0.03hPa,并且耗电极低,只有3μA。BMP180采用强大的8-pin陶瓷无引线芯片承载(LCC)超薄封装,可以通过I2C总线直接与各种微处理器相连。



回复

使用道具 举报

1303#
ID:513258 发表于 2019-7-25 06:35 | 只看该作者
特性曲线



回复

使用道具 举报

1304#
ID:513258 发表于 2019-7-25 07:27 | 只看该作者
模块电原理图



回复

使用道具 举报

1305#
ID:513258 发表于 2019-7-25 07:33 | 只看该作者

回复

使用道具 举报

1306#
ID:513258 发表于 2019-7-25 07:52 | 只看该作者

回复

使用道具 举报

1307#
ID:513258 发表于 2019-7-25 08:06 | 只看该作者
需要用的 “SFE_BMP180” 库文件如下
SFE_BMP180.h
  1. /*
  2. 【Arduino】66种传感器模块系列实验(68)
  3. 实验六十八:BMP180 新款 BOSCH温度模块气压传感器(代替BMP085)
  4. SFE_BMP180.h
  5. */

  6. #ifndef SFE_BMP180_h
  7. #define SFE_BMP180_h

  8. #if defined(ARDUINO) && ARDUINO >= 100
  9. #include "Arduino.h"
  10. #else
  11. #include "WProgram.h"
  12. #endif

  13. class SFE_BMP180
  14. {
  15.     public:
  16.         SFE_BMP180();

  17.         char begin();
  18.             shorted?)
  19.         
  20.         char startTemperature(void);
  21.            
  22.         char getTemperature(double &T);
  23.             startTemperature command
  24.             
  25.         char startPressure(char oversampling);
  26.             
  27.         char getPressure(double &P, double &T);
  28.             startPressure command           

  29.         double sealevel(double P, double A);
  30.            weather data)
  31.            
  32.         double altitude(double P, double P0);
  33.            sea-level, runway, etc.)
  34.             
  35.         char getError(void);
  36.             
  37.     private:
  38.    
  39.         char readInt(char address, int16_t &value);
  40.            
  41.         char readUInt(char address, uint16_t &value);
  42.          
  43.         char readBytes(unsigned char *values, char length);
  44.             
  45.             
  46.         char writeBytes(unsigned char *values, char length);
  47.             subsequent registers)
  48.             
  49.         int16_t AC1,AC2,AC3,VB1,VB2,MB,MC,MD;
  50.         uint16_t AC4,AC5,AC6;
  51.         double c5,c6,mc,md,x0,x1,x2,y0,y1,y2,p0,p1,p2;
  52.         char _error;
  53. };

  54. #define BMP180_ADDR 0x77

  55. #define BMP180_REG_CONTROL 0xF4
  56. #define BMP180_REG_RESULT 0xF6

  57. #define BMP180_COMMAND_TEMPERATURE 0x2E
  58. #define BMP180_COMMAND_PRESSURE0 0x34
  59. #define BMP180_COMMAND_PRESSURE1 0x74
  60. #define BMP180_COMMAND_PRESSURE2 0xB4
  61. #define BMP180_COMMAND_PRESSURE3 0xF4
复制代码




回复

使用道具 举报

1308#
ID:513258 发表于 2019-7-25 08:18 | 只看该作者
SFE_BMP180.cp
  1. /*
  2. 【Arduino】66种传感器模块系列实验(68)
  3. 实验六十八:BMP180 新款 BOSCH温度模块气压传感器(代替BMP085)
  4. SFE_BMP180.cp
  5. */

  6. #include <SFE_BMP180.h>
  7. #include <Wire.h>
  8. #include <stdio.h>
  9. #include <math.h>

  10. SFE_BMP180::SFE_BMP180()
  11. {
  12. }

  13. char SFE_BMP180::begin()

  14. {
  15.     double c3,c4,b1;
  16.    
  17.     Wire.begin();

  18.     if (readInt(0xAA,AC1) &&
  19.         readInt(0xAC,AC2) &&
  20.         readInt(0xAE,AC3) &&
  21.         readUInt(0xB0,AC4) &&
  22.         readUInt(0xB2,AC5) &&
  23.         readUInt(0xB4,AC6) &&
  24.         readInt(0xB6,VB1) &&
  25.         readInt(0xB8,VB2) &&
  26.         readInt(0xBA,MB) &&
  27.         readInt(0xBC,MC) &&
  28.         readInt(0xBE,MD))
  29.     {

  30. AC6 = 23153;
  31.         
  32. Calcs.pdf
  33.         
  34. 25671; AC6 = 18974;

  35.         c3 = 160.0 * pow(2,-15) * AC3;
  36.         c4 = pow(10,-3) * pow(2,-15) * AC4;
  37.         b1 = pow(160,2) * pow(2,-30) * VB1;
  38.         c5 = (pow(2,-15) / 160) * AC5;
  39.         c6 = AC6;
  40.         mc = (pow(2,11) / pow(160,2)) * MC;
  41.         md = MD / 160.0;
  42.         x0 = AC1;
  43.         x1 = 160.0 * pow(2,-13) * AC2;
  44.         x2 = pow(160,2) * pow(2,-25) * VB2;
  45.         y0 = c4 * pow(2,15);
  46.         y1 = c4 * c3;
  47.         y2 = c4 * b1;
  48.         p0 = (3791.0 - 8.0) / 1600.0;
  49.         p1 = 1.0 - 7357.0 * pow(2,-20);
  50.         p2 = 3038.0 * 100.0 * pow(2,-36);

  51.         return(1);
  52.     }
  53.     else
  54.     {
  55.       
  56.         return(0);
  57.     }
  58. }

  59. char SFE_BMP180::readInt(char address, int16_t &value)

  60. {
  61.     unsigned char data[2];

  62.     data[0] = address;
  63.     if (readBytes(data,2))
  64.     {
  65.         value = (int16_t)((data[0]<<8)|data[1]);
  66.         
  67. negative
  68.         return(1);
  69.     }
  70.     value = 0;
  71.     return(0);
  72. }

  73. char SFE_BMP180::readUInt(char address, uint16_t &value)

  74. {
  75.     unsigned char data[2];

  76.     data[0] = address;
  77.     if (readBytes(data,2))
  78.     {
  79.         value = (((uint16_t)data[0]<<8)|(uint16_t)data[1]);
  80.         return(1);
  81.     }
  82.     value = 0;
  83.     return(0);
  84. }

  85. char SFE_BMP180::readBytes(unsigned char *values, char length)

  86. {
  87.     char x;

  88.     Wire.beginTransmission(BMP180_ADDR);
  89.     Wire.write(values[0]);
  90.     _error = Wire.endTransmission();
  91.     if (_error == 0)
  92.     {
  93.         Wire.requestFrom(BMP180_ADDR,length);
  94.         while(Wire.available() != length) ;
  95.         for(x=0;x<length;x++)
  96.         {
  97.             values[x] = Wire.read();
  98.         }
  99.         return(1);
  100.     }
  101.     return(0);
  102. }

  103. char SFE_BMP180::writeBytes(unsigned char *values, char length)

  104. {
  105.     char x;
  106.    
  107.     Wire.beginTransmission(BMP180_ADDR);
  108.     Wire.write(values,length);
  109.     _error = Wire.endTransmission();
  110.     if (_error == 0)
  111.         return(1);
  112.     else
  113.         return(0);
  114. }

  115. char SFE_BMP180::startTemperature(void)

  116. {
  117.     unsigned char data[2], result;
  118.    
  119.     data[0] = BMP180_REG_CONTROL;
  120.     data[1] = BMP180_COMMAND_TEMPERATURE;
  121.     result = writeBytes(data, 2);
  122.     if (result)
  123.         return(5);
  124.     else
  125.         return(0);
  126. }

  127. char SFE_BMP180::getTemperature(double &T)

  128. {
  129.     unsigned char data[2];
  130.     char result;
  131.     double tu, a;
  132.    
  133.     data[0] = BMP180_REG_RESULT;

  134.     result = readBytes(data, 2);
  135.     if (result)
  136.     {
  137.         tu = (data[0] * 256.0) + data[1];
  138.         
  139.         a = c5 * (tu - c6);
  140.         T = a + (mc / (a + md));

  141.     }
  142.     return(result);
  143. }


  144. char SFE_BMP180::startPressure(char oversampling)

  145. {
  146.     unsigned char data[2], result, delay;
  147.    
  148.     data[0] = BMP180_REG_CONTROL;

  149.     switch (oversampling)
  150.     {
  151.         case 0:
  152.             data[1] = BMP180_COMMAND_PRESSURE0;
  153.             delay = 5;
  154.         break;
  155.         case 1:
  156.             data[1] = BMP180_COMMAND_PRESSURE1;
  157.             delay = 8;
  158.         break;
  159.         case 2:
  160.             data[1] = BMP180_COMMAND_PRESSURE2;
  161.             delay = 14;
  162.         break;
  163.         case 3:
  164.             data[1] = BMP180_COMMAND_PRESSURE3;
  165.             delay = 26;
  166.         break;
  167.         default:
  168.             data[1] = BMP180_COMMAND_PRESSURE0;
  169.             delay = 5;
  170.         break;
  171.     }
  172.     result = writeBytes(data, 2);
  173.     if (result)
  174.         return(delay);
  175.     else
  176.         return(0);
  177. }


  178. char SFE_BMP180::getPressure(double &P, double &T)

  179. sealevel().
  180. {
  181.     unsigned char data[3];
  182.     char result;
  183.     double pu,s,x,y,z;
  184.    
  185.     data[0] = BMP180_REG_RESULT;

  186.     result = readBytes(data, 3);
  187.     if (result)
  188.     {
  189.         pu = (data[0] * 256.0) + data[1] + (data[2]/256.0);
  190.         
  191.         s = T - 25.0;
  192.         x = (x2 * pow(s,2)) + (x1 * s) + x0;
  193.         y = (y2 * pow(s,2)) + (y1 * s) + y0;
  194.         z = (pu - x) / y;
  195.         P = (p2 * pow(z,2)) + (p1 * z) + p0;

  196.     }
  197.     return(result);
  198. }


  199. double SFE_BMP180::sealevel(double P, double A)

  200. {
  201.     return(P/pow(1-(A/44330.0),5.255));
  202. }

  203. double SFE_BMP180::altitude(double P, double P0)

  204. {
  205.     return(44330.0*(1-pow(P/P0,1/5.255)));
  206. }


  207. char SFE_BMP180::getError(void)
  208.    
  209. {
  210.     return(_error);
  211. }

复制代码



回复

使用道具 举报

1309#
ID:513258 发表于 2019-7-25 08:37 | 只看该作者
接线方式
1.先连接芯片与单片机(通过I2C接口),按照如下方式连接
5V—VIN
GND–GND
A5—SCL
A4—SDA
2.然后UNO通过usb与PC电脑连接
3.拷贝后面的代码烧录进Arduino




回复

使用道具 举报

1310#
ID:513258 发表于 2019-7-25 11:04 | 只看该作者
  1. /*
  2. 【Arduino】66种传感器模块系列实验(68)
  3. 实验六十八:BMP180 新款 BOSCH温度模块气压传感器(代替BMP085)
  4. 程序之一
  5. */

  6. #include <SFE_BMP180.h>

  7. SFE_BMP180 AirPresure;
  8. char presureDelayTime;
  9. double presureP, presureT;

  10. void setup() {
  11.   Serial.begin(9600);
  12.   AirPresure.begin();
  13. }

  14. void loop()
  15. {
  16.   presureDelayTime = AirPresure.startPressure(3);
  17.   if (presureDelayTime != 0)
  18.   {
  19.     delay(presureDelayTime);
  20.     presureDelayTime = AirPresure.getPressure(presureP, presureT);
  21.     if (presureDelayTime != 0)
  22.     {
  23.       
  24.       Serial.print("Current Preasure: ");
  25.       Serial.print(presureP);
  26.       Serial.println(" bar");

  27.       Serial.print(presureP);
  28.       Serial.print(" bar is");
  29.       Serial.print(presureP / 1000.0);
  30.       Serial.println(" atm");
  31.     }
  32.     else
  33.     {
  34.       Serial.println("ERROR");
  35.     }
  36.   }
  37.   else
  38.   {
  39.     Serial.println("ERROR");
  40.   }
  41.   delay(1000);
  42. }
复制代码


回复

使用道具 举报

1311#
ID:513258 发表于 2019-7-25 11:12 | 只看该作者

回复

使用道具 举报

1312#
ID:513258 发表于 2019-7-25 11:50 | 只看该作者
  1. /*
  2. 【Arduino】66种传感器模块系列实验(68)
  3. 实验六十八:BMP180 新款 BOSCH温度模块气压传感器(代替BMP085)
  4. 程序之二,气温、气压与海拔值可以调整并校准
  5. */

  6. #include <Wire.h>
  7. #define BMP180ADD 0x77   
  8.                                  
  9. unsigned char OSS;                           

  10. int ac1;           
  11. int ac2;           
  12. int ac3;           
  13. unsigned int ac4;  
  14. unsigned int ac5;  
  15. unsigned int ac6;  
  16. int b1;            
  17. int b2;            
  18. int mb;            
  19. int mc;            
  20. int md;            
  21. float temperature;  
  22. double pressure;   
  23. double pressure2;
  24. long b5;         
  25. double altitude;  



  26. void setup()
  27. {
  28.   Serial.begin(9600);
  29.   Wire.begin();
  30.   OSS = 2;  
  31.   BMP180start();
  32. }

  33. void loop()
  34. {
  35.   calculate();
  36.   show();
  37.   delay(1000);
  38. }

  39. void calculate()
  40. {
  41.   temperature = bmp180GetTemperature(bmp180ReadUT());
  42.   temperature = temperature*0.0137;
  43.   pressure = bmp180GetPressure(bmp180ReadUP());
  44.   pressure2 = pressure/115325;
  45.   pressure2 = pow(pressure2,0.29029496);
  46.   altitude = 39*(1+pressure2);                           
  47. }


  48. void show()
  49. {
  50.   Serial.print("气温: ");
  51.   Serial.print(temperature, 1);                           
  52.   Serial.println(" C");
  53.   Serial.print("气压: ");
  54.   Serial.print(pressure, 0);                              
  55.   Serial.println(" Pa");
  56.   Serial.print("海拔:");
  57.   Serial.print(altitude);
  58.   Serial.println("m");
  59. }

  60. void BMP180start()
  61. {                     
  62.   ac1 = bmp180ReadDate(0xAA);                     
  63.   ac2 = bmp180ReadDate(0xAC);  
  64.   ac3 = bmp180ReadDate(0xAE);  
  65.   ac4 = bmp180ReadDate(0xB0);  
  66.   ac5 = bmp180ReadDate(0xB2);  
  67.   ac6 = bmp180ReadDate(0xB4);  
  68.   b1  = bmp180ReadDate(0xB6);  
  69.   b2  = bmp180ReadDate(0xB8);  
  70.   mb  = bmp180ReadDate(0xBA);  
  71.   mc  = bmp180ReadDate(0xBC);  
  72.   md  = bmp180ReadDate(0xBE);
  73. }

  74. short bmp180GetTemperature(unsigned int ut)
  75. {
  76.   long x1, x2;
  77.   x1 = (((long)ut - (long)ac6)*(long)ac5) >> 15;  
  78.   x2 = ((long)mc << 11)/(x1 + md);               
  79.   b5 = x1 + x2;                                   
  80.   return ((b5 + 8)>>4);                           
  81. }

  82. long bmp180GetPressure(unsigned long up)
  83. {
  84.   long x1, x2, x3, b3, b6, p;
  85.   unsigned long b4, b7;
  86.   
  87.   b6 = b5 - 4000;

  88.   x1 = (b2 * (b6 * b6)>>12)>>11;
  89.   x2 = (ac2 * b6)>>11;
  90.   x3 = x1 + x2;
  91.   b3 = (((((long)ac1)*4 + x3)<<OSS) + 2)>>2;
  92.   
  93.   x1 = (ac3 * b6)>>13;
  94.   x2 = (b1 * ((b6 * b6)>>12))>>16;
  95.   x3 = ((x1 + x2) + 2)>>2;
  96.   b4 = (ac4 * (unsigned long)(x3 + 32768))>>15;
  97.   
  98.   b7 = ((unsigned long)(up - b3) * (50000>>OSS));
  99.   if (b7 < 0x80000000)
  100.     p = (b7<<1)/b4;
  101.   else
  102.     p = (b7/b4)<<1;
  103.    
  104.   x1 = (p>>8) * (p>>8);
  105.   x1 = (x1 * 3038)>>16;
  106.   x2 = (-7357 * p)>>16;
  107.   p += (x1 + x2 + 3791)>>4;
  108.   
  109.   return p;
  110. }

  111. int bmp180Read(unsigned char address)
  112. {
  113.   unsigned char data;
  114.   
  115.   Wire.beginTransmission(BMP180ADD);
  116.   Wire.write(address);
  117.   Wire.endTransmission();
  118.   
  119.   Wire.requestFrom(BMP180ADD, 1);
  120.   while(!Wire.available());
  121.    
  122.   return Wire.read();
  123. }

  124. int bmp180ReadDate(unsigned char address)
  125. {
  126.   unsigned char msb, lsb;
  127.   Wire.beginTransmission(BMP180ADD);
  128.   Wire.write(address);
  129.   Wire.endTransmission();
  130.   Wire.requestFrom(BMP180ADD, 2);
  131.   while(Wire.available()<2);
  132.   msb = Wire.read();
  133.   lsb = Wire.read();
  134.   return (int) msb<<8 | lsb;
  135. }

  136. unsigned int bmp180ReadUT()
  137. {
  138.   unsigned int ut;
  139.   Wire.beginTransmission(BMP180ADD);
  140.   Wire.write(0xF4);                       
  141.   Wire.write(0x2E);                       
  142.   Wire.endTransmission();  
  143.   delay(5);                              
  144.   ut = bmp180ReadDate(0xF6);               
  145.   return ut;
  146. }

  147. unsigned long bmp180ReadUP()
  148. {
  149.   unsigned char msb, lsb, xlsb;
  150.   unsigned long up = 0;
  151.   
  152.   Wire.beginTransmission(BMP180ADD);
  153.   Wire.write(0xF4);                        
  154.   Wire.write(0x34 + (OSS<<6));            
  155.   Wire.endTransmission();
  156.   delay(2 + (3<<OSS));                     
  157.   
  158.   Wire.beginTransmission(BMP180ADD);
  159.   Wire.write(0xF6);                        
  160.   Wire.endTransmission();
  161.   
  162.   Wire.requestFrom(BMP180ADD, 3);
  163.   while(Wire.available() < 3);            
  164.   msb = Wire.read();
  165.   lsb = Wire.read();
  166.   xlsb = Wire.read();
  167.   up = (((unsigned long) msb << 16) | ((unsigned long) lsb << 8) | (unsigned long) xlsb) >> (8-OSS);//16 to 19 bit
  168.   return up;
  169. }

复制代码


回复

使用道具 举报

1313#
ID:513258 发表于 2019-7-25 11:52 | 只看该作者

回复

使用道具 举报

1314#
ID:513258 发表于 2019-7-25 12:13 | 只看该作者
  1. /*
  2. 【Arduino】66种传感器模块系列实验(68)
  3. 实验六十八:BMP180 新款 BOSCH温度模块气压传感器(代替BMP085)
  4. 程序之三,温度、实时气压、已知海拔计算的海平面的气压、已知海平面气压计算的高度
  5. 只是算法有点烂,做做实验而已
  6. */

  7. #include <SFE_BMP180.h>
  8. #include <Wire.h>

  9. SFE_BMP180 pressure;

  10. #define ALTITUDE 255.0

  11. unsigned long gpstimes;

  12. void setup()
  13. {
  14. Serial.begin(9600);

  15. pressure.begin();

  16. }

  17. void loop()
  18. {
  19. gpstimes=millis();

  20. char status;
  21. double T,P,p0,a;

  22. status = pressure.startTemperature();
  23. delay(status);
  24. status = pressure.getTemperature(T);
  25. delay(status);

  26. Serial.print("temperature: ");
  27. Serial.print(T,2);
  28. Serial.println(" deg C, ");



  29. status = pressure.startPressure(3);
  30. delay(status);

  31. status = pressure.getPressure(P,T);

  32. // Print out the measurement:
  33. Serial.print("absolute pressure A: ");
  34. Serial.print(P,2);
  35. Serial.println(" mb, ");

  36. p0=1013.2;

  37. a = pressure.altitude(P,p0);
  38. Serial.print("computed altitude A: ");
  39. Serial.print(a,0);
  40. Serial.println(" meters, ");

  41. T=25.00;
  42. status = pressure.getPressure(P,T);

  43. Serial.print("absolute pressure B: ");
  44. Serial.print(P,2);
  45. Serial.println(" mb, ");

  46. p0=1013.2;

  47. a = pressure.altitude(P,p0);
  48. Serial.print("computed altitude B: ");
  49. Serial.print(a,0);
  50. Serial.println(" meters, ");

  51. gpstimes=millis()-gpstimes;
  52. Serial.print("gpstimes=");
  53. Serial.println(gpstimes);
  54. Serial.println();
  55. delay(2000);
  56. }
复制代码


回复

使用道具 举报

1315#
ID:513258 发表于 2019-7-25 12:52 | 只看该作者

回复

使用道具 举报

1316#
ID:513258 发表于 2019-7-25 13:47 | 只看该作者
实验六十九: AT24C256 I2C接口 EEPROM 存储模块 IIC

AT24C256
是ATMEL公司256kbit串行电可擦的可编程只读存储器,8引脚双排直插式封装,具有结构紧凑、存储容量大等特点,可以在2线总线上并接4片该IC,特别适用于具有高容量数据储存要求的数据采集系统。AT24C256采用SOP-8封装。




回复

使用道具 举报

1317#
ID:513258 发表于 2019-7-25 14:28 | 只看该作者
芯片参数
芯片有3种工作电压;
  5.0V(VCC=4.5V~5.5V)
  2.7V(VCC=2.7V~5.5V)
  1.8V(VCC=1.8V~3.6V)
特性:
  内部可以组成32k×8存储单元
  2线串行接口
  斯密特触发,滤波输入抑制噪声
  双向数据传送协议
  硬件写保护引脚和软件数据保护功能
  具有64字节页写模式




回复

使用道具 举报

1318#
ID:513258 发表于 2019-7-25 14:30 | 只看该作者

回复

使用道具 举报

1319#
ID:513258 发表于 2019-7-25 14:45 | 只看该作者
A0、A1:地址选择输入端。在串行总线结构中,可以连接4个AT24C256IC。用A0、A1来区分各IC。A0、A1悬空时为0。
SCL:串行时钟输入。上升沿将SDA上的数据写入存储器,下降沿从存储器读出数据送SDA上。
SDA:双向串行数据输入输出口。用于存储器与单片机之间的数据交换。
WP:写保护输入。此引脚与地相连时,允许写操作;与VCC相连时,所有的写存储器操作被禁止。如果不连,芯片内部下拉到地。
VCC:电源。
GND:地。
NC:空。




回复

使用道具 举报

1320#
ID:513258 发表于 2019-7-25 15:20 | 只看该作者
AT24C256的工作原理
AT24C256内部有512页,每一页为64字节,任一单元的地址为15位。地址范围0000H~7FFFH。
芯片工作状态
1)时钟和数据传送
一般情况下,SDA被外部的设备拉到高,只有当SCL为低电平时,SDA上的数据变化,表示要传送数据。SCL为高时SDA变化表示状态变化。
2)开始状态(START)
当SCL为高时,SDA由高到低表示数据传送开始,这一状态必须在所有命令之前。
3)结束状态(STOP)
当SCL为高时,SDA由低到高表示数据传送结束状态。
4)应答状态(ACK)
所有的地址和数据都是以8位的形式串行传送给存储器或从存储器读出的。存储器在第9个时钟周期SDA发零信号表示已经收到8位数据。见图总线协议图。



回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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