国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

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

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

3天內(nèi)不再提示

簡述HLS中的數(shù)組初始化遇到的那些個(gè)問題

OpenFPGA ? 來源:TeacherGaoFPGAHub ? 作者:TeacherGaoFPGAHub ? 2021-07-21 09:36 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

在HLS中使用數(shù)組時(shí),尤其是對(duì)數(shù)組初始化時(shí),盡可能加上關(guān)鍵字static,這樣C++中數(shù)組的行為才能與RTL中存儲(chǔ)單元的行為保持一致。例如:將FIR濾波器系數(shù)存儲(chǔ)在數(shù)組coeff中,由于系數(shù)固定不變,可以斷定該數(shù)組最終映射為RTL中的ROM

添加static之后,每次函數(shù)在被執(zhí)行時(shí),數(shù)組coeff都會(huì)記住其前一次被調(diào)用時(shí)的值。這就要理解static在C++中的含義,即static規(guī)定其指定的變量存儲(chǔ)方式為靜態(tài)存儲(chǔ)方式,每次調(diào)用的初始值為上一次調(diào)用的值,調(diào)用結(jié)束后存儲(chǔ)空間不釋放。對(duì)于指定static關(guān)鍵字的變量,VitisHLS在生成RTL代碼時(shí)會(huì)對(duì)其先進(jìn)行初始化。

7bb53a22-e428-11eb-a97a-12bb97331649.png

如果數(shù)組在整個(gè)函數(shù)執(zhí)行過程中只發(fā)生讀操作而沒有寫操作,那么建議添加關(guān)鍵字const,以保證VitisHLS能正確推斷出ROM。

如果在ROM的初始化過程中出現(xiàn)復(fù)雜的運(yùn)算,例如使用了math.h中的函數(shù)等,建議將初始化過程單獨(dú)封裝為一個(gè)函數(shù)。我們來看一個(gè)案例。在下面的代碼中,函數(shù)init_sin_table用于初始化數(shù)組sin_table。在其初始化過程中會(huì)調(diào)用math.h中的函數(shù)sin。

sin要求其形參為float或double。函數(shù)lookup_math中聲明了數(shù)組sin_table,并添加關(guān)鍵字static。在代碼第17行調(diào)用了函數(shù)init_sin_table完成數(shù)組初始化。第18行則是從sin_table中獲取相應(yīng)地址上的數(shù)據(jù)完成最終的乘法運(yùn)算。

7be282b6-e428-11eb-a97a-12bb97331649.png

從HLS綜合后的報(bào)告來看,最終sin_table的存儲(chǔ)形式(報(bào)告中的Storage列)為rom_1p,實(shí)現(xiàn)方式為auto,Latency為1。在資源評(píng)估報(bào)告中可以看到消耗了1個(gè)BRAM。

7c1a0862-e428-11eb-a97a-12bb97331649.png

7c46f2dc-e428-11eb-a97a-12bb97331649.png

編輯:jq

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • HLS
    HLS
    +關(guān)注

    關(guān)注

    1

    文章

    135

    瀏覽量

    25829

原文標(biāo)題:HLS中的數(shù)組初始化問題

