之前因为同学的一个小试验,需求用到频率计,所以自己想搞一个出来,所以网上找了许多材料,简略的有用8052单片机的守时器和计数器的结合来测其信号的频率,还有的是c8051f的捕捉功用,想来想去,仍是想用用自己了解的8052的计数器功用,究竟平常都用的是守时器功用,很少用到计数器功用,以便愈加深化的运用8052,今后再学习C8051F。
搞了好几天,时钟没有成果,计数功用却是有了,可是不能在1s的时刻里计数,很是头痛,遽然有一天,我的同学找到了一段代码,说是能够运转的,所以我拿过来,把LED改了一改,烧录之后,还真的成功了!甚是大喜啊!
函数功用:51单片机制造的频率计(当然这个频率计的频率规模是有约束的理论值为2Hz-1MHz)
编译环境:keil4
规划思维:测频率,其实便是一个守时计数的进程,在一守时刻内,检测脉冲的个数,最后用脉冲个数除以时刻便能够得到频率
修正:LiMingWangQiDong
板子:CCDZ-Cboard
CPU:STC89C52RC
晶振:12MHz
修正部分:LED显现部分4位显现2Hz-9999Hz
版别:0.1.0
********http://hi.baidu.com/zhangjiayue123/home****************************************/
#include
#include
#defineucharunsignedchar
#defineuintunsignedint
sbitdula=P2^6;
sbitwela=P2^7;
//ucharseg_du[]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90};//数码管的段选
ucharseg_du[]={
0x3f,0x06,0x5b,0x4f,
0x66,0x6d,0x7d,0x07,0x7f,0x6f};//数码管的段选
uchardbuf[4]={0,0,0,0};//用来装显现数据的空数组
uintcount;
uintcou,cou1;
voiddelay(void)//延时函数用于数码管动态扫描
{
uchari;
for(i=0;i《110;i++)
;
}
voiddisplay()//数码管显现函数
{
dula=1;
P0=seg_du[dbuf[3]];
dula=0;
P0=0xff;
wela=1;
P0=0xfe;
wela=0;
delay();
//
dula=1;
P0=seg_du[dbuf[2]];
dula=0;
P0=0xff;
wela=1;
P0=0xfd;
wela=0;
delay();
//
dula=1;
P0=seg_du[dbuf[1]];
dula=0;
P0=0xff;
wela=1;
P0=0xfb;
wela=0;
delay();
//
dula=1;
P0=seg_du[dbuf[0]];
dula=0;
P0=0xff;
wela=1;
P0=0xf7;
wela=0;
delay();
}
voidtimer0(void)interrupt1//守时器中止,用与守时计数
{
count++;
if(count==4000)//守时1s,
{
count=0;//将守时标志清零
TR1=0;//封闭计数器
cou1=TL1-6;//将小于250次脉冲的计数加上
dbuf[3]=(cou*250+cou1)/1000;
dbuf[2]=((cou*250+cou1)%1000)/100;
dbuf[1]=((cou*250+cou1)%100)/10;
dbuf[0]=(cou*250+cou1)%10;//显现处理函数
cou=0;//计数器清零
TL1=6;//翻开计数器中止
TR1=1;//敞开计数器,使之作业
}
}
voidTIme1(void)interrupt3//计数器中止,用于计数
{
cou++;
}
voidTIme0_init()//守时器0初始化
{
TMOD=0x62;//设置守时器0,和计数器1的形式
TH0=6;
TL0=6;//守时器的初值,用于中止一次计时250us
ET0=1;//开守时器0中止
TR0=1;//开守时器0
}
voidTIme1_init()//计数器1初始化
{
TH1=6;
TL1=6;//装载计数器的初值
ET1=1;//开计数器1中止
TR1=1;//开计数器1
EA=1;//开总中止
}
voidmain()
{
count=0;
TIme0_init();
time1_init();
while(1)
{
display();
}
}
也感谢网上的网友供给,
成果仍是能够的,只不过和自在四位显现,附上几张相片:
信号发生器的频率为5.677kHZ,LED上显现还能够吧。。。