版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認(rèn)領(lǐng)
文檔簡介
1、<p> 微機原理課程設(shè)計報告</p><p> 摘要 由于微電子學(xué)和計算機科學(xué)的迅速發(fā)展,給EDA(電子設(shè)計自動化)行業(yè)帶來了巨大的變化。特別是進入20世紀(jì)90年代后,電子系統(tǒng)已經(jīng)從電路板級系統(tǒng)集成發(fā)展成為包括ASIC、FPGA/CPLD和嵌入系統(tǒng)的多種模式。可以說EDA產(chǎn)業(yè)已經(jīng)成為電子信息類產(chǎn)品的支柱產(chǎn)業(yè)。EDA之所以能蓬
2、勃發(fā)展的關(guān)鍵因素之一就是采用了硬件描述語言(HDL)描述電路系統(tǒng)。就FPGA和CPLD開發(fā)而言,比較流行的HDL主要有Verilog HDL、VHDL、ABEL-HDL和 AHDL 等,其中VHDL和Verilog HDL因適合標(biāo)準(zhǔn)化的發(fā)展方向而最終成為IEEE標(biāo)準(zhǔn)。下面的設(shè)計就是用VHDL來完成實現(xiàn)的。</p><p><b> 關(guān)鍵詞:</b></p><p>
3、 VHDL UART </p><p><b> 正文:</b></p><p> 1.UART設(shè)計實例 通常設(shè)計數(shù)字電路大都采用自頂向下將系統(tǒng)按功能逐層分割的層次化設(shè)計方法,這比傳統(tǒng)自下向上的EDA設(shè)計方法有更明顯的優(yōu)勢(當(dāng)時的主要設(shè)計文件是電路圖)。因為由自頂向下的設(shè)計過程可以看出,從
4、總體行為設(shè)計開始到最終邏輯綜合,形成網(wǎng)絡(luò)表為止。每一步都要進行仿真檢查,這樣有利于盡早發(fā)現(xiàn)系統(tǒng)設(shè)計中存在的問題,從而可以大大縮短系統(tǒng)硬件的設(shè)計周期。 UART(即Universal Asynchronous Receiver Transmitter 通用異步收發(fā)器)是一種應(yīng)用廣泛的短距離串行傳輸接口。UART允許在串行鏈路上進行全雙工的通信。串行外設(shè)用
5、到的RS232-C異步串行接口,一般采用專用的集成電路即UART實現(xiàn)。如8250、8251、NS16450等芯片都是常見的UART器件,這類芯片已經(jīng)相當(dāng)復(fù)雜,有的含有許多輔助的模塊(如FIFO),有時我們不需要使用完整的UART的功能和這些輔助功能?;蛘咴O(shè)計上用到了FPGA/CPLD器件,那么我們就可以將所需要的UART功能集成到FPGA內(nèi)部。使用VHDL將UART的核心功能集成,從而使整個設(shè)計更加緊湊、穩(wěn)</p><
6、;p><b> 2.設(shè)計要求</b></p><p> 采用8位寬數(shù)據(jù)總線,16位寬地址總線;</p><p> 完整的數(shù)據(jù)收/發(fā)功能,波特率可調(diào); </p><p> 支持5-8位數(shù)據(jù)位、1-2位停止位、1位奇偶校驗位; </p><p> 一級數(shù)據(jù)緩沖,不使用FIFO;</p><
7、p> 具備奇偶校驗錯能力; </p><p><b> 支持接收數(shù)據(jù)完成。</b></p><p> 使用vhdl語言自頂向下設(shè)計,畫出各模塊結(jié)構(gòu)框圖、狀態(tài)機等,可使用modelsim仿真。</p><p> 設(shè)計的總體方案及原理</p><p><b> 3.1 基本思路</b>&
8、lt;/p><p> 根據(jù)實驗要求,我們使用VHDL語言并用modelsim進行仿真,在top層下面有接收層,發(fā)送層,分頻器,來實現(xiàn)各種波特率下面的發(fā)送與接收。分別設(shè)計相應(yīng)的testbench來檢驗正確與否,最后運行top的testbench來測試結(jié)果。</p><p><b> 3.2 設(shè)計原理</b></p><p><b>
9、UART簡述</b></p><p> UART即Universal Asynchronous Receiver Transmitter通用異步收發(fā)器,是一種應(yīng)廣泛的短距離串行傳輸接口。往往用于短距離、低速、低成本的微機與下拉機的通訊中。8250、8251、NS16450等芯片都是常見的UART器件。</p><p> “異步”指不需要額外的時鐘線進行數(shù)據(jù)的同步傳輸,是一種
10、串行總線接口,只需占用兩根線就可以完成數(shù)據(jù)的收發(fā)(一根接收數(shù)據(jù),一根發(fā)送數(shù)據(jù))。常用的傳輸率有4800bps、9600bps、19200bps和115200bps等。</p><p><b> 基本幀格式</b></p><p><b> 基本概念</b></p><p> 在信號線上有兩種狀態(tài),可分別用邏輯1和邏輯
11、0來區(qū)分。在發(fā)送空閑時,數(shù)據(jù)線應(yīng)保持在邏輯1狀態(tài);</p><p> 起始位。發(fā)送器是通過發(fā)送起始位而開始一個字符傳送,起始位使數(shù)據(jù)線處于邏輯0狀態(tài),提示接收器數(shù)據(jù)傳輸即將開始;</p><p> 數(shù)據(jù)位。起始位之后就是傳送數(shù)據(jù)位。數(shù)據(jù)位一般為一個字節(jié)的數(shù)據(jù)(也有6位、7位的情況),低位(LSB)在前,高位(MSB)在后;</p><p> 校驗位。可以認(rèn)為是
12、一個特殊的數(shù)據(jù)位。校驗位一般用來判斷接收的數(shù)據(jù)位有無錯誤,一般是奇偶校驗。 本課程設(shè)計里,UART使用1比特的奇校驗位;</p><p> 停止位。停止位在最后,用以標(biāo)志一個字符傳送的結(jié)束,它對應(yīng)于邏輯1狀態(tài);</p><p> 位時間。即每個位的時間寬度。起始位、數(shù)據(jù)位、校驗位的位寬度是一致的,停止位有0.5位、1位、1.5位格式,一般為1位;</p><p>
13、; 幀。從起始位開始到停止位結(jié)束的時間間隔稱之為一幀;</p><p> 波特率。UART的傳送速率,用于說明數(shù)據(jù)傳送的快慢。在串行通信中,數(shù)據(jù)是按位進行傳送的,因此傳送速率用每秒鐘傳送數(shù)據(jù)位的數(shù)目來表示,稱之為波特率。</p><p><b> 幀格式</b></p><p> UART的幀格式如下:</p><p
14、> UART的整個設(shè)計分為3個子模塊和一個頂層模塊:波特率發(fā)生器、發(fā)送模塊、接收模塊和一個頂層模塊。</p><p><b> 波特率發(fā)生器</b></p><p> 波特率發(fā)生器實際上就是一個簡單的分頻器。它把系統(tǒng)時鐘(clk)分頻成16倍的波特率時鐘,稱為分頻時鐘(bclk)。分頻時鐘控制了發(fā)送器和接收器的采樣速率,從而達到精準(zhǔn)采樣的目的。</p
15、><p><b> 發(fā)送器</b></p><p> 發(fā)送器要做的工作就是把CPU從數(shù)據(jù)總線上送來的8位并行數(shù)據(jù)按照波特率時鐘變?yōu)榇袛?shù)據(jù),先發(fā)1位的起始位,然后發(fā)8位的數(shù)據(jù),之后1位的奇校驗位和停止位。每1位都是發(fā)一個波特率時鐘,即16個分頻時鐘。在發(fā)送完數(shù)據(jù)后,產(chǎn)生一個發(fā)送確認(rèn)信號(命名為txd_done),當(dāng)該信號為1時表示一幀的數(shù)據(jù)發(fā)送完畢,等待下一幀數(shù)據(jù)的發(fā)
16、送。</p><p><b> 接收器</b></p><p> 接收器要做的工作就是把外部送來的串行數(shù)據(jù)按照波特率時鐘轉(zhuǎn)換成8比特的并行數(shù)據(jù),然后放在數(shù)據(jù)總線上供CPU使用。首先它要能夠檢測低電平的起始位,等待8個分頻時鐘后確認(rèn)信號是否一直保持低電平,是的話就開始每16個分頻時鐘(即一個波特率時鐘)采一次數(shù)據(jù)。接收完數(shù)據(jù)后返回奇校驗信息,并把接收完成信號(命名為
17、r_ready)置為高電平,表示一幀的數(shù)據(jù)接收完畢。</p><p><b> 頂層模塊</b></p><p> 頂層模塊把地址總線上的16位地址信號進行地址譯碼。將譯碼后的信號送往對應(yīng)的子模塊,把數(shù)據(jù)總線上的8位數(shù)據(jù)做并串轉(zhuǎn)換后輸出,或者把外部串行數(shù)據(jù)做串并轉(zhuǎn)換后送往數(shù)據(jù)總線。并且返回相應(yīng)的接收完成信號和奇校驗信號,或者返回發(fā)送完成信號。</p>
18、<p><b> UART原理圖:</b></p><p><b> 異步收發(fā)器結(jié)構(gòu)圖:</b></p><p> UART的設(shè)計與實現(xiàn)</p><p><b> 4.1 頂層設(shè)計</b></p><p> library IEEE;</p>
19、<p> use IEEE.STD_LOGIC_1164.ALL;</p><p> use IEEE.STD_LOGIC_ARITH.ALL;</p><p> use IEEE.STD_LOGIC_UNSIGNED.ALL;</p><p> ENTITY top is</p><p> Port (clk60mhz
20、,reset,rxd:in std_logic; </p><p> address,kk:in std_logic_vector(1 downto 0);</p><p> rec_ready,txd_out,txd_done_out,rec_check:out std_logic;</p><p> txdbuf_in:in std_logic_ve
21、ctor(7 downto 0); </p><p> rec_buf:out std_logic_vector(7 downto 0)); </p><p><b> end top;</b></p><p> ARCHITECTURE Behavioral of top is</p><p>
22、; component receiver</p><p> Port (bclkr,resetr,rxdr:in std_logic;</p><p> address: in std_logic_vector(1 downto 0);</p><p> r_ready,r_check:out std_logic;</p><p>
23、 rbuf:out std_logic_vector(7 downto 0));</p><p> end component;</p><p> component transmitter</p><p> Port (bclkt,resett:in std_logic;</p><p> address: in std_logic
24、_vector(1 downto 0);</p><p> txdbuf:in std_logic_vector(7 downto 0);</p><p> txd:out std_logic;</p><p> txd_done:out std_logic);</p><p> end component;</p>&
25、lt;p> component baud</p><p> Port (clk,resetb:in std_logic;</p><p><b> Top結(jié)果圖1</b></p><p><b> Top結(jié)果圖2</b></p><p> 當(dāng)reset信號為低電平時,輸入時為0101
26、0101,發(fā)送器發(fā)送的是0101010100分別是起始位低電平,由后向前的發(fā)送數(shù)據(jù)位8位,以及結(jié)尾的兩位高電平。</p><p> 4.2 UART分頻器</p><p> 波特率發(fā)生器實際上就是一個簡單的分頻器。可以根據(jù)給定的系統(tǒng)時鐘頻率(晶振時鐘)和要求的波特率算出波特率分頻因子。已算出的波特率分頻因子作為分頻器的分頻數(shù)。對于波特率發(fā)生器中的系數(shù)一般在FPGA實現(xiàn)時往往是固定的,但
27、對于不同的實現(xiàn),這個系數(shù)需要更改。波特率發(fā)生器產(chǎn)生的分頻時鐘,不是波特率時鐘,而是波特率時鐘的16倍,目的是為了在接收事實進行精確地采樣,以提出異步的串行數(shù)據(jù)。</p><p> 在VHDL實現(xiàn)的時候,設(shè)置了4個輸入端口和1個輸出端口,其中輸入端口kk用于設(shè)置所需的波特率。當(dāng)kk為00時對應(yīng)的波特率為9600bps;kk為01時對應(yīng)的波特率為19200bps;kk為10時對應(yīng)的波特率為115200bps。輸入端
28、口clk接系統(tǒng)時鐘,ben為使能端口,resetb為復(fù)位端口,低電平有效。輸出端口信號bclk即為不同波特率所對應(yīng)的分頻時鐘。這里的系統(tǒng)時鐘clk設(shè)為32MHz。</p><p> K的值依次為“00”,“01”,“10”,對應(yīng)的波特率分別為9600bps,19200bps,115200bps,由圖可知頻率越來越大,波形越來越密</p><p> library IEEE;</p
29、><p> use IEEE.STD_LOGIC_1164.ALL;</p><p> use IEEE.STD_LOGIC_ARITH.ALL;</p><p> use IEEE.STD_LOGIC_UNSIGNED.ALL;</p><p> ENTITY baud is</p><p> Port (cl
30、k,resetb:in std_logic;</p><p> k:in std_logic_vector(1 downto 0);</p><p> bclk:out std_logic);</p><p><b> end baud;</b></p><p> ARCHITECTURE behavioral
31、of baud is</p><p><b> begin</b></p><p> process(clk,resetb,k)</p><p> variable cnt:std_logic_vector(8 downto 0):="000000000";</p><p> variable
32、 clock:std_logic:='0';</p><p><b> begin</b></p><p> if resetb='1' then </p><p> cnt:="000000000"; bclk
33、<='0'; clock:='0';</p><p> elsif rising_edge(clk) then</p><p> if k="00" then</p><p> if cnt="110000110"then cnt:="000000000"; bc
34、lk<=not clock; </p><p> elsif cnt>="011000011"</p><p> then cnt:=cnt+'1'; bclk<= not clock;</p><p> else cnt:=cnt+'1'; bclk<=clock;</p&g
35、t;<p><b> end if; </b></p><p> elsif k="01" then</p><p> if cnt="011000011"then cnt:="000000000"; bclk<=not clock; </p><p>
36、elsif cnt>="01100010"</p><p> then cnt:=cnt+'1'; bclk<= not clock;</p><p> else cnt:=cnt+'1'; bclk<=clock;</p><p><b> end if; </b>&
37、lt;/p><p> elsif k="10" then</p><p> if cnt="00100000"then cnt:="000000000"; bclk<=not clock; </p><p> elsif cnt>="00010000"</p>
38、;<p> then cnt:=cnt+'1'; bclk<= not clock;</p><p> else cnt:=cnt+'1'; bclk<=clock;</p><p><b> end if; </b></p><p><b> end if;</
39、b></p><p><b> end if;</b></p><p> end process;</p><p> end behavioral;</p><p> 4.3 UART發(fā)送器</p><p> UART發(fā)送模塊的功能:接收到發(fā)送指令后,把數(shù)據(jù)按UART協(xié)議輸出,先輸
40、出一個低電平的起始位,然后從低到高輸出8個數(shù)據(jù)位,接著是可選的奇偶校驗位,最后是高電平的停止位。Testbench中實現(xiàn)了11010101的發(fā)送發(fā)送圖形,發(fā)送的數(shù)據(jù)幀為“0 11010101 1 1”采用偶校驗方式,校驗位應(yīng)該為1,由圖可知校驗位為1</p><p> library IEEE;</p><p> use IEEE.STD_LOGIC_1164.ALL;</p&g
41、t;<p> use IEEE.STD_LOGIC_ARITH.ALL;</p><p> use IEEE.STD_LOGIC_UNSIGNED.ALL;</p><p> ENTITY receiver is</p><p> generic(framlenr:integer:=9); </p><p&
42、gt; Port (bclkr,resetr,rxdr:in std_logic; </p><p> address: in std_logic_vector(1 downto 0);</p><p> r_ready:out std_logic;</p><p> rbuf:out std_logic_vector(7 downto 0);<
43、;/p><p> r_check:out std_logic:='0');</p><p> end receiver;</p><p> ARCHITECTURE Behavioral of receiver is</p><p> type states is (r_start,r_center,r_wait,r_sa
44、mple,r_stop); </p><p> signal state:states:=r_start;</p><p> signal rxd_sync:std_logic;</p><p><b> begin</b></p><p> pro1:process(rxdr)</p>
45、<p><b> begin</b></p><p> if rxdr='0' then rxd_sync<='0';</p><p> else rxd_sync<='1';</p><p><b> end if;</b></p>
46、;<p> end process;</p><p> pro2:process(bclkr,resetr,rxd_sync,address) </p><p> variable count:std_logic_vector(3 downto 0); </p><
47、;p> variable rcnt:integer:=0;</p><p> variable rbufs:std_logic_vector(8 downto 0);</p><p> variable aaa: std_logic;</p><p><b> begin</b></p><p> if
48、resetr='1' then state<=r_start; count:="0000"; </p><p> elsif rising_edge(bclkr) then</p><p> case state is</p><p> when r_start=>
49、 </p><p> if rxd_sync='0' </p><p> then state<=r_center; r_ready<='0'; rcnt:=0;</p><p> else state<=r_start; r_ready<='
50、0'; r_check<='0';</p><p> end if; </p><p> when r_center=> </p><p> if rxd_sync='0' </p><p> th
51、en if count="1000"</p><p> then state<=r_wait; count:="0000";</p><p> else count:=count+1; state<=r_center;</p><p><b> end if;</b></p>
52、<p> else state<=r_start;</p><p> end if; </p><p> when r_wait=> </p><p> if count>="1110" then</p>
53、<p> if rcnt=framlenr then state<=r_stop; </p><p> else state<=r_sample;</p><p><b> end if;</b></p><p> count:="0000"; </p&
54、gt;<p> else count:=count+1; state<=r_wait;</p><p><b> end if;</b></p><p> when r_sample=></p><p> rbufs(rcnt):=rxd_sync;</p><p> rcnt:=rc
55、nt+1;state<=r_wait; </p><p> when r_stop=></p><p> r_ready<='1'; </p><p> aaa:=rbufs(0) xor rbufs(1) xor rbufs(2) </p><p> xor rbufs(3) xor
56、 rbufs(4) xor rbufs(5) </p><p> xor rbufs(6) xor rbufs(7)xor rbufs(8);</p><p> if aaa='0'</p><p> then r_check<='0';</p><p> else r_check<=
57、9;1';</p><p><b> end if; </b></p><p> if address="01"</p><p> then rbuf<=rbufs(7 downto 0); </p><p> state<=r_start; </p>&l
58、t;p> else rbuf<="00000000"; </p><p> state<=r_stop;</p><p><b> end if;</b></p><p> when others=>state<=r_start;</p><p><b>
59、; end case;</b></p><p><b> end if;</b></p><p> end process;</p><p> end Behavioral;</p><p> 4.4UART接收器</p><p> UART接收模塊的功能:時時檢測線路,當(dāng)
60、線路產(chǎn)生下降沿時,即認(rèn)為線路有數(shù)據(jù)傳輸,啟動接收數(shù)據(jù)進程進行接收,按從低位到高位接收數(shù)據(jù)。根據(jù)Testbench中接收到的波形可知接受結(jié)果正確。奇偶校驗采用偶校驗方式,由圖觀察可知,第一串?dāng)?shù)據(jù)有四個1,所以校驗位為0,觀察波形校驗位為0,正確所以r_check=0;第二串?dāng)?shù)據(jù)有五個1,所以校驗位為1,觀察波形校驗位為1,錯誤所以r_check=1;第三串?dāng)?shù)據(jù)分析同上。</p><p> library IEEE
61、;</p><p> use IEEE.STD_LOGIC_1164.ALL;</p><p> use IEEE.STD_LOGIC_ARITH.ALL;</p><p> use IEEE.STD_LOGIC_UNSIGNED.ALL;</p><p> ENTITY receiver is</p><p>
62、; generic(framlenr:integer:=9); </p><p> Port (bclkr,resetr,rxdr:in std_logic; </p><p> r_ready:out std_logic;</p><p> rbuf:out std_logic_vector(7 downto 0);</p&
63、gt;<p> r_check:out std_logic:='0');</p><p> end receiver;</p><p> ARCHITECTURE Behavioral of receiver is</p><p> type states is (r_start,r_center,r_wait,r_sample
64、,r_stop); </p><p> signal state:states:=r_start;</p><p> signal rxd_sync:std_logic;</p><p><b> begin</b></p><p> pro1:process(rxdr)</p>
65、<p><b> begin</b></p><p> if rxdr='0' then rxd_sync<='0';</p><p> else rxd_sync<='1';</p><p><b> end if;</b></p&g
66、t;<p> end process;</p><p> pro2:process(bclkr,resetr,rxd_sync) </p><p> variable count:std_logic_vector(3 downto 0); </p><p>
67、 variable rcnt:integer:=0;</p><p> variable rbufs:std_logic_vector(8 downto 0);</p><p> variable aaa: std_logic;</p><p><b> begin</b></p><p> if resetr
68、='1'</p><p> then state<=r_start; count:="0000"; </p><p> elsif rising_edge(bclkr)</p><p> then case state is</p><p> when r_star
69、t=> </p><p> if rxd_sync='0' </p><p> then state<=r_center;</p><p> r_ready<='0'; rcnt:=0;</p><p> else
70、 state<=r_start; </p><p> r_ready<='0'; r_check<='0';</p><p> end if; </p><p> when r_center=> </p>&l
71、t;p> if rxd_sync='0' </p><p> then if count="1000"</p><p> then state<=r_wait; count:="0000";</p><p> else count:=count+1; state<=r_center;&
72、lt;/p><p><b> end if;</b></p><p> else state<=r_start;</p><p> end if; </p><p> when r_wait=> </p&g
73、t;<p> if count>="1110" then</p><p> if rcnt=framlenr then state<=r_stop; </p><p> else state<=r_sample;</p><p><b> end if;</b></p>
74、<p> count:="0000"; </p><p> else count:=count+1; state<=r_wait;</p><p><b> end if;</b></p><p> when r_sample=></p><
75、;p> rbufs(rcnt):=rxd_sync; </p><p> rcnt:=rcnt+1;state<=r_wait; </p><p> when r_stop=></p><p> r_ready<='1'; rbuf<=rbufs(7 downto 0);</p>&
76、lt;p> aaa:=rbufs(0) xor rbufs(1) xor rbufs(2)</p><p> xor rbufs(3) xor rbufs(4) xor rbufs(5)</p><p> xor rbufs(6) xor rbufs(7)xor rbufs(8);</p><p> if aaa='0'</p&g
77、t;<p> then r_check<='0';</p><p> else r_check<='1';</p><p><b> end if; </b></p><p> state<=r_start; </p><p> when oth
78、ers=>state<=r_start;</p><p><b> end case;</b></p><p><b> end if;</b></p><p> end process;</p><p> end Behavioral;</p><p>
79、<b> 5 總結(jié)與心得體會</b></p><p> 本設(shè)計由于采用了VHDL語言作為輸入方式并結(jié)合FPGA/CPLD,大大縮短了設(shè)計周期,提高了設(shè)計的可靠性、靈活性,使用戶可根據(jù)自己的需求,方便、高效地設(shè)計出適合的串行接口電路。用FPGA 來對UART接口進行開發(fā),可以減小系統(tǒng)的PCB面積,降低系統(tǒng)的功耗,提高設(shè)計的穩(wěn)定性和可靠性,并可以充分利用了FPGA 的剩余資源。該設(shè)計具有很大
80、的靈活性,雖然這一UART接口工作在每秒9600波特,但通過調(diào)整鎖相環(huán)的參數(shù),就可以使其工作在其他頻率,十分方便。這僅僅是一個簡單的通信接口,可根據(jù)不同系統(tǒng)的需要,增加FIFO等內(nèi)容。該模塊也可以作為一個完整的IP核,靈活地移植進各種型號的FPGA中,通用性很強。 </p><p> 通過此次課程設(shè)計,使我更加扎實的掌握了有關(guān)的知識,在設(shè)計過程中雖然遇到了一些問題,但經(jīng)過一次又一次的思考,一遍又一遍的檢查
81、終于找出了原因所在,也暴露出了前期我在這方面的知識欠缺和經(jīng)驗不足。實踐出真知,通過親自動手制作,使我們掌握的知識不再是紙上談兵。</p><p> 過而能改,善莫大焉。在課程設(shè)計過程中,我們不斷發(fā)現(xiàn)錯誤,不斷改正,不斷領(lǐng)悟,不斷獲取,最終的檢測調(diào)試環(huán)節(jié),本身就是在踐行“過而能改,善莫大焉”的知行觀。這次課程設(shè)計終于順利完成了,在設(shè)計中遇到了很多問題,最后我們大家的不懈努力下,終于游逆而解。在今后社會的發(fā)展和學(xué)習(xí)
82、實踐過程中,一定要不懈努力,不能遇到問題就想到要退縮,一定要不厭其煩的發(fā)現(xiàn)問題所在,然后一一進行解決,只有這樣,才能成功的做成想做的事,才能在今后的道路上劈荊斬棘,而不是知難而退,那樣永遠不可能收獲成功,收獲喜悅,也永遠不可能得到社會及他人對你的認(rèn)可!</p><p> 回顧起此課程設(shè)計,至今我仍感慨頗多,從理論到實踐,在這段日子里,可以說得是苦多于甜,但是可以學(xué)到很多很多的東西,同時不僅可以鞏固了以前所學(xué)過的
83、知識,而且學(xué)到了很多在書本上所沒有學(xué)到過的知識。通過這次課程設(shè)計使我懂得了理論與實際相結(jié)合是很重要的,只有理論知識是遠遠不夠的,只有把所學(xué)的理論知識與實踐相結(jié)合起來,從理論中得出結(jié)論,才能真正為社會服務(wù),從而提高自己的實際動手能力和獨立思考的能力。在設(shè)計的過程中遇到問題,可以說得是困難重重,但可喜的是最終都得到了解決。</p><p> 實驗過程中,也對團隊精神的進行了考察,讓我們在合作起來更加默契,在成功后一
84、起體會喜悅的心情。果然是團結(jié)就是力量,只有互相之間默契融洽的配合才能換來最終完美的結(jié)果。</p><p> 此次設(shè)計也讓我明白了思路即出路,有什么不懂不明白的地方要及時請教或上網(wǎng)查詢,只要認(rèn)真鉆研,動腦思考,動手實踐,就沒有弄不懂的知識,收獲頗豐。</p><p><b> 6 參考資料</b></p><p> VHDL數(shù)字電路設(shè)計教程
溫馨提示
- 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. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 微機原理課程設(shè)計報告
- 微機原理課程設(shè)計報告
- 《微機原理》課程設(shè)計報告
- 微機原理課程設(shè)計報告
- 微機原理課程設(shè)計報告21
- 微機原理課程設(shè)計報告--秒表設(shè)計
- 微機原理課程設(shè)計
- 微機原理課程設(shè)計報告(電子秒表)
- 微機原理課程設(shè)計報告交通燈
- 微機原理課程設(shè)計報告-雙機串行通信
- 微機原理課程設(shè)計報告--小鳥動畫程序
- 微機原理課程設(shè)計報告---紅綠燈
- 微機原理數(shù)字鐘課程設(shè)計報告
- 微機原理課程設(shè)計.rar
- 2017微機原理課程設(shè)計
- 微機原理課程設(shè)計---溫度采集系統(tǒng)報告
- 微機原理課程設(shè)計.rar
- 微機原理課程設(shè)計.rar
- 微機原理課程設(shè)計.rar
- 微機原理課程設(shè)計報告--步進電機設(shè)計
評論
0/150
提交評論