0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

matlab-粒子群算法优化simulink中的pid参数详解

冬至子 来源:算法工程师的学习日志 作者:搬砖工程师domi 2023-07-20 14:20 次阅读

图片

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

我们可以把PID控制器当做一个“黑箱”,输入为这三个参数,输出为响应曲线,我们要做的就是优化这个响应曲线。而一个控制效果好的PID控制器应针对不同类型输入都有较快的响应速度,较小的超调以及稳态误差。在本次分享中,选择输入信号为阶跃输入用来衡量PID控制效果。

PSO的适应函数选用综合指标来衡量设计效果,由于是数字控制器,我们选用求和而不是积分的方式:

图片

在特定的问题中,这个适应函数也可以按照实际需求修改,比如分析超调量、稳定时间等,具体问题具体分析

PSO的主函数和之前的案例类似

参数设置

wmax = 1;     % 最大惯性因子 
wmin = 0.6;   % 最小惯性因子 


% w = 0.6;      % 惯性因子 
c1 = 2;       % 加速常数
c2 = 2;       % 加速常数


Dim = 3;            % 维数
SwarmSize = 30;    % 粒子群规模
ObjFun = @PSO_PID;  % 待优化函数句柄


MaxIter = 10;      % 最大迭代次数  
MinFit = 0.1;       % 最小适应值 


Vmax = 1;
Vmin = -1;
Ub = [300 300 300];
Lb = [0 0 0];

其中的Ub和Lb分别是kp ki kd的上下限,开始优化的时候可以设置大一点,如果大概知道范围,也可以缩小范围,减少迭代次数

粒子群初始化

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:SwarmSize
    fSwarm(i,:) = PSO_PID(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) )
    w = wmax-(wmax-wmin)/MaxIter*iter;  %% 惯性权重因子调整
    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; end
        if VStep(j,:)< Vmin, VStep(j,:)=Vmin; end
        % 位置更新
        Swarm(j,:)=Swarm(j,:)+VStep(j,:);
        for k=1:Dim
            if Swarm(j,k) >Ub(k), Swarm(j,k)=Ub(k); end
            if Swarm(j,k)< Lb(k), Swarm(j,k)=Lb(k); end
        end
        % 适应值
        fSwarm(j,:) = PSO_PID(Swarm(i,:));
        % 个体最优更新     
        if fSwarm(j) < fgbest(j)
            gbest(j,:) = Swarm(j,:);
            fgbest(j) = fSwarm(j);
        end
        % 群体最优更新
        if fSwarm(j) < fzbest
            zbest = Swarm(j,:);
            fzbest = fSwarm(j);
        end
    end 
    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     % 绘制性能指标ITAE的变化曲线
plot(y_fitness,'LineWidth',2)
title('最优个体适应值','fontsize',18);
xlabel('迭代次数','fontsize',18);ylabel('适应值','fontsize',18);
set(gca,'Fontsize',18);


figure      % 绘制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');

目标函数设计

function z=PSO_PID(x)
assignin('base','Kp',x(1));    %粒子依次赋值给Kp
assignin('base','Ki',x(2));    %粒子依次赋值给Ki
assignin('base','Kd',x(3));    %粒子依次赋值给Kd
try  %% simulink仿真异常,返回一个极大值
    y_out=sim('PID_Model',[0,20]);    %使用命令行运行控制系统模型
    z = y_out.yout{1}.Values.Data(end);
catch
    z=1e6;
end

代码中assignin实现了m文件和simulink传递参数,其中y_out是simulink输出的目标变量,为啥这儿需要一个try呢,因为这个优化的过程中,可能参数设置不合理,会抛出simulink报错,故增加一个try避免代码异常出错提前结束优化过程

simulink模型用一个简单的pid控制带时延的传递函数

图片

仿真结果类似这样,因为迭代次数很少,设计中可以加大,得到更优的结果

图片

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • MATLAB仿真
    +关注

    关注

    4

    文章

    174

    浏览量

    19638
  • PID控制器
    +关注

    关注

    2

    文章

    156

    浏览量

    18332
  • 粒子群算法
    +关注

    关注

    0

    文章

    63

    浏览量

    12908
  • 数字控制器
    +关注

    关注

    0

    文章

    81

    浏览量

    19412
  • simulink仿真
    +关注

    关注

    0

    文章

    75

    浏览量

    8457
