Create pretty charts of your Nest thermostat data.
The point of this project was to see how well the Nest algorithms work. In particuar, the Nest claims to minimize overshoot, which is a common problem with cast-iron radiators. It also claims to know when to start heating in order to hit your target temperature exactly at the time you scheduled it.
Unfortunately, you can't actually access historical temperature data on the Nest website or via the iOS app. It shows you when heating was turned on/off and what the temperature targets were at those times, but it doesn't give you any indication of how well or how poorly the thermostat performed. This could be by design, as it's a lot of information to store.
This project uses an unofficial Nest API to pull your temperature readings periodically and store them in a database so that you can inspect the data yourself in an easily consumable form.
I also wanted an excuse to play with the D3 (Data-Driven Documents) library a little.
- Polls Nest website to collect thermostat telemetry
- Stores selected data in local MySQL database
- Generates a nice visualization of actual temp vs. set point
- Lower mini-chart is interactive pan-and-zoom of the upper chart
- Hover over the gray circles to get the exact timestamp and temperature
- LAMP stack
- Unofficial nest-api library by Guillaume Boudreau
- Yahoo Weather API (https://github.com/phront/Yahoo-Weather-API-PHP-class.git yahoo-api-master)
- D3 Js Library (https://www.d3js.org)
Clone this repo into your web root.
cd [your-web-root]
git clone https://github.com/mycon/nestgraph.git
Initialize git submodules nest-api-master
and yahoo-api-master
:
cd nestgraph
git submodule init
git submodule update
Grab the minified v3 version of d3js from https://d3js.org/d3.v3.min.js and place it into:
[your-web-root]/nestgraph/d3.min.js
Open inc/config.php
in a text editor and update:
nest_user
andnest_pass
variables with your username and password for nest.comlocal_tz
variable to reflect your time zone.local_woeid
with the code you find for your local address or city from: http://woeid.rosselliot.co.nz/
Run the test script to make sure that the API is able to pull your thermostat data correctly from nest.com.
php test.php
If this works, you should see a bunch of stuff fly across the screen, ending with something like this:
Heating : 0
Timestamp : 2013-01-15 22:10:39
Target temperature : 67.00
Current temperature : 67.53
Current humidity : 29
Choose a password for your local MySQL nest database, and update it in two places: inc/config.php
(the db_pass
variable) and dbsetup
.
As root or using a DBA account, run the commands in dbsetup to create the MySQL database that will be used to store historical data.
mysql -u root < dbsetup
Add your nests to the database.
php init_devices.php
Create a cron job to poll the website periodically and update the local database. The thermostat does not phone home on a fixed schedule, but typically it updates in 5 to 30 minute intervals. The script will only insert into the database if there is new data available. Obviously, update the path to insert.php
if it's not in /var/www/html/nestgraph
. Additionally, add an entry for the job that polls energy usage and weather data daily.
*/5 * * * * /bin/rm -f /tmp/nest_php_* ; /usr/bin/php /var/www/html/nestgraph/insert.php > /dev/null
2 9 * * * /bin/rm -f /tmp/nest_php_* ; /usr/bin/php /var/www/html/nestgraph/insertEnergy.php > /dev/null
(FYI, the reason we remove the files in /tmp
is because it seems the nest-api library attempts to cache authentication info too aggressively, and after a few days it ends up trying to connect to an AWS server that no longer exists.)
Point web browser to the nestgraph/index.php
directory on your webserver! Admire pretty graphs (actually, they won't be all that pretty until it has collected some data).
- Assumes you want temperatures displayed in Fahrenheit
- Doesn't automatically redraw when you resize the browser window
- Labels (current/target/heating) don't follow the trend lines when you pan/zoom
- Need to figure out what's actually wrong with the authentication caching in
nest-api
instead of just purging its files in/tmp