Skip to content

This Shelly script lowers your energy bill by optimizing heating based on the day's cheapest electricity market prices.

License

Notifications You must be signed in to change notification settings

LeivoSepp/Smart-heating-management-with-Shelly

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Smart and cheap heating with Shelly

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.

Key Features

  1. Dynamic Heating Time Calculation: Calculates optimal heating times for the next day based on weather forecasts and energy prices.

  2. Time Period Division: Divides the day into time periods and activates heating during the cheapest hour within each period.

  3. 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.

Monitoring and edit schedule

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.

How to check the Heating Schedule

To view the heating hours created by the script:

  1. Open the schedule.
  2. Click on Time to see the full heating schedule.
Open Schedule Open Schedule

How to edit schedule manually

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.

How to monitor script execution

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.

Configuring Script parameters

Using Shelly App

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.

Shelly KVS

Using Shelly KVS

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.

Shelly KVS

  1. alwaysOffHighPrice: 300 - Keep heating always OFF if electricity market price higher than this value (EUR/MWh).

  2. alwaysOnLowPrice: 10 - Keep heating always on if the electricity market price lower than this value (EUR/MWh).

  3. country: ee - Specifies the country for energy prices. Only countries available in the Elering API are supported.

    • ee - Estonia
    • fi - Finland
    • lt - Lithuania
    • lv - Latvia
  4. defaultTimer: 60 - Configures the default timer duration, in minutes, for toggling the Shelly state. The default value is set to 60 to align with hourly changes in energy prices.

  5. 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.

Network package Description
VORK1 Elektrilevi
Day and night basic rate 77 EUR/MWh
Elektrilevi Võrk 1
VORK2 Elektrilevi
Day 60 EUR/MWh
Night 35 EUR/MWh
Elektrilevi Võrk 2, 4
VORK4 Elektrilevi
Day 37 EUR/MWh
Night 21 EUR/MWh
Elektrilevi Võrk 2, 4
VORK5 Elektrilevi
Day 53 EUR/MWh
Night 30 EUR/MWh
Day Peak time 82 EUR/MWh
Holiday Peak Time 47 EUR/MWh
Elektrilevi Võrk 5Elektrilevi Võrk 5
Partner24 Imatra
Day and night basic rate 60 EUR/MWh
Partner24Plus Imatra
Day and night basic rate 39 EUR/MWh
Partner12 Imatra
Day 72 EUR/MWh
Night 42 EUR/MWh
Summer Daytime: MO-FR at 8:00–24:00.
Summer Night time: MO-FR at 0:00–08:00, SA-SU all day
Winter Daytime: MO-FR at 7:00–23:00.
Winter Night time: MO-FR at 23:00–7:00, SA-SU all day
Partner12Plus Imatra
Day 46 EUR/MWh
Night 27 EUR/MWh
Summer Daytime: MO-FR at 8:00–24:00.
Summer Night time: MO-FR at 0:00–08:00, SA-SU all day
Winter Daytime: MO-FR at 7:00–23:00.
Winter Night time: MO-FR at 23:00–7:00, SA-SU all day
NONE Network fee is set to 0 and it will not taken into account.
  1. heatingCurve: 0 - Forecast impact increases or decreases the number of hours calculated by the algorithm based on the weather forecast. Default 0, 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 heating
    • 6 - more heating
  2. 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.
  1. 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.
  2. powerFactor: 0.5 - Adjusts the heating curve to be either more gradual (flat) or more aggressive (steep). Default 0.5. This setting is applicable only if weather forecast used.

    • 0 - flat
    • 1 - steep
  3. relayID: 0 - Configures the Shelly relay ID when using a Shelly device with multiple relays. Default 0.

Important To Know

  • 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:

Tested Failure Scenarios

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.

  1. Shelly is working, but the internet goes down due to a home router crash or internet provider malfunction. Shelly time continues running.
  2. After a power outage, the internet is not working, and Shelly has no time.
  3. Elering HTTP error occurs, and the Elering server is not reachable.
  4. Elering API failure happens, and the service is down.
  5. Elering API returns incorrect data, and prices are missing.
  6. Weather forecast HTTP error occurs, and the server is unavailable.
  7. Weather forecast API service error occurs, and the JSON data is not received.

Smart Heating Algorithms

Weather Forecast Algorithm

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.

Advantages of Weather Forecast-Based Heating

  • 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.

Shelly Geolocation

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.

Heating Curve

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.

Heating curve for 24h period


  • 12 hour period graph represents visually how heating time varies with outside temperature and the heatingCurve parameter.

Heating curve for 12h period

For those interested in the mathematical aspect, the linear equation used to calculate heating time is: (Temperature Forecast) * PowerFactor + (Temperature Forecast + heatingCurve).

Time Period Algorithm

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.

Heating period 24h


  • 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.

Heating period 24h


Does it Truly Reduce My Electric Bills

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

How to Install this Script

Installation

  1. Optain a Shelly Plus, Pro or Gen3 device Shelly devices.
  2. Connect the Shelly device to your personal WiFi network. Refer to the Shelly web interface guides.
  3. 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.
  4. 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.
  5. 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".
  6. 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
  7. Click "Import code".

Insert code

  1. Name the script, for instance, "Heating 24h-Forecast", and save.
  2. Click "Start" once the saving process is complete.
  3. Configuring Script parameters

Updating Script

  1. Open script web page in Github.
  2. Click the button "Copy raw file". Now the script is in your clipboard memory.

Insert code

  1. 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."
  2. Open the script you wish to update.
  3. Select all script code and delete it Ctrl+ADelete.
  4. Paste the code from the clipboard to the script window Ctrl+V.
  5. Save the script, the version is now updated.
  6. All configurations remain unchanged, as they are stored in KVS or Virtual Components.

How to Verify Script Execution

  1. In Shelly app or web page, navigate to "Schedules".
  2. Inspect the scheduled times when the Shelly will be activated.
  3. Schedulers are organized based on the time.
  4. Advanced users can inspect KVS storage: Advanced → Key Value Storage → Script Data

How the Script Operates

  1. Internet Connection:
    • The script needs the internet to download daily electricity prices and weather forecasts.
  2. Daily Operation:
    • It runs every day after 23:00 or as needed during the day to set up heating times.
  3. 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
Loading
  1. 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]
Loading

Troubleshooting

Error "Couldn't get script"

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:

  1. 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.

  2. Alternative Solution Through Shelly Cloud: If accessing the device web page is not feasible, follow these steps on the Shelly cloud:

    1. Delete the existing script.
    2. Create a new script.
    3. Copy and paste the entire script into the scripting window.
    4. Configure all necessary settings.
    5. Save and close the script.
    6. Run the script.

    If any issues arise during this process, you can repeat the workaround by starting from the script deletion step.

Couldn't get script.

Advanced → Key Value Storage → Script Data

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.

  1. 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.

  2. 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.

  3. Key: version1 Value: 3.8

    The version indicates the installed script version.

Key Value Storage

License

This project is licensed under the MIT License. See the LICENSE file for details.

Author

Created by Leivo Sepp, 2024-2025

GitHub Repository