4#ifdef USE_SENSOR_FILTER
38 void input(
float value);
58 optional<float>
new_value(
float value)
final;
86 result = std::isnan(result) ? v : (comp(v, result) ? v : result);
123 explicit QuantileFilter(
size_t window_size,
size_t send_every,
size_t send_first_at,
float quantile);
146 using SortedWindowFilter::SortedWindowFilter;
164 optional<float>
new_value(
float value)
override;
184 using MinMaxFilter::MinMaxFilter;
204 using MinMaxFilter::MinMaxFilter;
240 optional<float>
new_value(
float value)
override;
261 void setup()
override;
263 optional<float>
new_value(
float value)
override;
287 optional<float>
new_value(
float value)
override;
316 optional<float>
new_value(
float value)
override;
326 optional<float>
new_value(
float value)
override;
354 std::array<TemplatableFn<float>, N>
values_{};
374 optional<float>
new_value(
float value)
override;
394 this->min_time_between_inputs_);
405 void loop()
override;
422 optional<float>
new_value(
float value)
override;
436 optional<float>
new_value(
float value)
override;
448 optional<float>
new_value(
float value)
override;
460 void setup()
override;
461 optional<float>
new_value(
float value)
override;
475 explicit DeltaFilter(
float min_a0,
float min_a1,
float max_a0,
float max_a1);
479 optional<float>
new_value(
float value)
override;
487 float (*
baseline_)(float) = [](
float last_value) {
return last_value; };
494optional<float>
or_filter_new_value(Filter **filters,
size_t count,
float value,
bool &has_value);
567 ClampFilter(
float min,
float max,
bool ignore_out_of_range);
568 optional<float>
new_value(
float value)
override;
579 optional<float>
new_value(
float value)
override;
588 optional<float>
new_value(
float value)
override;
597 optional<float>
new_value(
float value)
override;
608 optional<float>
new_value(
float value)
override;
625 optional<float>
new_value(
float value)
final;
void disable_loop()
Disable this component's loop.
Fixed-capacity circular buffer - allocates once at runtime, never reallocates.
Fixed-capacity vector - allocates once at runtime, never reallocates This avoids std::vector template...
Function-pointer-only templatable storage (4 bytes on 32-bit).
N is set by code generation to match the exact number of calibration segments.
CalibrateLinearFilter(std::initializer_list< std::array< float, 3 > > linear_functions)
std::array< std::array< float, 3 >, N > linear_functions_
optional< float > new_value(float value) override
N is set by code generation to match the exact number of polynomial coefficients.
optional< float > new_value(float value) override
CalibratePolynomialFilter(std::initializer_list< float > coefficients)
std::array< float, N > coefficients_
bool ignore_out_of_range_
ClampFilter(float min, float max, bool ignore_out_of_range)
optional< float > new_value(float value) override
optional< float > new_value(float value) override
float get_setup_priority() const override
DebounceFilter(uint32_t time_period)
void set_baseline(float(*fn)(float))
DeltaFilter(float min_a0, float min_a1, float max_a0, float max_a1)
optional< float > new_value(float value) override
float(* baseline_)(float)
Simple exponential moving average filter.
void set_send_every(uint16_t send_every)
optional< float > new_value(float value) override
void set_alpha(float alpha)
ExponentialMovingAverageFilter(float alpha, uint16_t send_every, uint16_t send_first_at)
Apply a filter to sensor values such as moving average.
virtual optional< float > new_value(float value)=0
This will be called every time the filter receives a new value.
virtual void initialize(Sensor *parent, Filter *next)
Initialize this filter, please note this can be called more than once.
A simple filter that only forwards the filter chain if it doesn't receive value_to_filter_out.
FilterOutValueFilter(std::initializer_list< TemplatableFn< float > > values_to_filter_out)
optional< float > new_value(float value) override
HeartbeatFilter(uint32_t time_period)
optional< float > new_value(float value) override
void set_optimistic(bool optimistic)
float get_setup_priority() const override
This class allows for creation of simple template filters.
const lambda_filter_t & get_lambda_filter() const
LambdaFilter(lambda_filter_t lambda_filter)
lambda_filter_t lambda_filter_
void set_lambda_filter(const lambda_filter_t &lambda_filter)
optional< float > new_value(float value) override
float compute_result() override
float compute_result() override
Base class for Min/Max filters.
float find_extremum_()
Helper to find min or max value in window, skipping NaN values Usage: find_extremum_<std::less<float>...
A simple filter that multiplies to each value it receives by multiplier.
TemplatableFn< float > multiplier_
optional< float > new_value(float value) override
MultiplyFilter(TemplatableFn< float > multiplier)
A simple filter that adds offset to each value it receives.
optional< float > new_value(float value) override
TemplatableFn< float > offset_
OffsetFilter(TemplatableFn< float > offset)
optional< float > new_value(float value) override
PhiNode(OrFilter *or_parent)
N is set by code generation to match the exact number of filters configured in YAML.
std::array< Filter *, N > filters_
void initialize(Sensor *parent, Filter *next) override
optional< float > new_value(float value) override
OrFilter(std::initializer_list< Filter * > filters)
float compute_result() override
void set_quantile(float quantile)
QuantileFilter(size_t window_size, size_t send_every, size_t send_first_at, float quantile)
Construct a QuantileFilter.
RoundFilter(uint8_t precision)
optional< float > new_value(float value) override
optional< float > new_value(float value) override
RoundMultipleFilter(float multiple)
Base-class for all sensors.
SkipInitialFilter(size_t num_to_ignore)
Construct a SkipInitialFilter.
optional< float > new_value(float value) override
Base class for filters that use a sliding window of values.
FixedRingBuffer< float > window_
Sliding window ring buffer - automatically overwrites oldest values when full.
optional< float > new_value(float value) final
SlidingWindowFilter(uint16_t window_size, uint16_t send_every, uint16_t send_first_at)
uint16_t send_every_
Send result every N values.
virtual float compute_result()=0
Called by new_value() to compute the filtered result from the current window.
uint16_t send_at_
Counter for send_every.
Simple sliding window moving average filter.
float compute_result() override
Base class for filters that need a sorted window (Median, Quantile).
FixedVector< float > get_window_values_()
Helper to get non-NaN values from the window (not sorted - caller will use nth_element) Returns empty...
Optimized lambda filter for stateless lambdas (no capture).
optional< float >(* lambda_filter_)(float)
optional< float > new_value(float value) override
StatelessLambdaFilter(optional< float >(*lambda_filter)(float))
Base class for streaming filters (batch windows where window_size == send_every).
StreamingFilter(uint16_t window_size, uint16_t send_first_at)
virtual void process_value(float value)=0
Called by new_value() to process each value in the batch.
virtual float compute_batch_result()=0
Called by new_value() to compute the result after collecting window_size values.
virtual void reset_batch()=0
Called by new_value() to reset internal state after sending a result.
optional< float > new_value(float value) final
Streaming max filter for batch windows (window_size == send_every).
void reset_batch() override
void process_value(float value) override
float compute_batch_result() override
Streaming min filter for batch windows (window_size == send_every).
void reset_batch() override
float compute_batch_result() override
void process_value(float value) override
Streaming moving average filter for batch windows (window_size == send_every).
float compute_batch_result() override
void reset_batch() override
void process_value(float value) override
Simple throttle average filter.
optional< float > new_value(float value) override
ThrottleAverageFilter(uint32_t time_period)
float get_setup_priority() const override
uint32_t min_time_between_inputs_
ThrottleFilter(uint32_t min_time_between_inputs)
optional< float > new_value(float value) override
Same as 'throttle' but will immediately publish values contained in value_to_prioritize.
optional< float > new_value(float value) override
uint32_t min_time_between_inputs_
ThrottleWithPriorityFilter(uint32_t min_time_between_inputs, std::initializer_list< TemplatableFn< float > > prioritized_values)
uint32_t timeout_start_time_
TimeoutFilterBase(uint32_t time_period)
float get_setup_priority() const override
virtual float get_output_value()=0
float get_output_value() override
TimeoutFilterLast(uint32_t time_period)
optional< float > new_value(float value) override
optional< float > new_value(float value) override
ToNTCResistanceFilter(double a, double b, double c)
optional< float > new_value(float value) override
ToNTCTemperatureFilter(double a, double b, double c)
Base class for filters that compare sensor values against a fixed list of configured values.
ValueListFilter(std::initializer_list< TemplatableFn< float > > values)
bool value_matches_any_(float sensor_value)
Check if sensor value matches any configured value (with accuracy rounding)
std::array< TemplatableFn< float >, N > values_
optional< float > throttle_with_priority_new_value(Sensor *parent, float value, const TemplatableFn< float > *values, size_t count, uint32_t &last_input, uint32_t min_time_between_inputs)
Non-template helper for ThrottleWithPriorityFilter (implementation in filter.cpp)
void or_filter_initialize(Filter **filters, size_t count, Sensor *parent, Filter *phi)
Non-template helpers for OrFilter (implementation in filter.cpp)
bool value_list_matches_any(Sensor *parent, float sensor_value, const TemplatableFn< float > *values, size_t count)
Non-template helper for value matching (implementation in filter.cpp)
optional< float > calibrate_polynomial_compute(const float *coefficients, size_t count, float value)
Non-template helper for polynomial calibration (implementation in filter.cpp)
optional< float > calibrate_linear_compute(const std::array< float, 3 > *functions, size_t count, float value)
Non-template helper for linear calibration (implementation in filter.cpp)
std::function< optional< float >(float)> lambda_filter_t
optional< float > or_filter_new_value(Filter **filters, size_t count, float value, bool &has_value)
void init_array_from(std::array< T, N > &dest, std::initializer_list< T > src)
Initialize a std::array from an initializer_list.