13种改进粒子群优化算法 matlab2022 运行结果和耗时对比

news2025/1/11 6:58:56

前言
阅读粒子群优化算法的文章,发现代码不仅要付费而且还没有运行结果,需要自己手动写代码运行,这里提供下我的运行结果。包含参数结果和耗时对比。
https://www.bilibili.com/read/cv11905136/?spm_id_from=333.999.0.0

% 定义适应度函数
fitness = @(x) x^6 - 3.5*x^4 + 4.3*x^3 + 2*x^2 + 0.8*x + 7;

% 定义初始参数
N = 100; % 初始种群个数
c1 = 2.5;
c2 = 1.6; 
w = 0.5; %权重
lamda = 0.5;  % 退火参数
M = 100; % 迭代次数
D = 1;   % 空间维数
c1max = 3;
c1min = 0.3;
c2max = 2;
c2min = 0.2;
wmax = 0.8; 
wmin = 0.3;
mean_max = 5;
mean_min = 0.5;
sigma = 0.5;
Pc = 0.9; % 杂交概率
Sp = 0.2; % 杂交池的大小比例
xmax = 8;
xmin =0.5;
MaxC = 6;

tic
[xm, fv] = PSO(fitness,N,c1,c2,w,M,D);  %基于模拟退火的粒子群优化算法
disp(['PSO 最佳结果:', num2str(xm)]);
disp(['PSO 最佳适应度值: ', num2str(fv)]);
elapsed_time = toc; % 获取结束时间
disp(['PSO 历时: ' num2str(toc) ' seconds']);  %计时结束

tic
[xm, fv] = SimuAPSO(fitness, N, c1, c2, lamda, M, D);  %基于模拟退火的粒子群优化算法
disp(['SimuAPSO 最佳结果:', num2str(xm)]);
disp(['SimuAPSO 最佳适应度值: ', num2str(fv)]);
elapsed_time = toc; % 获取结束时间
disp(['SimuAPSO 历时: ' num2str(toc) ' seconds']);  %计时结束

tic
[xm, fv] = YSPSO(fitness,N,c1,c2,M,D);  %带压缩因子的粒子群优化算法
disp(['YSPSO 最佳结果:', num2str(xm)]);
disp(['YSPSO 最佳适应度值: ', num2str(fv)]);
elapsed_time = toc; % 获取结束时间
disp(['YSPSO 历时: ' num2str(toc) ' seconds']);  %计时结束

tic
[xm, fv] = AsyLnCPSO(fitness,N,c1max,c1min,c2max,c2min,w,M,D);  %学习因子异步化的粒子群优化算法
disp(['AsyLnCPSO 最佳结果:', num2str(xm)]);
disp(['AsyLnCPSO 最佳适应度值: ', num2str(fv)]);
elapsed_time = toc; % 获取结束时间
disp(['AsyLnCPSO 历时: ' num2str(toc) ' seconds']);  %计时结束

tic
[xm, fv] = LinWPSO(fitness,N,c1,c2,wmax,wmin,M,D); %线性递减权重粒子群优化
disp(['LinWPSO 最佳结果:', num2str(xm)]);
disp(['LinWPSO 最佳适应度值: ', num2str(fv)]);
elapsed_time = toc; % 获取结束时间
disp(['LinWPSO 历时: ' num2str(toc) ' seconds']);  %计时结束

tic
[xm, fv] = SAPSO(fitness,N,c1,c2,wmax,wmin,M,D); %自适应权重粒子群优化算法
disp(['SAPSO 最佳结果:', num2str(xm)]);
disp(['SAPSO 最佳适应度值: ', num2str(fv)]);
elapsed_time = toc; % 获取结束时间
disp(['SAPSO 历时: ' num2str(toc) ' seconds']);  %计时结束

tic
[xm, fv] = RandWPSO(fitness,N,c1,c2,mean_max,mean_min,sigma,M,D); %随机权重粒子群优化算法
disp(['RandWPSO 最佳结果:', num2str(xm)]);
disp(['RandWPSO 最佳适应度值: ', num2str(fv)]);
elapsed_time = toc; % 获取结束时间
disp(['RandWPSO 历时: ' num2str(toc) ' seconds']);  %计时结束

