PID控制和误差曲线分析

news2024/12/23 20:47:31

PID控制模型

负反馈控制模型,到处都挺常见的,我记得高中的时候生物上就有一堆,什么体液调节之类的。PID控制也算是经典控制了,大家讲的都是经验之谈,这里我从误差曲线调节的角度来讲(误差曲线调节一般都是神经网络上谈的)。

PID模型

常分为位置式PID和增量式PID:

位置式: o u t = K p ∗ e k + K i ∗ ∑ e k + K d ∗ [ e k − e k − 1 ] out = K_p*e_k+K_i*∑e_k+K_d*[e_k-e_{k-1}] out=Kpek+Kiek+Kd[ekek1]

简记 o u t = K p ∗ e k + K i ∗ ∑ e k + K d ∗ e k ′ out = K_p*e_k+K_i*∑e_k+K_d*e_k' out=Kpek+Kiek+Kdek

增量式: o u t + = K p ∗ [ e k − e k − 1 ] + K i ∗ e k + K d ∗ [ e k − 2 e k − 1 + e k − 2 ] out += K_p*[e_k-e_{k-1}] + K_i*e_k+K_d*[e_k-2e_{k-1}+e_{k-2}] out+=Kp[ekek1]+Kiek+Kd[ek2ek1+ek2]

简记 o u t + = K p ∗ e k ′ + K i ∗ e k + K d ∗ e k ′ ′ out += K_p*e_k' + K_i*e_k+K_d*e_k'' out+=Kpek+Kiek+Kdek′′

待控制系统

我这里将待控制系统的模型分为两类:孤立系统和耗散系统

下图中,为一个桶,红色的是目标高度,假设橙色液体是水

1、孤立系统:

这种系统的特性就是你加一滴水,他就有一滴水留存
在这里插入图片描述

2、耗散系统

这种系统的特性就是你加一滴水,这滴水会自己从底部漏完然后消失
在这里插入图片描述

模型输出使得误差曲线降为0

控制理论中,我们常用的说法是这样:将桶的水位控制到目标高度(红线)。

负反馈调节

如上图中,水位低于目标高度(负值)时,我们需要往桶里加水(正值),才能使得水位更接近于目标,这便是负反馈调节,我们的操作输出和系统实际状态是相反,两者此消彼长维持系统平衡。

误差控制

我们若假设实际误差为: E r r o = O b s e r v − T a r g e t Err_o = Observ - Target Erro=ObservTarget,即实际误差 = 实际观测值 - 目标值 。
这样我们就不用关心正反馈还是负反馈了:

负反馈: o u t = − E r r o out = -Err_o out=Erro
正反馈: o u t = E r r o out = Err_o out=Erro

需要注意的是,这里的误差和pid算法中的误差刚好是相反的

至此,控制算法模型摆脱实际问题,成为独立的数学模型:控制模型的输出是误差的函数

误差曲线

当我们人为操纵待控制系统时,它的误差就会随着变化,我们的目标就只有一个:控制模型输出使得误差为0
在这里插入图片描述对于之前所述的孤立系统而言,我们只要假设单次加水量 W a d d W_{add} Wadd:

W a d d = − E r r o W_{add} = - Err_o Wadd=Erro

水没达到标高,就多加点水,水高于标高,就倒出点水,慢慢的水位就可以到达标高了。

当然,还有一个细节问题,就是单位,量级问题,比如说我加水用的是单位是 m 3 m^3 m3,对于一个桶和一根管,横截面积不同,加相同水的影响就不同,我们可以增加一个系数k,通过调节系数使得实际影响相同:
W a d d = − k ∗ E r r o W_{add} = - k*Err_o Wadd=kErro

这样做必然是有好处的,我们只需研究一个标准系统,其余的系统我们可以通过调节k参数将其转化为标准系统的等效系统,这样就能将之前研究成果应用在新的系统上了。

在这里插入图片描述

对于耗散系统而言,我们若假设单次加水量 W a d d W_{add} Wadd和之前一样,便会出现一个问题:

由于一直在漏水,达到平衡后将有:漏水量=加水量,由于漏水量不为0,所以必然有一个恒定误差,使得 W a d d W_{add} Wadd不为0,也就是我们常说的净差
在这里插入图片描述
我们需要做的就是在输出中加上一个输出常数 C C C,其值与漏水量相等,通过弥补常数抵消漏水影响,就可以使该系统转化为之前的孤立系统,剩下的和之前一样了
W a d d = − ( k ∗ E r r o + C ) W_{add} = - (k*Err_o + C) Wadd=(kErro+C)

