首页 > 其他分享 >数字滤波器设计---IIR 滤波器设计

数字滤波器设计---IIR 滤波器设计

时间:2023-11-14 13:00:48浏览次数:40  
标签:滤波器 函数 IIR Wn --- 设计 options


数字滤波器设计---IIR 滤波器设计

IIR 与 FIR 滤波器的比较

与 FIR 滤波器相比,IIR 滤波器的主要优点是,要满足同一组设定,它的滤波器阶数通常远远低于 FIR 滤波器。虽然 IIR 滤波器具有非线性相位,但 MATLAB® 软件中的数据处理通常是“离线”执行的,即整个数据序列在滤波之前是可用的。这允许采用非因果零相位滤波方法(通过 filtfilt 函数),消除 IIR 滤波器的非线性相位失真。

经典 IIR 滤波器

经典的 IIR 滤波器、巴特沃斯滤波器、切比雪夫 I 型和 II 型滤波器滤波器、椭圆滤波器和贝塞尔滤波器都以不同的方式逼近理想的矩形滤波器。

该工具箱提供的函数可在模拟域和数字域以及低通、高通、带通和带阻配置中创建所有上述类型的经典 IIR 滤波器(贝塞尔滤波器除外,因为它仅支持模拟情况)。对于大多数滤波器类型,您还可以在通带和阻带衰减以及过渡宽度方面找到符合给定滤波器设定的最低滤波器阶数。

其他 IIR 滤波器

直接滤波器设计函数 yulewalk 用于设计幅值响应接近特定频率响应函数的滤波器。这是创建多频带带通滤波器的一种方法。

您也可以使用参数化建模或系统辨识函数来设计 IIR 滤波器。这些函数在 Parametric Modeling 中有讨论。

广义巴特沃斯设计函数 maxflat 在 广义巴特沃斯滤波器设计 一节中有讨论。

IIR 滤波器方法概述

下表总结了工具箱中的各种滤波器方法,并列出可用于实现这些方法的函数。

工具箱滤波器方法和可用函数

滤波器方法

描述

滤波器函数

模拟原型

利用经典低通原型滤波器在连续(拉普拉斯)域中的极点和零点,通过频率变换和滤波器离散化获得数字滤波器。

整体设计函数:besselfbuttercheby1cheby2ellip

阶估算函数:buttordcheb1ordcheb2ordellipord

低通模拟原型函数:besselapbuttapcheb1apcheb2apellipap

频率变换函数:lp2bplp2bslp2hplp2lp

滤波器离散化函数:bilinearimpinvar

直接设计

通过逼近分段线性幅值响应,直接在离散时域中设计数字滤波器。

yulewalk

广义巴特沃斯设计

设计零点多于极点的低通巴特沃斯滤波器。

maxflat

参数化建模

设计逼近规定的时域或频域响应的数字滤波器。(请参阅 System Identification Toolbox™ 文档以了解大量的参数化建模工具。)

时域建模函数:lpcpronystmcb

频域建模函数:invfreqsinvfreqz

使用模拟原型的经典 IIR 滤波器设计

该工具箱提供的主要 IIR 数字滤波器设计方法基于将经典低通模拟滤波器转换为其等效的数字滤波器。以下各节说明如何设计滤波器,并总结了支持的滤波器类型的特征。有关滤波器设计过程的详细步骤,请参阅Special Topics in IIR Filter Design

完成经典 IIR 滤波器设计

使用滤波器设计函数,您可以轻松创建具有低通、高通、带通或带阻配置的任意阶滤波器。

滤波器设计函数

滤波器类型

设计函数

Bessel(仅模拟)

[b,a] = besself(n,Wn,options)

[z,p,k] = besself(n,Wn,options)

[A,B,C,D] = besself(n,Wn,options)

巴特沃斯

[b,a] = butter(n,Wn,options)

[z,p,k] = butter(n,Wn,options)

[A,B,C,D] = butter(n,Wn,options)

