MinMaxScaler
This filtering unit regularizes incoming signals by remapping them into a new interval of [0, 1]. It does so by keeping track of the minimum and the maximum values ever taken by the signal and rescales it such that the minimum value of the signal is mapped to 0 and the maximum value is mapped to 1.
In order to accommodate signals that might be changing through time, the user can specify a “decay time window” to control the rate of decay of the minimum and maximum boundaries. The principle is similar to the how the Smoother and the Normalizer make use of exponential moving average.
Caution
This filtering unit works well as long as there are no “outliers” in the signal (ie. extreme values) that appear in rare conditions. Such values will replace the minimum or maximum value and greatly restrict the spread of the filtered values.
There are three ways to prevent this:
Specifying a decay window using the
time(decayTime)
function.Smoothing incoming values using the
smooth()
method or a Smoother unit before sending to theMinMaxScaler
.Using a regularization unit that is less prone to outliers such as the Normalizer.
Example
Reacts to high input values by activating an output LED. Scaler is used to automatically adapt to incoming sensor values.
#include <Plaquette.h>
AnalogIn sensor(A0);
MinMaxScaler scaler;
DigitalOut led(13);
void begin() {}
void step() {
// Rescale value.
sensor >> scaler;
// Light led on threshold of 80%.
(scaler > 0.8) >> led;
}
Reference
-
class MinMaxScaler : public MovingFilter
Regularizes signal into [0,1] by rescaling it using the min and max values.
Public Functions
-
MinMaxScaler()
Constructor.
-
virtual void infiniteTimeWindow()
Sets time window to infinite.
-
virtual void timeWindow(float seconds)
Changes the time window (expressed in seconds).
-
virtual float timeWindow() const
Returns the time window (expressed in seconds).
-
virtual bool timeWindowIsInfinite() const
Returns true if time window is infinite.
-
virtual void reset()
Resets the moving filter.
-
virtual float put(float value)
Pushes value into the unit.
If isRunning() is false the filter will not be updated but will just return the filtered value.
- Parameters:
value – the value sent to the unit
- Returns:
the new value of the unit
-
virtual void resumeCalibrating()
Switches to calibration mode (default).
Calls to put(value) will return filtered value AND update the normalization statistics.
-
virtual void pauseCalibrating()
Switches to non-calibration mode: calls to put(value) will return filtered value without updating the normalization statistics.
-
virtual bool isCalibrating() const
Returns true iff the moving filter is in calibration mode.
-
inline virtual float get()
Returns value in [0, 1].
-
MinMaxScaler()