當(dāng)前位置:首頁 > 電源 > 數(shù)字電源
[導(dǎo)讀]分析了FIR濾波器幾種常見實現(xiàn)方法的原理與不足;提出一種基于SoPC的FIR濾波器設(shè)計;介紹了系統(tǒng)的設(shè)計流程及實現(xiàn)方法;結(jié)合Matlab給出FIR濾波器的仿真結(jié)果。整個設(shè)計以Altera公司現(xiàn)場可編程邏輯器芯片EP3C25E144C8N為核心,具有程序簡單,調(diào)試方便的特點,有一定的實用價值及應(yīng)用前景。

0 引言
    數(shù)字濾波(idgital filter)是由數(shù)字乘法器、加法器和延時單元組成的一種計算方法。其功能是對輸入離散信號的數(shù)字代碼進行運算處理,以達(dá)到改變信號頻譜的目的。數(shù)字濾波器根據(jù)頻域特性可分為低通、高通、帶通和帶阻4個基本類型;根據(jù)時域特性可分為無限脈沖響應(yīng)(infinite impulse response,IIR)濾波器和有限脈沖響應(yīng)(finite impulse response,F(xiàn)IR)濾波器。FIR濾波器不存在穩(wěn)定性和是否可實現(xiàn)的問題,容易做到線性相位,故在數(shù)據(jù)通信、圖像處理等領(lǐng)域廣泛應(yīng)用。
    目前,F(xiàn)IR濾波器的硬件實現(xiàn)有以下幾種方式:一種是使用通用數(shù)字濾波器集成電路,這種電路使用簡單,但是由于字長和階數(shù)的規(guī)格較少,不易完全滿足實際需要;雖然可采用多片擴展來滿足要求,但會增加體積和功耗,因而在實際應(yīng)用中受到限制。另一種是使用DSP芯片,DSP芯片有專用的數(shù)字信號處理函數(shù)可調(diào)用,實現(xiàn)FIR濾波器相對簡單,但是由于程序順序執(zhí)行,速度受到限制。而且,就是同一公司不同系統(tǒng)的DSP芯片,其編程指令也會有所不同,開發(fā)周期較長。還有一種是使用可編程邏輯器件,如FPGA(field programmable gate array),即現(xiàn)場可編程門陣列,有著規(guī)整的內(nèi)部邏輯塊整列和豐富的連線資源,特別適合用于細(xì)粒度和高并行度結(jié)構(gòu)的FIR濾波器實現(xiàn),相對于串行運算主導(dǎo)的通用DSP芯片來說,并行性和可擴展性都更好。
    本文介紹一種基于SoPC的FIR濾波器設(shè)計方案,設(shè)計流程如圖l所示。該設(shè)計方法程序簡單,調(diào)試方便,得到的FIR濾波器精確度高。



1 FIR濾波器原理
  
FIR數(shù)字濾波器是一種非遞歸系統(tǒng),其沖激響應(yīng)總是有限長的,其系統(tǒng)函數(shù)可以記為:,最基本的FIR濾波器可用下式表示是輸入采樣序列;h(m)是濾波器系數(shù);N是濾波器的階數(shù);y(n)表示濾波器的輸出序列。也可以用卷積來表示輸出序列y(n)與x(n),h(n)的關(guān)系:
y(n)=x(n)*h(n)
    圖2顯示了一個典型的直接T型3階FIR濾波器,其輸出序列y(n)滿足下列等式:
   
    在該FIR濾波器中,總共存在3個延時結(jié),4個乘法單元,1個4輸入的加法器。如果采用普通的數(shù)字信號處理器(DSP)來實現(xiàn),只能用串行的方式順序地執(zhí)行延時、乘加操作,不可能在1個DSP處理器指令周期內(nèi)完成,必須用多個指令周期來完成。但如果采用FPGA來實現(xiàn),就可以采用并行結(jié)構(gòu),在1個時鐘周期內(nèi)得到1個FIR濾波器的輸出。不難發(fā)現(xiàn),圖2的電路結(jié)構(gòu)是一種流水線結(jié)構(gòu),這種結(jié)構(gòu)在硬件系統(tǒng)中有利于并行高速運行。[!--empirenews.page--]

2 FIR濾波器的實現(xiàn)
    Altera提供的FIR Complier是結(jié)合Altera FPGA器件的FIR Filter Core,DSP Builder與FIR Compiler可以緊密結(jié)合起來。DSP Builder提供了FIR Core的應(yīng)用環(huán)境和仿真驗證環(huán)境。
