返回主页 单片机教程XL2000开发板 单片机学习 自制编程器 单片机资料 软件下载 电子技术产品介绍如何购买 进入论坛

第一章硬件资源模块第二章:keilc软件使用
at89s51单片机实验及实践课题     at89s51单片机实验及实践课题
1.闪烁灯2.模拟开关灯
3.多路开关状态指示4.广告灯的左移右移
5.广告灯(利用取表方式)6.报警产生器
7.I/O并行口直接驱动LED显示8.按键识别方法之一
9.一键多功能按键识别技术10.00-99计数器
11.00-59秒计时器(软件延时)12.可预置可逆4位计数器
13.动态数码显示技术14.4×4矩阵式键盘识别技术
15.定时计数器T0作定时(一)16.定时计数器T0作定时应用技术(二)
17.99秒马表设计18.“嘀、嘀、……”报警声
19.“叮咚”门铃20.字钟(★)
21.拉幕式数码显示技术22.电子琴
23.模拟计算器数字输入及显示24.8×8LED点阵显示技术
25.点阵LED“0-9”数字显示技术26.点阵式LED简单图形显示技术
27.ADC0809A/D转换器基本应用技术28.数字电压表
29.两点间温度控制30.四位数数字温度计
31.6位数显频率计数器32.电子密码锁设计
33.4×4键盘的电子密码锁34.带有存储器功能的数字温度计-DS1624技术应用
35.DS18B20数字温度计使用

单片机c语言<>欢迎进入51单片机学习网论坛讨论

本站新域名www.8951.com开通WWW.51C51.COM 中国单片机编程技术普及推广第一站!

31.    6位数显频率计数器

1.      实验任务

利用AT89S51单片机的T0T1的定时计数器功能,来完成对输入的信号进行频率计数,计数的频率结果通过8位动态数码管显示出来。要求能够对0250KHZ的信号频率进行准确计数,计数误差不超过±1HZ

2.      电路原理图

4.31.1

 

3.      系统板上硬件连线

(1).            把“单片机系统”区域中的P0.0P0.7与“动态数码显示”区域中的ABCDEFGH端口用8芯排线连接。

(2).            把“单片机系统”区域中的P2.0P2.7与“动态数码显示”区域中的S1S2S3S4S5S6S7S8端口用8芯排线连接。

(3).            把“单片机系统”区域中的P3.4T0)端子用导线连接到“频率产生器”区域中的WAVE端子上。

4.      程序设计内容

(1).            定时/计数器T0T1的工作方式设置,由图可知,T0是工作在计数状态下,对输入的频率信号进行计数,但对工作在计数状态下的T0,最大计数值为fOSC/24,由于fOSC12MHz,因此:T0的最大计数频率为250KHz。对于频率的概念就是在一秒只数脉冲的个数,即为频率值。所以T1工作在定时状态下,每定时1秒中到,就停止T0的计数,而从T0的计数单元中读取计数的数值,然后进行数据处理。送到数码管显示出来。

(2).            T1工作在定时状态下,最大定时时间为65ms,达不到1秒的定时,所以采用定时50ms,共定时20次,即可完成1秒的定时功能。

5.      C语言源程序

#include <AT89X52.H>

unsigned char code dispbit[]={0xfe,0xfd,0xfb,0xf7,0xef,0xdf,0xbf,0x7f};

unsigned char code dispcode[]={0x3f,0x06,0x5b,0x4f,0x66,

                               0x6d,0x7d,0x07,0x7f,0x6f,0x00,0x40};

unsigned char dispbuf[8]={0,0,0,0,0,0,10,10};

unsigned char temp[8];

unsigned char dispcount;

unsigned char T0count;

unsigned char timecount;

bit flag;

unsigned long x;

void main(void)

{

  unsigned char i;

  TMOD=0x15;

  TH0=0;

  TL0=0;

  TH1=(65536-4000)/256;

  TL1=(65536-4000)%256;

  TR1=1;

  TR0=1;

  ET0=1;

  ET1=1;

  EA=1;

  while(1)

   {

     if(flag==1)

       {

         flag=0;

         x=T0count*65536+TH0*256+TL0;

         for(i=0;i<8;i++)

           {

             temp[i]=0;

           }

         i=0;

         while(x/10)

           {

             temp[i]=x%10;

             x=x/10;

             i++;

           }

         temp[i]=x;

         for(i=0;i<6;i++)

           {

             dispbuf[i]=temp[i];

           }

         timecount=0;

         T0count=0;

         TH0=0;

         TL0=0;

         TR0=1;

       }

   }

}

void t0(void) interrupt 1 using 0

{

  T0count++;

}

void t1(void) interrupt 3 using 0

{

  TH1=(65536-4000)/256;

  TL1=(65536-4000)%256;

  timecount++;

  if(timecount==250)

    {

      TR0=0;

      timecount=0;

      flag=1;

    }

  P0=dispcode[dispbuf[dispcount]];

  P2=dispbit[dispcount];

  dispcount++;

  if(dispcount==8)

    {

      dispcount=0;

    }

}