粒子群优化算法及MATLAB实现

article/2025/10/6 11:13:56

上一篇博客是关于蚁群优化算法的,有兴趣的可以看下
https://blog.csdn.net/HuangChen666/article/details/115913181
1. 粒子群优化算法概述
2. 粒子群优化算法求解
     2.1 连续解空间问题
     2.2 构成要素
     2.3 算法过程描述
     2.4 粒子速度更新公式
     2.5 速度更新参数分析
3. 粒子群优化算法小结
4. MATLAB代码

1. 粒子群优化算法概述

粒子群优化算法是一种基于 种群寻优的启发式搜索算法。在1995年由Kennedy和Eberhart首先提出来的。
它的主要启发来源于对 鸟群群体运动行为的研究。我们经常可以观察到鸟群表现出来的同步性,虽然每只鸟的运动行为都是互相 独立的,但是在整个鸟群的飞行过程中却表现出了高度一致性的复杂行为,并且可以自适应的调整飞行的状态和轨迹。
鸟群具有这样的复杂飞行行为的原因,可能是因为每只鸟在飞行过程中都遵循了一定的行为规则,并能够掌握邻域内其它鸟的飞行信息。
粒子群优化算法借鉴了这样的思想,每个粒子代表待求解问题搜索解空间中的一一个潜在解,它相当于一只飞行信息”包括粒子当前的 位置和速度两个状态量。
每个粒子都可以获得其邻域内其它个体的信息,对所经过的位置进行评价,井根据这些 信息和位置速度更新规则,改变自身的两个状态量,在“飞行”过程中传递信息和宣相学习,去更好地适应环境。随着这一过程的不断进行,粒子群最终能够找到问题的近似最优解。

2. 粒子群优化算法求解

粒子群优化算法一般适合解决连续解空间的问题,比如通过粒子群在解空间里进行搜索,找出极大值。

在这里插入图片描述

2.1 连续解空间问题

上图就是一个典型的粒子群优化算法求解极值的案例,可以看到初始时有四个粒子,求解过程可以理解为四个粒子不断向最大的粒子靠拢,在靠拢的过程中不断更新自身的最大值和整体的最大值,在自身最大值和整体最大值的影响下改变自身移动的速度,最终所有粒子均达到同一个极值的过程。

2.2 构成要素

1、粒子群

  • 每个粒子对应所求解问题的一个可行解
    即每个粒子本身就是一个可行解

  • 粒子通过其位置和速度表示
    在代码中的粒子用位置和速度表示,即横坐标表示粒子的位置,速度表示粒子接下来的运动趋势。
    x n ( i ) x_n^{(i)} xn(i) 表示粒子 i 在第 n 轮的位置
    v n ( i ) v_n^{(i)} vn(i) 表示粒子 i 在第 n 轮的速度

2、记录

  • p b e s t ( i ) p_{best}^{(i)} pbest(i) 表示粒子 i 的历史最好位置
  • g b e s t ( i ) g_{best}^{(i)} gbest(i) 表示全局历史最好位置

3、计算适应度的函数

  • 适应度: f ( x ) f(x) f(x) 即函数表达式

2.3 算法过程描述

1、初始化
  • 初始化粒子群:每个粒子的位置和速度,位置即每个粒子的初始 x x x 坐标,速度表示该粒子下一轮中 x x x 坐标的变化值,可正可负,即 x 0 ( i ) x_0^{(i)} x0(i) v 0 ( i ) v_0^{(i)} v0(i)
  • 初始化粒子 i 的历史最好位置 p b e s t ( i ) p_{best}^{(i)} pbest(i) 和全局粒子历史最好位置 g b e s t ( i ) g_{best}^{(i)} gbest(i) p b e s t ( i ) p_{best}^{(i)} pbest(i)的初始值使用随机数赋值, g b e s t ( i ) g_{best}^{(i)} gbest(i)设置为一个无穷小值(因为这里以求最大值为例)

