For communication about this project please join this telegram chat.
For issues or feature requests, please go to the issue section. It will be perfect if you attach log to your issue. Log you can collect with this python script. It helps you to save all data frames from the UART bus to a csv-file. This log combined with the detailed situation description will significantly speed up bug correction. There is also a detailed instruction describing how to properly request a feature.
- All data of this project (software, firmware, schemes, 3d-models etc.) are provided 'AS IS'. Everything you do with your devices, you are doing at your own risk. If you don't strongly understand what you are doing, just buy Wi-Fi module from your air conditioner manufacturer.
- I am not a programmer. So source code is certainly not optimal and badly decorated (but there are a lot of comments in it; sorry, a significant part of it is in Russian). Also, code may be written unsafe. I tried to test all parts of the code, but I'm sure I missed a lot of things. So treat it with suspicion, expect a trick from it, and if you discover something wrong write an issue here.
- Russian and English readme files are substantially identical in meaning. But in case of differences, the Russian version is more significant.
This custom component allows you to control your air conditioner through Wi-Fi if it is made in the AUX factory.
Component tested with ESPHome 1.18.0 and Rovex ALS1 air conditioner. It looks like many other air conditioners can be controlled by aux_ac
, but this possibility isn't tested. See list of tested ACs below for more details.
AUX is one of the OEM air conditioner manufacturers. AUX produce ACs for many brands. There is the following list of AUX-based air conditioner on the internet: AUX, Abion, AC ELECTRIC, Almacom, Ballu, Centek, Climer, DAX, Energolux, ERISSON, Green Energy, Hyundai, IGC, Kentatsu (some series only), Klimaire, KOMANCHI, LANZKRAFT, LEBERG, LGen, Monroe, Neoclima, NEOLINE, One Air, Pioneer (until 2016), Roda, Rovex, Royal Clima, SAKATA, Samurai, SATURN, Scarlett, SmartWay, Soling, Subtropic, SUBTROPIC, Supra, Timberk, Vertex, Zanussi. There are doubts about its completeness and reliability, but nothing better could be found.
The list of tested ACs is placed in a separate file and includes tested by the author or by users ACs. This list is permanently updated, mainly based on feedback from users in Telegram chat.
- If your AC is listed above, you should take a closer look at
aux_ac
. - If something about AUX is written on the nameplate of the air conditioner in the manufacturer line.
- If the User Manual of your HVAC describes connection to Wi-Fi with mobile app ACFreedom it seems you may go deeper with
aux_ac
. But try all soft and hardware for your own risk. You must clearly understand what you are doing. - If the manufacturer of your AC offers a CTTM-40X24-WIFI-AKS Wi-Fi module (left) or the one in the photo on the right for control. Moreover, the right module can be either with a USB connector or with a 5-pin connector.
If you are unsure, it is better to wait while other users will test your model of AC (maybe never). Or please go to telegram-chat with your questions. Maybe you will get help there.
If you have tested your air conditioner and aux_ac
works with it, please let me know about it. I'll add this info to the list of tested ACs above.
The best way to report about your test results is writing a message in the telegram or in the issue section.
For correct component operation, you need hardware and firmware. The hardware description is located in a separate file.
You need ESPHome v.1.18.0 or above. External_components
have appeared in this version. But it is better to use ESPHome v.1.20.4 or above, cause there were a lot of external_components
errors corrected before this version.
- Declare external component. Read the manual for details.
external_components:
- source:
type: git
url: https://github.com/GrKoR/esphome_aux_ac_component
In case you need a specific version of the component, you can use the component declaration from the example below. The example uses version 0.2.14 of the component. You can find a list of available versions on the GitHub tags page.
external_components:
- source:
type: git
url: https://github.com/GrKoR/esphome_aux_ac_component
ref: v.0.2.14
- Configure UART to communicate with air conditioner:
uart:
id: ac_uart_bus
# ATTENTION! For TX and RX use GPIO4 (D2) and GPIO5 (D1) for NodeMCU-like boards!
# See docs for details: https://github.com/GrKoR/esphome_aux_ac_component/blob/master/docs/HARDWARE-EN.md
tx_pin: GPIO1
rx_pin: GPIO3
baud_rate: 4800
data_bits: 8
parity: EVEN
stop_bits: 1
- ATTENTION! You need to disable the ESPHome logger so that it does not send its data to the air conditioner. Disabling the logger from the UART bus will not affect the logger output to the console or web server in any way.
logger:
baud_rate: 0
If for some reason you need the logger output to the UART, you can switch it to another UART. ESP8266 has two hardware UARTs: UART0 and UART1. Only UART0 suits for aux_ac
cause only it has both TX and RX. UART1 has TX only, and it can be used by logger for output:
logger:
level: DEBUG
hardware_uart: UART1
Minimal configuration:
climate:
- platform: aux_ac
name: "AC Name"
Full configuration:
climate:
- platform: aux_ac
name: "AC Name"
id: aux_id
uart_id: ac_uart_bus
period: 7s
show_action: true
display_inverted: false
timeout: 150
optimistic: true
indoor_temperature:
name: AC Indoor Temperature
id: ac_indoor_temp
accuracy_decimals: 1
internal: false
outdoor_temperature:
name: AC Outdoor Temperature
id: ac_outdoor_temp
internal: false
outbound_temperature:
name: AC Coolant Outbound Temperature
id: ac_outbound_temp
internal: false
inbound_temperature:
name: AC Coolant Inbound Temperature
id: ac_inbound_temp
internal: false
compressor_temperature:
name: AC Compressor Temperature
id: ac_strange_temp
internal: false
display_state:
name: AC Display State
id: ac_display_state
internal: false
defrost_state:
name: AC Defrost State
id: ac_defrost_state
internal: false
inverter_power:
name: AC Inverter Power
id: ac_inverter_power
internal: false
inverter_power_limit_value:
name: AC Inverter Power Limit Value
id: ac_inverter_power_limit_value
internal: false
inverter_power_limit_state:
name: AC Inverter Power Limit State
id: ac_inverter_power_limit_state
internal: false
preset_reporter:
name: AC Preset Reporter
id: ac_preset_reporter
internal: false
vlouver_state:
name: AC Vertical Louvers State
id: ac_vlouver_state
internal: false
visual:
min_temperature: 16
max_temperature: 32
temperature_step: 1
supported_modes:
- HEAT_COOL
- COOL
- HEAT
- DRY
- FAN_ONLY
custom_fan_modes:
- MUTE
- TURBO
supported_presets:
- SLEEP
custom_presets:
- CLEAN
- HEALTH
- ANTIFUNGUS
supported_swing_modes:
- VERTICAL
- HORIZONTAL
- BOTH
-
name (Required, string): The name of the climate device. At least one of
id
orname
is required! -
id (Optional, ID): Manually specify the ID used for code generation. At least one of
id
orname
is required! -
uart_id (Optional, ID): Manually specify the ID of the UART Bus if you want to use multiple UART buses.
-
period (Optional, time, default
7s
): Period between status requests to the AC.Aux_ac
will receive the new air conditioner status only after a regular request, even if you change the settings of AC using IR-remote. -
show_action (Optional, boolean, default
true
): Whether to show current action of the device (experimental). For example, in the HEAT_COOL mode, AC hardware may be in one of the following actions:-
HEATING: AC is heating the air in the room;
-
IDLE: AC is working in the FAN mode, cause the target temperature is reached;
-
COOLING: AC is cooling the air. The same thing will be in HEAT or COOL modes, with the only difference of the list of actions (IDLE + HEATING or IDLE + COOLING).
-
display_inverted (Optional, boolean, default
false
): It configures display driver logic level. As it turned out in the issue #31, different models of conditioners manage display different way. Rovex ACs powers off display by bit1
in command packet and power it on by bit0
. Many other conditioners do this vice versa.
-
-
timeout (Optional, unsigned integer, default
150
): Packet timeout foraux_ac
data receiver.
In the most common use ofaux_ac
, it isn't necessary to change this value. This keyword is optional, so you may omit it.
The only situation when you can play with timeout is heavily loaded ESP. When you are using your ESP for many hard tasks, it is possible thataux_ac
does not have enough time to receive AC responses. In this case, you can slightly raise the timeout value. But the best solution would be to remove some of the tasks from the ESP.
The timeout is limited to a range from150
to600
milliseconds. Other values are possible only with source code modification. But I don't recommend that. -
optimistic (Optional, boolean, default
true
): Whether entity states should be updated immediately after receiving a command from Home Assistant/ESPHome. -
indoor_temperature (Optional): Parameters of the room air temperature sensor.
- name (Required, string): The name for the temperature sensor.
- id (Optional, ID): Set the ID of this sensor for use in lambdas.
- internal (Optional, boolean): Mark this component as internal. Internal components will not be exposed to the frontend (like Home Assistant). As opposed to default Sensor behaviour, this variable is always true except in cases where the user has set it directly.
- All other options from Sensor.
-
outdoor_temperature (Optional): Parameters of the outdoor temperature sensor. They are the same as the indoor_temperature (see description above).
Attention! When the air conditioner is turned off, the outdoor temperature is updated rarely (every 6-7 hours). This isn't a bug of the component, but a feature of the air conditioner hardware. The only way to get changes more often is to create a template sensor, the temperature of which can be changed manually. When the air conditioner is working, the value of this sensor can be copied from the outdoor_temperature. When the air conditioner is turned off, the temperature value should be recalculated according to the dynamics of the outbound_temperature sensor (it changes frequently and shows values close to the air temperature when the air conditioner is turned off). You can't copy the value of outbound_temperature without changes to the template sensor in AC off mode, because these temperatures are not identical.
-
inbound_temperature (Optional): Parameters of the coolant inbound temperature sensor. They are the same as the indoor_temperature (see description above).
-
outbound_temperature (Optional): Parameters of the coolant outbound temperature sensor. They are the same as the indoor_temperature (see description above).
-
compressor_temperature (Optional): Parameters of the compressor temperature sensor. They are the same as the indoor_temperature (see description above).
-
display_state (Optional): The information for the HVAC display state sensor (is display ON or OFF)
- name (Required, string): The name for the display state sensor.
- id (Optional, ID): Set the ID of this sensor for use in lambdas.
- internal (Optional, boolean): Mark this component as internal. Internal components will not be exposed to the frontend (like Home Assistant). As opposed to default Binary Sensor behavior, this variable is always true except in cases where the user has set it directly.
- All other options from Binary Sensor.
-
defrost_state (Optional): The information for the HVAC defrost function state sensor (is it ON or OFF). All settings are the same as for the display_state (see description above).
-
inverter_power (Optional): The information for the inverter power sensor. All settings are the same as for the indoor_temperature (see description above).
ATTENTION! The parameter name was changed in v.0.2.9 due to incorrect spelling.
-
inverter_power_limit_state (Optional): Configuration of the power limit state sensor. It displays the state of the power limitation function for the inverter HVAC (is it ON or OFF). All settings are the same as for the display_state (see description above).
-
inverter_power_limit_value (Optional): Configuration of the power limit value sensor. All settings are the same as for the indoor_temperature (see description above).
It reports the current value of the power limitation function for the inverter HVAC. This sensor represents the value only after the HVAC confirms the power limitation. The value is always in the range from 30% to 100%. This is the hardware limitation. -
preset_reporter (Optional): Parameters of text sensor with current preset. All settings are the same as for the display_state (see description above).
ESPHome Climate devices are not reporting their active presets (from supported_presets and custom_presets lists) to MQTT. This behavior has been noticed at least in version 1.20.0. In case you are using MQTT and want to receive information about active preset, you should declare this sensor in your yaml. -
vlouver_state (Optional): Parameters of vertical louvers state sensor. All settings are the same as for the display_state (see description above). The state of the vertical louvers is encoded by the integer value (see aux_ac.vlouver_set action below).
-
supported_modes (Optional, list): List of supported modes. Possible values are:
HEAT_COOL
,COOL
,HEAT
,DRY
,FAN_ONLY
. Please note: some manufacturers call AUTO mode instead of HEAT_COOL. Defaults toFAN_ONLY
. -
custom_fan_modes (Optional, list): List of supported custom fan modes. Possible values are:
MUTE
,TURBO
. No custom fan modes by default. -
supported_presets (Optional, list): List of supported presets. Possible values are:
SLEEP
. No presets by default. -
custom_presets (Optional, list): List of supported custom presets. Possible values are:
CLEAN
,HEALTH
,ANTIFUNGUS
. No custom presets by default. -
supported_swing_modes (Optional, list): List of supported swing modes. Possible values are:
VERTICAL
,HORIZONTAL
,BOTH
. No swing modes by default. -
All other options from Climate.
This action turns a HVAC temperature display on when executed.
on_...:
then:
- aux_ac.display_on: aux_id
- aux_id (Requared, string): ID of
aux_ac
component.
This action turns a HVAC temperature display off when executed.
on_...:
then:
- aux_ac.display_off: aux_id
- aux_id (Requared, string): ID of
aux_ac
component.
This action moves HVAC vertical louvers to the specified position.
The position is encoded by the following values:
0
: the vertical louvers are inSWING
mode (they are moving up and down);1
: the louvers are stopped in a user position;2
: the louvers are in the topmost position;3
: the louvers are in one step above middle position;4
: the louvers are in the middle position;5
: the louvers are in one step below middle position;6
: the louvers are in the lowest position.
on_...:
then:
- aux_ac.vlouver_set:
id: aux_id
position: 3 # moves the louvers to the middle position
- aux_id (Required, string): ID of
aux_ac
component. - position (Required, integer): position of the vertical louvers.
This action stops vertical swing of louvers.
on_...:
then:
- aux_ac.vlouver_stop: aux_id
- aux_id (Required, string): ID of
aux_ac
component.
This action starts the vertical swing of louvers.
on_...:
then:
- aux_ac.vlouver_swing: aux_id
- aux_id (Required, string): ID of
aux_ac
component.
This action moves HVAC louvers to the topmost position.
on_...:
then:
- aux_ac.vlouver_top: aux_id
- aux_id (Required, string): ID of
aux_ac
component.
This action moves HVAC louvers to the position one step under the topmost.
on_...:
then:
- aux_ac.vlouver_middle_above: aux_id
- aux_id (Required, string): ID of
aux_ac
component.
This action moves HVAC louvers to the middle position.
on_...:
then:
- aux_ac.vlouver_middle: aux_id
- aux_id (Required, string): ID of
aux_ac
component.
This action moves HVAC louvers to the position one step under the middle position.
on_...:
then:
- aux_ac.vlouver_middle_below: aux_id
- aux_id (Required, string): ID of
aux_ac
component.
This action moves HVAC louvers to the lowest position.
on_...:
then:
- aux_ac.vlouver_bottom: aux_id
- aux_id (Required, string): ID of
aux_ac
component.
This action disables inverter HVAC power limitation.
on_...:
then:
- aux_ac.power_limit_off: aux_id
- aux_id (Required, string): ID of
aux_ac
component.
This action enables inverter HVAC power limitation and sets this limit value.
on_...:
then:
- aux_ac.power_limit_on:
id: aux_id
limit: 46 # limits the maximum power of the inverter HVAC at 46%
- aux_id (Required, string): ID of
aux_ac
component. - limit (Optional, integer): the maximum power of the inverter HVAC. If the power limitation is enabled, the inverter HVAC will limits its power.
Notice, that power limitation will affect the efficiency of your HVAC. For example, a low power limit may block the possibility of the conditioner to reach user-specified room temperature, because HVAC will not have enough power for it. Keep this in mind when you are using this function.
Due to hardware limitation this value should be in the range from 30%
to 100%
. The default value for limit
is 30%
(it will be used if limit
is omitted in configuration).
The source code of this example is located in the aux_ac_simple.yaml file.
All settings in it is trivial. Just copy the file to your local folder, specify your Wi-Fi settings and compile YAML with ESPHome.
All sources are located in advanced example folder.
This time we'll configure two relative identical air conditioners with aux_ac
custom component.
Let's imagine we have ACs in a kitchen and in a living room. Air conditioners can be of the same brand or different brands - the main thing is that they are compatible with aux_ac
and can be controlled using aux_ac
.
Because we are lazy, we'll define all common configuration parts for two air conditioners in one ac_common.yaml
file.
All specific parts of configuration are located in the ac_kitchen.yaml
and ac_livingroom.yaml
. Here we set devicename
and upper_devicename
for correct sensors and component naming. And here we specify the correct IP address of the device from secrets.yaml
.
Don't forget to specify wifi_ip_kitchen
, wifi_ota_ip_kitchen
, wifi_ip_livingroom
and wifi_ota_ip_livingroom
in the secrets.yaml
along with the other sensitive information, such as passwords, tokens etc.
If you try to compile ac_common.yaml
it will raise errors. You need to compile ac_kitchen.yaml
or ac_livingroom.yaml
instead.