ESPHome  2025.2.0
yashima.cpp
Go to the documentation of this file.
1 #include "yashima.h"
2 #include "esphome/core/log.h"
3 
4 namespace esphome {
5 namespace yashima {
6 
7 static const char *const TAG = "yashima.climate";
8 
9 const uint16_t YASHIMA_STATE_LENGTH = 9;
10 const uint16_t YASHIMA_BITS = YASHIMA_STATE_LENGTH * 8;
11 
12 /* the bit masks are intended to be sent from the MSB to the LSB */
13 const uint8_t YASHIMA_MODE_HEAT_BYTE0 = 0b00100000;
14 const uint8_t YASHIMA_MODE_DRY_BYTE0 = 0b01100000;
15 const uint8_t YASHIMA_MODE_COOL_BYTE0 = 0b11100000;
16 const uint8_t YASHIMA_MODE_FAN_BYTE0 = 0b10100000;
17 const uint8_t YASHIMA_MODE_AUTO_BYTE0 = 0b11100000;
18 const uint8_t YASHIMA_MODE_OFF_BYTE0 = 0b11110000;
19 const uint8_t YASHIMA_BASE_BYTE0 = 0b1110;
20 
21 const uint8_t YASHIMA_TEMP_MAX = 30; // Celsius
22 const uint8_t YASHIMA_TEMP_MIN = 16; // Celsius
23 const uint8_t YASHIMA_TEMP_RANGE = YASHIMA_TEMP_MAX - YASHIMA_TEMP_MIN + 1;
24 
26  0b01100100, // 16C
27  0b10100100, // 17C
28  0b00100100, // 18C
29  0b11000100, // 19C
30  0b01000100, // 20C
31  0b10000100, // 21C
32  0b00000100, // 22C
33  0b11111000, // 23C
34  0b01111000, // 24C
35  0b10111000, // 25C
36  0b00111000, // 26C
37  0b11011000, // 27C
38  0b01011000, // 28C
39  0b10011000, // 29C
40  0b00011000, // 30C
41 };
42 const uint8_t YASHIMA_BASE_BYTE1 = 0b11;
43 
44 const uint8_t YASHIMA_FAN_AUTO_BYTE2 = 0b11000000;
45 const uint8_t YASHIMA_FAN_LOW_BYTE2 = 0b00000000;
46 const uint8_t YASHIMA_FAN_MEDIUM_BYTE2 = 0b10000000;
47 const uint8_t YASHIMA_FAN_HIGH_BYTE2 = 0b01000000;
48 const uint8_t YASHIMA_BASE_BYTE2 = 0b111111;
49 
50 const uint8_t YASHIMA_BASE_BYTE3 = 0b11111111;
51 const uint8_t YASHIMA_BASE_BYTE4 = 0b11;
52 
53 const uint8_t YASHIMA_MODE_HEAT_BYTE5 = 0b00000000;
54 const uint8_t YASHIMA_MODE_DRY_BYTE5 = 0b00000000;
55 const uint8_t YASHIMA_MODE_FAN_BYTE5 = 0b00000000;
56 const uint8_t YASHIMA_MODE_AUTO_BYTE5 = 0b00000000;
57 const uint8_t YASHIMA_MODE_COOL_BYTE5 = 0b10000000;
58 const uint8_t YASHIMA_MODE_OFF_BYTE5 = 0b10000000;
59 const uint8_t YASHIMA_BASE_BYTE5 = 0b11111;
60 
61 const uint8_t YASHIMA_BASE_BYTE6 = 0b11111111;
62 const uint8_t YASHIMA_BASE_BYTE7 = 0b11111111;
63 const uint8_t YASHIMA_BASE_BYTE8 = 0b11001111;
64 
65 /* values sampled using a Broadlink Mini 3: */
66 // const uint16_t YASHIMA_HEADER_MARK = 9600;
67 // const uint16_t YASHIMA_HEADER_SPACE = 4800;
68 // const uint16_t YASHIMA_BIT_MARK = 720;
69 // const uint16_t YASHIMA_ONE_SPACE = 550;
70 // const uint16_t YASHIMA_ZERO_SPACE = 1640;
71 
72 /* scaled values to get correct timing on ESP8266/ESP32: */
73 const uint16_t YASHIMA_HEADER_MARK = 9035;
74 const uint16_t YASHIMA_HEADER_SPACE = 4517;
75 const uint16_t YASHIMA_BIT_MARK = 667;
76 const uint16_t YASHIMA_ONE_SPACE = 517;
77 const uint16_t YASHIMA_ZERO_SPACE = 1543;
79 
80 const uint32_t YASHIMA_CARRIER_FREQUENCY = 38000;
81 
85 
87  if (supports_cool_)
89  if (supports_heat_)
91 
93  traits.set_visual_min_temperature(YASHIMA_TEMP_MIN);
94  traits.set_visual_max_temperature(YASHIMA_TEMP_MAX);
96  return traits;
97 }
98 
100  if (this->sensor_) {
101  this->sensor_->add_on_state_callback([this](float state) {
102  this->current_temperature = state;
103  // current temperature changed, publish state
104  this->publish_state();
105  });
106  this->current_temperature = this->sensor_->state;
107  } else {
108  this->current_temperature = NAN;
109  }
110  // restore set points
111  auto restore = this->restore_state_();
112  if (restore.has_value()) {
113  restore->apply(this);
114  } else {
115  // restore from defaults
117  this->target_temperature = 24;
118  }
119 }
120 
122  if (call.get_mode().has_value())
123  this->mode = *call.get_mode();
124  if (call.get_target_temperature().has_value())
126 
127  this->transmit_state_();
128  this->publish_state();
129 }
130 
132  uint8_t remote_state[YASHIMA_STATE_LENGTH] = {0};
133 
134  remote_state[0] = YASHIMA_BASE_BYTE0;
135  remote_state[1] = YASHIMA_BASE_BYTE1;
136  remote_state[2] = YASHIMA_BASE_BYTE2;
137  remote_state[3] = YASHIMA_BASE_BYTE3;
138  remote_state[4] = YASHIMA_BASE_BYTE4;
139  remote_state[5] = YASHIMA_BASE_BYTE5;
140  remote_state[6] = YASHIMA_BASE_BYTE6;
141  remote_state[7] = YASHIMA_BASE_BYTE7;
142  remote_state[8] = YASHIMA_BASE_BYTE8;
143 
144  // Set mode
145  switch (this->mode) {
147  remote_state[0] |= YASHIMA_MODE_AUTO_BYTE0;
148  remote_state[5] |= YASHIMA_MODE_AUTO_BYTE5;
149  break;
151  remote_state[0] |= YASHIMA_MODE_COOL_BYTE0;
152  remote_state[5] |= YASHIMA_MODE_COOL_BYTE5;
153  break;
155  remote_state[0] |= YASHIMA_MODE_HEAT_BYTE0;
156  remote_state[5] |= YASHIMA_MODE_HEAT_BYTE5;
157  break;
159  default:
160  remote_state[0] |= YASHIMA_MODE_OFF_BYTE0;
161  remote_state[5] |= YASHIMA_MODE_OFF_BYTE5;
162  break;
163  // TODO: CLIMATE_MODE_FAN_ONLY, CLIMATE_MODE_DRY are missing in esphome
164  }
165 
166  // TODO: missing support for fan speed
167  remote_state[2] |= YASHIMA_FAN_AUTO_BYTE2;
168 
169  // Set temperature
170  uint8_t safecelsius = std::max((uint8_t) this->target_temperature, YASHIMA_TEMP_MIN);
171  safecelsius = std::min(safecelsius, YASHIMA_TEMP_MAX);
172  remote_state[1] |= YASHIMA_TEMP_MAP_BYTE1[safecelsius - YASHIMA_TEMP_MIN];
173 
174  auto transmit = this->transmitter_->transmit();
175  auto *data = transmit.get_data();
176 
177  data->set_carrier_frequency(YASHIMA_CARRIER_FREQUENCY);
178 
179  // Header
180  data->mark(YASHIMA_HEADER_MARK);
181  data->space(YASHIMA_HEADER_SPACE);
182  // Data (sent from the MSB to the LSB)
183  for (uint8_t i : remote_state) {
184  for (int8_t j = 7; j >= 0; j--) {
185  data->mark(YASHIMA_BIT_MARK);
186  bool bit = i & (1 << j);
187  data->space(bit ? YASHIMA_ONE_SPACE : YASHIMA_ZERO_SPACE);
188  }
189  }
190  // Footer
191  data->mark(YASHIMA_BIT_MARK);
192  data->space(YASHIMA_GAP);
193 
194  transmit.perform();
195 }
196 
197 } // namespace yashima
198 } // namespace esphome
const uint16_t YASHIMA_BIT_MARK
Definition: yashima.cpp:75
This class is used to encode all control actions on a climate device.
Definition: climate.h:33
const uint8_t YASHIMA_MODE_HEAT_BYTE0
Definition: yashima.cpp:13
void add_on_state_callback(std::function< void(float)> &&callback)
Add a callback that will be called every time a filtered value arrives.
Definition: sensor.cpp:52
void set_visual_temperature_step(float temperature_step)
float target_temperature
The target temperature of the climate device.
Definition: climate.h:186
const uint8_t YASHIMA_MODE_DRY_BYTE5
Definition: yashima.cpp:54
void set_carrier_frequency(uint32_t carrier_frequency)
Definition: remote_base.h:34
const optional< ClimateMode > & get_mode() const
Definition: climate.cpp:273
This class contains all static data for climate devices.
const uint8_t YASHIMA_BASE_BYTE1
Definition: yashima.cpp:42
void set_visual_min_temperature(float visual_min_temperature)
The climate device is set to heat to reach the target temperature.
Definition: climate_mode.h:18
const uint16_t YASHIMA_ONE_SPACE
Definition: yashima.cpp:76
const uint8_t YASHIMA_TEMP_MAP_BYTE1[YASHIMA_TEMP_RANGE]
Definition: yashima.cpp:25
ClimateMode mode
The active mode of the climate device.
Definition: climate.h:173
const uint8_t YASHIMA_TEMP_RANGE
Definition: yashima.cpp:23
float current_temperature
The current temperature of the climate device, as reported from the integration.
Definition: climate.h:179
bool has_value() const
Definition: optional.h:87
sensor::Sensor * sensor_
Definition: yashima.h:36
void transmit_state_()
Transmit via IR the state of this climate controller.
Definition: yashima.cpp:131
const uint16_t YASHIMA_HEADER_MARK
Definition: yashima.cpp:73
const uint8_t YASHIMA_BASE_BYTE8
Definition: yashima.cpp:63
const uint16_t YASHIMA_STATE_LENGTH
Definition: yashima.cpp:9
const uint8_t YASHIMA_FAN_LOW_BYTE2
Definition: yashima.cpp:45
The climate device is set to cool to reach the target temperature.
Definition: climate_mode.h:16
float state
This member variable stores the last state that has passed through all filters.
Definition: sensor.h:131
const uint16_t YASHIMA_ZERO_SPACE
Definition: yashima.cpp:77
const uint8_t YASHIMA_FAN_HIGH_BYTE2
Definition: yashima.cpp:47
void set_supported_modes(std::set< ClimateMode > modes)
const uint8_t YASHIMA_MODE_OFF_BYTE5
Definition: yashima.cpp:58
const uint8_t YASHIMA_FAN_AUTO_BYTE2
Definition: yashima.cpp:44
void set_visual_max_temperature(float visual_max_temperature)
const uint8_t YASHIMA_MODE_AUTO_BYTE0
Definition: yashima.cpp:17
The climate device is set to heat/cool to reach the target temperature.
Definition: climate_mode.h:14
const uint8_t YASHIMA_BASE_BYTE0
Definition: yashima.cpp:19
const optional< float > & get_target_temperature() const
Definition: climate.cpp:274
void publish_state()
Publish the state of the climate device, to be called from integrations.
Definition: climate.cpp:395
const uint8_t YASHIMA_MODE_OFF_BYTE0
Definition: yashima.cpp:18
The climate device is off.
Definition: climate_mode.h:12
const uint8_t YASHIMA_BASE_BYTE6
Definition: yashima.cpp:61
const uint8_t YASHIMA_FAN_MEDIUM_BYTE2
Definition: yashima.cpp:46
const uint8_t YASHIMA_BASE_BYTE2
Definition: yashima.cpp:48
const uint8_t YASHIMA_TEMP_MAX
Definition: yashima.cpp:21
const uint8_t YASHIMA_BASE_BYTE7
Definition: yashima.cpp:62
const uint8_t YASHIMA_MODE_AUTO_BYTE5
Definition: yashima.cpp:56
const uint8_t YASHIMA_MODE_FAN_BYTE0
Definition: yashima.cpp:16
const uint8_t YASHIMA_MODE_COOL_BYTE0
Definition: yashima.cpp:15
Implementation of SPI Controller mode.
Definition: a01nyub.cpp:7
const uint8_t YASHIMA_BASE_BYTE4
Definition: yashima.cpp:51
void set_supports_two_point_target_temperature(bool supports_two_point_target_temperature)
optional< ClimateDeviceRestoreState > restore_state_()
Restore the state of the climate device, call this from your setup() method.
Definition: climate.cpp:329
const uint8_t YASHIMA_MODE_FAN_BYTE5
Definition: yashima.cpp:55
void set_supports_current_temperature(bool supports_current_temperature)
void control(const climate::ClimateCall &call) override
Override control to change settings of the climate device.
Definition: yashima.cpp:121
const uint8_t YASHIMA_MODE_HEAT_BYTE5
Definition: yashima.cpp:53
remote_transmitter::RemoteTransmitterComponent * transmitter_
Definition: yashima.h:35
const uint8_t YASHIMA_MODE_COOL_BYTE5
Definition: yashima.cpp:57
const uint16_t YASHIMA_BITS
Definition: yashima.cpp:10
void add_supported_mode(ClimateMode mode)
const uint16_t YASHIMA_HEADER_SPACE
Definition: yashima.cpp:74
const uint32_t YASHIMA_CARRIER_FREQUENCY
Definition: yashima.cpp:80
const uint8_t YASHIMA_BASE_BYTE3
Definition: yashima.cpp:50
const uint8_t YASHIMA_MODE_DRY_BYTE0
Definition: yashima.cpp:14
bool state
Definition: fan.h:34
const uint8_t YASHIMA_TEMP_MIN
Definition: yashima.cpp:22
climate::ClimateTraits traits() override
Return the traits of this controller.
Definition: yashima.cpp:82
const uint8_t YASHIMA_BASE_BYTE5
Definition: yashima.cpp:59
const uint32_t YASHIMA_GAP
Definition: yashima.cpp:78