洗衣機控制電路設計eda課程設計_第1頁
已閱讀1頁,還剩25頁未讀 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權,請進行舉報或認領

文檔簡介

1、<p><b>  數(shù)字電子技術</b></p><p><b>  課程設計報告</b></p><p> 設計課題:洗衣機控制電路設計</p><p> 學生姓名:</p><p> 學生學號:</p><p> 專業(yè)班級:08級自動化1班</p>

2、<p> 學院名稱:電氣與信息工程學院</p><p>  一 課程設計的目的:</p><p>  1、能夠全面鞏固和應用“電子技術基礎數(shù)字部分”課程中所學的基本理論和方法,并初步掌握小型數(shù)字系統(tǒng)設計的基本方法。2、掌握VHDL語言編制小型模塊的方法,并采用層次化設計。</p><p>  3、培養(yǎng)電路設計能力,懂得理論設計與實物實現(xiàn)的有效結合。<

3、;/p><p>  4、掌握Altium Designer軟件的應用。</p><p>  二 總體方案分析及選擇:</p><p>  洗衣機電路包含有總的控制模塊,洗滌控制模塊,洗滌記時模塊,電動機控制模塊以及LCD液晶板的動態(tài)顯示模塊.經(jīng)過分析后,我們把前四個模塊進行組合,把他們合成一個模塊即:總控制模塊.他們之間的邏輯聯(lián)結關系,是對數(shù)電課程的一個很好總結,也是

4、自己對新知識(LCD液晶板的動態(tài)顯示)學習理解運用能力的一個很好的提升機會。</p><p>  三 基本功能要求:</p><p>  要求設計制作一個普通功能洗衣機控制電路,使之能控制洗衣機的進水閥,排水閥,洗滌程序電機,甩干驅(qū)動裝置等按預定程序工作.總體過程包括:進水 浸泡 洗滌 排水 甩干五個過程.進水從電路啟動開始.其中浸泡可供選擇,洗滌時間可以預置,洗滌結束時發(fā)出鈴聲進行

5、提示并自動切斷電源.發(fā)生故障如:缺水或進水超時 排水超時 甩干碰桶等時也可自動切斷電源!</p><p>  根據(jù)洗衣機工作時不同的洗衣服數(shù)量,我們設計了三個檔(duoxi zhongxi shaoxi)來對洗衣機的進水 浸泡 洗滌 排水 甩干的五個過程分別預置時間。以此來區(qū)分洗衣機不同洗衣數(shù)量下的工作狀態(tài)。</p><p>  用中小規(guī)模集成電路芯片或CPLD/FPGA設計符合上述任務要

6、求的電路,并制作出能實際運行的裝置.</p><p>  安裝并調(diào)試電路,測試各部分電路功能或模型.</p><p>  演示并交驗硬件裝置.</p><p><b>  下載實現(xiàn)圖:</b></p><p>  四 總控制模塊的生成程序</p><p>  library ieee;</

7、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 washer is</p><p><b&g

8、t;  port(</b></p><p>  clk0, clk1, rst, alarm: in std_logic;</p><p>  -----clk0:控制開關脈沖.clk1:記時開關脈沖.Rst:復位端.alarm報警輸入端.-------</p><p>  duoxi,zhongxi,shaoxi : in std_Logic;<

9、/p><p>  -----qiangxi:強洗輸入端。zhongxi:中洗輸入端。ruoxi:弱洗輸入端。-------------</p><p>  water_in, water_out, immersion, dry, z1, z2, voice, poweroff: out std_logic;</p><p>  -----進水,出水,浸泡,甩干,洗滌,響

10、鈴,斷電輸出端-------</p><p>  display_th, display_tl: out std_logic_vector(3 downto 0)</p><p>  -------------------輸出時間顯示高位低位輸出端-------------</p><p><b>  );</b></p><

11、;p>  end entity washer;</p><p>  architecture behave of washer is</p><p>  signal js, js_ten : std_logic;</p><p>  signal im, im_ten : std_logic;</p><p>  signal wa,

