通俗易懂讲PID,附参数调试口诀

1.彻底理解PID

//

1.1

PID定义

PID,就是“比例(proportional)、积分(integral)、微分(derivative)”,是一种很常见的控制算法。在工程实际中,应用最为广泛的调节器控制规律为比例、积分、微分控制,简称PID控制,又称PID调节。它以其结构简单、稳定性好、工作可靠、调整方便而成为工业控制的主要技术之一。

PID已经有107年的历史了,它并不是什么很神圣的东西,大家一定都见过PID的实际应用。比如四轴飞行器,再比如平衡小车......还有汽车的定速巡航、3D打印机上的温度控制器....就是类似于这种:需要将某一个物理量“保持稳定”的场合(比如维持平衡,稳定温度、转速等),PID都会派上大用场。

1.2

例题说明

比如,我想控制一个“热得快”,让一锅水的温度保持在50℃,这么简单的任务,为啥要用到微积分的理论呢?

这不是so easy嘛~ 小于50度就让它加热,大于50度就断电,不就行了?几行代码用Arduino分分钟写出来。但是在大多数场合中,用“开关量”来控制一个物理量,就显得比较简单粗暴了。有时候,是无法保持稳定的。因为单片机、传感器不是无限快的,采集、控制需要时间。而且,控制对象具有惯性。比如你将一个加热器拔掉,它的“余热”(即热惯性)可能还会使水温继续升高一小会。

这是需要PID算法:它可以将需要控制的物理量带到目标附近、它可以“预见”这个量的变化趋势、它也可以消除因为散热、阻力等因素造成的静态误差等。

1.3

算法解释

你应该已经知道了,P,I,D是三种不同的调节作用,既可以单独使用(P,I,D),也可以两个两个用(PI,PD),也可以三个一起用(PID)。这三种作用有什么区别呢?我们先只说PID控制器的三个最基本的参数:kP,kI,kD。

(1)KP

P就是比例的意思。它的作用最明显,原理也最简单。我们先说这个:需要控制的量,比如水温,有它现在的『当前值』,也有我们期望的『目标值』。当两者差距不大时,就让加热器“轻轻地”加热一下。要是当前温度比目标温度低得多,就让加热器“开足马力”加热,尽快让水温到达目标附近。这就是P的作用。

实际写程序时,就让偏差(目标减去当前)与调节装置的“调节力度”,建立一个一次函数的关系,就可以实现最基本的“比例”控制了~kP越大,调节作用越激进,kP调小会让调节作用更保守。要是你正在制作一个平衡车,有了P的作用,你会发现,平衡车在平衡角度附近来回“狂抖”,比较难稳住。

(2)KD

刚才我们有了P的作用。你不难发现,只有P好像不能让平衡车站起来,水温也控制得晃晃悠悠,好像整个系统不是特别稳定,总是在“抖动”。你心里设想一个弹簧:现在在平衡位置上。拉它一下,然后松手。这时它会震荡起来。因为阻力很小,它可能会震荡很长时间,才会重新停在平衡位置。请想象一下:要是把上图所示的系统浸没在水里,同样拉它一下 :这种情况下,重新停在平衡位置的时间就短得多。

我们需要一个控制作用,让被控制的物理量的“变化速度”趋于0,即类似于“阻尼”的作用。D的作用就是让物理量的速度趋于0,只要什么时候,这个量具有了速度,D就向相反的方向用力,尽力刹住这个变化。kD参数越大,向速度相反方向刹车的力道就越强。

(3)KI

还是以热水为例。假如有个人把我们的加热装置带到了非常冷的地方,开始烧水了。需要烧到50℃。在P的作用下,水温慢慢升高。直到升高到45℃时,他发现了一个不好的事情:天气太冷,水散热的速度,和P控制的加热的速度相等了。于是,水温永远地停留在45℃,永远到不了50℃。

设置一个积分量。只要偏差存在,就不断地对偏差进行积分(累加),并反应在调节力度上。这样一来,即使45℃和50℃相差不太大,但是随着时间的推移,只要没达到目标温度,这个积分量就不断增加。系统就会慢慢意识到:还没有到达目标温度,该增加功率啦!到了目标温度后,假设温度没有波动,积分值就不会再变动。这时,加热功率仍然等于散热功率。但是,温度是稳稳的50℃。kI的值越大,积分时乘的系数就越大,积分效果越明显。

所以,I的作用就是,减小静态情况下的误差,让受控物理量尽可能接近目标值。I在使用时还有个问题:需要设定积分限制。防止在刚开始加热时,就把积分量积得太大,难以控制。

//

2.PID参数调整口诀

//

参数整定找最佳,从小到大顺序查

先是比例后积分,最后再把微分加

曲线振荡很频繁,比例度盘要放大

曲线漂浮绕大湾,比例度盘往小扳

曲线偏离回复慢,积分时间往下降

曲线波动周期长,积分时间再加长

曲线振荡频率快,先把微分降下来

动差大来波动慢。微分时间应加长

理想曲线两个波,前高后低四比一

一看二调多分析,调节质量不会低

若要反应增快,增大P减小I

若要反应减慢,减小P增大I

如果比例太大,会引起系统震荡

如果积分太大,会引起系统迟钝

本文完全转载,原文链接:【技术讲堂】通俗易懂讲PID,附参数调试口诀_控制 (sohu.com)

  • 11
    点赞
  • 115
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
PID(PID Controller)是一种经典的反馈控制算法,用于控制系统中对给定目标值进行拟合调节,保持系统的稳定性和精确性。 要理解PID,首先需要了解其三个参数:比例(P)、积分(I)和微分(D)。比例参数反映了目标值与实际值之间的差异,积分参数用于消除系统的永久偏差,微分参数用来对系统变化速度作出响应。 举个例子来解释PID的原理。想象一下,你正在驾驶一辆汽车,并希望保持恒定的速度。如果你感受到速度过慢,就会踩下油门,将速度提高到合适的水平。这里的油门输入就是比例参数。但是,你会发现在某些情况下,车速会超过目标值。为了防止这种过冲,你会逐渐减小油门输入,直到速度稳定在目标水平。这个过程就使用了积分参数。此外,如果你发现速度变化过快,你会减缓脚下的压力,以平缓地控制车速,避免速度变化过大。这个调整速度的过程就使用了微分参数PID算法综合了比例、积分和微分参数,通过不断地调整输入来满足系统的要求。它采用了反馈机制,不断地监测实际值与目标值之间的差异,并通过计算得出需要调整的参数。通过不断地迭代计算,PID能够较快地逼近目标值,并保持系统的稳定性。 总而言之,PID是一种根据反馈信息实时调整控制参数算法。它广泛应用于工业控制、自动驾驶、机器人等领域,能够实现对系统的精确控制和稳定性维持。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值