ADC0832

ADC0832

电子工业芯片产品
ADC0832是美国国家半导体公司生产的一种8位分辨率、双通道A/D转换芯片。由于它体积小,兼容性,性价比高而深受单片机爱好者及企业欢迎,其目前已经有很高的普及率。学习并使用ADC0832可是使我们了解A/D转换器的原理,有助于我们单片机技术水平的提高。
  • 中文名:ADC0832
  • 外文名:
  • 所属品牌:
  • 产品类型:
  • 分辨率:8位
  • A/D转换器:逐次逼近式
  • A/D转换:双通道

特点

·输入输出电平与TTL/CMOS相兼容;

·5V电源供电时输入电压在0~5V之间;

·工作频率为250KHZ,转换时间为32μS;

·一般功耗仅为15mW;

·8P、14P—DIP(双列直插)、PICC多种封装;

·商用级芯片温宽为0°Cto+70°C,工业级芯片温宽为−40°Cto+85°C;

芯片接口说明:

·CS_片选使能,低电平芯片使能。

·CH0模拟输入通道0,或作为IN+/-使用。

·CH1模拟输入通道1,或作为IN+/-使用。

·GND芯片参考0电位(地)。

·DI数据信号输入,选择通道控制。

·DO数据信号输出,转换数据输出。

·CLK芯片时钟输入。

·Vcc/REF电源输入及参考电压输入(复用)。

ADC0832为8位分辨率A/D转换芯片,其最高分辨可达256级,可以适应一般的模拟量转换要求。其内部电源输入与参考电压的复用,使得芯片的模拟电压输入在0~5V之间。芯片转换时间仅为32μS,据有双数据输出可作为数据校验,以减少数据误差,转换速度快且稳定性能强。独立的芯片使能输入,使多器件挂接和处理器控制变的更加方便。通过DI数据输入端,可以轻易的实现通道功能的选择。

控制原理

单片机对ADC0832的控制原理

正常情况下ADC0832与单片机的接口应为4条数据线,分别是CS、CLK、DO、DI。但由于DO端与DI端在通信时并未同时有效并与单片机的接口是双向的,所以电路设计时可以将DO和DI并联在一根数据线上使用。当ADC0832未工作时其CS输入端应为高电平,此时芯片禁用,CLK和DO/DI的电平可任意。当要进行A/D转换时,须先将CS使能端置于低电平并且保持低电平直到转换完全结束。此时芯片开始转换工作,同时由处理器向芯片时钟输入端CLK输入时钟脉冲,DO/DI端则使用DI端输入通道功能选择的数据信号。在第1个时钟脉冲的下沉之前DI端必须是高电平,表示起始信号。在第2、3个脉冲下沉之前DI端应输入2位数据用于选择通道功能,其功能详见官方资料

如资料所示,当此2位数据为“1”、“0”时,只对CH0进行单通道转换。当2位数据为“1”、“1”时,只对CH1进行单通道转换。当2位数据为“0”、“0”时,将CH0作为正输入端IN+,CH1作为负输入端IN-进行输入。当2位数据为“0”、“1”时,将CH0作为负输入端IN-,CH1作为正输入端IN+进行输入。到第3个脉冲的下沉之后DI端的输入电平就失去输入作用,此后DO/DI端则开始利用数据输出DO进行转换数据的读取。从第4个脉冲下沉开始由DO端输出转换数据最高位DATA7,随后每一个脉冲下沉DO端输出下一位数据。直到第11个脉冲时发出最低位数据DATA0,一个字节的数据输出

完成。也正是从此位开始输出下一个相反字节的数据,即从第11个字节的下沉输出DATA0。随后输出8位数据,到第19个脉冲时数据输出完成,也标志着一次A/D转换的结束。最后将CS置高电平禁用芯片,直接将转换后的数据进行处理就可以了。

作为单通道模拟信号输入时ADC0832的输入电压是0~5V且8位分辨率时的电压精度为19.53mV。如果作为由IN+与IN-输入的输入时,可是将电压值设定在某一个较大范围之内,从而提高转换的宽度。但值得注意的是,在进行IN+与IN-的输入时,如果IN-的电压大于IN+的电压则转换后的数据结果始终为00H。

简单应用

图1

上图中说明了,ADC0832的封装以及工作模式的选取...

图2

此图说明了ADC0832的工作时序..时钟与DI,DO输入,输出的关系..

下面是测试程序,选择CH1,单片机晶振为,18.432MHz

;ADC0832简单测试(改)

A_0832_CSEQUP1.0;CS

A_0832_CLKEQUP1.1;CLK

A_0832_DIEQUP1.2;DI

A_0832_DEQUP1.3;DO

A_0832_TEQU40H;读取时的脉冲计数

A_0832_DAEQU41H;数据所存位置

ORG0

LJMPMAIN

ORG30H

MAIN:LCALLADC_RD

MOVA,A_0832_DA

AJMP$

ADC_RD:

MOVA_0832_T,#8

CLRA_0832_CLK

CLRA_0832_CS

SETBA_0832_DI;START

SETBA_0832_CLK;第一个上升沿

NOP

NOP

NOP

CLRA_0832_CLK

NOP

NOP

SETBA_0832_DI;选择CH1,通过组合选取通道(SGL/DIF)

NOP

SETBA_0832_CLK;第二个上升沿

NOP

NOP

NOP

CLRA_0832_CLK

NOP

NOP

SETBA_0832_DI;选择CH1,通过组合选取通道(ODD/SIGN)

NOP

SETBA_0832_CLK;第三个上升沿

NOP

NOP

NOP

CLRA_0832_CLK;首个下降沿

NOP

NOP

NOP

SETBA_0832_CLK

NOP

NOP

A_0832_RD:;读取前,8位

CLRA_0832_CLK

NOP

NOP

NOP

SETBA_0832_CLK

MOVC,A_0832_D

RLCA

DJNZA_0832_T,A_0832_RD

MOVA_0832_DA,A

RRA

MOVA_0832_T,#7

A_0832_RD1:;读后7位,+前1位

CLRA_0832_CLK

NOP

NOP

NOP

SETBA_0832_CLK

MOVC,A_0832_D

RRCA

DJNZA_0832_T,A_0832_RD1

CJNEA,A_0832_DA,ADC_RD

SETBA_0832_CS

RET

END

相关词条

相关搜索

其它词条