107 for (
int i = -1; i < 40; i++) {
112 if (
micros() - start_time > 90) {
130 if (end_time - start_time > 90) {
145 if (end_time - start_time >= 40) {
146 data[byte] |= 1 << bit;
156 if (error_code != 0) {
158 ESP_LOGW(TAG, ESP_LOG_MSG_COMM_FAIL);
163 "Data: Hum=0b" BYTE_TO_BINARY_PATTERN BYTE_TO_BINARY_PATTERN
164 ", Temp=0b" BYTE_TO_BINARY_PATTERN BYTE_TO_BINARY_PATTERN
", Checksum=0b" BYTE_TO_BINARY_PATTERN,
165 BYTE_TO_BINARY(data[0]), BYTE_TO_BINARY(data[1]), BYTE_TO_BINARY(data[2]), BYTE_TO_BINARY(data[3]),
166 BYTE_TO_BINARY(data[4]));
168 uint8_t checksum_a = data[0] + data[1] + data[2] + data[3];
173 if (checksum_a != data[4] && checksum_b != data[4]) {
175 ESP_LOGW(TAG,
"Invalid checksum");
181 if (checksum_a == data[4]) {
184 const uint16_t raw_temperature =
static_cast<uint16_t
>(data[2]) * 10 + (data[3] & 0x7F);
185 *
temperature =
static_cast<float>(raw_temperature) / 10.0f;
186 if ((data[3] & 0x80) != 0) {
191 const uint16_t raw_humidity =
static_cast<uint16_t
>(data[0]) * 10 + data[1];
192 *humidity =
static_cast<float>(raw_humidity) / 10.0f;
203 if (raw_temperature & 0x8000) {
204 if (!(raw_temperature & 0x4000))
205 raw_temperature = ~(raw_temperature & 0x7FFF);
206 }
else if (raw_temperature & 0x800) {
207 raw_temperature |= 0xf000;
210 if (raw_temperature == 1 && raw_humidity == 10) {
212 ESP_LOGW(TAG,
"Invalid data");
217 *humidity =
static_cast<float>(raw_humidity) * 0.1f;
218 if (*humidity > 100.0f)
220 *
temperature =
static_cast<int16_t
>(raw_temperature) * 0.1f;
223 if (*
temperature == 0.0f && (*humidity == 1.0f || *humidity == 2.0f)) {
225 ESP_LOGW(TAG,
"Invalid data");