基于vhdl語言串口控制器課程設(shè)計(jì)_第1頁
已閱讀1頁,還剩39頁未讀 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡介

1、<p><b>  EDA</b></p><p><b>  課程設(shè)計(jì)</b></p><p>  題目:串口控制器設(shè)計(jì) </p><p>  班級(jí): </p><p>  姓名: </p><p&

2、gt;  學(xué)號(hào): </p><p><b>  一:串口簡介</b></p><p>  串口是可以在使用一根線發(fā)送數(shù)據(jù)的同時(shí)用另一根線接收數(shù)據(jù)。串口通信協(xié)議也可以用于獲取遠(yuǎn)程采集設(shè)備的數(shù)據(jù)。通過RS-232以實(shí)現(xiàn)計(jì)算機(jī)之間、計(jì)算機(jī)與設(shè)備之間相互通信,目前仍是通訊領(lǐng)域廣泛使用的方法之一。幾乎每臺(tái)計(jì)算機(jī)都有一兩個(gè)串行接口,用來與調(diào)制解調(diào)

3、器、實(shí)驗(yàn)室設(shè)備、工控設(shè)備、POS終端等進(jìn)行數(shù)據(jù)傳輸。RS-232以其方便、經(jīng)濟(jì)的實(shí)現(xiàn)特點(diǎn),一直深受工程界的青睞。不論是在電力、工控還是電信、金融交通等諸多行業(yè)都有廣泛的應(yīng)用。</p><p>  系統(tǒng)主芯片采用RS-232串口通信控制器,由基本時(shí)鐘發(fā)生電路模塊,復(fù)位電路模塊,波特率選擇模塊,數(shù)據(jù)幀格式選擇模塊,串并轉(zhuǎn)換模塊組成。經(jīng)編譯和仿真所設(shè)計(jì)的程序,在可編程邏輯器件上下載驗(yàn)證,結(jié)合FPGA技術(shù)高度靈活性與模塊

4、化的特點(diǎn),實(shí)現(xiàn)基本RS-232總線通信的功能,以實(shí)現(xiàn)串口數(shù)據(jù)幀結(jié)構(gòu)選擇,串并轉(zhuǎn)換,波特率選擇等功能。通過軟件仿真,得到功能的驗(yàn)證,并進(jìn)行功能邏輯模塊的整合,從而驗(yàn)證設(shè)計(jì)的可行性與可靠性。</p><p>  本模塊的功能是驗(yàn)證實(shí)現(xiàn)和PC機(jī)進(jìn)行基本的串口通信的功能。需要在PC機(jī)上安裝一個(gè)串口調(diào)試工具來驗(yàn)證程序的功能。程序?qū)崿F(xiàn)了一個(gè)收發(fā)一幀10個(gè)bit(即無奇偶校驗(yàn)位)的串口控制器,10個(gè)bit是1位起始位,8個(gè)數(shù)據(jù)

5、位,1個(gè)結(jié)束位。串口的波特率由程序中定義的div_par參數(shù)決定,更改該參數(shù)可以實(shí)現(xiàn)相應(yīng)的波特率。程序當(dāng)前設(shè)定的div_par 的值是0x104,對(duì)應(yīng)的波特率是9600。用一個(gè)8倍波特率的時(shí)鐘將發(fā)送或接受每一位bit的周期時(shí)間劃分為8個(gè)時(shí)隙以使通信同步.程序的工作過程是:串口處于全雙工工作狀態(tài),按動(dòng)SW0,F(xiàn)PGA向PC發(fā)送“welcome"字符串(串口調(diào)試工具設(shè)成按ASCII碼接受方式);PC可隨時(shí)向FPGA發(fā)送0-F的十六

6、進(jìn)制數(shù)據(jù),F(xiàn)PGA接受后顯示在7段數(shù)碼管上。</p><p><b>  二:設(shè)計(jì)方案。</b></p><p><b>  1:接收模塊設(shè)計(jì)</b></p><p>  串口接收模塊針對(duì)于接收串行數(shù)據(jù)進(jìn)行協(xié)議包的解析,實(shí)現(xiàn)串行數(shù)據(jù)輸入,并行數(shù)據(jù)輸出的功能,從接收判斷的角度,實(shí)現(xiàn)了對(duì)于串口協(xié)議的解析功能。</p>

7、;<p><b>  2: 發(fā)送模塊設(shè)計(jì)</b></p><p>  串口發(fā)送模塊針對(duì)于接收并行數(shù)據(jù)進(jìn)行協(xié)議的組包設(shè)計(jì),實(shí)現(xiàn)并行數(shù)據(jù)輸入,串行數(shù)據(jù)輸出的功能,從發(fā)送的角度,實(shí)現(xiàn)了對(duì)于串口協(xié)議的組合功能。發(fā)送模塊設(shè)計(jì)與接收模塊類似,依然針對(duì)波特率,數(shù)據(jù)位,校驗(yàn)位,停止位進(jìn)行控制,實(shí)現(xiàn)全雙向的串口通信控制功能。</p><p><b>  三:電路

8、原理圖</b></p><p><b>  四:軟件流程</b></p><p><b>  五:實(shí)驗(yàn)源程序</b></p><p>  library IEEE;</p><p>  use IEEE.STD_LOGIC_1164.ALL;</p><p>  

9、use IEEE.STD_LOGIC_ARITH.ALL;</p><p>  use IEEE.STD_LOGIC_UNSIGNED.ALL; </p><p>  ENTITY UART IS</p><p><b>  PORT (</b></p><p>  clk : IN std_logic; &l

10、t;/p><p>  rst : IN std_logic; </p><p>  rxd : IN std_logic; </p><p>  txd : OUT std_logic; </p><p>  en : OUT std_logic_vector(7 downto 0); </p>&

11、lt;p>  seg_data : OUT std_logic_vector(7 DOWNTO 0); </p><p>  key_input : IN std_logic </p><p><b>  ); </b></p><p><b>  END UART;</b></p>

