资源简介
基本的粒子群算法,编写的MATLAB的M文件,对于熟悉算法流程有帮助
代码片段和文件信息
function [pso F] = pso_2D()
uav_size=4;
pop_size = 30; % pop_size 种群大小
part_size = 2*uav_size; % part_size 粒子大小
% Value=[0.9 0.8 0.7 0.6];
% p_kill=[0.1 0.1 0.2 0.9;0.8 0.8 0.2 0.1;0.3 0.4 0.5 0.2;0.4 0.9 0.3 0.3]
% Distance=[0.91813 0.56140 0.93860 0.20175;0.16374 0.93860 0.35965 0.35965;0.31579 0.97368 0.20760 0.67544;0.36008 0.75642 0.82016 0.5573]
% p_survial=[0.926 0.906 0.916 0.966;0.306 0.906 0.986 0.926;0.996 0.916 0.256 0.926;0.926 0.936 0.926 0.916]
gbest = zeros(1part_size+1); % gbest 当前搜索到的最小的值
max_gen = 6000; % max_gen 最大迭代次数
arr_present = ini_pos(pop_sizepart_size); % present 当前位置随机初始化rand()的范围为0~1
v=ini_v(pop_sizepart_size); % 初始化当前速度
pbest = zeros(pop_sizepart_size+1); % pbest 粒子以前搜索到的最优值,最后一列包括这些值的适应度
w_max = 0.9; % w_max 权系数最大值
w_min = 0.4;
v_max = 0.2; % **最大速度为粒子的范围宽度
c1 = 2; % 学习因子
c2 = 2; % 学习因子
best_record = zeros(1max_gen); % best_record记录最好的粒子的适应度。
% ————————————————————————
% 计算原始种群的适应度及初始化
% ————————————————————————
arr_present(:end)=ini_fit(arr_presentpop_sizepart_size);
% for k=1:pop_size
% present(kend) = fitness(present(k1:part_size)); %计算原始种群的适应度
% end
pbest = arr_present; %初始化各个粒子最优值
[best_value best_index] = max(arr_present(:end)); %初始化全局最优,即适应度为全局最小的值,根据需要也可以选取为最大值
gbest = arr_present(best_index:);
for i=1:max_gen
w = w_max-(w_max-w_min)*i/max_gen;
for j=1:pop_size
v(j:) = w.*v(j:)+c1.*rand.*(pbest(j1:part_size)-arr_present(j1:part_size))...
+c2.*rand.*(gbest(1:part_size)-arr_present(j1:part_size)); % 粒子速度更新 (a)
v(j:)=round(v(j:));
% c = find(abs(v)>0.2); %**最大速度设置,粒子的范围宽度
% v(c) = sign(v(c))*0.2; %如果速度大于3.14则,速度为3.14
arr_present(j1:part_size)= arr_present(j1:part_size)+v(j1:part_size); % 粒子位置更新 (b)
% arr_present(j1:part_size)=round(arr_present(j1:part_size))
c = find(arr_present>4);
arr_present(c) = 4;
d =
- 上一篇:用于中文分词的中文词库包
- 下一篇:基于Armijo准则的阻尼牛顿法
相关资源
- 粒子群算法优化pid源码 matlab仿真.ra
- pso解决单目标优化问题
- matlab粒子群算法PSO实现函数极值优化
- PSO负载均衡算法-matlab实现
- l粒子群算法工具箱psot
- PSO_LSSVM程序代码及LSSVM工具箱
- libsvm-3.1-[FarutoUltimate3.1
- PSO优化模糊控制器进行电动汽车能量
- 多目标粒子群社团检测算法MODPSO
- PSO优化SVM参数matlab
- 蜂群SVMABC-SVM遗传算法SVMGA-SVM粒子群
- 遗传粒子群优化算法-GAPSO.rar
- pso优化bp神经网络代码
- MATLAB 多目标粒子群算法源代码
- 粒子群算法应用在路径规划matlab
- MOPSO+
- 粒子群算法matlab含注释
- pso-bp代码
- 基于权重改进的PSO
- PSO优化PID参数
- pso工具箱 matlab
- 智能优化算法及其MATLAB第2版-书中的
- MOPSO多目标优化程序MATLAB代码.zip
- 基于粒子群算法的优化模型matlab程序
- psot工具箱及使用说明.zip
- matlab 2D椭圆和3D椭球拟合
- 灰狼算法GWO和粒子群算法PSO的matlab源
- PSO_GD.m粒子群求解多目标优化
- 粒子群优化CLPSO的MATLAB源代码
- 改进的PSO的matlab源程序
评论
共有 条评论