PID控制算法的C语言实现

您所在的位置:网站首页 pid控制中PD和TT代表什么 PID控制算法的C语言实现

PID控制算法的C语言实现

2024-07-14 06:20| 来源: 网络整理| 查看: 265

PID控制算法的C语言实现一 PID算法原理

   最近两天在考虑一般控制算法的C语言实现问题,发现网络上尚没有一套完整的比较体系的讲解。于是总结了几天,整理一套思路分享给大家。

   在工业应用中PID及其衍生算法是应用最广泛的算法之一,是当之无愧的万能算法,如果能够熟练掌握PID算法的设计与实现过程,对于一般的研发人员来讲,应该是足够应对一般研发问题了,而难能可贵的是,在我所接触的控制算法当中,PID控制算法又是最简单,最能体现反馈思想的控制算法,可谓经典中的经典。经典的未必是复杂的,经典的东西常常是简单的,而且是最简单的,想想牛顿的力学三大定律吧,想想爱因斯坦的质能方程吧,何等的简单!简单的不是原始的,简单的也不是落后的,简单到了美的程度。先看看PID算法的一般形式:

   PID的流程简单到了不能再简单的程度,通过误差信号控制被控量,而控制器本身就是比例、积分、微分三个环节的加和。这里我们规定(在t时刻):

   1.输入量为rin(t);

   2.输出量为rout(t);

   3.偏差量为err(t)=rin(t)-rout(t);

   pid的控制规律为

   理解一下这个公式,主要从下面几个问题着手,为了便于理解,把控制环境具体一下:

   1.规定这个流程是用来为直流电机调速的;

   2.输入量rin(t)为电机转速预定值;

   3.输出量rout(t)为电机转速实际值;

   4.执行器为直流电机;

   5.传感器为光电码盘,假设码盘为10线;

   6.直流电机采用PWM调速 转速用单位 转/min 表示;

  不难看出以下结论:

   1.输入量rin(t)为电机转速预定值(转/min);

   2. 输出量rout(t)为电机转速实际值(转/min);

   3.偏差量为预定值和实际值之差(转/min);

   那么以下几个问题需要弄清楚:

   1.通过PID环节之后的U(t)是什么值呢?

   2.控制执行器(直流电机)转动转速应该为电压值(也就是PWM占空比)。

   3.那么U(t)与PWM之间存在怎样的联系呢?

http://blog.21ic.com/user1/3407/archives/2006/33541.html(见附录1)这篇文章上给出了一种方法,即,每个电压对应一个转速,电压和转速之间呈现线性关系。但是我考虑这种方法的前提是把直流电机的特性理解为线性了,而实际情况下,直流电机的特性绝对不是线性的,或者说在局部上是趋于线性的,这就是为什么说PID调速有个范围的问题。具体看一下http://articles.e-works.net.cn/component/article90249.htm(见附录2)这篇文章就可以了解了。所以在正式进行调速设计之前,需要现有开环系统,测试电机和转速之间的特性曲线(或者查阅电机的资料说明),然后再进行闭环参数整定。这篇先写到这,下一篇说明连续系统的离散化问题。并根据离散化后的特点讲述位置型PID和增量型PID的用法和C语言实现过程。

PID控制算法的C语言实现二 PID算法的离散化

   上一节中,我论述了PID算法的基本形式,并对其控制过程的实现有了一个简要的说明,通过上一节的总结,基本已经可以明白PID控制的过程。这一节中先继续上一节内容补充说明一下。

   1.说明一下反馈控制的原理,通过上一节的框图不难看出,PID控制其实是对偏差的控制过程;

   2.如果偏差为0,则比例环节不起作用,只有存在偏差时,比例环节才起作用。

   3.积分环节主要是用来消除静差,所谓静差,就是系统稳定后输出值和设定值之间的差值,积分环节实际上就是偏差累计的过程,把累计的误差加到原有系统上以抵消系统造成的静差。

   4.而微分信号则反应了偏差信号的变化规律,或者说是变化趋势,根据偏差信号的变化趋势来进行超前调节,从而增加了系统的快速性。

   好了,关于PID的基本说明就补充到这里,下面将对PID连续系统离散化,从而方便在处理器上实现。下面把连续状态的公式再贴一下:

   假设采样间隔为T,则在第K T时刻:

偏差err(K)=rin(K)-rout(K);

积分环节用加和的形式表示,即err(K)+err(K+1)+……;

微分环节用斜率的形式表示,即[err(K)-err(K-1)]/T;

从而形成如下PID离散表示形式:

则u(K)可表示成为:

