魔方吧·中文魔方俱乐部

 找回密码
 注册
搜索
热搜: 魔方
查看: 257169|回复: 39

介绍 SokoFind 【2014年更新:v2.0.2中文版发布】 [复制链接]

Rank: 7Rank: 7Rank: 7

积分
2010
帖子
1577
精华
3
UID
91928
性别
保密

超级搬运工 六年元老

发表于 2009-7-21 23:03:17 |显示全部楼层
本帖最后由 sokoban 于 2014-2-5 13:01 编辑

SokoFind是Sokoban兄和我写的一个关卡搜查程序。
得到Sokoban兄的鼎力支持和帮忙, SokoFind才可以面世。
在此感谢Sokoban兄。

最新版本下载地址:
http://sokoban.ws/utility/sokofind.php


目前只有英文版本, 将来或者会出中文版本。

用法:

1。  输入关卡图案到“XSB Pattern”窗口。
2。  选择搜查路径。
3。  选择比较百分率; 默认100%。
4。  点击“Begin Search”开始搜查。结果会出现在“Output”窗口。

注: 在(1)提到的“关卡图案”不需要是正规的关卡。
          (如: 关卡图案可以没有‘人’或‘箱子’。)
          但一定是要XSB格式。

XSB Pattern 例子:
##########
##---#--##
##...$$-##
##...#---#
##...#$--#
##...#---#
######---#
#----#---#
#----#---#
#----#---#
##########





----#####
----#--@#
###-#$$-#
#.#-#-$-#
#.###-###
#.----##-
#--#---#-
####---#-
---#####-








sokofind.png


[ 本帖最后由 anian 于 2009-10-28 11:52 编辑 ]

[ 本帖最后由 sokoban 于 2011-11-8 10:42 编辑 ]
已有 1 人评分经验 收起 理由
sokoban + 15 原创内容

总评分: 经验 + 15   查看全部评分

Rank: 3Rank: 3

积分
814
帖子
721
精华
0
UID
79869
性别
发表于 2009-7-21 23:04:24 |显示全部楼层
这个是推箱子么?不懂的路过~~~
层先25单次16.09八板单次0.83最快平均0.886

使用道具 举报

Rank: 7Rank: 7Rank: 7

积分
5265
帖子
3218
精华
19
UID
13140
性别

论坛建设奖 八年元老

发表于 2009-7-22 09:06:01 |显示全部楼层
这个程序的核心算法是 anian 兄完成的,所有旋转和翻转都会比较,还能随意设置匹配比例,基本上没有漏网之鱼了。我只是写了一些 Windows 界面的代码。

[ 本帖最后由 sokoban 于 2009-7-22 09:07 编辑 ]

使用道具 举报

Rank: 8Rank: 8

积分
1918
帖子
588
精华
5
UID
145
性别

魔方破解达人 八年元老

发表于 2009-7-22 09:53:54 |显示全部楼层
再问,八个方向比较,每个方向要进行各种覆盖程度的许多次比较,最后取最大相似值吗?
所以关卡大小(长,宽)有些出入,也没有关系吗。

现在程序的用途是某人要从看到的某一图案到题库去找题目。
那么比对这一图案的一个局部也就可以了。
再进一步,我只要输入图案中某一行中的一段,进行字符串包含查找,就应该能找了,当然只输一行只要找4个方向。最后得出有限的一个列表,可以由人再去筛选。我目前是这样做的。当然我选择的图案中某一行中的一段,是我觉的比较有特点的内容,有时也要试几次。

另一种要求,就是在一万题规模的题库中自动寻找哪几关相似的问题。
我目前是整行及整列比较,也就是说如果题目行列都发生变化的情况,我就找不到了。这样也能找到不少相似的题目。当然看看题目中的说明,那才是最容易明白来源的方法。

使用道具 举报

Rank: 7Rank: 7Rank: 7

积分
5265
帖子
3218
精华
19
UID
13140
性别

论坛建设奖 八年元老

发表于 2009-7-22 10:49:08 |显示全部楼层
SokoFind 对每个方向,会多次比较(从左上角比到右下角),所以大小没有关系。把待找关卡最有特征的局部拿来做搜索亦可。

[ 本帖最后由 sokoban 于 2009-7-22 23:01 编辑 ]

使用道具 举报

Rank: 7Rank: 7Rank: 7

