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

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

原理

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

注意点

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

下面以一个实例进行说明

信号:x=0.5sin(2pi3t)+cos(2pi10*t),滤除8Hz-12Hz的信号。

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)&&(fs-f2)&m*(fs/N)

yy(m+1)=0;

else

yy(m+1)=y(m+1);

end

end %将频率为8Hz-12Hz的信号的幅值置0

yyi=abs(yy);

figure(3)

plot(f(1:N/2),yyi(1:N/2))

yi=ifft(yy);

figure(4)

plot(t,real(yi))

结果

8cf8d4ad7983773c8f38932dfe52cf38.png

88478062513810879195719a273475c4.png

滤波后

7ae3e4a71b51921f101634c76a7e6ff9.png

444d2f7275196fa54f3a08948576c49a.png

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值