单片机测量频率+c语言大全_第1页
单片机测量频率+c语言大全_第2页
单片机测量频率+c语言大全_第3页
单片机测量频率+c语言大全_第4页
单片机测量频率+c语言大全_第5页
已阅读5页,还剩16页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、目 录第一篇:51单片机C语言实验及实践教程_316位数显频率计数器第二篇:方波测频-频率计第三篇:单片机频率计程序第四篇: 单片机原理与应用实验报告51单片机C语言实验及实践教程_316位数显频率计数器发布: 2009-4-04 18:07 |  作者: 孙青安 |   查看: 80次1      实验任务 电子园51单片机学习网6fu M!Q? f2WY利用AT89S51单片机的T0、T1的定时计数器功能,来完成对输入的信号进行频率计数,计数的频率结果通过8位动态数码管显示出来。要

2、求能够对0250KHZ的信号频率进行准确计数,计数误差不超过±1HZ。电子园51单片机学习网!p4"L7o#?:t rm/vEv2      电路原理图 电子园51单片机学习网/NCBA电子园51单片机学习网G2Y;O!W F7C%Uacj图4.31.1电子园51单片机学习网UF1vN  电子园51单片机学习网tj"y*mnm3      系统板上硬件连线 电子园51单片机学习网 nV3DU#q(1)    

3、0;       把“单片机系统”区域中的P0.0P0.7与“动态数码显示”区域中的ABCDEFGH端口用8芯排线连接。电子园51单片机学习网Y"oW0"Tm#N(2)            把“单片机系统”区域中的P2.0P2.7与“动态数码显示”区域中的S1S2S3S4S5S6S7S8端口用8芯排线连接。s7G0loPs"X41921 (3)    &#

