DSP48E2 的 MAC模式功能仿真


DSP48E2 仿真代碼:
測試的功能為 P i = ( A + D ) ? B + P i ? 1 P_{i} = (A+D) * B + P_{i-1} Pi?=(A+D)?B+Pi?1?

`timescale 1ns / 1nsmodule dsp_tb;// 輸入reg CLK;reg CE;reg SCLR;reg signed [26:0] A, D;reg signed [17:0]  B;// 輸出wire signed [47:0] P;parameter period = 5; // 100MHzparameter num_test = 104;// 測試輪數always #period CLK=!CLK;// DSP 初始化initial beginCLK = 0;CE = 0;SCLR = 1;A = 0;B = 0;D = 0;#(period*2);CE = 1;SCLR = 0;end// 測試激勵生成integer i=0;always #10 begin//A = (1 << 26) - 1;//D = 0;//B = (1 << 16) - 1;A = $random % (1 << 18);D = $random % (1 << 8);B = $random % (1 << 8);if(i==num_test+1)begin#period $stop;end else begini=i+1;endend        reg signed [26:0] A_4r, D_4r, A_3r, D_3r, A_2r, D_2r, A_r, D_r;reg signed [17:0] B_r, B_2r, B_3r, B_4r; integer num_correct=0, num_error=0; // 記錄正確個數和錯誤個數wire signed [47:0] P_ref;reg signed [47:0] P_ref_r;wire result;       // 參考結果生成assign P_ref=(i<4)?0: (A_4r + D_4r)* B_4r + P_ref_r;assign result=(P_ref!=P);// 打印測試logalways@(posedge CLK)if(SCLR)begin{A_4r,D_4r, B_4r, A_3r,D_3r, B_3r, A_2r,D_2r, B_2r, A_r,D_r, B_r}<=0;P_ref_r <= 0;num_correct <= 0;num_error   <= 0;end elsebegin// 打拍同步延遲{A_4r,D_4r,B_4r}<={A_3r, D_3r, B_3r};{A_3r,D_3r,B_3r}<={A_2r, D_2r, B_2r};{A_2r, D_2r, B_2r}<={A_r, D_r, B_r};{A_r, D_r, B_r}<={A, D, B}; P_ref_r <= P_ref;// 結果比對和打印if(i>=5 && i<=num_test)begin // 前四個輸出P和P_ref的時序未同步,故不算$write("[%d]: (%d + %d)* %d + %d = %d, P_ref:%d, ",i-5,A_4r, D_4r, B_4r, P_ref_r, P, P_ref);if(result==1'b0)begin$display("Pass :)");num_correct <= num_correct + 1;end else begin$display("Fail :(");num_error <= num_error + 1;endend else begin$display("Accuracy:%d/%d=%d%%", num_correct,num_test-4,num_correct*100/(num_test-4));endend// 實例化待測模塊dsp_macro_0 uut(.CLK(CLK),.CE(CE),.SCLR(SCLR),.A(A),.B(B),.D(D),.P(P));   endmodule

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/904049.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/904049.shtml
英文地址,請注明出處:http://en.pswp.cn/news/904049.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

抽象工廠模式(Abstract Factory Pattern)

很好&#xff01;你現在已經開始接觸設計模式了&#xff0c;而**抽象工廠模式&#xff08;Abstract Factory Pattern&#xff09;是一種常用于“創建一系列相關產品”**的經典設計模式。 我會一步步幫你理解&#xff1a; &#x1f9e0; 一句話解釋 抽象工廠模式&#xff1a;提…

Thymeleaf模板引擎從入門到實戰:Spring Boot整合與核心用法詳解

在 Java Web 開發的世界里&#xff0c;模板引擎是連接后端數據與前端展示的重要橋梁。Thymeleaf 憑借其強大的功能和簡潔的語法&#xff0c;逐漸成為眾多開發者的首選。如果你正在尋找一款能夠讓你的 Web 應用開發更加高效、代碼更加優雅的模板引擎&#xff0c;那么 Thymeleaf …

【HarmonyOS】作業三 UI

目錄 一. 單選題&#xff08;共10題&#xff0c;10分&#xff09; 1. (單選題, 1分)關于Tabs組件頁簽的位置設置&#xff0c;下面描述錯誤的是 2. (單選題, 1分)下面哪個組件不能包含子組件? 3. (單選題, 1分)ArkTS語言的實現計數器功能的組件名稱是以下哪個? 4. (單選題…

《算法筆記》10.6小節——圖算法專題->拓撲排序 問題 C: Legal or Not

題目描述 ACM-DIY is a large QQ group where many excellent acmers get together. It is so harmonious that just like a big family. Every day,many "holy cows" like HH, hh, AC, ZT, lcc, BF, Qinz and so on chat on-line to exchange their ideas. When so…

博客信息管理/博客管理

&#x1f6e0; 博客管理模塊&#xff1a;設計建議 你應該以To B 的后臺系統思路來設計&#xff0c;但保持簡單、輕量級、自己易維護是關鍵。下面是針對你這個場景的建議。 &#x1f9f1; 前端頁面結構&#xff08;React/Vue 可用&#xff09; 頁面 說明 博客列表頁 展示所有博…

全平臺開源即時通訊IM框架MobileIMSDK:7端+TCP/UDP/WebSocket協議,鴻蒙NEXT端已發布,5.7K Stars

一、基本介紹 MobileIMSDK是一套全平臺原創開源IM通信層框架&#xff1a; 超輕量級、高度提煉&#xff0c;lib包50KB以內&#xff1b;精心封裝&#xff0c;一套API同時支持UDP、TCP、WebSocket三種協議&#xff08;可能是全網唯一開源的&#xff09;&#xff1b;客戶端支持iOS…

SpringBoot商城平臺系統設計與開發

概述 SpringBoot商城平臺系統實現了商品展示、購物車、訂單管理等商城核心功能&#xff0c;適合作為計算機專業設計項目或商城項目開發參考&#xff0c;實現商城平臺的核心功能&#xff0c;學習商品管理、訂單處理、支付集成等關鍵技術實現。 主要內容 1. 前臺用戶功能模塊 …

【網絡原理】深入理解HTTPS協議

本篇博客給大家帶來的是網絡原理的知識點, 由于時間有限, 分三天來寫, 本篇為線程第三篇,也是最后一篇. &#x1f40e;文章專欄: JavaEE初階 &#x1f680;若有問題 評論區見 ? 歡迎大家點贊 評論 收藏 分享 如果你不知道分享給誰,那就分享給薯條. 你們的支持是我不斷創作的動…

【C語言練習】018. 定義和初始化結構體

018. 定義和初始化結構體 018. 定義和初始化結構體1. 定義結構體示例1:定義一個簡單的結構體輸出結果2. 初始化結構體示例2:在聲明時初始化結構體輸出結果示例3:使用指定初始化器初始化結構體(C99及以上標準支持)輸出結果3. 結構體數組示例4:定義和初始化結構體數組輸出結…

3D版同步幀游戲

以下是實現一個3D版同步幀游戲的詳細步驟與完整代碼示例。我們將以第一人稱射擊游戲(FPS)為原型,重點講解3D空間中的同步機制優化。 項目升級:3D版核心改動 1. 3D坐標系與消息結構 // common/messages.go type Vector3 struct {X float32 `json:"x"`Y float32 `…

