基于fpga的六層電梯控制器_第1頁
已閱讀1頁,還剩24頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡介

1、<p>  《EDA技術(shù)》項(xiàng)目設(shè)計(jì)報(bào)告</p><p>  題目:基于FPGA的六層電梯控制器</p><p>  學(xué) 院:電子與信息工程學(xué)院</p><p>  專 業(yè):電子信息科學(xué)與技術(shù)</p><p>  姓 名: X X X </p><p>  班 級:

2、 14電信本(2)班 </p><p>  學(xué) 號: 140919022 </p><p>  指導(dǎo)老師: X X X </p><p><b>  二〇一六年十二月</b></p><p><b>  1、 緒論2</b></p><

3、;p>  1.1電梯控制器的發(fā)展現(xiàn)狀2</p><p>  1.2本次設(shè)計(jì)的主要內(nèi)容3</p><p>  1.3設(shè)計(jì)原理與思路4</p><p><b>  1.4硬件設(shè)計(jì)4</b></p><p><b>  1.5軟件設(shè)計(jì)5</b></p><p>  

4、2、 FPGA 硬件結(jié)構(gòu)知識6</p><p>  2.1 FPGA 概述6</p><p>  2.2 FPGA 體系結(jié)構(gòu)6</p><p>  2.3 FPGA 常用芯片介紹7</p><p>  3、VHDL 硬件描述語言7</p><p>  3.1 VHDL 語言特點(diǎn)7</p>&l

5、t;p>  3.2 狀態(tài)機(jī)的VHDL 實(shí)現(xiàn)8</p><p>  4、電梯控制器的工作原理8</p><p>  5、電梯控制系統(tǒng)的設(shè)計(jì)內(nèi)容9</p><p>  5.1 時(shí)鐘分頻模塊9</p><p>  5.2 按鍵處理模塊11</p><p>  5.3 電梯運(yùn)行控制模塊13</p>

6、<p>  5.4 數(shù)碼管顯示模塊19</p><p>  5.5 電梯超重控制可行性分析20</p><p>  6、 電梯控制器頂層圖形21</p><p><b>  7、 總結(jié)23</b></p><p><b>  緒論</b></p><p>

7、;  1.1電梯控制器的發(fā)展現(xiàn)狀</p><p>  國家規(guī)定超過六樓以上的樓層必須按要求安裝電梯,而且隨著超高層建筑的出現(xiàn),電梯的應(yīng)用越來越來廣泛了,與此同時(shí),對電梯的要求也越來越高了。目前,電梯的設(shè)計(jì)、工藝不斷提高,電梯的品種也逐漸增多,電梯的材質(zhì)由黑白到彩色,樣式由直式到斜式,在操縱控制方面更是步步出新:手柄開關(guān)操縱、按鈕控制、信號控制、集選控制、人機(jī)對話等;多臺(tái)電梯還出現(xiàn)了并聯(lián)控制、智能群控;雙層轎箱電梯

8、展示出節(jié)省井道空間,提升運(yùn)輸能力的優(yōu)勢,變速式自動(dòng)人行道扶梯大大節(jié)省了行人的時(shí)間;不同外形的電梯則使身處其中的乘客的視線不再封閉。</p><p>  電梯的結(jié)構(gòu)分為:四大空間,八大系統(tǒng);四大空間:機(jī)房部分、井道及地坑部分、轎廂部分、層站部分;八大系統(tǒng):曳引系統(tǒng)、導(dǎo)向系統(tǒng)、轎廂、門系統(tǒng)、重量平衡系統(tǒng)、電力拖動(dòng)系統(tǒng)、電氣控制系統(tǒng)、安全保護(hù)系統(tǒng);電梯的功能結(jié)構(gòu)決定電梯的八大應(yīng)用技術(shù):</p><p

9、>  1) 全數(shù)字識別乘客技術(shù)(所有乘客進(jìn)入電梯前進(jìn)行識別,其中包括眼球識別、指紋識別)</p><p>  2) 數(shù)字智能型安全控制技術(shù)(通過乘客識別系統(tǒng)或者IC 卡以及數(shù)碼監(jiān)控設(shè)備,拒絕外來人員進(jìn)入)</p><p>  3) 第四代無機(jī)房電梯技術(shù)(主機(jī)必須與導(dǎo)軌和轎廂分離,完全沒有共振共鳴,速度可以達(dá)到2.0M/S 以上,最高可以使用在30 層以上。)</p>&

10、lt;p>  4) 雙向安全保護(hù)技術(shù)(雙向安全鉗、雙向限速器,在歐洲必須使用,中國正在被普遍使用)</p><p>  5) 快速安裝技術(shù)(改變過去的電梯安裝方法,能夠快速組裝)</p><p>  6) 節(jié)能技術(shù)(采用節(jié)能技術(shù),使電梯更節(jié)約能源)</p><p>  7) 數(shù)字監(jiān)控技術(shù)(完全采用計(jì)算機(jī)進(jìn)行電梯監(jiān)控與控制)</p><p&g

11、t;  8) 無線遠(yuǎn)程控制及報(bào)警裝置(當(dāng)電梯產(chǎn)生故障時(shí),電梯可以通過無線裝置給手機(jī)發(fā)送故障信息,并通過手機(jī)發(fā)送信號對電梯進(jìn)行簡單控制。)</p><p>  本次設(shè)計(jì)主要是控制電梯的運(yùn)行模式和狀態(tài),對信號進(jìn)行處理的模塊,重點(diǎn)在對響應(yīng)的信號進(jìn)行處理,并將處理結(jié)果反饋給對應(yīng)功能的控制端口,實(shí)現(xiàn)對電梯運(yùn)行的全面控制。</p><p>  1.2本次設(shè)計(jì)的主要內(nèi)容</p><p

