MATLAB实现灰狼算法优化PID参数

MATLAB实现灰狼算法优化PID参数

一、问题描述

灰狼优化算法(Grey Wolf Optimizer, GWO)模拟灰狼的等级制度和群体捕猎行为,由Mirjalili于2014年提出。算法将狼群分为α、β、δ、ω四个等级,通过围猎、追捕、攻击三个步骤搜索最优解。

被控对象: G(s)=1s2+1.5s+1G(s) = \frac{1}{s^2 + 1.5s + 1}G(s)=s2+1.5s+11

优化目标: 最小化ITAE指标

二、GWO算法原理

2.1 狼群等级

  • α狼:最优解,负责决策
  • β狼:次优解,辅助决策
  • δ狼:第三优解
  • ω狼:其他个体,跟随前三者

2.2 位置更新公式

D⃗=∣C⃗⋅X⃗p(t)−X⃗(t)∣\vec{D} = |\vec{C} \cdot \vec{X}_p(t) - \vec{X}(t)|D =∣C ⋅X p(t)−X (t)∣
X⃗(t+1)=X⃗p(t)−A⃗⋅D⃗\vec{X}(t+1) = \vec{X}_p(t) - \vec{A} \cdot \vec{D}X (t+1)=X p(t)−A ⋅D

其中 a=2−2t/Tmaxa = 2 - 2t/T_{max}a=2−2t/Tmax 线性递减,A⃗=2ar⃗1−a\vec{A} = 2a\vec{r}_1 - aA =2ar 1−a,C⃗=2r⃗2\vec{C} = 2\vec{r}_2C =2r 2

2.3 算法参数

参数 数值
狼群数量 30
迭代次数 80

三、MATLAB代码

matlab 复制代码
%% GWO-PID: 灰狼算法优化PID参数
clc; clear; close all; rng(42);
s=tf('s'); G=1/(s^2+1.5*s+1);
Kp_r=[0,10]; Ki_r=[0,5]; Kd_r=[0,3];

n=30; max_iter=80;
wolves=rand(n,3).*[Kp_r(2),Ki_r(2),Kd_r(2)];
f=eval_pop(wolves,G);
[~,idx]=sort(f);
a=wolves(idx(1),:); fa=f(idx(1));
b=wolves(idx(2),:); fb=f(idx(2));
d=wolves(idx(3),:); fd=f(idx(3));
h=[fa];

for iter=1:max_iter
    a_coef=2-2*iter/max_iter;
    for i=1:n
        r1=rand(1,3); r2=rand(1,3);
        A1=2*a_coef.*r1-a_coef; C1=2*r2;
        X1=a-A1.*abs(C1.*a-wolves(i,:));
        r1=rand(1,3); r2=rand(1,3);
        A2=2*a_coef.*r1-a_coef; C2=2*r2;
        X2=b-A2.*abs(C2.*b-wolves(i,:));
        r1=rand(1,3); r2=rand(1,3);
        A3=2*a_coef.*r1-a_coef; C3=2*r2;
        X3=d-A3.*abs(C3.*d-wolves(i,:));
        wolves(i,:)=max(0,min((X1+X2+X3)/3,[Kp_r(2),Ki_r(2),Kd_r(2)]));
    end
    f=eval_pop(wolves,G);
    [mf,mi]=min(f);
    if mf<fa; d=b; fd=fb; b=a; fb=fa; a=wolves(mi,:); fa=mf;
    elseif mf<fb; d=b; fd=fb; b=wolves(mi,:); fb=mf;
    elseif mf<fd; d=wolves(mi,:); fd=mf; end
    h=[h,fa];
end

fprintf('Kp=%.4f Ki=%.4f Kd=%.4f ITAE=%.4f\n',a,fa);

function f=eval_pop(pop,G)
    n=size(pop,1); f=zeros(n,1); t=0:0.01:5;
    for i=1:n
        try
            C=pid(pop(i,1),pop(i,2),pop(i,3));
            [y,~]=step(feedback(C*G,1),t);
            e=1-y; f(i)=sum(t'.*abs(e))*0.01;
            if isnan(f(i))||f(i)>100, f(i)=100; end
        catch, f(i)=100; end
    end
end

四、运行结果

4.1 控制台输出

复制代码
GWO 20/80: ITAE=0.1091
GWO 40/80: ITAE=0.1063
GWO 60/80: ITAE=0.1044
GWO 80/80: ITAE=0.1039

===== GWO-PID =====
Kp=4.6727 Ki=3.1337 Kd=3.0000 ITAE=0.1039

五、结果对比

算法 Kp Ki Kd ITAE
GA 4.3340 2.8087 2.3031 0.1861
PSO 4.6586 3.1215 3.0000 0.1039
GWO 4.6727 3.1337 3.0000 0.1039

PSO和GWO效果相近,均优于GA。GWO的优势在于参数少、实现简单、无需调整交叉变异率。

六、改进方向

  1. 自适应参数 :动态调整∣A∣|A|∣A∣和∣C∣|C|∣C∣的收敛策略
  2. 混合算法:结合PSO提升GWO的局部搜索能力
  3. 多目标优化:同时优化超调量、上升时间、稳态误差

完整MATLAB代码可直接运行,如有问题欢迎交流!

相关推荐
哥布林学者1 小时前
深度学习进阶(十七)高效通道注意力 ECA
机器学习·ai
2zcode2 小时前
基于MATLAB深度学习的非酒精性脂肪性肝病超声图像分类研究( GUI界面+数据集+训练代码)
深度学习·matlab·分类
hoiii1872 小时前
基于MATLAB实现内点法解决凸优化问题
开发语言·matlab
YBAdvanceFu2 小时前
开源版Suno来了!用扩散模型生成带歌词的完整歌曲,DiffRhythm2实战详解
人工智能·深度学习·机器学习·多智能体·智能体·suno·diffrhythm2
YBAdvanceFu2 小时前
拆解 MusicGen:Meta 开源音乐大模型,到底是怎么跑起来的?
人工智能·深度学习·机器学习·数据挖掘·transformer·agent·智能体
承渊政道2 小时前
【动态规划算法】(完全背包问题从状态定义到空间优化)
数据结构·c++·学习·算法·leetcode·动态规划·哈希算法
超级大福宝2 小时前
【力扣48. 旋转图像】超好记忆版 + 口诀
c++·算法·leetcode
爱写代码的倒霉蛋2 小时前
2023年天梯赛L1-8
数据结构·算法
apollowing3 小时前
启发式算法WebApp实验室:从搜索策略到群体智能的能力进阶(上)
算法·启发式算法·web app