遗传算法经典实例代码_经典算法研究系列 之 深入浅出遗传算法

99d5bb2aade5c03166e2bd84b4059eda.gif关注数学,关注AI,关注我们公众号ID:Math-AIe6c4e8145887be6f33ac4c0421e0859d.png99d5bb2aade5c03166e2bd84b4059eda.gif91a8351db8b5d0babccae0b30f7b7f33.gif

391cffd5ab8d5aa5fbb41ac901c13baa.png

经典算法研究系列

遗传算法

1

初探遗传算法

Ok,先看维基百科对遗传算法所给的解释:

遗传算法是计算数学中用于解决最优化的搜索算法,是进化算法的一种。进化算法最初是借鉴了进化生物学中的一些现象而发展起来的,这些现象包括遗传、突变、自然选择以及杂交等。

遗传算法通常实现方式为一种计算机模拟。对于一个最优化问题,一定数量的候选解(称为个体)的抽象表示(称为染色体)的种群向更好的解进化。传统上,解用二进制表示(即0和1的串),但也可以用其他表示方法。进化从完全随机个体的种群开始,之后一代一代发生。在每一代中,整个种群的适应度被评价,从当前种群中随机地选择多个个体(基于它们的适应度),通过自然选择和突变产生新的生命种群,该种群在算法的下一次迭代中成为当前种群。

光看定义,可能思路并不清晰,咱们来几个清晰的图解、步骤、公式:

基本遗传算法的框图:

5943913af23bbfc502cac2a8501e377c.png

所以,遗传算法基本步骤是:

1)  初始化   t←0进化代数计数器;T是最大进化代数;随机生成M个个体作为初始群体    P(t);

2)  个体评价 计算P(t)中各个个体的适应度值;

3)  选择运算 将选择算子作用于群体;

4)  交叉运算 将交叉算子作用于群体;

5)  变异运算 将变异算子作用于群体,并通过以上运算得到下一代群体P(t + 1);

6)  终止条件判断  t≦T:t← t+1 转到步骤2;

        t>T:终止 输出解。 

好的,看下遗传算法的伪代码实现:

▲Procedures  GA:   伪代码

3e556d54f07fabb2b7bb0126b06e7611.png

2

深入遗传算法

1、智能优化算法概述

智能优化算法又称现代启发式算法,是一种具有全局优化性能、通用性强且适合于并行处理的算法。

这种算法一般具有严密的理论依据,而不是单纯凭借专家经验,理论上可以在一定的时间内找到最优解或近似最优解。 

遗传算法属于智能优化算法之一。 

常用的智能优化算法有:

遗传算法 、模拟退火算法、禁忌搜索算法、粒子群算法、蚁群算法。

(本经典算法研究系列,日后将陆续阐述模拟退火算法、粒子群算法、蚁群算法。)

2、遗传算法概述

遗传算法是由美国的J. Holland教授于1975年在他的专著《自然界和人工系统的适应性》中首先提出的。

借鉴生物界自然选择和自然遗传机制的随机化搜索算法。 

模拟自然选择和自然遗传过程中发生的繁殖、交叉和基因突变现象。

在每次迭代中都保留一组候选解,并按某种指标从解群中选取较优的个体,利用遗传算子(选择、交叉和变异)对这些个

体进行组合,产生新一代的候选解群,重复此过程,直到满足某种收敛指标为止。 

基本遗传算法(Simple Genetic Algorithms,GA)又称简单遗传算法或标准遗传算法),是由Goldberg总结出的一种最基本的遗传算法,其遗传进化操作过程简单,容易理解,是其它一些遗传算法的雏形和基础。

3、基本遗传算法的组成

(1)编码(产生初始种群)

(2)适应度函数

(3)遗传算子(选择、交叉、变异)

(4)运行参数

接下来,咱们分门别类,分别阐述着基本遗传算法的五个组成部分:

1)编码

