chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

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

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

在FPGA上建立MATLAB和Simulink算法原型

FPGA設計論壇 ? 來源:未知 ? 2023-08-06 10:45 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

wKgaomToPW-AS6rKAAAAuFYhST8378.png

點擊上方藍字關注我們

芯片設計和驗證工程師通常要為在硅片上實現的每一行RTL代碼寫出多達10行測試平臺代碼。驗證任務在設計周期內可能會占用50%或更多的時間。盡管如此辛 苦,仍有接近60%的芯片存在功能瑕疵,需要返工。由于HDL仿真不足以發(fā)現系統級錯誤,芯片設計人員正利用FPGA來加速算法創(chuàng)建和原型設計。

利用FPGA處理大型測試數據集可以使工程師快速評估算法和架構并迅速做出權衡。工程師也可以在實際環(huán)境下測試設計,避免因使用HDL仿真器耗大量時 間。系統級設計和驗證工具(如
matlabSimulink)通過在FPGA上快速建立算法原型,可以幫助工程師實現這些優(yōu)勢。

本文將介紹使用MATLAB和Simulink創(chuàng)建FPGA原型的最佳方法。這些最佳方法包括:在設計過程初期分析定點量化的效應并優(yōu)化字長,產生更 小、更高效的實現方案;利用自動HDL代碼生成功能,更快生成FPGA原型;重用具有HDL協同仿真功能的系統級測試平臺,采用系統級指標分析HDL實現 方案;通過FPGA在環(huán)仿真加速驗證(圖1)。

wKgaomToPW-ANDvUAABlixlUNas404.jpg


為什么在FPGA上建立原型?
在FPGA上建立算法原型可以增強工程師的信心,使他們相信自己的算法在實際環(huán)境中的表現能夠與預期相符。除了高速運行測試向量和仿真方案,工程師還可 以利用FPGA原型試驗軟件功能以及諸如RF模擬子系統的相關系統級功能。此外,由于FPGA原型運行速度更快,可以使用大型數據集,暴露出仿真模型未 能發(fā)現的缺陷。

