我是靠谱客的博主 沉静宝马,最近开发中收集的这篇文章主要介绍用matlab做巴特沃斯低通滤波器用matlab做巴特沃斯低通滤波器第一步:做出原信号的频谱函数,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

用matlab做巴特沃斯低通滤波器

趁着暑假,做一个心电图的matlab实验,遇到了滤波器问题,网上代码比较杂乱,做了一个汇总整理。
主要做了一个简单的低通滤波器并以三角函数为例子进行低通滤波。

基本数据

fk=100  %采样频率
N=1024  %采样个数
n=-N/2:N/2-1
f=n*fk/N
t=n/fk
y=sin(2*pi*10*t)

当然 f也可以表示成 f=linspace(-fk/2,fk/2,N);

第一步:做出原信号的频谱函数

注意:用fft函数作频谱分析,得到的是0~fk内的频谱
而用fftshift函数得到-fk/2~fk/2内的频谱

fft_y=fft(y);
fftshift_y=fftshift(fft_y);
f=linspace(-50,50,1024);
plot(f,abs(fftshift_y));

在这里插入图片描述

第二步:做出巴特沃斯低通滤波器

用buttord函数求出阶数以及Wn

butter函数是求Butterworth数字滤波器的系数,在求出系数后对信号进行滤波时用filter函数
[g,Wn]=buttord(Wp,ws,Rp,Rs);
Wp=fp/(0.5fk)=20/50=0.4(通带截至频率)
Ws=fs/(0.5*fk)=30/50=0.6(阻带截止频率)
Rp=1; 通带最大衰减
Rs=30; 阻带最小衰减
代码如下:

[g,Wn]=buttord(0.4,0.6,1,30);

用butter 求出差分方程的系数b a

不懂差分方程及filter用法的朋友可以点以下链接,参考这位大佬的理解
差分方程介绍

[b,a]=butter(g,Wn);

至此 准备工作都做完了 ,来看看这滤波器的相频特性啥样子

滤波器的相频特性

 [q,w]=freqz(b,a,256);
 plot(w*fs/(2*pi),abs(q))

所以说 咱写出来的滤波器长这个样子
20Hz为通带截至频率
30Hz为阻带截至频率
在这里插入图片描述

第三步:用滤波器过滤信号 并得出频谱图

用filter过滤

用filter函数就能把原信号y过滤成k函数 ,需要注意的是,它们都是时域函数,需要进行fft变换才能看到频谱图

 k=filter(b,a,y);
 fft_k=fft(k);
 fftshift_k=fftshift(fft_k);
 plot(f,abs(fftshift_k));

过滤后的结果如下:
在这里插入图片描述
没错,没变!我们低通滤波器允许20Hz以下的信号不变,而我们原信号的频率就是10Hz!

对高频的信号的低通滤波

这里就不赘述了,对y=sin(2pi40*t)的信号,依然用上面的低通过滤的结果如下图:
在这里插入图片描述
不要看它长的怪,注意一下幅值,约等于0,即把40Hz的信号过滤掉了!
行文至此,点个赞呗亲!

最后

以上就是沉静宝马为你收集整理的用matlab做巴特沃斯低通滤波器用matlab做巴特沃斯低通滤波器第一步:做出原信号的频谱函数的全部内容,希望文章能够帮你解决用matlab做巴特沃斯低通滤波器用matlab做巴特沃斯低通滤波器第一步:做出原信号的频谱函数所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(43)

评论列表共有 0 条评论

立即
投稿
返回
顶部