12、 wa_ten : std_logic;</p><p>  signal wa1, wa2, pwf: std_logic;</p><p>  signal cs, cs_ten : std_logic;</p><p>  signal dr, dr_ten : std_logic;</p><p>  signal xl, xl_te

13、n : std_logic;</p><p>  signal js_dh, js_dl: std_logic_vector(3 downto 0);</p><p>  signal im_dh, im_dl: std_logic_vector(3 downto 0);</p><p>  signal wa_dh, wa_dl: std_logic_vector

14、(3 downto 0);</p><p>  signal cs_dh, cs_dl: std_logic_vector(3 downto 0);</p><p>  signal dr_dh, dr_dl: std_logic_vector(3 downto 0);</p><p>  signal xl_dh, xl_dl: std_logic_vector(

15、3 downto 0);</p><p>  signal dis_th,dis_tl: std_logic_vector(3 downto 0);</p><p>  signal water_inh, water_inl, im_th, im_tl, wash_th: std_logic_vector(3 downto 0);</p><p>  signa

16、l wash_tl, water_outh, water_outl, dry_th, dry_tl: std_logic_vector(3 downto 0);</p><p><b>  begin</b></p><p>  -----------------------控制:控制器件實現(xiàn)洗衣機的功能:進水->浸水->洗滌->出水->甩

17、干</p><p>  control:process(clk0, rst,alarm,duoxi,zhongxi,shaoxi)</p><p>  variable n: integer;</p><p><b>  begin</b></p><p>  if duoxi='1' and zhong

18、xi='0' and shaoxi='0' then</p><p>  water_inh<="0001";</p><p>  water_inl<="0010";</p><p>  im_th<="1001";</p><p>

19、;  im_tl<="0000";</p><p>  wash_th<="1001";</p><p>  wash_tl<="0000";</p><p>  water_outh<="0001";</p><p>  water_ou

20、tl<="0010";</p><p>  dry_th<="1001";</p><p>  dry_tl<="0000";</p><p>  elsif duoxi='0' and zhongxi='1' and shaoxi='0'

21、; then</p><p>  water_inh<="0000";</p><p>  water_inl<="0110";</p><p>  im_th<="0110";</p><p>  im_tl<="0000";</p

22、><p>  wash_th<="0110";</p><p>  wash_tl<="0000";</p><p>  water_outh<="0000";</p><p>  water_outl<="0110";</p>

23、<p>  dry_th<="0110";</p><p>  dry_tl <="0000";</p><p>  elsif duoxi='0' and zhongxi='0' and shaoxi='1' then</p><p>  water

24、_inh<="0000";</p><p>  water_inl<="0110";</p><p>  im_th<="0011";</p><p>  im_tl<="0000";</p><p>  wash_th<="

25、;0011";</p><p>  wash_tl<="0000";</p><p>  water_outh<="0000";</p><p>  water_outl<="0110";</p><p>  dry_th<="0011&q

26、uot;;</p><p>  dry_tl <="0000";</p><p><b>  else</b></p><p>  water_inh<="0000";</p><p>  water_inl<="0000";</p>

27、;<p>  im_th<="0000";</p><p>  im_tl<="0000";</p><p>  wash_th<="0000";</p><p>  wash_tl<="0000";</p><p>  wa

28、ter_outh<="0000";</p><p>  water_outl<="0000";</p><p>  dry_th<="0000";</p><p>  dry_tl <="0000";</p><p><b>  

29、end if;</b></p><p>  if alarm = '1' then</p><p>  pwf <= '1';</p><p><b>  else</b></p><p>  if rst = '1' then</p>&l

30、t;p><b>  n := 0;</b></p><p>  im_ten <= '0';</p><p>  js_ten <= '0';</p><p>  wa_ten <= '0';</p><p>  cs_ten <= '

