無葉風扇控制器 畢業(yè)論文_第1頁
已閱讀1頁,還剩45頁未讀 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

1、<p><b>  畢 業(yè) 設(shè) 計</b></p><p>  課題名稱 無葉風扇控制器 </p><p>  姓 名 </p><p>  學 號 </p><p>  班 級 電子S1

2、0-2 </p><p>  專 業(yè) 應(yīng)用電子 </p><p>  所 在 系 電子技術(shù)系 </p><p>  指導教師 </p><p>  完成日期 2013-1-25 </p><p&g

3、t;  天津電子信息職業(yè)技術(shù)學院 頁號(1)</p><p>  畢業(yè)設(shè)計(論文)進度計劃表</p><p>  天津電子信息職業(yè)技術(shù)學院 </p><p>  注:1.本任務(wù)書一式兩份由指導教

4、師填寫,一份由學生所在系留存,一份發(fā)給學生,任務(wù)完成后附在說明書內(nèi)。</p><p>  2.簽字部分用筆填寫,其余各項均要求打印。(宋體、小4號字)</p><p>  畢業(yè)設(shè)計(論文)開題報告</p><p>  天津電子信息職業(yè)技術(shù)學院 頁號(1)</p>

5、<p>  天津電子信息職業(yè)技術(shù)學院 頁號(2)</p><p>  注:本報告一式兩份由學生本人填寫(打印、宋體、小4號字),一份由學生所在系留存,一份由學生完成設(shè)計(論文)后附在說明書內(nèi)。</p><p>  畢 業(yè) 設(shè) 計(論 文)</p><p><b&

6、gt;  無葉風扇控制器</b></p><p><b>  摘 要</b></p><p>  無葉風扇也叫空氣增倍機,它能產(chǎn)生自然持續(xù)的涼風,因無葉片,不會覆蓋塵土或傷到好奇兒童手指。更奇妙的是其造型奇特,外表既流線又清爽。產(chǎn)品靈感源于空氣葉片干手器。干手器的原理是迫使空氣經(jīng)過一個小口“刷”干手上的水,空氣增倍機是讓空氣從一個1.3毫米寬、繞著圓環(huán)轉(zhuǎn)

7、動的切口里吹出來。因空氣是被強制從這一圓圈里吹出來的,通過的空氣量可增到15倍,時速可增至35公里。</p><p>  本次設(shè)計產(chǎn)品的FPGA 芯片采用XILINX 公司的XC6SLX9作為系統(tǒng)控制核心,完成對無葉風扇的閉環(huán)控制,提供了一個帶有8位LED顯示、并使其集中到一塊面板上,使得操作方便快捷,直接在LED顯示實時壓強,設(shè)定壓強,該設(shè)計中使用成品壓強傳感器,對壓強進行實時采集,使用紅外傳感器采集人體信號信

8、息,實現(xiàn)無人自動停機,有人自動開機,使該系統(tǒng)更加人性化、智能化。</p><p>  適宜大多數(shù)普通家庭、寢室、辦公住所等。 </p><p>  關(guān)鍵詞: FPGA; 閉環(huán)控制; 壓強檢測; 人體檢測</p><p><b>  目錄</b></p><p><b>  一、緒 論2</b>&

9、lt;/p><p><b>  1.概述2</b></p><p><b>  2.特點3</b></p><p>  二、系統(tǒng)的總體設(shè)計4</p><p>  1.總體設(shè)計思想4</p><p><b>  2.系統(tǒng)總機構(gòu)4</b></p&

10、gt;<p>  3.系統(tǒng)設(shè)計原理圖5</p><p>  三、系統(tǒng)電路模塊7</p><p>  1.DCP-100-LX9 FPGA核心板7</p><p>  2.CGQ-002-A 壓力檢測電路8</p><p><b>  3.顯示電路8</b></p><p>

11、  四、軟件部分設(shè)計12</p><p><b>  五、結(jié) 論13</b></p><p><b>  六、致 謝14</b></p><p><b>  七、參考文獻15</b></p><p><b>  附錄16</b></p&

12、gt;<p>  1.VHDL程序源碼:16</p><p>  2.精彩瞬間:25</p><p><b>  一、緒 論</b></p><p><b>  1.概述</b></p><p>  JamesDyson公司歷時4年研發(fā)了一種神奇的無扇葉風扇,它使用了最新的流體動

13、力工程技術(shù),通過高效率的無刷電機使氣流增加15倍,以每秒118加侖的速率釋放出來,合1580CFM的風量。Dyson公司介紹,為了精確估算各項指標,為了優(yōu)化開口的翼型弧度,工程師們花了4年時間,經(jīng)歷了數(shù)百次模擬實驗把氣體流動圖通過激光多普勒測量儀繪制出來。Dyson本人解釋說:“風扇開口的弧度設(shè)計是無扇葉風扇的關(guān)鍵,我們發(fā)現(xiàn)利用這種方式對空氣進行引導和放大的效果很好,當然,這也是我們最初打算設(shè)計這樣一款無扇葉風扇的原因。</p&g