12、>  隨著可編程邏輯電路和EDA 技術(shù)的發(fā)展,在邏輯電路設(shè)計(jì)和嵌入式系統(tǒng)設(shè)計(jì)方面,以CPLD/FPGA 為代表的可編程邏輯器件已經(jīng)逐步代替了傳統(tǒng)的標(biāo)準(zhǔn)邏輯器件;本次設(shè)計(jì)的電梯控制器所有的程序可以集成在一個(gè)FPGA 開發(fā)芯片上面,不用在用其他功能的分立邏輯元件,達(dá)到集成度高、響應(yīng)快、功耗低的特點(diǎn)。</p><p>  本次設(shè)計(jì)是基于 FPGA 的電梯控制器的研究,是電梯控制的核心技術(shù),通過電梯控制器可以對電梯

13、運(yùn)行模式和狀態(tài)進(jìn)行全面的控制,這也是次設(shè)計(jì)的研究重要性;電梯的層數(shù)為6 層,本次設(shè)計(jì)采用模塊化設(shè)計(jì),主要分為四大模塊:時(shí)鐘分頻模塊、按鍵處理模塊、電梯運(yùn)行控制模塊、數(shù)碼管顯示模塊。</p><p>  由于 FPGA 技術(shù)近些年來蓬勃發(fā)展,而且在很多領(lǐng)域已經(jīng)應(yīng)用的十分成熟,用FPGA 可以實(shí)現(xiàn)對電梯精確、實(shí)時(shí)性控制,而且用于FPGA 開發(fā)的芯片都是一些微處理器芯片,便于集成和智能化設(shè)計(jì),而且大大縮短了開發(fā)周期。&

14、lt;/p><p>  1.3設(shè)計(jì)原理與思路</p><p>  本次設(shè)計(jì)是實(shí)現(xiàn) 6 層電梯的運(yùn)行控制,當(dāng)在某一樓層按下上升或者下降請求按鈕時(shí),控制器響應(yīng)該請求并控制電梯前往該樓層,當(dāng)?shù)竭_(dá)該樓層時(shí)電梯開門,當(dāng)進(jìn)入電梯后,電梯關(guān)門,此時(shí)按下要到達(dá)的樓層按鈕,控制器響應(yīng)該請求并控制電梯前往該樓層,當(dāng)?shù)竭_(dá)前往樓層后,電梯開門,走出電梯,然后關(guān)門......,就這樣往復(fù)的實(shí)現(xiàn)電梯的控制功能。電梯運(yùn)行時(shí)

15、遵循如下規(guī)則:當(dāng)電梯處于上升模式時(shí),只響應(yīng)比電梯所在位置高的上樓信號,由下至上依次執(zhí)行;直到最后一個(gè)上樓請求執(zhí)行完畢,如有更高層有下樓請求時(shí),則直接升到有下降請求的最高樓,然后進(jìn)入下降模式,電梯處于下降模式時(shí),則與上升相反。</p><p>  電梯的輸入信號主要包括外部輸入信號和內(nèi)部輸入信號;對于電梯外部輸入信號:每一層電梯門外都有上升請求和下降請求按鈕,其中一樓電梯門外只有上升請求按鈕,六樓電梯門外只有下降請

16、求按鈕。對于電梯內(nèi)部輸入信號主要有:6 個(gè)前往樓層的按鈕、提前關(guān)門按鈕、延時(shí)關(guān)門按鈕、電梯異常按鈕。</p><p>  電梯輸出信號也主要包括外部輸出信號和內(nèi)部輸出信號;對于電梯外部輸出信號包括上升請求按鈕和下降按鈕指示信號、電梯當(dāng)前所在樓層指示信號、電梯運(yùn)行方向指示信號。電梯內(nèi)部輸出信號包括6 個(gè)前往樓層按鈕指示信號、超重等警告指示信號、電梯當(dāng)前所在樓層指示信號、電梯運(yùn)行方面指示信號。</p>

17、<p><b>  1.4硬件設(shè)計(jì)</b></p><p>  本次設(shè)計(jì)主要是通過 Altera 公司生產(chǎn)的CycloneIII這一款芯片進(jìn)行功能的實(shí)現(xiàn),CycloneIII 器件采用TSMC90nm 低K 絕緣材料工藝技術(shù),這種技術(shù)結(jié)合Altera 低成本的設(shè)計(jì)方式,使之能夠在更低的成本下制造出更大容量的器件。這種新的器件比第一代Cyclone 產(chǎn)品具有兩倍多的I/O 引腳,且對

18、可編程邏輯的存儲(chǔ)塊和其它特性進(jìn)行了最優(yōu)的組合,具有許多新的增強(qiáng)特性。</p><p>  CycloneIII 器件包含了許多新的特性,如嵌入存儲(chǔ)器、嵌入乘法器、PLL 和低成本的封裝,這些都為諸如視頻顯示、數(shù)字電視(DTV)、機(jī)頂盒(STB)、DVD 播放器、DSL調(diào)制解調(diào)器、家用網(wǎng)關(guān)和中低端路由器等批量應(yīng)用進(jìn)行了優(yōu)化。在EDA 設(shè)計(jì)的開發(fā)板上面,支持SOPC 片上可編程,在CycloneIII 芯片旁邊外圍有

19、按鍵模塊、液晶顯示模塊、LED 指示燈等,通過QuartusⅡ平臺(tái)將硬件描述語言下載至該芯片中,然后進(jìn)行程序的調(diào)試、運(yùn)行并進(jìn)行功能的實(shí)現(xiàn)。</p><p><b>  1.5軟件設(shè)計(jì)</b></p><p>  Altera 的FPGA 設(shè)計(jì)主要采用兩種標(biāo)準(zhǔn)語言:VHDL/Verilog HDL。其中VerilogHDL 出現(xiàn)早,運(yùn)用廣泛,而且比較簡單,在NIOS 項(xiàng)

