基于单片机的数字频率计设计报告.docx

上传人:b****1 文档编号:2039117 上传时间:2023-05-02 格式:DOCX 页数:21 大小:204.77KB
下载 相关 举报
基于单片机的数字频率计设计报告.docx_第1页
第1页 / 共21页
基于单片机的数字频率计设计报告.docx_第2页
第2页 / 共21页
基于单片机的数字频率计设计报告.docx_第3页
第3页 / 共21页
基于单片机的数字频率计设计报告.docx_第4页
第4页 / 共21页
基于单片机的数字频率计设计报告.docx_第5页
第5页 / 共21页
基于单片机的数字频率计设计报告.docx_第6页
第6页 / 共21页
基于单片机的数字频率计设计报告.docx_第7页
第7页 / 共21页
基于单片机的数字频率计设计报告.docx_第8页
第8页 / 共21页
基于单片机的数字频率计设计报告.docx_第9页
第9页 / 共21页
基于单片机的数字频率计设计报告.docx_第10页
第10页 / 共21页
基于单片机的数字频率计设计报告.docx_第11页
第11页 / 共21页
基于单片机的数字频率计设计报告.docx_第12页
第12页 / 共21页
基于单片机的数字频率计设计报告.docx_第13页
第13页 / 共21页
基于单片机的数字频率计设计报告.docx_第14页
第14页 / 共21页
基于单片机的数字频率计设计报告.docx_第15页
第15页 / 共21页
基于单片机的数字频率计设计报告.docx_第16页
第16页 / 共21页
基于单片机的数字频率计设计报告.docx_第17页
第17页 / 共21页
基于单片机的数字频率计设计报告.docx_第18页
第18页 / 共21页
基于单片机的数字频率计设计报告.docx_第19页
第19页 / 共21页
基于单片机的数字频率计设计报告.docx_第20页
第20页 / 共21页
亲,该文档总共21页,到这儿已超出免费预览范围,如果喜欢就下载吧!
下载资源
资源描述

基于单片机的数字频率计设计报告.docx

《基于单片机的数字频率计设计报告.docx》由会员分享,可在线阅读,更多相关《基于单片机的数字频率计设计报告.docx(21页珍藏版)》请在冰点文库上搜索。

基于单片机的数字频率计设计报告.docx

基于单片机的数字频率计设计报告

目录

1前言2

2频率计原理3

3设计思想3

451单片机系统的硬件连接及调试3

5单元程序的设计5

5.11s定时5

5.2T1计数程序5

5.3频率数据采集6

5.4进制转换6

5.5数码显示8

6频率计系统总体程序10

7程序的调试10

8结束语11

参考文献12

 

智能数字频率计的设计

专业:

通信工程姓名:

***指导教师:

***

摘要:

采用单片机智能控制,结合外围电子电路,设计的智能数字频率计具有测量精度高,频率范围宽,稳定性好的特点,可应广泛用于各种测试场所。

关键词:

单片机,控制系统,仿真

Abstracts:

IntelligentControloftheuseofsingle-chip,combinedwiththeexternalelectroniccircuit,designofintelligentdigitalfrequencymeterwithameasurementofhighprecision,widefrequencyrange,stability,goodfeatures,canbewidelyusedinavarietyoftestsites。

Keywords:

Single-chip,controlsystems,simulation

1前言

单片机是20世纪中期发展起来的一种面向控制的大规模集成电路模块,具有功能强、体积小、可靠性高、价格低廉等特点,在工业控制、数据采集、智能仪表、机电一体化、家用电器等领域得到了广泛的应用,极大的提高了这些领域的技术水平和自动化程度。

51系列单片机是国内目前应用最广泛的一种8位单片机之一,随着嵌入式系统、片上系统等概念的提出和普遍接受及应用。

51系列及其衍生单片机还会在继后很长一段时间占据嵌入式系统产品的低端市场,因此,作为新世纪的大学生,在信息产业高速发展的今天,掌握单片机的基本结构、原理和使用是非常重要的。

本次课程设计主要用于对方波频率的测量。

2频率计原理

频率的测量实际上就是在1s时间内对信号进行计数,计数值就是信号频率。

