一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

電子發(fā)燒友App

硬聲App

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示
創(chuàng)作
電子發(fā)燒友網(wǎng)>電子資料下載>電子資料>如何使用HLS加速FPGA上的FIR濾波器

如何使用HLS加速FPGA上的FIR濾波器

2023-06-14 | zip | 0.00 MB | 次下載 | 2積分

資料介紹

描述

介紹

借助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 變換的延遲運算符

poYBAGSBnt6AbhiKAAFxUaY5Mak299.png
?

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

poYBAGSBnuKAOrroAAAo98CyIU4885.png
?

輸出信號可以用

pYYBAGSBnuaAAfTYAABZnkpnvqo781.png
?

或短

poYBAGSBnumADe_9AABCctg1fDQ522.png
?

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

poYBAGSBnuyAKmN9AAAvtzdsnmQ478.png
?

對于濾波器設(shè)計,使用了關(guān)于使用 python 進行低通 FIR 濾波器設(shè)計的 Scipy Cookbook 。

過濾器設(shè)計有具有以下特性的凱撒窗:

  • 10 Hz 的截止頻率 ( f_c )
  • 5 Hz 的過渡寬度 ( Δf )
  • 60 dB 的阻帶紋波 (A_stop)
pYYBAGSBnu-ADkKKAAGtrbvj93c981.png
帶 Kaiser 窗口的過濾器設(shè)計。自己的演講,靈感來自標(biāo)題={信號處理導(dǎo)論},出版商={Prentice Hall},作者={Orfanidis, Sophocles J.},年份={1998}
?

該食譜已針對該項目進行了改編fir.py

系數(shù):

pYYBAGSBnvKABpHlAACgeNwSAks685.png
?

頻率響應(yīng):

poYBAGSBnvWAQos_AADezx7_oDY188.png
?

過濾后的信號:

poYBAGSBnviAfb-EAADF1hdDvrI719.png
最后的圖顯示了原始信號(細藍線)、濾波信號(通過適當(dāng)?shù)南辔谎舆t移動以與原始信號對齊;細紅線)和濾波信號的“好”部分(粗綠線) . “好的部分”是信號中不受初始條件影響的部分。
?

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

pYYBAGSBnvuAL_WwAACbfvCDy7k725.png
?

高級合成

對于 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頭文件中。

pYYBAGSBnv-AUL-BAAGd-ZneEC4895.png
?

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

poYBAGSBnwSAQP3IAAJmxfbIuis979.png
?

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

?

poYBAGSBnweAcYW3AAD8PcQajLw049.png
?

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

pYYBAGSBnwqAFMwDAAJYQnwPcTU871.png
?

Vitis HLS 和 Vivado

與上一篇博文一樣,使用 Vitis HLS 和 Vivado 生成硬件。時鐘頻率使用100MHz,之后可以在Pynq中超頻。

Pynq

Pynq 代碼 ( fir.ipynb) 與之前的博文非常相似。系統(tǒng)可超頻至 250 MHz

pYYBAGSBnw2AB2sxAAFRkaPCUZY207.png
?

對于普通的 Python 實現(xiàn),已經(jīng)實現(xiàn)了 3160 倍的巨大性能提升。為了與scipy (lib) 的 lfilter()進行比較,可以實現(xiàn) 6.7 倍的性能提升。


下載該資料的人也在下載 下載該資料的人還在閱讀
更多 >

評論

查看更多

下載排行

本周

  1. 1山景DSP芯片AP8248A2數(shù)據(jù)手冊
  2. 1.06 MB  |  532次下載  |  免費
  3. 2RK3399完整板原理圖(支持平板,盒子VR)
  4. 3.28 MB  |  339次下載  |  免費
  5. 3TC358743XBG評估板參考手冊
  6. 1.36 MB  |  330次下載  |  免費
  7. 4DFM軟件使用教程
  8. 0.84 MB  |  295次下載  |  免費
  9. 5元宇宙深度解析—未來的未來-風(fēng)口還是泡沫
  10. 6.40 MB  |  227次下載  |  免費
  11. 6迪文DGUS開發(fā)指南
  12. 31.67 MB  |  194次下載  |  免費
  13. 7元宇宙底層硬件系列報告
  14. 13.42 MB  |  182次下載  |  免費
  15. 8FP5207XR-G1中文應(yīng)用手冊
  16. 1.09 MB  |  178次下載  |  免費

本月

  1. 1OrCAD10.5下載OrCAD10.5中文版軟件
  2. 0.00 MB  |  234315次下載  |  免費
  3. 2555集成電路應(yīng)用800例(新編版)
  4. 0.00 MB  |  33566次下載  |  免費
  5. 3接口電路圖大全
  6. 未知  |  30323次下載  |  免費
  7. 4開關(guān)電源設(shè)計實例指南
  8. 未知  |  21549次下載  |  免費
  9. 5電氣工程師手冊免費下載(新編第二版pdf電子書)
  10. 0.00 MB  |  15349次下載  |  免費
  11. 6數(shù)字電路基礎(chǔ)pdf(下載)
  12. 未知  |  13750次下載  |  免費
  13. 7電子制作實例集錦 下載
  14. 未知  |  8113次下載  |  免費
  15. 8《LED驅(qū)動電路設(shè)計》 溫德爾著
  16. 0.00 MB  |  6656次下載  |  免費

總榜

  1. 1matlab軟件下載入口
  2. 未知  |  935054次下載  |  免費
  3. 2protel99se軟件下載(可英文版轉(zhuǎn)中文版)
  4. 78.1 MB  |  537798次下載  |  免費
  5. 3MATLAB 7.1 下載 (含軟件介紹)
  6. 未知  |  420027次下載  |  免費
  7. 4OrCAD10.5下載OrCAD10.5中文版軟件
  8. 0.00 MB  |  234315次下載  |  免費
  9. 5Altium DXP2002下載入口
  10. 未知  |  233046次下載  |  免費
  11. 6電路仿真軟件multisim 10.0免費下載
  12. 340992  |  191187次下載  |  免費
  13. 7十天學(xué)會AVR單片機與C語言視頻教程 下載
  14. 158M  |  183279次下載  |  免費
  15. 8proe5.0野火版下載(中文版免費下載)
  16. 未知  |  138040次下載  |  免費