電子技術課程設計 字符發生器_第1頁
電子技術課程設計 字符發生器_第2頁
電子技術課程設計 字符發生器_第3頁
電子技術課程設計 字符發生器_第4頁
電子技術課程設計 字符發生器_第5頁
已閱讀5頁,還剩14頁未讀 繼續免費閱讀

下載本文檔

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

文檔簡介

1、電子技術課程設計 -16X16字符發生器學 院 : 專 業 :班 級 :姓 名 : 學 號 :指導教師 : 16X16字符發生器一設計任務及要求1.設計任務:利用實驗箱上16X16點陣,設計字符發生器,可以循環顯 示預置字符:同心協力 發奮向上。 2.設計要求:(1)利用VHDL編寫字符掃描驅動電路; (2)設計一個可以自動循環顯示8個字符的電路; 3編寫預置字符的rom程序生成模塊接入電路。 行選線產生信號發光二極管顯示屏列選線產生電路EPROM存儲器地址計數器時鐘脈沖源設計思路:此電路由八進制計數器,ROM和ADDRESS1這三局部構成。ADDRESS1的作用是在時鐘clk的作用下將從ro

2、m中讀出的信號對應正確的寫在1616的點陣上。Reset是復位端,起復位作用。輸出addr4.1選中16X16LED點陣的對應列,隨著addr4.1值得增加,從左往右依次選中點陣的各列addr0那么決定輸出是在高位還是在低位。FLEX10的lout0-7和hout0-7分別與LED點陣的低八位L0-7和高八位L8-15相連。八進制計數器是在addr7.0輸出0-7的循環計數,由此輸出與ADDRESS1的輸出addr4.0共同作為rom的輸入地址,以此決定q7.0的輸出即ADDRESS1的DIN7.0的輸入,此八進制計數器是由74LS160十進制計數器修改得來的,輸出由原來十進制的0-9循環輸出

3、變為八進制的0-7循環輸出。Rom是一個用來存儲數據的具有讀寫功能的的存儲器,在此電路中的作用是存儲“同心協力 發奮向上八個字.在addr7.0輸入相應的地址時讀取rom中的相應的數據,然后在輸出端q7.0輸出。在時鐘脈沖的作用下,地址計數器計數,EPROM相對應的地址單元中的代碼輸出,以驅動列選通線產生電路。地址計數器同時又為行選通線產生電路。地址隨著地址計數器計數值的變化,發光二極管顯示屏逐行掃描,顯示屏上顯示出字符或圖案。各模塊功能:1) ROM是只讀存儲器存放字符的代碼, 他是字符顯示器的核心部件。2發光二極管顯示屏用來顯示字符或圖案,他是由假設干發光二極管組成的點陣式顯示屏。 3)

4、ADDRESS1的作用是在時鐘clk的作用下將從ROM259*8中讀出的信號對應正確的寫在1616的點陣上。選擇器件與功能模塊用來構成輸出八進制的74LS160十進制計數器.74LS160器件圖 B.C.D 為輸入端; LDN為置數端;ENT與ENP為使能控制端;CLRN為置零端; RCO為進位輸出端; QA.QB.QC.QD為輸出端;CLK為脈沖信號輸入端.(2). 74160內部結構圖3.74160功能表CPCLRN(RD非)LDN(LD非) EP ET工作狀態X0X X X置零10 X X預置數X11 0 1保持X11 X 0保持(C=0)11 1 1計數(4).八進制計數器真值表CPQ

5、3Q2Q1Q000000100012001030011401005010160110701115用74160構成的8進制計數器原理圖6.八進制計數器時序仿真圖仿真分析:由仿真圖分析可知,輸出a,b,c將從000一直變化到111,即一個脈沖周期結束返回,由此可證明此接法正確為八進制計數器.2說明: CLK為時鐘輸入端口; RESER為置零端; DIN7.0為接受ROM數據信號端口; AD4.0為片選地址輸出; HOUT7.0,LOUT7.0分別為高八位斷驅動和低八位短驅動.Address1設計程序:LIBRARY IEEE;USE IEEE.std_logic_1164.ALL;USE IEEE

