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

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

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

3天內不再提示

使用matlab產生待濾波信號并編寫testbench進行仿真分析

Hx ? 來源:CSDN技術社區 ? 作者:DengFengLai123 ? 2021-04-27 18:18 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

本講使用matlab產生待濾波信號,并編寫testbench進行仿真分析,在Vivado中調用FIR濾波器的IP核進行濾波測試,下一講使用兩個DDS產生待濾波的信號,第五講或第六講開始編寫verilog代碼設計FIR濾波器,不再調用IP核。

本例使用上一講的FIR濾波器IP核工程。

matlab與FPGA數字濾波器設計(2)——Vivado調用IP核設計FIR濾波器

matlab與FPGA數字濾波器設計(1)——通過matlab的fdatool工具箱設計FIR數字濾波器

100063647-127709-tu_1.png

1. 新建仿真文件

(1) Simulation Sources -》 sim_1 -》右鍵 Add Sources;

(2) Add or Create Simulation Sources,新建仿真文件 fir_ip_tb;

100063647-127710-tu_2.png

2. 編寫testbench

(1) 例化加入的IP核,其中:

輸入時鐘引腳為 clk,設置為32MHz(此處暫時還未設定頻率);

輸入數據引腳為data_in,位寬16-bit,表示待濾波數據;

輸出數據引腳為data_out,位寬40-bit,表示濾波后的數據;

輸出數據有效信號引腳data_out_valid,位寬1-bit,輸出狀態,為高電平時表示輸出的data_out有效;

輸入數據準備好信號引腳data_in_ready,位寬1-bit,輸出狀態,為高電平時表示準備好接收輸入數據;

輸入有效信號S_AXIS_DATA_0_tvalid,為1時表示輸入信號有效,為0時即使有輸入信號data_in到 fir 的 ip 核 ,ip 核也不做處理,此處直接讓其恒為1,輸入數據恒有效;

總結,需要給ip核輸入的數據目前只有兩個,一個是時鐘,一個是待濾波數據。

100063647-127711-tu_3.png

(2) 產生32MHz時鐘信號;

初始 initial 時設置時鐘信號clk為低電平0,always 表示一直執行,#16表示每隔16 ns(單位是在仿真文件開頭自動有定義ns)時鐘取反一次,即每隔 16ns 時鐘 0/1間隔變化,相當于32ns一個時鐘周期,約等于32MHz;

100063647-127712-tu_4.png

3. 產生待濾波數據data_in

(1) 編寫matlab程序,產生兩個信號0.5MHz和5MHz,采樣頻率32MHz,采樣5個周期,進行16-bit量化,并把量化后的數據寫到 .txt 文件中;

100063647-127713-tu_5.png

可以看到,在 0.5MHz 和 5MHz處有兩個峰,表示抽樣后的兩個信號,經過濾波器之后,5MHz 信號被濾除,只剩下 0.5MHz 信號,藍色框內可以看到,在 3MHz 以后濾波器的響應已經低于 -80dB,相當于濾波后的幅度是濾波前的1/10000,濾波效果很好。

100063647-127714-tu_6.png

使用 32MHz 的采樣時鐘采樣 0.5MHz 待濾波信號(相當于0.5MHz信號疊加了5MHz噪聲),每個周期采樣 64 個點,在testbench中讀取一個周期的64個點,重復30個周期得到30個周期的輸入待濾波信號給FIR濾波器;

100063647-127715-tu_7.png

4. 仿真結果分析

點擊1處開始仿真,Vivado中一般默認只會仿真1us,這時候只看到了初始化的一部分,是看不到后續結果的,點擊2處進行仿真,會將所有的仿真步驟完成,執行到上圖中第64行的 $stop 語句停止仿真;

100063647-127716-tu_8.png

5. 仿真結果分析

(1) data_out_valid:初始為0,在1.872 ns跳變為1,輸出數據開始有效,在為0的那段時間輸出數據data_out無效,這段時間內是FIR的IP核進行一些內部的配置和初始化;

100063647-127717-tu_9.png

(2) 更改數據表示模式

對data_in,右鍵設置其數據格式Radix為有符號的十進制數(Signed Decimal),設置其波形為模擬波形(Analog);

對 data_out 同樣設置;

對 Pattern 設置 無符號十進制,不需要設置波形。

100063647-127718-tu_10.png

(3) 點擊放大縮小可以查看整個仿真的效果

通過下面幾圖,可以看到仿真效果很好,5MHz高頻噪聲濾除干凈,肉眼觀察不出來。

100063647-127719-tu_11.png

100063647-127720-tu_12.png

100063647-127721-tu_13.png

(4) Matlab數據分析

肉眼觀察時域的仿真圖無法得知高頻噪聲具體被濾掉了多少,是否還混有噪聲,此時需要將濾波后的數據按照前文讀取仿真數據的方式,將仿真得到的濾波后的數據寫入.txt文件,再通過 matlab 讀取 FPGA 濾波后的數據并進行FFT 頻譜分析,通過頻域的波形來觀察濾波效果,通過 matlab 仿真,可以看到高頻信號的確被濾除。

100063647-127722-tu_14.png

100063647-127723-tu_15.png