这个常数 C C C,我们是可以通过累计静态误差得到的,直到静态误差为0,累计值便不再增加:

C = k 2 ∗ ∑ e ( t ) C =k_2*∑e(t) C=k2e(t)

k 2 k_2 k2参数可以根据系统响应进行调整,若是系统响应的较慢,则参数应取较小值,若取太大了,使得 C C C常数>漏水量,输出就会产生一定的震荡区间,使得 C C C常数有时>漏水量,有时<漏水量。

当然,通常会对 C 项 C项 C进行积分限幅,比如漏水量最多不超过50,结果由于你的参数取太大了,导致算得C参数都为1000了,这样还会影响后续系统调整,导致调整滞后,引发系统进行发散式震荡。

输入与输出的区间映射

对于控制系统而言,一般采用离散输出,这里便存在一个分辨率的问题:

加上输出范围是[-1,0,1]三个值,而输入范围是[-2,-1,0,1,2],系统必然是要震荡的
在这里插入图片描述
假设输出恒为1时,输入为2;输出为-1时,输入为-2。那么我若想让输入为-1,则输出必然是在0和1之间震荡的,按照一定概率比例的0和1组合才能实现。

之前在静态误差累计部分说到 k 2 k_2 k2参数若取的偏大,就会造成系统震荡,便是这个原因, k 2 k_2 k2参数太大会使得输出分辨率降低。

对于一个要稳定控制的系统,其分辨率至少要保证控制系统输出分辨率 ≥ 控制系统输入分辨率

输出控制的频率

如果控制输出的频率太快了,比如说我往桶里倒水,结果我的水才刚倒出还飘在空中,我又进行下一次控制系统运算,采集得到的还是原来是量,这个就会产生滞后性,容易引发震荡(但可以通过降低控制系数来规避),所以控制频率最好根据被控系统的响应时间来估计一下。

如果控制太慢了,就会感觉到系统响应延迟,我设置目标值要好一会,才能到达状态。这就是控制模型和系统响应时间不匹配,产生的控制滞后了。

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

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

相关文章

Java集合 Map 集合 与 操作集合的工具类: Collections 的详细说明

Java集合 Map 集合 与 操作集合的工具类: Collections 的详细说明 每博一文案 别把人生,输给心情 师父说:心情不是人生的全部,却能左右人生的全部。 你有没有体会到,当你心情好的时候,生活仿佛阳光灿烂,顺…

第一章:ElasticSearch简介

Elaticsearch,简称为es, es是一个开源的高扩展的分布式全文检索引擎,它可以近乎实时的存储、检索数据; 本身扩展性很好,可以扩展到上百台服务器,处理PB级别的数据。 es也使用Java开发并使用Lucene作为其核…

MFC|各控件的使用

参考: MFC学习笔记-4-选项控件Combox的使用(https://dandelioncloud.cn/article/details/1517727978783109122) 文章目录控件与变量关联各控件的使用Combo Box添加设置默认选项插入 index从0开始删除获取1号索引的具体内容添加事件获取当前in…

前端学习--async

文章目录async函数await使用await等待Promise异步函数await等待普通函数什么时候使用async/awaitasync也是用于异步任务的,可以说是异步任务处理的另一种方式async函数 async修饰函数,表示这个函数中可以处理异步函数 async修饰的函数,会返…

每天10个前端小知识 【Day 3】

前端面试基础知识题 1. 使用js生成1-10000的数组 实现的方法很多,除了使用循环(for,while,forEach等)外,最简单的是使用Array.from //方法一: Array.from(new Array(10001).keys()).slice(1) //方法二:…

基于paddlex图像分类模型训练(二):训练自己的分类模型、熟悉官方demo

0. 前言 相关系列博文:基于paddlex图像分类模型训练(一):图像分类数据集切分:文件夹转化为imagenet训练格式 代码在线运行: https://aistudio.baidu.com/aistudio/projectdetail/5440569 1. 官方demo&a…

spring框架之注解开发

Spring是轻代码而重配置的框架,配置比较繁重,影响开发效率,所以注解开发是一种趋势。 让我们来看看注解开发之前是如何定义bean的? ① BrandDemo.java ② applicationContext.xml ③Test.java 一、注解开发定义bean 组件扫描 二…

信用卡APP评测系列——工银e生活5.0打造个人生活服务平台,引领用户美好生活

易观:中国信用卡市场规模增速趋稳,线上成为存量用户经营主阵地, APP用户高质量经营成为新发力点,也是业务良性增长保障,对此,银行机构着力用户体验竞相升级信用卡APP。工商银行顺势升级工银e生活APP5.0版&a…

第二章.神经网络—3层神经网络的实现,输出层设计

第二章.神经网络 2.3 三层神经网络的实现 1.各层间信号传递的实现 1).示意图: 2).公式: ①.用数学式表示a1(1): ②.用矩阵表示第一层的加权和: 3).实现: import numpy as np# 3层神经网络的实现# 参数初始化 def i…