2、循环执行如下三步直至满足结束条件

  • 计算每个粒子的适应度(即函数值): f ( x n ( i ) ) f(x_n^{(i)}) f(xn(i))
  • 更新每个粒子历史最好适应度及其相应的位置,更新当前全局最好适应度及其相应的位置
  • 更新每个粒子的速度和位置
    在这里插入图片描述
    粒子位置的更新即对每个粒子所在x轴的横坐标进行更新(其实每个粒子就是一个横坐标上的数),下一轮的位置等于上一轮的位置加上速度的变化乘以一个单位时间,所以这里的乘以1没有写出来。

2.4 粒子速度更新公式解读

在这里插入图片描述
在这里插入图片描述
从公式可以看出粒子下一轮的速度 = 粒子上一轮的速度 + 回到自己历史最好位置的倾向 + 去向全局最好位置的倾向,即惯性项+记忆项+社会项。
一般情况下确定了一个变量和其他变量的关系,下面就是参数的设置了,这里有两对参数 c k 和 r k c_k和r_k ckrk c k c_k ck 是权重参数,一般取值为2,实际上它影响了优化的速度, r k r_k rk 是随机参数,即0和1之间的随机数。

2.5 速度更新参数分析

在这里插入图片描述
权重参数主要是影响了粒子飞行的速度,在今后的使用中一般设置 c 1 和 c 2 c_1和c_2 c1c2相等的情况较多。

3. 粒子群优化算法改进

随着粒子群算法的广泛使用,人们发现如果加入一个惯性权重的话,优化的效果更好。
在这里插入图片描述
引入了一个 w w w 参数,控制先前粒子速度对下一轮粒子速度的影响,以适应不同场景。

4. MATLAB代码

求f= xsin(x)cos(2x) - 2xsin(3x)在[0,20]上的最大值
在这里插入图片描述
因为这里是多峰,所以设置权重参数c2>c1效果会更好。
代码借鉴 https://www.pianshen.com/article/2364328713/

clc;clear;
%% 初始化参数
f= @(x)x .* sin(x) .* cos(2 * x) - 2 * x .* sin(3 * x);
pnum=50;            %粒子个数
iter=100;           %迭代次数
w=0.8;              %惯性权重
c1=0.8;             %权重参数c1
c2=1.2;             %权重参数c2
xlimit=[0,20];      %位置限制
vlimit=[-1,1];      %速度限制
figure(1);ezplot(f,[xlimit(1),0.01,xlimit(2)]);
Px=((xlimit(2)-xlimit(1))*rand(pnum,1))+xlimit(1);      %随机产生粒子的初始位置
Pbest=Px;                       %粒子i历史上的最好位置
Gbest=[-inf,-inf];              %全局历史上的最好位置
Pymax=ones(pnum,1)/-eps;        %粒子i历史上的最大值
Pymin=ones(pnum,1)/eps;         %粒子i历史上的最小值
Pv=zeros(pnum,1);               %初始化粒子速度
Py=f(Px);                      %计算粒子适应度
hold on;
plot(Px, Py, 'ro');title('初始状态图');
figure(2);
max_record=zeros(pnum,1);
%% 迭代求解
for i=1:iterPy=f(Px);          %计算粒子适应度%更新Pbest和Gbest,粒子位置for j=1:pnumif Py(j)>Pymax(j)Pymax(j)=Py(j);Pbest(j)=Px(j);endend% 全局最好的位置if Gbest(1)<max(Pymax)[Gbest(1),max_index]=max(Pymax);Gbest(2)=Pbest(max_index);endmax_record(i)=Gbest(1);% 更新速度和位置Pv=Pv*w+c1*rand*(Pbest-Px)+c2*rand*(repmat(Gbest(2),pnum,1)-Px);Pv(Pv>vlimit(2))=vlimit(2);Pv(Pv<vlimit(1))=vlimit(1);Px=Px+Pv;Px(Px>xlimit(2))=xlimit(2);Px(Px<xlimit(1))=xlimit(1);x0 =xlimit(1):0.01:xlimit(2);plot(x0, f(x0), 'b-', Px, f(Px), 'ro');title('状态位置变化')pause(0.1);
end%% 得出结果
figure(3);plot(max_record);title('收敛过程');
disp(['最大值:',num2str(Gbest(1))]);
disp(['最大位置:',num2str(Gbest(2))]);

