国产毛片a精品毛-国产毛片黄片-国产毛片久久国产-国产毛片久久精品-青娱乐极品在线-青娱乐精品

FFT在單片機C8051中的實現

發布時間:2010-10-13 12:05    發布者:techshare
關鍵詞: c8051 , fft , 單片機
由于單片機的性價比高,因此在數據采集及頻譜分析系統中往往取代DSP芯片而被廣泛使用。在數字信號處理中,離散傅里葉變換(Discrete Fourier Transform,DFT)是常用的變換方法,它在各種數字信號處理系統中扮演著重要的角色。快速傅里葉變換(Fast Fourier Transfonn,FFT)并不是與離散傅里葉變換不同的另一種變換,而是為了減少DFT計算次數的一種快速有效的算法,且它們都是為了將信號變換到頻域并進行相應的頻譜分析。雖然FFT是一種快速的運算方法,但是為了計算N點的FFT依然需要Nlog2N次加法和0.5Nlog2N次乘法。當N比較大時,其運算復雜度對RAM的需求也是很大的。在本文中,我們將探討如何優化FFT算法,并將其在單片機中實現。

雖然在實現FFT方面已有很好的芯片來解決其運算速度及RAM容量的問題,但由于單片機的成本相對比較低。因此討論在單片機中實現FFT算法具有現實意義。最后本文還給出了用單片機實現FFT在雷達檢測中的應用。

1 基數為2的FFT算法

FFT的輸出與DFT的輸出是一致的,但冗余的計算在FFT中已被減去,使得其計算速度比較快。對于N-點的傅里葉變換,DFT需要的計算復雜度是N2,而FFT需要的計算復雜度是N/2log2N。因此當N比較大時,使用FFT做傅里葉變換將會大大減少計算量。比如做64點的DFT需要4096的計算復雜度,而使用FFT只需要192的計算復雜度。在單片機中,當使用別的優化方法時,FFT的計算需要更少的時間。

在本文中,使用FFT時,我們關心的是如何減少為了存儲中間數據所需要的臨時內存空間。在執行FFT時,輸入數據和輸出數據將以比特倒序的方式存儲。在順序與倒序之間改變時,每一數據點與數據集里的另一數據點的位置相換是由將樣本系列的順序倒置決定的。例如,在16點的FFT變換,樣本存儲的地址是001 b將與存儲在100 b位置上的樣本互換。具有倒序字節的位置是和沒有倒序字節的位置是相等的,比如0110 b是不互換位置的。計算FFT的順序是由FFT的輸入或輸出是否需要以倒序保存決定的。

2 對輸入數據加窗

FFT變換可以作用在具有有限時間長度的數據,但是對此數據集進行一個假設:就是周期的,且無限次重復。當樣本數據以這種方式重復時,最后一個樣本(下標[N-1])是緊接著下一周期中的第一個樣本([0])的。如圖1所示,當數據在整個樣本集中不是周期性的,則當對整個樣本做FFT時會導致不連續性。正因為這樣,數據在進行FFT變換前通常需要加窗。加窗使得樣本集變成周期性且去掉在第一個樣本與最后一個樣本之間的不連續。由于加窗改變了輸入數據,在頻域上它將產生一些噪聲。加窗會將信號的能量伸展到幾個點上。能量分布會削弱信號的峰值。大部分信號的原始內容存儲在主要部分里,當一部分發生旁瓣泄漏(如圖2所示),主要部分的寬度和旁瓣的高度由應用在信號的加窗算法決定。一些窗函數及其性能如表1所示。為計算N點FFT的加窗函數的系數的一些方程如表2所示。更多關于加窗算法與他們的參數參見文獻。












3 FFT優化

已經出現了很多優化FFT的方法。而這些優化方法的目的都是為了使得計算速度增快且盡可能的減少存儲數據所需要的RAM。

