79 const uint32_t write_at = s.buffer_write_at;
80 const uint32_t dist = (s.buffer_size + write_at - s.buffer_read_at) % s.buffer_size;
84 const uint32_t now =
micros();
85 if (now - s.buffer[write_at] < this->idle_us_) {
90 ESP_LOGVV(TAG,
"read_at=%u write_at=%u dist=%u now=%u end=%u", s.buffer_read_at, write_at, dist, now,
94 s.buffer_read_at = (s.buffer_read_at + 1) % s.buffer_size;
95 uint32_t prev = s.buffer_read_at;
96 s.buffer_read_at = (s.buffer_read_at + 1) % s.buffer_size;
97 const uint32_t reserve_size = 1 + (s.buffer_size + write_at - s.buffer_read_at) % s.buffer_size;
99 this->
temp_.reserve(reserve_size);
100 int32_t multiplier = s.buffer_read_at % 2 == 0 ? 1 : -1;
102 for (uint32_t i = 0; prev != write_at; i++) {
103 int32_t delta = s.buffer[s.buffer_read_at] - s.buffer[prev];
104 if (uint32_t(delta) >= this->
idle_us_) {
109 ESP_LOGVV(TAG,
" i=%u buffer[%u]=%u - buffer[%u]=%u -> %d", i, s.buffer_read_at, s.buffer[s.buffer_read_at], prev,
110 s.buffer[prev], multiplier * delta);
111 this->
temp_.push_back(multiplier * delta);
112 prev = s.buffer_read_at;
113 s.buffer_read_at = (s.buffer_read_at + 1) % s.buffer_size;
116 s.buffer_read_at = (s.buffer_size + s.buffer_read_at - 1) % s.buffer_size;