91欧美超碰AV自拍|国产成年人性爱视频免费看|亚洲 日韩 欧美一厂二区入|人人看人人爽人人操aV|丝袜美腿视频一区二区在线看|人人操人人爽人人爱|婷婷五月天超碰|97色色欧美亚州A√|另类A√无码精品一级av|欧美特级日韩特级

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

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

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

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

FPGA之家 ? 來(lái)源:FPGA之家 ? 作者:FPGA之家 ? 2022-04-26 10:19 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

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

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

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

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

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

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

這個(gè)問(wèn)題,對(duì)于FPGA、ASIC等邏輯電路設(shè)計(jì)人員來(lái)講,是非常重要的問(wèn)題。

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

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

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

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

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

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

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

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

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

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

接下來(lái),選芯片器件,評(píng)估資源占用情況,評(píng)估需要用多少乘法器,除法器,DSP,BRAM,GT等。

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

剩下的邏輯綜合、實(shí)現(xiàn)、比特流生成和調(diào)試等環(huán)節(jié),屬于常規(guī)操作,但對(duì)于邏輯綜合、實(shí)現(xiàn)中的時(shí)序約束和相關(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)該怎么去著手。

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

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

審核編輯 :李倩

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

    關(guān)注

    1660

    文章

    22412

    瀏覽量

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

    關(guān)注

    23

    文章

    4784

    瀏覽量

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

    關(guān)注

    1

    文章

    31

    瀏覽量

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

    關(guān)注

    1

    文章

    394

    瀏覽量

    62661

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

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

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

掃碼添加小助手

