Hello Mat

 找回密码
 立即注册
查看: 5503|回复: 4

优化算法案例分析与应用P169页

[复制链接]

3

主题

28

帖子

1

金钱

新手上路

Rank: 1

积分
29
发表于 2017-1-21 22:01:03 | 显示全部楼层 |阅读模式
按书上代码,敲的,报错
Error using  -
Matrix dimensions must agree.

Error in PSO_base1 (line 36)
       V(j, :) = V(j, :) +c1*rand*(gbest(j, :) -  pop(j, :)) + c2*rand*(zbest -  pop(j,
       :));

实在找不到错误在哪里。

求指点

回复

使用道具 举报

1323

主题

1551

帖子

0

金钱

管理员

Rank: 9Rank: 9Rank: 9

积分
22647
发表于 2017-1-21 22:27:37 | 显示全部楼层
检查变量:速度V、gbest、zbest的维度,贴出代码吧


或者直接看学习视频:
1粒子群算法 + (PPT+参考文献) + 源程序
2改进的粒子群算法(粒子群算法、线性权重递减PSO、线性权重递增PSO、惯性权重PSO(3种)、随机权重PSO、压缩因子PSO) + (PPT+参考文献) + 源程序

算法QQ  3283892722
群智能算法链接http://halcom.cn/forum.php?mod=forumdisplay&fid=73
回复 支持 反对

使用道具 举报

3

主题

28

帖子

1

金钱

新手上路

Rank: 1

积分
29
 楼主| 发表于 2017-1-22 16:50:53 | 显示全部楼层
Halcom 发表于 2017-1-21 22:27
速度V的维度声明错了,贴出代码吧,或者直接视频:

clc
clear all;
close all;
c1 = 1.49455;
c2 = 1.49455;

maxg = 200;
sizepop = 20;

%初始速度和种群上下边界
Vmax=1;
Vmin=-1;
popmax=5;
popmin=-5;

%产生粒子和速度
for i=1:sizepop
    %随机产生一个种群
    pop(i,:)=5*rands(1,2);%i是第行矩阵,列数待定。rands(1,2)产生一行两列。% 初始化种群
    V(i,:)=rands(1,2);%初始化速度
    %计算适应度
    fitness(i)=fun(pop(i,:));    %粒子的适应度值
end

%找最好的粒子
[bestfitness bestindex]=min(fitness);%min返回两个数值 一个是数值最小的 一个是这个最小数值的位置
zbest = pop(bestindex, :);%全局最优x1与x2值
gbest=pop;%个体最优x1与x2值
fitnessgbest = fitness; %个体最佳适应度
fitnesszbest=bestfitness; %全局最佳适应度值

%%迭代寻优
for i=1:maxg
    for j=1:sizepop
        %速度更新
       V(j, :) = V(j, :) +c1*rand*(gbest(j, :) -  pop(j, :)) + c2*rand*(zbest -  pop(j, :));
        V(j,find(V(j,:)>Vmax)) =Vmax;% 如果X是一个逻辑表达式,则返回一个逻辑数组,一般如果存在满足要求的元素,则返回一个单位列向量
        V(j,find(V(j,:)<Vmin)) =Vmin;
        %种群更新
        pop(j,:) = pop(j,:) +0.5*V(j,:);
        pop(j, find(pop(j,:)>popmax)) = popmax;
        pop(j, find(pop(j,:)<popmin)) = popmin;
        
        %自适应变异
        if rand<0.8
            k = ceil(2*rand);%ceil取整
            pop(j,k) = rand;
        end
        %适应度值
        fitness(j)=fun(pop(j,:));
        
        %个体最优更新
        if fitness(j) < fitnessgbest(j)
            gbest(j,:) = pop(j,:);
            fitnessgbest(j) = fitness(j);
        end
        
        %群体最优更新
        if fitness(j) < fitnesszbest
            zbest(j,:) = pop(j,:);
            fitnesszbest= fitness(j);
        end
    end
    yy(i) = fitnesszbest;%保存每一代最优个体
end
%%结果分析
plot(yy,'linewidth',2)
title(['适应度曲线 ' '终止代数= ' num2str(maxg)]);
grid on
xlabel('进化代数'); ylabel(' 适应度');
%输出结果
zbest
回复 支持 反对

使用道具 举报

1323

主题

1551

帖子

0

金钱

管理员

Rank: 9Rank: 9Rank: 9

积分
22647
发表于 2017-1-22 16:55:09 | 显示全部楼层
lancelotli 发表于 2017-1-22 16:50
clc
clear all;
close all;

zbest(j,:) = pop(j,:);改为:
zbest = pop(j,:);
算法QQ  3283892722
群智能算法链接http://halcom.cn/forum.php?mod=forumdisplay&fid=73
回复 支持 反对

使用道具 举报

3

主题

28

帖子

1

金钱

新手上路

Rank: 1

积分
29
 楼主| 发表于 2017-1-22 19:35:33 | 显示全部楼层
Halcom 发表于 2017-1-22 16:55
zbest(j,:) = pop(j,:);改为:
zbest = pop(j,:);

多谢大神!代码已经正确运行!
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

Python|Opencv|MATLAB|Halcom.cn ( 蜀ICP备16027072号 )

GMT+8, 2024-11-22 21:48 , Processed in 0.212089 second(s), 23 queries .

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表