生命游戏与遗传编程

作者: A7TuG3 | 来源:发表于2014-11-24 09:37 被阅读254次
生命游戏与遗传编程生命游戏与遗传编程

今天在一本书中读到一个很神奇的故事,在九十年代,生物学家Thomas S. Ray写过一个80条指令的病毒,并把这条病毒放在计算机里面『培养』,这些病毒不断复制和变异,变化出了各种不可思议的变种,比如在几十亿次运行之后,出现了仅仅有22条指令却有完善功能的病毒,当时麻省理工的科学家尝试用最短的指令来写一只病毒,却还是用了31条指令。

指令的多少关系到对计算机资源的索取,所以45条指令的病毒比80条指令的病毒更具优势,这位生物学家调整了计算机规则,给不同指令的病毒分配不同的资源,以达到某种『平等』,但是在一百五十亿次『繁衍』之后,出现了一种36条指令的病毒,这个病毒很『狡猾』,他在末尾多占用了一个字节,以『骗取』了多一倍的运行资源,结果横扫了整个系统。

作者还提出一种设想,让计算机程序也在运行中做到生物那样的自我进化,非人为的变得越来越人性化,比如Word,在你每次用完它之后就会默默的自我更新以达到更漂亮的外观和更人性化的体验,当然,前提是你应该为这些『程序生物』的繁衍设定一些规则。

看到这些神奇的东西,我感到我多年的计算机知识白学了。我立马开始搜索这方面的资料,我的感受是,这个世界太奇妙了。

『让计算机模拟生物进化』一直以来都是计算机科学和生物学的课题,事实上,早在1970年,美国数学家John Horton Conway就发明了一种『细胞自动机』,这也被称之为『生命游戏』。


生命游戏生命游戏

生命游戏是一个零玩家游戏。它包括一个二维矩形世界,这个世界中的每个方格居住着一个活着的或死了的细胞。一个细胞在下一个时刻生死取决于相邻八个方格中活着的或死了的细胞的数量。如果相邻方格活着的细胞数量过多,这个细胞会因为资源匮乏而在下一个时刻死去;相反,如果周围活细胞过少,这个细胞会因太孤单而死去。实际中,玩家可以设定周围活细胞的数目怎样时才适宜该细胞的生存。如果这个数目设定过高,世界中的大部分细胞会因为找不到太多的活的邻居而死去,直到整个世界都没有生命;如果这个数目设定过低,世界中又会被生命充满而没有什么变化。

实际中,这个数目一般选取2或者3;这样整个生命世界才不至于太过荒凉或拥挤,而是一种动态的平衡。这样的话,游戏的规则就是:当一个方格周围有2或3个活细胞时,方格中的活细胞在下一个时刻继续存活;即使这个时刻方格中没有活细胞,在下一个时刻也会“诞生”活细胞。

在这个游戏中,还可以设定一些更加复杂的规则,例如当前方格的状况不仅由父一代决定,而且还考虑祖父一代的情况。玩家还可以作为这个世界的“上帝”,随意设定某个方格细胞的死活,以观察对世界的影响。

在游戏的进行中,杂乱无序的细胞会逐渐演化出各种精致、有形的结构;这些结构往往有很好的对称性,而且每一代都在变化形状。一些形状已经锁定,不会逐代变化。有时,一些已经成形的结构会因为一些无序细胞的“入侵”而被破坏。但是形状和秩序经常能从杂乱中产生出来。

显然Thomas S. Ray的『病毒生物』比生命游戏中的这些『细胞』更加强大,它们运行在计算机系统中而非软件中,换言之,它们更加『高级一层』,所以这些病毒造成的变异更加神奇,而不仅仅是生命游戏中的形状体现。很遗憾我没有找到Thomas S. Ray的病毒样本 Thomas S. Ray的项目主页是:这里,有下载,有论文,自取。不过我找到了好几款现在还可以运行的生命游戏,有兴趣的不妨看看:这个,还有个程序员在Conway的生命游戏的基础上进行了更多的设置,使得其更加复杂有趣,这个『高级版』可以在这找到:这里