14、t;<p>  據(jù)了解,“無扇葉電風扇”是吸塵器的發(fā)明人戴森爵士的最新發(fā)明,因此還被冠名為“戴森空氣倍增器”。其吹風原理類似于烘手機。62歲的戴森是英國最知名的發(fā)明家之一,他說自己是在發(fā)明自動烘手機的時候突然得到靈感?!昂媸謾C是從一個小裂縫吹出氣流,把手烘干。于是我想到制造一個不用扇葉的空氣推動裝置。” </p><p><b>  2.特點</b></p>&l

15、t;p>  這款風扇(氣流放大器)有兩個尺寸:10英寸直徑和12英寸(25.4cm和30.48cm),10英寸的版本有瓦藍色和銀白色,12英寸的風扇只有銀白色。風扇上旋鈕可以調(diào)整出風量,而且可以調(diào)整吹風的角度。這款無葉電風扇的外形像一只巨大的指環(huán),能產(chǎn)生強有力的涼爽空氣,也比傳統(tǒng)電扇安全。另外,它清洗起來也比傳統(tǒng)電風扇方便得多,使用者不需要為清理扇葉上積滿的灰塵發(fā)愁了。和傳統(tǒng)電風扇一樣,它能夠90度角擺動。它還能通過人為控制發(fā)生燈

16、光變化。使用這種無扇葉風扇明顯的好處就是你不用擔心孩子的手會被扇葉傷到,你也不用操心給扇葉做清洗了。很多人更感興趣的是這種風扇不存在風扇中心區(qū)的“死區(qū)”,此外你也不用操心扇葉切割空氣產(chǎn)生的噪音了,不過無刷電機工作時依然有噪音,大概和XBox360工作時的差不多。不過這款風扇最大的劣勢就是價格,10英寸風扇售價299.9美元,12英寸的為329.99美元,合人民幣2046元、2250元。要享受真正的技術(shù)革新就得花大價錢。</p>

17、;<p><b>  二、系統(tǒng)的總體設(shè)計</b></p><p><b>  1.總體設(shè)計思想</b></p><p>  以FPGA為控制中心,外部傳感器為檢測元件,通過按鍵控制其無葉風扇的風速與開關(guān),輸出由LED顯示數(shù)碼管與紅外人體電路組成,F(xiàn)PGA通過接收各個壓力傳感器的返回狀態(tài)值來進行風速的控制,紅外人體檢測電路判斷是否人,

18、來進行風扇的開關(guān)控制(該功能可設(shè)置是否啟用)??刂葡到y(tǒng)的總體設(shè)計框圖如圖1-1所示:。</p><p>  圖2-1 系統(tǒng)總體設(shè)計框圖</p><p><b>  2.系統(tǒng)總機構(gòu)</b></p><p>  為了實現(xiàn)設(shè)計要求的基本功能,本系統(tǒng)必須包含四個基本功能模塊:</p><p>  1.FPGA控制模塊</

19、p><p><b>  2.壓強采集模塊</b></p><p><b>  3.風扇控制模塊</b></p><p><b>  4.顯示模塊</b></p><p>  其中FPGA控制模塊主要用于回應(yīng)傳感器信號和進行顯示程控;傳感器模塊主要用于感應(yīng)是否有物體通過,并形成電平信

20、號輸出,對風扇的實時控制;顯示模塊主要用于顯示當前風扇的氣壓值,及設(shè)置的氣壓值。</p><p>  為完善系統(tǒng)的功能同時能夠達到系統(tǒng)的設(shè)計指標,本系統(tǒng)必須包含以下功能模塊:</p><p>  1.復(fù)位電路:實現(xiàn)FPGA的復(fù)位控制</p><p>  2.振蕩電路:提供所需的FPGA時鐘頻率</p><p><b>  3.系統(tǒng)設(shè)

21、計原理圖</b></p><p>  本系統(tǒng)基本原理結(jié)構(gòu)圖如圖圖2-2所示。</p><p><b>  圖2-2 原理圖</b></p><p><b>  圖2-3 核心板</b></p><p>  圖2-4 顯示部分</p><p>  圖2-1由以

22、上系統(tǒng)基本原理框架圖可以看出,本系統(tǒng)的外圍電路相對比較復(fù)雜,功能的實現(xiàn)主要是從外部獲取控制信號之后在FPGA中進行數(shù)據(jù)處理,數(shù)據(jù)處理完畢之后FPGA便將控制信號輸出到報警電路進行報警,將顯示數(shù)據(jù)輸出到顯示電路進行顯示。所以本系統(tǒng)的FPGA數(shù)據(jù)處理方面的程序相對比較復(fù)雜一些,所有的感應(yīng)信號和顯示數(shù)據(jù)的處理和輸入控制都是在FPGA中進行處理,這就要求在設(shè)計程序的時候要認真思考FPGA管腳的分配問題。</p><p>

