![微机原理—计数器_第1页](http://file2.renrendoc.com/fileroot_temp3/2021-4/18/63a88125-d1be-4d49-b036-a79fe50de621/63a88125-d1be-4d49-b036-a79fe50de6211.gif)
![微机原理—计数器_第2页](http://file2.renrendoc.com/fileroot_temp3/2021-4/18/63a88125-d1be-4d49-b036-a79fe50de621/63a88125-d1be-4d49-b036-a79fe50de6212.gif)
![微机原理—计数器_第3页](http://file2.renrendoc.com/fileroot_temp3/2021-4/18/63a88125-d1be-4d49-b036-a79fe50de621/63a88125-d1be-4d49-b036-a79fe50de6213.gif)
![微机原理—计数器_第4页](http://file2.renrendoc.com/fileroot_temp3/2021-4/18/63a88125-d1be-4d49-b036-a79fe50de621/63a88125-d1be-4d49-b036-a79fe50de6214.gif)
![微机原理—计数器_第5页](http://file2.renrendoc.com/fileroot_temp3/2021-4/18/63a88125-d1be-4d49-b036-a79fe50de621/63a88125-d1be-4d49-b036-a79fe50de6215.gif)
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、目 录1.计数器的发展、应用及前景1.1概述计数器是一种基础测量仪器,到目前为止已有30多年的发展史。早期,设计师们追求的目标主要是扩展测量范围,再加上提高测量精度、稳定度等,这些也是人们衡量电子计算器的技术水平,决定电子计数器价格高低的主要依据。目前这些基本技术臻完善,成熟。应用现代技术可以轻松地将电子计数器的测频上限扩展到微波频段。 1.2基础知识简介电子计数器是一种多功能的电子测量仪器。它利用电子学的方法测出一定时间内输入的脉冲数目,并将结果以数字形式显示出来。通常电子计数器按照它的功能可分为以下三类:(1)通用计数器是利用数字电路技术数出给定时间内所通过的脉冲数并显示计数结果的数字化仪
2、器。通用计数器是其他数字化仪器的基础。在它的输入通道接入各种模-数变换器,再利用相应的换能器便可制成各种数字化仪器。通用计数器特点:测量精度高、量程宽、功能多、操作简单、测量速度快、直接显示数字,而且易于实现测量过程自动化。通用计数器按功能可分3类:1、频率计数器:专门用于测量高频和微波频率的计数器。2、计算计数器:具有计算功能的计数器,可进行数学运算,可用程序控制进行测量计算和显示等全部工作过程3、微波计数器:是以通用计数器和频率计数器为主配以测频扩展器而组成的微波频率计。应用领域:通用计数器在工业生产和科学实验中得到广泛应用。(2)频率计数器电子工程师经常需要测量频率、时间间隔、相位和对事
3、件计数,精确的测量离不开频率计数器或它的同类产品,如电子计数器和时间间隔分析仪。这些仪器为研发提供高精度和分析能力,为大批量生产提供高效率并为维修提供低成本和便携性。最早的电子计数器是为了对诸如原子现象之类的事情进行计数而设计出来的。在发明计数器之前,频率的测量都是用频率计(一种精度很低的协调装置)完成。频率计数器是以数字方式对信号参数进行精密测量的首批仪器之一。衡量频率计数器主要指标是测量范围、测量功能、精度和稳定性,这些也是决定价格高低的主要依据。随着电子测试技术的发展,频率计数器日趋成熟。目前,频率计数器已经能轻松测量射频、微波频段信号。除频率测量外,大多数频率计数器还综合了以下功能:频
4、率比、时间间隔、周期、上升/下降时间、相位、占空比、正/负脉冲宽度、总和、峰值电压以及时间间隔平均等。频率计功能延伸的最高境界就是综合了调制域分析仪的功能。(3)计算计数器一种带微处理器的具有计算功能的计数器,除了具有通用计数器的功能之外,能进行数学运算,求解比较复杂的方程式,可靠程序控制进行测量计算和显示等全部工作。 (4)频率计数器以通用计数器或频率计数器为主体,配以测频扩展器而组成的微波频率计。它的测频上限已进入毫米波段,有手动、半自动、全自动三类。系列化微波计数器是电子计数器发展的一个重要方向。 频率扩展技术将微波测频转换为较低的测频,按其原理主要有置换法、取样法和变频法等。各种方法的
5、主要性能评定项目包括测量速度、准确度、灵敏度、动态范围、允许信噪比、允许调频量、允许调幅量和幅度甄别等。 置换法:利用零拍原理,用与被测频率fx有一定关系的低频f0来置换fx,用计数器测出f0,从而求出fx。这种方法灵敏度高、动态范围大、允许调幅量大、幅度甄别显示最强分量,测量上限频率达26吉赫。 取样法:以取样技术为基础,应用锁相原理将微波频率转换为低频来测量。它兼具置换法和变频法的优点,但测量频率上限受微波取样技术的限制。 变频法:利用变频技术,将微波频率与频标谐波差频变换成低频,测量低频而算出被测频率。变频法的优点是允许信噪比高,允许调频量大,幅度甄别显示最弱分量等。2.设计要求利用82
6、53定时/计数器和8255接口电路,设计一个十进制计数器,对外部事件进行计数,计满100即清0,并在八个发光二极管或七段led.显示器上显示计数值。按下开关k0开始对外部事件计数,按下开关k1停止计数,按下开关k2显示器清零.2.1设计目的2.1.1 进一步撑握8255可编程并行接口芯片的工作原理及控制led显示电路的编程方法。2.1.2 进一步撑握8253定时器计数器的工作原理和编程方法。2.2 设计意义课程设计是计算机应用、电子类专业较重要的一个实践性环节。 其目的和作用是使学生能将已学过的模拟电路、数字电路、微机原理与接口技术、eda等知识综合运用于电子系统的设计中,从而培养学生对电子系
7、统的设计能力,这是在所有实践性课程中最具活力,最能培养学生的自主学习、实践能力,最能培养学生创新思维的实践课程之一。同时课程设计是对学生的一种基本素质训练较好方式。通过课程设计,使学生能运用已学过的计算机软件硬件知识来进行微机接口应用系统开发和调试。了解微机接口应用开发的全过程:分析需求,设计原理图,选用元器件,布线,编程,调试,撰写报告等。培养学生的动手能力和解决实际问题的能力,为今后从事微机接口应用和开发方面的工作打下坚实的基础3.硬件设计3.1设计方案3.1.1 系统框图及其描述(1) 系统框图如图1所示开始/暂停开关清零开关gate0out0clk0cpuad0-ad15io/rdio
8、/wr8253d0-d7rdwra1a08255d7-d0 pa口 pb0 pb1rdwr pc3-pc5a1a0cs74ls138地址译码器74ls138地址译码器数码管 系统框图 图 1(2) 系统框图描述8086通过地址译码器选中8253、8255芯片,通过数据总线d0d7对8253及8255进行数据的读写 。8253的定时器0工作在方式3,clk1接外部事件(单脉冲),gate0接开关k0,控制计数器的开始和暂停。outo接pb0。8255的pa、pb、pc三个端口均工作于方式0,pa、pc作为输出口,pb作为输入口。pc口通过3-8译码器选中对应的数码管,pb0接out0的输出,检测
9、电平的跳变从而实行计数,pb1接开关k1,对清零信号进行检测。pa0pa7接数码管的led-aled-dp,控制数码管数字的显示。3.1.2方案实现原理设定计时器0工作在方式3,计数器初值设定为2,外部事件脉冲通过计数器0clk0输入,将out0接到pb0,外部事件每触发一次,则在outo上发生一次电平的跳变,8086通过检测pb0口累计电平的跳变的次数,将值存放在寄存器cl中,每当cl中的值等于10,将ch中的值加1,实现十进制的进位,最后通过查表,将cl和ch的值显示到对应的数码管中。开关k0通过gate0控制计数器的工作状态,实现开始和暂停的功能,开关k1通过控制pb1端口的电平实现清零
10、的功能。3.2硬件原理3.2.1硬件原理图 硬件原理图 图 23.2.2硬件原理图描述(1)外部连线 8086通过地址总线a3a7接地址译码器输入端,y1(f210h)接8253片选,y3(f218h)接8255片选。8253计数器0clk0接单脉冲触发器(外部事件),out0接8255pb0,pb1接开关k1,gate0接开关k0,8255pc3pc5分别接 led-saled-sc,8255pa0pa7分别接led-aled-dp。(2)原理图描述 8086的地址线低位接在地址译码器74ls138上,8253、8255的片选端都接在地址译码器的输出上,从而决定了8253、8255的各端口地
11、址。从图上可以看出8253的片选地址是f210h,8255的片选地址 是f218h。8086的数据总线与8255、8253的数据端接起来,对8253及8255进行数据读写。8086将运算结果送到pa端口上,实现计数器的功能。3.3模块电路的介绍及分析3.3.1 8253芯片(1)8253的引脚及其功能8253是双列直插式24脚芯片,标准封装为dip24,引脚如图(2)8253的内部结构intel 8253芯片由数据总线缓冲器(8位)、读/写控制逻辑电路、控制字寄存器和3个结构完全相同的计数器组成。数据总线缓冲器用于将8253与系统数据总线相连,cpu读写8253的所有数据都经过这个缓冲器,包括
12、cpu写入方式控制字、cpu写入计数值和cpu读出计数值。读/写控制逻辑电路接收来自系统总线的输入信号,将其转换成8253内部的操作和控制信号,选择读写操作对象,决定内部总线上数据的传送方向。控制字寄存器接收来自cpu的方式控制字,控制相应计数器的工作方式。三个独立的计数器通道计数器0、计数器1和计数器2都是16位减1计数器,减1操作由每个计数器/定时器的时钟输入脉冲下降沿触发启动。与16位减1计数器对应的还有一个16位预置寄存器和输出锁存器。预置寄存器存放计数初值,输出锁存器用于写入锁存命令时锁定当前计数值。每个计数器在clk输入频率一定的情况下,可编程gate的控制方式和out的输出方式生
13、成6种信号发生器: 基本计数器, 可重复触发的单稳态触发器, 分频器, 方波发生器, 软件触发的选通信号发生器, 硬件触发的选通信号发生器。 8253引脚图 图 3 8253引脚功能图 图 4(3)8253方式控制字 8253的控制字包括4项不同的编程信息:d7 d6 d5 d4 d3 d2 d1 d0sc1sc0rw1rw0m2m1m0bcd 计数器选择 读写格式 工作方式选择 数制计数器选择:00为计数器0,01为计数器1,10为计数器2,11为非法。读写格式:00为计数器锁存命令,01为只读写低字节,10为只读写高字节,11为先读写低字节,再读写高字节。工作方式选择:由3位确定6种工作方
14、式。000为方式0,001为方式1,x10为方式2,x11为方式3,100为方式4,101为方式5。数制:0为二进制计数,1为bcd计数。3.3.2 8255芯片(1)8255的引脚及其功能8255是双列直插式40脚芯片,标准封装为dip40,引脚如图(2)8255的内部结构 8255a由数据总线缓冲器、读/写控制逻辑电路、a组和b组控制电路以及数据端口a、b和c组成。数据总线缓冲器是8255a与系统数据总线的接口,cpu输入输出的数据、cpu输出的控制字和外设的状态信息都是通过这个缓冲器传送的。读/写控制逻辑电路把cpu的控制命令或输出数据送至相应的端口,把外设的状态信息或输入数据通过相应的
15、端口送至cpu。数据端口pa和pb都包含一个8位输出锁存器/缓冲器和一个8位输入锁存器,pc口包含一个8位输出锁存器/缓冲器和一个8位输入缓冲器(不锁存输入信号)。在工作方式1或方式2下,pc口分成高4位和低4位两个输入口作为pa和pb的控制信号输出或状态信号输入。、a、a、和决定端口的地址。 8255引脚图 图 5 8255引脚功能图 图 6(3)8255方式控制字方式控制字方式控制字决定端口a、b和c的工作方式 。 按位操作控制字端口c的任一位可用这个控制字来置位或复位。3.3.3 74ls138译码器74ls138是38译码器,本设计中利用它来做地址译码以及数码管的位选。通过它选中825
16、3和8255的片选端以及应该显示字符的数码管1.1.1 8086芯片 8086通过数据总线、地址总线、控制总线完成对8253和8255的读写工作,与接口部件实现数据传送,让接口部件实现预计的功能4.软件设计 4.1 程序流程图 4.1.1 主程序流程图如图7 4.1.2 脉冲累计模块如图8 4.1.3 显示模块如图9 4.2 框图描述 4.2.1主程序框图描述(1)8253及8255的初始化,将00010110b写入8253控制字,设置定时器0工作在方式3,将10000010b写入8288控制字,设置pa、pc口为输出口,pb口为输入口。(2)判断清零开关k0是否为高电平,若是,则清零;若否,
17、则继续。(3)判断暂停开关k1是否为低电平,若是,则暂停;若否,则继续。(4)累积外部事件触发的次数,将个位值存储在cl中,将十位值存储在ch中。(5)通过查表,将cl和ch中的值显示到数码管中。 4.2.2 脉冲累计模块程序框图描述 检测pb.0端口是否有电平跳变,如有,将cl中的值加1,然后判断ch中的值是否为10,若是,将cl中的值清零,同时将ch中的值加1,再判断ch中的值是否为10,若是,将ch中的值清零,最后通过查表,将cl和ch中的值显示到数码管中。4.2.3 显示模块程序框图描述 通过pc.3pc.5选择数码管1,通过查表将cl中的值显示到数码管1中,调用延时程序,再选择数码管
18、你2,通过查表将ch中的值显示到数码管2中。n开始8253初始化 定时器0工作在方式38255初始化 b口输入,a,c口输出pb.1=1gate0=1清零累计脉冲跳变的次数显示在数码管上nyy 主程序流程图 图 7 ch=10检测脉冲是否有跳变nyyy显示到数码管ch=0cl=0,ch加1cl=10cl加1n 脉冲累计值模块显示模块选择数码管1,并将cl值读到pa口延时选择数码管2,并将ch值读到pa口延时 n 显示模块流程图 图 9 脉冲累计模块流程图 图 84.3 源程序4.3.1 程序代码;-;for eat598;8253 8255电子计数器(099);-p53_ctl equ 213
19、h ;8253的控制端口地址timer0 equ 210h ;8253的计数器0端口地址mode03 equ 00010110b ;8253的计数器0工作方式3p55_ctl equ 21bh ;8255的控制端口地址p8255a equ 218h ;8255的a口地址p8255b equ 219h ;8255的b口地址p8255c equ 21ah ;8255的c口地址;- 8253和8255端口初始化 -data segment save db 01hdata endscode segment assume cs:code,ds:datastart: mov ax,0 mov cx,0ff
20、h待添加的隐藏文字内容2 mov ax,data mov ds,ax cli mov dx, p53_ctl mov al,mode03 ;定时器0工作于方式3 out dx,al mov dx,timer0 mov al,02h out dx,al mov dx, p55_ctl mov al,82h ;设定8255的工作方式0,b口输入,a,c口输出 out dx,al;- 判定清零开关是否按下 -ks: mov dx,p8255b ;读取pb.1端口,判定是否清零 in al,dx and al,02h cmp al,02h jnz tj mov cx,0 call disp jmp k
21、s ;- 累计外部事件 - tj: mov dx,p8255b ;检测是否有脉冲是否有跳变 in al,dx and al,01h cmp save,al mov save,al je display inc cl ;脉冲下降沿,cl加1 cmp cl,10 ;到十回零,同时向高位进位 jnz display mov cl,0 inc ch cmp ch,10 jnz display mov ch,0display : call disp jmp ks ;- 数码管显示 -disp proc push cs pop ds mov al,00h ;选择第一个数码管 mov dx , p8255c
22、 out dx, al mov al, cl lea bx, led xlat mov dx, p8255a out dx ,al call delay mov al,08h ;选择第二个数码管 mov dx, p8255c out dx, al mov al, ch lea bx, led xlat mov dx ,p8255a out dx, al call delay retdisp endp;- 延迟程序 -delay proc push cx mov cx,1000h loop $ pop cx retdelay endp ;- 查表 - led : db 3fh,06h,5bh,4
23、fh,66h,6dh,7dh,07h,7fh,6fh ;数码管显示所要查的表 code ends end start 4.3.2 子程序入口参数和出口参数说明(1)显示子程序中,个位数和十位数的入口参数分别是cl和ch(2)延时子程序中,循环的次数的入口参数cx5. 系统调试及分析5.1硬件调试5.11 8253的调试将clk0接150hz的频率源,outo接clk1,out1接clk2。clk0,outo,out1,out2分别接l1,l2,l3,l4,观测这四个led灯亮灭情况,如果8253运行正常的话,l2灯亮灭的频率是1hz,每当l1亮灭10后,l3灯灭一次,每当l1亮灭100次后(l
24、2灯亮灭10次)。5.12 8255的调试通过初始化8255控制字,设定c口高4位为输入口,c口低4位为输出口,将c口低4位接到开关k0k3,c口高四位接到二极管l1l3,运行后观察l1l4灯的情况。5.13 数码管的调试将数码管的七个输入接口led-aled-dp接到开关k0k7,led-saled-sb接地,选择第一个数码管,将k0k7分别置为00111111,观察数码管的显示情况。5.2 软件调试在adek88平台上调试已经编好的程序,检查语法错误,再通过单步调试检查程序的逻辑错误。5.3 运行结果及分析检查好通讯口后,运行程序。将k1 置为高电平,开始累积外部事件,计数器从0开始计数,
25、当将k1置为低电平后,外部事件触发无效,暂停计数。当将k0置为高电平后,数码管置零。将k0置为低电平后,清零无效,计数器继续计数。数码管运行正常,从0开始计数到99后,计数器自动清零。5.4 故障原因分析5.4.1 查表错误(1)程序通过查表给数码管赋值,在没有写push cs ,pop ds之前,试用xlat查表时,经常出现错误。(2)在使用存储单元暂存脉冲个数时,当需要查表时,使用mov al,save时,值会改变,造成查表错误。5.4.2 数码管显示有余辉由于是通过3-8译码器选择数码管,每次只能显示一个数码管,没有加延时程序时,数码管会显示会出现余辉,看不清楚。5.4.3进位错误(1)
26、由于方案一采用定时器1和定时器2来计数,初始化设定定时器1和2工作在方式0,每当定时器1的计数值减到0时,out1产生一个脉冲,定时器2的计数值减一,当个位数码管显示9时,十位数码管进位加1,造成错误。比如当数码管为08时,当下一个外部事件触发时,数码管为19,再一个外部事件时,数码管为10。(2)由于定时器工作在方式0,每次计数器从初值9减为0时,需要从新装入初值,需要两个脉冲,所以每次当个位数码管为0时,都需要两次外部事件触发,计数器才能计数。6.心得体会微机原理与接口技术是一门很有趣的课程,任何一个计算机系统都是一个复杂的整体,学习计算机原理是要涉及到整体的每一部分。讨论某一部分原理时又要涉及到其它部分的工作原理。这样一来,不仅不能在短时间内较深入理解计算机的工作原理,而且也很难孤立地理解某一部分的工作原理。所以,在循序渐进的课堂教学过程中,我总是处于“学会了一些新知识,弄清了一些原来保留的问题,又出现了一些新问题”的循环中,直到课程结束时,才把保留的问题基本搞清楚。 学习该门课程知识时,其思维方法也和其它课程不同,该课程偏
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 心电图室奖惩制度的制定意见
- 2025年度汽车维修厂汽车尾气排放检测与治理合同
- 金华浙江金华永康市古山镇人民政府工作人员招聘笔试历年参考题库附带答案详解
- 金华2025年浙江金华浦江县县属医疗卫生单位招聘护理等专业人员16人笔试历年参考题库附带答案详解
- 浙江浙江省疾病预防控制中心招聘劳务派遣员工笔试历年参考题库附带答案详解
- 杭州2025年浙江杭州市教育局所属事业单位招聘166人笔试历年参考题库附带答案详解
- 2025年中国双层床架市场调查研究报告
- 2025年中国一次性使用PE手套市场调查研究报告
- 2025年规则导线剥皮机项目可行性研究报告
- 2025年罐头盒蜡烛项目可行性研究报告
- 2024年西宁城市职业技术学院高职单招(英语/数学/语文)笔试历年参考题库含答案解析
- 2024年临沂市高三一模(学业水平等级考试模拟试题)物理试卷
- 广州猎德大桥三维曲面塔清水混凝土施工技术
- 我国糖尿病视网膜病变临床诊疗指南2022解读
- Python数据挖掘实战全套教学课件
- 高级茶艺师技能鉴定(协会版)备考题库-下(多选、判断题汇总)
- 特种设备作业人员体检表(叉车)
- c30混凝土路面施工方案
- 加强师德师风建设学校师德师风警示教育讲座培训课件
- 猪饲料购销合同书
- 电商运营销售计划Excel模版
评论
0/150
提交评论