java - 使用 "for all"与未解释的排序 JAVA API

标签 java z3 z3py z3c.form

我正在尝试使用 java API 学习 Z3,因为没有文档我一直在查看 C API 文档,但直到现在我找不到如何使用一些基本功能的清晰示例。

我正在尝试对这个 Z3 代码进行编码(在在线版本中有效)

;general options for getting values when sat
(set-option :produce-models true)
(set-option :produce-assignments true)

;declaring new sorts
(declare-sort Task)
(declare-sort User)

;function for assign an specific user
(declare-fun assignUser (Task) User)
;creating a relation between a task and a usert
(declare-fun TaskUser (Task User) Bool)

;stablishing order
(declare-fun mustPrecede (Task Task) Bool)

(assert(forall((t Task)) (not (mustPrecede t t))))
(assert(forall((t1 Task)(t2 Task)(t3 Task)) (implies (and (mustPrecede t1 t2)(mustPrecede t2 t3)) (mustPrecede t1 t3))))        

;asserting that all task must have one assigned user
(assert(forall((t Task)(u User)) (TaskUser t u)))
;asserting that all task must have one assigned user
;(assert(forall((t1 Task)(t2 Task)) (not(= (assignUser t1) (assignUser t2))))) 

到目前为止,我只是设法声明未解释的排序并声明我的函数如下

      HashMap<String, String> cfg = new HashMap<String, String>();
      cfg.put("proof", "true");
      cfg.put("auto-config", "false");
      Context ctx = new Context(cfg);

    //cfg.put("model", "true");
    Sort USER = ctx.mkUninterpretedSort("USER");
    Sort TASK = ctx.mkUninterpretedSort("TASK");

    FuncDecl assignUser = ctx.mkFuncDecl("assignUser", TASK, USER);
    FuncDecl TaskUser = ctx.mkFuncDecl("TaskUser", new Sort[] { TASK, USER }, ctx.mkBoolSort());
    FuncDecl mustPrecede = ctx.mkFuncDecl("mustPrecede", new Sort[]{TASK,TASK}, ctx.mkBoolSort());

但是我找不到例子来表达

(assert(forall((t Task)) (not (mustPrecede t t))))
(assert(forall((t1 Task)(t2 Task)(t3 Task)) (implies (and (mustPrecede t1 t2) (mustPrecede t2 t3)) (mustPrecede t1 t3))))

;asserting that all task must have one assigned user
(assert(forall((t Task)(u User)) (TaskUser t u)))
;asserting that all task must have one assigned user
;(assert(forall((t1 Task)(t2 Task)) (not(= (assignUser t1) (assignUser t2))))) 

有人可以帮我解决这个问题吗?用 java API 表达这个 asserts-foralls 的方式是什么?

最佳答案

Z3 代码中有一组示例,其中包含各种 Java 调用:

https://z3.codeplex.com/SourceControl/latest#examples/java/JavaExample.java

它们包括构建和检查量化公式。

关于java - 使用 "for all"与未解释的排序 JAVA API,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25022699/

相关文章:

java - 在LWJGL中变换硬件光标

java - 单击运行 JS 函数清除表单的按钮后, View 无法恢复

z3 - 如何在 z3py 中连接正则表达式?

java - 类型类的工厂方法需要 Scala 设计建议

java - SimpleDateFormat 中的可选部分

c++ - 使用 C++ API 进行数组选择和存储

z3 - Z3 返回多个元素的乐趣

z3 - z3 的解决方法不支持注入(inject)性

Z3Py是不是能够做出一定的证明?

python - Z3 Python : ordering models and accessing their elements