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

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

輸出信號可以用

或短

這與輸入信號與脈沖響應的卷積相同

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

頻率響應:

過濾后的信號:

在食譜中,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)試目的,測試信號和預期響應也寫入fir.h
頭文件中。

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

為避免浮點運算,可以使用Vitis HLS 的定點包。為了不在 Python 中使用定點(為了與 Pynq 通信),函數(shù)的輸入和輸出仍然是 float。輸入和輸出必須進行相應的類型轉(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次閱讀
下載排行
本周
- 1DD3118電路圖紙資料
- 0.08 MB | 1次下載 | 免費
- 2AD庫封裝庫安裝教程
- 0.49 MB | 1次下載 | 免費
- 3PC6206 300mA低功耗低壓差線性穩(wěn)壓器中文資料
- 1.12 MB | 1次下載 | 免費
- 4網(wǎng)絡(luò)安全從業(yè)者入門指南
- 2.91 MB | 1次下載 | 免費
- 5DS-CS3A P00-CN-V3
- 618.05 KB | 1次下載 | 免費
- 6海川SM5701規(guī)格書
- 1.48 MB | 次下載 | 免費
- 7H20PR5電磁爐IGBT功率管規(guī)格書
- 1.68 MB | 次下載 | 1 積分
- 8IP防護等級說明
- 0.08 MB | 次下載 | 免費
本月
- 1貼片三極管上的印字與真實名稱的對照表詳細說明
- 0.50 MB | 103次下載 | 1 積分
- 2涂鴉各WiFi模塊原理圖加PCB封裝
- 11.75 MB | 89次下載 | 1 積分
- 3錦銳科技CA51F2 SDK開發(fā)包
- 24.06 MB | 43次下載 | 1 積分
- 4錦銳CA51F005 SDK開發(fā)包
- 19.47 MB | 19次下載 | 1 積分
- 5PCB的EMC設(shè)計指南
- 2.47 MB | 16次下載 | 1 積分
- 6HC05藍牙原理圖加PCB
- 15.76 MB | 13次下載 | 1 積分
- 7802.11_Wireless_Networks
- 4.17 MB | 12次下載 | 免費
- 8蘋果iphone 11電路原理圖
- 4.98 MB | 6次下載 | 2 積分
總榜
- 1matlab軟件下載入口
- 未知 | 935127次下載 | 10 積分
- 2開源硬件-PMP21529.1-4 開關(guān)降壓/升壓雙向直流/直流轉(zhuǎn)換器 PCB layout 設(shè)計
- 1.48MB | 420064次下載 | 10 積分
- 3Altium DXP2002下載入口
- 未知 | 233089次下載 | 10 積分
- 4電路仿真軟件multisim 10.0免費下載
- 340992 | 191390次下載 | 10 積分
- 5十天學會AVR單片機與C語言視頻教程 下載
- 158M | 183342次下載 | 10 積分
- 6labview8.5下載
- 未知 | 81588次下載 | 10 積分
- 7Keil工具MDK-Arm免費下載
- 0.02 MB | 73815次下載 | 10 積分
- 8LabVIEW 8.6下載
- 未知 | 65989次下載 | 10 積分
評論