功能描述
1、采用51/52單片機作為主要制器;
2、采用ADC0808(ADC0809通用)模數轉換晶片實作電壓的測量;
3、采用四位數位管進行顯示,測量電壓量程為0~5V,精度精确到0.01V。
仿真設計
采用Proteus作為仿真設計工具。Proteus是一款著名的EDA工具(仿真軟體),從原理圖布圖、代碼調試到單片機與外圍電路協同仿真,一鍵切換到PCB設計,真正實作了從概念到産品的完整設計。
單片機管腳說明:
P0端口(P0.0-P0.7):P0口為一個8位漏極開路雙向I/O口,每個引腳可吸收8TTL門電流。當P1口的管腳第一次寫1時,被定義為高阻輸入。P0能夠用于外部程式資料存儲器,它可以被定義為資料/位址的第八位。在FIASH程式設計時,P0 口作為原碼輸入口,當FIASH進行校驗時,P0輸出原碼,此時P0外部必須被拉高。
P1端口(P1.0-P1.7):P1口是一個内部提供上拉電阻的8位雙向I/O口,P1口緩沖器能接收輸出4TTL門電流。P1口管腳寫入1後,被内部上拉為高電平,可用作輸入,P1口被外部下拉為低電平時,将輸出電流,這是由于内部上拉的緣故。在FLASH程式設計和校驗時,P1口作為第八位位址接收。
P2端口(P2.0-P2.7):P2口為一個内部上拉電阻的8位雙向I/O口,P2口緩沖器可接收,輸出4個TTL門電流,當P2口被寫“1”時,其管腳被内部上拉電阻拉高,且作為輸入。并是以作為輸入時,P2口的管腳被外部拉低,将輸出電流。這是由于内部上拉的緣故。P2口,用于外部程式存儲器或16位位址外部資料存儲器進行存取時,P2口輸出位址的高八位。在給出位址“1”時,它利用内部上拉優勢,當對外部八位位址資料存儲器進行讀寫時,P2口輸出其特殊功能寄存器的内容。P2口在FLASH程式設計和校驗時接收高八位位址信号和控制信号。
P3端口(P3.0-P3.7):P3口管腳是一個帶有内部上拉電阻的8位的雙向I/O端口,可接收輸出4個TTL門電流。當P3口寫入“1”後,它們被内部上拉為高電平,并用作輸入。作為輸入端時,由于外部下拉為低電平,P3口将輸出電流(ILL)。P3口同時為閃爍程式設計和程式設計校驗接收一些控制信号。
VCC(40):供電電壓,其工作電壓為5V。
GND(20):接地。
RST(9):複位輸入。在振蕩器運作時,有兩個機器周期(24個振蕩周期)以上的高電平出現在此引腳時,将使單片機複位,隻要這個引腳保持高電平,51晶片便循環複位。複位後P3.0-P3.7口均置1,引腳表現為高電平,程式計數器和特殊功能寄存器SFR全部清零。當複位腳由高電平變為低電平時,晶片為ROM的00H處開始運作程式。複位操作不會對内部RAM有所影響。
ALE/PROG (30):當通路外部存儲器時,位址鎖存允許的輸出電平用于鎖存位址的地低位位元組。在FLASH程式設計期間,此引腳用于輸入程式設計脈沖。在平時,ALE端以不變的頻率周期輸出正脈沖信号,此頻率為振蕩器頻率的1/6。是以它可用作對外部輸出的脈沖或用于定時目的。然而要注意的是:每當用作外部資料存儲器時,将跳過一個ALE脈沖。如果想禁止ALE的輸出可在SFR8EH位址上置0。此時, ALE隻有在執行MOVX,MOVC指令是ALE才起作用。另外,該引腳被略微拉高。如果微處理器在外部執行狀态ALE禁止,則置位無效。
PSEN(29):外部程式存儲器的選通信号。在由外部程式存儲器取指令期間,每個機器周期兩次PSEN有效。但在通路外部資料存儲器時,這兩次有效的PSEN信号将不出現。
主程式設計
void main()
{
TimeInitial();
ADD_A=0;
ADD_B=0;
ADD_C=0;
_v10;
m=2;
while(1)
{
ST=0;
OE=0;
ST=1;
ST=0;
while(EOC==0);
OE=1;
getdata=P0;
OE=0;
if ((s1==0) && (s2==1) && (getdata<6))
{
ADD_A=1;
_v0_5;
m=10;
}
else if ((s1==1)&&(s2==0) && (getdata>254))
{
ADD_A=0;
_v10;
m=2;
}
temp=(getdata*1.0/255)*500*m;
dispbuf[0]=temp%10;
dispbuf[1]=temp/10%10;
dispbuf[2]=temp/100%10;
dispbuf[3]=temp/1000;
Display();
}
}