Table of Contents
Implementing a Readily Deployed Autonomous Thermostat in 200 Lines of Code
The problem at hand is to develop the code for the mictrocontroller of an autonomous thermostat for a building with multiple rooms. The goal is to minimize power usage while ensuring that the temperature in each room is maintained at a comfortable level. The system must take into account various factors such as the current day of the week, time of the day, external temperature, and motion prediction in each room. Based on this data the system has to determine the radiator schedule for a number of time intervals.
The goal of this example is of demonstrating how SOLVER-AI can be used to optimize energy usage in smart home systems. It showcases the use of predictive modeling in anticipating room occupancy and temperature changes, leading to more efficient energy usage. The system forecasts future states enabling it to make proactive decisions and optimize performance.
The example also showcases how the system can intelligently adapt to changes in habits by uploading updated historical data.
Don't forget to also have a look at Implementing a Readily Deployed Solar Plant Sizing Tool in 400 Lines of Code.
github
The clients with its examples can be downloaded from https://github.com/SOLVER-AI-LTD/client. The code can be found in:
- python: /python/example_thermostat.py
- JavaScript: js/example_thermostat.js
Problem Detailed Description
Let's consider a building with numRooms number of rooms. We'll refer to i as the room number, with i being an integer in range [0, numRooms-1]. The building is fitted with an autonomous thermostat which:
- Is connected to motion sensors in every room and gathers data stored in a motionSensorData.csv file at time intervalsDth(1/6 hour in the example). The file has as columns:- weekday: Day of the week, integer in range [0, 6] where 0 is Monday and 6 is Sunday.
- th: Time of the day in hours, with range [0, 23.99].
- motion_i: Motion in room- i, which has value 1 if motion was detected in the interval- Dthand 0 if no motion was detected.
 
- Is connected to temperature sensors in every room and also has a sensor to measure the external temperature. It collects data at time intervalsDthand stores it in a temperatureSensorData.csv, which has columns:- C_i: State of the radiator in room- i, which has values 0 if off and 1 if on.
- T_i: Temperature in room- i.
- Te: External temperature.
- DTh_i: Temperature variation in room- iin the time interval- Dth.
- power: Power consumption during interval- Dth.
 
Objectives and Constraints
Considering numForecastIntervals times, spaced by Dth, our objective is to determine the radiator states C_i_j for each of the times th_j and weekday_j, so that:
- The total power consumption is minimized.
- If motion is detected in roomithe temperature is greater than a required temperaturerequiredT_j.
- If no motion is detected in roomithe temperature is greater than a requiredTmin_j.
Implementation
The implementation that can be found in the code is as depicted in the image below, with N = numForecastIntervals - 1.
 
Autonomous Thermostat Implementation (for room i).
The columns correspond to the different times j, with each subsequent column at Dth time difference from the previous one.
at j = 0
- The thermostat knows for each roomi: temperatureT_i_0, the current state of the radiatorsC_i_0and the external temperature.
- temperatureSensorData.csv can be used for predictingDTh_i_0andpower_0.
at j = 1
- We determine the timeth_1andweekday_1by addingDthto the previous time and weekday.
- We determine the temperatureT_i_1fromDTh_i_0from the prediction at the previous step.
- We consider the external temperature to still beTe.
- Given unknownC_i_1temperatureSensorData.csv can be used for predictingDTh_i_1andpower_1.
at j, where j is greater or equal to 2 and smaller than N
- We determine the timeth_jandweekday_jby addingDthto the previous time and weekday.
- We determine the temperatureT_i_jfromDTh_i_1from the prediction at the previous step.
- We consider the external temperature to still beTe.
- Given unknownC_i_jtemperatureSensorData.csv can be used for predictingDTh_i_jandpower_j.
- motionSensorData.csv can be used for predictingmotion_i_j.
- Givenmotion_i_jand the required temperaturerequiredT_irelative to roomi:- Ifmotion_i_jis greater than 0.4 (the probability of having movement is greater than 40%) then Tconstraint_i_j is the difference between the current temperatureT_i_jand the requiredT_i temperature for roomi.
- Otherwise,T_i_jis a large positive number.
 
