您的位置:首页 > 理论基础 > 计算机网络

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

2016-04-02 11:32 295 查看
   最近在学习有关遗传算法和神经网络方面的知识,网上查看了很多这方面的秘笈,只怪小生天生愚钝、才疏学浅,不能很好的领悟秘笈中的真谛,往往被弄得晕头转向、不知所措



。直到有一天无意中看到了博主zzwu写的有关这方面的文章,初读之,如温旧习;渐深入,觉甚好;遂一气呵成,犹如拨云见日、茅塞顿开。余甚怕在茫茫Internet中再无机会拜读之,遂收藏于此,以便众人观之,绝无其他不良用途。在此对博主再次深表感谢。

博文转自:http://blog.csdn.net/zzwu/article/details/561630

.

.






(连载之九)



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

 清华大学出版社

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完-
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息