tic
[xm, fv] = BreedPSO(fitness,N,c1,c2,w,Pc,Sp,M,D); %基于杂交的粒子群优化算法
disp(['BreedPSO 最佳结果:', num2str(xm)]);
disp(['BreedPSO 最佳适应度值: ', num2str(fv)]);
elapsed_time = toc; % 获取结束时间
disp(['BreedPSO 历时: ' num2str(toc) ' seconds']);  %计时结束

tic
[xm, fv] = SecPSO(fitness,N,w,c1,c2,M,D); %二阶粒子群优化算法
disp(['SecPSO 最佳结果:', num2str(xm)]);
disp(['SecPSO 最佳适应度值: ', num2str(fv)]);
elapsed_time = toc; % 获取结束时间
disp(['SecPSO 历时: ' num2str(toc) ' seconds']);  %计时结束

tic
[xm, fv] = CLSPSO(fitness,N,c1,c2,w,xmax,xmin,M,MaxC,D); %混沌粒子群优化算法
disp(['CLSPSO 最佳结果:', num2str(xm)]);
disp(['CLSPSO 最佳适应度值: ', num2str(fv)]);
elapsed_time = toc; % 获取结束时间
disp(['CLSPSO 历时: ' num2str(toc) ' seconds']);  %计时结束

tic
[xm, fv] = LnCPSO(fitness,N,c1max,c1min,w,M,D); %学习因子同步变化的粒子群优化算法
disp(['LnCPSO 最佳结果:', num2str(xm)]);
disp(['LnCPSO 最佳适应度值: ', num2str(fv)]);
elapsed_time = toc; % 获取结束时间
disp(['LnCPSO 历时: ' num2str(toc) ' seconds']);  %计时结束

tic
[xm, fv] = SecVibratPSO(fitness,N,w,c1,c2,M,D); %二阶震荡粒子群优化算法
disp(['SecVibratPSO 最佳结果:', num2str(xm)]);
disp(['SecVibratPSO 最佳适应度值: ', num2str(fv)]);
elapsed_time = toc; % 获取结束时间
disp(['SecVibratPSO 历时: ' num2str(toc) ' seconds']);  %计时结束

tic
[xm, fv] = SelPSO(fitness,N,c1,c2,w,M,D); %基于自然选择的粒子群优化算法
disp(['SelPSO 最佳结果:', num2str(xm)]);
disp(['SelPSO 最佳适应度值: ', num2str(fv)]);
elapsed_time = toc; % 获取结束时间
disp(['SelPSO 历时: ' num2str(toc) ' seconds']);  %计时结束

运行测试结果如下:

PSO 最佳结果:-1.8256
PSO 最佳适应度值: -15.8147
PSO 历时: 0.11757 seconds
SimuAPSO 最佳结果:-1.827
SimuAPSO 最佳适应度值: -15.8146
SimuAPSO 历时: 0.024802 seconds
YSPSO 最佳结果:-1.8256
YSPSO 最佳适应度值: -15.8147
YSPSO 历时: 0.016281 seconds
AsyLnCPSO 最佳结果:-1.8256
AsyLnCPSO 最佳适应度值: -15.8147
AsyLnCPSO 历时: 0.017485 seconds
LinWPSO 最佳结果:-1.8256
LinWPSO 最佳适应度值: -15.8147
LinWPSO 历时: 0.01629 seconds
SAPSO 最佳结果:-1.8256
SAPSO 最佳适应度值: -15.8147
SAPSO 历时: 0.020679 seconds
RandWPSO 最佳结果:-1.8212
RandWPSO 最佳适应度值: -15.8133
RandWPSO 历时: 0.015598 seconds
BreedPSO 最佳结果:-1.8256
BreedPSO 最佳适应度值: -15.8147
BreedPSO 历时: 0.26581 seconds
SecPSO 最佳结果:-1.8268
SecPSO 最佳适应度值: -15.8146
SecPSO 历时: 0.014972 seconds
CLSPSO 最佳结果:-1.8261
CLSPSO 最佳适应度值: -15.8147
CLSPSO 历时: 0.033095 seconds
LnCPSO 最佳结果:-1.8256
LnCPSO 最佳适应度值: -15.8147
LnCPSO 历时: 0.015699 seconds
SecVibratPSO 最佳结果:-1.8257
SecVibratPSO 最佳适应度值: -15.8147
SecVibratPSO 历时: 0.017549 seconds
SelPSO 最佳结果:-1.8256
SelPSO 最佳适应度值: -15.8147
SelPSO 历时: 0.017709 seconds

