資料介紹
描述
介紹
借助Vitis 高層次綜合 (HLS) ,FPGA 的一般開發(fā)時間可以大大縮短。
在此項目中,將展示如何使用 HLS 加速 FPGA 上的 FIR 濾波器。
在之前關(guān)于使用 HLS 運行簡單神經(jīng)網(wǎng)絡(luò)的博客文章中,展示了使用 Pynq 的 KV260 的設(shè)置過程。
所有數(shù)據(jù)和預(yù)建硬件都在隨附的GitHub 存儲庫中
基礎(chǔ)知識
在數(shù)字信號處理中,有限脈沖響應(yīng) (FIR) 濾波器對任何給定的有限輸入信號都有有限響應(yīng)。FIR 濾波器由抽頭延遲線構(gòu)成,用于將輸入信號延遲給定數(shù)量的抽頭 ( N )。z^{-1} 是Z 變換的延遲運算符

濾波器系數(shù)可以排列在脈沖響應(yīng)向量中。

輸出信號可以用

或短

這與輸入信號與脈沖響應(yīng)的卷積相同

對于濾波器設(shè)計,使用了關(guān)于使用 python 進行低通 FIR 濾波器設(shè)計的 Scipy Cookbook 。
過濾器設(shè)計有具有以下特性的凱撒窗:
- 10 Hz 的截止頻率 ( f_c )
- 5 Hz 的過渡寬度 ( Δf )
- 60 dB 的阻帶紋波 (A_stop)
該食譜已針對該項目進行了改編fir.py
系數(shù):

頻率響應(yīng):

過濾后的信號:

在食譜中,scipy 函數(shù)scipy.signal.lfilter()
用于過濾信號。一個純的和非優(yōu)化的 python(使用 NumPy)實現(xiàn)看起來像:

高級合成
對于 HLS 部分,我們使用 74 抽頭濾波器過濾長度為 1024 的信號。在沒有并行性的情況下,我們需要大約 75k 個周期來過濾信號。
HLS中的 C++ 代碼fir.cpp
看起來與 Python 代碼非常相似。通過一些代碼提升技術(shù)(將i = 0時的代碼放在for 循環(huán)之外),HLS 可以流水線化最外層的循環(huán)。如果流水線循環(huán)包含更多循環(huán),它們將自動展開。
Python 腳本fir.py
將計算出的抽頭系數(shù)寫入 C++ 頭文件。出于調(diào)試目的,測試信號和預(yù)期響應(yīng)也寫入fir.h
頭文件中。

在綜合后報告中,我們看到相當(dāng)大的開銷,因為即使循環(huán)是流水線,它也需要 1345 個周期來過濾長度為 1024 的信號。這是由于昂貴的浮點運算。

為避免浮點運算,可以使用Vitis HLS 的定點包。為了不在 Python 中使用定點(為了與 Pynq 通信),函數(shù)的輸入和輸出仍然是 float。輸入和輸出必須進行相應(yīng)的類型轉(zhuǎn)換。在這個項目中,使用了 32 位的字寬和 1 位的整數(shù)寬度。
?

正如報告中所見,開銷幾乎消失,1058 個周期確實接近了 1024 個周期的最佳延遲。

Vitis HLS 和 Vivado
與上一篇博文一樣,使用 Vitis HLS 和 Vivado 生成硬件。時鐘頻率使用100MHz,之后可以在Pynq中超頻。
Pynq
Pynq 代碼 ( fir.ipynb
) 與之前的博文非常相似。系統(tǒng)可超頻至 250 MHz

