《A D转换及多位数码显示实验.doc》由会员分享,可在线阅读,更多相关《A D转换及多位数码显示实验.doc(17页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、课 程:微处理器原理与应用课 时:4学时教学环境:单片机实验室教学方法:讲解相关内容,指导学生实验实验四 A/D转换及多位数码显示实验 一、目的、任务和要求1.1 实验目的1. 掌握8051单片机控制的多位数码显示器电路的设计方法、程序结构和编程方法。2. 掌握LED动态扫描显示器的扫描方法和程序结构,同时进一步掌握单片机扩展I/O接口、定时中断的应用和编程方法。3. 掌握8051单片机控制的A/D转换电路的硬件设计、程序结构和编程方法。4. 掌握ADC0809芯片的工作原理和完成A/D转换的三种等待工作方式以及三种工作方式下的硬件电路和程序结构的设计方法1.2 实验任务搭建一个单片机控制的A
2、/D转换及多位数码显示电路,编写并调试通过一个能实现单路A/D转换和数码显示的程序。本实验采用七段LED数码管来显示A/D转换后的数值。1.3实验要求通过利用8051单片机的并行扩展功能和采用ADC0809芯片,搭建一个A/D转换电路,采用七段LED数码管来显示A/D转换后的数值。设计并调试通过相应的程序。二、 实验设备和器件2.1实验设备(1)微型计算机(PC机)(装配相关软件),(2)单片机实验箱或开发板。2.2电路元器件本实验采用Protues仿真软件搭建一个简单的单片机系统电路,进行电路仿真分析,不需要实际的元器件。若实验采用实验箱或万能板(或面包板)搭建电路,则需要如下元器件:ADC
3、0809,74LS02,10k电位器、七段LED数码管,74HC595、三极管9013、LED限流电阻、软导线等。学生可自己在课后搭建电路进行实验,并与仿真实验比较。三、实验内容及步骤3.1参考电路与程序代码1单片机控制ADC0809芯片的A/D转换参考电路该电路图是在80C51单片机最小系统的基础上,通过并行总线扩展ADC0809芯片,再将电位器的输出模拟电压信号接ADC0809的模拟信号输入端,同时采用扩展的方法接入一个多位7段LED数码显示器。如图6.1所示。+5V+5V+5V图6.1 单片机控制ADC0809芯片的A/D转换电路简图如图6.1(A)所示,8051数据线P0.1P0.7连
4、接0809数据口OUT8OUT0,8051地址线P2.0P2.2连接0809模拟输入信号的地址线ADDAADDC,8051地址线P2.7与读写控制线/RD、/WR通过或非门芯片74LS02连接0809的启动转换信号START、模拟输入端地址锁存信号ALE和转换输出控制端OE,0809的外接时钟信号CLOCK由8051单片机的ALE信号提供,0809的AD转换结束信号EOC接8051的P3.5脚(查询方式用)。AD转换后的数据由8051串口和串并转换芯片74HC595送至LED数码管的段码数据线,8051的P1.0P1.4脚作为位数据线经过三极管驱动器连接数码管的阳极。8VCCD7D0IN-0A
5、DDAADDBADDC CLKOE EOC ALESTARTADC0809P0口P1口 ALEP2口INTX/WR/RD8051373地址及读写逻辑88显示控制和显示器8地址及读写逻辑。图6.1(B) 单片机控制ADC0809芯片的AD转换电路简图B也可以如图6.1B所示,ADC0809和数码显示电路都通过并行总线来扩展,由于8051总线是数据地址复用总线,当地址空间紧缺时可用74LS373芯片来完成总线解复用和增加一些地址空间。2单片机控制ADC0809芯片的AD转换电路的参考程序代码(1) 图6.1(A)电路的参考程序代码 PORT7 EQU 7FFFH ;通道7启动地址 ORG 0000
6、H LJMP START ORG 0100H START:MOV SCON,#00H MOV R3,#50 ;设置显示循环变量的初值 LOOP:NOP MOV DPTR,#PORT7 MOVX DPTR,A ;启动通道7 MOV R2,#250 DJNZ R2,$ ;等待方式读 MOVX A,DPTR ;读AD转换结果 MOV B,#100 ;以下完成二十进制转换 DIV AB MOV 30H,A ;存百位 MOV A,#10 XCH A,B DIV AB MOV 31H,A ;存十位 MOV 32H,B ;存个位 NOP DISP:LCALL DL0 ;延时6ms左右 MOV A,30H ;
7、取百位数送显 MOV DPTR,#TAB MOVC A,A+DPTR ;转换成段码 CLR P3.2 MOV SBUF,A ;低位先发,送出百位段码 JNB TI,$ CLR TI SETB P3.2 ;锁存输出 MOV P1,#02h LCALL DL0 MOV A,31H ;取十位数 MOVC A,A+DPTR CLR P3.2 MOV SBUF,A ;低位先发,送出十位段码 JNB TI, $ CLR TI SETB P3.2 MOV P1,#04H LCALL DL0 MOV A,32H ;取个位数 MOVC A,A+DPTR CLR P3.2 MOV SBUF,A ;低位先发,送出个
8、位段码 JNB TI,$ CLR TI SETB P3.2 MOV P1,#08H DJNZ R3, DISP ;循环显示50次 MOV R3,#50 ;约1秒AD采样一次 LJMP LOOP DL0::MOV R0,#6 ;延时6ms左右 DL1:MOV R1,#2 DL2:MOV R2,#250 DJNZ R2,$ DJNZ R1,DL2 DJNZ R0,DL1 RET TAB:DB 0C0H,0F9H,0A4H,0B0H,99H,92H,82H,0F8H,80H DB 90H,88H,83H,0C6H,0A1H,86H,8EH,8CH,0FFH END (2)图6.1(B)电路的参考程序
9、代码PORT EQU 0CFA0H ; EL-MUL- 型实验箱通道0启动地址ORG 0000HLJMP STARTORG 4100HSTART: MOV DPTR, #PORT MOVX DPTR, A ;启动通道0MOV R0, #0FFHDJNZ R0, $ ;延时等待MOVX A, DPTR ;读结果MOV R1, ADISP: MOV A, R1 ;从R1中取转换结果SWAP A ;分离高四位和低四位ANL A, #0FH ;并依次存放在50H到51H中MOV 50H, AMOV A, R1ANL A, #0FHMOV 51H, ADISP2: MOV DPTR, #0CFE9H ;
10、CFE9H是8279控制口地址MOV A, #90HMOVX DPTR, A ;写显示RAM命令字DISP3:MOV R0, #50H ;R0存放待显数字的存储地址MOV R1, #02H ;R1存放待显数字的位数MOV DPTR, #0CFE8H ;CFE8H 是8279数据口地址DL0:MOV A, R0ACALL TABLE ;转换为显码MOVX DPTR, A ;送显码输出INC R0DJNZ R1, DL0SJMP DEL1 ;转入延时TABLE:INC AMOVC A, A+PCRETDB 3FH,06H,5BH,4FH,66H,6DH,7DH,07HDB 7FH,6FH,77H,
11、7CH,39H,5EH,79H,71HDEL1:MOV R6, #255 ;延时一段时间使显示更稳定DEL2:MOV R5, #255DEL3:DJNZ R5, DEL3DJNZ R6, DEL2LJMP START ;循环,再开始取样。END 3单片机控制ADC0809芯片的AD转换电路的参考程序结构 ( 图6.1A电路的参考程序代码 ) ( 图6.1B电路的参考程序代码 )程序地址分配(ORG)START:串口初始化LOOP:启动AD转换延时等待(100s以上)读取DISP:分离成3个十进制数同时每位送显示(段码及位码)调用延时子程序DL0循环(转LOOP)DL0:延时子程序(6ms左右)
12、END程序地址分配(ORG)START:启动AD转换延时等待(100s以上)读取DISP:分离成2个十六进制数DISP2:设置8279写显示命令字DISP3:显示循环初始化DL0:2位显示程序(循环2次送显)DEL1:延时程序段(200ms左右)转回STARTEND4. 深入实验问题(学生独立完成)(1)对于图6.1(A),电位器的输出信号AN0改接0809的ADIN1,试修改程序并加以验证。(2)对于图6.1(A),若ADDC、ADDB、ADDA及74LS02的6/2脚分别接P2.4,P2.5,P2.6和P2.7,试列出IN0、IN1、IN2和IN7的写数据(启动转换)和读数据的外部地址。四
13、、实验报告要求与考核标准1、 实验报告要求(1)按照实验任务画出电路图、程序流程图,写出程序代码和运行现象。(2)若将延时等待方式分别改为中断方式和查询方式,试修改硬件电路图和编写程序代码。(3)说明以十六进制数显示和以十进制数显示的两种程序代码的异同点。(4)结合实际电路,说明动态扫描的扫描周期和每一位数码管显示停留的时间长度。(5)结合程序流程图,说明显示缓冲区的地址空间、存储内容和刷新情况。(6)说明七段LED数码管共阴极与共阳极电路在硬件连接、位扫描码和字段码方面的异同点。(7)说明6位显示和4位显示的程序代码不同点。2、实验考核标准序号考核内容权重评分摘要扣分标准得分1电路设计软件仿
14、真电路(20分)画错接线 2分个画错元件 2分个仿真出错3分个实际电路连线(15分)接线错误3分个2软件设计程序编辑(10分) 编辑不规范2分个程序编译(10分) 编译出错2分个功能完整(15分)功能出错3分个3安全与纪律安全操作(15分)违规操作5分/ 次实验纪律(10分)违纪5分/ 次4综合考核综合(5分)517分 考 违分 操分(纪出分(出)0译规)0辑设错分 (路出件线分 电设得标摘权内序标考验点不序示位显 点异面字码扫件路阳与管 段七况情容储空址冲显说序合度长留示管每周的描说,际点同码程的制以显制十说码代写图硬试方查断改式等时象行和代,图程电务验要告标标求告址部据读转(数 出, ,
15、别 若 .图对证验并改 0 输位)(.)成立独(入 右右0段程 显次循程示 始始示:令示显 : 制六 分读上 0待转 : 分 右 程: 程码码(同数十成:读上以0(转 启 始初 分 右0(程延 显环(显: 化 环显 令示 置 数六 离 取)以0(时转 : ) 配址) 序延 转循 序 延位段示( 始 0读成数程 程右 :待 制显令始程次 右 独立( 验. 数部告标务图和时式断试码说以码际,每留合显址情七管阳码面显不验序摘电线出分辑规出(出分分送程时延数 分 读上 (时 : 化口 ) 分 # 稳示间一; , , , , , , , 延转 输码 显换转 :地据 是 0 位字数 地储数放 # : 令
16、写 , 0 , 地口 是 ; , 0 , 在依 0 , 四和高离 结换 , 结读 等延 0 0 道道启 # 0 00 地动0实 0 代代考路 图 , , 0 0, 0 0 : , # : #, 左 时 # : 一样 ; 0# 0示显 0 . , 段个,先; , . + 位个 # . 段段,位; , . 位十 输存 . , 段位出发低 . 段段转 , 送数百 , 左左 ; 个; 十十 , 0 百存 , 转转二完以 0#, 结转读 式待; $ # 道动; : 初的循置; 0, 0# 0 000 地地通 码码参电) 图代程的路 片0 制图路换的芯 控片( 。示控 000 - 间址些增复线完 用缺空当
17、总用数线 于展总过路示和 如简路 的0 单) 图。显控 及址 0 口 0 图) 的路 路展线总空 线些 00 。( 的路0 代)码 地 0 0 00 置 动 # ;式 结 , 以完转 , 十 ; 送 段 低位 存输 位 . , 段段 . , ,段 , . 0 0 0 一 # # 00 图考代0 动0 启 等 , 换 高 , , ,0, 令 # 地 数 0 是地 转 , , 间 分 (分分序循 配配 时)离 置 00 简路 /片0 机单 路/片0 机 +较比仿,简 行进后/己生学 软、 、0 极 ,数 、, 0 件件下需电)面板箱用采若元要需真仿,电片单个件仿 器路板开验片),关装机 计设验器备设序程过试设数后 显码 七采换/ ,芯0 采功扩片 用要实值数换/显数 用实。的显转 现个通并写示数多换/机片任验方方结程电下作种以工待的/成原的片 握法方构序计的路 制片 握法方用断定接 扩单步进结和描扫描态 掌法程和程方的电码位的单0掌目实要务的 验码数转 实实指内解法验实片学:时应与理: 与学法指实数 实掌位的方程态和结 断法片 的法握的的工下结方任多写通 显 显值要扩 芯/ 显设过序验计,验路器件个仿要元板电件 、,极 学生, 17
限制150内