运用傅里叶变换对信号进行简单的滤波

该博客介绍了通过傅里叶变换进行信号滤波的基本原理和MATLAB实现步骤。首先,解释了如何通过傅里叶变换分析信号的频率成分,并将不需要的频率成分设置为零。接着,展示了MATLAB代码,该代码创建了一个包含两个频率成分的信号,然后滤除了8Hz到15Hz之间的频率。最后,通过傅里叶逆变换得到滤波后的时域信号。代码包括了对原始信号的时域和频域显示,以及滤波后信号的频域和时域展示。
摘要由CSDN通过智能技术生成

原理:将信号进行傅里叶变换可以信号中有哪些频率成分,将需要滤除的频率成分的幅值置零,然后进行傅里叶逆变换就可以达到滤波的目的。

注意点:运行FFT进行变换时需要考虑奈奎斯特之后的振幅和相位,进行傅里叶逆变换的时候是取N个点进行变换,而不是取一半。

下面以一个实例进行说明:

信号:x=0.5*sin(2*pi*3*t)+cos(2*pi*10*t),滤除8Hz-15Hz的信号,程序运行的结果如下:

​​​​​​​​​​​​​​

 ​​​​​​​


图1是原始时域信号,图2是原始频域信号,图3是滤波后的频域信号,图4是经过IFFT之后得到的滤波后的时域信号

源代码如下:

clc,clear
dt=0.02;%采样间隔
N=512;%采样点数
t=0:dt:(N-1)*dt;%采样时刻
fs=1/dt;%采样频率,与才采样间隔互为倒数
n=0:1:N-1;
f=(fs/N).*n;%X轴每个点对应的频率
x=0.5*sin(2*pi*3*t)+cos(2*pi*10*t);%信号
figure(1)
plot(t,x) %显示原始信号的时域图
y=fft(x);%傅里叶变换得到一个复数
Ay=abs(y);%取模
Ayy=Ay*2/N;%转换成实际的幅值
figure(2)
plot(f(1:N/2),Ayy(1:N/2)) %显示原始信号的频域图
f1=8;
f2=15;
yy=zeros(1,length(y));
for m=0:N-1
   if(m*(fs/N)>f1&m*(fs/N)<f2|m*(fs/N)>(fs-f2)&m*(fs/N)<(fs-f1));%将奈奎斯特之后的频率也滤除点掉
       yy(m+1)=0; %将【f1,f2】频率段信号的幅值置0
   else
       yy(m+1)=y(m+1); %其它频率段保持原样
   end
end      
yyi=abs(yy)*2/N; %滤波后频域的幅值
figure(3)
plot(f(1:N/2),yyi(1:N/2)) %显示滤波后的频域图
yi=ifft(yy); %对滤波后的信号进行傅里叶反变换
figure(4)
plot(t,real(yi)) %显示滤波后的时域图
评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Dfreedom.

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值