找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 5853|回复: 1
打印 上一主题 下一主题
收起左侧

0-5V可调直流电源Proteus仿真

[复制链接]
跳转到指定楼层
楼主
可调直流电源Proteus仿真欢迎大家参考

仿真图如下(proteus的仿真工程文件可到附件中下载):


单片机源程序如下:
  1. #include <reg52.h>
  2. #include <intrins.h>
  3. #include "timer.h"
  4. #include "global.h"
  5. #define delay4us() {_nop_();_nop_();_nop_();_nop_();}
  6. #define vout 1
  7. #define vset 0
  8. #define vmode
  9. sbit RS = P2^0;
  10. sbit RW = P2^1;
  11. sbit EN  = P2^2;

  12. sbit DACSCLK = P2^3;
  13. sbit DACCS = P2^4;
  14. sbit DACDIN  = P2^5;

  15. sbit CS  = P1^0;
  16. sbit CLK = P1^1;
  17. sbit DIO = P1^2;
  18. sbit KEY1 = P3^6;
  19. sbit KEY2 = P3^7;
  20. #ifdef vmode
  21. uchar Display_Buffer[] = "00.00V           ";
  22. uchar code Line1[] = "Current Voltage:";
  23. #else
  24. uchar Display_Buffer[] = "                ";
  25. uchar code Line1[]     = "Current Speed:  ";
  26. #endif
  27. extern uint speed;
  28. void Delayms(uint ms)
  29. {
  30.         uchar i;
  31.         while(ms--)
  32.         {
  33.                  for(i=0;i<120;i++);
  34.         }
  35. }

  36. uchar Busy_Check()
  37. {
  38.         uchar LCD_Status;
  39.         RS = 0;
  40.         RW = 1;
  41.         EN = 1;
  42.         Delayms(1);
  43.            LCD_Status = P0;
  44.         EN = 0;
  45.         return LCD_Status;
  46. }

  47. void Write_LCD_Command(uchar cmd)
  48. {
  49.         while((Busy_Check()&0x80)==0x80);
  50.         RS = 0;
  51.         RW = 0;
  52.         EN = 0;
  53.         P0 = cmd;
  54.         EN = 1;
  55.         Delayms(1);
  56.         EN = 0;
  57. }

  58. void Write_LCD_Data(uchar dat)
  59. {
  60.         while((Busy_Check()&0x80)==0x80);
  61.         RS = 1;
  62.         RW = 0;
  63.         EN = 0;
  64.         P0 = dat;
  65.         EN = 1;
  66.         Delayms(1);
  67.         EN = 0;
  68. }

  69. void Initialize_LCD()
  70. {
  71.         Write_LCD_Command(0x38);
  72.         Delayms(1);       
  73.         Write_LCD_Command(0x01);
  74.         Delayms(1);       
  75.         Write_LCD_Command(0x06);
  76.         Delayms(1);       
  77.         Write_LCD_Command(0x0c);
  78.         Delayms(1);       
  79. }

  80. void ShowString(uchar x,uchar y,uchar *str)
  81. {
  82.         uchar i = 0;
  83.         if(y == 0)
  84.                 Write_LCD_Command(0x80 | x);
  85.         if(y == 1)
  86.                 Write_LCD_Command(0xc0 | x);
  87.         for(i=0;i<16;i++)
  88.         {
  89.                  Write_LCD_Data(str[i]);       
  90.         }
  91. }

  92. uchar Get_AD_Result(uchar ch)
  93. {
  94.         uchar i,dat1=0,dat2=0;
  95.         CS  = 0;
  96.         CLK = 0;
  97.         DIO = 1; _nop_(); _nop_();
  98.         CLK = 1; _nop_(); _nop_();
  99.         CLK = 0;

  100.         DIO = 1; _nop_(); _nop_();
  101.         CLK = 1; _nop_(); _nop_();
  102.         CLK = 0;
  103.         if(ch)
  104.         DIO = 1;
  105.         else
  106.         DIO = 0;
  107.          _nop_(); _nop_();
  108.         CLK = 1; _nop_(); _nop_();
  109.         CLK = 0;

  110.         DIO = 1; _nop_(); _nop_();
  111.         for(i=0;i<8;i++)
  112.         {
  113.                  CLK = 1; _nop_(); _nop_();
  114.                 CLK = 0; _nop_(); _nop_();
  115.                 if(DIO) dat1 |=0x80>>i;       
  116.         }
  117.         for(i=0;i<8;i++)
  118.         {
  119.                 if(DIO) dat2 |=0x01<<i;
  120.                 CLK = 1; _nop_(); _nop_();
  121.                 CLK = 0; _nop_(); _nop_();
  122.         }         
  123.         CS = 1;       
  124.         if (dat1 == dat2)
  125.                 return dat1;
  126.         else
  127.                 return 0x00;
  128. }

  129. void Set_DAC(uint dacvalue)
  130. {
  131.         uchar i;
  132.         uint dat;
  133.         dat = dacvalue;
  134.         dat &= 0x03ff;
  135.         DACCS  = 0;
  136.         DACSCLK = 0;

  137.         for(i=0;i<12;i++)
  138.         {
  139.                  if(dat & 0x0200)
  140.                         DACDIN = 1;
  141.                 else
  142.                         DACDIN = 0;
  143.                 DACSCLK = 1;
  144.                 dat <<= 1;
  145.                 DACSCLK = 0;
  146.         }
  147.         DACCS = 1;
  148. }

  149. void main()
  150. {
  151.         uchar B;
  152.         uint d,v;
  153.         Initialize_LCD();
  154.         InitTimer();
  155.         Delayms(10);
  156.         v = 0x0100;
  157.         StartTimer(0);
  158.         B = 0;
  159.         while(1)
  160.         {
  161.                  d = Get_AD_Result(vset);
  162.                 d &=0x00FF;         
  163.                 Set_DAC(d*4);
  164.                 d = Get_AD_Result(vout);
  165.                 d &=0x00FF;       
  166.                 d = d*1000.0/255;
  167.                 #ifdef vmode
  168.                 if(d/1000)
  169.                 Display_Buffer[0]=d/1000+'0';
  170.                 else
  171. ……………………

  172. …………限于本文篇幅 余下代码请从51黑下载附件…………
复制代码

所有资料51hei提供下载:
0·5V可调直流电源Proteus仿真.zip (87.82 KB, 下载次数: 36)


分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖 顶 踩
回复

使用道具 举报

沙发
ID:355214 发表于 2018-6-20 15:03 | 只看该作者
看看   
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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