Float output: Fix min_power and max_power adjusting when output is inverted (#1250)

This patch fixes faulty behaviour when both, invert and min_power/max_power
are set for a float output (e.g. PWM). The current code scales the output
level to the range [min_power, max_power] and subsequently inverts the value.
This leads to values that are outside the range [min_power, max_power].

This patch fixes the problem by inverting the requested level first and then
scaling it to the interval [min_power, max_power].

Co-authored-by: Thomas Niederprüm <niederp@physik.uni-kl.de>
This commit is contained in:
dubit0 2020-10-02 00:55:42 +02:00 committed by GitHub
parent dbec3d7c50
commit 002861f13b
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -29,10 +29,9 @@ void FloatOutput::set_level(float state) {
this->power_.unrequest(); this->power_.unrequest();
} }
#endif #endif
float adjusted_value = (state * (this->max_power_ - this->min_power_)) + this->min_power_;
if (this->is_inverted()) if (this->is_inverted())
adjusted_value = 1.0f - adjusted_value; state = 1.0f - state;
float adjusted_value = (state * (this->max_power_ - this->min_power_)) + this->min_power_;
this->write_state(adjusted_value); this->write_state(adjusted_value);
} }