版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
1、<p><b> 摘要I</b></p><p><b> 1概述1</b></p><p> 1.1課題背景及意義1</p><p> 1.2 EDA技術及實現方法概述1</p><p> 1.2.1 EDA技術簡介2</p><p> 1.
2、2.2 FPGA簡介3</p><p> 1.2.3 VHDL語言介紹4</p><p> 1.3 狀態(tài)機簡介5</p><p> 2 系統(tǒng)方案設計6</p><p><b> 2.1設計要求6</b></p><p> 2.2 總體設計方案6</p><
3、p> 2.2.1 控制器模塊化概述6</p><p> 2.2.2 電梯上下層運行流程圖7</p><p> 2.2.3電梯運行控制流程圖8</p><p> 2.2.4 電梯控制器設計思路9</p><p> 2.3 設計的VHDL實現10</p><p> 2.3.1 控制器實體設計1
4、0</p><p> 2.3.2 控制器結構體設計11</p><p><b> 3 器件選型11</b></p><p> 3.1 FPGA芯片選型11</p><p> 3.2 功能模塊12</p><p> 3.2.1 主控器模塊12</p><p&g
5、t; 3.2.2 分頻器模塊13</p><p> 3.2.3 譯碼器模塊13</p><p> 3.2.4 數據選擇器模塊14</p><p><b> 4 程序仿真15</b></p><p> 4.1 電梯控制器仿真分析15</p><p> 4.2 其它模塊仿真19
6、</p><p><b> 5 結論19</b></p><p><b> 參考文獻21</b></p><p><b> 致謝22</b></p><p><b> 附錄23</b></p><p> 基于FPG
7、A 的六層電梯控制系統(tǒng)</p><p><b> 摘 要</b></p><p> 本設計是基于電子設計自動化(EDA)技術中的甚高速集成電路硬件描述語言(VHDL)語言,運用FPGA所開發(fā)的四層電梯控制程序,采用Quartus II軟件仿真。運用有限狀態(tài)機的設計方法,設計了兩個進程相互配合,狀態(tài)機進程作為主要進程,信號燈控制進程作為輔助進程。在主進程中定義了7
8、個狀態(tài),在電梯時鐘的觸發(fā)下,通過當前狀態(tài)和信號燈信號判定下一狀態(tài)。信號燈控制進程中,信號燈存儲按鍵請求情況,它的熄滅是由狀態(tài)機進程中傳出的信號來控制。</p><p> 通過程序調試及運行仿真,結果表明,本程序可以完成電梯運行所在樓層顯示、電梯運行方向指示、關門延時設置等。</p><p> 關鍵詞:電梯控制器 VHDL 狀態(tài)機 FPGA</p><p>
9、<b> 1概述</b></p><p> 1.1課題背景及意義</p><p> 隨高層樓宇的增加,電梯越來越多的走進了人們的生活,對人們的生活的影響越來越大。為了讓電梯更好的服務人們,各種電梯新技術不斷地發(fā)展起來。隨著人們生活水平的不斷提高,經濟的快速發(fā)展和生產生活的需要,城市高層建筑如雨后春筍拔地而起。與此相應,作為一種可以垂直升降運輸的工具一電梯也得到迅
10、猛的發(fā)展。現在,電梯已完全融入我們的生活、工作及學習中,人們越來越離不開它。因此,它的安全可靠性、迅速準確性、舒適性,對人們來說都是非常重要的。為了確保電梯正常運行、安全使用,一般電梯都有專業(yè)的維修管理人員。他們必須對電梯原理、性能、特點、控制、運行要全面認識和掌握,才能做到對電梯的正確使用、管理及維護。根據我國有關部門的規(guī)定,電梯作業(yè)屬于特種作業(yè),其作業(yè)人員必須經過專門培訓,并經理論考試和實踐考核合格后,發(fā)給《特種作業(yè)操作證》方可上崗
11、操作。同時,對電梯操作人員定期考核,讓他們定期參加安全技術學習,扎扎實實地做好電梯維護和保養(yǎng)工作,才能使人們平安長久的使用電梯。</p><p> 電梯控制系統(tǒng)是一個相當復雜的邏輯控制系統(tǒng).系統(tǒng)要同時對幾百個信號進行接收、處理。由于用戶對電梯功能的要求不斷提高.其相應控制方式也在不斷發(fā)生變化。隨著EDA技術的快速發(fā)展.基于FPGA的微機化控制已廣泛應用于電梯電路設計與控制的各個方面。</p>&l
12、t;p> 在經濟不斷發(fā)展,科學技術日新月異的今天,樓的高度已和經濟發(fā)展同樣的速度成長起來。作為建筑的中樞神經,電梯起著不可或缺的作用,電梯作為建筑物內的主要運輸工具,像其他的交通工具一樣,已經成為我們日常生活的一個不可缺少的組成部分。一個國家的電梯需求總量,主要受其經濟增長速度、城市化水平、人口密度及數量、國家產業(yè)結構等綜合因素的影響。在全球經濟持續(xù)低迷的情況下,我國國民經濟仍然以較高的速度持續(xù)增長,城市化水平不斷提高。這從客觀
13、上導致了我國電梯行業(yè)的空前繁榮景象,我國已經成為全球最大的電梯市場。上世紀80年代以來,隨著經濟建設的持續(xù)高速發(fā)展,我國電梯需求量越來越大??傏厔菔巧仙模娞菪袠I(yè)進入了“第三次浪潮”。如此龐大的市場需求為我國電梯行業(yè)的發(fā)展創(chuàng)造了廣闊的舞臺!</p><p> 1.2 EDA技術及實現方法概述</p><p> 1.2.1 EDA技術簡介</p><p> E
14、DA代表了當今電子設計技術的最新發(fā)展方向,它的基本特征是:設計人員按照“自頂向下”的設計方法,對整個系統(tǒng)進行方案設計和功能劃分,系統(tǒng)的關鍵電路用一片或幾片專用集成電路(ASIC)實現,然后采用硬件描述語言(HDL)完成系統(tǒng)行為級設計,最后通過綜合器和適配器生成最終的目標器件,這樣的設計方法被稱為高層次的電子設計方法。下面介紹與EDA基本特征有關的幾個概念?! ?.“自頂向下”的設計方法,10年前,電子設計的基本思路還是選用標準集成電路
15、“自底向上”地構造出一個新的系統(tǒng),這樣的設計方法就如同一磚一瓦建造金字塔,不僅效率低、成本高而且容易出錯?! 「邔哟卧O計是一種“自頂向下”的全新設計方法,這種設計方法首先從系統(tǒng)設計入手,在頂層進行功能方框圖的劃分和結構設計。在方框圖一級進行仿真、糾錯,并用硬件描述語言對高層次的系統(tǒng)行為進行描述,在系統(tǒng)一級進行驗證。然后,用綜合優(yōu)化工具生成具體門電路的網絡表,其對應的物理實現級可以是印刷電路板或專用集成電路。由于設計的主要仿真和調試過程
16、是在高層次上完成的,這既有利于早期發(fā)現結構設計上的錯誤,避免設計工作的浪費,又減少了邏輯功能仿真的工作量,提高了設計的</p><p> 1.2.2 FPGA簡介</p><p> 目前以硬件描述語言(Verilog或 VHDL)所完成的電路設計,可以經過簡單的綜合與布局,快速的燒錄至 FPGA 上進行測試,是現代 IC 設計驗證的技術主流。這些可編輯元件可以被用來實現一些基本的邏輯門
17、電路(比如AND、OR、XOR、NOT)或者更復雜一些的組合功能比如解碼器或數學方程式。在大多數的FPGA里面,這些可編輯的元件里也包含記憶元件例如觸發(fā)器(Flip-flop)或者其他更加完整的記憶塊。 系統(tǒng)設計師可以根據需要通過可編輯的連接把FPGA內部的邏輯塊連接起來,就好像一個電路試驗板被放在了一個芯片里。一個出廠后的成品FPGA的邏輯塊和連接可以按照設計者而改變,所以FPGA可以完成所需要的邏輯功能
18、。</p><p> FPGA一般來說比ASIC(專用集成芯片)的速度要慢,無法完成復雜的設計,而且消耗更多的電能。但是他們也有很多的優(yōu)點比如可以快速成品,可以被修改來改正程序中的錯誤和更便宜的造價。廠商也可能會提供便宜的但是編輯能力差的FPGA。因為這些芯片有比較差的可編輯能力,所以這些設計的開發(fā)是在普通的FPGA上完成的,然后將設計轉移到一個類似于ASIC的芯片上。另外一種方法是用CPLD(復雜可編程邏輯器
19、件備)。</p><p> FPGA是由存放在片內RAM中的程序來設置其工作狀態(tài)的,因此,工作時需要對片內的RAM進行編程。用戶可以根據不同的配置模式,采用不同的編程方式。 </p><p> 加電時,FPGA芯片將EPROM中數據讀入片內編程RAM中,配置完成后,FPGA進入工作狀態(tài)。掉電后,FPGA恢復成白片,內部邏輯關系消失,因此,FPGA能夠反復使用。FPGA的編程無須專用的F
20、PGA編程器,只須用通用的EPROM、PROM編程器即可。當需要修改FPGA功能時,只需換一片EPROM即可。這樣,同一片FPGA,不同的編程數據,可以產生不同的電路功能。因此,FPGA的使用非常靈活。</p><p> 1.2.3 VHDL語言介紹</p><p> VHDL 的英文全名是 Very-High-Speed Integrated Circuit Hardware Des
21、cription Language,誕生于 1982 年。1987 年底,VHDL被 IEEE 和美國國防部確認為標準硬件描述語言。 </p><p> VHDL主要用于描述數字系統(tǒng)的結構,行為,功能和接口。除了含有許多具有硬件特征的語句外,VHDL的語言形式、描述風格以及語法是十分類似于一般的計算機高級語言。VHDL的程序結構特點是將一項工程設計,或稱設計實體(可以是一個元件,一個電路模塊或一個系統(tǒng))分成外部
22、(或稱可視部分,及端口)和內部(或稱不可視部分),既涉及實體的內部功能和算法完成部分。在對一個設計實體定義了外部界面后,一旦其內部開發(fā)完成后,其他的設計就可以直接調用這個實體。這種將設計實體分成內外部分的概念是VHDL系統(tǒng)設計的基本點。</p><p> VHDL具有功能強大的語言結構,可以用簡潔明確的源代碼來描述復雜的邏輯控制。它具有多層次的設計描述功能,層層細化,最后可直接生成電路級描述。VHDL支持同步電
23、路、異步電路和隨機電路的設計,這是其他硬件描述語言所不能比擬的。VHDL還支持各種設計方法,既支持自底向上的設計,又支持自頂向下的設計;既支持模塊化設計,又支持層次化設計。</p><p> VHDL 語言具有多層次的電路設計描述功能,既可描述系統(tǒng)級電路 , 也可以描述門級電路;描述方式既可以采用行為描述、寄存器傳輸描述或者結構描述,也可以采用三者的混合描述方式。同時,VHDL 語言也支持慣性延遲和傳輸延遲,這
24、樣可以準確地建立硬件電路的模型。VHDL 語言的強大描述能力還體現在它具有豐富的數據類型。VHDL 語言既支持標準定義的數據類型,也支持用戶定義的數據類型,這樣便會給硬件描述帶來較大的自由度。 </p><p> VHDL 語言很強的移植能力主要體現在: 對于同一個硬件電路的 VHDL 語言描述 , 它可以從一個模擬器移植到另一個模擬器上、從一個綜合器移植到另一個綜合器上或者從一個工作平臺移植到另一個工作平臺上
25、去執(zhí)行。</p><p> 采用 VHDL 語言描述硬件電路時, 設計人員并不需要首先考慮選擇進行設計的器件。這樣做的好處是可以使設計人員集中精力進行電路設計的優(yōu)化, 而不需要考慮其他的問題。當硬件電路的設計描述完成以后 ,VHDL 語言允許采用多種不同的器件結構來實現。</p><p> VHDL 語言采用基于庫 ( library) 的設計方法。在設計過程中 , 設計人員可以建立各
26、種可再次利用的模塊 , 一個大規(guī)模的硬件電路的設計不可能從門級電路開始一步步地進行設計 , 而是一些模塊的累加。這些模塊可以預先設計或者使用以前設計中的存檔模塊, 將這些模塊存放在庫中 , 就可以在以后的設計中進行復用。 </p><p> 由于 VHDL 語言是一種描述、模擬、綜合、優(yōu)化和布線的標準硬件描述語言 , 因此它可以使設計成果在設計人員之間方便地進行交流和共享, 從而減</p><
27、;p> 小硬件電路設計的工作量, 縮短開發(fā)周期</p><p><b> 1.3 狀態(tài)機簡介</b></p><p> 關于狀態(tài)機的一個極度確切的描述是它是一個有向圖形,由一組節(jié)點和一組相應的轉移函數組成。狀態(tài)機通過響應一系列事件而“運行”。每個事件都在屬于“當前” 節(jié)點的轉移函數的控制范圍內,其中函數的范圍是節(jié)點的一個子集。函數返回“下一個”(也許是同一
28、個)節(jié)點。這些節(jié)點中至少有一個必須是終態(tài)。當到達終態(tài), 狀態(tài)機停止。 </p><p> 包含一組狀態(tài)集(states)、一個起始狀態(tài)(start state)、一組輸入符號集(alphabet)、一個映射輸入符號和當前狀態(tài)到下一狀態(tài)的轉換函(transition function)的計算模型。當輸入符號串,模型隨即進入起始狀態(tài)。它要改變到新的狀態(tài),依賴于轉換函數。在有限狀態(tài)機中,會有有許多變量,例如,狀態(tài) 機
29、有很多與動作(actions)轉換(Mealy機)或狀態(tài)(摩爾機)關聯的動作,多重起始狀態(tài),基于沒有輸入符號的轉換,或者指定符號和狀態(tài)(非定有 限狀態(tài)機)的多個轉換,指派給接收狀態(tài)(識別者)的一個或多個狀態(tài),等等。 </p><p> 傳統(tǒng)應用程序的控制流程基本是順序的:遵循事先設定的邏輯,從頭到尾地執(zhí)行。很少有事件能改變標準執(zhí)行流程;而且這些事件主要涉及異常情況。“命令行實用程序”是這種傳統(tǒng)應用程序的典型例子
30、。 </p><p> 有限狀態(tài)機是一種概念性機器,它能采取某種操作來響應一個外部事件。具體采取的操作不僅能取決于接收到的事件,還能取決于各個事件的相對發(fā)生順序。之所以能 做到這一點,是因為機器能跟蹤一個內部狀態(tài),它會在收到事件后進行更新。為一個事件而響應的行動不僅取決于事件本身,還取決于機器的內部狀態(tài)。另外,采取 的行動還會決定并更新機器的狀態(tài)。這樣一來,任何邏輯都可建模成一系列事件/狀態(tài)組合。 </p
31、><p> 狀態(tài)機可歸納為4個要素,即現態(tài)、條件、動作、次態(tài)。這樣的歸納,主要是出于對狀態(tài)機的內在因果關系的考慮。“現態(tài)”和“條件”是因,“動作”和“次態(tài)”是果。詳解如下: </p><p> ?、佻F態(tài):是指當前所處的狀態(tài)。 </p><p> ?、跅l件:又稱為“事件”。當一個條件被滿足,將會觸發(fā)一個動作,或者執(zhí)行一次狀態(tài)的遷移。 </p><p&
32、gt; ③動作:條件滿足后執(zhí)行的動作。動作執(zhí)行完畢后,可以遷移到新的狀態(tài),也可以仍舊保持原狀態(tài)。動作不是必需的,當條件滿足后,也可以不執(zhí)行任何動作,直接遷移到新狀態(tài)。 </p><p> ?、艽螒B(tài):條件滿足后要遷往的新狀態(tài)?!按螒B(tài)”是相對于“現態(tài)”而言的,“次態(tài)”一旦被激活,就轉變成新的“現態(tài)”了。</p><p><b> 2 系統(tǒng)方案設計</b></p&
33、gt;<p><b> 2.1設計要求</b></p><p> (1) 每層電梯入口處設有上下請求開關,電梯內設有顧客到達層次的停站請求開關。</p><p> (2) 設有電梯入口處位置指示裝置及電梯運行模式(上升或下降)指示裝置。</p><p> (3) 電梯到達有停站請求的樓層,開門指示燈亮,開門后,經一段時延后
34、,電梯門關閉電梯繼續(xù)進行,直至執(zhí)行完最后一個請求信號后停留在當前層。</p><p> (4) 電梯運行規(guī)則:當處于上升模式時,只響應比所在位置高的請求信號,由下而上逐個執(zhí)行,直到最后一個上樓請求執(zhí)行完畢;高層有下樓請求,則直接升到請求層,進入下降模式。當電梯處于下降模式時則與上升模式相反。</p><p> 2.2 總體設計方案</p><p> 2.2.1
35、 控制器模塊化概述</p><p> 控制器的功能模塊如圖2.1所示,包括主控制器、樓層選擇器、狀態(tài)顯示器、譯碼器和樓層顯示器。乘客在電梯中選擇所要到達的樓層,通過主控制器的處理,電梯開始運行,狀態(tài)顯示器顯示電梯的運行狀態(tài),電梯所在樓層數通過譯碼器譯碼從而在樓層顯示器中顯示。由于其他模塊相對簡單很多,所以主控制器是核心部分。 </p><p> 圖2-1 總體設計方案</p>
36、;<p> 2.2.2 電梯上下層運行流程圖</p><p> 電梯上升流程圖,如圖2-2:</p><p> 圖2-2 電梯上升流程圖</p><p> 電梯下降流程圖,如圖2.3:</p><p> 圖2-3 電梯下降流程圖</p><p> 2.2.3電梯運行控制流程圖</p>
37、;<p><b> 如圖2.4:</b></p><p> 圖2-4 電梯運行控制流程圖</p><p> 2.2.4 電梯控制器設計思路</p><p> 電梯控制器運用狀態(tài)機的設計方法,思路比較清晰??梢詫㈦娞莸却拿棵腌娨约伴_門、關門都看成一個獨立的狀態(tài)。由于電梯又是每秒上升或下降一層,所以就可以通過一個統(tǒng)一的1秒為
38、周期的時鐘來觸發(fā)狀態(tài)機。根據電梯的實際工作情況,可以把狀態(tài)機設置7個狀態(tài),分別是“電梯停留在第1層”、“開門”、“關門”、 “開門等待4秒”、“上升”、“下降”和“停止狀態(tài)”。各個狀態(tài)之間的轉換條件可由上面的設計要求所決定。初始化狀態(tài)為1樓等待門是關閉的。各狀態(tài)機之間轉換圖如圖2.5:</p><p> 圖2-5 狀態(tài)機轉換圖</p><p> 2.3 設計的VHDL實現</p&
39、gt;<p> 2.3.1 控制器實體設計</p><p> 首先考慮輸入端口,一個異步復位端口reset,用于在系統(tǒng)不正常時回到初始狀態(tài);在電梯外部,必須有升降請求端口,一層是最低層,不需要有下降請求,六層是最高層,不需要有上升請求[3],二三四五層則上升、下降請求端口都有;在電梯的內部,應該設有各層停留的請求端口:一個電梯時鐘輸入端口,該輸入時鐘以1秒為周期,用于驅動電梯的升降及開門關門等動
40、作;另有一個按鍵時鐘輸入端口,時鐘頻率比電梯時鐘高。</p><p> 其次是輸出端口,有升降請求信號以后,就得有一個輸出端口來指示請求是否被響應,有請求信號以后,該輸出端口輸出邏輯‘l’。被響應以后則恢復邏輯‘0’;同樣,在電梯內部也應該有這樣的輸出端口來顯示各層停留是否被響應;在電梯外部,需要一個端口來指示電梯現在所處的位置;電梯開門關門的狀態(tài)也能用一個輸出端口來指示;為了觀察電梯的運行是否正確,可以設置一
41、個輸出端口來指示電梯的升降狀態(tài)。</p><p> 2.3.2 控制器結構體設計</p><p> 首先說明一下狀態(tài)。狀態(tài)機設置了7個狀態(tài),分別是電梯停留在l層(stoponl)、開門(dooropen)、關門(doorclose)、開門等待4秒(doorwait4)、上升(up)、下降(down)和停止(stop)。在實體說明定義完端口之后,在結構體architecture和begi
42、n之間需要有如下的定義語句,來定義狀態(tài)機。 type lift_state is (stoponl,dooropen,doorclose, doorwait4,up,down,stop): signal mylift:lift_state: 在結構體中,設計了兩個進程互相配合,一個是狀態(tài)機進程作為主要進程,另外一個是信號燈控制進程作為輔助進程。狀態(tài)機進程中的很多判斷條件是以信號燈進程產生的信號燈信號為依據的,而信號燈進程
43、中信號燈的熄滅又是由狀態(tài)機進程中傳出的clearup和cleardn信號來控制。 在狀態(tài)機進程中,在電梯的上升狀態(tài)中,通過對信號燈的判斷,決定下一個狀態(tài)是繼續(xù)上升還是停止;在電梯下降狀態(tài)中,也是通過對信號燈的判斷,決定下一個狀態(tài)是繼續(xù)下降還是停止;在電梯停止狀態(tài)中</p><p><b> 3 器件選型</b></p><p> 3.1 FPGA芯片選型&
44、lt;/p><p> 主控芯片選用Altera公司ACEX系列FPGA芯片EP1K30TC144-3, Altera公司是20世紀90年代以來發(fā)展較快的可編程邏輯器件生產廠家,在激烈的市場競爭中, 憑借其雄厚的技術實力,獨特的設計構思和功能齊全的芯片系列,躋身于世界最大的器件供應商之列。EP1K30TC144-3芯片屬于Altera公司的ACEX 1K系列,集成典型邏輯門數達30000個, 工作頻率最高可達178.
45、6MHz,最小傳輸延時為5.0ns,它將查找表(LUT)與嵌入式陣列塊(EAB)結合起來,提供了一種具有高效管芯的低成本結構。該芯片支持1.8到2.5V供電電壓,其I/O接口支持多電壓的連接:1.8V,2.5V,3.3V,5V僅在外接電阻時可承受,還提供可編程的節(jié)能工作模式。在編程工藝上,采用SRAM(靜態(tài)隨機存儲器)工藝,可插寫上萬次。這些特點使該芯片適用于復雜的邏輯功能和存儲功能的應用場合。</p><p>
46、<b> 3.2 功能模塊</b></p><p> 3.2.1 主控器模塊</p><p><b> 如圖3-1:</b></p><p> 圖3-1 電梯主控制模塊</p><p> 電梯主控制模塊端口說明:</p><p> buttonclk 按鈕時鐘信號
47、 liftclk 電梯時鐘信號 </p><p> reset 復位鍵 f1upbutton 一樓上樓按鈕 </p><p> f2upbutton 二樓上樓按鈕 f3upbutton 三樓上樓按鈕</p><p> f4upbutton 四樓上樓
48、按鈕 f5upbutton 五樓上樓按鈕</p><p> f2dnbutton 二樓下樓按鈕 f3dnbutton 三樓下樓按鈕</p><p> f4dnbutton 四樓下樓按鈕 f5dnbutton 五樓下樓按鈕 </p><p> f6dnbutton 六樓下樓按鈕
49、 stop1button 電梯內部一樓按鈕</p><p> stop2button 電梯內部二樓按鈕 stop3button 電梯內部三樓按鈕</p><p> stop4button 電梯內部四樓按鈕 stop5button 電梯內部五樓按鈕</p><p> stop6button 電梯內部六樓按鈕
50、 fuplight[6..1] 每樓層上升指示燈</p><p> fdnlight[6..1] 每樓層下降指示燈 stoplight[6..1] 電梯內部樓層指示燈 </p><p> position[2..0] 樓層位置顯示 doorlight 電梯門狀態(tài)顯示 </p><p> udsig 電梯上升下降顯示
51、</p><p> 3.2.2 分頻器模塊</p><p><b> 如圖3-2:</b></p><p> 圖3-2 分頻器模塊</p><p><b> 模塊端口說明:</b></p><p> clk_in 電源輸入端 div
52、_out 分頻后時鐘輸出端</p><p> 3.2.3 譯碼器模塊</p><p><b> 如圖3-3:</b></p><p><b> 圖3-3譯碼器模塊</b></p><p> aaa[2..0] 樓層位置輸出端 bbb[3..0] 譯碼輸出端</p&
53、gt;<p> 譯碼器邏輯功能表如表3-1</p><p> 表3-1 譯碼器邏輯功能表</p><p> 3.2.4 數據選擇器模塊</p><p><b> 如圖3-4:</b></p><p> 圖 3-4 數據選擇器模塊</p><p> 數據選擇器模塊端口說明:
54、</p><p> input[3..0] 譯碼器輸入端 output[6..0] 數據選擇器輸出端</p><p> 譯碼器邏輯功能表如表3-2</p><p> 表3-2 譯碼器邏輯功能表</p><p><b> 4 程序仿真</b></p><p> 4.1
55、電梯控制器仿真分析</p><p><b> 仿真示例1: </b></p><p> 圖4-1所示仿真的是在第五層電梯外部有上升請求,也就是f5upbuttton信號的一個脈沖[9],可以看到電梯從一層上升到五層,position信號由1變到5,doorlight信號‘1’表示開門,‘0’表示關門。當乘客進入電梯以后,在電梯內部要求上升到第六層,也就是stop6
56、button產生一個脈沖,電梯上升到第6層,開門4秒以后關門,停留在第六層,position最后的值為6。在仿真圖中看不到buttonclk,只顯示為一條黑色的線,是因為采用了頻率較大的時鐘。 再看fuplight信號燈,當五層有上升請求的時候,它的值由0變到16。(注意fuplight和fdnlight是6位的二進制向量,這里的“010000”,表示五層有請求;“000100”也就是4,表示三層有請求)。當電梯停留到第五層以后,
57、表明該請求被響應,所以它的值變?yōu)?,由于沒有下降請求信號,所以fdnlight信號燈的值一盲都為0。當電梯處于第五層時,udsig=0,即此時若沒有其他請求,電梯處于上升模式;當stop6button=1,即電梯內部按了六層請求時,電梯門燈滅電梯開始上升udsig=0,即處于上升模</p><p> 圖4-1 仿真示例1</p><p><b> 仿真示例2:</b&g
58、t;</p><p> 圖4-2是有下降請求的情況,它是圖4.1的繼續(xù),當電梯停留在第六層的時候,在電梯外第四層有下降請求,這時候fdnlight信號燈由0變?yōu)?,說明第四層有下降請求。電梯下降到第四層,響應了下降請求,所以fdnlight信號燈清0。電梯開始下降,即udsig=1,抵達四樓后電梯門開,doorlight=1, 這時候,在電梯內部有一樓向上請求,接著電梯內部有三樓的請求,所以電梯繼續(xù)下降,到達三
59、層后,電梯門開[11],四秒后電梯門關,又因為一樓有請求所以最終到達一樓停止響應,position信號的值保持在1,電梯處于上升模式。四秒后電梯門關。</p><p> 圖4-2 仿真示例2</p><p><b> 仿真示例3:</b></p><p> 圖4-3仿真的情況是,原先電梯停留在第一層,這時候電梯外第六層有下降請求,電梯上升
60、到第六層,乘客進入電梯以后要求下降到一層,與此同時,在電梯外第三層有上升請求,電梯首先要響應下降請求然后再響應這個上升請求,所以電梯得先下降到第一層,然后再上升到第三層來,接著電梯內部五樓,三樓都有請求信號,于是電梯升到五樓然后下降到三樓,這是符合常理的。從仿真的波形看,電梯的位置變化和想象是一致的。電梯的運行情況完全正確。最后乘客在電梯內部要求上升到三層,所以電梯最后的停留位置為三層。</p><p> 圖4
61、-3 仿真示例3</p><p><b> 仿真示例4:</b></p><p> 圖4-4所示的仿真,原先電梯停留在第一層,電梯外第六層有下降請求,電梯上升到六層,乘客進入電梯以后要求下降到一層,此時,二層有下降請求,接著又有上升請求,電梯首先在二層停留。然后下降到一層。隨后要響應二層上升請求,上升到二層,乘客進入電梯以后要求上升到三層,所以電梯最后的停留位置在
62、三層。</p><p> 圖4-4 仿真示例4</p><p> 4.2 其它模塊仿真</p><p> 鑒于以上主控器模塊仿真完全符合預期要求,可以推知其它模塊設計正確,故不再做數據選擇器模塊和譯碼器模塊的仿真分析。</p><p><b> 5 結論</b></p><p> 本電梯
63、系統(tǒng)實現了如下功能:</p><p> 1.各層電梯內部信號:各樓層請求按鍵。外部信號:上升下降請求按鍵,所在樓層顯示,電梯運行狀態(tài)顯示。 2.能夠存儲請求信號,電梯上升(下降)過程中,根據電梯的運行狀態(tài),首先按方向優(yōu)先、循環(huán)次序響應各請求。 3.電梯每秒升(降)一層樓。電梯到達有停站請求的樓層,經過1秒電梯門打開,開門指示燈亮,開門4秒后,電梯門關閉(開門指示燈滅),電梯繼續(xù)進行,直至執(zhí)行完最
64、后一個請求信號后停留在當前層。電梯初始狀態(tài)為一層關門狀態(tài)。</p><p> 綜上所述,完成了課題的所有要求,該設計采用模塊化編程,升級可實現任意多層電梯系統(tǒng),具有很強的適應性和實用性。 在本設計中,因為考慮了擴展性,所以在信號定義的時候就使用了二進制的向量,而不是整數。在設計方法上也做了特殊的設計,所以使得擴展性較好。如果要實現n層電梯的控制,首先在端口的地方就要加入所有的按鍵,而指示燈只要把向量中的
65、6改成n就可以了。同時需要在按鍵控制進程里加入其他按鍵觸發(fā)指示燈的語句。在電梯的升降狀態(tài)將6改成n,在電梯的開門狀態(tài)中將2改成n一1,在關門狀態(tài),將position=6改成position=n,關鍵是修改position=6的部分,如果按照每層羅列,將十分煩瑣,所以得尋求各層判斷條件的共性,解決方法之一就是,新建一個全局向量abc為std_logic_vector(n downto 1),abc的賦值為abc<=(pos=>
66、’1’,other=>'</p><p> 0’)。在電梯的上升模式時,如果有本層請求信號,則電梯開門;如果沒有任何請求信號,則電梯停在當前層;否則用abc和stoplight與fuplight向量比較,如果stoplight或fupligh比abc大,則說明更高層還有上升或者停戰(zhàn)請求,電梯需繼續(xù)上升;如果abc更大,則用abc與fdnlight作比較,如果fdnlight更大,則說明更高層有下降
67、請求,電梯繼續(xù)上升,否則電梯下降。電梯處在下降模式時同原理分析判定下一狀態(tài)。這樣可以大大簡化程序,但要注意的是abc向量作為判斷依據,需實時更新,可以單獨寫一個進程,觸發(fā)時鐘周期要設置得很小。在電梯的上升狀態(tài)和開門狀態(tài)中,把6改為n,在信號燈控制進程中加入其它按鍵觸發(fā)指示燈的語句。</p><p><b> 參考文獻</b></p><p> [1]潘松,黃繼業(yè).
68、EDA技術實用教程.科學出版社,2006</p><p> [2]付家才.EDA原理與應用[M].北京:化學工業(yè)出版社,2001:15-23 </p><p> [3]王振紅.VHDL數字電路設計應用實踐教程[M].北京:機械工業(yè)出版社,2003:2-14 </p><p> [4]黃智偉.FPGA系統(tǒng)設計與實踐[M].北京:電子工業(yè)出版社,2005:12-2
69、4</p><p> [5] 梁延東.電梯控制技術[M].北京:中國建筑工業(yè)出版社,1997:23-47</p><p><b> 致謝</b></p><p> 在這里對老師在平時授課中的耐心教導表示衷心感謝。</p><p> 通過此次課程設計,學到了很多之前不了解的知識,也意識到了大學課程對我們今后的學習有
70、很大的幫助。在課程設計中,我雖然碰到了很多困難和問題,到最后還是靠自己的努力與堅持獨立的完成了任務。這次設計給我最深的印象就是擴大自己的知識面,學習了很多以前不了解的知識,了解更多與本專業(yè)有關的科技信息,與時代共同進步,才能在將來成為有用的科技人才,覺得平時所學的知識有了實用的價值,達到了理論與實際相結合的目的,不僅學到了不少知識,而且鍛煉了自己的能力,使自己對以后的路有了更加清楚的認識,同時,對未來有了更多的信心。再次感謝老師的諄諄教
71、誨!</p><p><b> 附錄</b></p><p><b> 源程序:</b></p><p><b> 電梯控制程序:</b></p><p> library ieee;</p><p> use ieee.std_logic_1
72、164.all;</p><p> use ieee.std_logic_unsigned.all;</p><p> use ieee.std_logic_arith.all;</p><p> entity sixlift is</p><p><b> port(</b></p><p
73、> buttonclk:in std_logic; --按鈕時鐘信號 </p><p> liftclk: in std_logic; --電梯時鐘信號 </p><p>
74、reset:in std_logic; --復位鍵 </p><p> f1upbutton:in std_logic; --一樓上升按鈕 </p><p> f2upbutto
75、n:in std_logic; --二樓上升按鈕</p><p> f3upbutton:in std_logic; --三樓上升按鈕 </p><p> f4upbutton:in std_logic; --四樓上升按鈕</p><p> f5upbu
76、tton:in std_logic; </p><p> f2dnbutton:in std_logic; --二樓下降按鈕 </p><p> f3dnbutton:in std_logic; --三樓下降按鈕</p><p> f4dnbutto
77、n:in std_logic; --四樓下降按鈕</p><p> f5dnbutton:in std_logic; --五樓下降按鈕</p><p> f6dnbutton:in std_logic; --六樓下降按鈕 </p><p> fupl
78、ight:buffer std_logic_vector(6 downto 1); --上升指示燈 </p><p> fdnlight:buffer std_logic_vector(6 downto 1); --下降指示燈 </p><p> stop1butto
79、n,stop2button,stop3button, stop4button, stop5button, stop6button:in std_logic; --電梯內部按鈕 </p><p> stoplight:buffer std_logic_vector(6 downto 1); --內部停止指示燈
80、</p><p> position:buffer integer range 1 to 6; --樓層位置顯示 </p><p> doorlight:out std_logic; --電梯門指示燈 ‘1’ 開 ‘0’關
81、</p><p> udsig:buffer std_logic ); --‘0’處于上升模式,‘1’處于下降模式 </p><p> end sixlift;</p><p> architecture art of sixlift is </p><p>
82、 type lift_state is (stopon1,dooropen,doorclose,doorwait4,up,down,stop); --電梯所處的7個狀態(tài)</p><p> signal mylift:lift_state; --內部電梯狀態(tài)信號</p><p> signal clearup:std_logic; --上升清除信號
83、 </p><p> signal cleardn:std_logic; --下降清除信號 </p><p> signal waitcnt:integer range 0 to 2; --waitcnt為完成四秒延時而設置
84、 </p><p><b> begin</b></p><p> controllift:process(reset,liftclk) </p><p> variable pos:integer range 1 to 6; --樓層位置變量
85、 </p><p><b> begin</b></p><p> if reset='1' then </p><p> mylift<=
86、stopon1; --起始狀態(tài)</p><p> clearup<='0'; --上樓信號清除</p><p> cleardn<='0'; --下樓信號清除</p><p> pos:=1; --處于一樓</p><p> pos
87、ition<=1; --處于一樓</p><p><b> else</b></p><p> if liftclk'event and liftclk='1' then --四秒后門關 </p><p> case
88、mylift is</p><p> when stopon1 => doorlight<='1'; --電梯門開</p><p> position<=1; --電梯處于一樓</p><p><b> pos:=1;</b></p><p&g
89、t; mylift<=doorwait4; </p><p> when doorwait4 => waitcnt<=waitcnt+1; --waitcnt計數夠兩個電梯時鐘脈沖后狀態(tài)跳轉到doorclose,加上中間過程完成延時四秒</p><p&g
90、t; if waitcnt=’2’</p><p> then waitcnt<=0</p><p> mylift<=doorclose;</p><p> else mylift<=doorwait4;</p><p><b> end if;</b></p><p&g
91、t; ; </p><p> when doorclose =></p><p> doorlight<='0'; --電梯門關
92、 </p><p> if udsig='0' then --電梯處于上升模式 </p><p> if position=6 then
93、 </p><p> if stoplight="000000" and fuplight="000000" and fdnlight="000000" then </p><p> udsig<='1';mylift<=doorclose;
94、 </p><p> else udsig<='1';mylift<=down; </p><p> end if;
95、 </p><p> elsif position=5 then </p><p> if stoplight="000000" and fuplight="000000" and fdnlight="000000" then
96、 </p><p> udsig<='0';mylift<=doorclose; </p><p> elsif stoplight(6)='1' or fdnlight(6)='1' then </p>
97、<p> udsig<='0';mylift<=up;</p><p> else udsig<='1';mylift<=down; </p><p><b> end if;</b></p>&
98、lt;p> elsif position=4 then </p><p> if stoplight="000000" and fuplight="000000" and fdnlight="000000" then </p>&
99、lt;p> udsig<='0';mylift<=doorclose; </p><p> elsif stoplight(5)='1' or stoplight(6)= '1' or fdnlight(6)='1' or
100、fdnlight(5)='1' then </p><p> udsig<='0';mylift<=up;</p><p> else udsig<='1';mylift<=down; </p><p>
101、;<b> end if;</b></p><p> elsif position=3 then </p><p> if stoplight="000000" and fuplight="000000" and fdnlig
102、ht="000000" then </p><p> udsig<='0';mylift<=doorclose; </p><p> elsif stoplight(4)='1' or stoplight(5)=&
103、#39;1' or stoplight(6)= '1' or fdnlight(6)='1' or fdnlight(5)='1' or fdnlight(4)='1' then </p><p> udsig<='0';mylift<=up;</p><p> else udsig
104、<='1';mylift<=down; </p><p><b> end if;</b></p><p> elsif position=2 then
105、</p><p> if stoplight="000000" and fuplight="000000" and fdnlight="000000" then </p><p> udsig<='0';mylift<=doorclose;
106、 </p><p> elsif stoplight(3)='1' or stoplight(4)='1' or stoplight(5)='1' or stoplight(6)= '1' or fdnlight(6)='1' or fdnlight(5)='1' o
107、r fdnlight(4)='1' or fdnlight(3)='1' then </p><p> udsig<='0';mylift<=up;</p><p> else udsig<='1';mylift<=down;
108、 </p><p><b> end if;</b></p><p> elsif position=1 then </p><p> if stoplight="000000" and fu
109、plight="000000" and fdnlight="000000" then </p><p> udsig<='0';mylift<=doorclose; </p><p> else uds
110、ig<='0';mylift<=up;</p><p><b> end if;</b></p><p><b> end if;</b></p><p> elsif udsig='1' then
111、 </p><p> if position=1 then </p><p> if stoplight="000000" and fuplight="000000" and fdnlight=&qu
112、ot;000000" then </p><p> udsig<='0';mylift<=doorclose; </p><p> else udsig<='0'; mylift<=up;
113、 </p><p><b> end if; </b></p><p> elsif position=2 then </p><p> if sto
114、plight="000000" and fuplight="000000" and fdnlight="000000" then </p><p> udsig<='1';mylift<=doorclose; &
115、lt;/p><p> elsif stoplight(1)='1' or fuplight(1)='1' then </p><p> udsig<='1';mylift<=down; </p>
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 基于fpga的六層電梯控制系統(tǒng)課程設計
- 基于fpga六層電梯控制系統(tǒng)
- 基于FPGA六層電梯控制系統(tǒng).doc
- 基于FPGA六層電梯控制系統(tǒng)初稿.doc
- eda課程設計--基于fpga的4層電梯控制
- 基于FPGA六層電梯控制系統(tǒng)二稿.doc
- 四層電梯控制系統(tǒng)plc課程設計
- plc課程設計--- 四層電梯控制系統(tǒng)
- 電梯課程設計-- 基于plc的電梯控制系統(tǒng)設計
- 電梯課程設計---三層電梯模型控制系統(tǒng)設計
- 基于plc六層電梯控制系統(tǒng)的設計
- 基于plc六層電梯控制系統(tǒng)設計
- plc三層電梯課程設計--- 三層電梯控制系統(tǒng)的設計
- 課程設計---四層電梯plc控制系統(tǒng)的模擬
- 課程設計---基于plc的三層電梯運行控制系統(tǒng)設計
- plc課程設計---四層電梯plc控制系統(tǒng)設計
- plc課程設計--三層電梯控制系統(tǒng)設計
- plc課程設計--四層電梯plc控制系統(tǒng)設計
- plc課程設計---四層電梯plc控制系統(tǒng)設計
- plc電梯課程設計---基于plc控制的五層電梯系統(tǒng)
評論
0/150
提交評論