加入工程師交流群

    評(píng)論

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

    單片機(jī)常用的14個(gè)C語(yǔ)言算法分享

    ,對(duì)控制對(duì)象進(jìn)行控制。 十四、開(kāi)根號(hào)算法 單片機(jī)開(kāi)平方的快速算法 因?yàn)楣ぷ鞯男枰趩纹瑱C(jī)上實(shí)現(xiàn)開(kāi)根號(hào)的操作。目前開(kāi)平方的方法大部分是牛頓迭代法。我在查了
    發(fā)表于 01-29 06:59

    代碼實(shí)戰(zhàn)!什么是傅里葉變換?什么?Matlab實(shí)現(xiàn)FFT

    的提出讓人們看問(wèn)題的角度從時(shí)域變成了頻域,多了個(gè)維度??焖俑道锶~變換算法的提出普及了傅里葉變換在工程領(lǐng)域的應(yīng)用,在科學(xué)計(jì)算和數(shù)字信號(hào)處理等領(lǐng)域,F(xiàn)FT至今依然是非常強(qiáng)大的工具之
    的頭像 發(fā)表于 01-16 07:45 ?539次閱讀
    代碼實(shí)戰(zhàn)!什么是傅里葉變換?<b class='flag-5'>有</b>什么<b class='flag-5'>用</b>?Matlab<b class='flag-5'>實(shí)現(xiàn)</b>FFT

    用于單片機(jī)幾種C語(yǔ)言算法

    為克服隨機(jī)干擾引起的誤差,硬件上可采用濾波技術(shù),軟件上可采用軟件算法實(shí)現(xiàn)數(shù)字濾波。濾波算法往往是系統(tǒng)測(cè)控算法
    發(fā)表于 11-27 06:00

    利用Verdi調(diào)試協(xié)處理器的實(shí)現(xiàn)步驟

    本次給大家介紹的是利用Verdi調(diào)試協(xié)處理器的實(shí)現(xiàn)步驟。 有時(shí)為了觀察協(xié)處理器運(yùn)行情況,需要查看協(xié)處理器接口的信號(hào)波形,此時(shí)可以Verdi來(lái)查看主處理器發(fā)給協(xié)處理器的自定義指令以進(jìn)
    發(fā)表于 10-30 08:26

    RC5算法協(xié)處理器設(shè)計(jì)實(shí)現(xiàn)

    1、RC5算法參數(shù)選擇 通過(guò)三個(gè)可變參數(shù)可確定組加密算法,可表示為RC5-w/r/b。w表示明文/秘文字分組后的字長(zhǎng),完整明文/秘文字長(zhǎng)為2w;w
    發(fā)表于 10-30 08:25

    SM4算法實(shí)現(xiàn)分享(算法原理

    。而解密算法與加密算法采用同結(jié)構(gòu),只是輪密鑰使用的順序不同,加密采用順序的,解密采用逆序的。 SM4加密算法是典型的分組密碼算法,分組密
    發(fā)表于 10-30 08:10

    MD5信息摘要算法實(shí)現(xiàn)(基于蜂鳥(niǎo)E203協(xié)處理器)

    參與下一個(gè)512位分組數(shù)據(jù)中鏈接變量的初始值,重復(fù)2、3步驟,直到完成所有的分組,最后的輸出是32位的A、 B、 C和D的級(jí)聯(lián)成128位的信息摘要。 然后將其轉(zhuǎn)換為大端輸出。 【注:MD5算法的計(jì)算都是
    發(fā)表于 10-30 07:18

    復(fù)雜的軟件算法硬件IP核的實(shí)現(xiàn)

    看到整個(gè)實(shí)現(xiàn)只有個(gè)狀態(tài)“S0”。 對(duì)于復(fù)雜時(shí)序要求的操作,例如加密算法里面常見(jiàn)的 for 循環(huán)結(jié)構(gòu),在生成 begin 和 end 之
    發(fā)表于 10-30 07:02

    如何使用恢復(fù)算法來(lái)實(shí)現(xiàn)開(kāi)平方運(yùn)算

    =0.1101,具體計(jì)算過(guò)程如下: 硬件實(shí)現(xiàn)架構(gòu)圖如下所示,其中我們將8比特的操作數(shù)X作為輸入,從而得到的Q是4比特的。我們總共用到了17個(gè)減法模塊(SB,Subtract Block),每一個(gè)減法模塊都是
    發(fā)表于 10-24 13:33

    Newton-Raphson算法實(shí)現(xiàn)浮點(diǎn)除法(七)

    的牛頓迭代算法,直逼近于f(x) = 0的點(diǎn),則有xi+1 = xi (2 - xi b),這樣我們能夠用下述步驟實(shí)現(xiàn)a/b: 1)b
    發(fā)表于 10-24 07:53

    分享個(gè)LabVIEW開(kāi)發(fā)的聲學(xué)測(cè)試軟件

    分享個(gè)聲學(xué)測(cè)試軟件,采用聲卡作硬件采集設(shè)備。純LabVIEW開(kāi)發(fā),內(nèi)置頻響/失真等曲線分析算法、中科藍(lán)訊ANC混合降噪、序號(hào)輸入、數(shù)據(jù)顯示、圖形顯示、信息提示等基本步驟都有, PPL
    發(fā)表于 10-22 13:38

    數(shù)據(jù)濾波算法的具體實(shí)現(xiàn)步驟是怎樣的?

    (高頻電磁、瞬時(shí)脈沖等),選擇適配的濾波算法并落地。以下以電能質(zhì)量監(jiān)測(cè)中最常用的 IIR 低通濾波(抗高頻干擾)、滑動(dòng)平均濾波(抗瞬時(shí)脈沖)、卡爾曼濾波(抗動(dòng)態(tài)波動(dòng)) 為例,詳解具體實(shí)現(xiàn)步驟
    的頭像 發(fā)表于 10-10 16:45 ?826次閱讀

    CW32L012實(shí)現(xiàn)外部flash下載算法

    外部flash或者內(nèi)置的片上flash,都是編譯器通過(guò)調(diào)用寫(xiě)好的FLM文件來(lái)實(shí)現(xiàn)下載,單片機(jī)內(nèi)部的安裝pack包就會(huì)有(官方實(shí)現(xiàn)),外部flash的情況比較復(fù)雜,例如用的哪種flash,
    的頭像 發(fā)表于 10-09 17:38 ?1658次閱讀
    CW32L012<b class='flag-5'>實(shí)現(xiàn)</b>外部flash下載<b class='flag-5'>算法</b>

    【「AI芯片:科技探索與AGI愿景」閱讀體驗(yàn)】+AI的科學(xué)應(yīng)用

    AI被賦予了人的智能,科學(xué)家們希望在沒(méi)有人類的引導(dǎo)下,AI自主的提出科學(xué)假設(shè),諾貝爾獎(jiǎng)級(jí)別的假設(shè)哦。 AI驅(qū)動(dòng)科學(xué)被認(rèn)為是科學(xué)發(fā)現(xiàn)的第五個(gè)
    發(fā)表于 09-17 11:45

    款內(nèi)部4個(gè)步驟交流直接LED驅(qū)動(dòng)IC-WD15-S30A

    LED驅(qū)動(dòng)芯片 - WD15-S30A是款交流直接LED驅(qū)動(dòng)IC,內(nèi)部4個(gè)步驟。它可以從整流的交流電壓下驅(qū)動(dòng)幾個(gè)系列的led。它將提供很大的方便的設(shè)計(jì),因?yàn)樗枰倭康耐獠拷M件。
    的頭像 發(fā)表于 03-12 09:35 ?750次閱讀
    <b class='flag-5'>一</b>款內(nèi)部<b class='flag-5'>有</b>4<b class='flag-5'>個(gè)</b><b class='flag-5'>步驟</b>交流直接LED驅(qū)動(dòng)IC-WD15-S30A