Помощь - Поиск - Пользователи - Календарь
Полная версия этой страницы: фильтрация
Форум разработчиков электроники ELECTRONIX.ru > Цифровая обработка сигналов - ЦОС (DSP) > Алгоритмы ЦОС (DSP)
Dubov
Слышал тезис что при обработке блоков данных конечной длины например КИХ фильтром появляются "проблемы на краях сигнала". Я несовсем понял, но кажется речь шла о переходных процессах.
Вопрос как обрабатывать данные непрерывно? Скажем хочу промоделировать эти процессы на компьютере. Пишу программу на Си, которая заполняет массив (вместо реального АЦП). Данные нужно обрабатывать КИХ фильтром.
Как сделать "по уму"?
Я хочу сделать так: по указателю считать N отсчётов -> отфильтровать -> затем взять ещё N отсчётов - > отфильтровать....
evil_laugh
Цитата(Dubov @ Dec 21 2012, 14:26) *
Слышал тезис что при обработке блоков данных конечной длины например КИХ фильтром появляются "проблемы на краях сигнала". Я несовсем понял, но кажется речь шла о переходных процессах.
Вопрос как обрабатывать данные непрерывно? Скажем хочу промоделировать эти процессы на компьютере. Пишу программу на Си, которая заполняет массив (вместо реального АЦП). Данные нужно обрабатывать КИХ фильтром.
Как сделать "по уму"?
Я хочу сделать так: по указателю считать N отсчётов -> отфильтровать -> затем взять ещё N отсчётов - > отфильтровать....

Для непрерывной обработки данных потребуется циклический буфер длиной N, где N - кол-во коэфф-тов импульсной хар-ки фильтра. Вдвигаете в буфер отсчёт вх. сигнала, перемножаете буфер с ИХ фильтра, произведения суммируете. Краевой эффект будет заметен при недостаточной длине фильтра.

Цитата(Dubov @ Dec 21 2012, 14:26) *
Я хочу сделать так: по указателю считать N отсчётов -> отфильтровать -> затем взять ещё N отсчётов - > отфильтровать....


Получите ужосчто. Циклическая свёртка вместо линейной. Сигнал фильтровать нужно непрерывно, а не блоками. Для этого и нужен сдвиговый буфер.

Если хотите делать фильтрацию в частотной области, то гугль по ключ. слову overlap-save Вам в помощь.
beaRTS
по поводу кольцевого буфера/адресации делал гиф анимацию, а так же расписывал алгоритм такого ких фильтра-дециматора. коль интересно гляньте здесь

сам блоки данных не обрабатывал.
о краевом эффекте не наслышан.. только когда фильтр не полностью сперва "загружен" входными отсчетами (а именно пока во входном буфере нет половины длины импульсной характеристики), то наблюдался переходный процесс, а потом тишь-гладь.
Dubov
Цитата(evil_laugh @ Dec 21 2012, 18:44) *
Для непрерывной обработки данных потребуется циклический буфер длиной N, где N - кол-во коэфф-тов импульсной хар-ки фильтра. Вдвигаете в буфер отсчёт вх. сигнала, перемножаете буфер с ИХ фильтра, произведения суммируете. Краевой эффект будет заметен при недостаточной длине фильтра.



Получите ужосчто. Циклическая свёртка вместо линейной. Сигнал фильтровать нужно непрерывно, а не блоками. Для этого и нужен сдвиговый буфер.


то что вы описали - это тоже длоками по N отсчётов(пусть N = кол-во к-ф фильтра).

так как же тогда на Си реализовать сдвиговый буфер?
или, если я правильно понял, делать нужно так: при каждой итеррации в умножениях участвуют N-1 старых отсчётов и один новый?
не до конца понимаю...
Serg76
Цитата(Dubov @ Dec 21 2012, 20:03) *
или, если я правильно понял, делать нужно так: при каждой итеррации в умножениях участвуют N-1 старых отсчётов и один новый?
не до конца понимаю...

именно так
Для просмотра полной версии этой страницы, пожалуйста, пройдите по ссылке.
Invision Power Board © 2001-2025 Invision Power Services, Inc.