12、<p>  ARCHITECTURE arch OF UART IS</p><p>  -- //////////////////inner reg////////////////////</p><p>  SIGNAL div_reg : std_logic_vector(15 DOWNTO 0); </p><p>  SIGN

13、AL div8_tras_reg : std_logic_vector(2 DOWNTO 0); </p><p>  SIGNAL div8_rec_reg : std_logic_vector(2 DOWNTO 0); </p><p>  SIGNAL state_tras : std_logic_vector(3 DOWNTO 0); </p>

14、;<p>  SIGNAL state_rec : std_logic_vector(3 DOWNTO 0); </p><p>  SIGNAL clkbaud_tras : std_logic; </p><p>  SIGNAL clkbaud_rec : std_logic; </p><p>  SIGN

15、AL clkbaud8x : std_logic; </p><p>  SIGNAL recstart : std_logic; </p><p>  SIGNAL recstart_tmp : std_logic; </p><p>  SIGNAL trasstart : st

16、d_logic; </p><p>  SIGNAL rxd_reg1 : std_logic; </p><p>  SIGNAL rxd_reg2 : std_logic; </p><p>  SIGNAL txd_reg : std_logic; </p><p&g

17、t;  SIGNAL rxd_buf : std_logic_vector(7 DOWNTO 0); </p><p>  SIGNAL txd_buf : std_logic_vector(7 DOWNTO 0); </p><p>  SIGNAL send_state : std_logic_vector(2 DOWNTO 0);-

18、</p><p>  SIGNAL cnt_delay : std_logic_vector(19 DOWNTO 0);- </p><p>  SIGNAL start_delaycnt : std_logic; </p><p>  SIGNAL key_entry1 : std_logic; </p>

19、<p>  SIGNAL key_entry2 : std_logic; </p><p>  --//////////////////////////////////////////////</p><p>  CONSTANT div_par : std_logic_vector(15 DOWNTO 0) := "00000001

20、00000100"; </p><p>  SIGNAL txd_xhdl3 : std_logic; </p><p><b>  BEGIN</b></p><p>  en <="01010101" ;- </p><p>  txd

21、 <= txd_xhdl3; </p><p>  txd_xhdl3 <= txd_reg ;</p><p>  PROCESS(clk,rst)</p><p><b>  BEGIN</b></p><p>  IF (NOT rst = ’1’) THEN</p><p>

22、;  cnt_delay <= "00000000000000000000"; </p><p>  start_delaycnt <= ’0’; </p><p>  ELSIF(clk’EVENT AND clk=’1’)THEN</p><p>  IF (start_delaycnt = ’1’) THEN<

23、/p><p>  IF (cnt_delay /= "11000011010100000000") THEN</p><p>  cnt_delay <= cnt_delay + "00000000000000000001"; </p><p><b>  ELSE</b></p>

24、<p>  cnt_delay <= "00000000000000000000"; </p><p>  start_delaycnt <= ’0’; </p><p><b>  END IF;</b></p><p><b>  ELSE</b></p>

25、;<p>  IF ((NOT key_input=’1’) AND (cnt_delay = "00000000000000000000")) THEN</p><p>  start_delaycnt <= ’1’; </p><p><b>  END IF;</b></p><p><

26、b>  END IF;</b></p><p><b>  END IF;</b></p><p>  END PROCESS;</p><p>  PROCESS(clk,rst)</p><p><b>  BEGIN</b></p><p>  IF

27、(NOT rst = ’1’) THEN</p><p>  key_entry1 <= ’0’; </p><p>  ELSIF(clk’EVENT AND clk=’1’)THEN</p><p>  IF (key_entry2 = ’1’) THEN</p><p>  key_entry1 <= ’0’;

28、</p><p><b>  ELSE</b></p><p>  IF (cnt_delay = "11000011010100000000") THEN</p><p>  IF (NOT key_input = ’1’) THEN</p><p>  key_entry1 <= ’1’;

29、 </p><p><b>  END IF;</b></p><p><b>  END IF;</b></p><p><b>  END IF;</b></p><p><b>  END IF;</b></p><p>

30、  END PROCESS;</p><p>  PROCESS(clk,rst)</p><p><b>  BEGIN</b></p><p>  IF (NOT rst = ’1’) THEN</p><p>  div_reg <= "0000000000000000"; <

31、/p><p>  ELSIF(clk’EVENT AND clk=’1’)THEN</p><p>  IF (div_reg = div_par - "0000000000000001") THEN</p><p>  div_reg <= "0000000000000000"; </p><p&

32、gt;<b>  ELSE</b></p><p>  div_reg <= div_reg + "0000000000000001"; </p><p><b>  END IF;</b></p><p><b>  END IF;</b></p>&l

33、t;p>  END PROCESS;</p><p>  PROCESS(clk,rst) </p><p><b>  BEGIN</b></p><p>  IF (NOT rst = ’1’) THEN</p><p>  clkbaud8x <= ’0’; </p><p&g

34、t;  ELSIF(clk’EVENT AND clk=’1’)THEN</p><p>  IF (div_reg = div_par - "0000000000000001") THEN</p><p>  clkbaud8x <= NOT clkbaud8x; </p><p><b>  END IF;</b&

35、gt;</p><p><b>  END IF;</b></p><p>  END PROCESS;</p><p>  PROCESS(clkbaud8x,rst)</p><p><b>  BEGIN</b></p><p>  IF (NOT rst = ’1’)

36、 THEN</p><p>  div8_rec_reg <= "000"; </p><p>  ELSE IF(clkbaud8x’EVENT AND clkbaud8x = ’1’) THEN</p><p>  IF (recstart = ’1’) THEN </p><p>  div8_rec

