cnCalc计算器论坛

 找回密码
 注册
搜索
查看: 3429|回复: 12

VB 生命游戏

[复制链接]
发表于 2010-8-19 16:08:27 | 显示全部楼层 |阅读模式
  1. 'VB 生命游戏
  2. Const Size = 100
  3. Const Dis = 80
  4. Dim A(0 To Size + 1, 0 To Size + 1) As Boolean
  5. Private Sub Form_Load()
  6. Dim I As Long, J As Long
  7. Picture1.Width = Size * Dis + 300
  8. Picture1.Height = Size * Dis + 300
  9. Picture1.DrawWidth = Dis / 20 + 1
  10. Randomize
  11. 'For I = 1 To Size
  12. 'For J = 1 To Size
  13. '    A(I, J) = (Rnd() < 0.4)
  14. 'Next J
  15. 'Next I
  16. For I = Size / 2 - 15 To Size / 2 + 15
  17. For J = Size / 2 - 15 To Size / 2 + 15
  18.     A(I, J) = (Rnd() < 0.6)
  19. Next J
  20. Next I
  21. 'For I = Size / 2 - 35 To Size / 2 + 35
  22. '    A(I, Size / 2) = True
  23. 'Next I
  24. 'For I = 0 To Size + 1
  25. '    A(I, Size / 2) = True
  26. 'Next I
  27. End Sub
  28. Private Sub Timer1_Timer()
  29.     Dim I As Long, J As Long, M As Long, N As Long, Num As Long
  30.     Dim B(1 To Size, 1 To Size) As Boolean
  31.     DoEvents
  32.     For I = 1 To Size
  33.     For J = 1 To Size
  34.         If A(I, J) Then Num = -1 Else Num = 0
  35.         For M = I - 1 To I + 1
  36.         For N = J - 1 To J + 1
  37.             If A(M, N) Then Num = Num + 1
  38.         Next N
  39.         Next M
  40.         Select Case Num
  41.         Case 2
  42.             B(I, J) = A(I, J)
  43.         Case 3
  44.             B(I, J) = True
  45.         Case Else
  46.             B(I, J) = False
  47.         End Select
  48.     Next J
  49.     Next I
  50.     For I = 1 To Size
  51.     For J = 1 To Size
  52.         If B(I, J) Then Picture1.PSet (Dis * (I + 1), Dis * (J + 1)), vbBlue Else Picture1.PSet (Dis * (I + 1), Dis * (J + 1)), vbWhite
  53.         A(I, J) = B(I, J)
  54.     Next J
  55.     Next I
  56.    
  57.     For I = 1 To Size
  58.         A(0, I) = B(Size, I)
  59.         A(Size + 1, I) = B(1, I)
  60.         A(I, 0) = B(I, Size)
  61.         A(I, Size + 1) = B(I, 1)
  62.     Next I
  63. End Sub

复制代码
发表于 2010-8-19 17:04:34 | 显示全部楼层
很有趣的游戏
能提供运行程序(windows)或图形计算器(如9860)版本的程序吗?
 楼主| 发表于 2010-8-19 19:15:34 | 显示全部楼层
我的电脑上有病毒,你要exe吗?
发表于 2010-8-19 21:00:32 | 显示全部楼层
我想知道这是什么意思。。。
发表于 2010-8-20 08:55:46 | 显示全部楼层
发上来:

MD5:F455C86CA0EB1A9D716E35479AE49E7C
SHA1:9195C042F20FC689F0C28C613B7214863030AA66

VBLife.rar

3.98 KB, 下载次数: 29

发表于 2010-8-25 12:54:13 | 显示全部楼层
还挺有趣的
若可以自动生成一些细胞构型就好了
发表于 2010-8-25 18:42:13 | 显示全部楼层
要是LZ能多加一些模拟自然条件的子程序会更有趣
发表于 2010-8-26 10:34:41 | 显示全部楼层
这东西怎么玩???
发表于 2010-8-26 11:30:55 | 显示全部楼层
看不懂……
发表于 2010-8-26 12:19:00 | 显示全部楼层
这东西怎么玩???
zhj 发表于 2010-8-26 10:34
这个是零玩家的程序
百科介绍:


生命游戏是英国数学家约翰·何顿·康威在1970年发明的细胞自动机。它最初于1970年10月在《科学美国人》杂志中马丁·葛登能的“数学游戏”专栏出现。
[编辑本段]
概述  生命游戏其实是一个零玩家游戏。它包括一个二维矩形世界,这个世界中的每个方格居住着一个活着的或死了的细胞。一个细胞在下一个时刻生死取决于相邻八个方格中活着的或死了的细胞的数量。如果相邻方格活着的细胞数量过多,这个细胞会因为资源匮乏而在下一个时刻死去;相反,如果周围活细胞过少,这个细胞会因太孤单而死去。实际中,你可以设定周围活细胞的数目怎样时才适宜该细胞的生存。如果这个数目设定过高,世界中的大部分细胞会因为找不到太多的活的邻居而死去,直到整个世界都没有生命;如果这个数目设定过低,世界中又会被生命充满而没有什么变化。实际中,这个数目一般选取2或者3;这样整个生命世界才不至于太过荒凉或拥挤,而是一种动态的平衡。这样的话,游戏的规则就是:当一个方格周围有2或3个活细胞时,方格中的活细胞在下一个时刻继续存活;即使这个时刻方格中没有活细胞,在下一个时刻也会“诞生”活细胞。在这个游戏中,还可以设定一些更加复杂的规则,例如当前方格的状况不仅由父一代决定,而且还考虑祖父一代的情况。你还可以作为这个世界的God,随意设定某个方格细胞的死活,以观察对世界的影响。
  在游戏的进行中,杂乱无序的细胞会逐渐演化出各种精致、有形的结构;这些结构往往有很好的对称性,而且每一代都在变化形状。一些形状已经锁定,不会逐代变化。有时,一些已经成形的结构会因为一些无序细胞的“入侵”而被破坏。但是形状和秩序经常能从杂乱中产生出来。
  这个游戏被许多计算机程序实现了。Unix世界中的许多Hacker喜欢玩这个游戏,他们用字符代表一个细胞,在一个计算机屏幕上进行演化。著名的GNU Emacs编辑器中就包括这样一个小游戏。
[编辑本段]
原理  细胞自动机(又称元胞自动机),名字虽然很深奥,但是它的行为却是非常美妙的。所有这些怎样实现的呢?我们可以把计算机中的宇宙想象成是一堆方格子构成的封闭空间,尺寸为N的空间就有N*N个格子。而每一个格子都可以看成是一个生命体,每个生命都有两种状态,如果该格子生就显示兰色,死则显示白色。每一个格子旁边都有邻居格子存在,如果我们把3*3的9个格子构成的正方形看成一个基本单位的话,那么这个正方形中心的格子的邻居就是它旁边的8个格子。
  每个格子的生死遵循下面的原则:
  1. 如果一个细胞周围有3个细胞为生(一个细胞周围共有8个细胞),则该细胞为生(即该细胞若原先为死,则转为生,若原先为生,则保持不变) 。
  2. 如果一个细胞周围有2个细胞为生,则该细胞的生死状态保持不变;
  3. 在其它情况下,该细胞为死(即该细胞若原先为生,则转为死,若原先为死,则保持不变设定图像中每个像素的初始状态后依据上述的游戏规则演绎生命的变化,由于初始状态和迭代次数不同,将会得到令人叹服的优美图案)。
  这样就把这些若干个格子(生命体)构成了一个复杂的动态世界。运用简单的3条作用规则构成的群体会涌现出很多意想不到的复杂性为,这就是复杂性科学的研究焦点。
  细胞自动机有一个通用的形式化的模型,每个格子(或细胞)的状态可以在一个有限的状态集合S中取值,格子的邻居范围是一个半径r,也就是以这个格子为中心,在距离它r远的所有格子构成了这个格子的邻居集合,还要有一套演化规则,可以看成是一个与该格子当前状态以及邻居状态相关的一个函数,可以写成f:S*S^((2r)^N-1)->S。这就是细胞自动机的一般数学模型。
  最早研究细胞自动机的科学家是冯·诺伊曼,后来康韦发明了上面展示的这个最有趣的细胞自动机程序:《生命游戏》,而wolfram则详尽的讨论了一维世界中的细胞自动机的所有情况,认为可以就演化规则f进行自动机的分类,而只有当f满足一定条件的时候,系统演化出来的情况才是有活力的,否则不是因为演化规则太死板而导致生命的死亡,就是因为演化规则太复杂而使得随机性无法克服,系统乱成一锅粥,没有秩序。后来人工生命之父克里斯·朗顿进一步发展了元胞自动机理论。并认为具有8个有限状态集合的自动机就能够涌现出生命体的自复制功能。他根据不同系统的演化函数f,找到了一个参数lamda用以描述f的复杂性,得出了结论只有当lamda比混沌状态的lamda相差很小的时候,复杂的生命活系统才会诞生,因此,朗顿称生命诞生于“混沌的边缘”!并从此开辟了“人工生命”这一新兴的交叉学科!
  如今细胞自动机已经在地理学、经济学、计算机科学等领域得到了非常广泛的应用!
发表于 2010-8-26 16:16:24 | 显示全部楼层
懂了
这个程序很快就会达到稳定状态的……
 楼主| 发表于 2010-8-28 17:51:42 | 显示全部楼层
调节开头的几个常数以及timer1试试看
发表于 2010-8-30 09:58:48 | 显示全部楼层
运行时错误?

溢出?
您需要登录后才可以回帖 登录 | 注册

本版积分规则

Archiver|手机版|cnCalc计算器论坛

GMT+8, 2024-4-19 11:49 , Processed in 0.080868 second(s), 24 queries .

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表