后来我知道,Thomas S. Ray的程序其实属于遗传编程(GP)的范畴,按照百科的解释,遗传编程是一种特殊的利用进化算法的机器学习技术, 它开始于一群由随机生成的千百万个计算机程序组成的"人群",然后根据一个程序完成给定的任务的能力来确定某个程序的适合度,应用达尔文的自然选择(适者生存)确定胜出的程序,计算机程序间也模拟两性组合,变异,基因复制,基因删除等代代进化,直到达到预先确定的某个中止条件为止。

复杂的生命形式可以通过最简单的规则来进行演化,生命之奇妙莫过于此。更直观的感受可以通过以下一个五分钟的小视频来感受:

视频

算法是人写的,可是演化却是人所不能控制的,这种由简单规律和大量个体智慧共同作用的结合让我想到了分布式计算和大数据,我们炒的很火的新概念,其实早就根植于我们进化的基因当中,而拥有强大运算能力的现代计算机,则是潘多拉的魔盒,我们通过它来研究生命,但是里面也充满着未知。

我们所有计算机老师都告诉我们计算机是最老实的,你让它做什么它就做什么,可是计算机也有不老实的时候,某些时候,计算机的『失控』比『受控』更加令人兴奋。

失控的计算机,带来的是崭新的世界,诸如人工智能,进化模拟等等领域,我们需要的正是出乎我们预料的结果。

其实我也一直好奇,是什么让这些变异发生?让这些进化开启?让人所写的程序变得不被人理解?想来,这个原因应该和我们之所以从细胞进化到人,而又从石器时代走到信息时代的原因一样,这个原因就是生命之与世界的奥秘。

能够知道这些奇妙的东西真是太爽了。

相关文章

  • 生命游戏与遗传编程

    今天在一本书中读到一个很神奇的故事,在九十年代,生物学家Thomas S. Ray写过一个80条指令的病毒,并把这...

  • 遗传编程

    本文内容主要参考《集体智慧编程》和遗传编程。遗传编程非常详细,极力推荐。 遗传编程是收到生物进化理论的启发而形成的...

  • 3.1 生物学基础

    心理发展的生物学基础 1、遗传与基因 2、生命的开始 一、遗传与基因 1、细胞:身体的最小结构单位 2、染色体:遗...

  • 简单的细胞自动机

    使用python实现康威生命游戏Conway's game of life参考《python极客项目编程》wiki...

  • 生如夏花

    生命就像一场游戏,游戏里绝不允许你平淡的过下去,生命也是如此,生命与游戏的最大差距就是游戏可以重来,生命却决不可以...

  • 生命是什么——362许仕浩

    生命就像一场游戏,游戏里绝不允许你平淡的过下去,生命也是如此,生命与游戏的最大差距就是游戏可以重来,生命却决不可以...

  • "程序编写程序"的一个尝试:遗传编程

    本文最早发表本人博客:http://www.gotoli.us/?p=1773 遗传编程是遗传算法另一个重要的后续...

  • 【Minecraft】The State of Art:Mine

    Minecraft与编程 Minecraft 中文名:我的世界,已近成为了一款风靡与全球的沙盒类游戏,在游戏中玩家...

  • 哪个游戏编程培训机构教的好

    游戏编程师由于收入高,一直以来也是热门职业,所以想要学习游戏编程的人也越来越多,游戏编程培训学校也越来越多,游戏编...

  • 遗传力

    遗传力(Heritability)又称遗传率。遗传力是指遗传方差在表型方差(总方差,即遗传方差与环境方差的...

网友评论

  • d042aa0c83aa:Stephen Wolfram早年就痴迷过这个生命游戏
  • 楊小杉:想起了菲利普迪克的《Second Variety》
  • LostAbaddon:记得以前看到过,不但在软件领域有这样的生命游戏,有些已经开始做硬件了。
    他们用一些最简单的芯片通过一定的规则组合在一起,并控制一些可重组的外设装备,然后将这些“机械昆虫”丢到一个环境中,结果他发现这些“机械昆虫”最后知道如何在那些环境中行走了。
  • LostAbaddon:以前还在学校的时候,每年都会重写一个生命游戏,给予不同的规则和变种,设置不同的变异与繁衍规则,来看结果怎么样。
    有一阵子真的是非常痴迷这个啊~~~

本文标题:生命游戏与遗传编程

本文链接:https://www.haomeiwen.com/subject/swewtttx.html