blob: 81c23cde0f9fd4962db1a7d3b6d3f96e2265c504 [file] [log] [blame] [edit]
// REQUIRES: z3-prover
// RUN: mlir-translate --export-smtlib %s | z3 -in 2>&1 | FileCheck %s
// RUN: mlir-translate --export-smtlib --smtlibexport-inline-single-use-values %s | z3 -in 2>&1 | FileCheck %s
// Function and constant symbol declarations, uninterpreted sorts
smt.solver () : () -> () {
%0 = smt.declare_fun "b" : !smt.bv<32>
%1 = smt.declare_fun : !smt.int
%2 = smt.declare_fun : !smt.func<(!smt.int, !smt.bv<32>) !smt.bool>
%3 = smt.apply_func %2(%1, %0) : !smt.func<(!smt.int, !smt.bv<32>) !smt.bool>
smt.assert %3
%4 = smt.declare_fun : !smt.sort<"uninterpreted">
%5 = smt.declare_fun : !smt.sort<"other"[!smt.sort<"uninterpreted">]>
%6 = smt.declare_fun : !smt.func<(!smt.sort<"other"[!smt.sort<"uninterpreted">]>, !smt.sort<"uninterpreted">) !smt.bool>
%7 = smt.apply_func %6(%5, %4) : !smt.func<(!smt.sort<"other"[!smt.sort<"uninterpreted">]>, !smt.sort<"uninterpreted">) !smt.bool>
smt.assert %7
smt.check sat {} unknown {} unsat {}
}
// CHECK-NOT: WARNING
// CHECK-NOT: warning
// CHECK-NOT: ERROR
// CHECK-NOT: error
// CHECK-NOT: unsat
// CHECK: sat
// Big expression
smt.solver () : () -> () {
%true = smt.constant true
%false = smt.constant false
%0 = smt.not %true
%1 = smt.and %0, %true, %false
%2 = smt.or %1, %0, %true
%3 = smt.xor %0, %2
%4 = smt.implies %3, %false
%5 = smt.implies %4, %true
smt.assert %5
smt.check sat {} unknown {} unsat {}
}
// CHECK-NOT: WARNING
// CHECK-NOT: warning
// CHECK-NOT: ERROR
// CHECK-NOT: error
// CHECK-NOT: unsat
// CHECK: sat
// Constant array
smt.solver () : () -> () {
%true = smt.constant true
%false = smt.constant false
%c = smt.int.constant 0
%0 = smt.array.broadcast %true : !smt.array<[!smt.int -> !smt.bool]>
%1 = smt.array.store %0[%c], %false : !smt.array<[!smt.int -> !smt.bool]>
%2 = smt.array.select %1[%c] : !smt.array<[!smt.int -> !smt.bool]>
smt.assert %2
smt.check sat {} unknown {} unsat {}
}
// CHECK-NOT: WARNING
// CHECK-NOT: warning
// CHECK-NOT: ERROR
// CHECK-NOT: error
// CHECK: unsat
// BitVector extract and concat, and constants
smt.solver () : () -> () {
%xf = smt.bv.constant #smt.bv<0xf> : !smt.bv<4>
%x0 = smt.bv.constant #smt.bv<0> : !smt.bv<4>
%xff = smt.bv.constant #smt.bv<0xff> : !smt.bv<8>
%0 = smt.bv.concat %xf, %x0 : !smt.bv<4>, !smt.bv<4>
%1 = smt.bv.extract %0 from 4 : (!smt.bv<8>) -> !smt.bv<4>
%2 = smt.bv.repeat 2 times %1 : !smt.bv<4>
%3 = smt.eq %2, %xff : !smt.bv<8>
smt.assert %3
smt.check sat {} unknown {} unsat {}
}
// CHECK-NOT: WARNING
// CHECK-NOT: warning
// CHECK-NOT: ERROR
// CHECK-NOT: error
// CHECK-NOT: unsat
// CHECK: sat
// Quantifiers
smt.solver () : () -> () {
%1 = smt.forall ["a"] {
^bb0(%arg2: !smt.int):
%c2_1 = smt.int.constant 2
%2 = smt.int.mul %arg2, %c2_1
%3 = smt.exists {
^bb0(%arg1: !smt.int):
%c2 = smt.int.constant 2
%4 = smt.int.mul %c2, %arg1
%5 = smt.eq %4, %2 : !smt.int
smt.yield %5 : !smt.bool
}
smt.yield %3 : !smt.bool
}
smt.assert %1
smt.check sat {} unknown {} unsat {}
}
// CHECK-NOT: WARNING
// CHECK-NOT: warning
// CHECK-NOT: ERROR
// CHECK-NOT: error
// CHECK-NOT: unsat
// CHECK: sat
// Push and pop
smt.solver () : () -> () {
%three = smt.int.constant 3
%four = smt.int.constant 4
%unsat_eq = smt.eq %three, %four : !smt.int
%sat_eq = smt.eq %three, %three : !smt.int
smt.push 1
smt.assert %unsat_eq
smt.check sat {} unknown {} unsat {}
smt.pop 1
smt.assert %sat_eq
smt.check sat {} unknown {} unsat {}
}
// CHECK-NOT: WARNING
// CHECK-NOT: warning
// CHECK-NOT: ERROR
// CHECK-NOT: error
// CHECK-NOT: sat
// CHECK: unsat
// CHECK-NOT: WARNING
// CHECK-NOT: warning
// CHECK-NOT: ERROR
// CHECK-NOT: error
// CHECK-NOT: unsat
// CHECK: sat
// Reset
smt.solver () : () -> () {
%three = smt.int.constant 3
%four = smt.int.constant 4
%unsat_eq = smt.eq %three, %four : !smt.int
%sat_eq = smt.eq %three, %three : !smt.int
smt.assert %unsat_eq
smt.check sat {} unknown {} unsat {}
smt.reset
smt.assert %sat_eq
smt.check sat {} unknown {} unsat {}
}
// CHECK-NOT: WARNING
// CHECK-NOT: warning
// CHECK-NOT: ERROR
// CHECK-NOT: error
// CHECK-NOT: sat
// CHECK: unsat
// CHECK-NOT: WARNING
// CHECK-NOT: warning
// CHECK-NOT: ERROR
// CHECK-NOT: error
// CHECK-NOT: unsat
// CHECK: sat
smt.solver () : () -> () {
smt.set_logic "HORN"
%c = smt.declare_fun : !smt.int
%c4 = smt.int.constant 4
%eq = smt.eq %c, %c4 : !smt.int
smt.assert %eq
smt.check sat {} unknown {} unsat {}
}
// CHECK-NOT: WARNING
// CHECK-NOT: warning
// CHECK-NOT: ERROR
// CHECK-NOT: error
// CHECK-NOT: unsat
// CHECK-NOT: sat
// CHECK: unknown