http://chatgpt.dhexx.cn/article/EpU0F3FZ.shtml

相关文章

粒子群优化算法(PSO)python实践

1 算法介绍和原理 1.1 算法原理 强烈推荐知乎大佬的这篇文章&#xff1a;粒子群优化算法(Particle Swarm Optimization, PSO)的详细解读 - 知乎 (zhihu.com)。该文章详细介绍了算法的原理、算法流程、参数解释和一些Tips&#xff0c;这里就不过多赘述了。 粒子群优化算法&am…

粒子群优化算法python实现

文章目录 前言一、粒子群优化算法是什么&#xff1f;二、算法流程三、算法的python实现实验结果 前言 首先简单介绍粒子群优化算法&#xff0c;粒子群优化算法的python实现&#xff08;含代码&#xff09; 一、粒子群优化算法是什么&#xff1f; 粒子群优化算法(Particle Swa…

【优化算法】粒子群优化算法简介

这里是引用 文章目录 1. 简介2. 涌现复杂性3. 鸟群智能建模4. 代码实现5. Conclusion参考资料 1. 简介 人工智能是计算机科学的一个大领域&#xff0c;它模拟计算机中的智能行为。在此基础上&#xff0c;提出了一种基于元启发式&#xff08; metaheuristic&#xff09;的粒子群…

粒子群优化算法(Particle Swarm Optimization)

转自&#xff1a;https://www.cnblogs.com/21207-iHome/p/6062535.html 粒子群算法的思想源于对鸟/鱼群捕食行为的研究&#xff0c;模拟鸟集群飞行觅食的行为&#xff0c;鸟之间通过集体的协作使群体达到最优目的&#xff0c;是一种基于Swarm Intelligence的优化方法。它没有遗…

粒子群优化(PSO)算法

一.算法思想 粒子群算法( Particle Swarm Optimization, PSO)最早是由Eberhart和Kennedy于1995年提出,它的基本概念源于对鸟群觅食行为的研究。设想这样一个场景:一群鸟在随机搜寻食物,在这个区域里只有一块食物,所有的鸟都不知道食物在哪里,但是它们知道当前的位置离食…

智能优化算法——粒子群优化算法(PSO)(小白也能看懂)

前言&#xff1a; 本文主要参考B站的一篇学习视频后&#xff0c;加之自己的理解和浓缩精华&#xff0c;不想看文字的可以直接划到末尾去b站看原视频&#xff0c;非常通俗易懂。 理论知识&#xff1a; 感性认知&#xff1a;如下面一张图片所示。在一个范围内&#xff0c;以三…

智能算法系列之粒子群优化算法

本博客封面由ChatGPT DALLE 2共同创作而成。 文章目录 前言1. 算法思想2. 细节梳理2.1 超参数的选择2.2 一些trick 3. 算法实现3.1 问题场景3.2 python实现 代码仓库&#xff1a;IALib[GitHub] 前言 本篇是智能算法(Python复现)专栏的第三篇文章&#xff0c;主要介绍粒子群优化…

粒子群优化算法(PSO)

粒子群优化算法&#xff08;PSO&#xff09; 粒子群优化算法&#xff08;PSO&#xff09;是一种进化计算技术&#xff0c;源于对鸟群捕食行为的研究。该算法最初是受到飞鸟集群活动的规律性启发&#xff0c;进而利用群体智能建立的一个简化模型。粒子群算法在对动物及群活动行…

数学建模——粒子群优化算法(PSO)【有详细样例 + 工具:matlab】(万字总结)

文章目录 一、粒子群优化算法(PSO)是什么&#xff1f;二、粒子群优化算法有什么用&#xff1f;三、粒子群优化算法的适用范围&#xff1f;四、算法简介(有助于理解)五、算法流程第一步&#xff1a;初始化第二步&#xff1a;计算粒子的适应度第三步&#xff1a;更新个体极值与全…

