在matlab中使用不同的窗函数构造FIR数字低通滤波器

目的:
1.通过窗函数法设计FIR滤波器
2.使用窗函数法设计FIR滤波器,了解窗函数的形式和长度对滤波器性能的影响。

原理:
ex5.1

实现环境:
Matlab

理想低通滤波器设计:

function my_output=ideallp(wc,N)
%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=(N-1)/2;
n=0:1:(N-1);
m=n-alpha+eps;
my_output=sin(wc*m)./(pi*m);
end
  1. Boxcar窗
wp=0.2*pi;                          
ws=0.3*pi;                         
deltaw=ws-wp;                     
N=ceil(1.8*pi/deltaw);              
wc=(wp+ws)/2;                       
hd=ideallp(wc,N);                    
wd1=boxcar(N)';                     
h1=hd.*wd1;                         
[H1,w]=freqz(h1,1);                
plot(w/pi,20*log10(abs(H1)));
title('矩形窗');

得到频率响应曲线如下:

2.Kaiser窗
wp=0.2*pi;
ws=0.5*pi;
As=50;                              
deltaf=(ws-wp)/(2*pi);
N=ceil((As-7.95)/(14.36*deltaf))+1; %
beta=0.1102*(As-8.7); 
wdkai=kaiser(N,beta)';
wc=(ws+wp)/2;
hd=ideallp(wc,N);
h=hd.*wdkai;
[H,w]=freqz(h,1);
plot(w/pi,20*log10(abs(H)));
title('凯泽窗');

得到频率响应图像如下:

3.triang窗
wp=0.2*pi;                          %
ws=0.3*pi;
As=50;
deltaw=ws-wp;
N=ceil(6.1*pi/deltaw);
wdtri=triang(N)';
wc=(wp+ws)/2;
hd=ideallp(wc,N);
h=hd.*wdtri;
[H,w]=freqz(h,1);
plot(w/pi,20*log10(abs(H)));
title('Triang');

得到频率响应图像如下:

4.hanning窗 wp=0.2*pi; % ws=0.3*pi; As=50; deltaw=ws-wp; N=ceil(6.2*pi/deltaw); wdhann=hanning(N)’; wc=(wp+ws)/2; hd=ideallp(wc,N); h=hd.*wdhann; [H,w]=freqz(h,1); plot(w/pi,20*log10(abs(H))); title(‘Hanning’); 得到频率响应图像如下:
5.hamming窗
wp=0.2*pi;                          %
ws=0.3*pi;
As=50;
deltaw=ws-wp;
N=ceil(6.6*pi/deltaw);
wdhamm=hamming(N)';
wc=(wp+ws)/2;
hd=ideallp(wc,N);
h=hd.*wdhamm;
[H,w]=freqz(h,1);
plot(w/pi,20*log10(abs(H)));
title('Hamming');

得到频率响应图像如下:

6.blackman窗
wp=0.2*pi;                          %
ws=0.3*pi;
As=50;
deltaw=ws-wp;
N=ceil(6.1*pi/deltaw);
wdblack=blackman(N)';
wc=(wp+ws)/2;
hd=ideallp(wc,N);
h=hd.*wdblack;
[H,w]=freqz(h,1);
plot(w/pi,20*log10(abs(H)));
title('Blackman');

得到频率响应图像如下:


一、 主瓣的宽度由N决定,旁瓣的衰减由窗函数的形状决定。
二、 Kaiser的不同在于可以同时调整主瓣宽度和旁瓣衰减,这是其他窗函数不具备的。

三、 实际滤波的应用
设置初始信号为10Hz的余弦与40Hz余弦叠加而成的信号,分别采用以上滤波方法滤波。

  1. boxcar
%初始信号
t=0:0.01:2;
y=cos(2*pi*10*t)+cos(2*pi*40*t);
subplot(2,1,1);
plot(t,y);
title('initial signal');
yfft=fftshift(fft(y));
w=-50:0.5:50;
subplot(2,1,2);
plot(w,abs(yfft));
axis([0 50 0 100]);
title('frequence');
 %滤波器内容
wp=0.2*pi;                          
ws=0.3*pi;                         
deltaw=ws-wp;                      
N=ceil(1.8*pi/deltaw);            
wc=(wp+ws)/2;                       
hd=ideallp(wc,N);                 
wd1=boxcar(N)';                   
h1=hd.*wd1;
final=fftfilt(h1,y,200);
  %滤波之后的信号
figure;
subplot(2,1,1);
plot(final);
title('processed signal');
ynfft=fftshift(fft(final));
subplot(2,1,2);
plot(w,abs(ynfft));
axis([0 50 0 100]);
title('frequence filted');

运行结果如下:
初始信号如下


处理后信号如下:


可见40Hz分频成分明显降低,而10Hz分频保留较好。
同理,更改代码中的滤波器部分分别得到下面几个滤波结果对比
2. Kaiser

t=0:0.01:2;
y=cos(2*pi*10*t)+cos(2*pi*40*t);
w=-50:0.5:50;

wp=0.2*pi;
ws=0.5*pi;
As=50;                              %
deltaf=(ws-wp)/(2*pi);
N=ceil((As-7.95)/(14.36*deltaf))+1; %
beta=0.1102*(As-8.7); 
wdkai=kaiser(N,beta)';
wc=(ws+wp)/2;
hd=ideallp(wc,N);
h=hd.*wdkai;

