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


[算法]基本粒子群优化算法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'>

阅读全文(20215) | 回复(20) | 编辑 | 精华

回复:基本粒子群优化算法Matlab源程序
jorce(游客)发表评论于2013/1/9 11:00:44

谢谢您的提供

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

回复:基本粒子群优化算法Matlab源程序
求学者(游客)发表评论于2012/4/30 19:18:45

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

回复:基本粒子群优化算法Matlab源程序
游客(游客)发表评论于2011/3/28 13:03:04

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

回复:基本粒子群优化算法Matlab源程序
小妮(游客)发表评论于2010/12/7 11:02:59

谢谢分享,刚开始学粒子群算法,对我帮助很大
个人主页 | 引用回复 | 主人回复 | 返回 | 编辑 | 删除

回复:基本粒子群优化算法Matlab源程序
琳雁(游客)发表评论于2010/9/29 20:09:20

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

回复:基本粒子群优化算法Matlab源程序
ywzlynn发表评论于2010/8/30 10:39:28


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

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

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

回复:基本粒子群优化算法Matlab源程序
ZZZZ(游客)发表评论于2009/8/1 14:02:55

上面程序不能运行!
个人主页 | 引用回复 | 主人回复 | 返回 | 编辑 | 删除

回复:基本粒子群优化算法Matlab源程序
lemon(游客)发表评论于2009/7/4 10:02:44

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

回复:基本粒子群优化算法Matlab源程序
wangkai73(游客)发表评论于2009/5/27 10:58:22

感谢作者。
个人主页 | 引用回复 | 主人回复 | 返回 | 编辑 | 删除
» 1 2 »

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

 
«September 2025»
123456
78910111213
14151617181920
21222324252627
282930

  公告

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

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

 


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

  最新评论

  留言板

  链接

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



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

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