这篇文章主要讲解的是使用粒子群算法对PID参数进行寻优,大家可以进行参考。

基于粒子群算法的PID控制器优化设计

  • 1. 理论基础
  • 2. 问题描述
  • 3. 思路及步骤
    • 3.1 优化设计过程
    • 3.2 粒子群算法实现
  • 4. MATLAB程序
  • 5.仿真结果

1. 理论基础

PID控制器的一般形式为
u(t)=Kpe(t)+Ki∫0te(τ)dτ+Kdde(t)dtu(t) = {K_p}e(t) + {K_i}\int_0^t {e(\tau )} d\tau + {K_d}\frac{{de(t)}}{{dt}}u(t)=Kp​e(t)+Ki​∫0t​e(τ)dτ+Kd​dtde(t)​
其中,e(t)e(t)e(t)是系统误差;KpK_pKp​、KiK_iKi​和KdK_dKd​分别是对系统误差信号及其积分与微分量的加权,控制器通过这样的加权就可以计算出控制信号,驱动受控对象。
因此,PID控制器的三个参数的选择相当重要,优化这三个参数相当重要。传统参数的选取都是靠人工经验进行选取,此文章将使用PSO对PID控制器中的这三个参数进行优化。

2. 问题描述

PID控制器的系统结构图如下

PID控制器的优化问题就是确定一组合适的参数KpK_pKp​、KiK_iKi​、KdK_dKd​,使得指标达到最优。这里选用ITAE指标,其定义为
J=∫0∞t∣e(t)∣dtJ = \int_0^\infty {t\left| {e(t)} \right|dt} J=∫0∞​t∣e(t)∣dt
选取的被控对象为为下面的不稳定系统:
G(s)=s+2s4+8s3+4s2−s+0.4G(s) = \frac{{s + 2}}{{{s^4} + 8{s^3} + 4{s^2} - s + 0.4}}G(s)=s4+8s3+4s2−s+0.4s+2​
在Simulink环境下搭建上述的模型如下图所示:

3. 思路及步骤

3.1 优化设计过程

李用粒子群算法对PID控制器的参数进行优化设计,过程图如下所示:

上图中,粒子群算法与Simulink模型之间连接的桥梁是粒子(即PID控制器参数)和该粒子对应的适应值(即控制系统的性能指标)。优化过程如下:PSO产生粒子群(可以是初始化的粒子群,也可以是更新后的粒子群),将该粒子群中的粒子依次赋值给PID控制器的参数KpK_pKp​、KiK_iKi​、KdK_dKd​,然后运行控制器系统的Simulink模型,得到该参数对应的性能指标,该性能指标传递到PSO中作为该粒子的适应值,最后判断是否可以退出算法。

3.2 粒子群算法实现

粒子群算法中速度和位置是根据下面两个公式进行更新
vt+1=ωvt+c1r1(Pt−xt)+c2r2(Gt−xt){v_{t + 1}} = \omega {v_t} + {c_1}{r_1}({P_t} - {x_t}) + {c_2}{r_2}({G_t} - {x_t})vt+1​=ωvt​+c1​r1​(Pt​−xt​)+c2​r2​(Gt​−xt​)
xt+1=xt+vt+1x_{t+1}=x_t+v_{t+1}xt+1​=xt​+vt+1​
其中,xxx表示粒子的位置;vvv表示粒子的速度;ω\omegaω为惯性因子;c1c_1c1​、c2c_2c2​为加速度常数;r1r_1r1​、r2r_2r2​为[0,1][0,1][0,1]区间的随机数;PtP_tPt​是粒子迄今为止搜索到的最优为止;GtG_tGt​是整个粒子群迄今为止搜索到的最优为止。
PSO的流程如下:

  1. 初始化粒子群,随机产生所有粒子的位置和速度,并确定粒子的PtP_tPt​和GtG_tGt​。
  2. 对每个粒子,将其适应值与该粒子所经历过的最优位置PtP_tPt​的适应值进行比较,若较好,则将其作为当前的PtP_tPt​。
  3. 对每个粒子,将其适应值与整个粒子群所经历过的最优位置GtG_tGt​的适应值进行比较,若较好,则将其作为当前的GtG_tGt​。
  4. 按照上面的公式进行速度和位置的更新。
  5. 如果没有满足终止条件(通常为预设的最大迭代次数和适应值下限值),则返回步骤(2);否则,推出算法,得到最优解。

4. MATLAB程序

下面是Simulink图


其中函数部分的程序如下:

function z=PSO_PID(x)
assignin('base','Kp',x(1));    %粒子依次赋值给Kp
assignin('base','Ki',x(2));    %粒子依次赋值给Ki
assignin('base','Kd',x(3));    %粒子依次赋值给Kd
[t_time,x_state,y_out]=sim('PID_Model',[0,20]);    %使用命令行运行控制系统模型
z=y_out(end,1);    %返回性能指标

主程序如下:

