我要发布
仪器网/ 仪器社区/ 滤波器/ 如何用MATLAB做一个低通滤波器?

如何用MATLAB做一个低通滤波器?

寂寞在流浪zre    2009-12-02    滤波器    浏览 331 次

幅度|H|=1,0=

精彩问答
梦色未央 发布日期:2017-09-06
滤波器有很多种设计方式。Z简单的,就是用已有的buttord计算出Z符合条件的巴特沃思滤波器的阶数n和截止频率,再用butter计算n阶巴特沃斯数字滤波器系统函数分子、分母多项式的系数向量b、a。用freqz函数画出滤波器的幅频、相频图。用filter滤波。
例:
  规定:wp为通带截止频率;ws为阻带截止频率;ap为通带Z大衰减(dB);as为阻带Z大衰减(dB);wc为3dB截止频率;fn为采样率;
  滤波器设计条件:通带Z大衰减ap=1dB,阻带Z小衰减as=15dB,通带截止频率为wp=2000Hz,阻带截止频率为ws=5000Hz
  代码:
  fn=16000;
  ap=0.1;
  as=60;
  wp=2000;
  ws=5000; %输入滤波器条件
  wpp=wp/(fn/2);wss=ws/(fn/2); %归一化;
  [nwn]=buttord(wpp,wss,ap,as); %计算阶数截止频率
  [ba]=butter(n,wn); %计算N阶巴特沃斯数字滤波器系统函数分子、分母多项式的系数向量b、a。
  freqz(b,a,512,fn);%做出H(z)的幅频、相频图
  t =(1:1000)/16000;
  x=cos(4000*pi*t)+cos(6000*pi*t); %输入信号
  figure(2);
  subplot(2,1,1);
  plot(t,x); %合成信号时域波形
axis([0 0.01 -22])
X=fft(x); %进行傅里叶变换
subplot(2,1,2);
plot(abs(X));
y=filter(b,a,x); %滤波b、a滤波器系数,x滤波前序列
figure(3);
subplot(2,1,1); %
plot(t,y); %分离输出信号的时域波形
axis([0 0.01 -1.51.5]);
subplot(2,1,2);
plot(t,cos(4000*pi*t));%cos(4000*pi*t)理论时域波形
axis([0 0.01 -1.51.5])
被采纳
qmkfgkli8464 发布日期:2017-09-24 12:37:51
采用Kaiser窗设计
>> wp=2000*2*pi/10000;ws=2500*2*pi/10000;As=50;这里的衰减是自己随便设计的,你可以改
>> tr_width=ws-wp;
>> M=ceil((As-7.95)/(14.36*tr_width/(2*pi))+1)+1
>> n=[0:1:M-1];;
>> beta=0.1102*(As-8.7)
>> wc=(ws+wp)/2;
>> hd=ideal_lp(wc,M);
>> w_kai=(kaiser(M,beta))';
>> h=hd.*w_kai;
对了,你还要加上一个M文件,
function hd=ideal_lp(wc,M);
%Ideal Lowpass filter computation
%------------------------------------
%[hd]=ideal_lp(wc,M)
% hd=ideal impulse response between 0 to M-1
% wc=cutoff frequency in radians
% M=length of the ideal filter
%
alpha=(M-1)/2;
n=[0:1:(M-1)];
m=n-alpha+eps;
hd=sin(wc*m)./(pi*m);
全部评论
陪猫去看硫酸雨 发布日期:2009-12-03
命令行下面输入:fdatool

产生的界面里,把你的参数放进去即可

然后file- export

一个滤波器就设计好了。
最新主题
相关版块
我要评论
X您尚未登录
账号登录
X您尚未登录
手机动态密码登录
X您尚未登录
扫码登录
官方微信

仪器网微信服务号

扫码获取最新信息


仪器网官方订阅号

扫码获取最新信息

在线客服

咨询客服

在线客服
工作日:  9:00-18:00
联系客服 企业专属客服
电话客服:  400-822-6768
工作日:  9:00-18:00
订阅商机

仪采招微信公众号

采购信息一键获取海量商机轻松掌控