运行上面的代码要把这些算法保存成函数在matlab才能调用,像下图这样:
在这里插入图片描述
其中AsyLnCPSO.m

function [xm,fv] = AsyLnCPSO(fitness,N,c1max,c1min,c2max,c2min,w,M,D)

format long;

%------初始化种群的个体------------

for i=1:N

    for j=1:D

        x(i,j)=randn;  %随机初始化位置

        v(i,j)=randn;  %随机初始化速度

    end

end

%------先计算各个粒子的适应度,并初始化Pi和Pg----------------------

for i=1:N

    p(i)=fitness(x(i,:));

    y(i,:)=x(i,:);

end

pg = x(N,:);             %Pg为全局最优

for i=1:(N-1)

    if fitness(x(i,:))<fitness(pg)

        pg=x(i,:);

    end

end

%------进入主要循环,按照公式依次迭代------------

for t=1:M

    c1 = c1max - (c1max - c1min)*t/M;
    
    c2 = c2max - (c2max - c2min)*t/M;
    
    for i=1:N

        v(i,:)=w*v(i,:)+c1*rand*(y(i,:)-x(i,:))+c2*rand*(pg-x(i,:));

        x(i,:)=x(i,:)+v(i,:);

        if fitness(x(i,:))<p(i)

            p(i)=fitness(x(i,:));

            y(i,:)=x(i,:);

        end

        if p(i)<fitness(pg)

            pg=y(i,:);

        end

    end

    Pbest(t)=fitness(pg);
end
xm = pg';
fv = fitness(pg);

BreedPSO.m

function [xm,fv] = BreedPSO(fitness,N,c1,c2,w,Pc,Sp,M,D)
%Pc 杂交概率
%Sp 杂交池的大小比例
format long;

%------初始化种群的个体------------

for i=1:N

    for j=1:D

        x(i,j)=randn;  %随机初始化位置

        v(i,j)=randn;  %随机初始化速度

    end

end

%------先计算各个粒子的适应度,并初始化Pi和Pg----------------------

for i=1:N

    p(i)=fitness(x(i,:));

    y(i,:)=x(i,:);

end

pg = x(N,:);             %Pg为全局最优

for i=1:(N-1)

    if fitness(x(i,:))<fitness(pg)

        pg=x(i,:);

    end

end

%------进入主要循环,按照公式依次迭代------------

for t=1:M

    for i=1:N

        v(i,:)=w*v(i,:)+c1*rand*(y(i,:)-x(i,:))+c2*rand*(pg-x(i,:));

        x(i,:)=x(i,:)+v(i,:);

        if fitness(x(i,:))<p(i)

            p(i)=fitness(x(i,:));

            y(i,:)=x(i,:);

        end

        if p(i)<fitness(pg)

            pg=y(i,:);

        end
        
        r1 =rand();
        
        if r1 < Pc
            
            numPool = round(Sp*N);
            
            PoolX = x(1:numPool,:);
            
            PoolVX = v(1:numPool,:);
            
            for i=1:numPool
                
                seed1 = floor(rand()*(numPool-1)) + 1;
                
                seed2 = floor(rand()*(numPool-1)) + 1;
                
                pb = rand();
                
                childx1(i,:) = pb*PoolX(seed1,:) + (1-pb)*PoolX(seed2,:);
 
                childv1(i,:) = (PoolVX(seed1,:) + PoolVX(seed2,:))*norm(PoolVX(seed1,:))/ ...
                    norm(PoolVX(seed1,:) + PoolVX(seed2,:));

            end
            
            x(1:numPool,:) = childx1;
            
            v(1:numPool,:) = childv1;
            
        end
        
    end
    
end

xm = pg';

fv = fitness(pg);

CLSPSO.m