华数杯B题——校任务尝试

一、背景说明 根据影响社会稳定的因素,以及颜色革命,来衡量社会稳定性,判断社会风险 社会预警指标体系是由一系列经过理论遴选的敏感指标组成的一种测量社会危机现象及其运行过程的指标系统,它作为一种特定的测量工具和手段&…

Java设计模式--原型模式

概念:用原型实例(最初的)指定创建对象的种类,并且通过拷贝这些原型,创建新的对象。(自我复制能力)1.类图原理类图分析Prototype:原型类,声明一个克隆自己的接口ConcreteP…

Go编程规范和性能调优(三)——规范编码和性能优化

文章目录一、本次学习重点内容:二、详细知识点介绍:1、高质量编程简介什么是高质量?编程原则:2、编码规范注释:代码格式:命名规范变量:函数:package:错误和异常处理&…

关于yolov8的训练的一些改动

1、YOLOv8创新改进点: 1.1.Backbone 使用的依旧是CSP的思想,不过YOLOv5中的C3模块被替换成了C2f模块,实现了进一步的轻量化,同时YOLOv8依旧使用了YOLOv5等架构中使用的SPPF模块; 1.2.PAN-FPN 毫无疑问YOLOv8依旧使…

大文件传输软件的优势有哪些?-镭速传输

互联网时代,大数据传输是企业面临的必不可免的问题,可以选择传统的FTP、网盘等方式来传输,对于小型文件或许是有优势的;但是对于大型文件数据的话,也许会出现传输速度慢,数据不可靠的情况,极大的…

python3+requests+unittest:接口自动化测试(一)

简单介绍框架的实现逻辑,参考代码的git地址: GitHub - zhangying123456/python_unittest_interface: pythonunittest接口自动化测试脚本 1.环境准备 python3 pycharm编辑器 2.框架目录展示 (该套代码只是简单入门,有兴趣的可…

Nginx——Keepalived的原理与配置

摘要 Keepalived的作用是检测服务器的状态,如果有一台web服务器宕机,或工作出现故障,Keepalived将检测到,并将有故障的服务器从系统中剔除, 同时使用其他服务器代替该服务器的工作,当服务器工作正常后Keep…

python求解带约束的优化问题

带约束的优化问题可被定义为: 在python中,可以使用scipy的optimize包进行求解,具体求解函数为linprog,下面举例说明求解方法: 假设问题被定义为: 首先,求解最大值问题,我们可以通…

Spring Security 源码解读 :认证总览

Spring Security 提供如下几种认证机制: Username & PasswordOAuth2.0 LoginSAML 2.0 LoginRemember MeJAAS AuthenticationPre-authentication ScenariosX509 Authentication 这里使用Spring Boot 2.7.4版本,对应Spring Security 5.7.3版本 Serv…

LeetCode题目笔记——1588. 所有奇数长度子数组的和

文章目录题目描述题目难度——简单方法一:暴力代码/C代码/Python方法二:前缀和代码/C代码/Python总结题目描述 给你一个正整数数组 arr ,请你计算所有可能的奇数长度子数组的和。 子数组 定义为原数组中的一个连续子序列。 请你返回 arr 中…

MySql性能优化(六)索引监控

文章目录索引监控Handler_read_firstHandler_read_keyHandler_read_lastHandler_read_nextHandler_read_prevHandler_read_rndHandler_read_rnd_next索引监控 SHOW STATUS LIKE Handler_read%解释一下各个参数的含义 Handler_read_first 通过index获取数据的次数 Handler_r…