2020-03-11 18:24:51 +00:00
|
|
|
/**
|
|
|
|
* espmhp.cpp
|
|
|
|
*
|
|
|
|
* Implementation of esphome-mitsubishiheatpump
|
|
|
|
*
|
2020-07-06 16:29:52 +00:00
|
|
|
* Author: Geoff Davis <geoff@geoffdavis.com>
|
2020-06-03 04:13:34 +00:00
|
|
|
* Author: Phil Genera @pgenera on Github.
|
2020-07-06 16:29:52 +00:00
|
|
|
* Author: Barry Loong @loongyh on GitHub.
|
|
|
|
* Author: @am-io on Github.
|
2021-04-28 17:40:29 +00:00
|
|
|
* Author: @nao-pon on Github.
|
2021-05-27 20:38:25 +00:00
|
|
|
* Author: Simon Knopp @sijk on Github
|
2023-04-23 18:11:41 +00:00
|
|
|
* Author: Paul Murphy @donutsoft on GitHub
|
|
|
|
* Last Updated: 2023-04-22
|
2020-03-11 18:24:51 +00:00
|
|
|
* License: BSD
|
|
|
|
*
|
|
|
|
* Requirements:
|
2020-03-18 14:44:08 +00:00
|
|
|
* - https://github.com/SwiCago/HeatPump
|
2021-05-27 20:38:25 +00:00
|
|
|
* - ESPHome 1.18.0 or greater
|
2020-03-11 18:24:51 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
#include "espmhp.h"
|
2020-03-11 21:51:57 +00:00
|
|
|
using namespace esphome;
|
2020-03-11 18:24:51 +00:00
|
|
|
|
2020-03-11 18:49:25 +00:00
|
|
|
/**
|
|
|
|
* Create a new MitsubishiHeatPump object
|
|
|
|
*
|
|
|
|
* Args:
|
|
|
|
* hw_serial: pointer to an Arduino HardwareSerial instance
|
|
|
|
* poll_interval: polling interval in milliseconds
|
|
|
|
*/
|
2020-03-11 21:51:57 +00:00
|
|
|
MitsubishiHeatPump::MitsubishiHeatPump(
|
|
|
|
HardwareSerial* hw_serial,
|
|
|
|
uint32_t poll_interval
|
|
|
|
) :
|
|
|
|
PollingComponent{poll_interval}, // member initializers list
|
|
|
|
hw_serial_{hw_serial}
|
2021-05-26 08:56:57 +00:00
|
|
|
{
|
|
|
|
this->traits_.set_supports_action(true);
|
|
|
|
this->traits_.set_supports_current_temperature(true);
|
|
|
|
this->traits_.set_supports_two_point_target_temperature(false);
|
|
|
|
this->traits_.set_visual_min_temperature(ESPMHP_MIN_TEMPERATURE);
|
|
|
|
this->traits_.set_visual_max_temperature(ESPMHP_MAX_TEMPERATURE);
|
|
|
|
this->traits_.set_visual_temperature_step(ESPMHP_TEMPERATURE_STEP);
|
2023-04-23 18:11:41 +00:00
|
|
|
|
|
|
|
// Assume a succesful connection was made to the ESPHome controller on
|
|
|
|
// launch.
|
|
|
|
this->ping();
|
2021-05-26 08:56:57 +00:00
|
|
|
}
|
2020-03-11 18:49:25 +00:00
|
|
|
|
2020-03-11 18:24:51 +00:00
|
|
|
void MitsubishiHeatPump::check_logger_conflict_() {
|
2020-03-11 21:51:57 +00:00
|
|
|
#ifdef USE_LOGGER
|
|
|
|
if (this->get_hw_serial_() == logger::global_logger->get_hw_serial()) {
|
|
|
|
ESP_LOGW(TAG, " You're using the same serial port for logging"
|
|
|
|
" and the MitsubishiHeatPump component. Please disable"
|
|
|
|
" logging over the serial port by setting"
|
|
|
|
" logger:baud_rate to 0.");
|
|
|
|
}
|
|
|
|
#endif
|
2020-03-11 18:24:51 +00:00
|
|
|
}
|
|
|
|
|
2023-05-11 14:34:41 +00:00
|
|
|
void MitsubishiHeatPump::banner() {
|
|
|
|
ESP_LOGI(TAG, "ESPHome MitsubishiHeatPump version %s",
|
|
|
|
ESPMHP_VERSION);
|
|
|
|
}
|
|
|
|
|
2020-03-11 18:24:51 +00:00
|
|
|
void MitsubishiHeatPump::update() {
|
|
|
|
// This will be called every "update_interval" milliseconds.
|
|
|
|
//this->dump_config();
|
2020-03-11 21:51:57 +00:00
|
|
|
this->hp->sync();
|
|
|
|
#ifndef USE_CALLBACKS
|
|
|
|
this->hpSettingsChanged();
|
|
|
|
heatpumpStatus currentStatus = hp->getStatus();
|
|
|
|
this->hpStatusChanged(currentStatus);
|
|
|
|
#endif
|
2023-04-23 18:11:41 +00:00
|
|
|
this->enforce_remote_temperature_sensor_timeout();
|
2020-03-11 18:24:51 +00:00
|
|
|
}
|
|
|
|
|
2021-05-26 09:20:11 +00:00
|
|
|
void MitsubishiHeatPump::set_baud_rate(int baud) {
|
|
|
|
this->baud_ = baud;
|
|
|
|
}
|
|
|
|
|
2023-02-11 09:35:37 +00:00
|
|
|
void MitsubishiHeatPump::set_rx_pin(int rx_pin) {
|
|
|
|
this->rx_pin_ = rx_pin;
|
|
|
|
}
|
|
|
|
|
|
|
|
void MitsubishiHeatPump::set_tx_pin(int tx_pin) {
|
|
|
|
this->tx_pin_ = tx_pin;
|
|
|
|
}
|
|
|
|
|
2020-03-11 18:24:51 +00:00
|
|
|
/**
|
2021-05-26 08:56:57 +00:00
|
|
|
* Get our supported traits.
|
2020-03-11 18:24:51 +00:00
|
|
|
*
|
|
|
|
* Note:
|
|
|
|
* Many of the following traits are only available in the 1.5.0 dev train of
|
|
|
|
* ESPHome, particularly the Dry operation mode, and several of the fan modes.
|
|
|
|
*
|
|
|
|
* Returns:
|
2020-03-11 21:51:57 +00:00
|
|
|
* This class' supported climate::ClimateTraits.
|
2020-03-11 18:24:51 +00:00
|
|
|
*/
|
|
|
|
climate::ClimateTraits MitsubishiHeatPump::traits() {
|
2021-05-26 08:56:57 +00:00
|
|
|
return traits_;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Modify our supported traits.
|
|
|
|
*
|
|
|
|
* Returns:
|
|
|
|
* A reference to this class' supported climate::ClimateTraits.
|
|
|
|
*/
|
|
|
|
climate::ClimateTraits& MitsubishiHeatPump::config_traits() {
|
|
|
|
return traits_;
|
2020-03-11 18:24:51 +00:00
|
|
|
}
|
|
|
|
|
2023-08-03 13:58:53 +00:00
|
|
|
void MitsubishiHeatPump::update_swing_horizontal(const std::string &swing) {
|
|
|
|
this->horizontal_swing_state_ = swing;
|
|
|
|
|
|
|
|
if (this->horizontal_vane_select_ != nullptr &&
|
|
|
|
this->horizontal_vane_select_->state != this->horizontal_swing_state_) {
|
|
|
|
this->horizontal_vane_select_->publish_state(
|
|
|
|
this->horizontal_swing_state_); // Set current horizontal swing
|
|
|
|
// position
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void MitsubishiHeatPump::update_swing_vertical(const std::string &swing) {
|
|
|
|
this->vertical_swing_state_ = swing;
|
|
|
|
|
|
|
|
if (this->vertical_vane_select_ != nullptr &&
|
|
|
|
this->vertical_vane_select_->state != this->vertical_swing_state_) {
|
|
|
|
this->vertical_vane_select_->publish_state(
|
|
|
|
this->vertical_swing_state_); // Set current vertical swing position
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void MitsubishiHeatPump::set_vertical_vane_select(
|
|
|
|
select::Select *vertical_vane_select) {
|
|
|
|
this->vertical_vane_select_ = vertical_vane_select;
|
|
|
|
this->vertical_vane_select_->add_on_state_callback(
|
|
|
|
[this](const std::string &value, size_t index) {
|
|
|
|
if (value == this->vertical_swing_state_) return;
|
|
|
|
this->on_vertical_swing_change(value);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
void MitsubishiHeatPump::set_horizontal_vane_select(
|
|
|
|
select::Select *horizontal_vane_select) {
|
|
|
|
this->horizontal_vane_select_ = horizontal_vane_select;
|
|
|
|
this->horizontal_vane_select_->add_on_state_callback(
|
|
|
|
[this](const std::string &value, size_t index) {
|
|
|
|
if (value == this->horizontal_swing_state_) return;
|
|
|
|
this->on_horizontal_swing_change(value);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
void MitsubishiHeatPump::on_vertical_swing_change(const std::string &swing) {
|
|
|
|
ESP_LOGD(TAG, "Setting vertical swing position");
|
|
|
|
bool updated = false;
|
|
|
|
|
|
|
|
if (swing == "swing") {
|
|
|
|
hp->setVaneSetting("SWING");
|
|
|
|
updated = true;
|
|
|
|
} else if (swing == "auto") {
|
|
|
|
hp->setVaneSetting("AUTO");
|
|
|
|
updated = true;
|
|
|
|
} else if (swing == "up") {
|
|
|
|
hp->setVaneSetting("1");
|
|
|
|
updated = true;
|
|
|
|
} else if (swing == "up_center") {
|
|
|
|
hp->setVaneSetting("2");
|
|
|
|
updated = true;
|
|
|
|
} else if (swing == "center") {
|
|
|
|
hp->setVaneSetting("3");
|
|
|
|
updated = true;
|
|
|
|
} else if (swing == "down_center") {
|
|
|
|
hp->setVaneSetting("4");
|
|
|
|
updated = true;
|
|
|
|
} else if (swing == "down") {
|
|
|
|
hp->setVaneSetting("5");
|
|
|
|
updated = true;
|
|
|
|
} else {
|
|
|
|
ESP_LOGW(TAG, "Invalid vertical vane position %s", swing);
|
|
|
|
}
|
|
|
|
|
|
|
|
ESP_LOGD(TAG, "Vertical vane - Was HeatPump updated? %s", YESNO(updated));
|
|
|
|
|
|
|
|
// and the heat pump:
|
|
|
|
hp->update();
|
|
|
|
}
|
|
|
|
|
|
|
|
void MitsubishiHeatPump::on_horizontal_swing_change(const std::string &swing) {
|
|
|
|
ESP_LOGD(TAG, "Setting horizontal swing position");
|
|
|
|
bool updated = false;
|
|
|
|
|
|
|
|
if (swing == "swing") {
|
|
|
|
hp->setWideVaneSetting("SWING");
|
|
|
|
updated = true;
|
|
|
|
} else if (swing == "auto") {
|
|
|
|
hp->setWideVaneSetting("<>");
|
|
|
|
updated = true;
|
|
|
|
} else if (swing == "left") {
|
|
|
|
hp->setWideVaneSetting("<<");
|
|
|
|
updated = true;
|
|
|
|
} else if (swing == "left_center") {
|
|
|
|
hp->setWideVaneSetting("<");
|
|
|
|
updated = true;
|
|
|
|
} else if (swing == "center") {
|
|
|
|
hp->setWideVaneSetting("|");
|
|
|
|
updated = true;
|
|
|
|
} else if (swing == "right_center") {
|
|
|
|
hp->setWideVaneSetting(">");
|
|
|
|
updated = true;
|
|
|
|
} else if (swing == "right") {
|
|
|
|
hp->setWideVaneSetting(">>");
|
|
|
|
updated = true;
|
|
|
|
} else {
|
|
|
|
ESP_LOGW(TAG, "Invalid horizontal vane position %s", swing);
|
|
|
|
}
|
|
|
|
|
|
|
|
ESP_LOGD(TAG, "Horizontal vane - Was HeatPump updated? %s", YESNO(updated));
|
|
|
|
|
|
|
|
// and the heat pump:
|
|
|
|
hp->update();
|
|
|
|
}
|
|
|
|
|
2020-03-11 18:24:51 +00:00
|
|
|
/**
|
|
|
|
* Implement control of a MitsubishiHeatPump.
|
|
|
|
*
|
|
|
|
* Maps HomeAssistant/ESPHome modes to Mitsubishi modes.
|
|
|
|
*/
|
|
|
|
void MitsubishiHeatPump::control(const climate::ClimateCall &call) {
|
|
|
|
ESP_LOGV(TAG, "Control called.");
|
|
|
|
|
|
|
|
bool updated = false;
|
2020-09-08 08:48:49 +00:00
|
|
|
bool has_mode = call.get_mode().has_value();
|
2020-06-05 00:26:56 +00:00
|
|
|
bool has_temp = call.get_target_temperature().has_value();
|
2020-09-08 08:48:49 +00:00
|
|
|
if (has_mode){
|
2020-05-30 01:46:32 +00:00
|
|
|
this->mode = *call.get_mode();
|
2020-09-08 08:48:49 +00:00
|
|
|
}
|
2023-04-23 18:11:41 +00:00
|
|
|
|
|
|
|
if (last_remote_temperature_sensor_update_.has_value()) {
|
|
|
|
// Some remote temperature sensors will only issue updates when a change
|
|
|
|
// in temperature occurs.
|
|
|
|
|
|
|
|
// Assume a case where the idle sensor timeout is 12hrs and operating
|
|
|
|
// timeout is 1hr. If the user changes the HP setpoint after 1.5hrs, the
|
|
|
|
// machine will switch to operating mode, the remote temperature
|
|
|
|
// reading will expire and the HP will revert to it's internal
|
|
|
|
// temperature sensor.
|
|
|
|
|
|
|
|
// This change ensures that if the user changes the machine setpoint,
|
|
|
|
// the remote sensor has an opportunity to issue an update to reflect
|
|
|
|
// the new change in temperature.
|
|
|
|
last_remote_temperature_sensor_update_ =
|
|
|
|
std::chrono::steady_clock::now();
|
|
|
|
}
|
|
|
|
|
2020-09-08 08:48:49 +00:00
|
|
|
switch (this->mode) {
|
|
|
|
case climate::CLIMATE_MODE_COOL:
|
|
|
|
hp->setModeSetting("COOL");
|
|
|
|
hp->setPowerSetting("ON");
|
2020-07-06 05:02:04 +00:00
|
|
|
|
2020-09-08 08:48:49 +00:00
|
|
|
if (has_mode){
|
2020-06-05 00:26:56 +00:00
|
|
|
if (cool_setpoint.has_value() && !has_temp) {
|
|
|
|
hp->setTemperature(cool_setpoint.value());
|
|
|
|
this->target_temperature = cool_setpoint.value();
|
|
|
|
}
|
2020-06-06 13:40:54 +00:00
|
|
|
this->action = climate::CLIMATE_ACTION_IDLE;
|
2020-03-11 18:24:51 +00:00
|
|
|
updated = true;
|
2020-09-08 08:48:49 +00:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
case climate::CLIMATE_MODE_HEAT:
|
|
|
|
hp->setModeSetting("HEAT");
|
|
|
|
hp->setPowerSetting("ON");
|
|
|
|
if (has_mode){
|
2020-06-05 00:26:56 +00:00
|
|
|
if (heat_setpoint.has_value() && !has_temp) {
|
|
|
|
hp->setTemperature(heat_setpoint.value());
|
|
|
|
this->target_temperature = heat_setpoint.value();
|
|
|
|
}
|
2020-06-06 13:40:54 +00:00
|
|
|
this->action = climate::CLIMATE_ACTION_IDLE;
|
2020-03-11 18:24:51 +00:00
|
|
|
updated = true;
|
2020-09-08 08:48:49 +00:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
case climate::CLIMATE_MODE_DRY:
|
|
|
|
hp->setModeSetting("DRY");
|
|
|
|
hp->setPowerSetting("ON");
|
|
|
|
if (has_mode){
|
2020-06-06 13:17:40 +00:00
|
|
|
this->action = climate::CLIMATE_ACTION_DRYING;
|
2020-03-11 18:24:51 +00:00
|
|
|
updated = true;
|
2020-09-08 08:48:49 +00:00
|
|
|
}
|
|
|
|
break;
|
2021-06-21 04:28:38 +00:00
|
|
|
case climate::CLIMATE_MODE_HEAT_COOL:
|
2020-09-08 08:48:49 +00:00
|
|
|
hp->setModeSetting("AUTO");
|
|
|
|
hp->setPowerSetting("ON");
|
|
|
|
if (has_mode){
|
2020-06-05 00:26:56 +00:00
|
|
|
if (auto_setpoint.has_value() && !has_temp) {
|
|
|
|
hp->setTemperature(auto_setpoint.value());
|
|
|
|
this->target_temperature = auto_setpoint.value();
|
|
|
|
}
|
2020-06-06 13:40:54 +00:00
|
|
|
this->action = climate::CLIMATE_ACTION_IDLE;
|
2020-09-08 08:48:49 +00:00
|
|
|
}
|
|
|
|
updated = true;
|
|
|
|
break;
|
|
|
|
case climate::CLIMATE_MODE_FAN_ONLY:
|
|
|
|
hp->setModeSetting("FAN");
|
|
|
|
hp->setPowerSetting("ON");
|
|
|
|
if (has_mode){
|
2020-06-06 12:48:10 +00:00
|
|
|
this->action = climate::CLIMATE_ACTION_FAN;
|
2020-03-11 18:24:51 +00:00
|
|
|
updated = true;
|
2020-09-08 08:48:49 +00:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
case climate::CLIMATE_MODE_OFF:
|
|
|
|
default:
|
|
|
|
if (has_mode){
|
2020-03-11 18:24:51 +00:00
|
|
|
hp->setPowerSetting("OFF");
|
2020-06-06 15:41:28 +00:00
|
|
|
this->action = climate::CLIMATE_ACTION_OFF;
|
2020-03-11 18:24:51 +00:00
|
|
|
updated = true;
|
2020-09-08 08:48:49 +00:00
|
|
|
}
|
|
|
|
break;
|
2020-03-11 18:24:51 +00:00
|
|
|
}
|
|
|
|
|
2020-06-05 00:26:56 +00:00
|
|
|
if (has_temp){
|
2020-03-11 21:51:57 +00:00
|
|
|
ESP_LOGV(
|
|
|
|
"control", "Sending target temp: %.1f",
|
|
|
|
*call.get_target_temperature()
|
2020-06-05 00:26:56 +00:00
|
|
|
);
|
2020-03-11 18:24:51 +00:00
|
|
|
hp->setTemperature(*call.get_target_temperature());
|
2020-05-30 01:46:32 +00:00
|
|
|
this->target_temperature = *call.get_target_temperature();
|
2020-03-11 18:24:51 +00:00
|
|
|
updated = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
//const char* FAN_MAP[6] = {"AUTO", "QUIET", "1", "2", "3", "4"};
|
|
|
|
if (call.get_fan_mode().has_value()) {
|
2023-07-20 17:04:10 +00:00
|
|
|
ESP_LOGV("control", "Requested fan mode is %d", *call.get_fan_mode());
|
2020-05-30 01:46:32 +00:00
|
|
|
this->fan_mode = *call.get_fan_mode();
|
2020-03-11 18:24:51 +00:00
|
|
|
switch(*call.get_fan_mode()) {
|
|
|
|
case climate::CLIMATE_FAN_OFF:
|
|
|
|
hp->setPowerSetting("OFF");
|
|
|
|
updated = true;
|
|
|
|
break;
|
|
|
|
case climate::CLIMATE_FAN_DIFFUSE:
|
2020-06-28 04:33:39 +00:00
|
|
|
hp->setFanSpeed("QUIET");
|
2020-03-11 18:24:51 +00:00
|
|
|
updated = true;
|
|
|
|
break;
|
|
|
|
case climate::CLIMATE_FAN_LOW:
|
2020-06-28 04:33:39 +00:00
|
|
|
hp->setFanSpeed("1");
|
2020-03-11 18:24:51 +00:00
|
|
|
updated = true;
|
|
|
|
break;
|
|
|
|
case climate::CLIMATE_FAN_MEDIUM:
|
2020-06-28 04:33:39 +00:00
|
|
|
hp->setFanSpeed("2");
|
2020-03-11 18:24:51 +00:00
|
|
|
updated = true;
|
|
|
|
break;
|
|
|
|
case climate::CLIMATE_FAN_MIDDLE:
|
2020-06-28 04:33:39 +00:00
|
|
|
hp->setFanSpeed("3");
|
2020-03-11 18:24:51 +00:00
|
|
|
updated = true;
|
|
|
|
break;
|
|
|
|
case climate::CLIMATE_FAN_HIGH:
|
2020-06-28 04:33:39 +00:00
|
|
|
hp->setFanSpeed("4");
|
2020-03-11 18:24:51 +00:00
|
|
|
updated = true;
|
|
|
|
break;
|
|
|
|
case climate::CLIMATE_FAN_ON:
|
|
|
|
case climate::CLIMATE_FAN_AUTO:
|
|
|
|
default:
|
|
|
|
hp->setFanSpeed("AUTO");
|
|
|
|
updated = true;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//const char* VANE_MAP[7] = {"AUTO", "1", "2", "3", "4", "5", "SWING"};
|
|
|
|
if (call.get_swing_mode().has_value()) {
|
2023-07-20 17:04:10 +00:00
|
|
|
ESP_LOGD(TAG, "control - requested swing mode is %d",
|
2020-03-11 18:24:51 +00:00
|
|
|
*call.get_swing_mode());
|
|
|
|
|
2020-05-30 01:46:32 +00:00
|
|
|
this->swing_mode = *call.get_swing_mode();
|
2020-03-11 18:24:51 +00:00
|
|
|
switch(*call.get_swing_mode()) {
|
|
|
|
case climate::CLIMATE_SWING_OFF:
|
|
|
|
hp->setVaneSetting("AUTO");
|
2023-08-03 13:58:53 +00:00
|
|
|
hp->setWideVaneSetting("|");
|
2020-03-11 18:24:51 +00:00
|
|
|
updated = true;
|
|
|
|
break;
|
|
|
|
case climate::CLIMATE_SWING_VERTICAL:
|
|
|
|
hp->setVaneSetting("SWING");
|
2023-08-03 13:58:53 +00:00
|
|
|
hp->setWideVaneSetting("|");
|
|
|
|
updated = true;
|
|
|
|
break;
|
|
|
|
case climate::CLIMATE_SWING_HORIZONTAL:
|
|
|
|
hp->setVaneSetting("3");
|
|
|
|
hp->setWideVaneSetting("SWING");
|
|
|
|
updated = true;
|
|
|
|
break;
|
|
|
|
case climate::CLIMATE_SWING_BOTH:
|
|
|
|
hp->setVaneSetting("SWING");
|
|
|
|
hp->setWideVaneSetting("SWING");
|
2020-03-11 18:24:51 +00:00
|
|
|
updated = true;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
ESP_LOGW(TAG, "control - received unsupported swing mode request.");
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
ESP_LOGD(TAG, "control - Was HeatPump updated? %s", YESNO(updated));
|
2020-05-31 00:26:07 +00:00
|
|
|
|
2020-05-30 01:46:32 +00:00
|
|
|
// send the update back to esphome:
|
|
|
|
this->publish_state();
|
|
|
|
// and the heat pump:
|
2020-03-11 18:24:51 +00:00
|
|
|
hp->update();
|
|
|
|
}
|
|
|
|
|
|
|
|
void MitsubishiHeatPump::hpSettingsChanged() {
|
|
|
|
heatpumpSettings currentSettings = hp->getSettings();
|
|
|
|
|
|
|
|
if (currentSettings.power == NULL) {
|
|
|
|
/*
|
|
|
|
* We should always get a valid pointer here once the HeatPump
|
|
|
|
* component fully initializes. If HeatPump hasn't read the settings
|
|
|
|
* from the unit yet (hp->connect() doesn't do this, sadly), we'll need
|
|
|
|
* to punt on the update. Likely not an issue when run in callback
|
|
|
|
* mode, but that isn't working right yet.
|
|
|
|
*/
|
|
|
|
ESP_LOGW(TAG, "Waiting for HeatPump to read the settings the first time.");
|
2021-10-23 18:07:38 +00:00
|
|
|
esphome::delay(10);
|
2020-03-11 18:24:51 +00:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* ************ HANDLE POWER AND MODE CHANGES ***********
|
|
|
|
* https://github.com/geoffdavis/HeatPump/blob/stream/src/HeatPump.h#L125
|
|
|
|
* const char* POWER_MAP[2] = {"OFF", "ON"};
|
|
|
|
* const char* MODE_MAP[5] = {"HEAT", "DRY", "COOL", "FAN", "AUTO"};
|
|
|
|
*/
|
|
|
|
if (strcmp(currentSettings.power, "ON") == 0) {
|
|
|
|
if (strcmp(currentSettings.mode, "HEAT") == 0) {
|
2020-03-11 21:51:57 +00:00
|
|
|
this->mode = climate::CLIMATE_MODE_HEAT;
|
2020-06-05 00:26:56 +00:00
|
|
|
if (heat_setpoint != currentSettings.temperature) {
|
|
|
|
heat_setpoint = currentSettings.temperature;
|
|
|
|
save(currentSettings.temperature, heat_storage);
|
|
|
|
}
|
2020-06-06 13:40:54 +00:00
|
|
|
this->action = climate::CLIMATE_ACTION_IDLE;
|
2020-03-11 18:24:51 +00:00
|
|
|
} else if (strcmp(currentSettings.mode, "DRY") == 0) {
|
2020-03-11 21:51:57 +00:00
|
|
|
this->mode = climate::CLIMATE_MODE_DRY;
|
2020-06-06 13:17:40 +00:00
|
|
|
this->action = climate::CLIMATE_ACTION_DRYING;
|
2020-03-11 18:24:51 +00:00
|
|
|
} else if (strcmp(currentSettings.mode, "COOL") == 0) {
|
2020-03-11 21:51:57 +00:00
|
|
|
this->mode = climate::CLIMATE_MODE_COOL;
|
2020-06-05 00:26:56 +00:00
|
|
|
if (cool_setpoint != currentSettings.temperature) {
|
|
|
|
cool_setpoint = currentSettings.temperature;
|
|
|
|
save(currentSettings.temperature, cool_storage);
|
|
|
|
}
|
2020-06-06 13:40:54 +00:00
|
|
|
this->action = climate::CLIMATE_ACTION_IDLE;
|
2020-03-11 18:24:51 +00:00
|
|
|
} else if (strcmp(currentSettings.mode, "FAN") == 0) {
|
2020-03-11 21:51:57 +00:00
|
|
|
this->mode = climate::CLIMATE_MODE_FAN_ONLY;
|
2020-06-06 12:54:39 +00:00
|
|
|
this->action = climate::CLIMATE_ACTION_FAN;
|
2020-03-11 18:24:51 +00:00
|
|
|
} else if (strcmp(currentSettings.mode, "AUTO") == 0) {
|
2021-06-21 04:28:38 +00:00
|
|
|
this->mode = climate::CLIMATE_MODE_HEAT_COOL;
|
2020-06-05 00:26:56 +00:00
|
|
|
if (auto_setpoint != currentSettings.temperature) {
|
|
|
|
auto_setpoint = currentSettings.temperature;
|
|
|
|
save(currentSettings.temperature, auto_storage);
|
|
|
|
}
|
2020-06-06 13:40:54 +00:00
|
|
|
this->action = climate::CLIMATE_ACTION_IDLE;
|
2020-03-11 18:24:51 +00:00
|
|
|
} else {
|
|
|
|
ESP_LOGW(
|
|
|
|
TAG,
|
|
|
|
"Unknown climate mode value %s received from HeatPump",
|
|
|
|
currentSettings.mode
|
|
|
|
);
|
|
|
|
}
|
|
|
|
} else {
|
2020-03-11 21:51:57 +00:00
|
|
|
this->mode = climate::CLIMATE_MODE_OFF;
|
2020-06-06 15:41:28 +00:00
|
|
|
this->action = climate::CLIMATE_ACTION_OFF;
|
2020-03-11 18:24:51 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
ESP_LOGI(TAG, "Climate mode is: %i", this->mode);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* ******* HANDLE FAN CHANGES ********
|
|
|
|
*
|
|
|
|
* const char* FAN_MAP[6] = {"AUTO", "QUIET", "1", "2", "3", "4"};
|
|
|
|
*/
|
|
|
|
if (strcmp(currentSettings.fan, "QUIET") == 0) {
|
2020-03-11 21:51:57 +00:00
|
|
|
this->fan_mode = climate::CLIMATE_FAN_DIFFUSE;
|
2020-03-11 18:24:51 +00:00
|
|
|
} else if (strcmp(currentSettings.fan, "1") == 0) {
|
2020-03-11 21:51:57 +00:00
|
|
|
this->fan_mode = climate::CLIMATE_FAN_LOW;
|
2020-03-11 18:24:51 +00:00
|
|
|
} else if (strcmp(currentSettings.fan, "2") == 0) {
|
2020-03-11 21:51:57 +00:00
|
|
|
this->fan_mode = climate::CLIMATE_FAN_MEDIUM;
|
2020-03-11 18:24:51 +00:00
|
|
|
} else if (strcmp(currentSettings.fan, "3") == 0) {
|
2020-03-11 21:51:57 +00:00
|
|
|
this->fan_mode = climate::CLIMATE_FAN_MIDDLE;
|
2020-03-11 18:24:51 +00:00
|
|
|
} else if (strcmp(currentSettings.fan, "4") == 0) {
|
2020-03-11 21:51:57 +00:00
|
|
|
this->fan_mode = climate::CLIMATE_FAN_HIGH;
|
2020-03-11 18:24:51 +00:00
|
|
|
} else { //case "AUTO" or default:
|
2020-03-11 21:51:57 +00:00
|
|
|
this->fan_mode = climate::CLIMATE_FAN_AUTO;
|
2020-03-11 18:24:51 +00:00
|
|
|
}
|
2023-07-14 20:51:28 +00:00
|
|
|
ESP_LOGI(TAG, "Fan mode is: %i", this->fan_mode.value_or(-1));
|
2020-03-11 18:24:51 +00:00
|
|
|
|
|
|
|
/* ******** HANDLE MITSUBISHI VANE CHANGES ********
|
|
|
|
* const char* VANE_MAP[7] = {"AUTO", "1", "2", "3", "4", "5", "SWING"};
|
|
|
|
*/
|
2023-08-03 13:58:53 +00:00
|
|
|
if (strcmp(currentSettings.vane, "SWING") == 0 &&
|
|
|
|
strcmp(currentSettings.wideVane, "SWING") == 0) {
|
|
|
|
this->swing_mode = climate::CLIMATE_SWING_BOTH;
|
|
|
|
} else if (strcmp(currentSettings.vane, "SWING") == 0) {
|
2020-03-11 21:51:57 +00:00
|
|
|
this->swing_mode = climate::CLIMATE_SWING_VERTICAL;
|
2023-08-03 13:58:53 +00:00
|
|
|
} else if (strcmp(currentSettings.wideVane, "SWING") == 0) {
|
|
|
|
this->swing_mode = climate::CLIMATE_SWING_HORIZONTAL;
|
|
|
|
} else {
|
2020-03-11 21:51:57 +00:00
|
|
|
this->swing_mode = climate::CLIMATE_SWING_OFF;
|
2020-03-11 18:24:51 +00:00
|
|
|
}
|
|
|
|
ESP_LOGI(TAG, "Swing mode is: %i", this->swing_mode);
|
2023-08-03 13:58:53 +00:00
|
|
|
if (strcmp(currentSettings.vane, "SWING") == 0) {
|
|
|
|
this->update_swing_vertical("swing");
|
|
|
|
} else if (strcmp(currentSettings.vane, "AUTO") == 0) {
|
|
|
|
this->update_swing_vertical("auto");
|
|
|
|
} else if (strcmp(currentSettings.vane, "1") == 0) {
|
|
|
|
this->update_swing_vertical("up");
|
|
|
|
} else if (strcmp(currentSettings.vane, "2") == 0) {
|
|
|
|
this->update_swing_vertical("up_center");
|
|
|
|
} else if (strcmp(currentSettings.vane, "3") == 0) {
|
|
|
|
this->update_swing_vertical("center");
|
|
|
|
} else if (strcmp(currentSettings.vane, "4") == 0) {
|
|
|
|
this->update_swing_vertical("down_center");
|
|
|
|
} else if (strcmp(currentSettings.vane, "5") == 0) {
|
|
|
|
this->update_swing_vertical("down");
|
|
|
|
}
|
2020-03-11 18:24:51 +00:00
|
|
|
|
2023-08-03 13:58:53 +00:00
|
|
|
ESP_LOGI(TAG, "Vertical vane mode is: %s", currentSettings.vane);
|
|
|
|
|
|
|
|
if (strcmp(currentSettings.wideVane, "SWING") == 0) {
|
|
|
|
this->update_swing_horizontal("swing");
|
|
|
|
} else if (strcmp(currentSettings.wideVane, "<>") == 0) {
|
|
|
|
this->update_swing_horizontal("auto");
|
|
|
|
} else if (strcmp(currentSettings.wideVane, "<<") == 0) {
|
|
|
|
this->update_swing_horizontal("left");
|
|
|
|
} else if (strcmp(currentSettings.wideVane, "<") == 0) {
|
|
|
|
this->update_swing_horizontal("left_center");
|
|
|
|
} else if (strcmp(currentSettings.wideVane, "|") == 0) {
|
|
|
|
this->update_swing_horizontal("center");
|
|
|
|
} else if (strcmp(currentSettings.wideVane, ">") == 0) {
|
|
|
|
this->update_swing_horizontal("right_center");
|
|
|
|
} else if (strcmp(currentSettings.wideVane, ">>") == 0) {
|
|
|
|
this->update_swing_horizontal("right");
|
|
|
|
}
|
2020-03-11 18:24:51 +00:00
|
|
|
|
2023-08-03 13:58:53 +00:00
|
|
|
ESP_LOGI(TAG, "Horizontal vane mode is: %s", currentSettings.wideVane);
|
2020-03-11 18:24:51 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* ******** HANDLE TARGET TEMPERATURE CHANGES ********
|
|
|
|
*/
|
|
|
|
this->target_temperature = currentSettings.temperature;
|
|
|
|
ESP_LOGI(TAG, "Target temp is: %f", this->target_temperature);
|
|
|
|
|
2020-05-30 01:46:32 +00:00
|
|
|
/*
|
2020-06-06 12:11:19 +00:00
|
|
|
* ******** Publish state back to ESPHome. ********
|
2020-05-30 01:46:32 +00:00
|
|
|
*/
|
2020-06-06 12:11:19 +00:00
|
|
|
this->publish_state();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Report changes in the current temperature sensed by the HeatPump.
|
|
|
|
*/
|
|
|
|
void MitsubishiHeatPump::hpStatusChanged(heatpumpStatus currentStatus) {
|
|
|
|
this->current_temperature = currentStatus.roomTemperature;
|
2020-05-31 00:26:07 +00:00
|
|
|
switch (this->mode) {
|
2020-06-01 00:00:11 +00:00
|
|
|
case climate::CLIMATE_MODE_HEAT:
|
2020-06-06 12:11:19 +00:00
|
|
|
if (currentStatus.operating) {
|
2020-06-01 00:00:11 +00:00
|
|
|
this->action = climate::CLIMATE_ACTION_HEATING;
|
|
|
|
}
|
2020-06-03 03:30:53 +00:00
|
|
|
else {
|
|
|
|
this->action = climate::CLIMATE_ACTION_IDLE;
|
|
|
|
}
|
2020-06-01 00:00:11 +00:00
|
|
|
break;
|
|
|
|
case climate::CLIMATE_MODE_COOL:
|
2020-06-06 12:11:19 +00:00
|
|
|
if (currentStatus.operating) {
|
2020-06-01 00:00:11 +00:00
|
|
|
this->action = climate::CLIMATE_ACTION_COOLING;
|
|
|
|
}
|
2020-06-03 03:30:53 +00:00
|
|
|
else {
|
|
|
|
this->action = climate::CLIMATE_ACTION_IDLE;
|
|
|
|
}
|
2020-06-01 00:00:11 +00:00
|
|
|
break;
|
2021-06-21 04:28:38 +00:00
|
|
|
case climate::CLIMATE_MODE_HEAT_COOL:
|
2020-06-06 13:40:54 +00:00
|
|
|
this->action = climate::CLIMATE_ACTION_IDLE;
|
|
|
|
if (currentStatus.operating) {
|
|
|
|
if (this->current_temperature > this->target_temperature) {
|
|
|
|
this->action = climate::CLIMATE_ACTION_COOLING;
|
|
|
|
} else if (this->current_temperature < this->target_temperature) {
|
|
|
|
this->action = climate::CLIMATE_ACTION_HEATING;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
2020-06-03 03:30:53 +00:00
|
|
|
case climate::CLIMATE_MODE_DRY:
|
2020-06-06 12:11:19 +00:00
|
|
|
if (currentStatus.operating) {
|
2020-06-06 13:17:40 +00:00
|
|
|
this->action = climate::CLIMATE_ACTION_DRYING;
|
2020-06-06 12:11:19 +00:00
|
|
|
}
|
|
|
|
else {
|
|
|
|
this->action = climate::CLIMATE_ACTION_IDLE;
|
|
|
|
}
|
2020-06-06 13:17:40 +00:00
|
|
|
break;
|
2020-06-06 12:11:19 +00:00
|
|
|
case climate::CLIMATE_MODE_FAN_ONLY:
|
|
|
|
this->action = climate::CLIMATE_ACTION_FAN;
|
2020-06-06 13:17:40 +00:00
|
|
|
break;
|
2020-06-01 00:55:06 +00:00
|
|
|
default:
|
|
|
|
this->action = climate::CLIMATE_ACTION_OFF;
|
2020-05-30 01:46:32 +00:00
|
|
|
}
|
|
|
|
|
2023-04-23 18:11:41 +00:00
|
|
|
this->operating_ = currentStatus.operating;
|
|
|
|
|
2020-03-11 18:24:51 +00:00
|
|
|
this->publish_state();
|
|
|
|
}
|
|
|
|
|
2021-05-27 22:53:19 +00:00
|
|
|
void MitsubishiHeatPump::set_remote_temperature(float temp) {
|
|
|
|
ESP_LOGD(TAG, "Setting remote temp: %.1f", temp);
|
2023-04-23 18:11:41 +00:00
|
|
|
if (temp > 0) {
|
|
|
|
last_remote_temperature_sensor_update_ =
|
|
|
|
std::chrono::steady_clock::now();
|
|
|
|
} else {
|
|
|
|
last_remote_temperature_sensor_update_.reset();
|
|
|
|
}
|
|
|
|
|
2021-05-27 22:53:19 +00:00
|
|
|
this->hp->setRemoteTemperature(temp);
|
|
|
|
}
|
|
|
|
|
2023-04-23 18:11:41 +00:00
|
|
|
void MitsubishiHeatPump::ping() {
|
|
|
|
ESP_LOGD(TAG, "Ping request received");
|
|
|
|
last_ping_request_ = std::chrono::steady_clock::now();
|
|
|
|
}
|
|
|
|
|
|
|
|
void MitsubishiHeatPump::set_remote_operating_timeout_minutes(int minutes) {
|
|
|
|
ESP_LOGD(TAG, "Setting remote operating timeout time: %d minutes", minutes);
|
|
|
|
remote_operating_timeout_ = std::chrono::minutes(minutes);
|
|
|
|
}
|
|
|
|
|
|
|
|
void MitsubishiHeatPump::set_remote_idle_timeout_minutes(int minutes) {
|
|
|
|
ESP_LOGD(TAG, "Setting remote idle timeout time: %d minutes", minutes);
|
|
|
|
remote_idle_timeout_ = std::chrono::minutes(minutes);
|
|
|
|
}
|
|
|
|
|
|
|
|
void MitsubishiHeatPump::set_remote_ping_timeout_minutes(int minutes) {
|
|
|
|
ESP_LOGD(TAG, "Setting remote ping timeout time: %d minutes", minutes);
|
|
|
|
remote_ping_timeout_ = std::chrono::minutes(minutes);
|
|
|
|
}
|
|
|
|
|
|
|
|
void MitsubishiHeatPump::enforce_remote_temperature_sensor_timeout() {
|
2023-10-13 19:48:35 +00:00
|
|
|
// Handle ping timeouts.
|
2023-04-23 18:11:41 +00:00
|
|
|
if (remote_ping_timeout_.has_value() && last_ping_request_.has_value()) {
|
2023-10-13 19:48:35 +00:00
|
|
|
auto time_since_last_ping =
|
2023-04-23 18:11:41 +00:00
|
|
|
std::chrono::steady_clock::now() - last_ping_request_.value();
|
|
|
|
if(time_since_last_ping > remote_ping_timeout_.value()) {
|
|
|
|
ESP_LOGW(TAG, "Ping timeout.");
|
|
|
|
this->set_remote_temperature(0);
|
|
|
|
last_ping_request_.reset();
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Handle set_remote_temperature timeouts.
|
2023-10-13 19:48:35 +00:00
|
|
|
auto remote_set_temperature_timeout =
|
2023-04-23 18:11:41 +00:00
|
|
|
this->operating_ ? remote_operating_timeout_ : remote_idle_timeout_;
|
2023-10-13 19:48:35 +00:00
|
|
|
if (remote_set_temperature_timeout.has_value() &&
|
2023-04-23 18:11:41 +00:00
|
|
|
last_remote_temperature_sensor_update_.has_value()) {
|
2023-10-13 19:48:35 +00:00
|
|
|
auto time_since_last_temperature_update =
|
2023-04-23 18:11:41 +00:00
|
|
|
std::chrono::steady_clock::now() - last_remote_temperature_sensor_update_.value();
|
|
|
|
if (time_since_last_temperature_update > remote_set_temperature_timeout.value()) {
|
|
|
|
ESP_LOGW(TAG, "Set remote temperature timeout, operating=%d", this->operating_);
|
|
|
|
this->set_remote_temperature(0);
|
2023-10-13 19:48:35 +00:00
|
|
|
return;
|
2023-04-23 18:11:41 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-03-11 18:24:51 +00:00
|
|
|
void MitsubishiHeatPump::setup() {
|
|
|
|
// This will be called by App.setup()
|
|
|
|
this->banner();
|
|
|
|
ESP_LOGCONFIG(TAG, "Setting up UART...");
|
|
|
|
if (!this->get_hw_serial_()) {
|
|
|
|
ESP_LOGCONFIG(
|
|
|
|
TAG,
|
|
|
|
"No HardwareSerial was provided. "
|
|
|
|
"Software serial ports are unsupported by this component."
|
|
|
|
);
|
|
|
|
this->mark_failed();
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
this->check_logger_conflict_();
|
|
|
|
|
|
|
|
ESP_LOGCONFIG(TAG, "Intializing new HeatPump object.");
|
|
|
|
this->hp = new HeatPump();
|
2021-06-12 01:19:02 +00:00
|
|
|
this->current_temperature = NAN;
|
|
|
|
this->target_temperature = NAN;
|
|
|
|
this->fan_mode = climate::CLIMATE_FAN_OFF;
|
|
|
|
this->swing_mode = climate::CLIMATE_SWING_OFF;
|
2023-08-03 13:58:53 +00:00
|
|
|
this->vertical_swing_state_ = "auto";
|
|
|
|
this->horizontal_swing_state_ = "auto";
|
2020-03-11 18:24:51 +00:00
|
|
|
|
2020-03-11 21:51:57 +00:00
|
|
|
#ifdef USE_CALLBACKS
|
2020-03-11 18:24:51 +00:00
|
|
|
hp->setSettingsChangedCallback(
|
|
|
|
[this]() {
|
|
|
|
this->hpSettingsChanged();
|
|
|
|
}
|
|
|
|
);
|
|
|
|
|
|
|
|
hp->setStatusChangedCallback(
|
|
|
|
[this](heatpumpStatus currentStatus) {
|
|
|
|
this->hpStatusChanged(currentStatus);
|
|
|
|
}
|
|
|
|
);
|
2020-03-11 21:51:57 +00:00
|
|
|
#endif
|
2020-03-11 18:24:51 +00:00
|
|
|
|
|
|
|
ESP_LOGCONFIG(
|
|
|
|
TAG,
|
|
|
|
"hw_serial(%p) is &Serial(%p)? %s",
|
|
|
|
this->get_hw_serial_(),
|
|
|
|
&Serial,
|
2023-01-21 18:22:04 +00:00
|
|
|
YESNO((void *)this->get_hw_serial_() == (void *)&Serial)
|
2020-03-11 18:24:51 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
ESP_LOGCONFIG(TAG, "Calling hp->connect(%p)", this->get_hw_serial_());
|
2023-02-11 09:35:37 +00:00
|
|
|
if (hp->connect(this->get_hw_serial_(), this->baud_, this->rx_pin_, this->tx_pin_)) {
|
2020-03-11 18:24:51 +00:00
|
|
|
hp->sync();
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
ESP_LOGCONFIG(
|
|
|
|
TAG,
|
|
|
|
"Connection to HeatPump failed."
|
|
|
|
" Marking MitsubishiHeatPump component as failed."
|
|
|
|
);
|
|
|
|
this->mark_failed();
|
|
|
|
}
|
|
|
|
|
2020-06-05 00:26:56 +00:00
|
|
|
// create various setpoint persistence:
|
2021-10-23 18:16:48 +00:00
|
|
|
cool_storage = global_preferences->make_preference<uint8_t>(this->get_object_id_hash() + 1);
|
|
|
|
heat_storage = global_preferences->make_preference<uint8_t>(this->get_object_id_hash() + 2);
|
|
|
|
auto_storage = global_preferences->make_preference<uint8_t>(this->get_object_id_hash() + 3);
|
2020-06-05 00:26:56 +00:00
|
|
|
|
|
|
|
// load values from storage:
|
|
|
|
cool_setpoint = load(cool_storage);
|
|
|
|
heat_setpoint = load(heat_storage);
|
|
|
|
auto_setpoint = load(auto_storage);
|
|
|
|
|
2020-03-11 18:24:51 +00:00
|
|
|
this->dump_config();
|
|
|
|
}
|
|
|
|
|
2020-06-05 00:26:56 +00:00
|
|
|
/**
|
|
|
|
* The ESP only has a few bytes of rtc storage, so instead
|
2020-07-06 16:29:52 +00:00
|
|
|
* of storing floats directly, we'll store the number of
|
2020-06-05 00:26:56 +00:00
|
|
|
* TEMPERATURE_STEPs from MIN_TEMPERATURE.
|
|
|
|
**/
|
|
|
|
void MitsubishiHeatPump::save(float value, ESPPreferenceObject& storage) {
|
|
|
|
uint8_t steps = (value - ESPMHP_MIN_TEMPERATURE) / ESPMHP_TEMPERATURE_STEP;
|
|
|
|
storage.save(&steps);
|
|
|
|
}
|
|
|
|
|
|
|
|
optional<float> MitsubishiHeatPump::load(ESPPreferenceObject& storage) {
|
|
|
|
uint8_t steps = 0;
|
|
|
|
if (!storage.load(&steps)) {
|
|
|
|
return {};
|
|
|
|
}
|
|
|
|
return ESPMHP_MIN_TEMPERATURE + (steps * ESPMHP_TEMPERATURE_STEP);
|
|
|
|
}
|
|
|
|
|
2020-03-11 18:24:51 +00:00
|
|
|
void MitsubishiHeatPump::dump_config() {
|
|
|
|
this->banner();
|
|
|
|
ESP_LOGI(TAG, " Supports HEAT: %s", YESNO(true));
|
|
|
|
ESP_LOGI(TAG, " Supports COOL: %s", YESNO(true));
|
|
|
|
ESP_LOGI(TAG, " Supports AWAY mode: %s", YESNO(false));
|
2020-06-05 00:26:56 +00:00
|
|
|
ESP_LOGI(TAG, " Saved heat: %.1f", heat_setpoint.value_or(-1));
|
|
|
|
ESP_LOGI(TAG, " Saved cool: %.1f", cool_setpoint.value_or(-1));
|
|
|
|
ESP_LOGI(TAG, " Saved auto: %.1f", auto_setpoint.value_or(-1));
|
2020-03-11 18:24:51 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void MitsubishiHeatPump::dump_state() {
|
|
|
|
LOG_CLIMATE("", "MitsubishiHeatPump Climate", this);
|
|
|
|
ESP_LOGI(TAG, "HELLO");
|
|
|
|
}
|