版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、<p> 深 圳 大 學(xué) 實(shí) 驗(yàn) 報(bào) 告</p><p> 課程名稱: 數(shù)字系統(tǒng)現(xiàn)場(chǎng)集成技術(shù) </p><p> 實(shí)驗(yàn)項(xiàng)目名稱: 設(shè)計(jì)秒表 </p><p> 學(xué)院: 信息工程學(xué)院 <
2、;/p><p> 專業(yè): 集成電路設(shè)計(jì)與集成系統(tǒng) </p><p> 指導(dǎo)教師: </p><p> 報(bào)告人: 學(xué)號(hào): 班級(jí): </p><p> 實(shí)驗(yàn)時(shí)間:
3、 </p><p> 實(shí)驗(yàn)報(bào)告提交時(shí)間: </p><p><b> 教務(wù)部制</b></p><p><b> 目錄</b></p><p> 實(shí)驗(yàn)要求 -------------
4、-------------------------------------------------------------3</p><p> 實(shí)驗(yàn)環(huán)境 --------------------------------------------------------------------------3</p><p> Nexys2開發(fā)板介紹及本實(shí)驗(yàn)功能說明 ----------
5、---------------------------3</p><p> 框架圖功能與ASM圖 ---------------------------------------------------------4</p><p> 各層VHDL代碼、仿真結(jié)果及結(jié)果分析 ----------------------------------6</p><p>
6、 資源報(bào)告及實(shí)驗(yàn)結(jié)果 -----------------------------------------------------------50</p><p> 問題及解決 -----------------------------------------------------------------------51</p><p> 總結(jié) ----------------
7、----------------------------------------------------------------52</p><p><b> 一、實(shí)驗(yàn)要求:</b></p><p> 基本要求:它具有計(jì)時(shí)功能。此秒表有兩個(gè)按鍵(reset, start)按下reset鍵后,秒表清零,按下start鍵后,開始計(jì)時(shí), 再次按下start鍵后, 停止計(jì)
8、時(shí), 用FPGA開發(fā)板上的兩個(gè)七段數(shù)碼管顯示時(shí)間(以秒為單位),計(jì)時(shí)由0 到 59 循環(huán)。</p><p> 高級(jí)要求(可選):實(shí)現(xiàn)基本要求的前提下,增加一個(gè)按鍵(select),用于輪流切換兩個(gè)七段數(shù)碼管分別顯示百分之一秒,秒,分鐘。</p><p><b> 二、實(shí)驗(yàn)環(huán)境</b></p><p><b> windows7&
9、lt;/b></p><p><b> ISE14.4</b></p><p><b> Nexys2開發(fā)板</b></p><p> 三、Nexys2開發(fā)板介紹及本實(shí)驗(yàn)功能說明</p><p> Nexys2開發(fā)板的核心芯片是具有1200K門的Spartan 3E FPGA,時(shí)鐘是由
10、50MHz的晶振提供,還有4個(gè)的7段數(shù)碼管,4個(gè)按鈕,8個(gè)撥碼開關(guān)。</p><p> 下圖為Nexys2開發(fā)板的實(shí)際部分板分布:</p><p> 圖3.1 Nexys2開發(fā)板的實(shí)際部分板分布</p><p> 圖3.2 Nexys2開發(fā)板的I/O原理圖</p><p> Nexys2板上7段數(shù)碼管為共陽極的方式,陰極獨(dú)立。也就是說
11、驅(qū)動(dòng)7段數(shù)碼管的每一段的顯示,必須給低電平。由于板上的7段數(shù)碼管的設(shè)計(jì)結(jié)構(gòu),為了在4個(gè)數(shù)碼管上顯示數(shù)字,必須給出掃描控制電路,圖3.3給出了掃描控制電路的時(shí)序結(jié)構(gòu)。為了在每個(gè)數(shù)碼管上顯示和連續(xù)的點(diǎn)亮數(shù)碼管,所有的四個(gè)數(shù)碼管應(yīng)該每1到16ms就被驅(qū)動(dòng)一次。</p><p><b> 圖3。3 時(shí)序結(jié)構(gòu)</b></p><p> 但在本實(shí)驗(yàn)中,四個(gè)數(shù)碼管的驅(qū)動(dòng)時(shí)間為1
12、00us,所以每400us,數(shù)碼管就被驅(qū)動(dòng)一次,并且效果也很好。</p><p> 四、框架圖功能與ASM圖</p><p><b> 1、框架:</b></p><p><b> 圖4.1.1 框架</b></p><p> 本實(shí)驗(yàn)中使用了4個(gè)數(shù)碼管、3個(gè)按鈕、5個(gè)撥動(dòng)開關(guān),數(shù)碼管用來顯示
13、時(shí)間,按鈕分別是rst_p異步復(fù)位按鍵、start_stop開始/暫停按鍵、record_button記錄時(shí)間按鍵(只能記錄最近的4次),撥動(dòng)開關(guān)作用分別是key1(兩位)秒表時(shí)間選擇(00表示顯示秒和百分秒、01表示顯示分和秒、10表示顯示時(shí)和分、11表示顯示天和時(shí))、mode可切換看秒表還是記錄(1表示數(shù)碼管顯示的是正在計(jì)數(shù)時(shí)間,0表示數(shù)碼管顯示的是已記錄的時(shí)間)、key2(兩位)記錄次數(shù)選擇(00表示最近的一次記錄時(shí)間、01表示最
14、近第二次的記錄時(shí)間、11表示最近第三次的記錄時(shí)間、10表示最近第四次的記錄時(shí)間)。</p><p><b> ASM圖</b></p><p> 本實(shí)驗(yàn)中有一個(gè)counter計(jì)數(shù)模塊,輸出想要的天、時(shí)、分、秒和百分秒(后面有詳細(xì)介紹),它的ASM圖如下:</p><p> 圖4.2 counterASM圖</p><
15、p> 五、各層VHDL代碼、仿真結(jié)果及結(jié)果分析</p><p> 全部的模塊展開如下:</p><p> 圖5.0 全部模塊展開圖</p><p> 頂層chronography模塊</p><p> 此模塊只是負(fù)責(zé)連線、分頻器的分頻系數(shù)和復(fù)位的取反(因?yàn)槲伊?xí)慣低復(fù)位,而開發(fā)板的按鍵按下是高電平)</p><
16、;p><b> 代碼為:</b></p><p> library IEEE;</p><p> use IEEE.STD_LOGIC_1164.ALL;</p><p> entity chronography is</p><p><b> port(</b></p>
17、<p> clk : in std_logic;</p><p> rst_p : in std_logic;</p><p> start_stop : in std_logic;</p><p> record_button : in std_logic;</p><p> key1 : in std_logic_
18、vector (1 downto 0);--秒表時(shí)間選擇</p><p> mode : in std_logic;--可切換看秒表還是記錄</p><p> key2 : in std_logic_vector (1 downto 0);--記錄次數(shù)選擇</p><p> seg7 : out std_logic_vector (7 downto 0)
19、;--dp,g,f,e,d,c,b,a</p><p> an : out std_logic_vector (3 downto 0)</p><p><b> );</b></p><p> end chronography;</p><p> architecture Behavioral of chron
20、ography is</p><p> -----------------------------------------------------------</p><p> component button is</p><p><b> port(</b></p><p> clk : in std_lo
21、gic;</p><p> rst_n : in std_logic;</p><p> start_stop : in std_logic;--繼續(xù)/暫停鍵</p><p> record_button : in std_logic;--記錄鍵</p><p> key1 : in std_logic_vector (1 dow
22、nto 0);--時(shí)間切換選擇</p><p> mode : in std_logic;--選擇秒表時(shí)間還是看記錄時(shí)間</p><p> key2 : in std_logic_vector (1 downto 0);--可記錄4次,查看第幾次記錄</p><p> time_sel : out std_logic_vector (1 downto 0
23、);--等于key1</p><p> en_counter : out std_logic;--使能計(jì)數(shù)器,可使計(jì)數(shù)器繼續(xù)或暫停</p><p> en_recorder : out std_logic;--記錄的使能,每按一次,就記錄當(dāng)下時(shí)間</p><p> transfer : out std_logic;--選擇秒表時(shí)間還是看記錄時(shí)間<
24、/p><p> record_sel : out std_logic_vector (1 downto 0)--可記錄4次,查看第幾次記錄</p><p><b> );</b></p><p> end component;</p><p> -----------------------------------
25、------------------------</p><p> -----------------------------------------------------------</p><p> component div_clk is</p><p> generic (cnt : integer);--分頻系數(shù)</p><
26、;p><b> port(</b></p><p> clk : IN std_logic;</p><p> rst_n : IN std_logic;</p><p> f_clk : out std_logic</p><p><b> );</b></p>
27、<p> end component;</p><p> -----------------------------------------------------------</p><p> -----------------------------------------------------------</p><p> compo
28、nent counter is</p><p><b> port(</b></p><p> clk : in std_logic;--100hz</p><p> rst_n : in std_logic;</p><p> en : in std_logic;</p><p>
29、dayten : out integer range 0 to 3;--天數(shù)十位</p><p> dayge : out integer range 0 to 9;--天數(shù)個(gè)位</p><p> hourten : out integer range 0 to 2;--小時(shí)十位</p><p> hourge : out integer range 0
30、 to 9;--小時(shí)個(gè)位</p><p> minten :out integer range 0 to 5;--分鐘十位</p><p> minge :out integer range 0 to 9;--分鐘個(gè)位</p><p> secten :out integer range 0 to 5;--秒十位</p><p
31、> secge :out integer range 0 to 9;--秒個(gè)位</p><p> msecten : out integer range 0 to 9;--為100ms</p><p> msecge : out integer range 0 to 9--為10ms</p><p><b> );</b>
32、</p><p> end component;</p><p> -----------------------------------------------------------</p><p> -----------------------------------------------------------</p><p&
33、gt; component mux10_4 is</p><p><b> port(</b></p><p> dayten : in integer range 0 to 3;</p><p> dayge : in integer range 0 to 9;</p><p> hourten : in i
34、nteger range 0 to 2;</p><p> hourge : in integer range 0 to 9;</p><p> minten : in integer range 0 to 5;</p><p> minge : in integer range 0 to 9;</p><p> secten : i
35、n integer range 0 to 5;</p><p> secge : in integer range 0 to 9;</p><p> msecten : in integer range 0 to 9;</p><p> msecge : in integer range 0 to 9;</p><p> sel :
36、in std_logic_vector (1 downto 0);</p><p> out1 : out integer range 0 to 9;</p><p> out2 : out integer range 0 to 9;</p><p> out3 : out integer range 0 to 9;</p><p>
37、 out4 : out integer range 0 to 9</p><p><b> );</b></p><p> end component;</p><p> -----------------------------------------------------------</p><p> --
38、---------------------------------------------------------</p><p> component seg7display is</p><p><b> port(</b></p><p> clk : in std_logic;</p><p> rst
39、_n : in std_logic;</p><p> shu1 : in integer range 0 to 9;</p><p> shu2 : in integer range 0 to 9;</p><p> shu3 : in integer range 0 to 9;</p><p> shu4 : in integer
40、 range 0 to 9;</p><p> seg7 : out std_logic_vector (7 downto 0);</p><p> an : out std_logic_vector (3 downto 0)</p><p><b> );</b></p><p> end component;
41、</p><p> -----------------------------------------------------------</p><p> -----------------------------------------------------------</p><p> component recorder is</p>
42、<p><b> port(</b></p><p> clk : in std_logic;</p><p> en_recorder : in std_logic;</p><p> transfer : in std_logic;</p><p> record_sel : in std_l
43、ogic_vector (1 downto 0);</p><p> daytenin : in integer range 0 to 3;--天數(shù)十位</p><p> daygein : in integer range 0 to 9;--天數(shù)個(gè)位</p><p> hourtenin : in integer range 0 to 2;--小時(shí)十位
44、</p><p> hourgein : in integer range 0 to 9;--小時(shí)個(gè)位</p><p> mintenin :in integer range 0 to 5;--分鐘十位</p><p> mingein :in integer range 0 to 9;--分鐘個(gè)位</p><p> sec
45、tenin :in integer range 0 to 5;--秒十位</p><p> secgein :in integer range 0 to 9;--秒個(gè)位</p><p> msectenin : in integer range 0 to 9;--為100ms</p><p> msecgein : in integer range
46、0 to 9;--為10ms</p><p> dayten : out integer range 0 to 3;--天數(shù)十位</p><p> dayge : out integer range 0 to 9;--天數(shù)個(gè)位</p><p> hourten : out integer range 0 to 2;--小時(shí)十位</p>&
47、lt;p> hourge : out integer range 0 to 9;--小時(shí)個(gè)位</p><p> minten :out integer range 0 to 5;--分鐘十位</p><p> minge :out integer range 0 to 9;--分鐘個(gè)位</p><p> secten :out intege
48、r range 0 to 5;--秒十位</p><p> secge :out integer range 0 to 9;--秒個(gè)位</p><p> msecten : out integer range 0 to 9;--為100ms</p><p> msecge : out integer range 0 to 9--為10ms</p
49、><p><b> );</b></p><p> end component;</p><p> -----------------------------------------------------------</p><p> signal clk_10khz, clk_100hz: std_logic;
50、</p><p> signal rst_n : std_logic;</p><p> signal time_sel : std_logic_vector (1 downto 0);</p><p> signal en_counter : std_logic;</p><p> signal en_recorder : std_
51、logic;</p><p> signal recorder_sel : std_logic_vector (1 downto 0);</p><p> signal transfer : std_logic;</p><p> --cr : counter_recorder</p><p> signal dayten_cr :
52、integer range 0 to 3 := 0;</p><p> signal dayge_cr : integer range 0 to 9 := 0;</p><p> signal hourten_cr : integer range 0 to 2 := 0;</p><p> signal hourge_cr : integer range 0
53、to 9 := 0;</p><p> signal minten_cr : integer range 0 to 5 := 0;</p><p> signal minge_cr : integer range 0 to 9 := 0;</p><p> signal secten_cr : integer range 0 to 5 := 0;</p&
54、gt;<p> signal secge_cr : integer range 0 to 9 := 0;</p><p> signal msecten_cr : integer range 0 to 9 := 0;</p><p> signal msecge_cr : integer range 0 to 9 := 0;</p><p>
55、signal dayten : integer range 0 to 3 := 0;</p><p> signal dayge : integer range 0 to 9 := 0;</p><p> signal hourten : integer range 0 to 2 := 0;</p><p> signal hourge : integer r
56、ange 0 to 9 := 0;</p><p> signal minten : integer range 0 to 5 := 0;</p><p> signal minge : integer range 0 to 9 := 0;</p><p> signal secten : integer range 0 to 5 := 0;</p>
57、;<p> signal secge : integer range 0 to 9 := 0;</p><p> signal msecten : integer range 0 to 9 := 0;</p><p> signal msecge : integer range 0 to 9 := 0;</p><p> signal shu1
58、 : integer range 0 to 9 := 0;</p><p> signal shu2 : integer range 0 to 9 := 0;</p><p> signal shu3 : integer range 0 to 9 := 0;</p><p> signal shu4 : integer range 0 to 9 := 0;&l
59、t;/p><p><b> begin</b></p><p> process(rst_p)</p><p><b> begin</b></p><p> rst_n <= not rst_p;</p><p> end process;</p>
60、<p> --產(chǎn)生10khz的時(shí)鐘,用于useg7display</p><p> uclk_10khz : div_clk generic map (5000) port map(clk, '1', clk_10khz);</p><p> --產(chǎn)生200hz的時(shí)鐘,用于button和counter</p><p> uclk
61、_100hz : div_clk generic map (500000) port map(clk, rst_n, clk_100hz);</p><p><b> --掃面按鍵</b></p><p> u1button : button port map(clk_100hz, rst_n, start_stop, record_button, key1,
62、 mode, key2, time_sel, en_counter, en_recorder, transfer, recorder_sel);</p><p> --計(jì)數(shù)器,可輸出天數(shù)、小時(shí)、分鐘、秒以及10毫秒</p><p> u1counter : counter port map(clk_100hz, rst_n, en_counter, dayten_cr, dayge_
63、cr, hourten_cr, hourge_cr, minten_cr, minge_cr, secten_cr, secge_cr, msecten_cr, msecge_cr);</p><p> --記錄器,可記錄最新4次</p><p> u1recorder : recorder port map(clk_100hz, en_recorder, transfer, rec
64、order_sel, dayten_cr, dayge_cr, hourten_cr, hourge_cr, minten_cr, minge_cr, secten_cr, secge_cr, msecten_cr, msecge_cr, dayten, dayge, hourten, hourge, minten, minge, secten, secge, msecten, msecge);</p><p>
65、 --因?yàn)橹挥兴膫€(gè)數(shù)碼管,所以要選擇顯示什么時(shí)間</p><p> u1mux10_4 : mux10_4 port map(dayten, dayge, hourten, hourge, minten, minge, secten, secge, msecten, msecge, time_sel, shu1, shu2, shu3, shu4);</p><p><b>
66、; --數(shù)碼管的顯示</b></p><p> useg7display : seg7display port map(clk_10khz, rst_n, shu1, shu2, shu3, shu4, seg7, an);</p><p> end Behavioral;</p><p><b> RTL原理圖為:</b>
67、;</p><p> 圖5.1.1 頂層RTL原理圖</p><p> 打開之后可以看到有七個(gè)子模塊:</p><p> 圖5.1.2 頂層RTL原理圖</p><p><b> button模塊</b></p><p> 此模塊是按鍵和撥動(dòng)開關(guān)掃描,用來緩存和解析I/O輸入的數(shù)據(jù),即是
68、按鍵和撥動(dòng)開關(guān)的數(shù)據(jù),還可以有一定程度的消抖。</p><p><b> 代碼為:</b></p><p> ibrary IEEE;</p><p> use IEEE.STD_LOGIC_1164.ALL;</p><p> entity button is</p><p><b
69、> port(</b></p><p> clk : in std_logic;</p><p> rst_n : in std_logic;</p><p> start_stop : in std_logic;--繼續(xù)/暫停鍵</p><p> record_button : in std_logic;--
70、記錄鍵</p><p> key1 : in std_logic_vector (1 downto 0);--時(shí)間切換選擇</p><p> mode : in std_logic;--選擇秒表時(shí)間還是看記錄時(shí)間</p><p> key2 : in std_logic_vector (1 downto 0);--可記錄4次,查看第幾次記錄</p&
71、gt;<p> time_sel : out std_logic_vector (1 downto 0);--等于key1</p><p> en_counter : out std_logic;--使能計(jì)數(shù)器,可使計(jì)數(shù)器繼續(xù)或暫停</p><p> en_recorder : out std_logic;--記錄的使能,每按一次,就記錄當(dāng)下時(shí)間</p>
72、;<p> transfer : out std_logic;--選擇秒表時(shí)間還是看記錄時(shí)間</p><p> record_sel : out std_logic_vector (1 downto 0)--可記錄4次,查看第幾次記錄</p><p><b> );</b></p><p> end button;&l
73、t;/p><p> architecture Behavioral of button is</p><p><b> begin</b></p><p> process(clk, rst_n)</p><p> variable start_stop1 : std_logic := '0';<
74、;/p><p> variable start_stop2 : std_logic := '0';</p><p> variable start_stop3 : std_logic := '0';</p><p> variable recordbutton1 : std_logic := '0';</p&g
75、t;<p> variable recordbutton2 : std_logic := '0';</p><p> variable recordbutton3 : std_logic := '0';</p><p><b> begin</b></p><p> if(rst_n = &
76、#39;0') then</p><p> start_stop1 := '0';</p><p> start_stop2 := '0';</p><p> start_stop3 := '0';</p><p> recordbutton1 := '0';&l
77、t;/p><p> recordbutton2 := '0';</p><p> recordbutton3 := '0';</p><p><b> else</b></p><p> if(clk' event and clk = '1') then<
78、/p><p> start_stop2 := start_stop1;</p><p> start_stop1 := start_stop;</p><p> recordbutton2 := recordbutton1;</p><p> recordbutton1 := record_button;</p><p
79、> if((start_stop1 = '0') and (start_stop2 = '1')) then--下降沿</p><p> start_stop3 := not start_stop3;</p><p><b> end if;</b></p><p> if((recordbutt
80、on1 = '1') and (recordbutton2 = '0')) then</p><p> recordbutton3 := '1';</p><p><b> else</b></p><p> recordbutton3 := '0';</p>
81、<p><b> end if;</b></p><p> time_sel <= key1;</p><p> transfer <= mode;</p><p> record_sel <= key2;</p><p><b> end if;</b><
82、;/p><p><b> end if;</b></p><p> en_counter <= start_stop3;</p><p> en_recorder <= recordbutton3;</p><p> end process;</p><p> end Behav
83、ioral;</p><p><b> RTL原理圖為</b></p><p> 圖5.2.1 button RTL原理圖</p><p> button的測(cè)試模塊button_tb代碼為:</p><p> LIBRARY ieee;</p><p> USE ieee.std_log
84、ic_1164.ALL;</p><p> ENTITY button_tb IS</p><p> END button_tb;</p><p> ARCHITECTURE behavior OF button_tb IS </p><p> -- Component Declaration for the Unit Under T
85、est (UUT)</p><p> COMPONENT button</p><p><b> PORT(</b></p><p> clk : IN std_logic;</p><p> rst_n : IN std_logic;</p><p> start_stop : I
86、N std_logic;</p><p> record_button : IN std_logic;</p><p> key1 : IN std_logic_vector(1 downto 0);</p><p> mode : IN std_logic;</p><p> key2 : IN std_logic_vec
87、tor(1 downto 0);</p><p> time_sel : OUT std_logic_vector(1 downto 0);</p><p> en_counter : OUT std_logic;</p><p> en_recorder : OUT std_logic;</p><p> transfer :
88、 OUT std_logic;</p><p> record_sel : OUT std_logic_vector(1 downto 0)</p><p><b> );</b></p><p> END COMPONENT;</p><p><b> --Inputs</b><
89、/p><p> signal clk : std_logic := '0';</p><p> signal rst_n : std_logic := '0';</p><p> signal start_stop : std_logic := '0';</p><p> signal re
90、cord_button : std_logic := '0';</p><p> signal key1 : std_logic_vector(1 downto 0) := (others => '0');</p><p> signal mode : std_logic := '0';</p><p>
91、signal key2 : std_logic_vector(1 downto 0) := (others => '0');</p><p><b> --Outputs</b></p><p> signal time_sel : std_logic_vector(1 downto 0);</p><p> sig
92、nal en_counter : std_logic;</p><p> signal en_recorder : std_logic;</p><p> signal transfer : std_logic;</p><p> signal record_sel : std_logic_vector(1 downto 0);</p><
93、p> -- Clock period definitions</p><p> constant clk_period : time := 10 ns;</p><p><b> BEGIN</b></p><p> -- Instantiate the Unit Under Test (UUT)</p><p
94、> uut: button PORT MAP (</p><p> clk => clk,</p><p> rst_n => rst_n,</p><p> start_stop => start_stop,</p><p> record_button => record_button,</p
95、><p> key1 => key1,</p><p> mode => mode,</p><p> key2 => key2,</p><p> time_sel => time_sel,</p><p> en_counter => en_counter,</p>
96、<p> en_recorder => en_recorder,</p><p> transfer => transfer,</p><p> record_sel => record_sel</p><p><b> );</b></p><p> -- Clock proce
97、ss definitions</p><p> clk_process :process</p><p><b> begin</b></p><p> clk <= '0';</p><p> wait for clk_period/2;</p><p> clk
98、 <= '1';</p><p> wait for clk_period/2;</p><p> end process;</p><p> -- Stimulus process</p><p> stim_proc1: process</p><p><b> begin
99、</b></p><p> -- hold reset state for 100 ns.</p><p> rst_n <= '1';</p><p> start_stop <= '0';</p><p> record_button <= '0';
100、</p><p> wait for 30 ns;</p><p> start_stop <= '1';</p><p> wait for 30 ns;</p><p> start_stop <= '0';</p><p> wait for 100 ns;&
101、lt;/p><p> record_button <= '1';</p><p> wait for 30 ns;</p><p> record_button <= '0';</p><p> wait for 100 ns;</p><p> start_stop
102、<= '1';</p><p> wait for 30 ns;</p><p> start_stop <= '0';</p><p> -- insert stimulus here </p><p><b> wait;</b></p><p&
103、gt; end process;</p><p> stim_proc2: process</p><p><b> begin</b></p><p> -- hold reset state for 100 ns.</p><p> key1 <= "00";</p>
104、;<p> mode <= '0';</p><p> key2 <= "10";</p><p> wait for 50 ns;</p><p> key1 <= "01";</p><p> mode <= not mode;<
105、/p><p> key2 <= "11";</p><p> wait for 50 ns;</p><p> key1 <= "10";</p><p> mode <= not mode;</p><p> key2 <= "00&qu
106、ot;;</p><p> wait for 50 ns;</p><p> key1 <= "11";</p><p> mode <= not mode;</p><p> key2 <= "01";</p><p> wait for 50 ns
107、;</p><p> key1 <= "00";</p><p> mode <= not mode;</p><p> key2 <= "10";</p><p> wait for 50 ns;</p><p> key1 <= "
108、00";</p><p> mode <= not mode;</p><p> key2 <= "11";</p><p> -- insert stimulus here </p><p><b> wait;</b></p><p> en
109、d process;</p><p><b> END;</b></p><p><b> 仿真結(jié)果為</b></p><p> 圖5.2.2 button仿真結(jié)果</p><p> 由圖5.2.2分析,當(dāng)start_stop按鍵按下,然后松開之后的下一個(gè)時(shí)鐘沿到來時(shí),en_counter就
110、取反,從而控制counter模塊的計(jì)數(shù);而每按下record_button之后,en_recordeer就會(huì)產(chǎn)生一個(gè)脈沖,給recorder模塊一個(gè)記錄的信號(hào);其余的都是緩存作用,transfer對(duì)應(yīng)mode撥動(dòng)開關(guān)的輸入,time_sel對(duì)應(yīng)key1撥動(dòng)開關(guān)的輸入,recorder_sel對(duì)應(yīng)key2的輸入。</p><p> 計(jì)數(shù)counter模塊</p><p> 此模塊是用來計(jì)
111、數(shù)時(shí)間的,可輸出天、時(shí)、分、秒、百分秒,可由en來開始/暫停計(jì)數(shù)。</p><p><b> VHDL代碼為:</b></p><p> library IEEE;</p><p> use IEEE.STD_LOGIC_1164.ALL;</p><p> entity counter is</p>
112、<p><b> port(</b></p><p> clk : in std_logic;--100hz</p><p> rst_n : in std_logic;</p><p> en : in std_logic;--開始/暫停計(jì)數(shù)</p><p> dayten : out
113、 integer range 0 to 3;--天數(shù)十位</p><p> dayge : out integer range 0 to 9;--天數(shù)個(gè)位</p><p> hourten : out integer range 0 to 2;--小時(shí)十位</p><p> hourge : out integer range 0 to 9;--小時(shí)個(gè)
114、位</p><p> minten :out integer range 0 to 5;--分鐘十位</p><p> minge :out integer range 0 to 9;--分鐘個(gè)位</p><p> secten :out integer range 0 to 5;--秒十位</p><p> secge
115、:out integer range 0 to 9;--秒個(gè)位</p><p> msecten : out integer range 0 to 9;--為100ms</p><p> msecge : out integer range 0 to 9--為10ms</p><p><b> );</b></p>
116、<p> end counter;</p><p> architecture Behavioral of counter is</p><p><b> begin</b></p><p> process(clk,rst_n,en)</p><p> variable vdayten : inte
117、ger range 0 to 3 := 3;</p><p> variable vdayge : integer range 0 to 10 := 10;</p><p> variable vhourten : integer range 0 to 3 := 3;</p><p> variable vhourge : integer range 0 to
118、 10 := 10;</p><p> variable vminten : integer range 0 to 6 := 6;</p><p> variable vminge : integer range 0 to 10 := 10;</p><p> variable vsecten : integer range 0 to 6 := 6;</
119、p><p> variable vsecge : integer range 0 to 10 := 10;</p><p> variable vmsecten : integer range 0 to 10 := 10;</p><p> variable vmsecge : integer range 0 to 10 := 10;</p><
120、;p><b> begin</b></p><p> if(rst_n = '0') then</p><p> vdayten := 3;</p><p> vdayge := 10;</p><p> vhourten := 3;</p><p> vhour
121、ge := 10;</p><p> vminten := 6;</p><p> vminge := 10;</p><p> vsecten := 6;</p><p> vsecge := 10;</p><p> vmsecten := 10;</p><p> vmsecg
122、e := 10;</p><p><b> else </b></p><p> if(en = '1') then</p><p> if(clk' event and clk = '1') then</p><p> vmsecge := vmsecge - 1;<
123、;/p><p> if(vmsecge = 0) then</p><p> vmsecge := 10;</p><p> vmsecten := vmsecten - 1;</p><p> if(vmsecten = 0) then</p><p> vmsecten := 10;</p>&
124、lt;p> vsecge := vsecge - 1;</p><p> if(vsecge = 0) then</p><p> vsecge := 10;</p><p> vsecten := vsecten - 1;</p><p> if(vsecten = 0) then</p><p>
125、 vsecten := 6;</p><p> vminge := vminge - 1;</p><p> if((vminge = 0)) then</p><p> vminge := 10;</p><p> vminten := vminten - 1;</p><p> if(vminten =
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 數(shù)字電子技術(shù)課程設(shè)計(jì)(數(shù)字秒表)
- 數(shù)字電子技術(shù)課程設(shè)計(jì)(數(shù)字秒表)
- 電子技術(shù)課程設(shè)計(jì)報(bào)告--數(shù)字電子秒表設(shè)計(jì)
- 數(shù)字電子技術(shù)課程設(shè)計(jì)--電子秒表的設(shè)計(jì)
- 數(shù)字電子技術(shù)課程設(shè)計(jì)--電子秒表的設(shè)計(jì)
- 數(shù)字秒表課程設(shè)計(jì)
- 數(shù)字秒表課程設(shè)計(jì)
- 數(shù)字秒表課程設(shè)計(jì)
- 課程設(shè)計(jì)--數(shù)字秒表設(shè)計(jì)
- 數(shù)字秒表課程設(shè)計(jì)
- 課程設(shè)計(jì)-- 數(shù)字秒表
- 課程設(shè)計(jì)---數(shù)字秒表設(shè)計(jì)
- 電子技術(shù)課程設(shè)計(jì) --電子秒表
- 單片機(jī)技術(shù)課程設(shè)計(jì)--電子秒表設(shè)計(jì)
- 微機(jī)原理與接口技術(shù)課程設(shè)計(jì)-數(shù)字式秒表
- eda課程設(shè)計(jì)--數(shù)字秒表設(shè)計(jì)
- 課程設(shè)計(jì)報(bào)告---數(shù)字秒表設(shè)計(jì)
- eda課程設(shè)計(jì)--數(shù)字秒表設(shè)計(jì)
- 數(shù)字秒表課程設(shè)計(jì)報(bào)告
- 簡(jiǎn)易數(shù)字秒表課程設(shè)計(jì)
評(píng)論
0/150
提交評(píng)論