找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 2973|回复: 2
收起左侧

TLC2543 protues仿真(含单片机源代码)

[复制链接]
ID:255233 发表于 2018-1-16 10:50 | 显示全部楼层 |阅读模式
TLC2543 protues仿真原理图如下(proteus仿真工程文件可到本帖附件中下载)
0.png 0.png
单片机源程序如下:
  1. #include <reg52.h>
  2. #include <intrins.h>
  3. #include "head.h"
  4. #include "interrupt.h"


  5. int Voltage;
  6. double base_v=4095;                   //基准电压定义,仿真用


  7. /*****************************************************
  8. 函数功能:延时1ms
  9. ***************************************************/
  10. void delay1ms()
  11. {
  12.    unchar i,j;       
  13.          for(i=0;i<9;i++)
  14.           for(j=0;j<33;j++)
  15.            ;                 
  16. }
  17. /*****************************************************
  18. 函数功能:延时若干毫秒
  19. 入口参数:n
  20. ***************************************************/
  21. void delaynms(int n)
  22. {
  23.   unchar i;
  24.         for(i=0;i<n;i++)
  25.         delay1ms();
  26. }


  27. /*****************************************************
  28. 函数功能:延时若干微秒
  29. 入口参数:n
  30. ***************************************************/
  31. void delay(unchar n)
  32. {
  33.   unchar i;
  34.   for(i=0;i<n;i++)
  35.    {
  36.      _nop_();
  37.     }
  38. }



  39. /*****************************************************
  40. 函数功能:数码管显示       
  41. 入口参数:shu
  42. **************************************************/
  43. void display(int shu) //显示函数   
  44. {  


  45.          P0=dispcode[shu%10/1];
  46.          delaynms(1);
  47.          gw=0;
  48.          delaynms(1);
  49.          gw=1;
  50.          delaynms(1);       
  51.          P0=dispcode[shu%100/10];
  52.          delaynms(1);
  53.          sw=0;
  54.          delaynms(1);
  55.          sw=1;
  56.          P0=dispcode[shu%1000/100]|0x80; //加上小数点显示                 //仿真用
  57. //         P0=dispcode[shu%1000/100]&0x7f; //加上小数点显示                 
  58.          delaynms(1);
  59.          bw=0;
  60.          delaynms(1);
  61.          bw=1;
  62.          P0=dispcode[shu/1000];       
  63.          delaynms(1);
  64.          qw=0;
  65.          delaynms(1);
  66.          qw=1;
  67.          delaynms(1);
  68. }


  69. /*****************************************************
  70. 函数功能:AD转换
  71. 入口参数:port
  72. ***************************************************/
  73. unint read2543(unchar port)
  74. {
  75.   unint ad=0,i;
  76.   CLOCK=0;
  77.   _CS=1;                  /***可删***/
  78.   _CS=0;
  79.   port<<=4;
  80.   for(i=0;i<12;i++)
  81.    {
  82.      if(D_OUT) ad|=0x01;
  83.      D_IN=(bit)(port&0x80);
  84.      CLOCK=1;
  85.      delay(3);           /***可删***/
  86.      CLOCK=0;
  87.      delay(3);           /***可删***/
  88.      port<<=1;
  89.      ad<<=1;
  90.     }
  91.   _CS=1;
  92.   while(!D_EOC);
  93.   ad>>=1;
  94.   return(ad);
  95. }




  96. /*****************************************************
  97. 函数功能:测量电压
  98. 入口参数:
  99. ***************************************************/
  100. int action(char port)
  101. {
  102.   int ad;
  103.   unint i,j,max,min,sum,average;
  104.   unint a[10];
  105.   double  b=4095;
  106.   double  ad1;

  107.         for(j=0;j<10;j++)
  108.         {
  109.           a[j]=read2543(port);
  110.           delay(10);
  111.         }
  112.         sum=max=min=a[0];
  113.         for(i=0;i<10;i++)
  114.         {
  115.         if(max<a[i])
  116.         max=a[i];
  117.         }
  118.         for(i=0;i<10;i++)
  119.         {
  120.         if(min>a[i])
  121.         min=a[i];
  122.         }
  123.         for(i=1;i<10;i++)
  124.         {
  125.         sum+=a[i];
  126.         }       
  127.         sum=sum-max-min;
  128.         average=sum>>3;       
  129.         ad1=average;
  130.         ad1=(double)(base_v/b*average);         //4.095V基准时可以去掉
  131.         ad=(int)ad1;
  132.         ad=ad/10;
  133. return (ad);

  134. }
  135.                                                                                                                                                          


  136. /*****************************************************
  137. 函数功能:主函数
  138. 入口参数:
  139. ***************************************************/
  140. void main()
  141. {

  142.          time_init();

  143.           while(1)
  144.          {

  145.              TR0=1;
  146.                           
  147.                  Voltage=action(0);         
  148.        
  149.                 }
  150. }
复制代码

所有资料51hei提供下载:
TLC2543 protues(含源代码)仿真.rar (135.62 KB, 下载次数: 84)
回复

使用道具 举报

ID:255233 发表于 2018-1-16 10:59 | 显示全部楼层
用89c52单片机进行仿真,源代码、仿真图一应俱全,供大家参考学习。
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表