本站首页    管理页面    写新日志    退出


[算法]基本粒子群优化算法Matlab源程序
sunshine 发表于 2007/11/20 19:56:04

基本粒子群优化算法Matlab源程序     这个程序就是最基本的粒子群优化算法程序,用Matlab实现,非常简单。只有几十行代码。正所谓一分钱一分货啊,优化效果不总是令人满意。我还有几个改进的粒子群优化算法版本,这一段时间会陆续发上来。      下面是主函数的源程序,优化函数则以m文件的形式放在fitness.m里面,对不同的优化函数只要修改fitness.m就可以了通用性很强。      主函数源程序(main.m)   %------基本粒子群优化算法(Particle Swarm Optimization)----------- %------名称:基本粒子群优化算法(PSO) %------作用:求解优化问题 %------说明:全局性,并行性,高效的群体智能算法 %------作者:孙明杰(dreamsun2001@126.com) %------单位:中国矿业大学理学院计算数学硕2005 %------时间:2006年8月17日 <CopyRight@dReAmsUn> %------------------------------------------------------------------ %------初始格式化-------------------------------------------------- clear all; clc; format long; %------给定初始化条件---------------------------------------------- c1=1.4962;             %学习因子1 c2=1.4962;             %学习因子2 w=0.7298;              %惯性权重 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     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;         下面几天回继续发上来其他改进算法,并发上比较结果。先看看我这有3种方法对此函数的优化结果比较图形,图形不是很清楚,一直下降的就是改进算法比较成功的  500)this.width=500'>

阅读全文(16432) | 回复(21) | 编辑 | 精华

回复:基本粒子群优化算法Matlab源程序
805199835(游客)发表评论于2009/8/28 19:20:12

你好 找了好久粒子群算法的源程序。多谢你能提供这些程序代码。我有一个问题啊:如果输出的是 迭代次数与每次的最优适应值 的关系图的话  怎么实现呢  能给我说一下吗  谢谢了。

个人主页 | 引用回复 | 主人回复 | 返回 | 编辑 | 删除

回复:基本粒子群优化算法Matlab源程序
XX(游客)发表评论于2009/8/24 9:55:27

非常感谢!
个人主页 | 引用回复 | 主人回复 | 返回 | 编辑 | 删除

回复:基本粒子群优化算法Matlab源程序
XX(游客)发表评论于2009/8/24 9:55:27

非常感谢!
个人主页 | 引用回复 | 主人回复 | 返回 | 编辑 | 删除

回复:基本粒子群优化算法Matlab源程序
prettyduck(游客)发表评论于2009/8/7 13:59:09

以下引用学生(游客)在2008-1-22 13:48:15的评论: 谢谢哦
个人主页 | 引用回复 | 主人回复 | 返回 | 编辑 | 删除

回复:基本粒子群优化算法Matlab源程序
1(游客)发表评论于2009/6/5 11:05:16

谢谢喔!
个人主页 | 引用回复 | 主人回复 | 返回 | 编辑 | 删除

回复:基本粒子群优化算法Matlab源程序
冰雪儿(游客)发表评论于2009/5/7 10:42:12

以下引用学生(游客)在2008-1-22 13:48:15的评论: 谢谢哦
个人主页 | 引用回复 | 主人回复 | 返回 | 编辑 | 删除

回复:基本粒子群优化算法Matlab源程序
ZSQ(游客)发表评论于2009/4/16 15:44:45

请问如果函数的变量有约束条件限制,应如何改进程序
个人主页 | 引用回复 | 主人回复 | 返回 | 编辑 | 删除

回复:基本粒子群优化算法Matlab源程序
1233(游客)发表评论于2009/1/5 20:35:26

谢谢
个人主页 | 引用回复 | 主人回复 | 返回 | 编辑 | 删除

回复:基本粒子群优化算法Matlab源程序
mapleflying(游客)发表评论于2008/12/29 10:49:42

很感谢,想问下,文中给出的fitness适度值函数验证的时怎么样一个函数?thx
个人主页 | 引用回复 | 主人回复 | 返回 | 编辑 | 删除

回复:基本粒子群优化算法Matlab源程序
shelly(游客)发表评论于2008/11/28 9:33:15

多谢!!
个人主页 | 引用回复 | 主人回复 | 返回 | 编辑 | 删除
» 1 2 3 »

发表评论:
昵称:
密码:
主页:
标题:
验证码:  (不区分大小写,请仔细填写,输错需重写评论内容!)

 
«October 2025»
1234
567891011
12131415161718
19202122232425
262728293031

  公告

有一种鸟儿是永远关不住的
因为它的每片羽翼上都沾满了自由的光辉

方向:计算机视觉 人工智能 演化算法

 


  我的分类(专题)
  最近日志

  最新评论

  留言板

  链接

  Blog信息
blog名称:阳光海岸心
日志总数:166
评论数量:237
留言数量:-4
访问次数:1458673
建立时间:2006年6月2日



站点首页 | 联系我们 | 博客注册 | 博客登陆

Sponsored By W3CHINA
W3CHINA Blog 0.8 Processed in 1.520 second(s), page refreshed 144795047 times.
《全国人大常委会关于维护互联网安全的决定》  《计算机信息网络国际联网安全保护管理办法》
苏ICP备05006046号