

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
1、<p><b> 目錄</b></p><p> 1、引言.......................................................................................... 2</p><p> 2、方案設計及工作原理 ...............................
2、............................. 2</p><p> 2.1 方案設計及論證 ............................................................. 2</p><p> 2.2 工作原理 .....................................................
3、.................... 3</p><p> 2.2.1DS18B20工作原理................................................... 3</p><p> 2.2.2 LCD工作原理 ....................................................... 5<
4、;/p><p> 3、各功能模塊設計和仿真.......................................................... 8</p><p> 3.1 DS18B20溫度傳感器電路 ............................................. 8</p><p> 3.2時鐘及顯示控制
5、電路........................................................ 11</p><p> 3.3LCD顯示的實現電路........................................................ 12</p><p> 4、結果分析和調試..........................
6、............................................ 13</p><p> 5、體會.......................................................................................... 14</p><p> 6、參考文獻..................
7、................................................................ 14</p><p> 7、附錄........................................................................................... 15</p><p> 7.1
8、仿真圖................................................................................. 15</p><p> 7.2實物圖................................................................................. 16</p>&l
9、t;p> 7.3 DS18B20控制程序及LED數碼管顯示程序代碼........... 16</p><p> 7.4時鐘控制程序...................................................................... 21</p><p> 7.5 LCD顯示驅動程序 .....................
10、...................................... 23</p><p> 1—Wire數字溫度的測量及LCD顯示</p><p><b> 摘要:</b></p><p> 根據我們所學過的電子技術、EDA術、電子測量和計算機技術等知識設計具有一定功能和規(guī)模的數字信號處理、電子設備系統(tǒng)項目。完成該項目的方
11、案設計、硬件電路設計、應用軟件系統(tǒng)設計及系統(tǒng)調試。主要是利用EDA/SOPC實驗開發(fā)工具,設計DS18B20測量LCD顯示和其它控制系統(tǒng),并進行演示。</p><p> 關鍵詞:EDA,溫度傳感器,ds18b20,時序,lcd1602</p><p><b> 一、引言:</b></p><p> 隨著人們生活水平的不斷提高, EDA技術
12、無疑是人們追求的目標之一,它所給人帶來的方便也是不可否定的,其中數字溫度計就是一個典型的例子,但人們對它的要求越來越高,要為現代人工作、科研、生活、提供更好的更方便的設施就需要從EDA技術入手,一切向著數字化控制,智能化控制方向發(fā)展。</p><p> 本設計所介紹的數字溫度計與傳統(tǒng)的溫度計相比,具有讀數方便,測溫范圍廣,測溫準確,其輸出溫度采用數字顯示,該設計控制器使用EDA技術,測溫傳感器使用DS18B20
13、,用LCD實現溫度顯示,能準確達到以上要求。</p><p> 隨著時代的進步和發(fā)展,EDA技術已經普及到我們生活,工作,科研,各個領域,已經成為一種比較成熟的技術,本文將介紹一種基于EDA技術的數字溫度計,本溫度計屬于多功能溫度計,可以設置上下報警溫度,當溫度不在設置范圍內時,可以報警。二、方案設計及工作原理:</p><p><b> 1、方案設計論證:</b>
14、;</p><p><b> 方案一:</b></p><p> 用溫度傳感器測量溫度,使用51單片機作為主芯片控制及顯示。在電路設計中,溫度測量大多都是使用傳感器,所以這是非常容易想到的,可以采用一只溫度傳感器DS18B20,此傳感器,可以很容易直接讀取被測溫度值,進行轉換,使用89C51單片機處理傳輸的信號進行控制及顯示,就可以滿足設計要求。</p>
15、;<p><b> 方案二:</b></p><p> 基于FPGA溫度測量及顯示,使用EP1C12實驗開發(fā)板以實現所要求的溫度測量及顯示功能。EP1C12實驗開發(fā)板,其EDA開發(fā)平臺上自帶DS18B20溫度傳感器和LCD1602顯示和LED數碼管顯示,使用QuartusII軟件和VHDL語言編程即可實現設計所要求功能。</p><p> 從以上兩
16、種方案,很容易看出,采用方案二,電路在開發(fā)板上實現比較簡單,軟件設計也比較簡單,故采用了方案二。</p><p><b> 2、工作原理:</b></p><p> 1、DS18B20工作原理</p><p> DS18B20溫度傳感器是美國DALLAS半導體公司最新推出的一種改進型智能溫度傳感器,與傳統(tǒng)的熱敏電阻等測溫元件相比,它能直
17、接讀出被測溫度,并且可根據實際要求通過簡單的編程實現9~12位的數字值讀數方式。 TO-92封裝的DS18B20的引腳排列見下圖,其引腳功能描述見表1。</p><p><b> (底視圖)</b></p><p> 圖1 DS18B20</p><p> 表1 DS18B20詳細引腳功能描述</p><p>
18、 DS18B20采用3腳PR-35封裝或8腳SOIC封裝,其內部結構框圖如圖2所示。 </p><p> 圖2 DS18B20內部結構</p><p> 64位ROM的結構開始8位是產品類型的編號,接著是每個器件的惟一的序號,共有48位,最后8位是前面56位的CRC檢驗碼,這也是多個DS18B20可以采用一線進行通信的原因。溫度報警觸發(fā)器TH和TL,
19、可通過軟件寫入戶報警上下限。</p><p> DS18B20溫度傳感器的內部存儲器還包括一個高速暫存RAM和一個非易失性的可電擦除的EERAM。高速暫存RAM的結構為8字節(jié)的存儲器,結構如圖3所示。頭2個字節(jié)包含測得的溫度信息,第3和第4字節(jié)TH和TL的拷貝,是易失的,每次上電復位時被刷新。第5個字節(jié),為配置寄存器,它的內容用于確定溫度值的數字轉換分辨率。DS18B20工作時寄存器中的分辨率轉換為相應精度的溫
20、度數值。該字節(jié)各位的定義如圖3所示。低5位一直為1,TM是工作模式位,用于設置DS18B20在工作模式還是在測試模式,DS18B20出廠時該位被設置為0,用戶要去改動,R1和R0決定溫度轉換的精度位數,來設置分辨率。</p><p> 圖3 DS18B20字節(jié)定義</p><p> 由表1可見,DS18B20溫度轉換的時間比較長,而且分辨率越高,所需要的溫度數據轉換時間越長。因此,在
21、實際應用中要將分辨率和轉換時間權衡考慮。</p><p> 表1 DS18B20溫度轉換時間表</p><p> 高速暫存RAM的第6、7、8字節(jié)保留未用,表現為全邏輯1。第9字節(jié)讀出前面所有8字節(jié)的CRC碼,可用來檢驗數據,從而保證通信數據的正確性。</p><p> 當DS18B20接收到溫度轉換命令后,開始啟動轉換。轉換完成后的溫度值就以16位帶符號擴展
22、的二進制補碼形式存儲在高速暫存存儲器的第1、2字節(jié)。單片機可以通過單線接口讀出該數據,讀數據時低位在先,高位在后,數據格式以0.0625℃/LSB形式表示。</p><p> 當符號位S=0時,表示測得的溫度值為正值,可以直接將二進制位轉換為十進制;當符號位S=1時,表示測得的溫度值為負值,要先將補碼變成原碼,再計算十進制數值。表2是一部分溫度值對應的二進制溫度數據。</p><p>
23、 DS18B20完成溫度轉換后,就把測得的溫度值與RAM中的TH、TL字節(jié)內容作比較。若T>TH或T<TL,則將該器件內的報警標志位置位,并對主機發(fā)出的報警搜索命令作出響應。因此,可用多只DS18B20同時測量溫度并進行報警搜索。</p><p> 在64位ROM的最高有效字節(jié)中存儲有循環(huán)冗余檢驗碼(CRC)。主機ROM的前56位來計算CRC值,并和存入DS18B20的CRC值作比較,以判斷主機收到的ROM數據
24、是否正確。</p><p> DS18B20的測溫原理是這這樣的,器件中低溫度系數晶振的振蕩頻率受溫度的影響很小,用于產生固定頻率的脈沖信號送給減法計數器1;高溫度系數晶振隨溫度變化其振蕩頻率明顯改變,所產生的信號作為減法計數器2的脈沖輸入。器件中還有一個計數門,當計數門打開時,DS18B20就對低溫度系數振蕩器產生的時鐘脈沖進行計數進而完成溫度測量。計數門的開啟時間由高溫度系數振蕩器來決定,每次測量前,首先將
25、-55℃所對應的一個基數分別置入減法計數器1、溫度寄存器中,計數器1和溫度寄存器被預置在-55℃所對應的一個基數值。</p><p> 減法計數器1對低溫度系數晶振產生的脈沖信號進行減法計數,當減法計數器1的預置值減到0時,溫度寄存器的值將加1,減法計數器1的預置將重新被裝入,減法計數器1重新開始對低溫度系數晶振產生的脈沖信號進行計數,如此循環(huán)直到減法計數器計數到0時,停止溫度寄存器的累加,此時溫度寄存器中的數
26、值就是所測溫度值。其輸出用于修正減法計數器的預置值,只要計數器門仍未關閉就重復上述過程,直到溫度寄存器值大致被測溫度值。</p><p> 另外,由于DS18B20單線通信功能是分時完成的,它有嚴格的時隙概念,因此讀寫時序很重要。系統(tǒng)對DS18B20的各種操作按協(xié)議進行。操作協(xié)議為:初使化DS18B20(發(fā)復位脈沖)→發(fā)ROM功能命令→發(fā)存儲器操作命令→處理數據。</p><p><
27、;b> 2、LCD工作原理</b></p><p> LCD 顯示模塊是一種既簡便又省電的方法。文字型 LCD 顯示模塊已被廣泛的應用于事務機、電子儀表及相關高級產品上。常見文字型LCD 模塊有16字x1行、16字x2行、20字x1行、20字x2行、20字x4行等多種規(guī)格可供選擇。</p><p> EDA開發(fā)平臺配置了文字型 LCD 模塊,其內部是由 LCD 顯示
28、器、LCD 驅動器、LCD 控制器三部份所組成如圖4所示 。目前市售 LCD 模塊其控制方法均相同,LCD 模塊內部所使用的LCD控制器均與HITACHI的HD44780兼容,此背光 LCD 模塊具有16根腳位 ( 不含背光 )。不同廠牌的模塊模塊亦可互換,其應用方式亦均相同。具體的參數請參照此液晶的數據手冊。 </p><p> LCD文字型模塊,每個字符可顯示 5 * 7 或 5 * 10點字圖形,包含標準
29、之 ASCII 碼 ( 含大小寫英文字母、阿拉伯數字及特殊符號等 )。 </p><p> 一、LCD 控制指令及功能:</p><p> 1. 清除顯示( Clear Display ): 將ASCII碼20H填入DDRAM,并設定地址計數AC=0,由標將回至地址00H。</p><p> 2. 游標歸位( Returm Home ): 設定由標地址回歸至0
30、0h,但不清除DDRAM的內容。AC設為0。</p><p> 3. 進入模式( Entry Mode ): </p><p> 設定輸入一個字符后,光標予顯示字符的位移方向。 </p><p> I/D=0,游標向左移,AC減1; </p><p> I/D=1,游標向右移,AC加1; </p><p>
31、SH=0,顯示字符不移動; </p><p> SH=1,I/D=0,顯示字符向左移; </p><p> SH=1,I/D=1,顯示字符向右移;</p><p> 4. 顯示開關控制( Display on/off Control ) 設定顯示器、光標及是否閃爍光標控制</p><p> D=0,顯示器關閉;D=1,顯示器開啟<
32、;/p><p> C=0,光標不顯示;D=1,光標顯示</p><p> B=0,游標不閃爍;D=1,游標閃爍</p><p> 5. 光標及顯示器移動( Cursor or Display Shift ) </p><p> 設定光標或顯示器移動方向(DDRAM內容不變) </p><p> S/C=0,字符不
33、移動; </p><p> R/L=0,游標向左移; </p><p> R/L=1,游標向右移; </p><p> S/C=1,R/L=0,字符及光標向左移;</p><p> S/C=1,R/L=1,字符及光標向右移</p><p> 6. 功能設定( Function Set ) </p>
34、<p> 設定接口位長度(DL)、顯示列數(N)與顯示字符類型(F)功能。</p><p> DL=0,接口位長度8位;DL=1,接口位長度4位; </p><p> N=0,只顯示一列字符;N=1,可顯示兩列字符; </p><p> F=0,顯示5x8字型;F=1,顯示5x11字型;</p><p> 7. 設定C
35、GRAM地址( Set CGRAM Address ) </p><p> 設定CGRAM的地址計數器AC</p><p> 8. 設定DDRAM地址( Set DDRAM Address ) </p><p> 設定DDRAM的地址計數器AC</p><p> 9. 讀取忙碌旗號及地址( Read Busy and Address
36、) </p><p> 設定從CGRAM或DDRAM地址讀取忙碌旗號(BF,Busy Flag)及地址計數器AC的數據。</p><p> 10.內存數據寫入( Write Data to RAM ) </p><p> 將D0-D7的數據寫入CGRAM或DDRAM內部。(依前一筆寫入地址而定)</p><p><b> 二
37、、LCD時序</b></p><p> LCD顯示同樣對時序要求嚴格,其時序主要分為讀時序和寫時序如下圖。</p><p><b> 1、LCD寫時序</b></p><p><b> 2、LCD讀時序</b></p><p> 三、各功能模塊設計和仿真:</p>
38、<p> 1、DS18B20溫度傳感器電路</p><p> DS18B20可以采用兩種方式供電,在這采用電源供電方式,DS18B20的1腳接地,2腳作為信號線,3腳接電源。</p><p> 當DS18B20處于寫存儲器操作和溫度A/D轉換操作時,總線上必須有強的上拉,上拉開啟時間最大為10us。采用寄生電源供電方式時VDD端接地。由于單線制只有一根線,因此發(fā)送接口必須是
39、三態(tài)的。由于DS18B20是在一根I/O線上讀寫數據,因此,對讀寫的數據位有著嚴格的時序要求。DS18B20有嚴格的通信協(xié)議來保證各位數據傳輸的正確性和完整性。該協(xié)議定義了幾種信號的時序:初始化時序、讀時序、寫時序。所有時序都是將主機作為主設備,單總線器件作為從設備。而每一次命令和數據的傳輸都是從主機主動啟動寫時序開始,如果要求單總線器件回送數據,在進行寫命令后,主機需啟動讀時序完成數據接收。數據和命令的傳輸都是低位在先。DS18B20
40、模塊生成如圖5。</p><p> 圖5 DS18B20功能模塊</p><p> 在該模塊中inclk為時鐘輸入端,DQ為ds18b20的數據總線的輸入端,sel[3..0]為數碼管位選輸出端,seg[7..0]為數碼管段選輸出,templlreture[10..0]為當前溫度的輸出端,baojing為報警信號的輸出端。</p><p> 2、DS18B2
41、0的復位時序 </p><p> 3、DS18B20的讀時序</p><p> 對于DS18B20的讀時序分為讀0時序和讀1時序兩個過程。</p><p> 對于DS18B20的讀時隙是從主機把單總線拉低之后,在15秒之內就得釋放單總線,以讓DS18B20把數據傳輸到單總線上。DS18B20在完成一個讀時序過程,至少需要60us才能完成。</p>
42、<p> 4、DS18B20的寫時序</p><p> 對于DS18B20的寫時序仍然分為寫0時序和寫1時序兩個過程。</p><p> 對于DS18B20寫0時序和寫1時序的要求不同,當要寫0時序時,單總線要被拉低至少60us,保證DS18B20能夠在15us到45us之間能夠正確地采樣IO總線上的“0”電平,當要寫1時序時,單總線被拉低之后,在15us之內就得釋放單總
43、線。</p><p> 5、溫度轉換命令子程序</p><p> 溫度轉換命令子程序主要是發(fā)溫度轉換開始命令,當采用12位分辨率時轉換時間約為750ms,在本程序設計中采用1s顯示程序延時法等待轉換的完成。溫度轉換命令子程序流程圖如上圖,圖9所示,具體程序見附錄。</p><p> 圖9 溫度轉換流程圖 圖10 計算溫度流程圖&
44、lt;/p><p><b> 6、計算溫度子程序</b></p><p> 計算溫度子程序將RAM中讀取值進行BCD碼的轉換運算,并進行溫度值正負的判定,其程序流程圖如圖10所示。</p><p> 2、時鐘及顯示控制電路</p><p> 多功能數字鐘應該具有的功能有:顯示時-分-秒、整點報時、小時和分鐘可調等基本
45、功能。首先要知道鐘表的工作機理,整個鐘表的工作應該是在1Hz信號的作用下進行,這樣每來一個時鐘信號,秒增加1秒,當秒從59秒跳轉到00秒時,分鐘增加1分,同時當分鐘從59分跳轉到00分時,小時增加1小時,但是需要注意的是,小時的范圍是從0~23時。</p><p> 在實驗中為了顯示的方便,由于分鐘和秒鐘顯示的范圍都是從0~59,所以可以用一個3位的二進制碼顯示十位,用一個四位的二進制碼(BCD碼)顯示個位,對
46、于小時因為它的范圍是從0~23,所以可以用一個2位的二進制碼顯示十位,用4位二進制碼(BCD碼)顯示個位。</p><p> 開發(fā)板提供50Mhz的時鐘頻率,而時鐘需要的是1Hz時鐘信號,因此為了得到準確的1Hz信號,必須對輸入的系統(tǒng)時鐘進行分頻。其封裝見附件總電路圖的shizhong模塊。</p><p> 3、LCD顯示的實現電路</p><p> 1、L
47、CD顯示電路組成</p><p> LCD顯示包括時鐘分頻(圖6)、和LCD控制(圖7)模塊。</p><p> 其中時鐘分頻顧名思義是對整個LCD顯示提供頻率脈沖,計數器對LCD控制器控制,LCD控制模塊實現對LCD的初始化,指令寫入及內容的編碼顯示。</p><p> LCD顯示控制模塊,其中M[5..0]為計數器位數輸入端,clk1為時鐘輸入端,s1[1
48、0..0]為溫度數據輸入端,h1[3..0]和h10[3..0]分別為時鐘的小時的個位和十位輸入端,m1[3..0]和m10[3..0]分別為時鐘的分的個位和十位輸入端,se1[3..0]和se10[3..0]分別為時鐘的秒的個位和十位輸入端,D0~D7為輸出端作為8位二進制碼傳輸給LCD,rs為LCD的數據或命令的選擇端。</p><p><b> 2、LCD程序設計</b></p
49、><p><b> 流程圖如圖8</b></p><p> 部分命令設置程序(具體程序見附錄LCD顯示驅動程序)</p><p> when 0 => Q <=x"01"; RS<='0';-- 清屏</p><p> when 1 => Q <=
50、x"38"; RS<='0';--工作方式設置(初始化)</p><p> when 2 => Q <=x"06"; RS<='0';--輸入方式設置</p><p> when 3 => Q <=X"0f"; RS<='0';--顯
51、示開關控制(設置顯示、光標及閃爍開、關) when 7 => Q <=x"40"; RS<='0'; -- CGRAM</p><p><b> ......</b></p><p> when 36 => Q <=x"c0"; RS<='0';
52、--SECOND Row" li gong da xue ! " </p><p><b> ......</b></p><p> when 16 => Q <=x"80"; RS<='0'; -- FIRST Row</p><p> ...... &
53、lt;/p><p> when 55 => Q <=x"0c"; RS<='0'; </p><p> when others => Q <=x"A0"; RS<='1';</p><p><b> 圖8 程序流程圖</b><
54、/p><p> 四、結果分析及調試:</p><p> 本次課程設計在達到設計基本功能的同時,還加入了其他多項輔助功能,使設計項目更加人性化、更加完善。主要功能有DS18B20溫度讀取LED數碼管顯示、LCD1602溫度顯示、LCD1602當前時間顯示和時間調接以及溫度設定報警等功能。在整個設計調試過程中,也出現了一些錯誤和難關,但經過小組的探討,查閱相關資料以及詢問指導老師等方法,最終還
55、是逐步的解決了所遇到的問題。在下面列舉幾個主要的問題。</p><p> 首先遇到的第一個問題就是LED數碼管的編碼轉換上出現了錯誤。在DS18B20中傳輸出來的溫度數據是兩字節(jié)的二進制數據,在將溫度數值轉換成驅動LED顯示的八位二進制數時,沒有注意開發(fā)板上的數碼管是共陰極還是共陽極,顯示出錯。編碼取反后恢復正常。</p><p> 第二是LCD顯示時顯示亂碼,在編程時開始是在LCD驅
56、動外部編碼然后傳輸進入LCD驅動,驅動內部直接讀取編好后傳輸過來的兩位十六進制數,但LCD顯示出錯,顯示為亂碼,出錯原因可能是編碼傳輸和顯示時間不夠等等。最后將編碼轉換程序放入LCD顯示驅動中,將DS18B20讀取的兩字節(jié)數據,直接傳輸入驅動中再進行碼字轉換成LCD顯示所需的數碼。</p><p> 在設計中還有很多小問題,比如說計數器位數不夠,LCD顯示出現延遲等等??傮w來說,所遇到的問題都得到了有效地解決,
57、有的是原有基礎上找出錯誤修改,有的是換一種方法實現,解決問題實現目標方法多種多樣,但只要目的達到都是一種成功。</p><p><b> 五、體會:</b></p><p> 經過為期三周的時間的課程設計,掌握了電子技術、EDA技術、電子測量和計算機接口等綜合性應用技術;熟悉控制系統(tǒng)、嵌入式系統(tǒng)和可編程片上系統(tǒng)的設計方法;能設計出具有一定功能和規(guī)模的電子應用電路。
58、對以后相關工作的設計有了一定的幫助。</p><p><b> 六、參考文獻:</b></p><p> [1] EDA技術 郭勇 高等教育出版社 2004-07出版</p><p> [2] 何賓 EDA原理及應用 清華大學出版社 2009-06出版</p><p> [3] 趙剛 EDA技術簡
59、明教程 四川大學出版社 2004-07出版</p><p> [4] 江國強 EDA技術與應用(第3版) 電子工業(yè)出版社 2010-04出版</p><p> [5] 周立功 EDA實驗與實踐 北京航空航天大學出版社 2007-09出版</p><p> [6] 郭振武、叢紅俠 EDA實驗教程 南開大學出版社 2011-08出版</p>
60、;<p> [7] 潘松、 黃繼EDA技術與VHDL(第3版) 清華大學出版社 2009-09出版</p><p> [8] 羅力凡、 常春藤 基于VHDL的FPGA開發(fā)快速入門?技巧?實例 人民郵電出版社 2009-05出版</p><p> [9] 潘松、黃繼業(yè)、 潘明 EDA技術實用教程:Verilog HDL版(第4版) 科學出版社 2010-07出
61、版</p><p> [10] 譚會生、 張昌凡 EDA技術及應用:Verilog HDL版(第3版) 西安電子科技大學出版社 2011-07出版</p><p> [11] 周潤景、 蘇良碧 基于Quartus II的數字系統(tǒng)Verilog HDL設計實例詳解 電子工業(yè)出版社 2010-05出版</p><p><b> 七、附錄:&l
62、t;/b></p><p><b> 1、模塊電路圖</b></p><p><b> 2、實物圖</b></p><p><b> 3、程序清單</b></p><p> 1、DS18B20控制程序及LED數碼管顯示驅動程序代碼</p><p
63、> 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><p> ENTITY BO IS</p&g
64、t;<p><b> PORT(</b></p><p> DQ:inOUT STD_LOGIC; --DS18B20的單數據總線</p><p> --DQ2:IN STD_LOGIC;</p><p> inclk:in std_logic;</p><p> --k1,k2,k3,k4
65、,k5:in std_logic;--</p><p> sel:out std_logic_vector(3 downto 0);--數碼管位選</p><p> seg:out std_logic_vector(7 downto 0);--數碼管段選</p><p> templlreture:out std_logic_vector(10 downto
66、0); --當前溫度</p><p> baojing:out std_logic --報警信號</p><p><b> );</b></p><p><b> END;</b></p><p> ARCHITECTURE bhv OF BO IS</p><p&
67、gt; constant ml1:std_logic_vector(15 downto 0):="0011001100100010"; --命令1,即前一字節(jié)忽略讀DS18B20的ROM 后一字節(jié)開始轉換溫度</p><p> constant ml2:std_logic_vector(15 downto 0):="0011001101111101"; --命令
68、2,前一字節(jié)忽略讀DS18B20的ROM 后一字節(jié)開始讀暫存器</p><p> signal templ1,templ2:std_logic_vector(7 downto 0); --從DS18b20讀出的兩字節(jié)溫度</p><p> signal d,c,b,a:std_logic_vector(7 downto 0);--十進制數后的個位、小數點第一位、第二位對應的數碼管的段數
69、值</p><p> signal var1,var2,var3,var4:integer;--分別對應將二進制數據轉化為十進制數后的個位、小數點第一位、第二位</p><p> signal current_templ:std_logic_vector(10 downto 0); --當前溫度</p><p> signal cur:std_logic_
70、vector(7 downto 0); --當前溫度</p><p> signal ng:std_logic; --負數標志位</p><p> signal clk:std_logic;</p><p> signal count_48:std_logic_vector(4 downto 0);</p><p><b
71、> begin</b></p><p> process(inclk)</p><p><b> begin</b></p><p> if rising_edge(inclk) then</p><p> count_48<=count_48+1;</p><p&g
72、t; if count_48="11000" then</p><p> clk<=not clk;</p><p> count_48<="00000";</p><p><b> end if;</b></p><p><b> end if;&
73、lt;/b></p><p> end process;</p><p> process(clk)</p><p> variable saomiao:std_logic_vector(1 downto 0); --掃描變量</p><p> variable count1:std_logic_vector(10 down
74、to 0); --計數器1,用于DS18B20初始化時計時,以產生時序</p><p> variable count2:std_logic_vector(9 downto 0); --計數器2,用于向DS18B20寫命令時計時,以產生時序</p><p> variable count3:std_logic_vector(7 downto 0); --計數器3,用于向DS
75、18B20讀數據時計時,以產生時序</p><p> variable fenping_saomiao:std_logic_vector(7 downto 0); </p><p> variable i:integer range -1 to 15:=15; --命令比特計數值</p><p> variable init:integer range
76、 0 to 1:=0; --完成初始化標志</p><p> variable j:integer range 0 to 8:=0; --讀溫度時,比特計數值</p><p> variable k:integer range 0 to 1:=0; --用于指示讀取哪個溫度值</p><p> variable state:integer ran
77、ge 0 to 2:=0; --狀態(tài)標志,0時寫命令1,1時寫命令2,2時讀取溫度</p><p> variable templ:std_logic_vector(7 downto 0);</p><p><b> begin</b></p><p> if rising_edge(clk) then</p><
78、p> fenping_saomiao:=fenping_saomiao+1;</p><p> if fenping_saomiao="11111111" then</p><p> saomiao:=saomiao+1; --掃描</p><p> case saomiao is --對數碼管進行位掃描</p>
79、<p> when "00"=>sel<="0001";seg<=a; --注意數碼管的位選信號是低電平有效</p><p> when "01"=>sel<="0010";seg<=b;</p><p> when "10"=&g
80、t;sel<="0011";seg<=c;</p><p> when "11"=>sel<="0100";seg<=d;</p><p> when others=>sel<="0000";</p><p><b> end c
81、ase;</b></p><p><b> end if;</b></p><p> if state=0 then</p><p> if init=1 then --若初始化完成,開始寫命令1</p><p> count2:=count2+1;</p><p> i
82、f count2="0000000001" then --將總線拉低</p><p><b> DQ<='0';</b></p><p> elsif count2="0000001100" then --在15us內向總線寫一比特數值</p><p> DQ<=
83、ml1(i);</p><p> elsif count2="0001011010" then --在寫時序的15us~60us內,DS18B20對總線采樣,所以取90us</p><p><b> DQ<='1';</b></p><p> elsif count2="101011
84、0100" then --在大于1us之后,總線拉低,產生下一寫時序</p><p> --DQ<='0';</p><p> count2:="0000000000"; --計數器歸零</p><p> i:=i-1; --寫下1比特命令</p><p> if i=-
85、1 then --寫完命令,命令計數值歸零,初始化標志歸零,以產生下次初始化,狀態(tài)轉為1,即將寫命令2</p><p> i:=15;init:=0;state:=1;</p><p><b> end if;</b></p><p><b> end if;</b></p><p>
86、 else --init=0時進行初始化</p><p> count1:=count1+1;</p><p> if count1="000000000001" then</p><p><b> DQ<='1';</b></p><p> elsif count1
87、="000000000011" then --拉低</p><p><b> DQ<='0';</b></p><p> elsif count1="01010111100" then --初始化時要求,低電平至少保持480us,這里取500us</p><p><
88、b> DQ<='1';</b></p><p> elsif count1="01011011010" then --要求15us~60us,拉高,這里取30us(530),再釋放總線,以讓DS18B20發(fā)出存在脈沖</p><p><b> DQ<='Z';</b></
89、p><p> elsif count1="01111001010" then --存在脈沖為60us~240us,830,再拉高</p><p><b> DQ<='1';</b></p><p> elsif count1="10000000000" then --整個時
90、序要求960us,這里取1024us</p><p> init:=1;count1:="00000000000"; --總線拉低(也可以不拉低),初始化標志置1,即下次不進行初始化,計數器歸零</p><p><b> end if;</b></p><p><b> end if;</b>
91、</p><p> elsif state=1 then --state=1,寫命令2</p><p> if init=1 then</p><p> count2:=count2+1;</p><p> if count2="0000000001" then</p><p><
92、b> DQ<='0';</b></p><p> elsif count2="0000001100" then</p><p> DQ<=ml2(i);</p><p> elsif count2="0001011010" then</p><p>
93、<b> DQ<='1';</b></p><p> elsif count2="0001011100" then</p><p> count2:="0000000000";</p><p><b> i:=i-1;</b></p>&l
94、t;p> if i=-1 then</p><p> i:=15;init:=0;state:=2;</p><p><b> end if;</b></p><p><b> end if;</b></p><p><b> else</b></p>
95、;<p> count1:=count1+1;</p><p> if count1="000000000001" then</p><p><b> DQ<='1';</b></p><p> elsif count1="000000000011" then
96、 --拉低</p><p><b> DQ<='0';</b></p><p> elsif count1="01010111100" then --初始化時要求,低電平至少保持480us,這里取500us</p><p><b> DQ<='1';</
97、b></p><p> elsif count1="01011011010" then --要求15us~60us,拉高,這里取30us(530),再釋放總線,以讓DS18B20發(fā)出存在脈沖</p><p><b> DQ<='Z';</b></p><p> elsif count1=
98、"01111001010" then --存在脈沖為60us~240us,830,再拉高</p><p><b> DQ<='1';</b></p><p> elsif count1="10000000000" then --整個時序要求960us,這里取1024us</p>&
99、lt;p> init:=1;count1:="00000000000"; --總線拉低(也可以不拉低),初始化標志置1,即下次不進行初始化,計數器歸零</p><p><b> end if;</b></p><p><b> end if;</b></p><p> else
100、--state=2,讀取溫度</p><p> if k=0 then --k=0,讀取第一字節(jié)溫度(低字節(jié))</p><p> count3:=count3+1;</p><p> if count3="00000001" then</p><p><b> DQ<='0';&
101、lt;/b></p><p> elsif count3="00000100" then --低電平至少1us,在釋放總線</p><p><b> DQ<='Z';</b></p><p> elsif count3="00001101" then --要求在1
102、5us內讀取溫度</p><p> templ(j):=DQ;</p><p> elsif count3="01010000" then --讀時序至少60us,這里取80us</p><p><b> DQ<='1';</b></p><p> elsif cou
103、nt3="01010010" then --計數器歸零</p><p> count3:="00000000";</p><p> j:=j+1; --讀取下一比特</p><p> if j=8 then --讀取完</p><p> j:=0; --歸0</p>
104、<p> k:=1; --讀第2字節(jié)</p><p> templ1<=templ;</p><p><b> end if;</b></p><p><b> end if;</b></p><p> else --k=1 讀第2字節(jié)</p>&l
105、t;p> count3:=count3+1;</p><p> if count3="00000001" then</p><p><b> DQ<='0';</b></p><p> elsif count3="00000100" then</p>&l
106、t;p><b> DQ<='Z';</b></p><p> elsif count3="00001101" then</p><p> templ(j):=DQ;</p><p> elsif count3="01010000" then</p><
107、;p><b> DQ<='1';</b></p><p> elsif count3="01010010" then</p><p> count3:="00000000";</p><p><b> j:=j+1;</b></p>
108、<p> if j=8 then</p><p><b> j:=0;</b></p><p><b> k:=0;</b></p><p> state:=0; --狀態(tài)標志歸零,進入下次大循環(huán)</p><p> if (templ and "11111000&q
109、uot;)="11111000" then --如果溫度是負數則需要轉換下</p><p> templ:=(not templ);</p><p> templ1<=(not templ1)+1;</p><p> if templ1="0000000" then </p><p>
110、 templ:=templ+1;</p><p><b> end if;</b></p><p> ng<='1'; --負溫度標志</p><p><b> else</b></p><p><b> ng<='0';</b
111、></p><p><b> end if;</b></p><p> current_templ<=templ(2 downto 0) & templ1; --溫度值是templ_value2的低5位和templ_value1</p><p><b> end if;</b></p&g
112、t;<p><b> end if;</b></p><p><b> end if;</b></p><p><b> end if;</b></p><p><b> end if;</b></p><p> end proce
113、ss;</p><p> --process()</p><p> --end process;</p><p> process(current_templ)</p><p><b> begin</b></p><p> if CONV_INTEGER(current_templ)/
114、16>20 then --如果溫度大于25度,報警</p><p> baojing<='1';</p><p><b> else</b></p><p> baojing<='0';</p><p><b> end if;</b>&
115、lt;/p><p> templlreture<=current_templ; </p><p> if ng='1' then</p><p> d<="01000000"; --負號</p><p> var3<=CONV_INTEGER(current_templ)/160
116、rem 10; --十位</p><p> var2<=CONV_INTEGER(current_templ)/16 rem 10; --個位</p><p> var1<=CONV_INTEGER(current_templ)*10/16 rem 10; --小數點后一位</p><p><b> else</b>
117、;</p><p> var4<=CONV_INTEGER(current_templ)/1600; --百位</p><p> var3<=CONV_INTEGER(current_templ)/160 rem 10; --十位</p><p> var2<=CONV_INTEGER(current_templ)/16 rem 10
118、; --個位</p><p> var1<=CONV_INTEGER(current_templ)*10/16 rem 10; --小數點后一位</p><p><b> end if;</b></p><p> case var4 is--百位</p><p> when 0 => d &l
119、t;= "00000000";--000</p><p> when 1 => d <= "00000110";--100</p><p> when 2 => d <= "01011011";--200</p><p> when 3 => d <= "
120、01001111";--300</p><p> when 4 => d <= "01100110";--400</p><p> when 5 => d <= "01101101";--500</p><p> when 6 => d <= "01111101&q
121、uot;;--600</p><p> when 7 => d <= "00000111";--700</p><p> when 8 => d <= "01111111";--800</p><p> when 9 => d <= "01101111";--900
122、</p><p> when others => d <= "01000000";</p><p><b> end case;</b></p><p> case var3 is--十位</p><p> when 0 => c <= "00111111&q
123、uot;;</p><p> when 1 => c <= "00000110";</p><p> when 2 => c <= "01011011";--2</p><p> when 3 => c <= "01001111";--3</p>
124、<p> when 4 => c <= "01100110";--4</p><p> when 5 => c <= "01101101";--5</p><p> when 6 => c <= "01111101";--6</p><p>
125、; when 7 => c <= "00000111";--7</p><p> when 8 => c <= "01111111";--8</p><p> when 9 => c <= "01101111";--9</p><p> when ot
126、hers => c <= "00000000";</p><p><b> end case;</b></p><p> case var2 is--個位</p><p> when 0 => b <= "10111111";</p><p> wh
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 數字溫度測量系統(tǒng)課程設計論文
- 溫度測量顯示電路課程設計--溫度測量顯示電路設計
- 糧庫溫度測量顯示系統(tǒng)課程設計
- 課程設計---溫度測量顯示電路設計
- 溫度測量及時鐘顯示的課程設計
- 溫度控制課程設計--數字溫度測量系統(tǒng)
- 溫度采集及顯示課程設計
- 溫度采集附顯示課程設計課題論文
- lcd顯示設計單片機課程設計
- 課程設計--帶lcd顯示的定時鬧鐘
- 課程設計--帶lcd顯示的定時鬧鐘
- 數字溫度測量及顯示系統(tǒng).doc
- 電子測量課程設計-計算機串口接收+lcd距離顯示設計
- 畢業(yè)論文-數字顯示lcd屏設計
- 數字溫度測量及顯示系統(tǒng)設計開題報告
- 數字溫度測量及顯示系統(tǒng).doc
- 數字顯示lcd屏設計畢業(yè)論文
- 溫度控制顯示課程設計
- 課程設計--帶LCD顯示的定時鬧鐘.doc
- 液晶顯示屏lcd顯示接口設計課程設計
評論
0/150
提交評論