日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當(dāng)前位置:首頁 > 工業(yè)控制 > 電路設(shè)計項目集錦
[導(dǎo)讀]我們最近一直在研究的一件事是,在與Versal Devices合作時,使用Vitis開發(fā)解決方案。例如,請參閱我的項目在Vitis系統(tǒng)設(shè)計的Versal和使用芯片范圍調(diào)試Versal設(shè)計。

我們最近一直在研究的一件事是,在與Versal Devices合作時,使用Vitis開發(fā)解決方案。例如,請參閱我的項目在Vitis系統(tǒng)設(shè)計的Versal和使用芯片范圍調(diào)試Versal設(shè)計。

在這個項目中,我們將研究如何在AIE和HLS開發(fā)中使用Vitis功能仿真。

但什么是功能模擬?在為通用設(shè)備開發(fā)時,我們通常有獨立的PL或AIE設(shè)計,或者需要在組合設(shè)計中同時使用PL和AIE的異構(gòu)設(shè)計。

功能仿真使我們能夠在進行循環(huán)精確仿真之前驗證行為和驗證設(shè)計的功能正確性(Vitis子系統(tǒng)仿真)。

以前,我們已經(jīng)能夠使用x86模擬器進行AIE引擎開發(fā),并使用C-Sim進行HLS內(nèi)核功能仿真。然而,Vitis功能仿真為開發(fā)人員提供了一系列新的更高層次的抽象框架,我們可以使用這些框架執(zhí)行功能仿真。

Vitis Functional Simulation,使開發(fā)人員能夠使用Python或MATLAB單獨或組合地模擬HLS和AIE引擎。這種使用高級框架的能力可以加快開發(fā)時間,并使功能驗證與算法開發(fā)時使用的語言保持一致。

Vitis功能仿真

當(dāng)使用Vitis功能仿真時,我們在設(shè)計中獲得了幾個好處,包括

?編譯HLS內(nèi)核或AIE引擎圖(如果需要)。

?能力模擬和調(diào)試,因為我們正在建立的設(shè)計。

?仿真性能顯著提高,使仿真運行速度更快,因此能夠捕獲數(shù)百萬個樣本來計算性能,例如信號噪聲等。

由于VFS支持MATLAB和Python框架,因此VFS需要能夠有效地處理Python或MATLAB原生不支持的一系列類型,例如bfloat16, mex9, float8。為了使VFS能夠使用變量來轉(zhuǎn)換MATLAB數(shù)組和Python Numpy數(shù)組,列表和元組。varray的工作方式類似于Python中的numpy數(shù)組或MATLAB中的數(shù)組,但將所有所需的數(shù)據(jù)類型放在一個保護傘下。

支持的數(shù)據(jù)類型,取決于所使用的框架和AIE、AIE- ml和AIE- mlv2的目標(biāo)設(shè)備,下表提供了一個很好的參考。

而對于HLS內(nèi)核,類型如下。

有兩種方法可以實例化AIE或HLS內(nèi)核對象。

?配置文件-定義構(gòu)建細節(jié),如果存在將使用的構(gòu)建。如果沒有一個將被編譯和使用。

?鍵值對——定義輸入文件、平臺和仿真參數(shù)。然后,這些將用于創(chuàng)建配置文件。

在這個項目中,我們將探索使用Python流來驗證HLS設(shè)計。我們可以在通用設(shè)備上這樣做,但也可以在任何我們想要放置HLS IP核的設(shè)備上使用這種方法。

環(huán)境設(shè)置

要開始使用VFS,我們需要在安裝了Vitis 2025.1的Linux機器上進行開發(fā)。

對于這個例子,我將使用我的一臺Linux開發(fā)機器。

首先要做的是設(shè)置Vitis環(huán)境,這將允許我們的腳本根據(jù)需要調(diào)用Vitis。

在這個演示中,我將使用VSCode,因為它是開發(fā)python應(yīng)用程序的流行框架。因此,我使用集成終端。

建立了Vitis環(huán)境后,下一步是確保我們擁有所有必要的附加條件。在python中,我們唯一需要的VFS是NumPy。

如果您沒有,我們可以使用命令安裝它

請等待NumPy安裝完成。

為了檢查我們是否擁有我們需要的一切,我們可以在終端中啟動python3,并檢查我們是否能夠?qū)氡匾膒ython

如果沒有問題,我們就可以開始創(chuàng)建測試應(yīng)用程序了。

測試應(yīng)用程序

對于這個模塊,我們將編寫一個簡單的HLS模塊,它將兩個數(shù)字相加。

這將使用AXI流輸入,每個輸入最多可達64位,并將它們加在一起。

這段代碼定義了兩個實現(xiàn)流(FIFO通道)的輸入,它們攜帶64位無符號不帶小數(shù)位的定點數(shù)字。

結(jié)果創(chuàng)建一個流(FIFO通道),它也攜帶64位無符號定點數(shù)。

然后將這兩個輸入加在一起,以創(chuàng)建一個結(jié)果,該結(jié)果在編譯時采用該類型。

最后,將結(jié)果寫入輸出。

雖然簡單,但這演示了我們?nèi)绾卧贖SL IP內(nèi)核上使用流接口。

VFS測試應(yīng)用

VFS測試應(yīng)用程序如下所示

讓我們來分析一下

我們要做的第一件事是正確設(shè)置python腳本中所需的模塊。