至于说Kp、Ki、Kd三个参数的具体表达式,我想可以轻松的推出了,这里节省时间,不再详细表示了。

其实到这里为止,PID的基本离散表示形式已经出来了。目前的这种表述形式属于位置型PID,另外一种表述方式为增量式PID,由U上述表达式可以轻易得到:

那么:

这就是离散化PID的增量式表示方式,由公式可以看出,增量式的表达结果和最近三次的偏差有关,这样就大大提高了系统的稳定性。需要注意的是最终的输出结果应该为

       u(K)+增量调节值;

PID的离散化过程基本思路就是这样,下面是将离散化的公式转换成为C语言,从而实现微控制器的控制作用。

PID控制算法的C语言实现三 位置型PID的C语言实现

   上一节中已经抽象出了位置性PID和增量型PID的数学表达式,这一节,重点讲解C语言代码的实现过程,算法的C语言实现过程具有一般性,通过PID算法的C语言实现,可以以此类推,设计其它算法的C语言实现。

   第一步:定义PID变量结构体,代码如下:

struct _pid{     float SetSpeed;            //定义设定值     float ActualSpeed;        //定义实际值     float err;                //定义偏差值     float err_last;            //定义上一个偏差值     float Kp,Ki,Kd;            //定义比例、积分、微分系数     float voltage;          //定义电压值(控制执行器的变量)     float integral;            //定义积分值 }pid;

控制算法中所需要用到的参数在一个结构体中统一定义,方便后面的使用。

  第二部:初始化变量,代码如下:

void PID_init(){     printf("PID_init begin \n");     pid.SetSpeed=0.0;     pid.ActualSpeed=0.0;     pid.err=0.0;     pid.err_last=0.0;     pid.voltage=0.0;     pid.integral=0.0;     pid.Kp=0.2;     pid.Ki=0.015;     pid.Kd=0.2;     printf("PID_init end \n"); }

统一初始化变量,尤其是Kp,Ki,Kd三个参数,调试过程当中,对于要求的控制效果,可以通过调节这三个量直接进行调节。

第三步:编写控制算法,代码如下:

float PID_realize(float speed){     pid.SetSpeed=speed;     pid.err=pid.SetSpeed-pid.ActualSpeed;     pid.integral+=pid.err;     pid.voltage=pid.Kp*pid.err+pid.Ki*pid.integral+pid.Kd*(pid.err-pid.err_last);     pid.err_last=pid.err;     pid.ActualSpeed=pid.voltage*1.0;     return pid.ActualSpeed; }

注意:这里用了最基本的算法实现形式,没有考虑死区问题,没有设定上下限,只是对公式的一种直接的实现,后面的介绍当中还会逐渐的对此改进。

