带串行控制的10位模数转换器TLC1549在8051系统中的应用

发布时间:2010-6-11 14:36    发布者:我芯依旧
关键词: 8051 , TLC1549 , 串行控制 , 模数转换器
一、概述
  
TLC1549是美国德州仪器公司生产的10位模数转换器。它采用CMOS工艺,具有内在的采样和保持,采用差分基准电压高阻输入,抗干扰,可按比例量程校准转换范围,总不可调整误差达到±1LSB Max(4.8mV)等特点。





1.2TLC1549的工作温度范围内(自然通风)极限参数如下:

电源电压范围:
-0.5~6.5V
输入电压范围:
-0.3~VCC+0.3V
输出电压范围:
-0.3~VCC+0.3V
正基准电压:
VCC+0.1V
负基准电压:
-0.1V
峰值输入电流(任何输入端):
±20mA
峰值总输入电流(所有输入端):
±30mA
工作温度范围(自然通风):
TLC1549C
0~70℃
TLC1549I
-40~80℃
TLC1549M
-65~125℃

二、工作原理
  
在芯片选择(CS)无效情况下,I/O CLOCK 最初被禁止且DATA OUT 处于高阻状态。当串行接口把CS拉至有效时,转换时序开始允许I/O CLOCK 工作并使DATA OUT 脱离高阻状态。串行接口然后把I/O CLOCK 序列提供给I/O CLOCK 并从DATA OUT 接收前次转换结果。I/O CLOCK 从主机串行接口接收长度在10和16个时钟之间的输入序列。开始10个I/O 时钟提供采样模拟输入的控制时序。


在CS的下降沿,前次转换的MSB出现在DATA OUT端。10位数据通过DATA OUT 被发送到主机串行接口。为了开始转换,最少需要10个时钟脉冲。如果I/O CLOCK 传送大于10个时钟长度,那么在的10个时钟的下降沿,内部逻辑把DATA OUT 拉至低电平以确保其余位的值为零。在正常进行的转换周期内,规定时间内CS端高电平至低电平的跳变可终止该周期,器件返回初始状态(输出数据寄存器的内容保持为前次转换结果)。由于可能破坏输出数据,所以在接近转换完成时要小心防止CS被拉至低电平。时序图如图2。




三、应用介绍
  
3.1 TLC1549的理想转换特性如图3所示。





(1) 此曲线基于下列假设:VREF+和VREF-已被调整以便从数字0至1跳变的电压(VZT)为0.0024V,满度跳变电压(VFT)为4.908V。1LSB=4.8mV。


(2) 满度值(VFS)是指其额定中点(midstep)值具有最高的绝对值的那级台阶。零度值(VZS)是指其额定中点(midstep)值等于零的那级台阶。

3.2
TCL1549典型串行接口


3.3
应用程序


#include "d:\c51\inc\stdlib.h"
#define byte unsigned char
data int result;
sbit cs_ad=
0xa4;
sbit dout=
0xa3;
sbit clk=
0xa2;
void delay(void)
//延时子程序
{ data byte i,j;

for(i=0;i<255;i++)

{ for(j=0;j<255;j++) ; }
}
main()
{ data byte i;

number1:
cs_ad=1;
//禁止I/O CLOCK
cs_ad=0;

//开启控制电路,使能DATA OUT和I/O CLOCK
result=0;
//清转换变量

for(i=0;i<10;i++)
//采集10次 ,即10bit

{ clk=0;


result*=2;

if(dout) result++;

clk=1;

}

delay();

cs_ad=1; ;;;;
//DATA OUT 返回到高阻状态而终止序列

result1=result;
//转换后的数值存放在变量result1中

goto number1;
//重新去采集
本文地址:https://www.eechina.com/thread-12731-1-1.html     【打印本页】

本站部分文章为转载或网友发布,目的在于传递和分享信息,并不代表本网赞同其观点和对其真实性负责;文章版权归原作者及原出处所有,如涉及作品内容、版权和其它问题,我们将根据著作权人的要求,第一时间更正或删除。
您需要登录后才可以发表评论 登录 | 立即注册

厂商推荐

相关视频

关于我们  -  服务条款  -  使用指南  -  站点地图  -  友情链接  -  联系我们
电子工程网 © 版权所有   京ICP备16069177号 | 京公网安备11010502021702
快速回复 返回顶部 返回列表