控制算法: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调参经验:

相关推荐
地平线开发者36 分钟前
J6B vio scenario sample
算法
七歌杜金房2 小时前
我终于又有了自己的 Linux 电脑
linux·debian·mac
冬奇Lab3 小时前
Workflow 系列(04):Multi-Agent 协调——编排器边界、并发控制与上下文隔离
人工智能·工作流引擎
冬奇Lab3 小时前
每日一个开源项目(第147篇):HyperGraphRAG - 用超图表示 N 元关系,RAG 的第三代范式
人工智能·开源·graphql
甲维斯4 小时前
Github + 阿里云oss实现类似codex的自动更新!
人工智能
阿里云大数据AI技术5 小时前
光轮智能 × 阿里云:共建 Physical AI 云上数据、评测与持续学习基础设施
人工智能·机器学习
机器之心6 小时前
实锤了:Claude Code偷查用户,时区、中国AI实验室全是关键词
人工智能·openai
网易云信6 小时前
Cursor点燃个人开发者,企业级AI为何频频受挫?Agent工厂从提效工具到AI员工的跃迁
人工智能·开源