esphome-docs/components/climate/bang_bang.rst

99 lines
4.5 KiB
ReStructuredText
Raw Normal View History

2020-07-02 03:43:55 +02:00
Bang Bang Climate Controller
2019-05-12 22:44:59 +02:00
============================
.. seo::
:description: Instructions for setting up Bang Bang climate controllers with ESPHome.
2019-05-12 22:59:06 +02:00
:image: air-conditioner.png
2019-05-12 22:44:59 +02:00
The ``bang_bang`` climate platform allows you to regulate a value with a
`bang-bang controller <https://en.wikipedia.org/wiki/Bang%E2%80%93bang_control>`__ (also called hysteresis controller).
2020-07-02 03:43:55 +02:00
The operation principle of a bang_bang controller is quite simple. First, you specify an observable
value (for example the temperature of a room). The controller will try to keep this observed value
in a defined range. To do this, the controller can activate objects like a heating unit to change
the observed value.
2019-05-12 22:44:59 +02:00
2020-07-02 03:43:55 +02:00
The range that the controller will try to keep the observed value in can be controlled through the
front-end with the ``target_temperature_low`` and ``target_temperature_high`` values (see screenshot below).
As soon as the observed temperature dips below or above this range it will activate one of the
defined actions ``cool_action``, ``heat_action`` and ``idle_action``.
2019-05-12 22:44:59 +02:00
2020-07-02 03:43:55 +02:00
There are three types of bang bang controllers this platform can represent:
2019-05-12 22:44:59 +02:00
2020-07-02 03:43:55 +02:00
- **Heaters**: For devices where the observed temperature can only be increased.
2019-05-12 22:44:59 +02:00
2020-07-02 03:43:55 +02:00
- As soon as the temperature goes below the lower target temperature, ``heat_action`` will be called.
- When the temperature goes above the higher temperature, ``idle_action`` will be called.
2019-05-12 22:44:59 +02:00
2020-07-02 03:43:55 +02:00
- **Coolers**: For devices where the observed temperature can only be decreased.
2019-05-12 22:44:59 +02:00
2020-07-02 03:43:55 +02:00
- As soon as the temperature goes above the higher target temperature, ``cool_action`` will be called.
- When the temperature goes below the lower temperature, ``idle_action`` will be called.
- **Heater+Cooler**: For devices where the temperature can both actively be increased and decreased.
2019-05-12 22:44:59 +02:00
2020-07-02 03:43:55 +02:00
- When the current temperature is below the lower target temperature, ``heat_action`` is called.
- When the current temperature is within the target temperature range, ``idle_action`` is called.
- When the current temperature is above the higher target temperature, ``cool_action`` is called.
2020-07-02 03:43:55 +02:00
Do note that the actions are only called when the current temperature leaves the target temperature range.
2020-07-02 03:43:55 +02:00
.. figure:: images/climate-ui.png
:align: center
:width: 60.0%
2019-05-12 22:44:59 +02:00
.. code-block:: yaml
2020-07-02 03:43:55 +02:00
# Example configuration entry
2019-05-12 22:44:59 +02:00
climate:
- platform: bang_bang
name: "Bang Bang Climate Controller"
2019-05-12 22:44:59 +02:00
sensor: my_temperature_sensor
default_target_temperature_low: 20 °C
default_target_temperature_high: 22 °C
heat_action:
- switch.turn_on: heater
idle_action:
- switch.turn_off: heater
2020-07-02 03:43:55 +02:00
Configuration variables:
------------------------
2019-05-12 22:44:59 +02:00
- **sensor** (**Required**, :ref:`config-id`): The sensor that is used to measure the current temperature.
2020-07-02 03:43:55 +02:00
- **default_target_temperature_low** (**Required**, float): The default low target temperature for
the control algorithm. This can be dynamically set in the frontend later.
- **default_target_temperature_high** (**Required**, float): The default high target temperature for
the control algorithm. This can be dynamically set in the frontend later.
2019-05-12 22:44:59 +02:00
- **idle_action** (**Required**, :ref:`Action <config-action>`): The action to call when
2020-07-02 03:43:55 +02:00
the climate device wants to enter idle mode.
2019-05-12 22:44:59 +02:00
- **heat_action** (*Optional*, :ref:`Action <config-action>`): The action to call when
2020-07-02 03:43:55 +02:00
the climate device wants to heating mode and increase the current temperature. At least one
of ``heat_action`` and ``cool_action`` need to be specified.
2019-05-12 22:44:59 +02:00
- **cool_action** (*Optional*, :ref:`Action <config-action>`): The action to call when
2020-07-02 03:43:55 +02:00
the climate device wants to cooling mode and decrease the current temperature.
2019-05-27 19:22:36 +02:00
- All other options from :ref:`Climate <config-climate>`.
2019-05-12 22:44:59 +02:00
2020-07-02 03:43:55 +02:00
Advanced options:
2019-05-12 22:44:59 +02:00
- **away_config** (*Optional*): Additionally specify target temperature range settings for away mode.
2020-07-02 03:43:55 +02:00
Away mode can be used to have a second set of target temperatures (for example while the user is
away or during nighttime)
2019-05-12 22:44:59 +02:00
2020-07-02 03:43:55 +02:00
- **default_target_temperature_low** (**Required**, float): The default low target temperature for
the control algorithm during away mode.
- **default_target_temperature_high** (**Required**, float): The default high target temperature for
the control algorithm during away mode.
2019-05-12 22:44:59 +02:00
.. note::
2020-07-02 03:43:55 +02:00
While this platform uses the term temperature everywhere, it can also be used for other values.
2019-05-12 22:44:59 +02:00
For example, controlling humidity is also possible with this platform.
See Also
--------
- :doc:`/components/climate/index`
2020-07-02 03:43:55 +02:00
- :apiref:`bang_bang/bang_bang_climate.h`
2019-05-12 22:44:59 +02:00
- :ghedit:`Edit`