7

我发现了一个问题,如下面的简单 SMT-LIB 程序所示。

SMT-LIB 代码:

(declare-fun isDigit (Int) Bool)
(assert (forall ((x Int))
    (=>     (isDigit x)
        (and (>= x 0) (< x 10))
    )
  )
) 

(assert (forall ((x Int))   
    (=>     (and (>= x 12) (< x 15))
        (exists ((y Int))
            (and    (>= y 1) (< y 6)
                (isHost (- x y))
            )
        )
    )
  )
)

(check-sat)
(get-model)

这给出了以下警告:

WARNING: failed to find a pattern for quantifier (quantifier id: k!18)
sat
........
........

我想知道警告信息。我知道我错过了一些东西,但我无法理解。任何人都可以在这个问题上帮助我吗?

4

1 回答 1

3

Z3 使用不同的引擎来处理量词(参见Z3 指南)。这些引擎之一基于模式匹配(E-Matching)。Z3 尝试为每个量化公式推断模式。如果找不到,它会发出警告消息。用户还可以为每个量词提供模式。该指南显示了如何做到这一点。idk!18是 Z3 创建的默认 id。它基于行号(在您的情况下为第 18 行)。您还可以为量词提供自己的 ID。该警告只是告诉用户电子匹配引擎将无法处理指定的量词。

于 2012-02-08T16:37:20.610 回答