37、_reg <= div8_rec_reg + "001"; </p><p><b>  END IF;</b></p><p><b>  END IF;</b></p><p><b>  END IF;</b></p><p>  END

38、PROCESS;</p><p>  PROCESS(clkbaud8x,rst)</p><p><b>  BEGIN</b></p><p>  IF (NOT rst = ’1’) THEN</p><p>  div8_tras_reg <= "000"; </p>

39、<p>  ELSE IF(clkbaud8x’EVENT AND clkbaud8x = ’1’) THEN</p><p>  IF (trasstart = ’1’) THEN</p><p>  div8_tras_reg <= div8_tras_reg + "001";- </p><p><b> 

40、 END IF;</b></p><p><b>  END IF;</b></p><p><b>  END IF;</b></p><p>  END PROCESS;</p><p>  PROCESS(div8_rec_reg)</p><p><

41、b>  BEGIN</b></p><p>  IF (div8_rec_reg = "111") THEN</p><p>  clkbaud_rec <= ’1’; </p><p><b>  ELSE</b></p><p>  clkbaud_rec <=

42、’0’; </p><p><b>  END IF;</b></p><p>  END PROCESS;</p><p>  PROCESS(div8_tras_reg)</p><p><b>  BEGIN</b></p><p>  IF (div8_tras

43、_reg = "111") THEN</p><p>  clkbaud_tras <= ’1’; </p><p><b>  ELSE</b></p><p>  clkbaud_tras <= ’0’; </p><p><b>  END IF;</b&g

44、t;</p><p>  END PROCESS;</p><p>  PROCESS(clkbaud8x,rst)</p><p><b>  BEGIN</b></p><p>  IF (NOT rst = ’1’) THEN</p><p>  txd_reg <= ’1’;

45、</p><p>  trasstart <= ’0’; </p><p>  txd_buf <= "00000000"; </p><p>  state_tras <= "0000"; </p><p>  send_state <= "000&

46、quot;; </p><p>  key_entry2 <= ’0’; </p><p>  ELSE IF(clkbaud8x’EVENT AND clkbaud8x = ’1’) THEN</p><p>  IF (NOT key_entry2 = ’1’) THEN</p><p>  IF (key_entry1

47、 = ’1’) THEN</p><p>  key_entry2 <= ’1’; </p><p>  txd_buf <= "01110111"; --"w"</p><p><b>  END IF;</b></p><p><b>  ELS

48、E</b></p><p>  CASE state_tras IS</p><p>  WHEN "0000" => </p><p>  IF ((NOT trasstart=’1’) AND (send_state < "111") ) THEN</p><p>  tr

49、asstart <= ’1’; </p><p><b>  ELSE</b></p><p>  IF (send_state < "111") THEN</p><p>  IF (clkbaud_tras = ’1’) THEN</p><p>  txd_reg <=

50、’0’; </p><p>  state_tras <= state_tras + "0001"; </p><p><b>  END IF;</b></p><p><b>  ELSE</b></p><p>  key_entry2 <= ’0’

51、; </p><p>  state_tras <= "0000"; </p><p><b>  END IF;</b></p><p><b>  END IF;</b></p><p>  WHEN "0001" => -<

52、/p><p>  IF (clkbaud_tras = ’1’) THEN</p><p>  txd_reg <= txd_buf(0); </p><p>  txd_buf(6 DOWNTO 0) <= txd_buf(7 DOWNTO 1); </p><p>  state_tras <= state_tr

53、as + "0001"; </p><p><b>  END IF;</b></p><p>  WHEN "0010" => </p><p>  IF (clkbaud_tras = ’1’) THEN</p><p>  txd_reg <= txd_b

54、uf(0); </p><p>  txd_buf(6 DOWNTO 0) <= txd_buf(7 DOWNTO 1); </p><p>  state_tras <= state_tras + "0001"; </p><p><b>  END IF;</b></p>&l

55、t;p>  WHEN "0011" => </p><p>  IF (clkbaud_tras = ’1’) THEN</p><p>  txd_reg <= txd_buf(0); </p><p>  txd_buf(6 DOWNTO 0) <= txd_buf(7 DOWNTO 1); </p

56、><p>  state_tras <= state_tras + "0001"; </p><p><b>  END IF;</b></p><p>  WHEN "0100" => </p><p>  IF (clkbaud_tras = ’1’) THEN&

57、lt;/p><p>  txd_reg <= txd_buf(0); </p><p>  txd_buf(6 DOWNTO 0) <= txd_buf(7 DOWNTO 1); </p><p>  state_tras <= state_tras + "0001"; </p><p>&

58、lt;b>  END IF;</b></p><p>  WHEN "0101" => </p><p>  IF (clkbaud_tras = ’1’) THEN</p><p>  txd_reg <= txd_buf(0); </p><p>  txd_buf(6 DOWNTO

59、 0) <= txd_buf(7 DOWNTO 1); </p><p>  state_tras <= state_tras + "0001"; </p><p><b>  END IF;</b></p><p>  WHEN "0110" => </p>

60、<p>  IF (clkbaud_tras = ’1’) THEN</p><p>  txd_reg <= txd_buf(0); </p><p>  txd_buf(6 DOWNTO 0) <= txd_buf(7 DOWNTO 1); </p><p>  state_tras <= state_tras + &qu

61、ot;0001"; </p><p><b>  END IF;</b></p><p>  WHEN "0111" => </p><p>  IF (clkbaud_tras = ’1’) THEN</p><p>  txd_reg <= txd_buf(0);

62、 </p><p>  txd_buf(6 DOWNTO 0) <= txd_buf(7 DOWNTO 1); </p><p>  state_tras <= state_tras + "0001"; </p><p><b>  END IF;</b></p><p>  

