功能描述
1、采用51單片機作為主要晶片;
2、采用1602液晶顯示:頻率值F、周期P;
3、采用74HC08+74HC393組成信号輸入電路;
電路設計
采用Altium Designer作為電路設計工具。Altium Designer通過把原理圖設計、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口同時為閃爍程式設計和程式設計校驗接收一些控制信号。
仿真設計
主程式設計
void main()//主函數
{
unsigned long a=0;
bit b=0;
uchar tab[10];
uint temp=0;
LCD_init();
init();
LCD_sfj1(0,0);
LCD_print("Welcome to use ");
LCD_sfj1(0,1);
LCD_print("Please Wating...");
delay3();
LCD_write(0,0x01);
while(1)
{
if(K1==0)
{
delay2(10);
if(K1==0)
{
while(K1==0);
b=~b;
LCD_write(0,0x01);
}
}
temp=fenjie(0);
if(temp>c)
c=temp;
if(temp>c>>3&&temp<c>>1)
f=0;
if(b==0)
{
a=(aaa*256)+bbb;
if(a==0)
{
LCD_sfj1(0,0);
LCD_print("F= 0000000000 Hz");
LCD_sfj1(0,1);
LCD_print("F= 0000000000 Hz");
}
else
{
LCD_sfj1(0,0);
LCD_print("F= Hz");
sprintf(tab,"%ld",a);
LCD_sfj1(2,0);
LCD_print(tab);
LCD_sfj1(0,1);
LCD_print("P= ms");
sprintf(tab,"%0.6f",1000.0/a);
LCD_sfj1(2,1);
LCD_print(tab);
}
}
else
{
sprintf(tab,"%bd",e);
LCD_sfj1(0,0);
LCD_print(tab);
sprintf(tab,"Upp=%0.3fV",d);
LCD_sfj1(0,1);
LCD_print(tab);
}
}
}