20、目里運(yùn)用較多;而VHDL 語言功能強(qiáng)大,語句相對要復(fù)雜一些,所以對于現(xiàn)在一些復(fù)雜的可編程項(xiàng)目多采用VHDL語言編寫。</p><p>  VHDL(Very-High-Speed Integrated Circuit Hardware Description Language)主要用于描述數(shù)字系統(tǒng)的結(jié)構(gòu)、行為、功能和接口。除了含有許多具有硬件特征的語句外,VHDL 的語言形式和描述風(fēng)格與句法是十分類似于一般的計(jì)算

21、機(jī)高級語言。VHDL的程序結(jié)構(gòu)特點(diǎn)是將一項(xiàng)工程設(shè)計(jì),或稱設(shè)計(jì)實(shí)體(可以是一個(gè)元件,一個(gè)電路模塊或一個(gè)系統(tǒng))分成外部(或稱可視部分、端口)和內(nèi)部(或稱不可視部分),涉及實(shí)體的內(nèi)部功能和算法完成部分。在對一個(gè)設(shè)計(jì)實(shí)體定義了外部界面,一旦其內(nèi)部開發(fā)完成后,其他的設(shè)計(jì)就可以直接調(diào)用這個(gè)</p><p>  實(shí)體。如下圖4-1 是VHDL 的層次模型:</p><p>  圖 4-1 具有不同構(gòu)造體

22、的VHDL 模型</p><p>  VHDL 語言具有強(qiáng)大的語言結(jié)構(gòu),只需采用簡單明確的VHDL 語言程序就可以描述十分復(fù)雜的硬件電路。同時(shí),它還具有多層次的電路設(shè)計(jì)描述功能:既支持自頂向下的設(shè)計(jì)方式,也支持自底向上的設(shè)計(jì)方法;既支持模塊化設(shè)計(jì)方法, 也支持層次化設(shè)計(jì)方法;既可描述系統(tǒng)級電路,也可以描述門級電路;描述方式既可以采用行為描述、寄存器傳輸描述或者結(jié)構(gòu)描述,也可以采用三者的混合描述方式。VHDL 語言

23、具有很強(qiáng)的移植能力,對于同一個(gè)硬件電路的VHDL 語言描述,它可以從一個(gè)模擬器移植到另一個(gè)模擬器上、從一個(gè)綜合器移植到另一個(gè)綜合器上或者從一個(gè)工作平臺(tái)移植到另一個(gè)工作平臺(tái)上去執(zhí)行。VHDL 語言采用基于庫 ( library) 的設(shè)計(jì)方法。在設(shè)計(jì)過程中,設(shè)計(jì)人員可以建立各種可再次利用的模塊,一個(gè)大規(guī)模的硬件電路的設(shè)計(jì)不可能從門級電路開始一步步地進(jìn)行設(shè)計(jì),而是一些模塊的累加,這些模塊可以預(yù)先設(shè)計(jì)或者使用以前設(shè)計(jì)中的存檔模塊,將這些模塊存放

24、在庫中,就可以在以后的設(shè)計(jì)中進(jìn)行復(fù)用。</p><p>  本次設(shè)計(jì)主要是運(yùn)用 VHDL 語言進(jìn)行程序的編寫,采用自頂向下、模塊化設(shè)計(jì)方法。按照要求可以分為:時(shí)鐘分頻模塊、按鍵處理模塊、電梯運(yùn)行控制模塊、數(shù)碼管顯示模塊;分別設(shè)計(jì)出這四個(gè)模塊之后,進(jìn)行調(diào)試、運(yùn)行、功能仿真和時(shí)序分析,然后將生產(chǎn)的模塊圖在原理圖編輯器中連接起來,組成完整的電梯控制器。</p><p>  FPGA 硬件結(jié)構(gòu)知識

25、</p><p>  2.1 FPGA 概述</p><p>  FPGA(Field Programmable Gate Arry)即現(xiàn)場可編程門陣列,它是在PAL、GAL、CPLD 等可編程器件的基礎(chǔ)上進(jìn)一步發(fā)展的產(chǎn)物。它是作為專用集成電路(ASIC)領(lǐng)域中的一種半定制電路而出現(xiàn)的,既解決了定制電路的不足,又克服了原有可編程器件門電路數(shù)有限的缺點(diǎn);FPGA 采用了邏輯單元陣列LCA(L

26、ogic Cell Array)這樣一3個(gè)概念,內(nèi)部包括可配置邏輯模塊CLB(Configurable Logic Block)、輸入輸出模塊IOB(Input Output Block)和內(nèi)部連線(Interconnect)三個(gè)部分。</p><p>  2.2 FPGA 體系結(jié)構(gòu)</p><p>  FPGA 采用邏輯單元陣列(LCA,Logic Cell Array)新概念,內(nèi)部包括

27、可配置邏輯模塊(CLB,Configurable Logic Block)、輸入輸出模塊(IOB,Input Output Block)和內(nèi)部互連資源(IR,Interconnect Resources)三部分組成。</p><p>  1) 可配置邏輯塊(CLB,Configurable Logic Block)是FPGA 的主要組成部分,主要是由邏輯函數(shù)發(fā)生器、觸發(fā)器、數(shù)據(jù)選擇器等電路組成。</p>

28、;<p>  輸入輸出模塊(IOB,Input Output Block)提供了器件引腳和內(nèi)部邏輯陣列之間的連接,主要是由輸入觸發(fā)器、輸入緩沖器和輸出觸發(fā)、鎖存器、輸出緩沖器組成。</p><p>  可編程互連資源(IR,Interconnect Resources)可以將FPGA 內(nèi)部的CLB 和CLB 之間、CLB 和IOB 之間連接起來,構(gòu)成各種具有復(fù)雜功能的系統(tǒng),IR主要由許多金屬線段構(gòu)成

29、,這些金屬線段帶有可編程開關(guān),通過自動(dòng)布線實(shí)現(xiàn)各種電路的連接。</p><p>  2.3 FPGA 常用芯片介紹</p><p>  目前世界上有很多生產(chǎn)FPGA 芯片的公司,常用的主要有:Altera、XIlinx、Lattice和Actel,其中Altera 和XIlinx 占據(jù)主流市場。</p><p>  1) Altera 的主流FPGA 分為兩大類:一