function [xm,fv] = CLSPSO(fitness,N,c1,c2,w,xmax,xmin,M,MaxC,D)

format long;

%------初始化种群的个体------------

for i=1:N

    for j=1:D

        x(i,j)=randn;  %随机初始化位置

        v(i,j)=randn;  %随机初始化速度

    end

end

%------先计算各个粒子的适应度,并初始化Pi和Pg----------------------

for i=1:N

    p(i)=fitness(x(i,:));

    y(i,:)=x(i,:);

end

pg = x(N,:);             %Pg为全局最优

for i=1:(N-1)

    if fitness(x(i,:))<fitness(pg)

        pg=x(i,:);

    end

end

%------进入主要循环,按照公式依次迭代------------

for t=1:M
   
    for i=1:N
        
        v(i,:)=w*v(i,:)+c1*rand*(y(i,:)-x(i,:))+c2*rand*(pg-x(i,:));

        x(i,:)=x(i,:)+v(i,:);
        
        fv(i) = fitness(x(i,:));
        
    end
    
    [sort_fv,index] = sort(fv);
    
    Nbest = floor(N*0.2); 
    
    for n=1:Nbest
        
        tmpx = x(index(n),:);
        
        for k=1:MaxC
            
            for dim=1:D
                
                cx(dim) = (tmpx(1,dim) - xmin(dim))/(tmpx(1,dim) - xmax(dim));
                
                cx(dim) = 4*cx(dim)*(1 - cx(dim));
                
                tmpx(1,dim) = tmpx(1,dim) + cx(dim)*(xmax(dim) - xmin(dim));
                
            end
            
            fcs = fitness(tmpx);
            
            if fcs < sort_fv(n)
                
                x(index(n),:) = tmpx;
                
                break;
                
            end
                       
        end
         
        x(index(n),:) = tmpx;
        
    end
    
    r = rand();
    
    for s=1:D
        
        xmin(s) = max(xmin(s) , pg(s) - r*(xmax(s) - xmin(s)));
        
        xmax(s) = min(xmax(s) , pg(s) + r*(xmax(s) - xmin(s)));
        
    end
    
    x(1:Nbest, :) = x(index(1:Nbest),:);
    
    for i=(Nbest+1):N

        for j=1:D

            x(i,j)= xmin(j) + rand*(xmax(j) - xmin(j));  %随机初始化位置

            v(i,j)= randn;  %随机初始化速度

        end

    end
    
    Pbest(t)=fitness(pg);
    
    for i=1:N

        if fitness(x(i,:))<p(i)

            p(i)=fitness(x(i,:));

            y(i,:)=x(i,:);
            
        end


        if p(i)<fitness(pg)

            pg=y(i,:);

        end
        
    end

end

xm = pg';

fv = fitness(pg);

LinWPSO.m

function [xm,fv] = LinWPSO(fitness,N,c1,c2,wmax,wmin,M,D)
format long;

%------初始化种群的个体------------

for i=1:N

    for j=1:D

        x(i,j)=randn;  %随机初始化位置

        v(i,j)=randn;  %随机初始化速度

    end

end

%------先计算各个粒子的适应度,初始化Pi和Pg----------------------

for i=1:N

    p(i)=fitness(x(i,:));

    y(i,:)=x(i,:);

end

pg=x(N,:);             %Pg为全局最优

for i=1:(N-1)

    if fitness(x(i,:))<fitness(pg)

        pg=x(i,:);

    end

end

%------进入主要循环,按照公式依次迭代------------

for t=1:M

    for i=1:N

        w = wmax - (t-1)*(wmax-wmin)/(M-1);
        
        v(i,:)=w*v(i,:)+c1*rand*(y(i,:)-x(i,:))+c2*rand*(pg-x(i,:));

        x(i,:)=x(i,:)+v(i,:);

        if fitness(x(i,:))<p(i)

            p(i)=fitness(x(i,:));

            y(i,:)=x(i,:);

        end

        if p(i)<fitness(pg)

            pg=y(i,:);

        end

    end

    Pbest(t)=fitness(pg);
end
xm = pg';
fv = fitness(pg);

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1062370.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Visual Studio Code 安裝

