1 引言
由于單片機具有簡單實用,、高可靠性,、良好的性能價格比以及體積小等優(yōu)點,已經在各個技術領域得到了迅猛發(fā)展,。數字電壓表(Digital Voltmeter)簡稱DVM,,它是采用數字化測量技術,把連續(xù)的模擬量(直流輸入電壓)轉換成不連續(xù),、離散的數字形式并加以顯示的儀表,。傳統的指針式電壓表功能單一、精度低,,不能滿足數字化時代的需求,,采用單片機的數字電壓表,由精度高,、抗干擾能力強,,可擴展性強、集成方便,,還可與PC進行實時通信,。目前,由各種單片A/D 轉換器構成的數字電壓表,已被廣泛用于電子及電工測量,、工業(yè)自動化儀表,、自動測試系統等智能化測量領域,示出強大的生命力,。與此同時,,由DVM擴展而成的各種通用及專用數字儀器儀表,也把電量及非電量測量技術提高到嶄新水平,。本設計重點介紹單片A/D 轉換器以及由它們構成的基于單片機的數字電壓表的工作原理,。
2 總體設計方案
2.1 設路計思路
按系統功能要求,決定控制系統采用AT89S51單片機,,A/D轉換采用ADC0809.系統除能確保實現要求的功能外,,還可以方便地進行其功能的擴展。本文采用AT89S51作為核心元件,,AT89S51是一個低功耗,,高性能CMOS 8位單片機,片內含4k Bytes ISP(In-system programmable)的可反復擦寫1000次的Flash只讀程序存儲器,,器件采用ATMEL公司的高密度,、非易失性存儲技術制造,兼容標準MCS-51指令系統及80C51引腳結構,,芯片內集成了通用8位中央處理器和ISP Flash存儲單元,功能強大的微型計算機的AT89S51可為許多嵌入式控制應用系統提供高性價比的解決方案,。
采用NS公司的分辨率為8位的逐次比較型的高精度的模數轉換器ADC0809,ADC0809是帶有8位A/D轉換器,、8路多路開關以及微處理機兼容的控制邏輯的CMOS組件。它是逐次逼近式A/D轉換器,,可以和單片機直接接口,。把采取的電壓進行處理然后通過單片機的P口送到單片機然后經過程序處理,由LED電路把電壓數值顯示出來,。單片機加上外圍的串口顯示電路由74LS245和數碼管三極管組成,。
器件采用ATMEL公司的高密度,非易失性存儲技術生產,,兼容標準8051指令系統及引腳,。它集Flash程序存儲器,既可在線編程(ISP)也可用傳統方法進行編程及通用8位微處理器于單片芯片中,,ATMEL公司的功能強大,,低價AT89s51單片機可為您提供許多高性價比的應用場合,可靈活應用于各種控制領域,。
2.2 設計方框圖
數字電壓表系統設計方案
圖1 數字電壓表系統設計方案
3 設計原理分析
3.1 單片機AT89S51
AT89S51單片機是美國ATMEL公司生產的低功耗,,高性能CMOS 8位單片機,片內含4K bytes的可系統編程的Flash只讀程序存儲器,器件采用ATMEL公司的高密度,,非易失性存儲技術生產,,兼容標準8051指令系統及引腳。它集Flash程序存儲器,,既可在線編程(ISP)也可用傳統方法進行編程及通用8位微處理器于單片芯片中,,ATMEL公司的功能強大,低價AT89S51單片機可為您提供許多高性價比的應用場合,,可靈活應用于各種控制領域,。
3.2 AT89S51的特點
40個引腳,4k Bytes Flash片內程序存儲器,,128 bytes的隨機存取數據存儲器(RAM),,32個外部雙向輸入/輸出(I/O)口,5個中斷優(yōu)先級2層中斷嵌套中斷,,2個16位可編程定時計數器,,2個全雙工串行通信口,看門狗(WDT)電路,,片內時鐘振蕩器 此外,,AT89S51設計和配置了振蕩頻率可為0Hz并可通過軟件設置省電模式??臻e模式下,,CPU暫停工作,而RAM定時計數器,,串行口,,外中斷系統可繼續(xù)工作,掉電模式凍結振蕩器而保存RAM的數據,,停止芯片其它功能直至外中斷激活或硬件復位,。同時該芯片還具有PDIP、TQFP和PLCC等三種封裝形式,,以適應不同產品的需求,。
主要特性在:
● 與MCS-51單片機產品兼容
● 4K字節(jié)在系統可編程Flash存儲器
● 1000次擦寫周期
● 全靜態(tài)工作:0Hz-33MHz
● 32個可編程I/O口線
● 2個16位定時器/計數器
● 6個中斷源
● 全雙工UART串行通道
● 低功耗空閑和掉電模式
● 掉電后中斷可喚醒
● 看門狗定時器
● 雙數據指針
● 靈活的ISP編程(字或字節(jié)模式)
● 4.0---5.5V電壓工作范圍
3.3 ADC0809的內部邏輯結構
八路數字電壓表主要利用A/D轉換器,處理過程是先用A/D轉換器對各路電壓值進行采樣,,得到相應的數字量,,再按數字量與模擬量成正比關系運算得到對應的模擬電壓值,然后把模擬值通過顯示器顯示出來,。設計時假設待測的輸入電壓為八路,,電壓值的范圍為0~5V,要求能在4位LED數碼管上輪流顯示或單路選擇顯示,。測量的最小分辨率為0.0119V,c測量誤差為±0.02V,。
ADC0809是8路8位ADC芯片,片內有8路模擬開關、地址鎖存與譯碼,、256電阻梯形網絡,、電子開關樹、逐次逼近寄存器,、比較器和3態(tài)輸出鎖存器等,,特別適合與微機接口。時鐘頻率=1.26MHz,,轉換時間=100μs,,轉換誤差≤±1LSB,內含8路數據選擇器以便進行8路ADC,。8路8位2進制碼LSTTL電平輸出,,28腳封裝。ADC0809多路開關可選通8個模擬通道,,允許8路模擬量分時輸入,,共用A/D轉換器進行轉換。三態(tài)輸出鎖器用于鎖存A/D轉換完的數字量,,當OE端為高電平時,,才可以從三態(tài)輸出鎖存器取走轉換完的數據。ADC0809的內部邏輯結構如圖3.1所示,。
圖2 ADC0809的內部邏輯結構
3.4 引腳結構
ADC0809具有8路模擬量輸入通道IN0~IN7,,通過3位地址輸入端C、B,、A(因腳23,、24、25)進行選擇,。引腳22為地址鎖存控制端ALE,當輸入為高電平時,,C,、B、A引腳輸入的地址鎖存與ADC0809內部的鎖存器中,,經內部譯碼電路譯碼選中相應的模擬通道,。引腳6為啟動轉換控制端START,當輸入一個2 us寬的高電平脈沖時,,就啟動ADC0809開始對輸入通道的模擬量進行轉換,。引腳7為A/D轉換的結束信號EOC。ADC0809為逐次比較型A/D轉換器,,當開始轉換時,,EOC信號為低電平,經過一定時間,轉換結束,,轉換結束信號EOC輸出高電平,,轉換結果存放與ADC0809內部的輸出數據鎖存器中。引腳9為A/D轉換數據輸出允許控制端OE,,當OE為高電平時,,存放與輸出數據存儲器中的數據通過ADC0809的數據線D0~D7輸出。引腳10為ADC0809的時鐘信號輸入端CLOCK,。在連接時,,ADC0809的數據線D0~D7與AT89S51的P0口相連,ADC0809的地址引腳,、地址鎖存端ALE,、啟動信號START、數據輸出允許控制端OE分別與AT89S51的P2口相連,,轉換結束信號EOC與AT89S51的P3.7口相連,。時鐘信號輸入端CLOCK信號,由單片機的地址鎖存控制端ALE提供,。單片機的系統時鐘為12MHZ,。
IN0-IN7:8條模擬量輸入通道 。ADC0809對輸入模擬量要求:信號單極性,,電壓范圍是0-5V,,若信號太小,必須進行放大,;輸入的模擬量在轉換過程中保持不變,,如若模擬量變化太快,則需在輸入前增加采樣保持電路,。
地址輸入和控制線:4條 ,。ALE為地址鎖存允許輸入線,高電平有效,。當ALE線為高電平時,,地址鎖存與譯碼器將A,B,,C三條地址線的地址信號進行鎖存,,經譯碼后被選中的通道的模擬量進轉換器進行轉換。A,,B和C為地址輸入線,,用于選通IN0-IN7上的一路模擬量輸入。數字量輸出及控制線:11條 ,。ST為轉換啟動信號,,當ST上跳沿時,,所有內部寄存器清零;下跳沿時,,開始進行A/D轉換,;在轉換期間,ST應保持低電平,。EOC為轉換結束信號,。當EOC為高電平時,表明轉換結束,;否則,,表明正在進行A/D轉換。OE為輸出允許信號,,用于控制三條輸出鎖存器向單片機輸出轉換得到的數據,。OE=1,輸出轉換得到的數據,;OE=0,,輸出數據線呈高阻狀態(tài)。D7-D0為數字量輸出線,。
CLK為時鐘輸入信號線,。因ADC0809的內部沒有時鐘電路,所需時鐘信號必須由外界提供,,通常使用頻率為1MHZ,,VREF(+),VREF(-)為參考電壓輸入,。
3.5 ADC0809應用說明
ADC0809內部帶有輸出鎖存器,,可以與AT89S51單片機直接相連。 初始化時,,使ST和OE信號全為低電平,。送要轉換的哪一通道的地址到A,B,,C端口上,。在ST端給出一個至少有100ns寬的正脈沖信號。是否轉換完畢,,我們根據EOC信號來判斷。當EOC變?yōu)楦唠娖綍r,,這時給OE為高電平,,轉換的數據就輸出給單片機。
3.6 ADC0809工作原理
8路模擬信號由ADC0809的IN0~IN7端輸入,,AT89S51單片機的ALE端口輸出的脈沖信號送ADC0809的10腳作為ADC的時鐘信號(產生CLK信號的方法就得用軟件來產生),。A/D轉換完成之后,,從EOC端返回AT89S51一個轉換結束信號,單片機隨即用信號將A/D轉換的數字輸出從D0~D7端經P0口數據總線讀入自己的存儲器中,。A/D轉換過程全部結束,。再經軟件程序轉換成a~g 7段碼輸出,驅動LED數碼管,。各位數碼管由位控信號P3.0,、P3.1、P3.2,、P3.3控制,,由74LS245反相驅動將依次巡回點亮數碼管。
3.7 復位電路的設計
本設計采用了上電自動復位和手動復位,,上電自動復位是再加電瞬間電容通過充電來實現的,,其電路如圖3.2所示。在充電瞬間,,電容C通過復位電阻R充電,,RST端出現正脈沖,以復位,。只要電源VCC的上升時間不超過1MS,就可以實現自動復位,,既接通電源就完成了系統的復位初始化,手動復位是通過按鈕實現的,。
圖3 復位電路
3.8 時鐘電路的設計
任何一塊單片機的正常工作都離不開時鐘信號,,本設計中利用8951內部的高增益反相放大器,外加石英晶體以及兩個電容就構成了穩(wěn)定的自激振蕩器,。給單片機提供了時鐘信號,,保持單片機按正常的時序工作。
圖4 時鐘電路