遗传算法(GA)通过某种编码机制把对象抽象为由特定符号按一定顺序排成的串。

正如研究生物遗传是从染色体着手,而染色体则是由基因排成的串。

基本遗传算法(SGA)使用二进制串进行编码。 

初始种群:基本遗传算法(SGA)采用随机方法生成若干个个体的集合,该集合称为初始种群。

初始种群中个体的数量称为种群规模。

2)适应度函数 

遗传算法对一个个体(解)的好坏用适应度函数值来评价,适应度函数值越大,解的质量越好。

适应度函数是遗传算法进化过程的驱动力,也是进行自然选择的唯一标准,

它的设计应结合求解问题本身的要求而定。 

3.1、选择算子

遗传算法使用选择运算对个体进行优胜劣汰操作。

适应度高的个体被遗传到下一代群体中的概率大;适应度低的个体,被遗传到下一代群体中的概率小。

选择操作的任务就是从父代群体中选取一些个体,遗传到下一代群体。

基本遗传算法(SGA)中选择算子采用轮盘赌选择方法。

Ok,下面就来看下这个轮盘赌的例子,这个例子通俗易懂,对理解选择算子帮助很大。

f6298c3cd211416874e14a834c8f4174.png

轮盘赌选择方法
轮盘赌选择又称比例选择算子,其基本思想是:
各个个体被选中的概率与其适应度函数值大小成正比。

设群体大小为N,个体xi 的适应度为 f(xi),则个体xi的选择概率为:

fedb2c698d566bb6f98f00e8ef7b6e43.png

轮盘赌选择法可用如下过程模拟来实现:

(1)在[0, 1]内产生一个均匀分布的随机数r。
(2)若r≤q1,则染色体x1被选中。
(3)若qk-1其中的qi称为染色体xi (i=1, 2, …, n)的积累概率, 其计算公式为:

329abafcd39f042c9e3aa03b439c33e9.png

积累概率实例: 

78ade54695f89d9c870eec3a03eeb551.png

轮盘赌选择方法的实现步骤:
(1)计算群体中所有个体的适应度值;
(2)计算每个个体的选择概率;
(3)计算积累概率;
(4)采用模拟赌盘操作(即生成0到1之间的随机数与每个个体遗传到下一代群体的概率进行匹配)
来确定各个个体是否遗传到下一代群体中。

例如,有染色体
s1= 13 (01101)
s2= 24 (11000) 
s3= 8   (01000)
s4= 19 (10011)

假定适应度为f(s)=s^2 ,则
f (s1) = f(13) = 13^2 = 169
f (s2) = f(24) = 24^2 = 576
f (s3) = f(8) = 8^2 = 64
f (s4) = f(19) = 19^2 = 361

染色体的选择概率为:

cab0ffec2d8d1b4db658566fa9fee85b.png

染色体的累计概率为:

fefd208266052e10edde9e4029caf055.png

根据上面的式子,可得到:

a9db74a2283889e4d127a193663c7fbb.png

例如设从区间[0, 1]中产生4个随机数: 

   r1 = 0.450126,    r2 = 0.110347 

   r3 = 0.572496,    r4 = 0.98503 

f565e6b5b2d7508827df13a20a8f74ea.png

3.2、交叉算子

交叉运算,是指对两个相互配对的染色体依据交叉概率 Pc 按某种方式相互交换其部分基因,
从而形成两个新的个体。

交叉运算是遗传算法区别于其他进化算法的重要特征,它在遗传算法中起关键作用,
是产生新个体的主要方法。
基本遗传算法(SGA)中交叉算子采用单点交叉算子。

单点交叉运算

e0a4f50d0ccd31d27e9fd29587799011.png

3.3、变异算子 

变异运算,是指改变个体编码串中的某些基因值,从而形成新的个体。
变异运算是产生新个体的辅助方法,决定遗传算法的局部搜索能力,保持种群多样性。