6、.std_logic_unsigned.ALL;ENTITY address1 ISPORT( clk,reset:IN STD_LOGIC; ad :OUT STD_LOGIC_VECTOR(4 downto 0); din:in STD_LOGIC_VECTOR(7 DOWNTO 0); hout,lout:out STD_LOGIC_VECTOR(7 downto 0);END address1;ARCHITECTURE a OF address1 ISBEGIN process(clk,din,reset) VARIABLE Q1:STD_LOGIC_VECTOR(4 DOWNTO 0

7、); BEGIN IF CLKEVENT AND CLK=1THEN IF RESET=0OR(Q1=11111)THEN Q1:=00000; ELSE Q1:=Q1+1; END IF; END IF; CASE Q1(0)IS WHEN 0= LOUT=din; HOUT0); WHEN 1= HOUT=din; LOUT0); WHEN OTHERS= null; END CASE; ad=Q1; END PROCESS;END a;模塊功能:地址選擇器包含行選線產生電路和列選線產生電路,從ROM中選擇相應的地址輸出。Clk為掃描時鐘脈沖,控制掃描速度的快慢;RESET為復位端,只有在

8、RESET為高電平的情況下,在脈沖上升沿到來時,ad計數,其中ad4.1輸出掃描驅動信號,接入掃描片選端,依次選中LED點陣的各列,din輸入字符存儲器中每個存儲單元的數據,hout7.0控制LED點陣的高八位lout7.0 控制LED點陣的低八位,din中存儲器中調用的數據模塊分別由hout7.0或lout7.0輸出,在LED點陣中經掃描顯示字符。仿真圖: 3.用來存儲字符的ROM256X8存儲器ROM的說明 在設計ROM時,根據ROM的大小,我們可以采用不同的設計方法進行設計,比方4x8,8x8或256x8的ROM可以采用數組描述或WHEN-ELSE.然而數組描述ROM在面積上是最有效的,

9、在用數組描述時,常把數組常量的ROM放在一個程序包中,這種方法可以提供ROM的重用,在程序包中應當用常量定義ROM的大小.而用WHEN-ELSE描述一個ROM,它確實是最直觀的,它是類似查表的方法來設計的,本次設計就是一個用WHEN-ELSE設計的256x8的ROM.(2).存入ROM中的數據(文本格式.mif)width=8;depth=256;address_radix=hex;data_radix=hex;content begin00:00;01:00;02:fe;03:ff;04:02;05:00;06:02;07:00; -tong08:92;09:3f;0a:92;0b:10;0

10、c:92;0d:10;0e:92;0f:10;10:92;11:10;12:92;13:10;14:92;15:10;16:da;17:3f;18:02;19:40;1a:02;1b:80;1c:ff;1d:7f;1e:02;1f:00;20:00;21:00;22:00;23:00;24:00;25:04;26:00;27:02; -xin28:c0;29:01;2a:00;2b:00;2c:f0;2d:3f;2e:01;2f:40;30:02;31:40;32:1c;33:40;34:08;35:40;36:00;37:07; 38:00;39:70;3a:80;3b:00;3c:80;3

11、d:00;3e:00;3f:07;40:10;41:00;42:10;43:00;44:ff;45:ff;46:10;47:00; -xie 48:10;49:04;4a:80;4b:03;4c:00;4d:40;4e:10;4f:20;50:10;51:1c;52:ff;53:03;54:10;55:00;56:10;57:40; 58:10;59:80;5a:f8;5b:7f;5c:90;5d:00;5e:00;5f:03;60:10;61:80;62:10;63:80;64:10;65:80;66:10;67:60; -li 68:10;69:18;6a:ff;6b:07;6c:10;6

12、d:00;6e:10;6f:00;70:10;71:00;72:10;73:00;74:10;75:20;76:10;77:40; 78:10;79:80;7a:10;7b:40;7c:f8;7d:3f;7e:10;7f:00;80:08;81:01;82:08;83:01;84:08;85:01;86:99;87:00; -fen88:88;89:ff;8a:ff;8b:49;8c:28;8d:49;8e:18;8f:49;90:0f;91:7f;92:18;93:49;94:28;95:49;96:48;97:49; 98:88;99:ff;9a:88;9b:00;9c:8c;9d:01;

13、9e:88;9f:00;a0:10;a1:40;a2:10;a3:20;a4:18;a5:90;a6:16;a7:88; -faa8:10;a9:46;aa:90;ab:41;ac:f0;ad:23;ae:9f;af:14;b0:90;b1:08;b2:90;b3:14;b4:92;b5:22;b6:94;b7:21; b8:10;b9:40;ba:10;bb:c0;bc:18;bd:40;be:10;bf:00;c0:f8;c1:ff;c2:08;c3:00;c4:08;c5:00;c6:cc;c7:1f; -xiang c8:4a;c9:08;ca:49;cb:08;cc:48;cd:08

