声振论坛

 找回密码
 我要加入

QQ登录

只需一步,快速开始

查看: 5495|回复: 12

[共享资源] 我也发一个PSO的源代码,有图形

[复制链接]
发表于 2006-7-19 01:11 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?我要加入

x
有图形显示,很形象。

  1. function [pso F] = pso_2D()
  2. %   FUNCTION PSO  --------USE Particle Swarm Optimization Algorithm
  3. %global present;
  4. % close all;
  5. pop_size = 10;          %   pop_size 种群大小
  6. part_size = 2;          %   part_size 粒子大小,                                                                      ** =n-D
  7. gbest = zeros(1,part_size+1);            %   gbest 当前搜索到的最小的值
  8. max_gen = 80;          %   max_gen 最大迭代次数
  9. region=zeros(part_size,2);  %   设定搜索空间范围
  10. region=[-3,3;-3,3];          %                                                                                      **每一维设定不同范围


  11. rand('state',sum(100*clock));   %   重置随机数发生器状态
  12. arr_present = ini_pos(pop_size,part_size);   %   present 当前位置,随机初始化,rand()的范围为0~1

  13. v=ini_v(pop_size,part_size);             %   初始化当前速度


  14. pbest = zeros(pop_size,part_size+1);      %   pbest 粒子以前搜索到的最优值,最后一列包括这些值的适应度
  15. w_max = 0.9;                            %   w_max 权系数最大值
  16. w_min = 0.4;
  17. v_max = 2;             %                                                                                          **最大速度,为粒子的范围宽度
  18. c1 = 2;                   %   学习因子
  19. c2 = 2;                   %   学习因子
  20. best_record = zeros(1,max_gen);     %   best_record记录最好的粒子的适应度。
  21. %  ————————————————————————
  22. %   计算原始种群的适应度,及初始化
  23. %  ————————————————————————
  24. arr_present(:,end)=ini_fit(arr_present,pop_size,part_size);

  25. % for k=1:pop_size
  26. %     present(k,end) = fitness(present(k,1:part_size));  %计算原始种群的适应度
  27. % end

  28. pbest = arr_present;                                        %初始化各个粒子最优值
  29. [best_value best_index] = min(arr_present(:,end));         %初始化全局最优,即适应度为全局最小的值,根据需要也可以选取为最大值
  30. gbest = arr_present(best_index,:);
  31. %v = zeros(pop_size,1);          %   v 速度
  32. %  ————————————————————————
  33. %   迭代
  34. %  ————————————————————————
  35. % global m;
  36. % m = moviein(1000);      %生成帧矩阵
  37. x=[-3:0.01:3];
  38. y=[-3:0.01:3];
  39. z=@(x,y) 3*(1-x).^2.*exp(-(x.^2) - (y+1).^2) ...
  40.     - 10*(x/5 - x.^3 - y.^5).*exp(-x.^2-y.^2) ...
  41.     - 1/3*exp(-(x+1).^2 - y.^2);
  42. for i=1:max_gen
  43.     grid on;
  44.     %     plot3(x,y,z);
  45.     %     subplot(121),ezmesh(z),hold on,grid on,plot3(arr_present(:,1),arr_present(:,2),arr_present(:,3),'*'),hold off;
  46.     %     subplot(122),ezmesh(z),view([145,90]),hold on,grid on,plot3(arr_present(:,1),arr_present(:,2),arr_present(:,3),'*'),hold off;
  47.     ezmesh(z) ,hold on,grid on,plot3(arr_present(:,1),arr_present(:,2),arr_present(:,3),'*'),hold off;

  48.     drawnow
  49.     F(i)=getframe;

  50.     %     ezmesh(z)
  51.     % %     view([-37,90])
  52.     %     hold on;
  53.     %     grid on;
  54.     %     %   plot(-0.0898,0.7126,'ro');
  55.     %     plot3(arr_present(:,1),arr_present(:,2),arr_present(:,3),'*');                                                  %改为三维
  56.     %    axis([-2*pi,2*pi,-pi,pi,-50,10]);
  57.     %     hold off;
  58.     pause(0.01);
  59.     %     m(:,i) = getframe;        %添加图形
  60.     w = w_max-(w_max-w_min)*i/max_gen;
  61.     %    fprintf('#  %i 代开始!\n',i);
  62.     %   确定是否对打散已经收敛的粒子群——————————————————————————————
  63.     reset = 0;          %   reset = 1时设置为粒子群过分收敛时将其打散,如果=1则不打散
  64.     if reset==1
  65.         bit = 1;
  66.         for k=1:part_size
  67.             bit = bit&(range(arr_present(:,k))<0.1);
  68.         end
  69.         if bit==1       %   bit=1时对粒子位置及速度进行随机重置
  70.             arr_present = ini_pos(pop_size,part_size);   %   present 当前位置,随机初始化
  71.             v = ini_v(pop_size,part_size);           %   速度初始化
  72.             for k=1:pop_size                                    %   重新计算适应度
  73.                 arr_present(k,end) = fitness(arr_present(k,1:part_size));
  74.             end
  75.             warning('粒子过分集中!重新初始化……');      %   给出信息
  76.             display(i);
  77.         end
  78.     end

  79.     for j=1:pop_size
  80.         v(j,:) = w.*v(j,:)+c1.*rand.*(pbest(j,1:part_size)-arr_present(j,1:part_size))...
  81.             +c2.*rand.*(gbest(1:part_size)-arr_present(j,1:part_size));                        %  粒子速度更新 (a)

  82.         %   判断v的大小,限制v的绝对值小于5————————————————————————————
  83.         c = find(abs(v)>6);                                                                                              %**最大速度设置,粒子的范围宽度
  84.         v(c) = sign(v(c))*6;   %如果速度大于3.14则,速度为3.14

  85.         arr_present(j,1:part_size) = arr_present(j,1:part_size)+v(j,1:part_size);              %  粒子位置更新 (b)
  86.         arr_present(j,end) = fitness(arr_present(j,1:part_size));

  87.         if (arr_present(j,end)>pbest(j,end))&(Region_in(arr_present(j,:),region))     %   根据条件更新pbest,如果是最小的值为小于号,相反则为大于号
  88.             pbest(j,:) = arr_present(j,:);
  89.         end

  90.     end

  91.     [best best_index] = max(arr_present(:,end));                                      %   如果是最小的值为min,相反则为max

  92.     if best>gbest(end)&(Region_in(arr_present(best_index,:),region))                  %   如果当前最好的结果比以前的好,则更新最优值gbest,如果是最小的值为小于号,相反则为大于号
  93.         gbest = arr_present(best_index,:);
  94.     end

  95.     best_record(i) = gbest(end);
  96.     display(i);
  97. end

  98. pso = gbest;

  99. display(gbest);

  100. % figure;
  101. % plot(best_record);
  102. % movie2avi(F,'pso_2D1.avi','compression','MSVC');


  103. %   ***************************************************************************
  104. %      计算适应度
  105. %   ***************************************************************************
  106. function fit = fitness(present)
  107. fit=3*(1-present(1)).^2.*exp(-(present(1).^2) - (present(2)+1).^2) ...                                          %**需要求极值的函数,本例即peaks函数
  108.     - 10*(present(1)/5 - present(1).^3 - present(2).^5).*exp(-present(1).^2-present(2).^2) ...
  109.     - 1/3*exp(-(present(1)+1).^2 - present(2).^2);


  110. function ini_present=ini_pos(pop_size,part_size)
  111. ini_present = 3*rand(pop_size,part_size+1);        %初始化当前粒子位置,使其随机的分布在工作空间                         %** 6即为自变量范围


  112. function ini_velocity=ini_v(pop_size,part_size)
  113. ini_velocity =3/2*(rand(pop_size,part_size));        %初始化当前粒子速度,使其随机的分布在速度范围内


  114. function flag=Region_in(pos_present,region)
  115. [m n]=size(pos_present);
  116. flag=1;
  117. for j=1:n-1
  118.     flag=flag&(pos_present(1:j)>=region(j,1))&(pos_present(1:j)<=region(j,2));
  119. end


  120. function arr_fitness=ini_fit(pos_present,pop_size,part_size)
  121. for k=1:pop_size
  122.     arr_fitness(k,1) = fitness(pos_present(k,1:part_size));  %计算原始种群的适应度
  123. end
