Engee 文档
Notebook

低通和高通滤波器的实现

此演示演示了由以下差分方程定义的两个滤波器的实现:

  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!("功率DBW")
xlabel!("频率兆赫")
Out[0]:

根据信号谱,我们可以看到滤波器工作正常。

结论

在这个例子中,我们已经分析了两种情况下使用相同系数的高通滤波器和低通滤波器之间的差异,从而表明这些滤波器在实现方面存在相当少的差异。