基于AT89C51单片机的数字电压表设计.doc

上传人:知****量 文档编号:28104006 上传时间:2022-07-26 格式:DOC 页数:20 大小:241.54KB
返回 下载 相关 举报
基于AT89C51单片机的数字电压表设计.doc_第1页
第1页 / 共20页
基于AT89C51单片机的数字电压表设计.doc_第2页
第2页 / 共20页
点击查看更多>>
资源描述

《基于AT89C51单片机的数字电压表设计.doc》由会员分享,可在线阅读,更多相关《基于AT89C51单片机的数字电压表设计.doc(20页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。

1、 单片机课程设计报告基于at89c51的数字电压表设计设计课题: 专业班级: 学生: 指导教师: 设计时间: 仅供学习参考基于AT89C51单片机的数字电压表设计摘要数字电压表是常用的对电子电路进行检测的较精密仪器之一。本文的设计思想是一种基于单片机的数字电压表设计方式。该设计主要由三个模块组成:A/D转换模块、数据处理主控模块和显示模块。A/D转换模块主要由芯片ADC0808来完成,它负责将采集到的模拟量转换为相应的数字量传送到数据处理模块单片机。数据处理主控模块由单片机AT89C51来完成,它负责将ADC0808传送过来的数字量经过一定的数据处理,产生相对应的显示码传送到显示模块进行显示。

2、此外,它还控制芯片ADC0808的工作。经过仿真软件结果说明本设计中的电压表电路简单,所用元件较少,本钱低且测量精度高。此电压表可以测量05V的模拟输入电压值,并通过一个四位一体的共阴数码管显示出来。关键词:数字电压表,单片机,A/D转换,AT89C51,ADC0808目 录第1章 绪论1第2章 系统整体设计思路及方案22.1 设计题目22.2 设计思路22.3 设计方案2第3章 数字电压表的硬件设计33.1 单片机主控制模块的设计33.1.1 AT89C51性能简介33.1.2 AT89C51各引脚功能33.1.3 AT89C51的复位电路和时钟电路53.2 A/D转换电路设计63.2.1

3、ADC0808的主要特性73.2.2 ADC0808各引脚功能73.3 显示电路的设计83.4 总体电路设计10第4章 数字电压表的软件设计114.1 设计流程图114.2 各子程序简介12第5章 软件调试135.1 软件调试135.2 误差分析13结论15参考文献16附录 程序截图及解释17基于AT89C51单片机数字电压表的设计第1章 绪论 在电量的测量中,电压、电流和频率是最根本的三个被测量,其中电压量的测量最为经常。而且随着电子技术的开展,更是经常需要测量高精度的电压,所以数字电压表就成为一种必不可少的测量仪器。数字电压表Digital Voltmeter)简称DAM,它是采用数字化测

4、量技术,把连续的模拟量转换成不连续、离散的数字形式并加以显示的仪表。传统的指针式电压表功能单一、精度低,不能满足数字化时代的需求,采用单片机的数字电压表,有精度高、抗干扰能力强、集成方便,还可与PC进行实时通信等优点。 目前,由各种单片机和A/D转换器构成的数字电压表,已被广泛用于电子及电工测量、工业自动化仪表、自动测试系统等领域,显示出了它极强的生命力。与此同时,由DVM扩展而成的各种通用及专用数字仪表仪器,也把电量及非电量技术提高到崭新水平。新型数字电压表以其高准确度、高可靠性、高分辨率、高性价比等优良特性备受人们的青睐。 本文是以简易数字直流电压表的设计为研究内容,本系统主要包括三大模块