30、種是側(cè)重低成本、容量中等、性能可以滿足一般邏輯設(shè)計(jì)要求的,如Cyclone 系列;另一種是側(cè)重高性能、容量大、性能可以滿足各類高端應(yīng)用,如Stratix 系列。</p><p>  2) XIlinx 是FPGA發(fā)明者,是老牌PLD,產(chǎn)品的種類較全,主要有:XC9500/4000、Cool Runner(XPLA3)、Spartan、Virtex 等系列。</p><p>  3) Lat

31、tice 是在系統(tǒng)編程(ISP)技術(shù)的發(fā)明者,主要有:ispLSI2000/5000/8000、MACH4/5、ispMACH4000 等系列。</p><p>  4) Actel 公司是世界反熔絲技術(shù)的FPGA 領(lǐng)先供應(yīng)商,主要有兩大系列的反熔絲FPGA 產(chǎn)品SX-A 和MX 高速系列。</p><p>  3、VHDL 硬件描述語言</p><p>  3.1

32、 VHDL 語言特點(diǎn)</p><p>  VHDL(Very-High-Speed Integrated Circuit Hardware Description Language)是一種標(biāo)準(zhǔn)的硬件描述語言,中文意思是超高速集成電路硬件描述語言;利用VHDL 進(jìn)行系統(tǒng)行為級設(shè)計(jì)已經(jīng)成為FPGA 與ASIC 設(shè)計(jì)的主流,使用VHDL 不僅可以快速的描述和綜合FPGA 設(shè)計(jì),還可以提供一下的一些性能。</p&g

33、t;<p>  1) 功能強(qiáng)大且很具有靈活性,VHDL 具有很強(qiáng)大的語言結(jié)構(gòu),可以用簡潔明確的代碼描述復(fù)雜的控制邏輯,語言很靈活,支持設(shè)計(jì)庫和可重復(fù)使用的元件生成。</p><p>  2) 不依賴于器件的設(shè)計(jì),VHDL 允許設(shè)計(jì)者生成一個(gè)設(shè)計(jì)而不需要首先選擇一個(gè)用來實(shí)現(xiàn)設(shè)計(jì)的器件,對于同一個(gè)設(shè)計(jì)描述,可以采用多種不同的器件結(jié)構(gòu)來實(shí)現(xiàn)其功能。</p><p>  3) 具有可

34、移植性,因?yàn)閂HDL 是一種標(biāo)準(zhǔn)的語言,所以它可以被不同的工具所支持,這意味著同一個(gè)VHDL 設(shè)計(jì)描述可以在不同的設(shè)計(jì)項(xiàng)目中采用</p><p>  4) 可以對其設(shè)計(jì)性能進(jìn)行評估,設(shè)計(jì)者可以進(jìn)行一個(gè)完整的設(shè)計(jì)描述,并對其進(jìn)行綜合,生產(chǎn)選定的器件結(jié)構(gòu)的邏輯功能,然后評估結(jié)果,選用最適合設(shè)</p><p><b>  計(jì)需求的器件。</b></p><

35、;p>  5) 上市時(shí)間快、成本低、開發(fā)周期短,VHDL 語言的設(shè)計(jì)將大大提高數(shù)字單片化設(shè)計(jì)實(shí)現(xiàn)的速度,為生產(chǎn)者大大節(jié)約開發(fā)成本。</p><p>  3.2 狀態(tài)機(jī)的VHDL 實(shí)現(xiàn)</p><p>  有限狀態(tài)機(jī)以及其設(shè)計(jì)技術(shù)是使用數(shù)字系統(tǒng)設(shè)計(jì)中的重要組成部分,也是實(shí)現(xiàn)高效率、高可靠和高速控制邏輯系統(tǒng)的重要途徑,廣義而論,只要是涉及到觸發(fā)器的電路,都屬于狀態(tài)機(jī),由此也可以看出其重要

36、性。用VHDL 設(shè)計(jì)的狀態(tài)機(jī)根據(jù)不同的標(biāo)準(zhǔn)可以分為不同的形式:</p><p>  1) 從狀態(tài)機(jī)的信號輸出方式上分:Mealy 型和Moore 型;</p><p>  2) 從狀態(tài)機(jī)的描述結(jié)構(gòu)上分:單進(jìn)程狀態(tài)機(jī)和多進(jìn)程狀態(tài)機(jī);</p><p>  3) 從狀態(tài)機(jī)表達(dá)形式上分:符號化狀態(tài)機(jī)和確定狀態(tài)編碼狀態(tài)機(jī);</p><p>  4) 從

37、狀態(tài)機(jī)編碼方式上分:順序編碼狀態(tài)機(jī)、一位熱編碼狀態(tài)機(jī)和其他編碼方式狀態(tài)機(jī)。</p><p>  實(shí)際設(shè)計(jì)過程中,接觸最多的分類方法就是 Mealy 型和Moore 型;從輸出時(shí)序上看,前者是異步輸出,后者是同步輸出。Mealy 型狀態(tài)機(jī)的輸出是當(dāng)前狀態(tài)和所有輸入信號的函數(shù),它的輸出是輸入變化后立即變化的,不依賴時(shí)鐘的同步。Moore 型狀態(tài)的輸出僅為當(dāng)前狀態(tài)的函數(shù),但是在輸入發(fā)生變化時(shí)還必須等到時(shí)鐘的到來,輸出才