交叉运算和变异运算的相互配合,共同完成对搜索空间的全局搜索和局部搜索。
基本遗传算法(SGA)中变异算子采用基本位变异算子。

基本位变异算子是指对个体编码串随机指定的某一位或某几位基因作变异运算。
对于二进制编码符号串所表示的个体,若需要进行变异操作的某一基因座上的原有基因值为0,
则将其变为1;反之,若原有基因值为1,则将其变为0 。

基本位变异算子的执行过程:

7a3456a92c714298ed3b110982463a3a.png

4)运行参数

(1)M  :种群规模 
(2)T  :遗传运算的终止进化代数 
(3)Pc  :交叉概率 
(4)Pm :变异概率

3

浅出遗传算法

遗传算法的本质

遗传算法本质上是对染色体模式所进行的一系列运算,即通过选择算子将当前种群中的优良模式遗传
到下一代种群中,利用交叉算子进行模式重组,利用变异算子进行模式突变。
通过这些遗传操作,模式逐步向较好的方向进化,最终得到问题的最优解。

遗传算法的主要有以下八方面的应用:
(1)组合优化      (2)函数优化 (3)自动控制      (4)生产调度 
(5)图像处理      (6)机器学习 (7)人工生命      (8)数据挖掘

4

遗传算法的应用

遗传算法的应用举例、透析本质(这个例子简明、但很重要)

已知x为整数,利用遗传算法求解区间[0, 31]上的二次函数y=x2的最大值。

6287d6c18e046408f71c3869fce784c4.png

[分析]

原问题可转化为在区间[0, 31]中搜索能使 y 取最大值的点 a 的问题。
个体:[0, 31] 中的任意点x
适应度:函数值f(x)=x2
解空间:区间[0, 31]

这样, 只要能给出个体x的适当染色体编码, 该问题就可以用遗传算法来解决。

[解]

(1) 设定种群规模,编码染色体,产生初始种群。
将种群规模设定为4;用5位二进制数编码染色体;取下列个体组成初始种群S1

s1= 13 (01101),  s2= 24 (11000)
s3= 8 (01000),    s4= 19 (10011) 

(2) 定义适应度函数, 取适应度函数
f (x)=x^2

(3) 计算各代种群中的各个体的适应度, 并对其染色体进行遗传操作,
直到适应度最高的个体,即31(11111)出现为止。

首先计算种群S1中各个体:
s1= 13(01101),    s2= 24(11000)
s3= 8(01000),      s4= 19(10011)
的适应度f (si), 容易求得:
f (s1) = f(13) = 13^2 = 169
f (s2) = f(24) = 24^2 = 576
f (s3) = f(8) = 8^2 = 64
f (s4) = f(19) = 19^2 = 361

再计算种群S1中各个体的选择概率:

78c8cb598ad63abb82f5ad571099959f.png

由此可求得
P(s1) = P(13) = 0.14
P(s2) = P(24) = 0.49
P(s3) = P(8) = 0.06
P(s4) = P(19) = 0.31

再计算种群S1中各个体的积累概率:

ff8eb9af3b9b013c155867bf269d8592.png

选择-复制 

设从区间[0, 1]中产生4个随机数如下:
r1 = 0.450126,     r2 = 0.110347 
r3 = 0.572496,     r4 = 0.98503

dd41a04efc30b9a576534507abf6e54c.png

于是,经复制得群体:
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中共有
5×4×0.001=0.02
位基因可以变异。
0.02位显然不足1位,所以本轮遗传操作不做变异。

于是,得到第二代种群S2:
s1=11001(25),   s2=01100(12)
s3=11011(27),   s4=10000(16)

第二代种群S2中各染色体的情况:

70d4649e81c0d7b396197b6e4777ff19.png

假设这一轮选择-复制操作中,种群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中各染色体的情况:

cd3b1cf46b9c1e363396713b1d9162da.png

设这一轮的选择-复制结果为:

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),  s4’’=10000(16)