我們都知道,計算FFT的一個重要方法是蝶式方法。但是蝶式計算的每一次迭代都需要一個復雜的乘法(總共是四次的長整數乘法)。長整數乘法需要很多處理內存來完成。但是我們仔細觀察會發現其中一些乘法是不需要的,并且是可以省去的。特別是,當乘數為零時,結果將為零和當乘數為1時,相乘的結果將不變。對那些正弦和余弦函數是否為0或1進行查詢的代碼可以利用這些優點來減少計算量。這種優化方法能節省的計算量為:

其中N為FFT的點數。

4 程序總體設計

首長分成三個模塊集合而成。即數據采集模塊,A/D轉換模塊及FFT運算模塊。數據采集模塊主要是通過定時器來控制A/D轉換器的采樣周期,將采集到的數據轉換成有符號數,并且可以以復數形式存貯。FFT的運算模塊是在8051單片機的數據存貯器上運行256點的FFT,并經一快速平方根或快速對數運算,計算出對應128個頻率點的幅值或分貝表示值。具體流程如圖3。



5 在電話視頻中的應用

在一個會議中,當說話人變換時。我們需要攝像頭能自動跟蹤并檢測出說話人的位置,這就需要用到FFT及其反變換來計算角度。

6 結論

本文主要介紹了一種在單片機中實現FFT算法的優化方法,由于這可大大減少FFT的計算量及減少存儲數據所需要的RAM。因此其可應用在電話視頻會議中。
本文地址:http://www.qingdxww.cn/thread-32089-1-1.html     【打印本頁】

本站部分文章為轉載或網友發布,目的在于傳遞和分享信息,并不代表本網贊同其觀點和對其真實性負責;文章版權歸原作者及原出處所有,如涉及作品內容、版權和其它問題,我們將根據著作權人的要求,第一時間更正或刪除。
您需要登錄后才可以發表評論 登錄 | 立即注冊

廠商推薦

  • Microchip視頻專區
  • Chiptorials ——如何將CryptoAuthLib庫用于Microchip安全身份驗證IC
  • Chiptorials——如何使用ATECC608 TrustFLEX實現公鑰輪換
  • FPGA設計流程培訓教程
  • 無線充電基礎知識及應用培訓教程
  • 貿澤電子(Mouser)專區

相關在線工具

相關視頻

關于我們  -  服務條款  -  使用指南  -  站點地圖  -  友情鏈接  -  聯系我們
電子工程網 © 版權所有   京ICP備16069177號 | 京公網安備11010502021702
快速回復 返回頂部 返回列表
主站蜘蛛池模板: 亚洲免费在线播放 | 国产精品久久久久久免费播放 | 成年黄网站免费大全毛片 | 99在线观看视频免费精品9 | 日本在线视频免费 | 女人18毛片a级毛片一区②区 | 91在线视频免费看 | h视频在线观看免费网站 | 日本精品a在线 | 99精品视频免费在线观看 | 久久香蕉综合精品国产 | 天堂五月天 | 亚洲男人的天堂久久无 | 另类视频综合 | 狠狠色综合久久婷婷 | 亚洲一区二区高清 | 日韩精品一区二区三区在线观看 | 91精品国产色综合久久不卡蜜 | 亚洲最新在线观看 | 视频二区欧美 | 日韩欧美一区二区三区四区 | 国产精品99久久久 | 精品视频免费播放 | 国产精品永久免费 | 国产精品福利久久2020 | 国产精品久久毛片 | 国产精品成人久久久久 | www国产永久免费视频看看 | 国产麻豆媒一区一区二区三区 | 欧美午夜精品久久久久免费视 | 久久66热re国产毛片基地 | 亚洲一区二区三区精品视频 | 亚洲欧美精品伊人久久 | 欧美视| 国产成人精品久久免费动漫 | 成年美女黄网站色视频大全免费 | 亚洲综合色丁香麻豆 | 麻豆日韩 | 手机在线免费不卡一区二 | 极品国产一区二区三区 | 黄色网址中文字幕 |