楼主: 起云者
2091 0

[问答] pso粒子群优化算法怎么找到合适的权重啊 [推广有奖]

  • 0关注
  • 1粉丝

硕士生

55%

还不是VIP/贵宾

-

威望
0
论坛币
16474 个
通用积分
5.3600
学术水平
6 点
热心指数
6 点
信用等级
6 点
经验
1638 点
帖子
69
精华
0
在线时间
150 小时
注册时间
2015-5-24
最后登录
2023-3-2

楼主
起云者 企业认证  学生认证  发表于 2015-7-8 21:18:31 |只看作者 |坛友微信交流群|倒序 |AI写论文

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

求职就业群
赵安豆老师微信:zhaoandou666

经管之家联合CDA

送您一个全额奖学金名额~ !

感谢您参与论坛问题回答

经管之家送您两个论坛币!

+2 论坛币

clear all;  

clc;

format long;

%---给定初始化条件

c1=1.4962; %学习因子 1

c2=1.4962; %学习因子 2

w=0.7298; %惯性权重?这个换成wmax和wmin

MaxDT=1000; %最大迭代次数  

D=10; %搜索空间维数(未知数个数)  

N=40; %初始化群体个体数目  

eps=10^(-6); %设置精度(在已知最小值时候用)

%初始化种群的个体(可以在这里限定位置和速度的围)

for i=1:N     

for j=1:D

  x(i,j)=randn; %随机初始化位置   

   v(i,j)=randn; %随机初始化速度   

  end

end

%-先计算各个粒子的适应度,并初始化Pi 和Pg

for i=1:N

p(i)=fitness(x(i,:),D);

y(i,:)=x(i,:);

end

pg=x(1,:); %Pg 为全局最优

for i=2:N

if fitness(x(i,:),D)<fitness(pg,D)

pg=x(i,:);

end

end

%------进入主要循环,按照公式依次迭代,直到满足精度要求-----------

for t=1:MaxDT ///////w=wmax-(t/maxdt)*(wmax-wmin)

for i=1:N

v(i,:)=w*v(i,:)+c1*rand*(y(i,:)-x(i,:))+c2*rand*(pg-x(i,:));

x(i,:)=x(i,:)+v(i,:);

if fitness(x(i,:),D)<p(i)

p(i)=fitness(x(i,:),D);

y(i,:)=x(i,:);

end

if p(i)<fitness(pg,D)

pg=y(i,:);

end

end

Pbest(t)=fitness(pg,D);

end

%------最后给出计算结果  

disp('*************************************************************')

disp('函数的全局最优位置为:')

Solution=pg'  

disp('最后得到的优化极值为:')

Result=fitness(pg,D)  

disp('*************************************************************')  

%------算法结束---DreamSun GL & HF-适应度函数源程(fitness.m)

function result=fitness(x,D)

sum=0;  

for i=1:D

sum=sum+x(i)^2; end  

result=sum;


二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

关键词:PSO 粒子群 Fitness format FORMA fitness 未知数 空间

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

本版微信群
加好友,备注cda
拉您进交流群

京ICP备16021002-2号 京B2-20170662号 京公网安备 11010802022788号 论坛法律顾问:王进律师 知识产权保护声明   免责及隐私声明

GMT+8, 2024-5-6 13:29