esphome-mitsubishiheatpump/components/mitsubishi_heatpump/espmhp.h

169 lines
6.0 KiB
C
Raw Normal View History

2020-03-11 18:24:51 +00:00
/**
* espmhp.h
*
* Header file for esphome-mitsubishiheatpump
*
2020-07-06 16:29:52 +00:00
* Author: Geoff Davis <geoff@geoffdavis.com>
* Author: Phil Genera @pgenera 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
* Last Updated: 2021-06-23
2020-03-11 18:24:51 +00:00
* License: BSD
*
* Requirements:
* - https://github.com/SwiCago/HeatPump
* - ESPHome 1.19.1 or greater
2020-03-11 18:24:51 +00:00
*/
#define USE_CALLBACKS
2020-03-11 18:24:51 +00:00
#include "esphome.h"
#include "esphome/core/preferences.h"
2023-04-23 18:11:41 +00:00
#include <chrono>
2020-03-11 18:24:51 +00:00
#include "HeatPump.h"
#ifndef ESPMHP_H
#define ESPMHP_H
2020-03-11 18:24:51 +00:00
static const char* TAG = "MitsubishiHeatPump"; // Logging tag
2020-03-11 18:24:51 +00:00
2022-11-01 05:38:38 +00:00
static const char* ESPMHP_VERSION = "2.4.1";
2020-03-11 18:24:51 +00:00
/* If polling interval is greater than 9 seconds, the HeatPump
library reconnects, but doesn't then follow up with our data request.*/
static const uint32_t ESPMHP_POLL_INTERVAL_DEFAULT = 500; // in milliseconds,
2020-03-11 18:24:51 +00:00
// 0 < X <= 9000
static const uint8_t ESPMHP_MIN_TEMPERATURE = 16; // degrees C,
// defined by hardware
static const uint8_t ESPMHP_MAX_TEMPERATURE = 31; // degrees C,
//defined by hardware
static const float ESPMHP_TEMPERATURE_STEP = 0.5; // temperature setting step,
2020-03-11 18:24:51 +00:00
// in degrees C
2023-05-11 14:34:41 +00:00
class MitsubishiHeatPump : public esphome::PollingComponent, public esphome::climate::Climate {
2020-03-11 18:24:51 +00:00
public:
/**
* Create a new MitsubishiHeatPump object
*
* Args:
* hw_serial: pointer to an Arduino HardwareSerial instance
* poll_interval: polling interval in milliseconds
*/
MitsubishiHeatPump(
HardwareSerial* hw_serial,
uint32_t poll_interval=ESPMHP_POLL_INTERVAL_DEFAULT
);
2020-03-11 18:24:51 +00:00
// Print a banner with library information.
2023-05-11 14:34:41 +00:00
void banner();
2020-03-11 18:24:51 +00:00
// Set the baud rate. Must be called before setup() to have any effect.
void set_baud_rate(int);
// Set the RX pin. Must be called before setup() to have any effect.
void set_rx_pin(int);
// Set the TX pin. Must be called before setup() to have any effect.
void set_tx_pin(int);
2020-03-11 18:24:51 +00:00
// print the current configuration
void dump_config() override;
// handle a change in settings as detected by the HeatPump library.
void hpSettingsChanged();
// Handle a change in status as detected by the HeatPump library.
void hpStatusChanged(heatpumpStatus currentStatus);
// Set up the component, initializing the HeatPump object.
void setup() override;
// This is called every poll_interval.
void update() override;
// Configure the climate object with traits that we support.
2023-05-11 14:34:41 +00:00
esphome::climate::ClimateTraits traits() override;
2020-03-11 18:24:51 +00:00
// Get a mutable reference to the traits that we support.
2023-05-11 14:34:41 +00:00
esphome::climate::ClimateTraits& config_traits();
2020-03-11 18:24:51 +00:00
// Debugging function to print the object's state.
void dump_state();
// Handle a request from the user to change settings.
2023-05-11 14:34:41 +00:00
void control(const esphome::climate::ClimateCall &call) override;
2021-05-28 04:43:08 +00:00
// Use the temperature from an external sensor. Use
// set_remote_temp(0) to switch back to the internal sensor.
void set_remote_temperature(float);
2020-03-11 18:24:51 +00:00
2023-04-23 18:11:41 +00:00
// Used to validate that a connection is present between the controller
// and this heatpump.
void ping();
// Number of minutes before the heatpump reverts back to the internal
// temperature sensor if the machine is currently operating.
void set_remote_operating_timeout_minutes(int);
// Number of minutes before the heatpump reverts back to the internal
// temperature sensor if the machine is currently idle.
void set_remote_idle_timeout_minutes(int);
// Number of minutes before the heatpump reverts back to the internal
// temperature sensor if a ping isn't received from the controller.
void set_remote_ping_timeout_minutes(int);
2020-03-11 18:24:51 +00:00
protected:
// HeatPump object using the underlying Arduino library.
HeatPump* hp;
// The ClimateTraits supported by this HeatPump.
2023-05-11 14:34:41 +00:00
esphome::climate::ClimateTraits traits_;
2020-03-11 18:24:51 +00:00
// Allow the HeatPump class to use get_hw_serial_
friend class HeatPump;
//Accessor method for the HardwareSerial pointer
HardwareSerial* get_hw_serial_() {
return this->hw_serial_;
}
//Print a warning message if we're using the sole hardware UART on an
//ESP8266 or UART0 on ESP32
void check_logger_conflict_();
// various prefs to save mode-specific temperatures, akin to how the IR
// remote works.
2023-05-11 14:34:41 +00:00
esphome::ESPPreferenceObject cool_storage;
esphome::ESPPreferenceObject heat_storage;
esphome::ESPPreferenceObject auto_storage;
2023-05-11 14:34:41 +00:00
esphome::optional<float> cool_setpoint;
esphome::optional<float> heat_setpoint;
esphome::optional<float> auto_setpoint;
2023-05-11 14:34:41 +00:00
static void save(float value, esphome::ESPPreferenceObject& storage);
static esphome::optional<float> load(esphome::ESPPreferenceObject& storage);
2020-03-11 18:24:51 +00:00
private:
2023-04-23 18:11:41 +00:00
void enforce_remote_temperature_sensor_timeout();
2020-03-11 18:24:51 +00:00
// Retrieve the HardwareSerial pointer from friend and subclasses.
HardwareSerial *hw_serial_;
int baud_ = 0;
int rx_pin_ = -1;
int tx_pin_ = -1;
2023-04-23 18:11:41 +00:00
bool operating_ = false;
2023-10-13 19:48:35 +00:00
2023-10-13 20:02:55 +00:00
std::optional<std::chrono::duration<long long, std::ratio<60>>> remote_operating_timeout_;
std::optional<std::chrono::duration<long long, std::ratio<60>>> remote_idle_timeout_;
std::optional<std::chrono::duration<long long, std::ratio<60>>> remote_ping_timeout_;
std::optional<std::chrono::time_point<std::chrono::steady_clock>> last_remote_temperature_sensor_update_;
std::optional<std::chrono::time_point<std::chrono::steady_clock>> last_ping_request_;
2020-03-11 18:24:51 +00:00
};
#endif