23、<b>  三、系統(tǒng)電路模塊</b></p><p>  1.DCP-100-LX9 FPGA核心板</p><p>  型號:DCP-100-LX9</p><p>  名稱:FPGA 核心板</p><p>  說明:此模塊的FPGA 芯片采用XILINX 公司的XC6SLX9,配置方式JTAG 全部引出,芯片<

24、;/p><p>  時鐘為100MHz。外圍器件有:FLASH 芯片W25Q128BV、EEPROM 芯片M93C66、串口通訊芯片</p><p>  MAX3232、USB 轉(zhuǎn)串口芯片PL2303。線路板上以扁平帶方式引出72 路IO 口分9 組,分別為JA-JG ,方便與外圍電路數(shù)據(jù)地址線連接,如圖圖3-1所示。</p><p>  圖3-1 DCP-100-LX

25、9 FPGA核心板</p><p>  2.CGQ-002-A 壓力檢測電路</p><p>  型號:CGQ-002-A</p><p><b>  名稱:壓力檢測電路</b></p><p>  說明:傳感器采用摩托羅拉公司的高性能擴散硅壓力傳感器MPX53DP 并通過專門的保護</p><p&g

26、t;  支座安裝在線路板上。處理電路采用由運放構(gòu)成的兩級放大電路實現(xiàn)對信號的放大、調(diào)理。</p><p>  該模塊可用DC12V 供電,輸出為模擬量信號。</p><p>  圖示圖3-2 所示:</p><p>  圖3-2 CGQ-002-A 壓力檢測電路</p><p><b>  3.顯示電路</b><

27、/p><p><b>  數(shù)碼管顯示的工理</b></p><p>  八段LED顯示器由8個發(fā)光二極管組成?;?個長條形的發(fā)光管排列成“日”字形,另一個點形的發(fā)光管在顯示器的右下角作為顯示小數(shù)點用,它能顯示各種數(shù)字及部份英文字母。LED顯示器有兩種不同的形式:一種是8個發(fā)光二極管的陽極都連在一起的,稱之為共陽極LED顯示器;另一種是8個發(fā)光二極管的陰極都連在一起的,稱

28、之為共陰極LED顯示器。如圖4.6所示: </p><p>  圖3-3 數(shù)碼管顯示器</p><p>  在選用共陰的LED時,只要在某一個發(fā)光二極管加上高電平,該二極管即點亮,反之則暗。而選用共陽極的LED時,要使某一個發(fā)光二極管發(fā)亮,則需加上低電平,反之則暗。為了保護各段LED不受損壞,需要外加限流電阻。為了要顯示某個字型,則應(yīng)使此字形段的相應(yīng)點二極管點亮,也即送一個不同的電平組合代

29、表數(shù)據(jù)來控制LED顯示的字型,此數(shù)據(jù)稱為字符的段碼。本電路采用共陰極接法。十六進制數(shù)字型代碼表如表4.1所示: </p><p>  單片機驅(qū)動LED顯示有很多方法,按顯示方式可以分為靜態(tài)顯示和動態(tài)顯示。</p><p>  靜態(tài)顯示就是顯示驅(qū)動電路具有輸出鎖存功能,單片機將要顯示的數(shù)據(jù)送出后就不再控制LED,直到下一次顯示時再傳送一次新的數(shù)據(jù)。只要當前顯示的數(shù)據(jù)沒有變化,就無須理睬數(shù)碼顯

30、示管。靜態(tài)顯示的數(shù)據(jù)穩(wěn)定,占用的CPU時間少。靜態(tài)顯示中,每一個顯示器都要占用單獨具有鎖存功能的</p><p>  型代碼。這樣單片機只要把顯表3.1 十六進制數(shù)字型代碼表</p><p>  示的字型數(shù)據(jù)代碼發(fā)送到接口電路,該字段就可以顯示要發(fā)送的字型。當需要要顯示新的數(shù)據(jù)時,單片機再發(fā)送新的字型碼。</p><p>  另一種方法是動態(tài)掃描顯示。動態(tài)

31、掃描方法是用其接口電路把所有顯示器的8個筆畫字段(a~g和dp)同名端連在一起,而每一個顯示器的公共極COM各自獨立接受I/O線控制。CPU向字段輸出端口輸出字型碼時,所有顯示器接受相同的字型碼,但究竟使哪一位則由I/O線決定。動態(tài)掃描用分時的方法輪流控制每個顯示器的COM端,使每個顯示器輪流電亮。在輪流點亮過程中,每位顯示器的點亮時間極為短暫,但由于人的視覺暫留現(xiàn)象及發(fā)光二極管的余輝效應(yīng),給人的印象就是一組穩(wěn)定的顯示數(shù)據(jù)。</p

32、><p>  DCP-102-A 數(shù)碼管顯示和鍵盤電路</p><p>  型號:DCP-102-A</p><p>  名稱:數(shù)碼管顯示和鍵盤電路</p><p>  說明:該模塊包括八位數(shù)碼管顯示單元、查詢式鍵盤、矩陣式鍵盤所組成。該線路板配</p><p>  合FPGA 核心板可以完成數(shù)碼管的靜態(tài)和動態(tài)掃描實驗,完

33、成查詢式和矩陣式鍵盤實驗。</p><p>  圖3-4 數(shù)碼管顯示和鍵盤電路</p><p>  本設(shè)計中使用動態(tài)掃描的方式對數(shù)碼管進行控制掃描,其電路圖如圖4.7所示,圖中SRD2為上拉電阻排,電阻值為10K,驅(qū)動芯片用74HC573作為驅(qū)動使用,U2為位選驅(qū)動,U3為段碼驅(qū)動,單片機的P0口接LED的段碼驅(qū)動,單片機的P2口接LED的位選碼驅(qū)動,該器件驅(qū)動電流可以達到100mA,而

34、LED數(shù)碼管全亮時,最大電流可以達到32mA,如果全部驅(qū)動輸出會將數(shù)碼管燒壞,所以在程序中使用PWM輸出的控制,在消隱時,也就是禁止數(shù)碼管的輸出,之后加上一段時間的延時,要確保加入的時間與顯示時間和不能超過20ms,同時74HC573具有鎖存功能,在本設(shè)計中沒有使用該功能。</p><p><b>  四、軟件部分設(shè)計</b></p><p>  主程序完成控制、執(zhí)行

35、,流程圖如圖圖4.1所示。</p><p>  圖4.1 主程序流程圖</p><p><b>  五、結(jié) 論</b></p><p>  我們在設(shè)計調(diào)試過程中也遇到了一些問題,但我們牢記指導老師在平時訓練中教給我們的“定位準確、機理清楚、故障復(fù)現(xiàn)、措施有效、舉一反三”的技術(shù)歸零方針,并嚴格按照技術(shù)歸零方針來查找和解決問題。最后,通過團隊的共

36、同努力,完成了無葉風扇控制器的設(shè)計及制作。</p><p>  在這次畢設(shè)中,我們不但將學校所學的《模擬電子技術(shù)》、《數(shù)字電子技術(shù)》、《電子產(chǎn)品組裝工藝》、《PCB設(shè)計》等專業(yè)知識應(yīng)用到比賽中,實現(xiàn)了學以致用,而且專業(yè)知識和技能得到了大幅度的提升,同時鍛煉和提高了獨立分析問題、解決問題的能力、溝通能力及團隊協(xié)作能力。</p><p>  從整套系統(tǒng)的設(shè)計,調(diào)試和實現(xiàn)的過程中,我學到了許多很

37、有意義的東西: </p><p>  首先:使用的開發(fā)語言有VHDL語言,使我的編程能力得到了很大的鍛煉和提高。</p><p>  其次:設(shè)計和實現(xiàn)各種功能,可以說是對軟件工程中的軟件開發(fā)方法一次又一次的實踐。每次的成功和失敗,都給我深刻的啟示,指導我怎樣更好的進行軟件開發(fā),應(yīng)該避免哪些問題。</p><p>  再次:調(diào)試的時候,充分體驗了一次工程現(xiàn)場調(diào)試的氛圍

38、,與各位實驗室同學一起的場景至今仍然歷歷在目。再這里,我要再次的感謝我的指導老師張美英。</p><p>  畢業(yè)論文從十月份開始入手,到現(xiàn)在已經(jīng)三個月了。這份大學期間最后的作業(yè),是對我的又一次挑戰(zhàn)。雖然在旁人看來這工作可能微不足道,但我卻從中學到了不少東西;體會到了工作中的酸甜苦辣,也認識到了自己的不足之處。這對我今后的工作和學習都是大有裨益的。遺憾的是,限于時間和能力,沒能將工作做得更好。 最后,再次感謝所

39、有關(guān)心和幫助過我的老師和朋友們。</p><p><b>  六、致 謝</b></p><p>  首先,也是最主要感謝的是我的指導老師,xx兩位老師。在整個過程中他給了我很大的幫助,在論文題目制定時,他首先肯定了我的題目大方向,讓我在寫作時有了具體方向。在論文提綱制定時,我的思路不是很清晰,經(jīng)過老師的幫忙,讓我具體寫作時思路頓時清晰。在完成初稿后,老師認真查看了

40、我的文章,指出了我存在的很多問題。在此十分感謝張老師的細心指導,才能讓我順利完成畢業(yè)論文。</p><p>  最后要感謝在整個論文寫作過程中幫助過我的每一位人。</p><p><b>  七、參考文獻</b></p><p>  [1] 華兵.MCS-51單片機原理應(yīng)用.武漢:武漢華中科技大學出版社,2002 .5</p>&

41、lt;p>  [2] 李華.MCU-51系列單片機實用接口技術(shù).北京:北京航空航天大學出版社, 1993. 6</p><p>  [3] 陳光東.單片機微型計算機原理與接口技術(shù)(第二版).武漢:華中理工大學出版社,1999.4</p><p>  [4] 徐淑華,程退安,姚萬生.單片機微型機原理及應(yīng)用.哈爾濱:哈爾濱工業(yè)大學出版社,1999. 6.</p><p

42、>  [5] 九州.放大電路實用設(shè)計手冊.沈陽:遼寧科學技術(shù)出版社,2002.5</p><p>  [6] 樊昌元,丁義元. 高精度雷達研究.電子測量與儀器學報,2000.10</p><p>  [7] 蘇偉,鞏壁建.誤差分析.傳感器技術(shù),2004.</p><p>  [8] 永學等.1-Wire總線數(shù)字溫度傳感器DS18B20及應(yīng)用.電子產(chǎn)品世界,20

43、03.12</p><p><b>  附錄</b></p><p><b>  VHDL程序源碼:</b></p><p>  注:每部分函數(shù)應(yīng)單獨建立文件 ,有頂層 文件電泳子函數(shù)</p><p><b>  --頂層函數(shù)</b></p><p> 

44、 library IEEE;</p><p>  use IEEE.STD_LOGIC_1164.ALL;</p><p>  USE ieee.std_logic_unsigned.all;</p><p>  USE ieee.std_logic_arith.all;</p><p>  entity wendu is</p>

45、<p><b>  port(</b></p><p>  CLK : in std_logic;--100MHZ,系統(tǒng)時鐘</p><p>  RESET : in std_logic;</p><p>  ren: in std_logic;--人體紅外控制</p><

46、p>  pwm_out:out std_logic; --電機控制信號</p><p>  SDA : inout std_logic;--串行總線雙向數(shù)據(jù)</p><p>  SCL : out std_logic;--串行總線時鐘</p><p>  --switch: out std_logic;

47、 --小數(shù)點控制</p><p>  keyin: in std_logic_vector(3 downto 0 );</p><p>  data_in_ce: in std_logic_vector(11 downto 0);</p><p>  DOT: out std_logic;

48、--小數(shù)點控制</p><p>  LED7 : out std_logic_vector(6 downto 0);--斷碼(不包含小數(shù)點)</p><p>  BIT8 : out std_logic_vector(0 to 7)--位碼</p><p><b>  );</b></p><p&g

49、t;  end wendu;</p><p>  architecture Behavioral of wendu is</p><p>  --氣壓 信號 采集</p><p>  component ack_check</p><p><b>  port( </b></p><p>  CL

50、K : in std_logic;</p><p>  RESET : in std_logic;</p><p>  SDA : inout std_logic;--串行總線雙向數(shù)據(jù)</p><p>  SCL : out std_logic;--串行總線時鐘</p><p>  data_shi : ou

51、t std_logic_vector(11 downto 0)--</p><p><b>  );</b></p><p>  end component;</p><p><b>  --顯示 控制</b></p><p>  component display</p><

52、;p><b>  port(</b></p><p>  CLK : in std_logic;--100MHZ,系統(tǒng)時鐘</p><p>  RESET : in std_logic;</p><p>  ren: in std_logic;</p><p>  pwm_out

53、:out std_logic;--電機控制信號</p><p>  --switch: out std_logic; --小數(shù)點控制</p><p>  keyin: in std_logic_vector(3 downto 0 );</p><p>  data_in_ce: in std_log

54、ic_vector(11 downto 0);</p><p>  ---mode: in std_logic;</p><p>  DOT: out std_logic; --小數(shù)點控制</p><p>  LED7 : out std_logic_vector(6 downto 0);--斷碼

55、(不包含小數(shù)點)</p><p>  BIT8 : out std_logic_vector(0 to 7)--位碼</p><p><b>  );</b></p><p>  end component;</p><p>  signal data_r:std_logic_vector(11 downto

56、0);</p><p>  signal fu_hao:std_logic;</p><p><b>  begin</b></p><p>  u1: ack_check port map(</p><p><b>  CLK=>clk,</b></p><p>  

57、reset=>reset,</p><p><b>  SDA=>SDA,</b></p><p><b>  SCL=>SCL,</b></p><p>  data_shi=>data_r--AD氣壓值 輸出</p><p><b>  );</b>

58、</p><p>  u2:display port map(</p><p><b>  clk=>clk,</b></p><p>  reset=>reset,</p><p>  ren=>ren,--人體紅外控制</p><p>  pwm_out=>pwm_ou

59、t,--電機控制信號</p><p>  --switch=>switch,</p><p>  keyin=>keyin,</p><p>  data_in_ce=>data_r,--AD采集后的氣壓值</p><p><b>  dot=>dot,</b></p>

60、<p>  led7=>led7,</p><p>  bit8=>bit8</p><p><b>  );</b></p><p>  end Behavioral;</p><p>  --pwm 無葉風扇 控制 部分代碼</p><p>  library IEE

61、E;</p><p>  use IEEE.STD_LOGIC_1164.ALL;</p><p>  use ieee.std_logic_unsigned.all;</p><p>  use ieee.std_logic_arith.all;</p><p>  entity display is</p><p>

