IP庫(kù)簡(jiǎn)介
一直想做一個(gè)可以供大家學(xué)習(xí)、使用的開源IP庫(kù),類似OpenCores,OC上IP在領(lǐng)域內(nèi)的IP很少,通用性強(qiáng)一點(diǎn),所以作為OC的“補(bǔ)充”,所以做了一個(gè)開源IP庫(kù),側(cè)重點(diǎn)在領(lǐng)域的IP輔以工程或者仿真驗(yàn)證,一個(gè)人能力有限,歡迎大家能夠共同構(gòu)建,有什么問題可以在網(wǎng)頁(yè)郵箱批評(píng)指正,謝謝~
FPGA 上的跳頻無(wú)線電
列表中的第一個(gè) FPGA 項(xiàng)目是一個(gè)標(biāo)準(zhǔn)擴(kuò)頻系統(tǒng),屬于“direct sequence”或“frequency hopping”類型,或者是這兩種“混合”類型的某種組合。在跳頻中,系統(tǒng)在很寬的頻帶上從一個(gè)頻率“跳”到另一個(gè)頻率。頻率參與的模式是代碼序列的作用,從一個(gè)頻率跳到另一個(gè)頻率的速率是數(shù)據(jù)速率的函數(shù)。
該項(xiàng)目旨在 FPGA 上設(shè)計(jì)、仿真和開發(fā)用于跳頻系統(tǒng)的發(fā)射器和接收器。該項(xiàng)目的完成涵蓋了安全數(shù)字通信的藝術(shù),現(xiàn)在正被用于商業(yè)、工業(yè)和軍事目的。
該設(shè)計(jì)包括以下模塊;PN sequence block; serial to parallel converter; random input block; frequency synthesizer; mixer block。
FPGA 上的數(shù)字視頻縮放
此IP具有以下特點(diǎn):
- AXI STREAM接口;
- 支持向上或者向下縮放;
- 輸入支持RGB或者YYCbCr 444;
- 允許獨(dú)立的水平和垂直縮放,可以生成任何分辨率或者長(zhǎng)寬比;
- 內(nèi)具18個(gè)相位的7×7 FIR多相濾波器來提高視頻質(zhì)量;
- 支持2K及以上視頻;
- 無(wú)需進(jìn)行幀緩沖;
- 雙線性和最近鄰調(diào)整大小模式。
FPGA 上的 Canny 邊緣檢測(cè)
Canny 邊緣檢測(cè)是一種用于視覺處理的多階段算法,用于復(fù)雜視覺算法(例如車牌識(shí)別)的邊緣處理。Canny 邊緣檢測(cè)可以消除不相關(guān)的圖像信息,并為每個(gè)像素提供清晰的輸出。高性能計(jì)算傳統(tǒng)上是通過 Canny 邊緣檢測(cè)來實(shí)現(xiàn)的。但是,現(xiàn)在可以在嵌入式平臺(tái)上為低功耗移動(dòng)應(yīng)用程序?qū)嵤┮曈X算法。多個(gè)處理階段包括 Canny 等視覺算法。通常,處理器必須從外部存儲(chǔ)器獲取、處理輸入圖像幀并將其寫回外部存儲(chǔ)器。對(duì)于下一個(gè)處理塊,處理器重復(fù)這個(gè)過程。這種傳統(tǒng)的塊間內(nèi)存洗牌效率低下:在這個(gè) FPGA 項(xiàng)目中,我們已經(jīng)實(shí)現(xiàn)了帶有 9×9 算子的 Canny 邊緣檢測(cè)器。能夠在每個(gè)時(shí)鐘周期產(chǎn)生 1 個(gè)像素。我們已經(jīng)在高達(dá) 400Mhz 時(shí)鐘頻率的 Virte系列FPGA上成功實(shí)現(xiàn)。該項(xiàng)目的目的是檢測(cè)圖像中的銳利邊緣。
直接數(shù)字頻率合成器
直接數(shù)字合成 (DDS) 通過生成數(shù)字時(shí)變信號(hào)然后進(jìn)行數(shù)模轉(zhuǎn)換來生成模擬波形,通常是正弦波。由于 DDS 系統(tǒng)內(nèi)部的操作主要是數(shù)字操作,因此它可以提供輸出頻率之間的快速切換、令人滿意的頻率分辨率以及在寬頻率范圍內(nèi)的操作。設(shè)計(jì)人員可以使用多種頻率生成:從基于鎖相環(huán) (PLL) 的甚高頻合成技術(shù)到動(dòng)態(tài)數(shù)模轉(zhuǎn)換器 (DAC) 輸出編程,以產(chǎn)生較低頻率的任意波形。
但在通信和工業(yè)應(yīng)用中,DDS 方法正在迅速獲得解決頻率(或波形)生成要求的認(rèn)可,因?yàn)閱?a target="_blank">芯片 IC 器件只能產(chǎn)生具有高分辨率和準(zhǔn)確性的可編程模擬輸出波形。在這個(gè) FPGA 項(xiàng)目中,我們實(shí)現(xiàn)了用于數(shù)字上/下轉(zhuǎn)換和周期波形生成的高精度直接數(shù)字頻率合成器 (DDFS)。例如,正弦波、余弦波、方波和鋸齒波。輸出是 16 位帶符號(hào)數(shù)據(jù)樣本。該項(xiàng)目非常適合正交信號(hào)生成、數(shù)字調(diào)制/解調(diào)和軟件無(wú)線電應(yīng)用。此外,它還可以用作振蕩器和生成復(fù)雜的正交信號(hào)。以及周期性波形的產(chǎn)生。
例如,正弦波、余弦波、方波和鋸齒波。輸出是 16 位帶符號(hào)數(shù)據(jù)樣本。該項(xiàng)目非常適合正交信號(hào)生成、數(shù)字調(diào)制/解調(diào)和軟件無(wú)線電應(yīng)用。此外,它還可以用作振蕩器和生成復(fù)雜的正交信號(hào)。以及周期性波形的產(chǎn)生。例如,正弦波、余弦波、方波和鋸齒波。輸出是 16 位帶符號(hào)數(shù)據(jù)樣本。該項(xiàng)目非常適合正交信號(hào)生成、數(shù)字調(diào)制/解調(diào)和軟件無(wú)線電應(yīng)用。此外,它還可以用作振蕩器和生成復(fù)雜的正交信號(hào)。
優(yōu)化區(qū)塊鏈系統(tǒng)的哈希算法
加密哈希函數(shù)是一種哈希算法。它是一種將任意大小的信息映射到固定大小的哈希的數(shù)學(xué)算法。在 IT 中,加密哈希函數(shù)是很常用的。我們可以將它們用于數(shù)字簽名、消息的身份驗(yàn)證碼 (MAC) 和其他驗(yàn)證類型。我們還可以將它們用于哈希表中的索引數(shù)據(jù)、指紋識(shí)別、文件識(shí)別、檢測(cè)重復(fù)項(xiàng)或用作校驗(yàn)和(我們可以感知發(fā)送的文件是否發(fā)生了意外或故意的數(shù)據(jù)損壞)。哈希函數(shù)的算法被設(shè)計(jì)為一種不可逆的單向函數(shù)。然而,近年來有多種哈希算法被破壞。該 FPGA 項(xiàng)目旨在提供哈希算法的 FPGA 實(shí)現(xiàn),以生成工作量證明 (Pow) 的哈希值。在這個(gè)項(xiàng)目中,開發(fā)了區(qū)塊鏈系統(tǒng)來挖掘0x比特幣。我們使用了CVP 13 FPGA板,并在其上實(shí)現(xiàn)了Keccak-256算法。我們已經(jīng)實(shí)現(xiàn)了每秒500千兆的哈希值。
雷達(dá)信號(hào)處理器在FPGA上的實(shí)現(xiàn)
用于機(jī)載降水回波信號(hào)處理的高性能數(shù)字電子電路——已開發(fā)出商用領(lǐng)域的雷達(dá)測(cè)量設(shè)備——可編程門陣列(FPGA)。以前,將雷達(dá)回波數(shù)據(jù)下行到后處理地面站是一種常見的做法,這是一種昂貴的做法,消除了近實(shí)時(shí)使用自動(dòng)瞄準(zhǔn)數(shù)據(jù)的可能性。理論上,一個(gè)由大約20個(gè)個(gè)人計(jì)算機(jī)類型的微處理器組成的系統(tǒng)可以執(zhí)行機(jī)載處理;與這樣的系統(tǒng)相比,當(dāng)前基于 FPGA 的處理器體積小得多,功耗也低得多。或者,專用集成電路 (ASIC) 可用于板載處理。
然而,與 ASIC 實(shí)現(xiàn)相比,當(dāng)前的 FPGA 實(shí)現(xiàn)具有以下優(yōu)勢(shì):(1) 研究應(yīng)用程序具有更大的通用性,例如當(dāng)前的應(yīng)用程序;(2) 在研究應(yīng)用程序典型的有限生產(chǎn)量中成本更低。在 FPGA 上實(shí)現(xiàn)雷達(dá)信號(hào)處理技術(shù)是重要的領(lǐng)域。在這個(gè)FPGA項(xiàng)目中,我們選擇了FPGA中的幾個(gè)算法實(shí)現(xiàn)雷達(dá)方程以及脈沖壓縮算法,實(shí)現(xiàn)多普勒頻移以檢測(cè)目標(biāo)速度,并實(shí)現(xiàn)脈沖多普勒波形。
在FPGA上實(shí)現(xiàn)了一種恒虛警率(CFAR)檢測(cè)自適應(yīng)算法,用于雷達(dá)系統(tǒng)在噪聲、雜波和干擾的背景下檢測(cè)目標(biāo)信號(hào)。該項(xiàng)目的目的是從噪聲條件下檢測(cè)目標(biāo)。
FPGA 上的快速傅立葉變換 (FFT)
快速傅里葉變換 (FFT) 是 DSP 系統(tǒng)中使用的基本構(gòu)建塊,其應(yīng)用范圍從基于 OFDM 的數(shù)字調(diào)制解調(diào)器到超聲波、雷達(dá)和 CT 圖像重建的算法。盡管它的算法簡(jiǎn)單易懂,但對(duì)于當(dāng)今的工程師來說,實(shí)現(xiàn)架構(gòu)和細(xì)節(jié)的變體是必不可少的,并且是一個(gè)巨大的時(shí)間消耗。在這個(gè)FPGA項(xiàng)目中,我們?cè)贔PGA上實(shí)現(xiàn)了快速傅里葉變換;我們已經(jīng)使用蝶形技術(shù)在FPGA上實(shí)現(xiàn)了它。
FFT用于在復(fù)雜信號(hào)計(jì)劃中執(zhí)行頻率分量的查找。這是一個(gè)4096點(diǎn)的FFT。通過設(shè)備級(jí)固定點(diǎn)C模型,該FFT項(xiàng)目核心提供了四種不同的架構(gòu),并將平均實(shí)現(xiàn)時(shí)間從3-6個(gè)月縮短到按下一個(gè)按鈕。它還為用戶提供了對(duì)DSP算法和硬件工程師所需的所有適當(dāng)算法和實(shí)現(xiàn)進(jìn)行復(fù)雜權(quán)衡的機(jī)會(huì)。FFT項(xiàng)目強(qiáng)調(diào)增加動(dòng)態(tài)范圍,將數(shù)據(jù)和相位因子寬度的支持增加到34位,并支持IEEE單精度浮點(diǎn)數(shù)據(jù)形式。通過在內(nèi)部使用更高精度的定點(diǎn)FFT,實(shí)現(xiàn)可比的噪聲效率。
在 FPGA 上將 BCD 碼轉(zhuǎn)換為 7 段碼
數(shù)字解碼器 IC 是一種將一種數(shù)字格式轉(zhuǎn)換為另一種數(shù)字格式的設(shè)備,二進(jìn)制編碼的十進(jìn)制 (BCD) 到 7 段顯示解碼器是執(zhí)行此操作最廣泛使用的設(shè)備之一。7 段 LED(發(fā)光二極管)或 LCD(液晶顯示器)式顯示器為數(shù)字、字母甚至字母數(shù)字字符提供了一種非常方便的方式來顯示信息或數(shù)字?jǐn)?shù)據(jù)。通常,7 段顯示器由七個(gè)不同顏色的 LED(稱為段)組成。LED 段的正確組合需要在顯示屏上點(diǎn)亮,以生成從 0 到 9 和 A 到 F 的必要數(shù)字或十六進(jìn)制字符,相應(yīng)地,BCD 到 7 段顯示解碼器 74LS47 就是這樣做的。
FPGA 上的數(shù)字時(shí)鐘
數(shù)字時(shí)鐘的主要用途是使用 Artix-7 FPGA 板上的 7 段面板以數(shù)字方式顯示時(shí)間。默認(rèn)情況下,數(shù)字時(shí)鐘顯示運(yùn)行時(shí)間,可以使用分配給板載開關(guān)的時(shí)間設(shè)置來調(diào)整時(shí)間。警報(bào)角色也使用警報(bào)集和套件開關(guān)上的警報(bào)進(jìn)行配置。開發(fā)的數(shù)字時(shí)鐘是為 24 時(shí)鐘設(shè)計(jì)的格式。對(duì)于數(shù)字時(shí)鐘的硬件實(shí)現(xiàn),本項(xiàng)目采用FPGA。一旦 FPGA 打開,時(shí)鐘就會(huì)開始。FPGA 和板載時(shí)鐘將產(chǎn)生時(shí)序信號(hào)。可以使用板上的撥碼開關(guān)設(shè)置時(shí)鐘時(shí)間和鬧鐘時(shí)間。
使用數(shù)字運(yùn)算:計(jì)數(shù)、比較、遞增和遞減,改進(jìn)了建議的數(shù)字時(shí)鐘設(shè)計(jì)。使用時(shí)間設(shè)置開關(guān),可以設(shè)置時(shí)鐘時(shí)間,可以使用鬧鐘設(shè)置開關(guān)設(shè)置鬧鐘時(shí)間。如果時(shí)鐘等于鬧鐘時(shí)間,鬧鐘就會(huì)響起。通過使用顯示器上的按鈕,可以增加和減少分鐘和小時(shí)。在這個(gè) FPGA 項(xiàng)目中,我們?cè)?FPGA 上實(shí)現(xiàn)了數(shù)字時(shí)鐘。該模塊有一個(gè)輸入“FPGA 的源時(shí)鐘”,有 3 個(gè)輸出(時(shí)針、分針和秒針)。
FPGA 上的 JPEG 硬件壓縮器
壓縮圖像可以通過在不顯著降低圖像存儲(chǔ)和傳輸圖像質(zhì)量的情況下最大限度地減少成本和時(shí)間來提高設(shè)備效率??梢栽趫D像元素(像素)的矩陣上描述每個(gè)像素的單色圖像,由8位的灰度值描述。圖像數(shù)據(jù)的這種描述可能需要大量存儲(chǔ)需求。圖像壓縮旨在減小圖像的大小,同時(shí)保留大部分細(xì)節(jié)。它可以是有損壓縮,也可以是無(wú)損壓縮。
與無(wú)損壓縮相比,有損在數(shù)據(jù)量上有更高的壓縮比;而只是初始?jí)嚎s的近似值,可以重新創(chuàng)建圖像。圖像壓縮有很多規(guī)范,例如聯(lián)合圖像專家解壓縮 (CODEC) 團(tuán)隊(duì)、圖形交換格式 (GIF)、便攜式網(wǎng)絡(luò)圖形 (PNG)、文件圖片標(biāo)簽格式 (TIFF)。最常用的 JPEG 壓縮方式,使用并基于余弦離散變換 (DCT) 的有損圖像壓縮類型。根據(jù)在圖像和圖像中發(fā)現(xiàn)的細(xì)節(jié),JPEG 格式的壓縮圖像的壓縮效率可能約為原始大小的 10%。結(jié)果是所需帶寬減少了 90%。這個(gè) FPGA 項(xiàng)目包括一個(gè)完整的 JPEG 硬件,具有 4:1:1 子采樣,能夠以最大分辨率(256×256 @ 60 MHz)以每秒高達(dá) 42 張圖像的速率進(jìn)行壓縮,并將壓縮的JPEG圖像輸出到存儲(chǔ)器。。
FPGA 上的 FM 接收器
我們?cè)?FPGA 上構(gòu)建了一個(gè)簡(jiǎn)單的 FM 接收器,用于解調(diào) FM 調(diào)制頻率信號(hào)。我們使用偶極天線接收 FM 信號(hào),然后使用 FM 解調(diào)器邏輯解調(diào)接收到的信號(hào)。首先,我們使用ADC將模擬FM信號(hào)轉(zhuǎn)換為數(shù)字信號(hào),然后對(duì)其進(jìn)行數(shù)字處理以去除載波,從而獲得來自廣播電臺(tái)的唯一純聲波。
FPGA 上的平方根
在物理學(xué)中,平方根函數(shù)sqrt(x)是一個(gè)重要的基本函數(shù)——數(shù)字信號(hào)和圖像處理,ANN方程。現(xiàn)場(chǎng)可編程門陣列(FPGA)目前正在擴(kuò)展以解決這個(gè)問題。需要計(jì)算函數(shù)sqrt(x)的問題。FPGA制造商和第三方公司正在提出sqrt計(jì)算(x)的各種IP核心。但這些IP核心是幾十年前開發(fā)的,通常沒有考慮到最新一代FPGA的特性。
因此,它們確實(shí)需要升級(jí)。在這個(gè)FPGA項(xiàng)目中,提出了一種計(jì)算sqrt(x)的增強(qiáng)特征算法,它適合FPGA的實(shí)現(xiàn)。已經(jīng)在FPGA上編寫了一個(gè)代碼來尋找有符號(hào)數(shù)的平方根。該代碼基于“非恢復(fù)平方根算法”。該代碼采用一個(gè)32位大小的有符號(hào)數(shù)字,并返回平方根,平方根也是16位大小的帶符號(hào)類型。提出了一種類似CORDIC的改進(jìn)算法,用于推導(dǎo)平方根方程。該算法由與給定數(shù)據(jù)成比例的減少的步數(shù)之和分開,結(jié)果是位寬。
FPGA 錯(cuò)誤檢測(cè)-CRC
錯(cuò)誤檢測(cè)決定了通過介質(zhì)獲得的數(shù)據(jù)在傳輸時(shí)是否損壞。為實(shí)現(xiàn)這一點(diǎn),發(fā)射器使用一種功能來測(cè)量原始數(shù)據(jù)幀的數(shù)據(jù)校驗(yàn)和并附加校驗(yàn)和值。為了為接收到的數(shù)據(jù)幀創(chuàng)建校驗(yàn)和,接收器使用相同的計(jì)算技術(shù)并將接收到的校驗(yàn)和與傳輸?shù)男r?yàn)和進(jìn)行比較。如果兩個(gè)校驗(yàn)和值相同,則得到的數(shù)據(jù)幀是正確的,在傳輸或存儲(chǔ)過程中沒有數(shù)據(jù)損壞。在這個(gè) FPGA 項(xiàng)目中,在這個(gè)FPGA項(xiàng)目中,我們?cè)贔PGA上開發(fā)了CRC來檢測(cè)傳輸消息中的錯(cuò)誤。所生成的CRC電路的優(yōu)點(diǎn)是假定輸入被串行饋送到電路中。這意味著,輸入可能很長(zhǎng),并且FPGA資源的使用仍然保持不變。
FPGA 上的環(huán)形計(jì)數(shù)器
環(huán)形計(jì)數(shù)器是一種由連接到移位寄存器的觸發(fā)器組成的計(jì)數(shù)器,最后一個(gè)觸發(fā)器的輸出饋送到第一個(gè)觸發(fā)器的輸入,形成“循環(huán)”或“環(huán)形”結(jié)構(gòu)。在硬件設(shè)計(jì)(例如,ASIC 和FPGA 設(shè)計(jì))中,環(huán)形計(jì)數(shù)器也用于構(gòu)造有限狀態(tài)機(jī)。二進(jìn)制計(jì)數(shù)器將需要一個(gè)比環(huán)形計(jì)數(shù)器復(fù)雜得多的加法器電路,并且隨著位數(shù)的增加具有更顯著的傳播延遲,而無(wú)論代碼的位數(shù)如何,環(huán)形計(jì)數(shù)器的傳播延遲幾乎都是恒定的。在這個(gè)FPGA項(xiàng)目中,在FPGA上實(shí)現(xiàn)了一個(gè)環(huán)形計(jì)數(shù)器,由一系列正連接的觸發(fā)器組成。該電路是一種特殊類型的移位寄存器,其中最后一個(gè)觸發(fā)器的輸出被反饋到第一個(gè)觸發(fā)器輸入。
基于 AES 的加密處理器的 FPGA 實(shí)現(xiàn)
對(duì)數(shù)據(jù)安全的需求增加是不可否認(rèn)的事實(shí)。為了實(shí)現(xiàn)更高的安全性,加密算法在保護(hù)數(shù)據(jù)免遭未經(jīng)批準(zhǔn)的使用方面發(fā)揮著至關(guān)重要的作用。在這個(gè) FPGA 項(xiàng)目中,我們展示了一個(gè)使用高級(jí)加密標(biāo)準(zhǔn) (AES) 的加密處理器。AES 集成了一個(gè) 32 位通用 5 級(jí)流水線 MIPS 處理器。集成的AES模塊是一個(gè)全流水線模塊,遵循內(nèi)圓和外圓流水線設(shè)計(jì)。結(jié)果表明,所呈現(xiàn)的 AES 算法流水線版本和 MIPS 處理器優(yōu)于傳統(tǒng)方法。在 553 MHz 的工作頻率下,所提出的設(shè)計(jì)可以實(shí)現(xiàn) 58 Gbps 的吞吐量、240 ns 的延遲和 76 MW 的功耗。
設(shè)計(jì)是這樣實(shí)現(xiàn)的,即使加密協(xié)處理器同時(shí)運(yùn)行,加密指令也不會(huì)阻塞處理器的指令獲取周期。默認(rèn)情況下,如果指令是為處理器設(shè)計(jì)的,則每條指令都從指令內(nèi)存單元中取出并在 MIPS 處理器上完成其所有周期。然而,如果獲取指令不是MIPS指令,它將在解碼階段后的下一個(gè)時(shí)鐘周期被發(fā)送到密碼協(xié)處理器。我們將加密協(xié)處理器與 MIPS 合并并進(jìn)行這種集成,以便加密協(xié)處理器由 MIPS 運(yùn)行而不會(huì)干擾流水線階段。本項(xiàng)目的主要貢獻(xiàn)如下:
- 實(shí)現(xiàn)了AES的流水線版本,獲得了高吞吐量、低延遲和低功耗。
- 提出了AES 和MIPS 的集成,可以運(yùn)行在不同的頻率。
- 實(shí)施的 AES 充當(dāng)由 MIPS 指令控制的加密處理器,同時(shí)它不會(huì)干擾 MIPS 處理器的流水線階段。
評(píng)論
查看更多