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-06-18 01:17:25 +02:00
|
|
|
|
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-06-18 01:17:25 +02:00
|
|
|
|
2020-07-02 03:43:55 +02:00
|
|
|
.. figure:: images/climate-ui.png
|
|
|
|
:align: center
|
|
|
|
:width: 60.0%
|
2020-06-18 01:17:25 +02:00
|
|
|
|
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
|
2020-06-13 02:40:06 +02:00
|
|
|
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
|
|
|
|
--------
|
|
|
|
|
2020-06-13 02:40:06 +02:00
|
|
|
- :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`
|