使用MATLAB遗传算法工具实例详细计算机matlab计算机matlab.pdf
《使用MATLAB遗传算法工具实例详细计算机matlab计算机matlab.pdf》由会员分享,可在线阅读,更多相关《使用MATLAB遗传算法工具实例详细计算机matlab计算机matlab.pdf(48页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、Gen etic 最新发布的 MATLAB 7.0 Release 14已经包含了一个专门设计的遗传算法与直接搜索工具箱(Algorithm and Direct Search Toolbox,GADS)。使用遗传算法与直接搜索工具箱,可以扩展 MATLAB 及其优化 工具箱在处理优化问题方面的能力,可以处理传统的优化技术难以解决的问题,包括那些难以定义或不便于数 学建模的问题,可以解决目标函数较复杂的问题,比如目标函数不连续、或具有高度非线性、随机性以及目标 函数没有导数的情况。本章 8.1 节首先介绍这个遗传算法与直接搜索工具箱,其余各节分别介绍该工具箱中的遗传算法工具及其 使用方法。8.
2、1 遗传算法与直接搜索工具箱概述 本节介绍 MATLAB 的 GADS(遗传算法与直接搜索)工具箱的特点、图形用户界面及运行要求,解释如 何编写待优化函数的 M 文件,且通过举例加以阐明。8.1.1 工具箱的特点 GADS 工具箱是一系列函数的集合,它们扩展了优化工具箱和 MATLAB 数值计算环境的性能。遗传算法 与直接搜索工具箱包含了要使用遗传算法和直接搜索算法来求解优化问题的一些例程。这些算法使我们能够求 解那些标准优化工具箱范围之外的各种优化问题。所有工具箱函数都是 MATLAB 的 M 文件,这些文件由实现 特定优化算法的 MATLAB 语句所写成。使用语句 type fun cti
3、 on_n ame 就可以看到这些函数的 MATLAB 代码。我们也可以通过编写自己的 M 文件来实现来扩展遗传算法和直接搜索 工具箱的性能,也可以将该工具箱与 MATLAB 的其他工具箱或 Simulink 结合使用,来求解优化问题。工具箱函数可以通过图形界面或 MATLAB 命令行来访问,它们是用 MATLAB 语言编写的,对用户开放,因此可以查看算法、修改源代码或生成用户函数。遗传算法与直接搜索工具箱可以帮助我们求解那些不易用传统方法解决的问题,譬如表查找问题等。遗传算法与直接搜索工具箱有一个精心设计的图形用户界面,可以帮助我们直观、方便、快速地求解最优 化问题。8.1.1.1 功能特点
4、 遗传算法与直接搜索工具箱的功能特点如下:(1)图形用户界面和命令行函数可用来快速地描述问题、设置算法选项以及监控进程。(2)具有多个选项的遗传算法工具可用于问题创建、适应度计算、选择、交叉和变异。(3)直接搜索工具实现了一种模式搜索方法,其选项可用于定义网格尺寸、表决方法和搜索方 法。(4)遗传算法与直接搜索工具箱函数可与 MATLAB 的优化工具箱或其他的 MATLAB 程序结合 使用。(5)支持自动的 M 代码生成。8.1.1.2 图形用户界面和命令行函数 遗传算法工具函数可以通过命令行和图形用户界面来使用遗传算法。直接搜索工具函数也可以通过命令行 和图形用户界面来进行访问。图形用户界面
5、可用来快速地定义问题、设置算法选项、对优化问题进行详细定 义。遗传算法与直接搜索工具箱还同时提供了用于优化管理、性能监控及终止准则定义的工具,同时还提供大 量标准算法选项。在优化运行的过程中,可以通过修改选项来细化最优解,更新性能结果。用户也可以提供自己的算法选项 来定制工具箱。8.1.1.3 使用其他函数和求解器 遗传算法与直接搜索工具箱与 MATLAB 及优化工具箱是紧密结合在一起的。用户可以用遗传算法或直接 搜索算法来寻找最佳起始点,然后利用优化工具箱或用 MATLAB 程序来进一步寻找最优解。通过结合不同的 算法,可以充分地发挥 MATLAB 和工具箱的功能以提高求解的质量。对于某些特
6、定问题,使用这种方法还 可以得到全局(最优)解。8.1.1.4 显示、监控和输出结果 遗传算法与直接搜索工具箱还包括一系列绘图函数用来可视化优化结果。这些可视化功能直观地显示了优 化的过程,并且允许在执行过程中进行修改。工具箱还包括一系列绘图函数用来可视化优化结果。这些可视化功能直观地显示了优化的过程,并且允许 在执行过程中进行修改。该工具箱还提供了一些特殊绘图函数,它们不仅适用于遗传算法,还适用于直接搜索 算法。适用于遗传算法的函数包括函数值、适应度值和函数估计。适用于直接搜索算法的函数包括函数值、分 值直方图、系谱、适应度值、网格尺寸和函数估计。这些函数可以将多个绘图一并显示,可直观方便地
7、选取最 优曲线。另外,用户也可以添加自己的绘图函数。使用输出函数可以将结果写入文件,产生用户自己的终止准则,也可以写入用户自己的图形界面来运行工 具箱求解器。除此之外,还可以将问题的算法选项导出,以便日后再将它们导入到图形界面中去。8.1.1.5 所需的产品支持 遗传算法与直接搜索工具箱作为其他优化方法的补充,可以用来寻找最佳起始点,然后可以再通过使用传 统的优化技术来进一步寻找最优解。工具箱需要如下产品支持:(1)MATLAB。(2)优化工具箱。8.1.1.6 相关产品 与遗传算法与直接搜索工具箱相关的产品有:(1)统计工具箱应用统计算法和概率模式。(2)神经网络工具箱设计和仿真神经网络。(
8、3)模糊逻辑工具箱设计和仿真基于模糊逻辑的系统。(4)金融工具箱分析金融数据和开发金融算法。8.1.1.7 所需的系统及平台 遗传算法和直接搜索工具箱 对于对于运行环境、支持平台和系统的需求,可随时通过访问网站 了解最 新发布的信息。这里介绍的 MATLAB 7.0 Release 14 所需的最低配置是:Windows 系列操作系统,Pentium III 500 CPU、64MB RAM空闲硬盘空间 600MB 以上。8.1.2 编写待优化函数的 M 文件 为了使用遗传算法和直接搜索工具箱,首先必须编写一个 M 文件,来确定想要优化的函数。这个 M 文件 应该接受一个行向量,并且返回一个标
9、量。行向量的长度就是目标函数中独立变量的个数。本节将通过实例解 释如何编写这种 M 文件。8.1.2.1 编写 M 文件举例 下面的例子展示了如何为一个想要优化的函数编写 M 文件。假定我们想要计算下面函数的最小值:M 文件确定这个函数必须接受一个长度为 2 的行向量 X,分别与变量 x1 和 X2 相对应,并且返回一个标量 X,其值等于该函数的值。为了编写这个 M 文件,执行如下步骤:在 MATLAB 的 File 菜单中选择 New 菜单项。(2)选择 M-File,将在编辑器中打开一个新的 M 文件。(3)在该 M 文件中,输入下面两行代码:优化工具箱在处理优化问题方面的能力可以处理传统
10、的优化技术难以解决的问题包括那些难以定义或不便于数学建模的问题可以解决目标函数较复杂的问题比如目标函数不连续或具有高度非线性随机性以及目标函数没有导数的情况算法与直接搜索工具箱概述本节介绍的遗传算法与直接搜索工具箱的特点图形用户界面及运行要求解释如何编写待优化函数的文件且通过例加以阐明工具箱的特点工具箱是一系列函数的集合它们扩展了优化工具箱和数值计算环境的们能够求解那些标准优化工具箱范围之外的各种优化问题所有工具箱函数都是的文件这些文件由实现特定优化算法的语句所写成使用语句就可以看到这些函数的代码我们也可以通过编写自己的文件来实现来扩展遗传算法和直接搜索fun cti on z=my_fu n
11、(x)z=x(1)A2-2*x(1)*x(2)+6*x(1)+x(2)A2-6*x(2);(4)在 MATLAB 路径指定的目录中保存该 M 文件。为了查看该 M 文件是否返回正确的值,可键入 my_fun(2 3)ans=-5 注意:在运行遗传算法工具或模式搜索工具时,不要使用编辑器或调试器来调试目标函数的 M 文件,否则 会导致在命令窗口岀现 Java 异常消息,并且使调试更加困难。8.122 最大化与最小化 遗传算法和直接搜索工具箱中的优化函数总是使目标函数或适应度函数最小化。也就是说,它们求解如下 形式的问题:如果我们想要求岀函数 f(x)的最大值,可以转而求取函数 g(x)=-f(x
12、)的最小值,因为函数 g(x)最小值岀现的 地方与函数 f(x)最大值岀现的地方相同。例如,假定想要求前面所描述的函数 f(Xi,X2)=x-2x1x2 6x1 x|-6x2的最大值,这时,我们应当编写一 个 M 文件来计算,求函数 的最小值。8.1.2.3 自动代码生成 遗传算法与直接搜索工具箱提供了自动代码生成特性,可以自动生成求解优化问题所需要的 M 文件。例 如,图 8.1 所示的就是使用遗传算法工具的自动代码生成特性所产生的 M 文件。另外,图形用户界面所输岀的优化结果可以作为对来自命令行调用代码的一种解释,这些代码还用于使例 程和保护工作自动化。图8.1遗传算法M文件代码的自动生成
13、 8.2 使用遗传算法工具初步 遗传算法与直接搜索工具箱包含遗传算法工具和直接搜索工具。从本节至章末,将主要介绍其中的遗传算 法工具及其使用方法。本节主要介绍遗传算法工具使用的初步知识,内容包括:遗传算法使用规则,遗传算法工具的使用方式,举例说明如何使用遗传算法来求解一个优化问题,解释遗传算法的一些基本术语,最后阐述遗传算法的工作原 理与工作过程。8.2.1 遗传算法使用规则 遗传算法是一种基于自然选择、生物进化过程来求解问题的方法。遗传算法反复修改对于个体解决方案的 种群。在每一步,遗传算法随机地从当前种群中选择若干个体作为父辈,并且使用它们产生下一代的子种群。在连续若干代之后,种群朝着优化
14、解的方向进化。我们可以用遗传算法来求解各种不适宜于用标准优化算法求 解的优化问题,包括目标函数不连续、不可微、随机或高度非线性的问题。遗传算法在每一步使用下列三类规则从当前种群来创建下一代:(1)选择规则(Selection rules),选择对下一代种群有贡献的个体,称为父辈。(2)交叉规则(Crossover rules),将两个父辈结合起来构成下一代的子辈种群。(3)变异规则(Mutation rules),施加随机变化给父辈个体来构成子辈。遗传算法与标准优化算法主要在两个方面有所不同,它们的比较情况归纳于表 8.1 中 优化工具箱在处理优化问题方面的能力可以处理传统的优化技术难以解决的
15、问题包括那些难以定义或不便于数学建模的问题可以解决目标函数较复杂的问题比如目标函数不连续或具有高度非线性随机性以及目标函数没有导数的情况算法与直接搜索工具箱概述本节介绍的遗传算法与直接搜索工具箱的特点图形用户界面及运行要求解释如何编写待优化函数的文件且通过例加以阐明工具箱的特点工具箱是一系列函数的集合它们扩展了优化工具箱和数值计算环境的们能够求解那些标准优化工具箱范围之外的各种优化问题所有工具箱函数都是的文件这些文件由实现特定优化算法的语句所写成使用语句就可以看到这些函数的代码我们也可以通过编写自己的文件来实现来扩展遗传算法和直接搜索表8.1遗传算法与标准优化算法比较 标准算法 遗传算法 每次
16、迭代产生一个单点,点的序 列逼近一个优化解 每次迭代产生一个种群,种群逼 近一个优化解 通过确定性的计算在该序列中选 择下一个点 通过随机进化选择计算来选择下 一代种群 822 遗传算法使用方式 遗传算法工具有两种使用方式:(1)以命令行方式调用遗传算法函数 ga。(2)使用遗传算法工具,从图形用户界面到遗传算法。本节对这些方式做一个简要的介绍。8.2.2.1 在命令行调用函数 ga 对于在命令行使用遗传算法,可以用下列语法调用遗传算法函数 ga:x fval=ga(fitnessfun,nvars,options)其中:fitnessfun是适应度函数句柄;nvars 是适应度函数的独立变量
17、的个数;options 是一个包含遗传算法 选项参数的结构。如果不传递选项参数,则 ga 使用它本身的缺省选项值。函数所给出的结果:fval-适应度函数的最终值;x-最终值到达的点。我们可以十分方便地把遗传算法工具输岀的结果直接返回到 MATLAB 的 workspace(工作空间),或以不同 的选项从 M 文件多次调用函数 ga 来运行遗传算法。调用函数 ga 时,需要提供一个选项结构 options。后面的有关章节对于在命令行使用函数 ga 和创建选项结构 optio ns 提供了详细的描述。8.222 通过 GUI 使用遗传算法 遗传算法工具有一个图形用户界面 GUI,它使我们可以使用遗
18、传算法而不用工作在命令行方式。为了打开 遗传算法工具,可键入 gatool 打开的遗传算法工具图形用户界面如图 8.2 所示。优化工具箱在处理优化问题方面的能力可以处理传统的优化技术难以解决的问题包括那些难以定义或不便于数学建模的问题可以解决目标函数较复杂的问题比如目标函数不连续或具有高度非线性随机性以及目标函数没有导数的情况算法与直接搜索工具箱概述本节介绍的遗传算法与直接搜索工具箱的特点图形用户界面及运行要求解释如何编写待优化函数的文件且通过例加以阐明工具箱的特点工具箱是一系列函数的集合它们扩展了优化工具箱和数值计算环境的们能够求解那些标准优化工具箱范围之外的各种优化问题所有工具箱函数都是的
19、文件这些文件由实现特定优化算法的语句所写成使用语句就可以看到这些函数的代码我们也可以通过编写自己的文件来实现来扩展遗传算法和直接搜索输入适应度函数 的变量数目 开始遗传算法 显示结果 为了使用遗传算法工具,首先必须输入下列信息:Fitness function(适应度函数)-欲求最小值的目标函数。输入适应度函数的形式为 fitnessfun,其中 fitnessfun.m是计算适应度函数的 M 文件。在前面 编写待优化函数的 M 文件”一节里 已经解释了如何编写这种 M 文件。符号 产生一个对于函数 fitnessfun 的函数句柄。(2)Number of variables(变量个数)-适
20、应度函数输入向量的长度。对于 编写待优化函数的 M 文件”一节所描述的函数 My_fun,这个参数是 2。点击 Start 按钮,运行遗传算法,将在 Status and Results(状态与结果)窗格中显示岀相应的运行结果。在 Optio ns 窗格中可以改变遗传算法的选项。为了查看窗格中所列岀的各类选项,可单击与之相连的符号 8.2.3 举例:Rastrigin 函数 本节介绍一个例子,讲述如何寻找 Rastrigin 函数的最小值和显示绘制的图形。Rastrigin 函数是最常用来测 试遗传算法的一个典型函数。Rastrigin 函数的可视化图形显示,它具有多个局部最小值和一个全局最小
21、值,遗 传算法可以帮助我们确定这种具有多个局部最小值函数的最优解。8.2.3.1 Rastrigin 函数 具有两个独立变量的 Rastrigin 函数定义为 输入适应度函数 显示参数描述 图8.2遗传算法工具 优化工具箱在处理优化问题方面的能力可以处理传统的优化技术难以解决的问题包括那些难以定义或不便于数学建模的问题可以解决目标函数较复杂的问题比如目标函数不连续或具有高度非线性随机性以及目标函数没有导数的情况算法与直接搜索工具箱概述本节介绍的遗传算法与直接搜索工具箱的特点图形用户界面及运行要求解释如何编写待优化函数的文件且通过例加以阐明工具箱的特点工具箱是一系列函数的集合它们扩展了优化工具箱
22、和数值计算环境的们能够求解那些标准优化工具箱范围之外的各种优化问题所有工具箱函数都是的文件这些文件由实现特定优化算法的语句所写成使用语句就可以看到这些函数的代码我们也可以通过编写自己的文件来实现来扩展遗传算法和直接搜索Rastrigin 函数的图形如图 8.3 所示。优化工具箱在处理优化问题方面的能力可以处理传统的优化技术难以解决的问题包括那些难以定义或不便于数学建模的问题可以解决目标函数较复杂的问题比如目标函数不连续或具有高度非线性随机性以及目标函数没有导数的情况算法与直接搜索工具箱概述本节介绍的遗传算法与直接搜索工具箱的特点图形用户界面及运行要求解释如何编写待优化函数的文件且通过例加以阐明
23、工具箱的特点工具箱是一系列函数的集合它们扩展了优化工具箱和数值计算环境的们能够求解那些标准优化工具箱范围之外的各种优化问题所有工具箱函数都是的文件这些文件由实现特定优化算法的语句所写成使用语句就可以看到这些函数的代码我们也可以通过编写自己的文件来实现来扩展遗传算法和直接搜索06 局部最小点 O 局部最小点 5U 全局最小点0,0 niiaxiiTMJ minima 工具箱包含一个 M 文件,即 rastriginsfcn.m,是用来计算 Rastrigin 函数值的 图8.3 Rastrigin函数图形 如图 8.3 所示,Rastrigin 函数有许多局部最小值 一一在图上显示为 谷底(va
24、lleys)”。然而,该函数只有一 个全局最小值,岀现在 x-y平面上的点0,0处,正如图中竖直线指示的那样,函数的值在那里是 0。在任何不 同于0,0的局部最小点处,Rastrigin 函数的值均大于 0。局部最小处距原点越远,该点处 Rastrigin 函数的值越 大。Rastrigin 函数之所以最常用来测试遗传算法,是因为它有许多局部最小点,使得用标准的、基于梯度的查 找全局最小的方法十分困难。图 8.4 所示是 Rastrigin 函数的轮廓线,它显示岀最大最小交替变化的情形。图8.4 Rastrigin函数的轮廓线 823.2 寻找 Rastrigin 函数的最小值 优化工具箱在处
25、理优化问题方面的能力可以处理传统的优化技术难以解决的问题包括那些难以定义或不便于数学建模的问题可以解决目标函数较复杂的问题比如目标函数不连续或具有高度非线性随机性以及目标函数没有导数的情况算法与直接搜索工具箱概述本节介绍的遗传算法与直接搜索工具箱的特点图形用户界面及运行要求解释如何编写待优化函数的文件且通过例加以阐明工具箱的特点工具箱是一系列函数的集合它们扩展了优化工具箱和数值计算环境的们能够求解那些标准优化工具箱范围之外的各种优化问题所有工具箱函数都是的文件这些文件由实现特定优化算法的语句所写成使用语句就可以看到这些函数的代码我们也可以通过编写自己的文件来实现来扩展遗传算法和直接搜索本节解释
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 使用 MATLAB 遗传 算法 工具 实例 详细 计算机
限制150内