Z3 единственная система, которая способна опровергнуть REL051+1.p?

Задача в реляционной алгебре REL051+1.p читает

  File     : REL051+1 : TPTP v6.1.0. Released v4.0.0.
% Domain   : Relation Algebra
% Problem  : Dense linear ordering

Использование синтаксиса TPTP с соответствующим кодом

fof(f01,axiom,(
    ! [A] : o(A,A) )).

fof(f02,axiom,(
    ! [A,B] :
      ( ( A != B
        & o(A,B) )
     => ~ o(B,A) ) )).

fof(f03,axiom,(
    ! [A,B,C] :
      ( ( o(A,B)
        & o(B,C) )
     => o(A,C) ) )).

fof(f04,axiom,(
    ! [A,B] :
      ( ( A != B
        & o(A,B) )
     => ( o(A,f(A,B))
        & o(f(A,B),B) ) ) )).

fof(f05,axiom,(
    ! [A,B] :
      ( f(A,B) != A
      & f(A,B) != B ) )).

fof(f06,axiom,(
    ! [A,B] :
      ( o(A,B)
      | o(B,A) ) )).

Как вы можете видеть в TPTP, все ATP не могут доказать такую ​​проблему.

Эта теорема была опровергнута с помощью Z3 с использованием следующей SMT-LIB

(declare-sort S)
(declare-fun o (S S) Bool)
(declare-fun f (S S) S)
(assert (forall ((A S)) (o A A) ))
(assert (forall ((A S) (B S)) (implies (and (distinct A B) (o A B)) 
                                       (not (o B A)))   ) )
(assert (forall ((A S) (B S) (C S)) (implies (and (o A B) (o B C)) 
                                             (o A C))   ) )
(assert (forall ((A S) (B S)) (implies (and (distinct A B) (o A B)) 
                                       (and (o A (f A B)) (o (f A B) B)))   ) )
(declare-fun B () S)
(assert (forall ((A S)) (and (distinct (f A B) A) 
                                   (distinct (f A B) B))    ) )

(assert (not (forall ((A S)) (or (o A B) (o B A)) ) ))

(check-sat)
(get-model)

и соответствующий вывод

    sat
    (model
      ;; universe for S:
      ;;   S!val!0 S!val!3 S!val!1 S!val!2
      ;; -----------
      ;; definitions for universe elements:
      (declare-fun S!val!0 () S)
      (declare-fun S!val!3 () S)
      (declare-fun S!val!1 () S)
      (declare-fun S!val!2 () S)
      ;; cardinality constraint:
      (forall ((x S)) (or (= x S!val!0) (= x S!val!3) (= x S!val!1) (= x S!val!2)))
      ;; -----------
      (define-fun B () S
        S!val!1)
      (define-fun A!0 () S
        S!val!0)
      (define-fun f!47 ((x!1 S) (x!2 S)) S
        (ite (and (= x!1 S!val!2) (= x!2 S!val!1)) S!val!3
          S!val!2))
      (define-fun k!46 ((x!1 S)) S
        (ite (= x!1 S!val!2) S!val!2
        (ite (= x!1 S!val!0) S!val!0
        (ite (= x!1 S!val!3) S!val!3
          S!val!1))))
      (define-fun f ((x!1 S) (x!2 S)) S
        (f!47 (k!46 x!1) (k!46 x!2)))
      (define-fun o!48 ((x!1 S) (x!2 S)) Bool
        (ite (and (= x!1 S!val!1) (= x!2 S!val!1)) true
        (ite (and (= x!1 S!val!0) (= x!2 S!val!0)) true
        (ite (and (= x!1 S!val!2) (= x!2 S!val!2)) true
        (ite (and (= x!1 S!val!3) (= x!2 S!val!3)) true
          false)))))
      (define-fun o ((x!1 S) (x!2 S)) Bool
        (o!48 (k!46 x!1) (k!46 x!2)))
)

Пожалуйста, запустите этот пример онлайн здесь

Мой вопрос: это опровержение с Z3 правильно?

0 ответов

Другие вопросы по тегам