切比雪夫 I 型

[b,a] = cheby1(n,Rp,Wn,options)

[z,p,k] = cheby1(n,Rp,Wn,options)

[A,B,C,D] = cheby1(n,Rp,Wn,options)

切比雪夫 II 型

[b,a] = cheby2(n,Rs,Wn,options)

[z,p,k] = cheby2(n,Rs,Wn,options)

[A,B,C,D] = cheby2(n,Rs,Wn,options)

椭圆

[b,a] = ellip(n,Rp,Rs,Wn,options)

[z,p,k] = ellip(n,Rp,Rs,Wn,options)

[A,B,C,D] = ellip(n,Rp,Rs,Wn,options)

默认情况下,这些函数都返回低通滤波器;您只需指定所需的截止频率 Wn,以归一化单位表示(使奈奎斯特频率为 1 Hz)。要获得高通滤波器,请将 'high' 附加到函数的参数列表中。要获得带通或带阻滤波器,请将 Wn 指定为包含通带边缘频率的二元素向量。为带阻配置追加 'stop'

以下是一些数字滤波器示例:


[b,a] = butter(5,0.4);                    % Lowpass Butterworth
[b,a] = cheby1(4,1,[0.4 0.7]);            % Bandpass Chebyshev Type I
[b,a] = cheby2(6,60,0.8,'high');          % Highpass Chebyshev Type II
[b,a] = ellip(3,1,60,[0.4 0.7],'stop');   % Bandstop elliptic


要设计一个模拟滤波器(可能是出于仿真需要),请在尾部添加参数 's',以弧度/秒为单位指定截止频率:


[b,a] = butter(5,0.4,'s');      % Analog Butterworth filter

所有滤波器设计函数都会返回一个以传递函数、零极点增益或状态空间线性系统模型形式表示的滤波器,具体形式取决于存在多少输出参数。一般情况下,您应该避免使用传递函数形式,因为可能会发生舍入误差导致的数值问题。更好的做法是使用零极点增益形式,您可以使用 zp2sos 将其转换为二阶节 (SOS) 形式,然后使用 SOS 形式来分析或实现您的滤波器。

注意

所有经典的 IIR 低通滤波器都不适用于极低的截止频率。因此,与其设计通带非常窄的低通 IIR 滤波器,不如设计更宽的通带并抽取输入信号。

按照频域设定设计 IIR 滤波器

此工具箱提供阶选择函数,用于计算满足一组给定要求的最小滤波器阶。

滤波器类型

阶估计函数

巴特沃斯

[n,Wn] = buttord(Wp,Ws,Rp,Rs)

切比雪夫 I 型

[n,Wn] = cheb1ord(Wp,Ws,Rp,Rs)

切比雪夫 II 型

[n,Wn] = cheb2ord(Wp,Ws,Rp,Rs)

椭圆

[n,Wn] = ellipord(Wp,Ws,Rp,Rs)

它们与滤波器设计函数结合使用时非常有用。假设您需要一个具有以下设定的带通滤波器:通带为 1000 至 2000 Hz,阻带从通带两侧外 500 Hz 处开始,采样频率为 10 kHz,通带波纹至多 1 dB,阻带衰减至少 60 dB。您可以通过使用以下 butter 函数来满足这些设定。


[n,Wn] = buttord([1000 2000]/5000,[500 2500]/5000,1,60)
[b,a] = butter(n,Wn);
 
n =
    12
Wn =
    0.1951    0.4080


满足相同要求的椭圆滤波器由下式给出


[n,Wn] = ellipord([1000 2000]/5000,[500 2500]/5000,1,60)
[b,a] = ellip(n,1,60,Wn);
 
n =
    5
Wn =
    0.2000    0.4000


这些函数也适用于其他标准频带配置以及模拟滤波器。

经典 IIR 滤波器类型的比较

工具箱提供五种不同类型的经典 IIR 滤波器,它们各有所长。本部分显示每种滤波器的基本模拟原型形式,并总结了主要特征。

