目录

1.算法描述

2.仿真效果预览

3.MATLAB核心程序

4.完整MATLAB


1.算法描述

粒子群优化算法(PSO),粒子群中的每一个粒子都代表一个问题的可能解, 通过粒子个体的简单行为,群体内的信息交互实现问题求解的智能性。

在求解TSP这种整数规划问题的时候, PSO显然与ACO不同, PSO需要对算法本身进行一定的修改, 毕竟PSO刚开始是应用在求解连续优化问题上的.

    在路径规划中,我们将每一条路径规划为一个粒子,每个粒子群群有 n 个粒 子,即有 n 条路径,同时,每个粒子又有 m 个染色体,即中间过渡点的个数,每 个点(染色体)又有两个维度(x,y),在代码中用 posx 和 posy 表示一个种群。 通过每一代的演化,对粒子群进行演化操作,选择合适个体(最优路径)。

最终算法伪代码如下:

初始化: 每个粒子获得一个随机解和一个随机的SS (命名为速度)

For 在位置 X_{id} 的所有粒子, 计算新的位置 X_{id}':

计算 P_{id} 与 X_{id} 之间的差 A = P_{id} - X_{id}, 其中 A 为 BSS

计算 B = P_{gd} - X_{id}, 其中 B 为 BSS

根据速度更新公式计算新的速度 V_{id}', 并将 V_{id}' 转换为一个 BSS

计算新的解 X_{id}' = X_{id} + V_{id} (也就是 V_{id} 作用在 X_{id} 上)

更新 P_{id} 如果新的解更好

更新 P_{gd} 若出现新的全局最好的解

PSO初始化为一群随机粒子(随机解)。然后通过迭代找到最优解。在每一次迭代中,粒子通过跟踪两个“极值(pbest和gbest)”来更新自己。在找到这两个最优值后,粒子通过下面的公式来更新自己的速度和位置。

2.仿真效果预览

matlab2022a仿真结果如下:

3.MATLAB核心程序


%% 产生初始粒子和速度
for i=1:sizepop%随机产生一个种群pop(i,:)=init+range*rand(1,n);    %初始种群V(i,:)=rand(1,n);  %初始化速度%计算适应度fitness(i)=Rastrigrin(pop(i,:));   %染色体的适应度
end%% 个体极值和群体极值
[bestfitness bestindex]=min(fitness);
zbest=pop(bestindex,:);   %全局最佳
gbest=pop;    %个体最佳
fitnessgbest=fitness;   %个体最佳适应度值
fitnesszbest=bestfitness;   %全局最佳适应度值%% 迭代寻优
for i=1:maxgenind_1=ind;factor=calfactor(pop,sizepop,zbest);if i==1ind_1=1;endind=fuzzyclassification(factor,ind_1);if ind==1c1=c1+unifrnd(0.05,0.1);c2=c2-unifrnd(0.05,0.1);elseif ind==2c1=c1+0.5*unifrnd(0.05,0.1);c2=c2-0.5*unifrnd(0.05,0.1);elseif ind==3c1=c1+0.5*unifrnd(0.05,0.1);c2=c2+0.5*unifrnd(0.05,0.1);p=zbest;d=unidrnd(n);p(d)=p(d)+(popmax-popmin)*normrnd(0,sig^2);p(find(p(:)>popmax))=popmax;p(find(p(:)<popmin))=popmin;cv=Rastrigrin(p);if cv<fitnesszbestzbest=p;else[aa,bb]=max(fitness);pop(bb,:)=p;endelsec1=c1-unifrnd(0.05,0.1);c2=c2+unifrnd(0.05,0.1);endw=1/(1+1.5*exp(-2.6*factor));if c1<1.5c1=1.5;elseif c1>2.5c1=2.5;endif c2<1.5c2=1.5;elseif c2>2.5c2=2.5;endcrange=c1+c2;c1=(c1/crange)*4;c2=(c2/crange)*4;sig=sigmax-(sigmax-sigmin)*(i/maxgen);for j=1:sizepop  %速度更新V(j,:) = w*V(j,:) + c1*rand*(gbest(j,:) - pop(j,:)) + c2*rand*(zbest - pop(j,:));V(j,find(V(j,:)>Vmax))=Vmax;V(j,find(V(j,:)<Vmin))=Vmin;%种群更新pop(j,:)=pop(j,:)+V(j,:);pop(j,find(pop(j,:)>popmax))=popmax;pop(j,find(pop(j,:)<popmin))=popmin;%适应度值fitness(j)=Rastrigrin(pop(j,:));endfor j=1:sizepop%个体最优更新if fitness(j) < fitnessgbest(j)gbest(j,:) = pop(j,:);fitnessgbest(j) = fitness(j);end%群体最优更新if fitness(j) < fitnesszbestzbest = pop(j,:);fitnesszbest = fitness(j);endendyy(i)=fitnesszbest;end
A195