用单片机设计频率计通常采用的办法是使用单片机自带的计数器对输入脉冲进行计数;好处是设计出的频率计系统结构和程序编写简单,成本低廉,不需要外部计数器,直接利用所给的单片机最小系统就可以实现。

缺陷是受限于单片机计数的晶振频率,输入的时钟频率通常是单片机晶振频率的几分之一甚至是几十分之一,在本次设计使用的98C51单片机,由于检测一个由“1”到“0”的跳变需要两个机器周期,前一个机器周期测出“1”,后一个周期测出“0”。

故输入时钟信号的最高频率不得超过单片机晶振频率的二十四分之一。

根据频率检测的原理,很容易想到利用51单片机的T0、T1两个定时/计数器,一个用来定时,另一个用来计数,两者均应该工作在中断方式,一个中断用于1s时间的中断处理,一个中断用于对频率脉冲的计数溢出处理。

3设计思想

明确频率计工作原理以后,为了思路更清晰地对程序编写,还应该作出程序的总体框图,如图3.1所示。

程序的主体可以分为4个模块:

定时计数、采集数据、进制转换和数码显示。

图3.1频率计系统总体框图

451单片机系统的硬件连接及调试

本次课程设计使用的单片机系统是根据老师提供的系统原件,自己焊接而成。

焊接完成以后,首先烧写控制LED发光二极管闪烁的程序后,发现发光二极管是根据自己的设计而闪烁,烧写程序控制发光数码管显示时,数码管同样是根据自己的设计而显示的字符,说明本次51单片机的硬件焊接取得成功。

此次设计要求制作一频率计系统,需要使用的硬件主要包括51单片机芯片,ZLG7290数码管管理芯片和数码管。

另外还是用到排线若干,下载线及电源线。

其中51单片机硬件链接如图4.1所示,ZLG7290芯片连接图如图4.2所示,数码管连接图如图4.3所示。

 

4.1图51单片机硬件连接图

 

图4.2ZLG7290硬件连接图

 

图4.3数码管硬件连接图

5单元程序的设计

5.11s定时

本次设计选用定时器T0完成定时功能,选用方式1时最多也只能定时,显然不能满足定时1

的要求,可以用下面这种方法解决:

采用T0定时10,连续循环定时100次即可完成1

定时,用一个计数单元20H存放循环的次数,每一次循环20H单元自减1,当20H单元为零时则1

定时到时。

5.2T1计数程序

设计中T1采用计数功能,需要注意的一个问题是,输入的待测时钟信号的频率最高可以达到460800Hz,但计数器最多只能计数65536次,显然需要对计数单元进行扩展,扩展的思路是除了计数器T1的TH1和TL1用于计数外,再选用一个计数单元23H,每当计数器T1溢出回零时产生中断,中断程序执行23H单元自增1,这样,当一秒到时时采集的计数数据,23H单元存放的是数据的最高位,TH1存放的是数据的次高位,TL1存放的是数据的最低位。

当然,这里所说的“最高位”“次高位”以及“最低位”都是针对十六进制而言的。

T1计数程序的流程图如图5.1所示。

 

图5.1T1计数流程图

5.3频率数据采集

到1

定时时,存储计数器T1以及扩充计数单元23H记录的数据即为输入时钟信号的频率,为了保证记录的频率精确度,到1

定时后应立即停止T1的计数,因为指令的执行也需要时间,并且待测的时钟信号频率越高,指令执行所需要的时间就越不能忽略,这里采用的指令为CLRTR1。

5.4进制转换

从计数器采集到的频率数据是十六进制的,如果直接把这些数据送给数码管显示显然很不直观,因此需要把这些数据向十进制转换。

转换的算法有两种,第一种算法的思想是对该十六进制数除以100,商为百位,余数再除以10,再得到的商为十位,余数为个位。

这种算法虽然程序的编写非常简单,但是它的局限性也非常明显,即它只能对不大于两位的十六进制数进行转换,对于大于两位的十进制数则无能为力。

这次设计的频率计频率范围远不止两位十六进制数就能记得下,所以这里采用第二种方法。

第二种方法算法的编程实现非常复杂,但是可以对任意长度的十六进制数向十进制转换。

