Możesz to filtrować cyfrowo za pomocą filtra dolnoprzepustowego:
int valueFilt = (1-0.99)*value + 0.99*valueFilt;
Zmień 0,99, aby zmienić częstotliwość odcięcia (bliższa 1.0 to niższa częstotliwość). Rzeczywistym wyrażeniem tej wartości jest exp (-2 * pi * f / fs), gdzie f jest pożądaną częstotliwością odcięcia, a fs jest częstotliwością, z której próbkowane są dane.
Innym rodzajem „filtra cyfrowego” jest filtr zdarzeń. Działa dobrze na danych, które mają wartości odstające; np. 9,9,8,10,9,25,9. Filtr zdarzeń zwraca najczęstszą wartość. Statystycznie jest to tryb.
Średnie statystyczne, takie jak średnia, tryb itp. Można obliczyć za pomocą Biblioteki średniej Arduino .
Przykład wzięty ze strony Arduino Library, o którym mowa:
#include <Average.h>
#define CNT 600
int d[CNT];
void setup()
{
Serial.begin(9600);
}
void loop()
{
int i;
for(i=0; i<CNT; i++)
{
d[i] = random(500);
}
Serial.print("Mean: ");
Serial.print(mean(d,CNT),DEC);
Serial.print(" Mode: ");
Serial.print(mode(d,CNT),DEC);
Serial.print(" Max: ");
Serial.print(maximum(d,CNT),DEC);
Serial.print(" Min: ");
Serial.print(minimum(d,CNT),DEC);
Serial.print(" Standard deviation: ");
Serial.print(stddev(d,CNT),4);
Serial.println("");
Serial.println("");
delay(5000);
}