卷積神經網絡進化史:從LeNet-5到現代架構的完整發展脈絡

摘要 本文系統梳理卷積神經網絡(CNN)從誕生到繁榮的發展歷程。從1998年Yann LeCun開創性的LeNet-5出發&#xff0c;重點解析2012年引爆深度學習革命的AlexNet&#xff0c;并詳細拆解后續演進的五大技術方向&#xff1a;網絡深度化(VGG)、卷積功能強化(ResNet)、檢測任務遷移(F…

在 Windows 中安裝 Pynini 的記錄

#工作記錄 概述 Pynini 是一個用于加權有限狀態文法編譯的 Python 庫&#xff0c;廣泛應用于自然語言處理&#xff08;NLP&#xff09;領域。以下記錄旨在用于回顧和幫助大家在 Windows 系統中安裝 Pynini。 安裝思路&#xff1a; 優先用conda虛擬環境 或 在python3.12的vir…

深挖Java之:運算符與輸入器

今天我要介紹的是在Java中對于運算符與輸入器的一些基礎語法運算符與輸入器的代碼示例以及應用場景&#xff0c;他們在應用上的優勢與劣勢作說明介紹&#xff1a; 介紹&#xff1a;運算符與輸入器是兩個基礎且關鍵的概念&#xff0c;它們共同構成了程序與用戶、程序與數據之間…

