版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
1、<p><b> 摘 要</b></p><p> 該系統(tǒng)利用VHDL語言、PLD設(shè)計(jì)出租車計(jì)費(fèi)系統(tǒng),以MAX+PLUSⅡ軟件作為開發(fā)平臺,設(shè)計(jì)了出租車計(jì)費(fèi)器系統(tǒng)程序并進(jìn)行了程序仿真。使其實(shí)現(xiàn)計(jì)費(fèi)以及預(yù)置和模擬汽車啟動、停止、暫停等功能,并動態(tài)掃描顯示車費(fèi)數(shù)目。</p><p> 關(guān)鍵詞: 出租車計(jì)費(fèi)器;計(jì)數(shù)器;VHDL語言;MAX+PL
2、USⅡ; </p><p> Rental car fare register system design</p><p> Student: YANG Youtian Teacher: LIU Yaoming</p><p> Abstract:This system using the VHDL language, PLD design renta
3、l car costs the system, develops the platform by the MAX+PLUSⅡsoftware achievement, has designed the rental car fare register system program and has carried on the procedure simulation. Causes its realization to cost as
4、well as the initialization and the simulation automobile starts, stops, function and so on suspension, and dynamic scanning demonstration fare number.</p><p> Key words: The rental car costs the system; th
5、e counter; the VHDL language; MAX+PLUS II;</p><p><b> 目 次</b></p><p> 摘要……………………………………………………………………………………Ⅰ</p><p> Abstract………………………………………………………………………………Ⅱ</p>
6、<p> 1 引言…………………………………………………………………………………1</p><p> 1.1 設(shè)計(jì)背景………………………………………………………………………1</p><p> 1.2 EDA發(fā)展概況…………………………………………………………………2</p><p> 2 出租車計(jì)費(fèi)系統(tǒng)的設(shè)計(jì)………………………………………
7、……………………7</p><p> 2.1 出租車計(jì)費(fèi)設(shè)計(jì)………………………………………………………………7</p><p> 2.2 基本設(shè)計(jì)思想…………………………………………………………………7</p><p> 3 出租車計(jì)費(fèi)系統(tǒng)的實(shí)現(xiàn)……………………………………………………………8</p><p> 3.1 系統(tǒng)的
8、總體框圖………………………………………………………………8</p><p> 3.2 程序流程圖………………………………………………………………………9</p><p> 3.3 系統(tǒng)各功能模塊的實(shí)現(xiàn)………………………………………………………10</p><p> 3.3.1 模塊JIFEI的實(shí)現(xiàn)……………………………………………………10</p
9、><p> 3.3.2 模塊X的實(shí)現(xiàn)………………………………………………………12</p><p> 3.3.3 模塊XXX1的實(shí)現(xiàn)……………………………………………………15</p><p> 3.3.4 模塊SE的實(shí)現(xiàn)………………………………………………………16</p><p> 3.3.5 模塊DI的實(shí)現(xiàn)………………………
10、………………………………17</p><p> 4 系統(tǒng)仿真……………………………………………………………………………19</p><p> 4.1 模塊X的仿真結(jié)果…………………………………………………………19</p><p> 4.2 模塊JIFEI的仿真結(jié)果……………………………………………………19</p><p>
11、4.3 模塊XXX1的仿真結(jié)果………………………………………………………19</p><p> 4.4 模塊SE的結(jié)果驗(yàn)證…………………………………………………………20</p><p> 4.5 模塊DI的結(jié)果驗(yàn)證…………………………………………………………20</p><p> 5 結(jié)論…………………………………………………………………………………
12、21</p><p> 致謝……………………………………………………………………………………22</p><p> 參考文獻(xiàn)………………………………………………………………………………23</p><p><b> 1 引 言</b></p><p><b> 1.1 設(shè)計(jì)背景</b><
13、;/p><p> 隨著出租車行業(yè)的發(fā)展,對出租車計(jì)費(fèi)器的要求也越來越高。二十世紀(jì)后半期,隨著集成電路和計(jì)算機(jī)技術(shù)的飛速發(fā)展,數(shù)字系統(tǒng)也得到了飛速發(fā)展,其實(shí)現(xiàn)方法經(jīng)歷了由分立元件、SSI、MSI到LSI、VLSI以及UVLSI的過程。同時為了提高系統(tǒng)的可靠性與通用性,微處理器和專業(yè)集成電路(ASIC)逐漸取代了通用全硬件LSI電路,而ASIC以其體積小、重量輕、功耗低、速度快、成本低、保密性好而脫穎而出。目前,業(yè)界大
14、量可編程邏輯器件(PLD),尤其是現(xiàn)場可編程邏輯器件(FPLD)被大量地應(yīng)用在ASIC的制作當(dāng)中。在可編程集成電路的開發(fā)過程中,以計(jì)算機(jī)為工作平臺,融合了應(yīng)用電子技術(shù)、計(jì)算機(jī)技術(shù)、智能化技術(shù)最新成果的電子設(shè)計(jì)自動化(EDA)技術(shù)主要能輔助進(jìn)行三方面的設(shè)計(jì)工作:IC設(shè)計(jì),電子電路設(shè)計(jì)以及PCB設(shè)計(jì)</p><p> 理想的可編程邏輯開發(fā)系統(tǒng)能符合大量的設(shè)計(jì)要求:它能夠支持不同結(jié)構(gòu)的器件,在多種平臺運(yùn)行,提供易于使
15、用的界面,并且有廣泛的特征。此外,一個設(shè)計(jì)系統(tǒng)應(yīng)該能給設(shè)計(jì)師提供充分自由的設(shè)計(jì)輸入方法和設(shè)計(jì)工具選擇。Altered公司開發(fā)的MAX+PLUSⅡ開發(fā)系統(tǒng)能充分滿足可編程邏輯設(shè)計(jì)所有要求。 MAX+PLUSⅡ設(shè)計(jì)環(huán)境所提供的靈活性和高效性是無可比擬的。其豐富的圖形界面,輔之以完整的、可及時訪問的在線文檔,使設(shè)計(jì)人員能夠輕松、愉快地掌握和使用MAX+PLUSⅡ軟件。</p><p> 編程器是一種專門用于對
16、可編程器(如EPROM,EEPROM,GAL,CPLD,PAL等)進(jìn)行編程的專業(yè)設(shè)備</p><p> PLD器件的邏輯功能描述一般分為原理圖描述和硬件描述語言描述,原理圖描述是一種直觀簡便的方法,它可以將現(xiàn)有的小規(guī)模集成電路實(shí)現(xiàn)的功能直接用PLD器件來實(shí)現(xiàn),而不必去將現(xiàn)有的電路用語言來描述,但電路圖描述方法無法做到簡練;硬件描述語言描述是可編程器件設(shè)計(jì)的另一種描述方法,語言描述可能精確和簡練地表示電路的邏輯功
17、能,現(xiàn)在PLD的設(shè)計(jì)過程中廣泛使用。常用的硬件描述語言有ABEL,VHDL語言等,其中ABEL是一種簡單的硬件描述語言,其支持布爾方程、真值表、狀態(tài)機(jī)等邏輯描述,適用于計(jì)數(shù)器、譯碼器、運(yùn)算電路、比較器等邏輯功能的描述;VHDL語言是一種行為描述語言,其編程結(jié)構(gòu)類似于計(jì)算機(jī)中的C語言,在描述復(fù)雜邏輯設(shè)計(jì)時,非常簡潔,具有很強(qiáng)的邏輯描述和仿真能力,是未來硬件設(shè)計(jì)語言的主流。</p><p> VHDL就是超高速集成
18、電路硬件描述語言。覆蓋面廣,描述能力強(qiáng),是一個多層次的硬件描述語言。在VHDL語言中,設(shè)計(jì)的原始描述可以非常簡練,經(jīng)過層層加強(qiáng)后,最終可成為直接付諸生產(chǎn)的電路或版圖參數(shù)描述。具有良好的可讀性,即容易被計(jì)算機(jī)接受,也容易被讀者理解。使用期長,不會因工藝變化而使描述過時。因?yàn)閂HDL的硬件描述與工藝無關(guān),當(dāng)工藝改變時,只需修改相應(yīng)程序中的屬性參數(shù)即可。支持大規(guī)模設(shè)計(jì)的分解和已有設(shè)計(jì)的再利用。一個大規(guī)模的設(shè)計(jì)不可能由一個人獨(dú)立完成,必須由多人
19、共同承擔(dān),VHDL為設(shè)計(jì)的分解和設(shè)計(jì)的再利用提供了有力的支持。</p><p> 1.2 EDA發(fā)展概況</p><p> 電子設(shè)計(jì)技術(shù)的核心就是EDA技術(shù),EDA是指以計(jì)算機(jī)為工作臺,融合應(yīng)用電子技術(shù)、計(jì)算機(jī)技術(shù)、智能化技術(shù)最新成果而研制成的電子CAD通用軟件包,主要能輔助進(jìn)行三方面的設(shè)計(jì)工作,即IC設(shè)計(jì)、電子電路設(shè)計(jì)和PCB設(shè)計(jì)。EDA技術(shù)已有30年的發(fā)展歷程,大致可分為三個階段。
20、70年代為計(jì)算機(jī)輔助設(shè)計(jì)(CAD)階段,人們開始用計(jì)算機(jī)輔助進(jìn)行IC版圖編輯、PCB布局布線,取代了手工操作。80年代為計(jì)算機(jī)輔助工程(CAE)階段。與CAD相比,CAE除了有純粹的圖形繪制功能外,又增加了電路功能設(shè)計(jì)和結(jié)構(gòu)設(shè)計(jì),并且通過電氣連接網(wǎng)絡(luò)表將兩者結(jié)合在一起,實(shí)現(xiàn)了工程設(shè)計(jì)。CAE的主要功能是:原理圖輸入,邏輯仿真,電路分析,自動布局布線,PCB后分析。90年代為電子系統(tǒng)設(shè)計(jì)自動化(EDA)階段。 中國EDA市場已漸趨
21、成熟,不過大部分設(shè)計(jì)工程師面向的是PC主板和小型ASIC領(lǐng)域,僅有小部分(約11%)的設(shè)計(jì)人員開發(fā)復(fù)雜的片上系統(tǒng)器件。為了與臺灣和美國的設(shè)計(jì)工程師形成更有力的競爭,中國的設(shè)計(jì)隊(duì)伍有必要購入一些最新的EDA技術(shù)。在信息通信領(lǐng)域,要優(yōu)先發(fā)展高速寬帶信息網(wǎng)、深亞微米集成電路、新型元器件、計(jì)算機(jī)及軟件</p><p> 可編程邏輯器件自70年代以來,經(jīng)歷了PAL、GALGPLD、FPGA幾個發(fā)展階段,其中CPLD/F
22、PGA高密度可編程邏輯器件,目前集成度已高達(dá)200萬門/片,它將各模塊ASC集成度高的優(yōu)點(diǎn)和可編程邏輯器件設(shè)計(jì)生產(chǎn)方便的特點(diǎn)結(jié)合在一起,特別適合于樣品研制或小批量產(chǎn)品開發(fā),使產(chǎn)品能以最快的速度上市,而當(dāng)市場擴(kuò)大時,它可以很容易地轉(zhuǎn)換掩模ASIC實(shí)現(xiàn),因此開發(fā)風(fēng)險也大為降低。</p><p> 硬件描述語言(HDL)是一種用于設(shè)計(jì)硬件電子系統(tǒng)的計(jì)算機(jī)語言,它用軟件編程的方式來描述電子系統(tǒng)的邏輯功能、電路結(jié)構(gòu)和連接
23、形式,與傳統(tǒng)的門級描述方式相比,它更適合大規(guī)模系統(tǒng)的設(shè)計(jì)。例如一個32位的加法器,利用圖形輸入軟件需要輸人500至1000個門,而利用VHDL語言只需要書寫一行“A=B+C”即可。而且 VHDL語言可讀性強(qiáng),易于修改和發(fā)現(xiàn)錯誤。早期的硬件描述語言,如ABEL、HDL、AHDL,由不同的EDA廠商開發(fā),互不兼容,而且不支持多層次設(shè)計(jì),層次間翻譯工作要由人工完成。為了克服以上不足,1985年美國國防部正式推出了高速集成電路硬件描述語言VHD
24、L,1987年IEEE采納VHDL為硬件描述語言標(biāo)準(zhǔn)(IEEE STD-1076)。</p><p> ?。郑龋模淌且环N全方位的硬件描述語言,包括系統(tǒng)行為級。寄存器傳輸級和邏輯門多個設(shè)計(jì)層次,支持結(jié)構(gòu)、數(shù)據(jù)流和行為三種描述形式的混合描述,因此VHDL幾乎覆蓋了以往各種硬件俄語言的功能,整個自頂向下或由下向上的電路設(shè)計(jì)過程都可以用VHDL來完成。VHDL還具有以下優(yōu)點(diǎn):(1)VHDL的寬范圍描述能力使它成為高層進(jìn)
25、設(shè)計(jì)的核心,將設(shè)計(jì)人員的工作重心提高到了系統(tǒng)功能的實(shí)現(xiàn)與調(diào)試,而花較少的精力于物理實(shí)現(xiàn)。VHDL可以用簡潔明確的代碼描述來進(jìn)行復(fù)雜控制邏輯設(shè)計(jì),靈活且方便,而且也便于設(shè)計(jì)結(jié)果的交流、保存和重用。(3)VHDL的設(shè)計(jì)不依賴于特定的器件,方便了工藝的轉(zhuǎn)換。(4)VHDL是一個標(biāo)準(zhǔn)語言,為眾多的EDA廠商支持,因此移植性好。傳統(tǒng)的硬件電路設(shè)計(jì)方法是采用自下而上的設(shè)計(jì)方法,即根據(jù)系統(tǒng)對硬件的要求,詳細(xì)編制技術(shù)規(guī)格書,并畫出系統(tǒng)控制流圖;然后根據(jù)
26、技術(shù)規(guī)格書和系統(tǒng)控制流圖,對系統(tǒng)的功能進(jìn)行細(xì)化,合理地劃分功能模塊,并畫出系統(tǒng)的功能框圖;接著就進(jìn)行各功能模塊的細(xì)化和電路設(shè)計(jì);各功能模塊電路設(shè)計(jì)、調(diào)試完成后,將各功能模塊的硬件電路連接起來再進(jìn)行系統(tǒng)的調(diào)試,最后完成整個系統(tǒng)的硬件設(shè)計(jì)。采用傳統(tǒng)方法設(shè)計(jì)</p><p> 覆蓋面廣,描述能力強(qiáng),是一個多層次的硬件描述語言。在VHDL語言中,設(shè)計(jì)的原始描述可以非常簡練,經(jīng)過層層加強(qiáng)后,最終可成為直接付諸生產(chǎn)的電路或
27、版圖參數(shù)描述。</p><p> 具有良好的可讀性,即容易被計(jì)算機(jī)接受,也容易被讀者理解。</p><p> 使用期長,不會因工藝變化而使描述過時。因?yàn)閂HDL的硬件描述與工藝無關(guān),當(dāng)工藝改變時,只需修改相應(yīng)程序中的屬性參數(shù)即可。</p><p> 支持大規(guī)模設(shè)計(jì)的分解和已有設(shè)計(jì)的再利用。一個大規(guī)模的設(shè)計(jì)不可能由一個人獨(dú)立完成,必須由多人共同承擔(dān),VHDL為設(shè)
28、計(jì)的分解和設(shè)計(jì)的再利用提供了有力的支持。</p><p> 當(dāng)電路系統(tǒng)采用VHDL語言設(shè)計(jì)其硬件時,與傳統(tǒng)的電路設(shè)計(jì)方法相比較,具有如下的特點(diǎn):</p><p> 即從系統(tǒng)總體要求出發(fā),自上而下地逐步將設(shè)計(jì)的內(nèi)容細(xì)化,最后完成系統(tǒng)硬件的整體設(shè)計(jì)。在設(shè)計(jì)的過程中,對系統(tǒng)自上而下分成三個層次進(jìn)行設(shè)計(jì):</p><p> 第一層次是行為描述。所謂行為描述,實(shí)質(zhì)上就是
29、對整個系統(tǒng)的數(shù)學(xué)模型的描述。一般來說,對系統(tǒng)進(jìn)行行為描述的目的是試圖在系統(tǒng)設(shè)計(jì)的初始階段,通過對系統(tǒng)行為描述的仿真來發(fā)現(xiàn)設(shè)計(jì)中存在的問題。在行為描述階段,并不真正考慮其實(shí)際的操作和算法用何種方法來實(shí)現(xiàn),而是考慮系統(tǒng)的結(jié)構(gòu)及其工作的過程是否能到達(dá)系統(tǒng)設(shè)計(jì)的要求。</p><p> 第二層次是RTL方式描述。這一層次稱為寄存器傳輸描述(又稱數(shù)據(jù)流描述)。如前所述,用行為方式描述的系統(tǒng)結(jié)構(gòu)的程序,其抽象程度高,是很難
30、直接映射到具體邏輯元件結(jié)構(gòu)的。要想得到硬件的具體實(shí)現(xiàn),必須將行為方式描述的VHDL語言程序改寫為RTL方式描述的VHDL語言程序。也就是說,系統(tǒng)采用RTL方式描述,才能導(dǎo)出系統(tǒng)的邏輯表達(dá)式,才能進(jìn)行邏輯綜合。</p><p> 第三層次是邏輯綜合。即利用邏輯綜合工具,將RTL方式描述的程序轉(zhuǎn)換成用基本邏輯元件表示的文件(門級網(wǎng)絡(luò)表)。此時,如果需要,可將邏輯綜合的結(jié)果以邏輯原理圖的方式輸出。此后可對綜合的結(jié)果在
31、門電路級上進(jìn)行仿真,并檢查其時序關(guān)系。</p><p> 應(yīng)用邏輯綜合工具產(chǎn)生的門網(wǎng)絡(luò)表,將其轉(zhuǎn)換成PLD的編程碼,即可利用PLD實(shí)現(xiàn)硬件電路的設(shè)計(jì)。</p><p> 由自上而下的設(shè)計(jì)過程可知,從總體行為設(shè)計(jì)開始到最終的邏輯綜合,每一步都要進(jìn)行仿真檢查,這樣有利于盡早發(fā)現(xiàn)設(shè)計(jì)中存在的問題,從而可以大大縮短系統(tǒng)的設(shè)計(jì)周期。</p><p> 系統(tǒng)可大量采用PL
32、D芯片。</p><p> 由于目前眾多制造PLD芯片的廠家,其工具軟件均支持VHDL語言的編程。所以利用VHDL語言設(shè)計(jì)數(shù)字系統(tǒng)時,可以根據(jù)硬件電路的設(shè)計(jì)需要,自行利用PLD設(shè)計(jì)自用的ASIC芯片,而無須受通用元器件的限制。</p><p> EDA系統(tǒng)框架結(jié)構(gòu) EDA系統(tǒng)框架結(jié)構(gòu)(FRAMEWORK)是一套配置和使用EDA軟件包的規(guī)范。目前主要的EDA系統(tǒng)都建立了框架結(jié)構(gòu),如
33、 CADENCE公司的Design Framework,Mentor公司的Falcon Framework,而且這些框架結(jié)構(gòu)都遵守國際CFI組織制定的統(tǒng)一技術(shù)標(biāo)準(zhǔn)??蚣芙Y(jié)構(gòu)能將來自不同EDA廠商的工具軟件進(jìn)行優(yōu)化組合,集成在一個易于管理的統(tǒng)一的環(huán)境之下,而且還支持任務(wù)之間、設(shè)計(jì)師之間以及整個產(chǎn)品開發(fā)過程中的信息傳輸與共享,是并行工程和自頂向下設(shè)計(jì)施的實(shí)現(xiàn)基礎(chǔ)。</p><p> ?。牛模良夹g(shù)的每一次進(jìn)步,都引起了
34、設(shè)計(jì)層次上的一次飛躍,從設(shè)計(jì)層次上分,70年代為物理級設(shè)計(jì)(CAD),80年代為電路級設(shè)計(jì)(CAE),90年代進(jìn)入到系統(tǒng)級設(shè)計(jì)(EDA)。物理級設(shè)計(jì)主要指IC版圖設(shè)計(jì),一般由半導(dǎo)體廠家完成,對電子工程師沒有太大的意義,因此本文重點(diǎn)介紹電路級設(shè)計(jì)和系統(tǒng)級設(shè)計(jì)。</p><p> 仿真通過后,根據(jù)原理圖產(chǎn)生的電氣連接網(wǎng)絡(luò)表進(jìn)行PCB板的自動布局布線。在制作PCB板之前還可以進(jìn)行PCB后分析,其中包括熱分析、噪聲及竄
35、擾分析、電磁兼容分析、可靠性分析等,并可將分析后的結(jié)果參數(shù)反標(biāo)回電路圖,進(jìn)行第二次仿真,也稱為后仿真。后仿真主要是檢驗(yàn)PCB板在實(shí)際工作環(huán)境中的可行性。</p><p> 由此可見,電路級的EDA技術(shù)使電子工程師在實(shí)際的電子系統(tǒng)產(chǎn)生前,就可以全面地了解系統(tǒng)的功能特性和物理特性,從而將開發(fā)風(fēng)險消滅在設(shè)計(jì)階段,縮短了開發(fā)時間,降低了開發(fā)成本。</p><p> 系統(tǒng)級設(shè)計(jì) 進(jìn)人90年代以來
36、,電子信息類產(chǎn)品的開發(fā)明顯呈現(xiàn)兩個特點(diǎn):一是產(chǎn)品復(fù)雜程度提高;二是產(chǎn)品上市時限緊迫。然而,電路級設(shè)計(jì)本質(zhì)上是基于門級描述的單層次設(shè)計(jì),設(shè)計(jì)的所有工作(包括設(shè)計(jì)忙人、仿真和分析、設(shè)計(jì)修改等)都是在基本邏輯門這一層次上進(jìn)行的,顯然這種設(shè)計(jì)方法不能適應(yīng)新的形勢,一種高層次的電子設(shè)計(jì)方法,也即系統(tǒng)級設(shè)計(jì)方法,應(yīng)運(yùn)而生。</p><p> 高層次設(shè)計(jì)是一種“概念驅(qū)動式”設(shè)計(jì),設(shè)計(jì)人員無須通過原理圖描述電路,而是針對設(shè)計(jì)目
37、標(biāo)進(jìn)行功能描述。由于擺脫了電路細(xì)節(jié)的束縛,設(shè)計(jì)人員可以把精力集中于創(chuàng)造性的方案與概念的構(gòu)思上,而且這些概念構(gòu)思以高層次描述的形式輸人計(jì)算機(jī),EDA系統(tǒng)就能以規(guī)則驅(qū)動的方式自動完成整個設(shè)計(jì)。這樣,新的概念就能迅速有效地成為產(chǎn)品,大大縮短了,產(chǎn)品的研制周期。不僅如此,高層次設(shè)計(jì)只是定義系統(tǒng)的行為特性,可以不涉及實(shí)現(xiàn)工藝,因此還可以在廠家綜合庫的支持下,利用綜合優(yōu)化工。 </p><p> 2 出租車計(jì)費(fèi)系統(tǒng)的設(shè)計(jì)
38、</p><p> 2.1 出租車計(jì)費(fèi)設(shè)計(jì)</p><p> 實(shí)際中出租車的計(jì)費(fèi)工作原理一般分成3個階段: (1)車起步開始計(jì)費(fèi)。首先顯示起步價(本次設(shè)計(jì)起步費(fèi)為7.00元),車在行駛3 km以內(nèi),只收起步價7.00元。 (2)車行駛超過3 km后,按每公里2.2元計(jì)費(fèi)(在7.00元基礎(chǔ)上每行駛1 km車費(fèi)加2.2元),車費(fèi)依次累加。 (3)行駛路程達(dá)到或超過9 km后(車
39、費(fèi)達(dá)到20元),每公里加收50%的車費(fèi),車費(fèi)變成按每公里3.3元開始計(jì)費(fèi)。車暫時停止(行駛中遇紅燈或中途暫時停車)不計(jì)費(fèi),車費(fèi)保持不變。若停止則車費(fèi)清零,等待下一次計(jì)費(fèi)的開始</p><p> 2.2 基本設(shè)計(jì)思想 (1) 根據(jù)出租車計(jì)費(fèi)原理,將出租車計(jì)費(fèi)部分由5個計(jì)數(shù)器來完成分別為counterA,counterB,counterC,counterD,counterE。①計(jì)數(shù)器A完成車費(fèi)百位。②計(jì)數(shù)器B完
40、成車費(fèi)十位和個位。③計(jì)數(shù)器C完成車費(fèi)角和分。④計(jì)數(shù)器D完成計(jì)數(shù)到30(完成車費(fèi)的起步價)。⑤計(jì)數(shù)器E完成模擬實(shí)現(xiàn)車行駛100 m的功能。 (2)行駛過程中車費(fèi)附加50%的功能:由比較器實(shí)現(xiàn)。 (3)車費(fèi)的顯示:由動態(tài)掃描電路來完成。用專用模塊來實(shí)現(xiàn),完成數(shù)據(jù)的輸入即動態(tài)數(shù)據(jù)的顯示。 (4)通過分析可以設(shè)計(jì)出系統(tǒng)的頂層框圖如圖2.1所示:</p><p> 3 出租車計(jì)費(fèi)系統(tǒng)的實(shí)現(xiàn)</p>
41、<p> 3.1 系統(tǒng)的總體框圖</p><p><b> 3.2 程序流程圖</b></p><p> 3.3 系統(tǒng)各功能模塊的實(shí)現(xiàn)</p><p> 3.3.1 模塊JIFEI的實(shí)現(xiàn)</p><p> 模塊JIFEI見圖3.2。輸入端口START、STOP、PAUSE、JS分別為汽車起動、停止
42、、暫停、加速按鍵。</p><p> library ieee;</p><p> use ieee.std_logic_1164.all;</p><p> use ieee.std_logic_unsigned.all;</p><p> entity jifei is </p><p> port (c
43、lk,start,stop,pause,js:in std_logic;</p><p> chefei,luc:out integer range 0 to 8000);</p><p> end jifei;</p><p> architecture rtl of jifei is</p><p><b> begin
44、</b></p><p> process(clk,start,stop,pause,js)</p><p> variable a,b:std_logic;</p><p> variable aa:integer range 0 to 100;</p><p> variable chf,lc:integer rang
45、e 0 to 8000;</p><p> variable num:integer range 0 to 9;</p><p><b> begin</b></p><p> if(clk'event and clk='1')then</p><p> if(stop='0
46、9;)then</p><p><b> chf:=0;</b></p><p><b> num:=0;</b></p><p><b> b:='1';</b></p><p><b> aa:=0;</b></p>
47、<p><b> lc:=0;</b></p><p> elsif(start='0')then</p><p><b> b:='0';</b></p><p><b> chf:=700;</b></p><p>&l
48、t;b> lc:=0;</b></p><p> elsif(start='1' and js='1'and pause='1')then</p><p> if(b='0')then</p><p> num:=num+1;</p><p><b
49、> end if;</b></p><p> if(num=9)then</p><p><b> lc:=lc+5;</b></p><p><b> num:=0;</b></p><p><b> aa:=aa+5;</b></p>
50、<p><b> end if; </b></p><p> elsif(start='1'and js='0'and pause='1')then</p><p><b> lc:=lc+1;</b></p><p><b> aa:=aa+
51、1;</b></p><p><b> end if;</b></p><p> if(aa>=100)then</p><p><b> a:='1';</b></p><p><b> aa:=0;</b></p>&
52、lt;p><b> else</b></p><p><b> a:='0';</b></p><p><b> end if;</b></p><p> if(lc<300)then</p><p><b> null;<
53、/b></p><p> elsif(chf<2000 and a='1')then</p><p> chf:=chf+220;</p><p> elsif(chf>=2000 and a='1')then</p><p> chf:=chf+330;</p><
54、;p><b> end if;</b></p><p><b> end if;</b></p><p> chefei<=chf;</p><p><b> luc<=lc;</b></p><p> end process;</p>
55、<p><b> end rtl;</b></p><p> 3.3.2 模塊X的實(shí)現(xiàn)</p><p> 模塊X見圖3.3。該模塊把車費(fèi)和路程轉(zhuǎn)化為4位十進(jìn)制數(shù),daclk的頻率要比clk快得多</p><p> library ieee;</p><p> use ieee.std_logic_1
56、164.all;</p><p> use ieee.std_logic_unsigned.all;</p><p> entity x is</p><p> port(daclk:in std_logic;</p><p> ascore,bscore:in integer range 0 to 8000;</p>
57、<p> age,ashi,abai,aqian,bge,bshi,bbai,dqian:out std_logic_vector(3 downto 0));</p><p><b> end x ;</b></p><p> architecture rtl of x is</p><p><b> begin&l
58、t;/b></p><p> process(daclk,ascore)</p><p> variable comb1:integer range 0 to 8000;</p><p> variable comb1a,comb1b,comb1c,comb1d:std_logic_vector(3 downto 0);</p><p
59、><b> begin </b></p><p> if(daclk'event and daclk='1')then </p><p> if(comb1<ascore)then</p><p> if(comb1a=9 and comb1b=9 and comb1c=9)then</p>
60、;<p> comb1a:="0000";</p><p> comb1b:="0000";</p><p> comb1c:="0000";</p><p> comb1d:=comb1d+1;</p><p> comb1:=comb1+1;</p&
61、gt;<p> elsif(comb1a=9 and comb1b=9)then</p><p> comb1a:="0000";</p><p> comb1b:="0000";</p><p> comb1:=comb1+1;</p><p> comb1c:=comb1c+
62、1;</p><p> elsif(comb1a=9)then</p><p> comb1a:="0000";</p><p> comb1b:= comb1b+1;</p><p> comb1:= comb1+1;</p><p><b> else</b>&l
63、t;/p><p> comb1a:= comb1a+1;</p><p> comb1:= comb1+1;</p><p><b> end if;</b></p><p><b> else</b></p><p> ashi<= comb1b;</p&
64、gt;<p> age<= comb1a;</p><p> abai<= comb1c;</p><p> aqian<= comb1d;</p><p><b> comb1:=0;</b></p><p> comb1a:="0000";</p&g
65、t;<p> comb1b:="0000";</p><p> comb1c:="0000";</p><p> comb1d:="0000";</p><p><b> end if;</b></p><p><b> end
66、 if;</b></p><p> end process;</p><p> process(daclk,bscore)</p><p> variable comb2:integer range 0 to 8000;</p><p> variable comb2a,comb2b, comb2c,comb2d:std_
67、logic_vector(3 downto 0);</p><p><b> begin</b></p><p> if(daclk'event and daclk='1')then</p><p> if(comb2<bscore)then</p><p> if(comb2a=9
68、 and comb2b=9 and comb2c=9)then</p><p> comb2a:="0000";</p><p> comb2b:="0000";</p><p> comb2c:="0000";</p><p> comb2d:=comb2d+1;</
69、p><p> comb2:=comb2+1;</p><p> elsif(comb2a=9 and comb2b=9)then</p><p> comb2a:="0000";</p><p> comb2b:="0000";</p><p> comb2:= comb2
70、+1;</p><p> comb2c:= comb2c+1;</p><p> elsif(comb2a=9)then</p><p> comb2a:="0000";</p><p> comb2b:=comb2b+1;</p><p> comb2:=comb2+1;</p&g
71、t;<p><b> else</b></p><p> comb2a:= comb2a+1;</p><p> comb2:= comb2+1;</p><p><b> end if;</b></p><p><b> else</b></p&
72、gt;<p> bshi<=comb2b;</p><p> bge<=comb2a;</p><p> bbai<=comb2c;</p><p> bqian<=comb2d;</p><p><b> comb2:=0;</b></p><p>
73、; comb2a:="0000";</p><p> comb2b:="0000";</p><p> comb2c:="0000";</p><p> comb2d:="0000";</p><p><b> end if;</b>
74、;</p><p><b> end if;</b></p><p> end process;</p><p><b> end rtl;</b></p><p> 3.3.3 模塊XXX1的實(shí)現(xiàn)</p><p> 模塊XXX1見圖3.5。經(jīng)過該八進(jìn)制模塊將車費(fèi)和
75、路程顯示出來。</p><p> library ieee;</p><p> use ieee.std_logic_1164.all;</p><p> use ieee.std_logic_unsigned.all;</p><p> entity XXX1 is</p><p> port(c:in s
76、td_logic_vector(2 downto 0);</p><p> dp:out std_logic;</p><p> a1,a2,a3,a4,b1,b2,b3,b4:in std_logic_vector(3 downto 0);</p><p> d:out std_logic_vector(3 downto 0));</p>&l
77、t;p><b> end XXX1;</b></p><p> architecture rtl of xxx1 is</p><p><b> begin </b></p><p> process(c,a1,a2,a3,a4,b1,b2,b3,b4);</p><p> vari
78、able comb:std_logic_vector(2 downto o);</p><p><b> begin </b></p><p><b> comb:=c;</b></p><p> case comb is</p><p> when”000”=>d<=a1;&l
79、t;/p><p><b> dp<=’0’;</b></p><p> when”001”=>d<=a2;</p><p><b> dp<=’0’;</b></p><p> when”010”=>d<=a3;</p><p><
80、;b> dp<=’1’;</b></p><p> when”011”=>d<=a4;</p><p><b> dp<=’0’;</b></p><p> when”100”=>d<=b1;</p><p><b> dp<=’0’;<
81、;/b></p><p> when”101”=>d<=b2;</p><p><b> dp<=’0’;</b></p><p> when”110”=>d<=b3;</p><p><b> dp<=’1’;</b></p><
82、;p> when”111”=>d<=b4;</p><p><b> dp<=’0’;</b></p><p> when others=>null;</p><p><b> end case;</b></p><p> end process;</p
83、><p><b> end rtl;</b></p><p> 3.3.4 模塊SE的實(shí)現(xiàn)</p><p><b> 模塊SE見圖3.6</b></p><p> library ieee;</p><p> use ieee.std_logic_1164.all;&
84、lt;/p><p> use ieee.std_logic_unsigned.all;</p><p> entity se is</p><p> port(clk:in std_logic;</p><p> a:out std_logic_vector(2 down to 0));</p><p><b
85、> end se;</b></p><p> architecture rtl of se is</p><p><b> begin</b></p><p> process(clk)</p><p> variable b:std_logic_bector(2 downto 0);<
86、/p><p><b> begin </b></p><p> if(clk’event and clk=’1’)then</p><p> if(b=”111”)then</p><p><b> b:=”000”;</b></p><p><b> els
87、e</b></p><p><b> b:=b+1;</b></p><p><b> end if;</b></p><p><b> end if;</b></p><p><b> a<=b;</b></p>
88、<p> end process;</p><p><b> end rtl;</b></p><p> 3.3.5 模塊DI的實(shí)現(xiàn)</p><p><b> 模塊DI見圖3.7</b></p><p> library ieee;</p><p> u
89、se ieee.std_logic_1164.all;</p><p> use ieee.std_logic_unsigned.all;</p><p> entity di is</p><p> port(d:in std_logic_vector(3 downto 0);</p><p> q:out std_logic_ve
90、ctor(6 downto 0));</p><p><b> end di;</b></p><p> architecture rtl of di is</p><p><b> begin</b></p><p> process(d)</p><p><
91、;b> begin</b></p><p><b> case d is</b></p><p> when”0000”=>q<=”0111111”;</p><p> when”0001”=>q<=”0000110”;</p><p> when”0010”=>
92、q<=”1011011”;</p><p> when”0011”=>q<=”1001111”;</p><p> when”0100”=>q<=”1100110”;</p><p> when”0101”=>q<=”1101101”;</p><p> when”0110”=>q<
93、;=”1111101”;</p><p> when”0111”=>q<=”0100111”;</p><p> when”1000”=>q<=”1101111”;</p><p> when others=>q<=”1101111”</p><p><b> end case;</
94、b></p><p> end process;</p><p><b> end rtl;</b></p><p><b> 4 系統(tǒng)仿真</b></p><p> 4.1 模塊X的仿真結(jié)果</p><p> 將車費(fèi)和路程轉(zhuǎn)換成4位的十進(jìn)制如圖4.1所示:
95、</p><p> 輸入端為:Daclk, ascore, bscore</p><p> 輸出端為:Age, ashi, aqian, abai, bge, bshi, bqian, bbai;</p><p> 圖4.1 模塊X仿真波形圖</p><p> 4.2 模塊JIFEI的仿真結(jié)果</p><p>
96、 該模塊是模擬汽車的啟動、停止、暫停、加速按鍵,如圖4.2所示:</p><p> 輸入端口為:stop, start, pause, js;</p><p> 輸出端口為:clk, b;</p><p> 圖4.2 模塊JIFEI仿真波形圖</p><p> 4.3 模塊XXX1的仿真結(jié)果</p><p>
97、 該模塊是將車費(fèi)和路程顯示出來如圖4.3所示</p><p> 輸入端為:c, a1,a2,a3,a4,b1,b2,b3,b4;</p><p> 輸出端為:dp,d;</p><p> 圖4.3 模塊XXX1仿真波形圖</p><p> 4.4模塊SE的結(jié)果驗(yàn)證</p><p> 模塊SE仿真如圖4.4所
98、示:</p><p><b> 輸入端為:clk</b></p><p><b> 輸出端為:a</b></p><p> 圖4.4 模塊SE仿真波形圖</p><p> 4.5模塊DI的結(jié)果驗(yàn)證</p><p> 模塊DI仿真的結(jié)果如圖4.5所示 </p&g
99、t;<p><b> 輸入端為:d </b></p><p><b> 輸出端為:q</b></p><p> 圖4.5 模塊DI仿真波形圖</p><p><b> 5 結(jié)論</b></p><p> 出租車計(jì)費(fèi)器系統(tǒng)的設(shè)計(jì)已全部完成,能按預(yù)期的效果進(jìn)
100、行模擬汽車啟動、停止、暫停等功能,并設(shè)計(jì)動態(tài)掃描電路顯示車費(fèi)數(shù)目,由動態(tài)掃描電路來完成。車暫時停止不計(jì)費(fèi),車費(fèi)保持不變。若停止則車費(fèi)清零,等待下一次計(jì)費(fèi)的開始。出租車計(jì)費(fèi)器系統(tǒng)的設(shè)計(jì)已全部完成,能按預(yù)期的效果進(jìn)行模擬汽車啟動、停止、暫停等功能,并設(shè)計(jì)動態(tài)掃描電路顯示車費(fèi)數(shù)目,由動態(tài)掃描電路來完成。車暫時停止不計(jì)費(fèi),車費(fèi)保持不變。若停止則車費(fèi)清零,等待下一次計(jì)費(fèi)的開始。在出租車計(jì)費(fèi)系統(tǒng)的5個模塊中 ,重點(diǎn)在于JIFEI模塊,X模塊、XXX
101、1模塊。JIFEI模塊主要有汽車的啟動、停止、暫停、加速按鍵;X模塊主要是把車費(fèi)和路程轉(zhuǎn)化為4位十進(jìn)制;X模塊是將車費(fèi)和路程顯示出來。各模塊完成后,在將它們組合成完整的出租車系統(tǒng),在設(shè)計(jì)過程中還需要改進(jìn)的是控制系統(tǒng)的糾錯功能。出租車計(jì)費(fèi)系統(tǒng)的設(shè)計(jì)中體現(xiàn)了VHDL覆蓋面廣,描述能力強(qiáng),是一個多層次的硬件描述語言及PLD器件速度快,使用方便,便于修改等特點(diǎn),本設(shè)計(jì)在實(shí)用方面具有一定的價值。 </p><p>&
102、lt;b> 致 謝</b></p><p> 本文是在指導(dǎo)老師***老師的悉心指導(dǎo)下完成的,**老師在學(xué)術(shù)上嚴(yán)格要求,在生活上給予關(guān)懷,**老師的教誨和鼓勵,及在學(xué)術(shù)上一絲不茍的精神,作者受益匪淺,在此向**老師表示衷心的感謝和敬意! </p><p> 至此,畢業(yè)設(shè)計(jì)就快接近尾聲了,在這里我再一次誠摯的感謝*老師和在大學(xué)期間對我諄諄教導(dǎo)的老師和領(lǐng)導(dǎo)們。 <
103、/p><p> 最后,向在設(shè)計(jì)中給予我關(guān)心、支持和幫助的同學(xué)表示謝意!</p><p><b> 參考文獻(xiàn)</b></p><p> [1] 候伯亨,顧新.VHDL硬件描述語言與數(shù)字邏輯電路設(shè)計(jì).修訂版電子工程師必備知識[M].西安:西安電子科技大學(xué)出版社,1999[2] 張昌凡,等.可編程邏輯器件及VHDL設(shè)計(jì)技術(shù)[M].廣州:華南理
104、工大學(xué)出版社,2001[3] 曾繁泰,陳美金.VHDL程序設(shè)計(jì)[M].北京:清華大學(xué)出版社,2001</p><p> [4] 潘松,等.VHDL實(shí)用教程[M].成都:電子科技大學(xué)出版社,2000</p><p> [5] 高健, 沈慶宏, 高敦堂. ITS 中車輛檢測器設(shè)備的研究與實(shí)現(xiàn)[J ].</p><p> 交通與計(jì)算機(jī), 2002. 20 (
105、5):15218</p><p> [6] 王小平, 王彥芳, 等. 基于EDA 技術(shù)的出租車費(fèi)計(jì)價單片系統(tǒng)</p><p> [7] 盧慶利. 將VHDL 硬件描述語言引入數(shù)字電路教學(xué)的探索[J ]. 實(shí)</p><p> 驗(yàn)室研究與探索, 2000, 19 (5) : 67270</p><p> [8] 劉艷. EDA 技術(shù)在數(shù)
106、字系統(tǒng)電路設(shè)計(jì)實(shí)驗(yàn)中的應(yīng)用[J ]. 實(shí)驗(yàn)室研</p><p> 究與探索, 2002, 21 (3) : 63264</p><p> [9] 潭會生,張昌凡. EDA技術(shù)及應(yīng)用.西安:電子科技大學(xué)出版社.2001</p><p> [10] 徐穎.Protel 99 SE EDA技術(shù)及應(yīng)用.西安:機(jī)械工業(yè)出版社.2005 </p>
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 出租車計(jì)費(fèi)系統(tǒng)設(shè)計(jì)【畢業(yè)設(shè)計(jì)】
- 畢業(yè)設(shè)計(jì)----出租車計(jì)費(fèi)系統(tǒng)的設(shè)計(jì)
- 畢業(yè)設(shè)計(jì)----出租車計(jì)費(fèi)系統(tǒng)的設(shè)計(jì)
- 出租車計(jì)費(fèi)系統(tǒng)的設(shè)計(jì)
- 畢業(yè)設(shè)計(jì)論文基于fpga的出租車計(jì)費(fèi)系統(tǒng)設(shè)計(jì)
- 出租車計(jì)費(fèi)系統(tǒng)設(shè)計(jì)畢業(yè)論文
- 出租車計(jì)費(fèi)系統(tǒng)的設(shè)計(jì)【畢業(yè)論文】
- 畢業(yè)設(shè)計(jì)----基于pld設(shè)計(jì)的出租車計(jì)費(fèi)器系統(tǒng)
- 出租車計(jì)費(fèi)設(shè)計(jì).doc
- 出租車計(jì)費(fèi)設(shè)計(jì).doc
- [優(yōu)秀畢業(yè)設(shè)計(jì)精品] 基于fpga的出租車計(jì)費(fèi)系統(tǒng)的設(shè)計(jì)
- 出租車計(jì)費(fèi)系統(tǒng)的設(shè)計(jì)畢業(yè)論文定
- 基于plc單片機(jī)的出租車計(jì)費(fèi)系統(tǒng)設(shè)計(jì)畢業(yè)設(shè)計(jì)
- 畢業(yè)設(shè)計(jì)----基于pic單片機(jī)的出租車計(jì)費(fèi)系統(tǒng)
- 畢業(yè)設(shè)計(jì)----出租車計(jì)價系統(tǒng)
- 出租車計(jì)費(fèi)系統(tǒng)的設(shè)計(jì)開題報告
- 出租車計(jì)費(fèi)系統(tǒng)的設(shè)計(jì)【開題報告】
- 畢業(yè)設(shè)計(jì)----基于pic單片機(jī)的出租車計(jì)費(fèi)系統(tǒng)
- 畢業(yè)設(shè)計(jì)(論文)-eda技術(shù)在出租車計(jì)費(fèi)系統(tǒng)中的應(yīng)用設(shè)計(jì)
- 基于sopc的出租車計(jì)費(fèi)系統(tǒng)的設(shè)計(jì)
評論
0/150
提交評論