詳解基于單片機的數字電壓表的工作原理
1 引言
本文引用地址:http://www.ex-cimer.com/article/193078.htm由于單片機具有簡單實用、高可靠性、良好的性能價格比以及體積小等優(yōu)點,已經在各個技術領域得到了迅猛發(fā)展。數字電壓表(Digital Voltmeter)簡稱DVM,它是采用數字化測量技術,把連續(xù)的模擬量(直流輸入電壓)轉換成不連續(xù)、離散的數字形式并加以顯示的儀表。傳統(tǒng)的指針式電壓表功能單一、精度低,不能滿足數字化時代的需求,采用單片機的數字電壓表,由精度高、抗干擾能力強,可擴展性強、集成方便,還可與PC進行實時通信。目前,由各種單片A/D 轉換器構成的數字電壓表,已被廣泛用于電子及電工測量、工業(yè)自動化儀表、自動測試系統(tǒng)等智能化測量領域,示出強大的生命力。與此同時,由DVM擴展而成的各種通用及專用數字儀器儀表,也把電量及非電量測量技術提高到嶄新水平。本設計重點介紹單片A/D 轉換器以及由它們構成的基于單片機的數字電壓表的工作原理。
2 總體設計方案
2.1 設路計思路
按系統(tǒng)功能要求,決定控制系統(tǒng)采用AT89S51單片機,A/D轉換采用ADC0809.系統(tǒng)除能確保實現要求的功能外,還可以方便地進行其功能的擴展。本文采用AT89S51作為核心元件,AT89S51是一個低功耗,高性能CMOS 8位單片機,片內含4k Bytes ISP(In-system programmable)的可反復擦寫1000次的Flash只讀程序存儲器,器件采用ATMEL公司的高密度、非易失性存儲技術制造,兼容標準MCS-51指令系統(tǒng)及80C51引腳結構,芯片內集成了通用8位中央處理器和ISP Flash存儲單元,功能強大的微型計算機的AT89S51可為許多嵌入式控制應用系統(tǒng)提供高性價比的解決方案。
采用NS公司的分辨率為8位的逐次比較型的高精度的模數轉換器ADC0809,ADC0809是帶有8位A/D轉換器、8路多路開關以及微處理機兼容的控制邏輯的CMOS組件。它是逐次逼近式A/D轉換器,可以和單片機直接接口。把采取的電壓進行處理然后通過單片機的P口送到單片機然后經過程序處理,由LED電路把電壓數值顯示出來。單片機加上外圍的串口顯示電路由74LS245和數碼管三極管組成。
器件采用ATMEL公司的高密度,非易失性存儲技術生產,兼容標準8051指令系統(tǒng)及引腳。它集Flash程序存儲器,既可在線編程(ISP)也可用傳統(tǒng)方法進行編程及通用8位微處理器于單片芯片中,ATMEL公司的功能強大,低價AT89s51單片機可為您提供許多高性價比的應用場合,可靈活應用于各種控制領域。
2.2 設計方框圖
數字電壓表系統(tǒng)設計方案
圖1 數字電壓表系統(tǒng)設計方案
3 設計原理分析
3.1 單片機AT89S51
AT89S51單片機是美國ATMEL公司生產的低功耗,高性能CMOS 8位單片機,片內含4K bytes的可系統(tǒng)編程的Flash只讀程序存儲器,器件采用ATMEL公司的高密度,非易失性存儲技術生產,兼容標準8051指令系統(tǒng)及引腳。它集Flash程序存儲器,既可在線編程(ISP)也可用傳統(tǒng)方法進行編程及通用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定時計數器,串行口,外中斷系統(tǒng)可繼續(xù)工作,掉電模式凍結振蕩器而保存RAM的數據,停止芯片其它功能直至外中斷激活或硬件復位。同時該芯片還具有PDIP、TQFP和PLCC等三種封裝形式,以適應不同產品的需求。
主要特性在:
● 與MCS-51單片機產品兼容
● 4K字節(jié)在系統(tǒng)可編程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提供。單片機的系統(tǒng)時鐘為12MHZ。
評論