Purpose of this component is to provide easily configurable energy management for Home Assistant automations.
During the first phase it supports only to find nord pool cheapest hours (or most expensive) per day and automatic calendar creation. Later AIO Energy Management is planned to integrate into solar forecast to get support for solar energy usage.
Read more detailed information at the creatingsmarthome.com blog
-
Restart Home Assistant
or
-
Go to
HACS
->Integrations
, -
Select
...
from upper right corner, -
Select
Custom repositories
-
Add
https://github.com/kotope/aio_energy_management
and select Type asIntegration
-
Search for
AIO Energy Management
and select it -
Press
Download
-
Restart Home Assistant
SSH into Home assistant and write the following:
cd /config/custom_components
wget -O - https://raw.githubusercontent.com/kotope/aio_energy_management/master/install_to_home_assistant.sh | bash
- Cheapest Hours (or most expensive) - Nord Pool and Entso-E integration support
- Event Calendar
- Service utility
The cheapest hours configuration will create a binary_sensor type entity that will provide timeframe(s) containing percentually the cheapest hours per day.
Binary sensor will have the state 'on' when cheapest hours is active.
Automations can them be set to follow this sensor 'on' state.
The feature supports failsafe to ensure critical devices to run if for some reason Nord Pool price fetch has failed!
Installed and configured Nord Pool integration
Installed and configured Entso-E integration
Configuration is done through configuration.yaml.
Either nordpool_entity or entsoe_entity must be set, depending on which integration you want to use.
Configuration parameters are shown below:
Configuration | Mandatory | Description |
---|---|---|
nordpool_entity | no | Entity id of the nord pool integration |
entsoe_entity | no | Entity id of the entso-e integration. This is entso-e average_price sensor that provides all extra attributes |
unique_id | yes | Unique id to identify newly created entity |
name | yes | Friendly name of the created entity |
number_of_hours | yes | Number of hours required to get. Can contain entity_id of dynamic entity to get value from e.g. input_number |
first_hour | yes | starting hour used by cheapest hours calculation. If used 'starting_today' as true, must be AFTER nord pool price publishing. |
last_hour | yes | last hour used by cheapest hours calculation |
starting_today | yes | first_hour should be already on the same day. False if next day calculations only |
sequential | yes | true if trying to calculate sequential cheapest hours timeframe. False if multiple values are acceptable. |
failsafe_starting_hour | no | If for some reason nord pool prices can't be fetched before first_hour, use failsafe time to turn the sensor on. If failsafe_starting_hour is not given, the failsafe is disabled for the sensor. |
inversed | no | Want to find expensive hours to avoid? Set to True! default: false |
trigger_time | no | Earliest time to create next cheapest hours. Format: "HH:mm". Useful when waiting for other data to arrive before triggering event creation. Example: 'trigger_time: "19:00"' ! Deprecated: use trigger_hour instead ! |
price_limit | no | Only accept prices less than given float value or more than given float value if inversed is used. Note: given hours might be less than requested if not enough values can be found with given parameters. Only supported by non-seuqential cheapest_hours. Can contain entity_id of dynamic entity to get value from e.g. input_number |
trigger_hour | no | Earliest hour to create next cheapest hours. "HH:mm". Useful when waiting for other data to arrive before triggering event creation. Example: 'trigger_hour: 19'. Can contain entity_id of dynamic entity to get value from e.g. input_number |
The example configuration presents creation of three sensors: one for nord pool cheapest three hours, one for nord pool most expensive prices and final one for entso-e cheapest hours.
aio_energy_management:
cheapest_hours:
- nordpool_entity: sensor.nordpool
unique_id: my_cheapest_hours
name: My Cheapest Hours
first_hour: 21
last_hour: 12
starting_today: true
number_of_hours: 3
sequential: false
failsafe_starting_hour: 1
- nordpool_entity: sensor.nordpool
unique_id: my_expensive_hours
name: Expensive Hours
first_hour: 0
last_hour: 22
starting_today: false
number_of_hours: 4
sequential: false
failsafe_starting_hour: 1
inversed: true
- entsoe_entity: sensor.entsoe_average_price
unique_id: my_entsoe_cheapest_hours
name: My Entso-E Cheapest Hours
first_hour: 21
last_hour: 10
starting_today: true
number_of_hours: 5
sequential: false
Calendar feature will create a new calendar entity to display all upcoming scheduled energy management events. Also please note that the events can't be modified through the calendar, it's for displaying and automation purposes (for now at least).
Configuration required for energy management calendar:
Configuration | Mandatory | Description |
---|---|---|
unique_id | yes | Unique id to identify newly created entity |
name | yes | Friendly name of the created entity |
aio_energy_management:
calendar:
name: Energy Management
unique_id: energy_management_calendar
AIO Energy Management integration provides a service utility to be used alongside with other components. For now it only supports to clear cached cheapest hours data.
Service utility is provided automatically with the integration and does not need separate configuration.
Will clear stored data for specified cheapest hours configuration. Changes will take effect in next 30s when Home Assistant event loop is run. This is especially useful when trying different paremeters for cheapest hours: No longer need to wait until next day for changes to effect.
Parameter | Description |
---|---|
unique_id | unique_id of the item to be cleared. Unique_id should be the same as defined in cheapest_hours configuration entry. |
service: aio_energy_management.clear_data
data:
unique_id: my_cheapest_hours
aio_energy_management:
cheapest_hours:
- nordpool_entity: sensor.nordpool
unique_id: my_cheapest_hours
name: My Cheapest Hours
first_hour: 21
last_hour: 12
starting_today: true
number_of_hours: 3
sequential: false
failsafe_starting_hour: 1
- nordpool_entity: sensor.nordpool
unique_id: my_expensive_hours
name: Expensive Hours
first_hour: 0
last_hour: 22
starting_today: false
number_of_hours: 4
sequential: false
failsafe_starting_hour: 1
inversed: true
calendar:
name: Energy Management
unique_id: energy_management_calendar