【新要闻】简述滤波器设计规格对象函数fdesign的使用方法 1
1.1 滤波器设计流程
本文展示了如何使用Matlab中滤波器设计规格对象函数fdesign
的使用方法。根据fdesign
创建的滤波器规格对象,可以使用design
函数直接设计滤波器。
(资料图)
滤波器的设计、分析以及在数据流上的应用的示意图如下所示:
具体的步骤如下所示:
步骤一:创建一个fdesign.response
规格对象用以表述滤波器设计参数;步骤二:使用designmethods
确定针对滤波器规格队形的滤波器设计方法;步骤三:如果想要进一步修改滤波器的参数,可以查看designoptions
函数的使用方法,进行具体的滤波器参数设置。步骤四:使用design
方法从滤波器规格对象设计一个滤波器,并以步骤二中的设计方法作为输入。如果需要修改设计选项值,需要指定名称-值
对的方式向design
函数中传递参数;另外,如果在调用design
函数时,没有指定任何输出参数,则将默认启动滤波器可视化工具FVTool
,并现实设计滤波器的幅值响应。步骤五:至此,我们就可以进一步查看设计的滤波器分析结果包括:频率响应、损失函数、滤波器响应特征测量值等。具体的可以参考Analysis Methods for Filter System Objects。步骤六:经过滤波器分析、设计后,我们就可以将滤波器对象应用于输入数据流。1.2 滤波器设计规格对象函数fdesign的语法
fdesign
函数的使用语法主要包括如下四种方式:
designSpecs = fdesign.response
:返回一个具有特定响应(response
)的滤波器设计规格对象(design specification object)。(2)designSpecs = fdesign.response(spec)
:指定用于定义滤波器设计的变量spec
。(3)designSpecs = fdesign.response(___, Fs)
:指定设计滤波器的采样频率()。注意:Fs
参数必须作为最后一个参数。(4)designSpecs = fdesign.response(___, magunits)
:指定输入参数的幅值单位。二、低通滤波器设计与性能分析
示例:设计一个采样频率为的低通滤波器,低通滤波器的参数规格如下所示:
通带频率为;阻带频率为;通带波动为;阻带衰减为。低通滤波器的阶数可以根据参数规格自动的配置。
2.1 低通滤波器的设计
首先,使用fdesign.lowpass
函数设置低通滤波器规格对象,Matlab代码如下所示:
Fs = 96e3; % 采样频率Fpass = 20e3; % 通带频率Fstop = 24e3; % 阻带频率Apass = 0.01; % 通带波纹Astop = 80; % 阻带衰减% 使用fdesign.lowpass函数得到滤波器规格对象filtSpecsfiltSpecs = fdesign.lowpass( ... Fpass, ... % 通带频率 Fstop, ... % 阻带频率 Apass, ... % 通带波纹 Astop, ... % 阻带衰减 Fs); % 采样频率
然后,使用designmethods
函数可以输出针对滤波器规格对象filtSpecs
可用的滤波器设计方法,Matlab代码如下所示:
% 查看可用的滤波器设计方法designmethods(filtSpecs, "SystemObject", true)
该代码的执行结果如下图所示:
下面,使用design
函数设计两个满足规格的低通滤波器:
!! ✨ 注意:
design
函数的返回值是一个dsp.FIRdecimator
系统对象,Matlab代码如下所示:
等波纹FIR低通滤波器滤波器的实现代码如下所示:
lpFIR = design(filtSpecs, "equiripple", "SystemObject", true)
代码输出如下图所示:
椭圆IIR低通滤波器的实现代码如下所示:
lpIIR = design(filtSpecs, "ellip", "SystemObject", true)
代码输出结果如下图所示:
2.2 低通滤波器的分析
最后,我们可以使用如下函数对设计的滤波器进行分析与可视化:
measure
函数:测量滤波器系统对象的频率响应特性,对于低通滤波器,该函数测量的滤波器指标如下表所示:频率响应特性 | 描述 |
---|---|
Sample Rate | 滤波器采样频率 |
Passband Edge | 通带进入过渡时的边缘位置 |
3-dB Point | 响应曲线上-3dB点的位置 |
6-dB Point | 响应曲线上-6dB点的位置 |
Stopband Edge | 过渡带进入阻带时的边缘位置 |
Passband Ripple | 通带波纹 |
Stopband Atten | 阻带衰减 |
Transition Width | 通带与阻带之间的过渡宽度 |
cost
函数:评估滤波器系统对象的实现计算成本,并返回一个包含计算成本评估值的结构体,返回值包含的内容如下表所示:计算成本评估值 | 描述 |
---|---|
NumCoefficients | 滤波器系数的数量,不包含 |
NumStates | 滤波器状态的数量 |
MultiplicationsPerInputSample | 每个输入样本执行乘法运算的数量 |
AdditionsPerInputSample | 每个输入样本执行加法运算的数量 |
fvtool
:对滤波器进行可视化并直观地比较不同滤波器的性能。(1)滤波器频率响应特性测量
等波纹FIR低通滤波器滤波器的频率响应特性测量代码如下所示:
FIRmeas = measure(lpFIR)
等波纹FIR低通滤波器滤波器的频率响应特性测量结果如下图所示:
椭圆IIR低通滤波器的频率响应特性测量代码如下所示:
IIRmeas = measure(lpIIR)
椭圆IIR低通滤波器的频率响应特性测量结果如下图所示:
(2)滤波器计算成本评估
等波纹FIR低通滤波器滤波器的计算成本评估代码如下所示:
FIRcost = cost(lpFIR)
等波纹FIR低通滤波器滤波器的计算成本评估结果如下图所示:
椭圆IIR低通滤波器的计算成本评估代码如下所示:
IIRcost = cost(lpIIR)
椭圆IIR低通滤波器的计算成本评估结果如下图所示:
(3)滤波器频率响应可视化
下面使用fvtool
对等波纹FIR低通滤波器滤波器与椭圆IIR低通滤波器进行可视化处理,代码如下所示:
hvft = fvtool(lpFIR, lpIIR, "Fs", Fs);legend(hvft, "等波纹FIR低通滤波器", "椭圆IIR低通滤波器")
两个滤波器的可视化结果如下图所示: