RM新时代网站-首页

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

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

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

把一個算法用RTL實(shí)現(xiàn),有哪些比較科學(xué)的步驟?

FPGA之家 ? 來源:FPGA之家 ? 作者:FPGA之家 ? 2022-04-26 10:19 ? 次閱讀

針對近日技術(shù)交流群里討論的算法與RTL實(shí)現(xiàn)問題,寫篇文章,做一次總結(jié)。

新手遇到的是新問題,對于有相關(guān)經(jīng)驗(yàn)的工程師而言,可能都遇到過。

作為算法、FPGAIC等集中交流的平臺,群賢畢至,集思廣益,解決大家對相關(guān)知識和技術(shù)上的困惑,讓問題變得更簡單。

群友們提到一個很多人都會遇到的現(xiàn)實(shí)問題:

“把一個算法用RTL實(shí)現(xiàn),有哪些比較科學(xué)的步驟?第一步干什么?第二步干什么?第三步干什么……?”

c5cfc0d6-c506-11ec-bce3-dac502259ad0.png

這個問題,對于FPGA、ASIC等邏輯電路設(shè)計人員來講,是非常重要的問題。

通常來講,我們做算法實(shí)現(xiàn),需要有對標(biāo)的算法模型,作為驗(yàn)證硬件邏輯設(shè)計是否正確的參考依據(jù)。

我們首先要根據(jù)實(shí)際需求,針對某方面的信號處理問題,做一個鏈路級或模塊級快速仿真驗(yàn)證設(shè)計。最常見的比如通過MATLAB/C/C++等軟件環(huán)境進(jìn)行設(shè)計和驗(yàn)證。

c5ddef1c-c506-11ec-bce3-dac502259ad0.png

軟件環(huán)境可以快速搭建仿真模型,并且進(jìn)行驗(yàn)證,為硬件RTL實(shí)現(xiàn)提供參考依據(jù)。在具體算法設(shè)計時,必須考慮數(shù)據(jù)流的處理過程:數(shù)據(jù)從哪里來,數(shù)據(jù)需要經(jīng)過哪些步驟處理,處理之后送到哪里。

接下來,我們需要將MATLAB、C++等算法模型由浮點(diǎn)轉(zhuǎn)為定點(diǎn),這個工作可以做好之后再去做邏輯設(shè)計,也可以省略,但一定要清楚是如何定點(diǎn)的。

做好算法設(shè)計后,需要進(jìn)行性能評估,看是否符合預(yù)期要求,不符合則進(jìn)一步優(yōu)化,或者換一種設(shè)計方法。

在做邏輯實(shí)現(xiàn)之前,還有一個重要工作,就是對算法處理步驟進(jìn)行一步一步分解,解決如何從a到b再到c的過程,落實(shí)到加減乘除。

當(dāng)算法實(shí)際滿足要求后,則考慮邏輯實(shí)現(xiàn)的問題。

首先,建議采用自頂向下的設(shè)計思想,進(jìn)行系統(tǒng)架構(gòu)設(shè)計,明確整個處理過程,需要執(zhí)行哪些功能,涉及哪些接口。

c5ea2908-c506-11ec-bce3-dac502259ad0.png

接下來,選芯片器件,評估資源占用情況,評估需要用多少乘法器,除法器,DSP,BRAM,GT等。

其次,評估處理時間要求,是否需要實(shí)時性處理,給予多少時間來處理,進(jìn)而評估所需時鐘頻率,以及是否需要存在多個時鐘域處理。

c605bc72-c506-11ec-bce3-dac502259ad0.png

對于信號處理系統(tǒng),有的需要實(shí)時處理,有的則不需要實(shí)時處理。最具挑戰(zhàn)的無疑是實(shí)時性要求高的通信、雷達(dá)和圖像等領(lǐng)域的信號處理問題。

首先解決信號處理中的算法問題,為實(shí)現(xiàn)某一處理過程,需要分哪些步驟,最終得到什么樣的結(jié)果。

為了實(shí)現(xiàn)實(shí)時處理,邏輯電路該怎么去設(shè)計?

c61816e2-c506-11ec-bce3-dac502259ad0.png

于是,算法問題既要研究如何處理數(shù)據(jù)流的問題,也要研究如何快速處理的問題。

電路實(shí)現(xiàn)時,則需要考慮資源消耗、并行處理結(jié)構(gòu),流水處理和控制邏輯。

c6233ac2-c506-11ec-bce3-dac502259ad0.png

如果有處理速率要求,則需考慮并行+流水的處理方式,并考慮單時鐘下的數(shù)據(jù)位寬。

同時,務(wù)必明確數(shù)據(jù)流向,前后級接口,功能模塊內(nèi)部RTL邏輯處理,細(xì)化到每個時鐘應(yīng)該怎么處理,step by step。

c63a474e-c506-11ec-bce3-dac502259ad0.png

以上都比較明確后,可以著手進(jìn)行RTL設(shè)計。RTL設(shè)計的核心,便是寄存器、RAM和FSM的靈活使用。其中,F(xiàn)SM占據(jù)了大部分功能。通常情況下,我們不只是操作純數(shù)據(jù)流,而是在各種控制信號和參數(shù)下進(jìn)行設(shè)計,此時涉及各種FSM和選擇器設(shè)計,并注意是否需要進(jìn)行流控。

c65190fc-c506-11ec-bce3-dac502259ad0.png

RTL代碼設(shè)計完成之后,進(jìn)行TestBench平臺搭建和仿真驗(yàn)證是必要的,特別是對于復(fù)雜功能模塊或系統(tǒng)設(shè)計而言。經(jīng)驗(yàn)再豐富的工程師,也不敢保證,不經(jīng)過仿真驗(yàn)證直接上板一定沒問題。

驗(yàn)證也是一門重要的技術(shù),這也是為什么存在IC驗(yàn)證崗位,目的就是為芯片成功流片嚴(yán)格把關(guān),一旦流片失敗,損失重大,影響深遠(yuǎn)。

FPGA的開發(fā)設(shè)計,同樣需要進(jìn)行仿真驗(yàn)證。通常,我們可以通過算法鏈路產(chǎn)生所需激勵源,通過TestBench對功能模塊進(jìn)行驗(yàn)證,并進(jìn)行結(jié)果對比分析。重點(diǎn)解決兩個問題:

一是驗(yàn)證邏輯時序是否存在問題,比如信號是否對齊,有無接口處理不當(dāng)導(dǎo)致數(shù)據(jù)丟失等。

二是信號處理過程是否得當(dāng),數(shù)據(jù)位寬、精度等是否符合算法要求。

解決功能性問題后,就需要考慮性能問題。定點(diǎn)是否合適,與浮點(diǎn)算法性能的差異有多大,或者軟件中的定點(diǎn)處理與邏輯電路定點(diǎn)處理,誤差有多大。在不斷驗(yàn)證過程中,優(yōu)化算法設(shè)計和邏輯電路設(shè)計。

剩下的邏輯綜合、實(shí)現(xiàn)、比特流生成和調(diào)試等環(huán)節(jié),屬于常規(guī)操作,但對于邏輯綜合、實(shí)現(xiàn)中的時序約束和相關(guān)策略設(shè)置,也是十分重要的。

c671246c-c506-11ec-bce3-dac502259ad0.png

最后,用一張圖總結(jié)如何從算法到RTL實(shí)現(xiàn)。

c68b0e72-c506-11ec-bce3-dac502259ad0.png

本文只是粗略地分析了算法到RTL代碼實(shí)現(xiàn)之間的邏輯關(guān)系,以及從實(shí)現(xiàn)角度,我們應(yīng)該怎么去著手。

具體到某個信號處理算法實(shí)現(xiàn)時,必須清楚整個信號處理過程,對算法一步一步分解,再對信號流、定點(diǎn)和接口進(jìn)行設(shè)計。

做任何事情之前,先謀劃布局,磨刀不誤砍柴工,扎扎實(shí)實(shí)做好每一步,功到自然成。

審核編輯 :李倩

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

    關(guān)注

    1629

    文章

    21729

    瀏覽量

    602986
  • 算法
    +關(guān)注

    關(guān)注

    23

    文章

    4607

    瀏覽量

    92829
  • 仿真模型
    +關(guān)注

    關(guān)注

    1

    文章

    28

    瀏覽量

    12237
  • RTL
    RTL
    +關(guān)注

    關(guān)注

    1

    文章

    385

    瀏覽量

    59759

原文標(biāo)題:從算法到RTL實(shí)現(xiàn),F(xiàn)PGA工程師該怎么做?

