《单片机基础(第3版)——第10章.ppt》由会员分享,可在线阅读,更多相关《单片机基础(第3版)——第10章.ppt(36页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、单片机基础单片机基础(第第3版版)第第10章章10.1 单片机测控系统与模拟输入通道10.1.1 单片机测控系统概述测控包含“测”与“控”两个过程。所谓“测”就是实时采集被控对象的物理参量,诸如温度、压力、流量、速度和转速等。这些参量通常都是模拟量,即连续变化的物理量。所谓“控”就是把采集的数据经单片机计算、比较等处理后得出结论,以对被控对象实施校正控制。但经单片机处理后得到的是数字量结果。测控系统离不开模拟量与数字量的相互转换,因此,模/数(A/D)与数/模(D/A)转换也就成了测控系统的重要内容。10.1.2 模拟量输入通道模拟量输入通道的工作从采集信号开始。由于传感器采集到的模拟信号幅值
2、通常很小,而且连续变化的信号容易受到干扰,因此,要对传感器采集到的原始信号进行放大、采样、保持、滤波等处理后,才能送给A/D转换器。这一系列的处理过程构成了模拟输入通道,如下图。1.传感器传感器的主要功能是采集信号,也兼有信号转换功能,即把采集到的非电信号转换为电信号(电压或电流),以便于后续处理。传感器的种类繁多,常用的传感器有如下几种:温度传感器:用于将温度转换为电信号。光电传感器:利用光电效应将光信号转换为电信号。湿度传感器:常用的湿度传感器有毛发湿度计、干湿球湿度计、金属氧化物湿敏元件等。流量传感器:用于测量液体和气体的流量。常用的流量传感器有速度式流量计和容积式流量计等。压力传感器:
3、用于大气压力(气压)测量和容器壁压力测量等。机械量传感器:常用的机械量有拉力、压力、位移、速度、加速度、扭矩及荷重等。常见的机械量传感器有电阻应变片、力传感器、荷重传感器、位移传感器和转速传感器等。成分分析传感器:用于对混合气体或混合物的成分进行自动分析。pH值传感器:用于测量水溶液的酸碱度。2.放大器传感器得到的电压或电流信号往往幅度较小,难以直接进行A/D转换,需要使用放大器对模拟信号进行放大处理。放大器的种类很多,但在模拟输入通道中使用的是一种具有高放大倍数并带深度负反馈的直接耦合放大器,由于它可以对输入信号进行多种数学运算(例如比例、加、减、积分和微分等),所以称为运算放大器。运算放大
4、器具有输入阻抗高,增益大,可靠性高,价格低和使用方便等特点。现在已有各种专用或通用的运算放大器可供选择。3.采样/保持电路采样是为了跟踪输入信号的变化,其实质是将一个连续变化的模拟信号转换为时间上离散的采样信号,采样频率要远高于模拟信号中的最高频率成分(一般为2.5倍)。保持则是为了把采样信号保持一段时间,因为其后的A/D转换需要有一个时间过程。在保持期间要维持信号的稳定,尽可能保持信号不变。在模拟输入通道中,采样电路和保持电路是合在一起的,称为采样/保持电路。如下图所示。4.滤波器滤波可分为模拟滤波和数字滤波两种。模拟滤波由电子元器件搭建的滤波电路完成,模拟滤波又可分为无源和有源两种。无源滤
5、波是使用无源器件(电感、电容和电阻)构成的滤波电路。有源滤波器则是用放大器和电容、电阻构成的滤波电路。数字滤波,就是通过程序对采样信号进行平滑加工,以提高其有用信号,消除或抑制干扰信号。有多种数字滤波程序。与模拟滤波相比,数字滤波具有众多优点,所以在现代测控系统中广泛使用数字滤波。数字滤波不但不需要硬件设备,而且使用也很方便,只需在程序进入数据处理或控制算法前,附加一段滤波程序即可。5.多路开关许多测控系统都是多路系统,以便进行多路参量采集。在多路系统中,只要速度允许,就应该采用多通道共用一个A/D转换器的方案,以简化结构降低成本。需要在模拟输入通道中设置一个多路开关进行通道切换,以实现各通道
6、逐个、分时地被轮流接通。10.2 A/D转换器接口10.2.1 8位A/D转换芯片与80C51接口1.ADC0809芯片ADC0809采用逐次逼近式A/D转换原理,可实现8路模拟信号的分时采集,片内有8路模拟选通开关,以及相应的通道地址锁存与译码电路,转换时间为100 s左右。ADC0809的内部逻辑结构如下图所示。图中多路开关可选通8个模拟通道,允许8路模拟量分时输入,共用一个A/D转换芯片进行转换。地址锁存与译码电路完成对A、B、C 3个地址位进行锁存和译码,其译码输出用于通道选择。8位A/D转换器是逐次逼近式。输出锁存器用于存放和输出转换得到的数字量。ADC0809内部逻辑结构内部逻辑结
7、构 ADC0809各引脚功能如下:各引脚功能如下:IN7IN0:模拟量输入通道。A、B、C:地址线,模拟通道的选择信号。START:转换启动信号。START上升沿时,所有内部寄存器清0;START下降沿 时,开始进行A/D转换;在A/D转换期 间,START应保持低电平。D7D0:数据输出线。OE:输出允许信号。用于控制三态输出锁存 器向单片机输出转换得到的数据。OE0,输出数据线呈高电阻;OE1,输出数据。CLK:外部时钟信号引入端。EOC:转换结束信号(中断式或查询式)。2.ADC0809与80C51接口 下图给出了ADC0809与80C51的连接。8路模拟通道选择信号A、B、C分别接最低
8、3位地址A0、A1、A2(即P0.0、P0.1、P0.2),而地址锁存允许信号ALE由P2.0控制,则8路模拟通道的地址为FEF8HFEFFH。【例10.1】设有一个8路巡回检测系统,其采样数据依次存放在外部RAM A0HA7H单元中,按上图的接口电路,ADC0809的8个通道地址为FEF8HFEFFH。试进行程序设计。设计思路:执行一条“MOVX DPTR,A”指令,产生WR信号,使ALE和START有效,就可以启动一次A/D转换。但一次启动只能进行一个通道的转换,8个通道的A/D转换需按通道顺序逐个进行。为此,在程序中应当有改变通道号的指令,并且每改变一次就执行一次启动A/D转换指令。参考
9、程序初始化程序:MOV R0,#A0H;数据存储区首址MOV R2,#08H;通道数SETB IT1;边沿触发方式SETB EA;中断允许SETB EX1;外部中断1允许MOV DPTR,#FEF8H;通道首地址MOVX DPTR,A;启动A/D转换HERE:SJMP HERE;等待中断 中断服务程序:MOVX A,DPTR ;读一个通道数据MOVX R0,A;存数据INC DPTR;指向下一通道INC R0;指向下一存储单元DJNZ R2,NEXTRETINEXT:MOVX DPTR,A ;启动下一通道A/D转换RETI 10.2.2 12位A/D转换芯片与80C51接口对于多于8位的A/D
10、转换芯片,接口时要考虑转换结果的分时读出问题。现以12位A/D转换芯片AD574A为例进行说明。AD574A与80C51接口的信号线连接部分如下图所示。AD574A有两个模拟输入端,其中10VIN的电压范围是010 V,20VIN的电压范围是020 V。在80C51系统中使用AD574A芯片,其转换数据应该分两次读出,并按高8位和低4位分次。分次读出由A0控制,该引脚一般接地址线的最低位A0。A00时,读高8位;A01时,读低4位。R/C:读/启动转换信号。R/C0时为启动转换信号;R/C1时为读信号。STS:转换结束信号。转换期间为高电平,转换结束时下跳为低电平。12/8:输出位数选择信号。
11、12/81时,为12位输出,12/80时,为8位输出。CE:允许信号,高电平有效。参与启动转换和读数据的控制。10.2.3 A/D转换芯片应用说明1.按原理划分的芯片类型n积分型积分型A/D转换器。也称双斜率或多斜率A/D转换器。应用最为广泛,具有精度高、抗干扰能力强等优点。n逐次逼近型逐次逼近型A/D转换器。原理简单,便于实现,不存在时间延迟问题。n 闪烁型A/D转换器。最大特点是速度快,但功耗大且电路复杂,所以芯片尺寸也比较大。n 型A/D转换器。又称为过采样A/D转换器。虽然出现得较晚,但却具有分辨率高,价格便宜以及抗干扰能力强等优点。2.输入电压信号形式n单极性电压信号单极性电压信号,
12、各种A/D转换芯片都具有这种输入形式。一般可允许电压变化范围是0+5 V、0+10 V和0+20 V等。n双极形式的电压信号,可正可负,虽然还是通过一条引线输入,但芯片上需要有一对极性相反的工作电源与之配合。n差分信号是不共地的电压信号,两个极性的差分信号需要两条信号线输入,在芯片上表示为VIN+和VIN-。差分电压信号可以从非0 V开始,其变化范围可以是2 V、4 V、5 V和10 V等。3.输出二进制代码形式n二进制码二进制码A/D转换芯片输出的是二进制代码,其位数可分为8位、10位、12位、14位、16位、20位和24位等。nBCD码A/D转换芯片输出的是多位BCD码,这类转换芯片的典型
13、应用是在数字电压表中,输出的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等)内部有时
14、钟电路。另外一些A/D转换芯片(例如ADC0808/0809等)内部没有时钟电路,所需时钟信号由外界提供。(2)转换启动信号转换启动信号转换启动信号应由CPU提供,不同型号的A/D转换芯片对转换启动信号的要求不尽相同。有的要求脉冲信号启动,例如ADC0804、ADC0809等芯片,而有的芯片则要求电平信号启动,例如AD570、AD571和AD574等。6.转换结束与数据读取A/D转换后得到的数字量数据应及时传送给单片机进行处理,在数据转换完成后,进行读取。(1)定时等待方式对于一个A/D转换芯片来说,转换时间作为一项技术指标是已知且固定的,可用延时的方法等待转换结束,此即定时等待方式。(2)查
15、询方式A/D转换芯片都提供表明转换完成的状态信号,可以用查询方式,通过测试状态就可以知道转换是否完成。(3)中断方式表明转换是否完成的状态信号(ADC0809为EOC)都可作为中断请求信号使用,从而可采用中断方式进行转换数据的传送。10.3.1 D/A转换芯片D/A转换芯片很多,现以DAC0832为例进行说明。DAC0832为8位D/A转换芯片,单一+5 V电源供电,基准电压的幅度范围为10 V,电流建立时间为1 s,采用CMOS工艺,低功耗(20 mW),芯片为20引脚双列直插式封装。引脚排列如下图所示。10.3 D/A转换器接口DI7DI0:转换数据输入。CS:片选信号(输入),低电平有效
16、。ILE:数据锁存允许信号(输入),高电平有效。WR1:第1写信号(输入),低电平有效。XFER:数据传送控制信号(输入),低电平有效。WR2:第2写信号(输入),低电平有效。IOUT1:电流输出1。当数据为全1时,输出电流最大;为全0时,输出电流最小。IOUT2:电流输出2。RFB:反馈电阻端,即运算放大器的反馈电阻端,电阻(15 k)已固化在芯片中。DAC0832是电流输出型是电流输出型D/A转换器转换器,为得到电压的转换输出,使用时需在两个电流输出端接运算放大器,RFB即为运算放大器的反馈电阻。VREF:基准电压,是外加高精度电压源,与芯片内的电阻网络相连接,该电压可正可负,范围为-10
17、+10 V。基准电压决定D/A转换器的输出电压范围,例如,若VREF接+10 V,则输出电压范围是0-10 V。DGND:数字地。AGND:模拟地 DAC0832的内部结构框图如下图所示,电阻解码网络包含在图中的8位D/A转换器中。输入通道由输入寄存器和DAC寄存器构成两级数据输入锁存,由3个“与”门电路组成控制逻辑,产生LE1和LE2信号,分别对两个输入寄存器进行控制。10.3.2 DAC0832单缓冲连接方式所谓单缓冲连接方式,就是使DAC0832的两个输入寄存器中有一个(多为DAC寄存器)处于直通状态,另一个处于受控的锁存状态。在实际应用中,如果只有一路模拟量输出,或虽是多路模拟量输出但
18、并不要求输出同步的情况下,就应当采用单缓冲方式。其连接如下图所示。【例10.2】锯齿波的生成。在一些控制应用中,需要有一个线性增长的电压(锯齿波)来控制检测过程,移动记录笔或移动电子束等。对此可通过在DAC0832的输出端接运算放大器,由运算放大器产生锯齿波来实现,其电路连接如下图所示。ORG 8000HAJMP DASAWORG 8200HDASAW:MOV DPTR,#5000H;输入寄存器地址MOV R0,#00H;转换初值WW:MOV A,R0MOVX DPTR,A;D/A转换INC R0;转换值增量NOP;延时NOPNOPAJMP WW 程序清单(假定输入寄存器地址为5000H)10
19、.3.3 DAC0832双缓冲连接方式所谓双缓冲连接方式,就是把DAC0832的输入寄存器和DAC寄存器都接成受控锁存方式。在多路D/A转换中,如果要求同步输出,就应当采用双缓冲连接方式。DAC0832的双缓冲方式连接如下图所示。【例】XY绘图仪由X、Y两个方向的步进电机驱动,其中一个电机控制绘笔沿X轴方向运动,另一个电机控制绘笔沿Y轴方向运动。因此,对XY绘图仪的控制就有两点基本要求:一是需要两路D/A转换器分别给X通道和Y通道提供驱动信号,驱动绘图笔沿XY轴作平面运动;二是两路模拟信号要保证同步输出,以使绘制出的曲线光滑。否则,绘制出的曲线就会呈台阶状。单片机控制下的X-Y绘图仪输出 在使
20、用单片机控制绘图仪时,要使用两片DAC0832,并采用双缓冲方式连接,如下图所示。电路中以译码法产生地址。两片DAC0832共占据3个单元地址,其中两个输入寄存器各占一个地址,而两个DAC寄存器则合用一个地址。假定X方向DAC0832输入寄存器的地址为F0H,Y方向DAC0832输入寄存器的地址为F1H,两个DAC寄存器公用地址为F2H。X坐标数据存于Data单元中,Y坐标数据存于Data1单元中。则绘图仪的驱动程序为:MOV R1,#DATA;X坐标数据单元地址MOV R0,#0F0H;X向输入寄存器地址MOV A,R1;X坐标数据送AMOVX R0,A;X坐标数据送输入寄存器INC R1;
21、指向Y坐标数据单元地址INC R0;指向Y向输入寄存器地址MOV A,R1;Y坐标数据送AMOVX R0,A;Y坐标数据送输入寄存器INC R0;指向DAC寄存器地址MOVX R0,A;X、Y转换数据同步输出 10.4 A/D与D/A转换器芯片的串行接口10.4.1 通过I2C总线的串行接口对于有I2C总线接口的A/D或D/A转换芯片,可以通过I2C总线实现接口,现以A/D和D/A混合芯片PCF8591为例进行说明。PCF8591由Philips公司生产,是一个比较典型的带I2C总线接口的A/D和D/A转换混合芯片,CMOS半导体工艺。A/D转换部分的模拟输入通道为4路,转换结果为8位,采用具
22、有采样/保持电路的逐次逼近转换方式。D/A转换部分为1路模拟输出。双列直插式芯片的引脚排列如下图所示。各引脚功能如下:AIN3AIN0:模拟信号输入。A3A0:引脚地址。SCL、SDA:I2C总线接口信号。OSC:外部时钟输入,内部时钟输出。EXT:内外时钟选择,EXT0选择内部时钟,EXT1选择外部时钟。Aout:D/A转换模拟量输出。VDD、VSS:芯片电源。VREF:参考电源。AGND:模拟地。PCF8591的器件地址为1001,引脚地址由A2、A1和A0设定。一个系统最多可扩展8片PCF8591。PCF8591片内有控制寄存器,单片机通过向该寄存器写入控制字来控制A/D和D/A转换,为
23、此在转换前要进行写控制字传送。A/D转换部分读数据时先进行控制字的设置,以进行模拟通道选择、通道增量位和模拟信号输入形式(单端输入与差分输入)等设置。PCF8591芯片D/A转换部分写数据中的控制字的主要内容是设置模拟量输出允许位为1。随后每写入一个数据字节,转换结果就在AOUT端输出。10.4.2 通过软件模拟的串行接口对于没有串行接口的单片机芯片,可以使用软件模拟方法实现串行接口。以MAX187为例进行说明。MAX187是一个具有SPI总线的12位单模拟通道A/D转换芯片,内部有采样/保持电路,采用逐次逼近式转换方式,转换时间为10 s。其引脚排列如下图。各引脚功能如下:AIN:模拟信号输入,有效电压范围为0 VVREF。DOUT:转换结果串行输出。SCLK:时钟信号输入。CS:片选信号。SHDN:控制信号。该引脚接低电平,芯片处于低功耗状态;该引脚接高电平,芯片使用内部参考电源;该引脚悬空,芯片使用外部参考电源。VREF:参考电源。VDD:芯片电源。GND:数字地和模拟地。软件模拟串行接口的连接十分简单,只需80C51的3根口线分别连接MAX187的CS、SCLK和DOUT信号引脚,如下图所示。