采用HDL代碼生成功能的基于模型的設計可以使工程師有效地建立FPGA原型,如圖2所示。該圖向我們展示了這樣一種現實情況:工程師經??s短詳細設計 階段,試圖通過盡快開始硬件開發(fā)階段以符合開發(fā)周期的要求。現實中,當工程師發(fā)現定點算法達不到系統要求時,就得在HDL創(chuàng)建階段重新審視詳細設計階段。這樣的重疊工作將使HDL創(chuàng)建階段延長(如紫色長條所示),并可能引發(fā)各種設計問題(如膠合邏輯或設計補?。?。

wKgaomToPW-AQH4eAABbwfCU2EM393.jpg


由于自動HDL代碼生成流程比手工編碼快,工程師得以把節(jié)省下來的時間投入到詳細設計階段,生成更優(yōu)質的定點算法。與手動的工作流程相比,這種方法使工程師能夠以更快的速度生成質量更佳的FPGA原型。

數字下變頻器案例研究
為了說明采用基于模型的設計建立FPGA原型的最佳方法,可借助數字下變頻器(DDC)來進行案例研究。在眾多的
通信系統中,DDC是一種普通的構建塊 (圖3)。該構建塊用于將高速通帶輸入轉換為低速基帶輸出,以便使用較低采樣率時鐘進行處理。這樣,在硬件實施階段便可降低功耗、節(jié)約資源。DDC的主要 部件包括:數控振蕩器(NCO)、混頻器和數字濾波器鏈路(圖4)。

wKgaomToPW-AdpbhAABENhZ0GW4343.jpg


在設計過程初期分析定點量化的效應
工程師通常使用浮點數據類型來測試新的構想和開發(fā)初始算法。然而,FPGA和ASIC硬件實現要求轉換為定點數據類型,而這往往會造成量化誤差。使用手 動工作流程時,通常在HDL編碼過程中執(zhí)行定點量化。在該工作流程中,工程師無法輕易地通過比較定點表示形式和浮點參考值量化定點量化的效應,而分析針對 溢出的HDL實現也同樣不易。

為了明智確定所需的小數位數,在開始HDL編碼過程之前,工程師需要某種方法來比較浮點仿真結果與定點仿真結果。增加小數位數可以減小量化誤差;不過,這種方法需要增加字長(區(qū)域增多、功耗升高)。

例如,圖5展示了DDC濾波器鏈路中低通濾波器第一階段浮點與定點仿真結果的差異。這些差異是因定點量化所致。上方圖形顯示了浮點與定點仿真結果的重疊效果。下方圖形顯示了圖中每一點的量化誤差。工程師可能需要根據設計規(guī)范來增加小數位數以減小由此引出的量化誤差。

wKgaomToPW-AaZc5AABvZHRy7Io959.jpg


除了選擇小數位數之外,工程師還需要優(yōu)化字長,實現低功耗和區(qū)域優(yōu)化的設計。

在DDC案例研究中,工程師使用Simulink定點模塊組將部分數字濾波器鏈路的字長減少了8位之多(圖6)。

wKgaomToPW-Aei6dAABjoogEJaM814.jpg


利用自動HDL代碼生成功能更快生成FPGA原型
在生成FPGA原型時,HDL代碼必不可少。工程師手工編寫了Verilog或VHDL代碼。作為替代選擇,使用HDL編碼器自動生成HDL代碼具有眾 多明顯優(yōu)勢。工程師可以快速地評估能否在硬件中實施當前算法;迅速評估不同的算法實現,選擇最佳方案;并在FPGA上更快地建立算法原型。

對于DDC案例研究而言,可以在55秒內生成了5780行HDL代碼。工程師可以瀏覽并很快理解代碼(圖7)。自動代碼生成功能允許工程師對系統級模型進行更改,并且,通過重新生成HDL代碼,該功能可以在數分鐘之內生成更新的HDL實現方案。

wKgaomToPXCAAwqdAABl7dJQuYU401.jpg


重用具有協同仿真功能的系統級測試平臺進行HDL驗證
功能驗證:HDL協同仿真使工程師能夠重用Simulink模型,將激勵驅動至HDL仿真器,并對仿真輸出執(zhí)行交互式系統級分析(圖8)。

wKgaomToPXCAAZpfAABFH2ffuNw691.jpg


HDL仿真僅提供數字波形輸出,而HDL協同仿真則提供了顯示HDL代碼的完整視圖,并可以訪問Simulink的全套系統級分析工具。當工程師觀察到預期結果與HDL仿真結果存在差異時,可借助協同仿真進一步了解該失配所產生的系統級影響。

例如,在圖9中,頻譜儀視圖可以使工程師做出明智決定,忽略預期結果與HDL仿真結果之間的失配,其原因是該差異位于阻帶區(qū)。相比之下,數字波形輸出只 是將預期結果與HDL仿真結果的失配標記為誤差。盡管工程師最終可能得出相同的結論,但這將需要更多的時間完成所需的分析。

wKgaomToPXCANrD8AAB2twTbaQE089.jpg


測試覆蓋率:工程師可以使用HDL驗證工具、Simulink設計驗證工具和ModelSim/Questa自動執(zhí)行代碼覆蓋率分析。在該工作流程 中,Simulink設計驗證工具可針對模型覆蓋率生成一套測試用例。HDL驗證工具自動使用這一套測試用例運行ModelSim/Questa,收集代 碼覆蓋率數據,以對生成的代碼加以全面分析。

使用FPGA在環(huán)仿真加速驗證
使用系統級仿真和HDL協同仿真驗證DDC算法之后,便可以立即在FPGA目標平臺上部署DDC算法。對算法執(zhí)行基于FPGA的驗證(也稱為FPGA在 環(huán)仿真)可以增強對算法在現實環(huán)境中有效運行的信心。相比基于主機的HDL仿真,該驗證可以使工程師更快地運行測試方案。

對于DDC算法而言,可以使用Simulink模型驅動FPGA輸入激勵并分析FPGA的輸出(圖10)。與HDL協同仿真一樣,在Simulink中始終可以利用相關數據進行分析。

wKgaomToPXCAcO0zAAA4fXZfl8U467.jpg


圖11對比了HDL協同仿真和FPGA在環(huán)仿真這兩種用于DDC設計的驗證方法。在本案例中,FPGA在環(huán)仿真的速度是HDL協同仿真的23倍。這樣的 速度提升使工程師能夠運行更廣泛的測試用例并對其設計進行回歸測試。這使他們能夠識別出有待進一步分析的潛在問題區(qū)域。

wKgaomToPXCASRYUAABrEGYboVU006.jpg


盡管HDL協同仿真速度較慢,但它卻提高了HDL代碼的可見性。因此,它很適合針對FPGA在環(huán)仿真過程中發(fā)現的問題區(qū)域進行更詳細的分析。

本文小結
如果工程師遵循本文所述的四種最佳方法,開發(fā)FPGA原型將比傳統的手動工作流程快出許多,并能使工程師信心倍增。此外,工程師還可以在整個開發(fā)過程中 繼續(xù)優(yōu)化自己的模型,并快速地重新生成有關FPGA實現的代碼。與依賴手工編寫HDL的傳統工作流程相比,這種能力可以顯著縮短設計迭代的周期。

wKgaomToPXCAKDIIAAAJM7aZU1A512.png

有你想看的精彩 至芯科技FPGA就業(yè)培訓班——助你步入成功之路、8月12號西安中心開課、歡迎咨詢! 基于FPGA的CAN總線通信節(jié)點設計 解析高速ADCDAC與FPGA的配合使用

wKgaomToPXCAEM_tAABUdafP6GM068.jpg

掃碼加微信邀請您加入FPGA學習交流群

wKgaomToPXGAYxzmAABiq3a-ogY771.jpgwKgaomToPXGASC1yAAACXWrmhKE764.png

歡迎加入至芯科技FPGA微信學習交流群,這里有一群優(yōu)秀的FPGA工程師、學生、老師、這里FPGA技術交流學習氛圍濃厚、相互分享、相互幫助、叫上小伙伴一起加入吧!

點個在看你最好看


原文標題:在FPGA上建立MATLAB和Simulink算法原型

文章出處:【微信公眾號:FPGA設計論壇】歡迎添加關注!文章轉載請注明出處。


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

    關注

    1645

    文章

    22050

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    基于MatlabFPGA的雙邊濾波算法實現

    前面發(fā)過中值、均值、高斯濾波的文章,這些只考慮了位置,并沒有考慮相似度。那么雙邊濾波來了,既考慮了位置,有考慮了相似度,對邊緣的保持比前幾個好很多,當然實現也是復雜很多。本文將從原理入手,采用MatlabFPGA設計實現雙邊
    的頭像 發(fā)表于 07-10 11:28 ?635次閱讀
    基于<b class='flag-5'>Matlab</b>與<b class='flag-5'>FPGA</b>的雙邊濾波<b class='flag-5'>算法</b>實現

    基于FPGA的壓縮算法加速實現

    本設計中,計劃實現對文件的壓縮及解壓,同時優(yōu)化壓縮中所涉及的信號處理和計算密集型功能,實現對其的加速處理。本設計的最終目標是證明充分并行化的硬件體系結構 FPGA 實現該算法時,可
    的頭像 發(fā)表于 07-10 11:09 ?796次閱讀
    基于<b class='flag-5'>FPGA</b>的壓縮<b class='flag-5'>算法</b>加速實現

    無刷直流電機模糊PI控制系統建模與仿真

    摘 要:從無刷直流電機(BIDCM)的工作原理和結構出發(fā),分析了 BLDCM數學模型的基礎,采用模塊化方法,Matlab/Simulink
    發(fā)表于 07-07 18:25

    MATLAB/Simulink驅動汽車行業(yè)能效革命

    整車熱控制,MATLABSimulink 正以創(chuàng)新工具助力全球企業(yè)突破技術瓶頸,為綠色出行提供可靠保障。
    的頭像 發(fā)表于 05-14 14:22 ?260次閱讀
    <b class='flag-5'>MATLAB</b>/<b class='flag-5'>Simulink</b>驅動汽車行業(yè)能效革命

    如何實現MC33774ICSimulink環(huán)境中使用基于模型的設計?

    我想熟悉如何實現MC33774IC Simulink 環(huán)境中使用基于模型的設計。 盡管 MATLAB 提供了一些示例文件,但它們似乎是最終版本。要更深入地了解如何配置MC33774,我正在尋找一個教程,該教程解釋了如何從頭開
    發(fā)表于 04-10 08:05

    直流電機控制方法的Matlab仿真研究

    速度控制模型,以提高無刷直流電機速度控制系統的穩(wěn)定性和抗干擾能力 。使用 Matlab/Simulink 工具箱建立無刷直流電機的仿真模型,研究結果表明,模糊自適應 PID 算法能夠使
    發(fā)表于 03-27 12:15

    FPGA開發(fā)任務

    我想請人幫我開發(fā)一款基于FPGA的產品,把我寫好MATLAB代碼固化FPGA中,實現算法加速和加密功能。有興趣的聯系我
    發(fā)表于 03-15 10:19

    matlab里的simulink仿真一個推挽升壓仿真電路,輸出帶載能力很差?

    新手用了matlab里的simulink搭了個推挽仿真,pwm輸出為28khz,占空比0.45,變壓器匝數比1:31,輸入電壓12v,輸出電壓310v,想做個功率1kw的,然后接了個96.1的負載,輸出電壓只有160多v了。*附件:newpushpull.zip空載帶載變
    發(fā)表于 02-07 20:01

    MathWorks積極推動MATLABSimulink在教學項目中的應用

    全球領先的數學計算軟件開發(fā)商 MathWorks 今天宣布,其 MATLABSimulink 平臺中國的高校教育中取得顯著成效。隨著科技的迅猛發(fā)展,國家新質生產力對未來人才提出了更高的創(chuàng)新
    的頭像 發(fā)表于 12-27 15:32 ?937次閱讀

    SimulinkMATLAB 的結合使用 Simulink中的信號處理方法

    工程和科學研究中,信號處理是一個重要的領域,涉及到信號的采集、分析、處理和生成。MATLAB 提供了豐富的信號處理工具箱,而 Simulink 提供了一個直觀的圖形界面,使得復雜的信號處理系統可以
    的頭像 發(fā)表于 12-12 09:25 ?1518次閱讀

    分享兩則MATLABSimulink助力教學案例

    全球各地的高校都在使用 MATLABSimulink 開展教學與科研,幫助未來的工程師和科學家掌握未來世界工程項目與科學研究所要求的重要能力。讓我們一起來看看兩則 MATLAB
    的頭像 發(fā)表于 12-05 16:46 ?1170次閱讀
    分享兩則<b class='flag-5'>MATLAB</b>和<b class='flag-5'>Simulink</b>助力教學案例

    Matlab/Simulink/Stateflow建模開發(fā)及仿真測試

    matlab 模擬仿真 熟悉Matlab/Simulink/Stateflow建模開發(fā)及仿真測試,熟悉V模型開發(fā)流程。 熟悉自動代碼生成,能夠編寫或者配置自動代碼生成腳本。
    發(fā)表于 10-24 17:23

    FPGA仿真黑科技\"EasyGo Vs Addon \",助力大規(guī)模電力電子系統仿真

    仿真靈活性EasyGo FPGACoder是一種基于FPGA的快速算法開發(fā)技術,能將用戶基于Simulink開發(fā)的算法快速實現在
    發(fā)表于 10-23 18:18

    快速部署原型驗證:從子卡到調試的全方位優(yōu)化

    引言原型驗證是一種FPGA平臺上驗證芯片設計的過程,通過FPGA實現芯片的設計
    的頭像 發(fā)表于 09-30 08:04 ?1115次閱讀
    快速部署<b class='flag-5'>原型</b>驗證:從子卡到調試的全方位優(yōu)化

    FPGA算法工程師、邏輯工程師、原型驗證工程師有什么區(qū)別?

    邏輯工程師和 FPGA 原型驗證工程師工作重點和職責存在一定的區(qū)別: FPGA 算法工程師
    發(fā)表于 09-23 18:26