   到此为止,PID的基本实现部分就初步完成了。下面是测试代码:

int main(){     printf("System begin \n");     PID_init();     int count=0;     while(countumax,则只累加负偏差; 如果u(k-1)pid.umax)  //灰色底色表示抗积分饱和的实现     {        if(abs(pid.err)>200)      //蓝色标注为积分分离过程         {             index=0;         }else{             index=1;             if(pid.err0)             {             pid.integral+=pid.err;             }         }     }else{         if(abs(pid.err)>200)                    //积分分离过程         {             index=0;         }else{             index=1;             pid.integral+=pid.err;         }     }     pid.voltage=pid.Kp*pid.err+index*pid.Ki*pid.integral+pid.Kd*(pid.err-pid.err_last);     pid.err_last=pid.err;     pid.ActualSpeed=pid.voltage*1.0;     return pid.ActualSpeed; }

最终的测试程序运算结果如下,可以明显的看出系统的稳定时间相对前几次来讲缩短了不少。

100.000000 30.000000 95.000000 65.500000 103.750000 92.175003 115.237503 112.173752 126.794380 127.653938 137.468842 139.967911 146.934479 149.954224 155.144211 158.157745 162.174561 164.953079 168.149734 170.611786 173.205124 175.339691 177.470551 179.298065 181.063431 182.616440 184.086655 185.400513 186.628952 187.737457 188.766006 189.699692 190.561951 191.347580 192.071030 192.731674 193.338928 193.894257 194.404160 194.870834 195.299072 195.691193 196.050888 196.380341 196.682465 196.959244 197.213043 197.445572 197.658768 197.854111 198.033203 198.197311 198.347763 198.485626 198.612015 198.727829 198.834000 198.931290 199.020477 199.102219 199.177139 199.245804 199.308746 199.366425 199.419296 199.467758 199.512161 199.552872 199.590179 199.624390 199.655716 199.684464 199.710785 199.734924 199.757034 199.777298 199.795883 199.812912 199.828537 199.842834 199.855972 199.867981 199.879013 199.889099 199.898361 199.906845 199.914612 199.921753 199.928268 199.934280 199.939743 199.944794 199.949371 199.953629 199.957474 199.961029 199.964279 199.967270 199.969986 199.972504 199.974792 199.976898 199.978821 199.980591 199.982208 199.983688 199.985062 199.986298 199.987442 199.988495 199.989441 199.990326 199.991135 199.991867 199.992554 199.993179 199.993744 199.994263 199.994751 199.995178 199.995590 199.995941 199.996292 199.996582 199.996887 199.997116 199.997391 199.997574 199.997803 199.997971 199.998154 199.998291 199.998444 199.998581 199.998703 199.998810 199.998917 199.999008 199.999084 199.999176 199.999237 199.999298 199.999359 199.999405 199.999466 199.999496 199.999542 199.999588 199.999619 199.999649 199.999680 199.999710 199.999725 199.999756 199.999771 199.999786 199.999817 199.999817 199.999847 199.999847 199.999863 199.999863 199.999878 199.999893 199.999893 199.999908 199.999924 199.999924 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939 199.999939

                  PID控制算法的C语言实现七 梯形积分的PID控制算法C语言实现

   先看一下梯形算法的积分环节公式

   作为PID控制律的积分项,其作用是消除余差,为了尽量减小余差,应提高积分项运算精度,为此可以将矩形积分改为梯形积分,具体实现的语句为:

pid.voltage=pid.Kp*pid.err+index*pid.Ki*pid.integral/2+pid.Kd*(pid.err-pid.err_last);  //梯形积分

其它函数请参见本系列教程六中的介绍

最后运算的稳定数据为:199.999878,较教程六中的199.9999390而言,精度进一步提高。

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

PID控制算法的C语言实现八 变积分的PID控制算法C语言实现

   变积分PID可以看成是积分分离的PID算法的更一般的形式。在普通的PID控制算法中,由于积分系数ki是常数,所以在整个控制过程中,积分增量是不变的。但是,系统对于积分项的要求是,系统偏差大时,积分作用应该减弱甚至是全无,而在偏差小时,则应该加强。积分系数取大了会产生超调,甚至积分饱和,取小了又不能短时间内消除静差。因此,根据系统的偏差大小改变积分速度是有必要的。

   变积分PID的基本思想是设法改变积分项的累加速度,使其与偏差大小相对应:偏差越大,积分越慢; 偏差越小,积分越快。

   这里给积分系数前加上一个比例值index:

   当abs(err)0时,说明误差在朝向误差绝对值增大的方向变化,此时,如果abs(e)>Mmid,说明误差也较大,可考虑由控制器实施较强的控制作用,以达到扭转误差绝对值向减小的方向变化,并迅速减小误差的绝对值。此时如果abs(e)

temp )

     {

                        Pwm.DutyCycle_Uint8 = Pwm.DutyCycle_Uint8 - temp;

     }

     else

     {

                        Pwm.DutyCycle_Uint8 = 0;

     }

    }

    else

    {

                    return;

    }

   }

   else           //如果当前电压小于输出电压

   {

       if( ( UKTemp - ADPool.Value_Uint16[UPWMADCH] ) > UDELTA )

    {

        temp = UKTemp - ADPool.Value_Uint16[UPWMADCH];

     temp = temp / 4;  //上升处理不要超调,所以每次只+一半

     if( (255-Pwm.DutyCycle_Uint8) > temp )

     {

                        Pwm.DutyCycle_Uint8 += (temp/2);

     }

     else

     {

                        Pwm.DutyCycle_Uint8 = 255;

     }

    }

    else

    {

                    return;

    }

   }

            DisPlayVoltage();

            PWMChangeDuty(Pwm.DutyCycle_Uint8);  //改变占空比

   Delay(10,10);

 

        }

 }

}

/*****************************************************/

 

 

附录2

直流电机PWM调速系统中控制电压非线性研究

引言

    由于线性放大驱动方式效率和散热问题严重,目前绝大多数直流电动机采用开关驱动方式。开关驱动方式是半导体功率器件工作在开关状态,通过脉宽调制PWM控制电动机电枢电压,实现调速。目前已有许多文献介绍直流电机调速,宋卫国等用89C51单片机实现了直流电机闭环调速;张立勋等用AVR单片机实现了直流电机PWM调速;郭崇军等用C8051实现了无刷直流电机控制;张红娟等用PIC单片机实现了直流电机PWM调速;王晨阳等用DSP实现了无刷直流电机控制。上述文献对实现调速的硬件电路和软件流程的设计有较详细的描述,但没有说明具体的调压调速方法,也没有提及占空比与电机端电压平均值之间的关系。在李维军等基于单片机用软件实现直流电机PWM调速系统中提到平均速度与占空比并不是严格的线性关系,在一般的应用中,可以将其近似地看作线性关系。但没有做深入的研究。本文通过实验验证,在不带电机情况下,PWM波占空比与控制输出端电压平均值之间呈线性关系;在带电机情况下,占空比与电机端电压平均值满足抛物线方程,能取得精确的控制。本文的电机闭环调速是运用Matlab拟合的关系式通过PID控制算法实现。

