2020-03-11 16:36:56 +00:00
|
|
|
# esphome-mitsubishiheatpump
|
2020-03-11 17:22:35 +00:00
|
|
|
|
2020-03-11 23:54:51 +00:00
|
|
|
Wirelessly control your Mitsubishi Comfort HVAC equipment with an ESP8266 or
|
|
|
|
ESP32 using the [ESPHome](https://esphome.io) framework.
|
2020-03-11 17:22:35 +00:00
|
|
|
|
|
|
|
## Features
|
|
|
|
* Instant feedback of command changes via RF Remote to HomeAssistant or MQTT.
|
|
|
|
* Direct control without the remote.
|
2020-03-11 23:51:01 +00:00
|
|
|
* Uses the [SwiCago/HeatPump](https://github.com/SwiCago/HeatPump) Arduino
|
|
|
|
libary to talk to the unit directly via the internal `CN105` connector.
|
2020-03-12 06:04:27 +00:00
|
|
|
|
|
|
|
## Requirements
|
2020-03-18 14:44:08 +00:00
|
|
|
* https://github.com/SwiCago/HeatPump
|
2021-05-26 05:50:57 +00:00
|
|
|
* ESPHome 1.18.0 or greater
|
2020-03-11 17:22:35 +00:00
|
|
|
|
2020-03-11 22:32:49 +00:00
|
|
|
## Supported Microcontrollers
|
2020-03-11 23:18:24 +00:00
|
|
|
This library should work on most ESP8266 or ESP32 platforms. It has been tested
|
|
|
|
with the following MCUs:
|
2020-03-11 22:32:49 +00:00
|
|
|
* Generic ESP-01S board (ESP8266)
|
|
|
|
* WeMos D1 Mini (ESP8266)
|
|
|
|
* Generic ESP32 Dev Kit (ESP32)
|
|
|
|
|
|
|
|
## Supported Mitsubishi Climate Units
|
2020-03-11 23:51:01 +00:00
|
|
|
The underlying HeatPump library works with a number of Mitsubishi HVAC
|
|
|
|
units. Basically, if the unit has a `CN105` header on the main board, it should
|
2020-03-11 23:25:00 +00:00
|
|
|
work with this library. The [HeatPump
|
|
|
|
wiki](https://github.com/SwiCago/HeatPump/wiki/Supported-models) has a more
|
2020-03-11 23:18:24 +00:00
|
|
|
exhaustive list.
|
2020-03-11 22:32:49 +00:00
|
|
|
|
2020-03-11 23:54:51 +00:00
|
|
|
The same `CN105` connector is used by the Mitsubishi KumoCloud remotes, which
|
|
|
|
have a
|
2020-03-11 23:51:01 +00:00
|
|
|
[compatibility list](https://www.mitsubishicomfort.com/kumocloud/compatibility)
|
|
|
|
available.
|
|
|
|
|
2020-03-11 22:32:49 +00:00
|
|
|
The whole integration with this libary and the underlying HeatPump has been
|
|
|
|
tested by the author on the following units:
|
2020-03-11 23:25:00 +00:00
|
|
|
* `MSZ-GL06NA`
|
|
|
|
* `MFZ-KA09NA`
|
2020-03-11 22:32:49 +00:00
|
|
|
|
2020-03-11 17:22:35 +00:00
|
|
|
## Usage
|
2020-03-11 23:51:01 +00:00
|
|
|
### Step 1: Build a control circuit.
|
|
|
|
|
|
|
|
Build a control circuit with your MCU as detailed in the [SwiCago/HeatPump
|
|
|
|
README](https://github.com/SwiCago/HeatPump/blob/master/README.md).
|
2020-03-11 22:32:49 +00:00
|
|
|
You can use either an ESP8266 or an ESP32 for this.
|
2020-03-11 17:22:35 +00:00
|
|
|
|
2020-03-11 23:54:51 +00:00
|
|
|
Note: several users have reported that they've been able to get away with
|
2020-03-11 23:51:01 +00:00
|
|
|
not using the pull-up resistors, and just [directly connecting a Wemos D1 mini
|
|
|
|
to the control
|
|
|
|
board](https://github.com/SwiCago/HeatPump/issues/13#issuecomment-457897457)
|
|
|
|
via CN105.
|
|
|
|
|
2021-05-26 05:50:57 +00:00
|
|
|
### Step 2: Use ESPHome 1.18.0 or higher
|
2020-03-12 06:04:27 +00:00
|
|
|
|
2021-05-26 05:50:57 +00:00
|
|
|
The code in this repository makes use of a number of features in the 1.18.0
|
|
|
|
version of ESPHome, including various Fan modes and external components.
|
2020-03-12 06:04:27 +00:00
|
|
|
|
2021-05-26 05:50:57 +00:00
|
|
|
### Step 3: Add this repository as an external component
|
2020-03-11 22:05:47 +00:00
|
|
|
|
2021-05-26 05:50:57 +00:00
|
|
|
Add this repository to your ESPHome config:
|
2020-03-11 22:05:47 +00:00
|
|
|
|
2021-05-26 05:50:57 +00:00
|
|
|
```yaml
|
|
|
|
external_components:
|
|
|
|
- source: github://geoffdavis/esphome-mitsubishiheatpump
|
|
|
|
```
|
|
|
|
|
|
|
|
### Step 4: Configure the heatpump
|
2020-03-11 22:05:47 +00:00
|
|
|
|
2021-05-26 05:50:57 +00:00
|
|
|
Add a `mitsubishi_heatpump` to your ESPHome config:
|
2020-03-11 22:05:47 +00:00
|
|
|
|
2021-05-26 05:50:57 +00:00
|
|
|
```yaml
|
2021-05-26 22:44:07 +00:00
|
|
|
climate:
|
|
|
|
- platform: mitsubishi_heatpump
|
|
|
|
name: "My Heat Pump"
|
2020-03-11 17:22:35 +00:00
|
|
|
|
2021-05-26 22:44:07 +00:00
|
|
|
# Optional
|
|
|
|
hardware_uart: UART0
|
2020-03-11 17:22:35 +00:00
|
|
|
|
2021-05-26 22:44:07 +00:00
|
|
|
# Optional
|
|
|
|
update_period: 500ms
|
2021-05-26 05:50:57 +00:00
|
|
|
```
|
2020-03-11 23:51:01 +00:00
|
|
|
|
2021-05-26 05:50:57 +00:00
|
|
|
On ESP8266 you'll need to disable logging to serial because it conflicts with
|
|
|
|
the heatpump UART:
|
2020-03-11 23:51:01 +00:00
|
|
|
|
|
|
|
```yaml
|
2021-05-26 05:50:57 +00:00
|
|
|
logger:
|
|
|
|
baud_rate: 0
|
2020-03-11 23:51:01 +00:00
|
|
|
```
|
|
|
|
|
2021-05-26 05:50:57 +00:00
|
|
|
On ESP32 you can change `hardware_uart` to `UART1` or `UART2` and keep logging
|
|
|
|
enabled on the main serial port.
|
|
|
|
|
2020-03-11 23:54:51 +00:00
|
|
|
Note: this component DOES NOT use the ESPHome `uart` component, as it requires
|
|
|
|
direct access to a hardware UART via the Arduino `HardwareSerial` class. The
|
|
|
|
Mitsubishi Heatpump units use an atypical serial port setting ("even parity").
|
|
|
|
Parity bit support is not implemented in any of the existing software serial
|
|
|
|
libraries, including the one in ESPHome. There's currently no way to guarantee
|
|
|
|
access to a hardware UART nor retrieve the `HardwareSerial` handle from the
|
|
|
|
`uart` component within the ESPHome framework.
|
|
|
|
|
2020-03-11 23:51:01 +00:00
|
|
|
# Example configuration
|
|
|
|
|
|
|
|
Below is an example configuration which will include wireless strength
|
|
|
|
indicators and permit over the air updates. You'll need to create a
|
|
|
|
`secrets.yaml` file inside of your `esphome` directory with entries for the
|
|
|
|
various items prefixed with `!secret`.
|
|
|
|
|
2020-03-11 17:22:35 +00:00
|
|
|
```yaml
|
|
|
|
esphome:
|
2020-03-11 22:32:49 +00:00
|
|
|
name: denheatpump
|
|
|
|
platform: ESP8266
|
|
|
|
board: esp01_1m
|
|
|
|
# Boards tested: ESP-01S (ESP8266), Wemos D1 Mini (ESP8266); ESP32 Wifi-DevKit2
|
|
|
|
|
|
|
|
wifi:
|
|
|
|
ssid: !secret wifi_ssid
|
|
|
|
password: !secret wifi_password
|
|
|
|
|
|
|
|
# Enable fallback hotspot (captive portal) in case wifi connection fails
|
|
|
|
ap:
|
|
|
|
ssid: "Denheatpump Fallback Hotspot"
|
|
|
|
password: !secret fallback_password
|
|
|
|
|
|
|
|
captive_portal:
|
2020-03-11 17:22:35 +00:00
|
|
|
|
|
|
|
# Enable logging
|
|
|
|
logger:
|
2020-03-11 22:05:47 +00:00
|
|
|
# ESP8266 only - disable serial port logging, as the HeatPump component
|
|
|
|
# needs the sole hardware UART on the ESP8266
|
|
|
|
baud_rate: 0
|
2020-03-11 17:22:35 +00:00
|
|
|
|
2020-03-11 22:32:49 +00:00
|
|
|
# Enable Home Assistant API
|
|
|
|
api:
|
|
|
|
|
|
|
|
ota:
|
|
|
|
|
|
|
|
# Enable Web server.
|
|
|
|
web_server:
|
|
|
|
port: 80
|
|
|
|
|
|
|
|
# Sync time with Home Assistant.
|
|
|
|
time:
|
|
|
|
- platform: homeassistant
|
|
|
|
id: homeassistant_time
|
|
|
|
|
|
|
|
# Text sensors with general information.
|
|
|
|
text_sensor:
|
|
|
|
# Expose ESPHome version as sensor.
|
|
|
|
- platform: version
|
|
|
|
name: denheatpump ESPHome Version
|
|
|
|
# Expose WiFi information as sensors.
|
|
|
|
- platform: wifi_info
|
|
|
|
ip_address:
|
|
|
|
name: denheatpump IP
|
|
|
|
ssid:
|
|
|
|
name: denheatpump SSID
|
|
|
|
bssid:
|
|
|
|
name: denheatpump BSSID
|
|
|
|
|
|
|
|
# Sensors with general information.
|
|
|
|
sensor:
|
|
|
|
# Uptime sensor.
|
|
|
|
- platform: uptime
|
|
|
|
name: denheatpump Uptime
|
|
|
|
|
|
|
|
# WiFi Signal sensor.
|
|
|
|
- platform: wifi_signal
|
|
|
|
name: denheatpump WiFi Signal
|
|
|
|
update_interval: 60s
|
|
|
|
|
2021-05-26 05:50:57 +00:00
|
|
|
external_components:
|
|
|
|
- source: github://geoffdavis/esphome-mitsubishiheatpump
|
|
|
|
|
2021-05-26 22:44:07 +00:00
|
|
|
climate:
|
|
|
|
- platform: mitsubishi_heatpump
|
|
|
|
name: "Den Heat Pump"
|
2020-03-11 22:32:49 +00:00
|
|
|
|
2021-05-26 22:44:07 +00:00
|
|
|
# ESP32 only - change UART0 to UART1 or UART2 and remove the
|
|
|
|
# logging:baud_rate above to allow the built-in UART0 to function for
|
|
|
|
# logging.
|
|
|
|
hardware_uart: UART0
|
2020-03-11 17:22:35 +00:00
|
|
|
```
|
2020-03-11 22:32:49 +00:00
|
|
|
|
2021-05-26 09:51:43 +00:00
|
|
|
# Advanced
|
|
|
|
|
|
|
|
Some models of heat pump require different baud rates or don't support all
|
|
|
|
possible modes of operation. You can configure pretty much everything in YAML
|
|
|
|
to match what your hardware supports. For example:
|
|
|
|
|
|
|
|
```yaml
|
2021-05-26 22:44:07 +00:00
|
|
|
climate:
|
|
|
|
- platform: mitsubishi_heatpump
|
|
|
|
name: "My heat pump"
|
|
|
|
hardware_uart: UART2
|
|
|
|
baud_rate: 9600
|
|
|
|
supports:
|
|
|
|
mode: [AUTO, COOL, HEAT, FAN_ONLY]
|
|
|
|
fan_mode: [AUTO, LOW, MEDIUM, HIGH]
|
|
|
|
swing_mode: [OFF, VERTICAL]
|
|
|
|
visual:
|
|
|
|
min_temperature: 16
|
|
|
|
max_temperature: 31
|
|
|
|
temperature_step: 1.0
|
2021-05-26 09:51:43 +00:00
|
|
|
```
|
|
|
|
|
2020-03-11 22:32:49 +00:00
|
|
|
# See Also
|
|
|
|
|
2020-03-11 23:51:01 +00:00
|
|
|
## Other Implementations
|
2020-03-11 22:32:49 +00:00
|
|
|
The [gysmo38/mitsubishi2MQTT](https://github.com/gysmo38/mitsubishi2MQTT)
|
|
|
|
Arduino sketch also uses the `SwiCago/HeatPump`
|
2020-03-11 23:55:47 +00:00
|
|
|
library, and works with MQTT directly. The author found it's WiFi stack to not
|
|
|
|
be particularly robust, but the controls worked fine. Like this ESPHome
|
2020-03-11 22:32:49 +00:00
|
|
|
repository, it will automatically register the device in your HomeAssistant
|
|
|
|
instance if you have HA configured to do so.
|
|
|
|
|
2020-03-11 23:18:24 +00:00
|
|
|
There's also the built-in to ESPHome
|
|
|
|
[Mitsubishi](https://github.com/esphome/esphome/blob/dev/esphome/components/mitsubishi/mitsubishi.h)
|
2021-04-28 17:35:23 +00:00
|
|
|
climate component.
|
2020-03-11 22:32:49 +00:00
|
|
|
The big drawback with the built-in component is that it uses Infrared Remote
|
|
|
|
commands to talk to the Heat Pump. By contrast, the approach used by this
|
|
|
|
repository and it's underlying `HeatPump` library allows bi-directional
|
|
|
|
communication with the Mitsubishi system, and can detect when someone changes
|
|
|
|
the settings via an IR remote.
|
2020-03-11 23:51:01 +00:00
|
|
|
|
|
|
|
## Reference documentation
|
|
|
|
|
|
|
|
The author referred to the following documentation repeatedly:
|
|
|
|
* https://esphome.io/components/sensor/custom.html
|
|
|
|
* https://esphome.io/components/climate/custom.html
|
|
|
|
* Source for ESPHome's Dev branch: https://github.com/esphome/esphome/tree/dev/esphome/components/climate
|