5、:转换模块、数据处理模块及显示模块。其中,A/D转换采用ADC0808对输入的模拟信号进行转换,控制核心AT89C51再对转换的结果进行运算处理,最后驱动输出装置LED显示数字电压信号。 1第2章 系统整体设计思路及方案2.1 设计题目 基于单片机AT89C51数字电压表的设计2.2 设计思路(1根据设计题目,选择AT89C51单片机为核心控制器件。(2A/D转换采用ADC0808实现,连接单片机的P1口和P3口的四位引脚。(3电压显示采用4位一体的LED数码管。(4LED数码管的段码输入由端口P0产生;位码输入用端口P2产生。2.3 设计方案 本设计选择AT89C51单片机作为核心控制器件。

6、A/D转换采用ADC0808来实现。输入采用05V的直流电压源,电压显示采用4位一体的LED数码管,LED数码管的段码输人由端口P0输出,位码输人由端口 P2输出。时钟电路 复位电路A/D转换测量电压显示系统统AT89C51 P1 P3 P0P2 P1 硬件电路设计由6个局部组成: A/D转换电路,AT89C51单片机系统,LED显示系统、时钟电路、复位电路以及测量电压输入电路。硬件电路设计如图2-1所示。 图2-1 系统设计框图第3章 数字电压表的硬件设计3.1 单片机主控制模块的设计3.1.1 AT89C51性能简介 AT89C51是美国ATMEL公司生产的低电压,高性能CMOS8位单片机

7、,片内含有4KB的可反复擦写的只读程序存储器和128字节的随机存储器。该器件采用ATMEL高密度非易失存储器制造技术制造,与工业标准的MCS-51指令集和输出管脚相兼容,由于将多功能8位CPU和闪烁存储器组合在单个芯片中,ATMEL的AT89C51是一种高效微控制器,它为很多嵌入式控制系统提供了一种灵活性高且价廉的方案。 AT89C51功能性能:与MCS-51成品指令系统完全兼容;4KB可编程闪速存储器;寿命:1000次写/擦循环;数据保存时间:10年;全静态工作:0-24MHz;三级程序存储器锁定;128*8B内部RAM;32个可编程I/O口线;2个16位定时/计数器;5个中断源;可编程串行

8、UART通道;片内震荡器和掉电模式。3.1.2 AT89C51各引脚功能 AT89C51提供以下标准功能:4KB的Flash闪速存储器,128B内部RAM,32个I/O口线,两个16位定时/计数器,一个5向量两级中断结构,一个全双工串行通信口,片内震荡器及时钟电路,同时,AT89C51可降至0Hz静态逻辑操作,并支持两种软件可选的节电工作模式。空闲方式停止CPU的工作,但允许RAM,定时/计数器,串行通信口及中断系统继续工作,掉电方式保存RAM中的内容,但震荡器停止工作并禁止其他所有工作直到下一个硬件复位。AT89C51采用PDIP封装形式,引脚配置如图3-1所示。图3-1 AT89C51引脚

9、图AT89C51芯片的各引脚功能为: P0口:这组引脚共有8条,P0.0为最低位。这8个引脚有两种不同的功能,分别适用于不同的情况,第一种情况是89C51不带外存储器,P0口可以为通用I/O口使用,P0.0-P0.7用于传送CPU的输入/输出数据,这时输出数据可以得到锁存,不需要外接专用锁存器,输入数据可以得到缓冲,增加了数据输入的可靠性;第二种情况是89C51带片外存储器,P0.0-P0.7在CPU访问片外存储器时先传送片外存储器的低8位地址,然后传送CPU对片外存储器的读/写数据。P0口为开漏输出,在作为通用I/O使用时,需要在外部用电阻上拉。 P1口:这8个引脚和P0口的8个引脚类似,P

10、1.7为最高位,P1.0为最低位,当P1口作为通用I/O口使用时,P1.0-P1.7的功能和P0口的第一功能相同,也用于传送用户的输入和输出数据。 P2口:这组引脚的第一功能与上述两组引脚的第一功能相同即它可以作为通用I/O口使用,它的第一功能和P0口引脚的第二功能相配合,用于输出片外存储器的高8位地址,共同选中片外存储器单元,但不像P0口那样传送存储器的读/写数据。 P3口:这组引脚的第一功能和其余三个端口的第一功能相同,第二功能为控制功能,每个引脚并不完全相同,如下表3-1所示:表3-1 P3口各位的第二功能P3口各位第二功能P3.0 RXT串行口输入P3.1 TXD串行口输出P3.2/I

11、NT0外部中断0输入P3.3/INT1(外部中断1输入)P3.4T0定时器/计数器0的外部输入P3.5T1定时器/计数器1的外部输入P3.6/WR片外数据存储器写允许 P3.7/RD片外数据存储器读允许 Vcc为+5V电源线,GND接地。 ALE:地址锁存允许线,配合P0口的第二功能使用,在访问外部存储器时,89C51的CPU在P0.0-P0.7引脚线去传送随后而来的片外存储器读/写数据。在不访问片外存储器时,89C51自动在ALE线上输出频率为1/6震荡器频率的脉冲序列。该脉冲序列可以作为外部时钟源或定时脉冲使用。 EA:片外存储器访问选择线,可以控制89C51使用片内ROM或使用片外ROM

12、,假设EA=1,那么允许使用片内ROM, 假设EA=0,那么只使用片外ROM。 PSEN:片外ROM的选通线,在访问片外ROM时,89C51自动在PSEN线上产生一个负脉冲,作为片外ROM芯片的读选通信号。 RST:复位线,可以使89C51处于复位(即初始化)工作状态。通常89C51复位有自动上电复位和人工按键复位两种。 XTAL1和XTAL2:片内震荡电路输入线,这两个端子用来外接石英晶体和微调电容,即用来连接89C51片内OSC(震荡器)的定时反应回路。3.1.3 AT89C51的复位电路和时钟电路 单片机中CPU每执行一条指令,都必须在统一的时钟脉冲的控制下严格按时间节拍进行,而这个时钟

13、脉冲是单片机控制中的时序电路发出的。CPU执行一条指令的各个微操作所对应时间顺序称为单片机的时序。MCS-51单片机芯片内部有一个高增益反相放大器,用于构成震荡器,XTAL1为该放大器的输入端,XTAL2为该放大器输出端,但形成时钟电路还需附加其他电路。单片机AT89C51的时钟电路如图3-2所示,主要由电容C1- C3、电阻R1、晶振X1等组成。AT 89C51的18脚(XTAL2)和19脚(XTAL1)接时钟电路,其中19脚是AT89C51内部振荡器倒相放大器的输入端,用于接外部晶振和微调电容的一端;18脚是AT89C51内部振荡器倒相放大器输出端,用于接外部晶振和微调电容的另一端。图3-

14、2 AT89C51的时钟电路图 单片机在启动运行时都需要复位,使CPU和系统中的其他部件都处于一个确定的初始状态,并从这个状态开始工作。MCS-51单片机有一个复位引脚RST,采用施密特触发输入。当震荡器起振后,只要该引脚上出现2个机器周期以上的高电平即可确保时器件复位。复位完成后,如果RST端继续保持高电平,MCS-51就一直处于复位状态,只要RST恢复低电平后,单片机才能进入其他工作状态。图3-3是51系列单片机统常用的复位电路。图3-3 AT89C51的复位电路3.2 A/D转换电路设计 现实世界的物理量都是模拟量,能把模拟量转化成数字量的器件称为模/数转换器A/D转换器,A/D转换器是

15、单片机数据采集系统的关键接口电路,按照各种A/D芯片的转化原理可分为逐次逼近型,双重积分型等等。双积分式A/D转换器具有抗干扰能力强、转换精度高、价格廉价等优点。与双积分相比,逐次逼近式A/D转换的转换速度更快,而且精度更高,如ADC0809、ADC0808等,它们通常具有8路模拟选通开关及地址译码、锁存电路等,它们可以与单片机系统连接,将数字量送到单片机进行分析和显示。一个n位的逐次逼近型A/D转换器只需要比拟n次,转换时间只取决于位数和时钟周期,逐次逼近型A/D转换器转换速度快,因而在实际中广泛使用。3.2.1 ADC0808的主要特性 ADC0808是CMOS单片型逐次逼近式A/D转换器

16、,带有使能控制端,与微机直接接口,片内带有锁存功能的8路模拟多路开关,可以对8路0-5V输入模拟电压信号分时进行转换,由于ADC0808设计时考虑到假设干种模/数变换技术的长处,所以该芯片适应于过程控制,微控制器输入通道的接口电路,智能仪器和机床控制等领域。 ADC0808是分辨率为8位的、以逐次逼近原理进行模/数转换的器件。其内部有一个8通道多路开关,它可以根据地址码锁存译码后的信号,只选通8路模拟输入信号中的一个进行A/D转换。ADC0808是ADC0809的简化版本,功能根本相同。一般硬件仿真时采用ADC0808进行A/D转换,实际使用时采用ADC0809进行A/D转换。 3.2.2 A

17、DC0808各引脚功能图3-4 ADC0808引脚图 ADC0808芯片有28条引脚,采用双列直插式封装,其引脚图如图3-4所示。下面说明各个引脚功能: IN0-IN78条:8路模拟量输入线,用于输入和控制被转换的模拟电压。 ALE:地址锁存允许输入线,高电平有效,当ALE为高电平时,为地址输入线,用于选择IN0-IN7上那一条模拟电压送给比拟器进行A/D转换。ADDA,ADDB,ADDC:3位地址输入线,用于选择8路模拟输入中的一路,其对应关系如表3-2所示:表3-2 ADC0808通道选择表地址码 对应的输入通道 C B A 0 0 0 0 1 1 1 1 0 0 1 1 0 0 1 1

18、0 1 0 1 0 1 0 1 IN0 IN1 IN2 IN3 IN4 IN5 IN6 IN7 START:START为“启动脉冲输入法,该线上正脉冲由CPU送来,宽度应大于100ns,上升沿清零SAR,下降沿启动ADC工作。 EOC: EOC为转换结束输出线,该线上高电平表示A/D转换已结束,数字量已锁入三态输出锁存器。OE:数据输出允许信号,输入,高电平有效。当A/D转换结束时,此端输入一个高电平,才能翻开输出三态门,输出数字量。 REF+、REF-:参考电压输入量,给电阻阶梯网络供应标准电压。 Vcc、GND: Vcc为主电源输入端,GND为接地端,一般REF+与Vcc连接在一起,REF

19、-与GND连接在一起. CLK:时钟输入端。3.3 显示电路的设计 LED是发光二极管显示器的缩写。LED由于结构简单、价格廉价、与单片机接口方便等优点而得到广泛应用。LED显示器是由假设干个发光二极管组成显示字段的显示器件。在单片机中使用最多的是七段数码显示器。 在应用系统中,设计要求不同,使用的LED显示器的位数也不同,因此就生产了位数,尺寸,型号不同的LED显示器供选择,在本设计中,选择4位一体的数码型LED显示器,简称“4-LED。本系统中前一位显示电压的整数位,即个位,后三位显示电压的小数位。4-LED显示器引脚如图3-5所示,是一个共阴极接法的4位LED数码显示管,其中a,b,c,

20、e,f,g为4位LED各段的公共输出端,1、2、3、4分别是每一位位数选端,DP是小数点引出端,4位一体LED数码显示管的内部结构是由4个单独的LED组成,每个LED的段输出引脚在内部都并联后,引出到器件的外部。图3-5 4位LED引脚本设计中LED和单片机的连接如图3-6,图中可以看出,本设计用单片机的P0.0P0.7作为LED显示的片选端口,P2端口作为LED的位选信号。图3-6 显示电路连接图3.4 总体电路设计经过以上的设计过程,可设计出基于单片机的简易数字电压表硬件电路原理 图如图3-7所示。图3-7 设计电路总图此电路的工作原理是:+5V模拟电压信号通过变阻器RV1分压后由IN0进

21、入ADC0808,经过A/D转换后,读取转换后的采样值,通过公式:电压=采样值/采样精度*参考电压,将通过公式计算后的数字量经过其输出通道A0-A7传送给AT89C51芯片的P1口,AT89C51负责把接收到的数字量经过数据处理,产生正确的显示段码通过P0口传送给共阴数码管,P2.0、P2.1、P2.2、P2.3产生位选信号控制数码管的亮灭。AT89C51通过P3.4给ADC0808的CLOCK提供时钟信号,当给单片机的P3.0输出一个正脉冲,利用其下降沿可启动AD转换,由P3.2检测A/D转换是否完成,转换完成后,通过P3.1使输出允许控制端OE置为高电平,允许单片机读取转换数据,将转换结果

22、送给共阴数码管显示出来。 第4章 数字电压表的软件设计4.1 设计流程图 主程序主要完成信号存储、信号处理、A/ D转换以及调用显示等。主程流程如图4-1所示:程序首先从ORG0000H开始,然后无条件件跳转至主程序的首地址开始,初始化后,先调用模数转换程序进行输入信号的数字化,然后调用显示子程序将处理后的数字输出,一次数据结束后,循环执行调用的两个子程序。图4-1 主程序流程图A/D转换子程序如图4-2所示:首先进行开始模数转化,执行后,如果检测到转化没有完成那么继续转化,如果转化完成,执行下一条指令,将取得模数转化结果并转换为工程量,然后显示转换结果,此为一次模数转换,如此循环可转换下一组

23、数据,全部转换完毕后,结束。图4-2 A/D转换子程序流程图4.2 各子程序简介 初始化子程序的主要工作是设置定时器的工作模式,初值预置,开中断和翻开定时器等。 A/D转换子程序用来控制对输入的模块电压信号的采集测量,并将对应的数值存入相应的内存单元。显示子程序采用动态扫描实现四位数码管的数值显示,在本设计中,为了简化硬件设计,主要采用软件定时的方式,即用定时器0方式2产生40ms定时,通过软件延时程序来实现10ms的延时。 第5章 软件调试5.1 软件调试 软件调试的主要任务是排查错误,错误主要包括逻辑和功能错误,这些错误有些是显性的,而有些是隐形的,可以通过仿真开发系统发现逐步改正。Pro

24、teus软件可以对基于微控制器的设计连同所有的周围电子器件一起仿真。Proteus支持的微处理芯片包括8051系列、AVR系列、PIC系列、HC11系列及Z80等等。Proteus可以完成单片机系统原理图电路绘制、PCB设计,更为显著的特点是可以与u Visions3 IDE工具软件结合进行编程仿真调试。 本系统的调试主要以软件为主,其中,系统电路图的绘制和仿真我采用的是Proteus软件,程序方面,采用的是C语言,用Keil软件将程序写入单片机。5.2 误差分析 由于单片机AT89C51为8位处理器,当输入电压为5.00V时,ADC0808输出数据值为255FFH,因此单片机最高的数值分辨率

25、为0.0196V(5/255)。这就决定了电压表的最高分辨率只能到0.0196V,从下表可看到,测试电压以接近0.01V的幅度变化。本文的数字电压表可以测量0-5V的电压值,最大分辩率为0.001V。通过仿真测量结果可得到简易数字电压表与“标准数字电压表比照测试表。本次设计的电压表误差分析采用屡次测量求绝对差值的方法,并把各组数据列成表格,这样能更加清晰地看出误差的波动范围及大小,如下表5-1所示: 标准电压V0.000.501.001.502.002.503.003.504.004.505.00测量电压V0.000.5091.0001.5092.0002.4903.0003.4904.000

26、4.4905.000绝对误差V00.00900.00900.01000.01000.0100表5-1 误差分析 从上表可以看出,简易数字电压表测得的值和标准电压值偏差在0-0.02V,这可以通过校正ADC0808的基准电压来解决。因为该电压表设计时直接用5V的供电电源作为电压,所以电压可能有偏差。 结论 经过近段时间的努力,基于AT89C51单片机的数字电压表设计根本完成。但设计中仍然存在许多缺乏之处。这次设计是我第一次设计电路,并用Proteus实现了仿真。在这过程中,我对电路设计,单片机的使用等都有了新的认识。通过这次设计学会了Proteus和Keil软件的使用方法,掌握了从系统的需要、方

27、案的设计、功能模块的划分、原理图电路图的仿真的设计流程,积累了不少经验。 基于单片机的数字电压表使用性强、结构简单、本钱低、外接元件少。在实际应用工作应能好,测量电压准确,精度高。系统功能、指标到达了论文的预期要求,本文设计主要实现了简易数字电压表测量一路电压的功能,详细说明了从原理图的设计、电路图的仿真再到软件的调试。 通过本次设计,我对单片机这门课有了进一步的了解。无论是在硬件连接方面还是在软件编程方面。本次设计采用了AT89C51单片机芯片,设计中还用到了模/数转换芯片ADC0808,以前在学单片机课程时只是对其理论知识有了初步的理解。通过这次设计,对它的工作原理有了更深的理解。在调试过

28、程中遇到很多问题,硬件上的理论知识学得不够扎实,对电路的仿真方面也不够熟练。 总之这次电路的设计和仿真,根本上到达了设计的功能要求。在以后的实践工作中,我将继续努力学习电路设计方面的理论知识,并理论联系实际,争取在电路设计方面能有所提升。参考文献1王瑾.基于Proteus的数字电压表仿真设计J.电子设计工程,20212赵兆.基于FPGA的瞬变电磁数据采集系统的设计J.自动化与仪器仪表,2021(03)3高荣杰,章海亮,龚亮明,等.基于PROTEUS的单片机AD转换仿真J.计算机与现代化,2021(11).4胡健.单片机原理及接口技术.北京:机械工业出版社,2004年10月5王毓银.数字电路逻辑

29、设计.高等教育出版社,2005年12月6宋凤娟,孙军,李国忠.基于89C51单片机数字电压表设计J .工业控制计算机,2007/047谢维成、杨加国.单片机原理与应用及C51程序设计实例.电子工业出版社,2006年3月8李广弟.单片机根底.北京航空航天大学出版社,2007年5月9姜志海,黄玉清等著.单片机原理及应用M.北京:电子工业出版社.2005年7月 10魏立峰.单片机原理及应用技术.北京大学出版社,2005年11周润景.Protues在MCS-51&ARM7系统应用百例.第一版.北京:电子工业出版社2006年12边春远等著.MCS-51单片机应用开发实用子程序M.北京:人民邮电出版社.2005/913苗红霞.单片机实现数字电压表的软硬件设计J .河海大学常州分校学报,2002,03.14于殿泓、王新年.单片机原理与程序设计实验教程.西安电子科技大学出版社,2007/5附录 程序截图及解释13

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 应用文书 > 工作计划

本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

工信部备案号:黑ICP备15003705号© 2020-2023 www.taowenge.com 淘文阁