




已阅读5页,还剩7页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
一、初探遗传算法维基百科对遗传算法所给的解释:遗传算法是计算数学中用于解决最优化的搜索算法,是进化算法的一种。进化算法最初是借鉴了进化生物学中的一些现象而发展起来的,这些现象包括遗传、突变、自然选择以及杂交等。 遗传算法通常实现方式为一种计算机模拟。对于一个最优化问题,一定数量的候选解(称为个体)的抽象表示(称为染色体)的种群向更好的解进化。传统上,解用二进制表示(即0和1的串),但也可以用其他表示方法。进化从完全随机个体的种群开始,之后一代一代发生。在每一代中,整个种群的适应度被评价,从当前种群中随机地选择多个个体(基于它们的适应度),通过自然选择和突变产生新的生命种群,该种群在算法的下一次迭代中成为当前种群。基本遗传算法的框图:遗传算法基本步骤是:1) 初始化t0进化代数计数器;T是最大进化代数;随机生成M个个体作为初始群体P(t);2)个体评价计算P(t)中各个个体的适应度值;3)选择运算将选择算子作用于群体;4)交叉运算将交叉算子作用于群体;5)变异运算将变异算子作用于群体,并通过以上运算得到下一代群体P(t+1);6)终止条件判断tT:tt+1转到步骤2;tT:终止输出解。好的,看下遗传算法的伪代码实现:ProceduresGA:伪代码begininitializeP(0);t=0;/t是进化的代数,一代、二代、三代.while(t=T)dofori=1toMdo /M是初始种群的个体数EvaluatefitnessofP(t); /计算P(t)中各个个体的适应度endforfori=1toMdoSelectoperationtoP(t);/将选择算子作用于群体endforfori=1toM/2doCrossoveroperationtoP(t);/将交叉算子作用于群体endforfori=1toMdoMutationoperationtoP(t);/将变异算子作用于群体endforfori=1toMdoP(t+1)=P(t);/得到下一代群体P(t+1)endfort=t+1;/终止条件判断tT:tt+1转到步骤2endwhileend二、深入遗传算法1、智能优化算法概述智能优化算法又称现代启发式算法,是一种具有全局优化性能、通用性强且适合于并行处理的算法。这种算法一般具有严密的理论依据,而不是单纯凭借专家经验,理论上可以在一定的时间内找到最优解或近似最优解。遗传算法属于智能优化算法之一。常用的智能优化算法有:遗传算法、模拟退火算法、禁忌搜索算法、粒子群算法、蚁群算法。(本经典算法研究系列,日后将陆续阐述模拟退火算法、粒子群算法、蚁群算法。)2、遗传算法概述遗传算法是由美国的J.Holland教授于1975年在他的专著自然界和人工系统的适应性中首先提出的。借鉴生物界自然选择和自然遗传机制的随机化搜索算法。模拟自然选择和自然遗传过程中发生的繁殖、交叉和基因突变现象。在每次迭代中都保留一组候选解,并按某种指标从解群中选取较优的个体,利用遗传算子(选择、交叉和变异)对这些个体进行组合,产生新一代的候选解群,重复此过程,直到满足某种收敛指标为止。基本遗传算法(SimpleGeneticAlgorithms,GA)又称简单遗传算法或标准遗传算法),是由Goldberg总结出的一种最基本的遗传算法,其遗传进化操作过程简单,容易理解,是其它一些遗传算法的雏形和基础。3、基本遗传算法的组成(1)编码(产生初始种群)(2)适应度函数(3)遗传算子(选择、交叉、变异)(4)运行参数1、编码遗传算法(GA)通过某种编码机制把对象抽象为由特定符号按一定顺序排成的串。正如研究生物遗传是从染色体着手,而染色体则是由基因排成的串。基本遗传算法(SGA)使用二进制串进行编码。初始种群:基本遗传算法(SGA)采用随机方法生成若干个个体的集合,该集合称为初始种群。初始种群中个体的数量称为种群规模。2、适应度函数遗传算法对一个个体(解)的好坏用适应度函数值来评价,适应度函数值越大,解的质量越好。适应度函数是遗传算法进化过程的驱动力,也是进行自然选择的唯一标准,它的设计应结合求解问题本身的要求而定。3.1、选择算子遗传算法使用选择运算对个体进行优胜劣汰操作。适应度高的个体被遗传到下一代群体中的概率大;适应度低的个体,被遗传到下一代群体中的概率小。选择操作的任务就是从父代群体中选取一些个体,遗传到下一代群体。基本遗传算法(SGA)中选择算子采用轮盘赌选择方法。轮盘赌选择又称比例选择算子,其基本思想是:各个个体被选中的概率与其适应度函数值大小成正比。设群体大小为N,个体xi 的适应度为 f(xi),则个体xi的选择概率为:轮盘赌选择法可用如下过程模拟来实现:(1)在0, 1内产生一个均匀分布的随机数r。(2)若rq1,则染色体x1被选中。(3)若qk-1rqk(2kN), 则染色体xk被选中。其中的qi称为染色体xi (i=1, 2, , n)的积累概率, 其计算公式为:轮盘赌选择方法的实现步骤:(1)计算群体中所有个体的适应度值;(2)计算每个个体的选择概率;(3)计算积累概率;(4)采用模拟赌盘操作(即生成0到1之间的随机数与每个个体遗传到下一代群体的概率进行匹配)来确定各个个体是否遗传到下一代群体中。例如,有染色体s1= 13 (01101)s2= 24 (11000)s3= 8 (01000)s4= 19 (10011)假定适应度为f(s)=s2 ,则f (s1) = f(13) = 132 = 169f (s2) = f(24) = 242 = 576f (s3) = f(8) = 82 = 64f (s4) = f(19) = 192 = 361根据上面的式子,可得到:例如设从区间0,1中产生4个随机数:r1=0.450126,r2=0.110347r3=0.572496,r4=0.985033.2、交叉算子交叉运算,是指对两个相互配对的染色体依据交叉概率 Pc 按某种方式相互交换其部分基因,从而形成两个新的个体。交叉运算是遗传算法区别于其他进化算法的重要特征,它在遗传算法中起关键作用,是产生新个体的主要方法。基本遗传算法(SGA)中交叉算子采用单点交叉算子。单点交叉运算3.3、变异算子变异运算,是指改变个体编码串中的某些基因值,从而形成新的个体。变异运算是产生新个体的辅助方法,决定遗传算法的局部搜索能力,保持种群多样性。交叉运算和变异运算的相互配合,共同完成对搜索空间的全局搜索和局部搜索。基本遗传算法(SGA)中变异算子采用基本位变异算子。基本位变异算子是指对个体编码串随机指定的某一位或某几位基因作变异运算。对于二进制编码符号串所表示的个体,若需要进行变异操作的某一基因座上的原有基因值为0,则将其变为1;反之,若原有基因值为1,则将其变为0 。基本位变异算子的执行过程:4、运行参数(1)M :种群规模(2)T : 遗传运算的终止进化代数(3)Pc :交叉概率(4)Pm :变异概率三、浅出遗传算法遗传算法的本质遗传算法本质上是对染色体模式所进行的一系列运算,即通过选择算子将当前种群中的优良模式遗传到下一代种群中,利用交叉算子进行模式重组,利用变异算子进行模式突变。通过这些遗传操作,模式逐步向较好的方向进化,最终得到问题的最优解。遗传算法的主要有以下八方面的应用:(1)组合优化 (2)函数优化 (3)自动控制 (4)生产调度(5)图像处理 (6)机器学习 (7)人工生命 (8)数据挖掘四、遗传算法的应用遗传算法的应用举例、透析本质(这个例子简明、但很重要)已知x为整数,利用遗传算法求解区间0,31上的二次函数y=x2的最大值。分析原问题可转化为在区间0, 31中搜索能使 y 取最大值的点 a 的问题。个体:0, 31 中的任意点x适应度:函数值f(x)=x2解空间:区间0, 31这样, 只要能给出个体x的适当染色体编码, 该问题就可以用遗传算法来解决。解(1)设定种群规模,编码染色体,产生初始种群。将种群规模设定为4;用5位二进制数编码染色体;取下列个体组成初始种群S1s1= 13 (01101), s2= 24 (11000)s3= 8 (01000), s4= 19 (10011)(2) 定义适应度函数, 取适应度函数f (x)=x2(3) 计算各代种群中的各个体的适应度, 并对其染色体进行遗传操作,直到适应度最高的个体,即31(11111)出现为止。首先计算种群S1中各个体:s1= 13(01101), s2= 24(11000)s3= 8(01000), s4= 19(10011)的适应度f (si), 容易求得:f (s1) = f(13) = 132 = 169f (s2) = f(24) = 242 = 576f (s3) = f(8) = 82 = 64f (s4) = f(19) = 192 = 361再计算种群S1中各个体的选择概率:由此可求得P(s1) = P(13) = 0.14P(s2) = P(24) = 0.49P(s3) = P(8) = 0.06P(s4) = P(19) = 0.31再计算种群S1中各个体的积累概率:选择-复制设从区间0, 1中产生4个随机数如下:r1 = 0.450126, r2 = 0.110347r3 = 0.572496, r4 = 0.98503于是,经复制得群体:s1 =11000(24), s2 =01101(13)s3 =11000(24)(24被选中俩次), s4 =10011(19)交叉设交叉率pc=100%,即S1中的全体染色体都参加交叉运算。设s1与s2配对,s3与s4配对。s1 =11000(24), s2 =01101(13)s3 =11000(24), s4 =10011(19)分别交换后两位基因,得新染色体:s1=11001(25), s2=01100(12)s3=11011(27), s4=10000(16)变异设变异率pm=0.001。这样,群体S1中共有540.001=0.02位基因可以变异。0.02位显然不足1位,所以本轮遗传操作不做变异。于是,得到第二代种群S2:s1=11001(25), s2=01100(12)s3=11011(27), s4=10000(16)第二代种群S2中各染色体的情况:假设这一轮选择-复制操作中,种群S2中的4个染色体都被选中,则得到群体:s1=11001(25), s2= 01100(12)s3=11011(27), s4= 10000(16)做交叉运算,让s1与s2,s3与s4 分别交换后三位基因,得 s1=11100(28), s2 = 01001(9) s3 =11000(24), s4 = 10011(19)这一轮仍然不会发生变异。于是,得第三代种群S3:s1=11100(28), s2=01001(9)s3=11000(24), s4=10011(19)第三代种群S3中各染色体的情况:设这一轮的选择-复制结果为:s1=11100(28),s2=11100(28)s3=11000(24),s4=10011(19)做交叉运算,让s1与s4,s2与s3分别交换后两位基因,得s1=11111(31),s2=11100(28)s3=11000(24
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 安全培训题库建设方案及答案解析
- 换罐清渣工培训考核试卷及答案
- 铁合金湿法冶炼工应急处置考核试卷及答案
- 道岔钳工招聘考核试卷及答案
- 贵金属首饰制作工效率提升考核试卷及答案
- 创业公司财务部职责与财务规划
- 轴承制造工三级安全教育(班组级)考核试卷及答案
- 顽皮的小蝌蚪课件
- 2025医疗器械采购协议
- 劳动项目九 小小图书管理员说课稿-2025-2026学年小学劳动人教版五年级上册-人教版
- 1《我三十万大军胜利南渡长江》跨学科公开课一等奖创新教案统编版语文八年级上册
- 工程概算、预算、结算审核报告模板
- 2025至2030年中国不锈钢氢退丝行业投资前景及策略咨询报告
- 《民营经济促进法》全文学习解读
- 江西省防雷减灾白皮书 (2024年)
- 2025年新疆风力发电市场调查报告
- 面向新质生产力培育的科技成果转化策略与实践路径
- 2025年江西遂川县城发投资集团有限公司下属子公司招聘笔试参考题库含答案解析
- 布袋除尘器吊装方案
- 《人工智能:AIGC基础与应用》高职全套教学课件
- 装修公司全包装修合同
评论
0/150
提交评论