复制代码

[ 本帖最后由 风花雪月 于 2006-10-12 09:06 编辑 ]
回复
分享到:

使用道具 举报

发表于 2006-7-24 10:15 | 显示全部楼层

这个如何运行呢

如题,我怎么运行的时候会报错呢,请问怎么用呢
 楼主| 发表于 2006-7-24 18:05 | 显示全部楼层
在matlab7。0 下没问题的。
发表于 2006-10-6 22:38 | 显示全部楼层
[求助]
谁有关于PSO算法(粒子群算法)的源程序
能否传一份给我,先谢谢了!

邮箱是     guojian882003@163.com
发表于 2006-10-12 09:07 | 显示全部楼层
原帖由 nuaahill 于 2006-7-24 10:15 发表
如题,我怎么运行的时候会报错呢,请问怎么用呢


我在6.5下运行了一下,没能通过,估计要在7.0及以上版本运行才行
发表于 2006-10-12 10:35 | 显示全部楼层
原帖由 guojian882003 于 2006-10-6 22:38 发表

谁有关于PSO算法(粒子群算法)的源程序
能否传一份给我,先谢谢了!

邮箱是     guojian882003@163.com



一楼的不就是吗?
发表于 2006-10-21 21:43 | 显示全部楼层
呵呵,一直想编一个这样的解释性程序,就像一群小鸟在觅食搜索呢,确实很形象!
再高维的就不能显示出来了。
楼主对于隐式优化问题有过研究没有啊,大家探讨下!
发表于 2006-10-23 09:30 | 显示全部楼层
原帖由 风花雪月 于 2006-10-12 09:07 发表


