找回密码
 立即注册

QQ登录

只需一步,快速开始

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

这是控制直流电机的仿真文件和源代码

[复制链接]
跳转到指定楼层
楼主
ID:213588 发表于 2017-6-22 09:29 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
里面包含仿真文件和源代码文件
  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.             disbuf[i]=temp[i];
  98.            }
  99.        
  100.            timecount=0;
  101.            T0count=0;
  102.            TH0=0;
  103.        TL0=0;
  104.            T0count=0;
  105.            TR0=1;
  106.       
  107.      }
  108.    }
  109.   
  110. }
复制代码


仿真文件及原代码.zip

73.85 KB, 下载次数: 48, 下载积分: 黑币 -5

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

使用道具 举报

沙发
ID:213848 发表于 2017-6-22 20:30 | 只看该作者
赞  ,楼主 好人
回复

使用道具 举报

板凳
ID:253839 发表于 2017-11-26 17:56 | 只看该作者
学到不少
回复

使用道具 举报

地板
ID:249545 发表于 2017-11-26 21:05 | 只看该作者
在下水平有限,没原理图看不习惯!
好像是有PWM调速功能哩!
回复

使用道具 举报

5#
ID:476805 发表于 2019-2-19 15:59 | 只看该作者
感谢楼主分享
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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