2.1 建立模型文件
    為了調(diào)用FIR IP Core,在Simulink環(huán)境中新建模型文件,放置Sigtlal Compiler模塊和FIR模塊。啟動Simulink的方法:打開Matlab,在主命令窗口直接鍵入Simulink,按回車即可。然后打開Altera DSP Builder模塊,在MegaCore Functions調(diào)出fir_compiler_v7_0。
2.2 配置FIR濾波器核
    雙擊模型中的FIR模塊,在彈出來的選擇窗口中有:關(guān)于這個核(about this core)、程序說明書(documentation)、顯示元件(display symb01)、步驟1確定參數(shù)(Stepl:Parameterize)和步驟2生成(Step2:Generate)等4個不同的選項。點擊stepl,便打開了FIR濾波器核的參數(shù)設(shè)置窗口,如圖3所示。


    由圖3可見,濾波器的系數(shù)精度為32位,器件為CycloneⅢ,結(jié)構(gòu)為并行濾波器,結(jié)構(gòu)選擇了1級流水線,濾波器由LC邏輯宏單元構(gòu)成,系數(shù)數(shù)據(jù)存于FPGA的M9K模塊中,1個輸入通道,32位有符號并行輸入,全精度數(shù)據(jù)輸出。設(shè)定后會直接顯示濾波器的頻率響應(yīng)(frequency res-ponse)或時域響應(yīng)及系數(shù)值(timeresponse & coefficeient values)。由其頻率響應(yīng)圖可以看出,此FIR濾波器為低通濾波器。如果不符合設(shè)計要求,則可以通過對Edit Coefficient Set選項,對濾波器進行重新配置。
2.3 生成VHDL語言
    完成FIR濾波器核配置后,便可得到設(shè)計好的濾波器,加入輸入/輸出信號,形成如圖4所示電路。點擊SignalCompiler,再選擇Anal-yze,選擇Sigle step compilation中的Convert MDL to VHDL,就可以生成對應(yīng)的VHDL語言。


    在QuartusⅡ中打開編譯后生成的fir.qpf工程文件,可以得到濾波器的VHDL語言,其部分代碼如下:
   
    編譯成功后,可以將其轉(zhuǎn)換成元件。[!--empirenews.page--]
2.4 系統(tǒng)功能仿真
    在Matlab中,建立M文件,運用前面設(shè)置好參數(shù)所生成的FIR濾波器,打開FIR濾波器時域響應(yīng)與系數(shù)值(time response & coefficeient vahles)。得到該濾波器的時域響應(yīng)和系數(shù)值如圖5所示,由該系數(shù)表確定濾波器,并進行算法級仿真,得到如圖6所示的波形。


    圖6(a)為濾波前信號,圖6(b)為濾波后信號。從仿真波形可以看出,經(jīng)過FIR濾波器之后,高次諧波信號被很好地濾除了,達(dá)到了預(yù)定的設(shè)計目標(biāo)。

3 基本FPGA片上系統(tǒng)的功能測試
    設(shè)計目標(biāo)器件選用美國Altera公司Cyclone系列FPGA器件中的EP3C25E144C8N芯片,通過開發(fā)工具QuartusⅡ?qū)Ω鱾€模塊的VHDL源程序及頂層電路進行編譯、邏輯綜合、電路的糾錯、驗證、自動布局布線及仿真等各種測試,最終將設(shè)計編譯的數(shù)據(jù)下載到芯片中,同時與單片機AT89C51結(jié)合,進一步進行數(shù)據(jù)的快速處理和控制,實現(xiàn)鍵盤可設(shè)置參數(shù)及LCD顯示。經(jīng)實際電路測試驗證,達(dá)到了設(shè)計的要求。

4 結(jié)語
    這種基于SoPC數(shù)字濾波器的設(shè)計與實現(xiàn),不僅利用Matlab中的Simulink與Alterl DSP Builder工具確定FIR濾波器系數(shù),不用編程,只需簡單的設(shè)置,而且通過VHDL層次化設(shè)計方法,同時使FPGA與單片機相結(jié)合,采用C51及VHDL語言模塊化設(shè)計思想進行優(yōu)化編程,進一步完善了數(shù)據(jù)的快速處理和有效控制,提高了設(shè)計的靈活性、可靠性,也增強了系統(tǒng)功能的可擴展性。

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

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

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

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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