4、160;       把“单片机系统”区域中的P3.4(T0)端子用导线连接到“频率产生器”区域中的WAVE端子上。电子园51单片机学习网"av"qE(N5I,Es4      程序设计内容 *$lg48Hy41921 (1)            定时/计数器T0和T1的工作方式设置,由图可知,T0是工作在计数状态下,对输入的频率信号进行计数,但对工作在计

5、数状态下的T0,最大计数值为fOSC/24,由于fOSC12MHz,因此:T0的最大计数频率为250KHz。对于频率的概念就是在一秒只数脉冲的个数,即为频率值。所以T1工作在定时状态下,每定时1秒中到,就停止T0的计数,而从T0的计数单元中读取计数的数值,然后进行数据处理。送到数码管显示出来。(2)            T1工作在定时状态下,最大定时时间为65ms,达不到1秒的定时,所以采用定时50ms,共定时20次,即可完成1秒的定时功能。电子园51单片机学习网0E9r&K

6、|R,NN#include <reg52.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 dispbuf8=0,0,0,0,0,0,10,10; unsigned char temp8; 电子园51单片机学习网U i3A$ He+Wunsigned char dispcount; 电子

7、园51单片机学习网IK"Sh2|aunsigned char T0count; unsigned char timecount; bit flag; unsigned long x; 电子园51单片机学习网Qk;stye9F.Evoid main(void 电子园51单片机学习网u#h+N8O%i.Iunsigned char i; 电子园51单片机学习网s:3D8e ?r3H,kmTMOD=0x15; 电子园51单片机学习网c/v2Su0p$fYeTH0=0; TL0=0; TH1=(65536-4000/256; 电子园51单片机学习网"5da$KSEi-|#TL1=(

8、65536-4000%256; TR1=1; TR0=1; ET0=1; 电子园51单片机学习网v%k(k8o1v9i0a0a s#|ET1=1; 电子园51单片机学习网BNl:SbnEA=1; 电子园51单片机学习网;D"H8tF'while(1 电子园51单片机学习网- n5N(v0Y if(flag=1 电子园51单片机学习网E T4Vn H!1P 电子园51单片机学习网s3K9_1JttN8kflag=0; x=T0count*65536+TH0*256+TL0; 电子园51单片机学习网5I+r|Gwvfor(i=0;i<8;i+ tempi=0; 电子园51单

9、片机学习网y+z*1|6jS,v i=0; while(x/10 电子园51单片机学习网V'dk&l4|(Vtempi=x%10; 电子园51单片机学习网|-YJg R9K|Ex=x/10; i+; 电子园51单片机学习网 N:Wz1Rx tempi=x; for(i=0;i<6;i+ dispbufi=tempi; timecount=0; 电子园51单片机学习网?jG%sbT0count=0; TH0=0; TL0=0; 电子园51单片机学习网+A |+hmamTR0=1; 电子园51单片机学习网f EXPvye0p5E"Z void t0(void int

10、errupt 1 using 0 电子园51单片机学习网C3c Z Z8-kc_ T0count+; void t1(void interrupt 3 using 0 TH1=(65536-4000/256; TL1=(65536-4000%256; timecount+; if(timecount=250 电子园51单片机学习网8U V;L&xKt 电子园51单片机学习网 Ea g/OxB(wATR0=0; 电子园51单片机学习网nN;w_Rtimecount=0; flag=1; 电子园51单片机学习网;kZ9f0&Z1.WCP0=dispcodedispbufdispco

11、unt; P2=dispbitdispcount; 电子园51单片机学习网OM+G#Z0c0odispcount+; if(dispcount=8 电子园51单片机学习网J5Q3sovt dispcount=0; 电子园51单片机学习网l #?:O"hU3Y 方波测频-频率计2009-02-18 11:15完成功能:用查询的方法测一个方波的频率,并送数码管显示(P3.3输入1HZ方波,T1(P3.5)输入fx)测周期测频说明:这个题在做的时候,会出现一些问题,就是说当方波频率比较低的时候,会产生溢出,这样的数码管驱动就可能不对!按照老师的方法,我这里加进了一个原本程序没有的中断程序,

12、其中我用红色标注,这样程序就能记低频,希望大家能自己验证一下。程序如下:#include"at89x52.h" /头文件#define uchar unsigned char#define uint unsigned intuchar code tv=0xfe,0xfd,0xfb,0xf7;uchar code a=0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0x77,0x7c;uchar data led4;unsigned long int data f; /定义长整形全局变量fint s=0;void delay

13、(void /延时函数uint i;for(i=0;i<100;i+;ledxianshi( /显示函数,也就是数码管驱动uchar k,i;led0=f/10000; /取万位数(可能不够,可加)led1=f%10000/1000; /取千位数led2=f%1000/100; /取百位数led3=f%100/10; /取十位数led4=f%10; /取个位数for(k=0;k<4;k+ i=ledk;P0=ai;if(k= =1P0|=0x80; /固定在第2个数码管输出一个小数点P2=tvk;delay(; void kT1( void interrupt 3s+;TF1=0;

14、 /溢出清零TH1=0; /寄存器清零TL1=0; /寄存器清零void main( EA=1; /CPU开放中断ET1=1; /允许T1中断TMOD=0x10; /使T1工作在定时方式,用方式1TH1=0; /寄存器清零TL1=0; /寄存器清零while(1while(P3_5= =0; /等待一个低电平while(P3_5= =1; /等待一个高电平TR1=1; /允许T1开始定时while(P3_5= =0; /等待一个低电平while(P3_5= =1; /等待一个高电平TR1=0; /关定时定时器T1f=(TH1<<8+TL1+s*65536; /把T1定时送入变量fS

15、=0;f=100000000/f; /f=1000000L/f; /周期的倒数是频率while(1 /死循环 ledxianshi(;单片机频率计程序2009-03-03 13:21#include /*数码管位代码表(P0口*/unsigned char code dispbit=0xfe,0xfd,0xfb,0xf7,0xef,0xdf,0xbf,0x7f;/*数码管段代码表(P2口,共阴且高位接a,低位接h笔段*/   unsigned char code dispcode=0xFC,0x60,0xDA,0xF2,0x66,0xB6,0xBE,0xE0, &

16、#160;                             0xFE,0xF6,0xEE,0x3E,0x9C,0x7A,0x9E,0x8E,0x00;/*8位数据缓冲器*/           

17、0;                               unsigned char dispbuf8;             unsigned char temp8;&

18、#160;                 unsigned char dispcount;                 unsigned char T0count;unsigned char timecount;bit flag;   

19、0;               unsigned long x; /*初始化模块*/void initial(voidTMOD=0x15;                    TH0=0;TL0=0;TH1=(65536-4000/256;TL1=(65536-40

20、00%256;TR1=0;TR0=0;ET0=1;ET1=1;EA=1;/*/*显示模块*/void dataDisplay(unsigned char i;   for(i=0;i<8;i+tempi=0;i=0;while(x/10   tempi=x%10;   x=x/10;   i+;    tempi=x;for(i=0;i<8;i+   dispbufi=tempi;      

21、    P2=dispcodedispbufdispcount;P0=dispbitdispcount;dispcount+;if(dispcount=8   dispcount=0;/*/*信号频率测量模块*/float frequency(float freqinitial(;TR0=1;TR1=1;if(timecount=250   TR0=0;   freq=T0count*65536+TH0*256+TL0;      return(freq;

22、   /*/ /*信号周期测量模块*/ float cycle(float countinitial(;if(P3_4=1   TR0=1;TR1=1;   if(P3_4=0    TR0=0;        count=1000000/(timecount*4000+TH1*256+TL1-61536;           return(count; /*/ /*定时中断服

23、务程序1*/void t1(void interrupt 3 using 0/initial(;/TR0=1;/TR1=1;TH1=(65536-4000/256;TL1=(65536-4000%256;timecount+; /*/*定时中断服务程序2*/void t0(void interrupt 1 using 0/initial(;/TR0=1;/TR1=1;T0count+;/*/*主函数*/void main(voidwhile(1     x=frequency(x;   if(x<100  &

24、#160; x=cycle(x;      dataDisplay(; /*/回复匿名网友:#include /*数码管位代码表(P0口*/ unsigned char code dispbit=0xfe,0xfd,0xfb,0xf7,0xef,0xdf,0xbf,0x7f; /*数码管段代码表(P2口,共阴且高位接a,低位接h笔段*/ unsigned char code dispcode=0xFC,0x60,0xDA,0xF2,0x66,0xB6,0xBE,0xE0, 0xFE,0xF6,0xEE,0x3E,0x9C,0x7A,0x9E,0x8E,0

25、x00; /*8位数据缓冲器*/ unsigned char dispbuf8; unsigned char temp8; unsigned char dispcount; unsigned long T0count; unsigned long timecount; long freq; /bit flag; unsigned long x; bit ifStart=0; /*初始化模块*/ void initial(void TMOD=0x15; TH0=0; TL0=0; TH1=(65536-4000/256; TL1=(65536-4000%256; timecount=0; T0c

26、ount=0; ifStart=0; TR1=0; TR0=0; ET0=1; ET1=1; EA=1; /*/ /*显示模块*/ void dataDisplay( unsigned char i; for(i=0;i<8;i+ tempi=0; i=0; while(x/10 tempi=x%10; x=x/10; i+; tempi=x; for(i=0;i<8;i+ dispbufi=tempi; P2=dispcodedispbufdispcount; P0=dispbitdispcount; dispcount+; if(dispcount=8 dispcount=0;

27、 /*/ /*信号频率测量模块*/ void frequency(void initial(; TR0=1;TR1=1; /*/ /*信号周期测量模块*/ /*void cycle( initial(; if(P3_4=1 TR0=1;TR1=1; if(P3_4=0 TR0=0; count=1000000/(timecount*4000+TH1*256+TL1-61536; return(count; */ /*/ /*定时中断服务程序1*/ void t1(void interrupt 3 using 0 /initial(; /TR0=1; /TR1=1; TH1=(65536-400

28、0/256; TL1=(65536-4000%256; timecount+; /*/ /*定时中断服务程序2*/ void t0(void interrupt 1 using 0 /initial(; /TR0=1; /TR1=1; T0count+; /*/ /*主函数*/ void main(void while(1 frequency(; if(!ifStart ifStart=1; if(timecount>=500 TR0=0;TR1=0;EA=0; freq=T0count*65536+TH0*256+TL0; initial(; ifStart=0; x=freq; da

29、taDisplay(; /*/ 这个是运行正常的程序,不过只写了测频的,测周的没写完。 单片机原理与应用实验报告实验3:简单频繁计姓名院系计算机应用学号任课教师谭家兴指导教师谭家兴评阅教师谭家兴实验地点电子实验室实验时间2010 年6月 17日星期四实验目的:单片计算机即单片微型计算机。(Single-Chip Microcomputer ),是 集CPU ,RAM ,ROM ,定时,计数和多种接口于一体的微控制器。他体积小,成本低,功能强,广泛应用于智能产品和工业自动化上。而51单片机是各单片机中最为典型和最有代表性的一种。这次课程设计通过对它的学习,应用,从而达到学习、设计、开发软、硬的能

30、力。实验要求:设计一个频率计,输入某个频率的信号.能用单片机检测出这个信号的频率.也就是统计一秒钟内收到多少个脉冲.实验原理:通过信号发生器产生一个信号.通过单片机3.5端口(外部中断0接收.把外部中断0设置成下降沿触发方式.统计收到的脉冲个数,把定时计数器0设置成方式1(13位定时器.通过一个按钮启动定时器0和外部中断0,定时器开始计时.外部中断0开始计数,一秒钟后用数码管显示中断收到的脉冲个数实验过程中遇到的问题以及如何解决的?实验中由于信号发生器产生的信号电压过低,外部中断端口未能识别收到的脉冲数,后来提高电压后正常接收数码管显示的时候.未能正常显示数的各个位,经过反复调试还是显示出来了仿真软件显示效果:一秒钟后按下按钮后显示的结果:流程图:源代码:#include / 头文件端口声明#define uchar unsigned char /变量宏定义#define uint unsigned intunsigned char code table1= /共阳极0f数码管编码0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0x88,0x83,0xc6,0

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

最新文档

评论

0/150

提交评论