




已阅读5页,还剩14页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
目 录第一篇:51单片机C语言实验及实践教程_316位数显频率计数器第二篇:方波测频-频率计第三篇:单片机频率计程序第四篇: 单片机原理与应用实验报告51单片机C语言实验及实践教程_316位数显频率计数器发布: 2009-4-04 18:07|作者: 孙青安| 查看: 80次1 实验任务 电子园51单片机学习网6fu M!Q? f2WY利用AT89S51单片机的T0、T1的定时计数器功能,来完成对输入的信号进行频率计数,计数的频率结果通过8位动态数码管显示出来。要求能够对0250KHZ的信号频率进行准确计数,计数误差不超过1HZ。电子园51单片机学习网!p4L7o#?:t rm/v)Ev2 电路原理图 电子园51单片机学习网/NC)BA电子园51单片机学习网G2Y;O!W F7C%Ua)cj图4.31.1电子园51单片机学习网UF1vN 电子园51单片机学习网tjy*mnm3 系统板上硬件连线 电子园51单片机学习网 nV3DU#q(1) 把“单片机系统”区域中的P0.0P0.7与“动态数码显示”区域中的ABCDEFGH端口用8芯排线连接。电子园51单片机学习网YoW0T)m#N(2) 把“单片机系统”区域中的P2.0P2.7与“动态数码显示”区域中的S1S2S3S4S5S6S7S8端口用8芯排线连接。s7G0loPsX41921 (3) 把“单片机系统”区域中的P3.4(T0)端子用导线连接到“频率产生器”区域中的WAVE端子上。电子园51单片机学习网avqE(N5I,Es4 程序设计内容 *$lg48Hy41921 (1) 定时/计数器T0和T1的工作方式设置,由图可知,T0是工作在计数状态下,对输入的频率信号进行计数,但对工作在计数状态下的T0,最大计数值为fOSC/24,由于fOSC12MHz,因此:T0的最大计数频率为250KHz。对于频率的概念就是在一秒只数脉冲的个数,即为频率值。所以T1工作在定时状态下,每定时1秒中到,就停止T0的计数,而从T0的计数单元中读取计数的数值,然后进行数据处理。送到数码管显示出来。(2) T1工作在定时状态下,最大定时时间为65ms,达不到1秒的定时,所以采用定时50ms,共定时20次,即可完成1秒的定时功能。电子园51单片机学习网0E9r&K|R,NN#include 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; 电子园51单片机学习网IKSh2|aunsigned char T0count; unsigned char timecount; bit flag; unsigned long x; 电子园51单片机学习网Qk;sty)e9F.Evoid main(void) 电子园51单片机学习网)u#h+N8O%i.I unsigned char i; 电子园51单片机学习网s:3D8e ?r3H,k)m TMOD=0x15; 电子园51单片机学习网c/v2Su0p$fYe TH0=0; TL0=0; TH1=(65536-4000)/256; 电子园51单片机学习网5da$KSEi-|# TL1=(65536-4000)%256; TR1=1; TR0=1; ET0=1; 电子园51单片机学习网v%k(k8o1v9i0a0a s#| ET1=1; 电子园51单片机学习网BNl:Sbn EA=1; 电子园51单片机学习网;DH8tF while(1) 电子园51单片机学习网- n5N(v0Y if(flag=1) 电子园51单片机学习网E T4Vn H!1P 电子园51单片机学习网s3K9_1JttN8k flag=0; x=T0count*65536+TH0*256+TL0; 电子园51单片机学习网5I+r)|Gwv for(i=0;i8;i+) tempi=0; 电子园51单片机学习网y+z*1|6jS,v i=0; while(x/10) 电子园51单片机学习网Vdk&l4|(V tempi=x%10; 电子园51单片机学习网|-YJg R9K|E x=x/10; i+; 电子园51单片机学习网 N:Wz1R)x tempi=x; for(i=0;i6;i+) dispbufi=tempi; timecount=0; 电子园51单片机学习网?jG%sb T0count=0; TH0=0; TL0=0; 电子园51单片机学习网+A |+hmam TR0=1; 电子园51单片机学习网f EXPvye0p5EZ void t0(void) interrupt 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(wA TR0=0; 电子园51单片机学习网nN;w_R timecount=0; flag=1; 电子园51单片机学习网;kZ9f0&Z1.WC P0=dispcodedispbufdispcount; P2=dispbitdispcount; 电子园51单片机学习网OM+G#Z0c0o dispcount+; if(dispcount=8) 电子园51单片机学习网J5Q3sovt dispcount=0; 电子园51单片机学习网l #?:OhU3Y 方波测频-频率计2009-02-18 11:15完成功能:用查询的方法测一个方波的频率,并送数码管显示(P3.3输入1HZ方波,T1(P3.5)输入fx)测周期测频说明:这个题在做的时候,会出现一些问题,就是说当方波频率比较低的时候,会产生溢出,这样的数码管驱动就可能不对!按照老师的方法,我这里加进了一个原本程序没有的中断程序,其中我用红色标注,这样程序就能记低频,希望大家能自己验证一下。程序如下:#includeat89x52.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; /定义长整形全局变量f int s=0; void delay(void) /延时函数 uint i;for(i=0;i100;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;k4;k+) i=ledk; P0=ai; if(k= =1)P0|=0x80; /固定在第2个数码管输出一个小数点 P2=tvk; delay(); void kT1( void ) interrupt 3s+;TF1=0; /溢出清零 TH1=0; /寄存器清零 TL1=0; /寄存器清零 void main() EA=1; /CPU开放中断 ET1=1; /允许T1中断TMOD=0x10; /使T1工作在定时方式,用方式1 TH1=0; /寄存器清零 TL1=0; /寄存器清零 while(1) while(P3_5= =0); /等待一个低电平 while(P3_5= =1); /等待一个高电平 TR1=1; /允许T1开始定时 while(P3_5= =0); /等待一个低电平 while(P3_5= =1); /等待一个高电平 TR1=0; /关定时定时器T1 f=(TH18)+TL1+s*65536; /把T1定时送入变量fS=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, 0xFE,0xF6,0xEE,0x3E,0x9C,0x7A,0x9E,0x8E,0x00;/*8位数据缓冲器*/ unsigned char dispbuf8; unsigned char temp8; unsigned char dispcount; unsigned char T0count;unsigned char timecount;bit flag; unsigned long x; /*初始化模块*/void initial(void)TMOD=0x15; TH0=0;TL0=0;TH1=(65536-4000)/256;TL1=(65536-4000)%256;TR1=0;TR0=0;ET0=1;ET1=1;EA=1;/*/*显示模块*/void dataDisplay()unsigned char i; for(i=0;i8;i+)tempi=0;i=0;while(x/10) tempi=x%10; x=x/10; i+; tempi=x;for(i=0;i8;i+) dispbufi=tempi; P2=dispcodedispbufdispcount;P0=dispbitdispcount;dispcount+;if(dispcount=8) dispcount=0;/*/*信号频率测量模块*/float frequency(float freq)initial();TR0=1;TR1=1;if(timecount=250) TR0=0; freq=T0count*65536+TH0*256+TL0; return(freq); /*/ /*信号周期测量模块*/ float cycle(float count)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-4000)/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) x=frequency(x); if(x100) 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,0x00; /*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; T0count=0; ifStart=0; TR1=0; TR0=0; ET0=1; ET1=1; EA=1; /*/ /*显示模块*/ void dataDisplay() unsigned char i; for(i=0;i8;i+) tempi=0; i=0; while(x/10) tempi=x%10; x=x/10; i+; tempi=x; for(i=0;i=500) TR0=0;TR1=0;EA=0; freq=T0count*65536+TH0*256+TL0; initial(); ifStart=0; x=freq; dataDisplay(); /*/ 这个是运行正常的程序,不过只写了测频的,测周的没写完。 单片机原理与应用实验报告实验3:简单频繁计姓名院系计算机应用学号任课教师谭家兴指导教师谭家兴评阅教师谭家兴实验地点电子实验室实验时间2010 年6月 17日星期四实验目的:单片计算机即单片微型计算机。(Single-Chip Microcomputer ),是 集CPU ,RAM ,ROM ,定时,计数和多种接口于一体的微控制器。他体积小,成本低,功能强,广泛应用于智能产品和工业自动化上。而51单片机是各单片机中最为典型和最有代表性的一种。这次课程设计通过对它的学习,应用,从而达到学习、设计、开发软、硬的能力。实验要求:设计一个频率计,输入某个频率的信号.能用单片机检测出这个信号的频率.也就是统计一秒钟内收到多少个脉冲.实验原理:通过信号发生器产生一个信号.通过单片机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,0xa1,0x86,0x8e;/共阴极的数码管0f的段编码是这样的:unsigned char code table2=/共阴极0f数码管编码0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07, /470x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71;uint count=0; /定义脉冲计数变量sbit K1=P10;sbit K2=P17;void delay(uchar y) / 延时子程序 uchar x; while(y-)for(x=110;x0;x-); display(co
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年国网东北分部高校毕业生招聘(第二批)笔试参考题库附带答案详解
- 2025山东东营众邦人力资源有限责任公司招聘3人笔试参考题库附带答案详解
- 2025四川绵阳绵州酒店有限公司招聘客户经理等勤杂岗位31人笔试参考题库附带答案详解
- 2025中铁工程装备集团郑州招聘10人(河南)笔试参考题库附带答案详解
- 地铁乘客安全认知培训课件
- 危险作业环境安全培训课件
- 地质野外安全培训课件
- 固定资产概述课件
- 回顾拓展七课件
- 回转窑煅烧操作课件
- 电缆沟及盖板作业指导书培训课件
- GB/T 19867.6-2016激光-电弧复合焊接工艺规程
- GB/T 19478-2018畜禽屠宰操作规程鸡
- 三级教育考试卷(焊工)答案
- 无生上课课堂教学评价标准
- 深圳低压电工作业-实际操作培训课件-科目四-作业现场应急处理
- 植物生理学第十三章植物的逆境生理课件
- 中控岗位培训课件
- 宾馆酒店前台责任书
- 2.2 第2课时 基本不等式的综合应用(课件)高一数学(人教A版2019必修第一册)
- 勿忘国耻教学课件
评论
0/150
提交评论