遗传算法入门(连载之九)


(连载之九)

.
扎自<游戏编程中的人工智能技术>第三章


 清华大学出版社


3.4.5 运行找路径者程序 (Running the Pathfinder Program)

.......当你运行 Pathfinder 程序时,你将看到,程序不是每次都能找到一条通往出口的路径。 Bob 有时会被粘住在一个局部地区不确定地逗来逗去,如同一个喝醉了酒的人在试着寻找他的回家的路。这主要由于群体太快地收敛到一个特殊类型的染色体。这样,由于群体中的成员变得如此相似, crossover 算子的有益效应这时实际上已经不能发挥作用,所有发生的事情都是靠总量很少的变异 操作在起作用 。但因变异率设置很低,当染色体类型的差异消失后,仅仅依靠变异本身已不足以去发现一个解。另外,由于轮盘赌选择的工作方式,使得任何一代的最合适的染色体无法保证传到下一代。 这意味着,只要在适当时候,立即杀死这个成员,遗传算法就能在群体中找到一个几乎完全的解,但在这样做时,它将失去它所拥有的所有好的基因!在后面的章节中,我 将会谈到这些问题,并介绍一些技术来帮助维护基因组的差异性且同时能保留那些较好的基因组。但在这里,我首先需要花费一些时间来考察不同的编码方法,并考察它们怎样和你可能遇到的问题类型关联在一起。这就是我在下一个章中将要做的事情。 

3.4.6 二进制数转换问题的答案[见第98页]

 

l. .11011

2. .21

3.5 练习题(Stuff to Try)

 

........从现在开始,在每一章的后面,我都要给你出一些点子,让你按照它来编写出相应的游戏程序。我不强调这些程序本身有多么重要。但这是唯一能使你对那些算法产生“感性”认识的方法。而且,当你开始去做复杂的题目时,这种“感性”认识将变得非常重要。

1.  为杂交率,突变率,群体尺寸,染色体长度等参数设置各种不同的值来进行试验,观察它们对算法的效率有什么影响?

2.  试去掉杂交操作,而增加突变率,看会发生什么结果?如果单用杂交操作,而不利用突变,又会发生什么?

3. 修改适应性分数的计算函数,使多次进入同一小格的染色体得到惩罚。这应该导致更有效的到出口的路径。

4. 你能想到另外的什么办法使路径的寻找更为有效吗?

-连载9完-

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值