31、0';</p><p>  dr_ten <= '0';</p><p>  xl_ten <= '0';</p><p>  pwf <= '0';</p><p>  elsif clk0 = '1' and clk0 'event then

32、</p><p>  if n = 0 then</p><p>  if water_inh = "0000" and water_inl = "0000" then</p><p><b>  n := 1;</b></p><p><b>  else</b&

33、gt;</p><p>  js_ten <= '1';</p><p>  if js = '1' then</p><p><b>  n := 1;</b></p><p><b>  end if;</b></p><p><

34、;b>  end if;</b></p><p>  elsif js = '0' and n = 1 then</p><p>  if im_th = "0000" and im_tl = "0000" then</p><p><b>  n := 2;</b>&l

35、t;/p><p><b>  else</b></p><p>  im_ten <= '1';</p><p>  if im = '1' then</p><p><b>  n := 2;</b></p><p><b>  

36、end if;</b></p><p><b>  end if;</b></p><p>  elsif im = '0' and n = 2 then</p><p>  if wash_th = "0000" and wash_tl = "0000" then</p

37、><p><b>  n := 3;</b></p><p><b>  else</b></p><p>  wa_ten <= '1';</p><p>  if wa = '1' then</p><p><b>  n :=

38、 3;</b></p><p><b>  end if;</b></p><p><b>  end if;</b></p><p>  elsif wa = '0' and n = 3 then</p><p>  if water_outh = "0000

39、" and water_outl = "0000" then</p><p><b>  n := 4;</b></p><p><b>  else</b></p><p>  cs_ten <= '1';</p><p>  if cs = &

40、#39;1' then</p><p><b>  n := 4;</b></p><p><b>  end if;</b></p><p><b>  end if;</b></p><p>  elsif cs = '0' and n = 4 th

41、en</p><p>  if dry_th = "0000" and dry_tl = "0000" then</p><p><b>  n := 5;</b></p><p><b>  else</b></p><p>  dr_ten <= &

42、#39;1';</p><p>  if dr = '1' then</p><p><b>  n := 5;</b></p><p><b>  end if;</b></p><p><b>  end if;</b></p><

43、;p>  elsif dr = '0' and n = 5 then</p><p>  xl_ten <= '1';</p><p>  if xl = '1' then</p><p><b>  n := 6;</b></p><p><b> 

44、 end if;</b></p><p>  elsif xl = '0' and n = 6 then</p><p>  pwf <= '1';</p><p><b>  end if;</b></p><p><b>  end if;</b>

45、;</p><p><b>  end if;</b></p><p>  end process;</p><p>  -----------------------------記時-----------------------------</p><p>  ------------------進水記時-------

46、-------------------</p><p>  js_jishiqi:process(clk1, js_ten,water_inh,water_inl)</p><p><b>  begin</b></p><p>  if js_ten = '0' then</p><p>  js_dh

47、 <= water_inh;</p><p>  js_dl <= water_inl;</p><p>  js <= '0';</p><p>  elsif clk1 = '1' and clk1 'event then</p><p>  if js_dh = "00

48、00" and js_dl = "0000" then</p><p>  js <= '0';</p><p><b>  else</b></p><p>  js <= '1';</p><p>  if js_dl = "0000

49、" then</p><p>  js_dl <= "1001";</p><p>  js_dh <= js_dh - 1;</p><p><b>  else</b></p><p>  js_dl <= js_dl - 1;</p><p>

50、<b>  end if;</b></p><p><b>  end if;</b></p><p><b>  end if;</b></p><p>  end process;</p><p>  -------------浸泡記時-------------------

51、----</p><p>  im_jishiqi:process(clk1, im_ten,im_th,im_tl)</p><p><b>  begin</b></p><p>  if im_ten = '0' then</p><p>  im_dh <= im_th;</p>

52、<p>  im_dl <= im_tl;</p><p>  im <= '0';</p><p>  elsif clk1 = '1' and clk1 'event then</p><p>  if im_dh = "0000" and im_dl = "0000

