序列檢測器設(shè)計-modelsim-verilog-實驗報告.doc_第1頁
序列檢測器設(shè)計-modelsim-verilog-實驗報告.doc_第2頁
序列檢測器設(shè)計-modelsim-verilog-實驗報告.doc_第3頁
序列檢測器設(shè)計-modelsim-verilog-實驗報告.doc_第4頁
序列檢測器設(shè)計-modelsim-verilog-實驗報告.doc_第5頁
已閱讀5頁,還剩2頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)

文檔簡介

實驗四-序列檢測一、實驗?zāi)康模?.實驗?zāi)康模和ㄟ^學(xué)習(xí)硬件編程語言,掌握一般時序邏輯分析的方法。2.學(xué)會使用Verilog語言編寫實現(xiàn)任意序列檢測。3.學(xué)會使用Verilog編寫測試文件testbech的方法并在Modelsim中實現(xiàn)時序仿真。二、實驗設(shè)備1.PC機(jī)一臺2.Modelsim軟件三、實驗內(nèi)容:序列檢測器是能夠與從二進(jìn)制碼流中檢測出一組特定序列的信號的時序電路。通過接受的序列號與檢測其預(yù)設(shè)值比較,當(dāng)檢測到輸入信號匹配時,輸出響應(yīng)的指示。設(shè)計序列檢測器,要求能夠識別序列“10010”。din為數(shù)字碼流的輸入,z是檢測標(biāo)記的輸出,高電平表示“發(fā)現(xiàn)指定序列”,低電平表示“沒有發(fā)現(xiàn)指定的序列”。檢測序列“10010”時序輸入與輸出示例如下:T1234567891011121314151617181920x00011001001000010010z00000000100100000001Table 1 - 序列檢測時序輸入與輸出示例1.打開Modelsim軟件,切換目錄至常用位置,這里選擇D:seqdet。(注,在D:seqdet目錄下一保存有序列檢測文件seqdet.v和測試文件seqdet_tb.v,源程序在附錄里) 2.然后新建工程,F(xiàn)ile -New-Project,建立工程工程為seqdet,設(shè)置如下,并在接下來的步驟中添加序列檢測文件seqdet.v和測試文件seqdet_tb.v。 4.編譯文件編譯無誤后,進(jìn)行仿真5.文件仿真在彈出的窗口中選擇Design-work-seqdet_tb,默認(rèn)選中優(yōu)化選項。選擇OK6.添加信號到wave視圖中。在仿真狀態(tài)下,切換到左側(cè)導(dǎo)航窗口到object視圖下,添加信號T,clk,rst,x,z,q到wave窗口中,添加完成后如圖所示:7.運(yùn)行仿真至1000ns,波形圖顯示如圖所示:8.結(jié)果分析:對上述圖形分析如下,當(dāng)rst復(fù)位信號為高電平時,輸入使能,輸入的x序列為x:0001_1001_0010_0001_0010_1000。用藍(lán)色表示的為第一次檢測到匹配序列“10010”,黃色表示為第二次匹配序列,紫色表示為第三次匹配序列。z分別在這三處匹配時輸出高電平,其他為低電平,實現(xiàn)了序列檢測的功能。四,程序:源程序模塊seqdet.v :module seqdet( input wire x, /信號輸入 input wire clk, /時鐘信號 input wire rst, output wire z, output reg 4:0 q /序列輸出); wire 4:0 q_next; assign q_next =q3:0,x; assign z = (q_next= 5b10010) ? 1b1:1b0; always (posedge clk,negedge rst) if(!rst) q = 5d0; else q = q_next; endmodule 測試程序模塊seqdet_tb.vtimescale 1ns/1nsmodule seqdet_tb;localparam T =20; reg clk,rst;reg 23:0 data;wire z,x;wire 4:0 q; assign x = data23; initialbegin clk =0; rst =1; #2 rst =0; #30 rst =1; data =20b1100_1001_0000_1001_0100; #(T*1000) $stop;end always #T clk = clk; always (posedge clk) #2 data = data22:0,data23; seqdet U1( .x(x), .z(z), .clk(clk), .q(q), .rst(rst);endmodule五、實驗總結(jié):通過本次實驗,對Verilog硬件描述語言有了進(jìn)一步認(rèn)識,學(xué)會編寫verilog語

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論