4.完整MATLAB

V

基于matlab的自适应PSO优化算法仿真相关推荐

  1. 【MATLAB】自适应果蝇优化算法整定PID控制器参数(六)—— 一阶带时延的被控对象

    [MATLAB]自适应果蝇优化算法整定PID控制器参数(六)-- 一阶带时延的被控对象 目录 [MATLAB]自适应果蝇优化算法整定PID控制器参数(六)-- 一阶带时延的被控对象 0研究背景 1自适 ...

  2. matlab 压缩感知矩阵_【精读】基于MATLAB的钢筋下料优化算法

    基于MATLAB的钢筋下料优化算法 摘要:运用MATLAB软件求解实际工程中一维钢筋下料优化的问题,提出了首先列举出单根原料分割的所有可行解,其次采用线性规划的方法求出理想条件下最优方案,最后通过整数 ...

  3. 基于matlab的信号能量检测算法仿真

    能量检测方法,即将接收到的模拟信号变为数字信号后,通过FFT变换,然后再进行,在现有的通信系统中,通常为ASK.PSK.FSK.QAM等,它们都由数字基带脉冲对周期性载波的参数进行调制.采样频率fs ...

  4. 基于MATLAB的LTEA载波聚合算法仿真

    目录 一.理论基础 二.案例背景 1.问题描述 2.思路流程 三.部分MATLAB仿真 四.仿真结论分析 五.参考文献 一.理论基础 在非连续载波聚合( 高频+低频) 场景下,载波衰减特性不同,聚合的 ...

  5. 基于matlab的GPS信号相关检测算法仿真

    目录 1.算法描述 2.仿真效果预览 3.MATLAB核心程序 4.完整MATLAB 1.算法描述 全球定位系统(Global Positioning System,GPS),是一种以人造地球卫星为基 ...

  6. 基于matlab的图像HOG特征提取算法仿真

    目录 1.算法概述 2.仿真效果 3.MATLAB仿真源码 1.算法概述 方向梯度直方图(Histogram of Oriented Gradient, HOG)特征是一种在计算机视觉和图像处理中用来 ...

  7. 基于matlab的立体图像编码解码算法仿真与分析

    欢迎订阅<FPGA学习入门100例教程>.<MATLAB学习入门100例教程> 目录 一.理论基础 二.核心程序 2.1 获得左右两个图像

  8. 【中继功率分配】基于MATLAB的中继功率分配算法仿真

    1.软件版本 matlab2013b 2.本算法理论知识

  9. matlab代码:基于粒子群算法的智能微电网经济运行优化 智能微电网PSO优化算法

    matlab代码:基于粒子群算法的智能微电网经济运行优化 智能微电网PSO优化算法 基于时段电价差异,制定合理的储能系统充放电运行方式,优化各时段微电网与主网之间的交换功率,从而使得风光储微网系统综合 ...

最新文章

  1. COM Surrogate 遇到问题需要关闭。我们对此引起的不便表示抱歉
  2. ZeroMQ接口函数之 :zmq_ctx_shutdown - 停止一个ZMQ context
  3. 538B. Quasi Binary
  4. python定时器的使用方法_Python timer定时器两种常用方法解析
  5. matlab 上穿,Matlab混入模式(Mixin)
  6. SDAutoLayout 一行代码搞定自动布局
  7. 使用 IntraWeb (26) - 基本控件之 TIWMenu
  8. android百度地图单点定位_Android百度地图实现搜索和定位及自定义图标绘制并点击时弹出泡泡...
  9. Json Formatter 1.0 Json格式化工具
  10. python opencv 识别角度_opencv python 角点检测/FAST算法
  11. OpenSSL解析X509证书
  12. 霍尔传感器的工作原理、分类及应用
  13. npm i --legacy-peer-deps
  14. APM32F103C8T6兼容性测试
  15. 游吟诗人之中二病犯了
  16. LiteOS + PahoMQTT 连接华为云
  17. 【单片机仿真项目】数码管(proteus原理图+keil代码)
  18. 济宁中考计算机考试试题,济宁市初中信息技术考试模拟题-1.doc
  19. 东北电力大学计算机学院教务处,2020年东北电力大学计算机学院初试
  20. 利用Arcpy批量图斑生成图片

热门文章

  1. 基于MFC的时间日期实例应用讲解
  2. 提取360安全卫士中的360手机助手(绿色化)
  3. css font-family常用字体中英文对照表
  4. .java文件出现小闹钟
  5. 做真正的自己,to be the truthful yourself
  6. 2022-2027年中国益智玩具行业市场深度分析及投资战略规划报告
  7. 修改html中meta标签,利用JS或JQuery修改网页title和meta标签的content内容
  8. Vue实现计数器的学习笔记
  9. 阿里面试题,说说Java 类加载机制
  10. Machine learning(ML)常用的几类学习器及Python实现