巴特沃斯滤波器

巴特沃斯滤波器提供理想低通滤波器在模拟频率 Ω = 0 和 Ω = ∞ 处的响应的最佳泰勒级数逼近;对于任意阶 N,幅值平方响应在这两个位置的 2N – 1 阶导数为零(即在 Ω = 0 和 Ω = ∞ 处达到最大平坦)。总体而言,响应呈单调形态,从 Ω = 0 到 Ω = ∞ 平稳下降。在 Ω = 1 处,∣H(jΩ)∣=1/√2。

数字滤波器设计---IIR 滤波器设计_信息与通信

切比雪夫 I 型滤波器

切比雪夫 I 型滤波器通过在通带中引入 Rp dB 的等波纹,将整个通带的理想和实际频率响应之间的绝对差降至最低。其阻带响应达到最大平坦度。从通带到阻带的过渡比巴特沃斯滤波器更快。在 Ω = 1 处,∣H(jΩ)∣=10−Rp/20。

数字滤波器设计---IIR 滤波器设计_信息与通信_02

切比雪夫 II 型滤波器

切比雪夫 II 型滤波器通过在阻带中加入 Rs dB 的等波纹,将整个阻带的理想频率响应和实际频率响应之间的绝对差降至最低。其通带响应达到最大平坦度。

阻带不像 I 类滤波器那样快地逼近零(对于偶数滤波器阶 n 则根本不会逼近零)。然而,通带中没有波纹通常是重要优势。在 Ω = 1 处,∣H(jΩ)∣=10−Rs/20。

数字滤波器设计---IIR 滤波器设计_低通滤波器_03

椭圆滤波器

椭圆滤波器在通带和阻带中均采用等波纹。它们通常以任何支持的滤波器类型中的最低阶满足滤波器要求。在给定滤波器阶数 n、以分贝为单位的通带波纹 Rp、以分贝为单位的阻带波纹 Rs 的情况下,椭圆滤波器可以最小化过渡宽度。在 Ω = 1 处,∣H(jΩ)∣=10−Rp/20。

数字滤波器设计---IIR 滤波器设计_低通滤波器_04

贝塞尔滤波器

模拟贝塞尔低通滤波器在零频率处具有最大平坦度的群延迟,并且在整个通带内保持几乎恒定的群延迟。因此,滤波后的信号在通带频率范围内保持其波形。当模拟贝塞尔低通滤波器通过频率映射转换为数字滤波器时,它不再具有这种最大平坦属性。Signal Processing Toolbox™ 仅支持使用完整贝塞尔设计函数实现模拟滤波器。

相比其他滤波器,贝塞尔滤波器通常需要更高的阶数才能获得理想的阻带衰减。在 Ω = 1 处 ∣H(jΩ)∣<1/√2,并且会随着滤波器阶数 n 的增大而减小。

数字滤波器设计---IIR 滤波器设计_低通滤波器_05

注意

上面显示的低通滤波器是用模拟原型函数 besselapbuttapcheb1apcheb2ap 和 ellipap 创建的。这些函数求截止频率为 1 弧度/秒的适当类型的 n 阶模拟滤波器的零点、极点和增益。滤波器整体设计函数(besselfbuttercheby1cheby2 和 ellip)将调用原型函数作为设计过程的第一步。有关详细信息,请参阅 Special Topics in IIR Filter Design

要创建类似的绘图,请使用 n = 5,并根据需要使用 Rp = 0.5 和 Rs = 20。例如,要创建椭圆滤波器图,请使用以下代码:


[z,p,k] = ellipap(5,0.5,20);
w = logspace(-1,1,1000);
h = freqs(k*poly(z),poly(p),w);
semilogx(w,abs(h)), grid
xlabel('Frequency (rad/s)')
ylabel('Magnitude')


直接 IIR 滤波器设计

