電子發(fā)燒友App

硬聲App

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示
創(chuàng)作
電子發(fā)燒友網(wǎng)>電子資料下載>電子資料>QuickFFT:Arduino的高速(低精度)FFT

QuickFFT:Arduino的高速(低精度)FFT

2022-11-18 | zip | 0.01 MB | 次下載 | 2積分

資料介紹

描述

典型的 Arduino 具有有限的 RAM 和處理能力,而 FFT 是一個計算密集型過程。對于許多實時應(yīng)用,唯一的要求是獲得最大振幅的頻率或檢測頻率峰值。

在我的一個教程中,我準(zhǔn)備了一個 FFT 代碼,可以在這里找到:EasyFFT

此代碼能夠在 Arduino nano 上執(zhí)行多達(dá) 128 個樣本的 FFT。由于 Arduino 的內(nèi)存有限,不可能有比這更高的樣本數(shù)。我稍微修改了函數(shù)以提高速度并減少內(nèi)存消耗。這種修改允許 Arduino 以五倍的速度執(zhí)行 FFT,并消耗幾乎一半的內(nèi)存。本教程不涉及 FFT 的工作,可以在EasyFFT中找到它的參考資料

?

在職的

修改了典型的 FFT 函數(shù)以提高速度,但精度較低。如圖所示,測試信號需要乘以正弦或余弦波形。這些值可以在 0 到 1 之間,因此必須進(jìn)行浮點乘法。在 Arduino 中,浮點乘法比整數(shù)運算慢。

?

?
?
?
poYBAGN27WCAL7nwAADyOp1np9k042.png
?
1 / 4 ? EasyFFT
?

在此功能中,正弦/余弦波被方波代替。因為我們必須將測試信號與可能具有值 0、1 或 -1 的方波相乘。因此,我們可以將浮點乘法替換為簡單的整數(shù)加法或減法。對于 Arduino 整數(shù)加法或減法大約快 5 倍。這使得求解速度提高了大約 5 倍。

由于這種修改,現(xiàn)在頻率 bin 值可以存儲為整數(shù)(以前是浮點數(shù)),并且我們獲得了另一個降低內(nèi)存消耗的優(yōu)勢。在 Arduino Nano 中,int 消耗 2 個字節(jié)的內(nèi)存,而 float 消耗 4 個字節(jié)的內(nèi)存。由于新代碼的這一優(yōu)勢,我們能夠?qū)?256 個樣本(之前為 128 個樣本)執(zhí)行 FFT。

在 Normal FFT 中,我們需要存儲正弦值以加快求解速度。在新功能中,由于我們不再需要正弦/余弦值,我們可以消除它并節(jié)省一些內(nèi)存。

執(zhí)行:

實現(xiàn)這個功能很簡單。我們可以簡單地復(fù)制代碼中的函數(shù)。可以使用以下命令執(zhí)行此功能:

float f= Q_FFT(data,256,100);In function Q_FFT,

數(shù)據(jù):該術(shù)語是具有信號值的數(shù)組,推薦的樣本大小為 2、4、8、32、64、128、256、512、... 等。如果樣本大小不屬于這些值,它將被剪裁到最近的值的下側(cè)。例如,如果樣本大小為 75,則將對 64 個樣本執(zhí)行 FFT。最大樣本數(shù)量受 Arduino 上可用 RAM 的限制。

第二項指定數(shù)組中的樣本數(shù),最后一項是以 Hz 為單位的采樣頻率。

第 2 步:代碼

本節(jié)說明在EasyFFT代碼中所做的修改,在代碼中進(jìn)行修改時需要牢記,

1. 如前所述,這里使用整數(shù)進(jìn)行 FFT。Arduino 中的 Int 是一個 16 位數(shù)字,可以包含從 -32768 到 32768 的值。只要這個 int 的值超過這個范圍,就會導(dǎo)致問題。在水平計算后消除這個問題。如果任何值超過 15000 個完整的數(shù)組將除以 100。這將防止 int 溢出。

2、幅值計算:計算幅值時,需要對實部和虛部取平方,求和的平方根。平方和函數(shù)的平方根是耗時的。為了使這個過程更快,這段代碼將簡單地做一些實部和虛部的量級。這肯定不太準(zhǔn)確,并且在某些情況下可能導(dǎo)致錯誤的結(jié)論。您可以選擇返回 Normal 方法進(jìn)行幅度計算,但這需要更多時間,并且您還需要做一些安排來存儲這些數(shù)字。

3. 本代碼沒有多峰檢測模塊。它將簡單地選擇具有最大幅度的值(不包括第一個數(shù)字,即直流偏移)。如果您需要多個峰,您可以參考EasyFFT代碼并在此處進(jìn)行所需的修改。在這種情況下,一些數(shù)組/變量也需要聲明為全局變量。

4. 該函數(shù)包含以下行:

unsigned int Pow2[13]={1,2,4,8,16,32,64,128,256,512,1024,2048};