53、" then</p><p>  im <= '0';</p><p><b>  else</b></p><p>  im <= '1';</p><p>  if im_dl = "0000" then</p><p>

54、;  im_dl <= "1001";</p><p>  im_dh <= im_dh - 1;</p><p><b>  else</b></p><p>  im_dl <= im_dl - 1;</p><p><b>  end if;</b><

55、;/p><p><b>  end if;</b></p><p><b>  end if;</b></p><p>  end process;</p><p>  -----------------洗滌記時----------------------</p><p>  w

56、a_jishiqi:process(clk1, wa_ten,wash_th,wash_tl)</p><p>  variable m: integer;</p><p><b>  begin</b></p><p>  if wa_ten = '0' then</p><p>  wa_dh <

57、;= wash_th;</p><p>  wa_dl <= wash_tl;</p><p>  wa <= '0';</p><p>  wa1 <= '0';</p><p>  wa2 <= '0';</p><p><b>  

58、m := 0;</b></p><p>  elsif clk1 = '1' and clk1 'event then</p><p>  if wa_dh = "0000" and wa_dl = "0000" then</p><p>  wa <= '0';<

59、;/p><p>  wa1 <= '0';</p><p>  wa2 <= '0';</p><p><b>  else</b></p><p>  wa <= '1';</p><p>  if m = 0 then</p&

60、gt;<p>  wa1 <= '1';</p><p>  wa2 <= '1';</p><p>  elsif m = 10 then</p><p>  wa1 <= '0';</p><p>  wa2 <= '1';</p&

61、gt;<p>  elsif m = 13 then</p><p>  wa1 <= '1';</p><p>  wa2 <= '0';</p><p>  elsif m = 23 then</p><p>  wa1 <= '0';</p>

62、<p>  wa2 <= '0';</p><p>  elsif m = 26 then</p><p><b>  m := 0;</b></p><p>  wa1 <= '1';</p><p>  wa2 <= '1';</p&g

63、t;<p><b>  end if;</b></p><p>  m := m + 1;</p><p>  if wa_dl = "0000" then</p><p>  wa_dl <= "1001";</p><p>  wa_dh <= wa_

64、dh - 1;</p><p><b>  else</b></p><p>  wa_dl <= wa_dl - 1;</p><p><b>  end if;</b></p><p><b>  end if;</b></p><p><

65、;b>  end if;</b></p><p>  end process;</p><p>  --------------出水記時---------------------------</p><p>  cs_jishiqi:process(clk1, cs_ten,water_outh,water_outl)</p><

66、;p><b>  begin</b></p><p>  if cs_ten = '0' then</p><p>  cs_dh <= water_outh;</p><p>  cs_dl <= water_outl;</p><p>  cs <= '0';&

67、lt;/p><p>  elsif clk1 = '1' and clk1 'event then</p><p>  if cs_dh = "0000" and cs_dl = "0000" then</p><p>  cs <= '0';</p><p>

68、<b>  else</b></p><p>  cs <= '1';</p><p>  if cs_dl = "0000" then</p><p>  cs_dl <= "1001";</p><p>  cs_dh <= cs_dh - 1

69、;</p><p><b>  else</b></p><p>  cs_dl <= cs_dl - 1;</p><p><b>  end if;</b></p><p><b>  end if;</b></p><p><b>

70、  end if;</b></p><p>  end process;</p><p>  --------------甩干記時-----------------------</p><p>  dr_jishiqi:process(clk1, dr_ten,dry_th,dry_tl)</p><p><b>  b

71、egin</b></p><p>  if dr_ten = '0' then</p><p>  dr_dh <= dry_th;</p><p>  dr_dl <= dry_tl;</p><p>  dr <= '0';</p><p>  elsi

72、f clk1 = '1' and clk1 'event then</p><p>  if dr_dh = "0000" and dr_dl = "0000" then</p><p>  dr <= '0';</p><p><b>  else</b>&