62、;<b>  port(</b></p><p>  CLK : in std_logic;--100MHZ,系統(tǒng)時鐘</p><p>  RESET : in std_logic;</p><p>  ren: in std_logic;</p><p>  pwm_out :

63、out std_logic;--電機控制信號</p><p>  keyin: in std_logic_vector(3 downto 0 );</p><p>  data_in_ce: in std_logic_vector(11 downto 0); --</p><p>  DOT: out std_logic;

64、 --小數(shù)點控制</p><p>  LED7 : out std_logic_vector(6 downto 0);--斷碼(不包含小數(shù)點)</p><p>  BIT8 : out std_logic_vector(0 to 7)--位碼</p><p><b>  );</b></p&

65、gt;<p>  end display;</p><p>  architecture Behavioral of display is</p><p>  signal Data0_se,Data1_se,Data2_se: std_logic_vector(3 downto 0); --直接掉 設(shè)置 顯示的,每一位的BCD嗎</p><p> 

66、 signal Data0_ce,Data1_ce,Data2_ce: std_logic_vector(3 downto 0); --直接掉 設(shè)置 顯示的,每一位的BCD嗎</p><p>  signal clk_scan : std_logic ;--位碼掃描時鐘</p><p>  signal dispcnt : std_logic_vector(5

67、downto 0);--每一位的顯示掃描</p><p>  signal dis_data : integer range 0 to 17;--直接調(diào)用用于顯示的斷碼</p><p>  signal key_reg: std_logic_vector(3 downto 0); --直接掉顯示的,每一位的BCD嗎</p><p>  type pr

68、ocess_state is (st0,st1,st2);--測試顯示 十進制轉(zhuǎn)BCD碼信號狀態(tài)定義</p><p>  signal current_state : process_state;</p><p>  type process_state_se is (st0_se,st1_se,st2_se);--設(shè)置顯示 十進制轉(zhuǎn)BCD碼信號狀態(tài)定義</p><

69、p>  signal current_state_se : process_state_se;</p><p>  signal clk100hz :std_logic;</p><p>  signal switch: std_logic:='0';</p><p>  signal se : integer range 0

70、to 400:=0;--設(shè)置數(shù)據(jù)</p><p>  signal ce : integer range 0 to 400:=0;--設(shè)置數(shù)據(jù)</p><p>  signal data_in_se: std_logic_vector(11 downto 0);--設(shè)定 的 BCD碼 </p><p>  signal data_in_ce

71、_r: std_logic_vector(11 downto 0);--測試 的 BCD碼 </p><p>  signal zhuan1:std_logic;</p><p>  signal pw : integer range 0 to 100000:=0;--設(shè)置數(shù)據(jù)</p><p>  --調(diào)用按鍵程序---------------

72、-------------------------------------------------------</p><p>  component Key_Control</p><p><b>  port(</b></p><p>  CLK : in std_logic;--100MHZ</p><p>  

73、RESET : in std_logic;--CPU RESET </p><p>  KEYIN : in std_logic_vector(3 downto 0);--輸入按鍵</p><p>  KEYOUT : out std_logic_vector(3 downto 0)--按鍵輸出指示</p><p><b>  );</b>&

74、lt;/p><p>  end component;</p><p><b>  begin</b></p><p>  u1: Key_Control port map(</p><p><b>  CLK=>CLK,</b></p><p>  RESET=>R

75、ESET,</p><p>  KEYIN=>keyin,</p><p>  KEYout(0)=>key_reg(0),</p><p>  KEYout(1)=>key_reg(1),</p><p>  KEYout(2)=>key_reg(2),</p><p>  KEYout(3)

76、=>key_reg(3)</p><p><b>  );</b></p><p>  ---------------------------------------------------------------------------------------</p><p><b>  --分頻 按鍵延時</b>

77、</p><p>  process(clk)</p><p>  variable count:integer range 0 to 500000;</p><p><b>  begin</b></p><p>  if RESET='0' then count:=0;clk100hz<=

78、9;0';</p><p>  elsif rising_edge(CLK) then </p><p>  if count=500000-4 then </p><p>  count:=0;clk100hz<=not clk100hz;</p><p>  else count:=count+1;</p>&

79、lt;p><b>  end if;</b></p><p><b>  end if; </b></p><p>  end process;</p><p>  -- 啟動 停止 按鍵 狀態(tài)</p><p>  process(key_reg(0),key_reg(1),clk100h

80、z,clk)</p><p><b>  begin</b></p><p>  if rising_edge(clk) then </p><p>  if key_reg(0)='1' then switch<='1';--啟動 信號 </p><p>  e

81、lsif key_reg(1)='1' then switch<='0';--pwm_out<='0';--停止 信號</p><p><b>  end if;</b></p><p><b>  end if;</b></p><p>  end proce

82、ss;</p><p><b>  --設(shè)置 按鍵</b></p><p>  process(key_reg(2),key_reg(3),clk100hz,clk)</p><p><b>  begin</b></p><p>  if rising_edge(clk) then </p

