pso算法源代码matlab_MATLAB粒子群(PSO)优化算法程序集合

本文介绍了MATLAB中粒子群优化算法(PSO)的实现,包括初始化粒子群、单步更新位置速度的函数以及完整的PSO算法过程。通过模拟鸟群寻找食物的过程,寻找函数y=1-cos(3*x)*exp(-x)在[0,4]的最大值,展示了PSO算法如何逐步收敛找到最优解。文章提供了相关的MATLAB代码示例和适应度函数。" 130858722,18870241,Python segy:海洋勘探数据处理利器,"['Python', '开发语言', '地球物理', '数据处理', 'segy']
摘要由CSDN通过智能技术生成

点击上方蓝字关注“公众号”

703dcc23577112397ff71f94eccc4d06.gif

MATLAB粒子群(PSO)优化算法程序集合

PSO算法就是模拟一群鸟寻找食物的过程,每个鸟就是PSO中的粒子,也就是我们需要求解问题的可能解,这些鸟在寻找食物的过程中,不停改变自己在空中飞行的位置与速度。大家也可以观察一下,鸟群在寻找食物的过程中,开始鸟群比较分散,逐渐这些鸟就会聚成一群,这个群忽高忽低、忽左忽右,直到最后找到食物。这个过程我们转化为一个数学问题。寻找函数y=1-cos(3*x)*exp(-x)的在[0,4]最大值。该函数的图形如下:

4429c29c006e15fa39aabff4567e6412.png

d0fb074de660282357c8fc1265c4e827.gif

在交错并联变换器的设计中,若想得到优良的纹波特性和响应功能,各支路的交错触发脉冲需设计合理。

当x=0.9350-0.9450,达到最大值y=1.3706。为了得到该函数的最大值,我们在[0,4]之间随机的洒一些点,为了演示,我们放置两个点,并且计算这两个点的函数值,同时给这两个点设置在[0,4]之间的一个速度。下面这些点就会按照一定的公式更改自己的位置,到达新位置后,再计算这两个点的值,然后再按照一定的公式更新自己的位置。直到最后在y=1.3706这个点停止自己的更新。这个过程与粒子群算法作为对照如下:

这两个点就是粒子群算法中的粒子。该函数的最大值就是鸟群中的食物,计算两个点函数值就是粒子群算法中的适应值,计算用的函数就是粒子群算法中的适应度函数。更新自己位置的一定公式就是粒子群算法中的位置速度更新公式。下面演示一下这个算法运行一次的大概过程:

第一次初始化

6c64ec8a3539f4327168756ee721d353.png

第一次更新位置

a0fc0cf3c904e387e1a31e184b09f202.png

最后的结果(30次迭代)

a59660e30468340d8a00dab94bef01b8.png

最后所有的点都集中在最大值的地方。

8600d3d0e816db5783bdfc5552d59384.gif c759887cfe67cdf9ef0d0283dfa55431.png 8cd711543cac3d9bd63a889a54c6bc8f.png

01

标准粒子群算法的实现

主要分为3个函数。

第一个函数为粒子群初始化函数:

InitSwarm(SwarmSize......AdaptFunc)其主要作用是初始化粒子群的粒子,并设定粒子的速度、位置在一定的范围内。本函数所采用的数据结构如下所示:

表ParSwarm记录的是粒子的位置、速度与当前的适应度值,我们用W来表示位置,用V来代表速度,用F来代表当前的适应度值。在这里我们假设粒子个数为N,每个粒子的维数为D。

4bc41ee375ee861410e13fbdab58fb03.png

表OptSwarm记录每个粒子的历史最优解(粒子历史最好的适应度)以及全部粒子搜索到的全局最优解。用Wg代表全局最优解,W.,1代表每个粒子的历史最优解。粒子群初始化阶段表OptSwarm的前N行与表ParSwarm中的相同,而Wg的值为表ParSwarm中适应度值的最大值对应的行。

82d826be140fa8ba398097b0b24f24a4.png

dd24dafc37533c54c127421ca63852a7.gif

01

根据这样的思想MATLAB代码如下:

function [ParSwarm,OptSwarm]=InitSwarm(SwarmSize,ParticleSize,ParticleScope,AdaptFunc)

%功能描述:初始化粒子群,限定粒子群的位置以及速度在指定的范围内

%[ParSwarm,OptSwarm,BadSwarm]=InitSwarm(SwarmSize,ParticleSize,ParticleScope,AdaptFunc)

%

%输入参数:SwarmSize:种群大小的个数

%输入参数:ParticleSize:一个粒子的维数

%输入参数:ParticleScope:一个粒子在运算中各维的范围;

%ParticleScope格式:

%3维粒子的ParticleScope格式:

%[x1Min,x1Max

%x2Min,x2Max

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值