自动控制——变速积分的PID控制

news2024/9/21 12:22:45

变速积分的PID控制

PID控制(Proportional-Integral-Derivative Control)是工业控制中最常用的控制算法之一。标准的PID控制器由比例(P)、积分(I)和微分(D)三个部分组成,通过调节这三个部分的参数,实现对系统输出的精确控制。然而,标准的PID控制器在某些情况下可能会出现积分饱和或积分累积的问题,导致系统性能下降。为了解决这些问题,变速积分的PID控制(Variable Integral PID Control)应运而生。

变速积分的PID控制理论

变速积分的PID控制器在传统PID控制器的基础上,对积分项进行了改进。它通过调节积分速度,使得在误差较大时积分速度较慢,而在误差较小时积分速度较快,从而避免了积分饱和问题,提高了系统的动态响应性能。

标准PID控制器

标准PID控制器的控制律如下:

u ( t ) = K p e ( t ) + K i ∫ e ( t )   d t + K d d e ( t ) d t u(t) = K_p e(t) + K_i \int e(t) \, dt + K_d \frac{d e(t)}{dt} u(t)=Kpe(t)+Kie(t)dt+Kddtde(t)

其中:

  • u ( t ) u(t) u(t) 是控制输入
  • e ( t ) e(t) e(t) 是误差信号
  • K p K_p Kp 是比例增益
  • K i K_i Ki 是积分增益
  • K d K_d Kd 是微分增益

变速积分的PID控制器

变速积分的PID控制器的控制律如下:

u ( t ) = K p e ( t ) + K i ∫ α ( e ( t ) ) e ( t )   d t + K d d e ( t ) d t u(t) = K_p e(t) + K_i \int \alpha(e(t)) e(t) \, dt + K_d \frac{d e(t)}{dt} u(t)=Kpe(t)+Kiα(e(t))e(t)dt+Kddtde(t)

其中, α ( e ( t ) ) \alpha(e(t)) α(e(t)) 是一个与误差 e ( t ) e(t) e(t) 有关的调节因子,用于调整积分速度。常用的调节因子形式如下:

α ( e ( t ) ) = 1 1 + β ∣ e ( t ) ∣ \alpha(e(t)) = \frac{1}{1 + \beta |e(t)|} α(e(t))=1+βe(t)1

其中, β \beta β 是调节参数,用于控制积分速度的变化范围。当 β = 0 \beta = 0 β=0 时,变速积分的PID控制器退化为标准PID控制器。

变速积分的PID控制器的优点

  1. 避免积分饱和:通过调节积分速度,在误差较大时减慢积分速度,避免积分饱和问题。
  2. 提高动态响应性能:在误差较小时加快积分速度,提高系统的动态响应性能。
  3. 增强鲁棒性:对于具有大扰动和参数不确定性的系统,变速积分的PID控制器能够更好地应对,提高系统的鲁棒性。

公式推导

变速积分的PID控制器的控制律可以通过以下步骤推导得到:

  1. 定义误差信号:

e ( t ) = r ( t ) − y ( t ) e(t) = r(t) - y(t) e(t)=r(t)y(t)

其中, r ( t ) r(t) r(t) 是期望输出, y ( t ) y(t) y(t) 是实际输出。

  1. 计算比例项:

P ( t ) = K p e ( t ) P(t) = K_p e(t) P(t)=Kpe(t)

  1. 计算积分项:

I ( t ) = K i ∫ α ( e ( t ) ) e ( t )   d t I(t) = K_i \int \alpha(e(t)) e(t) \, dt I(t)=Kiα(e(t))e(t)dt

  1. 计算微分项:

D ( t ) = K d d e ( t ) d t D(t) = K_d \frac{d e(t)}{dt} D(t)=Kddtde(t)

  1. 综合控制律:

u ( t ) = P ( t ) + I ( t ) + D ( t ) u(t) = P(t) + I(t) + D(t) u(t)=P(t)+I(t)+D(t)

Python代码示例

下面是一个实现变速积分的PID控制器的Python代码示例。假设我们有一个简单的温度控制系统,通过变速积分的PID控制器保持系统温度在期望值。

import numpy as np
import matplotlib.pyplot as plt

# 定义系统参数
dt = 0.1  # 时间步长
t = np.arange(0, 10, dt)  # 时间数组
n = len(t)

# 初始化状态变量
temperature = np.zeros(n)  # 系统温度
desired_temperature = np.ones(n) * 50  # 期望温度
external_disturbance = np.sin(t) * 10  # 外界扰动

# 控制器参数
Kp = 2.0  # 比例增益
Ki = 1.0  # 积分增益
Kd = 0.5  # 微分增益
beta = 0.1  # 调节因子参数

# 初始化误差变量
e_prev = 0  # 上一时刻的误差
integral = 0  # 误差积分

# 定义调节因子
def alpha(e):
    return 1 / (1 + beta * abs(e))

