Документация Engee
Notebook

Реализация фильтров нижних и верхних частот

Открыть пример в Engee

В данной демонстрации показаны реализации двух фильтров, заданных следующими разностными уравнениями:

  1. Фильтр нижних частот: y(n) = 0,5x(n) + 0,5x(n-1) (усреднение)
  2. Фильтр верхних частот: y(n) = 0,5x(n) - 0,5x(n-1) (конечная разность)

На рисунке ниже показана модель из которой мы видим, что для фильтров даны общие коэффициенты и главные их отличия заключены в последнем сумматоре.

image.png

Далее для запуска модели применим вспомогательную функцию.

In [ ]:
function run_model( name_model)
    
    Path = (@__DIR__) * "/" * name_model * ".engee"
    
    if name_model in [m.name for m in engee.get_all_models()] # Проверка условия загрузки модели в ядро
        model = engee.open( name_model ) # Открыть модель
        model_output = engee.run( model, verbose=true ); # Запустить модель
    else
        model = engee.load( Path, force=true ) # Загрузить модель
        model_output = engee.run( model, verbose=true ); # Запустить модель
        engee.close( name_model, force=true ); # Закрыть модель
    end
    sleep(5)
    return model_output
end

run_model("hipass_lopass") # Запуск модели.
Building...
Progress 25%
Progress 100%
Progress 100%
Progress 100%
Out[0]:
Dict{String, DataFrames.DataFrame} with 2 entries:
  "hipass" => 20001×2 DataFrame…
  "lopass" => 20001×2 DataFrame

Проанализируем записанные результаты построив графики сигналов во временной и в частотной областях.

In [ ]:
hipass = collect(simout["hipass_lopass/hipass"]);
lopass = collect(simout["hipass_lopass/lopass"]);

plot(hipass.time[1:500], [hipass.value[1:500], lopass.value[1:500]],label=["Фильтр нижних частот" "Фильтр верхних частот"])
Out[0]:

Как мы видим исходя из данных представленных во временной области, главные отличия между данными на выходе фильтров верхних и нижних частот, это различия в амплитуде сигналов и неравномерности колебательных импульсов, данную тенденцию мы наблюдаем при использовании фильтров верхних частот.

In [ ]:
using FFTW

Comp_hipass = ComplexF64.(hipass.value);
Comp_lopass = ComplexF64.(lopass.value);

spec_hipass = fftshift(fft(Comp_hipass));
spec_lopass = fftshift(fft(Comp_lopass));

x = [10log10.(abs.((spec_hipass/3e6))),10log10.(abs.((spec_lopass/3e6)))];
plot(x, label =["Фильтр нижних частот" "Фильтр верхних частот"])
ylabel!("Мощность дБВт")
xlabel!("Частота МГц")
Out[0]:

Исходя из спектров сигналов мы видим, что фильтры работают корректно.

Вывод

В данном примере мы разобрали различия между фильтрами верхних частот и фильтрами нижних частот используя в обоих случаях одни и те же коэффициенты, тем самым показали, что различий между этими фильтрами в плане реализации достаточно мало.

Блоки, использованные в примере