康威生命游戏
此条目过于依赖第一手来源。 (2023年9月9日) |
康威生命游戏(英语:Conway's Game of Life),又称康威生命棋,是英国数学家约翰·何顿·康威在1970年发明的细胞自动机。
它最初于1970年10月在《科学美国人》杂志上马丁·葛登能的“数学游戏”专栏出现。[1]
规则
[编辑]生命游戏中,对于任意细胞,规则如下:
- 每个细胞有两种状态 - 存活或死亡,每个细胞与以自身为中心的周围八格细胞产生互动(如图,黑色为存活,白色为死亡)
- 当前细胞为存活状态时,当周围的存活细胞低于2个时(不包含2个),该细胞变成死亡状态。(模拟生命数量稀少)
- 当前细胞为存活状态时,当周围有2个或3个存活细胞时,该细胞保持原样。
- 当前细胞为存活状态时,当周围有超过3个存活细胞时,该细胞变成死亡状态。(模拟生命数量过多)
- 当前细胞为死亡状态时,当周围有3个存活细胞时,该细胞变成存活状态。(模拟繁殖)
可以把最初的细胞结构定义为种子,当所有在种子中的细胞同时被以上规则处理后,可以得到第一代细胞图。按规则继续处理当前的细胞图,可以得到下一代的细胞图,周而复始。
概述
[编辑]生命游戏是一个零玩家游戏。它包括一个二维矩形世界,这个世界中的每个方格居住着一个活着的或死了的细胞。一个细胞在下一个时刻生死取决于相邻八个方格中活着的或死了的细胞的数量。如果相邻方格活着的细胞数量过多,这个细胞会因为资源匮乏而在下一个时刻死去;相反,如果周围活细胞过少,这个细胞会因太孤单而死去。实际中,玩家可以设定周围活细胞的数目怎样时才适宜该细胞的生存。如果这个数目设定过高,世界中的大部分细胞会因为找不到太多的活的邻居而死去,直到整个世界都没有生命;如果这个数目设定过低,世界中又会被生命充满而没有什么变化。
实际中,这个数目一般选取2或者3;这样整个生命世界才不至于太过荒凉或拥挤,而是一种动态的平衡。这样的话,游戏的规则就是:当一个方格周围有2或3个活细胞时,方格中的活细胞在下一个时刻继续存活;即使这个时刻方格中没有活细胞,在下一个时刻也会“诞生”活细胞。
在这个游戏中,还可以设定一些更加复杂的规则,例如当前方格的状况不仅由父一代决定,而且还考虑祖父一代的情况。玩家还可以作为这个世界的“上帝”,随意设定某个方格细胞的死活,以观察对世界的影响。
在游戏的进行中,杂乱无序的细胞会逐渐演化出各种精致、有形的结构;这些结构往往有很好的对称性,而且每一代都在变化形状。一些形状已经锁定,不会逐代变化。有时,一些已经成形的结构会因为一些无序细胞的“入侵”而被破坏。但是形状和秩序经常能从杂乱中产生出来。
这个游戏被许多计算机程序实现了。Unix世界中的许多骇客喜欢玩这个游戏,他们用字符代表一个细胞,在一个计算机屏幕上进行演化。比较著名的例子是,GNU Emacs编辑器中就包括这样一个小游戏。
稳定状态
[编辑]-
方块
-
面包
-
蜂巢
-
大船
-
小船
-
桶子
-
池塘
-
蛇
-
航空母舰
-
独木舟
-
芒果
-
回纹针
振荡状态
[编辑]-
信号灯(周期=2轮)
-
蟾蜍(周期=2轮)
-
红绿灯(周期=2轮)
-
烽火(周期=2轮)
-
脉冲星(周期=3轮)
-
慨影(周期=15轮)
会移动的振荡状态
[编辑]参见
[编辑]参考资料
[编辑]外部链接
[编辑]- Golly (页面存档备份,存于互联网档案馆)
- John Conway's Game of Life (页面存档备份,存于互联网档案馆)
- Conway's Game of Life simulator for Microsoft Windows
- Python版本并以彩色图像方式呈现于CMD中 (页面存档备份,存于互联网档案馆)
- Game of Life Applet (页面存档备份,存于互联网档案馆) (中国留学生编写的Applet)
- 用不到100行go 语言实现的网页版,用随机数初始化 (页面存档备份,存于互联网档案馆)
- Conway's game of life implementation. (Silverlight)
- JavaScript网页版本 (页面存档备份,存于互联网档案馆)
- 另一个JavaScript网页版本 (页面存档备份,存于互联网档案馆)
- 开源JavaScript网页版本 (页面存档备份,存于互联网档案馆)
- 高斯珀滑翔机枪 生命游戏介绍 在blogspot
- LifeWiki (页面存档备份,存于互联网档案馆),关于康威生命游戏的wiki