这种算法的基本思路是:

第一步将最高位的高半字节提出来,除以10,把商存储起来,余数与最高位的低半字节组合成一个字节,再除以10,再存储商,余数以此类推,直到最后一次计算得到的余数即为十进制数的个位;第二步把第一步存储的商组合成一个字节,依次除以10,仍然把每次得到的商存储起来,以此类推最后一次得到的余数即为十进制数的十位;以后也是以此类推得到十进制数的百位、千位……以上算法必须要注意的一个为题是,每次得到的余数与低位的半字节组合成一个字节时,余数必须放在该字节的高半字节,否则计算错误。

该本次频率计系待测的时钟信号的最高频率为460800Hz,对应的十六进制数为70800H,这里就以70800H转换为十进制数为例来说明这种算法。

第一步:

用7H除以10,商0H余7H,把商0存储在24H单元,余数7H与下一个字节08H的高半字节0H组合成一个字节70H。

70H除以10,商BH余2H,把商BH存储在25H单元,余数2H与8H组合成一个字节28H。

28H除以10,商4H余0H,把商4H存储在26H单元,余数0H与0H组合成一个字节00H。

00H除以10,商0H余0H,把商0H存储在27H单元,余数0H与0H组合成一个字节00H。

00H除以10,商0H余0H,把商0H存储在28H单元,余数0即为所需十进制数的个位。

第二步:

把存储在24H与25H单元的商组合成一个字节0BH。

0BH除以10,同第一步,存储商,余数与下一个商组合成一个字节,再除以10,一次类推得到十进制数的十位0。

第三步:

方法同第二步,得到十进制数的百位8。

第四步:

方法同第三步,得到十进制数的千位0。

第五步:

方法同第四步,得到十进制数的万位6和十万位4。

最后得到了十进制数460800。

图5.2详细的展示了这种进制转换算法的过程。

 

图5.2进制转换说明图

5.5数码显示

将采集到的频率转换为十进制数后,还不能直接将这些数送给数码显示,因为七段LED数码管内部由7个条形发光二极管和一个小圆点发光二极管组成,根据各管的亮暗组合成字符。

本次设计所给数码管十进制数显示代码如下所示。

表5.1LED十进制字形显示代码表

0---------------------------FC1---------------------------60

2---------------------------DA3--------------------------F2

4---------------------------665--------------------------B6

6---------------------------BE7---------------------------E0

8---------------------------FE9---------------------------E6

 

将十进制数转换为相应的LED显示的代码,最容易实现的编程方法就是查表,因数码管最多只需要显示六位,只需要查六次表就可以了,图5.4是将十进制数对应的LED显示代码存入以60H为首单元的流程图。

 

 

图5.3十进制数转换为显示代码流程图

MOV@R1,A;把即将数码管显示的数据送入以60H为首的单元

DJNZR2,NEXT3

TAB:

DB0FCH,60H,0DAH,0F2H,66H,0B6H,0BEH,0E0H,0FEH,0F6H

得到十进制数的LED显示代码以后,就可以把这些代码送入数码管显示了,方法是50单片机先通过

通信的方式把显示代码发送给数码管管理芯片ZLG7290相应的显示区域,就可以通过数码管显示频率了。

51单片机通过

通信传送数据的过程如图5.5所示。

 

 

图5.4

通信过程框图

6频率计系统总体程序

各单元子程序已经设计完毕,将各子程序通过适当的指令链接起来,总程序的第一部分为T0、T1初始化,第二部分为1

定时,第三部分为计数,第四部分为采集频率,第五福分为进制转化,第六部分为数码显示,这几各部分即构成了频率计系统的总体程序,如附录所示。

7程序的调试

编写的频率计总体程序编译成HEX文件,烧写入51单片机内,P3.5角输入一定频率(较小)的时钟信号,观察数码管显示的频率与输入信号的频率相符,逐渐增大输入信号的频率,数码显示的频率开始出现误差,并且误差随着输入信号频率的增加而增加,当输信号达到频率计所允许输入的最高频率时,误差达到了650Hz,即误差

此误差很小可以认误差在允许的范围内,即频率计的计频功能满足要求。

