mirror of
https://github.com/esphome/esphome-docs.git
synced 2025-01-26 22:21:38 +01:00
BME280 environment cookbook entry (#107)
* bme280 environment cookbook entery new cookbook entery fixing this issue: https://github.com/OttoWinter/esphomedocs/issues/89 * Formatting * Fixed formatting, removed global variables Fixed formatting, removed global variables as requested by OttoWinter * Comply with google C++ style guide * Fixed brackets * Tested and fixed typos/formatting Yalm expamples were tested by Mihalski
This commit is contained in:
parent
324891206e
commit
afb30ad1f8
1
.gitignore
vendored
1
.gitignore
vendored
@ -5,3 +5,4 @@ _build
|
||||
__pycache__/
|
||||
*.py[cod]
|
||||
*$py.class
|
||||
esphomeyaml/.DS_Store
|
||||
|
107
esphomeyaml/cookbook/bme280_environment.rst
Normal file
107
esphomeyaml/cookbook/bme280_environment.rst
Normal file
@ -0,0 +1,107 @@
|
||||
BME280 Environment
|
||||
==================
|
||||
|
||||
.. seo::
|
||||
:description: Instructions for setting up BME280 sensors in esphomelib and calculate altitude, absolute humidity, and sea level pressure.
|
||||
:image: bme280.jpg
|
||||
:keywords: BME280
|
||||
|
||||
The :doc:`/esphomeyaml/components/sensor/bme280` is a simple temperature, humidity, and pressure sensor with communication over I2C.
|
||||
With some simple math it is possible to either determine the height of the sensor, or the current pressure at sea level.
|
||||
This guide can be applied to any sensor measuring temperature and pressure at the same time, like the :doc:`/esphomeyaml/components/sensor/bmp280`, or :doc:`/esphomeyaml/components/sensor/bme680`.
|
||||
|
||||
.. figure:: images/bme280-header.jpg
|
||||
:align: center
|
||||
:width: 75.0%
|
||||
|
||||
The first step is to connect the sensor as described :doc:`here </esphomeyaml/components/switch/bme280>`.
|
||||
After validating the sensor is working, we can proceed and add some formulas.
|
||||
|
||||
.. code-block:: yaml
|
||||
sensor:
|
||||
- platform: bme280
|
||||
temperature:
|
||||
name: "BME280 Temperature"
|
||||
id: bme280_temperature
|
||||
pressure:
|
||||
name: "BME280 Pressure"
|
||||
id: bme280_pressure
|
||||
humidity:
|
||||
name: "BME280 Realtive Humidity"
|
||||
id: bme280_humidity
|
||||
address: 0x77
|
||||
update_interval: 15s
|
||||
- platform: template
|
||||
name: "Altitude"
|
||||
lambda: |-
|
||||
const float STANDARD_SEA_LEVEL_PRESSURE = 1013.25; //in hPa, see note
|
||||
return ((id(bme280_temperature).state + 273.15) / 0.0065) * (powf((STANDARD_SEA_LEVEL_PRESSURE / id(bme280_pressure).state), 0.190234) - 1); // in meter
|
||||
update_interval: 15s
|
||||
- platform: template
|
||||
name: "Absolute Humidity"
|
||||
lambda: |-
|
||||
const float mw = 18.01534; // molar mass of water g/mol
|
||||
const float r = 8.31447215; // Universal gas constant J/mol/K
|
||||
return (6.112 * powf(2.718281828, (17.67 * id(bme280_temperature).state) / (id(bme280_temperature).state + 243.5)) * id(bme280_humidity).state * mw) / ((273.15 + id(bme280_temperature).state) * r); // in grams/m^3
|
||||
update_interval: 15s
|
||||
|
||||
Altitude and absolute humidity:
|
||||
-------------------------------
|
||||
|
||||
The first block ``sensor`` starts with the normal bme280 sensor components ``temperature``, ``pressure``, and ``humidity`` with each their own id.
|
||||
After the bme280 sensor, a :doc:`/esphomeyaml/components/sensor/template` is defined to calculate the altitude in a lambda.
|
||||
The variable ``STANDARD_SEA_LEVEL_PRESSURE`` (in hPa), should be filled in for your location.
|
||||
The formula derived from `here <https://github.com/finitespace/BME280/blob/master/src/EnvironmentCalculations.cpp>`, converts the currently measured pressure to the altitudes in meters including temperature compensation.
|
||||
|
||||
The lambda in the second :doc:`/esphomeyaml/components/sensor/template` defines two physical constants and converts the currently measured pressure to absolute humidity (grams/m^3).
|
||||
|
||||
.. note::
|
||||
|
||||
Calculating the altitude with the BME280 sensor accurately requires this value to be known at sea level for your location and day.
|
||||
This can be achieved by replacing the global constant ``STANDARD_SEA_LEVEL_PRESSURE`` by for example pulling this value live from the internet or a stationary sensor via MQTT.
|
||||
|
||||
Equivalent sea level pressure:
|
||||
------------------------------
|
||||
|
||||
Calculating the sea level pressure with a statically mounted sensor can be be used as reference for moving sensors as mentioned in the note above.
|
||||
|
||||
.. code-block:: yaml
|
||||
sensor:
|
||||
- platform: bme280
|
||||
temperature:
|
||||
name: "BME280 Temperature"
|
||||
id: bme280_temperature
|
||||
pressure:
|
||||
name: "BME280 Pressure"
|
||||
id: bme280_pressure
|
||||
humidity:
|
||||
name: "BME280 Relative Humidity"
|
||||
id: bme280_humidity
|
||||
address: 0x77
|
||||
update_interval: 15s
|
||||
- platform: template
|
||||
name: "Equivalent sea level pressure"
|
||||
lambda: |-
|
||||
const float STANDARD_ALTITUDE = 0.6; // in meters, see note
|
||||
return id(bme280_pressure).state / powf(1 - ((0.0065 * STANDARD_ALTITUDE) / (id(bme280_temperature).state + (0.0065 * STANDARD_ALTITUDE) + 273.15)), 5.257); // in hPa
|
||||
update_interval: 15s
|
||||
|
||||
.. note::
|
||||
|
||||
For calculating the equivalent sea level pressure, the sensor needs to be mounted at a fixed altitude.
|
||||
Therefore it is not possible to calculate altitude at the same time, and vice versa!
|
||||
|
||||
Formula explanation
|
||||
-------------------
|
||||
|
||||
- `Relative humidity calculations <https://carnotcycle.wordpress.com/2012/08/04/how-to-convert-relative-humidity-to-absolute-humidity/>`__
|
||||
- `Altitude calculation <https://en.wikipedia.org/wiki/Atmospheric_pressure#Altitude_variation>`__
|
||||
|
||||
See Also
|
||||
--------
|
||||
|
||||
- :doc:`/esphomeyaml/components/sensor/template`
|
||||
- :doc:`/esphomeyaml/components/sensor/bme280`
|
||||
- `Edit this page on GitHub <https://github.com/OttoWinter/esphomedocs/blob/current/esphomeyaml/cookbook/bme280_environment.rst>`__
|
||||
|
||||
.. disqus::
|
After Width: | Height: | Size: 4.9 KiB |
BIN
esphomeyaml/cookbook/images/bme280-header.jpg
Normal file
BIN
esphomeyaml/cookbook/images/bme280-header.jpg
Normal file
Binary file not shown.
After Width: | Height: | Size: 190 KiB |
Loading…
Reference in New Issue
Block a user