ESPHome 2025.12.0-dev
Loading...
Searching...
No Matches
yashima.cpp
Go to the documentation of this file.
1#include "yashima.h"
2#include "esphome/core/log.h"
3
4namespace esphome {
5namespace yashima {
6
7static const char *const TAG = "yashima.climate";
8
9const uint16_t YASHIMA_STATE_LENGTH = 9;
11
12/* the bit masks are intended to be sent from the MSB to the LSB */
13const uint8_t YASHIMA_MODE_HEAT_BYTE0 = 0b00100000;
14const uint8_t YASHIMA_MODE_DRY_BYTE0 = 0b01100000;
15const uint8_t YASHIMA_MODE_COOL_BYTE0 = 0b11100000;
16const uint8_t YASHIMA_MODE_FAN_BYTE0 = 0b10100000;
17const uint8_t YASHIMA_MODE_AUTO_BYTE0 = 0b11100000;
18const uint8_t YASHIMA_MODE_OFF_BYTE0 = 0b11110000;
19const uint8_t YASHIMA_BASE_BYTE0 = 0b1110;
20
21const uint8_t YASHIMA_TEMP_MAX = 30; // Celsius
22const uint8_t YASHIMA_TEMP_MIN = 16; // Celsius
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};
42const uint8_t YASHIMA_BASE_BYTE1 = 0b11;
43
44const uint8_t YASHIMA_FAN_AUTO_BYTE2 = 0b11000000;
45const uint8_t YASHIMA_FAN_LOW_BYTE2 = 0b00000000;
46const uint8_t YASHIMA_FAN_MEDIUM_BYTE2 = 0b10000000;
47const uint8_t YASHIMA_FAN_HIGH_BYTE2 = 0b01000000;
48const uint8_t YASHIMA_BASE_BYTE2 = 0b111111;
49
50const uint8_t YASHIMA_BASE_BYTE3 = 0b11111111;
51const uint8_t YASHIMA_BASE_BYTE4 = 0b11;
52
53const uint8_t YASHIMA_MODE_HEAT_BYTE5 = 0b00000000;
54const uint8_t YASHIMA_MODE_DRY_BYTE5 = 0b00000000;
55const uint8_t YASHIMA_MODE_FAN_BYTE5 = 0b00000000;
56const uint8_t YASHIMA_MODE_AUTO_BYTE5 = 0b00000000;
57const uint8_t YASHIMA_MODE_COOL_BYTE5 = 0b10000000;
58const uint8_t YASHIMA_MODE_OFF_BYTE5 = 0b10000000;
59const uint8_t YASHIMA_BASE_BYTE5 = 0b11111;
60
61const uint8_t YASHIMA_BASE_BYTE6 = 0b11111111;
62const uint8_t YASHIMA_BASE_BYTE7 = 0b11111111;
63const 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: */
73const uint16_t YASHIMA_HEADER_MARK = 9035;
74const uint16_t YASHIMA_HEADER_SPACE = 4517;
75const uint16_t YASHIMA_BIT_MARK = 667;
76const uint16_t YASHIMA_ONE_SPACE = 517;
77const uint16_t YASHIMA_ZERO_SPACE = 1543;
79
80const uint32_t YASHIMA_CARRIER_FREQUENCY = 38000;
81
99
101 if (this->sensor_) {
102 this->sensor_->add_on_state_callback([this](float state) {
104 // current temperature changed, publish state
105 this->publish_state();
106 });
107 this->current_temperature = this->sensor_->state;
108 } else {
109 this->current_temperature = NAN;
110 }
111 // restore set points
112 auto restore = this->restore_state_();
113 if (restore.has_value()) {
114 restore->apply(this);
115 } else {
116 // restore from defaults
118 this->target_temperature = 24;
119 }
120}
121
123 if (call.get_mode().has_value())
124 this->mode = *call.get_mode();
125 if (call.get_target_temperature().has_value())
127
128 this->transmit_state_();
129 this->publish_state();
130}
131
133 uint8_t remote_state[YASHIMA_STATE_LENGTH] = {0};
134
135 remote_state[0] = YASHIMA_BASE_BYTE0;
136 remote_state[1] = YASHIMA_BASE_BYTE1;
137 remote_state[2] = YASHIMA_BASE_BYTE2;
138 remote_state[3] = YASHIMA_BASE_BYTE3;
139 remote_state[4] = YASHIMA_BASE_BYTE4;
140 remote_state[5] = YASHIMA_BASE_BYTE5;
141 remote_state[6] = YASHIMA_BASE_BYTE6;
142 remote_state[7] = YASHIMA_BASE_BYTE7;
143 remote_state[8] = YASHIMA_BASE_BYTE8;
144
145 // Set mode
146 switch (this->mode) {
148 remote_state[0] |= YASHIMA_MODE_AUTO_BYTE0;
149 remote_state[5] |= YASHIMA_MODE_AUTO_BYTE5;
150 break;
152 remote_state[0] |= YASHIMA_MODE_COOL_BYTE0;
153 remote_state[5] |= YASHIMA_MODE_COOL_BYTE5;
154 break;
156 remote_state[0] |= YASHIMA_MODE_HEAT_BYTE0;
157 remote_state[5] |= YASHIMA_MODE_HEAT_BYTE5;
158 break;
160 default:
161 remote_state[0] |= YASHIMA_MODE_OFF_BYTE0;
162 remote_state[5] |= YASHIMA_MODE_OFF_BYTE5;
163 break;
164 // TODO: CLIMATE_MODE_FAN_ONLY, CLIMATE_MODE_DRY are missing in esphome
165 }
166
167 // TODO: missing support for fan speed
168 remote_state[2] |= YASHIMA_FAN_AUTO_BYTE2;
169
170 // Set temperature
171 uint8_t safecelsius = std::max((uint8_t) this->target_temperature, YASHIMA_TEMP_MIN);
172 safecelsius = std::min(safecelsius, YASHIMA_TEMP_MAX);
173 remote_state[1] |= YASHIMA_TEMP_MAP_BYTE1[safecelsius - YASHIMA_TEMP_MIN];
174
175 auto transmit = this->transmitter_->transmit();
176 auto *data = transmit.get_data();
177
179
180 // Header
181 data->mark(YASHIMA_HEADER_MARK);
182 data->space(YASHIMA_HEADER_SPACE);
183 // Data (sent from the MSB to the LSB)
184 for (uint8_t i : remote_state) {
185 for (int8_t j = 7; j >= 0; j--) {
186 data->mark(YASHIMA_BIT_MARK);
187 bool bit = i & (1 << j);
188 data->space(bit ? YASHIMA_ONE_SPACE : YASHIMA_ZERO_SPACE);
189 }
190 }
191 // Footer
192 data->mark(YASHIMA_BIT_MARK);
193 data->space(YASHIMA_GAP);
194
195 transmit.perform();
196}
197
198} // namespace yashima
199} // namespace esphome
This class is used to encode all control actions on a climate device.
Definition climate.h:33
const optional< float > & get_target_temperature() const
Definition climate.cpp:287
const optional< ClimateMode > & get_mode() const
Definition climate.cpp:292
ClimateMode mode
The active mode of the climate device.
Definition climate.h:256
float target_temperature
The target temperature of the climate device.
Definition climate.h:237
float current_temperature
The current temperature of the climate device, as reported from the integration.
Definition climate.h:230
void publish_state()
Publish the state of the climate device, to be called from integrations.
Definition climate.cpp:426
optional< ClimateDeviceRestoreState > restore_state_()
Restore the state of the climate device, call this from your setup() method.
Definition climate.cpp:350
void set_visual_max_temperature(float visual_max_temperature)
void add_feature_flags(uint32_t feature_flags)
void set_visual_temperature_step(float temperature_step)
void set_visual_min_temperature(float visual_min_temperature)
void set_supported_modes(ClimateModeMask modes)
void add_supported_mode(ClimateMode mode)
void set_carrier_frequency(uint32_t carrier_frequency)
Definition remote_base.h:30
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:90
float state
This member variable stores the last state that has passed through all filters.
Definition sensor.h:116
void transmit_state_()
Transmit via IR the state of this climate controller.
Definition yashima.cpp:132
climate::ClimateTraits traits() override
Return the traits of this controller.
Definition yashima.cpp:82
void control(const climate::ClimateCall &call) override
Override control to change settings of the climate device.
Definition yashima.cpp:122
remote_transmitter::RemoteTransmitterComponent * transmitter_
Definition yashima.h:35
bool state
Definition fan.h:0
@ CLIMATE_SUPPORTS_CURRENT_TEMPERATURE
@ CLIMATE_MODE_HEAT
The climate device is set to heat to reach the target temperature.
@ CLIMATE_MODE_COOL
The climate device is set to cool to reach the target temperature.
@ CLIMATE_MODE_HEAT_COOL
The climate device is set to heat/cool to reach the target temperature.
@ CLIMATE_MODE_OFF
The climate device is off.
const uint8_t YASHIMA_BASE_BYTE1
Definition yashima.cpp:42
const uint8_t YASHIMA_MODE_COOL_BYTE5
Definition yashima.cpp:57
const uint8_t YASHIMA_MODE_AUTO_BYTE5
Definition yashima.cpp:56
const uint8_t YASHIMA_TEMP_MIN
Definition yashima.cpp:22
const uint16_t YASHIMA_HEADER_MARK
Definition yashima.cpp:73
const uint8_t YASHIMA_BASE_BYTE8
Definition yashima.cpp:63
const uint16_t YASHIMA_HEADER_SPACE
Definition yashima.cpp:74
const uint32_t YASHIMA_GAP
Definition yashima.cpp:78
const uint8_t YASHIMA_MODE_HEAT_BYTE5
Definition yashima.cpp:53
const uint8_t YASHIMA_MODE_DRY_BYTE0
Definition yashima.cpp:14
const uint8_t YASHIMA_FAN_HIGH_BYTE2
Definition yashima.cpp:47
const uint8_t YASHIMA_TEMP_RANGE
Definition yashima.cpp:23
const uint8_t YASHIMA_TEMP_MAX
Definition yashima.cpp:21
const uint8_t YASHIMA_FAN_AUTO_BYTE2
Definition yashima.cpp:44
const uint16_t YASHIMA_BITS
Definition yashima.cpp:10
const uint16_t YASHIMA_BIT_MARK
Definition yashima.cpp:75
const uint32_t YASHIMA_CARRIER_FREQUENCY
Definition yashima.cpp:80
const uint8_t YASHIMA_BASE_BYTE3
Definition yashima.cpp:50
const uint16_t YASHIMA_ZERO_SPACE
Definition yashima.cpp:77
const uint8_t YASHIMA_MODE_OFF_BYTE5
Definition yashima.cpp:58
const uint8_t YASHIMA_BASE_BYTE2
Definition yashima.cpp:48
const uint8_t YASHIMA_BASE_BYTE5
Definition yashima.cpp:59
const uint8_t YASHIMA_MODE_AUTO_BYTE0
Definition yashima.cpp:17
const uint8_t YASHIMA_MODE_FAN_BYTE0
Definition yashima.cpp:16
const uint8_t YASHIMA_MODE_OFF_BYTE0
Definition yashima.cpp:18
const uint8_t YASHIMA_MODE_DRY_BYTE5
Definition yashima.cpp:54
const uint8_t YASHIMA_BASE_BYTE4
Definition yashima.cpp:51
const uint8_t YASHIMA_MODE_FAN_BYTE5
Definition yashima.cpp:55
const uint16_t YASHIMA_STATE_LENGTH
Definition yashima.cpp:9
const uint16_t YASHIMA_ONE_SPACE
Definition yashima.cpp:76
const uint8_t YASHIMA_FAN_LOW_BYTE2
Definition yashima.cpp:45
const uint8_t YASHIMA_FAN_MEDIUM_BYTE2
Definition yashima.cpp:46
const uint8_t YASHIMA_BASE_BYTE6
Definition yashima.cpp:61
const uint8_t YASHIMA_MODE_COOL_BYTE0
Definition yashima.cpp:15
const uint8_t YASHIMA_TEMP_MAP_BYTE1[YASHIMA_TEMP_RANGE]
Definition yashima.cpp:25
const uint8_t YASHIMA_BASE_BYTE7
Definition yashima.cpp:62
const uint8_t YASHIMA_MODE_HEAT_BYTE0
Definition yashima.cpp:13
const uint8_t YASHIMA_BASE_BYTE0
Definition yashima.cpp:19
Providing packet encoding functions for exchanging data with a remote host.
Definition a01nyub.cpp:7