This Shelly script is designed to optimize heating activation by leveraging energy market prices from Elering, ensuring heating operates during the most cost-effective hours using various algorithms.
- Smart and cheap heating with Shelly
- Smart Heating Algorithms
- Does it Truly Reduce My Electric Bills
- How to Install this Script
- Troubleshooting
- License
- Author
-
Dynamic Heating Time Calculation: Calculates optimal heating times for the next day based on weather forecasts and energy prices.
-
Time Period Division: Divides the day into time periods and activates heating during the cheapest hour within each period.
-
Price-Level Utilization: Employs minimum and maximum price thresholds to keep the Shelly system consistently on or off based on cost efficiency.
Execution Schedule: The script runs daily after 23:00 or as necessary during the day to set up heating time slots for the upcoming period.
Starting from the script version 3.9 (January 2025), this script creates a single scheduler using an advanced timespec that includes all the required heating hours.
To view the heating hours created by the script:
- Open the schedule.
- Click on Time to see the full heating schedule.
You can manually override the schedule by clicking on any hour to include or exclude it for a specific day, then lick Next → Next → Save.
The next time the script calculates a new schedule, it will generate a fresh schedule with the updated timespec.
The field lastcalculation
in KVS is updated each time electricity prices are retrieved from Elering and a heating schedule is generated for the next heating period.
This script supports Shelly Virtual Components, allowing script parameters to be modified remotely using the Shelly app on a mobile phone.
Virtual Components are supported on Shelly Gen 2 Pro devices, as well as all newer Gen 3 and later devices.
For older Shelly devices that do not support Virtual Components, all parameters are saved to the Shelly KVS store. These settings can be modified directly via the Shelly web interface.
To update them, access the Shelly device via its IP address, navigate to Menu → Advanced → KVS, and locate the desired settings.
-
alwaysOffHighPrice: 300
- Keep heating always OFF if electricity market price higher than this value (EUR/MWh). -
alwaysOnLowPrice: 10
- Keep heating always on if the electricity market price lower than this value (EUR/MWh). -
country: ee
- Specifies the country for energy prices. Only countries available in the Elering API are supported.ee
- Estoniafi
- Finlandlt
- Lithuanialv
- Latvia
-
defaultTimer: 60
- Configures the default timer duration, in minutes, for toggling the Shelly state. The default value is set to60
to align with hourly changes in energy prices. -
elektrilevi: VORK2
- this defines the Elektrilevi or Imatra electricity transmission tariff package. Options include VORK1, VORK2, VORK4, VORK5, Partner24, Partner24Plus, Partner12, Partner12Plus, and NONE. Select None to ignore transmission fees. Please check the details in this Elektrilevi page or Imatra page. Options are the following.
-
heatingCurve: 0
- Forecast impact increases or decreases the number of hours calculated by the algorithm based on the weather forecast. Default0
, shifting by 1 equals 1h. This setting is applicable only if weather forecast used. Check heating curve impact for heating time dependency graphs.-6
- less heating6
- more heating
-
heatingMode: { "timePeriod": 12, "heatingTime": 0,"isFcstUsed": true }
Heating mode options are described in the following table.
You can customize or change the heating modes to better suit your personal preferences and specific situations. This flexibility allows you to adjust the system based on your needs, energy considerations, and comfort requirements.
Heating mode | Description | Best usage |
---|---|---|
{ "timePeriod": 24, "heatingTime": 10,"isFcstUsed": true } |
The heating time for 24-hour period depends on the outside temperature. | Concrete floor heating system or big water tank capable of retaining thermal energy for a duration of at least 10 to 15 hours. |
{ "timePeriod": 12, "heatingTime": 5,"isFcstUsed": true } |
The heating time for each 12-hour period depends on the outside temperature. | Gypsum (kipsivalu) floor heating system or water tank capable of retaining thermal energy for a duration of 5 to 10 hours. |
{ "timePeriod": 6, "heatingTime": 2,"isFcstUsed": true } |
The heating time for each 6-hour period depends on the outside temperature. | Air source heat pumps, radiators or underfloor heating panels with small water tank capable of retaining energy for a duration of 3 to 6 hours. |
{ "timePeriod": 24, "heatingTime": 20,"isFcstUsed": false } |
Heating is activated during the 20 most cost-effective hours in a day. | Ventilation system. |
{ "timePeriod": 24, "heatingTime": 12,"isFcstUsed": false } |
Heating is activated during the 12 most cost-effective hours in a day. | Big water tank 1000L or more. |
{ "timePeriod": 12, "heatingTime": 6,"isFcstUsed": false } |
Heating is activated during the six most cost-effective hours within every 12-hour period. | Big water tank 1000L or more with heavy usage. |
{ "timePeriod": 12, "heatingTime": 2,"isFcstUsed": false } |
Heating is activated during the two most cost-effective hours within every 12-hour period. | A 150L hot water boiler for a little household. |
{ "timePeriod": 6, "heatingTime": 2,"isFcstUsed": false } |
Heating is activated during the two most cost-effective hours within every 6-hour period. | A 200L hot water boiler for a household with four or more people. |
{ "timePeriod": 0, "heatingTime": 0,"isFcstUsed": false } |
Heating is only activated during hours when the price is lower than the specified alwaysOnLowPrice . |
-
isOutputInverted: true
- Configures the relay state to either normal or inverted.true
- Inverted relay state. This is required by many heating systems like Nibe or Thermia.false
- Normal relay state, used for water heaters.
-
powerFactor: 0.5
- Adjusts the heating curve to be either more gradual (flat) or more aggressive (steep). Default0.5
. This setting is applicable only if weather forecast used.0
- flat1
- steep
-
relayID: 0
- Configures the Shelly relay ID when using a Shelly device with multiple relays. Default0
.
-
When the script is stopped, the schedule is deleted. Shelly only follows the heating algorithm when the script is running.
-
Only one script can run at a time on newer Shelly devices using Virtual Components, as they are limited to a maximum of 10 components.
-
Up to two instances of this script can run concurrently in KVS mode, both employing different algorithm. These instances can either operate with the same switch output using Shelly Plus 1 or use different switch outputs, as supported by devices like Shelly Plus 2PM.
-
This script creates a special "watchdog" script. This "watchdog" script ensures proper cleanup when the heating script is stopped or deleted.
-
To mitigate the impact of internet outages, this script uses parameter ``heating time`` to turn on heating based on historically cheap hours.
-
The "Run on startup" button for this script must be activated. This setting ensures that the script starts after a power outage, restart, or firmware update.
-
This script exclusively handles scheduler generated by its own processes. This script is designed to delete only the scheduler that it has created.
-
This solution will only have benefits if you have an hourly priced energy contract. If your energy contract features a flat rate, this solution will not contribute to reducing your energy bill.
- This script depends on the internet and these two services:
- Electricity market price from Elering API,
- Weather forecast from Open-Meteo API.
During any of the failures below, Shelly uses the Heating Time
duration to turn on heating based on historically cheap hours.
Historical cheap hours are the following periods: 00:00-08:00, 12:00-15:00, and 20:00-23:00. In error mode, Shelly divides the heating time equally between the first and second halves of the day.
- Shelly is working, but the internet goes down due to a home router crash or internet provider malfunction. Shelly time continues running.
- After a power outage, the internet is not working, and Shelly has no time.
- Elering HTTP error occurs, and the Elering server is not reachable.
- Elering API failure happens, and the service is down.
- Elering API returns incorrect data, and prices are missing.
- Weather forecast HTTP error occurs, and the server is unavailable.
- Weather forecast API service error occurs, and the JSON data is not received.
This algorithm calculates the heating time for the next day based on weather forecasts. It is particularly effective for various home heating systems, including those with substantial water tanks capable of retaining thermal energy. This approach optimizes energy usage by aligning heating needs with anticipated weather conditions.
- Temperature Responsiveness:
When the outside temperature is a mild +17 degrees Celsius, no heating is necessary. Conversely, as the temperature drops to -5 degrees Celsius, there is a need for some heating, and for extremely cold conditions like -20 degrees Celsius, significant amount of heating is required.
- Smart Heating Management:
Utilizing weather forecasts allows for smart and adaptive heating management. The system will proactively adjust heating times based on the outside temperature, creating a responsive and dynamic heating schedule.
- Location-Specific Forecast:
To provide accurate weather forecasts, location data is necessary. This enables the system to deliver precise predictions for your home's climate, allowing for a customized and effective heating strategy.
Ensure that your Shelly device has the correct location information by checking Shelly → Settings → Geolocation → Latitude/Longitude.
Note: Shelly's location is determined based on your internet provider's IP address, which may or may not accurately reflect your home location. Verify and update the latitude and longitude settings as needed.
The relationship between temperature and heating time is known as the heating curve.
Heating time is influenced by the insulation of your household. For instance, an old and uninsulated house may require 10 hours of heating at -5 degrees, whereas a new A-class house might only need 6 hours.
To account for these differences, the script includes the parameter heatingCurve
, allowing users to customize the heating curve based on their specific household characteristics.
- 24 hour period graph represents visually how heating time varies with outside temperature and the
heatingCurve
parameter which shifts the heating curve to the left or right, whereas shifting 1 equals 1h. The Shelly device has a maximum limit of 20 schedulers, representing the maximum heating hours the script can manage within a 24-hour period. If more heating hours are needed, the script employs a 12-hour algorithm.
- 12 hour period graph represents visually how heating time varies with outside temperature and the
heatingCurve
parameter.
For those interested in the mathematical aspect, the linear equation used to calculate heating time is: (Temperature Forecast) * PowerFactor + (Temperature Forecast + heatingCurve)
.
This algorithm divides heating into distinct time periods, activating heating during the most cost-effective hours within each period. It is well-suited for use cases such as hot water boilers, where usage is contingent on the household size rather than external temperature. This method optimizes energy efficiency by aligning heating with periods of lower energy costs.
- A 24-hour graph with 10 heating hours visually shows when the most affordable times for heating are chosen during the day. The red bar represents heating hours within the day.
- A 4-hour graph with 1 heating hours visually shows how the most affordable time for heating is chosen during each of the 4h-period. The red bar represents heating hour within the period.
In short: yes.
Here's a more detailed explanation. While your overall daily electric consumption remains the same, this script optimizes the activation of your heating devices for the most economical hours. Consequently, even with the same energy consumption, your electricity bill is reduced.
Appliances like water heaters, water tanks, ground-source or air-source heat pumps, electric radiators, underfloor electric heaters, and air conditioning are examples of energy-intensive devices that benefit from being activated during the most cost-effective times of the day.
Electricity prices can fluctuate significantly, sometimes varying up to 100 times during a day. Check electricity market prices for more information. https://dashboard.elering.ee/et/nps/price
- Optain a Shelly Plus, Pro or Gen3 device Shelly devices.
- Connect the Shelly device to your personal WiFi network. Refer to the Shelly web interface guides.
- The firmware of Shelly Gen2 Plus devices must be version 1.4.4 or higher. The KVS store is read only if the firmware version is 1.4.3 or older.
- The firmware of Shelly Gen2 Pro or Gen3 devices must be version 1.4.4 or higher. The script will not install Virtual Components if the firmware version is 1.4.3 or older.
- Open the Shelly device web page: Click Settings → Device Information → Device IP → click on the IP address. The Shelly device web page will open, on the left menu click "<> Scripts".
- Click the "Library" button (do not click "Create Script") → Configure URL → copy-paste and save the following link. By following this method, you can ensure that you will get the latest version of the script.
https://raw.githubusercontent.com/LeivoSepp/Smart-heating-management-with-Shelly/master/manifest.json
- Click "Import code".
- Name the script, for instance, "Heating 24h-Forecast", and save.
- Click "Start" once the saving process is complete.
- Configuring Script parameters
- Open script web page in Github.
- Click the button "Copy raw file". Now the script is in your clipboard memory.
- Access the Shelly device web page: Navigate to Settings → Device Information → Device IP → click on the IP address. The Shelly device web page will open; on the left menu, select "<> Scripts."
- Open the script you wish to update.
- Select all script code and delete it Ctrl+A → Delete.
- Paste the code from the clipboard to the script window Ctrl+V.
- Save the script, the version is now updated.
- All configurations remain unchanged, as they are stored in KVS or Virtual Components.
- In Shelly app or web page, navigate to "Schedules".
- Inspect the scheduled times when the Shelly will be activated.
- Schedulers are organized based on the time.
- Advanced users can inspect KVS storage: Advanced → Key Value Storage → Script Data
- Internet Connection:
- The script needs the internet to download daily electricity prices and weather forecasts.
- Daily Operation:
- It runs every day after 23:00 or as needed during the day to set up heating times.
- Workflow:
- The script follows a flowchart to determine the best heating hours based on market prices and weather forecasts.
flowchart TD
0[Start loop] --> A
A[Get Shelly time and location] --> K{Is weather forecast used?}
K -- Yes --> B{Get weather forecast <br> from Open-Meteo.com API}
B -- Succeeded </br>Calculate heating time --> D{Get electricity market price <br> from Elering API}
K -- No --> D
B -- Failed</br>Check again in 1 minute --> B
D -- Succeeded</br>Calculate heating schedules --> L{Check, if market price and </br> forecast data is accurate}
D -- Failed</br>Check again in 1 minute --> D
L -- Yes</br>Check again in 1 minute --> L
L -- No</br>Start the script --> 0
- Watchdog workflow
flowchart TD
0[Start heating script] --> A
A[Create 'watchdog' script </br>with an event handler] --> K{Is heating script </br>stopped or deleted?}
K -- Yes --> B[Find the script schedule</br>and delete it]
There is an issue within the Shelly system that may affect your experience when attempting to open scripts through the Shelly cloud or mobile app. The encountered error, "Couldn't get script," is a known bug preventing the opening of scripts larger than 15kB via these platforms.
To navigate around this inconvenience, we suggest the following workarounds:
-
Open the Script Through Device Web Page: Access the device web page to successfully open any script. This method provides a direct and reliable solution to view and manage your scripts seamlessly.
-
Alternative Solution Through Shelly Cloud: If accessing the device web page is not feasible, follow these steps on the Shelly cloud:
- Delete the existing script.
- Create a new script.
- Copy and paste the entire script into the scripting window.
- Configure all necessary settings.
- Save and close the script.
- Run the script.
If any issues arise during this process, you can repeat the workaround by starting from the script deletion step.
The script saves data in Shelly KVS (Key-Value-Storage) to preserve it in case of power outages or restarts.
To access the stored data on the Shelly device web page, navigate to Advanced → KVS.
-
Key:
schedulerIDs1
Value:1
The numeric values represent schedule ID number created by the script. This information is crucial for each script to identify and manage schedule associated with it. It aids in the proper deletion of outdated schedules when creating new ones is necessary.
-
Key:
lastcalculation1
Value:Fri Dec 27 2024 23:29:20 GMT+0200
This timestamp indicates the time when the script successfully retrieved market prices from Elering and created schedules. While this information is primarily for your reference, it offers insights into the timeline of script activities.
-
Key:
version1
Value:3.8
The version indicates the installed script version.
This project is licensed under the MIT License. See the LICENSE file for details.
Created by Leivo Sepp, 2024-2025