在這種情況下,我們將導(dǎo)入VFS模塊,使我們能夠支持Vitis功能仿真。該模塊將為腳本提供所有必要的函數(shù)來定義HLS內(nèi)核,檢查其輸入和輸出,當(dāng)然在模擬中運行HSL內(nèi)核。

然后我們還需要導(dǎo)入數(shù)組類型,使我們能夠與HLS內(nèi)核共享數(shù)據(jù)。

要導(dǎo)入的最后一個模塊是numpy,它使我們能夠創(chuàng)建隨機數(shù)數(shù)組。

導(dǎo)入模塊后,下一步是創(chuàng)建HLS內(nèi)核對象,在此流程中,我使用鍵值對方法。在這種方法中,我們提供了HLS內(nèi)核的源代碼,所針對的部分板和要模擬的實際HLS函數(shù)的名稱。

下一步是設(shè)置我們希望生成的隨機樣本的數(shù)量。

然后還創(chuàng)建了兩個NumPy數(shù)組,其中包含0到63之間的隨機數(shù)。創(chuàng)建的隨機樣本的數(shù)量取決于前面定義的隨機樣本的數(shù)量。這使得測試平臺可以根據(jù)需要進行縮放。

但是,我們需要將NumPy數(shù)組轉(zhuǎn)換為一種不同的格式,以便能夠?qū)㈦S機數(shù)應(yīng)用于HLS內(nèi)核。

我們使用va模塊數(shù)組類型,對于我們用來將NumPy數(shù)組轉(zhuǎn)換為無符號(0),64位寬(64)和0小數(shù)的固定類型的varray,因為我們的目標(biāo)是HLS內(nèi)核中的ap_unit類型。

接下來的兩行報告HLS內(nèi)核上的輸入格式和輸出類型。

這應(yīng)該與我們期望的類型和寬度保持一致。

最后,內(nèi)核可以運行,VFS的結(jié)果可以在輸出數(shù)組中捕獲。當(dāng)然,這將被格式化為一個數(shù)組。

然后我們可以顯示輸入值和輸出結(jié)果,當(dāng)然結(jié)果應(yīng)該是兩個輸入值的相加。

運行模擬將顯示HLS內(nèi)核的編譯,因為沒有進行預(yù)編譯。

編譯完成后,將加載hlkernel,并完成Vitis功能仿真。

總結(jié)

該項目展示了如何使用Python模擬Vitis HLS內(nèi)核,這為我們提供了一種非常靈活的方法,可以使用最流行的算法開發(fā)框架之一來驗證功能。

本文編譯自hackster.io

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

LED驅(qū)動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: 驅(qū)動電源

在工業(yè)自動化蓬勃發(fā)展的當(dāng)下,工業(yè)電機作為核心動力設(shè)備,其驅(qū)動電源的性能直接關(guān)系到整個系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動勢抑制與過流保護是驅(qū)動電源設(shè)計中至關(guān)重要的兩個環(huán)節(jié),集成化方案的設(shè)計成為提升電機驅(qū)動性能的關(guān)鍵。

關(guān)鍵字: 工業(yè)電機 驅(qū)動電源

LED 驅(qū)動電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個照明設(shè)備的使用壽命。然而,在實際應(yīng)用中,LED 驅(qū)動電源易損壞的問題卻十分常見,不僅增加了維護成本,還影響了用戶體驗。要解決這一問題,需從設(shè)計、生...

關(guān)鍵字: 驅(qū)動電源 照明系統(tǒng) 散熱

根據(jù)LED驅(qū)動電源的公式,電感內(nèi)電流波動大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關(guān)鍵字: LED 設(shè)計 驅(qū)動電源

電動汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產(chǎn)業(yè)的重要發(fā)展方向。電動汽車的核心技術(shù)之一是電機驅(qū)動控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機驅(qū)動系統(tǒng)中的關(guān)鍵元件,其性能直接影響到電動汽車的動力性能和...

關(guān)鍵字: 電動汽車 新能源 驅(qū)動電源

在現(xiàn)代城市建設(shè)中,街道及停車場照明作為基礎(chǔ)設(shè)施的重要組成部分,其質(zhì)量和效率直接關(guān)系到城市的公共安全、居民生活質(zhì)量和能源利用效率。隨著科技的進步,高亮度白光發(fā)光二極管(LED)因其獨特的優(yōu)勢逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關(guān)鍵字: 發(fā)光二極管 驅(qū)動電源 LED

LED通用照明設(shè)計工程師會遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關(guān)鍵字: LED 驅(qū)動電源 功率因數(shù)校正

在LED照明技術(shù)日益普及的今天,LED驅(qū)動電源的電磁干擾(EMI)問題成為了一個不可忽視的挑戰(zhàn)。電磁干擾不僅會影響LED燈具的正常工作,還可能對周圍電子設(shè)備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來解決L...

關(guān)鍵字: LED照明技術(shù) 電磁干擾 驅(qū)動電源

開關(guān)電源具有效率高的特性,而且開關(guān)電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機重量也有所下降,所以,現(xiàn)在的LED驅(qū)動電源

關(guān)鍵字: LED 驅(qū)動電源 開關(guān)電源

LED驅(qū)動電源是把電源供應(yīng)轉(zhuǎn)換為特定的電壓電流以驅(qū)動LED發(fā)光的電壓轉(zhuǎn)換器,通常情況下:LED驅(qū)動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: LED 隧道燈 驅(qū)動電源
關(guān)閉