73、lt;/p><p>  dr <= '1';</p><p>  if dr_dl = "0000" then</p><p>  dr_dl <= "1001";</p><p>  dr_dh <= dr_dh - 1;</p><p><

74、b>  else</b></p><p>  dr_dl <= dr_dl - 1;</p><p><b>  end if;</b></p><p><b>  end if;</b></p><p><b>  end if;</b></p&

75、gt;<p>  end process;</p><p>  ------------------響鈴記時----------------------</p><p>  xl_jishiqi:process(clk1, xl_ten)</p><p><b>  begin</b></p><p>  

76、if xl_ten = '0' then</p><p>  xl_dh <= "0010";</p><p>  xl_dl <= "0000";</p><p>  xl <= '0';</p><p>  elsif clk1 = '1&#

77、39; and clk1 'event then</p><p>  if xl_dh = "0000" and xl_dl = "0000" then</p><p>  xl <= '0';</p><p><b>  else</b></p><p&

78、gt;  xl <= '1';</p><p>  if xl_dl = "0000" then</p><p>  xl_dl <= "1001";</p><p>  xl_dh <= xl_dh - 1;</p><p><b>  else</b

79、></p><p>  xl_dl <= xl_dl - 1;</p><p><b>  end if;</b></p><p><b>  end if;</b></p><p><b>  end if;</b></p><p>  e

80、nd process;</p><p>  ----------------------------顯示時間--------------------------</p><p>  xianshishijian: process(clk1, js_ten, im_ten, wa_ten,cs_ten,dr_ten,xl_ten)</p><p><b> 

81、 begin</b></p><p>  if js_ten = '1' and im_ten = '0' and wa_ten = '0' and cs_ten = '0' and dr_ten = '0' and xl_ten = '0' then</p><p>  if cl

82、k1 = '1' and clk1 'event then</p><p>  dis_th <= js_dh;</p><p>  dis_tl <= js_dl;</p><p><b>  end if;</b></p><p>  elsif im_ten = '1&#

83、39; and wa_ten = '0' and cs_ten = '0' and dr_ten = '0' and xl_ten = '0' then</p><p>  if clk1 = '1' and clk1 'event then</p><p>  dis_th <= im_dh;&

84、lt;/p><p>  dis_tl <= im_dl;</p><p><b>  end if;</b></p><p>  elsif wa_ten = '1' and cs_ten = '0' and dr_ten = '0' and xl_ten = '0' then&

85、lt;/p><p>  if clk1 = '1' and clk1 'event then</p><p>  dis_th <= wa_dh;</p><p>  dis_tl <= wa_dl;</p><p><b>  end if;</b></p><p&g

86、t;  elsif cs_ten = '1' and dr_ten = '0' and xl_ten = '0' then</p><p>  if clk1 = '1' and clk1 'event then</p><p>  dis_th <= cs_dh;</p><p>  d

87、is_tl <= cs_dl;</p><p><b>  end if;</b></p><p>  elsif dr_ten = '1' and xl_ten = '0' then</p><p>  if clk1 = '1' and clk1 'event then</

88、p><p>  dis_th <= dr_dh;</p><p>  dis_tl <= dr_dl;</p><p><b>  end if;</b></p><p>  elsif xl_ten = '1' then</p><p>  if clk1 = '

89、1' and clk1 'event then</p><p>  dis_th <= xl_dh;</p><p>  dis_tl <= xl_dl;</p><p><b>  end if;</b></p><p><b>  end if;</b></p&

90、gt;<p>  end process;</p><p>  ----------------------------輸出-----------------------------</p><p>  output:process(dis_th, dis_tl, im, js, cs, dr, wa1, wa2, xl, pwf)</p><p>&

91、lt;b>  begin</b></p><p>  display_th <= dis_th;</p><p>  display_tl <= dis_tl;</p><p>  immersion <= im;</p><p>  water_in <= js;</p><p&

