aircon/README.md

234 lines
9.5 KiB
Markdown
Raw Permalink Normal View History

2021-06-03 09:07:12 +10:00
# Overview
2021-06-03 19:46:14 +10:00
![aircon.sh in action](https://cube.nethack.net/images/aircon_control.png "aircon.sh in action")
2021-06-03 09:07:12 +10:00
Script to automate control of an home reverse cycle aircon system based on custom logic and temperature measurements.
2023-12-04 16:56:26 +11:00
This was originally written for an [AdvantageAir](https://www.advantageair.com.au/) system. It just uses the myair API to interface with the aircon, so should be easily adaptable to other systems.
2021-06-03 09:07:12 +10:00
2021-06-23 15:29:55 +10:00
It can also log to an influxdb database for easy integration into Grafana or similar.
![grafana integration](https://cube.nethack.net/images/aircon_grafana.png "grafana integration")
2021-06-03 09:07:12 +10:00
# Features
2022-05-28 15:29:21 +10:00
- Define temperature rules based on weekday and/or time
2021-06-03 19:46:14 +10:00
- Automatically adjust aircon settings based on defined temperature thresholds
2022-05-28 15:29:21 +10:00
- Control zone temperature by opening/closing vents
- Open/close vents in adjacent zones to assist in temperature control
- Turn the entire aircon system on/off as needed to control temperature
2021-06-03 19:58:49 +10:00
- Turn zones on/off based on ARP table entries for specific MAC addresses (for example, if a TV is turned on or a person's phone is detected)
2022-05-28 15:29:21 +10:00
- Log temperature measurements to a CSV file or InfluxDB
2021-06-03 09:07:12 +10:00
# Usage
2022-05-28 15:23:39 +10:00
```text
usage: ./aircon.sh [options]
2022-05-28 15:23:39 +10:00
Modifies aircon based on configured parameters in /Users/rob/.airconrc.
2022-05-28 15:23:39 +10:00
-a file Specify location of arping binary (default: /usr/local/sbin/arping).
-b Rule debug mode. Show processing of time rules.
-A db Log actions to given influxdb database.
2022-05-28 15:23:39 +10:00
-c Cron mode. Only show output if actions were taken.
-D dbhost Specify influxdb hostname for -I and -A options (default: localhost)
-f file Specify an alternate config file.
-h Show this text.
-i x.x.x.x Specify IP address for aircon (default is 10.99.99.1)
-I db Log all zone temperatures to given influxdb database, then exit (see -o).
-k file If file exists, never change aircon settings (default: /Users/rob/.aircon_noaction).
2022-05-28 15:23:39 +10:00
-l num Set number of too hot/cold zones at which to taking action.
-L Log all zone temperatures to CSV file, then exit (see -o).
-m Generate a config file based on current aircon setup.
-o file Specify CSV output file. Default: /Users/rob/acstats.csv
-P Use pymyair instead of direct JSON API calls (also see -x).
2022-05-28 15:23:39 +10:00
-p Profiler mode.
-s Validate config file then exit.
-S[H] Show configured rules in human-readable format
(HTML if -H given, otherwise ANSI).
-t num Specify degrees below min temperature before taking action.
-T num Specify degrees above max temperature before taking action.
-w List which people are available then exit.
-W List zone-owning devices are available then exit.
-x path Specify location of 'pymyair' (from https://github.com/smallsam/pymyair)
(only used if -P specified)
2022-05-28 15:23:39 +10:00
-y Actually run commands/db inserts. By default, commands are just displayed.
```
2021-06-03 09:10:14 +10:00
2021-06-03 19:46:14 +10:00
# Examples
2021-06-03 19:52:03 +10:00
## Sample .airconrc file
2021-06-03 19:46:14 +10:00
```text
root@gridbug:~# cat .airconrc
2021-06-03 19:46:14 +10:00
options -t 0.5
2021-06-03 09:16:07 +10:00
modelock heat
2021-06-03 09:16:07 +10:00
constant Family
2021-06-03 09:16:07 +10:00
owner Study robsphone
owner Rob&Beth robsphone bethsphone
owner Brendan brendansphone
owner Media lgtv_wifi
2021-06-03 09:16:07 +10:00
@Thu-Fri;0830-1630 force Nursery close # Childcare hours
@1830-0630 temp Nursery 17-19
2021-06-03 09:16:07 +10:00
@0600-2359 temp Family 18-21
temp Media 18-22
temp Rob&Beth 18-22
@Mon-Fri;0830-1730 temp Study 18-22 # Rob working
@Sat-Sun ignore Study # Not working
2021-06-03 09:16:07 +10:00
adj Brendan Family
adj Media Brendan
adj Rob&Beth Family
adj Study Family
2021-06-03 09:16:07 +10:00
person Rob robsphone
person Beth bethsphone
person Brendan brendansphone
```
2021-06-03 09:16:07 +10:00
## Generate ~/.airconrc based on your actual aircon zones
```text
2021-06-03 19:46:14 +10:00
bash$ aircon.sh -m
```
2021-06-03 19:46:14 +10:00
## Log temperature for each zone to csv then exit
```text
2021-06-03 19:46:14 +10:00
bash$ aircon.sh -L -o /root/acstats.csv -x /usr/local/bin/pymyair -f /root/.airconrc
```
2021-06-03 19:46:14 +10:00
## Preview influxdb inserts for zone temperatures
```text
2021-06-03 19:52:03 +10:00
bash$ aircon.sh -I myinfluxdb
/usr/local/bin/influx -database myinfluxdb -execute INSERT temperature,room=Family value=18.7
/usr/local/bin/influx -database myinfluxdb -execute INSERT temperature,room=Brendan value=19.1
/usr/local/bin/influx -database myinfluxdb -execute INSERT temperature,room=Media value=21
/usr/local/bin/influx -database myinfluxdb -execute INSERT temperature,room=Rob&Beth value=18.4
/usr/local/bin/influx -database myinfluxdb -execute INSERT temperature,room=Study value=19.2
/usr/local/bin/influx -database myinfluxdb -execute INSERT temperature,room=Nursery value=17.8
/usr/local/bin/influx -database myinfluxdb -execute INSERT attendance,person=Rob value=1
/usr/local/bin/influx -database myinfluxdb -execute INSERT attendance,person=Beth value=1
/usr/local/bin/influx -database myinfluxdb -execute INSERT aircon running=0
/usr/local/bin/influx -database myinfluxdb -execute INSERT aircon mode=0
```
2021-06-03 19:46:14 +10:00
## Log temperature for each zone to local influxdb then exit
```text
2021-06-03 19:46:14 +10:00
bash$ aircon.sh -I myinfluxdb -y
```
2021-06-03 19:46:14 +10:00
## Determine required aircon changes and display them only (dry run)
```text
2021-06-03 19:46:14 +10:00
bash$ aircon.sh
2021-06-03 19:52:03 +10:00
Aircon mode: heat (locked to heat)
Current myzone: Family (zone 1)
Tolerance: 0.5 degrees low, 0 degrees high
Valid Set Actual Proposed
Zone Temp State Temp Temp Action
Family (C) 18-21 open 19 21.6 close_vent
Brendan n/a close 19 19.3 n/a
Media 18-22 close 20 21.6 n/a
Rob&Beth 18-22 close 18 19.5 n/a
Study n/a close 19 20.6 n/a
Bedroom2 18-21 close 18 19.5 n/a
2021-06-03 19:52:03 +10:00
Nursery 17-19 open 19 18.9 set_myzone
Analysis:
- Family is too hot (constant zone)
Proposed commands:
myair 10.99.99.1 set --zone 1 --state off --temp 19 # In zone Family, close vent
myair 10.99.99.1 myzone --zone 7 # Set MyZone to Nursery
```
2021-06-03 19:46:14 +10:00
## Make required aircon changes
```text
2021-06-03 19:46:14 +10:00
bash$ aircon.sh -y
2021-06-03 19:52:03 +10:00
Aircon mode: heat (locked to heat)
Current myzone: Family (zone 1)
Tolerance: 0.5 degrees low, 0 degrees high
Valid Set Actual Proposed
Zone Temp State Temp Temp Action
Family (C) 18-21 open 19 21.6 close_vent
Brendan n/a close 19 19.3 n/a
Media 18-22 close 20 21.6 n/a
Rob&Beth 18-22 close 18 19.5 n/a
Study n/a close 19 20.6 n/a
Bedroom2 18-21 close 18 19.5 n/a
2021-06-03 19:52:03 +10:00
Nursery 17-19 open 19 18.9 set_myzone
Analysis:
- Family is too hot (constant zone)
Proposed commands:
myair 10.99.99.1 set --zone 1 --state off --temp 19 # In zone Family, close vent
myair 10.99.99.1 myzone --zone 7 # Set MyZone to Nursery
Running action: In zone Family, close vent
RUNNING myair 10.99.99.1 set --zone 1 --state off --temp 19
Running action: Set MyZone to Nursery
RUNNING myair 10.99.99.1 myzone --zone 7
```
2021-06-03 19:52:03 +10:00
2021-06-03 19:46:14 +10:00
## Make required aircon changes and log actions to influxdb
```text
2021-06-03 19:46:14 +10:00
bash$ aircon.sh -y -A myinfluxdb
```
2021-06-03 19:46:14 +10:00
## Make required aircon changes and only produce output if actions taken (cron mdoe)
```text
2021-06-03 19:46:14 +10:00
bash$ aircon.sh -y -c
```
2021-06-03 19:46:14 +10:00
2022-05-28 15:15:47 +10:00
## Show which zone owners are detected, then exit
```text
2022-05-28 15:15:47 +10:00
bash$ aircon.sh -W
Devices Availability
bethsphone Available
brendansphone Available
lg-wifi Unavailable
robsphone Available
```
2022-05-28 15:15:47 +10:00
## Dump current rules, showing which ones are active (use -SH for HTML format)
```text
2022-05-28 15:15:47 +10:00
root@gridbug:scripts# ./aircon.sh -S
>> Querying aircon... ok
- Only operate the aircon in heat mode
- Close vent in Media if lg-wifi isn't online
- Close vent in Study if robsphone isn't online
- Close vent in Rob&Beth if one of (robsphone bethsphone) aren't online
- Close vent in Brendan if brendansphone isn't online
- Ignore Brendan temperature when deciding what to do
- Ignore Nursery temperature when deciding what to do
- Force the vent in Nursery to be closed
- [out-of-hours] From Mon to Fri between 08:30 and 18:00, Close vent in Ben/Sewing if brendanslaptop isn't online
- Prevent Nursery from being the MyZone
- Prevent Ben/Sewing from being the MyZone
- [out-of-hours] From Mon to Tue between 08:30 and 16:30, Force the vent in Nursery to be closed
- [out-of-hours] Between 08:30 and 16:30, Force the vent in Nursery to be closed
- [ignored] Keep temperature of Nursery between 25-26 degrees
- From Sat to Sun, Ignore Study temperature when deciding what to do
- [out-of-hours] From Mon to Fri between 08:30 and 18:00, Close vent in Ben/Sewing if brendansphone isn't online
- Between 06:00 and 23:59, Keep temperature of Family between 18-21 degrees
- [ignored] Keep temperature of Brendan between 18-20 degrees
- [out-of-hours] Between 20:00 and 07:00, Keep temperature of Rumpus between 18-22 degrees
- Keep temperature of Media between 18-21 degrees
- Keep temperature of Rob&Beth between 18-22 degrees
- [out-of-hours] From Mon to Fri between 08:30 and 17:30, Keep temperature of Study between 18-22 degrees
- [out-of-hours] Between 19:30 and 06:30, Keep temperature of Nursery between 18-19 degrees
- [out-of-hours] Between 20:00 and 07:00, Keep temperature of Ben/Sewing between 18-22 degrees
- [out-of-hours] From Mon to Fri between 08:30 and 17:30, Keep temperature of Ben/Sewing between 17-22 degrees
```
2021-06-03 19:46:14 +10:00
2021-06-03 09:10:14 +10:00