63、WHEN "1000" => </p><p>  IF (clkbaud_tras = ’1’) THEN</p><p>  txd_reg <= txd_buf(0); </p><p>  txd_buf(6 DOWNTO 0) <= txd_buf(7 DOWNTO 1); </p><

64、;p>  state_tras <= state_tras + "0001"; </p><p><b>  END IF;</b></p><p>  WHEN "1001" => </p><p>  IF (clkbaud_tras = ’1’) THEN</p>

65、;<p>  txd_reg <= ’1’; </p><p>  txd_buf <= "01010101"; </p><p>  state_tras <= state_tras + "0001"; </p><p><b>  END IF;</b>

66、;</p><p>  WHEN "1111" =></p><p>  IF (clkbaud_tras = ’1’) THEN</p><p>  state_tras <= state_tras + "0001"; </p><p>  send_state <= send

67、_state + "001"; </p><p>  trasstart <= ’0’; </p><p>  CASE send_state IS</p><p>  WHEN "000" =></p><p>  txd_buf <= "01100101&qu

68、ot;; --"e" </p><p>  WHEN "001" =></p><p>  txd_buf <= "01101100";-- "l" </p><p>  WHEN "010" =></p><p> 

69、 txd_buf <= "01100011"; --"c" </p><p>  WHEN "011" =></p><p>  txd_buf <= "01101111";-- "o" </p><p>  WHEN "100&qu

70、ot; =></p><p>  txd_buf <= "01101101"; -- "m" </p><p>  WHEN "101" =></p><p>  txd_buf <= "01100101";-- "e" </p&g

71、t;<p>  WHEN OTHERS =></p><p>  txd_buf <= "00000000"; </p><p><b>  END CASE;</b></p><p><b>  END IF;</b></p><p>  WHEN

72、 OTHERS =></p><p>  IF (clkbaud_tras = ’1’) THEN</p><p>  state_tras <= state_tras + "0001"; </p><p>  trasstart <= ’1’; </p><p><b>  EN

73、D IF;</b></p><p><b>  END CASE;</b></p><p><b>  END IF;</b></p><p><b>  END IF;</b></p><p><b>  END IF;</b></p&

74、gt;<p>  END PROCESS;</p><p>  PROCESS(clkbaud8x,rst) </p><p><b>  BEGIN</b></p><p>  IF (NOT rst = ’1’) THEN</p><p>  rxd_reg1 <= ’0’; </p

75、><p>  rxd_reg2 <= ’0’; </p><p>  rxd_buf <= "00000000"; </p><p>  state_rec <= "0000"; </p><p>  recstart <= ’0’; </p>

76、<p>  recstart_tmp <= ’0’; </p><p>  ELSE IF(clkbaud8x’EVENT AND clkbaud8x = ’1’) THEN</p><p>  rxd_reg1 <= rxd; </p><p>  rxd_reg2 <= rxd_reg1; </p>&

77、lt;p>  IF (state_rec = "0000") THEN</p><p>  IF (recstart_tmp = ’1’) THEN</p><p>  recstart <= ’1’; </p><p>  recstart_tmp <= ’0’; </p><p>  st

78、ate_rec <= state_rec + "0001"; </p><p><b>  ELSE</b></p><p>  IF ((NOT rxd_reg1 AND rxd_reg2) = ’1’) THEN </p><p>  recstart_tmp <= ’1’; </p>