對于普通的 Python 實現(xiàn),已經(jīng)實現(xiàn)了 3160 倍的巨大性能提升。為了與scipy (lib) 的 lfilter()進行比較,可以實現(xiàn) 6.7 倍的性能提升。
- 如何使用FPGA實現(xiàn)分布式算法的高階FIR濾波器 31次下載
- 如何使用FPGA實現(xiàn)實現(xiàn)高速并行FIR濾波器 15次下載
- 如何使用FPGA實現(xiàn)實現(xiàn)高速并行FIR濾波器 7次下載
- 如何使用FPGA實現(xiàn)FIR抽取濾波器的設(shè)計
- FIR濾波器的FPGA設(shè)計與實現(xiàn) 14次下載
- 基于FPGA的32階FIR濾波器的設(shè)計與實現(xiàn) 16次下載
- 基于MATLAB的FIR濾波器設(shè)計與濾波 64次下載
- 基于FPGA的FIR濾波器設(shè)計與實現(xiàn) 39次下載
- 基于matlab和fpga的FIR濾波器設(shè)計 58次下載
- 一種在FPGA上實現(xiàn)的FIR濾波器的資源優(yōu)化算法 36次下載
- 基于FPGA設(shè)計的FIR濾波器的實現(xiàn)與對比 121次下載
- 基于MATLAB與FPGA的FIR濾波器設(shè)計與仿真 120次下載
- 基于MATLAB及FPGA的FIR低通濾波器的設(shè)計 82次下載
- 基于FPGA對稱型FIR濾波器的設(shè)計與實現(xiàn)
- FIR濾波器的FPGA實現(xiàn)及其仿真研究
- 基于FPGA實現(xiàn)FIR數(shù)字濾波器 841次閱讀
- Verilog并行FIR濾波器設(shè)計 987次閱讀
- FIR濾波器的MATLAB與FPGA設(shè)計 3462次閱讀
- 基于FPGA的可調(diào)FIR濾波器在實際通信系統(tǒng)中的實現(xiàn)方法設(shè)計 2611次閱讀
- FPGA是如何設(shè)計并實現(xiàn)了32階FIR數(shù)字濾波器的硬件電路? 5441次閱讀
- FPGA的FIR抽取濾波器設(shè)計教程 1319次閱讀
- FPGA的FIR抽取濾波器設(shè)計詳細教程 2362次閱讀
- 一種基于分布式算法的低通FIR濾波器 3282次閱讀
- 基于FPGA乘法器的FIR 低通濾波器整體設(shè)計 3426次閱讀
- 使用FPGA構(gòu)建的數(shù)字濾波器設(shè)計方案 8881次閱讀
- DSP in FPGA:FIR濾波器(二) 2178次閱讀
- DSP in FPGA:FIR濾波器(一) 9643次閱讀
- 基于FPGA的FIR數(shù)字濾波器設(shè)計方案 9251次閱讀
- 基于Matlab的FIR帶通濾波器設(shè)計與實現(xiàn) 2.9w次閱讀
- 基于DSP的FIR濾波器的設(shè)計 1.1w次閱讀
下載排行
本周
- 1山景DSP芯片AP8248A2數(shù)據(jù)手冊
- 1.06 MB | 532次下載 | 免費
- 2RK3399完整板原理圖(支持平板,盒子VR)
- 3.28 MB | 339次下載 | 免費
- 3TC358743XBG評估板參考手冊
- 1.36 MB | 330次下載 | 免費
- 4DFM軟件使用教程
- 0.84 MB | 295次下載 | 免費
- 5元宇宙深度解析—未來的未來-風(fēng)口還是泡沫
- 6.40 MB | 227次下載 | 免費
- 6迪文DGUS開發(fā)指南
- 31.67 MB | 194次下載 | 免費
- 7元宇宙底層硬件系列報告
- 13.42 MB | 182次下載 | 免費
- 8FP5207XR-G1中文應(yīng)用手冊
- 1.09 MB | 178次下載 | 免費
本月
- 1OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費
- 2555集成電路應(yīng)用800例(新編版)
- 0.00 MB | 33566次下載 | 免費
- 3接口電路圖大全
- 未知 | 30323次下載 | 免費
- 4開關(guān)電源設(shè)計實例指南
- 未知 | 21549次下載 | 免費
- 5電氣工程師手冊免費下載(新編第二版pdf電子書)
- 0.00 MB | 15349次下載 | 免費
- 6數(shù)字電路基礎(chǔ)pdf(下載)
- 未知 | 13750次下載 | 免費
- 7電子制作實例集錦 下載
- 未知 | 8113次下載 | 免費
- 8《LED驅(qū)動電路設(shè)計》 溫德爾著
- 0.00 MB | 6656次下載 | 免費
總榜
- 1matlab軟件下載入口
- 未知 | 935054次下載 | 免費
- 2protel99se軟件下載(可英文版轉(zhuǎn)中文版)
- 78.1 MB | 537798次下載 | 免費
- 3MATLAB 7.1 下載 (含軟件介紹)
- 未知 | 420027次下載 | 免費
- 4OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費
- 5Altium DXP2002下載入口
- 未知 | 233046次下載 | 免費
- 6電路仿真軟件multisim 10.0免費下載
- 340992 | 191187次下載 | 免費
- 7十天學(xué)會AVR單片機與C語言視頻教程 下載
- 158M | 183279次下載 | 免費
- 8proe5.0野火版下載(中文版免費下載)
- 未知 | 138040次下載 | 免費
評論