功能描述
1、采用51/52單片機作為主要晶片;
2、采用6位數位管顯示頻率值,精度0.001KHz;
3、采用74HC573驅動數位管;
4、信号可由外部輸入,也可由闆上555晶片産生;
電路設計
采用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(void) //主函數
{
unsigned char i;
TMOD=0x15; //定義T1為定時模式,T0位計數模式
TH0=0;
TL0=0; //計數器清零
TH1=0x3c;
TL1=0xb0; //定時器指派(定時50ms)
TR1=1; //打開定時器T1
TR0=1; //打開計數器T0
ET0=1; //打開中斷允許
ET1=1; //打開中斷允許
EA=1; //打開中斷總開關
while(1) //進入循環,因為括号内為常數1,不會變化,是以該表達式一直成立,又稱死循環
{
display(); //調用顯示函數
if(flag) //判斷1秒時間是否到
{
flag=0; //标志位清零,計算完脈沖數後重新開始計時計數
x=T0count*65536+TH0*256+TL0; //讀取1秒時間内的計數個數(T0count為每次計數超過65536時進入計數中斷加1)
for(i=0;i<6;i++) //for循環将暫存數組内資料清零
{
temp[i]=0;
}
i=0; //i清零
while(x/10) //将x拆分為6個一位數
{
temp[i]=x%10; //如果x/10不為0,将x除以10的餘數指派temp【i】
x=x/10; //然後将x/10的商指派給x
i++; //i++
}
temp[i]=x; //最高位直接指派給temp【i】
for(i=0;i<6;i++) //for循環用于将資料送入顯示暫存數組
{
dispbuf[i]=temp[i]; //指派語句
}
T0count=0; //計數器中斷次數清零
TH0=0;
TL0=0; //計數器清零
TR0=1;
TR1=1; //重新打開定時計數器
}
}
}