收藏 人收藏

    评论

    相关推荐

    PSO算法在数控机床交流伺服系统PID参数优化的应用

    PSO算法在数控机床交流伺服系统PID参数优化的应用摘要:针对发展高精度数控机床的要求,在数控机床交流伺服控制系统
    发表于 05-17 11:38

    粒子群算法城镇能源优化调度问题

    computation)。源于对鸟群捕食的行为研究。粒子群优化算法的基本思想:是通过群体个体之间的协作和信息共享来寻找最优解.PSO的优势:在于简单容易实现并且没有许多
    发表于 07-07 06:04

    什么是粒子群算法

    粒子群算法(1.初步了解)​ 1995年,受鸟类捕食行为的启发,Kennedy和Eberhart正式提出了粒子群优化算法的概念。研究中发现,
    发表于 07-07 07:50

    Simulink粒子群算法(PSO)整定PID参数(附代码和讲解)精选资料分享

    本文提供粒子群算法简介和一个算法举例,提供粒子群算法仿真PID的M文件代码及
    发表于 09-08 07:53

    基于模拟退火结合粒子群算法介绍

    优化选址】基于模拟退火结合粒子群算法求解分布式电源定容选址问题matlab源码1 算法介绍1.1 模拟退火
    发表于 12-29 07:04

    基于模拟退火结合粒子群算法分析

    优化选址】基于模拟退火结合粒子群算法求解分布式电源定容选址问题matlab源码1 算法介绍1.1 模拟退火
    发表于 01-03 06:41

    基于模拟退火结合粒子群算法相关资料分享

    优化选址】基于模拟退火结合粒子群算法求解分布式电源定容选址问题matlab源码1 算法介绍1.1 模拟退火
    发表于 01-03 07:58

    基于混合粒子群算法PID参数寻优

    提出一种将单纯形法SM与粒子群算法PSO结合的混合粒子群算法HPSO。通过对3种常用测试函数进行优化和比较,结果表明HPSO比PSO和SM都
    发表于 05-25 16:29 19次下载

    PID控制器的量子粒子群多目标优化设计

    摘要:智能算法粒子群算法已被应用于PID控制器的参数优化,以弥补传统
    发表于 01-27 13:48 27次下载

    自适应双层粒子群优化算法_周志勇

    自适应双层粒子群优化算法_周志勇
    发表于 01-07 20:32 0次下载

    基于粒子群优化的输入整形器参数自整定算法_蔡力钢

    基于粒子群优化的输入整形器参数自整定算法_蔡力钢
    发表于 01-08 13:49 2次下载

    粒子群优化算法在配方设计中的应用王涛

    粒子群优化算法在配方设计中的应用_王涛
    发表于 03-15 08:00 0次下载

    如何使用免疫粒子群优化算法实现增量式的PID控制

    基于粒子群优化算法的收敛速度快简单易实现的特点和免疫算法的免疫记忆、免疫自我调节和多峰值收敛的特点,本文设计出免疫粒子群
    发表于 11-01 15:41 7次下载
    如何使用免疫<b class='flag-5'>粒子群</b><b class='flag-5'>优化</b><b class='flag-5'>算法</b>实现增量式的<b class='flag-5'>PID</b>控制

    基于免疫粒子群优化算法的增量式PID控制

    基于免疫粒子群优化算法的增量式PID控制(山东汇科工控技术有限公司官网)-文档为基于免疫粒子群优化
    发表于 09-30 12:27 12次下载
    基于免疫<b class='flag-5'>粒子群</b><b class='flag-5'>优化</b><b class='flag-5'>算法</b>的增量式<b class='flag-5'>PID</b>控制

    粒子群优化算法的应用 粒子群优化算法研究方法

      摘要:粒子群优化算法是一种基于群智能的随机优化算法,具有简单易实现、设置参数少、全局
    发表于 07-19 15:01 0次下载