92、gt;  water_out <= cs;</p><p>  dry <= dr;</p><p>  z1 <= wa1;</p><p>  z2 <= wa2;</p><p>  voice <= xl;</p><p>  poweroff <= pwf;</p&g

93、t;<p>  end process;</p><p>  end behave;</p><p><b>  測試文件:</b></p><p>  ------------------------------------------------------------</p><p>  -- VH

94、DL Testbench for washer</p><p>  -- 2010 11 26 21 48 4</p><p>  -- Created by "EditVHDL"</p><p>  -- "Copyright (c) 2002 Altium Limited"</p><p>  --

95、----------------------------------------------------------</p><p>  Library IEEE;</p><p>  Use IEEE.std_logic_1164.all;</p><p>  Use IEEE.std_logic_textio.all;</p>&l

96、t;p>  Use STD.textio.all;</p><p>  ------------------------------------------------------------</p><p>  ------------------------------------------------------------</p><p> 

97、 entity Testwasher is</p><p>  end Testwasher;</p><p>  ------------------------------------------------------------</p><p>  -------------------------------------------------------

98、-----</p><p>  architecture stimulus of Testwasher is</p><p>  file RESULTS: TEXT open WRITE_MODE is "results.txt";</p><p>  procedure WRITE_RESULTS(</p><p> 

99、 alarm: std_logic;</p><p>  clk0: std_logic;</p><p>  clk1: std_logic;</p><p>  display_th: std_logic_vector(3 downto 0);</p><p>  display_tl: std_logic_vector(3 downto

100、 0);</p><p>  dry: std_logic;</p><p>  duoxi: std_logic;</p><p>  immersion: std_logic;</p><p>  poweroff: std_logic;</p><p>  rst: std_logic;</p>&

101、lt;p>  shaoxi: std_logic;</p><p>  voice: std_logic;</p><p>  water_in: std_logic;</p><p>  water_out: std_logic;</p><p>  z1: std_logic;</p><p>  z2: s

102、td_logic;</p><p>  zhongxi: std_logic</p><p><b>  ) is</b></p><p>  variable l_out : line;</p><p><b>  begin</b></p><p>  write(l_o

103、ut, now, right, 15);</p><p>  write(l_out, alarm, right, 2);</p><p>  write(l_out, clk0, right, 2);</p><p>  write(l_out, clk1, right, 2);</p><p>  write(l_out, display

104、_th, right, 5);</p><p>  write(l_out, display_tl, right, 5);</p><p>  write(l_out, dry, right, 2);</p><p>  write(l_out, duoxi, right, 2);</p><p>  write(l_out, immersi

105、on, right, 2);</p><p>  write(l_out, poweroff, right, 2);</p><p>  write(l_out, rst, right, 2);</p><p>  write(l_out, shaoxi, right, 2);</p><p>  write(l_out, voice, ri

106、ght, 2);</p><p>  write(l_out, water_in, right, 2);</p><p>  write(l_out, water_out, right, 2);</p><p>  write(l_out, z1, right, 2);</p><p>  write(l_out, z2, right, 2)

107、;</p><p>  write(l_out, zhongxi, right, 2);</p><p>  writeline(RESULTS, l_out);</p><p>  end procedure;</p><p>  component washer</p><p><b>  port (&

108、lt;/b></p><p>  alarm: in std_logic;</p><p>  clk0: in std_logic;</p><p>  clk1: in std_logic;</p><p>  display_th: out std_logic_vector(3 downto 0);</p><

109、p>  display_tl: out std_logic_vector(3 downto 0);</p><p>  dry: out std_logic;</p><p>  duoxi: in std_logic;</p><p>  immersion: out std_logic;</p><p>  poweroff: ou

110、t std_logic;</p><p>  rst: in std_logic;</p><p>  shaoxi: in std_logic;</p><p>  voice: out std_logic;</p><p>  water_in: out std_logic;</p><p>  water_out

111、: out std_logic;</p><p>  z1: out std_logic;</p><p>  z2: out std_logic;</p><p>  zhongxi: in std_logic</p><p><b>  );</b></p><p>  end compone

