博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
笛卡尔遗传规划Cartesian Genetic Programming (CGP)简单理解(1)
阅读量:4324 次
发布时间:2019-06-06

本文共 1289 字,大约阅读时间需要 4 分钟。

初识遗传算法Genetic Algorithm(GA)

  遗传算法是计算数学中用于解决最优化的搜索算法,是进化算法的一种。进化算法借鉴了进化生物学中的一些现象而发展起来的,这些现象包括遗传、突变、自然选择以及杂交等,是一个通过计算机模拟解决最优化问题的过程,遗传算法从代表问题可能存在的一个解集的一个种群(population)开始的,一个种群由一定数量的候选解也称为个体(individual)组成,个体由基因(gene)编码而成,基因的表现形式实际上是每个个体上带有的染色体(chromosome) 染色体即为基因的集合,应用遗传算法的一般步骤是:1.需要实现表现形到基因型的编码工作,常用编码方法有二进制编码、格雷码编码、浮点编码和符号编码。2.进化从随机个体(初代种群)的种群开始,之后一代一代进化。按照优胜劣汰的准则在每一代中,评价整个种群的适应度(fitness),从当前种群中选择(selection)多个个体(基于它们的适应度)。3.借助于自然遗传学的遗传算子(genetic operators)进行组合交叉(crossover)变异(mutation) 产生新的种群,该种群在算法的下一次迭代中成为新的种群。4.在末代种群中的最优个体通过解码(decoding)产生最优解

框图

笛卡尔遗传规划介绍

  笛卡尔遗传规划源自 Miller 等人对进化数字电路的发展。1999 年出现了专门研究笛卡尔遗传规划的团队2000 年由 Miller 等人发表了Cartesian Genetic Programming,正式提出了笛卡尔遗传规划的一般形式。笛卡尔遗传规划由一个带索引节点的有向图表示,这是一个有n个输入m个输出的有向图(directed graph),其中输入节点的下标为 0 到 n-1,输出由最后一列的m个节点得到。有向图的每个节点都由 4 个正整数组成,其中包含 2 个输入位、1 个参数位和 1 个用来索引使用函数的函数索引位。每个节点通过两个输入、一个参数并通过所选函数计算出节点的输出。如图所示该个体的染色体的基因型由这些节点组成,有向图的大小为\(r\times c\),其中同一列的节点不可以互相连接,节点只能向前连接,不同列的节点的连接限制为Levels-back(例如Levels-back = 2 那么第i列的节点最多可以连接到i-2列)。不同个体之间可以交叉、变异等一系列遗传变换产生新的个体。

框图

通常选用具有一行任意列的纵深形式的CGP网络,一般来说节点函数的元数一般与节点输入个数相同

框图

Reference:

[1] Miller, Julian F. "Cartesian genetic programming." Cartesian Genetic Programming. Springer, Berlin, Heidelberg, 2011. 17-34. Online Tutorials:

未完待续。。。。。。。

转载于:https://www.cnblogs.com/Techdim/p/10653353.html

你可能感兴趣的文章
秒杀多线程第四篇 一个经典的多线程同步问题
查看>>
RocketMQ配置
查看>>
vs code调试console程序报错--preLaunchTask“build”
查看>>
蚂蚁金服井贤栋:用技术联手金融机构,形成服务小微的生态合力
查看>>
手机通话记录统计分析
查看>>
端口号大全
查看>>
机器学习基石笔记2——在何时可以使用机器学习(2)
查看>>
POJ 3740 Easy Finding (DLX模板)
查看>>
MySQL 处理重复数据
查看>>
关于typedef的用法总结(转)
查看>>
【strtok()】——分割字符串
查看>>
Linux下安装rabbitmq
查看>>
曹德旺
查看>>
【转】判断点在多边形内(matlab)
查看>>
java基础之集合:List Set Map的概述以及使用场景
查看>>
Python 线程 进程 协程
查看>>
iOS语言中的KVO机制
查看>>
excel第一次打开报错 向程序发送命令时出错 多种解决办法含终极解决方法
查看>>
响应式web设计之CSS3 Media Queries
查看>>
实验三
查看>>