PSO对象箱.docVIP

  1. 1、本文档共5页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
PSO对象箱

PSO算法使用简介 PSO工具箱简介 PSOt为PSO的工具箱,该工具箱将PSO算法的核心部分封装起来,提供给用户的为算法的可调参数,用户只需要定义好自己需要优化的函数(计算最小值或者最大值),并设置好函数自变量的取值范围、每步迭代允许的最大变化量(称为最大速度,Max_V)等,即可自行优化。 与遗传算法相比,PSO仅需要调整少数几个参数即可实现函数的优化。该算法对待优化函数没有任何特别的要求(如可微分、时间连续等),因而其通用性极强,对多变量、高度非线性、不连续及不可微的情况更加具有其优势。 该工具箱的使用主要分为几个步骤: 在Matlab中设置工具箱的路径; 定义待优化函数; 调用PSO算法的核心函数:pso_Trelea_vectorized()。 其中第三步最关键,用户需要根据自己的需要设置好参数,可使算法极快收敛。 下面对各个步骤一一介绍。 设置工具箱的路径 在Matlab的命令窗口点击“File——Set Path….”,如下图: 在弹出的对话框中点击“Add Folder”,然后浏览找到工具箱放置的位置,如下图 若想用到该工具箱所带的测试函数,还需要用如上同样的方法,设置路径指向工具箱下的“testfunctions”文件夹; 若想用于训练神经网络的训练,设置路径指向工具箱下的“testfunctions”文件夹“nnet” 定义待优化函数(参见文件test_func.m) 用户根据自己的需要,定义需要优化的函数。举个例子,若想计算如下二元函数的最小值 z= 0.5*(x-3)^2+0.2*(y-5)^2-0.1 其中自变量x、y的范围均为[-50, 50]。 可按下面的方法定义该待优化函数: %%----------------------------------------------------------------%% function z=test_func(in) nn=size(in); x=in(:,1); y=in(:,2); nx=nn(1); for i=1:nx temp = 0.5*(x(i)-3)^2+0.2*(y(i)-5)^2-0.1; z(i,:) = temp; end %%----------------------------------------------------------------%% 需要特别指出的是:PSO算法的核心函数pso_Trelea_vectorized()自动初始化一组随机变量,因而待优化函数test_func(in)中的输入in是一个矩阵,由一组x和y的值组成,对应的,函数的输出z为一个向量 定义待优化函数(参见文件test_main.m) 当定义好待优化函数后,设置相应的参数,然后就可以调用PSO进行优化了,对上面优化问题,按下面的方式进行调用: %%----------------------------------------------------------------%% clear clc x_range=[-50,50]; %参数x变化范围 y_range=[-50,50]; %参数y变化范围 range = [x_range;y_range]; %参数变化范围(组成矩阵) Max_V = 0.2*(range(:,2)-range(:,1)); %最大速度取变化范围的10%~20% n=2; %待优化函数的维数,此例子中仅x、y两个自变量,故为2 pso_Trelea_vectorized(test_func,n,Max_V,range) %调用PSO核心模块 %%----------------------------------------------------------------%% PSO算法中相关参数的说明 工具箱中相关参数的含义 在该工具箱中,用户可以设置PSO算法的13个参数(参见pso_Trelea_vectorized()的注释部分),但实际上,有些参数采用采用算法提供的默认值即可,算法的默认值说明如下(在pso_Trelea_vectorized函数的定义中,用变量Pdef表示,若用户在pso_Trelea_vectorized的调用中赋以数值,则会覆盖相应的参数。笔者通常直接修改Pdef的数值,而不在调用时指定。)。 1)Pdef = [100 2000 24 2 2 0.9 0.4 1500 1e-25 250 NaN 0 0]; P(1),为在matlab命令窗进行显示的间隔数,取值为100表示每迭代100次显示一次;若取值为0,则不显示中间过程 2)Pdef = [100 2

文档评论(0)

baoyue + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档