另外在观察数码管显示的时候,发现高位的“0”仍然能够显示,而通常十进制的高位的“0”通常是省略的。

显示“0”的原因是没有考虑到频率值小于六位十进制数的情况,当频率小于六位十进制数时,传送到ZLG7290显示区的数据仍然是六位,高位由“0”填充,因此会出现高位显示“0”的情况。

为了解决这个问题,需要另外添加一段屏蔽高位的“0”的程序。

解决的思想是把高位“0”的个数记下,设为n,那么只需要传送给管理芯片的数据位数为6-n。

程序流程图如图7.1所示。

 

 

 

图7.1屏蔽高位“0”流程图

 

程序经过调试以后,数码管从高位第一位不为“0”的数开始显示。

至此,本次课程设计制作的频率计系统无论是计频功能还是显示功能都取得成功。

 

8结束语

本次课程设计有较强的综合性,不仅要求设计者能灵活使用单片机的各种指令,熟练使用单片计计数器余定时器,熟练编写顺序结构程序,循环结构程序以及分支结构程序,还要求对单片机的电路连接结构,对数码管管理芯片有明确清晰的了解与认识,否则在设计的第一步就会遇到障碍。

经过一个多星期的资料收集与查询,又经过几天的总体构思,再脑中对频率计的设计有了一个总体的框架,对程序的流程图也有一个基本的结构,最后结合参考资料,结合自己对单片机知识的认识,又经过两天对程序的编写以及程序的改进,最后终于完成了本次课程设计各各项内容。

通过设计学到了很多,例如面对问题要保持冷静,特别是在程序的编写这一块,要找出程序的错误一定要有一个冷静的头脑,否则很难发现错误甚至是越改越错。

另外我还认识到与他人合作的重要性,虚心向别人学习,吸取别人编写程序的一些好的风格与特点再融入到自己的程序中,都是一些不错的方法。

 

参考文献

[1]李群芳.单片微型计算机与接口技术(第二版).北京:

电子工业出版社,2005

[2]蒋立培.单片危机系统使用教程.北京:

机械工业出版社,2004

[3]凌玉华.单片机原理及应用系统设计.长沙:

中南大学出版社,2006

[4]王琼.单片机原理及应用实践教程.合肥:

合肥工业大学出版社,2005

[5]刘丹.例说8051.北京:

人民邮电出版社,2006

 

附录汇编源程序代码

;ydg于2001年,第1秒显示012345

;T0用于产生秒信号

;T1用于计数,溢出送5FH,1秒后取出,5FH-62H,TH1-61H,TL1-60H

;1MHZ频率计

P_B1EQUP3.7

P_B2EQUP3.1

P_B3EQUP3.0

P_B4EQUP3.2

P_B5EQUP3.3

P_B6EQUP3.4

ORG000H;

AJMPMAIN;转主程序

ORG00BH

AJMPT0_;转中断T0程序

ORG01BH;

AJMPT1_;转中断T1程序

ORG30H;

MAIN:

MOVSP,#20H;

MOVP1,#000H;

MOVP3,#0FFH;

MOVR0,#30H;首地址

MOVR1,#006;字节数

MOVA,#000H;首字节

KN:

MOV@R0,A;

INCR0;

INCA;

DJNZR1,KN;

ACALLT0_0;中断初始化

XS1:

CLRA;装显示第一位

MOVR0,#30H;

MOVA,@R0;

ACALLOUT;

CLRP_B1;

ACALLKL0;1位显示(高)

SETBP_B1;

INCR0;

MOVA,@R0;

ACALLOUT;

CLRP_B2;

ACALLKL0;2位显示

SETBP_B2;

INCR0;

MOVA,@R0;

ACALLOUT;

CLRP_B3;打开此位

ACALLKL0;3位显示

SETBP_B3;关闭此位

INCR0;

MOVA,@R0;

ACALLOUT;

CLRP_B4;

ACALLKL0;4位显示

SETBP_B4;

INCR0;

MOVA,@R0;

ACALLOUT;

CLRP_B5;

ACALLKL0;5位显示

SETBP_B5;

 

INCR0;

MOVA,@R0;

ACALLOUT;

CLRP_B6;打开此位

