matlab——FFT傅里叶快速变换
目錄
一、自身的理解與補(bǔ)充
二、其他參考鏈接
一、轉(zhuǎn)載:https://blog.csdn.net/u013215903/article/details/48091359
FFT是Fast Fourier Transform(快速傅里葉變換)的簡稱,這種算法可以減少計(jì)算DFT(離散傅里葉變換,關(guān)于此更詳細(xì)的說明見后文)的時(shí)間,大大提高了運(yùn)算效率,并曾經(jīng)一度被認(rèn)為是信號分析技術(shù)劃時(shí)代的進(jìn)步,其重要性由此可見一斑。閑話少敘,言歸正傳。
基于FFT在信號分析中的重要性,其必然會(huì)成為MATLAB的座上賓。FFT算法在MATLAB中實(shí)現(xiàn)的函數(shù)是Y=fft(x,n)。剛接觸頻譜分析用到FFT時(shí),幾乎都會(huì)對MATLAB的fft函數(shù)產(chǎn)生一些疑惑,本文本著從問題出發(fā)的原則,主要著手對一下幾個(gè)問題進(jìn)行解釋:
(一)fft函數(shù)計(jì)算得到的Y是輸入信號x的頻譜嗎?如果不是還要經(jīng)過怎樣的變換?為什么要除以N。
(二)如何計(jì)算Y對應(yīng)的頻率f,并繪制(f,Y)頻譜圖?
(三)如何根據(jù)離散信號的長度確定n的數(shù)值?
下面以MATLAB幫助文檔中的例子來一一看這幾個(gè)問題。
1、關(guān)于問題(一)
程序(1)處為何要除以信號的采樣長度L?
由Fourier變換對
可知,fft函數(shù)直接計(jì)算得到的X(k)并不是頻譜幅值。
在x(j)的Fourier級數(shù)(3)中,諧波分量
對應(yīng)的幅值為X(k)/N,因此必須對fft得到的結(jié)果除以離散信號的長度N才能得到頻譜幅值。
2、關(guān)于問題(三)
程序(1)處,fft函數(shù)的第二個(gè)參數(shù)NFFT為何取值
NFFT = 2^nextpow2(L);其含義是取不小于L的最小的2的冪。之所以這樣取值是因?yàn)镕FT算法要求信號的長度為2的冪,當(dāng)NFFT大于信號長度時(shí),fft函數(shù)以零補(bǔ)齊。
由(2)可知幅值譜只取了前半部分,并且還要乘以倍數(shù)2。也就是說頻譜幅值是
2*abs(Y(1:NFFT/2+1))這是因?yàn)樾盘柕念l譜是前后對稱的,而且一般負(fù)頻率沒有物理意義。也就是說絕對值相等的頻率,其對應(yīng)的頻率幅值是相等的,所以把正頻率對應(yīng)的頻率幅值的兩倍作為頻譜幅值。
3、關(guān)于問題(二)
由離散傅里葉變換(DFT)的推導(dǎo)過程可知,如果信號的時(shí)間長度是T0,則用DFT進(jìn)行頻譜分析的頻率分辨率是1/T0。由于fft函數(shù)取信號的長度是NFFT,采樣頻率是Fs,由此可知fft的頻率分辨率是Fs/NFFT。因此與頻譜幅值
2*abs(Y(1:NFFT/2+1))相對應(yīng)的頻率值是
f=1/(NFFT*T)*(0:NFFT/2);或者
f = Fs/2*linspace(0,1,NFFT/2+1);以上是轉(zhuǎn)載自:
版權(quán)聲明:本文為CSDN博主「ferry21」的原創(chuàng)文章,遵循CC 4.0 BY-SA版權(quán)協(xié)議,轉(zhuǎn)載請附上原文出處鏈接及本聲明。原文鏈接:https://blog.csdn.net/u013215903/article/details/48091359
————————————————
?
二、自身的理解與補(bǔ)充:
function FFT(Fs) %FFT 用于對函數(shù)進(jìn)行快速傅里葉變換,其中參數(shù)有:Fs--采樣頻率,即每秒選取的信息樣本個(gè)數(shù),Hz;L--信號長度,即有多少個(gè)采樣周期,也叫采樣點(diǎn)的數(shù)目;x--需要進(jìn)行傅里葉變換的函數(shù) % 本例中添加了噪聲為零平均值的隨機(jī)噪聲 L=1000;%信號長度 T=1/Fs;%采樣周期采樣時(shí)間,單位為s t=(0:L-1)*T;%每個(gè)采樣點(diǎn)采樣時(shí)的時(shí)刻,單位為s x = 0.7*sin(2*pi*50*t)+sin(2*pi*120*t); y=x+2*randn(size(t));%給需要傅里葉變換的函數(shù)x添加了隨機(jī)噪聲 figure(1)%創(chuàng)建一個(gè)新的繪圖窗口 plot(1000*t(1:50),y(1:50))%將時(shí)間單位換算成毫秒,繪制加了噪聲的原始函數(shù)與時(shí)間的圖像 title("x+零平均值噪聲信號") xlabel("y(t)") ylabel("time(ms)")%以上是對原信號進(jìn)行繪制,下面是對信號進(jìn)行傅里葉變換后再繪制變換后的圖像NFFT=2^nextpow2(L);%nextpow2函數(shù)是求以2為底的指數(shù)的函數(shù),2^a>=L,通過這樣來使得采樣的點(diǎn)數(shù)為2的冪次方的數(shù),從而加快傅里葉變換的速度 %若NFFT>L,零填充到NFFT長度 Y = fft(y,NFFT)/L;%求函數(shù)y的L點(diǎn)一維快速傅里葉變換 (1) f = Fs/2*linspace(0,1,NFFT/2+1);% (2) figure(2) plot(f,2*abs(Y(1:NFFT/2+1))) % (3) title("頻譜圖") xlabel("頻率Hz") ylabel("幅值|Y(f)|")end1.為什么在(2處加1) ?
答:
不加1的情況
加1的情況
三、其他參考鏈接
http://www.voidcn.com/article/p-nqwoasuu-bwe.html
https://www.cnblogs.com/liugl7/p/5265334.html
總結(jié)
以上是生活随笔為你收集整理的matlab——FFT傅里叶快速变换的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: redis:Invalid input
- 下一篇: 电脑版QQ更换透明背景教程(真的透明)