EDA自動售貨機設計
《EDA自動售貨機設計》由會員分享,可在線閱讀,更多相關《EDA自動售貨機設計(24頁珍藏版)》請在裝配圖網(wǎng)上搜索。
1、 摘 要 人類社會已進入到高度發(fā)達的信息化社會, 信息社會的發(fā)展離不開電子產品的進步?,F(xiàn)代電子產品在性能提高、復雜度增大的同時,價格卻一直呈下降趨勢,而且產品更新?lián)Q代的步伐也越來越快, 實現(xiàn)這種進步的主要原因就是生產制造技術和電子設計技術的發(fā)展。 自動售貨是 20 世紀 70 年代在日本、 歐美發(fā)展起來的一種全新的消費方式, 自動售貨機又被稱為 24 小時營業(yè)的微型自助超市,它的售貨領域非常廣泛,是發(fā)達國家 商品零售的一種主要方式。 本設計要實現(xiàn)自動售貨機的基本功能, 如投幣處理、 商品 選擇、購貨撤銷、異常退幣、計算存貨等
2、功能。采用 VHDL硬件描述語言編程的設計 方法設計系統(tǒng)核心電路的硬件程序,與一般的軟件開發(fā)不同, VHDL 編程更需要熟悉 一些底層的硬件知識,特別是數(shù)字邏輯電路的設計,因此 VHDL編程的方法、思路都要更多的與硬件電路聯(lián)系起來。 完成系統(tǒng)各個功能模塊的硬件程序設計后, 在軟件平 臺上進行編譯和電路仿真,最后生成的目標文件下載到實驗臺內的 FPGA芯片以實現(xiàn)該系統(tǒng),并在實驗臺上對設計進行驗證。 關鍵字 :自動售貨機 ;VHDL編程;編譯;電路仿真 Abstract Human society has en
3、tered into a highly developed information community, social development of information on electronic products progress. the modern electronic products in the performance, the increased complexity of the same time, the price has been a downward trend, and the pace of product faster and faster, the re
4、alization of this progress is that of manufacturing technology and electronic design of technology. The coin is in the 70s of 20th century in japan, and develop a new and vending machine is called open 24 hours in the cafeteria, it is very widespread area of sale in retail in the developed countr
5、ies, is a major way. this is designed to enable automatic machines in the basic functionality, such as a coin, choose and purchases of goods, money is retired, stock and functions. Complete system of the various functional modules of hardware, software design process in the compilation and circuit e
6、mulation, the target file download to the test stand in the chip to implement the system fpga, and on the stage of design validation. Keywords: Vending machine; Vhdl programming ; Compilation ; Circuit simulation - 1 - 目
7、 錄 引言 ........................................................... - 3 - 1 EDA技術簡介 ................................................. - 10 - 1.1 EDA 技術的發(fā)展概況 ..................................... - 10 - 1.2 EDA 技術的基本特征 ..................................... - 10 - 1.2.1 “自頂向下”的設計方法 ....
8、........................ - 11 - 1.2.2 高層次設計 ........................................ - 11 - 2 工作原理 ..................................................... - 11 - 2. 1 任務概述 .............................................. - 11 - 2.2 系統(tǒng)設計 - 12 - 2.3 系統(tǒng)組成方框圖 ...........................
9、.............. - 12 - 2.4 工作過程 ............................................... - 12 - 3 設計方案 ..................................................... - 13 - 3.1 自動售貨機 VHDL程序 .................................... - 13 - 3.2 各功能部件系統(tǒng)仿真圖 ................................... - 16 - 結 論 .......
10、................................................. - 19 - 參考文獻 ...................................................... - 20 - - 2 -
11、 引言 自動售貨機能夠根據(jù)投入錢幣自動收貨的機器,是商業(yè)自動化的常用設備。不受 時間、地點的限制,能節(jié)省人力物力。 現(xiàn)代售貨機的功能、 結構根據(jù)商品的種類而異。 貨幣裝置時售貨機的核心, 其主要功能是確認投入幣數(shù)及面值, 計算余額,找兌余額。 因此,自動售貨機在商業(yè),食品業(yè)越來越普及,更方便消費者購買自己所需的商品。 使用方便、可靠、節(jié)省人力的自動售貨機將在社會生活中成為一種趨勢。 新 浪 騰訊 ?QQ 空間搜 狐 網(wǎng) 易 谷 歌 鳳 凰 網(wǎng)新 浪微博 新 華 網(wǎng) 人
12、 民 網(wǎng)中國移動 中國政府網(wǎng) 人 人 網(wǎng)開 心 網(wǎng) 天涯社區(qū) 汽車之家 4399 游戲太平洋電腦 東方財富 中華英才網(wǎng) 中 彩 網(wǎng) 賽 爾 號智聯(lián)招聘 攜程旅行網(wǎng) CNTV 中國電信 58 同城 淘 寶 網(wǎng)湖南衛(wèi)視 大眾點評網(wǎng) 工商銀行 凡客誠品 中關村在線 國美電器 易 車 網(wǎng) 去哪兒網(wǎng) 京東商城 蘇寧易購 新功能 刷卡購物功能: 在網(wǎng)絡環(huán)境支持情況下,具備多種電子支付功能,如信用卡、儲值卡、手機卡等刷卡消費。 多種貨幣識別功能:
13、電控系統(tǒng)可以配合紙幣、硬幣識別器增加代金券功能,可以識別紙質和硬幣類型的代金券。 數(shù)據(jù)下載功能: 應用 USB技術,使用一個優(yōu)盤,就能輕松下載售貨機的運營信息,然后使用 PC機對下載的 數(shù)據(jù)進行處理,便于運營商掌握不同地區(qū)、不同機器、不同商品的售賣情況。 - 3 - 無線網(wǎng)絡運營管理功能: 將自動售貨機當前運營的數(shù)據(jù),包括系統(tǒng)狀態(tài)、系統(tǒng)故障、料道故障、缺貨情況、銷售數(shù)據(jù) 通過安裝在自動售貨機上的 GPRS模塊無線傳輸?shù)绞圬洐C網(wǎng)絡服務器,運營人員可以在任何一臺 聯(lián)網(wǎng)的電腦上掌握售貨機的這些
14、信息,實現(xiàn)自動售貨機的大規(guī)模運營和網(wǎng)絡化管理。 EDA技術是以計算機為工具完成數(shù)字系統(tǒng)的邏輯綜合、布局布線和設計仿真等工 作。電路設計者只需要完成對系統(tǒng)功能的描述,就可以由計算機軟件進行系統(tǒng)處理, 最后得到設計結果, 并且修改設計方案如同修改軟件一樣方便。 利用 EDA工具可以極大地提高設計效率。 利用硬件描述語言編程來表示邏輯器件及系統(tǒng)硬件的功能和行為, 是 EDA設計方法的一個重要特征。 VHDL(Very High Speed Integrated Circuit Hardware Description La
15、nguage,超高速集成電路硬件描述語言)是硬件描述語言的一種,對系統(tǒng)硬件的描述功能很強而語法又比較簡單。 VHDL具有強大的行為描述能力,設計者可以不懂硬件的結構, 只需集中精力進行電子系統(tǒng)的設計和性能優(yōu)化; 具有方便的邏輯仿真與調試功能, 在設計早期就能查驗系統(tǒng)的功能, 方便地比較各種方案的可行性及其優(yōu)劣。目前, VHDL作為 IEEE 的工業(yè)標準硬件描述語言,得到眾多 EDA公司的支持,在電子工程領域已經(jīng)成為事實上通用硬件描述語言。 本文采用 VHDL作為工具描述了自動售貨機控制模塊的邏輯控制電路, 并在 FPGA 上實現(xiàn)。該自動售貨機能夠根據(jù)投入硬幣額度, 按預定的要求在投入
16、硬幣大于規(guī)定值 時送出飲料并找零。 設計方案 本文所設計的簡易自動售貨機可銷售礦泉水,假設每瓶 1.5 元。設兩個投幣孔,分別接收 1 元和 5 角兩種硬幣, 兩個輸出口, 分別輸出購買的商品和找零。 假設每次只能投入一枚 1 元或 5 角硬幣,投入 1 元 5 角硬幣后機器自動給出一瓶礦泉水; 投入 2 元硬幣后,在給出一瓶礦泉水的同時找回一枚 5 角的硬幣。另外設置一復位按鈕,當復位按鈕按下時,自動售貨機回到初始狀態(tài)。 開發(fā)軟件選用功能強大的 Altera 公司的最新可編程邏輯器件開發(fā)工具 Quartus II 8.0 ,實現(xiàn)芯片選用 Alt
17、era 公司 FLEX10K系列的 EPF10K10LC84-;4首先在計算機上完成程序設計、 編譯及時序仿真, 然后將經(jīng)過驗證的設計文件下載到選擇的可編程邏輯器件中,并在電子設計自動化實驗系統(tǒng)中進行硬件模擬和測試。 狀態(tài)機 VHDL程序設計 - 4 - 0 表示不輸出貨物或不找零。 有限狀態(tài)機 FSM( Finite State Machine )及其設計技術是實用數(shù)字系統(tǒng)設計中實現(xiàn)高效率、高可靠邏輯控制的重要途徑。 傳統(tǒng)的狀態(tài)機設計方法需進行繁瑣的狀態(tài)分配、繪制狀態(tài)表、簡化次態(tài)方程等,而利用 VHDL可以避免這些煩瑣的
18、過程,直接利用狀態(tài)轉換圖進行狀態(tài)機的描述。此外,與 VHDL的其他描述方式相比,狀態(tài)機的VHDL表述豐富多樣,程序層次分明,結構清晰,易讀易懂;在排錯、修改和模塊移植方面也有其獨到的特點。 狀態(tài)機有摩爾( Moore)型和米立( Mealy)型兩種。 Moore 型狀態(tài)機的輸出信號只與當前狀態(tài)有關; Mealy 型狀態(tài)機的輸出信號不僅與當前狀態(tài)有關,還與輸入信號有關。結合本文設計, 由于輸出僅與狀態(tài)有關, 選用了 Moore 型狀態(tài)機設計自動售貨機控制模塊,狀態(tài)轉換圖如圖 1 所示。 圖 1 自動售貨機狀態(tài)轉換圖 1)狀態(tài)定義: S0 表示初態(tài)
19、, S1 表示投入 5 角硬幣, S2 表示投入 1 元硬幣, S3 表示投入 1 元 5 角硬幣, S4 表示投入 2 元硬幣。 2)輸入信號:取投幣信號為輸入邏輯變量,用兩位的矢量 state_inputs 表示。 state_inputs (0)表示投入 1 元硬幣, state_inputs ( 1)表示投入 5 角硬幣。輸入信號為 1 表示投入硬幣,輸入信號為 0 表示未投入硬幣。 3)輸出信號:給出礦泉水和找零為兩個輸出變量,用兩位的矢量 comb_outputs 表示。 comb_outputs( 0)表示輸出貨物, comb_outputs( 1)表示找 5
20、 角零錢。輸出 信號為 1 表示輸出貨物或找零,輸出信號為 EDA技術是以計算機為工具完成數(shù)字系統(tǒng)的邏輯綜合、 布局布線和設計仿真等工作。電路設計者只需要完成對系統(tǒng)功能的描述,就可以由計算機軟件進行系統(tǒng)處理, 最后得到設計結果, 并且修改設計方案如同修改軟件一樣方便。 利用 EDA工具可以極大地提高設計效率。 利用硬件描述語言編程來表示邏輯器件及系統(tǒng)硬件的功能和行為, 是 EDA設計方法的一個重要特征。 VHDL(Very High Speed Integrated Circuit Hardware Description Language,超高速集成電路
21、硬件描述語言)是硬件描述語言的一種,對系統(tǒng)硬件的描述功能很強而語法又比較簡單。 VHDL具有強大的行為描述能力,設計者可以不懂硬件的結構, 只需集中精力進行電子系統(tǒng)的設計和性能優(yōu)化; 具有方便的邏輯仿真與調試功能, 在設計早期就能查驗系統(tǒng)的功能, 方便地比較各種方案的可行性及其優(yōu)劣。目前, VHDL作為 IEEE 的工業(yè)標準硬件描述語言,得到眾多 EDA公司的支持,在電子工程領域已經(jīng)成為事實上通用硬件描述語言。 本文采用 VHDL作為工具描述了自動售貨機控制模塊的邏輯控制電路, 并在 FPGA 上實現(xiàn)。該自動售貨機能夠根據(jù)投入硬幣額度, 按預定的要求在投入硬幣大于規(guī)定值時送出飲料并找
22、零。 - 5 - 設計方案 本文所設計的簡易自動售貨機可銷售礦泉水,假設每瓶 1.5 元。設兩個投幣孔, 分別接收 1 元和 5 角兩種硬幣, 兩個輸出口, 分別輸出購買的商品和找零。 假設每次只能投入一枚 1 元或 5 角硬幣,投入 1 元 5 角硬幣后機器自動給出一瓶礦泉水; 投入 2 元硬幣后,在給出一瓶礦泉水的同時找回一枚 5 角的硬幣。另外設置一復位按鈕,當復位按鈕按下時,自動售貨機回到初始狀態(tài)。 開發(fā)軟件選用功能強大的 Altera 公司的最新可編程邏輯器件開發(fā)工具 Quartus II 8.0 ,
23、實現(xiàn)芯片選用 Altera 公司 FLEX10K系列的 EPF10K10LC84-;4首先在計算機上完成程序設計、 編譯及時序仿真, 然后將經(jīng)過驗證的設計文件下載到選擇的可編程邏輯器件中,并在電子設計自動化實驗系統(tǒng)中進行硬件模擬和測試。 狀態(tài)機 VHDL程序設計 有限狀態(tài)機 FSM( Finite State Machine )及其設計技術是實用數(shù)字系統(tǒng)設計中實現(xiàn)高效率、高可靠邏輯控制的重要途徑。 傳統(tǒng)的狀態(tài)機設計方法需進行繁瑣的狀態(tài)分配、繪制狀態(tài)表、簡化次態(tài)方程等,而利用 VHDL可以避免這些煩瑣的過程,直接利用狀態(tài)轉換圖進行狀態(tài)機的描述。此外,與 VHDL的其他描述方式
24、相比,狀態(tài)機的VHDL表述豐富多樣,程序層次分明,結構清晰,易讀易懂;在排錯、修改和模塊移植方面也有其獨到的特點。 狀態(tài)機有摩爾( Moore)型和米立( Mealy)型兩種。 Moore 型狀態(tài)機的輸出信號只與當前狀態(tài)有關; Mealy 型狀態(tài)機的輸出信號不僅與當前狀態(tài)有關,還與輸入信號有關。結合本文設計, 由于輸出僅與狀態(tài)有關, 選用了 Moore 型狀態(tài)機設計自動售貨機控制模塊,狀態(tài)轉換圖如圖 1 所示。 圖 1 自動售貨機狀態(tài)轉換圖 1)狀態(tài)定義: S0 表示初態(tài), S1 表示投入 5 角硬幣, S2 表示投入 1 元硬幣, S3 表示投入
25、 1 元 5 角硬幣, S4 表示投入 2 元硬幣。 2)輸入信號:取投幣信號為輸入邏輯變量,用兩位的矢量 state_inputs 表示。 state_inputs (0)表示投入 1 元硬幣, state_inputs ( 1)表示投入 5 角硬幣。輸入信號為 1 表示投入硬幣,輸入信號為 0 表示未投入硬幣。 3)輸出信號:給出礦泉水和找零為兩個輸出變量,用兩位的矢量 comb_outputs 表示。 comb_outputs( 0)表示輸出貨物, comb_outputs( 1)表示找 5 角零錢。輸出信號為 1 表示輸出貨物或找零,輸出信號為 0 表示不輸出貨物或
26、不找零。 根據(jù)圖 1 所示的狀態(tài)轉換圖,用 VHDL中的 CASE_WHEN結構和 IF_THEN_ELSE語句實現(xiàn)控制功能,源程序如下: - 6 - LIBRARY IEEE; -- 庫和程序包的使用說明 USE IEEE.STD_LOGIC_1164.ALL; ENTITY sellmachine IS -- 實體定義 PORT(clk , reset : IN std_logic; state_inputs:IN std_logic_vector ( 0 TO 1 ); comb
27、_outputs:OUT std_logic_vector (0 TO 1 )) ; END sellmachine; ARCHITECTURE state OF sellmachine IS -- 結構體 TYPE fsm_st IS ( S0,S1, S2,S3,S4) ; -- 狀態(tài)枚舉類型定義 SIGNAL current_state , next_state:fsm_st; -- 狀態(tài)信號的定義 BEGIN reg:PROCESS(reset ,clk ) -- 時序進程 BEGIN IF reset= ‘1’
28、 THEN current_state 《 =S0; -- 異步復位 ELSIF rising_edge (clk ) THEN current_state 《=next_state; -- 狀態(tài)轉換 END IF; END PROCESS; corn:PROCESS( current_state ,state_inputs ) -- 組合進程 BEGIN CASE current_state IS WHEN S0=》comb_outputs 《=“00”; -- 現(xiàn)態(tài) S0 IF state_i
29、nputs 《=“00” THEN next_state 《 =S0; -- 輸入不同,次態(tài)不同 - 7 - ELSIF state_inputs 《=“01” THEN next_state 《 =S1; ELSIF state_inputs 《=“10” T HEN next_state 《=S2; END IF; WHEN S1=》comb_outputs 《=“00”; -- 現(xiàn)態(tài) S1 IF state_inputs 《=“00” THEN next_state 《 =S1;
30、 -- 輸入不同,次態(tài)不同 ELSIF state_inputs 《=“01” THEN next_state 《 =S2; ELSIF state_inputs 《=“10” THEN next_state 《 =S3; END IF; WHEN S2=》comb_outputs 《=“00”; -- 現(xiàn)態(tài) S2 IF state_inputs 《=“00” THEN next_state 《 =S2; -- 輸入不同,次態(tài)不同 ELSIF state_inputs 《=“01” THEN next_state 《 =S3;
31、 ELSIF state_inputs 《=“10” THEN next_state 《 =S4; END IF; WHEN S3=》comb_outputs 《=“10”; -- 現(xiàn)態(tài) S3 IF state_inputs 《=“00” THEN next_state 《 =S0; -- 輸入不同,次態(tài)不同 ELSIF state_inputs 《=“01” THEN next_state 《 =S1; ELSIF state_inputs 《=“10” THEN next_state 《 =S2; END IF;
32、 WHEN S4=》comb_outputs 《=“11”; -- 現(xiàn)態(tài) S4 IF state_inputs 《=“00” THEN next_state 《 =S0; -- 輸入不同,次態(tài)不同 ELSIF state_inputs 《=“01” THEN next_state 《 =S1; ELSIF state_inputs 《=“10” THEN next_state 《 =S2; END IF; - 8 - END CASE; END PROCESS; E
33、ND state; 編譯、仿真及 FPGA實現(xiàn) 在 Altera 公司的可編程邏輯器件集成開發(fā)平臺 Quartus II 8.0 下完成程序的編輯、編譯并進行時序仿真。 1)編譯:編譯是 EDA設計中的核心環(huán)節(jié)。 軟件將對設計輸入文件進行邏輯化簡、綜合和優(yōu)化, 適當?shù)赜靡黄蚨嗥骷M行適配,最后產生編程用的編程文件。主要包括設計編譯和檢查、邏輯優(yōu)化和綜合、適配和分割、布局和布線、生成編程數(shù)據(jù)文件等過程。自動售貨機控制模塊 VHDL文件編譯報告如圖 2 所示。 圖 2 編譯報告 報告中給出了進行編譯的時間、 采用的開發(fā)軟件的
34、版本、 頂層設計實體名、 選用器件的系列和型號、時序分析情況、占用資源情況及引腳使用情況等信息。 2)時序仿真:編譯后對系統(tǒng)和各模塊進行時序仿真,分析其時序關系,估計設 計的性能及檢查和消除競爭冒險是非常有必要的。 仿真前,先利用波形編輯器建立波 形文件,仿真結果將會生成報告文件和輸出信號波形, 從中便可以觀察到各個節(jié)點的 信號變化。若發(fā)現(xiàn)錯誤, 則返回設計輸入中修改設計邏輯。 自動售貨機控制模塊仿真 波形如圖 3 所示。 圖 3 時序仿真波形 3) FPGA實現(xiàn):將編譯階段生成的編程數(shù)據(jù)文件通過 Quartus II
35、下載到芯片EPF10K10LC84-4中,并在電子設計自動化實驗系統(tǒng)中進行測試得到了正確的結果。 - 9 - 基于 EDA的自動售貨機的控制系統(tǒng) 1 EDA 技術簡介 EDA( Electronic Design Automation ),即電子設計自動化,是指利用計算機
36、完 成電子系統(tǒng)的設計。 EDA技術是以計算機和微電子技術為先導的,匯集了計算機圖形 學、拓撲學、邏輯學、微電子工藝與結構學和計算數(shù)學等多種計算機應用學科最新成 果的先進技術。 EDA技術以計算機為工具,代替人完成數(shù)字系統(tǒng)的邏輯綜合、布局布線和設計仿真等工作。 設計人員只需要完成對系統(tǒng)功能的描述, 就可以由計算機軟件進行處理,得到設計結果, 而且修改設計如同修改軟件一樣方便, 可以極大地提高設 計效率 [1] 。 1.1 EDA 技術的發(fā)展概況 從 20 世紀 60 年代中期開始, 人們就不斷開發(fā)出各種計算機輔助設計工具來幫助設計人員進行電子系統(tǒng)的
37、設計。 電路理論和半導體工藝水平的提高, 對 EDA技術的發(fā)展起到了巨大的作用,使 EDA作用范圍從 PCB板設計延伸到電子線路和集成電路設計,直至整個系統(tǒng)的設計,也使 IC 芯片系統(tǒng)應用、電路制作和整個電子生產過程都集成 在一個環(huán)境之中。 根據(jù)電子設計技術的發(fā)展特征, EDA技術發(fā)展大致分為三個階段 [2] 。 1.2 EDA 技術的基本特征 EDA技術代表了當今電子設計技術的最新發(fā)展方向,它的基本特征是:設計人員 按照“自頂向下”的設計方法,對整個系統(tǒng)進行方案設計和功能劃分,系統(tǒng)的關鍵電 - 10 -
38、路用一片或幾片專用集成電路( ASIC)實現(xiàn),然后采用硬件描述語言( HDL)完成系 統(tǒng)行為級設計,最后通過綜合器和適配器生成最終的目標器件 [3] 。這樣的設計方法被 稱為高層次的電子設計方法。下面介紹與 EDA基本特征有關的幾個概念。 1.2.1“自頂向下”的設計方法 10 年前,電子設計的基本思路還是選擇標準集成電路“自底向上” (Bottom-Up)地構 造出一個新的系統(tǒng),這樣的設計方法就如同一磚一瓦地建造金字塔,不僅效率低、成本高而且還容易出錯。 1.2.2 高層次設計 高層次設計提供了一種“自頂向下” (Top-Down)的全新的
39、設計方法,這種設計方法首先從系統(tǒng)設計入手, 在頂層進行功能方框圖的劃分和結構設計。 在方框圖一級進行仿真、糾錯,并用硬件描述語言對高層次的系統(tǒng)行為進行描述, 在系統(tǒng)一級進行驗證。然后用綜合優(yōu)化工具生成具體門電路的網(wǎng)表, 其對應的物理實現(xiàn)級可以是印刷電路板或專用集成電路。 由于設計的主要仿真和調試過程是在高層次上完成的, 這不僅有利于早期發(fā)現(xiàn)結構設計上的錯誤, 避免設計工作的浪費, 而且也減少了邏輯功能仿真的工作量,提高了設計的一次成功率。 2 工作原理 2. 1 任務概述 自動售貨是 20 世紀 70 年代在日本、 歐美發(fā)展起來的一種全新的消費方式, 自
40、動售貨機又被稱為 24 小時營業(yè)的微型自助超市,它的售貨領域非常廣泛,是發(fā)達國家 商品零售的一種主要方式。 自動售貨機作為一種先進的消費方式, 已經(jīng)成為城市現(xiàn)代文明發(fā)達程度的重要標志,其新穎、時尚的購物方式, 24 小時營業(yè)的特點給人們生活帶來了便利, 美化了城市環(huán)境, 受到消費者的歡迎。 但是在我國自動售貨機的普及還不及發(fā)達國家, 主要原因是我國 EDA技術的應用水平長期落后于發(fā)達國家。 本設計要實現(xiàn)自動售貨機的基本功能,可以實現(xiàn)投幣處理、計算投幣總額、輸出商品、輸出 找零的控制。 - 11 -
41、 2.2 系統(tǒng)設計 設計一臺自動售貨機 ,要求具備貨物信息存儲 、進程控制、硬幣處理、余額計算、自動找零、狀態(tài)顯示等功能。該系統(tǒng)能完成貨物信息存儲,進程控制,硬幣處理,余額計算,顯示等功能。該系統(tǒng)可以管理四種貨物 ,每種的數(shù)量和單價在初始化時輸入,在存儲器中存儲。用戶可以用硬幣進行購物,按鍵進行選擇。系統(tǒng)根據(jù)用戶輸入的貨幣,判斷錢幣是否夠,錢幣足夠則根據(jù)顧客的要求自動售貨,錢幣不足則給出提示并退出。系統(tǒng)自動的計算出應找錢幣余額、庫存數(shù)量并顯示。 2.3 系統(tǒng)組成方框圖 系統(tǒng)按功能分為:分頻模塊;控制模塊;譯碼模塊;譯碼顯示模塊。
42、 系統(tǒng)組成方框圖 2.4 工作過程 首先由售貨員把自動售貨機里的每種商品的數(shù)量和單價通過 set 鍵和 sel 鍵 置入到 RAM里。然后顧客通過 sel 鍵對所需要購買的商品進行選擇,選定以后通 過 get 鍵進行購買,再按 finish 鍵取回找?guī)?,同時結束此次交易。按 get 鍵時,如果投的錢數(shù)等于或則大于所購買的商品單價,則自動售貨機會給出所購買的商 品;如果投的錢數(shù)不夠,自動售貨機不做響應,繼續(xù)等待顧客的下次操作。顧客的下次操
43、作可以繼續(xù)投幣,直到錢數(shù)到達所要的商品單價進行購買;也可以直接按 finish 鍵退幣。 - 12 - 3 設計方案 3.1 自動售貨機 VHDL程序 -- 文件名: AUTO.vhd。 -- 功能:硬幣處理,余額計算,輸出商品。 -- 說明:顯示的錢數(shù) coin 的 以 5 角為單位。 library ieee; use ieee.std_logic_arith.all; use ieee.std_logic_1164.a
44、ll; use ieee.std_logic_unsigned.all; entity AUTO is port ( clk:in std_logic; -- 系統(tǒng)時鐘 set,get,sel,finish: in std_logic; -- 設定、買、選擇、完成信號 coin0,coin1: in std_logic; --5 角硬幣、 1 元硬幣 price,quantity :in std_logic_vector(3 downto 0); -- 價格、數(shù)量數(shù)據(jù) item0 , act:out std_logic_v
45、ector(3 downto 0); -- 顯示、開關信號 y0,y1 :out std_logic_vector(6 downto 0); -- 錢數(shù)、商品數(shù)量顯示數(shù)據(jù) act10,act5 :out std_logic); --1 元硬幣、 5 角硬幣 end AUTO; architecture behav of AUTO is type ram_type is array(3 downto 0)of std_logic_vector(7 downto 0); signal ram :ram_type; -- 定義 RAM
46、 signal item: std_logic_vector(1 downto 0); -- 商品種類 signal coin: std_logic_vector(3 downto 0); -- 幣數(shù)計數(shù)器 signal pri,qua:std_logic_vector(3 downto 0); -- 商品單價、數(shù)量 signal clk1: std_logic; -- 控制系統(tǒng)的時鐘信號 begin com:process(set,clk1) variable quan:std_logic_vector(3 downto 0); begin
47、 if set=1 then ram(conv_integer(item))<=price & quantity;act<="0000"; - 13 - -- 把商品的單價、數(shù)量置入到 RAM elsif clk1event and clk1=1 then act5<=0; act10<=0; if coin0=1 then if coin<"1001"then coin<=coin+1; -- 投入 5 角硬幣, coin 自加 1 else coin<="0000"; end if; elsif
48、 coin1=1 then if coin<"1001"then coin<=coin+2; -- 投入 1 元硬幣, coin 自加 2 else coin<="0000"; end if; elsif sel= ‘1’ then item<=item+1; -- 對商品進行循環(huán)選擇 elsif get=1 then -- 對商品進行購買 if qua>"0000" and coin>=pri then coin<=coin-pri;quan:=quan-1; ram(conv_integer(item))<=pri & quan;
49、 if item="00" then act<="1000"; -- 購買時,自動售貨機對 4 種商品的操作 elsif item="01" then act<="0100"; elsif item="10" then act<="0010"; elsif item="11" then act<="0001"; end if; end if; elsif finish=1 then -- 結束交易,退幣(找?guī)牛? if coin> “0001” then act10<= ‘1’;coin<=coin-2; -- 此 IF 語句完成找?guī)挪僮?
50、 elsif coin>"0000" then act5<=1; coin<=coin-1; else act5<=0; act10<=0; end if; elsif get=0 then act<="0000"; for i in 4 to 7 loop pri(i-4)<=ram (conv_integer(item))(i); -- 商品單價的讀取 end loop; for i in 0 to 3 loop quan(i):=ram(conv_integer(item))(i); -- 商品數(shù)量的讀取 - 14 -
51、 end loop; end if; end if; qua<=quan; end process com; m32:process(clk) -- 此進程完成對 32Mhz的脈沖分頻 variable q: std_logic_vector( 24 downto 0); begin if clkevent and clk=1 then q:=q+1; end if; if q="111111111111111111111111" then clk1<=1; else clk1<=0; e
52、nd if; end process m32; code0:process(item) -- 商品指示燈譯碼 begin case item is when "00"=>item0<="0111"; when "01"=>item0<="1011"; when "10"=>item0<="1101"; when others=>item0<="1110"; end case; end process code1: process (coin) -- 錢數(shù)的 BCD到七段碼的譯碼 Begin case coin is
53、 when "0000"=>y0<="0000001"; when "0001"=>y0<="1001111"; when "0010"=>y0<="0010010"; when "0011"=>y0<="0000110"; when "0100"=>y0<="1001100"; when "0101"=>y0<="0100100"; when "0110"=>y0<="0100000"; when "0111"=>y0<="0001111"; - 15 - when "1000"=>y0<="0
54、000000"; when "1001"=>y0<="0000100"; when others=>y0<="1111111"; end case; end process; code2: process (qua) -- 單價的 BCD到七段碼的譯碼 Begin case qua is when "0000"=>y1<="0000001"; when "0001"=>y1<="1001111"; when "0010"=>y1<="0010010"; when "0011"=>y1<="0000110"; when "
55、0100"=>y1<="1001100"; when "0101"=>y1<="0100100"; when "0110"=>y1<="0100000"; when "0111"=>y1<="0001111"; when "1000"=>y1<="0000000"; when "1001"=>y1<="0000100"; when others=>y1<="1111111"; end case; end process; end behav; 3.2 各功能部件系統(tǒng)仿真圖 通過軟件仿真,得出如下仿真圖:
56、 - 16 - 系統(tǒng)仿真全圖
57、 - 17 - 系統(tǒng)仿真圖 -商品種類選擇部分 系統(tǒng)仿真圖 -投幣部分 系統(tǒng)仿真圖 -購買、找?guī)沤Y束交易部 - 1
58、8 - 結 論 這次設計完成了。再設計中遇到了種種問題,在自己查閱資料及老師的幫助下一 一攻克了。在即將開設 EDA專業(yè)課程時, 為了能夠更加熟練的掌握本課程, 選擇了這 個學年設計。在設計過程中,通過自己的動手及查閱了相關資料,初步了解了 VHDL 語言的編程, 并熟悉了相關軟件的使用。
59、 本次學年設計我學到了不少新的東西, 也發(fā)現(xiàn)了大量的問題, 有些在設計過程中已經(jīng)解決, 有些還有待今后慢慢學習。 學習中會有更多的問題,有更多的難點,但也會有更多的收獲。 這次設計不僅提高了動手能力,更培養(yǎng)了自學 ,獨立思考和處理問題的能力。 為以后的學習和工作提供了幫助。 由于我的水平有限, 學年設計還并不十分完善, 論文還有許多疏漏, 懇請各位老師批評指正。 - 19 -
60、 參考文獻 [1] 鄭燕 . 基于 VHDL語言與 Quartus Ⅱ軟件的可編程邏輯器件應用與開發(fā) .2007. [2] 楊曉慧 . 基于 FPGA的 EDA/SOPC技術與 VHDL.2007. [3] 張霞. VHDL在現(xiàn)代 EDA中的應用. 2001. [4] 潘松、黃繼業(yè). EDA技術實用教程 2002. [5] 李志方. EDA技術簡介 .2001 . - 20 -
- 溫馨提示:
1: 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
2: 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
3.本站RAR壓縮包中若帶圖紙,網(wǎng)頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
4. 未經(jīng)權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
5. 裝配圖網(wǎng)僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。