# 模拟系统
for i in range(1, n):
    # 计算误差
    e = desired_temperature[i] - temperature[i-1]
    
    # 误差积分(变速积分)
    integral += alpha(e) * e * dt
    
    # 误差微分
    derivative = (e - e_prev) / dt
    
    # 变速积分PID控制器
    u = Kp * e + Ki * integral + Kd * derivative
    
    # 更新系统温度
    temperature[i] = temperature[i-1] + (u + external_disturbance[i]) * dt
    
    # 更新上一时刻的误差
    e_prev = e

# 绘制结果
plt.figure(figsize=(10, 4))
plt.plot(t, desired_temperature, label='Desired Temperature')
plt.plot(t, temperature, label='Actual Temperature')
plt.plot(t, external_disturbance, label='External Disturbance')
plt.xlabel('Time [s]')
plt.ylabel('Temperature')
plt.legend()
plt.title('Variable Integral PID Control for Temperature System')
plt.grid(True)
plt.show()

在这里插入图片描述

代码解释

  1. 系统参数和时间数组:定义了时间步长 dt 和时间数组 t,用来模拟系统在一段时间内的行为。
  2. 状态变量初始化:初始化了系统温度 temperature、期望温度 desired_temperature 和外界扰动 external_disturbance
  3. 控制器参数:定义了变速积分PID控制器的比例增益 Kp、积分增益 Ki、微分增益 Kd 和调节因子参数 beta
  4. 误差变量初始化:初始化了上一时刻的误差 e_prev 和误差积分 integral
  5. 调节因子函数:定义了调节因子函数 alpha(e),用于计算变速积分中的积分速度。
  6. 系统模拟:通过迭代计算,在每个时间步长内根据变速积分PID控制律计算控制输入,并更新系统温度。
  7. 结果绘制:使用 matplotlib 绘制系统温度、期望温度和外界扰动的变化曲线。

结论

变速积分的PID控制器在传统PID控制器的基础上,通过调节积分速度,能够有效地避免积分饱和问题,提高系统的动态响应性能和鲁棒性。在实际应用中,变速积分的PID控制器适用于具有大扰动和参数不确定性的系统,能够实现更精确的控制效果。结合Python代码示例,可以更直观地理解变速积分的PID控制器的基本原理和实现方法。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1925603.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

连锁直营店小程序赋能多店如何管理

如商超便利店卖货线下场景,也有不少品牌以同城多店和多地开店经营为主,获取店铺周围客户和散流,如今线上重要性凸显,品牌电商发展是经营的重要方式之一,也是完善同城和外地客户随时便捷消费的方式之一。 多个门店管理…

Js 前置,后置补零的原生方法与补字符串 padStart及padEnd

在工作中,遇到了需要将不满八位的一个字符串进行后补0的操作,所以就在网上学习了关于js原生补充字符串的方法,然后用这篇博客记录下来。 目录 前置补充字符串 String.prototype.padStart() 后置补充字符串String.prototype.padEnd() 前置补…

OpenGL笔记十之Shader类的封装

OpenGL笔记十之Shader类的封装 —— 2024-07-10 晚上 bilibili赵新政老师的教程看后笔记 code review! 文章目录 OpenGL笔记十之Shader类的封装1.运行2.目录结构3.main.cpp4.application4.1.CMakeLists.txt4.2.Application.h4.3.Application.cpp 5.assets5.1.shaders&#xf…

虚拟机:VMware功能,安装与使用

目录 一、虚拟机介绍 二、VMware 1.介绍 2.安装 (1)根据提示按步骤安装​编辑 (2)更改软件的安装地址​编辑 (3)根据自己的需求选择是否需要软件更新​编辑 (4)根据需求选择…

20240715 每日AI必读资讯

🌐 代号“ 草莓 ”,OpenAI 被曝研发新项目:将 AI 推理能力提至新高度 - OpenAI 公司被曝正在研发代号为“ 草莓 ”的全新项目,进一步延伸去年 11 月宣布的 Q* 项目,不断提高 AI 推理能力,让其更接近人类的…

27.数码管的驱动,使用74HC595移位寄存器芯片

PS:升腾A7pro系列FPGA没有数码管外设,因此以AC620FPGA为例展开实验。 (1)共阳极数码管和共阴极数码管示意图: AC620中的数码管属于共阳极数码管,段选端口(dp,g,f,e,d,c,b,a)低电平即可点亮led。人眼的视觉…

Flink CDC 同步表至Paimon 写数据流程,write算子和commit算子。

Flink CDC 同步表至Paimon 写数据流程,write算子和commit算子。(未吃透版) 流程图 一般基本flink cdc 任务同步数据至paimon表时包含3个算子,source、write、global commit。 source端一般是flink connector实现的连接源端进行获取数据的过程,本文探究的是 source算子获…

算法学习笔记(8.6)-编辑距离问题

目录 Question: 动态规划思路: 第一步:思考每轮的决策,定义状态,从而得到dp表 第二步:找出最优子结构,进而推导出状态转移方程 第三步:确定边界条件和状态转移顺序 代码实现&#xf…