文章出處:【微信號(hào):Open_FPGA,微信公眾號(hào):OpenFPGA】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    PC強(qiáng)實(shí)時(shí)運(yùn)動(dòng)控制(一):C#的EtherCAT總線初始化(下)

    通過使用配置工具導(dǎo)出ZAR文件進(jìn)行EtherCAT總線初始化
    的頭像 發(fā)表于 02-05 10:00 ?916次閱讀
    PC強(qiáng)實(shí)時(shí)運(yùn)動(dòng)控制(一):C#的EtherCAT總線<b class='flag-5'>初始化</b>(下)

    RK平臺(tái)網(wǎng)絡(luò)問題排查指南:從初始化到吞吐量,一文搞定常見故障

    在嵌入式開發(fā),RK(瑞芯微)平臺(tái)憑借高性能、高兼容性廣泛應(yīng)用于物聯(lián)網(wǎng)、工業(yè)控制等場景,而以太網(wǎng)作為核心通信接口,其穩(wěn)定性直接決定了設(shè)備的可用性。但實(shí)際開發(fā),我們常會(huì)遇到初始化失敗、
    的頭像 發(fā)表于 02-02 17:22 ?2214次閱讀
    RK平臺(tái)網(wǎng)絡(luò)問題排查指南:從<b class='flag-5'>初始化</b>到吞吐量,一文搞定常見故障

    國民技術(shù)發(fā)布N32Cube芯片配置與初始化代碼生成工具

    1月30日,國民技術(shù)(NSING)正式發(fā)布N32Cube——芯片配置與初始化代碼生成工具,讓時(shí)鐘、引腳與外設(shè)的配置一目了然、輕松上手!
    的頭像 發(fā)表于 02-02 15:26 ?540次閱讀
    國民技術(shù)發(fā)布N32Cube芯片配置與<b class='flag-5'>初始化</b>代碼生成工具

    MCU工程初始化,到底該不該交給工具?

    初始化 MCU特殊外設(shè)或硬件約束 工程驗(yàn)證和調(diào)試 結(jié)論 交給工具并不意味著放棄控制 而是讓工程師從重復(fù)操作解放出來 專注于不可自動(dòng)的高價(jià)值工作 審核編輯 黃宇
    的頭像 發(fā)表于 01-29 10:18 ?140次閱讀
    MCU工程<b class='flag-5'>初始化</b>,到底該不該交給工具?

    EtherCAT總線初始化步驟

    EtherCAT(Ethernet for Control Automation Technology)是一種高性能的工業(yè)以太網(wǎng)通信協(xié)議,廣泛應(yīng)用于工業(yè)自動(dòng)領(lǐng)域。其初始化過程是確保系統(tǒng)穩(wěn)定運(yùn)行
    的頭像 發(fā)表于 12-22 10:10 ?575次閱讀
    EtherCAT總線<b class='flag-5'>初始化</b>步驟

    數(shù)組的初體驗(yàn)

    的物品是按一定順序放置的。 1.我們來看一下如何聲明一個(gè)數(shù)組: 數(shù)據(jù)類型 數(shù)組名稱[長度]; 數(shù)組只聲明也不行啊,看一下數(shù)組是如何
    發(fā)表于 11-25 08:06

    瀚海微SD NAND TF卡硬件識(shí)別與初始化類問題探討

    在瀚海微SD NAND/TF卡的實(shí)際應(yīng)用,硬件識(shí)別與初始化是保障設(shè)備正常運(yùn)行的首要環(huán)節(jié),該環(huán)節(jié)出現(xiàn)故障會(huì)直接導(dǎo)致存儲(chǔ)卡無法投入使用,尤其在工業(yè)控制、車載設(shè)備等關(guān)鍵場景,可能引發(fā)設(shè)備停機(jī)、數(shù)據(jù)丟失
    的頭像 發(fā)表于 11-18 09:58 ?515次閱讀
    瀚海微SD NAND  TF卡硬件識(shí)別與<b class='flag-5'>初始化</b>類問題探討

    串口通信基石:Air8000下Modbus RTU串口初始化詳解!

    串口初始化是Modbus RTU通信穩(wěn)定可靠的關(guān)鍵起點(diǎn)。本篇深入剖析Air8000開發(fā)板串口參數(shù)配置、初始化代碼實(shí)現(xiàn)及調(diào)試要點(diǎn),結(jié)合master_rtu示例,分享實(shí)際操作的經(jīng)驗(yàn)與避坑指南,讓您
    的頭像 發(fā)表于 10-28 16:33 ?1653次閱讀
    串口通信基石:Air8000下Modbus RTU串口<b class='flag-5'>初始化</b>詳解!

    NVMe高速傳輸之?dāng)[脫XDMA設(shè)計(jì)33:初始化功能驗(yàn)證與分析

    模型。 在這里以最小存儲(chǔ)子系統(tǒng)模型為例說明對(duì)初始化功能的驗(yàn)證與分析。 在本節(jié)測(cè)試用例, 設(shè)置橋設(shè)備模型不啟用 BAR 空間, 設(shè)置 NVMe 設(shè)備模型 BAR0 空間大小為 64KB, 不啟用其余
    發(fā)表于 10-08 08:02

    GraniStudio:IO初始化以及IO資源配置例程

    1.文件運(yùn)行 導(dǎo)入工程 雙擊運(yùn)行桌面GraniStudio.exe。 通過引導(dǎo)界面導(dǎo)入IO初始化以及IO資源配置例程,點(diǎn)擊導(dǎo)入按鈕。 打開IO初始化以及IO資源配置例程所在路徑,選中IO初始化以及
    的頭像 發(fā)表于 08-22 17:34 ?933次閱讀
    GraniStudio:IO<b class='flag-5'>初始化</b>以及IO資源配置例程

    GraniStudio:初始化例程

    1.文件運(yùn)行 導(dǎo)入工程 雙擊運(yùn)行桌面GraniStudio.exe。 通過引導(dǎo)界面導(dǎo)入初始化例程,點(diǎn)擊導(dǎo)入按鈕。 打開初始化例程所在路徑,選中初始化.gsp文件,點(diǎn)擊打開,完成導(dǎo)入。 2.功能
    的頭像 發(fā)表于 08-22 16:45 ?891次閱讀
    GraniStudio:<b class='flag-5'>初始化</b>例程

    MCU外設(shè)初始化:為什么參數(shù)配置必須優(yōu)先于使能

    在微控制器領(lǐng)域,初始化參數(shù)配置階段至關(guān)重要。此時(shí),雖無電源驅(qū)動(dòng),但微控制器在使能信號(hào)到來前,借初始化參數(shù)配置這一精細(xì)步驟,開啟關(guān)鍵準(zhǔn)備進(jìn)程。初始化參數(shù)配置如同物理坐標(biāo)錨定、邏輯指令部署、內(nèi)在秩序預(yù)設(shè)
    的頭像 發(fā)表于 08-13 10:38 ?788次閱讀

    定義IO初始化結(jié)構(gòu)體

    由上述IOPORT相關(guān)功能的枚舉類型我們可以知道,在對(duì)IOPORT模塊進(jìn)行初始化時(shí)需要根據(jù)情況配置它們。因此我們定義一個(gè)IOPORT初始化的結(jié)構(gòu)體類型IOPORT_Init_t,它的成員包括了由上述所有枚舉類型所聲明的變量,因此該結(jié)構(gòu)體類型的變量可以包含IOPORT的相關(guān)
    的頭像 發(fā)表于 07-16 16:26 ?1407次閱讀

    IM系列設(shè)備過載故障:界面初始化終止的診斷流程與修復(fù)指南

    當(dāng) IM 系列設(shè)備出現(xiàn)過載故障導(dǎo)致界面初始化終止時(shí),通常表現(xiàn)為設(shè)備啟動(dòng)后操作界面無顯示、指示燈異常閃爍或初始化進(jìn)度條停滯不前,同時(shí)可能伴隨設(shè)備運(yùn)行異響或異常發(fā)熱。初步判斷時(shí),可觀察設(shè)備是否有錯(cuò)
    的頭像 發(fā)表于 06-28 09:47 ?1207次閱讀

    IM 系列設(shè)備過載保護(hù)機(jī)制下界面初始化中斷的底層邏輯與解決方案

    一、過載保護(hù)機(jī)制與界面初始化的關(guān)聯(lián)基礎(chǔ) IM 系列設(shè)備的過載保護(hù)機(jī)制是保障設(shè)備安全運(yùn)行的核心功能,其通過傳感器實(shí)時(shí)采集設(shè)備運(yùn)行參數(shù),如電流、電壓、溫度、系統(tǒng)資源占用率等。一旦這些參數(shù)超出預(yù)設(shè)閾值
    的頭像 發(fā)表于 06-27 09:58 ?540次閱讀