79、<p><b>  END IF;</b></p><p><b>  END IF;</b></p><p><b>  ELSE</b></p><p>  IF (state_rec >= "0001" AND state_rec<="10

80、00") THEN</p><p>  IF (clkbaud_rec = ’1’) THEN</p><p>  rxd_buf(7) <= rxd_reg2; </p><p>  rxd_buf(6 DOWNTO 0) <= rxd_buf(7 DOWNTO 1); </p><p>  state_r

81、ec <= state_rec + "0001"; </p><p><b>  END IF;</b></p><p><b>  ELSE</b></p><p>  IF (state_rec = "1001") THEN</p><p> 

82、 IF (clkbaud_rec = ’1’) THEN</p><p>  state_rec <= "0000"; </p><p>  recstart <= ’0’; </p><p><b>  END IF;</b></p><p><b>  END I

83、F;</b></p><p><b>  END IF;</b></p><p><b>  END IF;</b></p><p><b>  END IF;</b></p><p><b>  END IF;</b></p>

84、<p>  END PROCESS;</p><p>  PROCESS(rxd_buf) </p><p><b>  BEGIN</b></p><p>  CASE rxd_buf IS</p><p>  WHEN "00110000" =></p><

85、p>  seg_data <= "10101111";-- 0 </p><p>  WHEN "00110001" =></p><p>  seg_data <= "10100000";-- 1 </p><p>  WHEN "00110010" =&

86、gt;</p><p>  seg_data <= "11000111";-- 2 </p><p>  WHEN "00110011" =></p><p>  seg_data <= "11100101"; --3 </p><p>  WHEN &

87、quot;00110100" =></p><p>  seg_data <= "11101000"; --4 </p><p>  WHEN "00110101" =></p><p>  seg_data <= "01101101";-- 5 </p>

88、<p>  WHEN "00110110" =></p><p>  seg_data <= "01101111"; --6 </p><p>  WHEN "00110111" =></p><p>  seg_data <= "10100001&quo

89、t;; --7 </p><p>  WHEN "00111000" =></p><p>  seg_data <= "11101111";-- 8 </p><p>  WHEN "00111001" =></p><p>  seg_data <

90、;= "11101101";-- 9 </p><p>  WHEN "01000001" =></p><p>  seg_data <= "11101011"; --A </p><p>  WHEN "01000010" =></p><

91、;p>  seg_data <= "01101110";-- B </p><p>  WHEN "01000011" =></p><p>  seg_data <= "00001111"; --C </p><p>  WHEN "01000100"

92、=></p><p>  seg_data <= "11100110"; --D </p><p>  WHEN "01000101" =></p><p>  seg_data <= "01001111"; --E </p><p>  WHEN &q

93、uot;01000110" =></p><p>  seg_data <= "01001011"; --F </p><p>  WHEN OTHERS =></p><p>  seg_data <= "11111111"; </p><p&g

94、t;<b>  END CASE;</b></p><p>  END PROCESS;</p><p><b>  END arch;</b></p><p><b>  六:總結(jié)</b></p><p>  在此次的RS-232串口通信控制器設(shè)計(jì)過程中,更進(jìn)一步地熟悉有關(guān)數(shù)

95、字電路的知識(shí)和具體應(yīng)用。學(xué)會(huì)了利QuarterII軟件進(jìn)行原理圖的繪制,硬件描述語言VHDL的編寫,程序的仿真等工作。并能根據(jù)仿真結(jié)果分析設(shè)計(jì)的存在的問題和缺陷,從而進(jìn)行程序的調(diào)試和完善。</p><p>  在設(shè)計(jì)電路中,往往是先仿真后連接實(shí)物圖,但有時(shí)候仿真和電路連接并不是完全一致的,例如在對(duì)具體模塊的仿真的過程中,往往沒有考慮到整體設(shè)計(jì)的層面以及與上下模塊接口的設(shè)計(jì)。再加上器件對(duì)信號(hào)的延時(shí)等問題,實(shí)際下載到

96、實(shí)驗(yàn)箱上后會(huì)出現(xiàn)一系列的問題,因此仿真圖和電路連接圖還是有一定區(qū)別的。</p><p>  此次的數(shù)字鐘設(shè)計(jì)重在于按鍵的控制和各個(gè)模塊代碼的編寫,雖然能把鍵盤接口和各個(gè)模塊的代碼編寫出來,并能正常顯示,但對(duì)于各個(gè)模塊的優(yōu)化設(shè)計(jì)還有一定的缺陷和不足??偟膩碚f,通過這次的設(shè)計(jì)實(shí)驗(yàn)更進(jìn)一步地增強(qiáng)了實(shí)驗(yàn)的動(dòng)手能力,對(duì)數(shù)字鐘的工作原理也有了更加透徹的理解。</p><p><b>  七:

97、參考文獻(xiàn)</b></p><p>  [1] 劉君,常明,秦娟,基于硬件描述語言(VHDL)的數(shù)字時(shí)鐘設(shè)計(jì),天津理工大學(xué)學(xué)報(bào),2007,第23卷 第4期,40-41</p><p>  [2] 廖日坤,CPLD/FPGA嵌入式應(yīng)用開發(fā)技術(shù)白金手冊(cè),中國電力出版社,2003,212-218。</p><p>  [3] 王開軍,姜宇柏,面向CPLD/FPG

98、A的VHDL設(shè)計(jì),機(jī)械工業(yè)出版社,2006,28-65。</p><p>  [4] 譚會(huì)生,張昌凡,EDA技術(shù)及應(yīng)用,西安電子科技大學(xué)出版社,2002。 </p><p>  [5] 高吉祥,電子技術(shù)基礎(chǔ)實(shí)驗(yàn)與課程設(shè)計(jì),電子工業(yè)出版社,2002。</p><p>  [7] 謝自美,電子線路設(shè)計(jì)、實(shí)驗(yàn)、測(cè)試,華中理工大學(xué)出版社,2003。</p>&

99、lt;p>  [8] 趙志杰,集成電路應(yīng)用識(shí)圖方法,機(jī)械工業(yè)出版社,2003,35-40。</p><p>  大學(xué)本科生畢業(yè)設(shè)計(jì)(論文)撰寫規(guī)范</p><p>  本科生畢業(yè)設(shè)計(jì)(論文)是學(xué)生在畢業(yè)前提交的一份具有一定研究價(jià)值和實(shí)用價(jià)值的學(xué)術(shù)資料。它既是本科學(xué)生開始從事工程設(shè)計(jì)、科學(xué)實(shí)驗(yàn)和科學(xué)研究的初步嘗試,也是學(xué)生在教師的指導(dǎo)下,對(duì)所進(jìn)行研究的適當(dāng)表述,還是學(xué)生畢業(yè)及學(xué)位資格認(rèn)

100、定的重要依據(jù)。畢業(yè)論文撰寫是本科生培養(yǎng)過程中的基本訓(xùn)練環(huán)節(jié)之一,應(yīng)符合國家及各專業(yè)部門制定的有關(guān)標(biāo)準(zhǔn),符合漢語語法規(guī)范。指導(dǎo)教師應(yīng)加強(qiáng)指導(dǎo),嚴(yán)格把關(guān)。</p><p><b>  1、論文結(jié)構(gòu)及要求</b></p><p>  論文包括題目、中文摘要、外文摘要、目錄、正文、參考文獻(xiàn)、致謝和附錄等幾部分。</p><p><b>  1

101、.1 題目</b></p><p>  論文題目應(yīng)恰當(dāng)、準(zhǔn)確地反映論文的主要研究內(nèi)容。不應(yīng)超過25字,原則上不得使用標(biāo)點(diǎn)符號(hào),不設(shè)副標(biāo)題。</p><p>  1.2 摘要與關(guān)鍵詞</p><p><b>  1.2.1 摘要</b></p><p>  本科生畢業(yè)設(shè)計(jì)(論文)的摘要均要求用中、英兩種文字給出

102、,中文在前。</p><p>  摘要應(yīng)扼要敘述論文的研究目的、研究方法、研究內(nèi)容和主要結(jié)果或結(jié)論,文字要精煉,具有一定的獨(dú)立性和完整性,摘要一般應(yīng)在300字左右。摘要中不宜使用公式、圖表,不標(biāo)注引用文獻(xiàn)編號(hào),避免將摘要寫成目錄式的內(nèi)容介紹。</p><p><b>  1.2.2 關(guān)鍵詞</b></p><p>  關(guān)鍵詞是供檢索用的主題詞條

103、,應(yīng)采用能覆蓋論文主要內(nèi)容的通用技術(shù)詞條(參照相應(yīng)的技術(shù)術(shù)語標(biāo)準(zhǔn)),一般列3~5個(gè),按詞條的外延層次從大到小排列,應(yīng)在摘要中出現(xiàn)。</p><p><b>  1.3 目錄</b></p><p>  目錄應(yīng)獨(dú)立成頁,包括論文中全部章、節(jié)的標(biāo)題及頁碼。</p><p><b>  1.4 論文正文</b></p>

104、;<p>  論文正文包括緒論、論文主體及結(jié)論等部分。</p><p><b>  1.4.1 緒論</b></p><p>  緒論一般作為論文的首篇。緒論應(yīng)說明選題的背景、目的和意義,國內(nèi)外文獻(xiàn)綜述以及論文所要研究的主要內(nèi)容。</p><p>  文管類論文的緒論是畢業(yè)論文的開頭部分,一般包括說明論文寫作的目的與意義,對(duì)所研究

105、問題的認(rèn)識(shí)以及提出問題。緒論只是文章的開頭,不必寫章號(hào)。</p><p>  畢業(yè)設(shè)計(jì)(論文)緒論部分字?jǐn)?shù)不多于全部論文字?jǐn)?shù)的1/4。</p><p>  1.4.2 論文主體</p><p>  論文主體是論文的主要部分,要求結(jié)構(gòu)合理,層次清楚,重點(diǎn)突出,文字簡練、通順。論文主體的內(nèi)容要求參照《大學(xué)本科生畢業(yè)設(shè)計(jì)(論文)的規(guī)定》第五章。</p>&l

