教学文库网 - 权威文档分享云平台
您的当前位置:首页 > 精品文档 > 高等教育 >

基于matlab的IIR数字滤波器设计(doc 19页)(正式版)

来源:网络收集 时间:2026-05-01
导读: 基于matlab的IIR数字滤波器设计 一. IIR数字滤波器介绍 1.IIR数字滤波器的基本原理 所谓数字滤波器,是指输入,输出均为数字信号,通过一定运算关系改变输入信号所含频率成分的相对比例或者滤除某些频率成分的硬件。实质上就是一个由有限精度算法实现的线性

基于matlab的IIR数字滤波器设计

一. IIR数字滤波器介绍 1.IIR数字滤波器的基本原理

所谓数字滤波器,是指输入,输出均为数字信号,通过一定运算关系改变输入信号所含频率成分的相对比例或者滤除某些频率成分的硬件。实质上就是一个由有限精度算法实现的线性时不变离散系统。它的基本工作原理是利用离散系统的特性对系统输入信号进行加工和变换,改变输入序列的频谱或信号波形,让有用的频率分量通过,抑制无用的信号分量输出,因此数字滤波与模拟滤波的概念相同,根据其频率特性同样可以分为低通,高通,带通,带阻,只是信号的形式和实现滤波方式有所不同。如果要处理的信号是模拟信号,就可以通过A/D或者D/A转换,在信号形式上进行匹配转换,同样可以使用数字滤波器对模拟信号进行滤波。

数字滤波器滤波的数学表达式:y(n)=x(n)*h(n); 如果滤波器的输入输出信号都是离散信号,那么该滤波器的脉冲响应也一定是离散信号,这样的滤波器就成为了数字滤波器。

上面的系统为时域离散系统时,其频域特性为:

其中分别是数字滤波器的输出序列和输入序列的频域响应,是数字滤波器的频域响应。可以看见按照输入信号的频谱特点和处理信号的目的适当选择滤波器的频域响应,使得滤波后的输出信号满足设计性能要求,就是滤波器的滤波原理。 2.IIR数字滤波器传输特性

IIR数字滤波器的系统函数可以表示为:H(Z)=,式中H(Z)称为N阶IIR滤波器函数。 3..数字滤波器的技术要求.

我们通常设计的数字滤波器一般属于选频滤波器,。

我们的目的是要设计一个因果可实现的滤波器,另外买也要考虑到成本和复杂性问题,因此实用中通带和阻带都允许一定的误差容限,即通带不一定是完全水平的,阻带也不可能完全衰减到零。而且,通带和阻带之间还要设置一定带宽的过渡带。如下图表示低通滤波器的技术要求: 图中, 分别表示通带截止频率和阻带截止频率,通带频率范围为0≤w≤,通带中要求(1-δ1)≤|H≤1,阻带截止频率范围≤w≤Π,再阻带中要求≤δ2,从到称为过渡带,在这个频带内,幅度响应从通带平滑的下落到阻带。 二. IIR数字滤波器的设计方法 1.常用的IIR滤波器设计方法

(1). 以模拟滤波器函数为基础的变换法;即先设计一满足指定条件的模拟滤波器H(s),再将该模拟滤波器转化为数字滤波器H(z)。

(2). 直接设计法:在z平面内,根据零、极点对系统特性的影响,调整零极点位置得H(z)。

(3). 最优化设计法(计算机辅助设计),在某种最小化误差准则下,建立差分方程系数 a k、b i 对理想特性的逼近方程,使用迭代方法解方程组得到最佳逼近系统。由于此方法计算量大,需要借助于计算机进行设计。

下面分别介绍函数设计法和信号处理图形界面来设计IIR数字滤波器,得出最优化的设计方法。 2.基于matlab的函数设计IIR数字滤波器

IIR数字滤波器设计的一般方法是先设计低通模拟滤波器,进行频率变换,将其转换为相应的(高通,带通等)模拟滤波器,在转换为高通,带通或带阻数字滤波器,由模拟滤波器设计数字滤波器的方法。这是因为模拟滤波器设计方法已经很成熟,它不仅有完整的设计公式,还有完善的图表供查阅,另外,还有一些典型的滤波器类型可供我们使用。对设计的全过程的各个步骤,MATLAB都提供了了相应的工具箱函数,使IIR数字滤波器设计变得非常简单。 2.1. 基于matlab函数的IIR滤波器设计 2.1.1.设计方法选择:

程序设计法是基于MATLAB中相应的工具箱函数来实现的,IIR数字滤波器的设计步骤可由图1.2所

示的流程图来表示。

这个图也清晰的表示了5类20个信号处理工具箱函数的作用,

在MATLAB中,模拟滤波器的系统函数

