MATLAB实现粒子群算法优化PID参数

MATLAB实现粒子群算法优化PID参数

一、问题描述

粒子群算法(PSO)通过模拟鸟群觅食行为搜索最优解,适用于PID参数整定问题。

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

优化目标: 最小化ITAE指标

二、PSO算法原理

每个粒子代表一组PID参数,通过跟踪个体最优和全局最优更新位置:

  • vt+1=wvt+c1r1(pbest−xt)+c2r2(gbest−xt)v_{t+1} = w v_t + c_1 r_1(p_{best} - x_t) + c_2 r_2(g_{best} - x_t)vt+1=wvt+c1r1(pbest−xt)+c2r2(gbest−xt)
  • xt+1=xt+vt+1x_{t+1} = x_t + v_{t+1}xt+1=xt+vt+1

算法参数

参数 数值
粒子数 30
迭代次数 80
惯性权重w 0.7
学习因子c1/c2 1.5 / 1.5

三、MATLAB代码

matlab 复制代码
%% PSO-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];

swarm=30; max_iter=80; w=0.7; c1=1.5; c2=1.5;
pos=rand(swarm,3).*[Kp_r(2),Ki_r(2),Kd_r(2)];
vel=randn(swarm,3)*0.1;
pbest=pos; pbest_val=eval_pop(pos,G);
[gbest_val,i]=min(pbest_val); gbest=pos(i,:);
h=[gbest_val];

for iter=1:max_iter
    r1=rand(swarm,3); r2=rand(swarm,3);
    vel=w*vel+c1*r1.*(pbest-pos)+c2*r2.*(gbest-pos);
    pos=max(0,pos+vel);
    pos(:,1)=min(pos(:,1),Kp_r(2));
    pos(:,2)=min(pos(:,2),Ki_r(2));
    pos(:,3)=min(pos(:,3),Kd_r(2));
    val=eval_pop(pos,G);
    for i=1:swarm
        if val(i)<pbest_val(i)
            pbest_val(i)=val(i); pbest(i,:)=pos(i,:);
        end
        if val(i)<gbest_val
            gbest_val=val(i); gbest=pos(i,:);
        end
    end
    h=[h,gbest_val];
end

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

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 控制台输出

复制代码
PSO 20/80: ITAE=0.1047
PSO 40/80: ITAE=0.1039
PSO 60/80: ITAE=0.1039
PSO 80/80: ITAE=0.1039

===== PSO-PID =====
Kp=4.6586 Ki=3.1215 Kd=3.0000 ITAE=0.1039

五、结果分析

PSO优化得到的PID参数ITAE=0.1039,优于GA的0.1861:

  • 收敛更快:PSO在40代前就已收敛
  • 精度更高:ITAE指标更优
  • 参数合理:Kd达到上限3.0,表明系统需要较强微分作用

六、参数设置建议

参数 说明
粒子数20~50 影响搜索广度
学习因子1~2 控制个体与全局搜索比例
惯性权重0.4~0.9 大值全局搜索,小值局部搜索

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

相关推荐
JieE21221 小时前
LeetCode 56. 合并区间|超清晰 JS 图解思路,面试高频区间题
javascript·算法·面试
Jack201 天前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法
小小杨树1 天前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色
JieE2122 天前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE2122 天前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法
vivo互联网技术2 天前
CVPR 2026 | 全新强化学习框架 BeautyGRPO:重塑真实人像
算法·大模型·cvpr·影像
Darling噜啦啦2 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
用户497863050732 天前
(一)小红的数组操作
算法·编程语言
怕浪猫2 天前
Electron 系列文章封面图
算法·架构·前端框架