一种PID参数量子粒子群自整定方法
moboyou 2025-04-25 13:13 39 浏览
摘 要: 传统的PID参数整定方法由于需要决策者具有较强的工程经验,难以处理非连续、非线性或时滞的复杂系统。针对这种情况,提出一种新的基于量子粒子群优化的PID参数自整定方法。该算法采用问题的时间绝对偏差乘积积分方程来评价粒子的适应值;设计一种时变变异算子,用来均衡粒子的全局和局部开发能力。实验结果表明,该算法在超调量和调节时间等指标上皆优于传统粒子群优化算法。
0 引言
PID控制器因其原理简单、结构清晰和可替换性强等优点,备受广大工程人员的好评[1]。然而,由于所设计控制器的效果完全取决于PID的三个参数,因此,PID参数整定一直备受学者的关注。
根据所采用方式的不同,已有PID参数整定方法可分为传统整定方法和智能优化方法两类[2]。对于低阶、线性和实时控制系统,传统整定方法可以取得好的控制效果;但是,随着工业水平的快速发展,实际工业生产中经常会出现一些复杂非连续、非线性或时滞的系统。为了提高PID参数整定的效果,人们尝试将智能算法用于PID参数的整定,典型方法如模糊推理算法[3]、神经网络方法[4]、遗传算法[5]和粒子群优化算法(PSO)[6-7]等。
量子粒子群优化算法[8](Quantum behaved Particle Swarm Optimization,QPSO)是孙俊等人在2004年提出的一种改进型粒子群优化算法。相对传统粒子群优化算法[9],该算法在保留结构简单和易于执行等优点的基础上,显著提高了粒子的搜索能力。本文将量子粒子群优化算法用于自动调整PID的参数,提出一种改进的量子粒子群自整定方法。
1 PID参数的改进量子粒子群自整定方法
1.1 粒子编码及初始种群
本文将PID控制器三个参数作为粒子群优化三个决策变量,并进行实数编码,也就是说将每一个粒子看作一个三维空间向量即:
xi=(xi1,xi2,xi3)=(kip,kii,kid)
运行粒子群算法之前,本文先用传统的Z-N整定法得到一个参数整定结果,并将该结果作为一个参考范围,用来确定每一维决策变量的取值范围。出于实际考虑,粒子位置不可能出现负数,所以粒子搜索空间设定如下:
其中,
、
和
为Z-N整定法得到的参数参考值,若迭代过程中粒子位置超出上述边界,则取边界值。
1.2 适应度函数的选取
针对PID参数自整定问题,需要确定一个用来判定PID控制效果的性能指标。本文选取时间绝对偏差乘积积分方程(ITAE)作为评价指标,计算公式如下:
利用增量式的PID控制算法将PID控制器的三个控制参数KP、KI和KD作为系统输入,并以系统响应曲线确定的J值作为响应粒子的适应值。
1.3 一致时变变异算子
为了均衡算法的全局和局部搜索能力,给出一种时变变异算子,同时调节粒子的变异概率和变异范围。所提变异算子的伪代码如下:
FOR i=1 to N//*N为粒子群规模*//
IF pm=e(-2×t/Tmax)>rd//*rd为间随机数*//
d=rand(1,3)//*在{1,2,3}中随机选择一维*//
xid=xid+N(0,1)×rang//*N(0,1)为标准高斯分布函数*//
ENDIF
ENDFOR
可以看出,在算法初期阶段,粒子群中所有粒子将受变异算子的影响,并且每个粒子允许在整个决策空间中变异,因此,在初始阶段算法具有好的全局探索能力。随着迭代次数的增加,变异算子的影响逐渐变弱,因此,在迭代后期算法将具有好的局部开发能力。
1.4 算法执行步骤
本文所提改进算法的流程如下:
(1)根据Z-N方法确定KP、KI和KD的取值范围,随后在取值范围内随机初始化N个粒子;
(2)初始化粒子的自身位置为其个体最优点,粒子群中最好位置为粒子的全局最优点;
(3)计算每个粒子的平均最优位置:
Ait=(c1r1Pit+c2r2Pgt)/(c1r1+c2r2)(3)
其中,Pit=(P ti,1,P ti,2,P ti,3)为到目前t时刻第i个粒子发现的最好位置,即通常说的微粒个体最优点;Pgt=(P tg,1,P tg,2,P tg,3)为到目前t时刻所有粒子发现的最好位置,即通常说的粒子全局最优点;c1和c2为学习因子,r1和r2为服从均匀分布U(0,1)的随机数。
(4)更新每个粒子的位置:
其中,
参数
为收缩-扩张系数,为保证粒子收敛,本文取0<
<1.782;参数u为服从均匀分布U(0,1)的随机数;N为粒子群的规模。
(5)执行一致变异算子;
(6)利用式(1)计算每个粒子的适应值;
(7)更新粒子的个体最优点和全局最优点;
(8)判断是否达到预设的算法终止条件,如果满足,则终止算法并输出结果,否则返回步骤(3)。
2 实验仿真
为了验证上述改进量子粒子群优化算法在PID控制上的优越性,本文利用Simulink良好的模拟能力,进行PID控制器的参数优化与模拟。
被控对象如下:
图1给出了Simulink开发的仿真系统。
2.1 参数设置
设置模型输入信号为系统阶跃响应,采样周期为0.01 s。分别运用改进量子粒子优化算法和基本PSO算法,比较两者所产生参数的控制效果。两种算法采用相同的种群规模20以及迭代次数50。
2.2 结果分析
利用本文所提改进算法和基本PSO算法,分别优化问题30次,表1和表2出示了两者算法所得的统计结果。可以看出,本文所提算法性能明显优于基本PSO算法,其所得最差结果(即适应值最大的解)也优于基本粒子群优化算法所得最优结果(即适应值最小的解)。进一步,图2和图3展示了某次实验时两种算法所得最优参数对应的控制响应曲线。
可以看出,本文算法所得控制参数展示了更好的控制效果,在超调量和调节时间等指标上皆优于传统PSO算法。
3 结论
本文将量子粒子群优化算法用于自动调整PID的三个控制参数,通过采用一致时变变异算子均衡粒子的全局和局部开发能力,提出一种改进的PID参数量子粒子群自整定方法。利用Simulink对系统进行仿真,并与基本PSO算法进行比较,实验验证了所提算法的有效性。
参考文献
[1] 陶永华.新型PID控制及其应用[M].北京:机械工业出版社,2003.
[2] 安凤栓,常俊林,苏丕朝,等.基于改进粒子群优化算法的PID控制器参数优化[J].工矿自动化,2010(5):54-57.
[3] 朱颖合,薛凌云,黄伟.基于自组织调整因子的模糊PID控制器设计[J].系统仿真学报,2011,23(12):2732-2737.
[4] 杜海树,杨智,邱熔胜,等.神经智能PID控制算法应用[J].甘肃工业大学学报,1999,25(3):72-76.
[5] 周洪波,齐占庆,衡强,等.一种改进的遗传算法及其在PID控制中的应用[J].控制工程,2007,14(6):589-591.
[6] 王介生,王金城,王伟.基于粒子群算法的PID参数自整定[J].控制与决策,2005,20(1):73-76.
[7] 孙慧,杨守义,穆晓敏.NC-OFDM系统导频设计的离散粒子群算法[J].电子技术应用,2014,40(7):99-102.
[8] 孙俊.量子行为粒子群优化算法研究[D].无锡:江南大学,2009.
[9] KENNEDY J, EBERHART R. Particle swarm optimization[C]. Proceedings of the 1995 IEEE International Conference on Neural Networks, 1995:1942-1948.
相关推荐
- 黄道十二宫杀手密码51年后被破解,来自两位程序员和数学家合作
-
杨净边策发自凹非寺量子位报道|公众号QbitAI黄道十二宫杀手(ZodiacKiller)可能是世界上最知名的高智商连环杀手,52年来从未被抓获。他的事迹已被改编成了多部好莱坞电影。△...
- 深入剖析MediaCodec解码器的基本原理及使用「建议新手收藏」
-
一,MediaCodec工作原理MediaCodec类Android提供的用于访问低层多媒体编/解码器接口,它是Android低层多媒体架构的一部分,通常与MediaExtractor、MediaMu...
- Retrofit WebService 实践
-
前言作为Android开发,平时和后端聊得最多的除了喝酒就是接口。常用语:Restful和WebService,前者现在聊得多,后者以前聊得多。默认含义分别为:Restful:HTTP协议...
- 建议收藏!175部4K UHD版本经典高分电影洗版参考目录(2015之前)
-
本内容来源于@什么值得买APP,观点仅代表作者本人|作者:1L789近两年很多经典高分老电影陆续开始重制成4KUHD版本,虽然我早已将这些电影的BD蓝光版收入,但纠结一番后还是花了不少时间将其全部...
- 2 个月的面试亲身经历告诉大家,如何进入 BAT 等大厂?
-
这篇文章主要是从项目来讲的,所以,从以下几个方面展开。怎么介绍项目?怎么介绍项目难点与亮点?你负责的模块?怎么让面试官满意?怎么介绍项目?我在刚刚开始面试的时候,也遇到了这个问题,也是我第一个思考的问...
- 详解Android官推Kotlin-First的图片加载库
-
前言Coil是一个非常年轻的图片加载库,在2020年10月22日才发布了1.0.0版本,但却受到了Android官方的推广,在AndroidDevelopersBackst...
- webview 渲染机制:硬件加速方式渲染的Android Web
-
webview渲染是什么?webview渲染是用于展现web页面的控件;webview可以内嵌在移动端,实现前端的混合式开发,大多数混合式开发框架都是基于webview模式进行二次开发的w...
- 因为我对Handler的了解,居然直接给我加了5K
-
1Handler是什么?android提供的线程切换工具类。主要的作用是通过handler实现从子线程切换回主线程进行ui刷新操作。1.1为什么Handler能实现线程切换?在创建Handler的...
- 「经典总结」一个View,从无到有会走的三个流程,你知道吗?
-
前言一个View,从无到有会走三个流程,也就是老生常谈的measure,layout,draw三流程我们都知道Android视图是由一层一层构成的层级结构,直白点说,就是父View包含子View而子V...
- 这些垃圾代码是谁写的?哦,原来小丑竟是我自己
-
程序员是最喜欢自嘲、自黑的群体之一,比如他们常常称自己是“码农”、“程序猿”,再比如他们的工作明明是写代码、修Bug,也有人调侃说:“明明我们是修代码、写Bug!”本文整理了一些程序员“修代码、写...
- 手把手教你爬取天堂网1920*1080大图片(批量下载)——理论篇
-
/1前言/平时我们要下载图片,要要一个一个点击下载是不是觉得很麻烦?那有没有更加简便的方法呢?答案是肯定的,这里我们以天堂网为例,批量下载天堂网的图片。/2项目准备工作/首先我们第一步我们要安装...
- 音视频开发需要你懂得 ffmpeg 开源库的编码原理
-
引言音视频开发需要你懂得音视频中一些基本概念,针对编解码而言,我们必须提前懂得编解码器的一些特性,码流的结构,码流中一些重要信息如sps,pps,vps,startcode以及基本的工作原理,...
- 「8年老 Android 开发」最全最新 Android 面试题系列全家桶(带答案)
-
下面跟大家分享的这些面试题都是互联网大厂真实流出的面试内容,每个问题都附带完整详细的答案,不像网上的那些资料三教九流有的甚至还没答案,这些面试题我也是经过日积月累才整理出来的精品资料。这些面试题主要是...
- 手把手教你爬取天堂网1920*1080大图片(批量下载)——实战篇
-
/1前言/上篇文章手把手教你爬取天堂网1920*1080大图片(批量下载)——理论篇我们谈及了天堂网站图片抓取的理论,这篇文章将针对上篇文章的未尽事宜进行完善,完成图片的批量抓取。/2图片网址解...
- PHP 8.1.9 更新发布
-
CLI:修复了内置服务器通过PHP_CLI_server_WORKERS环境变量的潜在溢出。修正了GH-8952(不再可能有意关闭std句柄)。Core:修复了GH-8923的错误(Windows上的...
- 一周热门
- 最近发表
- 标签列表
-
- curseforge官网网址 (16)
- 外键约束 oracle (36)
- oracle的row number (32)
- 唯一索引 oracle (34)
- oracle in 表变量 (28)
- oracle导出dmp导出 (28)
- oracle 数据导出导入 (16)
- oracle两个表 (20)
- oracle 数据库 字符集 (20)
- oracle安装补丁 (19)
- matlab化简多项式 (20)
- 多线程的创建方式 (29)
- 多线程 python (30)
- java多线程并发处理 (32)
- 宏程序代码一览表 (35)
- c++需要学多久 (25)
- c语言编程小知识大全 (17)
- css class选择器用法 (25)
- css样式引入 (30)
- html5和css3新特性 (19)
- css教程文字移动 (33)
- php简单源码 (36)
- php个人中心源码 (25)
- 网站管理平台php源码 (19)
- php小说爬取源码 (23)