遗传算法初探

遗传算法
首先进行基因编码,就是将基因型映射到表现型
采用浮点数编码
例如一个二进制串<1000101110110101000111>表示实数值 0.637197

std::vector 是 STL(standard template library)库里面的现成的模板类。
它用起来就像动态数组。利用 vector(容器)我们可以方便而且高效的对容器
里面的元素进行操作。示例如下:

  1. //添加头文件,并使用 std 名空间。
  2. #include
  3. using namespace std;
  4. //定义一个 vector,<>内的是这个 vector 所装载的类型。
  5. vector MyVector;
  6. //为 vector 后面添加一个整型元素 0。
  7. MyVector.push_back(0);
  8. //把 vector 的第一个元素的值赋给变量 a。值得注意的是如果 vector 的长度只有 1,
    而你
  9. //去访问它的下一个元素的话,编译和运行都不会报错,它会返回一个随机值给你,
    所以使
  10. //用的时候一定要注意这个潜伏的 BUG。
    20.21. int a = MyVector[0];
  11. //把 vector 里面的元素全部清空。
  12. MyVector.clear();
  13. //返回 vector 里面的元素的个数。
  14. MyVector.size()
    使用轮盘赌的方式完成对于劣等个体的筛选
    基因重组/交叉
    二进制编码:―随机把其中几个位于同一位置的编码进行交换,产生新的个体

浮点数编码
子代编码值=父代编码值+α(母方编码值-父方编码值)α=[0,1]
基因突变
二进制编码:随机取反
浮点数编码:减去(加上)一个小随机数

其在神经网络中的应用
首先随机产生一种分布,选用一种编码方案对神经网络中的超参数进行编码。因此在网络结构和学习规则已定的前提下,一条编码链对应确定的一个神经网络。
然后计算每个神经网络的误差函数,确定其适应度函数,选择适应度最大的网络结构遗传给下一代,并且进行基因重组交叉和变异。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

孤舟丨笠翁

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值