控制算法:PID算法

PID算法是什么

PID 控制算法是自动化领域应用最广泛的经典控制算法。

PID 是通过**误差(Error)**来调整输出的反馈机制。误差等于"你想要的目标值"减去"目前的实际值"。

P (Proportional) - 比例:解决"当前"的误差
  • 原理:输出与误差成正比。误差越大,给的力越大。

  • 直观感受:离红线越远,油门踩得越深。

  • 缺点 :存在静差。当车非常接近红线时,误差极小,踩油门的力可能不足以克服摩擦力,导致车停在红线前一点点,永远到不了目标点。

I (Integral) - 积分:解决"累积"的误差
  • 原理:将过去一段时间的所有误差加起来。

  • 直观感受:如果你停在红线前不动了,误差会随时间累积。积分项会发现"我们还没到!",然后慢慢加大油门,直到车刚好停在红线上,消除静差。

  • 缺点 :容易导致超调。力给得太猛,车可能会冲过红线。

D (Derivative) - 微分:预测"未来"的误差
  • 原理:计算速度。

  • 直观感受:如果发现车速极快,正在飞速接近红线,微分项会提前"踩刹车"减速。

  • 作用:它起到了阻尼的作用,能有效减少振荡和超调,让系统更稳。


PID的输出到底是什么东西?

PID的输出应该是初始状态跟目标状态(温度,速度,位置等等),输出从本质来讲是"能量的浓度"。 比如你现在想要让从a点到b点,输出的能量可以说是油门踩下的深度(或者电机的转速,或者pwm的占空比无所谓,他们之间是一种线性关系),pid在t时刻的输出是一个数字,这个数字越大就是在告诉你t时刻应该踩深点,电机转快点,pwm的占空比应该再大一些,他们之间可以理解成一种线性映射的转换关系。

专业点来说,PID的输出是一个控制量,是一个无量纲的数值(比如 float 范围 -1.0 到 1.0,或者 int 0 到 255)。它代表了控制器**"想要"执行器(Actuator)施加多大的修正力度**。代表的是**"致动器的做功强度"或"控制信号的幅值"**。例子: 控制温度时,输出是加热功率(类似于能量流率)。


PID 算法优缺点对比表

维度 优点 (Advantages) 缺点 (Disadvantages)
模型依赖 无需数学模型:典型的"黑盒"控制,不需要知道受控对象的物理方程(如 F=ma),通过试凑参数即可。 缺乏预见性:因为没有模型,它无法预测未来的状态,只能对已经发生的误差做出反应(滞后性)。
计算复杂度 仅涉及加减乘除 难以处理多输入多输出
工程实现 代码实现简单 约束处理能力差
性能表现 鲁棒性较好 调参往往依赖工程师的经验,对于非线性、时变系统很难达到最优状态。
适用范围 工业界 90% 都在用 PID。 不适合精细规划

PID公式


如何使用或者部署PID算法:

1.将PID公式离散化


PID调参经验:

相关推荐
Coder_Boy_5 小时前
技术发展的核心规律是「加法打底,减法优化,重构平衡」
人工智能·spring boot·spring·重构
会飞的老朱7 小时前
医药集团数智化转型,智能综合管理平台激活集团管理新效能
大数据·人工智能·oa协同办公
聆风吟º8 小时前
CANN runtime 实战指南:异构计算场景中运行时组件的部署、调优与扩展技巧
人工智能·神经网络·cann·异构计算
Codebee10 小时前
能力中心 (Agent SkillCenter):开启AI技能管理新时代
人工智能
你撅嘴真丑11 小时前
第九章-数字三角形
算法
聆风吟º11 小时前
CANN runtime 全链路拆解:AI 异构计算运行时的任务管理与功能适配技术路径
人工智能·深度学习·神经网络·cann
uesowys11 小时前
Apache Spark算法开发指导-One-vs-Rest classifier
人工智能·算法·spark
AI_567811 小时前
AWS EC2新手入门:6步带你从零启动实例
大数据·数据库·人工智能·机器学习·aws
User_芊芊君子11 小时前
CANN大模型推理加速引擎ascend-transformer-boost深度解析:毫秒级响应的Transformer优化方案
人工智能·深度学习·transformer
ValhallaCoder11 小时前
hot100-二叉树I
数据结构·python·算法·二叉树