B(1)SM?B(2)SM?1?......?B(M)S?B(M?1)B(S)H(S)= ?NN?1A(S)A(1)S?A(2)S?.....?A((N)S?A(N?1)数字滤波器的系统函数

B(1)?B(2)Z?1?.....?B(M)Z?(M?1)?B(M?1)Z?MB(Z)H(Z)= ??1?(N?1)?NA(Z)A(1)?A(2)Z?.....?A(N)Z?A(N?1)Z在实际工程中,需要的设计结果是系数向量B和A,用B和A来综合滤波器的硬件实现结构或软件

运算结构,为了直观的看出设计结果,本文的实例均以滤波器幅频响应曲线作为设计结果输出。如果需要滤波器系数,在运行程序后,只要在MATLAB命令窗口键入系数向量名,则相应的系数就显示出来了。 2.1.2.程序设计实例分析

(a)设计高通和带通Butterworth数字滤波器

我们给出四阶归一化 Butterworth模拟滤波器的系统函数 H(S)?1

S4?2.6131S3?3.4142S2?2.6131S?1jw用双线性变换法从Ha(s)设计四阶带通butterworth数字滤波器HBP(Z),并图示|HBP(e)|, 设计采样周期T=1s,指标如下

w1c?0.35?,wuc?0.65?

现在我们分步进行:■建模 由于本例主要涉及三个问题: (1) 由数字滤波器指标求相应的模拟滤波器指标; (2) 模拟滤波器频率变换(因为已给定阶数和模拟滤波器的归一化低通原型); (3) 由相应的模拟滤波器到数字滤波器(双线性变换法)。

由于调用bilinear函数将模拟滤波器转换成数字滤波器非常容易,并且有效抑制频率失真的问题,本例给定了数字滤波器指标,所以首先要设计处与该指标相应的四阶Butterworth模拟滤波器,然后调用bilinear函数将其转换为数字滤波器即可,应当特别注意的是,对于双线性变换法,由数字边界频率求相应的模拟边界频率时,一定要考虑预畸变矫正。只有这样,最终设计结果才能满足所给指标, (ⅰ)首先按照步骤一的要求

设计高通数字滤波器时,相应的模拟高通滤波器3dB截止频率为 ?C?w2tg(c) T2 设计带通数字滤波器时,相应的模拟滤波器的3dB截止频率为 ?LC?ww22tg(lc),?uc?tg(uc) T2T2(ⅱ)步骤二的的原理

可调用MATLAB频率变换函数lp2lp,lp2hp,lp2bp,分别实现从模拟低通到模拟低通,高通,带通,带阻的频率变换。

▲【Bt,At】=lp2hp(B,A,wc),将系数向量为B和A的模拟滤波器归一化低通原型(3Db)截止频频为1rad/s),变换成3dB截止频率为wc的高通模拟滤波器,返回高通模拟滤波器系数向量Bt和At。

▲【Bt,At】=lp2bp(B,A,wo,Bw)将系数向量为B和A的模拟滤波器归一化低通原型变换成中心频率为wo,带宽为Bw的带通模拟滤波器,返回带通模拟滤波器的系数向量Bt和At。 其中,wo=?lc?uc ,Bw??uc??lc

由以上原理我们来编写如下程序:

%用双线性变换法设计数字高通和带通滤波器 clear;close all

T=1;wch=pi/2; %T为采样间隔,wch位数字高通3dB截止频率 wlc=0.35*pi;wuc=0.65*pi; %wlc,wuc;数字高通3dB截止频率 B=1;A=[1,2.6131,3.4142,2.6131,1];

[h,w]=freqs(B,A,512); %求原归一化模拟滤波器的频率响应 subplot(3,2,1);plot(w,20*log10(abs(h))); %画模拟滤波器幅频特性 grid;axis([0,10,-90,0])

xlabel('w/ ');ylabel('模拟低通幅度(dB)') %(1)设计高通

omegach=2*tan(wch/2)/T; %预畸变求模拟高通3dB截止频率 [Bhs,Ahs]=lp2hp(B,A,omegach); %模拟域低通转换为高通系数 [Bhz,Ahz]=bilinear(Bhs,Ahs,1/T); %模拟转换位数字高通系数变量 [h,w]=freqz(Bhz …… 此处隐藏:3670字,全部文档内容请下载后查看。喜欢就下载吧 ……

基于matlab的IIR数字滤波器设计(doc 19页)(正式版).doc 将本文的Word文档下载到电脑,方便复制、编辑、收藏和打印
本文链接:https://www.jiaowen.net/wendang/616239.html(转载请注明文章来源)
Copyright © 2020-2025 教文网 版权所有
声明 :本网站尊重并保护知识产权,根据《信息网络传播权保护条例》,如果我们转载的作品侵犯了您的权利,请在一个月内通知我们,我们会及时删除。
客服QQ:78024566 邮箱:78024566@qq.com
苏ICP备19068818号-2
Top
× 游客快捷下载通道(下载后可以自由复制和排版)
VIP包月下载
特价:29 元/月 原价:99元
低至 0.3 元/份 每月下载150
全站内容免费自由复制
VIP包月下载
特价:29 元/月 原价:99元
低至 0.3 元/份 每月下载150
全站内容免费自由复制
注:下载文档有可能出现无法下载或内容有问题,请联系客服协助您处理。
× 常见问题(客服时间:周一到周五 9:30-18:00)