14、;ce:48;cf:08;d0:48;d1:08;d2:48;d3:08;d4:48;d5:08;d6:e8;d7:1f; d8:48;d9:40;da:08;db:80;dc:fc;dd:7f;de:08;df:00; e0:00;e1:80;e2:00;e3:80;e4:00;e5:80;e6:00;e7:80; -shang e8:00;e9:80;ea:00;eb:80;ec:00;ed:80;ee:ff;ef:ff;f0:20;f1:80;f2:20;f3:80;f4:20;f5:80;f6:30;f7:80;f8:20;f9:80;fa:00;fb:80;fc:00;fd:c0;f

15、e:00;ff:80;end;由VHDL編譯生成的ROM256X8存儲器圖 1616掃描LED點陣的工作原理同8位掃描數碼管類似。它有16個共陰極輸出端口,每個共陰極對應有16個LED顯示燈。所以其掃描譯碼地址需4位信號線。 2864E2PROM存貯器是電可擦除/編程的只讀存貯器,容量為8k8bit ,有13位并行地址線和8位并行數據線,而一個完整的字符所需的存貯容間為32字節即328 bit,也就是說2864最多可連續存256個1616點陣字形。存貯方式可事先約定好.ROM仿真圖仿真分析:從仿真結果可得:00:20; 01:80; 02:20; 03:40;04:20;05:20;06:20

16、.與ROM的程序中的地址和信息是對應的,由此可知此模塊是正確的,可以使用。五.總體設計電路圖 1.工作情況:將74LS160十進制計數器變為了八進制的計數器。在輸入clk1的作用下在輸出端輸出000-111的地址數據。八進制輸出的地址數據與ADDRESS1的輸出addr4.0共同作為了存儲器ROM的地址輸入。此輸入地址選定了存儲器中在該地址上存儲的數據。然后將數據在存儲器的輸出端q7.0輸出。存儲器的輸出作用下輸出的addr4.1決定了輸出結果在1616的點陣上列循環掃描。而addr0那么決定著輸出在1616的點陣上的行掃描,也即輸出時在低位lout還是在高位hout。 總體上說來就是計數器提

17、供局部地址,而ROM是一個字符的存儲庫,ADDRESS1那么是決定著要輸出的字符如何在1616的點陣上掃描輸出。 2.模塊間的連接關系:計數器的輸出連接在 ROM2598的地址輸入端,ROM2598的輸出q7.0連接在 ADDRESS1的din7.0端。 ADDRESS1的輸出addr4.0又回到了ROM2568的地址輸入端。1.時序仿真結果仿真分析:RESET接低電平;CLK1為CLK的10倍,當CLK1第一個上升沿未到來時,列選信號輸出端為00,即點陣第一列選通,此時LED低八位L7L4為1110十六進制為E,L3L0為0000十六進制為0;LED高八位L15L12為0000十六進制為0,

18、L11L8為0000十六進制為0.由此可推斷模擬結果符合設計要求.管腳分配圖3實驗連線管腳編號管腳定義管腳編號管腳定義22Clk39hout423Clk147hout524reset48hout625addr049hout727addr150lout028addr251lout129addr352lout230addr453lout335hout054lout436hout158lout537hout259lout638hout360lout7 clk驅動器ADDRESS1時鐘信號輸入端,頻率f=500hzClk1計數器74160時鐘信號輸入端.頻率F=5KHZreset驅動器ADDRESSS

19、1置零端,低電平有效Lout7.0點陣低八位數據輸入端Hout7.0點陣高八位數據輸入端Addr4.0點陣列選地址控制端將CLK1端接時鐘輸出,并使輸入頻率約為8KHZ,CLK端接輸入頻率約為100HZ的時鐘信號; addr4.0接顯示模塊的SEL0,SEL1,SEL2,SEL3;LOUT7.0和HOUT7.0分別與LED輸入端L15-L0的低8位和高8位L8L15相連.連接好后翻開開關,接上連接線進行下載。實驗完成后,led點陣隨著clk1的變化逐次顯示“同心協力 發奮向上 八個大字。六心得體會 通過本次課程設計我感觸很深,這是我做的第一次課程設計,從開始到結束到是在匆匆忙忙的生活中度過的,在這三個星期的日子里,可以說是苦多于甜,但是可以學的到很多很多的東西,同時不僅可以穩固以前所學過的知識,而且學到了很

溫馨提示

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

評論

0/150

提交評論