2022-08-09 07:21:30 +02:00
|
|
|
Feedback Cover
|
|
|
|
==============
|
|
|
|
|
|
|
|
.. seo::
|
|
|
|
:description: Instructions for setting up feedback covers in ESPHome.
|
|
|
|
|
2024-08-14 04:51:21 +02:00
|
|
|
The ``feedback`` cover platform allows you to create covers with position control that
|
|
|
|
can optionally have feedback from sensors to detect the fully-open and fully-closed states (endstops),
|
2022-08-09 07:21:30 +02:00
|
|
|
and from sensors to detect actual movement (opening/closing). In all the cases the current
|
|
|
|
position is approximated with the time the cover has been moving in a direction.
|
|
|
|
|
|
|
|
It supports *open*, *close*, *stop* and *toggle* actions. Tilt control is not supported.
|
|
|
|
|
|
|
|
.. figure:: images/more-info-ui.png
|
|
|
|
:align: center
|
|
|
|
:width: 50.0%
|
|
|
|
|
|
|
|
.. code-block:: yaml
|
|
|
|
|
|
|
|
# Example configuration entry
|
|
|
|
cover:
|
|
|
|
- platform: feedback
|
|
|
|
name: "Gate"
|
|
|
|
|
|
|
|
open_action:
|
|
|
|
- switch.turn_on: open_cover_switch
|
|
|
|
open_duration: 2.1min
|
|
|
|
open_endstop: open_endstop_binary_sensor
|
|
|
|
open_sensor: open_movement_binary_sensor
|
|
|
|
|
|
|
|
close_action:
|
|
|
|
- switch.turn_on: close_cover_switch
|
|
|
|
close_duration: 2min
|
|
|
|
close_endstop: close_endstop_binary_sensor
|
|
|
|
close_sensor: close_movement_binary_sensor
|
|
|
|
|
|
|
|
stop_action:
|
|
|
|
- switch.turn_off: open_cover_switch
|
|
|
|
- switch.turn_off: close_cover_switch
|
|
|
|
|
|
|
|
Use Cases
|
|
|
|
---------
|
|
|
|
|
|
|
|
It is a versatile cover that can accommodate for a number of DIY setups, or monitoring an externally controlled cover:
|
|
|
|
|
|
|
|
Time-Based
|
|
|
|
**********
|
|
|
|
|
|
|
|
Simplest case, when no sensors are available. The state is thus assumed.
|
|
|
|
|
|
|
|
It is a drop-in replacement of :doc:`/components/cover/time_based`
|
|
|
|
|
|
|
|
Endstop Sensors
|
|
|
|
***************
|
|
|
|
|
|
|
|
For cases where there are endstops at one or both ends of the cover to detect the fully-open and fully-closed states.
|
2024-08-14 04:51:21 +02:00
|
|
|
When any of these endstops are reached, an actual state is read and updated and the cover optionally
|
2022-08-09 07:21:30 +02:00
|
|
|
stopped (via ``stop_action``). The state is not assumed.
|
|
|
|
|
|
|
|
The extension also handles the case where the cover has builtin endstops, which stops the movement, independently to
|
2024-08-14 04:51:21 +02:00
|
|
|
the component's logic. In this case, when the cover is fully closed (either if timed based or sensor based) the
|
2022-08-09 07:21:30 +02:00
|
|
|
``stop_action`` is not triggered.
|
|
|
|
|
|
|
|
It is a drop-in replacement of :doc:`/components/cover/endstop`.
|
|
|
|
|
|
|
|
Movement Sensors
|
|
|
|
****************
|
|
|
|
|
|
|
|
If movement feedback is available, the cover no longer operates in *optimistic mode* (assuming that movement starts
|
|
|
|
as soon as an action is triggered) and can also react to commands issued to cover from an external control and still
|
2022-08-09 16:00:55 +02:00
|
|
|
keep states in sync (useful for "smartization" of an existing cover).
|
2022-08-09 07:21:30 +02:00
|
|
|
|
|
|
|
When there are no specific endstop sensors, and if the cover has builtin endstops and no external control logic,
|
2024-08-14 04:51:21 +02:00
|
|
|
these movement sensors can optionally be use to infer the endstop state.
|
2022-08-09 07:21:30 +02:00
|
|
|
When the movement stops (with no stop action being requested) it is assumed that it was caused by
|
2024-08-14 04:51:21 +02:00
|
|
|
the builtin endstops, and so the close/open state (according to current direction) was reached.
|
2022-08-09 07:21:30 +02:00
|
|
|
This function is activated setting ``infer_endstop`` to True.
|
|
|
|
|
|
|
|
It can be used to replace a :doc:`/components/cover/current_based`, with some modifications in the yaml. See :ref:`migrating_current_based`
|
|
|
|
|
|
|
|
Safety Features
|
|
|
|
---------------
|
|
|
|
|
|
|
|
To protect the cover hardware from damage, some safety options are available:
|
|
|
|
|
|
|
|
- *Max duration*, to protect from faulty endstops
|
|
|
|
- *Direction change wait time*, like an interlock wait time, to protect motors from sudden direction changes
|
2024-08-14 04:51:21 +02:00
|
|
|
- *Obstacle sensors* and *rollback*, possibility to stop and optionally rollback the cover when some external sensors detects an obstacle
|
2022-08-09 07:21:30 +02:00
|
|
|
(it might be a sensor for high current consumption or an infrared light detecting an obstruction in the path).
|
|
|
|
|
|
|
|
|
|
|
|
Configuration variables
|
|
|
|
-----------------------
|
|
|
|
|
|
|
|
- **stop_action** (**Required**, :ref:`Action <config-action>`): The action that should
|
|
|
|
be performed when the remote requests the cover to be closed or an endstop is reached.
|
|
|
|
|
|
|
|
Open options:
|
|
|
|
|
|
|
|
- **open_action** (**Required**, :ref:`Action <config-action>`): The action that should
|
|
|
|
be performed when the remote requests the cover to be opened.
|
|
|
|
- **open_duration** (**Required**, :ref:`config-time`): The amount of time it takes the cover
|
|
|
|
to open up from the fully-closed state.
|
|
|
|
- **open_endstop** (**Optional**, :ref:`config-id`): The ID of the
|
|
|
|
:ref:`Binary Sensor <config-binary_sensor>` that turns on when the open position is reached.
|
|
|
|
- **open_sensor** (**Optional**, :ref:`config-id`): The ID of the
|
|
|
|
:ref:`Binary Sensor <config-binary_sensor>` that turns on when the cover is moving in the open direction.
|
|
|
|
- **open_obstacle_sensor** (**Optional**, :ref:`config-id`): The ID of the
|
|
|
|
:ref:`Binary Sensor <config-binary_sensor>` that turns on when an obstacle that blocks the
|
|
|
|
open direction is detected.
|
|
|
|
|
|
|
|
Close options:
|
|
|
|
|
|
|
|
- **close_action** (**Required**, :ref:`Action <config-action>`): The action that should
|
|
|
|
be performed when the remote requests the cover to be closed.
|
|
|
|
- **close_duration** (**Required**, :ref:`config-time`): The amount of time it takes the cover
|
|
|
|
to close from the fully-open state.
|
|
|
|
- **close_endstop** (**Optional**, :ref:`config-id`): The ID of the
|
|
|
|
:ref:`Binary Sensor <config-binary_sensor>` that turns on when the closed position is reached.
|
|
|
|
- **close_sensor** (**Optional**, :ref:`config-id`): The ID of the
|
|
|
|
:ref:`Binary Sensor <config-binary_sensor>` that turns on when the cover is moving in the close direction.
|
|
|
|
- **close_obstacle_sensor** (**Optional**, :ref:`config-id`): The ID of the
|
|
|
|
:ref:`Binary Sensor <config-binary_sensor>` that turns on when an obstacle that blocks the
|
|
|
|
close direction is detected.
|
|
|
|
|
|
|
|
Additional options:
|
|
|
|
|
|
|
|
- **has_built_in_endstop** (*Optional*, boolean): Indicates that the cover has built in end stop
|
|
|
|
detectors. In this configuration the ``stop_action`` is not performed when the open or close
|
|
|
|
time is completed and if the cover is commanded to open or close the corresponding actions
|
|
|
|
will be performed without checking current state. Defaults to ``false``.
|
2024-08-14 04:51:21 +02:00
|
|
|
- **infer_endstop_from_movement** (*Optional*, boolean): Whether to infer endstop state from the movement sensor.
|
2022-08-09 07:21:30 +02:00
|
|
|
Requires movement sensors to be set, no endstop sensors and to have builtin endstops. Defaults to ``false``.
|
|
|
|
- **assumed_state** (*Optional*, boolean): Whether the true state of the cover is not known.
|
|
|
|
This will make the Home Assistant frontend show buttons for both OPEN and CLOSE actions, instead
|
|
|
|
of hiding or disabling one of them. Defaults to ``true`` if no sensor is available to known
|
|
|
|
the actual state of the cover.
|
|
|
|
- **max_duration** (*Optional*, :ref:`config-time`): The maximum duration the cover should be opening
|
2024-08-14 04:51:21 +02:00
|
|
|
or closing. Useful for protecting from dysfunctional endstops.
|
2022-08-09 07:21:30 +02:00
|
|
|
Requires internal, builtin or inferred endstops.
|
|
|
|
- **direction_change_wait_time** (*Optional*, :ref:`config-time`): Stops cover and forces a wait time between changes in direction,
|
2024-08-14 04:51:21 +02:00
|
|
|
and takes it into account when computing cover position (useful to protect motors).
|
2022-08-09 07:21:30 +02:00
|
|
|
When this option is set (even at 0s) if an open/close action is invoked while the cover is moving in the opposite direction,
|
2024-08-14 04:51:21 +02:00
|
|
|
then and intermediate stop action will be invoked to generate the delay.
|
|
|
|
- **acceleration_wait_time** (*Optional*, :ref:`config-time`): Considers a wait time needed by the cover to actually
|
|
|
|
start moving after command is issued and takes it into account when computing cover position
|
|
|
|
(useful for heavy covers with large inertia).
|
|
|
|
Intended to not accumulate error when doing multiple partial open/close actions).
|
2022-08-09 07:21:30 +02:00
|
|
|
The open/close duration includes one instance of this delay, as it is the total amount of time from
|
|
|
|
issuing a command to reaching endstop.
|
|
|
|
Defaults to ``0s``.
|
|
|
|
- **update_interval** (*Optional*, :ref:`config-time`): The interval
|
|
|
|
to publish updated position information to the UI while the cover is moving.
|
|
|
|
Defaults to ``1s``.
|
|
|
|
- **obstacle_rollback** (*Optional*, percentage): The percentage of rollback the cover will perform in case of
|
|
|
|
obstacle detection while moving. Defaults to ``10%``.
|
|
|
|
- All other options from :ref:`Cover <config-cover>`.
|
|
|
|
|
|
|
|
Example Configurations
|
|
|
|
----------------------
|
|
|
|
|
|
|
|
.. _migrating_current_based:
|
|
|
|
|
|
|
|
Migrating Current-Based Cover
|
|
|
|
*****************************
|
|
|
|
|
|
|
|
Most options can be left untouched, but some modifications are needed:
|
|
|
|
|
|
|
|
|
|
|
|
1. All current sensing related options must be moved to auxiliary :doc:`/components/binary_sensor/analog_threshold`,
|
|
|
|
to convert current readings to binary sensors, using the corresponding thresholds and delays.
|
|
|
|
|
|
|
|
If there where any open/close obstacle current threshold defined, a separate binary sensor with that threshold should be defined.
|
|
|
|
The option ``start_sensing_delay`` should be directly replaced by a ``delayed_off`` filter in the movement sensors, or alternatively
|
2024-08-14 04:51:21 +02:00
|
|
|
hysteresis options could be used to reduce the noise.
|
2022-08-09 07:21:30 +02:00
|
|
|
2. To have the very same behavior implicit in current based cover, you must always set ``has_built_in_endstop`` and ``infer_endstop_from_movement``
|
|
|
|
to True.
|
|
|
|
|
|
|
|
.. code-block:: yaml
|
|
|
|
|
2024-08-14 04:51:21 +02:00
|
|
|
# Example original sensor configuration
|
2022-08-09 07:21:30 +02:00
|
|
|
cover:
|
|
|
|
- platform: current_based
|
|
|
|
name: "Current Based Cover"
|
|
|
|
|
|
|
|
open_sensor: open_current_sensor
|
|
|
|
open_moving_current_threshold: 0.5
|
|
|
|
open_obstacle_current_threshold: 0.8
|
|
|
|
start_sensing_delay: 0.8s
|
|
|
|
# ...rest of options
|
|
|
|
|
2024-08-14 04:51:21 +02:00
|
|
|
# Example converted sensor configuration
|
2022-08-09 07:21:30 +02:00
|
|
|
binary_sensor:
|
|
|
|
- platform: analog_threshold
|
|
|
|
id: open_binary_sensor
|
|
|
|
sensor_id: open_current_sensor
|
|
|
|
threshold: 0.5
|
2022-09-22 16:22:59 +02:00
|
|
|
filters:
|
2022-08-09 07:21:30 +02:00
|
|
|
- delayed_off: 0.8s
|
|
|
|
- platform: analog_threshold
|
|
|
|
id: open_obstacle_binary_sensor
|
|
|
|
sensor_id: open_current_sensor
|
|
|
|
threshold: 0.8
|
|
|
|
# ... repeat for close sensors
|
|
|
|
|
|
|
|
cover:
|
|
|
|
- platform: feedback
|
|
|
|
name: "Feedback Based Cover"
|
|
|
|
has_built_in_endstop: true
|
|
|
|
infer_endstop_from_movement: true
|
|
|
|
|
|
|
|
open_sensor: open_binary_sensor
|
|
|
|
open_obstacle_sensor: open_obstacle_binary_sensor
|
|
|
|
#... rest of options
|
|
|
|
|
2024-08-14 04:51:21 +02:00
|
|
|
3. Malfunction detection is not directly supported by Feedback Cover, as the malfunction was very narrowly defined to a specific use case
|
|
|
|
(while in other hardware configurations, the same situation is perfectly valid).
|
2022-08-09 07:21:30 +02:00
|
|
|
|
|
|
|
The malfunction alerted specifically when there was current in the opposite direction of the requested operation (possibly due to a relay welded).
|
|
|
|
This detection can still be achieved by putting the logic directly in the switch, (or whatever needed according to your specific use case).
|
|
|
|
|
|
|
|
.. code-block:: yaml
|
|
|
|
|
2024-08-14 04:51:21 +02:00
|
|
|
# Example original malfunction configuration
|
2022-08-09 07:21:30 +02:00
|
|
|
cover:
|
|
|
|
- platform: current_based
|
2024-08-14 04:51:21 +02:00
|
|
|
close_sensor: close_current
|
2022-08-09 07:21:30 +02:00
|
|
|
close_action:
|
|
|
|
- switch.turn_on: open_relay
|
2024-08-14 04:51:21 +02:00
|
|
|
open_sensor: open_current
|
2022-08-09 07:21:30 +02:00
|
|
|
open_action:
|
2024-08-14 04:51:21 +02:00
|
|
|
- switch.turn_on: open_relay
|
|
|
|
|
2022-08-09 07:21:30 +02:00
|
|
|
malfunction_detection: true
|
|
|
|
malfunction_action:
|
2024-08-14 04:51:21 +02:00
|
|
|
- logger.log: "Malfunction detected. Relay welded."
|
|
|
|
#... rest of options
|
2022-08-09 07:21:30 +02:00
|
|
|
|
2024-08-14 04:51:21 +02:00
|
|
|
# Example converted malfunction configuration
|
2022-08-09 07:21:30 +02:00
|
|
|
switch:
|
|
|
|
- platform: gpio
|
|
|
|
id: open_relay
|
2024-08-14 04:51:21 +02:00
|
|
|
#... rest of options
|
2022-08-09 07:21:30 +02:00
|
|
|
on_turn_off:
|
|
|
|
- delay: 200ms #allow for switching time and any discharge
|
|
|
|
- if:
|
2024-08-14 04:51:21 +02:00
|
|
|
condition:
|
2022-08-09 07:21:30 +02:00
|
|
|
binary_sensor.is_on: open_binary_sensor
|
2024-08-14 04:51:21 +02:00
|
|
|
# alternative can check directly
|
2022-08-09 07:21:30 +02:00
|
|
|
# on sensor.in_range open_current
|
|
|
|
then:
|
2024-08-14 04:51:21 +02:00
|
|
|
- logger.log: "Malfunction detected. Relay welded."
|
2022-08-09 07:21:30 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
See Also
|
|
|
|
--------
|
|
|
|
|
|
|
|
- :doc:`index`
|
|
|
|
- :ref:`automation`
|
|
|
|
- :apiref:`feedback/feedback_cover.h`
|
|
|
|
- :ghedit:`Edit`
|