版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、<p> 本科生畢業(yè)論文(設(shè)計(jì))</p><p> 基于EDA技術(shù)的交通燈設(shè)計(jì)</p><p> 姓 名: </p><p> 指導(dǎo)教師: </p><p> 院 系: 信息工程學(xué)院 </p><p>
2、; 專 業(yè): 電子信息工程 </p><p> 提交日期: </p><p><b> 目 錄</b></p><p><b> 中文摘要2</b></p><p><b> 外文摘要3</b></p
3、><p><b> 引言4</b></p><p><b> 1.緒論5</b></p><p> 1.1 EDA技術(shù)概述5</p><p> 1.1.1 EDA技術(shù)的發(fā)展與應(yīng)用5</p><p> 1.1.2 EDA技術(shù)的基本特征5</p>&
4、lt;p> 1.1.3 EDA的設(shè)計(jì)方法5</p><p> 1.2 硬件描述語(yǔ)言VHDL6</p><p> 1.2.1 VHDL的簡(jiǎn)介6</p><p> 1.2.2 VHDL的設(shè)計(jì)方法7</p><p> 1.3 MaxPlus II開(kāi)發(fā)平臺(tái)系統(tǒng)8</p><p> 1.3.1 Max
5、Plus II簡(jiǎn)介8</p><p> 1.3.2 MaxPlus II的特點(diǎn)9</p><p> 2.交通燈控制系統(tǒng)介紹10</p><p> 2.1 交通燈控制系統(tǒng)的功能10</p><p> 2.2 交通燈控制系統(tǒng)設(shè)計(jì)選擇10</p><p> 2.3 交通燈控制系統(tǒng)設(shè)計(jì)要求11</p
6、><p> 2.4 交通燈控制系統(tǒng)的基本組成模塊11</p><p> 2.5 交通燈控制器狀態(tài)12</p><p> 3.交通燈控制系統(tǒng)的設(shè)計(jì)12</p><p> 3.1 交通燈控制器功能描述及設(shè)計(jì)方法12</p><p> 3.2 交通燈控制器各模塊的程序設(shè)計(jì)13</p><p
7、> 3.2.1 控制部分的設(shè)計(jì)13</p><p> 3.2.2 顯示部分的設(shè)計(jì)14</p><p> 3.2.3 分頻器部分的設(shè)計(jì)15</p><p> 3.3 交通燈控制系統(tǒng)的仿真16</p><p> 3.3.1 對(duì)交通燈控制部分進(jìn)行仿真16</p><p> 3.3.2 對(duì)交通燈顯示
8、部分模塊進(jìn)行仿真17</p><p> 3.3.3 對(duì)交通燈系統(tǒng)進(jìn)行仿真18</p><p><b> 結(jié)束語(yǔ)19</b></p><p><b> 參考文獻(xiàn)20</b></p><p><b> 致謝21</b></p><p>&l
9、t;b> 附錄22 </b></p><p> 基于EDA技術(shù)的交通燈設(shè)計(jì)</p><p> 摘 要:伴隨著社會(huì)的發(fā)展以及人類生活水平的提高,汽車的數(shù)量在不斷增加。隨著EDA技術(shù)的發(fā)展和應(yīng)用領(lǐng)域的擴(kuò)大與深入,EDA技術(shù)在電子信息、通信、自動(dòng)、控制及計(jì)算機(jī)應(yīng)用等領(lǐng)域的重要性日益突出。隨著汽車數(shù)量的不斷增加,交通的問(wèn)題日益突出,單單依靠人力來(lái)指揮交通已經(jīng)不可行了。
10、所以,設(shè)計(jì)交通燈來(lái)完成這個(gè)需求就顯的越加迫切了。為了確保十字路口的行人和車輛順利、暢通地通過(guò),往往采用電子控制的交通信號(hào)來(lái)進(jìn)行指揮。以下就是運(yùn)用數(shù)字電子設(shè)計(jì)出的交通燈,其中紅燈亮,表示該條路禁止通行;黃燈亮表示停車;綠燈亮表示允許通行。</p><p> 關(guān)鍵詞:EDA;VHDL;PLD;交通燈</p><p> Design of Traffic Light </p>
11、<p> Based on EDA Technology</p><p> Abstract:With the development of society and the improvement of people's living standard, the number of cars is increasing.Along with the development of DEA te
12、chnology and it's expansion in application fields, the EDA technology in electronic information, communication, automatic control , computer application and other fields is of growing importance. With the ever increa
13、sing number of cars, traffic problems have become increasingly prominent,which leads to it not to be feasible only rely on ma</p><p> Key Words: EDA;VHDL;PLD;the traffic lights</p><p><b>
14、 引言</b></p><p> 隨著城市汽車保有量的越來(lái)越多,城市的交通擁擠問(wèn)題正逐漸引起人們的注意。交通燈是交管部門管理城市交通的重要工具。提高十字路口的通行效率,對(duì)緩解交通阻塞具有十分重要的現(xiàn)實(shí)意義。</p><p> 傳統(tǒng)的交通燈硬件電路設(shè)計(jì)方法是采用自下而上的設(shè)計(jì)方法,即根據(jù)系統(tǒng)對(duì)硬件的要求,詳細(xì)編制技術(shù)規(guī)格書(shū),并畫出系統(tǒng)控制流圖;然后根據(jù)技術(shù)規(guī)格書(shū)和系統(tǒng)控制流
15、圖,對(duì)系統(tǒng)的功能進(jìn)行細(xì)化,合理地劃分功能模塊,并畫出系統(tǒng)的功能框圖;接著就進(jìn)行各功能模塊的細(xì)化和電路設(shè)計(jì);各功能模塊電路設(shè)計(jì)、調(diào)試完成后,將各功能模塊的硬件電路連接起來(lái)再進(jìn)行系統(tǒng)的調(diào)試,最后完成整個(gè)系統(tǒng)的硬件設(shè)計(jì)。采用傳統(tǒng)方法設(shè)計(jì)數(shù)字系統(tǒng),特別是當(dāng)電路系統(tǒng)非常龐大時(shí),設(shè)計(jì)者必須具備較好的設(shè)計(jì)經(jīng)驗(yàn),而且繁雜多樣的原理圖的閱讀和修改也給設(shè)計(jì)者帶來(lái)諸多的不便。</p><p> 本文采用VHDL語(yǔ)言設(shè)計(jì)其硬件,以可編
16、程邏輯器件為載體,EDA軟件為開(kāi)發(fā)工具,設(shè)計(jì)一個(gè)交通燈。第一階段,通過(guò)參閱文獻(xiàn)及相關(guān)資料確定交通燈的設(shè)計(jì)方案,構(gòu)建電路功能模塊,利用相關(guān)軟件繪畫出電路圖,要求圖形繪制完整、精確、符合規(guī)范。第二階段,以硬件描述語(yǔ)言為系統(tǒng)邏輯描述的表達(dá)方式在EDA軟件平臺(tái)上編寫源程序,要求設(shè)計(jì)合理、性能得到優(yōu)化、器件利用率最高。第三階段,對(duì)所編寫的程序進(jìn)行仿真以確定能否達(dá)到要求并根據(jù)具體情況對(duì)程序不斷改進(jìn)。最后下載配置至EDA實(shí)驗(yàn)箱中檢測(cè)設(shè)計(jì)結(jié)果實(shí)現(xiàn)最后的
17、設(shè)計(jì)與仿真。</p><p><b> 1 緒論</b></p><p> 1.1 EDA技術(shù)概述</p><p> EDA是電子設(shè)計(jì)自動(dòng)化(Electronic Design Automation)的縮寫,在20世紀(jì)90年代初從計(jì)算機(jī)輔助設(shè)計(jì)(CAD)、計(jì)算機(jī)輔助制造(CAM)、計(jì)算機(jī)輔助測(cè)試(CAT)和計(jì)算機(jī)輔助工程(CAE)的概念發(fā)
18、展而來(lái)的。EDA技術(shù)就是以計(jì)算機(jī)為工具,設(shè)計(jì)者在EDA軟件平臺(tái)上,用硬件描述語(yǔ)言HDL完成設(shè)計(jì)文件,然后由計(jì)算機(jī)自動(dòng)地完成邏輯編譯、化簡(jiǎn)、分割、綜合、優(yōu)化、布局、布線和仿真,直至對(duì)于特定目標(biāo)芯片的適配編譯、邏輯映射和編程下載等工作。</p><p> 1.1.1 EDA技術(shù)的發(fā)展與應(yīng)用</p><p> 電子設(shè)計(jì)技術(shù)的核心就是EDA技術(shù),EDA是指以計(jì)算機(jī)為工作平臺(tái),融合應(yīng)用電子技術(shù)、
19、計(jì)算機(jī)技術(shù)、智能化技術(shù)最新成果而研制成的電子CAD通用軟件包,主要能輔助進(jìn)行三方面的設(shè)計(jì)工作,即IC設(shè)計(jì)、電子電路設(shè)計(jì)和PCB設(shè)計(jì)。</p><p> EDA技術(shù)是伴隨著計(jì)算機(jī)、集成電路、電子系統(tǒng)設(shè)計(jì)的發(fā)展, 經(jīng)歷了計(jì)算機(jī)輔助設(shè)計(jì)(CAD)、計(jì)算機(jī)輔助工程設(shè)計(jì)(CAE)和電子系統(tǒng)設(shè)計(jì)自動(dòng)化( ESDA)三個(gè)發(fā)展階段。20世紀(jì)70年代為CAD階段, 這一階段人們開(kāi)始用計(jì)算機(jī)輔助進(jìn)行IC版圖編輯和PCB 布局布線,
20、 取代了手工操作。80年代為CAE階段,與CAD相比, 除了純粹的圖形繪制功能外, 又增加了電路功能設(shè)計(jì)和結(jié)構(gòu)設(shè)計(jì), 并通過(guò)電氣連接網(wǎng)表將兩者結(jié)合在一起,以實(shí)現(xiàn)工程設(shè)計(jì)。90年代為ESDA階段, ESDA的基本特征是設(shè)計(jì)人員按“自頂向下”的設(shè)計(jì)方法,對(duì)整個(gè)系統(tǒng)進(jìn)行方案設(shè)計(jì)和功能劃分, 然后采用硬件描述語(yǔ)言(HDL)完成系統(tǒng)行為級(jí)設(shè)計(jì), 最后通過(guò)綜合器和適配器生成最終的目標(biāo)器件。ESDA的出現(xiàn), 使設(shè)計(jì)師開(kāi)始實(shí)現(xiàn)“概念驅(qū)動(dòng)工程”的夢(mèng)想,
21、從而擺脫了大量的輔助設(shè)計(jì)作, 把精力集中在創(chuàng)造性的方案與概念構(gòu)思上, 極大地提高了系統(tǒng)的效率, 縮短了產(chǎn)品的研制周期。</p><p> 1.1.2 EDA技術(shù)的基本特征</p><p> EDA代表了當(dāng)今電子設(shè)計(jì)技術(shù)的最新發(fā)展方向,它的基本特征是:設(shè)計(jì)人員按照“自頂向下”的設(shè)計(jì)方法,對(duì)整個(gè)系統(tǒng)進(jìn)行方案設(shè)計(jì)和功能劃分,系統(tǒng)的關(guān)鍵電路用一片或幾片專用集成電路(ASIC)實(shí)現(xiàn),然后采用硬件
22、描述語(yǔ)言(HDL)完成系統(tǒng)行為級(jí)設(shè)計(jì),最后通過(guò)綜合器和適配器生成最終的目標(biāo)器件,這樣的設(shè)計(jì)方法被稱為高層次的電子設(shè)計(jì)方法。EDA設(shè)計(jì)方法被越來(lái)越多的硬件設(shè)計(jì)人員采用,基本上取代了傳統(tǒng)的硬件設(shè)計(jì)方法。</p><p> 1.1.3 EDA的設(shè)計(jì)方法</p><p> “自頂向下”的設(shè)計(jì)方法。高層次設(shè)計(jì)是一種“自頂向下”的全新設(shè)計(jì)方法,這種設(shè)計(jì)方法首先從系統(tǒng)設(shè)計(jì)人手,在頂層進(jìn)行功能方框圖的
23、劃分和結(jié)構(gòu)設(shè)計(jì)。在方框圖一級(jí)進(jìn)行仿真、糾錯(cuò),并用硬件描述語(yǔ)言對(duì)高層次的系統(tǒng)行為進(jìn)行描述,在系統(tǒng)一級(jí)進(jìn)行驗(yàn)證。然后,用綜合優(yōu)化工具生成具體門電路的網(wǎng)絡(luò)表,其對(duì)應(yīng)的物理實(shí)現(xiàn)級(jí)可以是印刷電路板或?qū)S眉呻娐贰S捎谠O(shè)計(jì)的主要仿真和調(diào)試過(guò)程是在高層次上完成的,這既有利于早期發(fā)現(xiàn)結(jié)構(gòu)設(shè)計(jì)上的錯(cuò)誤,避燃計(jì)工作的浪費(fèi),又減少了邏輯功能仿真的工作量,提高了設(shè)計(jì)的一次成功率。</p><p> 1.2 硬件描述語(yǔ)言VHDL<
24、/p><p> 1.2.1 VHDL的簡(jiǎn)介</p><p> 硬件描述語(yǔ)言(HDL)是一種用于設(shè)計(jì)硬件電子系統(tǒng)的計(jì)算機(jī)語(yǔ)言,它用軟件編程的方式來(lái)描述電子系統(tǒng)的邏輯功能、電路結(jié)構(gòu)和連接形式,與傳統(tǒng)的門級(jí)描述方式相比,它更適合大規(guī)模系統(tǒng)的設(shè)計(jì)。例如一個(gè)32位的加法器,利用圖形輸入軟件需要輸人500至1000個(gè)門,而利用VHDL語(yǔ)言只需要書(shū)寫一行"A=B+C"即可。而且 VH
25、DL語(yǔ)言可讀性強(qiáng),易于修改和發(fā)現(xiàn)錯(cuò)誤。早期的硬件描述語(yǔ)言,如ABEL、HDL、AHDL,由不同的EDA廠商開(kāi)發(fā),互不兼容,而且不支持多層次設(shè)計(jì),層次間翻譯工作要由人工完成。為了克服以上不足,1985年美國(guó)國(guó)防部正式推出了高速集成電路硬件描述語(yǔ)言VHDL,1987年IEEE采納VHDL為硬件描述語(yǔ)言標(biāo)準(zhǔn)(IEEE STD-1076)。</p><p> VHDL是一種全方位的硬件描述語(yǔ)言,包括系統(tǒng)行為級(jí)。寄存器傳
26、輸級(jí)和邏輯門級(jí)多個(gè)設(shè)計(jì)層次,支持結(jié)構(gòu)、數(shù)據(jù)流和行為三種描述形式的混合描述,因此VHDL幾乎覆蓋了以往各種硬件俄語(yǔ)言的功能,整個(gè)自頂向下或由底向上的電路設(shè)計(jì)過(guò)程都可以用VHDL來(lái)完成。VHDL還具有以下優(yōu)點(diǎn):</p><p> ?。?)VHDL的寬范圍描述能力使它成為高層進(jìn)設(shè)計(jì)的核心,將設(shè)計(jì)人員的工作重心提高到了系統(tǒng)功能的實(shí)現(xiàn)與調(diào)試,而花較少的精力于物理實(shí)現(xiàn)。</p><p> (2)VH
27、DL可以用簡(jiǎn)潔明確的代碼描述來(lái)進(jìn)行復(fù)雜控制邏輯艄設(shè)計(jì),靈活且方便,而且也便于設(shè)計(jì)結(jié)果的交流、保存和重用。</p><p> ?。?)VHDL的設(shè)計(jì)不依賴于特定的器件,方便了工藝的轉(zhuǎn)換。</p><p> (4)VHDL是一個(gè)標(biāo)準(zhǔn)語(yǔ)言,為眾多的EDA廠商支持,因此移植性好。</p><p> 用VHDL語(yǔ)言編程實(shí)現(xiàn)數(shù)字電子系統(tǒng)硬件設(shè)計(jì)容易做到技術(shù)共享。他人用VHD
28、L語(yǔ)言實(shí)現(xiàn)了IP模塊和軟核(soft core),程序包(package)和設(shè)計(jì)庫(kù)(library)很容易移植到自己的系統(tǒng)設(shè)計(jì)中。許多設(shè)計(jì)不用從頭開(kāi)始,少花錢辦快事,縮短產(chǎn)品設(shè)計(jì)周期,加速產(chǎn)品更新,提高設(shè)計(jì)效益,這也是VHDL語(yǔ)言得到廣泛應(yīng)用的重要原因。</p><p> 值得指出的是:Verilog-HDL等硬件描述語(yǔ)言獲得較為廣泛的應(yīng)用。但最適合于用CPLD&VHDL等器件實(shí)現(xiàn)數(shù)字電子系統(tǒng)設(shè)計(jì)的硬件描述語(yǔ)言
29、當(dāng)屬于VHDL。</p><p> 1.2.2 VHDL的設(shè)計(jì)方法</p><p> 傳統(tǒng)的硬件電路設(shè)計(jì)方法是采用自下而上的設(shè)計(jì)方法,即根據(jù)系統(tǒng)對(duì)硬件的要求,詳細(xì)編制技術(shù)規(guī)格書(shū),并畫出系統(tǒng)控制流圖;然后根據(jù)技術(shù)規(guī)格書(shū)和系統(tǒng)控制流圖,對(duì)系統(tǒng)的功能進(jìn)行細(xì)化,合理地劃分功能模塊,并畫出系統(tǒng)的功能框圖;接著就進(jìn)行各功能模塊的細(xì)化和電路設(shè)計(jì);各功能模塊電路設(shè)計(jì)、調(diào)試完成后,將各功能模塊的硬件電路
30、連接起來(lái)再進(jìn)行系統(tǒng)的調(diào)試,最后完成整個(gè)系統(tǒng)的硬件設(shè)計(jì)。采用傳統(tǒng)方法設(shè)計(jì)數(shù)字系統(tǒng),特別是當(dāng)電路系統(tǒng)非常龐大時(shí),設(shè)計(jì)者必須具備較好的設(shè)計(jì)經(jīng)驗(yàn),而且繁雜多樣的原理圖的閱讀和修改也給設(shè)計(jì)者帶來(lái)諸多的不便。</p><p> 當(dāng)電路系統(tǒng)采用VHDL語(yǔ)言設(shè)計(jì)其硬件時(shí),與傳統(tǒng)的電路設(shè)計(jì)方法相比較,具有如下的特點(diǎn):</p><p> 第一,采用自上而下的設(shè)計(jì)方法。</p><p&g
31、t; 即從系統(tǒng)總體要求出發(fā),自上而下地逐步將設(shè)計(jì)的內(nèi)容細(xì)化,最后完成系統(tǒng)硬件的整體設(shè)計(jì)。在設(shè)計(jì)的過(guò)程中,對(duì)系統(tǒng)自上而下分成三個(gè)層次進(jìn)行設(shè)計(jì):</p><p> 第一層次是行為描述。所謂行為描述,實(shí)質(zhì)上就是對(duì)整個(gè)系統(tǒng)的數(shù)學(xué)模型的描述。一般來(lái)說(shuō),對(duì)系統(tǒng)進(jìn)行行為描述的目的是試圖在系統(tǒng)設(shè)計(jì)的初始階段,通過(guò)對(duì)系統(tǒng)行為描述的仿真來(lái)發(fā)現(xiàn)設(shè)計(jì)中存在的問(wèn)題。在行為描述階段,并不真正考慮其實(shí)際的操作和算法用何種方法來(lái)實(shí)現(xiàn),而是考
32、慮系統(tǒng)的結(jié)構(gòu)及其工作的過(guò)程是否能到達(dá)系統(tǒng)設(shè)計(jì)的要求。</p><p> 第二層次是RTL方式描述。這一層次稱為寄存器傳輸描述(又稱數(shù)據(jù)流描述)。如前所述,用行為方式描述的系統(tǒng)結(jié)構(gòu)的程序,其抽象程度高,是很難直接映射到具體邏輯元件結(jié)構(gòu)的。要想得到硬件的具體實(shí)現(xiàn),必須將行為方式描述的VHDL語(yǔ)言程序改寫為RTL方式描述的VHDL語(yǔ)言程序。也就是說(shuō),系統(tǒng)采用RTL方式描述,才能導(dǎo)出系統(tǒng)的邏輯表達(dá)式,才能進(jìn)行邏輯綜合。
33、</p><p> 第三層次是邏輯綜合。即利用邏輯綜合工具,將RTL方式描述的程序轉(zhuǎn)換成用基本邏輯元件表示的文件(門級(jí)網(wǎng)絡(luò)表)。此時(shí),如果需要,可將邏輯綜合的結(jié)果以邏輯原理圖的方式輸出。此后可對(duì)綜合的結(jié)果在門電路級(jí)上進(jìn)行仿真,并檢查其時(shí)序關(guān)系。</p><p> 第二,應(yīng)用邏輯綜合工具產(chǎn)生的門級(jí)網(wǎng)絡(luò)表,將其轉(zhuǎn)換成PLD的編程碼點(diǎn),即可利用PLD實(shí)現(xiàn)硬件電路的設(shè)計(jì)。</p>
34、<p> 由自上而下的設(shè)計(jì)過(guò)程可知,從總體行為設(shè)計(jì)開(kāi)始到最終的邏輯綜合,每一步都要進(jìn)行仿真檢查,這樣有利于盡早發(fā)現(xiàn)設(shè)計(jì)中存在的問(wèn)題,從而可以大大縮短系統(tǒng)的設(shè)計(jì)周期。</p><p> 第三,系統(tǒng)可大量采用PLD芯片。</p><p> 由于目前眾多制造PLD芯片的廠家,其工具軟件均支持VHDL語(yǔ)言的編程。所以利用VHDL語(yǔ)言設(shè)計(jì)數(shù)字系統(tǒng)時(shí),可以根據(jù)硬件電路的設(shè)計(jì)需要,自行
35、利用PLD設(shè)計(jì)自用的ASIC芯片,而無(wú)須受通用元器件的限制。</p><p> 第四,采用系統(tǒng)早期仿真。</p><p> 從自上而下的設(shè)計(jì)過(guò)程中可以看到,在系統(tǒng)設(shè)計(jì)過(guò)程中要進(jìn)行三級(jí)仿真,即行為層次仿真、RTL層次仿真和門級(jí)層次仿真。這三級(jí)仿真貫穿系統(tǒng)設(shè)計(jì)的全過(guò)程,從而可以在系統(tǒng)設(shè)計(jì)的早期發(fā)現(xiàn)設(shè)計(jì)中存在的問(wèn)題,大大縮短系統(tǒng)設(shè)計(jì)的周期,節(jié)約大量的人力和物力。自頂而下的設(shè)計(jì)方法使系統(tǒng)被分解
36、為各個(gè)模塊的集合之后,可以對(duì)設(shè)計(jì)的每個(gè)獨(dú)立模塊指派不同的工作小組,這些工作小組可以工作在不同地點(diǎn),甚至可以分屬于不同的單位,最后將不同的模塊集成為最終的系統(tǒng)模型,并對(duì)其進(jìn)行綜合測(cè)試和評(píng)價(jià)。其自頂而下的設(shè)計(jì)流程如圖1-1所示:</p><p> 圖1-1 自頂而下的設(shè)計(jì)流程</p><p> 1.3 MaxPlus II開(kāi)發(fā)平臺(tái)系統(tǒng)</p><p> 1.3.
37、1 MaxPlus II簡(jiǎn)介</p><p> MaxPlus II的全稱是Multiple Array and Programmable Logic Use System2(多陣列矩陣及可編程邏輯用戶系統(tǒng)2),是Altera公司的全集成化可編程邏輯設(shè)計(jì)環(huán)境。從最初的第一代A+PLUS,第二代MaxPlus II,發(fā)展到第三代MaxPlus II,Altera公司的開(kāi)發(fā)工具軟件在發(fā)展中不斷完善。MaxPlus
38、II的版本不升級(jí),功能也越來(lái)越強(qiáng)大,目前發(fā)行的MaxPlus II已經(jīng)到10.2版。</p><p> MaxPlus II的界面友好,在線幫助完備,初學(xué)者也可以很快學(xué)習(xí)掌握。完成高性能的設(shè)計(jì)。其次,在進(jìn)行原理圖輸入時(shí),可以直接放置74系列邏輯芯片,所以對(duì)于普通愛(ài)好者來(lái)說(shuō),即使不使用Altera的可編程器件,也可以把MaxPlus II作為邏輯仿真工具,另外,不用搭建硬件電路,即可對(duì)自己的設(shè)計(jì)進(jìn)行調(diào)試,支持Al
39、tera公司不同結(jié)構(gòu)的可編程邏輯器件,能滿足用戶各種各樣的設(shè)計(jì)需要。MaxPlus II具有突出的靈活性與高效性,為設(shè)計(jì)者提供了多種可自由選擇的設(shè)計(jì)方法和工具。</p><p> 1.3.2 MaxPlus II的特點(diǎn)</p><p> 1. MaxPlus II的編譯核心支持Altera的FLEX 10K、FLEX 8K、MAX9000、MAX7000、FLASHlogic、MAX5
40、000、Classic系列可編程邏輯器件; </p><p> 2. MaxPlus II的設(shè)計(jì)輸入、處理與校驗(yàn)功能一起提供了全集成化的一套可編程邏輯開(kāi)發(fā)工具,可加快動(dòng)態(tài)調(diào)試,縮短開(kāi)發(fā)周期; </p><p> 3. MaxPlus II支持各種HDL設(shè)計(jì)輸入,包括VHDL、Verilog和Altera的AHDL; </p><p> 4. MaxPlus I
41、I可與其他工業(yè)標(biāo)準(zhǔn)設(shè)計(jì)輸入、綜合與校驗(yàn)工具鏈接。與CAE工具的接口符合EDIF200和209、參數(shù)化模塊庫(kù)( LPM )、Verilog、VHDL及其它標(biāo)準(zhǔn)。設(shè)計(jì)者可使用Altera或標(biāo)準(zhǔn)CAE設(shè)計(jì)輸入工具去建立邏輯設(shè)計(jì),使用MaxPlus II編譯器對(duì)Altera器件設(shè)計(jì)進(jìn)行編譯,并使用Altera或其它CAE校驗(yàn)工具進(jìn)行器件或板級(jí)仿真。MaxPlus II支持與Synopsys、Viewlogic、Mentor Graphics、C
42、adence、Exemplar、Data I/O、Intergraph、Minc、OrCAD等公司提供的工具接口。利用MaxPlus II軟件平臺(tái)進(jìn)行設(shè)統(tǒng)設(shè)計(jì)。具體的設(shè)計(jì)流程圖如圖1-2所示:</p><p> 2 交通燈控制系統(tǒng)介紹</p><p> 城市中常見(jiàn)的大型十字路口如圖2-1所示。</p><p> 一般情況下,當(dāng)汽車行駛至十字交通路口時(shí),有3種選
43、擇: 向前,向左轉(zhuǎn)彎,向右轉(zhuǎn)彎。根據(jù)我國(guó)的交通規(guī)則規(guī)定,汽車是靠右行駛,向右拐彎只要走弧形的支干道即可,不需受十字交通燈的束縛。因此,本文主要考慮前行和左轉(zhuǎn)這兩種情況。十字路口交通燈負(fù)責(zé)控制各走向紅綠燈的狀態(tài)及轉(zhuǎn)換,并且各狀態(tài)之間有一定的時(shí)間過(guò)渡。同時(shí),東西南北每條干道上都為人行橫道設(shè)置了紅綠燈,提醒行人在安全時(shí)刻穿越道路以保證行人的安全。</p><p> 2.1 交通燈控制系統(tǒng)的功能</p>
44、<p> 交通燈控制系統(tǒng)主要是實(shí)現(xiàn)城市十字交叉路口紅綠燈的控制。在現(xiàn)代化的大城市中,十字交叉路口越來(lái)越多,在每個(gè)交叉路口都需要使用紅綠燈進(jìn)行交通指揮和管理,紅、黃、綠燈的轉(zhuǎn)換要有一個(gè)準(zhǔn)確的時(shí)間間隔和轉(zhuǎn)換順序,這就需要有一個(gè)安全、自動(dòng)的系統(tǒng)對(duì)紅、黃、綠燈的轉(zhuǎn)換進(jìn)行管理,本系統(tǒng)就是基于此目的而開(kāi)發(fā)的。</p><p> 2.2 交通燈控制系統(tǒng)設(shè)計(jì)選擇</p><p> 城市路口
45、交通信號(hào)控制系統(tǒng)大體上分為三種類型: 定周期的信號(hào)機(jī)、多時(shí)段且具有無(wú)電纜協(xié)調(diào)功能的微電腦型信號(hào)機(jī)以及聯(lián)網(wǎng)式自適應(yīng)多相位智能型信號(hào)機(jī)。具體采用哪種類型, 應(yīng)根據(jù)其應(yīng)用場(chǎng)合及特點(diǎn)加以確定。其中, 第一種類型以其成本低,設(shè)計(jì)簡(jiǎn)單, 安裝及維護(hù)方便等特點(diǎn)得到了廣泛應(yīng)用。</p><p> 2.3 交通燈控制系統(tǒng)設(shè)計(jì)要求</p><p> 1.能顯示十字路口東西、南北兩個(gè)方向的紅、黃、綠燈的指示
46、狀態(tài),用兩組紅、黃、綠三色燈作為兩個(gè)方向的紅、黃、綠燈;</p><p> 2.南北向?yàn)橹鞲傻溃看瓮ㄐ袝r(shí)間為50S,東西向?yàn)橹Ц傻溃看瓮ㄐ袝r(shí)間為30S;</p><p> 3.能實(shí)現(xiàn)正常的倒計(jì)時(shí)功能,用兩組數(shù)碼管作為東西、南北向的倒計(jì)時(shí)顯示。其中,黃燈:5S。</p><p> 4.能實(shí)現(xiàn)特殊狀態(tài)的功能。按下SP鍵后,能實(shí)現(xiàn)以下特殊功能:</p>
47、;<p> ?。?)顯示倒計(jì)時(shí)的兩組數(shù)碼管閃爍;</p><p> (2)計(jì)數(shù)器停止計(jì)數(shù)并保持在原來(lái)的狀態(tài);</p><p> (3)東西、南北路口均顯示紅燈狀態(tài);</p><p> ?。?)特殊狀態(tài)解除后能繼續(xù)計(jì)數(shù);</p><p> 5. 能實(shí)現(xiàn)全清零功能。按下reset鍵后,系統(tǒng)實(shí)現(xiàn)全清零,計(jì)數(shù)器由初狀態(tài)計(jì)數(shù),對(duì)應(yīng)狀
48、態(tài)的指示燈亮;</p><p> 6. 用VHDL語(yǔ)言設(shè)計(jì)上述功能的交通燈控制器,并用層次化方法設(shè)計(jì)該電路;</p><p> 7. 仿真、驗(yàn)證設(shè)計(jì)的正確性。</p><p> 2.4 交通燈控制系統(tǒng)的基本組成模塊</p><p> 交通燈控制器原理框圖如圖2-2所示,包括置數(shù)模塊、計(jì)數(shù)模塊、主控制器模塊和譯碼器模塊。置數(shù)模塊將交通燈
49、的點(diǎn)亮?xí)r間預(yù)置到置數(shù)電路中,計(jì)數(shù)模塊以秒為單位倒計(jì)時(shí),當(dāng)計(jì)數(shù)值減為零時(shí),主控電路改變輸出狀態(tài),電路進(jìn)入下一個(gè)狀態(tài)的倒計(jì)時(shí)。其中,核心部分是主控制模塊。</p><p> 2.5 交通燈控制器狀態(tài)</p><p> 根據(jù)要求,交通燈分四個(gè)狀態(tài),如下表2-1:</p><p> 表2-1 交通燈的四個(gè)狀態(tài)</p><p> 3 交通燈控
50、制系統(tǒng)的設(shè)計(jì)</p><p> 有一條主干道和一條支干道的匯合點(diǎn)形成的十字路口,為確保車輛安全,迅速通行,在干道和支道的入口設(shè)置了紅、綠、黃3色信號(hào)燈。</p><p> 3.1 交通燈控制器功能描述及設(shè)計(jì)方法</p><p> 通過(guò)兩組交通燈來(lái)模擬控制東西、南北兩條通道上的車輛通行,所有功能在實(shí)驗(yàn)操作平臺(tái)上進(jìn)行模擬通過(guò),根據(jù)原理其主要功能如圖3-1:<
51、/p><p> 圖3-1 系統(tǒng)結(jié)構(gòu)圖</p><p> 其中l(wèi)edcontrol部分為控制器模塊,ledshhow部分為譯碼器模塊。控制器包括指數(shù)模塊、計(jì)數(shù)模塊和主控制器模塊。置數(shù)模塊將交通燈的點(diǎn)亮?xí)r間預(yù)置到置數(shù)電路中,計(jì)數(shù)模塊以秒為單位倒計(jì)時(shí),當(dāng)計(jì)數(shù)值減為零時(shí),主控電路改變輸出狀態(tài),電路進(jìn)入下一個(gè)狀態(tài)的倒計(jì)時(shí)。譯碼器模塊將控制器模塊的控制作用通過(guò)譯碼表現(xiàn)出來(lái),即我們看到的交通燈。最后上
52、圖最左邊是系統(tǒng)輸入,右邊是系統(tǒng)輸出。</p><p> 3.2 交通燈控制器各模塊的程序設(shè)計(jì)</p><p> 下面是各功能模塊的VHDL程序,文中只寫出了它們的核心部分,各模塊完整的程序在附錄中給出。</p><p> 3.2.1 控制部分的設(shè)計(jì)</p><p> 控制模塊是交通控制系統(tǒng)的核心部分,控制模塊主要用于控制系統(tǒng)的時(shí)鐘、計(jì)
53、數(shù)值、循環(huán)周期判別和人工控制信號(hào)輸入,并將計(jì)數(shù)值做相關(guān)的運(yùn)算得到數(shù)碼管的倒計(jì)時(shí)值,同時(shí)控制十字路口信號(hào)燈的亮、滅火閃爍。如圖3-2所示,reset是復(fù)位引腳;clk是時(shí)鐘引腳,其值為分頻器的輸出時(shí)鐘信號(hào);urgen是緊急狀態(tài)引腳;state[1..0]是狀態(tài)引腳;sub,set1,set2是狀態(tài)選擇引腳。</p><p> process(reset,clk)</p><p><b
54、> begin</b></p><p> if reset='1'then</p><p> count<="0000000";</p><p> state<="00"; </p><
55、p> elsif clk'event and clk='1'then</p><p> if urgen='0'then count<=count+1;subtemp<='1';else subtemp<='0';end if;</p><p> if count=0 then state
56、<="00";set1<='1';set2<='1';</p><p> elsif count=25 then state<="01";set1<='1';</p><p> elsif count=30 then state<="10";s
57、et1<='1';set2<='1';</p><p> elsif count=45 then state<="11";set2<='1';</p><p> elsif count=50 then count<="0000000";else set1<=
58、9;0';set2<='0';end if;</p><p><b> end if;</b></p><p> end process statelabel;</p><p> 圖3-2 控制部分的圖形</p><p> 3.2.2 顯示部分的設(shè)計(jì)</p><
59、;p> 顯示模塊包括數(shù)碼管動(dòng)態(tài)掃描電路和譯碼顯示電路,動(dòng)態(tài)掃描電路用于選擇需要顯示的數(shù)碼管,譯碼顯示電路用于將輸入的二進(jìn)制信息轉(zhuǎn)換為數(shù)碼管顯示編碼。如圖3-3所示,clk是時(shí)鐘引腳;urgen是緊急狀態(tài)引腳;state[1..0]是狀態(tài)引腳;sub,set1,set2是狀態(tài)選擇引腳,在sub為上升沿時(shí),可以用set1和set2來(lái)選擇調(diào)整交通燈的狀態(tài);r1,g1,y1,r2,g2,y2分別是主干道方向和次干道方向的紅、綠、黃燈信號(hào)
60、引腳;led1[7..0],led2[7..0]分別為主干道方向和次干道方向的數(shù)碼管倒計(jì)時(shí)信號(hào)燈引腳。</p><p><b> label2:</b></p><p> process(sub)</p><p><b> begin</b></p><p> if sub'even
61、t and sub='1'then</p><p> if set2='1'then</p><p> count2<=setstate2;</p><p> elsif count2(3 downto 0)="0000" then count2<=count2-7;</p><
62、;p> else count2<=count2-1; end if;</p><p><b> g2<=tg2;</b></p><p><b> r2<=tr2;</b></p><p><b> y2<=ty2;</b></p><p>
63、;<b> end if;</b></p><p> end process label2;</p><p><b> label1:</b></p><p> process(sub)</p><p><b> begin</b></p><p&
64、gt; if sub'event and sub='1'then</p><p> if set1='1'then 圖3-3 顯示部分的圖形</p><p> count1<=setstate1;</p><p> elsif count
65、1(3 downto 0)="0000" then count1<=count1-7;</p><p> else count1<=count1-1;end if;</p><p><b> g1<=tg1;</b></p><p><b> r1<=tr1;</b><
66、;/p><p><b> y1<=ty1;</b></p><p><b> end if;</b></p><p> end process label1; </p><p> 3.2.3 分頻器部分的設(shè)計(jì)</p>&l
67、t;p> 分頻模塊通過(guò)分頻得到計(jì)數(shù)模塊的時(shí)鐘頻率,此頻率作為數(shù)碼管動(dòng)態(tài)顯示的掃描時(shí)鐘頻率。如圖3-4所示,clk_in是分頻器的時(shí)鐘輸入引腳;clk為時(shí)鐘輸出引腳;reset為復(fù)位引腳。</p><p> process(clk_in,reset) is</p><p> variable cnt:t_short;</p><p><b>
68、begin</b></p><p> if(reset='1')then</p><p><b> cnt:=0;</b></p><p><b> clk<='0';</b></p><p> elsif rising_edge(clk_i
69、n)then</p><p> if(cnt<=(divide_period/2))then</p><p><b> clk<='1';</b></p><p> cnt:=cnt+1;</p><p> elsif(cnt<(divide_period-1))then<
70、/p><p><b> clk<='0';</b></p><p> cnt:=cnt+1;</p><p><b> else</b></p><p><b> cnt:=0;</b></p><p><b> e
71、nd if;</b></p><p><b> end if;</b></p><p> end process;</p><p> 圖3-4 分頻器部分的圖形</p><p> 3.3 交通燈控制系統(tǒng)的仿真</p><p> 3.3.1 對(duì)交通燈控制部分進(jìn)行仿真</
72、p><p> 在MaxPlus II軟件中導(dǎo)入交通燈控制程序,對(duì)此程序編譯無(wú)錯(cuò)誤后,建立Vector waveform file 文件保存時(shí)仿真文件名要與設(shè)計(jì)文件名一致。在其中設(shè)計(jì)始終開(kāi)始時(shí)間為0,結(jié)束時(shí)間為5us,周期為50ns。仿真結(jié)果如圖3-5:</p><p> 圖3-5 交通燈控制部分仿真圖一</p><p> 當(dāng)reset='1'st
73、ate<="00"count<="0000000";</p><p> 當(dāng)reset='0'在上升沿到來(lái)時(shí)執(zhí)行當(dāng) count=0 則state<="00";set1<='1';set2<='1'; </p><p> count=25 s
74、tate<="01";set1<='1'; count=30 then state<="10";set1<='1';set2<='1';</p><p> count=45 then state<="11";set2<='1';</p>
75、<p> count=50 then count<="0000000",否則 set1<='0';set2<='0'</p><p><b> 仿真的結(jié)果正確。</b></p><p> 圖3-6 交通燈控制部分仿真圖二</p><p> 3.3.2
76、對(duì)交通燈顯示部分模塊進(jìn)行仿真</p><p> 在 MaxPlus II 軟件中導(dǎo)入交通燈顯示程序,對(duì)此程序編譯無(wú)錯(cuò)誤后,建立Vector waveform file 文件保存時(shí)仿真文件名要與設(shè)計(jì)文件名一致。將控制仿真的結(jié)果貼到顯示仿真中,兩次在其中設(shè)計(jì)的開(kāi)始時(shí)間為0,結(jié)束時(shí)間為5us,周期為50ns。仿真結(jié)果如下:</p><p> 圖3-7 交通燈顯示部分仿真圖一</p&g
77、t;<p> 仿真結(jié)果與程序所要的結(jié)果一樣。</p><p> 當(dāng)state="00"時(shí)g1<='1';當(dāng)state(1)<= '0'時(shí)r2<='1'。</p><p> 圖3-8 交通燈顯示部分仿真圖二</p><p> 當(dāng)urgen='1'
78、;時(shí)r1<='1',r2<='1';仿真結(jié)果與程序設(shè)計(jì)符合。</p><p> 3.3.3 對(duì)交通燈系統(tǒng)進(jìn)行仿真</p><p> 在 MaxPlus II 軟件中導(dǎo)入交通燈系統(tǒng)程序,對(duì)此程序編譯無(wú)錯(cuò)誤后,建立Vector waveform file 文件保存時(shí)仿真文件名要與設(shè)計(jì)文件名一致。在其中設(shè)計(jì)開(kāi)始時(shí)間為0,結(jié)束時(shí)間為5us,周期為50
79、ns。仿真結(jié)果如下:</p><p> 圖3-9 交通燈系統(tǒng)分仿真圖一</p><p> 圖3-10 交通燈系統(tǒng)仿真圖二</p><p> 系統(tǒng)仿真的結(jié)果符合設(shè)計(jì)要求。與前面仿真的結(jié)果也一致。</p><p><b> 結(jié)束語(yǔ)</b></p><p> 經(jīng)歷了數(shù)星期的畢業(yè)設(shè)計(jì)眼看塵埃
80、落定,看似簡(jiǎn)單的題目做起來(lái)也是舉步維艱。通過(guò)課程設(shè)計(jì),發(fā)現(xiàn)了自己的很多不足,自己知識(shí)的很多漏洞,與此同時(shí)也學(xué)會(huì)了獨(dú)立克服困難的能力。</p><p> 本設(shè)計(jì)采用VHDL 硬件描述語(yǔ)言文本輸入方式,在確立總體預(yù)期實(shí)現(xiàn)功能的前提下,分層次進(jìn)行描述,其中所用到的數(shù)據(jù)均可依現(xiàn)場(chǎng)情況而設(shè)置,修改方便靈活。特殊狀態(tài)可自行修改和添加,但總的前提是保持狀態(tài)二(南北東西均為紅燈) 的優(yōu)先級(jí)最高。須注意的是,功能四的兩模擬頻率不
81、能太高,否則將無(wú)法實(shí)現(xiàn)。事實(shí)上這也與實(shí)際情況相符,因?yàn)榭紤]到道路行使中車速受限因素存在。</p><p> 數(shù)字化時(shí)代的到來(lái)給人們的生活帶來(lái)了極大的改變,有理由相信隨著數(shù)字化的深入,交通燈控制器的功能將日趨完善。而且VHDL語(yǔ)言對(duì)EDA 產(chǎn)生的影響也是深遠(yuǎn)的,它縮短了電子產(chǎn)品的設(shè)計(jì)周期,為設(shè)計(jì)者提供了方便。</p><p><b> 參考文獻(xiàn)</b></p&
82、gt;<p> 朱正偉. EDA技術(shù)與應(yīng)用[M].北京:清華大學(xué)出版社,2009.</p><p> 候伯亨. VHDL硬件描述語(yǔ)言與數(shù)字電路邏輯設(shè)計(jì)[M].西安:西安電子科技大學(xué)出版社,1999.</p><p> 方翔. 電子信息技術(shù)在智能交通信號(hào)燈控制中的應(yīng)用[J].機(jī)電信息, 2010,(12):39-44.</p><p> 王振紅.
83、 VHDL數(shù)字電路設(shè)計(jì)與應(yīng)用實(shí)踐教程[M].北京: 機(jī)械工業(yè)出版社, 2003.</p><p> 焦鍵. EDA軟件在數(shù)字電路中的應(yīng)用[J].硅谷, 2010,(9):100-103.</p><p> Stephen Brown,Zvonko Vranesic. Fundamentals of Digital Logic With VHDL Design,Third Edition
84、[M].北京:電子工業(yè)出版社,2009.</p><p> 湯澤軍,周歡喜,吳進(jìn). 一種交通信號(hào)燈控制系統(tǒng)的設(shè)計(jì)與實(shí)現(xiàn)方案[J].長(zhǎng)沙航空職業(yè)技術(shù)學(xué)院學(xué)報(bào),2010,(3):18-21.</p><p> Clinal Cale. Real Digital,A Hands-on Approach to Digital Design[M].西安:西安電子科技大學(xué)出版社,2009.<
85、/p><p> 胡蓉. 基于EDA技術(shù)基礎(chǔ)的數(shù)字電路課程設(shè)計(jì)[J].職業(yè)教育研究, 2010,(06):49-54.</p><p> 李春雨,高原. 基于VHDL狀態(tài)機(jī)的交通燈控制器設(shè)計(jì)[J].山西電子技術(shù),2010,(1):54—56.</p><p> 江培蕾,戴彥. 基于FPGA的交通控制器的設(shè)計(jì)[J].黑龍江科技信息, 2010,(1):74—78.&l
86、t;/p><p><b> 致謝</b></p><p> 本論文是在xx老師的精心指導(dǎo)下完成的。在做畢業(yè)設(shè)計(jì)的整個(gè)過(guò)程中,都得到了xx老師的耐心指導(dǎo)和詳細(xì)解答,特別是在設(shè)計(jì)的初始階段,xx老師在需求分析方面給了我很大的幫助,在老師幫助和指導(dǎo)下,使我能很快地就確定了系統(tǒng)的目的和開(kāi)發(fā)方案,并且在后來(lái)的程序?qū)崿F(xiàn)方面給予了正確的引導(dǎo),使我少走了很多彎路,并提高了我的效率。這
87、對(duì)于我以后的工作和學(xué)習(xí)都有很大的幫助,在此衷心感謝xx老師的耐心輔導(dǎo)。</p><p> 最后,我衷心地祝福所有給予我?guī)椭睦蠋熀屯瑢W(xué),希望他們?cè)谝院蟮娜兆永锕ぷ黜樌?!學(xué)習(xí)進(jìn)步!再創(chuàng)輝煌!</p><p><b> 附錄</b></p><p> 交通燈設(shè)計(jì)中的各模塊程序</p><p> 一、控制部分的VHDL
88、程序</p><p> library ieee;</p><p> use ieee.std_logic_1164.all;</p><p> use ieee.std_logic_unsigned.all;</p><p> entity ledcontrol is</p><p> port(reset
89、,clk,urgen:in std_logic;</p><p> state:out std_logic_vector(1 downto 0);</p><p> sub,set1,set2 :out std_logic);</p><p> end ledcontrol;</p><p> architecture control
90、 of ledcontrol is</p><p> signal count: std_logic_vector(6 downto 0);</p><p> signal subtemp: std_logic;</p><p><b> begin</b></p><p> sub<=subtemp an
91、d (not clk);</p><p> statelabel:</p><p> process(reset,clk)</p><p><b> begin</b></p><p> if reset='1'then</p><p> count<="
92、0000000";</p><p> state<="00"; </p><p> elsif clk'event and clk='1'then</p><p> if urgen='0'then count<
93、=count+1;subtemp<='1';else subtemp<='0';end if;</p><p> if count=0 then state<="00";set1<='1';set2<='1';</p><p> elsif count=25 then st
94、ate<="01";set1<='1';</p><p> elsif count=30 then state<="10";set1<='1';set2<='1';</p><p> elsif count=45 then state<="11"
95、;;set2<='1';</p><p> elsif count=50 then count<="0000000";else set1<='0';set2<='0';end if;</p><p><b> end if;</b></p><p>
96、 end process statelabel;</p><p> end control;</p><p> 二、顯示部分的VHDL程序</p><p> library ieee;</p><p> use ieee.std_logic_1164.all;</p><p> use ieee.std_l
97、ogic_unsigned.all;</p><p> entity ledshow is</p><p> port(clk,urgen:in std_logic;</p><p> state:in std_logic_vector(1 downto 0);</p><p> sub,set1,set2:in std_logic;
98、</p><p> r1,g1,y1,r2,g2,y2:out std_logic;</p><p> led1,led2:out std_logic_vector(7 downto 0));</p><p> end ledshow;</p><p> architecture show of ledshow is</p>
99、;<p> signal count1,count2:std_logic_vector(7 downto 0);</p><p> signal setstate1,setstate2:std_logic_vector(7 downto 0);</p><p> signal tg1,tg2,tr1,tr2,ty1,ty2 :std_logic;</p>
100、<p><b> begin</b></p><p> led1<="11111111"when urgen='1'and clk='0' else count1;</p><p> led2<="11111111"when urgen='1'and c
101、lk='0' else count2;</p><p> tg1<='1'when state="00"and urgen='0' else '0';</p><p> ty1<='1'when state="01"and urgen='0'
102、; else '0';</p><p> tr1<='1'when state(1)='1'or urgen='1' else '0';</p><p> tg2<='1'when state="10"and urgen='0' else
103、39;0';</p><p> ty2<='1'when state="11"and urgen='0' else '0';</p><p> tr2<='1'when state(1)='0'or urgen='1' else '0'
104、;</p><p> setstate1<= "00100101"when state="00"else</p><p> "00000101"when state="01"else</p><p> "00100000";</p><
105、p> setstate2<= "00010101"when state="10"else</p><p> "00000101"when state="11"else</p><p> "00110000";</p><p><b> l
106、abel2:</b></p><p> process(sub)</p><p><b> begin</b></p><p> if sub'event and sub='1'then</p><p> if set2='1'then</p>&
107、lt;p> count2<=setstate2;</p><p> elsif count2(3 downto 0)="0000" then count2<=count2-7;</p><p> else count2<=count2-1; end if;</p><p><b> g2<=tg2;
108、</b></p><p><b> r2<=tr2;</b></p><p><b> y2<=ty2;</b></p><p><b> end if;</b></p><p> end process label2;</p>&
109、lt;p><b> label1:</b></p><p> process(sub)</p><p><b> begin</b></p><p> if sub'event and sub='1'then</p><p> if set1='1
110、39;then</p><p> count1<=setstate1;</p><p> elsif count1(3 downto 0)="0000" then count1<=count1-7;</p><p> else count1<=count1-1;end if;</p><p><
111、;b> g1<=tg1;</b></p><p><b> r1<=tr1;</b></p><p><b> y1<=ty1;</b></p><p><b> end if;</b></p><p> end process l
112、abel1;</p><p><b> end show;</b></p><p> 三、分頻器部分的VHDL程序</p><p> library ieee;</p><p> use ieee.std_logic_1164.all;</p><p> use work.p_alarm
113、.all;</p><p> entity divider is</p><p> port(clk_in:in std_logic;</p><p> reset:in std_logic;</p><p> clk:out std_logic);</p><p> end divider;</p&g
114、t;<p> architecture div of divider is</p><p> constant divide_period:t_short:=1000;</p><p><b> begin</b></p><p> process(clk_in,reset) is</p><p>
115、 variable cnt:t_short;</p><p><b> begin</b></p><p> if(reset='1')then</p><p><b> cnt:=0;</b></p><p><b> clk<='0';&
116、lt;/b></p><p> elsif rising_edge(clk_in)then</p><p> if(cnt<=(divide_period/2))then</p><p><b> clk<='1';</b></p><p> cnt:=cnt+1;</p&
117、gt;<p> elsif(cnt<(divide_period-1))then</p><p><b> clk<='0';</b></p><p> cnt:=cnt+1;</p><p><b> else</b></p><p><b&
118、gt; cnt:=0;</b></p><p><b> end if;</b></p><p><b> end if;</b></p><p> end process;</p><p><b> end div;</b></p><
119、;p> 四、p_alarm程序包</p><p> library ieee;</p><p> use ieee.std_logic_1164.all;</p><p> package p_alarm is</p><p> subtype t_digital is integer range 0 to 9;</p&
120、gt;<p> subtype t_short is integer range 0 to 65535;</p><p> type t_clock_time is array(5 downto 0)of t_digital;</p><p> type t_display is array(5 downto 0)of t_digital;</p><
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫(kù)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 畢業(yè)設(shè)計(jì)---基于eda技術(shù)的交通燈設(shè)計(jì)
- eda技術(shù)的交通燈畢業(yè)設(shè)計(jì)
- 畢業(yè)論文--基于eda技術(shù)的交通燈設(shè)計(jì)
- 畢業(yè)設(shè)計(jì)-eda技術(shù)交通燈控制器(課程設(shè)計(jì))
- 交通燈畢業(yè)設(shè)計(jì)---- 基于單片機(jī)的交通燈設(shè)計(jì)
- eda交通燈課程設(shè)計(jì)---交通燈控制系統(tǒng)的設(shè)計(jì)
- 交通燈設(shè)計(jì)畢業(yè)設(shè)計(jì)
- 交通燈畢業(yè)設(shè)計(jì)
- eda交通燈課程設(shè)計(jì)報(bào)告(eda)
- eda交通燈課程設(shè)計(jì)
- 畢業(yè)設(shè)計(jì)---基于plc的交通燈設(shè)計(jì)
- eda實(shí)驗(yàn)交通燈設(shè)計(jì)報(bào)告
- 畢業(yè)設(shè)計(jì)(基于plc的交通燈設(shè)計(jì))
- eda交通燈課程設(shè)計(jì)
- eda實(shí)驗(yàn)交通燈設(shè)計(jì)報(bào)告
- 基于sopc交通燈的eda課程設(shè)計(jì)
- eda實(shí)驗(yàn)交通燈設(shè)計(jì)報(bào)告
- eda交通燈課程設(shè)計(jì)---交通燈控制系統(tǒng)
- 畢業(yè)設(shè)計(jì)--基于plc控制交通燈設(shè)計(jì)
- 交通燈畢業(yè)設(shè)計(jì)--基于單片機(jī)的交通燈控制系統(tǒng)設(shè)計(jì)
評(píng)論
0/150
提交評(píng)論