83、><p>  if key_reg(2)='1' then</p><p>  if rising_edge (clk100hz) then--按鍵延時時鐘 防止10hz 高電平多加</p><p>  if se=400 then se<=0; --增加 設(shè)定 壓強</p><p>  else se<=se+5;

84、</p><p><b>  end if;</b></p><p><b>  end if;</b></p><p>  elsif key_reg(3)='1' then </p><p>  if rising_edge (clk100hz) then</p>

85、<p>  if se=0 then se<=400; --減小 設(shè)定 壓強</p><p>  else se<=se-10;</p><p><b>  end if;</b></p><p><b>  end if;</b></p><p><b>  end

86、 if;</b></p><p><b>  end if;</b></p><p>  end process;</p><p><b>  --顯示調(diào)換信號</b></p><p>  process(data_in_ce,clk,zhuan1,pw)</p><

87、p>  variable count : integer range 0 to 100000:=0;</p><p>  variable count1 : integer range 0 to 100000:=0;</p><p><b>  begin</b></p><p>  if rising_edge(clk) then--C

88、ONV_INTEGER(data_in_ce)</p><p>  if rising_edge(CLK) then</p><p>  if count1>=10 then </p><p>  count1:=0;</p><p>  zhuan1<=not zhuan1;</p><p><b&

89、gt;  pw<=pw+1;</b></p><p>  if pw>=1500 then pw<=0; end if;</p><p><b>  else </b></p><p>  count1:=count1+1;</p><p><b>  end if;</b&

90、gt;</p><p><b>  end if;</b></p><p>  if switch='1' then ce<=CONV_INTEGER(data_in_ce);--將輸入的 二進制 強制轉(zhuǎn)換 為 十進制--mode<='0';--or data_in<wen_out</p><

91、;p>  if ren='1' then --人體紅外 控制 (有人)</p><p>  if (ce>=10 and ce<=se) then </p><p>  if pw<100 then</p><p>  pwm_out<='1';</p><p>  e

92、lsif pw>=100 then--低電平時間為100</p><p>  pwm_out<='0';</p><p><b>  end if;</b></p><p><b>  end if;</b></p><p>  if (ce>50 and ce&l

93、t;=se) then </p><p>  if pw<500 then</p><p>  pwm_out<='1';</p><p>  elsif pw>=500 then--低電平時間為100</p><p>  pwm_out<='0';</p><p&

94、gt;<b>  end if;</b></p><p><b>  end if;</b></p><p>  if (ce>100 and ce<=se) then </p><p>  if pw<1000 then</p><p>  pwm_out<='1

95、';</p><p>  elsif pw>=1000 then--低電平時間為100</p><p>  pwm_out<='0';</p><p><b>  end if;</b></p><p><b>  end if;</b></p>&

96、lt;p>  else pwm_out<='1';--人體紅外 控制 (無人)</p><p><b>  end if;</b></p><p>  elsif switch='0' then </p><p>  ce<=0;--將輸入的 二進制 強制轉(zhuǎn)換 為 十進制--mode

97、<='1';--or data_in>wen_out</p><p>  pwm_out<='1';</p><p><b>  end if;</b></p><p><b>  end if;</b></p><p>  end process;

98、</p><p>  --設(shè)定顯示 十進制-BCD碼轉(zhuǎn)換_;</p><p>  process(CLK,RESET)</p><p>  variable d0 : std_logic_vector(3 downto 0);</p><p>  variable d1 : std_logic_vector(3 downto 0);<

99、/p><p>  variable d2 : std_logic_vector(3 downto 0);</p><p>  variable memory_data:integer range 0 to 10000;</p><p><b>  begin</b></p><p>  if RESET='0'

100、; then d0:="0000";d1:="0000";d2:="0000";current_state_se<=st0_se;</p><p>  elsif rising_edge(CLK) then</p><p>  case current_state_se is</p><p>  w

101、hen st0_se => memory_data:=se;--將要轉(zhuǎn)換的 十進制數(shù)</p><p>  d0:="0000";</p><p>  d1:="0000";</p><p>  d2:="0000";</p><p>  current_state_se<

102、=st1_se;</p><p>  when st1_se => if memory_data >99 then</p><p>  memory_data:= memory_data-100;</p><p><b>  d2:=d2+1;</b></p><p>  elsif memory_data

103、> 9 then</p><p>  memory_data:= memory_data-10;</p><p><b>  d1:=d1+1;</b></p><p>  else d0:= CONV_STD_LOGIC_VECTOR(memory_data,4);</p><p>  current_state

104、_se<=st2_se; </p><p><b>  end if;</b></p><p>  when st2_se => data_in_se<=d2&d1&d0;</p><p>  current_state_se<=st0_se;</p><p>  when ot

105、hers => current_state_se<=st0_se;</p><p><b>  end case;</b></p><p><b>  end if;</b></p><p>  end process;</p><p>  --測試顯示 十進制-BCD碼轉(zhuǎn)

