日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

HDLBits答案(13)_Verilog移位寄存器附加题

發布時間:2023/12/19 编程问答 35 豆豆
生活随笔 收集整理的這篇文章主要介紹了 HDLBits答案(13)_Verilog移位寄存器附加题 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

Verilog移位寄存器

HDLBits鏈接


前言

今天更新一節內容,該小節題目不多,共三道,但技巧性挺強。


題庫

題目描述1:各單元的下一狀態是此時當前單元相鄰兩位的異或。

在這個電路中,創建一個512單元系統(q(511:0)),并在每個時鐘周期中前進一個時間步長。加載(load)表明系統的狀態應該加載data[511:0]至q中,假設邊界(q[0]和q[512])都為零。

Solution1:

module top_module(input clk,input load,input [511:0] data,output [511:0] q ); always @(posedge clk)beginif(load)beginq <= data;endelse beginq <= {1'b0,q[511:1]}^{q[510:0],1'b0};endendendmodule

題目描述2:

與題目一類似,狀態轉移條件發生變化,如下圖所示:

Solution2:

module top_module(input clk,input load,input [511:0] data,output [511:0] q ); always @(posedge clk)beginif(load)beginq <= data;endelse begin q <= (~{1'b0,q[511:1]} & q) | (q & ~{q[510:0],1'b0}) | {~{1'b0,q[511:1]} & {q[510:0],1'b0}} | {~q & {q[510:0],1'b0}};endendendmodule

tips:進行卡諾圖化簡后可看懂q狀態轉移的含義。

題目描述3:

一個中心點周圍有8個鄰居,如果周圍的鄰居中1的數目為0-1個,那么中心點變為0;如果周圍鄰居中1的數目為2個,那么中心點狀態不變;如果周圍鄰居中1的數目為3個,中心點變為1;如果周圍鄰居中1的數目大于3個,中心點變為0。

我們可以將周圍的8個鄰居的值都加起來來判斷周圍鄰居中1的個數,值得注意的是,這里我們在for中使用了阻塞賦值,因需要當前拍(本周期)得到結果在當前拍(本周期)就去判斷

建議大家做該題的時候花一個16*16的方陣,分析邊界條件,達到事半功倍的效果。

生命游戲之父約翰·康威因感染新冠于2020年4月11日去世,享年83歲,在此表示哀悼。

Solution3:

module top_module(input clk,input load,input [255:0] data,output [255:0] q );reg [3:0] count;integer i;always @(posedge clk)beginif(load)beginq <= data;endelse beginfor(i=0;i<256;i++)beginif(i == 0)begincount = q[255] + q[240] + q[241] + q[15] + q[1] + q[31] + q[16] + q[17];endelse if(i == 15)begincount = q[254] + q[255] + q[240] + q[14] + q[0] + q[30] + q[31] + q[16];endelse if(i == 240)begincount = q[239] + q[224] + q[225] + q[255] + q[241] + q[15] + q[0] + q[1];endelse if(i == 255)begincount = q[238] + q[239] + q[224] + q[254] + q[240] + q[15] + q[0] + q[14];endelse if( i>0 && i<15)begincount = q[239+i]+q[240+i]+q[241+i]+q[i-1]+q[i+1]+q[i+15]+q[i+16]+q[i+17];endelse if(i>240 && i<255)begincount = q[i-17]+q[i-16]+q[i-15]+q[i-1]+q[i+1]+q[i-239]+q[i-240]+q[i-241];endelse if( i%16 == 0)begincount = q[i-1]+q[i-16]+q[i-15]+q[i+15]+q[i+1]+q[i+31]+q[i+16]+q[i+17];endelse if(i % 16 == 15)begincount = q[i-17]+q[i-16]+q[i-31]+q[i-1]+q[i-15]+q[i+15]+q[i+16]+q[i+1];endelse begincount = q[i-17]+q[i-16]+q[i-15]+q[i-1]+q[i+1]+q[i+15]+q[i+16]+q[i+17];endcase(count)4'd2:q[i] <= q[i];4'd3:q[i] <= 1'b1;default:q[i] <= 1'b0;endcaseendendendendmodule

小結

本次練習主要難在第三題中的阻塞賦值,因為我們需在當前周期內算出count并對當前算出的count值進行判斷,需用阻塞賦值。

希望自己以后遇到問題能夠慢慢劃分解決,徐圖緩進

創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎

總結

以上是生活随笔為你收集整理的HDLBits答案(13)_Verilog移位寄存器附加题的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。