106、t;p>  論文主體各章后應(yīng)有一節(jié)“本章小結(jié)”。</p><p><b>  1.4.3 結(jié)論</b></p><p>  結(jié)論作為單獨(dú)一章排列,但不加章號(hào)。</p><p>  結(jié)論是對(duì)整個(gè)論文主要成果的歸納,要突出設(shè)計(jì)(論文)的創(chuàng)新點(diǎn),以簡練的文字對(duì)論文的主要工作進(jìn)行評(píng)價(jià),一般為400~1 000字。</p><p

107、><b>  1.5 參考文獻(xiàn)</b></p><p>  參考文獻(xiàn)是論文不可缺少的組成部分,它反映了論文的取材來源和廣博程度。論文中要注重引用近期發(fā)表的與論文工作直接有關(guān)的學(xué)術(shù)期刊類文獻(xiàn)。對(duì)理工類論文,參考文獻(xiàn)數(shù)量一般應(yīng)在15篇以上,其中學(xué)術(shù)期刊類文獻(xiàn)不少于8篇,外文文獻(xiàn)不少于3篇;對(duì)文科類、管理類論文,參考文獻(xiàn)數(shù)量一般為10~20篇,其中學(xué)術(shù)期刊類文獻(xiàn)不少于8篇,外文文獻(xiàn)不少于3篇

108、。</p><p>  在論文正文中必須有參考文獻(xiàn)的編號(hào),參考文獻(xiàn)的序號(hào)應(yīng)按在正文中出現(xiàn)的順序排列。</p><p>  產(chǎn)品說明書、各類標(biāo)準(zhǔn)、各種報(bào)紙上刊登的文章及未公開發(fā)表的研究報(bào)告(著名的內(nèi)部報(bào)告如PB、AD報(bào)告及著名大公司的企業(yè)技術(shù)報(bào)告等除外)不宜做為參考文獻(xiàn)引用。但對(duì)于工程設(shè)計(jì)類論文,各種標(biāo)準(zhǔn)、規(guī)范和手冊(cè)可作為參考文獻(xiàn)。</p><p>  引用網(wǎng)上參考文

109、獻(xiàn)時(shí),應(yīng)注明該文獻(xiàn)的準(zhǔn)確網(wǎng)頁地址,網(wǎng)上參考文獻(xiàn)不包含在上述規(guī)定的文獻(xiàn)數(shù)量之內(nèi)。</p><p><b>  1.6 致謝</b></p><p>  對(duì)導(dǎo)師和給予指導(dǎo)或協(xié)助完成論文工作的組織和個(gè)人表示感謝。內(nèi)容應(yīng)簡潔明了、實(shí)事求是,避免俗套。</p><p><b>  1.7 附錄</b></p><

110、p>  如開題報(bào)告、文獻(xiàn)綜述、外文譯文及外文文獻(xiàn)復(fù)印件、公式的推導(dǎo)、程序流程圖、圖紙、數(shù)據(jù)表格等有些不宜放在正文中,但有參考價(jià)值的內(nèi)容可編入論文的附錄中。</p><p><b>  2、論文書寫規(guī)定</b></p><p>  2.1 論文正文字?jǐn)?shù)</p><p>  理工類 論文正文字?jǐn)?shù)不少于20 000字。</p>

111、<p>  文管類 論文正文字?jǐn)?shù)12 000-20 000字。其中漢語言文學(xué)專業(yè)不少于7 000字。</p><p>  外語類 論文正文字?jǐn)?shù)8 000-10 000個(gè)外文單詞。</p><p>  藝術(shù)類 論文正文字?jǐn)?shù)3 000~5 000字。</p><p><b>  2.2 論文書寫</b></p><