BUUCTF逆向wp [FlareOn4]login

按老规矩先查壳&#xff0c;但本题是html文件&#xff0c;查壳会报错 在网上查了一下&#xff0c;可以用vscode查看源代码&#xff0c;我们用VS code打开。 <!DOCTYPE Html /> <html> <head> <title>FLARE On 2017</title> </head> <…

d3dcompiler_47.dll缺失怎么修复,一步步分析d3dcompiler_47.dll文件

d3dcompiler_47.dll缺失怎么修复&#xff1f;快速教大家解决出现d3dcompiler_47.dll问题的方法&#xff0c;一步步教大家快速有效的将丢失的d3dcompiler_47.dll如何修复。 一步步修复d3dcompiler_47.dll分析 1. 重新安装受影响的程序 如果是特定程序报告缺少d3dcompiler_47.d…

Vue实现滚动元素始终固定在最底部

1. 应用场景——聊天 在聊天的时候&#xff0c;展示聊天内容的元素是可以滚动的&#xff0c;通过上下滚动来查看过往消息。不过在首次打开聊天页面以及发送新消息时需要固定在滚动的最底部以及时展示最新的消息&#xff0c;这样才能获得比较好的用户体验。 效果&#xff1a; …

每日一练,java

目录 描述示例 总结 描述 题目来自牛客网 •输入一个字符串&#xff0c;请按长度为8拆分每个输入字符串并进行输出&#xff1b; •长度不是8整数倍的字符串请在后面补数字0&#xff0c;空字符串不处理。 输入描述&#xff1a; 连续输入字符串(每个字符串长度小于等于100) 输…

Wikijs 部署教程

以下是一个 Wikijs 部署的简单教程&#xff0c;涵盖了使用 Docker 和直接安装两种方式&#xff1a; 方法一&#xff1a; 使用 Docker (推荐) Docker 是一个方便快捷的方式来部署 Wikijs&#xff0c;它可以避免许多手动配置步骤。 安装 Docker: 按照 https://docs.docker.com/…

接口测试返回参数的自动化对比!

引言 在现代软件开发过程中&#xff0c;接口测试是验证系统功能正确性和稳定性的核心环节。接口返回参数的对比不仅是确保接口功能实现的手段&#xff0c;也是测试过程中常见且重要的任务。为了提高对比的效率和准确性&#xff0c;我们可以通过自动化手段实现这一过程。本文将…

android CameraX构建相机拍照

Android CameraX 是一个 Jetpack 支持库&#xff0c;旨在简化相机应用的开发工作。它提供了一致且易用的API接口&#xff0c;适用于大多数Android设备&#xff0c;并可向后兼容至Android 5.0&#xff08;API级别21&#xff09;。 CameraX解决了在多种设备上实现相机功能时所遇…

LLM代理应用实战:构建Plotly数据可视化代理

如果你尝试过像ChatGPT这样的LLM&#xff0c;就会知道它们几乎可以为任何语言或包生成代码。但是仅仅依靠LLM是有局限的。对于数据可视化的问题我们需要提供一下的内容 描述数据:模型本身并不知道数据集的细节&#xff0c;比如列名和行细节。手动提供这些信息可能很麻烦&#…

javascipt学习笔记一

JavaScript基础day1 一、编程语言 1.编程 编程&#xff1a;就是让计算机为解决某个问题而使用某种编程设计语言编写程序代码&#xff0c;最终得到结果的过程 计算机程序&#xff1a; 就是计算机所执行的一系列的指令集合。 2.计算机语言 计算机语言指的是用于人与计算机之间通…

Manim的代码练习02:在manim中Dot ,Arrow和NumberPlane对象的使用

Dot&#xff1a;指代点对象或者表示点的符号。Arrow&#xff1a;指代箭头对象&#xff0c;包括直线上的箭头或者向量箭头等。NumberPlane&#xff1a;指代数轴平面对象&#xff0c;在Manim中用来创建包含坐标轴的数学坐标系平面。Text&#xff1a;指代文本对象&#xff0c;用来…

国产数据库VastBase与C/C++程序适配

背景 2022年底的项目&#xff0c;记录一下。 某项目后台使用C程序开发&#xff0c;使用的是OCI连接Oracle数据库。现需要做去O国产化适配改造。 本文聊聊C/C应用程序如何使用VastBase替换Oracle。 编译适配 开发包获取 从VastBase官方或接口人处获取OCI开发包&#xff0c;包含…

品牌产业出海指南如何搭建国际化架构的跨境电商平台?

在“品牌&产业出海指南 – 成功搭建跨境电商平台”系列中&#xff0c;我们将从电商分销系统、跨境平台商城/多商户商城系统和国际化架构三个方面对帮助您梳理不同平台模式的优缺点、应用场景、开发重点和运营建议。 在“品牌&产业出海指南 – 成功搭建跨境电商平台”系…