112、nt;</p><p>  signal alarm: std_logic;</p><p>  signal clk0: std_logic;</p><p>  signal clk1: std_logic;</p><p>  signal display_th: std_logic_vector(3 downto 0);</p&

113、gt;<p>  signal display_tl: std_logic_vector(3 downto 0);</p><p>  signal dry: std_logic;</p><p>  signal duoxi: std_logic;</p><p>  signal immersion: std_logic;</p>&

114、lt;p>  signal poweroff: std_logic;</p><p>  signal rst: std_logic;</p><p>  signal shaoxi: std_logic;</p><p>  signal voice: std_logic;</p><p>  signal water_in: std

115、_logic;</p><p>  signal water_out: std_logic;</p><p>  signal z1: std_logic;</p><p>  signal z2: std_logic;</p><p>  signal zhongxi: std_logic;</p><p><

116、b>  begin</b></p><p>  DUT:washer port map (</p><p>  alarm => alarm,</p><p>  clk0 => clk0,</p><p>  clk1 => clk1,</p><p>  display_th =

117、> display_th,</p><p>  display_tl => display_tl,</p><p>  dry => dry,</p><p>  duoxi => duoxi,</p><p>  immersion => immersion,</p><p>  pow

118、eroff => poweroff,</p><p>  rst => rst,</p><p>  shaoxi => shaoxi,</p><p>  voice => voice,</p><p>  water_in => water_in,</p><p>  water_ou

119、t => water_out,</p><p><b>  z1 => z1,</b></p><p><b>  z2 => z2,</b></p><p>  zhongxi => zhongxi</p><p><b>  );</b></p

120、><p>  STIMULUS0:process</p><p><b>  begin</b></p><p>  -- insert stimulus here</p><p>  alarm <= '0';</p><p>  duoxi<='0';&

121、lt;/p><p>  zhongxi<='1';</p><p>  shaoxi<='0' ;</p><p>  rst <= '1';</p><p>  wait for 10ns;</p><p>  rst <= '0'

122、;</p><p>  wait for 1000ns;</p><p>  alarm <= '1';</p><p><b>  wait;</b></p><p>  end process;</p><p><b>  process</b>&l

123、t;/p><p><b>  begin</b></p><p>  clk0 <= '1';</p><p>  clk1 <= '1';</p><p>  wait for 1ns;</p><p>  clk0 <= '0';&

124、lt;/p><p>  clk1 <= '0';</p><p>  wait for 1ns;</p><p>  end process;</p><p>  WRITE_RESULTS(</p><p><b>  alarm,</b></p><p&g

125、t;<b>  clk0,</b></p><p><b>  clk1,</b></p><p>  display_th,</p><p>  display_tl,</p><p><b>  dry,</b></p><p><b> 

126、 duoxi,</b></p><p>  immersion,</p><p><b>  poweroff,</b></p><p><b>  rst,</b></p><p><b>  shaoxi,</b></p><p><

127、;b>  voice,</b></p><p><b>  water_in,</b></p><p>  water_out,</p><p><b>  z1,</b></p><p><b>  z2,</b></p><p>&

128、lt;b>  zhongxi</b></p><p><b>  );</b></p><p>  end architecture;</p><p>  ------------------------------------------------------------</p><p>  生成的

129、器件和仿真波形:</p><p><b>  顯示模塊生成程序:</b></p><p>  LIBRARY IEEE;</p><p>  USE IEEE.std_Logic_1164.ALL;</p><p>  ENTITY OUTPUT IS</p><p><b>  POR

130、T</b></p><p>  (R, CP, BUSY :IN Std_Logic;-----使能輸入端,脈沖輸入端,輸入信號忙輸入端--------</p><p>  LINE_OUT,STROBE,RST:OUT STD_LOGIC;------行選擇輸出端,輸入數(shù)據(jù)使能輸出端,復位輸出端---</p><p>  TIME_IN :IN STD

131、_LOGIC_VECTOR(7 DOWNTO 0);--------輸入時間-----------</p><p>  ADDR_OUT :OUT Std_Logic_Vector( 3DOWNTO 0);--------地址輸出端----------</p><p>  DATA_OUT : OUT Std_Logic_Vector(7 DOWNTO 0));-----數(shù)據(jù)輸出端----

