【題目要求】
在CT107D單片機綜合實訓平臺上,利用NE555產生方波信號並測量其頻率,具體功能要求如下:
[1] 上電開機運行時,關閉蜂鳴器、繼電器和8個LED指示燈。
[2] 用短路環將J13中的NAL與P34短接,NE555發生的信號輸入到單片機的P34引腳。
[3] 單片機測量信號頻率,並顯示在數碼管中,頻率數據顯示用6位數碼管,單位是Hz,當顯示長度不足6位時,未使用到的數碼管熄滅,在最左邊的1位數碼管用“F”作爲提示符。顯示格式如下:
【特別提示】
本題是第10屆藍橋杯省賽編程題目的一個部分。
因爲很多考生反映,因爲不懂NE555芯片,所以不會做這個題目。其實你不需要懂NE555芯片也可能做這個題目,對於藍橋杯競賽平臺CT107D板子上NE555電路,你只需要知道2點就可以:
[1] NE555電路是一個信號發生電路,其信號輸出接到單片機的P34引腳,即單片機的T0引腳。
[2] 該信號的頻率大小可以通過Rb3可調電位器改變。
因爲NE555芯片基本上就是一個純硬件的設計,沒有可編程的內容,因此,一點電路確定了,就沒有變化了,單片機也不需要對它有任何的配置。所以,在整個單片機測量頻率的過程中,跟NE555芯片一點兒關係都沒有,實際上考查的是你應用定時/計數器測量信號頻率的技術。
【參考代碼】
/*=====================================================================
***案例名稱:基於NE555的信號發生與頻率測量
***編程模式:MM模式
***作者信息:廣東職業技術學院 歐浩源(小蜜蜂老師)
***電子郵箱:[email protected]
***設計時間:2019-04-06
=====================================================================*/
#include "reg52.h"
#include "absacc.h"
unsigned char code SMG_DM_NoDot[18]=
{0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,
0x88,0x80,0xc6,0xc0,0x86,0x8e,0xbf,0x7f};
unsigned int count_f = 0;
unsigned char count_t = 0;
unsigned int dat_f = 0;
void DelaySMG(unsigned int t)
{
while(t--);
}
void DisplaySMG_Bit(unsigned char pos, unsigned char value)
{
XBYTE[0xE000] = 0xFF;
XBYTE[0xC000] = 0x01 << pos;
XBYTE[0xE000] = value;
}
void DisplaySMG_F()
{
DisplaySMG_Bit(0, SMG_DM_NoDot[15]);
DelaySMG(500);
if(dat_f > 9999)
DisplaySMG_Bit(3, SMG_DM_NoDot[dat_f / 10000]);
DelaySMG(500);
if(dat_f > 999)
DisplaySMG_Bit(4, SMG_DM_NoDot[(dat_f / 1000) % 10]);
DelaySMG(500);
if(dat_f > 99)
DisplaySMG_Bit(5, SMG_DM_NoDot[(dat_f / 100) % 10]);
DelaySMG(500);
if(dat_f > 9)
DisplaySMG_Bit(6, SMG_DM_NoDot[(dat_f / 10) % 10]);
DelaySMG(500);
DisplaySMG_Bit(7, SMG_DM_NoDot[dat_f % 10]);
DelaySMG(500);
}
void Init_Timer()
{
TH0 = 0xff;
TL0 = 0xff;
TH1 = (65536 - 50000) / 256;
TL1 = (65536 - 50000) % 256;
TMOD = 0x16; //定時器1用方式1,定時;定時器0用方式2,計數
ET0 = 1;
ET1 = 1;
EA = 1;
TR0 = 1;
TR1 = 1;
}
void Service_T0() interrupt 1
{
count_f++;
}
void Service_T1() interrupt 3
{
TH1 = (65536 - 50000) / 256;
TL1 = (65536 - 50000) % 256;
count_t++;
if(count_t == 20)
{
dat_f = count_f;
count_f = 0;
count_t = 0;
}
}
void main()
{
Init_Timer();
XBYTE[0x8000] = 0xff;
XBYTE[0xA000] = 0x00;
while(1)
{
DisplaySMG_F();
}
}