积分
2010
帖子
1577
精华
3
UID
91928
性别
保密

超级搬运工 六年元老

发表于 2009-7-23 02:50:16 |显示全部楼层
原帖由 jinyou 于 2009-7-22 09:53 发表
再问,八个方向比较,每个方向要进行各种覆盖程度的许多次比较,最后取最大相似值吗?
所以关卡大小(长,宽)有些出入,也没有关系吗。


SokoFind 是每个关卡八个方向都进行比较, 当找到一个方向达到用者的要求(百分率) 时就会停止其它方向的比较。
虽然再比较其它的方向可能会得到更高的百分率 -- 个人觉得没有必要。
再者, 除非关卡特殊和百分率非常低(或者pattern非常小) 关卡不会有两个方向都达到百分率要求。

如Sokoban兄所说, 关卡大小有些出入不成问题。

[ 本帖最后由 anian 于 2009-7-23 03:13 编辑 ]

使用道具 举报

Rank: 8Rank: 8

积分
1918
帖子
588
精华
5
UID
145
性别

魔方破解达人 八年元老

发表于 2009-7-23 10:32:18 |显示全部楼层
我的意思程序首先判断是完整XSB,做规格化等...,如果只输入关卡的局部,就可以进行直接比较.而现在不行.

一般应该按照相似率排序.所以有必要得到更高的百分率.

使用道具 举报

Rank: 7Rank: 7Rank: 7

积分
2010
帖子
1577
精华
3
UID
91928
性别
保密

超级搬运工 六年元老

发表于 2009-7-23 12:21:13 |显示全部楼层
原帖由 jinyou 于 2009-7-23 10:32 发表
我的意思程序首先判断是完整XSB,做规格化等...,如果只输入关卡的局部,就可以进行直接比较.而现在不行.


为什么不行?  
SokoFind之所以开发的主要原因就是其它的关卡搜查程序不能输入关卡的局部。
SokoFind是可以用关卡的局部来搜查。
也是这个原因, 我才叫它做“XSB Pattern” 而不是 “XSB Level”。

但是有一点我没有说明白, 那就是“XSB Pattern”的格式。

为了方便输入关卡的局部和空位, “XSB Pattern”的格式是需要在“关卡的局部”加一个方形外墙。

列子:

如果想便输入关卡的局部是:

-------#-$#
-------#.-#
########-$#
.-.-.-.#.-#
-$-$-$---$#
########--#
-------####


那就要加一个方形外墙, 变成了:
#############
#-------#-$##
#-------#.-##
#########-$##
#.-.-.-.#.-##
#-$-$-$---$##
#########--##
#-------#####
#############

SokoFind在阅读XSB Pattern后会去除方形外墙。
还有一点, XSB Pattern是没有做规格化的。   只有那些进行搜查的关卡才做规格化然后再比较。

mf8_2x.gif




frame_00143.gif


[ 本帖最后由 anian 于 2009-10-28 12:00 编辑 ]

使用道具 举报

Rank: 8Rank: 8

积分
1918
帖子
588
精华
5
UID
145
性别

魔方破解达人 八年元老

发表于 2009-7-23 13:41:05 |显示全部楼层
那些进行搜查的关卡,基本上不再改变,是否先做好规格化加以保存,空间换时间。
你的程序在读入XSB Pattern后,检测到不能规格化的就是局部,就自动加方形外墙,而不该要求输入者加。除非你的编辑框能提供列编辑模式。

另问搜查路径中支持哪些文件格式,是否包含子文件夹。

[ 本帖最后由 jinyou 于 2009-7-23 13:42 编辑 ]

使用道具 举报

Rank: 7Rank: 7Rank: 7

积分
5265
帖子
3218
精华
19
UID
13140
性别

论坛建设奖 八年元老

发表于 2009-7-23 15:47:14 |显示全部楼层
我来回答一下第二个问题。第一个留给 anian 兄了

在设定的路径之下(包括子文件夹),所有扩展名为 TXT、XSB 和 SOK 的推箱子关卡文件都会逐一检查。所以支持多种扩展名,本质上都是一种格式:xsb格式。

使用道具 举报

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

Archiver|手机版|魔方吧·中文魔方俱乐部

GMT+8, 2024-4-18 19:00

Powered by Discuz! X2

© 2001-2011 Comsenz Inc.

回顶部