38、會(huì)變化,由此可見,Moore 型要多等待一個(gè)時(shí)鐘周期。</p><p>  本次設(shè)計(jì)中,電梯控制模塊部分就利用Moore 型狀態(tài)機(jī)的方法實(shí)現(xiàn)對電梯運(yùn)行狀態(tài)的同步控制,通過將電梯運(yùn)行過程分解為一些實(shí)質(zhì)性的狀態(tài)來進(jìn)行轉(zhuǎn)換,使得電梯的運(yùn)行變得方便、快捷、穩(wěn)定。</p><p>  4、電梯控制器的工作原理</p><p>  本次設(shè)計(jì)是實(shí)現(xiàn) 6 層電梯的運(yùn)行控制,當(dāng)在某一

39、樓層按下上升或者下降請求按鈕時(shí),控制器響應(yīng)該請求并控制電梯前往該樓層,當(dāng)?shù)竭_(dá)該樓層時(shí),電梯開門,當(dāng)進(jìn)入電梯后,電梯關(guān)門,此時(shí)按下要到達(dá)的樓層按鈕,控制器響應(yīng)該請求并控制電梯前往該樓層,當(dāng)?shù)竭_(dá)前往樓層后,電梯開門,走出電梯,然后關(guān)門......,就這樣往復(fù)的實(shí)現(xiàn)電梯的控制功能。</p><p>  在電梯運(yùn)行時(shí)遵循如下規(guī)則:當(dāng)電梯處于上升模式時(shí),只響應(yīng)比電梯所在位置高的上樓信號,由下至上依次執(zhí)行;直到最后一個(gè)上樓請

40、求執(zhí)行完畢,如有更高層有下樓請求時(shí),則直接升到有下降請求的最高樓,然后進(jìn)入下降模式,電梯處于下降模式時(shí),則與上升相反。</p><p>  電梯的輸入信號主要包括外部輸入信號和內(nèi)部輸入信號;對于電梯外部輸入信號主要有:每一層電梯門外都有上升請求和下降請求按鈕,其中一樓電梯門外只有上升請求按鈕,6 樓電梯門外只有下降請求按鈕。對于電梯內(nèi)部輸入信號主要有:6 個(gè)前往樓層的按鈕、提前關(guān)門按鈕、延時(shí)關(guān)門按鈕、電梯異常按鈕

41、。</p><p>  電梯輸出信號也主要包括外部輸出信號和內(nèi)部輸出信號;對于電梯外部輸出信號包括上升請求按鈕和下降按鈕指示信號、電梯當(dāng)前所在樓層指示信號、電梯運(yùn)行方向指示信號。電梯內(nèi)部輸出信號包括6 個(gè)前往樓層按鈕指示信號、超重等警告指示信號、電梯當(dāng)前所在樓層指示信號、電梯運(yùn)行方面指示信號。</p><p>  5、電梯控制系統(tǒng)的設(shè)計(jì)內(nèi)容</p><p>  本次

42、設(shè)計(jì)是基于 FPGA 的電梯控制器的研究,是電梯控制的核心技術(shù),通過電梯控制器可以對電梯運(yùn)行模式和狀態(tài)進(jìn)行全面的控制,這也是次設(shè)計(jì)的研究重要性;電梯的層數(shù)為6 層,本次設(shè)計(jì)采用模塊化設(shè)計(jì)方法,主要分為四大模塊:時(shí)鐘分頻模塊、按鍵處理模塊、電梯運(yùn)行控制模塊、數(shù)碼管顯示模塊。其方框原理圖5-0 如下:</p><p>  圖 5-0 電梯控制器原理圖</p><p>  5.1 時(shí)鐘分頻模塊&

43、lt;/p><p>  時(shí)鐘分頻模塊功能是將系統(tǒng)頻率分頻為兩種不同的頻率,一個(gè)是2 分頻時(shí)鐘供電梯運(yùn)行控制模塊使用,另一個(gè)8 分頻時(shí)鐘供其他模塊使用,其源代碼如下:</p><p>  時(shí)鐘分頻模塊:clkdiv.vhd</p><p>  LIBRARY ieee;</p><p>  USE ieee.std_logic_1164.all;&

