當(dāng)前位置:首頁(yè) > 單片機(jī) > 單片機(jī)
[導(dǎo)讀]0 引言 由于單片機(jī)的性價(jià)比高,因此在數(shù)據(jù)采集及頻譜分析系統(tǒng)中往往取代DSP芯片而被廣泛使用。在數(shù)字信號(hào)處理中,離散傅里葉變換(Discrete Fourier Transform,DFT)是常用的變換方法,它在各種數(shù)字信號(hào)處理系


0 引言
    由于單片機(jī)的性價(jià)比高,因此在數(shù)據(jù)采集及頻譜分析系統(tǒng)中往往取代DSP芯片而被廣泛使用。在數(shù)字信號(hào)處理中,離散傅里葉變換(Discrete Fourier Transform,DFT)是常用的變換方法,它在各種數(shù)字信號(hào)處理系統(tǒng)中扮演著重要的角色??焖俑道锶~變換(Fast Fourier Transfonn,FFT)并不是與離散傅里葉變換不同的另一種變換,而是為了減少DFT計(jì)算次數(shù)的一種快速有效的算法,且它們都是為了將信號(hào)變換到頻域并進(jìn)行相應(yīng)的頻譜分析。雖然FFT是一種快速的運(yùn)算方法,但是為了計(jì)算N點(diǎn)的FFT依然需要Nlog2N次加法和0.5Nlog2N次乘法。當(dāng)N比較大時(shí),其運(yùn)算復(fù)雜度對(duì)RAM的需求也是很大的。在本文中,我們將探討如何優(yōu)化FFT算法,并將其在單片機(jī)中實(shí)現(xiàn)。
    雖然在實(shí)現(xiàn)FFT方面已有很好的芯片來(lái)解決其運(yùn)算速度及RAM容量的問(wèn)題,但由于單片機(jī)的成本相對(duì)比較低。因此討論在單片機(jī)中實(shí)現(xiàn)FFT算法具有現(xiàn)實(shí)意義。最后本文還給出了用單片機(jī)實(shí)現(xiàn)FFT在雷達(dá)檢測(cè)中的應(yīng)用。


1 基數(shù)為2的FFT算法
    FFT的輸出與DFT的輸出是一致的,但冗余的計(jì)算在FFT中已被減去,使得其計(jì)算速度比較快。對(duì)于N-點(diǎn)的傅里葉變換,DFT需要的計(jì)算復(fù)雜度是N2,而FFT需要的計(jì)算復(fù)雜度是N/2log2N。因此當(dāng)N比較大時(shí),使用FFT做傅里葉變換將會(huì)大大減少計(jì)算量。比如做64點(diǎn)的DFT需要4096的計(jì)算復(fù)雜度,而使用FFT只需要192的計(jì)算復(fù)雜度。在單片機(jī)中,當(dāng)使用別的優(yōu)化方法時(shí),F(xiàn)FT的計(jì)算需要更少的時(shí)間。
    在本文中,使用FFT時(shí),我們關(guān)心的是如何減少為了存儲(chǔ)中間數(shù)據(jù)所需要的臨時(shí)內(nèi)存空間。在執(zhí)行FFT時(shí),輸入數(shù)據(jù)和輸出數(shù)據(jù)將以比特倒序的方式存儲(chǔ)。在順序與倒序之間改變時(shí),每一數(shù)據(jù)點(diǎn)與數(shù)據(jù)集里的另一數(shù)據(jù)點(diǎn)的位置相換是由將樣本系列的順序倒置決定的。例如,在16點(diǎn)的FFT變換,樣本存儲(chǔ)的地址是001 b將與存儲(chǔ)在100 b位置上的樣本互換。具有倒序字節(jié)的位置是和沒(méi)有倒序字節(jié)的位置是相等的,比如0110 b是不互換位置的。計(jì)算FFT的順序是由FFT的輸入或輸出是否需要以倒序保存決定的。


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

3 FFT優(yōu)化
    已經(jīng)出現(xiàn)了很多優(yōu)化FFT的方法。而這些優(yōu)化方法的目的都是為了使得計(jì)算速度增快且盡可能的減少存儲(chǔ)數(shù)據(jù)所需要的RAM。
    我們都知道,計(jì)算FFT的一個(gè)重要方法是蝶式方法。但是蝶式計(jì)算的每一次迭代都需要一個(gè)復(fù)雜的乘法(總共是四次的長(zhǎng)整數(shù)乘法)。長(zhǎng)整數(shù)乘法需要很多處理內(nèi)存來(lái)完成。但是我們仔細(xì)觀察會(huì)發(fā)現(xiàn)其中一些乘法是不需要的,并且是可以省去的。特別是,當(dāng)乘數(shù)為零時(shí),結(jié)果將為零和當(dāng)乘數(shù)為1時(shí),相乘的結(jié)果將不變。對(duì)那些正弦和余弦函數(shù)是否為0或1進(jìn)行查詢的代碼可以利用這些優(yōu)點(diǎn)來(lái)減少計(jì)算量。這種優(yōu)化方法能節(jié)省的計(jì)算量為:其中N為FFT的點(diǎn)數(shù)。


4 程序總體設(shè)計(jì)
    首長(zhǎng)分成三個(gè)模塊集合而成。即數(shù)據(jù)采集模塊,A/D轉(zhuǎn)換模塊及FFT運(yùn)算模塊。數(shù)據(jù)采集模塊主要是通過(guò)定時(shí)器來(lái)控制A/D轉(zhuǎn)換器的采樣周期,將采集到的數(shù)據(jù)轉(zhuǎn)換成有符號(hào)數(shù),并且可以以復(fù)數(shù)形式存貯。FFT的運(yùn)算模塊是在8051單片機(jī)的數(shù)據(jù)存貯器上運(yùn)行256點(diǎn)的FFT,并經(jīng)一快速平方根或快速對(duì)數(shù)運(yùn)算,計(jì)算出對(duì)應(yīng)128個(gè)頻率點(diǎn)的幅值或分貝表示值。具體流程如圖3。

5 在電話視頻中的應(yīng)用
    在一個(gè)會(huì)議中,當(dāng)說(shuō)話人變換時(shí)。我們需要攝像頭能自動(dòng)跟蹤并檢測(cè)出說(shuō)話人的位置,這就需要用到FFT及其反變換來(lái)計(jì)算角度。


6 結(jié)論
    本文主要介紹了一種在單片機(jī)中實(shí)現(xiàn)FFT算法的優(yōu)化方法,由于這可大大減少FFT的計(jì)算量及減少存儲(chǔ)數(shù)據(jù)所需要的RAM。因此其可應(yīng)用在電話視頻會(huì)議中。

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

倫敦2024年8月29日 /美通社/ -- 英國(guó)汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開(kāi)發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來(lái)越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來(lái)越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場(chǎng)的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開(kāi)幕式在貴陽(yáng)舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語(yǔ)權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營(yíng)業(yè)績(jī)穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤(rùn)率延續(xù)升勢(shì) 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長(zhǎng) 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競(jìng)爭(zhēng)力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競(jìng)爭(zhēng)優(yōu)勢(shì)...

關(guān)鍵字: 通信 BSP 電信運(yùn)營(yíng)商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國(guó)電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場(chǎng) NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長(zhǎng)三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡(jiǎn)稱"軟通動(dòng)力")與長(zhǎng)三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