<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>

新聞中心

EEPW首頁(yè) > 模擬技術(shù) > 設計應用 > 實(shí)驗18:秒表計數器

實(shí)驗18:秒表計數器

作者: 時(shí)間:2023-10-12 來(lái)源:電子森林 收藏
  • (1)熟悉和掌握開(kāi)發(fā)流程和軟件使用方法;
  • (2)通過(guò)實(shí)驗理解和掌握計數器原理;
  • (3)掌握用數據流和行為級描述寄存器單元的方法。

設計簡(jiǎn)單秒表(60進(jìn)制),并要求帶啟動(dòng)、復位、暫停功能。

本文引用地址:http://dyxdggzs.com/article/202310/451446.htm

如下所示,秒表(60進(jìn)制)即顯示從00到59循環(huán)跳轉計數。并且通過(guò)開(kāi)關(guān)設置,達到復位至00,任意時(shí)刻暫停和啟動(dòng)的功能。我們通過(guò)將開(kāi)發(fā)板的12M晶振分頻(參考分頻程序)出1Hz的計時(shí)頻率,實(shí)現秒鐘的效果。將clk_1s的上升沿作為觸發(fā)信號計時(shí)。通過(guò)開(kāi)發(fā)板上的按鍵開(kāi)關(guān)置零,實(shí)現復位功能。通過(guò)撥碼開(kāi)關(guān)置1或0,實(shí)現暫停和啟動(dòng)的功能。


程序清單counter60.v

 module counter60 
(input wire clk,rst,           //時(shí)鐘和復位輸入
input wire key,				  //啟動(dòng)暫停按鍵
output wire [8:0] segment_led_1,segment_led_2    	  //數碼管輸出
); 
wire	clk1h;			//1秒時(shí)鐘
reg	[7:0] cnt;			//計時(shí)計數器
reg		flag;			//啟動(dòng)暫停標志 
divide #				//例化分頻器產(chǎn)生1秒時(shí)鐘信號
(
.WIDTH(24),
.N(12_000_000)
) u1
(
.clk(clk),
.rst_n(rst),
.clkout(clk1h)
);
always @(posedge clk)		//產(chǎn)生標志信號
	if(!rst)
		flag = 1'b0;
	else if(!key)
		flag = ~flag;
	else
		flag = flag;always @(posedge clk1h )        //產(chǎn)生60進(jìn)制計數器
	begin	//數碼管顯示要按照十進(jìn)制的方式顯示
		if(!rst)
			cnt <= 8'h00;		//復位初值顯示00
		else if(flag)
			begin
				if(cnt[3:0] == 4'd9)	//個(gè)位滿(mǎn)九?
					begin
						cnt[3:0] <= 4'd0;	//個(gè)位清零
						if(cnt[7:4] == 4'd5 )	//十位滿(mǎn)五?
							cnt[7:4] <= 4'd0;	//個(gè)位清零
						else
							cnt[7:4] <= cnt[7:4] + 1'b1;	//十位加一
					end
				else cnt[3:0] <= cnt[3:0] + 1'b1;	//個(gè)位加一
			end
		else
			cnt <= cnt;
	end
	segment u2
	(
	.seg_data_1		(cnt[7:4]),  //seg_data input
	.seg_data_2		(cnt[3:0]),  //seg_data input
	.segment_led_1	(segment_led_1),  //MSB~LSB = SEG,DP,G,F,E,D,C,B,A
	.segment_led_2	(segment_led_2)   //MSB~LSB = SEG,DP,G,F,E,D,C,B,A
	);
	endmodule

其中例化的模塊還包括分頻模塊程序divide.v和數碼管segment.v

  1. 打開(kāi),建立工程。
  2. 新建設計文件,并鍵入設計代碼。
  3. 根據邏輯綜合并分配管腳,在本實(shí)驗中引腳分配如下:clkin —C1,rstnin—L14,key1—M13,[8:0] segmentled1 — A10~C9,[8:0] segmentled2 —C12~A12
  4. 構建并輸出編程文件,燒寫(xiě)至的Flash之中。
  5. 觀(guān)察輸出結果。

開(kāi)發(fā)板上的兩個(gè)顯示數碼管從00至59循環(huán)累加。當按鍵開(kāi)關(guān)L14按下時(shí),計數器復位。在計數過(guò)程中,按一次M13計數暫停,再按一次M13正常計數。我們可以通過(guò)暫停清零啟動(dòng)的過(guò)程達到秒表計數功能。




評論


相關(guān)推薦

技術(shù)專(zhuān)區

關(guān)閉
国产精品自在自线亚洲|国产精品无圣光一区二区|国产日产欧洲无码视频|久久久一本精品99久久K精品66|欧美人与动牲交片免费播放
<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>