This package is to be used with:
- A working Domoticz instance where you have heaters and thermometers
- A first Google Calc spreadsheet where you define which temperature you want per room, day, hour
- A second Google Calc spreadsheet where you simply want to see the total electricity consumption per room, day.
- A state (probably as a state.json file) Javascript object that represents the state of your house, including rooms, heaters, ...
Once you have all this, you can create a simple script (see example.js) that will:
- Figure out which temperature you want in each of your rooms by fetching that data in a Google Calc sheet
- Fetch the temperatures in your rooms by asking that to Domoticz
- Send the right ON/OFF commands to your heaters
- compute how much power you have used and upload that to Google Calc
I live in an old house with electric heating. I set up Domoticz so that I could fine tune when the heaters start and stop. For that I have a few thermo sensors and one Chacon remote contact per heater. Most of them are plugged to the pilot thread with a diode in a way that when the Chacon module is ON, it means that the heater is OFF. Most of my old 1000W heaters are directly plugged to the Chacon so they are ON when the module is ON.
I made some LUA scripts but they were not really nice. I tried to make Python work with Domoticz but couldn't figure it out.
Then I found that you could do everything with Domoticz with its JSON API. You simply need to have access to Domoticz API. There is nothing to setup in Domoticz for that. If you have access to Domoticz's web interface, then you have access to the JSON API.
So here are the scripts that I use at home. Feel free to fork them to your needs.
They run on a Raspberry Pi on which also runs Domoticz with my RFXCom.
Open the example.js file to get hints on how to cron that script so that it runs every minute.
I discovered that some orders sometimes got lost (thick walls) ... so every 15 minutes, I ressend the commands up to three times.
This module is basically managing the state machine that represents the house. The state is inside the state variable. Insite that state var, we have the rooms object that contains all the room objects. Insite de rooms, we have all the heaters that are in the heaters object that contains all the heater objects. So for example, we have: state.rooms.Kitchen.heaters.35 : that is the heater with device ID 35 (in Domoticz) in the room called Kitchen.
You can install it with git or npm:
npm install domoticz-heaters
Then open and edit the example.js file to suit your needs. Do the same with configs-default.json and house_state.json.
If you want to use it like me, use two different Google Calc documents. There is a very good tutorial on how to set up access to Google Calc sheets from NodeJS on Twilio.
Copy:
- My Google Calc sheet that stores the consumption.
- My Google Calc sheet that stores the temperatures I want per day, room, hour
⭐ Don't hesitate to star that repo if it was of any use for you ;-)
Upgrading node on raspberry pi:
curl -sL https://deb.nodesource.com/setup_9.x | sudo -E bash -
sudo apt-get install -y nodejs