一、Visual Studio Code 安裝 VS Code 下载地址&#xff1a;https://code.visualstudio.com/ windows系统的快速下载地址&#xff1a;https://vscode.cdn.azure.cn/stable/441438abd1ac652551dbe4d408dfcec8a499b8bf/VSCodeUserSetup-x64-1.75.1.exe macOS系统的快速下载地址…

最短路径专题6 最短路径-多路径

题目&#xff1a; 样例&#xff1a; 输入 4 5 0 2 0 1 2 0 2 5 0 3 1 1 2 1 3 2 2 输出 2 0->1->2 0->3->2 思路&#xff1a; 根据题意&#xff0c;最短路模板还是少不了的&#xff0c; 我们要添加的是&#xff0c; 记录各个结点有多少个上一个结点走动得来的…

即时通讯软件

通信协议 发送消息可以是个struct 客户端分两个线程&#xff1a;读取服务器&#xff0c;给服务器发&#xff08;否则会导致阻塞&#xff09; read和write的第二个参数类型是&#xff1a;void *buf——————不仅仅是一个字符串&#xff0c;也可以是一个结构体等等&#xf…

【进程管理】初识进程

一.何为进程 教材一般会给出这样的答案: 运行起来的程序 或者 内存中的程序 这样说太抽象了&#xff0c;那我问程序和进程有什么区别呢&#xff1f;诶&#xff1f;这我知道&#xff0c;书上说&#xff0c;动态的叫进程&#xff0c;静态的叫程序。那么静态和动态又是什么意思…

JAVA面经整理(8)

一)为什么要有区&#xff0c;段&#xff0c;页&#xff1f; 1)页是内存和磁盘之间交互的基本单位内存中的值修改之后刷到磁盘的时候还是以页为单位的索引结构给程序员提供了高效的索引实现方式&#xff0c;不过索引信息以及数据记录都是记录在文件上面的&#xff0c;确切来说是…

buuctf-[GXYCTF2019]禁止套娃 git泄露,无参数rce

用dirsearch扫一下&#xff0c;看到flag.php 访问一下没啥东西&#xff0c;使用githack python2 GitHack.py http://8996e81f-a75c-4180-b0ad-226d97ba61b2.node4.buuoj.cn/.git/查看index.php <?php include "flag.php"; echo "flag在哪里呢&#xff1f;…

【Jmeter】性能测试脚本开发——性能测试环境准备、Jmeter脚本编写和执行

文章目录 一、常用的Jmeter元件二、性能测试环境准备三、编写Jmeter脚本四、执行测试脚本 一、常用的Jmeter元件 取样器-HTTP请求 作用&#xff1a;发送HTTP请求配置原件-HTTP请求默认值 作用&#xff1a;设置HTTP请求的默认参数配置原件-用户定义的变量 作用&#xff1a;定义…

在win10里顺利安装了apache2.4.41和php7.4.29

最近在学习网站搭建。其中有一项内容是在windows操作系统里搭建apachephp环境。几天前根据一本书的上的说明尝试了一下&#xff0c;在win10操作系统里安装这两个软件&#xff1a;apache2.4.41和php7.4.29&#xff0c;安装以后apche能正常启动&#xff0c;但是php没有正常工作。…

深入探讨前后端之争:揭秘Go语言在未来全栈Web开发中的关键角色与价值

&#x1f337;&#x1f341; 博主猫头虎&#x1f405;&#x1f43e; 带您进入 Golang 语言的新世界✨✨&#x1f341; &#x1f984; 博客首页——&#x1f405;&#x1f43e;猫头虎的博客&#x1f390; &#x1f433; 《面试题大全专栏》 &#x1f995; 文章图文并茂&#x1f…

【计算机组成原理】考研真题攻克与重点知识点剖析 - 第 2 篇:数据的表示和运算

前言 本文基础知识部分来自于b站&#xff1a;分享笔记的好人儿的思维导图与王道考研课程&#xff0c;感谢大佬的开源精神&#xff0c;习题来自老师划的重点以及考研真题。此前我尝试了完全使用Python或是结合大语言模型对考研真题进行数据清洗与可视化分析&#xff0c;本人技术…