下一講使用兩個 DDS 產生待濾波的信號,結合FIR濾波器搭建一個信號產生及濾波的系統,并編寫testbench進行仿真分析。
編輯:lyn

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

    關注

    189

    文章

    3025

    瀏覽量

    238696
  • 仿真
    +關注

    關注

    54

    文章

    4482

    瀏覽量

    138251
  • fir濾波器
    +關注

    關注

    1

    文章

    97

    瀏覽量

    19697
  • Vivado
    +關注

    關注

    19

    文章

    857

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    使用MATLAB和Simulink進行信號完整性分析

    信號完整性是保持高速數字信號的質量的過程。信號完整性是衡量電信號從源傳輸到目標位置時的質量的關鍵度量。在高速數字和模擬電子中,確保信號的預期
    的頭像 發表于 01-23 13:57 ?7217次閱讀
    使用<b class='flag-5'>MATLAB</b>和Simulink<b class='flag-5'>進行</b><b class='flag-5'>信號</b>完整性<b class='flag-5'>分析</b>

    求助,關于testbench仿真的問題求解

    我用c 寫了一段加密算法,其中包含了S盒替換表和密鑰等參數,現在想用vcs和testbench仿真這個程序,c 編譯成機器碼后怎么區分哪段數據是寫入ITCM哪段是寫入DTCM的,又應該怎么寫入DTCM
    發表于 11-05 08:56

    語法糾錯和testbench的自動生成

    編寫Verilog代碼時,我一般都是先在編輯器上寫完,因為編輯器vscode或者notepad++可以提供語法高亮和自動補全等功能,然后用仿真器跑仿真,但是在編寫過程中不可避免的會有
    發表于 10-27 07:07

    基于Matlab與FPGA的雙邊濾波算法實現

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

    無刷直流電機控制系統的建模仿真分析

    摘要:分析了BLDCM的數學模型,運用MATLAB仿真軟件搭建了無刷直流電機控制系統的仿真模型。本系統采用了速度PID控制、電流遲滯控制的雙閉環控制方案,電流遲滯控制是為了更方便地跟蹤
    發表于 06-27 16:52

    羅德與施瓦茨方案:D波段射頻寬帶信號產生分析

    R&S D波段寬帶信號產生分析方案,是市面上最為緊湊及易用的解決方案,信號源可直接對上變頻器進行參數設定,頻譜與
    的頭像 發表于 06-16 14:46 ?1719次閱讀
    羅德與施瓦茨方案:D波段射頻寬帶<b class='flag-5'>信號</b><b class='flag-5'>產生</b>與<b class='flag-5'>分析</b>

    嵌入式直驅力矩電機設計及其系統仿真分析

    和基于 Matlab/Simulink 的雙閉環電機調速系統仿真模型,對力矩電機系統進行仿真分析,兩者仿
    發表于 06-11 15:11

    利用MATLAB對交流電機調速系統進行建模和仿真

    技術是借助計算機及相關技術,對真實系統的運行過程和狀態進行數字化模擬的技術。Simulink作為MATLAB的一個組件,能夠實現對動態系統的建模、仿真和綜合分析。本文在Simulink
    發表于 06-06 14:31

    基于 FPGA 的任意波形發生器+低通濾波器系統設計

    濾波信號,兩個正弦波的頻率分別是200Hz、800Hz。用MATLAB產生頻率為500Hz的低通濾波
    發表于 05-07 15:34

    testbench中如何使用阻塞賦值和非阻塞賦值

    本文詳細闡述了在一個testbench中,應該如何使用阻塞賦值與非阻塞賦值。首先說結論,建議在testbench中,對時鐘信號(包括分頻時鐘)使用阻塞賦值,對其他同步信號使用非阻塞賦值
    的頭像 發表于 04-15 09:34 ?1205次閱讀
    在<b class='flag-5'>testbench</b>中如何使用阻塞賦值和非阻塞賦值

    怎么利用matlab得到95%,80%和70%的置信區間,生成不同區間下的功率誤差貝塔分布?

    matlab仿真 matlab新手,怎么利用matlab得到95%,80%和70%的置信區間,生成不同區間下的功率誤差貝塔分布
    發表于 04-09 01:21

    進群免費領FPGA學習資料!數字信號處理、傅里葉變換與FPGA開發等

    的基礎知識,講述了確定性數字信號處理的知識,包括離散時間信號及系統的介紹、z變換、傅里葉變換、頻率分析以及濾波器設計等。介紹了隨機數字信號
    發表于 04-07 16:41

    如何用FOC電機控制MATLAB仿真

    )、電機與控制模塊(藍色方框)、控制信號給定模塊(黃色方框)、信號分路與顯示模塊(綠色方框)。整體結構及功能介紹 用MATLAB2013以上版本打開文件,看到如圖1所示界面:可以看到仿真
    發表于 03-28 14:51

    MATLAB仿真在直流電機雙閉環調速系統中的應用

    分析了直流調速系統原理的基礎上,在MATLAB/SIMULINK 仿真環境下對轉速、電流雙閉環調速系統建模并進行仿真
    發表于 03-20 13:03

    使用AFG31000系列信號發生器精準復制真實場景信號

    中的核心工具。本文將詳細介紹如何利用該系列信號發生器復制復雜場景信號,探討其在不同領域的應用與優化技巧。 ? 一、信號特性分析:復制真實
    的頭像 發表于 03-20 11:45 ?767次閱讀
    使用AFG31000系列<b class='flag-5'>信號</b>發生器精準復制真實場景<b class='flag-5'>信號</b>