// 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