关于tlc2543输入通道的解释和程序

关于tlc2543输入通道的解释和程序

ID:34742175

大小:179.13 KB

页数:4页

时间:2019-03-10

关于tlc2543输入通道的解释和程序_第1页
关于tlc2543输入通道的解释和程序_第2页
关于tlc2543输入通道的解释和程序_第3页
关于tlc2543输入通道的解释和程序_第4页
资源描述:

《关于tlc2543输入通道的解释和程序》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库

1、书上和网上的相关程序很多,但是有一个问题大家可能会遇到,就是读出的数不是想要的通道的数值,我就谈谈这个的问题。见网上有人问到TLC2543多路转换时出现通道之间串位的问题,我也遇到了,例如:输入的是通道0,读的数却是通道1,等等。我分析了一下,出现问题的原因如下:书上印的、网上传的关于TLC2543转换输出12位的子函数的形参大多是uchar型的,如调取子函数:read(ucharport)。调取子函数时以十六进制表示输入的通道数,如通道0为0x00,通道1为ox10等等,可是子函数里有一条是port<<=4;这让只有八位的ucharport

2、向左移四位之后,原来的包含通道信息的高四位被舍弃,变为原来的低四位,通道数肯定不是你想要的那个通道了。以uchar为形参,用十六进制表示通道数时去掉port<<=4;才是正确的。如果你非要加上port<<=4;也可以,此时形参设定为uchar,那你就输入十进制的通道数,如通道0为0,通道1为1,如通道1,写为二进制是0001,那么port就是00000001,左移4位正好变为00010000,也是对的。而偏偏有人输入的是十进制的通道数,再加上1条左移,那读出的数肯定就不对了。如果设定通道变量为uintport,这时port为16位整型,por

3、t的高8位都是0,左移4位之后剩下的高4位仍然是0,此时余下的12位加上左移补上的4个0,12位输出的同时正好把前12位同步输入。这个时候,左移4位这条指令也是必不可少的。#include#include#defineuintunsignedint#defineucharunsignedcharsbitADout=P1^0;sbitADin=P1^1;sbitCS=P1^2;sbitCLK=P1^3;sbitEOC=P1^4;sbitLE1=P1^6;sbitLE2=P1^7;ucharduan[]={

4、0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0x7c};ucharD=0,wei[]={0xfe,0xfd,0xfb,0xf7,0xdf,0xef};floatk,z;uintn;//////////延时子函数voiddelay(uintus){uchari;for(i=0;i

5、AD/10%10;g=AD%10;P0=0xff;LE1=1;P0=wei[0];LE1=0;LE2=1;P0=duan[q];LE2=0;delay(10);P0=0xff;LE1=1;P0=wei[1];LE1=0;LE2=1;P0=duan[b];LE2=0;delay(10);P0=0xff;LE1=1;P0=wei[2];LE1=0;LE2=1;P0=duan[s];LE2=0;delay(10);P0=0xff;LE1=1;P0=wei[3];LE1=0;LE2=1;P0=duan[g];LE2=0;delay(10);}////

6、///TLC2543转换和读取子函数,只转换了三路模拟电压信号。uintreadAD(ucharport){ucharch,i,j;uintad;ch=port;for(j=0;j<3;j++)///////空循环三次,为什么是三次!?{ad=0;ch=port;EOC=1;CS=1;CS=0;CLK=0;for(i=0;i<12;i++){if(ADout)ad

7、=0x01;ADin=(bit)(ch&0x80);CLK=1;CLK=0;ch<<=1;ad<<=1;}}CS=1;/////////转换和读取数值while(!EOC);ad>

8、>=1;return(ad);}//主函数voidmain(){while(1){n=readAD(0x00);//得到通道0的数值k=readAD(0x10);//得到通道1的数值z=readAD(0x20);//得到通道2的数值//display(n);//想检验哪一路读取的对不对,就让显示哪一路display(k);//display(z);}}

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。