Nginx搭建Rtmp流媒体服务,并使用Ffmpeg推流

文章目录 1.rtmp流媒体服务框架图2.nginx配置3.配置nginx4.使用ffmpeg推流5.实时推摄像头流 本项目在开发板上使用nginx搭建流媒体服务&#xff0c;利用ffmpeg进行推流&#xff0c;在pc上使用vlc media进行拉流播放。 1.rtmp流媒体服务框架图 2.nginx配置 下载&#xff1a;wge…

C++(STL容器适配器)

前言&#xff1a; 适配器也称配接器&#xff08;adapters&#xff09;在STL组件的灵活组合运用功能上&#xff0c;扮演着轴承、转换器的角色。 《Design Patterns》对adapter的定义如下&#xff1a;将一个class的接口转换为另一个class的接口&#xff0c;使原本因接口不兼容而…

2023年R1快开门式压力容器操作证模拟考试题库及R1快开门式压力容器操作理论考试试题

题库来源&#xff1a;安全生产模拟考试一点通公众号小程序 2023年R1快开门式压力容器操作证模拟考试题库及R1快开门式压力容器操作理论考试试题是由安全生产模拟考试一点通提供&#xff0c;R1快开门式压力容器操作证模拟考试题库是根据R1快开门式压力容器操作最新版教材&#…

6.Tensors For Beginners-What are Convector

Covectors &#xff08;协向量&#xff09; What‘s a covector Covectors are “basically” Row Vectors 在一定程度上&#xff0c;可认为 协向量 基本上就像 行向量。 但不能简单地认为 这就是列向量进行转置&#xff01; 行向量 和 列向量 是根本不同类型的对象。 …

026 - STM32学习笔记 - 液晶屏控制(三) - DMA2D快速绘制矩形、直线

026- STM32学习笔记 - 液晶屏控制&#xff08;三&#xff09; - DMA2D快速绘制矩形、直线等 上节直接操作LTDC在先视频上直接显示&#xff0c;我们直接操作显存地址空间中的内容&#xff0c;用来显示图形&#xff0c;但是相对来说&#xff0c;这种方法费时费力&#xff0c;这节…

矩阵的c++实现(2)

上一次我们了解了矩阵的运算和如何使用矩阵解决斐波那契数列&#xff0c;这一次我们多看看例题&#xff0c;了解什么情况下用矩阵比较合适。 先看例题 1.洛谷P1939 【模板】矩阵加速&#xff08;数列&#xff09; 模板题应该很简单。 补&#xff1a;1<n<10^9 10^9肯定…

进程调度算法之时间片轮转调度(RR),优先级调度以及多级反馈队列调度

1.时间片轮转调度算法(RR) round Robin 1.算法思想 公平地、轮流地为各个进程服务&#xff0c;让每个进程在一定时间间隔内都可以得到响应。 2.算法规则 按照各进程到达就绪队列的顺序&#xff0c;轮流让各个进程执行一个时间片&#xff08;如100ms&#xff09;。 若进程未…

项目_游戏|外星人入侵

导入pygame&#xff0c;设定游戏屏幕&#xff08;大小、颜色&#xff09;&#xff0c;及游戏循环、退出机制 创建设置类 导入ship&#xff0c;绘制飞船 图灵官网&#xff0c;源代码文件没法下载&#xff0c;从网上找图片&#xff0c;更改尺寸及后缀&#xff0c;存入文件导入。 …

JS-前端在dom中预览pdf等文件

1、将pdf等文件显示到dom元素中预览 pdf文件可以是blob、url、file类型等只要使用URL.createObjectURL(file)全部转为URL即可使用无需借助任何插件&#xff0c;只需要使用<object></object>标签即可实现 1.1、html <template><div class"home"…

【数据结构与算法】树、二叉树的概念及结构(详解)

前言: &#x1f4a5;&#x1f388;个人主页:​​​​​​Dream_Chaser&#xff5e; &#x1f388;&#x1f4a5; ✨✨专栏:http://t.csdn.cn/oXkBa ⛳⛳本篇内容:c语言数据结构--树以及二叉树的概念与结构 目录 一.树概念及结构 1.树的概念 1.1树与非树 树的特点&#xff1…