44、lt;/p><p>  use ieee.std_logic_unsigned.all; --定義所用的標(biāo)準(zhǔn)庫</p><p>  ENTITY clkdiv IS --時(shí)鐘分頻寄存器(CLKDIV)</p><p><b>  PORT(</b></p><p>  clk : in out std_logi

45、c; --系統(tǒng)時(shí)鐘頻率</p><p>  clk_2hz: out std_logic; --2分頻脈沖(作為電梯控制時(shí)鐘</p><p>  clk_8hz: out std_logic --8分頻脈沖(作為按鍵處理時(shí)鐘)</p><p>  );--定義輸入輸出變量</p><p>  end clkdiv;</

46、p><p>  ARCHITECTURE behave OF clkdiv IS</p><p>  signal cnt:std_logic_vector(7 downto 0); --定義一個(gè)8 位的變量</p><p>  begin process (clk) --時(shí)鐘分頻進(jìn)程</p><p><b>  begin<

47、;/b></p><p>  if clk'event and clk='1' then --時(shí)鐘脈沖上升沿有效</p><p>  cnt <= cnt + 1;</p><p>  clk_8hz <= cnt(1); --變量cnt 的第1 位輸出2 分頻</p><p>  clk_2hz

48、<= cnt(4); --變量cnt 的第3 位輸出8 分頻</p><p><b>  end if;</b></p><p>  end process;</p><p>  end behave;</p><p>  源程序編寫完成后,進(jìn)行調(diào)試、運(yùn)行并生成模塊文件,確認(rèn)沒有錯(cuò)誤之后進(jìn)行功能仿真、時(shí)序分析。其

49、模塊原理圖5-1 如下:</p><p>  圖 5-1 時(shí)鐘分頻模塊原理圖</p><p>  5.2 按鍵處理模塊</p><p>  按鍵處理模塊的功能是把電梯外部與內(nèi)部的按鍵信號進(jìn)行處理,把處理好的按鍵信號送到電梯運(yùn)行控制模塊;根據(jù)電梯外部按鍵信號轉(zhuǎn)化為電梯運(yùn)行控制模塊的外部請求信號,根據(jù)電梯內(nèi)部的按鍵信號轉(zhuǎn)化為電梯運(yùn)行控制模塊的電梯前往信號,根據(jù)電梯樓層信

50、號及時(shí)清除電梯外部與內(nèi)部按鍵信號。其源代碼編寫如 下:</p><p>  按鍵處理模塊:keypro.vhd</p><p>  library ieee;</p><p>  use ieee.std_logic_1164.all;</p><p>  use ieee.std_logic

51、_arith.all;</p><p>  use ieee.std_logic_unsigned.all;</p><p>  entity keypro is</p><p>  port (clk:in std_logic;--按鍵時(shí)鐘</p><p>  reset:in std_logic;--異步置位按鍵</

52、p><p>  fup:in std_logic_vector(5 downto 1); --上升請求按鍵(低電平有</p><p>  fdn:in std_logic_vector(6 downto 2); --下降請求按鍵(低電平有效)</p><p>  fuplight:out std_logic_vector (6 downto 1);--電

53、梯外部上升請求指示燈</p><p>  fdnlight:out std_logic_vector (6 downto 1);--電梯外部下降請求指示燈</p><p>  st: in std_logic_vector (6 downto 1); --電梯內(nèi)部各層請求按鍵</p><p>  stlight:out std_logic_vector (

54、6 downto 1);--電梯內(nèi)部各層請求指示燈</p><p>  position:in integer range 1 to 6;--電梯位置指示</p><p>  clearup:in std_logic;--用于清除上升請求指示燈的信號</p><p>  cleardn:in std_logic--用于清除下降請求指示燈的信號</p>

55、;<p><b>  );</b></p><p>  end keypro;</p><p>  architecture behave of keypro is--控制按鍵信號燈進(jìn)程</p><p><b>  begin</b></p><p>  process(reset,c

56、lk)</p><p><b>  begin</b></p><p>  if reset = '0' then</p><p>  stlight <= "000000";</p><p>  fuplight <= "000000";</p&

57、gt;<p>  fdnlight <= "000000";</p><p><b>  else </b></p><p>  if clk'event and clk='1' then</p><p>  --清除電梯當(dāng)前外部上升請求信號和電梯內(nèi)部前往該樓層信號</p&g

58、t;<p>  if clearup = '1' then</p><p>  stlight(position) <= '0';</p><p>  fuplight(position) <= '0';</p><p><b>  else</b></p

59、><p>  fuplight <=(not fup) & '0';</p><p>  stlight <= not st;</p><p><b>  end if;</b></p><p>  --清除電梯當(dāng)前外部下降請求信號和電梯內(nèi)部前往該樓層信號</p>

60、<p>  if cleardn = '1' then</p><p>  stlight(position) <= '0';</p><p>  fdnlight(position) <= '0';</p><p><b>  else</b></p>

61、;<p>  fdnlight <= '0' & (not fdn);</p><p>  stlight <= not st;</p><p>  end if;</p><p><b>  end if;</b></p><p><b&

62、gt;  end if;</b></p><p>  end process;</p><p>  end behave;</p><p>  源程序編寫完成后,進(jìn)行編譯、運(yùn)行并生成模塊文件,確認(rèn)沒有錯(cuò)誤之后進(jìn)行波形仿真、時(shí)序分析。其模塊原理圖5-2 如下:</p><p>  圖 5-2 按鍵處理模塊原理圖</p>

63、<p>  5.3 電梯運(yùn)行控制模塊</p><p>  電梯運(yùn)行控制模塊是此次設(shè)計(jì)的核心,電梯運(yùn)行的模式和狀的態(tài)控制效果完全取決于電梯控制模塊,它的功能是在系統(tǒng)2 分頻時(shí)鐘下,根據(jù)按鍵處理模塊輸出的信號,控制電梯上升與下降運(yùn)行模式和狀態(tài),當(dāng)電梯關(guān)門時(shí)輸出相應(yīng)的上升與下降清除信號,同時(shí)輸出電梯當(dāng)前所在樓層的數(shù)碼管輸出信號與電梯運(yùn)行方向,本次是設(shè)計(jì)的6層電梯控制系統(tǒng),在源程序中具體要體現(xiàn)一下功能:&l

64、t;/p><p>  1) 每層電梯(除 1 樓和6 樓外,1 樓只有上升請求按鈕,6 樓只有下降請求按鈕)入口出設(shè)置有上升和下降請求按鈕,電梯內(nèi)部設(shè)有要到達(dá)樓層的請求按鈕1-6 樓。</p><p>  2) 設(shè)有電梯所處位置數(shù)碼管顯示部分,電梯運(yùn)行模式的 LED 顯示部分。</p><p>  3) 電梯能記憶電梯外部所有信號請求,并按照電梯運(yùn)行規(guī)則進(jìn)行順序響應(yīng),每

65、個(gè)電梯請求信號保留到電梯響應(yīng)結(jié)束。</p><p>  4) 電梯運(yùn)行規(guī)則:當(dāng)電梯上升時(shí)候,只響應(yīng)比電梯所在樓層高的上樓信號,由下到上依次執(zhí)行,直到最后一個(gè)上升請求信號執(zhí)行完畢,當(dāng)電梯下降時(shí)候,只響應(yīng)比電梯所在樓層低的下樓信號,由上到下依次執(zhí)行,直到最后一下下降請求信號執(zhí)行完畢。</p><p>  電梯運(yùn)行控制模塊的源程序如下:</p><p>  電梯運(yùn)行控制模

66、塊:elevrun.vhd</p><p>  library ieee;</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>&

