【藍橋杯單片機進階強化-08】基於NE555的信號發生與頻率測量

【題目要求】

  在CT107D單片機綜合實訓平臺上,利用NE555產生方波信號並測量其頻率,具體功能要求如下:

 [1] 上電開機運行時,關閉蜂鳴器、繼電器和8個LED指示燈。

 [2] 用短路環將J13中的NALP34短接,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();
	}
}

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章