此工具箱使用直接方法一词来说明 IIR 设计的方法,这些方法基于离散域中的设定设计滤波器。与模拟原型方法不同,直接设计方法不受标准低通、高通、带通或带阻配置的约束。相反,这些函数设计的滤波器具有任意(也许是多频带)频率响应。本部分讨论专门用于滤波器设计的 yulewalk 函数;Parametric Modeling讨论其他也比较直接的方法,如 Prony 方法、线性预测、Steiglitz-McBride 方法和逆频率设计。

yulewalk 函数通过拟合指定的频率响应来设计递归 IIR 数字滤波器。yulewalk 的名称反映其求滤波器分母系数的方法:它求理想的指定幅值平方响应的逆 FFT,并使用所得的自相关函数样本求解修正的尤尔-沃克方程。以下语句


[b,a] = yulewalk(n,f,m)


返回行向量 b 和 a,分别包含 n 阶 IIR 滤波器的 n+1 个分子系数和分母系数,该滤波器的频率幅值特征逼近向量 f 和 m 中给出的频率幅值特征。f 是频率点向量,范围从 0 到 1,其中 1 代表奈奎斯特频率。m 是向量,包含 f 中各点的特定幅值响应。f 和 m 可以说明任何分段线性形状幅值响应,包括多频带响应。此函数的对应 FIR 函数是 fir2,它还基于任意分段线性幅值响应设计滤波器。有关详细信息,请参阅 FIR 滤波器设计

请注意,yulewalk 不接受相位信息,也不对最终滤波器的最佳性做出声明。

使用 yulewalk 设计多频带滤波器,并绘制指定和实际频率响应:


m = [0   0   1   1   0   0   1   1   0 0];
f = [0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 1];
[b,a] = yulewalk(10,f,m);
[h,w] = freqz(b,a,128)
plot(f,m,w/pi,abs(h))


数字滤波器设计---IIR 滤波器设计_低通滤波器_06

广义巴特沃斯滤波器设计

您可以使用工具箱函数 maxflat 设计广义巴特沃斯滤波器,即零点和极点数量不同的巴特沃斯滤波器。这非常适合一些极点比零点计算成本更高的实现。maxflat 与 butter 函数非常相似,区别在于使用前者时,您可以指定两个阶(分子阶与分母阶各一)而不是只指定一个。这些滤波器具有最大平坦度。这表示所得滤波器对于任何分子和分母阶均为最佳,即在 0 处和奈奎斯特频率 ω = π 处的最高阶导数均设置为 0。

例如,当两个阶相同时,maxflat 与 butter 相同:


[b,a] = maxflat(3,3,0.25)
 
b =
    0.0317    0.0951    0.0951    0.0317
a =
    1.0000   -1.4590    0.9104   -0.1978
 
[b,a] = butter(3,0.25)
 
b =
    0.0317    0.0951    0.0951    0.0317
a =
    1.0000   -1.4590    0.9104   -0.1978


但是,maxflat 函数更通用,因为它允许您设计零点多于极点的滤波器:


[b,a] = maxflat(3,1,0.25)
 
b =
    0.0950    0.2849    0.2849    0.0950
a =
    1.0000   -0.2402


maxflat 的第三个输入是半功率频率,该频率介于 0 和 1 之间,幅值响应为 1/√2。

您还可以使用 'sym' 选项设计具有最大平坦度属性的线性相位滤波器:


maxflat(4,'sym',0.3)
 
ans =
    0.0331    0.2500    0.4337    0.2500    0.0331


有关 maxflat 算法的完整细节,请参阅 Selesnick 和 Burrus [2]

标签:滤波器,函数,IIR,Wn,---,设计,options
From: https://blog.51cto.com/oliverHuang/8366489