67、lt;p>  entity elerun is</p><p>  port (clk:in std_logic;--電梯時(shí)鐘</p><p>  alarm:in std_logic;</p><p>  reset:in std_logic;--異步置位按鍵</p><p>  fuplight:in std_logic_v

68、ector (6 downto 1);--電梯外部上升請求指示燈</p><p>  fdnlight:in std_logic_vector (6 downto 1);--電梯外部下降請求指示燈</p><p>  stlight:in std_logic_vector (6 downto 1); --電梯內(nèi)部各層請求指示燈</p><p>  position:

69、out integer range 1 to 6; --電梯位置指示</p><p>  doorlight:out std_logic; --電梯門開關(guān)指示燈</p><p>  clearup:out std_logic;--用于清除上升請求指示燈的信號</p><p>  cleardn:out std_logic;--用于清除下降

70、請求指示燈的信號</p><p>  yanshi:in std_logic;</p><p>  tiqian:in std_logic;</p><p>  udsig:buffer std_logic_vector(7 downto 0)--電梯升降指示</p><p><b>  );</b></p

71、><p>  end elerun;</p><p>  architecture sixflift of elerun is</p><p>  type lift_state is</p><p>  (stopon1,dooropen,doorclose,doorwait1,doorwait2,doorwait3,</p>

72、<p>  doorwait4,doorwait5,doorwait6,up,down,stop);</p><p>  signal mylift: lift_state;</p><p>  signal pos: integer range 6 downto 1;</p><p>  signal udflag :std_logic;</p&g

73、t;<p>  signal posreg :integer range 1 to 6;</p><p>  signal one:std_logic_vector (6 downto 1);</p><p><b>  begin</b></p><p>  process(reset,clk)--控制電梯狀態(tài)的進(jìn)程&l

74、t;/p><p><b>  begin </b></p><p>  if (reset = '1' or alarm = '1') then</p><p>  mylift <= stopon1;</p><p>  clearup <= '1';</

75、p><p>  cleardn <= '1';</p><p><b>  else</b></p><p>  if (clk 'event and clk = '1') then</p><p>  case mylift is</p><p> 

76、 when stopon1 => </p><p>  doorlight <= '0';</p><p>  posreg <= 1;</p><p>  mylift <= doorwait1;</p><p>  clearup <= '0';&l

77、t;/p><p>  cleardn <= '0';</p><p>  udsig <= "00000010";</p><p>  when doorwait1 => </p><p>  if tiqian = '1' then</p><

78、p>  mylift <= doorclose;</p><p>  elsif yanshi = '1' then</p><p>  mylift <= doorwait1;</p><p><b>  else</b></p><p>  mylift <= doorwait

79、2;</p><p>  end if;</p><p>  clearup <= '0';</p><p>  cleardn <= '0';</p><p>  when doorwait2 => </p><p>  if tiqian =

80、'1' then</p><p>  mylift <= doorclose;</p><p>  elsif yanshi = '1' then</p><p>  mylift <= doorwait1;</p><p><b>  else</b></p>

81、<p>  mylift <= doorwait3;</p><p>  end if;</p><p>  clearup <= '0';</p><p>  cleardn <= '0';</p><p>  when doorwait3 => <

82、;/p><p>  if tiqian = '1' then</p><p>  mylift <= doorclose;</p><p>  elsif yanshi = '1' then</p><p>  mylift <= doorwait1;</p><p><b

83、>  else</b></p><p>  mylift <= doorwait4;</p><p><b>  end if;</b></p><p>  clearup <= '0';</p><p>  cleardn <= '0';

84、</p><p>  when doorwait4 => </p><p>  if tiqian = '1' then</p><p>  mylift <= doorclose;</p><p>  elsif yanshi = '1' then</p><p>  my

85、lift <= doorwait1;</p><p><b>  else</b></p><p>  mylift <= doorwait5;</p><p>  end if;</p><p>  clearup <= '0';</p><p>  c

86、leardn <= '0';</p><p>  when doorwait5 => </p><p>  if tiqian = '1' then</p><p>  mylift <= doorclose;</p><p>  elsif yanshi = '1

87、9; then</p><p>  mylift <= doorwait1;</p><p><b>  else</b></p><p>  mylift <= doorwait6;</p><p>  end if;</p><p>  clearup <= '

88、;0';</p><p>  cleardn <= '0';</p><p>  when doorwait6 => </p><p>  mylift <= doorclose; </p><p>  cleardn <= (not udflag); </p

89、><p>  clearup <= udflag;</p><p>  when doorclose => </p><p>  doorlight <= '0';</p><p>  clearup <= '0';</p><p>  cleardn &l

90、t;= '0';</p><p>  if posreg = 6 then</p><p>  if (stlight = "000000" and fuplight = "000000" and fdnlight = "000000") then</p><p>  

91、mylift <= doorclose;</p><p>  udsig <= "00000010";</p><p>  elsif stlight > "000000" or fdnlight > "000000" or fuplight > "000000" t

92、hen</p><p>  mylift <= down;</p><p>  udsig<="01111010";</p><p>  udflag <= '1';</p><p><b>  end if;</b></p><p&

93、gt;  elsif posreg = 1 then</p><p>  if (stlight = "000000" and fuplight = "000000" and fdnlight = "000000") then</p><p>  mylift <= doorclose;</

94、p><p>  udsig <= "00000010";</p><p>  elsif stlight > "000000" or fdnlight > "000000" or fuplight > "000000" then</p><p>  mylift &l

95、t;= up;</p><p>  udsig<="01111100";</p><p>  udflag <= '0';</p><p><b>  end if;</b></p><p><b>  else</b></p><

96、;p>  if (stlight = "000000" and fuplight = "000000" and fdnlight = "000000") then</p><p>  mylift <= doorclose;</p><p>  udsig <= "00000010";

97、</p><p>  elsif stlight >= (one + one) or fuplight >= (one + one) or fdnlight >= (one + one) then</p><p>  mylift <= up;</p><p>  udsig<="01111100";<

98、;/p><p>  udflag <= '0';</p><p>  elsif (stlight + stlight) <= one or (fuplight + fuplight) <= one or (fdnlight + fdnlight) <= one then </p><p>  mylift

99、<= down;</p><p>  udsig<="01111010";</p><p>  udflag <= '1';</p><p><b>  else </b></p><p>  mylift <= doorclose;</p>&l

100、t;p><b>  end if;</b></p><p>  end if;</p><p>  when up =></p><p>  clearup <= '0';</p><p>  cleardn <= '0';&l

101、t;/p><p>  if posreg < 6 and (stlight(posreg) = '1' or fuplight(posreg) = '1' or (stlight = "000000" and fdnlight(posreg) = '1'))</p><p>  then mylift <= st

102、op;</p><p>  if (stlight = "000000" and fdnlight(posreg) = '1' and fuplight = "000000") then</p><p>  udflag <= '1';</p><p>  end if;&l

103、t;/p><p>  elsif posreg = 6 and (stlight(posreg) = '1' or fuplight(posreg) = '1' or ( fuplight = "000000" and fdnlight(posreg) = '1'))</p><p>  then mylift <

104、;= stop; </p><p>  elsif posreg = 6 and ( fdnlight > "000000" or fuplight > "000000") then</p><p>  mylift <= stop;</p><p><b>  els

105、e</b></p><p>  mylift <= up;</p><p>  udsig<="01111100";</p><p>  udflag <= '0'; </p><p>  if posreg<6 then</p>&l

106、t;p>  posreg <= (posreg+1);</p><p>  end if;</p><p><b>  end if;</b></p><p>  when down =></p><p>  clearup <= '0';</p>&l

107、t;p>  cleardn <= '0'; </p><p>  if posreg > 1 and (stlight(posreg) = '1' or fdnlight(posreg) = '1' or ( stlight = "000000" and fuplight(posreg) = '1' )

108、)</p><p>  then mylift <= stop;</p><p>  if (stlight = "000000" and fuplight(posreg) = '1' and fdnlight = "000000") then</p><p>  udflag <= '0&

109、#39;;</p><p><b>  end if;</b></p><p>  elsif posreg = 1 and (stlight(posreg) = '1' or fdnlight(posreg) = '1' or ( fdnlight = "000000" and fuplight(posreg)

110、= '1'))</p><p>  then mylift <= stop;</p><p>  elsif posreg = 1 and ( fdnlight > "000000" or fuplight > "000000") then</p><p>  mylift <=

