简述滤波器设计规格对象函数fdesign的使用方法 1

电子说

1.3w人已加入

描述

1.1 滤波器设计流程

本文展示了如何使用Matlab中滤波器设计规格对象函数fdesign的使用方法。根据fdesign创建的滤波器规格对象,可以使用design函数直接设计滤波器。

滤波器的设计、分析以及在数据流上的应用的示意图如下所示:

matlab

具体的步骤如下所示:

  • 步骤一: 创建一个fdesign.response规格对象用以表述滤波器设计参数;
  • 步骤二: 使用designmethods确定针对滤波器规格队形的滤波器设计方法;
  • 步骤三: 如果想要进一步修改滤波器的参数,可以查看designoptions函数的使用方法,进行具体的滤波器参数设置。
  • 步骤四: 使用design方法从滤波器规格对象设计一个滤波器,并以步骤二中的设计方法作为输入。如果需要修改设计选项值,需要指定名称-值对的方式向design函数中传递参数;另外,如果在调用design函数时,没有指定任何输出参数,则将默认启动滤波器可视化工具FVTool,并现实设计滤波器的幅值响应。
  • 步骤五: 至此,我们就可以进一步查看设计的滤波器分析结果包括:频率响应、损失函数、滤波器响应特征测量值等。具体的可以参考Analysis Methods for Filter System Objects。
  • 步骤六: 经过滤波器分析、设计后,我们就可以将滤波器对象应用于输入数据流。

1.2 滤波器设计规格对象函数fdesign的语法

fdesign函数的使用语法主要包括如下四种方式:

  • (1)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函数得到滤波器规格对象filtSpecs
filtSpecs = fdesign.lowpass( ...
    Fpass, ...  % 通带频率
    Fstop, ...  % 阻带频率
    Apass, ...  % 通带波纹
    Astop, ...  % 阻带衰减
    Fs);        % 采样频率

然后,使用designmethods函数可以输出针对滤波器规格对象filtSpecs可用的滤波器设计方法,Matlab代码如下所示:

% 查看可用的滤波器设计方法
designmethods(filtSpecs, 'SystemObject', true)

该代码的执行结果如下图所示:

matlab

下面,使用design函数设计两个满足规格的低通滤波器:

  • 等波纹FIR低通滤波器(equiripple);
  • 椭圆IIR低通滤波器。

!! ✨ 注意: design函数的返回值是一个dsp.FIRdecimator系统对象,Matlab代码如下所示:

等波纹FIR低通滤波器滤波器的实现代码如下所示:

lpFIR = design(filtSpecs, 'equiripple', 'SystemObject', true)

代码输出如下图所示:

matlab

椭圆IIR低通滤波器的实现代码如下所示:

lpIIR = design(filtSpecs, 'ellip', 'SystemObject', true)

代码输出结果如下图所示:

matlab

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低通滤波器滤波器的频率响应特性测量结果如下图所示:

matlab

椭圆IIR低通滤波器的频率响应特性测量代码如下所示:

IIRmeas = measure(lpIIR)

椭圆IIR低通滤波器的频率响应特性测量结果如下图所示:

matlab

(2)滤波器计算成本评估

等波纹FIR低通滤波器滤波器的计算成本评估代码如下所示:

FIRcost = cost(lpFIR)

等波纹FIR低通滤波器滤波器的计算成本评估结果如下图所示:

matlab

椭圆IIR低通滤波器的计算成本评估代码如下所示:

IIRcost = cost(lpIIR)

椭圆IIR低通滤波器的计算成本评估结果如下图所示:

matlab

(3)滤波器频率响应可视化

下面使用fvtool对等波纹FIR低通滤波器滤波器与椭圆IIR低通滤波器进行可视化处理,代码如下所示:

hvft = fvtool(lpFIR, lpIIR, 'Fs', Fs);
legend(hvft, '等波纹FIR低通滤波器', '椭圆IIR低通滤波器')

两个滤波器的可视化结果如下图所示:

matlab

打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分