動態規劃之多狀態問題1

題目解析&#xff1a; 也就是給一個預約數組&#xff0c;選擇一些數字&#xff0c;讓其總和最大&#xff0c;但不能選擇相鄰的兩個數字 算法原理&#xff1a; 依舊可以根據經驗題目 以dp[i]位置結尾時&#xff0c;巴拉巴拉 根據題目要求補充完整&#xff0c;dp[i]&#xff…

計網_可靠傳輸ARQ機制

2024.09.04&#xff1a;網工老姜&beokayy網工學習筆記 第5節 可靠傳輸機制 5.1 可靠傳輸5.2 ARQ機制、ARQ協議5.3 ARQ簡介&#xff08;可靠傳輸&#xff09;5.3.1 停止等待協議&#xff08;1&#xff09;無差錯情況&#xff08;2&#xff09;有差錯情況確認丟失確認遲到 5.…

華為eNSP:多區域集成IS-IS

一、什么是多區域集成IS-IS&#xff1f; 多區域集成IS-IS是一種基于中間系統到中間系統&#xff08;IS-IS&#xff09;協議優化的網絡架構設計&#xff0c;通過多區域協同、路徑優化和擴展性增強實現高效路由管理&#xff0c;其核心特征如下&#xff1a; 1、分布式架構與多區…

自定義Dockerfile,發布springboot項目

(1) 上傳jar包 把hello項目打成一個可執行的jar包 hello-1.0-SNAPSHOT.jar&#xff0c;把這個jar包上傳到linux中 (2) 創建文件&#xff0c;文件名my_hello&#xff08;就是一個Dockerfile&#xff09;&#xff0c;內容如下 #1.定義父鏡像(定義當前工程依賴的環境)&#xff1a;…

vscode源代碼管理Tab-文件右側標志(M、A 等)的含義

Git 常用標志(M、A 等)的含義 在 VSCode 的源代碼管理&#xff08;Source Control&#xff09;標簽頁中&#xff0c;文件右側顯示的 Monaco 裝飾徽章&#xff08;Badge&#xff09;&#xff08;如 M、A 等&#xff09;&#xff0c;本質上是對 Git 文件狀態標志 的可視化呈現。…

基于 vue-flow 實現可視化流程圖

vue-flow 是一個基于 Vue.js 的強大且靈活的可視化流程圖庫&#xff0c;它允許開發者輕松創建交互式的流程圖、工作流圖、節點圖等。 主要特點 易于使用 &#xff1a;提供了簡潔的 API 和組件&#xff0c;開發者可以快速上手并創建復雜的流程圖。高度可定制 &#xff1a;支持…

【愚公系列】《Manus極簡入門》015-時間管理顧問:“商業時間規劃大師”

&#x1f31f;【技術大咖愚公搬代碼&#xff1a;全棧專家的成長之路&#xff0c;你關注的寶藏博主在這里&#xff01;】&#x1f31f; &#x1f4e3;開發者圈持續輸出高質量干貨的"愚公精神"踐行者——全網百萬開發者都在追更的頂級技術博主&#xff01; &#x1f…