找回密码
 立即注册

QQ登录

只需一步,快速开始

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

用单片机控制电机正反转

[复制链接]
跳转到指定楼层
楼主
用单片机控制电机正反转,并用proteus进行了仿真


单片机源程序如下:
  1. #include <reg51.h>
  2. #include <math.h>
  3. #define uchar unsigned char
  4. #define uint unsigned int
  5. #define ON 0
  6. #define OFF 1
  7. sbit PWM=P3^5;
  8. sbit MP=P3^4;
  9. bit FLAG=0;
  10. uchar code dispbit[6]={0x20,0x10,0x08,0x04,0x02,0x01};

  11. uchar code seg[]={0xC0,0xF9,0xA4,0xB0,0x99,0x92,0x82,0xF8,0x80,0x90};
  12.                                         //0,1,2,3,4,5,6,7,8,9
  13. uchar disbuf[6]={0,0,0,0,10,10};
  14. uint temp[6];
  15. uint discount=0;
  16. uint timecount=0;//定时的次数
  17. uint T0count=0;
  18. uint hus=0;
  19. uint k=60;
  20. uint Vc;
  21. uint Vs;
  22. uint tm=3000;
  23. uint x;
  24. void t0_serv() interrupt 1
  25. { T0count++;
  26. }
  27. void t1_serv() interrupt 3
  28. {
  29.   PWM=1;
  30.   TH1=(65536-tm)/256;
  31.   TL1=(65536-tm)%256;
  32.   hus++;
  33.   if(hus==tm)
  34.    { PWM=0;
  35.      TH1=(25536+tm)/256;
  36.      TL1=(25536+tm)%256;
  37.    
  38.    }
  39.   timecount++;
  40.     if(timecount==250)
  41.     {  
  42.            //FLAG=1;
  43.            TR0=0;
  44.            hus=0;
  45.            timecount=0;
  46.            Vc=T0count*65536+TH0*256+TL0;
  47.            Vs=144;
  48.            if(abs(Vc-Vs)>5)
  49.             { tm=abs(k*(Vc-Vs));
  50.                   T0count=0;
  51.                   TR0=1;
  52.                   TR1=1;
  53.                   ET0=1;
  54.                   ET1=1;
  55.                   EA=1;
  56.                 }
  57.           FLAG=1;
  58.           TR0=0;
  59.           timecount=0;
  60.           }
  61.         P0=dispbit[discount];         
  62.         P1=seg[disbuf[discount]];         
  63.         discount++;
  64.           if(discount==6)
  65.            { discount=0;
  66.            }
  67. }          
  68. void main()
  69. {  uint i;
  70.    TMOD=0x15;
  71.    TH0=0;
  72.    TL0=0;
  73.    TH1=(65536-tm)/256;
  74.    TL1=(65536-tm)%256;
  75.    TR0=1;
  76.    TR1=1;
  77.    ET0=1;
  78.    ET1=1;
  79.    EA=1;
  80.    while(1)
  81.   { if(FLAG==1)
  82.    { FLAG=0;
  83.          x=T0count*65536+TH0*256+TL0;
  84.           for(i=0;i<6;i++)
  85.           {temp[i]=0;
  86.           }
  87.         i=0;
  88.         while(x/10)
  89.          {
  90.               temp[i]=x%10;
  91.            x=x/10;
  92.            i++;
  93.           }
  94.         temp[i]=x;
  95.             for(i=0;i<6;i++)
  96.           {       
  97. ……………………

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

所有资料51hei提供下载:
仿真文件及原代码.zip (73.85 KB, 下载次数: 24)


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

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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