123456789101112131415161718192021222324252627282930313233343536373839404142434445464748 |
- http://electronix.ru/forum/lofiversion/index.php/t12237.html
- Самый простой способ, аналогичный ФНЧ, т.е. для условий, что сигнал
- низкочастотый и сетевая частота в нём присутствует в виде наводки как
- единственный высокочастоный сигнал:
- Частота дискретизации 1000 Гц;
- Подавляемая частота 50 Гц;
- На одном периоде подавляемой частоты получается 20 отсчетов.
- Для синуса при данных условиях получается, что если брать сумму выборок
- X(n-10)+X(n), то в результате должен получаться ноль.
- Но кроме синуса, какую-то часть веса выборки составляет полезный сигнал и
- простое суммирование приведёт к удвоению его среднего значения. Тогда делаем
- так: (X(n-10)+X(n))/2.
- -=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-
- http://chipenable.ru/index.php/programming-avr/item/162-prostoy-cifrovoy-filtr.html
- По сути, программа этого цифрового фильтра состоит всего из двух строчек на Си.:
- Dacc = Dacc + Din - Dout
- Dout = Dacc/K
- где Dout - выходное значение фильтра, Din - входное значение фильтра, K -
- постоянный коэффициент, который рассчитывается по формуле:
- K = T x SPS
- где T - это постоянная времени фильтра, SPS - частота дискретизации АЦП.
- Dacc и Dout должны сохранять свои значения, после выполнения алгоритма. Если
- алгоритм реализовать в виде функции, то эти переменные можно просто сделать
- статическими.
- Для 8-ми разрядных входных данных алгоритм цифрового фильтра в Си коде может выглядеть так:
- #define SPS 9600UL
- #define Trc 0.001f
- #define K (SPS*Trc)
- uint8_t Filtr(uint8_t data)
- {
- static uint16_t Dacc = 0;
- static uint8_t Dout = 0;
- uint8_t Din = data;
- Dacc = Dacc + Din - Dout;
- Dout = Dacc/(uint16_t)K;
- return Dout;
- }
- ---
- Моё: я думаю, что SPS нужно брать не частоту АЦП, а частоту выборок.
|