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


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

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

回复:基本粒子群优化算法Matlab源程序
lyn(游客)发表评论于2009/4/30 11:54:44

啊有联系方式  留一个啊

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

回复:基本粒子群优化算法Matlab源程序
pandeng(游客)发表评论于2009/4/25 10:45:13

我想要改进后的算法,邮箱为:864821649G@gmail.com 多谢楼主
个人主页 | 引用回复 | 主人回复 | 返回 | 编辑 | 删除

回复:基本粒子群优化算法Matlab源程序
软测量(游客)发表评论于2009/4/23 10:55:12

谢谢主人的分享,很希望能向你请教关于粒子群优化的MATLAB编程问题。
个人主页 | 引用回复 | 主人回复 | 返回 | 编辑 | 删除

回复:基本粒子群优化算法Matlab源程序
huaihai(游客)发表评论于2008/8/23 17:43:13

以下引用R(游客)在2008-2-29 16:18:30的评论: 赞人品请教楼主,我是新手,怎样才能运行你的程序
个人主页 | 引用回复 | 主人回复 | 返回 | 编辑 | 删除

回复:基本粒子群优化算法Matlab源程序
huang20021983(游客)发表评论于2008/4/21 16:16:57

搂主测试的是什么函数啊
个人主页 | 引用回复 | 主人回复 | 返回 | 编辑 | 删除

回复:基本粒子群优化算法Matlab源程序
datou30(游客)发表评论于2008/4/10 13:14:47

谢谢博主的程序   对我很有启发  你真是个好人
个人主页 | 引用回复 | 主人回复 | 返回 | 编辑 | 删除

回复:基本粒子群优化算法Matlab源程序
jinye123(游客)发表评论于2008/4/4 12:22:19

楼主  非常感谢  写的简洁明了  外行都能看懂 之前复制走了  改进了一下
个人主页 | 引用回复 | 主人回复 | 返回 | 编辑 | 删除

回复:基本粒子群优化算法Matlab源程序
R(游客)发表评论于2008/2/29 16:18:30

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

回复:基本粒子群优化算法Matlab源程序
飞行(游客)发表评论于2008/1/3 9:51:31

楼主真是好人呐
个人主页 | 引用回复 | 主人回复 | 返回 | 编辑 | 删除

回复:基本粒子群优化算法Matlab源程序
乔(游客)发表评论于2007/12/5 9:29:54

谢谢博主的无私奉献精神,!
个人主页 | 引用回复 | 主人回复 | 返回 | 编辑 | 删除
» 1 2 »

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

 
«September 2025»
123456
78910111213
14151617181920
21222324252627
282930

  公告

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

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

 


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

  最新评论

  留言板

  链接

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



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

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