请看动态图: https://github.com/neozhaoliang/pywonderland/raw/master/img/wilson.gif
这个图演示的是概率论中的一个随机算法,叫做 Wilson 算法,它生成一个完美迷宫(即一个生成树),而且这个迷宫是在所有完美迷宫中等概率地随机选取的,UST 这个单词的意思是 uniform spanning tree
的简写,即服从一致分布的生成树。
生成迷宫后根据每个顶点与起点的距离对迷宫进行染色,使用的是宽度优先搜索算法。
整个动态图是用 python 一次生成的,不调用任何外部程序和第三方模块。(字体文件没有办法,这是必须的,不过如果不嵌入文本,只生成迷宫的话则不需要此文件)。只要你安装了纯净版的 python2 或者 python3,那么不需要安装任何依赖即可运行。
程序运行时间一般不超过半分钟,生成的动态图一般在 1M 左右,一般包含 1000 - 5000 帧。(是的你没看错,就是这么拽)
项目之前在论坛上发过,不过这次玩了一点新花样。当然最精彩的永远在后面。下一个项目双曲蜂巢正在紧张制作中。
1
z0z 2017-10-10 14:30:36 +08:00
我除了回复还能干什么
|
2
mathzhaoliang OP @z0z 术业有专攻啊。每个人用 python 干的事情是不一样的,我只是选了一个比较少有人玩的方向。
|
3
lieh222 2017-10-10 14:41:02 +08:00
一脸蒙蔽的进来,一脸蒙蔽的出去
|
4
z0z 2017-10-10 14:42:29 +08:00
@mathzhaoliang 多谢安慰啊。突然想起来了,大神请移步到这里 https://www.v2ex.com/t/395736#reply3 可否点拨一下文中的那个连接实现计算极限功能的大概原理?
|
5
BBCCBB 2017-10-10 14:44:19 +08:00
cool
|
6
mathzhaoliang OP @z0z 它那个网站只是调用了后台的一个程序(我猜他是用了 mathematica,不过也可能用的是自己写的其它程序)
。 处理多项式,微分,积分这些属于符号计算的领域(记得吴文俊的机器证明吗?),符号计算有一套自己的算法来表示和研究数学对象,它与通常进行数值计算的科学计算器很不一样。比如分解多项式,它就是先在有限域上计算(有限域运算比较慢,但是不存在精度损失的问题),然后回到实数域上。插值的方法也很常用,但是不是你想的那种用法。 |
7
xrlin 2017-10-10 14:50:52 +08:00
厉害
|
9
vtwoextb 2017-10-10 15:01:22 +08:00
一脸蒙蔽的进来,一脸蒙蔽的出去
|
10
SakuraSa 2017-10-10 15:02:16 +08:00
很 cool,不知道能不能放出源码供大家学习一下?
|
11
z0z 2017-10-10 15:05:22 +08:00
|
13
CEBBCAT 2017-10-10 15:17:28 +08:00 via Android
好棒!我要在我们 Minecraft 服务器用这个做多层迷宫
|
14
dalang 2017-10-10 15:20:26 +08:00
cool
|
15
malkavia 2017-10-10 15:35:02 +08:00
github 已 star
好厉害 |
17
mathzhaoliang OP @CEBBCAT 这个方法比常用的 Prim, Kruskal 算法要慢,它的关键在于生成的迷宫服从一致分布。你在游戏里面用这个算法估计会很慢 。。。
|
18
CEBBCAT 2017-10-10 17:17:31 +08:00
@mathzhaoliang #17 (●'◡'●),人工识图盖迷宫
|
19
Mcatt 2017-10-10 17:21:37 +08:00
厉害
|
20
liyang803 2017-10-10 17:22:37 +08:00
一脸蒙蔽的进来,一脸蒙蔽的出去
|
21
linuxchild 2017-10-10 17:51:21 +08:00
一脸蒙蔽的进来,一脸蒙蔽的出去
|
22
cbiqih 2017-10-10 17:56:03 +08:00
一脸蒙蔽的出去,再一脸蒙蔽的进来~
|
23
ashin 2017-10-10 18:27:38 +08:00
厉害
|
24
xiaozizayang 2017-10-10 20:01:43 +08:00
很早就看到大佬的项目 继续膜拜
|
25
newworld 2017-10-10 20:19:51 +08:00
已 star https://github.com/neozhaoliang
真大佬...收下我的膝盖!哈哈哈 |
26
ranleng 2017-10-10 20:22:44 +08:00
一脸蒙蔽的进来,一脸蒙蔽的思考,一脸蒙蔽的出去.
(先 star 了.. 明天研究研究 |
27
mathzhaoliang OP |
28
Chingim 2017-10-10 21:57:06 +08:00
数学好的都是真大神
|
29
zingl 2017-10-10 22:09:27 +08:00
还以为是能生成 python 脚本的新东西
|
30
yang2yang 2017-10-10 22:20:54 +08:00
膜拜大佬
|
31
Tunar 2017-10-11 08:57:08 +08:00 via Android
很 coooooool !
|
32
lxy42 2017-10-11 09:36:21 +08:00
厉害
|
33
zjddp 2017-10-11 12:18:07 +08:00
第 2500 star 已送上
|
34
mathzhaoliang OP @zjddp 哇,谢谢!!
|
35
zhangzixu 2017-10-11 13:55:16 +08:00
学习学习
|
36
sennes 2017-10-11 17:33:17 +08:00
挺有趣的 |
37
mathzhaoliang OP @sennes 很棒!怎么做到在回复里面贴图片的?
|
38
mathzhaoliang OP @sennes 我知道了。你是传到新浪图库然后用 md 格式引入的。。。
|
39
sennes 2017-10-12 11:24:18 +08:00
@mathzhaoliang #36
Hello 如果是新浪图库的话 直接贴地址就行了 不需要加 Markdown 格式 另外我用的是一款叫 V2EX plus 的 Chrome 插件 可以直接在回复中插图的 |
40
sennes 2017-10-12 11:59:33 +08:00
|
41
mathzhaoliang OP @sennes 可以当头像吗?我看 V2EX 允许 GIF 格式的图片,但是上传动图作为头像会报错吧?
|
42
sennes 2017-10-12 14:29:55 +08:00
@mathzhaoliang #39 哈哈有些网站支持 gif 动图头像的。
|
43
mathzhaoliang OP @sennes 我在这个项目下的另一个程序 Reaction Diffusion Simulation 也可以用来生成字符动态图:
http://wxt.sinaimg.cn/thumb300/4e130e36ly1fkgoanosrmg205k02snmt.gif?tags=%5B%5D |
44
mathzhaoliang OP |
45
sennes 2017-10-13 18:04:41 +08:00
@mathzhaoliang #42 好 我研究一下!
|
46
f8281113 2017-10-13 23:08:45 +08:00
一脸蒙蔽的进来,一脸蒙蔽的出去 ^v^
|
47
dd0754 2017-10-14 00:02:06 +08:00
一脸蒙蔽的进来,一脸蒙蔽的出去
|
48
wisetc 2017-10-15 17:42:09 +08:00
高深
|
49
buyaoshuohua 2017-10-23 11:31:10 +08:00
一脸蒙蔽的进来,一脸蒙蔽的出去
|