相关文章

  • 汇编-neg求补(改变正负号)
     neg指令详细解释规则:1.negreg(对寄存器操作)2.negmem(对内存操作)作用:将目的操作数的所以数据位取反加1影响的标志:进位标志(CF),零标志(ZF),符合标志(SF),溢出标志(OF),辅助进位标志(AF),奇偶标志(PF)当操作数为0时,置CF位为0当操作数不为0时,置CF位为1.386.modelflat,stdcalloptionca......
  • 学无止境--linux串口编程(RS485)
    备注:学习记录所用,若有高手不吝赐教,万分感谢!一、概括  linux将串口都映射成了TTY终端,所以在串口编程时,找到并使能平台的TTY,然后操作TTY终端即可。  例如对于Nuclei平台的轩辕91030M芯片设备树: uart0:serial@10013000{ compatible="sifive,uart0"; reg=<0x00x100......
  • C++U4-04-递推2
    上节课作业部分(点击跳转) 排列组合排列 组合:  练习题目 题2 编程题1,用递推求组合数编程题3:[【递推】直线分割平面问题]【算法分析】用a[i]表示i条直线最多能将这个圆分割成的部分数:当i=1时,a[1]=2;当i=2时,a[2]=4;......
  • 读书笔记 -- Junit 实战(3rd)Ch07 用 mock object 进行测试
    8.1mockobject简介隔离测试:最大优点是能编写专门测试单一方法的测试代码,而不会受到被测方法调用某个对象所带来的副作用的影响。mockobject(mocks):非常适合测试与代码的其余部分隔离开的一部分代码。 mocks与隔离测试的区别:mock并不实现任何逻辑,只提供一些方法的空壳,......
  • 以太网通信控制板-A3-控制板作为TCP服务器和电脑TCP客户端通信(连接电脑网线方式, TCP
    <p><iframename="ifd"src="https://mnifdv.cn/resource/cnblogs/CH579_DTU_PBX/index1.html"frameborder="0"scrolling="auto"width="100%"height="1500"></iframe></p> 说明这节......
  • PostCSS通过px2rem插件和lib-flexible将px单位转换为rem(root em)单位实现大屏适配
    目录文档postcss中使用postcss-plugin-px2rem安装postcss-plugin-px2rem示例默认配置webpack中使用postcss-plugin-px2rem项目结构安装依赖文件内容大屏适配参考文章文档类似的插件postcss-plugin-px2remhttps://www.npmjs.com/package/postcss-plugin-px2remhttps://github.com/......
  • WSL2报错:nvidia-smi Command ‘nvidia-smi‘ not found, but can be installed with:
    找了很多方法在社区找了很多方法,结果在b站评论区找到了一个方法给解决了原本一开始有人说是驱动版本问题我nvcc-V是ok的,但是nvidia-smi一直报错,Command‘nvidia-smi’notfound,butcanbeinstalledwith:解决cp/usr/lib/wsl/lib/nvidia-smi/usr/bin/nvidia-smichmodogu+......
  • 前端学习-JavaScrip学习-cookie
    在使用Microsoftedge的时候,运行以下代码会报兼容性错误,但是一直没解决'content-type'headercharsetvalueshouldbe'utf-8'.使用chrome不会存储cookie也没有报错使用火狐可以成功存储cookie<!DOCTYPEhtml><htmllang="en"><head><metacharset="......
  • Programming abstractions in C阅读笔记:p184-p195
    《ProgrammingAbstractionsInC》学习第61天,p184-p195总结。一、技术总结1.mutualrecursion2.naturalnumber(1)定义p184,Ifyoulimitthedomainofpossiblevaluestothesetofnaturalnumbers,whicharedefinedsimplyasthesetofnonnegativeintegers.3.最大公约......
  • VS2017 fail: An XML declaration with an encoding is required for all non-UTF8 do
    VS2017打开一个别人的项目,报错无法打开,提示:AnXMLdeclarationwithanencodingisrequiredforallnon-UTF8documents研究一番,没有找到直接原因。换个思路,是不是IDE版本问题?检查一下项目文件,IDE版本是:VisualStudioVersion=17.5.33414.496这个是VS2022的版本。于是下载安装V......