文章出處:【微信號:zhuyandz,微信公眾號:FPGA之家】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    【「從算法到電路—數(shù)字芯片算法的電路實(shí)現(xiàn)」閱讀體驗(yàn)】+閱讀第章部分筆記

    數(shù)字電路設(shè)計分為前端和后端前端開發(fā)工程師負(fù)責(zé)編寫RTL即對數(shù)字電路的抽象描述。后端開發(fā)工程師負(fù)責(zé)將該抽象描述轉(zhuǎn)變?yōu)榫哂芯唧w型號名稱的電路元器件,并且將其放置在特定的位置,線路將它們連接在起。前端是抽象型電路,后端是具象型電
    發(fā)表于 12-02 21:41

    【「從算法到電路—數(shù)字芯片算法的電路實(shí)現(xiàn)」閱讀體驗(yàn)】+內(nèi)容簡介

    內(nèi)容簡介這是本深入解讀基礎(chǔ)算法及其電路設(shè)計,以打通算法研發(fā)到數(shù)字IC設(shè)計的實(shí)現(xiàn)屏障,以及指導(dǎo)芯片設(shè)計工程師從底層掌握復(fù)雜電路設(shè)計與優(yōu)化方法為目標(biāo)的專業(yè)技術(shù)書。任何芯片(如WiFi芯片
    發(fā)表于 11-21 17:14

    【「從算法到電路—數(shù)字芯片算法的電路實(shí)現(xiàn)」閱讀體驗(yàn)】+介紹基礎(chǔ)硬件算法模塊

    作為嵌入式開發(fā)者往往比較關(guān)注硬件和軟件的協(xié)調(diào)。本書介紹了除法器,信號發(fā)生器,濾波器,分頻器等基本算法的電路實(shí)現(xiàn),雖然都是基礎(chǔ)內(nèi)容,但是也是最常用到的基本模塊。 隨著逆全球化趨勢的出現(xiàn),過去的研發(fā)
    發(fā)表于 11-21 17:05

    【「從算法到電路—數(shù)字芯片算法的電路實(shí)現(xiàn)」閱讀體驗(yàn)】+本介紹基礎(chǔ)硬件算法模塊實(shí)現(xiàn)的好書

    看下本書內(nèi)容簡介,然后再瀏覽下各個章節(jié)的內(nèi)容。 從簡介來看,本書也是關(guān)注最基礎(chǔ),最常用的那部分算法的電路實(shí)現(xiàn),比較貼合工程實(shí)踐,適合無基礎(chǔ)或者
    發(fā)表于 11-20 13:42

    Pure path studio內(nèi)能否自己創(chuàng)建component,來實(shí)現(xiàn)特定的算法,例如LMS算法

    TLV320AIC3254EVM-K評估模塊, Pure path studio軟件開發(fā)環(huán)境。 問題:1.Pure path studio 內(nèi)能否自己創(chuàng)建component,來實(shí)現(xiàn)特定的
    發(fā)表于 11-01 08:25

    使用AIC3254做音頻采集,使用PPS 5.95進(jìn)行算法編輯,想使用兩距離較遠(yuǎn)的麥克風(fēng)采集語音,什么樣的算法比較好?

    我的產(chǎn)品使用AIC3254做音頻采集,使用PPS 5.95進(jìn)行算法編輯,現(xiàn)在想使用兩距離較遠(yuǎn)的麥克風(fēng)采集語音,請問什么樣的算法比較好?
    發(fā)表于 10-29 06:03

    簡述光刻工藝的三主要步驟

    “ 光刻作為半導(dǎo)體中的關(guān)鍵工藝,其中包括3大步驟的工藝:涂膠、曝光、顯影。三步驟異常,整
    的頭像 發(fā)表于 10-22 13:52 ?512次閱讀

    名單公布!【書籍評測活動NO.46】從算法到電路 | 數(shù)字芯片算法的電路實(shí)現(xiàn)

    :elecfans123)領(lǐng)取書籍進(jìn)行評測,如在5工作日內(nèi)未聯(lián)系,視為放棄本次試用評測資格! 《從算法到電路——數(shù)字芯片算法的電路實(shí)現(xiàn)》 是
    發(fā)表于 10-09 13:43

    tlv3501做了過零比較器,正弦波變成方波,大于1MHz 時波形變形很大怎么改善?

    tlv3501做了過零比較器,正弦波變成方波,頻率在1MHz以下時方波波形正常,大于1MHz 時波形變形很大,要求是達(dá)到10MHz
    發(fā)表于 08-30 06:15

    需要單限電壓比較器,閾值電壓200mv,LM311可以實(shí)現(xiàn)嗎?

    需要單限電壓比較器,閾值電壓200mv,LM311可以實(shí)現(xiàn)嗎?
    發(fā)表于 08-16 13:55

    神經(jīng)網(wǎng)絡(luò)反向傳播算法的原理、數(shù)學(xué)推導(dǎo)及實(shí)現(xiàn)步驟

    傳播算法的原理、數(shù)學(xué)推導(dǎo)、實(shí)現(xiàn)步驟以及在深度學(xué)習(xí)中的應(yīng)用。 神經(jīng)網(wǎng)絡(luò)概述 神經(jīng)網(wǎng)絡(luò)是種受人腦啟發(fā)的計算模型,由大量的神經(jīng)元(或稱為節(jié)點(diǎn))組成,每個神經(jīng)元與其他神經(jīng)元通過權(quán)重連接。神經(jīng)
    的頭像 發(fā)表于 07-03 11:16 ?774次閱讀

    FPGA能實(shí)現(xiàn)什么樣的算法?

    FPGA功能如此強(qiáng)大,請問FPGA能實(shí)現(xiàn)或者比較適合實(shí)現(xiàn)什么樣的算法?
    發(fā)表于 05-26 20:18

    蘋果手機(jī)一個id怎么取消同步

    蘋果手機(jī)一個id怎么取消同步? 取消蘋果手機(jī)間的同步功能可以通過以下步驟完成。請注意,這些步驟適用于iOS 11及更高版本。 步驟1:打
    的頭像 發(fā)表于 02-19 10:19 ?3137次閱讀

    表的使用方法步驟表的作用哪些

    排除。在本文中將詳細(xì)介紹萬表的使用方法步驟以及它的些常見作用。 首先,我們來了解下萬表的基本組成部分。通常,
    的頭像 發(fā)表于 01-25 10:08 ?2989次閱讀

    如何運(yùn)放作為比較

    電子發(fā)燒友網(wǎng)站提供《如何運(yùn)放作為比較器.ppt》資料免費(fèi)下載
    發(fā)表于 01-02 11:03 ?0次下載
    RM新时代网站-首页