132、-----</p><p>  END OUTPUT;</p><p>  ARCHITECTURE XS OF OUTPUT IS</p><p>  TYPE State_type IS(S0,S1,S2,S3,S4);</p><p>  SIGNAL S :State_Type;</p><p>  SIGNA

133、L LCDPT:INTEGER RANGE 0 TO 14;</p><p><b>  BEGIN</b></p><p>  PROCESS(CP,R)</p><p><b>  BEGIN</b></p><p>  IF R='1' THEN</p><

134、p>  S<=S0;LCDPT<=0;RST<='1';</p><p>  ELSIF CP='1' AND CP 'EVENT THEN</p><p><b>  CASE S IS</b></p><p>  WHEN S0=> S<=S1;LCDPT<=

135、0;RST<='1';</p><p>  WHEN S1=> RST<='0';STROBE<='0';</p><p>  IF BUSY='0' THEN</p><p>  LCDPT<=LCDPT+1;</p><p>  IF LCDPT

136、=15 THEN</p><p><b>  S<=S3;</b></p><p><b>  ELSE</b></p><p><b>  S<=S2;</b></p><p><b>  END IF;</b></p><

137、;p><b>  END IF;</b></p><p>  WHEN S2=> S<=S1;STROBE<='1';</p><p>  WHEN S3=> STROBE<='0';</p><p>  IF BUSY='0' THEN</p>

138、<p>  IF LCDPT=16 THEN</p><p>  LCDPT<=15;</p><p><b>  ELSE</b></p><p>  LCDPT<=LCDPT+1;</p><p><b>  END IF;</b></p><p>

139、<b>  S<=S4;</b></p><p><b>  END IF;</b></p><p>  WHEN S4=> STROBE<='1';S<=S3;</p><p>  WHEN OTHERS=> NULL;</p><p><b&g

140、t;  END CASE;</b></p><p><b>  END IF;</b></p><p>  END PROCESS;</p><p>  PROCESS (LCDPT,TIME_IN)</p><p><b>  BEGIN</b></p><p>

141、;  CASE LCDPT IS</p><p>  WHEN 0 => NULL;</p><p>  WHEN 1 => DATA_OUT<="01010111" ; ADDR_OUT<="0000"; LINE_OUT<='0';</p><p>  WHEN 2 =>

142、 DATA_OUT<="01000001" ; ADDR_OUT<="0001"; LINE_OUT<='0';</p><p>  WHEN 3 => DATA_OUT<="01010011" ; ADDR_OUT<="0010"; LINE_OUT<='0'

143、;</p><p>  WHEN 4 => DATA_OUT<="01001000" ; ADDR_OUT<="0011"; LINE_OUT<='0';</p><p>  WHEN 5 => DATA_OUT<="01000101" ; ADDR_OUT<="

144、0100"; LINE_OUT<='0';</p><p>  WHEN 6 => DATA_OUT<="01010010" ; ADDR_OUT<="0101"; LINE_OUT<='0';</p><p>  WHEN 7 => DATA_OUT<="

145、01001111" ; ADDR_OUT<="0111"; LINE_OUT<='0';</p><p>  WHEN 8 => DATA_OUT<="01000110" ; ADDR_OUT<="1000"; LINE_OUT<='0';</p><p&g

146、t;  WHEN 9 => DATA_OUT<="01010000" ; ADDR_OUT<="1010"; LINE_OUT<='0';</p><p>  WHEN 10 => DATA_OUT<="01001001" ; ADDR_OUT<="1011"; LINE_OU

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經(jīng)權益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
  • 6. 下載文件中如有侵權或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論