ACALLKL0;6位显示(低)

SETBP_B6;关闭此位

MOVP1,#00H;关显示器

AJMPXS1;

T0_:

DJNZ3AH,END_;中断最高位减一,不为零转结束

NOP;1000,000US时基修终正细调

CLRTR1;时间为1秒,关闭T1计数

MOV61H,TH1;读T1高位

MOV62H,TL1;读T1低位

MOVP1,#000H;关闭显示;

MOVP3,#0FFH;

ACALLT0_0;中断初始化

ACALLBINBCD;二进制转十进制数

NOP;(60H,61H,62H)(70H,71H,72H,73H)(77H)

ACALLBCD8H;双字节转单字节

NOP;73H74H75H=30H31H,32H33H,34H35H

ACALLH_0;高位无效0消隐

END_:

RETI

T1_:

INC60H;溢出次数加1=65535,最高字节

RETI;中断结束

T0_0:

MOV5FH,60H

MOV60H,#00H;计数最高位

NOP

MOV3AH,#01FH;中断最高位

MOVTMOD,#51H;T0T1初始化T0置模式1,16位定时,T1置模式1,16位计数

MOVTH0,#07BH;T0高位置初值H

MOVTL0,#094H;T0低位置初值L时基修终正粗调

MOVTH1,#00H;T1高位置初值H

MOVTL1,#00H;T1低位置初值L

SETBTR0;启动T0计数

SETBET0;允许T0中断

SETBTR1;启动T1计数

SETBET1;允许T1中断

SETBEA;CPU开放中断

RET;

OUT:

MOVP1,#00H

MOVDPTR,#TAB;

MOVCA,@A+DPTR;

MOVP1,A;输出

RET

;程序用途:

3字节数转换为BCD码

;入口:

(60H,61H,62H)为3字节24位二进制数从高到低

;出口:

(70H,71H,72H,73H)为转换的BCD码(压缩的BCD码),字节在数77H从高到低

BINBCD:

CLRA;A清零

MOV70H,A;70H清零

MOV71H,A;71H清零

MOV72H,A;72H清零

MOV73H,A;73H清零

MOV74H,A;74H清零

MOV75H,A;75H清零

MOV77H,#24;24位二进制

MOV60H,5FH

IBTL2:

CLRC;清进位位

MOVA,62H;二进制送累加器

RLCA;含进位循环左移

MOV62H,A;返回

MOVA,61H;二进制送累加器

RLCA;含进位循环左移

MOV61H,A;返回

MOVA,60H;二进制送累加器

RLCA;含进位循环左移

MOV60H,A;返回

MOVA,73H;

ADDCA,73H;

DAA;

MOV73H,A;

MOVA,72H;

ADDCA,72H;

DAA;

MOV72H,A;

MOVA,71H;

ADDCA,71H;

DAA;

MOV71H,A;

MOVA,70H;

ADDCA,70H;

DAA;

MOV70H,A;

DJNZ77H,IBTL2;

NOP;

RET;一字节转换为二字节

BCD8H:

SETBRS0

MOVR0,#71H;原码位置

MOVR1,#30H;BCD码位置

MOVR2,#03H;原码字数

HH:

MOVA,@R0;

SWAPA;

ANLA,#0FH;

MOV@R1,A;

INCR1;BCD码加一

MOVA,@R0;

ANLA,#0FH;

MOV@R1,A;

INCR0;原码加一

INCR1;BCD码加一

DJNZR2,HH;

CLRRS0

RET;

H_0:

SETBRS1

MOVR0,#2FH

MOVR1,#05H;

H_1:

INCR0

MOVA,@R0;

JZH_2;

AJMPH_3

H_2:

MOVA,#0AH

MOV@R0,A;

DJNZR1,H_1

H_3:

CLRRS1

RET

KL0:

MOVR6,#005H;

KL1:

MOVR7,#0FFH;

KL2:

DJNZR7,KL2;

DJNZR6,KL1;

RET

 

TAB:

DB3FH,06H,5BH,4FH,66H;0,1,2,3,4,

DB6DH,7DH,07H,7FH,6FH;5,6,7,8,9,

DB80H;灭

END

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 工程科技 > 能源化工

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2