版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
1、<p><b> 目錄</b></p><p> 1、引言.......................................................................................... 2</p><p> 2、方案設(shè)計及工作原理 ...............................
2、............................. 2</p><p> 2.1 方案設(shè)計及論證 ............................................................. 2</p><p> 2.2 工作原理 .....................................................
3、.................... 3</p><p> 2.2.1DS18B20工作原理................................................... 3</p><p> 2.2.2 LCD工作原理 ....................................................... 5<
4、;/p><p> 3、各功能模塊設(shè)計和仿真.......................................................... 8</p><p> 3.1 DS18B20溫度傳感器電路 ............................................. 8</p><p> 3.2時鐘及顯示控制
5、電路........................................................ 11</p><p> 3.3LCD顯示的實現(xiàn)電路........................................................ 12</p><p> 4、結(jié)果分析和調(diào)試..........................
6、............................................ 13</p><p> 5、體會.......................................................................................... 14</p><p> 6、參考文獻(xiàn)..................
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數(shù)碼管顯示程序代碼........... 16</p><p> 7.4時鐘控制程序...................................................................... 21</p><p> 7.5 LCD顯示驅(qū)動程序 .....................
10、...................................... 23</p><p> 1—Wire數(shù)字溫度的測量及LCD顯示</p><p><b> 摘要:</b></p><p> 根據(jù)我們所學(xué)過的電子技術(shù)、EDA術(shù)、電子測量和計算機技術(shù)等知識設(shè)計具有一定功能和規(guī)模的數(shù)字信號處理、電子設(shè)備系統(tǒng)項目。完成該項目的方
11、案設(shè)計、硬件電路設(shè)計、應(yīng)用軟件系統(tǒng)設(shè)計及系統(tǒng)調(diào)試。主要是利用EDA/SOPC實驗開發(fā)工具,設(shè)計DS18B20測量LCD顯示和其它控制系統(tǒng),并進(jìn)行演示。</p><p> 關(guān)鍵詞:EDA,溫度傳感器,ds18b20,時序,lcd1602</p><p><b> 一、引言:</b></p><p> 隨著人們生活水平的不斷提高, EDA技術(shù)
12、無疑是人們追求的目標(biāo)之一,它所給人帶來的方便也是不可否定的,其中數(shù)字溫度計就是一個典型的例子,但人們對它的要求越來越高,要為現(xiàn)代人工作、科研、生活、提供更好的更方便的設(shè)施就需要從EDA技術(shù)入手,一切向著數(shù)字化控制,智能化控制方向發(fā)展。</p><p> 本設(shè)計所介紹的數(shù)字溫度計與傳統(tǒng)的溫度計相比,具有讀數(shù)方便,測溫范圍廣,測溫準(zhǔn)確,其輸出溫度采用數(shù)字顯示,該設(shè)計控制器使用EDA技術(shù),測溫傳感器使用DS18B20
13、,用LCD實現(xiàn)溫度顯示,能準(zhǔn)確達(dá)到以上要求。</p><p> 隨著時代的進(jìn)步和發(fā)展,EDA技術(shù)已經(jīng)普及到我們生活,工作,科研,各個領(lǐng)域,已經(jīng)成為一種比較成熟的技術(shù),本文將介紹一種基于EDA技術(shù)的數(shù)字溫度計,本溫度計屬于多功能溫度計,可以設(shè)置上下報警溫度,當(dāng)溫度不在設(shè)置范圍內(nèi)時,可以報警。二、方案設(shè)計及工作原理:</p><p><b> 1、方案設(shè)計論證:</b>
14、;</p><p><b> 方案一:</b></p><p> 用溫度傳感器測量溫度,使用51單片機作為主芯片控制及顯示。在電路設(shè)計中,溫度測量大多都是使用傳感器,所以這是非常容易想到的,可以采用一只溫度傳感器DS18B20,此傳感器,可以很容易直接讀取被測溫度值,進(jìn)行轉(zhuǎn)換,使用89C51單片機處理傳輸?shù)男盘栠M(jìn)行控制及顯示,就可以滿足設(shè)計要求。</p>
15、;<p><b> 方案二:</b></p><p> 基于FPGA溫度測量及顯示,使用EP1C12實驗開發(fā)板以實現(xiàn)所要求的溫度測量及顯示功能。EP1C12實驗開發(fā)板,其EDA開發(fā)平臺上自帶DS18B20溫度傳感器和LCD1602顯示和LED數(shù)碼管顯示,使用QuartusII軟件和VHDL語言編程即可實現(xiàn)設(shè)計所要求功能。</p><p> 從以上兩
16、種方案,很容易看出,采用方案二,電路在開發(fā)板上實現(xiàn)比較簡單,軟件設(shè)計也比較簡單,故采用了方案二。</p><p><b> 2、工作原理:</b></p><p> 1、DS18B20工作原理</p><p> DS18B20溫度傳感器是美國DALLAS半導(dǎo)體公司最新推出的一種改進(jìn)型智能溫度傳感器,與傳統(tǒng)的熱敏電阻等測溫元件相比,它能直
17、接讀出被測溫度,并且可根據(jù)實際要求通過簡單的編程實現(xiàn)9~12位的數(shù)字值讀數(shù)方式。 TO-92封裝的DS18B20的引腳排列見下圖,其引腳功能描述見表1。</p><p><b> ?。ǖ滓晥D)</b></p><p> 圖1 DS18B20</p><p> 表1 DS18B20詳細(xì)引腳功能描述</p><p>
18、 DS18B20采用3腳PR-35封裝或8腳SOIC封裝,其內(nèi)部結(jié)構(gòu)框圖如圖2所示。 </p><p> 圖2 DS18B20內(nèi)部結(jié)構(gòu)</p><p> 64位ROM的結(jié)構(gòu)開始8位是產(chǎn)品類型的編號,接著是每個器件的惟一的序號,共有48位,最后8位是前面56位的CRC檢驗碼,這也是多個DS18B20可以采用一線進(jìn)行通信的原因。溫度報警觸發(fā)器TH和TL,
19、可通過軟件寫入戶報警上下限。</p><p> DS18B20溫度傳感器的內(nèi)部存儲器還包括一個高速暫存RAM和一個非易失性的可電擦除的EERAM。高速暫存RAM的結(jié)構(gòu)為8字節(jié)的存儲器,結(jié)構(gòu)如圖3所示。頭2個字節(jié)包含測得的溫度信息,第3和第4字節(jié)TH和TL的拷貝,是易失的,每次上電復(fù)位時被刷新。第5個字節(jié),為配置寄存器,它的內(nèi)容用于確定溫度值的數(shù)字轉(zhuǎn)換分辨率。DS18B20工作時寄存器中的分辨率轉(zhuǎn)換為相應(yīng)精度的溫
20、度數(shù)值。該字節(jié)各位的定義如圖3所示。低5位一直為1,TM是工作模式位,用于設(shè)置DS18B20在工作模式還是在測試模式,DS18B20出廠時該位被設(shè)置為0,用戶要去改動,R1和R0決定溫度轉(zhuǎn)換的精度位數(shù),來設(shè)置分辨率。</p><p> 圖3 DS18B20字節(jié)定義</p><p> 由表1可見,DS18B20溫度轉(zhuǎn)換的時間比較長,而且分辨率越高,所需要的溫度數(shù)據(jù)轉(zhuǎn)換時間越長。因此,在
21、實際應(yīng)用中要將分辨率和轉(zhuǎn)換時間權(quán)衡考慮。</p><p> 表1 DS18B20溫度轉(zhuǎn)換時間表</p><p> 高速暫存RAM的第6、7、8字節(jié)保留未用,表現(xiàn)為全邏輯1。第9字節(jié)讀出前面所有8字節(jié)的CRC碼,可用來檢驗數(shù)據(jù),從而保證通信數(shù)據(jù)的正確性。</p><p> 當(dāng)DS18B20接收到溫度轉(zhuǎn)換命令后,開始啟動轉(zhuǎn)換。轉(zhuǎn)換完成后的溫度值就以16位帶符號擴展
22、的二進(jìn)制補碼形式存儲在高速暫存存儲器的第1、2字節(jié)。單片機可以通過單線接口讀出該數(shù)據(jù),讀數(shù)據(jù)時低位在先,高位在后,數(shù)據(jù)格式以0.0625℃/LSB形式表示。</p><p> 當(dāng)符號位S=0時,表示測得的溫度值為正值,可以直接將二進(jìn)制位轉(zhuǎn)換為十進(jìn)制;當(dāng)符號位S=1時,表示測得的溫度值為負(fù)值,要先將補碼變成原碼,再計算十進(jìn)制數(shù)值。表2是一部分溫度值對應(yīng)的二進(jìn)制溫度數(shù)據(jù)。</p><p>
23、 DS18B20完成溫度轉(zhuǎn)換后,就把測得的溫度值與RAM中的TH、TL字節(jié)內(nèi)容作比較。若T>TH或T<TL,則將該器件內(nèi)的報警標(biāo)志位置位,并對主機發(fā)出的報警搜索命令作出響應(yīng)。因此,可用多只DS18B20同時測量溫度并進(jìn)行報警搜索。</p><p> 在64位ROM的最高有效字節(jié)中存儲有循環(huán)冗余檢驗碼(CRC)。主機ROM的前56位來計算CRC值,并和存入DS18B20的CRC值作比較,以判斷主機收到的ROM數(shù)據(jù)
24、是否正確。</p><p> DS18B20的測溫原理是這這樣的,器件中低溫度系數(shù)晶振的振蕩頻率受溫度的影響很小,用于產(chǎn)生固定頻率的脈沖信號送給減法計數(shù)器1;高溫度系數(shù)晶振隨溫度變化其振蕩頻率明顯改變,所產(chǎn)生的信號作為減法計數(shù)器2的脈沖輸入。器件中還有一個計數(shù)門,當(dāng)計數(shù)門打開時,DS18B20就對低溫度系數(shù)振蕩器產(chǎn)生的時鐘脈沖進(jìn)行計數(shù)進(jìn)而完成溫度測量。計數(shù)門的開啟時間由高溫度系數(shù)振蕩器來決定,每次測量前,首先將
25、-55℃所對應(yīng)的一個基數(shù)分別置入減法計數(shù)器1、溫度寄存器中,計數(shù)器1和溫度寄存器被預(yù)置在-55℃所對應(yīng)的一個基數(shù)值。</p><p> 減法計數(shù)器1對低溫度系數(shù)晶振產(chǎn)生的脈沖信號進(jìn)行減法計數(shù),當(dāng)減法計數(shù)器1的預(yù)置值減到0時,溫度寄存器的值將加1,減法計數(shù)器1的預(yù)置將重新被裝入,減法計數(shù)器1重新開始對低溫度系數(shù)晶振產(chǎn)生的脈沖信號進(jìn)行計數(shù),如此循環(huán)直到減法計數(shù)器計數(shù)到0時,停止溫度寄存器的累加,此時溫度寄存器中的數(shù)
26、值就是所測溫度值。其輸出用于修正減法計數(shù)器的預(yù)置值,只要計數(shù)器門仍未關(guān)閉就重復(fù)上述過程,直到溫度寄存器值大致被測溫度值。</p><p> 另外,由于DS18B20單線通信功能是分時完成的,它有嚴(yán)格的時隙概念,因此讀寫時序很重要。系統(tǒng)對DS18B20的各種操作按協(xié)議進(jìn)行。操作協(xié)議為:初使化DS18B20(發(fā)復(fù)位脈沖)→發(fā)ROM功能命令→發(fā)存儲器操作命令→處理數(shù)據(jù)。</p><p><
27、;b> 2、LCD工作原理</b></p><p> LCD 顯示模塊是一種既簡便又省電的方法。文字型 LCD 顯示模塊已被廣泛的應(yīng)用于事務(wù)機、電子儀表及相關(guān)高級產(chǎn)品上。常見文字型LCD 模塊有16字x1行、16字x2行、20字x1行、20字x2行、20字x4行等多種規(guī)格可供選擇。</p><p> EDA開發(fā)平臺配置了文字型 LCD 模塊,其內(nèi)部是由 LCD 顯示
28、器、LCD 驅(qū)動器、LCD 控制器三部份所組成如圖4所示 。目前市售 LCD 模塊其控制方法均相同,LCD 模塊內(nèi)部所使用的LCD控制器均與HITACHI的HD44780兼容,此背光 LCD 模塊具有16根腳位 ( 不含背光 )。不同廠牌的模塊模塊亦可互換,其應(yīng)用方式亦均相同。具體的參數(shù)請參照此液晶的數(shù)據(jù)手冊。 </p><p> LCD文字型模塊,每個字符可顯示 5 * 7 或 5 * 10點字圖形,包含標(biāo)準(zhǔn)
29、之 ASCII 碼 ( 含大小寫英文字母、阿拉伯?dāng)?shù)字及特殊符號等 )。 </p><p> 一、LCD 控制指令及功能:</p><p> 1. 清除顯示( Clear Display ): 將ASCII碼20H填入DDRAM,并設(shè)定地址計數(shù)AC=0,由標(biāo)將回至地址00H。</p><p> 2. 游標(biāo)歸位( Returm Home ): 設(shè)定由標(biāo)地址回歸至0
30、0h,但不清除DDRAM的內(nèi)容。AC設(shè)為0。</p><p> 3. 進(jìn)入模式( Entry Mode ): </p><p> 設(shè)定輸入一個字符后,光標(biāo)予顯示字符的位移方向。 </p><p> I/D=0,游標(biāo)向左移,AC減1; </p><p> I/D=1,游標(biāo)向右移,AC加1; </p><p>
31、SH=0,顯示字符不移動; </p><p> SH=1,I/D=0,顯示字符向左移; </p><p> SH=1,I/D=1,顯示字符向右移;</p><p> 4. 顯示開關(guān)控制( Display on/off Control ) 設(shè)定顯示器、光標(biāo)及是否閃爍光標(biāo)控制</p><p> D=0,顯示器關(guān)閉;D=1,顯示器開啟<
32、;/p><p> C=0,光標(biāo)不顯示;D=1,光標(biāo)顯示</p><p> B=0,游標(biāo)不閃爍;D=1,游標(biāo)閃爍</p><p> 5. 光標(biāo)及顯示器移動( Cursor or Display Shift ) </p><p> 設(shè)定光標(biāo)或顯示器移動方向(DDRAM內(nèi)容不變) </p><p> S/C=0,字符不
33、移動; </p><p> R/L=0,游標(biāo)向左移; </p><p> R/L=1,游標(biāo)向右移; </p><p> S/C=1,R/L=0,字符及光標(biāo)向左移;</p><p> S/C=1,R/L=1,字符及光標(biāo)向右移</p><p> 6. 功能設(shè)定( Function Set ) </p>
34、<p> 設(shè)定接口位長度(DL)、顯示列數(shù)(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. 設(shè)定C
35、GRAM地址( Set CGRAM Address ) </p><p> 設(shè)定CGRAM的地址計數(shù)器AC</p><p> 8. 設(shè)定DDRAM地址( Set DDRAM Address ) </p><p> 設(shè)定DDRAM的地址計數(shù)器AC</p><p> 9. 讀取忙碌旗號及地址( Read Busy and Address
36、) </p><p> 設(shè)定從CGRAM或DDRAM地址讀取忙碌旗號(BF,Busy Flag)及地址計數(shù)器AC的數(shù)據(jù)。</p><p> 10.內(nèi)存數(shù)據(jù)寫入( Write Data to RAM ) </p><p> 將D0-D7的數(shù)據(jù)寫入CGRAM或DDRAM內(nèi)部。(依前一筆寫入地址而定)</p><p><b> 二
37、、LCD時序</b></p><p> LCD顯示同樣對時序要求嚴(yán)格,其時序主要分為讀時序和寫時序如下圖。</p><p><b> 1、LCD寫時序</b></p><p><b> 2、LCD讀時序</b></p><p> 三、各功能模塊設(shè)計和仿真:</p>
38、<p> 1、DS18B20溫度傳感器電路</p><p> DS18B20可以采用兩種方式供電,在這采用電源供電方式,DS18B20的1腳接地,2腳作為信號線,3腳接電源。</p><p> 當(dāng)DS18B20處于寫存儲器操作和溫度A/D轉(zhuǎn)換操作時,總線上必須有強的上拉,上拉開啟時間最大為10us。采用寄生電源供電方式時VDD端接地。由于單線制只有一根線,因此發(fā)送接口必須是
39、三態(tài)的。由于DS18B20是在一根I/O線上讀寫數(shù)據(jù),因此,對讀寫的數(shù)據(jù)位有著嚴(yán)格的時序要求。DS18B20有嚴(yán)格的通信協(xié)議來保證各位數(shù)據(jù)傳輸?shù)恼_性和完整性。該協(xié)議定義了幾種信號的時序:初始化時序、讀時序、寫時序。所有時序都是將主機作為主設(shè)備,單總線器件作為從設(shè)備。而每一次命令和數(shù)據(jù)的傳輸都是從主機主動啟動寫時序開始,如果要求單總線器件回送數(shù)據(jù),在進(jìn)行寫命令后,主機需啟動讀時序完成數(shù)據(jù)接收。數(shù)據(jù)和命令的傳輸都是低位在先。DS18B20
40、模塊生成如圖5。</p><p> 圖5 DS18B20功能模塊</p><p> 在該模塊中inclk為時鐘輸入端,DQ為ds18b20的數(shù)據(jù)總線的輸入端,sel[3..0]為數(shù)碼管位選輸出端,seg[7..0]為數(shù)碼管段選輸出,templlreture[10..0]為當(dāng)前溫度的輸出端,baojing為報警信號的輸出端。</p><p> 2、DS18B2
41、0的復(fù)位時序 </p><p> 3、DS18B20的讀時序</p><p> 對于DS18B20的讀時序分為讀0時序和讀1時序兩個過程。</p><p> 對于DS18B20的讀時隙是從主機把單總線拉低之后,在15秒之內(nèi)就得釋放單總線,以讓DS18B20把數(shù)據(jù)傳輸?shù)絾慰偩€上。DS18B20在完成一個讀時序過程,至少需要60us才能完成。</p>
42、<p> 4、DS18B20的寫時序</p><p> 對于DS18B20的寫時序仍然分為寫0時序和寫1時序兩個過程。</p><p> 對于DS18B20寫0時序和寫1時序的要求不同,當(dāng)要寫0時序時,單總線要被拉低至少60us,保證DS18B20能夠在15us到45us之間能夠正確地采樣IO總線上的“0”電平,當(dāng)要寫1時序時,單總線被拉低之后,在15us之內(nèi)就得釋放單總
43、線。</p><p> 5、溫度轉(zhuǎn)換命令子程序</p><p> 溫度轉(zhuǎn)換命令子程序主要是發(fā)溫度轉(zhuǎn)換開始命令,當(dāng)采用12位分辨率時轉(zhuǎn)換時間約為750ms,在本程序設(shè)計中采用1s顯示程序延時法等待轉(zhuǎn)換的完成。溫度轉(zhuǎn)換命令子程序流程圖如上圖,圖9所示,具體程序見附錄。</p><p> 圖9 溫度轉(zhuǎn)換流程圖 圖10 計算溫度流程圖&
44、lt;/p><p><b> 6、計算溫度子程序</b></p><p> 計算溫度子程序?qū)AM中讀取值進(jìn)行BCD碼的轉(zhuǎn)換運算,并進(jìn)行溫度值正負(fù)的判定,其程序流程圖如圖10所示。</p><p> 2、時鐘及顯示控制電路</p><p> 多功能數(shù)字鐘應(yīng)該具有的功能有:顯示時-分-秒、整點報時、小時和分鐘可調(diào)等基本
45、功能。首先要知道鐘表的工作機理,整個鐘表的工作應(yīng)該是在1Hz信號的作用下進(jìn)行,這樣每來一個時鐘信號,秒增加1秒,當(dāng)秒從59秒跳轉(zhuǎn)到00秒時,分鐘增加1分,同時當(dāng)分鐘從59分跳轉(zhuǎn)到00分時,小時增加1小時,但是需要注意的是,小時的范圍是從0~23時。</p><p> 在實驗中為了顯示的方便,由于分鐘和秒鐘顯示的范圍都是從0~59,所以可以用一個3位的二進(jìn)制碼顯示十位,用一個四位的二進(jìn)制碼(BCD碼)顯示個位,對
46、于小時因為它的范圍是從0~23,所以可以用一個2位的二進(jìn)制碼顯示十位,用4位二進(jìn)制碼(BCD碼)顯示個位。</p><p> 開發(fā)板提供50Mhz的時鐘頻率,而時鐘需要的是1Hz時鐘信號,因此為了得到準(zhǔn)確的1Hz信號,必須對輸入的系統(tǒng)時鐘進(jìn)行分頻。其封裝見附件總電路圖的shizhong模塊。</p><p> 3、LCD顯示的實現(xiàn)電路</p><p> 1、L
47、CD顯示電路組成</p><p> LCD顯示包括時鐘分頻(圖6)、和LCD控制(圖7)模塊。</p><p> 其中時鐘分頻顧名思義是對整個LCD顯示提供頻率脈沖,計數(shù)器對LCD控制器控制,LCD控制模塊實現(xiàn)對LCD的初始化,指令寫入及內(nèi)容的編碼顯示。</p><p> LCD顯示控制模塊,其中M[5..0]為計數(shù)器位數(shù)輸入端,clk1為時鐘輸入端,s1[1
48、0..0]為溫度數(shù)據(jù)輸入端,h1[3..0]和h10[3..0]分別為時鐘的小時的個位和十位輸入端,m1[3..0]和m10[3..0]分別為時鐘的分的個位和十位輸入端,se1[3..0]和se10[3..0]分別為時鐘的秒的個位和十位輸入端,D0~D7為輸出端作為8位二進(jìn)制碼傳輸給LCD,rs為LCD的數(shù)據(jù)或命令的選擇端。</p><p><b> 2、LCD程序設(shè)計</b></p
49、><p><b> 流程圖如圖8</b></p><p> 部分命令設(shè)置程序(具體程序見附錄LCD顯示驅(qū)動程序)</p><p> when 0 => Q <=x"01"; RS<='0';-- 清屏</p><p> when 1 => Q <=
50、x"38"; RS<='0';--工作方式設(shè)置(初始化)</p><p> when 2 => Q <=x"06"; RS<='0';--輸入方式設(shè)置</p><p> when 3 => Q <=X"0f"; RS<='0';--顯
51、示開關(guān)控制(設(shè)置顯示、光標(biāo)及閃爍開、關(guān)) 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> 四、結(jié)果分析及調(diào)試:</p><p> 本次課程設(shè)計在達(dá)到設(shè)計基本功能的同時,還加入了其他多項輔助功能,使設(shè)計項目更加人性化、更加完善。主要功能有DS18B20溫度讀取LED數(shù)碼管顯示、LCD1602溫度顯示、LCD1602當(dāng)前時間顯示和時間調(diào)接以及溫度設(shè)定報警等功能。在整個設(shè)計調(diào)試過程中,也出現(xiàn)了一些錯誤和難關(guān),但經(jīng)過小組的探討,查閱相關(guān)資料以及詢問指導(dǎo)老師等方法,最終還
55、是逐步的解決了所遇到的問題。在下面列舉幾個主要的問題。</p><p> 首先遇到的第一個問題就是LED數(shù)碼管的編碼轉(zhuǎn)換上出現(xiàn)了錯誤。在DS18B20中傳輸出來的溫度數(shù)據(jù)是兩字節(jié)的二進(jìn)制數(shù)據(jù),在將溫度數(shù)值轉(zhuǎn)換成驅(qū)動LED顯示的八位二進(jìn)制數(shù)時,沒有注意開發(fā)板上的數(shù)碼管是共陰極還是共陽極,顯示出錯。編碼取反后恢復(fù)正常。</p><p> 第二是LCD顯示時顯示亂碼,在編程時開始是在LCD驅(qū)
56、動外部編碼然后傳輸進(jìn)入LCD驅(qū)動,驅(qū)動內(nèi)部直接讀取編好后傳輸過來的兩位十六進(jìn)制數(shù),但LCD顯示出錯,顯示為亂碼,出錯原因可能是編碼傳輸和顯示時間不夠等等。最后將編碼轉(zhuǎn)換程序放入LCD顯示驅(qū)動中,將DS18B20讀取的兩字節(jié)數(shù)據(jù),直接傳輸入驅(qū)動中再進(jìn)行碼字轉(zhuǎn)換成LCD顯示所需的數(shù)碼。</p><p> 在設(shè)計中還有很多小問題,比如說計數(shù)器位數(shù)不夠,LCD顯示出現(xiàn)延遲等等。總體來說,所遇到的問題都得到了有效地解決,
57、有的是原有基礎(chǔ)上找出錯誤修改,有的是換一種方法實現(xiàn),解決問題實現(xiàn)目標(biāo)方法多種多樣,但只要目的達(dá)到都是一種成功。</p><p><b> 五、體會:</b></p><p> 經(jīng)過為期三周的時間的課程設(shè)計,掌握了電子技術(shù)、EDA技術(shù)、電子測量和計算機接口等綜合性應(yīng)用技術(shù);熟悉控制系統(tǒng)、嵌入式系統(tǒng)和可編程片上系統(tǒng)的設(shè)計方法;能設(shè)計出具有一定功能和規(guī)模的電子應(yīng)用電路。
58、對以后相關(guān)工作的設(shè)計有了一定的幫助。</p><p><b> 六、參考文獻(xiàn):</b></p><p> [1] EDA技術(shù) 郭勇 高等教育出版社 2004-07出版</p><p> [2] 何賓 EDA原理及應(yīng)用 清華大學(xué)出版社 2009-06出版</p><p> [3] 趙剛 EDA技術(shù)簡
59、明教程 四川大學(xué)出版社 2004-07出版</p><p> [4] 江國強 EDA技術(shù)與應(yīng)用(第3版) 電子工業(yè)出版社 2010-04出版</p><p> [5] 周立功 EDA實驗與實踐 北京航空航天大學(xué)出版社 2007-09出版</p><p> [6] 郭振武、叢紅俠 EDA實驗教程 南開大學(xué)出版社 2011-08出版</p>
60、;<p> [7] 潘松、 黃繼EDA技術(shù)與VHDL(第3版) 清華大學(xué)出版社 2009-09出版</p><p> [8] 羅力凡、 常春藤 基于VHDL的FPGA開發(fā)快速入門?技巧?實例 人民郵電出版社 2009-05出版</p><p> [9] 潘松、黃繼業(yè)、 潘明 EDA技術(shù)實用教程:Verilog HDL版(第4版) 科學(xué)出版社 2010-07出
61、版</p><p> [10] 譚會生、 張昌凡 EDA技術(shù)及應(yīng)用:Verilog HDL版(第3版) 西安電子科技大學(xué)出版社 2011-07出版</p><p> [11] 周潤景、 蘇良碧 基于Quartus II的數(shù)字系統(tǒng)Verilog HDL設(shè)計實例詳解 電子工業(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數(shù)碼管顯示驅(qū)動程序代碼</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的單數(shù)據(jù)總線</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);--數(shù)碼管位選</p><p> seg:out std_logic_vector(7 downto 0);--數(shù)碼管段選</p><p> templlreture:out std_logic_vector(10 downto
66、0); --當(dāng)前溫度</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é)開始轉(zhuǎn)換溫度</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);--十進(jìn)制數(shù)后的個位、小數(shù)點第一位、第二位對應(yīng)的數(shù)碼管的段數(shù)
69、值</p><p> signal var1,var2,var3,var4:integer;--分別對應(yīng)將二進(jìn)制數(shù)據(jù)轉(zhuǎn)化為十進(jìn)制數(shù)后的個位、小數(shù)點第一位、第二位</p><p> signal current_templ:std_logic_vector(10 downto 0); --當(dāng)前溫度</p><p> signal cur:std_logic_
70、vector(7 downto 0); --當(dāng)前溫度</p><p> signal ng:std_logic; --負(fù)數(shù)標(biāo)志位</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); --計數(shù)器1,用于DS18B20初始化時計時,以產(chǎn)生時序</p><p> variable count2:std_logic_vector(9 downto 0); --計數(shù)器2,用于向DS18B20寫命令時計時,以產(chǎn)生時序</p><p> variable count3:std_logic_vector(7 downto 0); --計數(shù)器3,用于向DS
75、18B20讀數(shù)據(jù)時計時,以產(chǎn)生時序</p><p> variable fenping_saomiao:std_logic_vector(7 downto 0); </p><p> variable i:integer range -1 to 15:=15; --命令比特計數(shù)值</p><p> variable init:integer range
76、 0 to 1:=0; --完成初始化標(biāo)志</p><p> variable j:integer range 0 to 8:=0; --讀溫度時,比特計數(shù)值</p><p> variable k:integer range 0 to 1:=0; --用于指示讀取哪個溫度值</p><p> variable state:integer ran
77、ge 0 to 2:=0; --狀態(tài)標(biāo)志,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 --對數(shù)碼管進(jìn)行位掃描</p>
79、<p> when "00"=>sel<="0001";seg<=a; --注意數(shù)碼管的位選信號是低電平有效</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內(nèi)向總線寫一比特數(shù)值</p><p> DQ<=
83、ml1(i);</p><p> elsif count2="0001011010" then --在寫時序的15us~60us內(nèi),DS18B20對總線采樣,所以取90us</p><p><b> DQ<='1';</b></p><p> elsif count2="101011
84、0100" then --在大于1us之后,總線拉低,產(chǎn)生下一寫時序</p><p> --DQ<='0';</p><p> count2:="0000000000"; --計數(shù)器歸零</p><p> i:=i-1; --寫下1比特命令</p><p> if i=-
85、1 then --寫完命令,命令計數(shù)值歸零,初始化標(biāo)志歸零,以產(chǎn)生下次初始化,狀態(tài)轉(zhuǎn)為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時進(jìn)行初始化</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"; --總線拉低(也可以不拉低),初始化標(biāo)志置1,即下次不進(jìn)行初始化,計數(shù)器歸零</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"; --總線拉低(也可以不拉低),初始化標(biāo)志置1,即下次不進(jìn)行初始化,計數(shù)器歸零</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內(nèi)讀取溫度</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 --計數(shù)器歸零</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)標(biāo)志歸零,進(jìn)入下次大循環(huán)</p><p> if (templ and "11111000&q
109、uot;)="11111000" then --如果溫度是負(fù)數(shù)則需要轉(zhuǎn)換下</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'; --負(fù)溫度標(biāo)志</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"; --負(fù)號</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; --小數(shù)點后一位</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; --小數(shù)點后一位</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)系上傳者。文件的所有權(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)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 數(shù)字溫度測量系統(tǒng)課程設(shè)計論文
- 溫度測量顯示電路課程設(shè)計--溫度測量顯示電路設(shè)計
- 糧庫溫度測量顯示系統(tǒng)課程設(shè)計
- 課程設(shè)計---溫度測量顯示電路設(shè)計
- 溫度測量及時鐘顯示的課程設(shè)計
- 溫度控制課程設(shè)計--數(shù)字溫度測量系統(tǒng)
- 溫度采集及顯示課程設(shè)計
- 溫度采集附顯示課程設(shè)計課題論文
- lcd顯示設(shè)計單片機課程設(shè)計
- 課程設(shè)計--帶lcd顯示的定時鬧鐘
- 課程設(shè)計--帶lcd顯示的定時鬧鐘
- 數(shù)字溫度測量及顯示系統(tǒng).doc
- 電子測量課程設(shè)計-計算機串口接收+lcd距離顯示設(shè)計
- 畢業(yè)論文-數(shù)字顯示lcd屏設(shè)計
- 數(shù)字溫度測量及顯示系統(tǒng)設(shè)計開題報告
- 數(shù)字溫度測量及顯示系統(tǒng).doc
- 數(shù)字顯示lcd屏設(shè)計畢業(yè)論文
- 溫度控制顯示課程設(shè)計
- 課程設(shè)計--帶LCD顯示的定時鬧鐘.doc
- 液晶顯示屏lcd顯示接口設(shè)計課程設(shè)計
評論
0/150
提交評論