Jestem doświadczonym inżynierem oprogramowania i pracuję nad czujnikami smartfonów. Chodziłem na podstawowe zajęcia EE z DSP i staram się wykorzystać swoją wiedzę. Wierzę, że rozumiem splot, funkcje przenoszenia, transformację Z itp. Wiem trochę o filtrach FIR i IIR.
Teraz, czytając API i dokumentację oprogramowania, widzę, że ludzie stosują LPF do czujników danych w dziedzinie czasu. Wiem, że robisz to za pomocą równań różnicowych (np. Y [i] = y [i-1] + 2 * x [i]), ale nauczyłem się w mojej klasie EE, że LPF są zwykle stosowane poprzez operację splotu gdzie zwołujesz sygnał czasowy ze współczynnikami fali cynkowej (na przykład) i określoną częstotliwością odcięcia. Dlatego potoczne użycie „filtra dolnoprzepustowego” nie jest dla mnie wystarczająco dokładne.
Na przykład interfejs API Google Android ma tę dokumentację: http://developer.android.com/reference/android/hardware/SensorEvent.html#values
public void onSensorChanged(SensorEvent event)
{
// alpha is calculated as t / (t + dT)
// with t, the low-pass filter's time-constant
// and dT, the event delivery rate
final float alpha = 0.8;
gravity[0] = alpha * gravity[0] + (1 - alpha) * event.values[0];
gravity[1] = alpha * gravity[1] + (1 - alpha) * event.values[1];
gravity[2] = alpha * gravity[2] + (1 - alpha) * event.values[2];
linear_acceleration[0] = event.values[0] - gravity[0];
linear_acceleration[1] = event.values[1] - gravity[1];
linear_acceleration[2] = event.values[2] - gravity[2];
}
Jak interpretować ten filtr dolnoprzepustowy? Jaka jest częstotliwość odcięcia? Jaka jest przepustowość przejścia? Czy używają tego LPF wyłącznie do uśredniania?