模数转换芯片AD7810的原理及应用

描述

     AD7810是美国模拟器件公司(Analog Devices)生产的一种低功耗10位高速串行A/D转换器。该产品有8脚DIP和SOIC两种封装形式,并带有内部时钟。它的外围接线极其简单,AD7810的转换时间为2μs,采用标准SPI同步串行接口输出和单一电源(2.7V~5.5V)供电。在自动低功耗模式下,该器件在转换吞吐率为1kSPS时的功耗仅为27μW,因此特点适合于便携式仪表及各种电池供电的应用场合使用。

  1 AD7810引脚功能

  AD7810引脚排列如图1所示,各引脚的功能如下:


  1 脚CONVST:转换启动输入信号。

  2 脚VIN+:模拟信号同相输入端。

  3 脚VIN-:模拟信号反相输入端。

  4 脚GND:接地端口。

  5 脚VREF:转换参考电压输入端。

  6 脚DOUT:串行数据输出端。

  7 脚SCLK:时钟输入端。

  8 脚VDD:电源端。

  2 AD7810主要参数

  AD7810的主要参数如下:

  分辨率:10位二进制;

  转换时间:2μs;

  非线性误差:±1LSB;

  电源电压范围:2.7~5.5V;

  电源功耗:高速方式时为17.5mW,低功耗方式时为5μW;

  参考电压VEFR范围:1.2V~VDD;

  模拟电压输入范围:0V~VREF;

  输出形式:SPI同步串行输出,与TTL电平兼容。

  3.1 高速模式工

  图2是AD7810工作在高速模式时的时序图。在此模式下,启动信号CONVST一般处于高电平。在CONVST端输入一个负脉冲,其下降沿将启动一次转换。若采用内部时钟,那么,转换需要2μs的时间(图中t1)。当转换结束时(图中A点),AD7810会自动将转换结果锁存到输出移位寄存器中。此后,在每一个SCLK脉冲的上升沿,数据按由高到低的原则(首先发送DB9,最后发送DB0)依次出现在DOUT上。如果在转换还未结束之前就发出SCLK信号来启动数据输出,那么,在DOUT上出现的将是上一次转换的结果。


  启动信号CONVST应在转换结束前变为高电平,即t3应小于t1,否则器件将自动进入低功耗模式。另外,串行时钟SCLK的最高频率不能超过20MHz。

  3.2 自动低功耗模式

  图3是AD7810工作在自动低功耗模式时的时序图。在此模式下,启动信号CONVST为低电平时,器件处于低功耗休眠状态。当在CONVST端输入一个正脉冲时,可在其上升沿将器件从休眠状态唤醒,唤醒过程需要1μs的时间(图中t2)。当器件被唤醒后,系统将自动启动一次转换,转换时间也是2μs(图中t1)。转换结束时,AD7810将转换结果锁存到输出移位寄存器中,同时自动将器件再一次置于低拉耗状态。


  启动信号CONVST正脉冲的宽度(图2中t3)应小于1μs,否则器件被唤醒后将不会自动启动转换,而是将A/D转换的启动时间顺延至CONVST的睛降沿处。自动低功耗模式是AD7810是一大特铎,一般当数据吞吐率小于100kSPS时,应使器件工作在此模式下。在5V电源电压下,当数据吞吐率为100kSPS时,器件的功耗2.7mW;而当数据吞吐率为 10kSPS时,功耗为270μW;若数据吞吐率为1kSPS,则其功耗仅27μW。

  4 AD7810的典型应用

  AD7810应用时几乎不需外围元件。图4所示是其典型应用电路,其参考电压VREF接至VDD,模拟输入VIN-接至GND,而待转换电压则从VIN+输入。


  AD7810 几乎可与各种MCU进行接口,图4中的MCU可以是8051 或PIC16C6X/7X。当与PIC16C6X/7X系列单片机进行接口时,可将SCLK接至单片机的SCK(RC3),将DOUT接至SDI(RC4),而其启动信号CONVST则可接至单片机的任意输出口上(如RC0)。由于PIC单片机的 SPI方式每次只能接收8位数据,因此10位数据应分两次读取。当AD7810与8051接口时,电路采用的是一种模拟串口方式,AD7810的 SCLK、DOUT和CONVST分别接至8051的P1.0、P1.1和P1.2,只要严格按照AD7810的时序要求操作,一般接口都不会有问题。这种方式实际上可扩展到所有的MCU种类。另外,8051也可利用其串行口工作方式0与AD7810进行通讯(图中未画出),但这时应解决好两个问题:一是由于8051在TXD的上升沿进行采样,这样,TXD应经过一个反相器再接到SCLK,而将RXD接至DOUT,然后将CONVST接至任意一个输出端口。二是8051串行口首先接收低位数据,这一点与AD7810刚好相反,因此,编程时应当注意。

  下面给出PIC16C6X/7X和8051分别与AD7810进行通讯的两段程序,作者只对与A/D转换有关的部分进行了编写(常用资源定义、芯片定义等均未列出),两段程序均可钭AD7810的工作控制在自动低功耗方式。8051与AD7810通讯程序如下:

  START:CLR P1.0 ;初始化

  SETB P1.0

  CLR P1.2

  LOOP:CALL CON0

  ... ;主程序省略

  ;

  ;A/D转换子程序,返回时数据低8位在R2中,高2位在R3中

  CON0:MOV R1,#`10 ;10位数据

  MOV R2,#0

  SETB P1.2 ;唤醒启动AD7810

  CLR P1.2

  CON1:SETB P1.0 ;发送SCLK信号

  MOV C,P1.1 ;读一位数据

  CLR P1.0

  MOV A,R2 ;数据移位

  RLC A

  MOV R2,A

  MOV A,R3

  RLC A

  MOV R3,A

  DJNZ R1,CON1

  RET

  PIC16C6X/7X与AD7810的通讯程序如下:

  REG1 EQU 0X20 ;寄存器定义

  REG2 EQU 0X21

  CLRF PORTC ;端口初始化

  BSF STATUS,RP0

  MOVLW 0X30

  MOVWF TRISC

  BCF STATUS,PR0

  BCF SSPCON,SSPEN

  MOVLW 0X00 ;SPI初始化

  MOVWF SSPCON

  BSF SSPCON,SSPEN SPI开放

  LOOP CALL ADCON

  ... ;主程序省略

  ;

  ;A/D转换子程序,返回时数据低8位在REFG1中,高2位在REG2中

  ADCON BSF PORTC,0 ;唤醒启动AD7810

  BCF PORTC,0

  MOVWF SSPBUF ;启动接收高8位

  BSF STATUS,RP0

  CON1 BTFSS SSPSTAT,BF ;数据已接收?

  GOTO CON1 ;没有收到

  BCF STATUS,RP0

  MOVF SSPBUF,W

  MOVWF REG1 ;高8位送REG1

  MOVWF SSPBUF ;启动接收低2位

  BSF STATUS,PR0

  CON1 BTFSS SSPSTAT,BF ;数据已接收?

  GOTO CON1 ;没有收到

  BCF STATUS,RP0

  MOVF SSPBUF,W

  ANDLW B11000000 ;保留有效位

  MOVWF REG2 ;低2位送REG2

  BCF STATUS,C ;进位位清零

  RLCF REG2,1 ;数据调整

  RLCF REG1,1

  RLCF REG2,1

  RLCF REG1,1 ;低8位

  RLCF REG2,1 ;高2位

  RETURN



  :
打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

全部0条评论

快来发表一下你的评论吧 !

登录/注册
×
20
完善资料,
赚取积分