final=fftfilt(h1,y,200);
subplot(2,1,1);
plot(final);
title('processed signal');
ynfft=fftshift(fft(final));
subplot(2,1,2);
plot(w,abs(ynfft));
axis([0 50 0 100]);
title('frequence filted');
3. Triang
t=0:0.01:2;
y=cos(2*pi*10*t)+cos(2*pi*40*t);
w=-50:0.5:50;

wp=0.2*pi;                          %
ws=0.3*pi;
As=50;
deltaw=ws-wp;
N=ceil(6.1*pi/deltaw);
wdtri=triang(N)';
wc=(wp+ws)/2;
hd=ideallp(wc,N);
h=hd.*wdtri;

final=fftfilt(h1,y,200);
subplot(2,1,1);
plot(final);
title('processed signal');
ynfft=fftshift(fft(final));
subplot(2,1,2);
plot(w,abs(ynfft));
axis([0 50 0 100]);
title('frequence filted');


  1. Hanning
t=0:0.01:2;
y=cos(2*pi*10*t)+cos(2*pi*40*t);
w=-50:0.5:50;

wp=0.2*pi;                          %
ws=0.3*pi;
As=50;
deltaw=ws-wp;
N=ceil(6.2*pi/deltaw);
wdhann=hanning(N)';
wc=(wp+ws)/2;
hd=ideallp(wc,N);
h=hd.*wdhann;

final=fftfilt(h1,y,200);
subplot(2,1,1);
plot(final);
title('processed signal');
ynfft=fftshift(fft(final));
subplot(2,1,2);
plot(w,abs(ynfft));
axis([0 50 0 100]);
title('frequence filted');
5. Hamming
t=0:0.01:2;
y=cos(2*pi*10*t)+cos(2*pi*40*t);
w=-50:0.5:50;

wp=0.2*pi;                          %
ws=0.3*pi;
As=50;
deltaw=ws-wp;
N=ceil(6.6*pi/deltaw);
wdhamm=hamming(N)';
wc=(wp+ws)/2;
hd=ideallp(wc,N);
h=hd.*wdhamm;

final=fftfilt(h1,y,200);
subplot(2,1,1);
plot(final);
title('processed signal');
ynfft=fftshift(fft(final));
subplot(2,1,2);
plot(w,abs(ynfft));
axis([0 50 0 100]);
title('frequence filted');
6. Blackman
t=0:0.01:2;
y=cos(2*pi*10*t)+cos(2*pi*40*t);
w=-50:0.5:50;

wp=0.2*pi;                          %
ws=0.3*pi;
As=50;
deltaw=ws-wp;
N=ceil(6.1*pi/deltaw);
wdblack=blackman(N)';
wc=(wp+ws)/2;
hd=ideallp(wc,N);
h=hd.*wdblack;

final=fftfilt(h1,y,200);
subplot(2,1,1);
plot(final);
title('processed signal');
ynfft=fftshift(fft(final));
subplot(2,1,2);
plot(w,abs(ynfft));
axis([0 50 0 100]);
title('frequence filted');


不同滤波方式衰减过程不同,但由于此次信号只有两个分频,体现的不太明显。

  • 43
    点赞
  • 345
    收藏
    觉得还不错? 一键收藏
  • 8
    评论
设计一个FIR线性相位低通数字滤波器,可以按照以下步骤进行: 1. 确定滤波器的截止频率(cutoff frequency)和采样频率(sampling frequency)。 2. 计算滤波器的阶数(order),可以根据巴特沃斯公式或者窗函数法进行计算。 3. 选择一个矩形窗(rectangular window),这个窗口的长度应该与滤波器的阶数相等。 4. 计算出矩形窗的系数(window coefficients),这个系数可以通过以下公式计算: h(n) = sin(2πfc(n-(M-1)/2)) / (π(n-(M-1)/2)) 其,fc是滤波器的截止频率,M是滤波器的阶数。 5. 将计算出来的系数应用到滤波器,得到滤波器的传递函数(transfer function)。 6. 使用MATLAB的filter函数将滤波器应用到信号,得到滤波后的结果。 下面是一个具体的MATLAB代码示例,用于设计一个FIR线性相位低通数字滤波器: ```matlab % 设计一个FIR线性相位低通数字滤波器 % 采样频率为8kHz,截止频率为1kHz fs = 8000; fc = 1000; % 计算滤波器的阶数 order = 40; % 构造矩形窗 win = rectwin(order+1)'; % 计算窗口系数 n = 0:order; h = sin(2*pi*fc*(n-(order)/2))/(pi*(n-(order)/2)); h((order+1)/2) = 2*fc/fs; h = h.*win; % 使用MATLAB的freqz函数查看滤波器特性 freqz(h,1,1024,fs); % 使用filter函数将滤波器应用到信号 x = randn(1,10000); y = filter(h,1,x); % 绘制滤波前后的信号图形 t = 0:1/fs:(length(x)-1)/fs; figure; subplot(2,1,1); plot(t,x); title('原始信号'); subplot(2,1,2); plot(t,y); title('滤波后的信号'); ``` 运行这段代码后,会生成一个滤波器特性的频谱图和一个滤波前后的信号图形。可以根据自己的需要修改代码的采样频率、截止频率、滤波器阶数等参数。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值