版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、 基于单片机的数字电压表设计基于单片机的数字电压表设计 学 院(系): 机电工程系 专 业: 自动化 1101 指 导 老师: 廖晓波 学 生 姓名: 陈德兵 学 号: 201140142 负 责 部分: adc0808 西南科技大学城市学院 citycollegeofsouthwestuniversityofcitycollegeofsouthwestuniversityof scienceandtechnologyscienceandtechnology 摘 要 本文介绍了一种基于单片机的数字电压表的设计。该设计主要由三个 模块组成:a/d 转换模块,数据处理模块及显示模块。a/d 转换主
2、要由芯片 adc0808 来 完成,它负责把采集到的模拟量转换为相应的数字量再传送到数据处理模块。数据处 理则由芯片 at89c51 来完成,其负责把 adc0808 传送来的数字量经过一定的数据处理, 产生相应的显示码送到显示模块进行显示;此外,它还控制着 adc0808 芯片工作。该系 统的数字电压表电路简单,所用的元件较少,成本低,且测量精度和可靠性较高。此 数字电压表经过 proteus 软件仿真和调试,可以测量 0-5v 的 1 路模拟直流输入电压值, 并通过一个四位一体的 7 段数码管显示出来。 关键词 数字电压表;a/d 转换;at89c51;adc0808;proteus su
3、mmarythis paper introduces a design based on single chip microcomputer digital voltmeter.this design is mainly composed of three modules:a/d conversion module, data processing module and display module.a/d conversion is mainly competed by the chip adc0808, it is responsible for the collection to the
4、 analog conversion to the corresponding digital quantity and then transferred to the data processing module,data processing is done by chip at89c51,it is responsible for the send adc0808 to digital quantity through certain data processing,generating the corresponding display code sent to the display
5、 module,in addition, it also controls the adc0808 chip.the system of the digital voltmeter circuit is simple, the less components, low cost, and high measurement accuracy and reliability,the digital voltmeter through the proteus software simulation and debugging, can measure of 0 to 5 v analog dc in
6、put voltage value, and through a four one of the seven segment digital tube display. key wordsdigital voltmeter. a/d conversion; at89c51. adc0808; proteus 目 录 1 引言.1 1.1 数字电压表的发展现状.1 1.2 本课题研究的主要内容.1 2 设计总体方案.2 2.1 设计要求.2 2.2 设计思路.2 2.3 设计方案.2 3 硬件电路设计.3 3.1 a/d 转换模块.3 3.1.1 逐次逼近型 a/d 转换器原理.3 3.1.2
7、adc0808 主要特性.3 3.1.3 adc0808 的外部引脚特征.4 3.1.4 adc0808 的内部结构及工作流程.5 3.2 单片机系统.7 3.2.1 at89c51 性能.7 3.2.2 at89c51 各引脚功能.7 3.3 复位电路和时钟电路.10 3.3.1 复位电路设计.10 3.3.2 时钟电路设计.10 3.4 led 显示系统设计.11 3.4.1 led 基本结构.11 3.4.2 led 显示器的选择.11 3.4.3 led 译码方式.12 3.4.4 led 显示器与单片机接口设计.13 3.5 电压调节电路及声光报警电路.13 3.5.1 电压调节电路
8、.13 3.5.2 声光报警电路.14 3.6 总体电路设计.14 4 程序设计.16 4.1 程序设计总方案.16 4.2 系统子程序设计.16 4.2.1 初始化程序.16 4.2.2 a/d 转换子程序.16 4.2.3 显示子程序.17 4.3 仿真.17 4.3.1 软件调试.17 4.3.2 显示结果及误差分析.18 参考文献.21 附录.21 1 引言 1.1 数字电压表的发展现状 在电量的测量中,电压、电流和频率是最基本的三个被测量,其中电压量的测量 最为经常。而且随着电子技术的发展,更是经常需要测量高精度的电压,所以数字电 压表就成为一种必不可少的测量仪器。数字电压表简称 d
9、vm,它是采用数字化测量技术, 把连续的模拟量转换成不连续、离散的数字形式并加以显示的仪表。由于数字式仪器 具有读数准确方便、精度高、误差小、测量速度快等特而得到广泛应用1。 传统的指针式刻度电压表功能单一,进度低,容易引起视差和视觉疲劳,因而不 能满足数字化时代的需要。采用单片机的数字电压表,将连续的模拟量如直流电压转 换成不连续的离散的数字形式并加以显示,从而精度高、抗干扰能力强,可扩展性强、 集成方便,还可与 pc 实时通信。数字电压表是诸多数字化仪表的核心与基础2。以数 字电压表为核心,可以扩展成各种通用数字仪表、专用数字仪表及各种非电量的数字 化仪表。目前,由各种单片机和 a/d 转
10、换器构成的数字电压表作全面深入的了解是很 有必要的。 最近的几十年来,随着半导体技术、集成电路(ic)和微处理器技术的发展,数 字电路和数字化测量技术也有了巨大的进步,从而促使了数字电压表的快速发展,并 不断出现新的类型。数字电压表从 1952 年问世以来,经历了不断改进的过程,从最早 采用继电器、电子管和形式发展到了现在的全固态化、集成化(ic 化) ,另一方面,精 度也从 0.01%-0.005%。 目前,数字电压表的内部核心部件是 a/d 转换器,转换的精度很大程度上影响着 数字电压表的准确度,因而,以后数字电压表的发展就着眼在高精度和低成本这两个 方面。 1.2 本课题研究的主要内容
11、本文是以数字直流电压表的设计为研究内容,本系统主要包括三大模块:转换模 块、数据处理模块及显示模块。其中,a/d 转换采用 adc0808 对输入的模拟信号进行转 换,控制核心 at89c51 再对转换的结果进行运算处理,最后驱动输出装置 led 显示数 字电压信号。 2 设计总体方案 2.1 设计要求 以 mcs-51 系列单片机为核心器件,组成一个简单的直流数字电压表。 采用 1 路模拟量输入,能够测量 0-5v 之间的直流电压值。 电压显示用 4 位一体的 led 数码管显示,至少能够显示两位小数。 尽量使用较少的元器件。 2.2 设计思路 根据设计要求,选择 at89c51 单片机为核
12、心控制器件。 a/d 转换采用 adc0808 实现,与单片机的接口为 p1 口和 p2 口的高四位引脚。 电压显示采用 4 位一体的 led 数码管。 led 数码的段码输入,由并行端口 p0 产生:位码输入,用并行端口 p2 低四位产 生。 2.3 设计方案 硬件电路设计由 6 个部分组成; a/d 转换电路,at89c51 单片机系统,led 显示系 统、时钟电路、复位电路以及测量电压输入电路。硬件电路设计框图如图 2.1 所示。 时钟电路 复位电路 a/d 转换电路测量电压输入 显示系统 at89c51 p1 p2 p2 p0 图 2.1 3 硬件电路设计 3.1 a/d 转换模块 现
13、实世界的物理量都是模拟量,能把模拟量转化成数字量的器件称为模/数转换器 (a/d 转换器) ,a/d 转换器是单片机数据采集系统的关键接口电路,按照各种 a/d 芯 片的转化原理可分为逐次逼近型,双重积分型等等。双积分式 a/d 转换器具有抗干扰 能力强、转换精度高、价格便宜等优点。与双积分相比,逐次逼近式 a/d 转换的转换 速度更快,而且精度更高,比如 adc0809、adc0808 等,它们通常具有 8 路模拟选通开 关及地址译码、锁存电路等,它们可以与单片机系统连接,将数字量送到单片机进行 分析和显示。一个 n 位的逐次逼近型 a/d 转换器只需要比较 n 次,转换时间只取决于 位数和
14、时钟周期,逐次逼近型 a/d 转换器转换速度快,因而在实际中广泛使用。 3.1.1 逐次逼近型 a/d 转换器原理 逐次逼近型 a/d 转换器是由一个比较器、a/d 转换器、存储器及控制电路组成。它 利用内部的寄存器从高位到低位一次开始逐位试探比较。 转换过程如下: 开始时,寄存器各位清零,转换时,先将最高位置 1,把数据送入 a/d 转换器转换, 转换结果与输入的模拟量比较,如果转换的模拟量比输入的模拟量小,则 1 保留,如 果转换的模拟量比输入的模拟量大,则 1 不保留,然后从第二位依次重复上述过程直 至最低位,最后寄存器中的内容就是输入模拟量对应的二进制数字量。其原理框图如 图 3.1
15、所示: 顺序脉冲 发生器 主次逼近 寄存器 adc 输入数字量输入电压 电压 比较器 图 3.1 逐次逼近式 a/d 转换器原理图 3.1.2 adc0808 主要特性 adc0808 是 cmos 单片型逐次逼近式 a/d 转换器,带有使能控制端,与微机直接接 口,片内带有锁存功能的 8 路模拟多路开关,可以对 8 路 0-5v 输入模拟电压信号分时 进行转换,由于 adc0808 设计时考虑到若干种模/数变换技术的长处,所以该芯片非常 适应于过程控制,微控制器输入通道的接口电路,智能仪器和机床控制等领域5。 adc0808 主要特性:8 路 8 位 a/d 转换器,即分辨率 8 位;具有锁
16、存控制的 8 路模拟开关;易 与各种微控制器接口;可锁存三态输出,输出与 ttl 兼容;转换时间:128s;转换精度: 0.2%;单个+5v 电源供电;模拟输入电压范围 0- +5v,无需外部零点和满度调整;低功耗,约 15mw。 3.1.3 adc0808 的外部引脚特征 adc0808 芯片有 28 条引脚,采用双列直插式封装,其引脚图如图 3.2 所示。 图 3.2 adc0808 引脚图 下面说明各个引脚功能: in0-in7(8 条):8 路模拟量输入线,用于输入和控制被转换的模拟电压。 地址输入控制(4 条): ale:地址锁存允许输入线,高电平有效,当 ale 为高电平时,为地址
17、输入线,用 于选择 in0-in7 上那一条模拟电压送给比较器进行 a/d 转换。 adda,addb,addc:3 位地址输入线,用于选择 8 路模拟输入中的一路,其对应关系 如表 3.1 所示: 表 3.1 adc0808 通道选择表 start:start 为“启动脉冲”输入法,该线上正脉冲由 cpu 送来,宽度应大于 100ns,上升沿清零 sar,下降沿启动 adc 工作。 eoc: eoc 为转换结束输出线,该线上高电平表示 a/d 转换已结束,数字量已锁入 三态输出锁存器。 d1-d8:数字量输出端,d1 为高位。 oe:oe 为输出允许端,高电平能使 d1-d8 引脚上输出转换
18、后的数字量。 ref+、ref-:参考电压输入量,给电阻阶梯网络供给标准电压。 vcc、gnd: vcc 为主电源输入端,gnd 为接地端,一般 ref+与 vcc 连接在一起, ref-与 gnd 连接在一起。 clk:时钟输入端。 3.1.4 adc0808 的内部结构及工作流程 adc0808 由 8 路模拟通道选择开关,地址锁存与译码器,比较器,8 位开关树型 a/d 转换器,逐次逼近型寄存器,定时和控制电路和三态输出锁存器等组成,其内部结 构如图 3.3 所示。 地址码 c b a 对应的输入通道 0 0 0 0 1 1 1 1 0 0 1 1 0 0 1 1 0 1 0 1 0 1
19、 0 1 in0 in1 in2 in3 in4 in5 in6 in7 图 3.3 adc0808 的内部结构 其中: (1)8 路模拟通道选择开关实现从 8 路输入模拟量中选择一路送给后面的比较器 进行比较。 (2)地址锁存与译码器用于当 ale 信号有效时,锁存从 adda、addb、addc 3 根 地址线上送来的 3 位地址,译码后产生通道选择信号,从 8 路模拟通道中选择当前模 拟通道。 (3)比较器,8 位开关树型 a/d 转换器,逐次逼近型寄存器,定时和控制电路组 成 8 位 a/d 转换器,当 start 信号有效时,就开始对当前通道的模拟信号进行转换, 转换完成后,把转换得
20、到的数字量送到 8 位三态锁存器,同时通过引脚送出转换结束 信号。 (4)三态输出锁存器保存当前模拟通道转换得到的数字量,当 oe 信号有效时, 把转换的结果送出。 adc0808 的工作流程为: (1)输入 3 位地址,并使 ale=1,将地址存入地址锁存器中,经地址译码器从 8 路 模拟通道中选通 1 路模拟量送给比较器。 (2)送 start 一高脉冲,start 的上升沿使逐次寄存器复位,下降沿启动 a/d 转 换,并使 eoc 信号为低电平。 (3)当转换结束时,转换的结果送入到输出三态锁存器中,并使 eoc 信号回到高 电平,通知 cpu 已转换结束。 (4)当 cpu 执行一读数
21、据指令时,使 oe 为高电平,则从输出端 d0-d7 读出数据。 3.2 单片机系统 3.2.1 at89c51 性能 at89c51 是美国 atmel 公司生产的低电压,高性能 cmos8 位单片机,片内含有 4kb 的可反复擦写的只读程序存储器和 128 字节的随机存储器。该器件采用 atmel 高密度 非易失存储器制造技术制造,与工业标准的 mcs-51 指令集和输出管脚相兼容,由于将 多功能 8 位 cpu 和闪烁存储器组合在单个芯片中,atmel 的 at89c51 是一种高效微控制 器,它为很多嵌入式控制系统提供了一种灵活性高且价廉的方案。 at89c51 功能性能:与 mcs-
22、51 成品指令系统完全兼容;4kb 可编程闪速存储器;寿 命:1000 次写/擦循环;数据保留时间:10 年;全静态工作:0-24mhz;三级程序存储 器锁定;128*8b 内部 ram;32 个可编程 i/o 口线;2 个 16 位定时/计数器;5 个中断源; 可编程串行 uart 通道;片内震荡器和掉电模式。 3.2.2 at89c51 各引脚功能 at89c51 提供以下标准功能:4kb 的 flash 闪速存储器,128b 内部 ram,32 个 i/o 口线,两个 16 位定时/计数器,一个 5 向量两级中断结构,一个全双工串行通信口, 片内震荡器及时钟电路,同时,at89c51 可
23、降至 0hz 静态逻辑操作,并支持两种软件可 选的节电工作模式。空闲方式停止 cpu 的工作,但允许 ram,定时/计数器,串行通信 口及中断系统继续工作,掉电方式保存 ram 中的内容,但震荡器停止工作并禁止其他 所有工作直到下一个硬件复位。at89c51 采用 pdip 封装形式,引脚配置如图 3.4 所示。 图 3.4 at89c51 的引脚图 at89c51 芯片的各引脚功能为: p0 口:这组引脚共有 8 条,p0.0 为最低位。这 8 个引脚有两种不同的功能,分别 适用于不同的情况,第一种情况是 89c51 不带外存储器,p0 口可以为通用 i/o 口使用, p0.0-p0.7 用
24、于传送 cpu 的输入/输出数据,这时输出数据可以得到锁存,不需要外接 专用锁存器,输入数据可以得到缓冲,增加了数据输入的可靠性;第二种情况是 89c51 带片外存储器,p0.0-p0.7 在 cpu 访问片外存储器时先传送片外存储器的低 8 位地址, 然后传送 cpu 对片外存储器的读/写数据。p0 口为开漏输出,在作为通用 i/o 使用时, 需要在外部用电阻上拉。 p1 口:这 8 个引脚和 p0 口的 8 个引脚类似,p1.7 为最高位,p1.0 为最低位,当 p1 口作为通用 i/o 口使用时,p1.0-p1.7 的功能和 p0 口的第一功能相同,也用于传送 用户的输入和输出数据。 p
25、2 口:这组引脚的第一功能与上述两组引脚的第一功能相同即它可以作为通用 i/o 口使用,它的第一功能和 p0 口引脚的第二功能相配合,用于输出片外存储器的高 8 位地址,共同选中片外存储器单元,但并不是像 p0 口那样传送存储器的读/写数据。 p3 口:这组引脚的第一功能和其余三个端口的第一功能相同,第二功能为控制功 能,每个引脚并不完全相同,如下表 2 所示: p3 口各位第二功能 p3.0 rxt(串行口输入) p3.1 txd(串行口输出) p3.2 /int0(外部中断 0 输入) p3.3 /int1(外部中断 1 输入) p3.4 t0(定时器/计数器 0 的外部输入) p3.5
26、t1(定时器/计数器 1 的外部输入) p3.6 /wr(片外数据存储器写允许) p3.7 /rd(片外数据存储器读允许) 表 3.2 p3 口各位的第二功能 vcc 为+5v 电源线,vss 接地。 ale:地址锁存允许线,配合 p0 口的第二功能使用,在访问外部存储器时,89c51 的 cpu 在 p0.0-p0.7 引脚线去传送随后而来的片外存储器读/写数据。在不访问片外存 储器时,89c51 自动在 ale 线上输出频率为 1/6 震荡器频率的脉冲序列。该脉冲序列可 以作为外部时钟源或定时脉冲使用。 /ea:片外存储器访问选择线,可以控制 89c51 使用片内 rom 或使用片外 ro
27、m, 若/ea=1,则允许使用片内 rom, 若/ea=0,则只使用片外 rom。 /psen:片外 rom 的选通线,在访问片外 rom 时,89c51 自动在/psen 线上产生一 个负脉冲,作为片外 rom 芯片的读选通信号。 rst:复位线,可以使 89c51 处于复位(即初始化)工作状态。通常 89c51 复位有自 动上电复位和人工按键复位两种。 xtal1 和 xtal2:片内震荡电路输入线,这两个端子用来外接石英晶体和微调电容, 即用来连接 89c51 片内 osc(震荡器)的定时反馈回路。 3.3 复位电路和时钟电路 3.3.1 复位电路设计 单片机在启动运行时都需要复位,使
28、cpu 和系统中的其他部件都处于一个确定的 初始状态,并从这个状态开始工作。mcs-51 单片机有一个复位引脚 rst,采用施密特触 发输入。当震荡器起振后,只要该引脚上出现 2 个机器周期以上的高电平即可确保时 器件复位1。复位完成后,如果 rst 端继续保持高电平,mcs-51 就一直处于复位状态, 只要 rst 恢复低电平后,单片机才能进入其他工作状态。单片机的复位方式有上电自 动复位和手动复位两种,图 3.5 是 51 系列单片机统常用的上电复位和手动复位组合电 路,只要 vcc 上升时间不超过 1ms,它们都能很好的工作。 图 3.5 复位电路 3.3.2 时钟电路设计 单片机中 c
29、pu 每执行一条指令,都必须在统一的时钟脉冲的控制下严格按时间节 拍进行,而这个时钟脉冲是单片机控制中的时序电路发出的。cpu 执行一条指令的各个 微操作所对应时间顺序称为单片机的时序。mcs-51 单片机芯片内部有一个高增益反相 放大器,用于构成震荡器,xtal1 为该放大器的输入端,xtal2 为该放大器输出端,但 形成时钟电路还需附加其他电路1。 本设计系统采用内部时钟方式,利用单片机内部的高增益反相放大器,外部电路 简单,只需要一个晶振和 2 个电容即可,如图 3.6 所示。 图 3.6 时钟电路 电路中的器件选择可以通过计算和实验确定,也可以参考一些典型电路的参数, 电路中,电容器
30、c1 和 c2 对震荡频率有微调作用,通常的取值范围是 3010pf,在这 个系统中选择了 33pf;石英晶振选择范围最高可选 24mhz,它决定了单片机电路产生 的时钟信号震荡频率,在本系统中选择的是 12mhz,因而时钟信号的震荡频率为 12mhz。 3.4 led 显示系统设计 3.4.1 led 基本结构 led 是发光二极管显示器的缩写。led 由于结构简单、价格便宜、与单片机接口方 便等优点而得到广泛应用。led 显示器是由若干个发光二极管组成显示字段的显示器件 6。在单片机中使用最多的是七段数码显示器。led 七段数码显示器由 8 个发光二极管 组成显示字段,其中 7 个长条形的
31、发光二极管排列成“日”字形,另一个圆点形的发 光二极管在显示器的右下角作为显示小数点用,其通过不同的组合可用来显示各种数 字。led 引脚排列如下图 3.7 所示: 图 3.7 led 引脚排列 3.4.2 led 显示器的选择 在应用系统中,设计要求不同,使用的 led 显示器的位数也不同,因此就生产了 位数,尺寸,型号不同的 led 显示器供选择,在本设计中,选择 4 位一体的数码型 led 显示器,简称“4-led” 。本系统中前一位显示电压的整数位,即个位,后两位显示电 压的小数位。 4-led 显示器引脚如图 3.8 所示,是一个共阴极接法的 4 位 led 数码显示管,其中 a,b
32、,c,e,f,g 为 4 位 led 各段的公共输出端,1、2、3、4 分别是每一位的位数选 端,dp 是小数点引出端,4 位一体 led 数码显示管的内部结构是由 4 个单独的 led 组 成,每个 led 的段输出引脚在内部都并联后,引出到器件的外部。 图 3.8 4 位 led 引脚 对于这种结构的 led 显示器,它的体积和结构都符合设计要求,由于 4 位 led 阴 极的各段已经在内部连接在一起,所以必须使用动态扫描方式(将所有数码管的段选 线并联在一起,用一个 i/o 接口控制)显示。 3.4.3 led 译码方式 译码方式是指由显示字符转换得到对应的字段码的方式,对于 led 数
33、码管显示器, 通常的译码方式有硬件译码和软件译码方式两种。 硬件译码是指利用专门的硬件电路来实现显示字符码的转换。 软件译码就是编写软件译码程序,通过译码程序来得到要显示的字符的字段码, 译码程序通常为查表程序3。 本设计系统中为了简化硬件线路设计,led 译码采用软件编程来实现。由于本设计 采用的是共阴极 led,其对应的字符和字段码如下表 3.3 所示。 表 3.3 共阴极字段码表 显示字符共阴极字段码 03fh 106h 25bh 34fh 466h 56dh 67dh 707h 87fh 96fh 3.4.4 led 显示器与单片机接口设计 由于单片机的并行口不能直接驱动 led 显示
34、器,所以,在一般情况下,必须采用 专用的驱动电路芯片,使之产生足够大的电流,显示器才能正常工作7。如果驱动电 路能力差,即负载能力不够时,显示器亮度就低,而且驱动电路长期在超负荷下运行 容易损坏,因此,led 显示器的驱动电路设计是一个非常重要的问题。 为了简化数字式直流电压表的电路设计,在 led 驱动电路的设计上,可以利用单 片机 p0 口上外接的上拉电阻来实现,即将 led 的 a-g 段显示引脚和 dp 小数点显示引 脚并联到 p0 口与上拉电阻之间,这样,就可以加大 p0 口作为输出口的驱动能力,使 得 led 能按照正常的亮度显示出数字,如图 3.9 所示。 图 3.9 led 与
35、单片机接口间的设计 3.5 电压调节电路及声光报警电路 3.5.1 电压调节电路 通过滑动电阻器调节电压,在仪表上显示出来,调节电路如图 3.10: 图 3.10 3.5.2 声光报警电路 当任一一个电压表获得的电压值超过设定阀值,本电路中阀值为 1v,扬声器和二极管会工作, 扬声器发出一定频率的“哔哱”声音,同时二极管发光。如图 3.11 图 3.11 3.6 总体电路设计 经过以上的设计过程,可设计出基于单片机的数字直流电压表硬件电路原理图如 图 3.12 所示。 图 3.12 基于单片机的数字电压表 proteus 仿真 此电路的工作原理是:+5v 模拟电压信号通过变阻器 vr1 分压后
36、由 adc08008 的 in7 通道进入(由于使用的 in0 通道,所以 adda,addb,addc 均接低电平) ,经过模/数 转换后,产生相应的数字量经过其输出通道 d0-d7 传送给 at89c51 芯片的 p1 口, at89c51 负责把接收到的数字量经过数据处理,产生正确的 7 段数码管的显示段码传送 给四位 led,同时它还通过其四位 i/o 口 p2.0、p2.1、p2.2、p2.3 产生位选信号控制 数码管的亮灭。此外,at89c51 还控制 adc0808 的工作。其中,单片机 at89c51 通过定 时器中断从 p2.4 输出方波,接到 adc0808 的 clock
37、,p2.6 发正脉冲启动 a/d 转换, p2.5 检测 a/d 转换是否完成,转换完成后,p2.7 置高从 p1 口读取转换结果送给 led 显示出来3。 数字直流电压表的硬件电路已经设计完成,就可以选取相应的芯片和元器件,利 用 proteus 软件绘制出硬件的原理,并仔细地检查修改,直至形成完善的硬件原理图。 但要真正实现电路对电压的测量和显示的功能,还需要有相应的软件配合,才能达到 设计要求。 4 程序设计 4.1 程序设计总方案 根据模块的划分原则,将该程序划分初始化模块,a/d 转换子程序和显示子程序, 这三个程序模块构成了整个系统软件的主程序,如图 4.1 所示。 开始 调用a/
38、d转换子程序 调用显示子程序 结束 初始化 图 4.1 数字式直流电压表主程序框图 4.2 系统子程序设计 4.2.1 初始化程序 所谓初始化,是对将要用到的 mcs-51 系列单片机内部部件或扩展芯片进行初始工 作状态设定,初始化子程序的主要工作是设置定时器的工作模式,初值预置,开中断 和打开定时器等。 4.2.2 a/d 转换子程序 a/d 转换子程序用来控制对输入的模块电压信号的采集测量,并将对应的数值存入 相应的内存单元,其转换流程图如图 4.2 所示。 启动转换 a/d 转换结束? 输出转换结果 数值转换 显示 结束 图 4.2 a/d 转换流程图 4.2.3 显示子程序 显示子程序
39、采用动态扫描实现四位数码管的数值显示,在采用动态扫描显示方式 时,要使得 led 显示的比较均匀,又有足够的亮度,需要设置适当的扫描频率,当扫 描频率在 70hz 左右时,能够产生比较好的显示效果,一般可以采用间隔 10ms 对 led 进行动态扫描一次,每一位 led 的显示时间为 1ms。 在本设计中,为了简化硬件设计,主要采用软件定时的方式,即用定时器 0 溢出 中断功能实现 11s 定时,通过软件延时程序来实现 5ms 的延时。 4.3 仿真 4.3.1 软件调试 软件调试的主要任务是排查错误,错误主要包括逻辑和功能错误,这些错误有些 是显性的,而有些是隐形的,可以通过仿真开发系统发现
40、逐步改正。proteus 软件可以 对基于微控制器的设计连同所有的周围电子器件一起仿真,用户甚至可以实时采用诸 开始 如 led/lcd、键盘、rs232 终端等动态外设模型来对设计进行交互仿真。proteus 支持 的微处理芯片包括 8051 系列、avr 系列、pic 系列、hc11 系列及 z80 等等。proteus 可以完成单片机系统原理图电路绘制、pcb 设计,更为显著点的特点是可以与 u visions3 ide 工具软件结合进行编程仿真调试8。 本系统的调试主要以软件为主,其中,系统电路图的绘制和仿真我采用的是 proteus 软件,而程序方面,采用的是汇编语言,用 keil
41、软件将程序写入单片机。 4.3.2 显示结果及误差分析 显示结果 1.当 in0 输入电压值为 3.50v 时,显示结果如图 4.3 所示。测量误差为 0.02v。 图 4.3 图 4.4 2. 当 in0 口输入电压值为 2.50v 时,显示结果如图 4.4。测量误差为 0.02v。输入电 压为 3.50v 时,led 的显示结果为 3.48v,输入电压为 3.50v 时,led 的显示结果为 3.48v,在多次试验中,电路中仪表的值总与 led 屏显示的值有一定的差值,因为在数 模转换及 led 屏限流电阻上的电压损耗,使到达最终 led 的电压有略微降低是正常的, 在误差范围之内。 实物
42、运行图:系统通电后,两个电压数据交替循环显示,时间间隔为 1s。 结束语 经过这一段时间的努力,课程设计基于单片机的数字电压表基本完成。但设计中 的一些细微之处不是很完善。在电路中用 proteus 软件实现了仿真,在这过程中,使 我对电路设计和单片机的使用等都有了新的认识。通过这次设计学会了 proteus 和 keil 软件的使用方法,掌握了从系统的需要、方案的设计、功能模块的划分、原理图 的设计和电路图的仿真的设计流程,积累了不少经验。 基于单片机的数字电压表使用性强、结构简单、成本低、外接元件少。在实际应 用工作应能好,测量电压准确,精度高。系统功能、指标达到了课题的预期要求、系 统在
43、硬件设计上充分考虑了可扩展性,经过一定的改造,可以增加功能。本文设计主 要实现了数字电压表测量一路电压的功能,详细说明了从原理图的设计、电路图的仿 真再到软件的调试。 通过本次设计,我对单片机这门课有了进一步的了解。无论是在硬件连接方面还 是在软件编程方面。本次设计采用了 at89c51 单片机芯片,与以往的单片机相比增加 了许多新的功能,使其功能更为完善,应用领域也更为广泛。设计中还用到了模/数转 换芯片 adc0808,以前在学单片机课程时只是对其理论知识有了初步的理解。通过这次 设计,对它的工作原理有了更深的理解。在调试过程中遇到很多问题,最后和老师同 学一步一个脚印解决了一个又一个问题。 这次电路的设计和仿真,基本上达到了课程设计的功能要求。在以后的实践中, 我将继续努力学习电路设计方面的理论知识,并理论联系实际,争取在电路设计方面 能有所提升。 参考文献 1 胡健.单片机原理及接口技术.北京:机械工业出版社,2004 年 10 月 2 于殿泓.单片机原理与程序设计实验教程.西安电子科技大学出版社,2007 年 5 月 3 谢维成
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 苏教版四年级下册数学第三单元 三位数乘两位数 测试卷完整参考答案
- 框架性合作协议书(10篇)
- 诚信承诺要点保证书
- 货物运输与广告合作协议
- 购房担保合同法律效力
- 购销合同印花税的税率计算器使用便捷
- 购销合同法律保护建议
- 购销合同签订中的合同协同办公
- 资管产品存款策略研究
- 超市食品保证书示例
- 2023年天猫超市消费新趋势白皮书
- 常规冰冻制片常见问题分析湘雅医院病理科付春燕
- 燃气项目各种管理制度
- 腮腺及面神经解剖
- 无机非金属材料工程专业大学生职业生涯规划书
- 轴对称图形与中心对称图形的认识
- 医院病历门诊病历处方笺
- 我的职业梦,我的中国梦(6篇)
- 剪映:手机短视频制作-配套课件
- 财务审计投标方案
- 梅城小学一日常规检查表-第-周
评论
0/150
提交评论