我在6.5下运行了一下,没能通过,估计要在7.0及以上版本运行才行


是语法问题,需要作一定的修改才能在6.5下运行,比如:
  1. function [pso F] = pso_2D()
复制代码

  1. z=@(x,y) 3*(1-x).^2.*exp(-(x.^2) - (y+1).^2) ...
  2.     - 10*(x/5 - x.^3 - y.^5).*exp(-x.^2-y.^2) ...
  3.     - 1/3*exp(-(x+1).^2 - y.^2);
复制代码


上面的语法格式6.5都是不支持的
发表于 2006-10-23 09:31 | 显示全部楼层
原帖由 andy_3656 于 2006-10-21 21:43 发表
呵呵,一直想编一个这样的解释性程序,就像一群小鸟在觅食搜索呢,确实很形象!
再高维的就不能显示出来了。
楼主对于隐式优化问题有过研究没有啊,大家探讨下!


支持一下,希望楼主能够出来探讨一下
发表于 2008-1-22 15:09 | 显示全部楼层
正在作这方面的优化,很好用,很形象,谢谢,我运行了,效果很好!
发表于 2008-5-6 10:40 | 显示全部楼层
刚才用matlab7.0运行了,不错。
LZ强!
发表于 2009-3-12 10:00 | 显示全部楼层
谢谢lz,很有启发
发表于 2009-6-26 23:45 | 显示全部楼层
看了下~不错啊
您需要登录后才可以回帖 登录 | 我要加入

本版积分规则

QQ|小黑屋|Archiver|手机版|联系我们|声振论坛

GMT+8, 2024-11-11 18:24 , Processed in 0.069920 second(s), 18 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表