找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 2786|回复: 1
收起左侧

直流电机的速度环PI控制-速度电流检测部分+仿真+源程序

[复制链接]
ID:324366 发表于 2018-5-28 10:12 | 显示全部楼层 |阅读模式
直流电机的速度环PI控制-速度电流检测部分仿真原理图如下(proteus仿真工程文件可到本帖附件中下载)
QQ截图20180528094758.png QQ截图20180528093228.png QQ截图20180528093054.png QQ截图20180528093026.png

单片机源程序如下:
  1. #include <absacc.h>
  2. #include <reg51.h>
  3. #define IN0 XBYTE[0x7ff8]
  4. unsigned char   disbit[]={0xfe,0xfd,0xfb,0xf7};
  5. unsigned char code discode[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f};
  6. unsigned int   disbuf[4]={0,0,0,0};
  7. unsigned int  ad=100;
  8. unsigned char q=0;
  9. unsigned char *Adr;
  10. unsigned char count,miaoshu;
  11. unsigned char sec,tcnt;
  12. sbit p26=P2^6;
  13. void delay(unsigned char N)
  14. {
  15.    unsigned char i;
  16.    for(i=0;i<N;i++);
  17. }
  18. void display(unsigned char ch)
  19. {  
  20.    unsigned char k;   //显示,常用的一种程序,可以把disbuf数组变成一个暂时变量输出
  21.    disbuf[0]=ch%10;
  22.    disbuf[1]=(ch%100)/10;
  23.    disbuf[2]=ch/100%10;
  24.    disbuf[3]=1;
  25.    for(k=0;k<4;k++)
  26.           {
  27.             P2=0xff; // p2作为输出,必须先置高电平
  28.             P1=discode[disbuf[k]];
  29.             P2=disbit[k];
  30.           }
  31. }
  32.    
  33. void read_ch(void) interrupt 0 using 0
  34. {  
  35.    
  36.    ad=*Adr;
  37.    
  38. }

  39. void t0(void) interrupt 1 using 0 //定时T0中断服务函数
  40. {
  41.         tcnt++; //每过250ust tcnt 加一
  42.         if(tcnt==40) //计满40 次(1/100 秒)时
  43.         {               
  44.                 tcnt=0; //重新再计
  45.                 sec++;
  46.                 if(sec==10) //定时0.1 秒,在从零开始计时
  47.                 {
  48.                         sec=0;
  49.                 TH0=0x06; //对TH0 TL0 赋值
  50.                 TL0=0x06;
  51.                         miaoshu=count;
  52.                        count=0;
  53.                 }
  54.         }
  55. }

  56. void sdf(void) interrupt 2 using 0 //计数T1中断服务函数
  57. {   
  58.         count=count+1;
  59.    
  60.        
  61. }
  62. main()
  63. {
  64.   unsigned int m;
  65.   unsigned char s1=0x44;
  66.   EX0=1;
  67.   IT1=1;
  68.   Adr=&IN0;
  69.   TMOD=0x02; //定时器T0工作在方式2 自动重装方式,计数器T1工作在方式2 自动重装方式
  70.         TH0=0x06; //对TH0 TL0 赋值
  71.         TL0=0x06;
  72.         TR0=1; //开始定时
  73.         ET0=1; //允许T0 产生中断
  74.         EA=1;
  75.         EX1=1;
  76.         TR1=1;
  77.         IT1=1;
  78.     EA=1;
  79.            sec=0;
  80.         SCON=0x90; //MODER1,REN=1;
  81.         PCON=0x00;
  82.         miaoshu=0;tcnt=0;count=0;
  83. while(1)
  84.   {
  85.         *Adr=0;
  86.     for(m=0;m<5000;m++)
  87.        {  
  88.               if(p26==1)
  89.               {display(ad);
  90.            }         
  91.         else
  92.                    { display(miaoshu);
  93.                    }
  94.        }
  95.     do{   
  96.         SBUF=0xff;
  97.         while(TI==0);TI=0;
  98.          
  99.          while(RI==0);RI=0;
  100.          }while(SBUF!=0xbb);
  101. ……………………

  102. …………限于本文篇幅 余下代码请从51黑下载附件…………
复制代码
0.png
所有资料51hei提供下载:
速度电流检测部分.zip (226.67 KB, 下载次数: 83)

评分

参与人数 1黑币 +50 收起 理由
admin + 50 共享资料的黑币奖励!

查看全部评分

回复

使用道具 举报

ID:406352 发表于 2018-10-13 14:26 | 显示全部楼层
下载看看
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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