单片机考试报告.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
单片机考试报告

实验目的: 1、了解MCS-51单片机定时器/计数器的工作原理与工作方式; 2、掌握定时器/计数器T0和T1在定时器和计数器两中方式下的编程; 3、掌握单片机内部时钟频率和波形输出; 4、掌握使用Proteus进行单片机系统仿真的方法; 实验内容 使用定时器T0与计数器T1进行时,通过外部输入频率,单片机P0进行显示; 将定时器/计数器1设定为计数方式,定时器/计数器0设定为定时方式,通过定时对单片机频率进行扫描,输出到P0口用数码管显示出频率的数值,记录数据; 改变输入频率的大小,再次观察数码管的变化。 实验环境 PC机一台,Proteus仿真软件 KEIL uVision2软件 硬件电路接线图 说明:U1为频率输入,通过单片机和数码管显示频率的大小。 实验程序流程图 其工作原理如图l所示。该方法是使用单片机自带的计数器对输入脉冲进行计数,其好处是设计出的频率计系统结构和程序编写简单,成本低廉,不需要外部计数器,直接利用所给的单片机最小系统就可以实现。这种方法的缺陷是受限于单片机计数的晶振频率。本次设计使用的AT89S51单片机,将其内部定时/计数器Tl的功能设为定时。频率信号由T0端引入。由于检测一个由“1”到“0”的跳变需要两个机器周期。前一个机器周期测出“1”,后一个周期测出“0”。故输入时钟信号的最高频率不得超过单片机晶振频率的二十四分之一。而且由于定时不能达到ls,所以要多次引起片内定时器的溢出中断,由此会引起测频的误差。 实验程序清单 #include AT89X51.h unsigned char code dispbit[]={0xfe,0xfd,0xfb,0xf7,0xef,0xdf,0xbf,0x7f}; unsigned char code dispcod1[]={0xbf,0x86,0xdb,0xcf,0xe6,0xed,0xfd,0x87,0xff,0xef}; unsigned char code dispcode[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0x70,0x76,0x5b,0x00}; unsigned char dispbuf[8]={0,0,0,0,0,0,0,0}; unsigned char temp[8]; unsigned char dispcount; unsigned char T0count; unsigned char timecount; bit flag; unsigned long x,y; void chushihua(void) { TMOD=0x15; TH1=(65536-5000)/256; TL1=(65536-5000)%256; TR1=1; TR0=1; ET0=1; ET1=1; EA=1; } main() { unsigned char i; chushihua(); while(1) { if(flag==1) { flag=0; x=T0count*65536+TH0*256+TL0; y=x; dispbuf[0]=12; dispbuf[1]=11; if(x999) { dispbuf[0]=11; dispbuf[1]=10; } if(x499999) { x=888888; dispbuf[0]=8; dispbuf[1]=8; } for(i=0;i8;i++) { temp[i]=0; } i=2; while(x/10) { temp[i]=x%10; x=x/10; i++; } temp[i]=x; for(i=7;i2;i--) { if(temp[i]==0) { temp[i]=13; } else break; } for(i=2;i8;i++) { dispbuf[i]=temp[i]; } timecount=0; T0count=0; TH0=0; TL0=0; TR0=1; } } } void t0(void) interrupt 1 { T0count++; } void t1(void) interrupt 3 { TH1=(65536-5000)/256; TL1=(65536-5000)%256; timec

文档评论(0)

qwd513620855 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档