主流A/D转换芯片学习详解(1):美信MAX197

在数据采集系统中,a/d转换的速度和精度又决定了采集系统的速度和精度。max197是maxim公司推出的具有12位测量精度的高速a/d转换芯片,只需单一电源供电,且转换时间很短(6us),具有8路输入通道,还提供了标准的并行接口——8位三态数据i/o口,可以和大部分单片机直接接口,使用十分方便。
max197简介
max197芯片是多量程(±10v,±5v,0~10v,0~5v)、8通道、12位高精度的a/d转换器。它采用逐次逼近工作方式,有标准的微机接口。三态数据i/o口用做8位数据总线,数据总线的时序与绝大多数通用的微处理器兼容。全部逻辑输入和输出与ttl/cmos电平兼容。新型a/d转换器芯片max197与一般a/d转换器芯片相比,具有极好的性能价格比,仅需单一+5v供电,且外围电路简单,可简化电路设计。
1、特性
(1)12位分辨率,1/2lsb线形度;
(2)单+5v供电;
(3)软件可编程选择输入量程: 10v, 5v,0~+5v,0~+10v;
(4)输入多路选择器保护: 16.5v
(5)8路模拟输入通道;
(6)6us转换时间,100ksps采样速度;
(7)内/外部采集控制;
(8)内部4.096v或外部参考电压;
(9)两种掉电模式;
(10)内部或外部时钟。
max197转换的基本原理
max197无需外接元器件就可独立完成a/d转换功能。它可分为内部采样模式和外部采样模式,采样模式由控制寄存器的d5位决定。在内部采样控制模式(控制位置0)中,由写脉冲启动采样间隔,经过瞬间的采样间隔(芯片时钟为2mhz时,为3ms),即开始a/d转换。在外部采样模式(d5=1)中,由两个写脉冲分别控制采样和a/d转换。在第一个写脉冲出现时,写入acqmod为1,开始采样间隔。在第二个写脉冲出现时,写入控制字acqmod为0,max197停止采样,开始a/d转换。这两个写脉冲之间的时间间隔为一次采样时间。当一次转换结束后,max197相应的int引脚置低电平,通知处理器可以读取转换结果。内部采样模式的数据转换时序对于模拟到数字量的转换,时序要求非常严格,由于max197的数字信号输出引脚是复用的,要正确读出转换结果,时序要求尤其重要。在一次采样开始前,可以通过单片机的8位数据线把这些控制字写入max197来初始化相应的参数。然后按照一定的时序进行采样和转换。
图1 max197引脚定义视图
引脚功能介绍
max197具有四种不同的封装:dip28,宽so,ssop和陶瓷sb封装。
1脚(clk):时钟输入。外部时钟输入时,由此引脚输入电平与ttl或cmos兼容的时钟。内部时钟模式时,该脚与地之间接一电容,以确定内部时钟频率,当f=1.56mhz时,外接电容的典型值cclk=100pf。
2脚( ):片选线,低电平有效。
3脚( ):当 为低电平时,在内部采集模式下, 的上升沿将锁存数据,并启动一次采集和一次转换周期;在外部采集模式下, 的第一个上升沿启动采集,第二个上升沿结束采集,并启动转换周期。
4脚( )当 为低电平时, 得下降沿将允许读取数据总线上的数据。
5脚(hben)用于切换12位转换结果。此脚为高电平时数据总线上的数据为高4位,此脚为低电平时数据总上的数据为低8位。
max197 c程序
对于学max197的人来说是一个很好的机会,这个程序不难,绝对可以看懂它:
以下两个是。h文件的,你们另外保存一下就行了
#include
#include
#define uchar unsigned char
#define uint unsigned int
#includedelay.h
#includechuankou.h
sbit max197_cs=p0^0;
sbit max197_wr=p0^1;
sbit max197_rd=p0^2;
sbit max197_hben=p0^3;
uchar premp,temp1;
void max197_write(char temp)
{
max197_cs=1;
max197_wr=1;
delays(1);
max197_cs=0;
_nop_();
_nop_();
max197_wr=0;
_nop_();
_nop_();
_nop_();
_nop_();
p1=temp;
_nop_();
_nop_();
_nop_();
_nop_();
max197_wr=1;
_nop_();
max197_cs=1;
delayl(5);
}
long int max197_read()
{
long int premp;
uint templ,temph;
delayl(2);
max197_hben=0;
_nop_();
max197_cs=0;
max197_rd=0;
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
templ=p1;
delayl(600);
max197_hben=1;
delayl(600);
_nop_();
_nop_();
_nop_();
_nop_();
temph=p1;
delays(1);
max197_rd=1;
max197_cs=1;
premp=temph*256|templ;
return premp;
}
void init_max197()
{
p1=0x00;
max197_write(0x40);
}
void main()
{
long int frag,i;
uint j;
init_uart();
while(1)
{
init_max197();
frag=max197_read();
i=frag*500000/4096;
send_dat(i/100000);
send_char('.');
send_dat(i/10000%10);
send_dat(i/1000%10);
send_dat(i/100%10);
send_dat(i/10%10);
send_dat(i%10);
send_char('v');
send_char(' ');
send_char('');
}
}
#ifndef chuankou
#define chuankou
void init_uart()
{
tmod = 0x20;
th1 = 0xfa;
tl1 = 0xfa;
scon = 0x40;
pcon = 0x80;
tr1 = 1;
ren = 1;
}
void send_dat(uint dat1)
{
sbuf = (dat1+'0');
while(ti==0);
ti = 0;
}
void send_char(uchar dat)
{
sbuf = dat;
while(ti==0);
ti=0;
}
void printstr(uchar *p)
{
while((*p)!='')
{
send_dat(*p);
p++;
}
}
#endif
#ifndef delay
#define delay
delayl(uint n)
{
uint i,j;
for(i=n;i>0;i--)
for(j=114;j>0;j--);
}
delays(uint i)
{
while(i--);
}
#endif
一、max197在多通道数据采集中的应用
内部采样模式的数据转换时序
对于模拟到数字量的转换,时序要求非常严格,由于max197的数字信号输出引脚是复用的,要正确读出转换结果,时序要求尤其重要。在一次采样开始前,可以通过单片机的8位数据线把这些控制字写入max197来初始化相应的参数。然后按照一定的时序进行采样和转换。
hben为12位数据高4位或低8位有效控制位,当此位为高时,高4位数据有效,为低时低8位数据有效。可以通过控制这个引脚来读取12位的转换结果。
max197与单片机硬件接口设计
max197是一种通用a/d芯片,可以和多种微机接口,在此选用at89c52单片机作为主处理器。通过at89c52的p0.0~p0.7与max197的d0~d7相连,既用于输入max197的初始化控制字,也用于读取转换结果数据。 用at89c52单片机的p2.7作片选信号,则max197的高位地址为7fh。选择max197为软件设置低功耗工作方式,所以置shdn脚为高电平。本文采用外部基准电压,所以refdj接高电平,而ref则接外部输入参考电压。at89c52单片机的p1.1脚用做判读高、低位数据的选择线,直接与hben脚相连。max197的int脚可与at89c52的int0相连,以便实现中断,读取转换结果。
在电路中,agnd和dgnd应相互独立,各种电源与模拟地之间都用0.1mf电容来消除电源的纹波。max197的硬件电路设计如图2所示。
软件设计
max197与其它a/d芯片不同之处在于它的很多硬件功能都是利用内部控制字来实现的,如通道选择、模拟信号量程、极性等。max197的输出数据采用无符号二进制模式(单极性输入方式)或二进制补码形式(双极性输入方式)。当cs和rd都有效时,hben为低电平,低8位数据被读出,hben为高电平,复用的高4位被读出,另外4位保持低电平(在单极性方式下),或另外4位为符号位(在双极性方式下)。
由以上可知,正确进行采集转换并读取数据的前提是必须正确设置控制字以及max197的各种控制信号。本设计中,进行数据采集转换前都对max197进行初始化,以便确定其采集转换的通道、量程和极性等。
程序的编写可以采用查询和中断两种方式,其中查询方式是在查询相应的标志成立时,执行读取;而中断则通过把max197的int引脚连接到单片机的外部中断引脚来实现。本设计的软件是利用mcs-51汇编指令进行编写的,利用中断进行数据的转换和读取等操作。综上,一个典型a/d转换的控制与读取程序流程如图3所示。
结语
此设计表明,以max197为核心的数据采集a/d转换电路具有外围电路简单、与处理器并口兼容性好、时序控制简单易懂的特点,其变换时间短(6ms),可靠性和性价比高,并且编程简单,比较适合实时性要求较高的大数据量数据采集与高速a/d转换使用。
二、基于max197的多通道压力数据采集系统
本文介绍了一种基于at89c51和max197的压力数据采集系统,系统与pc利用rs232通信,在pc端软件接收。系统在前级留出4~20ma的模拟信号接口,只要符合标准的信号都可接入,大大提高了系统的通用性
水利工程中常常需要对某些重要区段配置压力测量系统,比如管道进出口、直线段、局部转折、局部转弯处等,用来测定诸如管道沿程阻力系数和不同类型管道局部阻力系数等对工程影响较大的参数。水文测量中单点的测量基本上是没有意义的,必须通过合理的阵列测量才能进行频谱分析等工作。
多通道采集系统处理方案
根据系统要求,系统前端配置多路传感器以探测液压信号,实际系统中使用了32路。传感器采回的信号为电流信号,在a/d变换前要变为电压信号。a/d变换中采用的是maxim生产的max197对32个通道进行循环采集。采集结果送入单片机中进行预处理,单片机选用atmel公司的产品at89c51,使用rs232通信接口与pc端连接并发送数据。pc端将收到的数据在数据处理软件中进行结果处理、显示。系统流程如图1所示。
图1 多通道采集系统流程图
传感器及过压保护
传感器采用ast4410型号的液压传感器,其性能参数如图2所示。
长度:60mm
直径:17mm
测量范围:表压 0~40mpa 绝压0~10kpa
精度等级:0.2级或 0.5级1~5vdc
输出信号:4~20madc
工作电压:12~36vdc
过程接口:1/4npt螺纹
引线方式:电缆线
实际电路中供电电压使用24v,这对于后级的a/d以及单片机电路来说是相当危险的值,因此需要设置高电压保护电路。
图2 高电压保护电路
a/d采样及max197应用
max197的内部核心部分是一个采用逐次逼近方式的dac,前端包括一个用来切换模拟输入通道的多路复用器以及输入信号调理和过压保护电路。其内部还建有一个2.5v的能隙基准电压源,管脚如图3所示。
图3 max197引脚定义视图
max197既可以使用内部参考电压源,也可以使用外部参考电压源。当使用内部参考源时,芯片内部的2.5v基准源经放大后向ref提供4.096v参考电平。这时应在ref与agnd之间接入一个4.7μf电容,在refadj与agnd之间接入一个0.01μf电容。当使用外部参考源时,接至ref 的外部参考源必须能够提供400μa的直流工作电流,且输出电阻小于10ω。如果参考源噪声较大,应在ref端与模拟信号地之间接一个4.7μf电容。模拟量输入通道拥有±16.5v的过电压保护,即使在关断状态下,保护也有效。
通过将控制寄存器的acqmod位置0可选择内部采集控制模式。在内部采集控制模式下,写信号脉冲将开始一个由内部定时控制长度的采集间隔。在6个时钟周期长度的采集间隔结束时,将启动下一个转换。
在内部采集控制模式下,max197的模拟信号输入电路拥有5mhz的信号带宽,当使用内部采集控制模式并使用外接2mhz时钟时,可达到100ksa/s的通过速率。
通过将控制寄存器的acqmod位置1可选择外部采集控制模式。采用外部采集控制模式是为了精确控制采样孔径或独立控制采集和转换时间。由用户分别通过两个写信号脉冲控制采集间隔和开始转换时间,第一个写信号脉冲时将控制寄存器的acqmod位置1,开始一个采集间隔。第二个写信号脉冲时将控制寄存器的 acqmod位置0,结束采集间隔并开始转换。然而,如果在第二个写信号脉冲时将控制寄存器的acqmod位置1,则将开始又一个采集间隔。
在第一个写信号脉冲和第二个写信号脉冲时,控制寄存器中的模拟通道选择位必须置相同的值。电源关断模式控制位可以置不同的值。
选用at89c51单片机作为主处理器。通过p0.0~p0.7与max197的d0~d7相连,既用于输入max197的初始化控制字,也用于读取转换结果数据。 用at89c51单片机的p2.7作片选信号,则max197的高位地址为7fh。选择max197为软件设置低功耗工作方式,所以置shdn脚为高电平。本文采用外部基准电压,所以refdj接高电平,而ref则接外部输入参考电压。at89c51单片机的p1.1脚用做判读高、低位数据的选择线,直接与hben脚相连。max197的int脚可与at89c51的int0相连,以便实现中断,读取转换结果。max197只有8个通道,一共要采32路压力值,用8片4选1的模拟开关实现。
在电路中,agnd和dgnd应相互独立,各种电源与模拟地之间都用0.1mf电容来消除电源的纹波。
ax197的硬件电路设计如图4所示。
图4 max197连接原理图
单片机数据采集程序设计如下:
void scan(uchar channel){ //channel为通道数
uchar conword,low8,high4,i; //定义变量
for(i=0;i《8;i++){
if(i》0)channel=channel》》1;
if(channel&1){
conword=0x50+i;
p12=1;
xbyte[0xe000]=conword; //读取数据
while(p32==1){}
//p12=0;
p13=0;
low8=xbyte[0xe000]; //低位处理
p13=1;
high4=xbyte[0xe000]&0x0f; //高位处理
sumx[i]=high4*256+low8; //数据整合
}
}
}
根据系统的要求以及芯片的性能,选择10ms为采样的最小间隔。后面在pc端的程序可调整设定发送间隔,如果发送间隔大于采样间隔,则将采样得到的完整数据取均值后再发送,可以起到滤波的作用。
if(freq》=10){ //interval 设定采样间隔为10ms
freq=0;
scanall();
num1++;
p16=0;
p17=0;
}
if(num1》=interval){ //interval 即为pc端发送的指令
for(i=0;i《32;i++){ //如果大于10ms则取平均值
if(sum[i]!=0){
union{
ulong usum;
uchar ustr[4];
} nua;
uchar a;
transfer(i);
sum[i]=sum[i]/num1;
nua.usum=sum[i];
a=nua.ustr[2];
transfer(a);
a=nua.ustr[3];
transfer(a);
sum[i]=0;
}
}
num1=0;
num2++;
}
串行通信部分
图5 max232通信连接原理图
采用max232芯片与pc机通信,电路连接如图5所示。
总结
将系统进行实际测试,连续运行14小时正常。该系统已用于水库模型测量实验中,运行良好。将前端传感器更换后,后级系统可以应用于多种场合,另外加入保护电路后更可用于恶劣条件下。系统前级提供4~20ma的电流模拟信号,后级即可工作并将信号输出,通用性较强。

NVIDIA股票大跌25% 未来GPU前景依然看好
电源适配器自动综合测试系统
学习下如何去抓APP的数据
佳能EOSM6评测 总体来讲特色非常鲜明
GitHub访问速度慢怎么办?教你一招解决!
主流A/D转换芯片学习详解(1):美信MAX197
三星天翼3G旗舰W799评测
关于世界顶尖锂电池研究团队及研究方向的介绍
华为5G Polar码为何被力挺?听通信工程师的大实话
led3mm和5mm区别 共阳5mm发光二极管参数
电路设计参考图
讲不出再见!华为Mate7已经降到无人问津
可以用什么标准来描述不同类型的数字人类
CSS框架:Semantic UI的优缺点
伺服电机如何进行快速的测试?
关于为Simulink模型添加注解的五种方式分析和介绍
微软封禁员工讨论OpenAI DALL-E 3模型漏洞
适合新手使用的5款超简单电路图制作软件
苹果春季发布会定于3月23日举行,但不会发布AirPods3
NVIDIA RTX 3080库存不足或不足