%% 清空环境
clear
clc%% 参数设置
w = 0.6;      % 惯性因子
c1 = 2;       % 加速常数
c2 = 2;       % 加速常数Dim = 3;            % 维数
SwarmSize = 100;    % 粒子群规模
ObjFun = @PSO_PID;  % 待优化函数句柄MaxIter = 100;      % 最大迭代次数
MinFit = 0.1;       % 最小适应值 Vmax = 1;
Vmin = -1;
Ub = [300 300 300];
Lb = [0 0 0];%% 粒子群初始化Range = ones(SwarmSize,1)*(Ub-Lb);Swarm = rand(SwarmSize,Dim).*Range + ones(SwarmSize,1)*Lb      % 初始化粒子群VStep = rand(SwarmSize,Dim)*(Vmax-Vmin) + Vmin                 % 初始化速度fSwarm = zeros(SwarmSize,1);
for i=1:SwarmSizefSwarm(i,:) = feval(ObjFun,Swarm(i,:));                         % 粒子群的适应值
end%% 个体极值和群体极值
[bestf bestindex]=min(fSwarm);
zbest=Swarm(bestindex,:);   % 全局最佳
gbest=Swarm;                % 个体最佳
fgbest=fSwarm;              % 个体最佳适应值
fzbest=bestf;               % 全局最佳适应值%% 迭代寻优
iter = 0;
y_fitness = zeros(1,MaxIter);   % 预先产生4个空矩阵
K_p = zeros(1,MaxIter);
K_i = zeros(1,MaxIter);
K_d = zeros(1,MaxIter);
while( (iter < MaxIter) && (fzbest > MinFit) )for j=1:SwarmSize% 速度更新VStep(j,:) = w*VStep(j,:) + c1*rand*(gbest(j,:) - Swarm(j,:)) + c2*rand*(zbest - Swarm(j,:));if VStep(j,:)>Vmax, VStep(j,:)=Vmax; endif VStep(j,:)<Vmin, VStep(j,:)=Vmin; end% 位置更新Swarm(j,:)=Swarm(j,:)+VStep(j,:);for k=1:Dimif Swarm(j,k)>Ub(k), Swarm(j,k)=Ub(k); endif Swarm(j,k)<Lb(k), Swarm(j,k)=Lb(k); endend% 适应值fSwarm(j,:) = feval(ObjFun,Swarm(j,:));% 个体最优更新     if fSwarm(j) < fgbest(j)gbest(j,:) = Swarm(j,:);fgbest(j) = fSwarm(j);end% 群体最优更新if fSwarm(j) < fzbestzbest = Swarm(j,:);fzbest = fSwarm(j);endend iter = iter+1;                      % 迭代次数更新y_fitness(1,iter) = fzbest;         % 为绘图做准备K_p(1,iter) = zbest(1);K_i(1,iter) = zbest(2);K_d(1,iter) = zbest(3);
end
%% 绘图输出
figure(1)      % 绘制性能指标ITAE的变化曲线
plot(y_fitness,'LineWidth',2)
title('最优个体适应值','fontsize',18);
xlabel('迭代次数','fontsize',18);ylabel('适应值','fontsize',18);
set(gca,'Fontsize',18);figure(2)      % 绘制PID控制器参数变化曲线
plot(K_p)
hold on
plot(K_i,'k','LineWidth',3)
plot(K_d,'--r')
title('Kp、Ki、Kd 优化曲线','fontsize',18);
xlabel('迭代次数','fontsize',18);ylabel('参数值','fontsize',18);
set(gca,'Fontsize',18);
legend('Kp','Ki','Kd',1);

5.仿真结果

经过优化后的PID控制器的最优参数以及性能指标为
Kp=33.6326,Ki=0.1662K_p= 33.6326, K_i=0.1662 Kp​=33.6326,Ki​=0.1662
Kd=38.7892,ITAE=1.0580K_d= 38.7892 , ITAE= 1.0580Kd​=38.7892,ITAE=1.0580

性能指标曲线图:

单位阶跃响应曲线:

KpK_pKp​、KiK_iKi​、KdK_dKd​优化曲线:

大家如果有使用PSO算法对LQR中的Q参数进行优化的程序可以进行交流一下,谢谢!