1 系统硬件设计

    本系统是基于TX-1C实验板上的AT89C52单片机,调速系统的硬件原理图如图1所示,主要由AT89C52单片机、555振荡电路、L298驱动电路、光电隔离、霍尔元件测速电路、MAX 232电平转换电路等组成。

 

图1 闭环控制系统示意图

2 系统软件设计

    系统采用模块化设计,软件由1个主程序,3个中断子程序,即外部中断0、外部中断1,定时器0子程序,PID算法子程序,测速子程序及发送数据到串口显示子程序组成,主程序流程图如图2所示。外部中断0通过比较直流电平与锯齿波信号产生PWM波,外部中断1用于对传感器的脉冲计数。定时器0用于对计数脉冲定时。测得的转速通过串口发送到上位机显示,通过PID模块调整转速到设定值。本实验采用M/T法测速,它是同时测量检测时间和在此检测时间内霍尔传感器所产生的转速脉冲信号的个数来确定转速。由外部中断1对霍尔传感器脉冲计数,同时起动定时器0,当计数个数到预定值2 000后,关定时器0,可得到计2 000个脉冲的计数时间,由式计算出转速:

n=60f/K=60N/(KT) (1)

    式中:n为直流电机的转速;K为霍尔传感器转盘上磁钢数;f为脉冲频率;N为脉冲个数;T为采样周期。

 

图2 主程序流程图

3 实验结果及原因分析

    3.1 端电压平均值与转速关系

    3.1.1 实验结果

    实验用的是永磁稳速直流电机,型号是EG-530YD-2BH,额定转速2 000~4 000 r/min,额定电压12 V。电机在空载的情况下,测得的数据用Matlab做一次线性拟合,拟合的端电压平均值与转速关系曲线如图3(a)所示。相关系数R-square:0.952 1。拟合曲线方程为:

y=0.001 852x+0.296 3 (2)

    由式(2)可知,端电压平均值与转速可近似为线性关系,根椐此关系式,在已测得的转速的情况下可以计算出当前电压。为了比较分析,同样用Matlab做二次线性拟合,拟合的端电压平均值与转速关系曲线如图3(b)所示。相关系数R-square:0.986 7。

 

图3 端电压平均值与转速关系曲线图

3.1.2 原因分析

    比较图3(a)可知,当转速在0~1 500 r/min和4 000~5 000 r/min,端电压平均值与转速间存在的非线性,用二次曲拟合如图3(b)所示,拟合相关系数较高。由图3(a)可见,当电机转速为0时电机两端电压平均值约为1.3 V。这是因为电机处于静止状态时,摩擦力为静摩擦力,静摩擦力是非线性的。随着外力的增加而增加,最大值发生在运动前的瞬间。电磁转矩为负载制动转矩和空载制动转矩之和,由于本系统不带负载,因此电磁转矩为空载制动转矩。空载制动转矩与转速之间此时是非线性的。电磁转矩与电流成正比,电流又与电压成正比,因此此时电压与转速之间是非线性的。

    当转速在2 000~4 000 r/min线性关系较好,占空比的微小改变带来的转速改变较大,因此具有较好的调速性能。这是因为随着运动速度的增加,摩擦力成线性的增加,此时的摩擦力为粘性摩擦力。粘性摩擦是线性的,与速度成正比,空载制动转矩与速度成正比,也即电磁转矩与电流成正比,电流又与电压成正比,因此此时电压与转速之间是线性的。当转速大于4 000 r/min。由于超出了额定转速所以线性度较差且调速性能较差。此时用二次曲线拟合结果较好,因为当电机高速旋转时,摩擦阻力小到可以忽略,此时主要受电机风阻型负荷的影响,当运动部件在气体或液体中运动时,其受到的摩擦阻力或摩擦阻力矩被称为风机型负荷。对同一物体,风阻系数一般为固定值。阻力大小与速度的平方成正比。即空载制动转矩与速度的平方成正比,也即电磁转矩与速度的平方成正比,电磁转矩与电流成正比,电流又与电压成正比,因此此时电压与转速之间是非线性的。

 3.2 占空比与端电压平均值关系

    3.2.1 实验结果

    拟合占空比与端电压平均值关系曲线如图4所示。相关系数R-square:0.998 4。拟合曲线方程为:

 

