Add ignore out of range option for clamp filter (#5455)

Co-authored-by: Jesse Hills <3060199+jesserockz@users.noreply.github.com>
This commit is contained in:
kahrendt 2023-10-25 16:30:23 -04:00 committed by GitHub
parent 841b24f744
commit 93056dead9
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
4 changed files with 23 additions and 6 deletions

View file

@ -16,6 +16,7 @@ from esphome.const import (
CONF_FROM, CONF_FROM,
CONF_ICON, CONF_ICON,
CONF_ID, CONF_ID,
CONF_IGNORE_OUT_OF_RANGE,
CONF_ON_RAW_VALUE, CONF_ON_RAW_VALUE,
CONF_ON_VALUE, CONF_ON_VALUE,
CONF_ON_VALUE_RANGE, CONF_ON_VALUE_RANGE,
@ -688,6 +689,7 @@ CLAMP_SCHEMA = cv.All(
{ {
cv.Optional(CONF_MIN_VALUE, default="NaN"): cv.float_, cv.Optional(CONF_MIN_VALUE, default="NaN"): cv.float_,
cv.Optional(CONF_MAX_VALUE, default="NaN"): cv.float_, cv.Optional(CONF_MAX_VALUE, default="NaN"): cv.float_,
cv.Optional(CONF_IGNORE_OUT_OF_RANGE, default=False): cv.boolean,
} }
), ),
validate_clamp, validate_clamp,
@ -700,6 +702,7 @@ async def clamp_filter_to_code(config, filter_id):
filter_id, filter_id,
config[CONF_MIN_VALUE], config[CONF_MIN_VALUE],
config[CONF_MAX_VALUE], config[CONF_MAX_VALUE],
config[CONF_IGNORE_OUT_OF_RANGE],
) )

View file

@ -434,13 +434,25 @@ optional<float> CalibratePolynomialFilter::new_value(float value) {
return res; return res;
} }
ClampFilter::ClampFilter(float min, float max) : min_(min), max_(max) {} ClampFilter::ClampFilter(float min, float max, bool ignore_out_of_range)
: min_(min), max_(max), ignore_out_of_range_(ignore_out_of_range) {}
optional<float> ClampFilter::new_value(float value) { optional<float> ClampFilter::new_value(float value) {
if (std::isfinite(value)) { if (std::isfinite(value)) {
if (std::isfinite(this->min_) && value < this->min_) if (std::isfinite(this->min_) && value < this->min_) {
return this->min_; if (this->ignore_out_of_range_) {
if (std::isfinite(this->max_) && value > this->max_) return {};
return this->max_; } else {
return this->min_;
}
}
if (std::isfinite(this->max_) && value > this->max_) {
if (this->ignore_out_of_range_) {
return {};
} else {
return this->max_;
}
}
} }
return value; return value;
} }

View file

@ -411,12 +411,13 @@ class CalibratePolynomialFilter : public Filter {
class ClampFilter : public Filter { class ClampFilter : public Filter {
public: public:
ClampFilter(float min, float max); ClampFilter(float min, float max, bool ignore_out_of_range);
optional<float> new_value(float value) override; optional<float> new_value(float value) override;
protected: protected:
float min_{NAN}; float min_{NAN};
float max_{NAN}; float max_{NAN};
bool ignore_out_of_range_;
}; };
class RoundFilter : public Filter { class RoundFilter : public Filter {

View file

@ -335,6 +335,7 @@ CONF_IDLE_LEVEL = "idle_level"
CONF_IDLE_TIME = "idle_time" CONF_IDLE_TIME = "idle_time"
CONF_IF = "if" CONF_IF = "if"
CONF_IGNORE_EFUSE_MAC_CRC = "ignore_efuse_mac_crc" CONF_IGNORE_EFUSE_MAC_CRC = "ignore_efuse_mac_crc"
CONF_IGNORE_OUT_OF_RANGE = "ignore_out_of_range"
CONF_IGNORE_STRAPPING_WARNING = "ignore_strapping_warning" CONF_IGNORE_STRAPPING_WARNING = "ignore_strapping_warning"
CONF_IIR_FILTER = "iir_filter" CONF_IIR_FILTER = "iir_filter"
CONF_ILLUMINANCE = "illuminance" CONF_ILLUMINANCE = "illuminance"