模拟电子
返回首页

10位串行模数转换芯片AD7810的原理及应用

2006-05-07 来源:国外电子元器件

    摘要:文章对高速低功耗10位串行模数转换芯片AD7810的引脚功能、主要参数、特性及典型应用作了详尽的介绍,同时给出了微处理器PIC16C6X/7X以及8051单片机与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 AD7810的工作模式

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

进入模拟电子查看更多内容>>
相关视频
  • 嵌入式开发入门模电(模拟电路)基础

  • 世健KOL: A2B及音频处理系统解决方案介绍

  • 运算放大器视频教程

  • 功率半导体器件

  • 模拟电子电路

  • 德州仪器全系列直流降压产品详解

最新器件
精选电路图
  • CCD图像传感器在微光电视系统中的应用

  • 如何利用ESP8266制作一个简单的四轴飞行器

  • 离子检测器电路分析

  • 优化电路板布局的简单方法

  • 一个简单的立体声平衡指示器电路

  • 使用NE555和磁簧开关的橱柜照明电路

    相关电子头条文章