MATLAB实现傅里叶变换信号滤波详解
创作时间:
作者:
@小白创作中心
MATLAB实现傅里叶变换信号滤波详解
引用
CSDN
1.
https://blog.csdn.net/weixin_44225182/article/details/102488649
运用傅里叶变换对信号进行简单的滤波
原理
将信号进行傅里叶变换可以分析信号中有哪些频率成分,将需要滤除的频率成分的幅值置零,然后进行傅里叶逆变换就可以达到滤波的目的。
注意点
运行FFT进行变换时需要考虑奈奎斯特之后的振幅和相位,进行傅里叶逆变换的时候是取N个点进行变换,而不是取一半。
下面以一个实例进行说明
信号:x=0.5sin(2π3t)+cos(2π10t),滤除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)<(fs-f1));%将奈奎斯特之后的频率也滤除点掉
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))
结果
滤波后
热门推荐
二氧化碳变汽油?真的假的
别人劝你喝酒怎样拒绝
徐州有多火爆?《新华日报》头版聚焦!
首信起诉刘英一案:法律适用与争议焦点解析
AI写作检查原理:深入解析其工作技术与机制
一个妙招解决家庭WiFi覆盖难题!
交通事故车辆检测报告:全面分析事故原因及责任判定
探索不同主人物MBTI性格类型的迷人之旅
如何优化网络的QoS设置
时机管理:提升个人与团队执行力的策略
编程中的mod是什么
郾城之战:胜败之间见真章
郾城之战:岳家军以少胜多的经典战役
激光技术在航天航空领域的应用
中国首次实现星地激光通信超高速数据传输——100Gbps!
如何提高中国移动笔试通过率?
佛教如何看待“欲望”?
2024年1-10月澄海区经济运行情况统计报告
如何增重最快?健康增重3步驟與增胖的錯誤迷思
痛经攻略:告别每月的“痛”苦
佛前发愿,先发这四个大愿
怎样在群晖NAS上设置并管理应用程序的定时任务
《怪物猎人:荒野》铳枪怎么玩 铳枪教学
国寿系私募再扩二期为A股输送弹药!首期500亿元主投高股息蓝筹股
自己动手——做纳豆
电机控制中的热管理:散热技术与设计,让电机系统冷静工作,延长使用寿命
【瑞士步琦】喷雾干燥技术制备利福平可吸入干粉制剂的研究
2025年蛇宝宝乳名大全 属蛇带口的小名100个
Excel中怎么做乘法口诀表
叶黄素和花青素哪个对眼睛好?