Dubov 0 21 декабря, 2012 Опубликовано 21 декабря, 2012 · Жалоба Слышал тезис что при обработке блоков данных конечной длины например КИХ фильтром появляются "проблемы на краях сигнала". Я несовсем понял, но кажется речь шла о переходных процессах. Вопрос как обрабатывать данные непрерывно? Скажем хочу промоделировать эти процессы на компьютере. Пишу программу на Си, которая заполняет массив (вместо реального АЦП). Данные нужно обрабатывать КИХ фильтром. Как сделать "по уму"? Я хочу сделать так: по указателю считать N отсчётов -> отфильтровать -> затем взять ещё N отсчётов - > отфильтровать.... Цитата Поделиться сообщением Ссылка на сообщение Поделиться на другие сайты Поделиться
evil_laugh 0 21 декабря, 2012 Опубликовано 21 декабря, 2012 · Жалоба Слышал тезис что при обработке блоков данных конечной длины например КИХ фильтром появляются "проблемы на краях сигнала". Я несовсем понял, но кажется речь шла о переходных процессах. Вопрос как обрабатывать данные непрерывно? Скажем хочу промоделировать эти процессы на компьютере. Пишу программу на Си, которая заполняет массив (вместо реального АЦП). Данные нужно обрабатывать КИХ фильтром. Как сделать "по уму"? Я хочу сделать так: по указателю считать N отсчётов -> отфильтровать -> затем взять ещё N отсчётов - > отфильтровать.... Для непрерывной обработки данных потребуется циклический буфер длиной N, где N - кол-во коэфф-тов импульсной хар-ки фильтра. Вдвигаете в буфер отсчёт вх. сигнала, перемножаете буфер с ИХ фильтра, произведения суммируете. Краевой эффект будет заметен при недостаточной длине фильтра. Я хочу сделать так: по указателю считать N отсчётов -> отфильтровать -> затем взять ещё N отсчётов - > отфильтровать.... Получите ужосчто. Циклическая свёртка вместо линейной. Сигнал фильтровать нужно непрерывно, а не блоками. Для этого и нужен сдвиговый буфер. Если хотите делать фильтрацию в частотной области, то гугль по ключ. слову overlap-save Вам в помощь. Цитата Поделиться сообщением Ссылка на сообщение Поделиться на другие сайты Поделиться
beaRTS 0 21 декабря, 2012 Опубликовано 21 декабря, 2012 (изменено) · Жалоба по поводу кольцевого буфера/адресации делал гиф анимацию, а так же расписывал алгоритм такого ких фильтра-дециматора. коль интересно гляньте здесь сам блоки данных не обрабатывал. о краевом эффекте не наслышан.. только когда фильтр не полностью сперва "загружен" входными отсчетами (а именно пока во входном буфере нет половины длины импульсной характеристики), то наблюдался переходный процесс, а потом тишь-гладь. Изменено 21 декабря, 2012 пользователем beaRTS Цитата Поделиться сообщением Ссылка на сообщение Поделиться на другие сайты Поделиться
Dubov 0 21 декабря, 2012 Опубликовано 21 декабря, 2012 · Жалоба Для непрерывной обработки данных потребуется циклический буфер длиной N, где N - кол-во коэфф-тов импульсной хар-ки фильтра. Вдвигаете в буфер отсчёт вх. сигнала, перемножаете буфер с ИХ фильтра, произведения суммируете. Краевой эффект будет заметен при недостаточной длине фильтра. Получите ужосчто. Циклическая свёртка вместо линейной. Сигнал фильтровать нужно непрерывно, а не блоками. Для этого и нужен сдвиговый буфер. то что вы описали - это тоже длоками по N отсчётов(пусть N = кол-во к-ф фильтра). так как же тогда на Си реализовать сдвиговый буфер? или, если я правильно понял, делать нужно так: при каждой итеррации в умножениях участвуют N-1 старых отсчётов и один новый? не до конца понимаю... Цитата Поделиться сообщением Ссылка на сообщение Поделиться на другие сайты Поделиться
Serg76 0 21 декабря, 2012 Опубликовано 21 декабря, 2012 · Жалоба или, если я правильно понял, делать нужно так: при каждой итеррации в умножениях участвуют N-1 старых отсчётов и один новый? не до конца понимаю... именно так Цитата Поделиться сообщением Ссылка на сообщение Поделиться на другие сайты Поделиться