112、;p>  本科生畢業(yè)論文用B5紙計(jì)算機(jī)排版、編輯與雙面打印輸出。</p><p>  論文版面設(shè)置為:畢業(yè)論文B5紙、縱向、為橫排、不分欄,上下頁邊距分別為2.5cm和2cm,左右頁邊距分別為2.4cm和2cm,對(duì)稱頁邊距、左側(cè)裝訂并裝訂線為0cm、奇偶頁不同、無網(wǎng)格。論文正文滿頁為29行,每行33個(gè)字,字號(hào)為小四號(hào)宋體,每頁版面字?jǐn)?shù)為957個(gè),行間距為固定值20磅。</p><p>

113、;  頁眉。頁眉應(yīng)居中置于頁面上部。單數(shù)頁眉的文字為“章及標(biāo)題”;雙數(shù)頁眉的文字為“大學(xué)本科生畢業(yè)設(shè)計(jì)(論文)”。頁眉的文字用五號(hào)宋體,頁眉文字下面為2條橫線(兩條橫線的長度與版芯尺寸相同,線粗0.5磅)。頁眉、頁腳邊距分別為1.8cm和1.7cm。</p><p>  頁碼。頁碼用小五號(hào)字,居中標(biāo)于頁面底部。摘要、目錄等文前部分的頁碼用羅馬數(shù)字單獨(dú)編排,正文以后的頁碼用阿拉伯?dāng)?shù)字編排。</p>&

114、lt;p><b>  2.3 摘要</b></p><p>  中文摘要一般為300字左右,外文摘要應(yīng)與中文摘要內(nèi)容相同,在語法、用詞和書寫上應(yīng)正確無誤,摘要頁勿需寫出論文題目。中、外文摘要應(yīng)各占一頁,編排裝訂時(shí)放置正文前,并且中文在前,外文在后。</p><p><b>  2.4 目錄</b></p><p> 

115、 目錄應(yīng)包括論文中全部章節(jié)的標(biāo)題及頁碼,含中、外文摘要;正文章、節(jié)題目;</p><p>  參考文獻(xiàn);致謝;附錄。</p><p>  正文章、節(jié)題目(理工類要求編寫到第3級(jí)標(biāo)題,即□.□.□。文科、管理類可視論文需要進(jìn)行,編寫到2~3級(jí)標(biāo)題。)</p><p><b>  2.5 論文正文</b></p><p> 

116、 2.5.1 章節(jié)及各章標(biāo)題</p><p>  論文正文分章、節(jié)撰寫,每章應(yīng)另起一頁。</p><p>  各章標(biāo)題要突出重點(diǎn)、簡明扼要。字?jǐn)?shù)一般在15字以內(nèi),不得使用標(biāo)點(diǎn)符號(hào)。標(biāo)題中盡量不用英文縮寫詞,對(duì)必須采用者,應(yīng)使用本行業(yè)的通用縮寫詞。</p><p><b>  2.5.2 層次</b></p><p>  

117、層次以少為宜,根據(jù)實(shí)際需要選擇。層次代號(hào)格式見表1和表2。</p><p>  表1 理工類論文層次代號(hào)及說明</p><p>  ↑ ↑</p><p>  版心左邊線 版心右邊線</p><p>  表2

118、文管類論文層次代號(hào)及說明</p><p>  ↑ ↑</p><p>  版心左邊線 版心右邊線</p><p>  各層次題序及標(biāo)題不得置于頁面的最后一行(孤行)。</p><p>&l

119、t;b>  2.6 參考文獻(xiàn)</b></p><p>  正文中引用文獻(xiàn)標(biāo)示應(yīng)置于所引內(nèi)容最末句的右上角,用小五號(hào)字體。所引文獻(xiàn)編號(hào)用阿拉伯?dāng)?shù)字置于方括號(hào)“[ ]”中,如“二次銑削[1]”。當(dāng)提及的參考文獻(xiàn)為文中直接說明時(shí),其序號(hào)應(yīng)該與正文排齊,如“由文獻(xiàn)[8,10~14]可知”。</p><p>  經(jīng)濟(jì)、管理類論文引用文獻(xiàn),若引用的是原話,要加引號(hào),一般寫在段中;若引

120、的不是原文只是原意,文前只需用冒號(hào)或逗號(hào),而不用引號(hào)。在參考文獻(xiàn)之外,若有注釋的話,建議采用夾注,即緊接文句,用圓括號(hào)標(biāo)明。</p><p>  不得將引用文獻(xiàn)標(biāo)示置于各級(jí)標(biāo)題處。</p><p>  參考文獻(xiàn)書寫格式應(yīng)符合GB7714-1987《文后參考文獻(xiàn)著錄規(guī)則》。常用參考文獻(xiàn)編寫項(xiàng)目和順序應(yīng)按文中引用先后次序規(guī)定如下:</p><p><b>  

121、著作圖書文獻(xiàn)</b></p><p>  序號(hào)└─┘作者.書名(版次).出版地:出版者,出版年:引用部分起止頁</p><p><b>  第一版應(yīng)省略</b></p><p><b>  翻譯圖書文獻(xiàn)</b></p><p>  序號(hào)└─┘作者.書名(版次).譯者.出版地: 出版者,出

122、版年:引用部分起止頁</p><p><b>  第一版應(yīng)省略</b></p><p><b>  學(xué)術(shù)刊物文獻(xiàn)</b></p><p>  序號(hào)└─┘作者.文章名.學(xué)術(shù)刊物名.年,卷(期):引用部分起止頁</p><p><b>  學(xué)術(shù)會(huì)議文獻(xiàn)</b></p>

123、<p>  序號(hào)└─┘作者.文章名.編者名.會(huì)議名稱,會(huì)議地址,年份.出版地,出版者,</p><p>  出版年:引用部分起止頁</p><p><b>  學(xué)位論文類參考文獻(xiàn)</b></p><p>  序號(hào)└─┘研究生名.學(xué)位論文題目.出版地.學(xué)校(或研究單位)及學(xué)位論文級(jí)別.答</p><p>  辯

