单片机基础(第3版)――第10章

整理文档很辛苦,赏杯茶钱您下走!

免费阅读已结束,点击下载阅读编辑剩下 ...

阅读已结束,您可以下载文档离线阅读编辑

资源描述

单片机基础(第3版)李广弟等编著北京航空航天大学出版社2007年6月第10章单片机A/D及D/A转换接口10.1单片机测控系统与模拟输入通道10.2A/D转换器接口10.3D/A转换器接口10.4A/D与D/A转换器芯片的串行接口10.1单片机测控系统与模拟输入通道10.1.1单片机测控系统概述测控包含“测”与“控”两个过程。所谓“测”就是实时采集被控对象的物理参量,诸如温度、压力、流量、速度和转速等。这些参量通常都是模拟量,即连续变化的物理量。所谓“控”就是把采集的数据经单片机计算、比较等处理后得出结论,以对被控对象实施校正控制。但经单片机处理后得到的是数字量结果。测控系统离不开模拟量与数字量的相互转换,因此,模/数(A/D)与数/模(D/A)转换也就成了测控系统的重要内容。10.1.2模拟输入通道模拟输入通道的工作从采集信号开始。由于传感器采集到的模拟信号幅值通常很小,而且连续变化的信号容易受到干扰,因此,要对传感器采集到的原始信号进行放大、采样、保持、滤波等处理后,才能送给A/D转换器。这一系列的处理过程构成了模拟输入通道,如下图。1.传感器传感器的主要功能是采集信号,也兼有信号转换功能,即把采集到的非电信号转换为电信号(电压或电流),以便于后续处理。传感器的种类繁多,常用的传感器有如下几种:①温度传感器:用于将温度转换为电信号。②光电传感器:利用光电效应将光信号转换为电信号。③湿度传感器:常用的湿度传感器有毛发湿度计、干湿球湿度计、金属氧化物湿敏元件等。④流量传感器:用于测量液体和气体的流量。常用的流量传感器有速度式流量计和容积式流量计等。⑤压力传感器:用于大气压力(气压)测量和容器壁压力测量等。⑥机械量传感器:常用的机械量有拉力、压力、位移、速度、加速度、扭矩及荷重等。常见的机械量传感器有电阻应变片、力传感器、荷重传感器、位移传感器和转速传感器等。⑦成分分析传感器:用于对混合气体或混合物的成分进行自动分析。⑧pH值传感器:用于测量水溶液的酸碱度。2.放大器传感器得到的电压或电流信号往往幅度较小,难以直接进行A/D转换,需要使用放大器对模拟信号进行放大处理。放大器的种类很多,但在模拟输入通道中使用的是一种具有高放大倍数并带深度负反馈的直接耦合放大器,由于它可以对输入信号进行多种数学运算(例如比例、加、减、积分和微分等),所以称为运算放大器。运算放大器具有输入阻抗高,增益大,可靠性高,价格低和使用方便等特点。现在已有各种专用或通用的运算放大器可供选择。3.采样/保持电路采样是为了跟踪输入信号的变化,其实质是将一个连续变化的模拟信号转换为时间上离散的采样信号,采样频率要远高于模拟信号中的最高频率成分(一般为2.5倍)。保持则是为了把采样信号保持一段时间,因为其后的A/D转换需要有一个时间过程。在保持期间要维持信号的稳定,尽可能保持信号不变。在模拟输入通道中,采样电路和保持电路是合在一起的,称为采样/保持电路。如下图所示。4.滤波器滤波可分为模拟滤波和数字滤波两种。模拟滤波由电子元器件搭建的滤波电路完成,模拟滤波又可分为无源和有源两种。无源滤波是使用无源器件(电感、电容和电阻)构成的滤波电路。有源滤波器则是用放大器和电容、电阻构成的滤波电路。数字滤波,就是通过程序对采样信号进行平滑加工,以提高其有用信号,消除或抑制干扰信号。有多种数字滤波程序,例如,程序判断滤波程序、中值滤波程序、算术平均滤波程序、加权平均滤波程序、一阶滞后滤波程序以及复合滤波程序等。与模拟滤波相比,数字滤波具有众多优点,所以在现代测控系统中广泛使用数字滤波。数字滤波不但不需要硬件设备,而且使用也很方便,只需在程序进入数据处理或控制算法前,附加一段滤波程序即可。5.多路转换许多测控系统都是多路系统,以便进行多路参量采集。在多路系统中,只要速度允许,就应该采用多通道共用一个A/D转换器的方案,以简化结构降低成本。需要在模拟输入通道中设置一个多路开关进行通道切换,以实现各通道逐个、分时地被轮流接通。10.2A/D转换器接口10.2.18位A/D转换芯片与80C51接口1.ADC0809芯片ADC0809采用逐次逼近式A/D转换原理,可实现8路模拟信号的分时采集,片内有8路模拟选通开关,以及相应的通道地址锁存与译码电路,转换时间为100μs左右。ADC0809的内部逻辑结构如下图所示。图中多路开关可选通8个模拟通道,允许8路模拟量分时输入,共用一个A/D转换芯片进行转换。地址锁存与译码电路完成对A、B、C3个地址位进行锁存和译码,其译码输出用于通道选择。8位A/D转换器是逐次逼近式,由控制与时序电路、逐次逼近寄存器、树状开关以及256R电阻阶梯网络等组成。输出锁存器用于存放和输出转换得到的数字量。ADC0809内部逻辑结构ADC0809各引脚功能如下:IN7~IN0:模拟量输入通道。A、B、C:地址线,模拟通道的选择信号。A为低位地址,C为高位地址。能进行8个通道的选择。ALE:地址锁存允许信号。对应ALE上跳沿,A、B、C地址状态送入地址锁存器中。START:转换启动信号。START上跳沿时,所有内部寄存器清0;START下跳沿时,开始进行A/D转换;在A/D转换期间,START应保持低电平。D7~D0:数据输出线。OE:输出允许信号。用于控制三态输出锁存器向单片机输出转换得到的数据。OE=0,输出数据线呈高电阻;OE=1,输出转换得到的数据。CLK:外部时钟信号引入端。EOC:转换结束信号。EOC=0,正在进行转换;EOC=1,转换结束。VCC:+5V电源。VREF:参考电源。2.ADC0809与80C51接口下图给出了ADC0809与80C51的连接。8路模拟通道选择信号A、B、C分别接最低3位地址A0、A1、A2(即P0.0、P0.1、P0.2),而地址锁存允许信号ALE由P2.0控制,则8路模拟通道的地址为FEF8H~FEFFH。【例10.1】设有一个8路巡回检测系统,其采样数据依次存放在外部RAMA0H~A7H单元中,按上图的接口电路,ADC0809的8个通道地址为FEF8H~FEFFH。试进行程序设计。设计思路:执行一条“MOVX@DPTR,A”指令,产生WR信号,使ALE和START有效,就可以启动一次A/D转换。但一次启动只能进行一个通道的转换,8个通道的A/D转换需按通道顺序逐个进行。为此,在程序中应当有改变通道号的指令,并且每改变一次就执行一次启动A/D转换指令。参考程序初始化程序:MOVR0,#A0H;数据存储区首址MOVR2,#08H;通道计数SETBIT1;边沿触发方式SETBEA;中断允许SETBEX1;外部中断1允许MOVDPTR,#FEF8H;通道首地址MOVX@DPTR,A;启动A/D转换HERE:SJMPHERE;等待中断中断服务程序:MOVXA,@DPTR;读一个通道数据MOVX@R0,A;存数据INCDPTR;指向下一通道INCR0;指向下一存储单元DJNZR2,NEXTRETINEXT:MOVX@DPTR,A;启动下一通道A/D转换RETI10.2.212位A/D转换芯片与80C51接口对于多于8位的A/D转换芯片,接口时要考虑转换结果的分时读出问题。现以12位A/D转换芯片AD574A为例进行说明。AD574A与80C51接口的信号线连接部分如下图所示。AD574A有两个模拟输入端,其中10VIN的电压范围是0~10V,20VIN的电压范围是0~20V。在80C51系统中使用AD574A芯片,其转换数据应该分两次读出,并按高8位和低4位分次。分次读出由A0控制,该引脚一般接地址线的最低位A0。A0=0时,读高8位;A0=1时,读低4位。R/C:读/启动转换信号。R/C=0时为启动转换信号;R/C=1时为读信号。STS:转换结束信号。转换期间为高电平,转换结束时下跳为低电平。12/8:输出位数选择信号。12/8=1时,为12位输出,12/8=0时,为8位输出。CE:允许信号,高电平有效。参与启动转换和读数据的控制。10.2.3A/D转换芯片应用说明1.按原理划分的芯片类型积分型A/D转换器。也称双斜率或多斜率A/D转换器。应用最为广泛,具有精度高、抗干扰能力强等优点。逐次逼近型A/D转换器。原理简单,便于实现,不存在时间延迟问题。闪烁型A/D转换器。最大特点是速度快,但功耗大且电路复杂,所以芯片尺寸也比较大。∑△型A/D转换器。又称为过采样A/D转换器。虽然出现得较晚,但却具有分辨率高,价格便宜以及抗干扰能力强等优点。2.输入电压信号形式单极性电压信号,各种A/D转换芯片都具有这种输入形式。一般可允许电压变化范围是0~+5V、0~+10V和0~+20V等。双极形式的电压信号,可正可负,虽然还是通过一条引线输入,但芯片上需要有一对极性相反的工作电源与之配合。差分信号是不共地的电压信号,两个极性的差分信号需要两条信号线输入,在芯片上表示为VIN+和VIN-。差分电压信号可以从非0V开始,其变化范围可以是±2V、±4V、±5V和±10V等。3.输出二进制代码形式二进制码A/D转换芯片输出的是二进制代码,其位数可分为8位、10位、12位、14位、16位、20位和24位等。BCD码A/D转换芯片输出的是多位BCD码,这类转换芯片的典型应用是在数字电压表中,输出的BCD码可直接送LED或LCD进行显示。常见的BCD码A/D转换芯片的位数有3位半、4位半和5位半等。4.A/D转换器分辨率A/D转换器,被转换量是电压,所以分辨率是对输入电压信号变化的分辨能力,A/D转换器位数越多,分辨率的值越小,分辨能力就越强,亦即转换器对输入量变化的敏感程度也就越高。所以选择A/D转换器时,要把位数放在重要的位置。5.A/D转换器的控制信号A/D转换芯片中有一些控制信号,包括时钟信号、转换启动信号和转换结束信号等,接口连接时要对这些信号进行处理。(1)时钟信号时钟信号A/D转换需要时钟信号的配合,有些A/D转换芯片(例如AD571等)内部有时钟电路。另外一些A/D转换芯片(例如ADC0808/0809等)内部没有时钟电路,所需时钟信号由外界提供。(2)转换启动信号转换启动信号转换启动信号应由CPU提供,不同型号的A/D转换芯片对转换启动信号的要求不尽相同。有的要求脉冲信号启动,例如ADC0804、ADC0809等芯片,而有的芯片则要求电平信号启动,例如AD570、AD571和AD574等。6.转换结束与数据读取A/D转换后得到的数字量数据应及时传送给单片机进行处理,在数据转换完成后,进行读取。(1)定时等待方式对于一个A/D转换芯片来说,转换时间作为一项技术指标是已知且固定的,可用延时的方法等待转换结束,此即定时等待方式。(2)查询方式A/D转换芯片都提供表明转换完成的状态信号,可以用查询方式,通过测试状态就可以知道转换是否完成。(3)中断方式表明转换是否完成的状态信号(ADC0809为EOC)都可作为中断请求信号使用,从而可采用中断方式进行转换数据的传送。10.3.1D/A转换芯片D/A转换芯片很多,现以DAC0832为例进行说明。DAC0832为8位D/A转换芯片,单一+5V电源供电,基准电压的幅度范围为±10V,电流建立时间为1μs,采用CMOS工艺,低功耗(20mW),芯片为20引脚双列直插式封装。引脚排列如下图所示。10.3D/A转换器接口DI7~DI0:转换数据输入。CS:片选信号(输入),低电平有效。ILE:数据锁存允许信号(输入),高电平有效。WR1:第1写信号(输入),低电平有效。XFER:数据传送控制信号(输入),低电平有效。WR2:第2写信号(输入),低电平有效。IOUT1:电流输出1。当数据为全1时,输出电流最大;为全0时,输出电流最小。IOUT2:电流输出2。RFB:反馈电阻端,即运算放大器的反馈电阻端,电阻(15kΩ)已固化在芯片中。DAC0832是电流输出型D/A转换器,为得到电压的转换输出,使用时需在两个电流输出端接运算放大器,RFB即为运算放大器的反馈电阻

1 / 37
下载文档,编辑使用

©2015-2020 m.777doc.com 三七文档.

备案号:鲁ICP备2024069028号-1 客服联系 QQ:2149211541

×
保存成功