106、換_;</p><p>  process(CLK,RESET)</p><p>  variable d0 : std_logic_vector(3 downto 0);</p><p>  variable d1 : std_logic_vector(3 downto 0);</p><p>  variable d2 : std_log

107、ic_vector(3 downto 0);</p><p>  variable memory_data:integer range 0 to 10000;</p><p><b>  begin</b></p><p>  if RESET='0' then d0:="0000";d1:="00

108、00";d2:="0000";current_state<=st0;</p><p>  elsif rising_edge(CLK) then</p><p>  case current_state is</p><p>  when st0 => memory_data:=ce;--將要轉(zhuǎn)換的 十進制數(shù)</p&

109、gt;<p>  d0:="0000";</p><p>  d1:="0000";</p><p>  d2:="0000";</p><p>  current_state<=st1;</p><p>  when st1 => if memory_da

110、ta >99 then</p><p>  memory_data:= memory_data-100;</p><p><b>  d2:=d2+1;</b></p><p>  elsif memory_data > 9 then</p><p>  memory_data:= memory_data-1

111、0;</p><p><b>  d1:=d1+1;</b></p><p>  else d0:= CONV_STD_LOGIC_VECTOR(memory_data,4);</p><p>  current_state<=st2; </p><p><b>  end if;</b>&l

112、t;/p><p>  when st2 => data_in_ce_r<=d2&d1&d0;</p><p>  current_state<=st0;</p><p>  when others => current_state<=st0;</p><p><b>  end

113、 case;</b></p><p><b>  end if;</b></p><p>  end process;</p><p>  --將整理后的數(shù)據(jù)送到顯示</p><p>  process(CLK,RESET,Data2_se,Data1_se,Data0_se,Data2_ce,Data1_c

114、e,Data0_ce)</p><p><b>  begin</b></p><p>  if rising_edge(CLK) then</p><p>  Data2_se<= data_in_se(11 downto 8);</p><p>  Data1_se<= data_in_se(7

115、downto 4);</p><p>  Data0_se<= "0000";--data_in_se(3 downto 0);</p><p>  Data2_ce<= data_in_ce_r(11 downto 8);</p><p>  Data1_ce<= data_in_ce_r(7 downto 4);<

116、/p><p>  Data0_ce<= data_in_ce_r(3 downto 0);</p><p><b>  end if;</b></p><p>  end process;</p><p>  --為位碼掃描 時間</p><p>  process(CLK,RE

117、SET) </p><p>  variable count : integer range 0 to 100000:=0;</p><p><b>  begin</b></p><p>  if RESET='0' then null;</p><p>  elsif rising_edge(CLK)

118、 then</p><p>  if count>=20000 then </p><p><b>  count:=0;</b></p><p>  clk_scan<=not clk_scan;</p><p><b>  else </b></p><p>

119、  count:=count+1;</p><p><b>  end if;</b></p><p><b>  end if;</b></p><p>  end process;</p><p><b>  --位碼掃描控制</b></p><p>

120、;  process(clk_scan,RESET) </p><p><b>  begin</b></p><p>  if RESET='0' then null;</p><p>  elsif rising_edge(clk_scan) then</p><p>  if dispcnt = &

121、quot;100000" then</p><p>  dispcnt <= "000000";</p><p><b>  else </b></p><p>  dispcnt<=dispcnt+1;</p><p><b>  end if;</b>

122、</p><p><b>  end if;</b></p><p>  end process;</p><p><b>  --顯示控制</b></p><p>  process(dispcnt,RESET)</p><p><b>  begin</

123、b></p><p>  if RESET='0' then </p><p>  BIT8<="11111111";</p><p><b>  else</b></p><p>  case dispcnt is</p><p>  when &

124、quot;000001" =>dis_data<=CONV_INTEGER(Data2_se); BIT8<="01111111";DOT<='1';</p><p>  when "000010" =>dis_data<=CONV_INTEGER(Data1_se);BIT8<="101

125、11111";DOT<='1'; </p><p>  when "000011" =>dis_data<=CONV_INTEGER(Data0_se); BIT8<="11011111";DOT<='1'; </p><p>  when "000100"

126、; =>dis_data<=15; BIT8<="11101111";DOT<='1';--P </p><p>  when "000101" =>dis_data<=CONV_INTEGER(Data2_ce); BIT8<="11110111";DOT<=

127、9;1';</p><p>  when "000110" =>dis_data<=CONV_INTEGER(Data1_ce);BIT8<="11111011";DOT<='1'; </p><p>  when "000111" =>dis_data<=CONV_

128、INTEGER(Data0_ce); BIT8<="11111101";DOT<='1'; </p><p>  when "001000" =>dis_data<=15; BIT8<="11111110";DOT<='1';--P </p>

129、<p>  when others =>dis_data<=17; BIT8<="11111110";DOT<='1';--空 不顯示</p><p><b>  end case;</b></p><p><b>  end if;</b>&l

溫馨提示

  • 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)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
  • 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論