124、年份:引用部分起止頁 </p><p>  西文文獻(xiàn)中第一個(gè)詞和每個(gè)實(shí)詞的第一個(gè)字母大寫,余者小寫;俄文文獻(xiàn)名第一個(gè)詞和專有名詞的第一個(gè)字母大寫,余者小寫;日文文獻(xiàn)中的漢字須用日文漢字,不得用中文漢字、簡化漢字代替。文獻(xiàn)中的外文字母一律用正體。</p><p>  作者為多人時(shí),一般只列出前3名作者,不同作者姓名間用逗號(hào)相隔。外文姓名按國際慣例,將作者名的縮寫置前,作者姓置后。</p

125、><p>  學(xué)術(shù)會(huì)議若出版論文集者,可在會(huì)議名稱后加上“論文集”字樣。未出版論文集者省去“出版者”、“出版年”兩項(xiàng)。會(huì)議地址與出版地相同者省略“出版地”。會(huì)議年份與出版年相同者省略“出版年”。</p><p>  學(xué)術(shù)刊物文獻(xiàn)無卷號(hào)的可略去此項(xiàng),直接寫“年,(期)”。</p><p>  參考文獻(xiàn)序號(hào)頂格書寫,不加括號(hào)與標(biāo)點(diǎn),其后空一格寫作者名。序號(hào)應(yīng)按文獻(xiàn)在論文中的

126、被引用順序編排。換行時(shí)與作者名第一個(gè)字對(duì)齊。若同一文獻(xiàn)中有多處被引用,則要寫出相應(yīng)引用頁碼,各起止頁碼間空一格,排列按引用順序,不按頁碼順序。</p><p>  參考文獻(xiàn)書寫格式示例見附錄1。</p><p><b>  2.7 名詞術(shù)語</b></p><p>  科技名詞術(shù)語及設(shè)備、元件的名稱,應(yīng)采用國家標(biāo)準(zhǔn)或部頒標(biāo)準(zhǔn)中規(guī)定的術(shù)語或名稱。

127、標(biāo)準(zhǔn)中未規(guī)定的術(shù)語要采用行業(yè)通用術(shù)語或名稱。全文名詞術(shù)語必須統(tǒng)一。一些特殊名詞或新名詞應(yīng)在適當(dāng)位置加以說明或注解。</p><p>  文管類專業(yè)技術(shù)術(shù)語應(yīng)為常見、常用的名詞。</p><p>  采用英語縮寫詞時(shí),除本行業(yè)廣泛應(yīng)用的通用縮寫詞外,文中第一次出現(xiàn)的縮寫詞應(yīng)該用括號(hào)注明英文全文。</p><p><b>  2.8 計(jì)量單位</b>

128、;</p><p>  物理量計(jì)量單位及符號(hào)一律采用《中華人民共和國法定計(jì)量單位》(GB3100~3102—1993,見附錄2),不得使用非法定計(jì)量單位及符號(hào)。計(jì)量單位符號(hào),除用人名命名的單位第一個(gè)字母用大寫之外,一律用小寫字母。</p><p>  非物理單位(如件、臺(tái)、人、元、次等)可以采用漢字與單位符號(hào)混寫的方式,如“萬t·km”,“t/(人·a)”等。</

129、p><p>  文稿敘述中不定數(shù)字之后允許用中文計(jì)量單位符號(hào),如“幾千克至1 000kg”。</p><p>  表達(dá)時(shí)刻時(shí)應(yīng)采用中文計(jì)量單位,如“上午8點(diǎn)45分”,不能寫成“8h45min”。</p><p>  計(jì)量單位符號(hào)一律用正體。</p><p>  2.9 外文字母的正、斜體用法</p><p>  按照GB3

130、100~3102-1986及GB7159-1987的規(guī)定使用,即物理量符號(hào)、物理常量、變量符號(hào)用斜體,計(jì)量單位等符號(hào)均用正體。</p><p><b>  2.10 數(shù)字</b></p><p>  按國家語言文字工作委員會(huì)等七單位1987年發(fā)布的《關(guān)于出版物上數(shù)字用法的規(guī)定》,除習(xí)慣用中文數(shù)字表示的以外,一般均采用阿拉伯?dāng)?shù)字(參照附錄3)。</p>&

131、lt;p><b>  2.11 公式</b></p><p>  原則上居中書寫。若公式前有文字(如“解”、“假定”等),文字頂格書寫,公式仍居中寫。公式末不加標(biāo)點(diǎn)。</p><p>  公式序號(hào)按章編排,如第1章第一個(gè)公式序號(hào)為“(1-1)”,附錄2中的第一個(gè)公式為(②-1)等。 </p><p>  文中引用公式時(shí),一般用“

132、見式(1-1)”或“由公式(1-1)”。</p><p>  公式中用斜線表示“除”的關(guān)系時(shí),若分母部分為乘積應(yīng)采用括號(hào),以免含糊不清,如a/(bcosx)。通?!俺恕钡年P(guān)系在前,如acosx/b而不寫(a/b)cosx。</p><p><b>  2.12 插表</b></p><p>  表格不加左、右邊線。</p><

133、;p>  表序一般按章編排,如第1章第一個(gè)插表的序號(hào)為“表1-1”等。表序與表名之間空一格,表名中不允許使用標(biāo)點(diǎn)符號(hào),表名后不加標(biāo)點(diǎn)。表序與表名置于表上,居中排寫(見附錄4)。</p><p>  表頭設(shè)計(jì)應(yīng)簡單明了,盡量不用斜線。表頭中可采用化學(xué)符號(hào)或物理量符號(hào)。</p><p>  全表如用同一單位,將單位符號(hào)移到表頭右上角,加圓括號(hào)(見附錄4中的例2)。</p>

溫馨提示

  • 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ì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論