c++ - 计算二阶巴特沃斯低通滤波器的系数

标签 c++ signal-processing

随着,

采样频率:10kHz
截止频率:1kHz

我实际上如何计算下面差分方程的系数?

我知道差分方程将采用这种形式,但不知道如何实际计算出系数 b0、b1、b2、a1、a2 的数字

y(n)  =  b0.x(n) + b1.x(n-1) + b2.x(n-2) + a1.y(n-1) + a2.y(n-2)

我最终会在 C++ 中实现这个 LPF,但我需要先知道如何实际计算系数,然后才能使用它

最佳答案

给你。 ff 是频率比,在您的情况下为 0.1:

    const double ita =1.0/ tan(M_PI*ff);
    const double q=sqrt(2.0);
    b0 = 1.0 / (1.0 + q*ita + ita*ita);
    b1= 2*b0;
    b2= b0;
    a1 = 2.0 * (ita*ita - 1.0) * b0;
    a2 = -(1.0 - q*ita + ita*ita) * b0;

结果是:

b0=0.0674553
b1=0.134911
b2=0.0674553
a1=1.14298
a2=-0.412802

关于c++ - 计算二阶巴特沃斯低通滤波器的系数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20924868/

相关文章:

matlab - Matlab 中的局部最大值

java - 从低通滤波转换

c++ - 为什么 std::get() 不能用于获取 vector 的成员?

c++ - OpenMP:如何在任务中实现线程本地对象?

c++ - 接收 HTTP header

c++ - 为什么 C++ 不自动使用 operator== 而不是 operator!=

c++ - 多态性从基类调用函数

c# - MathNet.Filter 不过滤数据

python - 使用 LSTM 对使用 Keras 的可变长度信号进行多标签分类

audio - 信号/声音处理:使文本振动成音乐