Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.52/29: Рейтинг темы: голосов - 29, средняя оценка - 4.52
0 / 0 / 0
Регистрация: 10.09.2018
Сообщений: 28

Фильтр Баттерворта

25.12.2018, 00:30. Показов 6195. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
День добрый!

Задача написать функцию фильтрации сигнала на плюсах. Фильтр - фильтр Баттерворта, 10 порядка. Коэффициенты высчитывались матлабом. Столкнулся с тем, что при одинаковых сигналах и коэффициентов моя функция уходит в бесконечность, когда та же функция в матлабе - считает все правильно.
код матлаба:
Matlab M
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
function [Y, z]  = my_otherFilter(b,a, X, z)
%X - входной сигнал
% b,a  - коэффициенты
% Y - выходной 
 
n    = length(a);
z(n) = 0;      % Creates zeros if input z is omitted
b = b / a(1);  
a = a / a(1);
Y    = zeros(size(X));
for m = 1:length(Y)
   Y(m) = b(1) * X(m) + z(1);
   for i = 2:n
      
      z(i - 1) = b(i) * X(m) + z(i) - a(i) * Y(m);
   end
end
z = z(1:n - 1);
 
end
Здесь обрабатывается сразу весь массив, когда на плюсах - каждое новое значение. И загружаются значения коэффициентов из текстового файла (коэффициенты верные, если что ).
z- вектор начальных значений, устанавливается на ноль.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
void filter(std::vector<double>&input, std::vector<double>&output,std::string way_for_filter_koeff) {
    static std::vector<double> a, b;
    static bool first_loading = 1;
    int order = 10;
    
    if (first_loading) {
        
        std::ifstream input(way_for_filter_koeff);
        double koef;
        for (size_t i = 0; i <= order; i++) {
            input >> koef;
            b.push_back(koef);
        }
 
        for (size_t i = 0; i <= order; i++) {
            input >> koef;
            a.push_back(koef);
        }
        first_loading = 0;
    }
    
    order = a.size();
    static std::vector<double>z;
    
    for (int i  = 0;i<order;i++)
        z.push_back(0);      // Creates zeros if input z is omitted
    if (a.at(0) != 1) {
        for (int i = 0; i < order; i++) {
            b.at(i) /= a.at(0);  
            a.at(i) /= a.at(0);
        }
    }
    
    double new_sample = 0;
        new_sample = b.at(0) * *(input.end()-1) + z.at(0);
        
        for (int i = 1; i < order; i++) {
            z.at(i - 1) = b.at(i) * *(input.end() - 1) + z.at(i) - a.at(i) * new_sample;
            
        }
        z.erase(z.end() - 1);
 
        std::ofstream out("filtered.txt", std::ios::app);
        out << new_sample << std::endl;
        output.push_back(new_sample);
 
};
Применялось для фильтрации сигнала экг.
Коэффициенты высчитывались через функцию butter(...) в Матлабе([b,a] = butter(5,[4.5,150]/360), и через fdatool. Частота дискретизации 360. граничные частоты - 4.5 и 150. Ломаю голову, где ошибка который день.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
25.12.2018, 00:30
Ответы с готовыми решениями:

фильтр Баттерворта
Добрый вечер! Подскажите пожалуйста, с программой столкнулась в первые. у Меня есть текстовый файл в котором лежит сигнал ЭКГ, который...

Фильтр Баттерворта
Добрый день. Делаю курсовую, все рассчитала, надо проверить ФНЧ в MathCad. Не пойму где ошибка. В файле то что получается у меня и то...

Фильтр Баттерворта
Доброго времени суток! Подскажите, пожалуйста, как рассчитать коэффициенты полосового фильтра Баттерворта 8-го порядка методом...

1
Мозгоправ
 Аватар для L0M
1745 / 1039 / 468
Регистрация: 01.10.2018
Сообщений: 2,138
Записей в блоге: 2
25.12.2018, 09:26
Я ничего не понимаю в обработке сигналов, не знаю что такое фильтр Баттерворта и не имел дела с Матлабом, однако...

У вас в С++ написана очевидная лажа. Как минимум: в матлабе Y - это массив (угадал?), в C++ - одиночное значение; не вижу цикла по m (строка 11 матлаба). Ну и ещё всяко-разно.

Если вы покажете файл с коэффициентами, а также файл со входными значениями и файл с выходными значениями, посчитанными в матлабе, тогда можно продолжать разговор. Иначе это гадание на кофейной гуще.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
25.12.2018, 09:26
Помогаю со студенческими работами здесь

Фильтр Баттерворта и Чебышева 2 порядка для заданного сигнала
Здравствуйте, имеется сигнал ЭГГ с наложенной на него помехой. Нужно отфильтровать сигнал с помощью фильтра Батерворта и Чебышева 2...

Дан фильтр Баттерворта 3-го порядка,средняя частота 100кГц,полоса режекции 10кГц
Дан фильтр Баттерворта 3-го порядка,средняя частота 100кГц,полоса режекции 10кГц. Как построить для него дискретный фильтр??? кто может...

Реализация ФНЧ Баттерворта
есть ли у кого уже готовый код расчета фильтра?

Расчет фильтра Баттерворта
Привет всем! Сколько не искал,не могу найти верный алгоритм расчета фильтра Баттерворта 4 порядка. Можете подсказать или скинуть...

ЛАЧХ, АЧХ Фильтра Баттерворта
Что я делаю не так? Помогите,пожалуйста. Алгоритм использую вот этот


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru