1

fzn2smt工具允许通过Yices求解flatzinc公式。

当我尝试运行它时,求解器会回答UNKNOWN我测试的每个公式。例如

~$ java -Xmx4096M fzn2smt -ce "./yices-2.5.2/bin/yices -f" -i 2DPacking.fzn 
Time1:170
=====UNKNOWN=====

但是,在给定的示例中,它似乎正确地2DPacking.fzn.smt在文件的同一目录中创建了实例2DPacking.fzn

~$ ls
2DPacking.fzn.smt    2DPacking.fzn    2DPacking.mzn    2DPacking.ozn

如果我手动运行Yices公式smt,我会得到一个肯定的结果:

~$ yices-smt -f 2DPacking.fzn.smt 
sat

(= x____00002_6_ 0)
...

IMPLICANT:
(>= x____00003_4_ 0)
...

问:有没有其他人有经验fzn2smt并知道如何解决这个问题?


为了确定我遇到的问题不是由于安装部分,我将在这里分享:

 main_dir
 main_dir/fzn2smt-2-0-02      # unpacked fzn2smt files
 main_dir/antlr               # unpacked antlr-runtime-3.5 files
 main_dir/yices-2.5.2         # unpacked yices files

我还按照工具说明的要求修改了环境变量:

 PATH=${main_dir}/yices-2.5.2/bin/:${PATH}
 PATH=${main_dir}/fzn2smt-2-0-02/:${PATH}

 CLASSPATH=${main_dir}:${CLASSPATH}
 CLASSPATH=${main_dir}/antlr:${CLASSPATH}
 CLASSPATH=${main_dir}/fzn2smt-2-0-02:${CLASSPATH}
4

1 回答 1

1

正如@Dekker在评论中所建议的那样,问题是由于fzn2smt似乎有一段时间没有更新。

经过一些试验和错误,我发现它的最新版本Yices似乎与fzn2smtversion兼容2.2.1

它可以执行如下:

~$ java -Xmx4096M fzn2smt -ce "./yices-2.2.1/bin/yices-smt -f" -i 2DPacking.fzn
Time1:162
Time: 207
Pos: 0
item = array2d(1..2, 1..4, [0, 0, 0, 0, 1, 1, 1, 1]);
obj = 1;
----------
Time: 223
Pos: 0
item = array2d(1..2, 1..4, [0, 0, 0, 0, 1, 1, 1, 1]);
obj = 1;
----------
==========
Time2:228

最初,与在SMT-COMP 2009上展示的fzn2smt版本相结合。要使用该版本,使用该工具的命令行指令略有不同2Yices

~$ java -Xmx4096M fzn2smt -ce "./yices2smt09/bin/yices -f" -i 2DPacking.fzn
Time1:160
Time: 208
Pos: 0
item = array2d(1..2, 1..4, [0, 0, 0, 0, 1, 1, 1, 1]);
obj = 1;
----------
==========
Time2:223

请注意

  • 可执行文件在这里命名yices,而不是yices-smt

  • 输出略有不同,由于某些原因,使用较新版本的工具时会多次打印解决方案


旧版本Yices可以从这里下载。

于 2017-09-20T08:45:06.507 回答