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


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

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

回复:基本粒子群优化算法Matlab源程序
DFSAF(游客)发表评论于2008/11/15 21:17:24

以下引用雨中风铃(游客)在2008-10-25 9:49:52的评论: 呵呵,真的谢谢啊,好好学习,这种东西真的不好找到。

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

回复:基本粒子群优化算法Matlab源程序
雨中风铃(游客)发表评论于2008/10/25 9:49:52

呵呵,真的谢谢啊,好好学习,这种东西真的不好找到。
个人主页 | 引用回复 | 主人回复 | 返回 | 编辑 | 删除

回复:基本粒子群优化算法Matlab源程序
呵呵(游客)发表评论于2008/5/28 10:49:00

有没有粒子群算法用于特征提取的matlab程序啊
个人主页 | 引用回复 | 主人回复 | 返回 | 编辑 | 删除

回复:基本粒子群优化算法Matlab源程序
fanfan(游客)发表评论于2008/5/22 21:29:43

以下引用Inzaghi0514(游客)在2008-3-21 16:05:07的评论:谢谢你,真的帮助挺大!谢谢,谢谢,谢谢 ,谢谢
个人主页 | 引用回复 | 主人回复 | 返回 | 编辑 | 删除

回复:基本粒子群优化算法Matlab源程序
daishu(游客)发表评论于2008/5/22 1:39:30

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

回复:基本粒子群优化算法Matlab源程序
happy1120(游客)发表评论于2008/4/14 9:03:25

这些程序代码真的很好,谢谢你啊!
个人主页 | 引用回复 | 主人回复 | 返回 | 编辑 | 删除

回复:基本粒子群优化算法Matlab源程序
豪爽(游客)发表评论于2008/4/11 15:17:48

你真是太有才了!借用一下!^_^
个人主页 | 引用回复 | 主人回复 | 返回 | 编辑 | 删除

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

楼主说三种有3种方法对此函数的优化结果比较图形,图形无法显示!并且不明白一点,只有两种方法啊,基本的和带交叉因子的,那一种是什么,可否发上来看一下!谢谢楼主!
个人主页 | 引用回复 | 主人回复 | 返回 | 编辑 | 删除

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

谢谢你,真的帮助挺大!
个人主页 | 引用回复 | 主人回复 | 返回 | 编辑 | 删除

回复:基本粒子群优化算法Matlab源程序
学生(游客)发表评论于2008/1/22 13:48:15

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

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

 
«December 2025»
123456
78910111213
14151617181920
21222324252627
28293031

  公告

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

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

 


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

  最新评论

  留言板

  链接

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



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

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