- Given the minimum temperatureTmin_i,TconstraintMin_i_jis the difference between the current temperatureT_i_jand the minimum temperature.
at j = N = numForecastIntervals - 1
- We determine the timeth_Nandweekday_Nby addingDthto the previous time and weekday.
- We determine the temperatureT_i_NfromDTh_i_1from the prediction at the previous step.
- We consider the external temperature to still be Te.
- motionSensorData.csv can be used for predictingmotion_i_N.
- Givenmotion_i_Nand the required temperaturerequiredT_irelative to roomi:- Ifmotion_i_Nis greater than 0.4 (the probability of having movement is greater than 40%) then Tconstraint_i_N is the difference between the current temperatureT_i_Nand the requiredT_i temperature for roomi.
- Otherwise,T_i_Nis a large positive number.
 
- Given the minimum temperatureTmin_i,TconstraintMin_i_Nis the difference between the current temperatureT_i_Nand the minimum temperature.
Therefore, in order to perform this implementation, we need to set up:
- Equation modules forth_jandweekday_j
- Equation modules forTe_j, where in this case we consider all of them equal toTe.
- A SoftData for the temperatureSensorData.csv with VectorizationIndices: 0 tonumForecastIntervals- 2.
- A SoftData for the motionSensorData.csv with VectorizationIndices: 2 tonumForecastIntervals- 1.
- Equation modules for computingT_i_jforjfrom 1 tonumForecastIntervals- 1.
- Equation modules for computingTconstr_i_jforjfrom 2 tonumForecastIntervals- 1.
- Equation modules for computingTconstrMin_i_jforjfrom 2 tonumForecastIntervals- 1.
- An Equation module for computingpoweras the sum of thepower_jforjfrom 1 tonumForecastIntervals- 2.
We'll then have to set:
- As constants:- The time at which the calculation is performed (th_0,weekday_0) and the the state values forj= 0,T_i_0for each room.
- The required temperatures for each roomrequiredT_i.
- The minimum temperatures for each roomTmin_i.
- The intervalDth.
 
- As ranges:- The radiators controllersC_i_jfor all rooms andiandjfrom 1 tonumForecastIntervals- 2 to vary between 0 and 1 and be an integer.
 
- As constraints:- Require thatTconstr_i_jis greater than 0 forjfrom 0 tonumForecastIntervals- 1.
- Require thatTconstrMin_i_jis greater than 0 forjfrom 0 tonumForecastIntervals- 1.
 
- As objective:- powerto be minimized.
 
In the code we:
- Create a SolverAiClientSetup object solverAiClientSetup.
- Use the solverAiClientSetup object for creating all required modules and Problem.
- Create a SolverAiComputeInput object input.
- Use the input object to set up the solverSetup, constants, inputs, objectives and constraints.
- Create a SolverAiClientCompute object solverAiClientCompute.
- Run the computation with the runSolver function of the solverAiClientCompute object.
Notes:
- The data provided for the example was generated so that:- The temperatureSensorData.csv file was created by specific heat transfer coefficients between rooms and definition of the positioning of the rooms.
- The motionSensorData.csv file was created by specifying ranges of times within the week where motion was expected for each room on different days. A random number generator was then used so to produce I higher likelihood of motion during those periods.
 
Extending the Code
The code provided in example_thermostat perform all of the operations, from createion of the modules and Problem, to execution, to deletion. This would obviously not be the case if this was implemented in reality. We could imagine that:
- The thermostat could provide a server with the number of available sensors. The server would then call SOLVER-AI to setup modules and Problem. This would have to be performed only once at installation of the thermostat, or if additinal sensors were added to the system.
- In operation, the thermostat would upload (update) the motion and temperature data on a daily / weekly basis to avoid performing the machine learning training, which is time-consuming.
- A intermediary server should be interposed between the thermostat and SOLVER-AI to ensure the token is kept safe.