图4 占空比与端电压平均值关系曲线图

    如图4所示,占空比与端电压平均值满足抛物线方程。运用积分分离的PID算法改变电机端电压平均值,可以运用此关系式改变占空比,从而实现了PWM调速。

    用示波器分别测出电压的顶端值Utop与底端值Ubase,端电压平均值Uarg满足关系式:

    其中:α为占空比。

    正是由于所测得的电机端电压底端值Ubase不为0,所以得出的占空比与端电压平均值之间关系曲线为抛物线。若将电机取下,直接测L298的out1与out2输出电压。所测得的电机端电压底端值Ubase约为0,所得的占空比与端电压平均值满足线性关系,即令式(4)中Ubase为0,式(4)变为:

 

    3.2.2 原因分析

    将电机取下后,直接测L298的输出端之间的电压,占空比与端电压平均值满足关系式(5),说明整个硬件电路的设计以及软件编程的正确性。从电机反电势角度分析,当直流电机旋转时,电枢导体切割气隙磁场,在电枢绕组中产生感应电动势。由于感应电动势方向与电流的方向相反,感应电动势也即反电势。直流电机的等效模型如图5所示。图5(a)表示电机工作在电动机状态。图5(b)表示电机工作在发电机状态。

 

图5 直流电机等效电路

    如图5(a)所示,电压平衡方程为:

式中:U为外加电压;Ia为电枢电流;Ra为电枢绕组电阻;2△Ub为一对电刷接触压降,一般取2△Ub为0.5~2 V;Ea为电枢绕组内的感应电动势。电机空载时,电枢电流可忽略不计,即电流Ia为0。空载时的磁场由主磁极的励磁磁动势单独作用产生。给电机外加12 V的额定电压,由(6)可得反电势:

 

    以40%的占空比为例,电机端电压Uab是测量中的电压平均值Uarg,其值为8.34 V,测量中的电压底端值Ubase约为7 V。由式(7)可得Ea的值范围应在6.34~7.84 V。由图5(b)可见,此时Uab的值是测得的底端值Ubase即电机的电动势Ea为7 V。

    当PWM工作在低电平状态,直流电机不会立刻停止,会继续旋转,电枢绕组切割气隙磁场,电机此时工作在发电机状态,产生感应电动势E。

 

    式中:Ce为电机电动势常数;φ为每级磁通量。由于电机空载,所以图5(b)中无法形成回路。用单片机仿真软件Proteus可直观的看出在PWM为低电平状态,电机处于减速状态。低电平持续时间越长,电机减速量越大。正是由于在低电平期间,电机处于减速状态,由式(8)可知,Ce,φ均为不变量,转速n的变化引起E的改变。此时Uab的值等于E的值。电机在低电平期间不断的减速,由于PWM周期较短,本文中取20 ms,电机在低电平期间转速还未减至0,PWM又变为高电平了。这样,就使测得的Ubase值不为0。以40%的占空比为例,当PWM工作在低电平状态,测得Ubase的值约为7 V。由式(8)可知,当正占空比越大,转速也就越大,同时减速时间越短,感应电势E的值越大。所以Ubase的值也就越大。

4 结语

    重点分析了直流电机PWM调速过程中控制电压的非线性,对非线性的影响因素做了详细的分析。由于PWM在低电平期间电压的底端值不为0,导致了占空比与电机端电压平均值之间呈抛物线关系。因此,可用得出的抛物线关系式实现精确调速。本系统的非线性研究可为电机控制中非线性的进一步研究提供依据,在实际运用中,可用于移动机器人、飞行模拟机的精确控制。

 

 

附录3

隶属函数(membership function),用于表征模糊集合的数学工具。对于普通集合A,它可以理解为某个论域U上的一个子集。为了描述论域U中任一元素u是否属于集合A,通常可以用0或1标志。用0表示u不属于A,而用1表示属于A ,从而得到了U上的一个二值函数χA(u),它表征了U的元素u对普通集合的从属关系,通常称为A的特征函数,为了描述元素u对U上的一个模糊集合的隶属关系,由于这种关系的不分明性,它将用从区间[0,1]中所取的数值代替0,1这两值来描述,记为(u),数值(u)表示元素隶属于模糊集的程度,论域U上的函数μ即为模糊集的隶属函数,而(u)即为u对A的隶属度。

 



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3