基于粒子群算法的PID控制器优化设计相关推荐

  1. 《MATLAB智能算法30个案例》:第14章 基于粒子群算法的PID控制器优化设计

    <MATLAB智能算法30个案例>:第14章 基于粒子群算法的PID控制器优化设计 1. 前言 2. MATLAB 仿真示例 3. 小结 1. 前言 <MATLAB智能算法30个案例 ...

  2. PSO粒子群算法调节PID控制器参数

    概述 PSO(粒子群算法)在处理连续问题上有着较强的能力,因此很适合用来做参数优化,而PID控制器由三个参数组成,它们分别是: Kp.Ki.KdK_p.K_i.K_dKp​.Ki​.Kd​ 我们可以把 ...

  3. 基于遗传算法和粒子群算法的PID悬架控制、LQR悬架控制和滑模悬架控制

    目录 1.基于遗传算法和粒子群算法的的PID悬架控制 1.1 两种悬架系统 1.1.1 将路面激励整合到悬架系统 1.1.2 不将路面激励整合到悬架系统 1.1.3 总结 1.2 PID经典控制理论 ...

  4. 基于粒子群算法的组卷系统的研究与实现

    摘 要 组卷系统的主要任务是根据用户的需要用当前数据库中的试题组成一套符合用户需求的试卷.随着数据库与题量增大,传统采用随机选取和回朔试探法的组卷抽提算法因其抽题时间长,占用的空间复杂度太大,容易陷入 ...

  5. matlab 重叠峰分解 算法,一种基于粒子群算法的光谱重叠峰分解方法与流程

    本发明涉及一种基于粒子群算法的光谱重叠峰分解方法. 背景技术: 由于探测器能量分辨率等原因,峰位接近且峰宽较大的不同谱峰之间常常出现严重重叠干扰的现象,要对光谱作进一步较为准确.全面的成分定量和定性分 ...

  6. 【机器学习】基于粒子群算法的非线性函数寻优

    本微信图文介绍了基于粒子群算法的非线性函数寻优过程,并利用Matlab实现.

  7. 粒子群课设_GitHub - LIYAJUN2018/tscss: 基于粒子群算法的中职自动排课系统

    kvf-admin kvf-admin是一套快速开发框架.脚手架.后台管理系统.权限系统,上手简单,拿来即用.为广大开发者去除大部分重复繁锁的代码工作,让开发者拥有更多的时间陪恋人.家人和朋友. 后端 ...

  8. MATLAB代码:基于粒子群算法的电动汽车充电站最优选址和定容

    MATLAB代码:基于粒子群算法的电动汽车充电站最优选址和定容 关键词:选址定容 电动汽车 充电站位置 仿真平台:MATLAB 主要内容:代码主要做的是一个电动汽车充电站的选址定容问题,提出了能够计及 ...

  9. 【ELM预测】基于粒子群算法PSO优化极限学习机预测含Matlab源码

    1 模型 为了提高空气质量预测精度,提出一种基于粒子群算法优化极限学习机的空气质量预测模型.运用粒子群算法优化极限学习机的初始权值和偏置,在保证预测误差最小的情况下实现空气质量最优预测.选择平均绝对百 ...

  10. 基于粒子群算法的冷热电三联供综合能源系统优化调度

    基于粒子群算法的冷热电三联供综合能源系统优化调度 摘要:本代码建立了微型燃气轮机冷热电三联供系统模型,综合考虑天然气的消耗.燃气轮机的运行维护.购电费用.排污处理费用,将四部分费用之和作为目标函数,采 ...

最新文章

  1. 分享个人预算系统源码(含说明文档)
  2. 「多图」图解10大CNN架构
  3. 掉一根头发,搞定二叉排序(搜索)树
  4. 回归树与基于规则的模型(part3)--回归模型树
  5. 【翻译】.NET Core3.1发布
  6. 'unsigned char'-C编程中的声明,赋值和用法
  7. mac怎么看cpu温度?教你不装软件查看 Mac CPU芯片温度
  8. linux内核 address_space 结构
  9. 微博android4.1.2,微博客户端Fuubo
  10. c语言中isupper用法,C 库函数 isupper() 使用方法及示例
  11. 3dmax联机分布式渲染方法技巧详解
  12. ERROR ~/.vuerc may be outdated. Please delete it and re-run vue-cli in manual mode.
  13. 使用RT-Thread Studio DIY 迷你桌面时钟(二)| 获取温湿度传感器数据(I2C设备驱动+SHT3x软件包)
  14. 信创引领丨呼叫中心加速适配国产化
  15. PyQt5 Qt Designer 新手教程(一)—— 软件界面介绍
  16. 子集构造法NFA转换成DFA
  17. 远程办公:通过cpolar内网穿透,远程桌面控制家里公司内网电脑
  18. SpringBoot配置过滤器和拦截器
  19. cnpm报错:Error: Cannot find module ‘diagnostics_channel‘
  20. 如果想入手软路由我推荐友善官方出品的NanoPi-R2S和NanoPi-R5S

热门文章

  1. android水印的添加,Android添加水印的正确方法 只要三步!
  2. python将网页保存为pdf,利用Python将网页保存为PDF文件
  3. 转子系统动力学模型matlab程序代码
  4. python实现小写金额转换成大写
  5. 人工智能/机器学习/深度学习 经典必看书籍【附百度网盘链接】
  6. 基于GD32MCU程序远程升级IAP设计思路
  7. 第十届全国大学生光电设计大赛分析前瞻(一文看懂光电设计大赛创意赛,做好准备)
  8. ubuntu安装anjuta
  9. QT等待动态图gif加载透明背景lable
  10. matlab 快速傅里叶反变换函数(ifft)编写