遗传算法原理与应用讲稿.ppt
《遗传算法原理与应用讲稿.ppt》由会员分享,可在线阅读,更多相关《遗传算法原理与应用讲稿.ppt(65页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、关于遗传算法原理与关于遗传算法原理与应用应用第一页,讲稿共六十五页哦报告提纲报告提纲一、遗传算法概述一、遗传算法概述 二、遗传算法原理二、遗传算法原理三、遗传算法的应用三、遗传算法的应用第二页,讲稿共六十五页哦一、遗传算法概述1 1、智能优化算法智能优化算法 2 2、基本遗传算法基本遗传算法 3 3、遗传算法的特点遗传算法的特点 第三页,讲稿共六十五页哦1 1、智能优化算法、智能优化算法 智能优化算法又称为现代启发式算法,智能优化算法又称为现代启发式算法,是一种具有全局优化性能、通用性强、且适是一种具有全局优化性能、通用性强、且适合于并行处理的算法。这种算法一般具有严合于并行处理的算法。这种算
2、法一般具有严密的理论依据,而不是单纯凭借专家经验,密的理论依据,而不是单纯凭借专家经验,理论上可以在一定的时间内找到最优解或近理论上可以在一定的时间内找到最优解或近似最优解。似最优解。第四页,讲稿共六十五页哦常用的智能优化算法常用的智能优化算法(1 1 1 1)遗传算法遗传算法遗传算法遗传算法 (Genetic AlgorithmGenetic Algorithm,简称简称简称简称GAGA)(2 2 2 2)模拟退火算法模拟退火算法模拟退火算法模拟退火算法(Simulated AnnealingSimulated Annealing,简称简称简称简称SASA)(3 3 3 3)禁忌搜索算法禁忌
3、搜索算法禁忌搜索算法禁忌搜索算法(Tabu SearchTabu Search,简称简称简称简称TSTS)第五页,讲稿共六十五页哦智能优化算法的特点智能优化算法的特点 它们的共同特点:都是从任一解出发,按它们的共同特点:都是从任一解出发,按照某种机制,以一定的概率在整个求解空间中照某种机制,以一定的概率在整个求解空间中探索最优解。由于它们可以把搜索空间扩展到探索最优解。由于它们可以把搜索空间扩展到整个问题空间,因而具有全局优化性能。整个问题空间,因而具有全局优化性能。第六页,讲稿共六十五页哦遗传算法起源遗传算法起源 遗传算法是由美国的遗传算法是由美国的J.Holland教授于教授于1975年在
4、他的专著年在他的专著自然界和人工系统的适应自然界和人工系统的适应性性中首先提出的,它是一类借鉴生物界自然中首先提出的,它是一类借鉴生物界自然选择和自然遗传机制的随机化搜索算法选择和自然遗传机制的随机化搜索算法。第七页,讲稿共六十五页哦遗传算法的搜索机制遗传算法的搜索机制 遗传算法模拟自然选择和自然遗传过程中发遗传算法模拟自然选择和自然遗传过程中发生的繁殖、交叉和基因突变现象,在每次迭代中生的繁殖、交叉和基因突变现象,在每次迭代中都保留一组候选解,并按某种指标从解群中选取都保留一组候选解,并按某种指标从解群中选取较优的个体,利用遗传算子较优的个体,利用遗传算子(选择、交叉和变异选择、交叉和变异)
5、对这些个体进行组合,产生新一代的候选解群,对这些个体进行组合,产生新一代的候选解群,重复此过程,直到满足某种收敛指标为止。重复此过程,直到满足某种收敛指标为止。第八页,讲稿共六十五页哦2 2、基本遗传算法、基本遗传算法 基本遗传算法(基本遗传算法(Simple Genetic Algorithms,简称,简称SGA,又称简单遗传算法或,又称简单遗传算法或标准遗传算法),是由标准遗传算法),是由Goldberg总结出的一种总结出的一种最基本的遗传算法,其遗传进化操作过程简单,最基本的遗传算法,其遗传进化操作过程简单,容易理解,是其它一些遗传算法的雏形和基础。容易理解,是其它一些遗传算法的雏形和基
6、础。第九页,讲稿共六十五页哦基本遗传算法的组成基本遗传算法的组成 (1 1)编码(产生初始种群)编码(产生初始种群)(2 2)适应度函数)适应度函数(3 3)遗传算子(选择、交叉、变异)遗传算子(选择、交叉、变异)(4 4)运行参数)运行参数第十页,讲稿共六十五页哦 编码编码 GA是通过某种编码机制把对象抽是通过某种编码机制把对象抽象为由特定符号按一定顺序排成的串。象为由特定符号按一定顺序排成的串。正如研究生物遗传是从染色体着手,正如研究生物遗传是从染色体着手,而染色体则是由基因排成的串。而染色体则是由基因排成的串。SGA使用二进制串进行编码。使用二进制串进行编码。第十一页,讲稿共六十五页哦函
7、数优化示例函数优化示例 求下列一元函数的最大值:求下列一元函数的最大值:x-1,2 x-1,2 ,求解结果精确到,求解结果精确到6 6位小数。位小数。第十二页,讲稿共六十五页哦SGA对于本例的编码对于本例的编码 由于区间长度为由于区间长度为3,求解结果精确到,求解结果精确到6位小数,位小数,因此可将自变量定义区间划分为因此可将自变量定义区间划分为3106等份。又因等份。又因为为221 3106 222,所以本例的二进制编码长度至,所以本例的二进制编码长度至少需要少需要22位,本例的编码过程实质上是将区间位,本例的编码过程实质上是将区间-1,2内对应的实数值转化为一个二进制串内对应的实数值转化为
8、一个二进制串(b21b20b0)。)。第十三页,讲稿共六十五页哦几个术语几个术语 基因型:基因型:1000101110110101000111 表现型:表现型:0.637197 编码解码个体(染色体)基因第十四页,讲稿共六十五页哦初始种群初始种群 SGA采用随机方法生成若干个个采用随机方法生成若干个个体的集合,该集合称为初始种群。初体的集合,该集合称为初始种群。初始种群中个体的数量称为种群规模。始种群中个体的数量称为种群规模。第十五页,讲稿共六十五页哦 适应度函数适应度函数 遗传算法对一个个体(解)的好坏用适遗传算法对一个个体(解)的好坏用适应度函数值来评价,适应度函数值越大,解应度函数值来评
9、价,适应度函数值越大,解的质量越好。适应度函数是遗传算法进化过的质量越好。适应度函数是遗传算法进化过程的驱动力,也是进行自然选择的唯一标准,程的驱动力,也是进行自然选择的唯一标准,它的设计应结合求解问题本身的要求而定。它的设计应结合求解问题本身的要求而定。第十六页,讲稿共六十五页哦选择算子选择算子 遗传算法使用选择运算来实现对群体中的个体遗传算法使用选择运算来实现对群体中的个体遗传算法使用选择运算来实现对群体中的个体遗传算法使用选择运算来实现对群体中的个体进行优胜劣汰操作:适应度高的个体被遗传到下一进行优胜劣汰操作:适应度高的个体被遗传到下一进行优胜劣汰操作:适应度高的个体被遗传到下一进行优胜
10、劣汰操作:适应度高的个体被遗传到下一代群体中的概率大;适应度低的个体,被遗传到下代群体中的概率大;适应度低的个体,被遗传到下代群体中的概率大;适应度低的个体,被遗传到下代群体中的概率大;适应度低的个体,被遗传到下一代群体中的概率小。选择操作的任务就是按某种一代群体中的概率小。选择操作的任务就是按某种一代群体中的概率小。选择操作的任务就是按某种一代群体中的概率小。选择操作的任务就是按某种方法从父代群体中选取一些个体,遗传到下一代群方法从父代群体中选取一些个体,遗传到下一代群方法从父代群体中选取一些个体,遗传到下一代群方法从父代群体中选取一些个体,遗传到下一代群体。体。体。体。SGASGA中选择算
11、子采用轮盘赌选择方法。中选择算子采用轮盘赌选择方法。中选择算子采用轮盘赌选择方法。中选择算子采用轮盘赌选择方法。第十七页,讲稿共六十五页哦轮盘赌选择方法轮盘赌选择方法 轮盘赌选择又称比例选择算子,它的基本思想是:各轮盘赌选择又称比例选择算子,它的基本思想是:各轮盘赌选择又称比例选择算子,它的基本思想是:各轮盘赌选择又称比例选择算子,它的基本思想是:各个个体被选中的概率与其适应度函数值大小成正比。设群个个体被选中的概率与其适应度函数值大小成正比。设群个个体被选中的概率与其适应度函数值大小成正比。设群个个体被选中的概率与其适应度函数值大小成正比。设群体大小为体大小为体大小为体大小为n n,个体,个
12、体,个体,个体i i 的适应度为的适应度为的适应度为的适应度为 F Fi i,则个体,则个体,则个体,则个体i i 被选中遗传到被选中遗传到被选中遗传到被选中遗传到下一代群体的概率为:下一代群体的概率为:下一代群体的概率为:下一代群体的概率为:第十八页,讲稿共六十五页哦轮盘赌选择方法的实现步骤轮盘赌选择方法的实现步骤(1 1 1 1)计算群体中所有个体的适应度函数值(需要解码);计算群体中所有个体的适应度函数值(需要解码);计算群体中所有个体的适应度函数值(需要解码);计算群体中所有个体的适应度函数值(需要解码);(2 2 2 2)利用比例选择算子的公式,计算每个个体被选中遗传利用比例选择算子
13、的公式,计算每个个体被选中遗传利用比例选择算子的公式,计算每个个体被选中遗传利用比例选择算子的公式,计算每个个体被选中遗传到下一代群体的概率;到下一代群体的概率;到下一代群体的概率;到下一代群体的概率;(3 3 3 3)采用模拟赌盘操作(即生成采用模拟赌盘操作(即生成采用模拟赌盘操作(即生成采用模拟赌盘操作(即生成0 0 0 0到到到到1 1 1 1之间的随机数与之间的随机数与之间的随机数与之间的随机数与每个个体遗传到下一代群体的概率进行匹配)来确定各每个个体遗传到下一代群体的概率进行匹配)来确定各每个个体遗传到下一代群体的概率进行匹配)来确定各每个个体遗传到下一代群体的概率进行匹配)来确定各
14、个个体是否遗传到下一代群体中。个个体是否遗传到下一代群体中。个个体是否遗传到下一代群体中。个个体是否遗传到下一代群体中。第十九页,讲稿共六十五页哦交叉算子交叉算子 所谓交叉运算,是指对两个相互配对的染色体所谓交叉运算,是指对两个相互配对的染色体所谓交叉运算,是指对两个相互配对的染色体所谓交叉运算,是指对两个相互配对的染色体依据交叉概率依据交叉概率依据交叉概率依据交叉概率 P Pc c 按某种方式相互交换其部分基因,按某种方式相互交换其部分基因,按某种方式相互交换其部分基因,按某种方式相互交换其部分基因,从而形成两个新的个体。交叉运算是遗传算法区别于从而形成两个新的个体。交叉运算是遗传算法区别于
15、从而形成两个新的个体。交叉运算是遗传算法区别于从而形成两个新的个体。交叉运算是遗传算法区别于其他进化算法的重要特征,它在遗传算法中起关键作其他进化算法的重要特征,它在遗传算法中起关键作其他进化算法的重要特征,它在遗传算法中起关键作其他进化算法的重要特征,它在遗传算法中起关键作用,是产生新个体的主要方法。用,是产生新个体的主要方法。用,是产生新个体的主要方法。用,是产生新个体的主要方法。SGASGA中交叉算子采中交叉算子采中交叉算子采中交叉算子采用单点交叉算子。用单点交叉算子。用单点交叉算子。用单点交叉算子。第二十页,讲稿共六十五页哦单点交叉运算单点交叉运算 交叉前:交叉前:00000|0111
16、000000001000011100|00000111111000101交叉后:交叉后:00000|0000011111100010111100|01110000000010000交叉点第二十一页,讲稿共六十五页哦变异算子变异算子 所谓变异运算,是指依据变异概率所谓变异运算,是指依据变异概率所谓变异运算,是指依据变异概率所谓变异运算,是指依据变异概率 P Pm m 将个体将个体将个体将个体编码串中的某些基因值用其它基因值来替换,从而形编码串中的某些基因值用其它基因值来替换,从而形编码串中的某些基因值用其它基因值来替换,从而形编码串中的某些基因值用其它基因值来替换,从而形成一个新的个体。遗传算法
17、中的变异运算是产生新个成一个新的个体。遗传算法中的变异运算是产生新个成一个新的个体。遗传算法中的变异运算是产生新个成一个新的个体。遗传算法中的变异运算是产生新个体的辅助方法,它决定了遗传算法的局部搜索能力,体的辅助方法,它决定了遗传算法的局部搜索能力,体的辅助方法,它决定了遗传算法的局部搜索能力,体的辅助方法,它决定了遗传算法的局部搜索能力,同时保持种群的多样性。交叉运算和变异运算的相互同时保持种群的多样性。交叉运算和变异运算的相互同时保持种群的多样性。交叉运算和变异运算的相互同时保持种群的多样性。交叉运算和变异运算的相互配合,共同完成对搜索空间的全局搜索和局部搜索。配合,共同完成对搜索空间的
18、全局搜索和局部搜索。配合,共同完成对搜索空间的全局搜索和局部搜索。配合,共同完成对搜索空间的全局搜索和局部搜索。SGASGA中变异算子采用基本位变异算子。中变异算子采用基本位变异算子。中变异算子采用基本位变异算子。中变异算子采用基本位变异算子。第二十二页,讲稿共六十五页哦基本位变异算子基本位变异算子 基本位变异算子是指对个体编码串随机指基本位变异算子是指对个体编码串随机指基本位变异算子是指对个体编码串随机指基本位变异算子是指对个体编码串随机指定的某一位或某几位基因作变异运算。对于基定的某一位或某几位基因作变异运算。对于基定的某一位或某几位基因作变异运算。对于基定的某一位或某几位基因作变异运算。
19、对于基本遗传算法中用二进制编码符号串所表示的个本遗传算法中用二进制编码符号串所表示的个本遗传算法中用二进制编码符号串所表示的个本遗传算法中用二进制编码符号串所表示的个体,若需要进行变异操作的某一基因座上的原体,若需要进行变异操作的某一基因座上的原体,若需要进行变异操作的某一基因座上的原体,若需要进行变异操作的某一基因座上的原有基因值为有基因值为有基因值为有基因值为0 0,则变异操作将其变为,则变异操作将其变为,则变异操作将其变为,则变异操作将其变为1 1;反之,;反之,;反之,;反之,若原有基因值为若原有基因值为若原有基因值为若原有基因值为1 1,则变异操作将其变为,则变异操作将其变为,则变异
20、操作将其变为,则变异操作将其变为0 0。第二十三页,讲稿共六十五页哦基本位变异算子的执行过程基本位变异算子的执行过程 变异前:变异前:000001110000000010000变异后:变异后:000001110001000010000变异点第二十四页,讲稿共六十五页哦运行参数运行参数(1)M :种群规模种群规模(2)T :遗传运算的终止进化代数遗传运算的终止进化代数(3)Pc :交叉概率交叉概率(4)Pm:变异概率变异概率 第二十五页,讲稿共六十五页哦SGA的框图的框图 产生初始群体产生初始群体是否满足停止准则是否满足停止准则是是输出结果并结束输出结果并结束计算个体适应度值计算个体适应度值比例
21、选择运算比例选择运算单点交叉运算单点交叉运算基本位变异运算基本位变异运算否否产生新一代群体产生新一代群体执行M/2次第二十六页,讲稿共六十五页哦3、遗传算法的特点、遗传算法的特点(1)群体搜索,易于并行化处理;)群体搜索,易于并行化处理;(2)不是盲目穷举,而是启发式搜索;)不是盲目穷举,而是启发式搜索;(3)适应度函数不受连续、可微等条件的约束,)适应度函数不受连续、可微等条件的约束,适用范围很广。适用范围很广。第二十七页,讲稿共六十五页哦二、遗传算法原理1 1、遗传算法的数学基础遗传算法的数学基础 2 2、遗传算法的收敛性分析遗传算法的收敛性分析 3 3、遗传算法的改进遗传算法的改进 第二
22、十八页,讲稿共六十五页哦1 1、遗传算法的数学基础遗传算法的数学基础(1 1)模式定理)模式定理 (2 2)积木块假设)积木块假设 第二十九页,讲稿共六十五页哦模式模式 模式是指种群个体基因串中的相似样板,模式是指种群个体基因串中的相似样板,它用来描述基因串中某些特征位相同的结构。它用来描述基因串中某些特征位相同的结构。在二进制编码中,模式是基于三个字符集在二进制编码中,模式是基于三个字符集(0,1,*)的字符串,符号的字符串,符号*代表任意字符,即代表任意字符,即 0 或者或者 1。模式示例:模式示例:10*1第三十页,讲稿共六十五页哦两个定义两个定义定义定义1:模式:模式 H 中确定位置的
23、个数称为模式中确定位置的个数称为模式 H 的阶,记作的阶,记作O(H)。例如。例如O(10*1)=3。定义定义2:模式:模式 H 中第一个确定位置和最后一个确中第一个确定位置和最后一个确定位置之间的距离称为模式定位置之间的距离称为模式 H 的定义距,记作的定义距,记作(H)。例如。例如(10*1)=4。第三十一页,讲稿共六十五页哦模式的阶和定义距的含义模式的阶和定义距的含义 模式阶用来反映不同模式间确定性的差模式阶用来反映不同模式间确定性的差异,模式阶数越高,模式的确定性就越高,所异,模式阶数越高,模式的确定性就越高,所匹配的样本数就越少。在遗传操作中,即使阶匹配的样本数就越少。在遗传操作中,
24、即使阶数相同的模式,也会有不同的性质,而模式的数相同的模式,也会有不同的性质,而模式的定义距就反映了这种性质的差异。定义距就反映了这种性质的差异。第三十二页,讲稿共六十五页哦模式定理模式定理 模式定理:具有低阶、短定义距以及平均模式定理:具有低阶、短定义距以及平均适应度高于种群平均适应度的模式在子代中呈适应度高于种群平均适应度的模式在子代中呈指数增长。指数增长。模式定理保证了较优的模式(遗传算法模式定理保证了较优的模式(遗传算法的较优解)的数目呈指数增长,为解释遗传的较优解)的数目呈指数增长,为解释遗传算法机理提供了数学基础。算法机理提供了数学基础。第三十三页,讲稿共六十五页哦模式定理模式定理
25、 从模式定理可看出,有高平均适应度、短定义距、从模式定理可看出,有高平均适应度、短定义距、从模式定理可看出,有高平均适应度、短定义距、从模式定理可看出,有高平均适应度、短定义距、低阶的模式,在连续的后代里获得至少以指数增长的低阶的模式,在连续的后代里获得至少以指数增长的低阶的模式,在连续的后代里获得至少以指数增长的低阶的模式,在连续的后代里获得至少以指数增长的串数目,这主要是因为选择使最好的模式有更多的复串数目,这主要是因为选择使最好的模式有更多的复串数目,这主要是因为选择使最好的模式有更多的复串数目,这主要是因为选择使最好的模式有更多的复制,交叉算子不容易破坏高频率出现的、短定义长的制,交叉
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 遗传 算法 原理 应用 讲稿
限制150内