MATLAB中fft函数用法、性质、特性、缺陷全面深入解析(含程序).docx
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- MATLAB fft 函数 用法 性质 特性 缺陷 全面 深入 解析 程序
- 资源描述:
-
______________________________________________________________________________________________________________ MATLAB中fft函数用法、性质、特性、缺陷全面深入解析(含程序) 前言 目前网络上在信号处理方面对fft函数使用泛滥,但大多数人根本就不了解它的性能,使用方法也是千奇百怪,各种程序代码鱼龙混杂,乱七八糟,误导了很多人,所以我在这里进行一下全面的演示说明,希望后来人能够少走弯路。 fft 信号处理中获得时域信号的频域的方法叫做傅里叶变换,但教材上的变换都是理论推导的理想、连续、无限情况,在实际的matlab计算中,必须是实际、离散、有限的计算,所以实现起来比较麻烦,需要各种转换。fft函数就是为了实现快速傅里叶变换而设计的计算机算法,与传统傅里叶变换的步骤不完全一样,但通过适当的变换也能够获得时域信号的频域图形。 fft只是数值计算,不是理论推导,所以频域图形肯定有误差,但我们能够通过适当调整变换参数来提高频域图形的精确性。 建议大家能够理论推导的傅里叶变换就直接在纸上推导好了再用matlab直接画出来就是了。所以不是因为fft精确,而是因为fft能够对大数据复杂信号变换计算快,自由度可控制性高,所以使用的人才多。 fft(x)图示 fft的一些定性问题解析 时域信号x有多少个点,fft(x)就有多少个点,这时的fft(x)之所以是对称的,是因为fft的方法是进行周期计算从-2π,2π,所以后面的一半要翻转到负半轴,是负频率。所以有用的是fft(x)的前一半的点。 我是经过各项测试实验,才完全明白fft的性能。 利用程序解释如下: %这里的fft变换有补零 clear all; Fs = 1e3; %这是原始时域信号x的采样频率 multiple=0.6; %x进行fft前的补零倍数,可以增加频率分辨率 time=2; t = 0:1/Fs:time-1/Fs; %这个会影响x的采样点数,当然点数越多,频域越精确越平滑 %x = 1.5*cos(2*pi*100*t)+3*sin(2*pi*202.5*t)+2*sin(2*pi*1250*t); x = 1.5*cos(2*pi*100*t)+3*sin(2*pi*201.25*t); %频率最小分辨率————————————————- x=[x,zeros(1,length(x)*multiple)]; %{ 注意可以通过对x进行补零来增加频率分辨率,只是因为fft的周期性计算方法,需要在 后面对fft(x)后的数据进行幅度值重新计算时,乘以多的零点的倍数,见后面的幅度值计算。 %} %freqres = Fs/length(x); freqres =1/time; %{ x的频率必须是freqres的整数倍时,x的频率才能被正确分辨,也就是相应频域值才能够正 常,比如freqres=1,在频率202.5处的幅度就不正常,当freqres=2时,在频率1001处的幅 度就不正常。 %} %—————————————————— %{ x有多少个点,fft(x)就有多少个点,这时的fft(x)之所以是对称的,-是因为fft的方法是进行 周期计算从[-2π,2π],所以后面的一半要翻转到负半轴,是负频率。所以有用的是fft(x)的 前一半的点再加上0点。 %} xdft = fft(x); xdft = xdft(1:length(x)/2+1); %————这与fft方法的周期计算方法相关,也就是幅度值要重新计算一下—————— xdft = 1/length(x).*xdft; xdft(2:end-1) = (1+multiple)*2*xdft(2:end-1); %{ 幅度值首先由于周期对称性,需要乘以2,然后由于补零的倍数是multiple,所以是 (1+multiple)*2 %} %重新计算频率横坐标————————————————————————————— freq = 0:Fs/length(x):Fs/2; %{ Fs/2就是最高能够显示出来的频率,但要注意实际上,fft(x)实际是计算出了任何频率, 但是在[Fs/2,Fs]这个区间的频率,是关于Fs/2这里对称的,也就是正负的频率开始混合或者 混叠在一起。而超出了Fs的频率则会由于周期性,它的值先减去Fs后,重新从0点开始。 所以这个程序并不是说画出了在[0,Fs/2]的一定正确的频率,而是可能会出现频率的混合和混叠, 一定要先预判一下频率的区间范围后,再使用fft这个函数。 %} %—————————————————————————— plot(freq,abs(xdft)); %画频域幅度谱 title('频域图'); fft的一些定量详细解析与测试 利用程序解释如下: %为了更好的展示,这里信号没有补零 clear all; clc; Fs = 1e3; %这是原始时域信号x的采样频率 multiple=0; %x进行fft前的补零倍数,可以增加频率分辨率,也会影响信号频域值 time=10; t = 0:1/Fs:time-1/Fs; %这个会影响x的采样点数,当然点数越多,频域越精确越平滑 %x = 1.5*cos(2*pi*100*t)+3*sin(2*pi*202.5*t)+2*sin(2*pi*1450*t); %x = 1.5*cos(2*pi*100*t)+3*sin(2*pi*200*t)+2*cos(2*pi*100000.1*t); x = 1.5*cos(2*pi*100*t)+3*sin(2*pi*200*t)+2*cos(2*pi*0.1*t); %频率最小分辨率————————————————- x=[x,zeros(1,length(x)*multiple)]; %{ 注意可以通过对x进行补零来增加频率分辨率,只是因为fft的周期性计算方法,需要在 后面对fft(x)后的数据进行幅度值重新计算时,乘以多的零点的倍数,见后面的幅度值计算。 %} freqres = Fs/length(x); %{ x的频率必须是freqres的整数倍时,x的频率才能被正确分辨,也就是幅度值才能够正常, 比如freqres=1,在频率202.5处的幅度就不正常,当freqres=2时,在频率1001处的幅度就不正常。 %} %—————————————————— %{ 有多少个点,fft(x)就有多少个点,这时的fft(x)之所以是对称的,- 是因为fft的方法是进行周期计算从[-2π,2π],所以后面的一半要翻转到负半轴, 是负频率。所以有用的是fft(x)的前一半的点再加上0点。 %} xdft = fft(x); subplot(3,1,1);plot(0:length(xdft)-1,abs(xdft));title('abs');title('频域图'); subplot(3,1,2);plot(0:length(xdft)-1,real(xdft));title('real'); subplot(3,1,3);plot(0:length(xdft)-1,imag(xdft));title('imag'); back=ifft(xdft); error=x-back; for i=2:length(xdft)/2 store(i)=abs(xdft(i))-abs(xdft(length(xdft)-i+2)); %这时的误差为0, %store(i)=real(xdft(i+1))-real(xdft(length(xdft)-i+1)); %这时的误差为0, %store(i)=imag(xdft(i+1))+imag(xdft(length(xdft)-i+1)); %这时的误差为0,注意这时是加号 end figure; plot(store);title('正负频率误差'); 首先如上面程序所示,xdft=fft(x),频率分辨率是freqres,设L=length(xdft)=length(x),显示的频率范围是0:freqres:Fs-freqres,点数范围是1,L。xdft的幅度谱在频率范围1*freqres,L2-1*freqres,也就是点数范围2,L2内,是与右边点数范围L,L2+2内的频率的实部是完全对称的,虚部是正负对称的,所以幅度谱是完全对称的。xdft的幅度谱在频率范围L2+1*freqres,L-1*freqres,也就是点数范围L2+2,L,是与左边边点数范围L2,2内的频率的实部是完全对称的,虚部是正负对称的,所以幅度谱是完全对称的,但是这时候左右的正负频率是混叠的,这就是奈奎斯特准则的限制,采样率要大于信号的最高频率才不会出现混叠,因此只有0,Fs2的频率是准确可用的。然后是缺的几个特征点,在频率为0,也就是第1个点的地方,频率虚部为0,实部为实际振幅值的两倍;在频率为L2*freqres=Fs2,也就是点数为L2+1的地方,频率虚部为0,实部为实际振幅值的两倍;在频率为Fs的地方,也就是超出了频率范围,那么这个点的频率值变为Fs-Fs=0,与频率为0时的情况一致;同理,在频率为Fs+freqres的地方,那么这个点的频率值变为Fs+freqres-Fs=freqres,与前面的情况一致,又是一个循环。横轴必须是以Hz单位进行转换。 fft变换存在的缺陷与问题 有人问,为什么我画的频域图与书上的不一样啊,这就是你在对参数进行设置时,没有考虑到它们对于fft变换后的结果的影响,或者根本就没设置正确。不要直接就进行fft变换,变换前必须先估计信号的频率范围,和你想要获得的图形精确程度,然后适当改变参数,确定不会发生下面这些问题。 1. 混叠效应 如果x(t)的频谱是带限的,X(f)=0, |f| > fm,则由抽样定理,抽样间隔最大满足 Ts=1/2fm 如果f(t)的频谱不是带限的,则抽样后频谱总要发生混叠,减小抽样间隔Ts,fs增大,可减小混叠,但工作量增加。 解决办法:预滤波,再抽样,或者一般选择Ts<1/(3~5)fm。 2. 泄漏(leakage) 若X(f)为有限带宽频谱,则x(t)为时间无限的。为利用FFT分析x(t)的频谱,必须截取x(t) 有限范围,即加窗。频域卷积后,使原频带受限的频谱扩展开来(有限带宽拖了尾巴),这种现象称为泄漏。 解决方法:改善窗的形状或长度。 3.栅栏效应(Picket Fence Effect) N点序列的DFT只能在有限的N个频点上观察频谱,这相当于从栅栏的缝隙中观察景色,对于了解信号在整个频域上的特性是不够的。为了观察到其他频率的信息,需要对原信号x[n]做一些处理,以便在不同的频点上采样。 解决方法:增加采样点数,信号补零。 4.补零与fft分辨率 通过补零观察到更多的频点,但是这并不意味着补零能够提高真正的频谱分辨率。这是因为x[n] 实际上是x(t)采样的主值序列,而将x[n]补零得到的x'[n] 周期延拓之后与原来的序列并不相同,也不是x(t)的采样。因此 与 是不同离散信号的频谱。对于补零至M点的x'的DFT,只能说它的分辨率2π/M仅具有计算上的意义, 并不是真正的、物理意义上的频谱。物理频谱分辨率的提高只能在满足采样定理的条件下增加时域采样长度来实现。 5.物理分辨率与计算分辨率 频率分辨率是指所用的算法能将信号中两个考得很近的谱峰保持分开的能力。若信号x(t)的长度为T秒,通过傅里叶变换后得到X(jw),那么X(jw)的频率分辨率是: Δf = 1/T (Hz) 而计算分辨率是 Δf = fs/M (Hz) 当M长度不够时,可以通过对x(t)后面补零,使补零后的序列达到所需要的长度N,但这并没有增加频谱的分辨率,因为有效的数据长度M并没有增加。计算分辨率是靠计算得出的,并不能反映真实的频率分辨能力,与“物理分辨率”是不相同的。 2015年5月22日 BY XUHAO 百度账号:xuhaobestone2 Welcome To Download !!! 欢迎您的下载,资料仅供参考! 精品资料展开阅读全文
咨信网温馨提示:1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前可先查看【教您几个在下载文档中可以更好的避免被坑】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时联系平台进行协调解决,联系【微信客服】、【QQ客服】,若有其他问题请点击或扫码反馈【服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【版权申诉】”,意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:0574-28810668;投诉电话:18658249818。




MATLAB中fft函数用法、性质、特性、缺陷全面深入解析(含程序).docx



实名认证













自信AI助手
















微信客服
客服QQ
发送邮件
意见反馈



链接地址:https://www.zixin.com.cn/doc/2277883.html