粒子群优化算法(PSO)附代码

文章目录 1 算法介绍2 算法模型3 实现步骤4 MATLAB代码实现PSO算法4.1. main.m4.2. 运行结果 1 算法介绍 粒子群优化算法(Particle Swarm Optimization&#xff0c;PSO)是一种经典的群智能算法&#xff0c;该算法灵感源自于鸟类飞行和觅食的社会活动&#xff0c;鸟群通过个体之…

浏览器添加划词翻译插件

网站&#xff1a;https://github.com/Selection-Translator/crx-selection-translate 安装下载的扩展程序

Chrome划词翻译-Saladict

Saladict 沙拉查词是一款专业划词翻译扩展&#xff0c;为交叉阅读而生。大量权威词典涵盖中英日韩法德西语&#xff0c;支持复杂的 划词操作、网页翻译、生词本、PDF&#xff0c;以及 Vimium 全键盘操作 。 迄今为止最好用的网页划词翻译插件。 下载安装地址&#xff1a;Chrome…

谷歌划词翻译

谷歌划词翻译是个谷歌插件 复制及时翻译很好用 插件下载地址 配置谷歌翻译方法

惊了,MATLAB竟能制作如此方便的划词翻译工具???

我点开程序一看&#xff0c;程序第一行就写着import&#xff0c; 却歪歪斜斜的每行上都是着MATLAB几个大字。 我横竖睡不着&#xff0c;仔细看了半夜&#xff0c; 才从字缝里看出字来&#xff0c;满页都写着 ⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀——Java 其实用的…

python实现划词翻译

最近因为编程&#xff0c;需要大量地看一些说明文档&#xff0c;无奈说明文档都是英文的&#xff0c;可把我这个半桶水折腾死了&#xff0c;太多词汇不知道&#xff0c;一个个复制翻译太麻烦了。于是我根据自己的需要&#xff0c;用python写了一个划词翻译。 一&#xff1a;使…

划词翻译简单实现

环境&#xff1a;archlinux &#xff0c;其余linux系统类似 安装依赖 sudo pacman -S xsel sudo pacman -S translate-shell sudo pacman -S libnotify脚本书写 创建脚本 touch word_translate.sh chmod x word_translate.sh vim word_tranlate.sh#!/bin/bashwhile true; d…

Chrome划词插件-有道词典

当我们在阅读文章&#xff0c;查找资料或者查看英文文献时&#xff0c;经常会遇到不认识的英文单词&#xff0c;这时&#xff0c;我们往往会复制单词百度一下才行。 其实&#xff0c;遇到这种情况&#xff0c;我们可以直接下载一个有道词典的Chrome划词插件&#xff0c;遇到需…

PDF划词翻译插件

PDF划词翻译插件 1、打开一个拓展插件的下载网站2、下载沙拉查词并安装3、进入详情&#xff0c;设置为允许打开文件网址4、固定她5、打开她的设置最终划词结果 1、打开一个拓展插件的下载网站 点击此网站地址 2、下载沙拉查词并安装 打开开发者模式&#xff0c;把下载好的.cr…

福昕pdf阅读器的划词翻译功能如何添加(图文并茂)

一、打开福昕阅读器 二、可在上方工具栏&#xff0c;点击“帮助”&#xff0c;关于福昕阅读器领鲜版查看安装的版本信息&#xff0c;如图1-1&#xff0c;图1-2 图1-1 图1-2 三、找到上方工具栏的图标按键&#xff0c;名为“自定义快速访问工具栏”&#xff0c;如图1-3&#…

谷歌浏览器无法翻译成中文,谷歌翻译,最新(沉浸式翻译和划词翻译,chrome无法翻译,谷歌浏览器无法翻译此网页)

简介&#xff1a;谷歌浏览器自带的翻译功能&#xff0c;对我们来说用处很大&#xff0c;但有的时候突然就会变成“无法翻译此网页”&#xff0c;之前给大家提供过两种无法翻译此网页的解决方案&#xff0c;这次再给大家分享下两款别的翻译方法&#xff1b; 一、上次介绍&#x…