这一轮仍然不会发生变异。

于是,得第四代种群S4: 

s1=11111(31)(出现最优解),  s2=11100(28)

s3=11000(24),  s4=10000(16)

显然,在这一代种群中已经出现了适应度最高的染色体s1=11111。

于是,遗传操作终止,将染色体(11111)作为最终结果输出。

然后,将染色体“11111”解码为表现型,即得所求的最优解:31。

将31代入函数y=x2中,即得原问题的解,即函数y=x2的最大值为961。 

所以,综合以上各代群的情况,如下:

85016446dd3bf203e0d857e2284c5751.png

END2e919107af18a5edf0d6cedd4a8acc6b.png

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/304489.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java buffalo_随你怎么玩!Buffalo 网络硬盘新潮流

现代时尚的办公环境是怎样的?ADSL、无线网络、笔记本、还有咖啡,惬意地被沙发包裹起来,自由自在地网上冲浪……;当然仅仅有这些还是不够,我们需要视频会议、需要网络下载、甚至打印、扫描,还有需要随时随地…

.NET gRPC核心功能初体验

gRPC是高性能的RPC框架, 有效地用于服务通信(不管是数据中心内部还是跨数据中心)。由Google开源,目前是一个Cloud Native Computing Foundation(CNCF)孵化项目。其功能包括:•双向流•强大的二进制序列化•可插拔的身份…

为什么我怎么也理解不了波粒二象性,是因为智商不够吗?

大家好,各位观众。如果你们之前不能完全理解波粒二象性(现象本身,或者这个概念的内涵和外延)。不用担心,我认为十有八九不是智商问题:量子物理的内容有太多“反常识”了。很多时候,是我们的脑袋…

设备间的连线图例

转载于:https://blog.51cto.com/51fashion/243017

化学版2048,你玩过吗?内含游戏链接

今天来给大家推荐一款游戏——Na(钠),也可以叫它化学版2048。首先2048大家都不陌生,曾经火爆一时的小游戏,于14年由年仅19岁的意大利程序员加布里勒希鲁尼(Gabriele Cirulli)开发出来。2048游戏…

sqlsession.selectlist 会返回null么_StackOverflow经典问题:代码中如何去掉烦人的“!=nullquot;判空语句...

推荐阅读:程序员引路人:腾讯T4曰“面试不仅仅是技术过硬就可以了,你还需要懂得这些”​zhuanlan.zhihu.com问题为了避免空指针调用,我们经常会看到这样的语句if (someobject ! null) { someobject.doCalc();}最终,项…

如何在 ASP.Net Core 中使用 Configuration Provider

ASP.NET Core 是一个开源的,跨平台的,精简的模块化框架,可用于构建高性能,可扩展的web应用程序, ASP.NET Core 中的数据配置常用 k-v 的形式存储,值得注意的是,新的数据配置还支持 层级方式&…

GdiPlus[30]: IGPPen: 线帽

StartCap 和 EndCap 属性分别用来读写两段的线帽, 测试图:StartCap 和 EndCap 测试代码:uses GdiPlus;procedure TForm1.FormPaint(Sender: TObject); constCapArr: array[0..8] of Byte (0, 1, 2, 3, $10, $11, $12, $13, $14); varGraphics: IGPGraphics;Pen: IGPPen;Pt1,Pt…

你知道怎么样排序才能做到多快好省?

小智最近迷上了计算机算法,今天过来给大家讲讲排序算法。准备讲排序算法之前,我们还是要先回顾一下排序这个概念。排序是一门古老的科学。排序问题,用数学的方式可以表达如下问题输入:给定n个数,a1, a2, a3, ..., an…

C# 使用 Index 和 Range 简化集合操作

C# 使用 Index 和 Range 简化集合操作Intro有的语言数组的索引值是支持负数的,表示从后向前索引,比如:arr[-1]从 C# 8 开始,C# 支持了数组的反向 Index,和 Range 操作,反向 Index 类似于其他语言中的负索引…