111、 stop;</p><p><b>  else </b></p><p>  mylift <= down;</p><p>  udsig<="01111010";</p><p>  udflag <= '1';</p><p&g

112、t;  if posreg>1 then</p><p>  posreg <= (posreg-1);</p><p>  end if;</p><p><b>  end if;</b></p><p>  when stop => </p><p>  myl

113、ift <= dooropen;</p><p>  clearup <= '0';</p><p>  cleardn <= '0';</p><p>  when dooropen => </p><p>  doorlight <= '1';

114、 </p><p>  clearup <= '0';</p><p>  cleardn <= '0';</p><p>  mylift <= doorwait1;</p><p>  when others =></p><p>  my

115、lift <= doorwait1;</p><p>  clearup <= '0';</p><p>  cleardn <= '0';</p><p><b>  end case;</b></p><p><b>  end if;<

116、;/b></p><p><b>  end if;</b></p><p>  end process ;</p><p>  position <= posreg;</p><p>  process(clk,posreg)</p><p><b>  begin<

117、;/b></p><p>  if clk 'event and clk = '1' then</p><p>  case posreg is</p><p>  when 1 => one <= "000001";</p><p>  when 2 => one <

118、= "000010";</p><p>  when 3 => one <= "000100"; </p><p>  when 4 => one <= "001000"; </p><p>  when 5 => one <= "010000"; &

119、lt;/p><p>  when 6 => one <= "100000"; </p><p><b>  end case;</b></p><p><b>  end if;</b></p><p>  end process ;</p><p&

120、gt;<b>  end ;</b></p><p>  電梯控制運(yùn)行模塊源程序編寫完成后,進(jìn)行編譯、運(yùn)行并生成模塊文件,確認(rèn)沒有錯(cuò)誤之后進(jìn)行波形仿真、時(shí)序分析。其模塊原理圖5-3 如下:</p><p>  圖 5-3 電梯運(yùn)行控制模塊原理圖</p><p>  5.4 數(shù)碼管顯示模塊</p><p>  數(shù)碼管顯

121、示模塊的功能主要是把樓層信號轉(zhuǎn)化為數(shù)字信號,通過數(shù)碼管進(jìn)行顯示,顯示電梯運(yùn)行到的樓層指示,本次設(shè)計(jì)用的是共陰極數(shù)碼管,其源程序如下:</p><p>  數(shù)碼管顯示模塊:floorled.vhd</p><p>  library ieee;</p><p>  use ieee.std_logic_1164.all;--定義所用的標(biāo)準(zhǔn)庫</p>&l

122、t;p>  entity floorled is</p><p>  port(clk : in std_logic;--系統(tǒng)時(shí)鐘頻率</p><p>  position :in std_logic_vector(2 downto 0);--電梯位置變量</p><p>  posled : out std_logic_vector(7 downto 0)

123、--電梯樓層顯示變量</p><p>  ); --定義輸入輸出變量 </p><p>  end floorled;</p><p>  architecture behave of floorled is</p><p><b>  begin&l

124、t;/b></p><p>  process(clk)--時(shí)鐘分頻進(jìn)程</p><p><b>  begin</b></p><p>  if clk 'event and clk = '1' then--時(shí)鐘脈沖上升沿有效</p><p>  case position is</

125、p><p>  when "001" => posled <= "01100000";--顯示數(shù)字1</p><p>  when "010" => posled <= "11011010";--顯示數(shù)字2</p><p>  when "011"

126、 => posled <= "11110010";--顯示數(shù)字3</p><p>  when "100" => posled <= "01100110";--顯示數(shù)字4</p><p>  when "101" => posled <= "10110110&quo

溫馨提示

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

評論

0/150

提交評論