將上述變量聲明為全局變量(將其粘貼在代碼開頭)將在每次執(zhí)行時節(jié)省 1 毫秒的時間。

5. 與 EasyFFT 函數(shù)不同,其中前 5 個峰存儲在預(yù)定義的數(shù)組中。此函數(shù)將返回一個浮點值。該值表示以赫茲為單位的具有最大幅度的頻率。所以代碼的表示看起來像這樣。

float f= Q_FFT(data,256,100);

6. 峰值檢測:一旦找到具有最大幅度的頻率,此功能將使用其前后的頻率幅度來計算準(zhǔn)確的結(jié)果。此計算中使用的幅度也是模數(shù)的總和(不是平方和的平方根)

如果 Fn 是具有最大幅度的頻率,則可以通過以下公式計算頻率。

實際 F= ( An- 1 *Fn-1 + An-1 *Fn-1 + An-1 *Fn-1 ) / (An-1+An+An+1)

其中 An 是頻率 n 的幅度,F(xiàn)n-1 是頻率值。

?

第 3 步:結(jié)果:

上圖與EasyFFT的比較顯示了求解時間它的速度與比較顯示。

?

?
?
?
pYYBAGN27WKAe5jLAACUKmZtI0E186.png
?
1 / 2 ?比較
?

顯示了具有 3 個不同頻率的正弦波的樣本數(shù)據(jù)。QuickFFT 的結(jié)果與 Scilab 輸出進(jìn)行比較。正如我們在圖像中看到的,最大振幅的 3 個峰值與 Scilab 輸出相匹配。但是,輸出包含大量噪聲,這可能會誤導(dǎo)某些應(yīng)用程序。因此,建議在申請您的應(yīng)用程序之前正確檢查代碼。

我希望您發(fā)現(xiàn)此代碼對您的項目有用。如有任何疑問或建議,請發(fā)表評論。


下載該資料的人也在下載 下載該資料的人還在閱讀
更多 >

評論

查看更多

下載排行

本周

  1. 1山景DSP芯片AP8248A2數(shù)據(jù)手冊
  2. 1.06 MB  |  532次下載  |  免費
  3. 2RK3399完整板原理圖(支持平板,盒子VR)
  4. 3.28 MB  |  339次下載  |  免費
  5. 3TC358743XBG評估板參考手冊
  6. 1.36 MB  |  330次下載  |  免費
  7. 4DFM軟件使用教程
  8. 0.84 MB  |  295次下載  |  免費
  9. 5元宇宙深度解析—未來的未來-風(fēng)口還是泡沫
  10. 6.40 MB  |  227次下載  |  免費
  11. 6迪文DGUS開發(fā)指南
  12. 31.67 MB  |  194次下載  |  免費
  13. 7元宇宙底層硬件系列報告
  14. 13.42 MB  |  182次下載  |  免費
  15. 8FP5207XR-G1中文應(yīng)用手冊
  16. 1.09 MB  |  178次下載  |  免費

本月

  1. 1OrCAD10.5下載OrCAD10.5中文版軟件
  2. 0.00 MB  |  234315次下載  |  免費
  3. 2555集成電路應(yīng)用800例(新編版)
  4. 0.00 MB  |  33566次下載  |  免費
  5. 3接口電路圖大全
  6. 未知  |  30323次下載  |  免費
  7. 4開關(guān)電源設(shè)計實例指南
  8. 未知  |  21549次下載  |  免費
  9. 5電氣工程師手冊免費下載(新編第二版pdf電子書)
  10. 0.00 MB  |  15349次下載  |  免費
  11. 6數(shù)字電路基礎(chǔ)pdf(下載)
  12. 未知  |  13750次下載  |  免費
  13. 7電子制作實例集錦 下載
  14. 未知  |  8113次下載  |  免費
  15. 8《LED驅(qū)動電路設(shè)計》 溫德爾著
  16. 0.00 MB  |  6656次下載  |  免費

總榜

  1. 1matlab軟件下載入口
  2. 未知  |  935054次下載  |  免費
  3. 2protel99se軟件下載(可英文版轉(zhuǎn)中文版)
  4. 78.1 MB  |  537798次下載  |  免費
  5. 3MATLAB 7.1 下載 (含軟件介紹)
  6. 未知  |  420027次下載  |  免費
  7. 4OrCAD10.5下載OrCAD10.5中文版軟件
  8. 0.00 MB  |  234315次下載  |  免費
  9. 5Altium DXP2002下載入口
  10. 未知  |  233046次下載  |  免費
  11. 6電路仿真軟件multisim 10.0免費下載
  12. 340992  |  191187次下載  |  免費
  13. 7十天學(xué)會AVR單片機(jī)與C語言視頻教程 下載
  14. 158M  |  183279次下載  |  免費
  15. 8proe5.0野火版下載(中文版免費下載)
  16. 未知  |  138040次下載  |  免費