我的小服务器

朋友做了一个工控机的板子,我要了一块来,自己加上了迅驰1.2G CPU,再从笔记本上拆了一个1G内存和老的移动硬盘 30G IDE,就算搭起了一个最简陋的服务器。此外我从破DVD光驱上拆了一块铁皮底板,打了几个洞,把主…

爱心助农|百万斤丑苹果紧急待售!谁能帮这些特困孩子熬过寒冷冬天?

题记:人们在猛兽横行的蛮荒年代,得以从树上回归地面,是人们守望相助的结果,也是人类能繁衍至今的原因在这个什么都讲究颜值的年代有这样一个东西却以“丑”、“但非常好吃”引起了我们的注意它便是山西临猗的冰糖心丑苹果还要一个…

微软开源AI诊断工具Error Analysis

喜欢就关注我们吧!Error Analysis 使用机器学习技术,助数据科学家更好地了解模型错误模式。在 2020 年 5 月的微软 Build 大会上,微软推出了三个响应式的 AI(Responsible AI,RAI)工具包,这三个工…

【SDL的编程】VC环境搭建

SDL(simple DirectMedia Layer)是一个可跨平台的开源库,最近由于自己的兴趣,就把它windosXP下的环境搭建了下。PC:Mircrosoft Windows XP Service Pack3Platform:Mircrosoft Visual C 6.0SourceCode&#x…

# 保持最外层获取焦点_大事件!沈阳爱尔白内障焕晶诊疗中心正式启用,两位PanOptix三焦点人工晶体植入患者清晰见证!...

近日,沈阳爱尔眼科医院大东院区白内障焕晶诊疗中心正式投入使用!由沈阳爱尔眼科医院大东院区业务院长朱建勋领衔的白内障手术团队始终与国内外一流水准保持同步,开创性引进了爱尔康AcrySof IQ PanOptix 新一代三焦点人工晶状体。中心最先入住…

使用 Tye 辅助开发 k8s 应用竟如此简单(六)

续上篇,这篇我们来进一步探索 Tye 更多的使用方法。本篇我们将进一步研究 Tye 与分布式应用程序运行时 Dapr 如何碰撞出更精彩的火花。巧了,巧了,真是巧了 今天正值 dapr 1.0 发布的日子。如果你暂时还不了解什么是 dapr。那不如通过以下简短…

BeetleX.WebFamily针对Web SPA应用的改进

BeetleX.WebFamily1.0在集成vueelementaxios的基础上添加应用页、窗体布局和登陆验证等功能。通过以上功能开发Web SPA应用时只需要编写vue控件和配置菜单即可实现应用开发。使用创建一个.net控制台项目,然后通过Nuget引入BeetleX.WebFamily1.0组件,并在…

php acl rbac,建站常用的用户权限管理模型ACL和RBAC的区别

常用的权限管理模型ACL和RBAC的区别1.ACLACL是最早也是最基本的一种访问控制机制,它的原理非常简单:每一项资源,都配有一个列表,这个列表记录的就是哪些用户可以对这项资源执行CRUD中的那些操作。当系统试图访问这项资源时&#x…

华为年终奖,小员工分百万!任正非:钱给多了,不是人才也变成了人才!

华为今年又提前发了巨额年终奖,并公布了新的奖金方案,23级奖金额有近百万,并且宣称“上不封顶、绝不拖欠”,一时间引起热议。任正非签发的内部文件:华为不搞按资排辈,只要做出突出贡献,在新方案…

Redis缓存穿透、缓存雪崩、缓存击穿好好说说

前言 Redis是目前非常流行的缓存数据库啦,其中一个主要作用就是为了避免大量请求直接打到数据库,以此来缓解数据库服务器压力;用上缓存难道就高枕无忧了吗?no,no,no,没有这么完美的技术, 缓存穿透、缓存雪崩…