Z3
 
Loading...
Searching...
No Matches
z3++.h
Go to the documentation of this file.
1/*++
2Copyright (c) 2012 Microsoft Corporation
3
4 Thin C++ layer on top of the Z3 C API.
5 Main features:
6 - Smart pointers for all Z3 objects.
7 - Object-Oriented interface.
8 - Operator overloading.
9 - Exceptions for signaling Z3 errors
10
11 The C API can be used simultaneously with the C++ layer.
12 However, if you use the C API directly, you will have to check the error conditions manually.
13 Of course, you can invoke the method check_error() of the context object.
14Author:
15
16 Leonardo (leonardo) 2012-03-28
17
18Notes:
19
20--*/
21#pragma once
22
23#include<cassert>
24#include<ostream>
25#include<string>
26#include<memory>
27#include<vector>
28#include<z3.h>
29#include<limits.h>
30#include<functional>
31
32#undef min
33#undef max
34
49namespace z3 {
50
51 class exception;
52 class config;
53 class context;
54 class symbol;
55 class params;
56 class param_descrs;
57 class ast;
58 class sort;
59 class constructors;
60 class constructor_list;
61 class func_decl;
62 class expr;
63 class solver;
64 class goal;
65 class tactic;
66 class simplifier;
67 class probe;
68 class model;
69 class func_interp;
70 class func_entry;
71 class statistics;
72 class apply_result;
73 template<typename T> class cast_ast;
74 template<typename T> class ast_vector_tpl;
79
80 inline void set_param(char const * param, char const * value) { Z3_global_param_set(param, value); }
81 inline void set_param(char const * param, bool value) { Z3_global_param_set(param, value ? "true" : "false"); }
82 inline void set_param(char const * param, int value) { auto str = std::to_string(value); Z3_global_param_set(param, str.c_str()); }
84
88 class exception : public std::exception {
89 std::string m_msg;
90 public:
91 virtual ~exception() throw() = default;
92 exception(char const * msg):m_msg(msg) {}
93 char const * msg() const { return m_msg.c_str(); }
94 char const * what() const throw() { return m_msg.c_str(); }
95 friend std::ostream & operator<<(std::ostream & out, exception const & e);
96 };
97 inline std::ostream & operator<<(std::ostream & out, exception const & e) { out << e.msg(); return out; }
98
99#if !defined(Z3_THROW)
100#if __cpp_exceptions || _CPPUNWIND || __EXCEPTIONS
101#define Z3_THROW(x) throw x
102#else
103#define Z3_THROW(x) {}
104#endif
105#endif // !defined(Z3_THROW)
106
110 class config {
111 Z3_config m_cfg;
112 config(config const &) = delete;
113 config & operator=(config const &) = delete;
114 public:
115 config() { m_cfg = Z3_mk_config(); }
116 ~config() { Z3_del_config(m_cfg); }
117 operator Z3_config() const { return m_cfg; }
121 void set(char const * param, char const * value) { Z3_set_param_value(m_cfg, param, value); }
125 void set(char const * param, bool value) { Z3_set_param_value(m_cfg, param, value ? "true" : "false"); }
129 void set(char const * param, int value) {
130 auto str = std::to_string(value);
131 Z3_set_param_value(m_cfg, param, str.c_str());
132 }
133 };
134
138
146
148 if (l == Z3_L_TRUE) return sat;
149 else if (l == Z3_L_FALSE) return unsat;
150 return unknown;
151 }
152
153
154
160 class context {
161 private:
163 bool m_enable_exceptions = true;
164 rounding_mode m_rounding_mode;
165 Z3_context m_ctx = nullptr;
166 void init(config & c) {
167 set_context(Z3_mk_context_rc(c));
168 }
169 void set_context(Z3_context ctx) {
170 m_ctx = ctx;
171 m_enable_exceptions = true;
172 m_rounding_mode = RNE;
173 Z3_set_error_handler(m_ctx, 0);
175 }
176
177
178 context(context const &) = delete;
179 context & operator=(context const &) = delete;
180
181 context(Z3_context c) { set_context(c); }
182 void detach() { m_ctx = nullptr; }
183 public:
184 context() { config c; init(c); }
185 context(config & c) { init(c); }
186 ~context() { if (m_ctx) Z3_del_context(m_ctx); }
187 operator Z3_context() const { return m_ctx; }
188
194 if (e != Z3_OK && enable_exceptions())
196 return e;
197 }
198
199 void check_parser_error() const {
200 check_error();
201 }
202
210 void set_enable_exceptions(bool f) { m_enable_exceptions = f; }
211
212 bool enable_exceptions() const { return m_enable_exceptions; }
213
217 void set(char const * param, char const * value) { Z3_update_param_value(m_ctx, param, value); }
221 void set(char const * param, bool value) { Z3_update_param_value(m_ctx, param, value ? "true" : "false"); }
225 void set(char const * param, int value) {
226 auto str = std::to_string(value);
227 Z3_update_param_value(m_ctx, param, str.c_str());
228 }
229
234 void interrupt() { Z3_interrupt(m_ctx); }
235
239 symbol str_symbol(char const * s);
243 symbol int_symbol(int n);
247 sort bool_sort();
251 sort int_sort();
255 sort real_sort();
259 sort bv_sort(unsigned sz);
260
264 sort char_sort();
272 sort seq_sort(sort& s);
282 sort array_sort(sort d, sort r);
283 sort array_sort(sort_vector const& d, sort r);
290 sort fpa_sort(unsigned ebits, unsigned sbits);
294 template<size_t precision>
309 sort enumeration_sort(char const * name, unsigned n, char const * const * enum_names, func_decl_vector & cs, func_decl_vector & ts);
310
317 func_decl tuple_sort(char const * name, unsigned n, char const * const * names, sort const* sorts, func_decl_vector & projs);
318
319
328 sort datatype(symbol const& name, constructors const& cs);
329
337 sort datatype(symbol const &name, sort_vector const &params, constructors const &cs);
338
345 sort_vector datatypes(unsigned n, symbol const* names,
346 constructor_list *const* cons);
347
348
353 sort datatype_sort(symbol const& name);
354
361 sort datatype_sort(symbol const& name, sort_vector const& params);
362
363
367 sort uninterpreted_sort(char const* name);
368 sort uninterpreted_sort(symbol const& name);
369
370 func_decl function(symbol const & name, unsigned arity, sort const * domain, sort const & range);
371 func_decl function(char const * name, unsigned arity, sort const * domain, sort const & range);
372 func_decl function(symbol const& name, sort_vector const& domain, sort const& range);
373 func_decl function(char const * name, sort_vector const& domain, sort const& range);
374 func_decl function(char const * name, sort const & domain, sort const & range);
375 func_decl function(char const * name, sort const & d1, sort const & d2, sort const & range);
376 func_decl function(char const * name, sort const & d1, sort const & d2, sort const & d3, sort const & range);
377 func_decl function(char const * name, sort const & d1, sort const & d2, sort const & d3, sort const & d4, sort const & range);
378 func_decl function(char const * name, sort const & d1, sort const & d2, sort const & d3, sort const & d4, sort const & d5, sort const & range);
379
380 func_decl recfun(symbol const & name, unsigned arity, sort const * domain, sort const & range);
381 func_decl recfun(symbol const & name, const sort_vector& domain, sort const & range);
382 func_decl recfun(char const * name, sort_vector const& domain, sort const & range);
383 func_decl recfun(char const * name, unsigned arity, sort const * domain, sort const & range);
384 func_decl recfun(char const * name, sort const & domain, sort const & range);
385 func_decl recfun(char const * name, sort const & d1, sort const & d2, sort const & range);
386
393 void recdef(func_decl decl, expr_vector const& args, expr const& body);
394 func_decl user_propagate_function(symbol const& name, sort_vector const& domain, sort const& range);
395
399 expr constant(symbol const & name, sort const & s);
400 expr constant(char const * name, sort const & s);
404 expr bool_const(char const * name);
405 expr int_const(char const * name);
406 expr real_const(char const * name);
407 expr string_const(char const * name);
408 expr bv_const(char const * name, unsigned sz);
409 expr fpa_const(char const * name, unsigned ebits, unsigned sbits);
410
411 template<size_t precision>
412 expr fpa_const(char const * name);
413
417 expr variable(unsigned index, sort const& s);
418
419
421
422 expr bool_val(bool b);
423
424 expr int_val(int n);
425 expr int_val(unsigned n);
426 expr int_val(int64_t n);
427 expr int_val(uint64_t n);
428 expr int_val(char const * n);
429
430 expr real_val(int n);
431 expr real_val(unsigned n);
432 expr real_val(int64_t n);
433 expr real_val(uint64_t n);
434 expr real_val(int64_t n, int64_t d);
435 expr real_val(char const * n);
436
437 expr bv_val(int n, unsigned sz);
438 expr bv_val(unsigned n, unsigned sz);
439 expr bv_val(int64_t n, unsigned sz);
440 expr bv_val(uint64_t n, unsigned sz);
441 expr bv_val(char const * n, unsigned sz);
442 expr bv_val(unsigned n, bool const* bits);
443
444 expr fpa_val(double n);
445 expr fpa_val(float n);
446 expr fpa_nan(sort const & s);
447 expr fpa_inf(sort const & s, bool sgn);
448
449 expr string_val(char const* s);
450 expr string_val(char const* s, unsigned n);
451 expr string_val(std::string const& s);
452 expr string_val(std::u32string const& s);
453
454 expr num_val(int n, sort const & s);
455
459 expr_vector parse_string(char const* s);
460 expr_vector parse_file(char const* file);
461
462 expr_vector parse_string(char const* s, sort_vector const& sorts, func_decl_vector const& decls);
463 expr_vector parse_file(char const* s, sort_vector const& sorts, func_decl_vector const& decls);
464 };
465
466
467 template<typename T>
468 class array {
469 std::unique_ptr<T[]> m_array;
470 unsigned m_size;
471 array(array const &) = delete;
472 array & operator=(array const &) = delete;
473 public:
474 array(unsigned sz):m_array(new T[sz]),m_size(sz) {}
475 template<typename T2>
476 array(ast_vector_tpl<T2> const & v);
477 void resize(unsigned sz) { m_array.reset(new T[sz]); m_size = sz; }
478 unsigned size() const { return m_size; }
479 T & operator[](int i) { assert(0 <= i); assert(static_cast<unsigned>(i) < m_size); return m_array[i]; }
480 T const & operator[](int i) const { assert(0 <= i); assert(static_cast<unsigned>(i) < m_size); return m_array[i]; }
481 T const * ptr() const { return m_array.get(); }
482 T * ptr() { return m_array.get(); }
483 };
484
485 class object {
486 protected:
488 public:
489 object(context & c):m_ctx(&c) {}
490 virtual ~object() = default;
491 context & ctx() const { return *m_ctx; }
493 friend void check_context(object const & a, object const & b);
494 };
495 inline void check_context(object const & a, object const & b) { (void)a; (void)b; assert(a.m_ctx == b.m_ctx); }
496
497 class symbol : public object {
498 Z3_symbol m_sym;
499 public:
500 symbol(context & c, Z3_symbol s):object(c), m_sym(s) {}
501 operator Z3_symbol() const { return m_sym; }
502 Z3_symbol_kind kind() const { return Z3_get_symbol_kind(ctx(), m_sym); }
503 std::string str() const { assert(kind() == Z3_STRING_SYMBOL); return Z3_get_symbol_string(ctx(), m_sym); }
504 int to_int() const { assert(kind() == Z3_INT_SYMBOL); return Z3_get_symbol_int(ctx(), m_sym); }
505 friend std::ostream & operator<<(std::ostream & out, symbol const & s);
506 };
507
508 inline std::ostream & operator<<(std::ostream & out, symbol const & s) {
509 if (s.kind() == Z3_INT_SYMBOL)
510 out << "k!" << s.to_int();
511 else
512 out << s.str();
513 return out;
514 }
515
516
517 class param_descrs : public object {
518 Z3_param_descrs m_descrs;
519 public:
520 param_descrs(context& c, Z3_param_descrs d): object(c), m_descrs(d) { Z3_param_descrs_inc_ref(c, d); }
521 param_descrs(param_descrs const& o): object(o.ctx()), m_descrs(o.m_descrs) { Z3_param_descrs_inc_ref(ctx(), m_descrs); }
523 Z3_param_descrs_inc_ref(o.ctx(), o.m_descrs);
524 Z3_param_descrs_dec_ref(ctx(), m_descrs);
525 m_descrs = o.m_descrs;
526 object::operator=(o);
527 return *this;
528 }
529 ~param_descrs() override { Z3_param_descrs_dec_ref(ctx(), m_descrs); }
532
533 unsigned size() { return Z3_param_descrs_size(ctx(), m_descrs); }
534 symbol name(unsigned i) { return symbol(ctx(), Z3_param_descrs_get_name(ctx(), m_descrs, i)); }
535 Z3_param_kind kind(symbol const& s) { return Z3_param_descrs_get_kind(ctx(), m_descrs, s); }
536 std::string documentation(symbol const& s) { char const* r = Z3_param_descrs_get_documentation(ctx(), m_descrs, s); check_error(); return r; }
537 std::string to_string() const { return Z3_param_descrs_to_string(ctx(), m_descrs); }
538 };
539
540 inline std::ostream& operator<<(std::ostream & out, param_descrs const & d) { return out << d.to_string(); }
541
542 class params : public object {
543 Z3_params m_params;
544 public:
545 params(context & c):object(c) { m_params = Z3_mk_params(c); Z3_params_inc_ref(ctx(), m_params); }
546 params(params const & s):object(s), m_params(s.m_params) { Z3_params_inc_ref(ctx(), m_params); }
547 ~params() override { Z3_params_dec_ref(ctx(), m_params); }
548 operator Z3_params() const { return m_params; }
549 params & operator=(params const & s) {
550 Z3_params_inc_ref(s.ctx(), s.m_params);
551 Z3_params_dec_ref(ctx(), m_params);
552 object::operator=(s);
553 m_params = s.m_params;
554 return *this;
555 }
556 void set(char const * k, bool b) { Z3_params_set_bool(ctx(), m_params, ctx().str_symbol(k), b); }
557 void set(char const * k, unsigned n) { Z3_params_set_uint(ctx(), m_params, ctx().str_symbol(k), n); }
558 void set(char const * k, double n) { Z3_params_set_double(ctx(), m_params, ctx().str_symbol(k), n); }
559 void set(char const * k, symbol const & s) { Z3_params_set_symbol(ctx(), m_params, ctx().str_symbol(k), s); }
560 void set(char const * k, char const* s) { Z3_params_set_symbol(ctx(), m_params, ctx().str_symbol(k), ctx().str_symbol(s)); }
561 friend std::ostream & operator<<(std::ostream & out, params const & p);
562 };
563
564 inline std::ostream & operator<<(std::ostream & out, params const & p) {
565 out << Z3_params_to_string(p.ctx(), p); return out;
566 }
567
568 class ast : public object {
569 protected:
570 Z3_ast m_ast;
571 public:
572 ast(context & c):object(c), m_ast(0) {}
573 ast(context & c, Z3_ast n):object(c), m_ast(n) { Z3_inc_ref(ctx(), m_ast); }
574 ast(ast const & s) :object(s), m_ast(s.m_ast) { Z3_inc_ref(ctx(), m_ast); }
575 ~ast() override { if (m_ast) { Z3_dec_ref(*m_ctx, m_ast); } }
576 operator Z3_ast() const { return m_ast; }
577 operator bool() const { return m_ast != 0; }
578 ast & operator=(ast const & s) {
579 Z3_inc_ref(s.ctx(), s.m_ast);
580 if (m_ast)
581 Z3_dec_ref(ctx(), m_ast);
582 object::operator=(s);
583 m_ast = s.m_ast;
584 return *this;
585 }
587 unsigned hash() const { unsigned r = Z3_get_ast_hash(ctx(), m_ast); check_error(); return r; }
588 friend std::ostream & operator<<(std::ostream & out, ast const & n);
589 std::string to_string() const { return std::string(Z3_ast_to_string(ctx(), m_ast)); }
590
591
595 friend bool eq(ast const & a, ast const & b);
596 };
597 inline std::ostream & operator<<(std::ostream & out, ast const & n) {
598 out << Z3_ast_to_string(n.ctx(), n.m_ast); return out;
599 }
600
601 inline bool eq(ast const & a, ast const & b) { return Z3_is_eq_ast(a.ctx(), a, b); }
602
603 template<typename T>
604 class ast_vector_tpl : public object {
605 Z3_ast_vector m_vector;
606 void init(Z3_ast_vector v) { Z3_ast_vector_inc_ref(ctx(), v); m_vector = v; }
607 public:
609 ast_vector_tpl(context & c, Z3_ast_vector v):object(c) { init(v); }
610 ast_vector_tpl(ast_vector_tpl const & s):object(s), m_vector(s.m_vector) { Z3_ast_vector_inc_ref(ctx(), m_vector); }
611 ast_vector_tpl(context& c, ast_vector_tpl const& src): object(c) { init(Z3_ast_vector_translate(src.ctx(), src, c)); }
612
613 ~ast_vector_tpl() override { Z3_ast_vector_dec_ref(ctx(), m_vector); }
614 operator Z3_ast_vector() const { return m_vector; }
615 unsigned size() const { return Z3_ast_vector_size(ctx(), m_vector); }
616 T operator[](unsigned i) const { Z3_ast r = Z3_ast_vector_get(ctx(), m_vector, i); check_error(); return cast_ast<T>()(ctx(), r); }
617 void push_back(T const & e) { Z3_ast_vector_push(ctx(), m_vector, e); check_error(); }
618 void resize(unsigned sz) { Z3_ast_vector_resize(ctx(), m_vector, sz); check_error(); }
619 T back() const { return operator[](size() - 1); }
620 void pop_back() { assert(size() > 0); resize(size() - 1); }
621 bool empty() const { return size() == 0; }
623 Z3_ast_vector_inc_ref(s.ctx(), s.m_vector);
624 Z3_ast_vector_dec_ref(ctx(), m_vector);
625 object::operator=(s);
626 m_vector = s.m_vector;
627 return *this;
628 }
629 ast_vector_tpl& set(unsigned idx, ast& a) {
630 Z3_ast_vector_set(ctx(), m_vector, idx, a);
631 return *this;
632 }
633 /*
634 Disabled pending C++98 build upgrade
635 bool contains(T const& x) const {
636 for (T y : *this) if (eq(x, y)) return true;
637 return false;
638 }
639 */
640
641 class iterator final {
642 ast_vector_tpl const* m_vector;
643 unsigned m_index;
644 public:
645 iterator(ast_vector_tpl const* v, unsigned i): m_vector(v), m_index(i) {}
646
647 bool operator==(iterator const& other) const noexcept {
648 return other.m_index == m_index;
649 };
650 bool operator!=(iterator const& other) const noexcept {
651 return other.m_index != m_index;
652 };
654 ++m_index;
655 return *this;
656 }
657 void set(T& arg) {
658 Z3_ast_vector_set(m_vector->ctx(), *m_vector, m_index, arg);
659 }
660 iterator operator++(int) noexcept { iterator tmp = *this; ++m_index; return tmp; }
661 T * operator->() const { return &(operator*()); }
662 T operator*() const { return (*m_vector)[m_index]; }
663 };
664 iterator begin() const noexcept { return iterator(this, 0); }
665 iterator end() const { return iterator(this, size()); }
666 friend std::ostream & operator<<(std::ostream & out, ast_vector_tpl const & v) { out << Z3_ast_vector_to_string(v.ctx(), v); return out; }
667 std::string to_string() const { return std::string(Z3_ast_vector_to_string(ctx(), m_vector)); }
668 };
669
670
674 class sort : public ast {
675 public:
676 sort(context & c):ast(c) {}
677 sort(context & c, Z3_sort s):ast(c, reinterpret_cast<Z3_ast>(s)) {}
678 sort(context & c, Z3_ast a):ast(c, a) {}
679 operator Z3_sort() const { return reinterpret_cast<Z3_sort>(m_ast); }
680
684 unsigned id() const { unsigned r = Z3_get_sort_id(ctx(), *this); check_error(); return r; }
685
689 Z3_sort_kind sort_kind() const { return Z3_get_sort_kind(*m_ctx, *this); }
693 symbol name() const { Z3_symbol s = Z3_get_sort_name(ctx(), *this); check_error(); return symbol(ctx(), s); }
697 bool is_bool() const { return sort_kind() == Z3_BOOL_SORT; }
701 bool is_int() const { return sort_kind() == Z3_INT_SORT; }
705 bool is_real() const { return sort_kind() == Z3_REAL_SORT; }
709 bool is_arith() const { return is_int() || is_real(); }
713 bool is_bv() const { return sort_kind() == Z3_BV_SORT; }
717 bool is_array() const { return sort_kind() == Z3_ARRAY_SORT; }
721 bool is_datatype() const { return sort_kind() == Z3_DATATYPE_SORT; }
725 bool is_relation() const { return sort_kind() == Z3_RELATION_SORT; }
729 bool is_seq() const { return sort_kind() == Z3_SEQ_SORT; }
733 bool is_re() const { return sort_kind() == Z3_RE_SORT; }
741 bool is_fpa() const { return sort_kind() == Z3_FLOATING_POINT_SORT; }
742
748 unsigned bv_size() const { assert(is_bv()); unsigned r = Z3_get_bv_sort_size(ctx(), *this); check_error(); return r; }
749
750 unsigned fpa_ebits() const { assert(is_fpa()); unsigned r = Z3_fpa_get_ebits(ctx(), *this); check_error(); return r; }
751
752 unsigned fpa_sbits() const { assert(is_fpa()); unsigned r = Z3_fpa_get_sbits(ctx(), *this); check_error(); return r; }
758 sort array_domain() const { assert(is_array()); Z3_sort s = Z3_get_array_sort_domain(ctx(), *this); check_error(); return sort(ctx(), s); }
764 sort array_range() const { assert(is_array()); Z3_sort s = Z3_get_array_sort_range(ctx(), *this); check_error(); return sort(ctx(), s); }
765
766 friend std::ostream & operator<<(std::ostream & out, sort const & s) { return out << Z3_sort_to_string(s.ctx(), Z3_sort(s.m_ast)); }
767
770 };
771
772
777 class func_decl : public ast {
778 public:
780 func_decl(context & c, Z3_func_decl n):ast(c, reinterpret_cast<Z3_ast>(n)) {}
781 operator Z3_func_decl() const { return reinterpret_cast<Z3_func_decl>(m_ast); }
782
786 unsigned id() const { unsigned r = Z3_get_func_decl_id(ctx(), *this); check_error(); return r; }
787
788 unsigned arity() const { return Z3_get_arity(ctx(), *this); }
789 sort domain(unsigned i) const { assert(i < arity()); Z3_sort r = Z3_get_domain(ctx(), *this, i); check_error(); return sort(ctx(), r); }
790 sort range() const { Z3_sort r = Z3_get_range(ctx(), *this); check_error(); return sort(ctx(), r); }
791 symbol name() const { Z3_symbol s = Z3_get_decl_name(ctx(), *this); check_error(); return symbol(ctx(), s); }
792 Z3_decl_kind decl_kind() const { return Z3_get_decl_kind(ctx(), *this); }
793 unsigned num_parameters() const { return Z3_get_decl_num_parameters(ctx(), *this); }
794
795
797 Z3_func_decl tc = Z3_mk_transitive_closure(ctx(), *this); check_error(); return func_decl(ctx(), tc);
798 }
799
800 bool is_const() const { return arity() == 0; }
801
802 expr operator()() const;
803 expr operator()(unsigned n, expr const * args) const;
804 expr operator()(expr_vector const& v) const;
805 expr operator()(expr const & a) const;
806 expr operator()(int a) const;
807 expr operator()(expr const & a1, expr const & a2) const;
808 expr operator()(expr const & a1, int a2) const;
809 expr operator()(int a1, expr const & a2) const;
810 expr operator()(expr const & a1, expr const & a2, expr const & a3) const;
811 expr operator()(expr const & a1, expr const & a2, expr const & a3, expr const & a4) const;
812 expr operator()(expr const & a1, expr const & a2, expr const & a3, expr const & a4, expr const & a5) const;
813
815
816 };
817
821 expr select(expr const & a, expr const& i);
822 expr select(expr const & a, expr_vector const & i);
823
828 class expr : public ast {
829 public:
830 expr(context & c):ast(c) {}
831 expr(context & c, Z3_ast n):ast(c, reinterpret_cast<Z3_ast>(n)) {}
832
836 sort get_sort() const { Z3_sort s = Z3_get_sort(*m_ctx, m_ast); check_error(); return sort(*m_ctx, s); }
837
841 bool is_bool() const { return get_sort().is_bool(); }
845 bool is_int() const { return get_sort().is_int(); }
849 bool is_real() const { return get_sort().is_real(); }
853 bool is_arith() const { return get_sort().is_arith(); }
857 bool is_bv() const { return get_sort().is_bv(); }
861 bool is_array() const { return get_sort().is_array(); }
865 bool is_datatype() const { return get_sort().is_datatype(); }
869 bool is_relation() const { return get_sort().is_relation(); }
873 bool is_seq() const { return get_sort().is_seq(); }
877 bool is_re() const { return get_sort().is_re(); }
878
887 bool is_finite_domain() const { return get_sort().is_finite_domain(); }
891 bool is_fpa() const { return get_sort().is_fpa(); }
892
898 bool is_numeral() const { return kind() == Z3_NUMERAL_AST; }
899 bool is_numeral_i64(int64_t& i) const { bool r = Z3_get_numeral_int64(ctx(), m_ast, &i); check_error(); return r;}
900 bool is_numeral_u64(uint64_t& i) const { bool r = Z3_get_numeral_uint64(ctx(), m_ast, &i); check_error(); return r;}
901 bool is_numeral_i(int& i) const { bool r = Z3_get_numeral_int(ctx(), m_ast, &i); check_error(); return r;}
902 bool is_numeral_u(unsigned& i) const { bool r = Z3_get_numeral_uint(ctx(), m_ast, &i); check_error(); return r;}
903 bool is_numeral(std::string& s) const { if (!is_numeral()) return false; s = Z3_get_numeral_string(ctx(), m_ast); check_error(); return true; }
904 bool is_numeral(std::string& s, unsigned precision) const { if (!is_numeral()) return false; s = Z3_get_numeral_decimal_string(ctx(), m_ast, precision); check_error(); return true; }
905 bool is_numeral(double& d) const { if (!is_numeral()) return false; d = Z3_get_numeral_double(ctx(), m_ast); check_error(); return true; }
906 bool as_binary(std::string& s) const { if (!is_numeral()) return false; s = Z3_get_numeral_binary_string(ctx(), m_ast); check_error(); return true; }
907
908 double as_double() const { double d = 0; is_numeral(d); return d; }
909 uint64_t as_uint64() const { uint64_t r = 0; is_numeral_u64(r); return r; }
910 int64_t as_int64() const { int64_t r = 0; is_numeral_i64(r); return r; }
911
912
916 bool is_app() const { return kind() == Z3_APP_AST || kind() == Z3_NUMERAL_AST; }
920 bool is_const() const { return is_app() && num_args() == 0; }
924 bool is_quantifier() const { return kind() == Z3_QUANTIFIER_AST; }
925
929 bool is_forall() const { return Z3_is_quantifier_forall(ctx(), m_ast); }
933 bool is_exists() const { return Z3_is_quantifier_exists(ctx(), m_ast); }
937 bool is_lambda() const { return Z3_is_lambda(ctx(), m_ast); }
942 bool is_var() const { return kind() == Z3_VAR_AST; }
946 bool is_algebraic() const { return Z3_is_algebraic_number(ctx(), m_ast); }
947
951 bool is_well_sorted() const { bool r = Z3_is_well_sorted(ctx(), m_ast); check_error(); return r; }
952
956 expr mk_is_inf() const {
957 assert(is_fpa());
958 Z3_ast r = Z3_mk_fpa_is_infinite(ctx(), m_ast);
959 check_error();
960 return expr(ctx(), r);
961 }
962
966 expr mk_is_nan() const {
967 assert(is_fpa());
968 Z3_ast r = Z3_mk_fpa_is_nan(ctx(), m_ast);
969 check_error();
970 return expr(ctx(), r);
971 }
972
977 assert(is_fpa());
978 Z3_ast r = Z3_mk_fpa_is_normal(ctx(), m_ast);
979 check_error();
980 return expr(ctx(), r);
981 }
982
987 assert(is_fpa());
988 Z3_ast r = Z3_mk_fpa_is_subnormal(ctx(), m_ast);
989 check_error();
990 return expr(ctx(), r);
991 }
992
996 expr mk_is_zero() const {
997 assert(is_fpa());
998 Z3_ast r = Z3_mk_fpa_is_zero(ctx(), m_ast);
999 check_error();
1000 return expr(ctx(), r);
1001 }
1002
1007 assert(is_fpa());
1008 Z3_ast r = Z3_mk_fpa_to_ieee_bv(ctx(), m_ast);
1009 check_error();
1010 return expr(ctx(), r);
1011 }
1012
1016 expr mk_from_ieee_bv(sort const &s) const {
1017 assert(is_bv());
1018 Z3_ast r = Z3_mk_fpa_to_fp_bv(ctx(), m_ast, s);
1019 check_error();
1020 return expr(ctx(), r);
1021 }
1022
1029 std::string get_decimal_string(int precision) const {
1031 return std::string(Z3_get_numeral_decimal_string(ctx(), m_ast, precision));
1032 }
1033
1037 expr algebraic_lower(unsigned precision) const {
1038 assert(is_algebraic());
1039 Z3_ast r = Z3_get_algebraic_number_lower(ctx(), m_ast, precision);
1040 check_error();
1041 return expr(ctx(), r);
1042 }
1043
1044 expr algebraic_upper(unsigned precision) const {
1045 assert(is_algebraic());
1046 Z3_ast r = Z3_get_algebraic_number_upper(ctx(), m_ast, precision);
1047 check_error();
1048 return expr(ctx(), r);
1049 }
1050
1056 Z3_ast_vector r = Z3_algebraic_get_poly(ctx(), m_ast);
1057 check_error();
1058 return expr_vector(ctx(), r);
1059 }
1060
1064 unsigned algebraic_i() const {
1066 unsigned i = Z3_algebraic_get_i(ctx(), m_ast);
1067 check_error();
1068 return i;
1069 }
1070
1074 unsigned id() const { unsigned r = Z3_get_ast_id(ctx(), m_ast); check_error(); return r; }
1075
1086 int get_numeral_int() const {
1087 int result = 0;
1088 if (!is_numeral_i(result)) {
1089 assert(ctx().enable_exceptions());
1090 if (!ctx().enable_exceptions()) return 0;
1091 Z3_THROW(exception("numeral does not fit in machine int"));
1092 }
1093 return result;
1094 }
1095
1105 unsigned get_numeral_uint() const {
1106 assert(is_numeral());
1107 unsigned result = 0;
1108 if (!is_numeral_u(result)) {
1109 assert(ctx().enable_exceptions());
1110 if (!ctx().enable_exceptions()) return 0;
1111 Z3_THROW(exception("numeral does not fit in machine uint"));
1112 }
1113 return result;
1114 }
1115
1123 assert(is_numeral());
1124 int64_t result = 0;
1125 if (!is_numeral_i64(result)) {
1126 assert(ctx().enable_exceptions());
1127 if (!ctx().enable_exceptions()) return 0;
1128 Z3_THROW(exception("numeral does not fit in machine int64_t"));
1129 }
1130 return result;
1131 }
1132
1140 assert(is_numeral());
1141 uint64_t result = 0;
1142 if (!is_numeral_u64(result)) {
1143 assert(ctx().enable_exceptions());
1144 if (!ctx().enable_exceptions()) return 0;
1145 Z3_THROW(exception("numeral does not fit in machine uint64_t"));
1146 }
1147 return result;
1148 }
1149
1151 return Z3_get_bool_value(ctx(), m_ast);
1152 }
1153
1154 expr numerator() const {
1155 assert(is_numeral());
1156 Z3_ast r = Z3_get_numerator(ctx(), m_ast);
1157 check_error();
1158 return expr(ctx(),r);
1159 }
1160
1161
1163 assert(is_numeral());
1164 Z3_ast r = Z3_get_denominator(ctx(), m_ast);
1165 check_error();
1166 return expr(ctx(),r);
1167 }
1168
1169
1174 bool is_string_value() const { return Z3_is_string(ctx(), m_ast); }
1175
1181 std::string get_string() const {
1183 char const* s = Z3_get_string(ctx(), m_ast);
1184 check_error();
1185 return std::string(s);
1186 }
1187
1193 std::u32string get_u32string() const {
1195 unsigned n = Z3_get_string_length(ctx(), m_ast);
1196 std::u32string s;
1197 s.resize(n);
1198 Z3_get_string_contents(ctx(), m_ast, n, (unsigned*)s.data());
1199 return s;
1200 }
1201
1202 operator Z3_app() const { assert(is_app()); return reinterpret_cast<Z3_app>(m_ast); }
1203
1210 func_decl decl() const { Z3_func_decl f = Z3_get_app_decl(ctx(), *this); check_error(); return func_decl(ctx(), f); }
1217 unsigned num_args() const { unsigned r = Z3_get_app_num_args(ctx(), *this); check_error(); return r; }
1225 expr arg(unsigned i) const { Z3_ast r = Z3_get_app_arg(ctx(), *this, i); check_error(); return expr(ctx(), r); }
1233 expr_vector vec(ctx());
1234 unsigned argCnt = num_args();
1235 for (unsigned i = 0; i < argCnt; i++)
1236 vec.push_back(arg(i));
1237 return vec;
1238 }
1239
1245 expr body() const { assert(is_quantifier()); Z3_ast r = Z3_get_quantifier_body(ctx(), *this); check_error(); return expr(ctx(), r); }
1246
1252 friend expr operator!(expr const & a);
1253
1260 friend expr operator&&(expr const & a, expr const & b);
1261
1262
1269 friend expr operator&&(expr const & a, bool b);
1276 friend expr operator&&(bool a, expr const & b);
1277
1284 friend expr operator||(expr const & a, expr const & b);
1291 friend expr operator||(expr const & a, bool b);
1292
1299 friend expr operator||(bool a, expr const & b);
1300
1301 friend expr implies(expr const & a, expr const & b);
1302 friend expr implies(expr const & a, bool b);
1303 friend expr implies(bool a, expr const & b);
1304
1305 friend expr mk_or(expr_vector const& args);
1306 friend expr mk_xor(expr_vector const& args);
1307 friend expr mk_and(expr_vector const& args);
1308
1309 friend expr ite(expr const & c, expr const & t, expr const & e);
1310
1311 bool is_true() const { return is_app() && Z3_OP_TRUE == decl().decl_kind(); }
1312 bool is_false() const { return is_app() && Z3_OP_FALSE == decl().decl_kind(); }
1313 bool is_not() const { return is_app() && Z3_OP_NOT == decl().decl_kind(); }
1314 bool is_and() const { return is_app() && Z3_OP_AND == decl().decl_kind(); }
1315 bool is_or() const { return is_app() && Z3_OP_OR == decl().decl_kind(); }
1316 bool is_xor() const { return is_app() && Z3_OP_XOR == decl().decl_kind(); }
1317 bool is_implies() const { return is_app() && Z3_OP_IMPLIES == decl().decl_kind(); }
1318 bool is_eq() const { return is_app() && Z3_OP_EQ == decl().decl_kind(); }
1319 bool is_ite() const { return is_app() && Z3_OP_ITE == decl().decl_kind(); }
1320 bool is_distinct() const { return is_app() && Z3_OP_DISTINCT == decl().decl_kind(); }
1321
1322 friend expr distinct(expr_vector const& args);
1323 friend expr concat(expr const& a, expr const& b);
1324 friend expr concat(expr_vector const& args);
1325
1326 friend expr operator==(expr const & a, expr const & b);
1327 friend expr operator==(expr const & a, int b);
1328 friend expr operator==(int a, expr const & b);
1329
1330 friend expr operator!=(expr const & a, expr const & b);
1331 friend expr operator!=(expr const & a, int b);
1332 friend expr operator!=(int a, expr const & b);
1333
1334 friend expr operator+(expr const & a, expr const & b);
1335 friend expr operator+(expr const & a, int b);
1336 friend expr operator+(int a, expr const & b);
1337 friend expr sum(expr_vector const& args);
1338
1339 friend expr operator*(expr const & a, expr const & b);
1340 friend expr operator*(expr const & a, int b);
1341 friend expr operator*(int a, expr const & b);
1342
1343 /* \brief Power operator */
1344 friend expr pw(expr const & a, expr const & b);
1345 friend expr pw(expr const & a, int b);
1346 friend expr pw(int a, expr const & b);
1347
1348 /* \brief mod operator */
1349 friend expr mod(expr const& a, expr const& b);
1350 friend expr mod(expr const& a, int b);
1351 friend expr mod(int a, expr const& b);
1352
1353 /* \brief rem operator */
1354 friend expr rem(expr const& a, expr const& b);
1355 friend expr rem(expr const& a, int b);
1356 friend expr rem(int a, expr const& b);
1357
1358 friend expr is_int(expr const& e);
1359
1360 friend expr operator/(expr const & a, expr const & b);
1361 friend expr operator/(expr const & a, int b);
1362 friend expr operator/(int a, expr const & b);
1363
1364 friend expr operator-(expr const & a);
1365
1366 friend expr operator-(expr const & a, expr const & b);
1367 friend expr operator-(expr const & a, int b);
1368 friend expr operator-(int a, expr const & b);
1369
1370 friend expr operator<=(expr const & a, expr const & b);
1371 friend expr operator<=(expr const & a, int b);
1372 friend expr operator<=(int a, expr const & b);
1373
1374
1375 friend expr operator>=(expr const & a, expr const & b);
1376 friend expr operator>=(expr const & a, int b);
1377 friend expr operator>=(int a, expr const & b);
1378
1379 friend expr operator<(expr const & a, expr const & b);
1380 friend expr operator<(expr const & a, int b);
1381 friend expr operator<(int a, expr const & b);
1382
1383 friend expr operator>(expr const & a, expr const & b);
1384 friend expr operator>(expr const & a, int b);
1385 friend expr operator>(int a, expr const & b);
1386
1387 friend expr pble(expr_vector const& es, int const * coeffs, int bound);
1388 friend expr pbge(expr_vector const& es, int const * coeffs, int bound);
1389 friend expr pbeq(expr_vector const& es, int const * coeffs, int bound);
1390 friend expr atmost(expr_vector const& es, unsigned bound);
1391 friend expr atleast(expr_vector const& es, unsigned bound);
1392
1393 friend expr operator&(expr const & a, expr const & b);
1394 friend expr operator&(expr const & a, int b);
1395 friend expr operator&(int a, expr const & b);
1396
1397 friend expr operator^(expr const & a, expr const & b);
1398 friend expr operator^(expr const & a, int b);
1399 friend expr operator^(int a, expr const & b);
1400
1401 friend expr operator|(expr const & a, expr const & b);
1402 friend expr operator|(expr const & a, int b);
1403 friend expr operator|(int a, expr const & b);
1404 friend expr nand(expr const& a, expr const& b);
1405 friend expr nor(expr const& a, expr const& b);
1406 friend expr xnor(expr const& a, expr const& b);
1407
1408 friend expr min(expr const& a, expr const& b);
1409 friend expr max(expr const& a, expr const& b);
1410
1411 friend expr bv2int(expr const& a, bool is_signed);
1412 friend expr int2bv(unsigned n, expr const& a);
1413 friend expr bvadd_no_overflow(expr const& a, expr const& b, bool is_signed);
1414 friend expr bvadd_no_underflow(expr const& a, expr const& b);
1415 friend expr bvsub_no_overflow(expr const& a, expr const& b);
1416 friend expr bvsub_no_underflow(expr const& a, expr const& b, bool is_signed);
1417 friend expr bvsdiv_no_overflow(expr const& a, expr const& b);
1418 friend expr bvneg_no_overflow(expr const& a);
1419 friend expr bvmul_no_overflow(expr const& a, expr const& b, bool is_signed);
1420 friend expr bvmul_no_underflow(expr const& a, expr const& b);
1421
1422 expr rotate_left(unsigned i) const { Z3_ast r = Z3_mk_rotate_left(ctx(), i, *this); ctx().check_error(); return expr(ctx(), r); }
1423 expr rotate_right(unsigned i) const { Z3_ast r = Z3_mk_rotate_right(ctx(), i, *this); ctx().check_error(); return expr(ctx(), r); }
1424 expr repeat(unsigned i) const { Z3_ast r = Z3_mk_repeat(ctx(), i, *this); ctx().check_error(); return expr(ctx(), r); }
1425
1426 friend expr bvredor(expr const & a);
1427 friend expr bvredand(expr const & a);
1428
1429 friend expr abs(expr const & a);
1430 friend expr sqrt(expr const & a, expr const & rm);
1431 friend expr fp_eq(expr const & a, expr const & b);
1432
1433 friend expr operator~(expr const & a);
1434 expr extract(unsigned hi, unsigned lo) const { Z3_ast r = Z3_mk_extract(ctx(), hi, lo, *this); ctx().check_error(); return expr(ctx(), r); }
1435 expr bit2bool(unsigned i) const { Z3_ast r = Z3_mk_bit2bool(ctx(), i, *this); ctx().check_error(); return expr(ctx(), r); }
1436 unsigned lo() const { assert (is_app() && Z3_get_decl_num_parameters(ctx(), decl()) == 2); return static_cast<unsigned>(Z3_get_decl_int_parameter(ctx(), decl(), 1)); }
1437 unsigned hi() const { assert (is_app() && Z3_get_decl_num_parameters(ctx(), decl()) == 2); return static_cast<unsigned>(Z3_get_decl_int_parameter(ctx(), decl(), 0)); }
1438
1442 friend expr fma(expr const& a, expr const& b, expr const& c, expr const& rm);
1443
1447 friend expr fpa_fp(expr const& sgn, expr const& exp, expr const& sig);
1448
1452 friend expr fpa_to_sbv(expr const& t, unsigned sz);
1453
1457 friend expr fpa_to_ubv(expr const& t, unsigned sz);
1458
1462 friend expr sbv_to_fpa(expr const& t, sort s);
1463
1467 friend expr ubv_to_fpa(expr const& t, sort s);
1468
1472 friend expr fpa_to_fpa(expr const& t, sort s);
1473
1477 friend expr round_fpa_to_closest_integer(expr const& t);
1478
1484 expr extract(expr const& offset, expr const& length) const {
1486 Z3_ast r = Z3_mk_seq_extract(ctx(), *this, offset, length); check_error(); return expr(ctx(), r);
1487 }
1488 expr replace(expr const& src, expr const& dst) const {
1490 Z3_ast r = Z3_mk_seq_replace(ctx(), *this, src, dst);
1491 check_error();
1492 return expr(ctx(), r);
1493 }
1494 expr unit() const {
1495 Z3_ast r = Z3_mk_seq_unit(ctx(), *this);
1496 check_error();
1497 return expr(ctx(), r);
1498 }
1499 expr contains(expr const& s) const {
1500 check_context(*this, s);
1501 Z3_ast r = Z3_mk_seq_contains(ctx(), *this, s);
1502 check_error();
1503 return expr(ctx(), r);
1504 }
1505 expr at(expr const& index) const {
1506 check_context(*this, index);
1507 Z3_ast r = Z3_mk_seq_at(ctx(), *this, index);
1508 check_error();
1509 return expr(ctx(), r);
1510 }
1511 expr nth(expr const& index) const {
1512 check_context(*this, index);
1513 Z3_ast r = Z3_mk_seq_nth(ctx(), *this, index);
1514 check_error();
1515 return expr(ctx(), r);
1516 }
1517 expr length() const {
1518 Z3_ast r = Z3_mk_seq_length(ctx(), *this);
1519 check_error();
1520 return expr(ctx(), r);
1521 }
1522 expr stoi() const {
1523 Z3_ast r = Z3_mk_str_to_int(ctx(), *this);
1524 check_error();
1525 return expr(ctx(), r);
1526 }
1527 expr itos() const {
1528 Z3_ast r = Z3_mk_int_to_str(ctx(), *this);
1529 check_error();
1530 return expr(ctx(), r);
1531 }
1532 expr ubvtos() const {
1533 Z3_ast r = Z3_mk_ubv_to_str(ctx(), *this);
1534 check_error();
1535 return expr(ctx(), r);
1536 }
1537 expr sbvtos() const {
1538 Z3_ast r = Z3_mk_sbv_to_str(ctx(), *this);
1539 check_error();
1540 return expr(ctx(), r);
1541 }
1543 Z3_ast r = Z3_mk_char_to_int(ctx(), *this);
1544 check_error();
1545 return expr(ctx(), r);
1546 }
1548 Z3_ast r = Z3_mk_char_to_bv(ctx(), *this);
1549 check_error();
1550 return expr(ctx(), r);
1551 }
1553 Z3_ast r = Z3_mk_char_from_bv(ctx(), *this);
1554 check_error();
1555 return expr(ctx(), r);
1556 }
1557 expr is_digit() const {
1558 Z3_ast r = Z3_mk_char_is_digit(ctx(), *this);
1559 check_error();
1560 return expr(ctx(), r);
1561 }
1562
1563 friend expr range(expr const& lo, expr const& hi);
1567 expr loop(unsigned lo) {
1568 Z3_ast r = Z3_mk_re_loop(ctx(), m_ast, lo, 0);
1569 check_error();
1570 return expr(ctx(), r);
1571 }
1572 expr loop(unsigned lo, unsigned hi) {
1573 Z3_ast r = Z3_mk_re_loop(ctx(), m_ast, lo, hi);
1574 check_error();
1575 return expr(ctx(), r);
1576 }
1577
1581 expr operator[](expr const& index) const {
1582 assert(is_array() || is_seq());
1583 if (is_array()) {
1584 return select(*this, index);
1585 }
1586 return nth(index);
1587 }
1588
1589 expr operator[](expr_vector const& index) const {
1590 return select(*this, index);
1591 }
1592
1596 expr simplify() const { Z3_ast r = Z3_simplify(ctx(), m_ast); check_error(); return expr(ctx(), r); }
1600 expr simplify(params const & p) const { Z3_ast r = Z3_simplify_ex(ctx(), m_ast, p); check_error(); return expr(ctx(), r); }
1601
1605 expr substitute(expr_vector const& src, expr_vector const& dst);
1606
1611
1616
1617
1618 class iterator {
1619 expr& e;
1620 unsigned i;
1621 public:
1622 iterator(expr& e, unsigned i): e(e), i(i) {}
1623 bool operator==(iterator const& other) const noexcept {
1624 return i == other.i;
1625 }
1626 bool operator!=(iterator const& other) const noexcept {
1627 return i != other.i;
1628 }
1629 expr operator*() const { return e.arg(i); }
1630 iterator& operator++() { ++i; return *this; }
1631 iterator operator++(int) { assert(false); return *this; }
1632 };
1633
1634 iterator begin() { return iterator(*this, 0); }
1635 iterator end() { return iterator(*this, is_app() ? num_args() : 0); }
1636
1637 };
1638
1639#define _Z3_MK_BIN_(a, b, binop) \
1640 check_context(a, b); \
1641 Z3_ast r = binop(a.ctx(), a, b); \
1642 a.check_error(); \
1643 return expr(a.ctx(), r); \
1644
1645
1646 inline expr implies(expr const & a, expr const & b) {
1647 assert(a.is_bool() && b.is_bool());
1649 }
1650 inline expr implies(expr const & a, bool b) { return implies(a, a.ctx().bool_val(b)); }
1651 inline expr implies(bool a, expr const & b) { return implies(b.ctx().bool_val(a), b); }
1652
1653
1654 inline expr pw(expr const & a, expr const & b) { _Z3_MK_BIN_(a, b, Z3_mk_power); }
1655 inline expr pw(expr const & a, int b) { return pw(a, a.ctx().num_val(b, a.get_sort())); }
1656 inline expr pw(int a, expr const & b) { return pw(b.ctx().num_val(a, b.get_sort()), b); }
1657
1658 inline expr mod(expr const& a, expr const& b) {
1659 if (a.is_bv()) {
1661 }
1662 else {
1664 }
1665 }
1666 inline expr mod(expr const & a, int b) { return mod(a, a.ctx().num_val(b, a.get_sort())); }
1667 inline expr mod(int a, expr const & b) { return mod(b.ctx().num_val(a, b.get_sort()), b); }
1668
1669 inline expr operator%(expr const& a, expr const& b) { return mod(a, b); }
1670 inline expr operator%(expr const& a, int b) { return mod(a, b); }
1671 inline expr operator%(int a, expr const& b) { return mod(a, b); }
1672
1673
1674 inline expr rem(expr const& a, expr const& b) {
1675 if (a.is_fpa() && b.is_fpa()) {
1677 } else {
1679 }
1680 }
1681 inline expr rem(expr const & a, int b) { return rem(a, a.ctx().num_val(b, a.get_sort())); }
1682 inline expr rem(int a, expr const & b) { return rem(b.ctx().num_val(a, b.get_sort()), b); }
1683
1684#undef _Z3_MK_BIN_
1685
1686#define _Z3_MK_UN_(a, mkun) \
1687 Z3_ast r = mkun(a.ctx(), a); \
1688 a.check_error(); \
1689 return expr(a.ctx(), r); \
1690
1691
1692 inline expr operator!(expr const & a) { assert(a.is_bool()); _Z3_MK_UN_(a, Z3_mk_not); }
1693
1694 inline expr is_int(expr const& e) { _Z3_MK_UN_(e, Z3_mk_is_int); }
1695
1696#undef _Z3_MK_UN_
1697
1698 inline expr operator&&(expr const & a, expr const & b) {
1699 check_context(a, b);
1700 assert(a.is_bool() && b.is_bool());
1701 Z3_ast args[2] = { a, b };
1702 Z3_ast r = Z3_mk_and(a.ctx(), 2, args);
1703 a.check_error();
1704 return expr(a.ctx(), r);
1705 }
1706
1707 inline expr operator&&(expr const & a, bool b) { return a && a.ctx().bool_val(b); }
1708 inline expr operator&&(bool a, expr const & b) { return b.ctx().bool_val(a) && b; }
1709
1710 inline expr operator||(expr const & a, expr const & b) {
1711 check_context(a, b);
1712 assert(a.is_bool() && b.is_bool());
1713 Z3_ast args[2] = { a, b };
1714 Z3_ast r = Z3_mk_or(a.ctx(), 2, args);
1715 a.check_error();
1716 return expr(a.ctx(), r);
1717 }
1718
1719 inline expr operator||(expr const & a, bool b) { return a || a.ctx().bool_val(b); }
1720
1721 inline expr operator||(bool a, expr const & b) { return b.ctx().bool_val(a) || b; }
1722
1723 inline expr operator==(expr const & a, expr const & b) {
1724 check_context(a, b);
1725 Z3_ast r = Z3_mk_eq(a.ctx(), a, b);
1726 a.check_error();
1727 return expr(a.ctx(), r);
1728 }
1729 inline expr operator==(expr const & a, int b) { assert(a.is_arith() || a.is_bv() || a.is_fpa()); return a == a.ctx().num_val(b, a.get_sort()); }
1730 inline expr operator==(int a, expr const & b) { assert(b.is_arith() || b.is_bv() || b.is_fpa()); return b.ctx().num_val(a, b.get_sort()) == b; }
1731 inline expr operator==(expr const & a, double b) { assert(a.is_fpa()); return a == a.ctx().fpa_val(b); }
1732 inline expr operator==(double a, expr const & b) { assert(b.is_fpa()); return b.ctx().fpa_val(a) == b; }
1733
1734 inline expr operator!=(expr const & a, expr const & b) {
1735 check_context(a, b);
1736 Z3_ast args[2] = { a, b };
1737 Z3_ast r = Z3_mk_distinct(a.ctx(), 2, args);
1738 a.check_error();
1739 return expr(a.ctx(), r);
1740 }
1741 inline expr operator!=(expr const & a, int b) { assert(a.is_arith() || a.is_bv() || a.is_fpa()); return a != a.ctx().num_val(b, a.get_sort()); }
1742 inline expr operator!=(int a, expr const & b) { assert(b.is_arith() || b.is_bv() || b.is_fpa()); return b.ctx().num_val(a, b.get_sort()) != b; }
1743 inline expr operator!=(expr const & a, double b) { assert(a.is_fpa()); return a != a.ctx().fpa_val(b); }
1744 inline expr operator!=(double a, expr const & b) { assert(b.is_fpa()); return b.ctx().fpa_val(a) != b; }
1745
1746 inline expr operator+(expr const & a, expr const & b) {
1747 check_context(a, b);
1748 Z3_ast r = 0;
1749 if (a.is_arith() && b.is_arith()) {
1750 Z3_ast args[2] = { a, b };
1751 r = Z3_mk_add(a.ctx(), 2, args);
1752 }
1753 else if (a.is_bv() && b.is_bv()) {
1754 r = Z3_mk_bvadd(a.ctx(), a, b);
1755 }
1756 else if (a.is_seq() && b.is_seq()) {
1757 return concat(a, b);
1758 }
1759 else if (a.is_re() && b.is_re()) {
1760 Z3_ast _args[2] = { a, b };
1761 r = Z3_mk_re_union(a.ctx(), 2, _args);
1762 }
1763 else if (a.is_fpa() && b.is_fpa()) {
1764 r = Z3_mk_fpa_add(a.ctx(), a.ctx().fpa_rounding_mode(), a, b);
1765 }
1766 else {
1767 // operator is not supported by given arguments.
1768 assert(false);
1769 }
1770 a.check_error();
1771 return expr(a.ctx(), r);
1772 }
1773 inline expr operator+(expr const & a, int b) { return a + a.ctx().num_val(b, a.get_sort()); }
1774 inline expr operator+(int a, expr const & b) { return b.ctx().num_val(a, b.get_sort()) + b; }
1775
1776 inline expr operator*(expr const & a, expr const & b) {
1777 check_context(a, b);
1778 Z3_ast r = 0;
1779 if (a.is_arith() && b.is_arith()) {
1780 Z3_ast args[2] = { a, b };
1781 r = Z3_mk_mul(a.ctx(), 2, args);
1782 }
1783 else if (a.is_bv() && b.is_bv()) {
1784 r = Z3_mk_bvmul(a.ctx(), a, b);
1785 }
1786 else if (a.is_fpa() && b.is_fpa()) {
1787 r = Z3_mk_fpa_mul(a.ctx(), a.ctx().fpa_rounding_mode(), a, b);
1788 }
1789 else {
1790 // operator is not supported by given arguments.
1791 assert(false);
1792 }
1793 a.check_error();
1794 return expr(a.ctx(), r);
1795 }
1796 inline expr operator*(expr const & a, int b) { return a * a.ctx().num_val(b, a.get_sort()); }
1797 inline expr operator*(int a, expr const & b) { return b.ctx().num_val(a, b.get_sort()) * b; }
1798
1799
1800 inline expr operator>=(expr const & a, expr const & b) {
1801 check_context(a, b);
1802 Z3_ast r = 0;
1803 if (a.is_arith() && b.is_arith()) {
1804 r = Z3_mk_ge(a.ctx(), a, b);
1805 }
1806 else if (a.is_bv() && b.is_bv()) {
1807 r = Z3_mk_bvsge(a.ctx(), a, b);
1808 }
1809 else if (a.is_fpa() && b.is_fpa()) {
1810 r = Z3_mk_fpa_geq(a.ctx(), a, b);
1811 }
1812 else {
1813 // operator is not supported by given arguments.
1814 assert(false);
1815 }
1816 a.check_error();
1817 return expr(a.ctx(), r);
1818 }
1819
1820 inline expr operator/(expr const & a, expr const & b) {
1821 check_context(a, b);
1822 Z3_ast r = 0;
1823 if (a.is_arith() && b.is_arith()) {
1824 r = Z3_mk_div(a.ctx(), a, b);
1825 }
1826 else if (a.is_bv() && b.is_bv()) {
1827 r = Z3_mk_bvsdiv(a.ctx(), a, b);
1828 }
1829 else if (a.is_fpa() && b.is_fpa()) {
1830 r = Z3_mk_fpa_div(a.ctx(), a.ctx().fpa_rounding_mode(), a, b);
1831 }
1832 else {
1833 // operator is not supported by given arguments.
1834 assert(false);
1835 }
1836 a.check_error();
1837 return expr(a.ctx(), r);
1838 }
1839 inline expr operator/(expr const & a, int b) { return a / a.ctx().num_val(b, a.get_sort()); }
1840 inline expr operator/(int a, expr const & b) { return b.ctx().num_val(a, b.get_sort()) / b; }
1841
1842 inline expr operator-(expr const & a) {
1843 Z3_ast r = 0;
1844 if (a.is_arith()) {
1845 r = Z3_mk_unary_minus(a.ctx(), a);
1846 }
1847 else if (a.is_bv()) {
1848 r = Z3_mk_bvneg(a.ctx(), a);
1849 }
1850 else if (a.is_fpa()) {
1851 r = Z3_mk_fpa_neg(a.ctx(), a);
1852 }
1853 else {
1854 // operator is not supported by given arguments.
1855 assert(false);
1856 }
1857 a.check_error();
1858 return expr(a.ctx(), r);
1859 }
1860
1861 inline expr operator-(expr const & a, expr const & b) {
1862 check_context(a, b);
1863 Z3_ast r = 0;
1864 if (a.is_arith() && b.is_arith()) {
1865 Z3_ast args[2] = { a, b };
1866 r = Z3_mk_sub(a.ctx(), 2, args);
1867 }
1868 else if (a.is_bv() && b.is_bv()) {
1869 r = Z3_mk_bvsub(a.ctx(), a, b);
1870 }
1871 else if (a.is_fpa() && b.is_fpa()) {
1872 r = Z3_mk_fpa_sub(a.ctx(), a.ctx().fpa_rounding_mode(), a, b);
1873 }
1874 else {
1875 // operator is not supported by given arguments.
1876 assert(false);
1877 }
1878 a.check_error();
1879 return expr(a.ctx(), r);
1880 }
1881 inline expr operator-(expr const & a, int b) { return a - a.ctx().num_val(b, a.get_sort()); }
1882 inline expr operator-(int a, expr const & b) { return b.ctx().num_val(a, b.get_sort()) - b; }
1883
1884 inline expr operator<=(expr const & a, expr const & b) {
1885 check_context(a, b);
1886 Z3_ast r = 0;
1887 if (a.is_arith() && b.is_arith()) {
1888 r = Z3_mk_le(a.ctx(), a, b);
1889 }
1890 else if (a.is_bv() && b.is_bv()) {
1891 r = Z3_mk_bvsle(a.ctx(), a, b);
1892 }
1893 else if (a.is_fpa() && b.is_fpa()) {
1894 r = Z3_mk_fpa_leq(a.ctx(), a, b);
1895 }
1896 else {
1897 // operator is not supported by given arguments.
1898 assert(false);
1899 }
1900 a.check_error();
1901 return expr(a.ctx(), r);
1902 }
1903 inline expr operator<=(expr const & a, int b) { return a <= a.ctx().num_val(b, a.get_sort()); }
1904 inline expr operator<=(int a, expr const & b) { return b.ctx().num_val(a, b.get_sort()) <= b; }
1905
1906 inline expr operator>=(expr const & a, int b) { return a >= a.ctx().num_val(b, a.get_sort()); }
1907 inline expr operator>=(int a, expr const & b) { return b.ctx().num_val(a, b.get_sort()) >= b; }
1908
1909 inline expr operator<(expr const & a, expr const & b) {
1910 check_context(a, b);
1911 Z3_ast r = 0;
1912 if (a.is_arith() && b.is_arith()) {
1913 r = Z3_mk_lt(a.ctx(), a, b);
1914 }
1915 else if (a.is_bv() && b.is_bv()) {
1916 r = Z3_mk_bvslt(a.ctx(), a, b);
1917 }
1918 else if (a.is_fpa() && b.is_fpa()) {
1919 r = Z3_mk_fpa_lt(a.ctx(), a, b);
1920 }
1921 else {
1922 // operator is not supported by given arguments.
1923 assert(false);
1924 }
1925 a.check_error();
1926 return expr(a.ctx(), r);
1927 }
1928 inline expr operator<(expr const & a, int b) { return a < a.ctx().num_val(b, a.get_sort()); }
1929 inline expr operator<(int a, expr const & b) { return b.ctx().num_val(a, b.get_sort()) < b; }
1930
1931 inline expr operator>(expr const & a, expr const & b) {
1932 check_context(a, b);
1933 Z3_ast r = 0;
1934 if (a.is_arith() && b.is_arith()) {
1935 r = Z3_mk_gt(a.ctx(), a, b);
1936 }
1937 else if (a.is_bv() && b.is_bv()) {
1938 r = Z3_mk_bvsgt(a.ctx(), a, b);
1939 }
1940 else if (a.is_fpa() && b.is_fpa()) {
1941 r = Z3_mk_fpa_gt(a.ctx(), a, b);
1942 }
1943 else {
1944 // operator is not supported by given arguments.
1945 assert(false);
1946 }
1947 a.check_error();
1948 return expr(a.ctx(), r);
1949 }
1950 inline expr operator>(expr const & a, int b) { return a > a.ctx().num_val(b, a.get_sort()); }
1951 inline expr operator>(int a, expr const & b) { return b.ctx().num_val(a, b.get_sort()) > b; }
1952
1953 inline expr operator&(expr const & a, expr const & b) { if (a.is_bool()) return a && b; check_context(a, b); Z3_ast r = Z3_mk_bvand(a.ctx(), a, b); a.check_error(); return expr(a.ctx(), r); }
1954 inline expr operator&(expr const & a, int b) { return a & a.ctx().num_val(b, a.get_sort()); }
1955 inline expr operator&(int a, expr const & b) { return b.ctx().num_val(a, b.get_sort()) & b; }
1956
1957 inline expr operator^(expr const & a, expr const & b) { check_context(a, b); Z3_ast r = a.is_bool() ? Z3_mk_xor(a.ctx(), a, b) : Z3_mk_bvxor(a.ctx(), a, b); a.check_error(); return expr(a.ctx(), r); }
1958 inline expr operator^(expr const & a, int b) { return a ^ a.ctx().num_val(b, a.get_sort()); }
1959 inline expr operator^(int a, expr const & b) { return b.ctx().num_val(a, b.get_sort()) ^ b; }
1960
1961 inline expr operator|(expr const & a, expr const & b) { if (a.is_bool()) return a || b; check_context(a, b); Z3_ast r = Z3_mk_bvor(a.ctx(), a, b); a.check_error(); return expr(a.ctx(), r); }
1962 inline expr operator|(expr const & a, int b) { return a | a.ctx().num_val(b, a.get_sort()); }
1963 inline expr operator|(int a, expr const & b) { return b.ctx().num_val(a, b.get_sort()) | b; }
1964
1965 inline expr nand(expr const& a, expr const& b) { if (a.is_bool()) return !(a && b); check_context(a, b); Z3_ast r = Z3_mk_bvnand(a.ctx(), a, b); a.check_error(); return expr(a.ctx(), r); }
1966 inline expr nor(expr const& a, expr const& b) { if (a.is_bool()) return !(a || b); check_context(a, b); Z3_ast r = Z3_mk_bvnor(a.ctx(), a, b); a.check_error(); return expr(a.ctx(), r); }
1967 inline expr xnor(expr const& a, expr const& b) { if (a.is_bool()) return !(a ^ b); check_context(a, b); Z3_ast r = Z3_mk_bvxnor(a.ctx(), a, b); a.check_error(); return expr(a.ctx(), r); }
1968 inline expr min(expr const& a, expr const& b) {
1969 check_context(a, b);
1970 Z3_ast r;
1971 if (a.is_arith()) {
1972 r = Z3_mk_ite(a.ctx(), Z3_mk_ge(a.ctx(), a, b), b, a);
1973 }
1974 else if (a.is_bv()) {
1975 r = Z3_mk_ite(a.ctx(), Z3_mk_bvuge(a.ctx(), a, b), b, a);
1976 }
1977 else {
1978 assert(a.is_fpa());
1979 r = Z3_mk_fpa_min(a.ctx(), a, b);
1980 }
1981 a.check_error();
1982 return expr(a.ctx(), r);
1983 }
1984 inline expr max(expr const& a, expr const& b) {
1985 check_context(a, b);
1986 Z3_ast r;
1987 if (a.is_arith()) {
1988 r = Z3_mk_ite(a.ctx(), Z3_mk_ge(a.ctx(), a, b), a, b);
1989 }
1990 else if (a.is_bv()) {
1991 r = Z3_mk_ite(a.ctx(), Z3_mk_bvuge(a.ctx(), a, b), a, b);
1992 }
1993 else {
1994 assert(a.is_fpa());
1995 r = Z3_mk_fpa_max(a.ctx(), a, b);
1996 }
1997 a.check_error();
1998 return expr(a.ctx(), r);
1999 }
2000 inline expr bvredor(expr const & a) {
2001 assert(a.is_bv());
2002 Z3_ast r = Z3_mk_bvredor(a.ctx(), a);
2003 a.check_error();
2004 return expr(a.ctx(), r);
2005 }
2006 inline expr bvredand(expr const & a) {
2007 assert(a.is_bv());
2008 Z3_ast r = Z3_mk_bvredand(a.ctx(), a);
2009 a.check_error();
2010 return expr(a.ctx(), r);
2011 }
2012 inline expr abs(expr const & a) {
2013 Z3_ast r;
2014 if (a.is_int()) {
2015 expr zero = a.ctx().int_val(0);
2016 expr ge = a >= zero;
2017 expr na = -a;
2018 r = Z3_mk_ite(a.ctx(), ge, a, na);
2019 }
2020 else if (a.is_real()) {
2021 expr zero = a.ctx().real_val(0);
2022 expr ge = a >= zero;
2023 expr na = -a;
2024 r = Z3_mk_ite(a.ctx(), ge, a, na);
2025 }
2026 else {
2027 r = Z3_mk_fpa_abs(a.ctx(), a);
2028 }
2029 a.check_error();
2030 return expr(a.ctx(), r);
2031 }
2032 inline expr sqrt(expr const & a, expr const& rm) {
2033 check_context(a, rm);
2034 assert(a.is_fpa());
2035 Z3_ast r = Z3_mk_fpa_sqrt(a.ctx(), rm, a);
2036 a.check_error();
2037 return expr(a.ctx(), r);
2038 }
2039 inline expr fp_eq(expr const & a, expr const & b) {
2040 check_context(a, b);
2041 assert(a.is_fpa());
2042 Z3_ast r = Z3_mk_fpa_eq(a.ctx(), a, b);
2043 a.check_error();
2044 return expr(a.ctx(), r);
2045 }
2046 inline expr operator~(expr const & a) { Z3_ast r = Z3_mk_bvnot(a.ctx(), a); return expr(a.ctx(), r); }
2047
2048 inline expr fma(expr const& a, expr const& b, expr const& c, expr const& rm) {
2050 assert(a.is_fpa() && b.is_fpa() && c.is_fpa());
2051 Z3_ast r = Z3_mk_fpa_fma(a.ctx(), rm, a, b, c);
2052 a.check_error();
2053 return expr(a.ctx(), r);
2054 }
2055
2056 inline expr fpa_fp(expr const& sgn, expr const& exp, expr const& sig) {
2058 assert(sgn.is_bv() && exp.is_bv() && sig.is_bv());
2059 Z3_ast r = Z3_mk_fpa_fp(sgn.ctx(), sgn, exp, sig);
2060 sgn.check_error();
2061 return expr(sgn.ctx(), r);
2062 }
2063
2064 inline expr fpa_to_sbv(expr const& t, unsigned sz) {
2065 assert(t.is_fpa());
2066 Z3_ast r = Z3_mk_fpa_to_sbv(t.ctx(), t.ctx().fpa_rounding_mode(), t, sz);
2067 t.check_error();
2068 return expr(t.ctx(), r);
2069 }
2070
2071 inline expr fpa_to_ubv(expr const& t, unsigned sz) {
2072 assert(t.is_fpa());
2073 Z3_ast r = Z3_mk_fpa_to_ubv(t.ctx(), t.ctx().fpa_rounding_mode(), t, sz);
2074 t.check_error();
2075 return expr(t.ctx(), r);
2076 }
2077
2078 inline expr sbv_to_fpa(expr const& t, sort s) {
2079 assert(t.is_bv());
2080 Z3_ast r = Z3_mk_fpa_to_fp_signed(t.ctx(), t.ctx().fpa_rounding_mode(), t, s);
2081 t.check_error();
2082 return expr(t.ctx(), r);
2083 }
2084
2085 inline expr ubv_to_fpa(expr const& t, sort s) {
2086 assert(t.is_bv());
2087 Z3_ast r = Z3_mk_fpa_to_fp_unsigned(t.ctx(), t.ctx().fpa_rounding_mode(), t, s);
2088 t.check_error();
2089 return expr(t.ctx(), r);
2090 }
2091
2092 inline expr fpa_to_fpa(expr const& t, sort s) {
2093 assert(t.is_fpa());
2094 Z3_ast r = Z3_mk_fpa_to_fp_float(t.ctx(), t.ctx().fpa_rounding_mode(), t, s);
2095 t.check_error();
2096 return expr(t.ctx(), r);
2097 }
2098
2100 assert(t.is_fpa());
2101 Z3_ast r = Z3_mk_fpa_round_to_integral(t.ctx(), t.ctx().fpa_rounding_mode(), t);
2102 t.check_error();
2103 return expr(t.ctx(), r);
2104 }
2105
2111 inline expr ite(expr const & c, expr const & t, expr const & e) {
2112 check_context(c, t); check_context(c, e);
2113 assert(c.is_bool());
2114 Z3_ast r = Z3_mk_ite(c.ctx(), c, t, e);
2115 c.check_error();
2116 return expr(c.ctx(), r);
2117 }
2118
2119
2124 inline expr to_expr(context & c, Z3_ast a) {
2125 c.check_error();
2128 Z3_get_ast_kind(c, a) == Z3_VAR_AST ||
2130 return expr(c, a);
2131 }
2132
2133 inline sort to_sort(context & c, Z3_sort s) {
2134 c.check_error();
2135 return sort(c, s);
2136 }
2137
2138 inline func_decl to_func_decl(context & c, Z3_func_decl f) {
2139 c.check_error();
2140 return func_decl(c, f);
2141 }
2142
2146 inline expr sle(expr const & a, expr const & b) { return to_expr(a.ctx(), Z3_mk_bvsle(a.ctx(), a, b)); }
2147 inline expr sle(expr const & a, int b) { return sle(a, a.ctx().num_val(b, a.get_sort())); }
2148 inline expr sle(int a, expr const & b) { return sle(b.ctx().num_val(a, b.get_sort()), b); }
2152 inline expr slt(expr const & a, expr const & b) { return to_expr(a.ctx(), Z3_mk_bvslt(a.ctx(), a, b)); }
2153 inline expr slt(expr const & a, int b) { return slt(a, a.ctx().num_val(b, a.get_sort())); }
2154 inline expr slt(int a, expr const & b) { return slt(b.ctx().num_val(a, b.get_sort()), b); }
2158 inline expr sge(expr const & a, expr const & b) { return to_expr(a.ctx(), Z3_mk_bvsge(a.ctx(), a, b)); }
2159 inline expr sge(expr const & a, int b) { return sge(a, a.ctx().num_val(b, a.get_sort())); }
2160 inline expr sge(int a, expr const & b) { return sge(b.ctx().num_val(a, b.get_sort()), b); }
2164 inline expr sgt(expr const & a, expr const & b) { return to_expr(a.ctx(), Z3_mk_bvsgt(a.ctx(), a, b)); }
2165 inline expr sgt(expr const & a, int b) { return sgt(a, a.ctx().num_val(b, a.get_sort())); }
2166 inline expr sgt(int a, expr const & b) { return sgt(b.ctx().num_val(a, b.get_sort()), b); }
2167
2168
2172 inline expr ule(expr const & a, expr const & b) { return to_expr(a.ctx(), Z3_mk_bvule(a.ctx(), a, b)); }
2173 inline expr ule(expr const & a, int b) { return ule(a, a.ctx().num_val(b, a.get_sort())); }
2174 inline expr ule(int a, expr const & b) { return ule(b.ctx().num_val(a, b.get_sort()), b); }
2178 inline expr ult(expr const & a, expr const & b) { return to_expr(a.ctx(), Z3_mk_bvult(a.ctx(), a, b)); }
2179 inline expr ult(expr const & a, int b) { return ult(a, a.ctx().num_val(b, a.get_sort())); }
2180 inline expr ult(int a, expr const & b) { return ult(b.ctx().num_val(a, b.get_sort()), b); }
2184 inline expr uge(expr const & a, expr const & b) { return to_expr(a.ctx(), Z3_mk_bvuge(a.ctx(), a, b)); }
2185 inline expr uge(expr const & a, int b) { return uge(a, a.ctx().num_val(b, a.get_sort())); }
2186 inline expr uge(int a, expr const & b) { return uge(b.ctx().num_val(a, b.get_sort()), b); }
2190 inline expr ugt(expr const & a, expr const & b) { return to_expr(a.ctx(), Z3_mk_bvugt(a.ctx(), a, b)); }
2191 inline expr ugt(expr const & a, int b) { return ugt(a, a.ctx().num_val(b, a.get_sort())); }
2192 inline expr ugt(int a, expr const & b) { return ugt(b.ctx().num_val(a, b.get_sort()), b); }
2193
2197 inline expr sdiv(expr const & a, expr const & b) { return to_expr(a.ctx(), Z3_mk_bvsdiv(a.ctx(), a, b)); }
2198 inline expr sdiv(expr const & a, int b) { return sdiv(a, a.ctx().num_val(b, a.get_sort())); }
2199 inline expr sdiv(int a, expr const & b) { return sdiv(b.ctx().num_val(a, b.get_sort()), b); }
2200
2204 inline expr udiv(expr const & a, expr const & b) { return to_expr(a.ctx(), Z3_mk_bvudiv(a.ctx(), a, b)); }
2205 inline expr udiv(expr const & a, int b) { return udiv(a, a.ctx().num_val(b, a.get_sort())); }
2206 inline expr udiv(int a, expr const & b) { return udiv(b.ctx().num_val(a, b.get_sort()), b); }
2207
2211 inline expr srem(expr const & a, expr const & b) { return to_expr(a.ctx(), Z3_mk_bvsrem(a.ctx(), a, b)); }
2212 inline expr srem(expr const & a, int b) { return srem(a, a.ctx().num_val(b, a.get_sort())); }
2213 inline expr srem(int a, expr const & b) { return srem(b.ctx().num_val(a, b.get_sort()), b); }
2214
2218 inline expr smod(expr const & a, expr const & b) { return to_expr(a.ctx(), Z3_mk_bvsmod(a.ctx(), a, b)); }
2219 inline expr smod(expr const & a, int b) { return smod(a, a.ctx().num_val(b, a.get_sort())); }
2220 inline expr smod(int a, expr const & b) { return smod(b.ctx().num_val(a, b.get_sort()), b); }
2221
2225 inline expr urem(expr const & a, expr const & b) { return to_expr(a.ctx(), Z3_mk_bvurem(a.ctx(), a, b)); }
2226 inline expr urem(expr const & a, int b) { return urem(a, a.ctx().num_val(b, a.get_sort())); }
2227 inline expr urem(int a, expr const & b) { return urem(b.ctx().num_val(a, b.get_sort()), b); }
2228
2232 inline expr shl(expr const & a, expr const & b) { return to_expr(a.ctx(), Z3_mk_bvshl(a.ctx(), a, b)); }
2233 inline expr shl(expr const & a, int b) { return shl(a, a.ctx().num_val(b, a.get_sort())); }
2234 inline expr shl(int a, expr const & b) { return shl(b.ctx().num_val(a, b.get_sort()), b); }
2235
2239 inline expr lshr(expr const & a, expr const & b) { return to_expr(a.ctx(), Z3_mk_bvlshr(a.ctx(), a, b)); }
2240 inline expr lshr(expr const & a, int b) { return lshr(a, a.ctx().num_val(b, a.get_sort())); }
2241 inline expr lshr(int a, expr const & b) { return lshr(b.ctx().num_val(a, b.get_sort()), b); }
2242
2246 inline expr ashr(expr const & a, expr const & b) { return to_expr(a.ctx(), Z3_mk_bvashr(a.ctx(), a, b)); }
2247 inline expr ashr(expr const & a, int b) { return ashr(a, a.ctx().num_val(b, a.get_sort())); }
2248 inline expr ashr(int a, expr const & b) { return ashr(b.ctx().num_val(a, b.get_sort()), b); }
2249
2253 inline expr zext(expr const & a, unsigned i) { return to_expr(a.ctx(), Z3_mk_zero_ext(a.ctx(), i, a)); }
2254
2258 inline expr bv2int(expr const& a, bool is_signed) { Z3_ast r = Z3_mk_bv2int(a.ctx(), a, is_signed); a.check_error(); return expr(a.ctx(), r); }
2259 inline expr int2bv(unsigned n, expr const& a) { Z3_ast r = Z3_mk_int2bv(a.ctx(), n, a); a.check_error(); return expr(a.ctx(), r); }
2260
2264 inline expr bvadd_no_overflow(expr const& a, expr const& b, bool is_signed) {
2265 check_context(a, b); Z3_ast r = Z3_mk_bvadd_no_overflow(a.ctx(), a, b, is_signed); a.check_error(); return expr(a.ctx(), r);
2266 }
2267 inline expr bvadd_no_underflow(expr const& a, expr const& b) {
2268 check_context(a, b); Z3_ast r = Z3_mk_bvadd_no_underflow(a.ctx(), a, b); a.check_error(); return expr(a.ctx(), r);
2269 }
2270 inline expr bvsub_no_overflow(expr const& a, expr const& b) {
2271 check_context(a, b); Z3_ast r = Z3_mk_bvsub_no_overflow(a.ctx(), a, b); a.check_error(); return expr(a.ctx(), r);
2272 }
2273 inline expr bvsub_no_underflow(expr const& a, expr const& b, bool is_signed) {
2274 check_context(a, b); Z3_ast r = Z3_mk_bvsub_no_underflow(a.ctx(), a, b, is_signed); a.check_error(); return expr(a.ctx(), r);
2275 }
2276 inline expr bvsdiv_no_overflow(expr const& a, expr const& b) {
2277 check_context(a, b); Z3_ast r = Z3_mk_bvsdiv_no_overflow(a.ctx(), a, b); a.check_error(); return expr(a.ctx(), r);
2278 }
2279 inline expr bvneg_no_overflow(expr const& a) {
2280 Z3_ast r = Z3_mk_bvneg_no_overflow(a.ctx(), a); a.check_error(); return expr(a.ctx(), r);
2281 }
2282 inline expr bvmul_no_overflow(expr const& a, expr const& b, bool is_signed) {
2283 check_context(a, b); Z3_ast r = Z3_mk_bvmul_no_overflow(a.ctx(), a, b, is_signed); a.check_error(); return expr(a.ctx(), r);
2284 }
2285 inline expr bvmul_no_underflow(expr const& a, expr const& b) {
2286 check_context(a, b); Z3_ast r = Z3_mk_bvmul_no_underflow(a.ctx(), a, b); a.check_error(); return expr(a.ctx(), r);
2287 }
2288
2289
2293 inline expr sext(expr const & a, unsigned i) { return to_expr(a.ctx(), Z3_mk_sign_ext(a.ctx(), i, a)); }
2294
2295 inline func_decl linear_order(sort const& a, unsigned index) {
2296 return to_func_decl(a.ctx(), Z3_mk_linear_order(a.ctx(), a, index));
2297 }
2298 inline func_decl partial_order(sort const& a, unsigned index) {
2299 return to_func_decl(a.ctx(), Z3_mk_partial_order(a.ctx(), a, index));
2300 }
2301 inline func_decl piecewise_linear_order(sort const& a, unsigned index) {
2302 return to_func_decl(a.ctx(), Z3_mk_piecewise_linear_order(a.ctx(), a, index));
2303 }
2304 inline func_decl tree_order(sort const& a, unsigned index) {
2305 return to_func_decl(a.ctx(), Z3_mk_tree_order(a.ctx(), a, index));
2306 }
2307
2308 template<> class cast_ast<ast> {
2309 public:
2310 ast operator()(context & c, Z3_ast a) { return ast(c, a); }
2311 };
2312
2313 template<> class cast_ast<expr> {
2314 public:
2315 expr operator()(context & c, Z3_ast a) {
2317 Z3_get_ast_kind(c, a) == Z3_APP_AST ||
2320 return expr(c, a);
2321 }
2322 };
2323
2324 template<> class cast_ast<sort> {
2325 public:
2326 sort operator()(context & c, Z3_ast a) {
2328 return sort(c, reinterpret_cast<Z3_sort>(a));
2329 }
2330 };
2331
2332 template<> class cast_ast<func_decl> {
2333 public:
2336 return func_decl(c, reinterpret_cast<Z3_func_decl>(a));
2337 }
2338 };
2339
2340 template<typename T>
2341 template<typename T2>
2342 array<T>::array(ast_vector_tpl<T2> const & v):m_array(new T[v.size()]), m_size(v.size()) {
2343 for (unsigned i = 0; i < m_size; i++) {
2344 m_array[i] = v[i];
2345 }
2346 }
2347
2348 // Basic functions for creating quantified formulas.
2349 // The C API should be used for creating quantifiers with patterns, weights, many variables, etc.
2350 inline expr forall(expr const & x, expr const & b) {
2351 check_context(x, b);
2352 Z3_app vars[] = {(Z3_app) x};
2353 Z3_ast r = Z3_mk_forall_const(b.ctx(), 0, 1, vars, 0, 0, b); b.check_error(); return expr(b.ctx(), r);
2354 }
2355 inline expr forall(expr const & x1, expr const & x2, expr const & b) {
2357 Z3_app vars[] = {(Z3_app) x1, (Z3_app) x2};
2358 Z3_ast r = Z3_mk_forall_const(b.ctx(), 0, 2, vars, 0, 0, b); b.check_error(); return expr(b.ctx(), r);
2359 }
2360 inline expr forall(expr const & x1, expr const & x2, expr const & x3, expr const & b) {
2362 Z3_app vars[] = {(Z3_app) x1, (Z3_app) x2, (Z3_app) x3 };
2363 Z3_ast r = Z3_mk_forall_const(b.ctx(), 0, 3, vars, 0, 0, b); b.check_error(); return expr(b.ctx(), r);
2364 }
2365 inline expr forall(expr const & x1, expr const & x2, expr const & x3, expr const & x4, expr const & b) {
2367 Z3_app vars[] = {(Z3_app) x1, (Z3_app) x2, (Z3_app) x3, (Z3_app) x4 };
2368 Z3_ast r = Z3_mk_forall_const(b.ctx(), 0, 4, vars, 0, 0, b); b.check_error(); return expr(b.ctx(), r);
2369 }
2370 inline expr forall(expr_vector const & xs, expr const & b) {
2371 array<Z3_app> vars(xs);
2372 Z3_ast r = Z3_mk_forall_const(b.ctx(), 0, vars.size(), vars.ptr(), 0, 0, b); b.check_error(); return expr(b.ctx(), r);
2373 }
2374 inline expr exists(expr const & x, expr const & b) {
2375 check_context(x, b);
2376 Z3_app vars[] = {(Z3_app) x};
2377 Z3_ast r = Z3_mk_exists_const(b.ctx(), 0, 1, vars, 0, 0, b); b.check_error(); return expr(b.ctx(), r);
2378 }
2379 inline expr exists(expr const & x1, expr const & x2, expr const & b) {
2381 Z3_app vars[] = {(Z3_app) x1, (Z3_app) x2};
2382 Z3_ast r = Z3_mk_exists_const(b.ctx(), 0, 2, vars, 0, 0, b); b.check_error(); return expr(b.ctx(), r);
2383 }
2384 inline expr exists(expr const & x1, expr const & x2, expr const & x3, expr const & b) {
2386 Z3_app vars[] = {(Z3_app) x1, (Z3_app) x2, (Z3_app) x3 };
2387 Z3_ast r = Z3_mk_exists_const(b.ctx(), 0, 3, vars, 0, 0, b); b.check_error(); return expr(b.ctx(), r);
2388 }
2389 inline expr exists(expr const & x1, expr const & x2, expr const & x3, expr const & x4, expr const & b) {
2391 Z3_app vars[] = {(Z3_app) x1, (Z3_app) x2, (Z3_app) x3, (Z3_app) x4 };
2392 Z3_ast r = Z3_mk_exists_const(b.ctx(), 0, 4, vars, 0, 0, b); b.check_error(); return expr(b.ctx(), r);
2393 }
2394 inline expr exists(expr_vector const & xs, expr const & b) {
2395 array<Z3_app> vars(xs);
2396 Z3_ast r = Z3_mk_exists_const(b.ctx(), 0, vars.size(), vars.ptr(), 0, 0, b); b.check_error(); return expr(b.ctx(), r);
2397 }
2398 inline expr lambda(expr const & x, expr const & b) {
2399 check_context(x, b);
2400 Z3_app vars[] = {(Z3_app) x};
2401 Z3_ast r = Z3_mk_lambda_const(b.ctx(), 1, vars, b); b.check_error(); return expr(b.ctx(), r);
2402 }
2403 inline expr lambda(expr const & x1, expr const & x2, expr const & b) {
2405 Z3_app vars[] = {(Z3_app) x1, (Z3_app) x2};
2406 Z3_ast r = Z3_mk_lambda_const(b.ctx(), 2, vars, b); b.check_error(); return expr(b.ctx(), r);
2407 }
2408 inline expr lambda(expr const & x1, expr const & x2, expr const & x3, expr const & b) {
2410 Z3_app vars[] = {(Z3_app) x1, (Z3_app) x2, (Z3_app) x3 };
2411 Z3_ast r = Z3_mk_lambda_const(b.ctx(), 3, vars, b); b.check_error(); return expr(b.ctx(), r);
2412 }
2413 inline expr lambda(expr const & x1, expr const & x2, expr const & x3, expr const & x4, expr const & b) {
2415 Z3_app vars[] = {(Z3_app) x1, (Z3_app) x2, (Z3_app) x3, (Z3_app) x4 };
2416 Z3_ast r = Z3_mk_lambda_const(b.ctx(), 4, vars, b); b.check_error(); return expr(b.ctx(), r);
2417 }
2418 inline expr lambda(expr_vector const & xs, expr const & b) {
2419 array<Z3_app> vars(xs);
2420 Z3_ast r = Z3_mk_lambda_const(b.ctx(), vars.size(), vars.ptr(), b); b.check_error(); return expr(b.ctx(), r);
2421 }
2422
2423 inline expr pble(expr_vector const& es, int const* coeffs, int bound) {
2424 assert(es.size() > 0);
2425 context& ctx = es[0u].ctx();
2427 Z3_ast r = Z3_mk_pble(ctx, _es.size(), _es.ptr(), coeffs, bound);
2428 ctx.check_error();
2429 return expr(ctx, r);
2430 }
2431 inline expr pbge(expr_vector const& es, int const* coeffs, int bound) {
2432 assert(es.size() > 0);
2433 context& ctx = es[0u].ctx();
2435 Z3_ast r = Z3_mk_pbge(ctx, _es.size(), _es.ptr(), coeffs, bound);
2436 ctx.check_error();
2437 return expr(ctx, r);
2438 }
2439 inline expr pbeq(expr_vector const& es, int const* coeffs, int bound) {
2440 assert(es.size() > 0);
2441 context& ctx = es[0u].ctx();
2443 Z3_ast r = Z3_mk_pbeq(ctx, _es.size(), _es.ptr(), coeffs, bound);
2444 ctx.check_error();
2445 return expr(ctx, r);
2446 }
2447 inline expr atmost(expr_vector const& es, unsigned bound) {
2448 assert(es.size() > 0);
2449 context& ctx = es[0u].ctx();
2451 Z3_ast r = Z3_mk_atmost(ctx, _es.size(), _es.ptr(), bound);
2452 ctx.check_error();
2453 return expr(ctx, r);
2454 }
2455 inline expr atleast(expr_vector const& es, unsigned bound) {
2456 assert(es.size() > 0);
2457 context& ctx = es[0u].ctx();
2459 Z3_ast r = Z3_mk_atleast(ctx, _es.size(), _es.ptr(), bound);
2460 ctx.check_error();
2461 return expr(ctx, r);
2462 }
2463 inline expr sum(expr_vector const& args) {
2464 assert(args.size() > 0);
2465 context& ctx = args[0u].ctx();
2466 array<Z3_ast> _args(args);
2467 Z3_ast r = Z3_mk_add(ctx, _args.size(), _args.ptr());
2468 ctx.check_error();
2469 return expr(ctx, r);
2470 }
2471
2472 inline expr distinct(expr_vector const& args) {
2473 assert(args.size() > 0);
2474 context& ctx = args[0u].ctx();
2475 array<Z3_ast> _args(args);
2476 Z3_ast r = Z3_mk_distinct(ctx, _args.size(), _args.ptr());
2477 ctx.check_error();
2478 return expr(ctx, r);
2479 }
2480
2481 inline expr concat(expr const& a, expr const& b) {
2482 check_context(a, b);
2483 Z3_ast r;
2484 if (Z3_is_seq_sort(a.ctx(), a.get_sort())) {
2485 Z3_ast _args[2] = { a, b };
2486 r = Z3_mk_seq_concat(a.ctx(), 2, _args);
2487 }
2488 else if (Z3_is_re_sort(a.ctx(), a.get_sort())) {
2489 Z3_ast _args[2] = { a, b };
2490 r = Z3_mk_re_concat(a.ctx(), 2, _args);
2491 }
2492 else {
2493 r = Z3_mk_concat(a.ctx(), a, b);
2494 }
2495 a.ctx().check_error();
2496 return expr(a.ctx(), r);
2497 }
2498
2499 inline expr concat(expr_vector const& args) {
2500 Z3_ast r;
2501 assert(args.size() > 0);
2502 if (args.size() == 1) {
2503 return args[0u];
2504 }
2505 context& ctx = args[0u].ctx();
2506 array<Z3_ast> _args(args);
2507 if (Z3_is_seq_sort(ctx, args[0u].get_sort())) {
2508 r = Z3_mk_seq_concat(ctx, _args.size(), _args.ptr());
2509 }
2510 else if (Z3_is_re_sort(ctx, args[0u].get_sort())) {
2511 r = Z3_mk_re_concat(ctx, _args.size(), _args.ptr());
2512 }
2513 else {
2514 r = _args[args.size()-1];
2515 for (unsigned i = args.size()-1; i > 0; ) {
2516 --i;
2517 r = Z3_mk_concat(ctx, _args[i], r);
2518 ctx.check_error();
2519 }
2520 }
2521 ctx.check_error();
2522 return expr(ctx, r);
2523 }
2524
2525 inline expr map(expr const& f, expr const& list) {
2526 context& ctx = f.ctx();
2527 Z3_ast r = Z3_mk_seq_map(ctx, f, list);
2528 ctx.check_error();
2529 return expr(ctx, r);
2530 }
2531
2532 inline expr mapi(expr const& f, expr const& i, expr const& list) {
2533 context& ctx = f.ctx();
2534 Z3_ast r = Z3_mk_seq_mapi(ctx, f, i, list);
2535 ctx.check_error();
2536 return expr(ctx, r);
2537 }
2538
2539 inline expr foldl(expr const& f, expr const& a, expr const& list) {
2540 context& ctx = f.ctx();
2541 Z3_ast r = Z3_mk_seq_foldl(ctx, f, a, list);
2542 ctx.check_error();
2543 return expr(ctx, r);
2544 }
2545
2546 inline expr foldli(expr const& f, expr const& i, expr const& a, expr const& list) {
2547 context& ctx = f.ctx();
2548 Z3_ast r = Z3_mk_seq_foldli(ctx, f, i, a, list);
2549 ctx.check_error();
2550 return expr(ctx, r);
2551 }
2552
2553 inline expr mk_or(expr_vector const& args) {
2554 array<Z3_ast> _args(args);
2555 Z3_ast r = Z3_mk_or(args.ctx(), _args.size(), _args.ptr());
2556 args.check_error();
2557 return expr(args.ctx(), r);
2558 }
2559 inline expr mk_and(expr_vector const& args) {
2560 array<Z3_ast> _args(args);
2561 Z3_ast r = Z3_mk_and(args.ctx(), _args.size(), _args.ptr());
2562 args.check_error();
2563 return expr(args.ctx(), r);
2564 }
2565 inline expr mk_xor(expr_vector const& args) {
2566 if (args.empty())
2567 return args.ctx().bool_val(false);
2568 expr r = args[0u];
2569 for (unsigned i = 1; i < args.size(); ++i)
2570 r = r ^ args[i];
2571 return r;
2572 }
2573
2574
2575 class func_entry : public object {
2576 Z3_func_entry m_entry;
2577 void init(Z3_func_entry e) {
2578 m_entry = e;
2579 Z3_func_entry_inc_ref(ctx(), m_entry);
2580 }
2581 public:
2582 func_entry(context & c, Z3_func_entry e):object(c) { init(e); }
2583 func_entry(func_entry const & s):object(s) { init(s.m_entry); }
2584 ~func_entry() override { Z3_func_entry_dec_ref(ctx(), m_entry); }
2585 operator Z3_func_entry() const { return m_entry; }
2587 Z3_func_entry_inc_ref(s.ctx(), s.m_entry);
2588 Z3_func_entry_dec_ref(ctx(), m_entry);
2589 object::operator=(s);
2590 m_entry = s.m_entry;
2591 return *this;
2592 }
2593 expr value() const { Z3_ast r = Z3_func_entry_get_value(ctx(), m_entry); check_error(); return expr(ctx(), r); }
2594 unsigned num_args() const { unsigned r = Z3_func_entry_get_num_args(ctx(), m_entry); check_error(); return r; }
2595 expr arg(unsigned i) const { Z3_ast r = Z3_func_entry_get_arg(ctx(), m_entry, i); check_error(); return expr(ctx(), r); }
2596 };
2597
2598 class func_interp : public object {
2599 Z3_func_interp m_interp;
2600 void init(Z3_func_interp e) {
2601 m_interp = e;
2602 Z3_func_interp_inc_ref(ctx(), m_interp);
2603 }
2604 public:
2605 func_interp(context & c, Z3_func_interp e):object(c) { init(e); }
2606 func_interp(func_interp const & s):object(s) { init(s.m_interp); }
2607 ~func_interp() override { Z3_func_interp_dec_ref(ctx(), m_interp); }
2608 operator Z3_func_interp() const { return m_interp; }
2610 Z3_func_interp_inc_ref(s.ctx(), s.m_interp);
2611 Z3_func_interp_dec_ref(ctx(), m_interp);
2612 object::operator=(s);
2613 m_interp = s.m_interp;
2614 return *this;
2615 }
2616 expr else_value() const { Z3_ast r = Z3_func_interp_get_else(ctx(), m_interp); check_error(); return expr(ctx(), r); }
2617 unsigned num_entries() const { unsigned r = Z3_func_interp_get_num_entries(ctx(), m_interp); check_error(); return r; }
2618 func_entry entry(unsigned i) const { Z3_func_entry e = Z3_func_interp_get_entry(ctx(), m_interp, i); check_error(); return func_entry(ctx(), e); }
2619 void add_entry(expr_vector const& args, expr& value) {
2620 Z3_func_interp_add_entry(ctx(), m_interp, args, value);
2621 check_error();
2622 }
2623 void set_else(expr& value) {
2624 Z3_func_interp_set_else(ctx(), m_interp, value);
2625 check_error();
2626 }
2627 };
2628
2629 class model : public object {
2630 Z3_model m_model;
2631 void init(Z3_model m) {
2632 m_model = m;
2634 }
2635 public:
2636 struct translate {};
2637 model(context & c):object(c) { init(Z3_mk_model(c)); }
2638 model(context & c, Z3_model m):object(c) { init(m); }
2639 model(model const & s):object(s) { init(s.m_model); }
2641 ~model() override { Z3_model_dec_ref(ctx(), m_model); }
2642 operator Z3_model() const { return m_model; }
2643 model & operator=(model const & s) {
2644 Z3_model_inc_ref(s.ctx(), s.m_model);
2645 Z3_model_dec_ref(ctx(), m_model);
2646 object::operator=(s);
2647 m_model = s.m_model;
2648 return *this;
2649 }
2650
2651 expr eval(expr const & n, bool model_completion=false) const {
2652 check_context(*this, n);
2653 Z3_ast r = 0;
2654 bool status = Z3_model_eval(ctx(), m_model, n, model_completion, &r);
2655 check_error();
2656 if (status == false && ctx().enable_exceptions())
2657 Z3_THROW(exception("failed to evaluate expression"));
2658 return expr(ctx(), r);
2659 }
2660
2661 unsigned num_consts() const { return Z3_model_get_num_consts(ctx(), m_model); }
2662 unsigned num_funcs() const { return Z3_model_get_num_funcs(ctx(), m_model); }
2663 func_decl get_const_decl(unsigned i) const { Z3_func_decl r = Z3_model_get_const_decl(ctx(), m_model, i); check_error(); return func_decl(ctx(), r); }
2664 func_decl get_func_decl(unsigned i) const { Z3_func_decl r = Z3_model_get_func_decl(ctx(), m_model, i); check_error(); return func_decl(ctx(), r); }
2665 unsigned size() const { return num_consts() + num_funcs(); }
2666 func_decl operator[](int i) const {
2667 assert(0 <= i);
2668 return static_cast<unsigned>(i) < num_consts() ? get_const_decl(i) : get_func_decl(i - num_consts());
2669 }
2670
2671 // returns interpretation of constant declaration c.
2672 // If c is not assigned any value in the model it returns
2673 // an expression with a null ast reference.
2675 check_context(*this, c);
2676 Z3_ast r = Z3_model_get_const_interp(ctx(), m_model, c);
2677 check_error();
2678 return expr(ctx(), r);
2679 }
2681 check_context(*this, f);
2682 Z3_func_interp r = Z3_model_get_func_interp(ctx(), m_model, f);
2683 check_error();
2684 return func_interp(ctx(), r);
2685 }
2686
2687 // returns true iff the model contains an interpretation
2688 // for function f.
2689 bool has_interp(func_decl f) const {
2690 check_context(*this, f);
2691 return Z3_model_has_interp(ctx(), m_model, f);
2692 }
2693
2695 Z3_func_interp r = Z3_add_func_interp(ctx(), m_model, f, else_val);
2696 check_error();
2697 return func_interp(ctx(), r);
2698 }
2699
2701 Z3_add_const_interp(ctx(), m_model, f, value);
2702 check_error();
2703 }
2704
2705 friend std::ostream & operator<<(std::ostream & out, model const & m);
2706
2707 std::string to_string() const { return m_model ? std::string(Z3_model_to_string(ctx(), m_model)) : "null"; }
2708 };
2709 inline std::ostream & operator<<(std::ostream & out, model const & m) { return out << m.to_string(); }
2710
2711 class stats : public object {
2712 Z3_stats m_stats;
2713 void init(Z3_stats e) {
2714 m_stats = e;
2715 Z3_stats_inc_ref(ctx(), m_stats);
2716 }
2717 public:
2718 stats(context & c):object(c), m_stats(0) {}
2719 stats(context & c, Z3_stats e):object(c) { init(e); }
2720 stats(stats const & s):object(s) { init(s.m_stats); }
2721 ~stats() override { if (m_stats) Z3_stats_dec_ref(ctx(), m_stats); }
2722 operator Z3_stats() const { return m_stats; }
2723 stats & operator=(stats const & s) {
2724 Z3_stats_inc_ref(s.ctx(), s.m_stats);
2725 if (m_stats) Z3_stats_dec_ref(ctx(), m_stats);
2726 object::operator=(s);
2727 m_stats = s.m_stats;
2728 return *this;
2729 }
2730 unsigned size() const { return Z3_stats_size(ctx(), m_stats); }
2731 std::string key(unsigned i) const { Z3_string s = Z3_stats_get_key(ctx(), m_stats, i); check_error(); return s; }
2732 bool is_uint(unsigned i) const { bool r = Z3_stats_is_uint(ctx(), m_stats, i); check_error(); return r; }
2733 bool is_double(unsigned i) const { bool r = Z3_stats_is_double(ctx(), m_stats, i); check_error(); return r; }
2734 unsigned uint_value(unsigned i) const { unsigned r = Z3_stats_get_uint_value(ctx(), m_stats, i); check_error(); return r; }
2735 double double_value(unsigned i) const { double r = Z3_stats_get_double_value(ctx(), m_stats, i); check_error(); return r; }
2736 friend std::ostream & operator<<(std::ostream & out, stats const & s);
2737 };
2738 inline std::ostream & operator<<(std::ostream & out, stats const & s) { out << Z3_stats_to_string(s.ctx(), s); return out; }
2739
2740
2741 inline std::ostream & operator<<(std::ostream & out, check_result r) {
2742 if (r == unsat) out << "unsat";
2743 else if (r == sat) out << "sat";
2744 else out << "unknown";
2745 return out;
2746 }
2747
2759 Z3_parameter_kind m_kind;
2760 func_decl m_decl;
2761 unsigned m_index;
2762 context& ctx() const { return m_decl.ctx(); }
2763 void check_error() const { ctx().check_error(); }
2764 public:
2765 parameter(func_decl const& d, unsigned idx) : m_decl(d), m_index(idx) {
2766 if (ctx().enable_exceptions() && idx >= d.num_parameters())
2767 Z3_THROW(exception("parameter index is out of bounds"));
2768 m_kind = Z3_get_decl_parameter_kind(ctx(), d, idx);
2769 }
2770 parameter(expr const& e, unsigned idx) : m_decl(e.decl()), m_index(idx) {
2771 if (ctx().enable_exceptions() && idx >= m_decl.num_parameters())
2772 Z3_THROW(exception("parameter index is out of bounds"));
2773 m_kind = Z3_get_decl_parameter_kind(ctx(), m_decl, idx);
2774 }
2775 Z3_parameter_kind kind() const { return m_kind; }
2776 expr get_expr() const { Z3_ast a = Z3_get_decl_ast_parameter(ctx(), m_decl, m_index); check_error(); return expr(ctx(), a); }
2777 sort get_sort() const { Z3_sort s = Z3_get_decl_sort_parameter(ctx(), m_decl, m_index); check_error(); return sort(ctx(), s); }
2778 func_decl get_decl() const { Z3_func_decl f = Z3_get_decl_func_decl_parameter(ctx(), m_decl, m_index); check_error(); return func_decl(ctx(), f); }
2779 symbol get_symbol() const { Z3_symbol s = Z3_get_decl_symbol_parameter(ctx(), m_decl, m_index); check_error(); return symbol(ctx(), s); }
2780 std::string get_rational() const { Z3_string s = Z3_get_decl_rational_parameter(ctx(), m_decl, m_index); check_error(); return s; }
2781 double get_double() const { double d = Z3_get_decl_double_parameter(ctx(), m_decl, m_index); check_error(); return d; }
2782 int get_int() const { int i = Z3_get_decl_int_parameter(ctx(), m_decl, m_index); check_error(); return i; }
2783 };
2784
2785
2786 class solver : public object {
2787 Z3_solver m_solver;
2788 void init(Z3_solver s) {
2789 m_solver = s;
2790 if (s)
2791 Z3_solver_inc_ref(ctx(), s);
2792 }
2793 public:
2794 struct simple {};
2795 struct translate {};
2798 solver(context & c, Z3_solver s):object(c) { init(s); }
2800 solver(context & c, solver const& src, translate): object(c) { Z3_solver s = Z3_solver_translate(src.ctx(), src, c); check_error(); init(s); }
2801 solver(solver const & s):object(s) { init(s.m_solver); }
2802 solver(solver const& s, simplifier const& simp);
2803 ~solver() override { Z3_solver_dec_ref(ctx(), m_solver); }
2804 operator Z3_solver() const { return m_solver; }
2805 solver & operator=(solver const & s) {
2806 Z3_solver_inc_ref(s.ctx(), s.m_solver);
2807 Z3_solver_dec_ref(ctx(), m_solver);
2808 object::operator=(s);
2809 m_solver = s.m_solver;
2810 return *this;
2811 }
2812 void set(params const & p) { Z3_solver_set_params(ctx(), m_solver, p); check_error(); }
2813 void set(char const * k, bool v) { params p(ctx()); p.set(k, v); set(p); }
2814 void set(char const * k, unsigned v) { params p(ctx()); p.set(k, v); set(p); }
2815 void set(char const * k, double v) { params p(ctx()); p.set(k, v); set(p); }
2816 void set(char const * k, symbol const & v) { params p(ctx()); p.set(k, v); set(p); }
2817 void set(char const * k, char const* v) { params p(ctx()); p.set(k, v); set(p); }
2828 void push() { Z3_solver_push(ctx(), m_solver); check_error(); }
2829 void pop(unsigned n = 1) { Z3_solver_pop(ctx(), m_solver, n); check_error(); }
2830 void reset() { Z3_solver_reset(ctx(), m_solver); check_error(); }
2831 void add(expr const & e) { assert(e.is_bool()); Z3_solver_assert(ctx(), m_solver, e); check_error(); }
2832 void add(expr const & e, expr const & p) {
2833 assert(e.is_bool()); assert(p.is_bool()); assert(p.is_const());
2834 Z3_solver_assert_and_track(ctx(), m_solver, e, p);
2835 check_error();
2836 }
2837 void add(expr const & e, char const * p) {
2838 add(e, ctx().bool_const(p));
2839 }
2840 void add(expr_vector const& v) {
2841 check_context(*this, v);
2842 for (unsigned i = 0; i < v.size(); ++i)
2843 add(v[i]);
2844 }
2845 void from_file(char const* file) { Z3_solver_from_file(ctx(), m_solver, file); ctx().check_parser_error(); }
2846 void from_string(char const* s) { Z3_solver_from_string(ctx(), m_solver, s); ctx().check_parser_error(); }
2847
2849 check_result check(unsigned n, expr * const assumptions) {
2851 for (unsigned i = 0; i < n; i++) {
2852 check_context(*this, assumptions[i]);
2853 _assumptions[i] = assumptions[i];
2854 }
2855 Z3_lbool r = Z3_solver_check_assumptions(ctx(), m_solver, n, _assumptions.ptr());
2856 check_error();
2857 return to_check_result(r);
2858 }
2860 unsigned n = assumptions.size();
2862 for (unsigned i = 0; i < n; i++) {
2863 check_context(*this, assumptions[i]);
2864 _assumptions[i] = assumptions[i];
2865 }
2866 Z3_lbool r = Z3_solver_check_assumptions(ctx(), m_solver, n, _assumptions.ptr());
2867 check_error();
2868 return to_check_result(r);
2869 }
2870 model get_model() const { Z3_model m = Z3_solver_get_model(ctx(), m_solver); check_error(); return model(ctx(), m); }
2876 std::string reason_unknown() const { Z3_string r = Z3_solver_get_reason_unknown(ctx(), m_solver); check_error(); return r; }
2877 stats statistics() const { Z3_stats r = Z3_solver_get_statistics(ctx(), m_solver); check_error(); return stats(ctx(), r); }
2878 expr_vector unsat_core() const { Z3_ast_vector r = Z3_solver_get_unsat_core(ctx(), m_solver); check_error(); return expr_vector(ctx(), r); }
2879 expr_vector assertions() const { Z3_ast_vector r = Z3_solver_get_assertions(ctx(), m_solver); check_error(); return expr_vector(ctx(), r); }
2880 expr_vector non_units() const { Z3_ast_vector r = Z3_solver_get_non_units(ctx(), m_solver); check_error(); return expr_vector(ctx(), r); }
2881 expr_vector units() const { Z3_ast_vector r = Z3_solver_get_units(ctx(), m_solver); check_error(); return expr_vector(ctx(), r); }
2882 expr_vector trail() const { Z3_ast_vector r = Z3_solver_get_trail(ctx(), m_solver); check_error(); return expr_vector(ctx(), r); }
2884 Z3_ast_vector r = Z3_solver_get_trail(ctx(), m_solver);
2885 check_error();
2886 expr_vector result(ctx(), r);
2887 unsigned sz = result.size();
2888 levels.resize(sz);
2889 Z3_solver_get_levels(ctx(), m_solver, r, sz, levels.ptr());
2890 check_error();
2891 return result;
2892 }
2893 void set_initial_value(expr const& var, expr const& value) {
2894 Z3_solver_set_initial_value(ctx(), m_solver, var, value);
2895 check_error();
2896 }
2897 void set_initial_value(expr const& var, int i) {
2898 set_initial_value(var, ctx().num_val(i, var.get_sort()));
2899 }
2900 void set_initial_value(expr const& var, bool b) {
2901 set_initial_value(var, ctx().bool_val(b));
2902 }
2903
2904 expr proof() const { Z3_ast r = Z3_solver_get_proof(ctx(), m_solver); check_error(); return expr(ctx(), r); }
2905 friend std::ostream & operator<<(std::ostream & out, solver const & s);
2906
2907 std::string to_smt2(char const* status = "unknown") {
2909 Z3_ast const* fmls = es.ptr();
2910 Z3_ast fml = 0;
2911 unsigned sz = es.size();
2912 if (sz > 0) {
2913 --sz;
2914 fml = fmls[sz];
2915 }
2916 else {
2917 fml = ctx().bool_val(true);
2918 }
2919 return std::string(Z3_benchmark_to_smtlib_string(
2920 ctx(),
2921 "", "", status, "",
2922 sz,
2923 fmls,
2924 fml));
2925 }
2926
2927 std::string dimacs(bool include_names = true) const { return std::string(Z3_solver_to_dimacs_string(ctx(), m_solver, include_names)); }
2928
2930
2931
2933 Z3_ast_vector r = Z3_solver_cube(ctx(), m_solver, vars, cutoff);
2934 check_error();
2935 return expr_vector(ctx(), r);
2936 }
2937
2939 solver& m_solver;
2940 unsigned& m_cutoff;
2941 expr_vector& m_vars;
2942 expr_vector m_cube;
2943 bool m_end;
2944 bool m_empty;
2945
2946 void inc() {
2947 assert(!m_end && !m_empty);
2948 m_cube = m_solver.cube(m_vars, m_cutoff);
2949 m_cutoff = 0xFFFFFFFF;
2950 if (m_cube.size() == 1 && m_cube[0u].is_false()) {
2951 m_cube = z3::expr_vector(m_solver.ctx());
2952 m_end = true;
2953 }
2954 else if (m_cube.empty()) {
2955 m_empty = true;
2956 }
2957 }
2958 public:
2959 cube_iterator(solver& s, expr_vector& vars, unsigned& cutoff, bool end):
2960 m_solver(s),
2961 m_cutoff(cutoff),
2962 m_vars(vars),
2963 m_cube(s.ctx()),
2964 m_end(end),
2965 m_empty(false) {
2966 if (!m_end) {
2967 inc();
2968 }
2969 }
2970
2972 assert(!m_end);
2973 if (m_empty) {
2974 m_end = true;
2975 }
2976 else {
2977 inc();
2978 }
2979 return *this;
2980 }
2981 cube_iterator operator++(int) { assert(false); return *this; }
2982 expr_vector const * operator->() const { return &(operator*()); }
2983 expr_vector const& operator*() const noexcept { return m_cube; }
2984
2985 bool operator==(cube_iterator const& other) const noexcept {
2986 return other.m_end == m_end;
2987 };
2988 bool operator!=(cube_iterator const& other) const noexcept {
2989 return other.m_end != m_end;
2990 };
2991
2992 };
2993
2995 solver& m_solver;
2996 unsigned m_cutoff;
2997 expr_vector m_default_vars;
2998 expr_vector& m_vars;
2999 public:
3001 m_solver(s),
3002 m_cutoff(0xFFFFFFFF),
3003 m_default_vars(s.ctx()),
3004 m_vars(m_default_vars)
3005 {}
3006
3008 m_solver(s),
3009 m_cutoff(0xFFFFFFFF),
3010 m_default_vars(s.ctx()),
3011 m_vars(vars)
3012 {}
3013
3014 cube_iterator begin() { return cube_iterator(m_solver, m_vars, m_cutoff, false); }
3015 cube_iterator end() { return cube_iterator(m_solver, m_vars, m_cutoff, true); }
3016 void set_cutoff(unsigned c) noexcept { m_cutoff = c; }
3017 };
3018
3020 cube_generator cubes(expr_vector& vars) { return cube_generator(*this, vars); }
3021
3022 };
3023 inline std::ostream & operator<<(std::ostream & out, solver const & s) { out << Z3_solver_to_string(s.ctx(), s); return out; }
3024
3025 class goal : public object {
3026 Z3_goal m_goal;
3027 void init(Z3_goal s) {
3028 m_goal = s;
3029 Z3_goal_inc_ref(ctx(), s);
3030 }
3031 public:
3032 goal(context & c, bool models=true, bool unsat_cores=false, bool proofs=false):object(c) { init(Z3_mk_goal(c, models, unsat_cores, proofs)); }
3033 goal(context & c, Z3_goal s):object(c) { init(s); }
3034 goal(goal const & s):object(s) { init(s.m_goal); }
3035 ~goal() override { Z3_goal_dec_ref(ctx(), m_goal); }
3036 operator Z3_goal() const { return m_goal; }
3037 goal & operator=(goal const & s) {
3038 Z3_goal_inc_ref(s.ctx(), s.m_goal);
3039 Z3_goal_dec_ref(ctx(), m_goal);
3040 object::operator=(s);
3041 m_goal = s.m_goal;
3042 return *this;
3043 }
3044 void add(expr const & f) { check_context(*this, f); Z3_goal_assert(ctx(), m_goal, f); check_error(); }
3045 void add(expr_vector const& v) { check_context(*this, v); for (unsigned i = 0; i < v.size(); ++i) add(v[i]); }
3046 unsigned size() const { return Z3_goal_size(ctx(), m_goal); }
3047 expr operator[](int i) const { assert(0 <= i); Z3_ast r = Z3_goal_formula(ctx(), m_goal, i); check_error(); return expr(ctx(), r); }
3048 Z3_goal_prec precision() const { return Z3_goal_precision(ctx(), m_goal); }
3049 bool inconsistent() const { return Z3_goal_inconsistent(ctx(), m_goal); }
3050 unsigned depth() const { return Z3_goal_depth(ctx(), m_goal); }
3051 void reset() { Z3_goal_reset(ctx(), m_goal); }
3052 unsigned num_exprs() const { return Z3_goal_num_exprs(ctx(), m_goal); }
3053 bool is_decided_sat() const { return Z3_goal_is_decided_sat(ctx(), m_goal); }
3054 bool is_decided_unsat() const { return Z3_goal_is_decided_unsat(ctx(), m_goal); }
3055 model convert_model(model const & m) const {
3056 check_context(*this, m);
3057 Z3_model new_m = Z3_goal_convert_model(ctx(), m_goal, m);
3058 check_error();
3059 return model(ctx(), new_m);
3060 }
3062 Z3_model new_m = Z3_goal_convert_model(ctx(), m_goal, 0);
3063 check_error();
3064 return model(ctx(), new_m);
3065 }
3066 expr as_expr() const {
3067 unsigned n = size();
3068 if (n == 0)
3069 return ctx().bool_val(true);
3070 else if (n == 1)
3071 return operator[](0u);
3072 else {
3073 array<Z3_ast> args(n);
3074 for (unsigned i = 0; i < n; i++)
3075 args[i] = operator[](i);
3076 return expr(ctx(), Z3_mk_and(ctx(), n, args.ptr()));
3077 }
3078 }
3079 std::string dimacs(bool include_names = true) const { return std::string(Z3_goal_to_dimacs_string(ctx(), m_goal, include_names)); }
3080 friend std::ostream & operator<<(std::ostream & out, goal const & g);
3081 };
3082 inline std::ostream & operator<<(std::ostream & out, goal const & g) { out << Z3_goal_to_string(g.ctx(), g); return out; }
3083
3084 class apply_result : public object {
3085 Z3_apply_result m_apply_result;
3086 void init(Z3_apply_result s) {
3087 m_apply_result = s;
3089 }
3090 public:
3091 apply_result(context & c, Z3_apply_result s):object(c) { init(s); }
3092 apply_result(apply_result const & s):object(s) { init(s.m_apply_result); }
3093 ~apply_result() override { Z3_apply_result_dec_ref(ctx(), m_apply_result); }
3094 operator Z3_apply_result() const { return m_apply_result; }
3096 Z3_apply_result_inc_ref(s.ctx(), s.m_apply_result);
3097 Z3_apply_result_dec_ref(ctx(), m_apply_result);
3098 object::operator=(s);
3099 m_apply_result = s.m_apply_result;
3100 return *this;
3101 }
3102 unsigned size() const { return Z3_apply_result_get_num_subgoals(ctx(), m_apply_result); }
3103 goal operator[](int i) const { assert(0 <= i); Z3_goal r = Z3_apply_result_get_subgoal(ctx(), m_apply_result, i); check_error(); return goal(ctx(), r); }
3104 friend std::ostream & operator<<(std::ostream & out, apply_result const & r);
3105 };
3106 inline std::ostream & operator<<(std::ostream & out, apply_result const & r) { out << Z3_apply_result_to_string(r.ctx(), r); return out; }
3107
3108 class tactic : public object {
3109 Z3_tactic m_tactic;
3110 void init(Z3_tactic s) {
3111 m_tactic = s;
3112 Z3_tactic_inc_ref(ctx(), s);
3113 }
3114 public:
3115 tactic(context & c, char const * name):object(c) { Z3_tactic r = Z3_mk_tactic(c, name); check_error(); init(r); }
3116 tactic(context & c, Z3_tactic s):object(c) { init(s); }
3117 tactic(tactic const & s):object(s) { init(s.m_tactic); }
3118 ~tactic() override { Z3_tactic_dec_ref(ctx(), m_tactic); }
3119 operator Z3_tactic() const { return m_tactic; }
3120 tactic & operator=(tactic const & s) {
3121 Z3_tactic_inc_ref(s.ctx(), s.m_tactic);
3122 Z3_tactic_dec_ref(ctx(), m_tactic);
3123 object::operator=(s);
3124 m_tactic = s.m_tactic;
3125 return *this;
3126 }
3127 solver mk_solver() const { Z3_solver r = Z3_mk_solver_from_tactic(ctx(), m_tactic); check_error(); return solver(ctx(), r); }
3128 apply_result apply(goal const & g) const {
3129 check_context(*this, g);
3130 Z3_apply_result r = Z3_tactic_apply(ctx(), m_tactic, g);
3131 check_error();
3132 return apply_result(ctx(), r);
3133 }
3135 return apply(g);
3136 }
3137 std::string help() const { char const * r = Z3_tactic_get_help(ctx(), m_tactic); check_error(); return r; }
3138 friend tactic operator&(tactic const & t1, tactic const & t2);
3139 friend tactic operator|(tactic const & t1, tactic const & t2);
3140 friend tactic repeat(tactic const & t, unsigned max);
3141 friend tactic with(tactic const & t, params const & p);
3142 friend tactic try_for(tactic const & t, unsigned ms);
3143 friend tactic par_or(unsigned n, tactic const* tactics);
3144 friend tactic par_and_then(tactic const& t1, tactic const& t2);
3146 };
3147
3148 inline tactic operator&(tactic const & t1, tactic const & t2) {
3150 Z3_tactic r = Z3_tactic_and_then(t1.ctx(), t1, t2);
3151 t1.check_error();
3152 return tactic(t1.ctx(), r);
3153 }
3154
3155 inline tactic operator|(tactic const & t1, tactic const & t2) {
3157 Z3_tactic r = Z3_tactic_or_else(t1.ctx(), t1, t2);
3158 t1.check_error();
3159 return tactic(t1.ctx(), r);
3160 }
3161
3162 inline tactic repeat(tactic const & t, unsigned max=UINT_MAX) {
3163 Z3_tactic r = Z3_tactic_repeat(t.ctx(), t, max);
3164 t.check_error();
3165 return tactic(t.ctx(), r);
3166 }
3167
3168 inline tactic with(tactic const & t, params const & p) {
3169 Z3_tactic r = Z3_tactic_using_params(t.ctx(), t, p);
3170 t.check_error();
3171 return tactic(t.ctx(), r);
3172 }
3173 inline tactic try_for(tactic const & t, unsigned ms) {
3174 Z3_tactic r = Z3_tactic_try_for(t.ctx(), t, ms);
3175 t.check_error();
3176 return tactic(t.ctx(), r);
3177 }
3178 inline tactic par_or(unsigned n, tactic const* tactics) {
3179 if (n == 0) {
3180 Z3_THROW(exception("a non-zero number of tactics need to be passed to par_or"));
3181 }
3183 for (unsigned i = 0; i < n; ++i) buffer[i] = tactics[i];
3184 return tactic(tactics[0u].ctx(), Z3_tactic_par_or(tactics[0u].ctx(), n, buffer.ptr()));
3185 }
3186
3187 inline tactic par_and_then(tactic const & t1, tactic const & t2) {
3189 Z3_tactic r = Z3_tactic_par_and_then(t1.ctx(), t1, t2);
3190 t1.check_error();
3191 return tactic(t1.ctx(), r);
3192 }
3193
3194 class simplifier : public object {
3195 Z3_simplifier m_simplifier;
3196 void init(Z3_simplifier s) {
3197 m_simplifier = s;
3199 }
3200 public:
3201 simplifier(context & c, char const * name):object(c) { Z3_simplifier r = Z3_mk_simplifier(c, name); check_error(); init(r); }
3202 simplifier(context & c, Z3_simplifier s):object(c) { init(s); }
3203 simplifier(simplifier const & s):object(s) { init(s.m_simplifier); }
3204 ~simplifier() override { Z3_simplifier_dec_ref(ctx(), m_simplifier); }
3205 operator Z3_simplifier() const { return m_simplifier; }
3207 Z3_simplifier_inc_ref(s.ctx(), s.m_simplifier);
3208 Z3_simplifier_dec_ref(ctx(), m_simplifier);
3209 object::operator=(s);
3210 m_simplifier = s.m_simplifier;
3211 return *this;
3212 }
3213 std::string help() const { char const * r = Z3_simplifier_get_help(ctx(), m_simplifier); check_error(); return r; }
3214 friend simplifier operator&(simplifier const & t1, simplifier const & t2);
3215 friend simplifier with(simplifier const & t, params const & p);
3217 };
3218
3219 inline solver::solver(solver const& s, simplifier const& simp):object(s) { init(Z3_solver_add_simplifier(s.ctx(), s, simp)); }
3220
3221
3222 inline simplifier operator&(simplifier const & t1, simplifier const & t2) {
3224 Z3_simplifier r = Z3_simplifier_and_then(t1.ctx(), t1, t2);
3225 t1.check_error();
3226 return simplifier(t1.ctx(), r);
3227 }
3228
3229 inline simplifier with(simplifier const & t, params const & p) {
3230 Z3_simplifier r = Z3_simplifier_using_params(t.ctx(), t, p);
3231 t.check_error();
3232 return simplifier(t.ctx(), r);
3233 }
3234
3235 class probe : public object {
3236 Z3_probe m_probe;
3237 void init(Z3_probe s) {
3238 m_probe = s;
3239 Z3_probe_inc_ref(ctx(), s);
3240 }
3241 public:
3242 probe(context & c, char const * name):object(c) { Z3_probe r = Z3_mk_probe(c, name); check_error(); init(r); }
3243 probe(context & c, double val):object(c) { Z3_probe r = Z3_probe_const(c, val); check_error(); init(r); }
3244 probe(context & c, Z3_probe s):object(c) { init(s); }
3245 probe(probe const & s):object(s) { init(s.m_probe); }
3246 ~probe() override { Z3_probe_dec_ref(ctx(), m_probe); }
3247 operator Z3_probe() const { return m_probe; }
3248 probe & operator=(probe const & s) {
3249 Z3_probe_inc_ref(s.ctx(), s.m_probe);
3250 Z3_probe_dec_ref(ctx(), m_probe);
3251 object::operator=(s);
3252 m_probe = s.m_probe;
3253 return *this;
3254 }
3255 double apply(goal const & g) const { double r = Z3_probe_apply(ctx(), m_probe, g); check_error(); return r; }
3256 double operator()(goal const & g) const { return apply(g); }
3257 friend probe operator<=(probe const & p1, probe const & p2);
3258 friend probe operator<=(probe const & p1, double p2);
3259 friend probe operator<=(double p1, probe const & p2);
3260 friend probe operator>=(probe const & p1, probe const & p2);
3261 friend probe operator>=(probe const & p1, double p2);
3262 friend probe operator>=(double p1, probe const & p2);
3263 friend probe operator<(probe const & p1, probe const & p2);
3264 friend probe operator<(probe const & p1, double p2);
3265 friend probe operator<(double p1, probe const & p2);
3266 friend probe operator>(probe const & p1, probe const & p2);
3267 friend probe operator>(probe const & p1, double p2);
3268 friend probe operator>(double p1, probe const & p2);
3269 friend probe operator==(probe const & p1, probe const & p2);
3270 friend probe operator==(probe const & p1, double p2);
3271 friend probe operator==(double p1, probe const & p2);
3272 friend probe operator&&(probe const & p1, probe const & p2);
3273 friend probe operator||(probe const & p1, probe const & p2);
3274 friend probe operator!(probe const & p);
3275 };
3276
3277 inline probe operator<=(probe const & p1, probe const & p2) {
3278 check_context(p1, p2); Z3_probe r = Z3_probe_le(p1.ctx(), p1, p2); p1.check_error(); return probe(p1.ctx(), r);
3279 }
3280 inline probe operator<=(probe const & p1, double p2) { return p1 <= probe(p1.ctx(), p2); }
3281 inline probe operator<=(double p1, probe const & p2) { return probe(p2.ctx(), p1) <= p2; }
3282 inline probe operator>=(probe const & p1, probe const & p2) {
3283 check_context(p1, p2); Z3_probe r = Z3_probe_ge(p1.ctx(), p1, p2); p1.check_error(); return probe(p1.ctx(), r);
3284 }
3285 inline probe operator>=(probe const & p1, double p2) { return p1 >= probe(p1.ctx(), p2); }
3286 inline probe operator>=(double p1, probe const & p2) { return probe(p2.ctx(), p1) >= p2; }
3287 inline probe operator<(probe const & p1, probe const & p2) {
3288 check_context(p1, p2); Z3_probe r = Z3_probe_lt(p1.ctx(), p1, p2); p1.check_error(); return probe(p1.ctx(), r);
3289 }
3290 inline probe operator<(probe const & p1, double p2) { return p1 < probe(p1.ctx(), p2); }
3291 inline probe operator<(double p1, probe const & p2) { return probe(p2.ctx(), p1) < p2; }
3292 inline probe operator>(probe const & p1, probe const & p2) {
3293 check_context(p1, p2); Z3_probe r = Z3_probe_gt(p1.ctx(), p1, p2); p1.check_error(); return probe(p1.ctx(), r);
3294 }
3295 inline probe operator>(probe const & p1, double p2) { return p1 > probe(p1.ctx(), p2); }
3296 inline probe operator>(double p1, probe const & p2) { return probe(p2.ctx(), p1) > p2; }
3297 inline probe operator==(probe const & p1, probe const & p2) {
3298 check_context(p1, p2); Z3_probe r = Z3_probe_eq(p1.ctx(), p1, p2); p1.check_error(); return probe(p1.ctx(), r);
3299 }
3300 inline probe operator==(probe const & p1, double p2) { return p1 == probe(p1.ctx(), p2); }
3301 inline probe operator==(double p1, probe const & p2) { return probe(p2.ctx(), p1) == p2; }
3302 inline probe operator&&(probe const & p1, probe const & p2) {
3303 check_context(p1, p2); Z3_probe r = Z3_probe_and(p1.ctx(), p1, p2); p1.check_error(); return probe(p1.ctx(), r);
3304 }
3305 inline probe operator||(probe const & p1, probe const & p2) {
3306 check_context(p1, p2); Z3_probe r = Z3_probe_or(p1.ctx(), p1, p2); p1.check_error(); return probe(p1.ctx(), r);
3307 }
3308 inline probe operator!(probe const & p) {
3309 Z3_probe r = Z3_probe_not(p.ctx(), p); p.check_error(); return probe(p.ctx(), r);
3310 }
3311
3312 class optimize : public object {
3313 Z3_optimize m_opt;
3314
3315 public:
3316 struct translate {};
3317 class handle final {
3318 unsigned m_h;
3319 public:
3320 handle(unsigned h): m_h(h) {}
3321 unsigned h() const { return m_h; }
3322 };
3325 Z3_optimize o = Z3_optimize_translate(src.ctx(), src, c);
3326 check_error();
3327 m_opt = o;
3328 Z3_optimize_inc_ref(c, m_opt);
3329 }
3330 optimize(optimize const & o):object(o), m_opt(o.m_opt) {
3331 Z3_optimize_inc_ref(o.ctx(), o.m_opt);
3332 }
3334 m_opt = Z3_mk_optimize(c);
3335 Z3_optimize_inc_ref(c, m_opt);
3336 add(expr_vector(c, src.assertions()));
3337 expr_vector v(c, src.objectives());
3338 for (expr_vector::iterator it = v.begin(); it != v.end(); ++it) minimize(*it);
3339 }
3341 Z3_optimize_inc_ref(o.ctx(), o.m_opt);
3342 Z3_optimize_dec_ref(ctx(), m_opt);
3343 m_opt = o.m_opt;
3344 object::operator=(o);
3345 return *this;
3346 }
3347 ~optimize() override { Z3_optimize_dec_ref(ctx(), m_opt); }
3348 operator Z3_optimize() const { return m_opt; }
3349 void add(expr const& e) {
3350 assert(e.is_bool());
3351 Z3_optimize_assert(ctx(), m_opt, e);
3352 }
3353 void add(expr_vector const& es) {
3354 for (expr_vector::iterator it = es.begin(); it != es.end(); ++it) add(*it);
3355 }
3356 void add(expr const& e, expr const& t) {
3357 assert(e.is_bool());
3358 Z3_optimize_assert_and_track(ctx(), m_opt, e, t);
3359 }
3360 void add(expr const& e, char const* p) {
3361 assert(e.is_bool());
3362 add(e, ctx().bool_const(p));
3363 }
3364 handle add_soft(expr const& e, unsigned weight) {
3365 assert(e.is_bool());
3366 auto str = std::to_string(weight);
3367 return handle(Z3_optimize_assert_soft(ctx(), m_opt, e, str.c_str(), 0));
3368 }
3369 handle add_soft(expr const& e, char const* weight) {
3370 assert(e.is_bool());
3371 return handle(Z3_optimize_assert_soft(ctx(), m_opt, e, weight, 0));
3372 }
3373 handle add(expr const& e, unsigned weight) {
3374 return add_soft(e, weight);
3375 }
3376 void set_initial_value(expr const& var, expr const& value) {
3377 Z3_optimize_set_initial_value(ctx(), m_opt, var, value);
3378 check_error();
3379 }
3380 void set_initial_value(expr const& var, int i) {
3381 set_initial_value(var, ctx().num_val(i, var.get_sort()));
3382 }
3383 void set_initial_value(expr const& var, bool b) {
3384 set_initial_value(var, ctx().bool_val(b));
3385 }
3386
3388 return handle(Z3_optimize_maximize(ctx(), m_opt, e));
3389 }
3391 return handle(Z3_optimize_minimize(ctx(), m_opt, e));
3392 }
3393 void push() {
3394 Z3_optimize_push(ctx(), m_opt);
3395 }
3396 void pop() {
3397 Z3_optimize_pop(ctx(), m_opt);
3398 }
3401 unsigned n = asms.size();
3403 for (unsigned i = 0; i < n; i++) {
3404 check_context(*this, asms[i]);
3405 _asms[i] = asms[i];
3406 }
3407 Z3_lbool r = Z3_optimize_check(ctx(), m_opt, n, _asms.ptr());
3408 check_error();
3409 return to_check_result(r);
3410 }
3411 model get_model() const { Z3_model m = Z3_optimize_get_model(ctx(), m_opt); check_error(); return model(ctx(), m); }
3412 expr_vector unsat_core() const { Z3_ast_vector r = Z3_optimize_get_unsat_core(ctx(), m_opt); check_error(); return expr_vector(ctx(), r); }
3413 void set(params const & p) { Z3_optimize_set_params(ctx(), m_opt, p); check_error(); }
3414 expr lower(handle const& h) {
3415 Z3_ast r = Z3_optimize_get_lower(ctx(), m_opt, h.h());
3416 check_error();
3417 return expr(ctx(), r);
3418 }
3419 expr upper(handle const& h) {
3420 Z3_ast r = Z3_optimize_get_upper(ctx(), m_opt, h.h());
3421 check_error();
3422 return expr(ctx(), r);
3423 }
3424 expr_vector assertions() const { Z3_ast_vector r = Z3_optimize_get_assertions(ctx(), m_opt); check_error(); return expr_vector(ctx(), r); }
3425 expr_vector objectives() const { Z3_ast_vector r = Z3_optimize_get_objectives(ctx(), m_opt); check_error(); return expr_vector(ctx(), r); }
3426 stats statistics() const { Z3_stats r = Z3_optimize_get_statistics(ctx(), m_opt); check_error(); return stats(ctx(), r); }
3427 friend std::ostream & operator<<(std::ostream & out, optimize const & s);
3430 std::string help() const { char const * r = Z3_optimize_get_help(ctx(), m_opt); check_error(); return r; }
3431 };
3432 inline std::ostream & operator<<(std::ostream & out, optimize const & s) { out << Z3_optimize_to_string(s.ctx(), s.m_opt); return out; }
3433
3434 class fixedpoint : public object {
3435 Z3_fixedpoint m_fp;
3436 public:
3438 fixedpoint(fixedpoint const & o):object(o), m_fp(o.m_fp) { Z3_fixedpoint_inc_ref(ctx(), m_fp); }
3439 ~fixedpoint() override { Z3_fixedpoint_dec_ref(ctx(), m_fp); }
3441 Z3_fixedpoint_inc_ref(o.ctx(), o.m_fp);
3442 Z3_fixedpoint_dec_ref(ctx(), m_fp);
3443 m_fp = o.m_fp;
3444 object::operator=(o);
3445 return *this;
3446 }
3447 operator Z3_fixedpoint() const { return m_fp; }
3448 expr_vector from_string(char const* s) {
3449 Z3_ast_vector r = Z3_fixedpoint_from_string(ctx(), m_fp, s);
3450 check_error();
3451 return expr_vector(ctx(), r);
3452 }
3453 expr_vector from_file(char const* s) {
3454 Z3_ast_vector r = Z3_fixedpoint_from_file(ctx(), m_fp, s);
3455 check_error();
3456 return expr_vector(ctx(), r);
3457 }
3458 void add_rule(expr& rule, symbol const& name) { Z3_fixedpoint_add_rule(ctx(), m_fp, rule, name); check_error(); }
3459 void add_fact(func_decl& f, unsigned * args) { Z3_fixedpoint_add_fact(ctx(), m_fp, f, f.arity(), args); check_error(); }
3467 expr get_answer() { Z3_ast r = Z3_fixedpoint_get_answer(ctx(), m_fp); check_error(); return expr(ctx(), r); }
3468 std::string reason_unknown() { return Z3_fixedpoint_get_reason_unknown(ctx(), m_fp); }
3469 void update_rule(expr& rule, symbol const& name) { Z3_fixedpoint_update_rule(ctx(), m_fp, rule, name); check_error(); }
3470 unsigned get_num_levels(func_decl& p) { unsigned r = Z3_fixedpoint_get_num_levels(ctx(), m_fp, p); check_error(); return r; }
3472 Z3_ast r = Z3_fixedpoint_get_cover_delta(ctx(), m_fp, level, p);
3473 check_error();
3474 return expr(ctx(), r);
3475 }
3477 stats statistics() const { Z3_stats r = Z3_fixedpoint_get_statistics(ctx(), m_fp); check_error(); return stats(ctx(), r); }
3479 expr_vector assertions() const { Z3_ast_vector r = Z3_fixedpoint_get_assertions(ctx(), m_fp); check_error(); return expr_vector(ctx(), r); }
3480 expr_vector rules() const { Z3_ast_vector r = Z3_fixedpoint_get_rules(ctx(), m_fp); check_error(); return expr_vector(ctx(), r); }
3481 void set(params const & p) { Z3_fixedpoint_set_params(ctx(), m_fp, p); check_error(); }
3482 std::string help() const { return Z3_fixedpoint_get_help(ctx(), m_fp); }
3484 std::string to_string() { return Z3_fixedpoint_to_string(ctx(), m_fp, 0, 0); }
3485 std::string to_string(expr_vector const& queries) {
3487 return Z3_fixedpoint_to_string(ctx(), m_fp, qs.size(), qs.ptr());
3488 }
3489 };
3490 inline std::ostream & operator<<(std::ostream & out, fixedpoint const & f) { return out << Z3_fixedpoint_to_string(f.ctx(), f, 0, 0); }
3491
3492 inline tactic fail_if(probe const & p) {
3493 Z3_tactic r = Z3_tactic_fail_if(p.ctx(), p);
3494 p.check_error();
3495 return tactic(p.ctx(), r);
3496 }
3497 inline tactic when(probe const & p, tactic const & t) {
3498 check_context(p, t);
3499 Z3_tactic r = Z3_tactic_when(t.ctx(), p, t);
3500 t.check_error();
3501 return tactic(t.ctx(), r);
3502 }
3503 inline tactic cond(probe const & p, tactic const & t1, tactic const & t2) {
3505 Z3_tactic r = Z3_tactic_cond(t1.ctx(), p, t1, t2);
3506 t1.check_error();
3507 return tactic(t1.ctx(), r);
3508 }
3509
3510 inline symbol context::str_symbol(char const * s) { Z3_symbol r = Z3_mk_string_symbol(m_ctx, s); check_error(); return symbol(*this, r); }
3511 inline symbol context::int_symbol(int n) { Z3_symbol r = Z3_mk_int_symbol(m_ctx, n); check_error(); return symbol(*this, r); }
3512
3513 inline sort context::bool_sort() { Z3_sort s = Z3_mk_bool_sort(m_ctx); check_error(); return sort(*this, s); }
3514 inline sort context::int_sort() { Z3_sort s = Z3_mk_int_sort(m_ctx); check_error(); return sort(*this, s); }
3515 inline sort context::real_sort() { Z3_sort s = Z3_mk_real_sort(m_ctx); check_error(); return sort(*this, s); }
3516 inline sort context::bv_sort(unsigned sz) { Z3_sort s = Z3_mk_bv_sort(m_ctx, sz); check_error(); return sort(*this, s); }
3517 inline sort context::string_sort() { Z3_sort s = Z3_mk_string_sort(m_ctx); check_error(); return sort(*this, s); }
3518 inline sort context::char_sort() { Z3_sort s = Z3_mk_char_sort(m_ctx); check_error(); return sort(*this, s); }
3519 inline sort context::seq_sort(sort& s) { Z3_sort r = Z3_mk_seq_sort(m_ctx, s); check_error(); return sort(*this, r); }
3520 inline sort context::re_sort(sort& s) { Z3_sort r = Z3_mk_re_sort(m_ctx, s); check_error(); return sort(*this, r); }
3521 inline sort context::fpa_sort(unsigned ebits, unsigned sbits) { Z3_sort s = Z3_mk_fpa_sort(m_ctx, ebits, sbits); check_error(); return sort(*this, s); }
3522
3523 template<>
3524 inline sort context::fpa_sort<16>() { return fpa_sort(5, 11); }
3525
3526 template<>
3527 inline sort context::fpa_sort<32>() { return fpa_sort(8, 24); }
3528
3529 template<>
3530 inline sort context::fpa_sort<64>() { return fpa_sort(11, 53); }
3531
3532 template<>
3533 inline sort context::fpa_sort<128>() { return fpa_sort(15, 113); }
3534
3535 inline sort context::fpa_rounding_mode_sort() { Z3_sort r = Z3_mk_fpa_rounding_mode_sort(m_ctx); check_error(); return sort(*this, r); }
3536
3537 inline sort context::array_sort(sort d, sort r) { Z3_sort s = Z3_mk_array_sort(m_ctx, d, r); check_error(); return sort(*this, s); }
3540 Z3_sort s = Z3_mk_array_sort_n(m_ctx, dom.size(), dom.ptr(), r); check_error(); return sort(*this, s);
3541 }
3542 inline sort context::enumeration_sort(char const * name, unsigned n, char const * const * enum_names, func_decl_vector & cs, func_decl_vector & ts) {
3544 for (unsigned i = 0; i < n; i++) { _enum_names[i] = Z3_mk_string_symbol(*this, enum_names[i]); }
3547 Z3_symbol _name = Z3_mk_string_symbol(*this, name);
3548 sort s = to_sort(*this, Z3_mk_enumeration_sort(*this, _name, n, _enum_names.ptr(), _cs.ptr(), _ts.ptr()));
3549 check_error();
3550 for (unsigned i = 0; i < n; i++) { cs.push_back(func_decl(*this, _cs[i])); ts.push_back(func_decl(*this, _ts[i])); }
3551 return s;
3552 }
3553 inline func_decl context::tuple_sort(char const * name, unsigned n, char const * const * names, sort const* sorts, func_decl_vector & projs) {
3556 for (unsigned i = 0; i < n; i++) { _names[i] = Z3_mk_string_symbol(*this, names[i]); _sorts[i] = sorts[i]; }
3558 Z3_symbol _name = Z3_mk_string_symbol(*this, name);
3559 Z3_func_decl tuple;
3560 sort _ignore_s = to_sort(*this, Z3_mk_tuple_sort(*this, _name, n, _names.ptr(), _sorts.ptr(), &tuple, _projs.ptr()));
3561 check_error();
3562 for (unsigned i = 0; i < n; i++) { projs.push_back(func_decl(*this, _projs[i])); }
3563 return func_decl(*this, tuple);
3564 }
3565
3567 context& ctx;
3568 Z3_constructor_list clist;
3569 public:
3572 operator Z3_constructor_list() const { return clist; }
3573 };
3574
3576 friend class constructor_list;
3577 context& ctx;
3578 std::vector<Z3_constructor> cons;
3579 std::vector<unsigned> num_fields;
3580 public:
3581 constructors(context& ctx): ctx(ctx) {}
3582
3584 for (auto con : cons)
3585 Z3_del_constructor(ctx, con);
3586 }
3587
3588 void add(symbol const& name, symbol const& rec, unsigned n, symbol const* names, sort const* fields) {
3590 array<Z3_sort> sorts(n);
3592 for (unsigned i = 0; i < n; ++i) sorts[i] = fields[i], _names[i] = names[i];
3593 cons.push_back(Z3_mk_constructor(ctx, name, rec, n, _names.ptr(), sorts.ptr(), sort_refs.ptr()));
3594 num_fields.push_back(n);
3595 }
3596
3597 Z3_constructor operator[](unsigned i) const { return cons[i]; }
3598
3599 unsigned size() const { return (unsigned)cons.size(); }
3600
3601 void query(unsigned i, func_decl& constructor, func_decl& test, func_decl_vector& accs) {
3602 Z3_func_decl _constructor;
3603 Z3_func_decl _test;
3604 array<Z3_func_decl> accessors(num_fields[i]);
3605 accs.resize(0);
3607 cons[i],
3608 num_fields[i],
3609 &_constructor,
3610 &_test,
3611 accessors.ptr());
3612 constructor = func_decl(ctx, _constructor);
3613
3614 test = func_decl(ctx, _test);
3615 for (unsigned j = 0; j < num_fields[i]; ++j)
3616 accs.push_back(func_decl(ctx, accessors[j]));
3617 }
3618 };
3619
3621 array<Z3_constructor> cons(cs.size());
3622 for (unsigned i = 0; i < cs.size(); ++i)
3623 cons[i] = cs[i];
3624 clist = Z3_mk_constructor_list(ctx, cs.size(), cons.ptr());
3625 }
3626
3627 inline sort context::datatype(symbol const& name, constructors const& cs) {
3629 for (unsigned i = 0; i < cs.size(); ++i) _cs[i] = cs[i];
3630 Z3_sort s = Z3_mk_datatype(*this, name, cs.size(), _cs.ptr());
3631 check_error();
3632 return sort(*this, s);
3633 }
3634
3635 inline sort context::datatype(symbol const &name, sort_vector const& params, constructors const &cs) {
3638 for (unsigned i = 0; i < cs.size(); ++i)
3639 _cs[i] = cs[i];
3640 Z3_sort s = Z3_mk_polymorphic_datatype(*this, name, _params.size(), _params.ptr(), cs.size(), _cs.ptr());
3641 check_error();
3642 return sort(*this, s);
3643 }
3644
3646 unsigned n, symbol const* names,
3647 constructor_list *const* cons) {
3648 sort_vector result(*this);
3652 for (unsigned i = 0; i < n; ++i)
3653 _names[i] = names[i], _cons[i] = *cons[i];
3654 Z3_mk_datatypes(*this, n, _names.ptr(), _sorts.ptr(), _cons.ptr());
3655 for (unsigned i = 0; i < n; ++i)
3656 result.push_back(sort(*this, _sorts[i]));
3657 return result;
3658 }
3659
3660
3661 inline sort context::datatype_sort(symbol const& name) {
3662 Z3_sort s = Z3_mk_datatype_sort(*this, name, 0, nullptr);
3663 check_error();
3664 return sort(*this, s);
3665 }
3666
3669 Z3_sort s = Z3_mk_datatype_sort(*this, name, _params.size(), _params.ptr());
3670 check_error();
3671 return sort(*this, s);
3672 }
3673
3674
3675 inline sort context::uninterpreted_sort(char const* name) {
3676 Z3_symbol _name = Z3_mk_string_symbol(*this, name);
3677 return to_sort(*this, Z3_mk_uninterpreted_sort(*this, _name));
3678 }
3680 return to_sort(*this, Z3_mk_uninterpreted_sort(*this, name));
3681 }
3682
3683 inline func_decl context::function(symbol const & name, unsigned arity, sort const * domain, sort const & range) {
3684 array<Z3_sort> args(arity);
3685 for (unsigned i = 0; i < arity; i++) {
3686 check_context(domain[i], range);
3687 args[i] = domain[i];
3688 }
3689 Z3_func_decl f = Z3_mk_func_decl(m_ctx, name, arity, args.ptr(), range);
3690 check_error();
3691 return func_decl(*this, f);
3692 }
3693
3694 inline func_decl context::function(char const * name, unsigned arity, sort const * domain, sort const & range) {
3695 return function(range.ctx().str_symbol(name), arity, domain, range);
3696 }
3697
3698 inline func_decl context::function(symbol const& name, sort_vector const& domain, sort const& range) {
3699 array<Z3_sort> args(domain.size());
3700 for (unsigned i = 0; i < domain.size(); i++) {
3701 check_context(domain[i], range);
3702 args[i] = domain[i];
3703 }
3704 Z3_func_decl f = Z3_mk_func_decl(m_ctx, name, domain.size(), args.ptr(), range);
3705 check_error();
3706 return func_decl(*this, f);
3707 }
3708
3709 inline func_decl context::function(char const * name, sort_vector const& domain, sort const& range) {
3710 return function(range.ctx().str_symbol(name), domain, range);
3711 }
3712
3713
3714 inline func_decl context::function(char const * name, sort const & domain, sort const & range) {
3715 check_context(domain, range);
3716 Z3_sort args[1] = { domain };
3717 Z3_func_decl f = Z3_mk_func_decl(m_ctx, str_symbol(name), 1, args, range);
3718 check_error();
3719 return func_decl(*this, f);
3720 }
3721
3722 inline func_decl context::function(char const * name, sort const & d1, sort const & d2, sort const & range) {
3724 Z3_sort args[2] = { d1, d2 };
3725 Z3_func_decl f = Z3_mk_func_decl(m_ctx, str_symbol(name), 2, args, range);
3726 check_error();
3727 return func_decl(*this, f);
3728 }
3729
3730 inline func_decl context::function(char const * name, sort const & d1, sort const & d2, sort const & d3, sort const & range) {
3732 Z3_sort args[3] = { d1, d2, d3 };
3733 Z3_func_decl f = Z3_mk_func_decl(m_ctx, str_symbol(name), 3, args, range);
3734 check_error();
3735 return func_decl(*this, f);
3736 }
3737
3738 inline func_decl context::function(char const * name, sort const & d1, sort const & d2, sort const & d3, sort const & d4, sort const & range) {
3740 Z3_sort args[4] = { d1, d2, d3, d4 };
3741 Z3_func_decl f = Z3_mk_func_decl(m_ctx, str_symbol(name), 4, args, range);
3742 check_error();
3743 return func_decl(*this, f);
3744 }
3745
3746 inline func_decl context::function(char const * name, sort const & d1, sort const & d2, sort const & d3, sort const & d4, sort const & d5, sort const & range) {
3748 Z3_sort args[5] = { d1, d2, d3, d4, d5 };
3749 Z3_func_decl f = Z3_mk_func_decl(m_ctx, str_symbol(name), 5, args, range);
3750 check_error();
3751 return func_decl(*this, f);
3752 }
3753
3754 inline func_decl context::recfun(symbol const & name, unsigned arity, sort const * domain, sort const & range) {
3755 array<Z3_sort> args(arity);
3756 for (unsigned i = 0; i < arity; i++) {
3757 check_context(domain[i], range);
3758 args[i] = domain[i];
3759 }
3760 Z3_func_decl f = Z3_mk_rec_func_decl(m_ctx, name, arity, args.ptr(), range);
3761 check_error();
3762 return func_decl(*this, f);
3763
3764 }
3765
3766 inline func_decl context::recfun(symbol const & name, sort_vector const& domain, sort const & range) {
3767 check_context(domain, range);
3768 array<Z3_sort> domain1(domain);
3769 Z3_func_decl f = Z3_mk_rec_func_decl(m_ctx, name, domain1.size(), domain1.ptr(), range);
3770 check_error();
3771 return func_decl(*this, f);
3772 }
3773
3774 inline func_decl context::recfun(char const * name, sort_vector const& domain, sort const & range) {
3775 return recfun(str_symbol(name), domain, range);
3776
3777 }
3778
3779 inline func_decl context::recfun(char const * name, unsigned arity, sort const * domain, sort const & range) {
3780 return recfun(str_symbol(name), arity, domain, range);
3781 }
3782
3783 inline func_decl context::recfun(char const * name, sort const& d1, sort const & range) {
3784 return recfun(str_symbol(name), 1, &d1, range);
3785 }
3786
3787 inline func_decl context::recfun(char const * name, sort const& d1, sort const& d2, sort const & range) {
3788 sort dom[2] = { d1, d2 };
3789 return recfun(str_symbol(name), 2, dom, range);
3790 }
3791
3792 inline void context::recdef(func_decl f, expr_vector const& args, expr const& body) {
3793 check_context(f, args); check_context(f, body);
3794 array<Z3_ast> vars(args);
3795 Z3_add_rec_def(f.ctx(), f, vars.size(), vars.ptr(), body);
3796 }
3797
3798 inline func_decl context::user_propagate_function(symbol const& name, sort_vector const& domain, sort const& range) {
3799 check_context(domain, range);
3800 array<Z3_sort> domain1(domain);
3801 Z3_func_decl f = Z3_solver_propagate_declare(range.ctx(), name, domain1.size(), domain1.ptr(), range);
3802 check_error();
3803 return func_decl(*this, f);
3804 }
3805
3806 inline expr context::constant(symbol const & name, sort const & s) {
3807 Z3_ast r = Z3_mk_const(m_ctx, name, s);
3808 check_error();
3809 return expr(*this, r);
3810 }
3811 inline expr context::constant(char const * name, sort const & s) { return constant(str_symbol(name), s); }
3812 inline expr context::variable(unsigned idx, sort const& s) {
3813 Z3_ast r = Z3_mk_bound(m_ctx, idx, s);
3814 check_error();
3815 return expr(*this, r);
3816 }
3817 inline expr context::bool_const(char const * name) { return constant(name, bool_sort()); }
3818 inline expr context::int_const(char const * name) { return constant(name, int_sort()); }
3819 inline expr context::real_const(char const * name) { return constant(name, real_sort()); }
3820 inline expr context::string_const(char const * name) { return constant(name, string_sort()); }
3821 inline expr context::bv_const(char const * name, unsigned sz) { return constant(name, bv_sort(sz)); }
3822 inline expr context::fpa_const(char const * name, unsigned ebits, unsigned sbits) { return constant(name, fpa_sort(ebits, sbits)); }
3823
3824 template<size_t precision>
3825 inline expr context::fpa_const(char const * name) { return constant(name, fpa_sort<precision>()); }
3826
3827 inline void context::set_rounding_mode(rounding_mode rm) { m_rounding_mode = rm; }
3828
3830 switch (m_rounding_mode) {
3831 case RNA: return expr(*this, Z3_mk_fpa_rna(m_ctx));
3832 case RNE: return expr(*this, Z3_mk_fpa_rne(m_ctx));
3833 case RTP: return expr(*this, Z3_mk_fpa_rtp(m_ctx));
3834 case RTN: return expr(*this, Z3_mk_fpa_rtn(m_ctx));
3835 case RTZ: return expr(*this, Z3_mk_fpa_rtz(m_ctx));
3836 default: return expr(*this);
3837 }
3838 }
3839
3840 inline expr context::bool_val(bool b) { return b ? expr(*this, Z3_mk_true(m_ctx)) : expr(*this, Z3_mk_false(m_ctx)); }
3841
3842 inline expr context::int_val(int n) { Z3_ast r = Z3_mk_int(m_ctx, n, int_sort()); check_error(); return expr(*this, r); }
3843 inline expr context::int_val(unsigned n) { Z3_ast r = Z3_mk_unsigned_int(m_ctx, n, int_sort()); check_error(); return expr(*this, r); }
3844 inline expr context::int_val(int64_t n) { Z3_ast r = Z3_mk_int64(m_ctx, n, int_sort()); check_error(); return expr(*this, r); }
3845 inline expr context::int_val(uint64_t n) { Z3_ast r = Z3_mk_unsigned_int64(m_ctx, n, int_sort()); check_error(); return expr(*this, r); }
3846 inline expr context::int_val(char const * n) { Z3_ast r = Z3_mk_numeral(m_ctx, n, int_sort()); check_error(); return expr(*this, r); }
3847
3848 inline expr context::real_val(int64_t n, int64_t d) { Z3_ast r = Z3_mk_real_int64(m_ctx, n, d); check_error(); return expr(*this, r); }
3849 inline expr context::real_val(int n) { Z3_ast r = Z3_mk_int(m_ctx, n, real_sort()); check_error(); return expr(*this, r); }
3850 inline expr context::real_val(unsigned n) { Z3_ast r = Z3_mk_unsigned_int(m_ctx, n, real_sort()); check_error(); return expr(*this, r); }
3851 inline expr context::real_val(int64_t n) { Z3_ast r = Z3_mk_int64(m_ctx, n, real_sort()); check_error(); return expr(*this, r); }
3852 inline expr context::real_val(uint64_t n) { Z3_ast r = Z3_mk_unsigned_int64(m_ctx, n, real_sort()); check_error(); return expr(*this, r); }
3853 inline expr context::real_val(char const * n) { Z3_ast r = Z3_mk_numeral(m_ctx, n, real_sort()); check_error(); return expr(*this, r); }
3854
3855 inline expr context::bv_val(int n, unsigned sz) { sort s = bv_sort(sz); Z3_ast r = Z3_mk_int(m_ctx, n, s); check_error(); return expr(*this, r); }
3856 inline expr context::bv_val(unsigned n, unsigned sz) { sort s = bv_sort(sz); Z3_ast r = Z3_mk_unsigned_int(m_ctx, n, s); check_error(); return expr(*this, r); }
3857 inline expr context::bv_val(int64_t n, unsigned sz) { sort s = bv_sort(sz); Z3_ast r = Z3_mk_int64(m_ctx, n, s); check_error(); return expr(*this, r); }
3858 inline expr context::bv_val(uint64_t n, unsigned sz) { sort s = bv_sort(sz); Z3_ast r = Z3_mk_unsigned_int64(m_ctx, n, s); check_error(); return expr(*this, r); }
3859 inline expr context::bv_val(char const * n, unsigned sz) { sort s = bv_sort(sz); Z3_ast r = Z3_mk_numeral(m_ctx, n, s); check_error(); return expr(*this, r); }
3860 inline expr context::bv_val(unsigned n, bool const* bits) {
3861 array<bool> _bits(n);
3862 for (unsigned i = 0; i < n; ++i) _bits[i] = bits[i] ? 1 : 0;
3863 Z3_ast r = Z3_mk_bv_numeral(m_ctx, n, _bits.ptr()); check_error(); return expr(*this, r);
3864 }
3865
3866 inline expr context::fpa_val(double n) { sort s = fpa_sort<64>(); Z3_ast r = Z3_mk_fpa_numeral_double(m_ctx, n, s); check_error(); return expr(*this, r); }
3867 inline expr context::fpa_val(float n) { sort s = fpa_sort<32>(); Z3_ast r = Z3_mk_fpa_numeral_float(m_ctx, n, s); check_error(); return expr(*this, r); }
3868 inline expr context::fpa_nan(sort const & s) { Z3_ast r = Z3_mk_fpa_nan(m_ctx, s); check_error(); return expr(*this, r); }
3869 inline expr context::fpa_inf(sort const & s, bool sgn) { Z3_ast r = Z3_mk_fpa_inf(m_ctx, s, sgn); check_error(); return expr(*this, r); }
3870
3871 inline expr context::string_val(char const* s, unsigned n) { Z3_ast r = Z3_mk_lstring(m_ctx, n, s); check_error(); return expr(*this, r); }
3872 inline expr context::string_val(char const* s) { Z3_ast r = Z3_mk_string(m_ctx, s); check_error(); return expr(*this, r); }
3873 inline expr context::string_val(std::string const& s) { Z3_ast r = Z3_mk_string(m_ctx, s.c_str()); check_error(); return expr(*this, r); }
3874 inline expr context::string_val(std::u32string const& s) { Z3_ast r = Z3_mk_u32string(m_ctx, (unsigned)s.size(), (unsigned const*)s.c_str()); check_error(); return expr(*this, r); }
3875
3876 inline expr context::num_val(int n, sort const & s) { Z3_ast r = Z3_mk_int(m_ctx, n, s); check_error(); return expr(*this, r); }
3877
3878 inline expr func_decl::operator()(unsigned n, expr const * args) const {
3880 for (unsigned i = 0; i < n; i++) {
3881 check_context(*this, args[i]);
3882 _args[i] = args[i];
3883 }
3884 Z3_ast r = Z3_mk_app(ctx(), *this, n, _args.ptr());
3885 check_error();
3886 return expr(ctx(), r);
3887
3888 }
3889 inline expr func_decl::operator()(expr_vector const& args) const {
3890 array<Z3_ast> _args(args.size());
3891 for (unsigned i = 0; i < args.size(); i++) {
3892 check_context(*this, args[i]);
3893 _args[i] = args[i];
3894 }
3895 Z3_ast r = Z3_mk_app(ctx(), *this, args.size(), _args.ptr());
3896 check_error();
3897 return expr(ctx(), r);
3898 }
3900 Z3_ast r = Z3_mk_app(ctx(), *this, 0, 0);
3901 ctx().check_error();
3902 return expr(ctx(), r);
3903 }
3904 inline expr func_decl::operator()(expr const & a) const {
3905 check_context(*this, a);
3906 Z3_ast args[1] = { a };
3907 Z3_ast r = Z3_mk_app(ctx(), *this, 1, args);
3908 ctx().check_error();
3909 return expr(ctx(), r);
3910 }
3911 inline expr func_decl::operator()(int a) const {
3912 Z3_ast args[1] = { ctx().num_val(a, domain(0)) };
3913 Z3_ast r = Z3_mk_app(ctx(), *this, 1, args);
3914 ctx().check_error();
3915 return expr(ctx(), r);
3916 }
3917 inline expr func_decl::operator()(expr const & a1, expr const & a2) const {
3918 check_context(*this, a1); check_context(*this, a2);
3919 Z3_ast args[2] = { a1, a2 };
3920 Z3_ast r = Z3_mk_app(ctx(), *this, 2, args);
3921 ctx().check_error();
3922 return expr(ctx(), r);
3923 }
3924 inline expr func_decl::operator()(expr const & a1, int a2) const {
3925 check_context(*this, a1);
3926 Z3_ast args[2] = { a1, ctx().num_val(a2, domain(1)) };
3927 Z3_ast r = Z3_mk_app(ctx(), *this, 2, args);
3928 ctx().check_error();
3929 return expr(ctx(), r);
3930 }
3931 inline expr func_decl::operator()(int a1, expr const & a2) const {
3932 check_context(*this, a2);
3933 Z3_ast args[2] = { ctx().num_val(a1, domain(0)), a2 };
3934 Z3_ast r = Z3_mk_app(ctx(), *this, 2, args);
3935 ctx().check_error();
3936 return expr(ctx(), r);
3937 }
3938 inline expr func_decl::operator()(expr const & a1, expr const & a2, expr const & a3) const {
3939 check_context(*this, a1); check_context(*this, a2); check_context(*this, a3);
3940 Z3_ast args[3] = { a1, a2, a3 };
3941 Z3_ast r = Z3_mk_app(ctx(), *this, 3, args);
3942 ctx().check_error();
3943 return expr(ctx(), r);
3944 }
3945 inline expr func_decl::operator()(expr const & a1, expr const & a2, expr const & a3, expr const & a4) const {
3946 check_context(*this, a1); check_context(*this, a2); check_context(*this, a3); check_context(*this, a4);
3947 Z3_ast args[4] = { a1, a2, a3, a4 };
3948 Z3_ast r = Z3_mk_app(ctx(), *this, 4, args);
3949 ctx().check_error();
3950 return expr(ctx(), r);
3951 }
3952 inline expr func_decl::operator()(expr const & a1, expr const & a2, expr const & a3, expr const & a4, expr const & a5) const {
3953 check_context(*this, a1); check_context(*this, a2); check_context(*this, a3); check_context(*this, a4); check_context(*this, a5);
3954 Z3_ast args[5] = { a1, a2, a3, a4, a5 };
3955 Z3_ast r = Z3_mk_app(ctx(), *this, 5, args);
3956 ctx().check_error();
3957 return expr(ctx(), r);
3958 }
3959
3960 inline expr to_real(expr const & a) { Z3_ast r = Z3_mk_int2real(a.ctx(), a); a.check_error(); return expr(a.ctx(), r); }
3961
3962 inline func_decl function(symbol const & name, unsigned arity, sort const * domain, sort const & range) {
3963 return range.ctx().function(name, arity, domain, range);
3964 }
3965 inline func_decl function(char const * name, unsigned arity, sort const * domain, sort const & range) {
3966 return range.ctx().function(name, arity, domain, range);
3967 }
3968 inline func_decl function(char const * name, sort const & domain, sort const & range) {
3969 return range.ctx().function(name, domain, range);
3970 }
3971 inline func_decl function(char const * name, sort const & d1, sort const & d2, sort const & range) {
3972 return range.ctx().function(name, d1, d2, range);
3973 }
3974 inline func_decl function(char const * name, sort const & d1, sort const & d2, sort const & d3, sort const & range) {
3975 return range.ctx().function(name, d1, d2, d3, range);
3976 }
3977 inline func_decl function(char const * name, sort const & d1, sort const & d2, sort const & d3, sort const & d4, sort const & range) {
3978 return range.ctx().function(name, d1, d2, d3, d4, range);
3979 }
3980 inline func_decl function(char const * name, sort const & d1, sort const & d2, sort const & d3, sort const & d4, sort const & d5, sort const & range) {
3981 return range.ctx().function(name, d1, d2, d3, d4, d5, range);
3982 }
3983 inline func_decl function(char const* name, sort_vector const& domain, sort const& range) {
3984 return range.ctx().function(name, domain, range);
3985 }
3986 inline func_decl function(std::string const& name, sort_vector const& domain, sort const& range) {
3987 return range.ctx().function(name.c_str(), domain, range);
3988 }
3989
3990 inline func_decl recfun(symbol const & name, unsigned arity, sort const * domain, sort const & range) {
3991 return range.ctx().recfun(name, arity, domain, range);
3992 }
3993 inline func_decl recfun(char const * name, unsigned arity, sort const * domain, sort const & range) {
3994 return range.ctx().recfun(name, arity, domain, range);
3995 }
3996 inline func_decl recfun(char const * name, sort const& d1, sort const & range) {
3997 return range.ctx().recfun(name, d1, range);
3998 }
3999 inline func_decl recfun(char const * name, sort const& d1, sort const& d2, sort const & range) {
4000 return range.ctx().recfun(name, d1, d2, range);
4001 }
4002
4003 inline expr select(expr const & a, expr const & i) {
4004 check_context(a, i);
4005 Z3_ast r = Z3_mk_select(a.ctx(), a, i);
4006 a.check_error();
4007 return expr(a.ctx(), r);
4008 }
4009 inline expr select(expr const & a, int i) {
4010 return select(a, a.ctx().num_val(i, a.get_sort().array_domain()));
4011 }
4012 inline expr select(expr const & a, expr_vector const & i) {
4013 check_context(a, i);
4015 Z3_ast r = Z3_mk_select_n(a.ctx(), a, idxs.size(), idxs.ptr());
4016 a.check_error();
4017 return expr(a.ctx(), r);
4018 }
4019
4020 inline expr store(expr const & a, expr const & i, expr const & v) {
4022 Z3_ast r = Z3_mk_store(a.ctx(), a, i, v);
4023 a.check_error();
4024 return expr(a.ctx(), r);
4025 }
4026
4027 inline expr store(expr const & a, int i, expr const & v) { return store(a, a.ctx().num_val(i, a.get_sort().array_domain()), v); }
4028 inline expr store(expr const & a, expr i, int v) { return store(a, i, a.ctx().num_val(v, a.get_sort().array_range())); }
4029 inline expr store(expr const & a, int i, int v) {
4030 return store(a, a.ctx().num_val(i, a.get_sort().array_domain()), a.ctx().num_val(v, a.get_sort().array_range()));
4031 }
4032 inline expr store(expr const & a, expr_vector const & i, expr const & v) {
4035 Z3_ast r = Z3_mk_store_n(a.ctx(), a, idxs.size(), idxs.ptr(), v);
4036 a.check_error();
4037 return expr(a.ctx(), r);
4038 }
4039
4041 Z3_ast r = Z3_mk_as_array(f.ctx(), f);
4042 f.check_error();
4043 return expr(f.ctx(), r);
4044 }
4045
4046#define MK_EXPR1(_fn, _arg) \
4047 Z3_ast r = _fn(_arg.ctx(), _arg); \
4048 _arg.check_error(); \
4049 return expr(_arg.ctx(), r);
4050
4051#define MK_EXPR2(_fn, _arg1, _arg2) \
4052 check_context(_arg1, _arg2); \
4053 Z3_ast r = _fn(_arg1.ctx(), _arg1, _arg2); \
4054 _arg1.check_error(); \
4055 return expr(_arg1.ctx(), r);
4056
4057 inline expr const_array(sort const & d, expr const & v) {
4059 }
4060
4061 inline expr empty_set(sort const& s) {
4063 }
4064
4065 inline expr full_set(sort const& s) {
4067 }
4068
4069 inline expr set_add(expr const& s, expr const& e) {
4070 MK_EXPR2(Z3_mk_set_add, s, e);
4071 }
4072
4073 inline expr set_del(expr const& s, expr const& e) {
4074 MK_EXPR2(Z3_mk_set_del, s, e);
4075 }
4076
4077 inline expr set_union(expr const& a, expr const& b) {
4078 check_context(a, b);
4079 Z3_ast es[2] = { a, b };
4080 Z3_ast r = Z3_mk_set_union(a.ctx(), 2, es);
4081 a.check_error();
4082 return expr(a.ctx(), r);
4083 }
4084
4085 inline expr set_intersect(expr const& a, expr const& b) {
4086 check_context(a, b);
4087 Z3_ast es[2] = { a, b };
4088 Z3_ast r = Z3_mk_set_intersect(a.ctx(), 2, es);
4089 a.check_error();
4090 return expr(a.ctx(), r);
4091 }
4092
4093 inline expr set_difference(expr const& a, expr const& b) {
4095 }
4096
4097 inline expr set_complement(expr const& a) {
4099 }
4100
4101 inline expr set_member(expr const& s, expr const& e) {
4103 }
4104
4105 inline expr set_subset(expr const& a, expr const& b) {
4107 }
4108
4109 // sequence and regular expression operations.
4110 // union is +
4111 // concat is overloaded to handle sequences and regular expressions
4112
4113 inline expr empty(sort const& s) {
4114 Z3_ast r = Z3_mk_seq_empty(s.ctx(), s);
4115 s.check_error();
4116 return expr(s.ctx(), r);
4117 }
4118 inline expr suffixof(expr const& a, expr const& b) {
4119 check_context(a, b);
4120 Z3_ast r = Z3_mk_seq_suffix(a.ctx(), a, b);
4121 a.check_error();
4122 return expr(a.ctx(), r);
4123 }
4124 inline expr prefixof(expr const& a, expr const& b) {
4125 check_context(a, b);
4126 Z3_ast r = Z3_mk_seq_prefix(a.ctx(), a, b);
4127 a.check_error();
4128 return expr(a.ctx(), r);
4129 }
4130 inline expr indexof(expr const& s, expr const& substr, expr const& offset) {
4132 Z3_ast r = Z3_mk_seq_index(s.ctx(), s, substr, offset);
4133 s.check_error();
4134 return expr(s.ctx(), r);
4135 }
4136 inline expr last_indexof(expr const& s, expr const& substr) {
4137 check_context(s, substr);
4138 Z3_ast r = Z3_mk_seq_last_index(s.ctx(), s, substr);
4139 s.check_error();
4140 return expr(s.ctx(), r);
4141 }
4142 inline expr to_re(expr const& s) {
4144 }
4145 inline expr in_re(expr const& s, expr const& re) {
4147 }
4148 inline expr plus(expr const& re) {
4150 }
4151 inline expr option(expr const& re) {
4153 }
4154 inline expr star(expr const& re) {
4156 }
4157 inline expr re_empty(sort const& s) {
4158 Z3_ast r = Z3_mk_re_empty(s.ctx(), s);
4159 s.check_error();
4160 return expr(s.ctx(), r);
4161 }
4162 inline expr re_full(sort const& s) {
4163 Z3_ast r = Z3_mk_re_full(s.ctx(), s);
4164 s.check_error();
4165 return expr(s.ctx(), r);
4166 }
4167 inline expr re_intersect(expr_vector const& args) {
4168 assert(args.size() > 0);
4169 context& ctx = args[0u].ctx();
4170 array<Z3_ast> _args(args);
4171 Z3_ast r = Z3_mk_re_intersect(ctx, _args.size(), _args.ptr());
4172 ctx.check_error();
4173 return expr(ctx, r);
4174 }
4175 inline expr re_diff(expr const& a, expr const& b) {
4176 check_context(a, b);
4177 context& ctx = a.ctx();
4178 Z3_ast r = Z3_mk_re_diff(ctx, a, b);
4179 ctx.check_error();
4180 return expr(ctx, r);
4181 }
4182 inline expr re_complement(expr const& a) {
4184 }
4185 inline expr range(expr const& lo, expr const& hi) {
4186 check_context(lo, hi);
4187 Z3_ast r = Z3_mk_re_range(lo.ctx(), lo, hi);
4188 lo.check_error();
4189 return expr(lo.ctx(), r);
4190 }
4191
4192
4193
4194
4195
4196 inline expr_vector context::parse_string(char const* s) {
4197 Z3_ast_vector r = Z3_parse_smtlib2_string(*this, s, 0, 0, 0, 0, 0, 0);
4198 check_error();
4199 return expr_vector(*this, r);
4200
4201 }
4202 inline expr_vector context::parse_file(char const* s) {
4203 Z3_ast_vector r = Z3_parse_smtlib2_file(*this, s, 0, 0, 0, 0, 0, 0);
4204 check_error();
4205 return expr_vector(*this, r);
4206 }
4207
4208 inline expr_vector context::parse_string(char const* s, sort_vector const& sorts, func_decl_vector const& decls) {
4211 array<Z3_sort> sorts1(sorts);
4213 for (unsigned i = 0; i < sorts.size(); ++i) {
4214 sort_names[i] = sorts[i].name();
4215 }
4216 for (unsigned i = 0; i < decls.size(); ++i) {
4217 decl_names[i] = decls[i].name();
4218 }
4219
4220 Z3_ast_vector r = Z3_parse_smtlib2_string(*this, s, sorts.size(), sort_names.ptr(), sorts1.ptr(), decls.size(), decl_names.ptr(), decls1.ptr());
4221 check_error();
4222 return expr_vector(*this, r);
4223 }
4224
4225 inline expr_vector context::parse_file(char const* s, sort_vector const& sorts, func_decl_vector const& decls) {
4228 array<Z3_sort> sorts1(sorts);
4230 for (unsigned i = 0; i < sorts.size(); ++i) {
4231 sort_names[i] = sorts[i].name();
4232 }
4233 for (unsigned i = 0; i < decls.size(); ++i) {
4234 decl_names[i] = decls[i].name();
4235 }
4236 Z3_ast_vector r = Z3_parse_smtlib2_file(*this, s, sorts.size(), sort_names.ptr(), sorts1.ptr(), decls.size(), decl_names.ptr(), decls1.ptr());
4237 check_error();
4238 return expr_vector(*this, r);
4239 }
4240
4242 assert(is_datatype());
4244 unsigned n = Z3_get_datatype_sort_num_constructors(ctx(), *this);
4245 for (unsigned i = 0; i < n; ++i)
4246 cs.push_back(func_decl(ctx(), Z3_get_datatype_sort_constructor(ctx(), *this, i)));
4247 return cs;
4248 }
4249
4251 assert(is_datatype());
4253 unsigned n = Z3_get_datatype_sort_num_constructors(ctx(), *this);
4254 for (unsigned i = 0; i < n; ++i)
4255 rs.push_back(func_decl(ctx(), Z3_get_datatype_sort_recognizer(ctx(), *this, i)));
4256 return rs;
4257 }
4258
4260 sort s = range();
4261 assert(s.is_datatype());
4262 unsigned n = Z3_get_datatype_sort_num_constructors(ctx(), s);
4263 unsigned idx = 0;
4264 for (; idx < n; ++idx) {
4266 if (id() == f.id())
4267 break;
4268 }
4269 assert(idx < n);
4270 n = arity();
4272 for (unsigned i = 0; i < n; ++i)
4273 as.push_back(func_decl(ctx(), Z3_get_datatype_sort_constructor_accessor(ctx(), s, idx, i)));
4274 return as;
4275 }
4276
4277
4279 assert(src.size() == dst.size());
4280 array<Z3_ast> _src(src.size());
4281 array<Z3_ast> _dst(dst.size());
4282 for (unsigned i = 0; i < src.size(); ++i) {
4283 _src[i] = src[i];
4284 _dst[i] = dst[i];
4285 }
4286 Z3_ast r = Z3_substitute(ctx(), m_ast, src.size(), _src.ptr(), _dst.ptr());
4287 check_error();
4288 return expr(ctx(), r);
4289 }
4290
4292 array<Z3_ast> _dst(dst.size());
4293 for (unsigned i = 0; i < dst.size(); ++i) {
4294 _dst[i] = dst[i];
4295 }
4296 Z3_ast r = Z3_substitute_vars(ctx(), m_ast, dst.size(), _dst.ptr());
4297 check_error();
4298 return expr(ctx(), r);
4299 }
4300
4302 array<Z3_ast> _dst(dst.size());
4304 if (dst.size() != funs.size()) {
4305 Z3_THROW(exception("length of argument lists don't align"));
4306 return expr(ctx(), nullptr);
4307 }
4308 for (unsigned i = 0; i < dst.size(); ++i) {
4309 _dst[i] = dst[i];
4310 _funs[i] = funs[i];
4311 }
4312 Z3_ast r = Z3_substitute_funs(ctx(), m_ast, dst.size(), _funs.ptr(), _dst.ptr());
4313 check_error();
4314 return expr(ctx(), r);
4315 }
4316
4317 typedef std::function<void(expr const& proof, std::vector<unsigned> const& deps, expr_vector const& clause)> on_clause_eh_t;
4318
4320 context& c;
4321 on_clause_eh_t m_on_clause;
4322
4323 static void _on_clause_eh(void* _ctx, Z3_ast _proof, unsigned n, unsigned const* dep, Z3_ast_vector _literals) {
4324 on_clause* ctx = static_cast<on_clause*>(_ctx);
4325 expr_vector lits(ctx->c, _literals);
4326 expr proof(ctx->c, _proof);
4327 std::vector<unsigned> deps;
4328 for (unsigned i = 0; i < n; ++i)
4329 deps.push_back(dep[i]);
4330 ctx->m_on_clause(proof, deps, lits);
4331 }
4332 public:
4333 on_clause(solver& s, on_clause_eh_t& on_clause_eh): c(s.ctx()) {
4334 m_on_clause = on_clause_eh;
4335 Z3_solver_register_on_clause(c, s, this, _on_clause_eh);
4336 c.check_error();
4337 }
4338 };
4339
4341
4342 typedef std::function<void(expr const&, expr const&)> fixed_eh_t;
4343 typedef std::function<void(void)> final_eh_t;
4344 typedef std::function<void(expr const&, expr const&)> eq_eh_t;
4345 typedef std::function<void(expr const&)> created_eh_t;
4346 typedef std::function<void(expr, unsigned, bool)> decide_eh_t;
4347 typedef std::function<bool(expr const&, expr const&)> on_binding_eh_t;
4348
4349 final_eh_t m_final_eh;
4350 eq_eh_t m_eq_eh;
4351 fixed_eh_t m_fixed_eh;
4352 created_eh_t m_created_eh;
4353 decide_eh_t m_decide_eh;
4354 on_binding_eh_t m_on_binding_eh;
4355 solver* s;
4356 context* c;
4357 std::vector<z3::context*> subcontexts;
4358
4359 unsigned m_callbackNesting = 0;
4360 Z3_solver_callback cb { nullptr };
4361
4362 struct scoped_cb {
4364 scoped_cb(void* _p, Z3_solver_callback cb):p(*static_cast<user_propagator_base*>(_p)) {
4365 p.cb = cb;
4366 p.m_callbackNesting++;
4367 }
4368 ~scoped_cb() {
4369 if (--p.m_callbackNesting == 0)
4370 p.cb = nullptr;
4371 }
4372 };
4373
4374 static void push_eh(void* _p, Z3_solver_callback cb) {
4375 user_propagator_base* p = static_cast<user_propagator_base*>(_p);
4376 scoped_cb _cb(p, cb);
4377 static_cast<user_propagator_base*>(p)->push();
4378 }
4379
4380 static void pop_eh(void* _p, Z3_solver_callback cb, unsigned num_scopes) {
4381 user_propagator_base* p = static_cast<user_propagator_base*>(_p);
4382 scoped_cb _cb(p, cb);
4383 static_cast<user_propagator_base*>(_p)->pop(num_scopes);
4384 }
4385
4386 static void* fresh_eh(void* _p, Z3_context ctx) {
4387 user_propagator_base* p = static_cast<user_propagator_base*>(_p);
4388 context* c = new context(ctx);
4389 p->subcontexts.push_back(c);
4390 return p->fresh(*c);
4391 }
4392
4393 static void fixed_eh(void* _p, Z3_solver_callback cb, Z3_ast _var, Z3_ast _value) {
4394 user_propagator_base* p = static_cast<user_propagator_base*>(_p);
4395 scoped_cb _cb(p, cb);
4396 expr value(p->ctx(), _value);
4397 expr var(p->ctx(), _var);
4398 p->m_fixed_eh(var, value);
4399 }
4400
4401 static void eq_eh(void* _p, Z3_solver_callback cb, Z3_ast _x, Z3_ast _y) {
4402 user_propagator_base* p = static_cast<user_propagator_base*>(_p);
4403 scoped_cb _cb(p, cb);
4404 expr x(p->ctx(), _x), y(p->ctx(), _y);
4405 p->m_eq_eh(x, y);
4406 }
4407
4408 static void final_eh(void* p, Z3_solver_callback cb) {
4409 scoped_cb _cb(p, cb);
4410 static_cast<user_propagator_base*>(p)->m_final_eh();
4411 }
4412
4413 static void created_eh(void* _p, Z3_solver_callback cb, Z3_ast _e) {
4414 user_propagator_base* p = static_cast<user_propagator_base*>(_p);
4415 scoped_cb _cb(p, cb);
4416 expr e(p->ctx(), _e);
4417 p->m_created_eh(e);
4418 }
4419
4420 static void decide_eh(void* _p, Z3_solver_callback cb, Z3_ast _val, unsigned bit, bool is_pos) {
4421 user_propagator_base* p = static_cast<user_propagator_base*>(_p);
4422 scoped_cb _cb(p, cb);
4423 expr val(p->ctx(), _val);
4424 p->m_decide_eh(val, bit, is_pos);
4425 }
4426
4427 static bool on_binding_eh(void* _p, Z3_solver_callback cb, Z3_ast _q, Z3_ast _inst) {
4428 user_propagator_base* p = static_cast<user_propagator_base*>(_p);
4429 scoped_cb _cb(p, cb);
4430 expr q(p->ctx(), _q), inst(p->ctx(), _inst);
4431 return p->m_on_binding_eh(q, inst);
4432 }
4433
4434 public:
4436
4438 Z3_solver_propagate_init(ctx(), *s, this, push_eh, pop_eh, fresh_eh);
4439 }
4440
4441 virtual void push() = 0;
4442 virtual void pop(unsigned num_scopes) = 0;
4443
4445 for (auto& subcontext : subcontexts) {
4446 subcontext->detach(); // detach first; the subcontexts will be freed internally!
4447 delete subcontext;
4448 }
4449 }
4450
4452 return c ? *c : s->ctx();
4453 }
4454
4464
4471 void register_fixed(fixed_eh_t& f) {
4472 m_fixed_eh = f;
4473 if (s) {
4474 Z3_solver_propagate_fixed(ctx(), *s, fixed_eh);
4475 }
4476 }
4477
4479 m_fixed_eh = [this](expr const &id, expr const &e) {
4480 fixed(id, e);
4481 };
4482 if (s) {
4483 Z3_solver_propagate_fixed(ctx(), *s, fixed_eh);
4484 }
4485 }
4486
4487 void register_eq(eq_eh_t& f) {
4488 m_eq_eh = f;
4489 if (s) {
4490 Z3_solver_propagate_eq(ctx(), *s, eq_eh);
4491 }
4492 }
4493
4495 m_eq_eh = [this](expr const& x, expr const& y) {
4496 eq(x, y);
4497 };
4498 if (s) {
4499 Z3_solver_propagate_eq(ctx(), *s, eq_eh);
4500 }
4501 }
4502
4511 void register_final(final_eh_t& f) {
4512 m_final_eh = f;
4513 if (s) {
4514 Z3_solver_propagate_final(ctx(), *s, final_eh);
4515 }
4516 }
4517
4519 m_final_eh = [this]() {
4520 final();
4521 };
4522 if (s) {
4523 Z3_solver_propagate_final(ctx(), *s, final_eh);
4524 }
4525 }
4526
4527 void register_created(created_eh_t& c) {
4528 m_created_eh = c;
4529 if (s) {
4530 Z3_solver_propagate_created(ctx(), *s, created_eh);
4531 }
4532 }
4533
4535 m_created_eh = [this](expr const& e) {
4536 created(e);
4537 };
4538 if (s) {
4539 Z3_solver_propagate_created(ctx(), *s, created_eh);
4540 }
4541 }
4542
4543 void register_decide(decide_eh_t& c) {
4544 m_decide_eh = c;
4545 if (s) {
4546 Z3_solver_propagate_decide(ctx(), *s, decide_eh);
4547 }
4548 }
4549
4551 m_decide_eh = [this](expr val, unsigned bit, bool is_pos) {
4552 decide(val, bit, is_pos);
4553 };
4554 if (s) {
4555 Z3_solver_propagate_decide(ctx(), *s, decide_eh);
4556 }
4557 }
4558
4560 m_on_binding_eh = [this](expr const& q, expr const& inst) {
4561 return on_binding(q, inst);
4562 };
4563 if (s)
4564 Z3_solver_propagate_on_binding(ctx(), *s, on_binding_eh);
4565 }
4566
4567 virtual void fixed(expr const& /*id*/, expr const& /*e*/) { }
4568
4569 virtual void eq(expr const& /*x*/, expr const& /*y*/) { }
4570
4571 virtual void final() { }
4572
4573 virtual void created(expr const& /*e*/) {}
4574
4575 virtual void decide(expr const& /*val*/, unsigned /*bit*/, bool /*is_pos*/) {}
4576
4577 virtual bool on_binding(expr const& /*q*/, expr const& /*inst*/) { return true; }
4578
4579 bool next_split(expr const& e, unsigned idx, Z3_lbool phase) {
4580 assert(cb);
4581 return Z3_solver_next_split(ctx(), cb, e, idx, phase);
4582 }
4583
4598 void add(expr const& e) {
4599 if (cb)
4601 else if (s)
4603 else
4604 assert(false);
4605 }
4606
4608 assert(cb);
4609 expr conseq = ctx().bool_val(false);
4610 array<Z3_ast> _fixed(fixed);
4611 Z3_solver_propagate_consequence(ctx(), cb, fixed.size(), _fixed.ptr(), 0, nullptr, nullptr, conseq);
4612 }
4613
4614 void conflict(expr_vector const& fixed, expr_vector const& lhs, expr_vector const& rhs) {
4615 assert(cb);
4616 assert(lhs.size() == rhs.size());
4617 expr conseq = ctx().bool_val(false);
4618 array<Z3_ast> _fixed(fixed);
4621 Z3_solver_propagate_consequence(ctx(), cb, fixed.size(), _fixed.ptr(), lhs.size(), _lhs.ptr(), _rhs.ptr(), conseq);
4622 }
4623
4624 bool propagate(expr_vector const& fixed, expr const& conseq) {
4625 assert(cb);
4626 assert((Z3_context)conseq.ctx() == (Z3_context)ctx());
4627 array<Z3_ast> _fixed(fixed);
4628 return Z3_solver_propagate_consequence(ctx(), cb, _fixed.size(), _fixed.ptr(), 0, nullptr, nullptr, conseq);
4629 }
4630
4632 expr_vector const& lhs, expr_vector const& rhs,
4633 expr const& conseq) {
4634 assert(cb);
4635 assert((Z3_context)conseq.ctx() == (Z3_context)ctx());
4636 assert(lhs.size() == rhs.size());
4637 array<Z3_ast> _fixed(fixed);
4640
4641 return Z3_solver_propagate_consequence(ctx(), cb, _fixed.size(), _fixed.ptr(), lhs.size(), _lhs.ptr(), _rhs.ptr(), conseq);
4642 }
4643 };
4644
4645}
4646
4649#undef Z3_THROW
4650
unsigned size() const
Definition z3++.h:3102
apply_result & operator=(apply_result const &s)
Definition z3++.h:3095
apply_result(context &c, Z3_apply_result s)
Definition z3++.h:3091
goal operator[](int i) const
Definition z3++.h:3103
friend std::ostream & operator<<(std::ostream &out, apply_result const &r)
Definition z3++.h:3106
~apply_result() override
Definition z3++.h:3093
apply_result(apply_result const &s)
Definition z3++.h:3092
unsigned size() const
Definition z3++.h:478
void resize(unsigned sz)
Definition z3++.h:477
T const & operator[](int i) const
Definition z3++.h:480
array(unsigned sz)
Definition z3++.h:474
T const * ptr() const
Definition z3++.h:481
T * ptr()
Definition z3++.h:482
T & operator[](int i)
Definition z3++.h:479
iterator(ast_vector_tpl const *v, unsigned i)
Definition z3++.h:645
bool operator==(iterator const &other) const noexcept
Definition z3++.h:647
iterator operator++(int) noexcept
Definition z3++.h:660
bool operator!=(iterator const &other) const noexcept
Definition z3++.h:650
iterator & operator++() noexcept
Definition z3++.h:653
void pop_back()
Definition z3++.h:620
friend std::ostream & operator<<(std::ostream &out, ast_vector_tpl const &v)
Definition z3++.h:666
unsigned size() const
Definition z3++.h:615
void resize(unsigned sz)
Definition z3++.h:618
ast_vector_tpl & operator=(ast_vector_tpl const &s)
Definition z3++.h:622
~ast_vector_tpl() override
Definition z3++.h:613
ast_vector_tpl(ast_vector_tpl const &s)
Definition z3++.h:610
bool empty() const
Definition z3++.h:621
iterator end() const
Definition z3++.h:665
ast_vector_tpl(context &c, Z3_ast_vector v)
Definition z3++.h:609
void push_back(T const &e)
Definition z3++.h:617
T back() const
Definition z3++.h:619
std::string to_string() const
Definition z3++.h:667
T operator[](unsigned i) const
Definition z3++.h:616
ast_vector_tpl & set(unsigned idx, ast &a)
Definition z3++.h:629
ast_vector_tpl(context &c, ast_vector_tpl const &src)
Definition z3++.h:611
ast_vector_tpl(context &c)
Definition z3++.h:608
iterator begin() const noexcept
Definition z3++.h:664
friend std::ostream & operator<<(std::ostream &out, ast const &n)
Definition z3++.h:597
ast(ast const &s)
Definition z3++.h:574
~ast() override
Definition z3++.h:575
ast & operator=(ast const &s)
Definition z3++.h:578
friend bool eq(ast const &a, ast const &b)
Return true if the ASTs are structurally identical.
Definition z3++.h:601
Z3_ast_kind kind() const
Definition z3++.h:586
Z3_ast m_ast
Definition z3++.h:570
ast(context &c)
Definition z3++.h:572
std::string to_string() const
Definition z3++.h:589
ast(context &c, Z3_ast n)
Definition z3++.h:573
unsigned hash() const
Definition z3++.h:587
ast operator()(context &c, Z3_ast a)
Definition z3++.h:2310
expr operator()(context &c, Z3_ast a)
Definition z3++.h:2315
func_decl operator()(context &c, Z3_ast a)
Definition z3++.h:2334
sort operator()(context &c, Z3_ast a)
Definition z3++.h:2326
Z3 global configuration object.
Definition z3++.h:110
~config()
Definition z3++.h:116
void set(char const *param, int value)
Set global parameter param with integer value.
Definition z3++.h:129
void set(char const *param, char const *value)
Set global parameter param with string value.
Definition z3++.h:121
config()
Definition z3++.h:115
void set(char const *param, bool value)
Set global parameter param with Boolean value.
Definition z3++.h:125
constructor_list(constructors const &cs)
Definition z3++.h:3620
void query(unsigned i, func_decl &constructor, func_decl &test, func_decl_vector &accs)
Definition z3++.h:3601
unsigned size() const
Definition z3++.h:3599
constructors(context &ctx)
Definition z3++.h:3581
Z3_constructor operator[](unsigned i) const
Definition z3++.h:3597
void add(symbol const &name, symbol const &rec, unsigned n, symbol const *names, sort const *fields)
Definition z3++.h:3588
A Context manages all other Z3 objects, global configuration options, etc.
Definition z3++.h:160
symbol str_symbol(char const *s)
Create a Z3 symbol based on the given string.
Definition z3++.h:3510
void recdef(func_decl decl, expr_vector const &args, expr const &body)
add function definition body to declaration decl. decl needs to be declared using context::recfun.
Definition z3++.h:3792
expr num_val(int n, sort const &s)
Definition z3++.h:3876
expr fpa_rounding_mode()
Definition z3++.h:3829
context()
Definition z3++.h:184
expr bv_val(int n, unsigned sz)
Definition z3++.h:3855
func_decl recfun(symbol const &name, unsigned arity, sort const *domain, sort const &range)
Definition z3++.h:3754
expr bool_val(bool b)
Definition z3++.h:3840
expr fpa_const(char const *name, unsigned ebits, unsigned sbits)
Definition z3++.h:3822
expr string_val(char const *s)
Definition z3++.h:3872
sort real_sort()
Return the Real sort.
Definition z3++.h:3515
Z3_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition z3++.h:192
expr bv_const(char const *name, unsigned sz)
Definition z3++.h:3821
expr string_const(char const *name)
Definition z3++.h:3820
sort array_sort(sort d, sort r)
Return an array sort for arrays from d to r.
Definition z3++.h:3537
void set_enable_exceptions(bool f)
The C++ API uses by defaults exceptions on errors. For applications that don't work well with excepti...
Definition z3++.h:210
sort string_sort()
Return the sort for Unicode strings.
Definition z3++.h:3517
sort re_sort(sort &seq_sort)
Return a regular expression sort over sequences seq_sort.
Definition z3++.h:3520
sort uninterpreted_sort(char const *name)
create an uninterpreted sort with the name given by the string or symbol.
Definition z3++.h:3675
sort enumeration_sort(char const *name, unsigned n, char const *const *enum_names, func_decl_vector &cs, func_decl_vector &ts)
Return an enumeration sort: enum_names[0], ..., enum_names[n-1]. cs and ts are output parameters....
Definition z3++.h:3542
void set(char const *param, int value)
Update global parameter param with Integer value.
Definition z3++.h:225
sort bool_sort()
Return the Boolean sort.
Definition z3++.h:3513
void set(char const *param, char const *value)
Update global parameter param with string value.
Definition z3++.h:217
~context()
Definition z3++.h:186
expr bool_const(char const *name)
create uninterpreted constants of a given sort.
Definition z3++.h:3817
void check_parser_error() const
Definition z3++.h:199
expr variable(unsigned index, sort const &s)
create a de-Bruijn variable.
Definition z3++.h:3812
expr_vector parse_string(char const *s)
parsing
Definition z3++.h:4196
sort fpa_sort()
Definition z3++.h:3524
symbol int_symbol(int n)
Create a Z3 symbol based on the given integer.
Definition z3++.h:3511
expr real_const(char const *name)
Definition z3++.h:3819
sort datatype(symbol const &name, constructors const &cs)
Create a recursive datatype over a single sort. name is the name of the recursive datatype n - the nu...
Definition z3++.h:3627
expr int_const(char const *name)
Definition z3++.h:3818
expr fpa_nan(sort const &s)
Definition z3++.h:3868
expr fpa_val(double n)
Definition z3++.h:3866
bool enable_exceptions() const
Definition z3++.h:212
sort bv_sort(unsigned sz)
Return the Bit-vector sort of size sz. That is, the sort for bit-vectors of size sz.
Definition z3++.h:3516
expr int_val(int n)
Definition z3++.h:3842
expr fpa_inf(sort const &s, bool sgn)
Definition z3++.h:3869
func_decl function(symbol const &name, unsigned arity, sort const *domain, sort const &range)
Definition z3++.h:3683
sort fpa_rounding_mode_sort()
Return a RoundingMode sort.
Definition z3++.h:3535
expr_vector parse_file(char const *file)
Definition z3++.h:4202
expr constant(symbol const &name, sort const &s)
create an uninterpreted constant.
Definition z3++.h:3806
sort char_sort()
Return the sort for Unicode characters.
Definition z3++.h:3518
func_decl tuple_sort(char const *name, unsigned n, char const *const *names, sort const *sorts, func_decl_vector &projs)
Return a tuple constructor. name is the name of the returned constructor, n are the number of argumen...
Definition z3++.h:3553
void set(char const *param, bool value)
Update global parameter param with Boolean value.
Definition z3++.h:221
sort int_sort()
Return the integer sort.
Definition z3++.h:3514
void interrupt()
Interrupt the current procedure being executed by any object managed by this context....
Definition z3++.h:234
void set_rounding_mode(rounding_mode rm)
Sets RoundingMode of FloatingPoints.
Definition z3++.h:3827
func_decl user_propagate_function(symbol const &name, sort_vector const &domain, sort const &range)
Definition z3++.h:3798
sort fpa_sort()
Return a FloatingPoint sort with given precision bitwidth (16, 32, 64 or 128).
expr real_val(int n)
Definition z3++.h:3849
sort_vector datatypes(unsigned n, symbol const *names, constructor_list *const *cons)
Create a set of mutually recursive datatypes. n - number of recursive datatypes names - array of name...
Definition z3++.h:3645
sort datatype_sort(symbol const &name)
a reference to a recursively defined datatype. Expect that it gets defined as a datatype.
Definition z3++.h:3661
context(config &c)
Definition z3++.h:185
sort seq_sort(sort &s)
Return a sequence sort over base sort s.
Definition z3++.h:3519
Exception used to sign API usage errors.
Definition z3++.h:88
char const * what() const
Definition z3++.h:94
virtual ~exception()=default
friend std::ostream & operator<<(std::ostream &out, exception const &e)
Definition z3++.h:97
char const * msg() const
Definition z3++.h:93
bool operator==(iterator const &other) const noexcept
Definition z3++.h:1623
iterator operator++(int)
Definition z3++.h:1631
iterator(expr &e, unsigned i)
Definition z3++.h:1622
expr operator*() const
Definition z3++.h:1629
iterator & operator++()
Definition z3++.h:1630
bool operator!=(iterator const &other) const noexcept
Definition z3++.h:1626
A Z3 expression is used to represent formulas and terms. For Z3, a formula is any expression of sort ...
Definition z3++.h:828
bool is_lambda() const
Return true if this expression is a lambda expression.
Definition z3++.h:937
expr numerator() const
Definition z3++.h:1154
friend expr pw(expr const &a, expr const &b)
Definition z3++.h:1654
friend expr sbv_to_fpa(expr const &t, sort s)
Conversion of a signed bit-vector term into a floating-point.
Definition z3++.h:2078
friend expr bvneg_no_overflow(expr const &a)
Definition z3++.h:2279
expr loop(unsigned lo, unsigned hi)
Definition z3++.h:1572
expr body() const
Return the 'body' of this quantifier.
Definition z3++.h:1245
friend expr bvadd_no_underflow(expr const &a, expr const &b)
Definition z3++.h:2267
expr ubvtos() const
Definition z3++.h:1532
friend expr sum(expr_vector const &args)
Definition z3++.h:2463
expr substitute(expr_vector const &src, expr_vector const &dst)
Apply substitution. Replace src expressions by dst.
Definition z3++.h:4278
bool is_quantifier() const
Return true if this expression is a quantifier.
Definition z3++.h:924
bool is_exists() const
Return true if this expression is an existential quantifier.
Definition z3++.h:933
bool is_numeral_u64(uint64_t &i) const
Definition z3++.h:900
bool is_int() const
Return true if this is an integer expression.
Definition z3++.h:845
friend expr operator/(expr const &a, expr const &b)
Definition z3++.h:1820
friend expr fp_eq(expr const &a, expr const &b)
Definition z3++.h:2039
friend expr concat(expr const &a, expr const &b)
Definition z3++.h:2481
friend expr bvmul_no_underflow(expr const &a, expr const &b)
Definition z3++.h:2285
int64_t get_numeral_int64() const
Return int64_t value of numeral, throw if result cannot fit in int64_t.
Definition z3++.h:1122
bool is_app() const
Return true if this expression is an application.
Definition z3++.h:916
friend expr fpa_to_fpa(expr const &t, sort s)
Conversion of a floating-point term into another floating-point.
Definition z3++.h:2092
friend expr operator&&(expr const &a, expr const &b)
Return an expression representing a and b.
Definition z3++.h:1698
friend expr operator!=(expr const &a, expr const &b)
Definition z3++.h:1734
friend expr operator+(expr const &a, expr const &b)
Definition z3++.h:1746
std::string get_string() const
for a string value expression return an escaped string value.
Definition z3++.h:1181
bool is_numeral(std::string &s) const
Definition z3++.h:903
expr char_to_int() const
Definition z3++.h:1542
bool is_var() const
Return true if this expression is a variable.
Definition z3++.h:942
bool is_numeral_u(unsigned &i) const
Definition z3++.h:902
friend expr min(expr const &a, expr const &b)
Definition z3++.h:1968
expr at(expr const &index) const
Definition z3++.h:1505
expr_vector args() const
Return a vector of all the arguments of this application. This method assumes the expression is an ap...
Definition z3++.h:1232
expr denominator() const
Definition z3++.h:1162
bool is_real() const
Return true if this is a real expression.
Definition z3++.h:849
bool is_numeral_i(int &i) const
Definition z3++.h:901
friend expr operator>(expr const &a, expr const &b)
Definition z3++.h:1931
expr mk_is_nan() const
Return Boolean expression to test for whether an FP expression is a NaN.
Definition z3++.h:966
int get_numeral_int() const
Return int value of numeral, throw if result cannot fit in machine int.
Definition z3++.h:1086
expr is_digit() const
Definition z3++.h:1557
friend expr bv2int(expr const &a, bool is_signed)
bit-vector and integer conversions.
Definition z3++.h:2258
friend expr operator~(expr const &a)
Definition z3++.h:2046
unsigned num_args() const
Return the number of arguments in this application. This method assumes the expression is an applicat...
Definition z3++.h:1217
friend expr nor(expr const &a, expr const &b)
Definition z3++.h:1966
friend expr fpa_fp(expr const &sgn, expr const &exp, expr const &sig)
Create an expression of FloatingPoint sort from three bit-vector expressions.
Definition z3++.h:2056
expr arg(unsigned i) const
Return the i-th argument of this application. This method assumes the expression is an application.
Definition z3++.h:1225
expr mk_is_normal() const
Return Boolean expression to test for whether an FP expression is a normal.
Definition z3++.h:976
friend expr bvsub_no_underflow(expr const &a, expr const &b, bool is_signed)
Definition z3++.h:2273
expr repeat(unsigned i) const
Definition z3++.h:1424
bool is_true() const
Definition z3++.h:1311
expr(context &c)
Definition z3++.h:830
friend expr mk_xor(expr_vector const &args)
Definition z3++.h:2565
bool is_numeral(std::string &s, unsigned precision) const
Definition z3++.h:904
unsigned get_numeral_uint() const
Return uint value of numeral, throw if result cannot fit in machine uint.
Definition z3++.h:1105
bool is_distinct() const
Definition z3++.h:1320
bool is_numeral(double &d) const
Definition z3++.h:905
expr rotate_left(unsigned i) const
Definition z3++.h:1422
friend expr operator*(expr const &a, expr const &b)
Definition z3++.h:1776
sort get_sort() const
Return the sort of this expression.
Definition z3++.h:836
friend expr nand(expr const &a, expr const &b)
Definition z3++.h:1965
bool is_and() const
Definition z3++.h:1314
friend expr fpa_to_ubv(expr const &t, unsigned sz)
Conversion of a floating-point term into an unsigned bit-vector.
Definition z3++.h:2071
friend expr bvredor(expr const &a)
Definition z3++.h:2000
expr extract(unsigned hi, unsigned lo) const
Definition z3++.h:1434
expr rotate_right(unsigned i) const
Definition z3++.h:1423
friend expr int2bv(unsigned n, expr const &a)
Definition z3++.h:2259
friend expr max(expr const &a, expr const &b)
Definition z3++.h:1984
bool is_relation() const
Return true if this is a Relation expression.
Definition z3++.h:869
friend expr xnor(expr const &a, expr const &b)
Definition z3++.h:1967
friend expr abs(expr const &a)
Definition z3++.h:2012
friend expr pbge(expr_vector const &es, int const *coeffs, int bound)
Definition z3++.h:2431
bool is_well_sorted() const
Return true if this expression is well sorted (aka type correct).
Definition z3++.h:951
bool is_or() const
Definition z3++.h:1315
friend expr round_fpa_to_closest_integer(expr const &t)
Round a floating-point term into its closest integer.
Definition z3++.h:2099
friend expr distinct(expr_vector const &args)
Definition z3++.h:2472
friend expr bvmul_no_overflow(expr const &a, expr const &b, bool is_signed)
Definition z3++.h:2282
friend expr bvsub_no_overflow(expr const &a, expr const &b)
Definition z3++.h:2270
bool is_const() const
Return true if this expression is a constant (i.e., an application with 0 arguments).
Definition z3++.h:920
expr length() const
Definition z3++.h:1517
friend expr mod(expr const &a, expr const &b)
Definition z3++.h:1658
friend expr fma(expr const &a, expr const &b, expr const &c, expr const &rm)
FloatingPoint fused multiply-add.
Definition z3++.h:2048
bool is_bool() const
Return true if this is a Boolean expression.
Definition z3++.h:841
friend expr mk_or(expr_vector const &args)
Definition z3++.h:2553
expr contains(expr const &s) const
Definition z3++.h:1499
friend expr ite(expr const &c, expr const &t, expr const &e)
Create the if-then-else expression ite(c, t, e)
Definition z3++.h:2111
expr algebraic_lower(unsigned precision) const
Definition z3++.h:1037
unsigned hi() const
Definition z3++.h:1437
expr simplify() const
Return a simplified version of this expression.
Definition z3++.h:1596
bool is_arith() const
Return true if this is an integer or real expression.
Definition z3++.h:853
expr mk_is_inf() const
Return Boolean expression to test for whether an FP expression is inf.
Definition z3++.h:956
expr stoi() const
Definition z3++.h:1522
expr_vector algebraic_poly() const
Return coefficients for p of an algebraic number (root-obj p i)
Definition z3++.h:1054
bool is_ite() const
Definition z3++.h:1319
bool is_bv() const
Return true if this is a Bit-vector expression.
Definition z3++.h:857
friend expr pbeq(expr_vector const &es, int const *coeffs, int bound)
Definition z3++.h:2439
friend expr operator^(expr const &a, expr const &b)
Definition z3++.h:1957
friend expr operator<=(expr const &a, expr const &b)
Definition z3++.h:1884
friend expr operator>=(expr const &a, expr const &b)
Definition z3++.h:1800
friend expr sqrt(expr const &a, expr const &rm)
Definition z3++.h:2032
friend expr pble(expr_vector const &es, int const *coeffs, int bound)
Definition z3++.h:2423
friend expr operator==(expr const &a, expr const &b)
Definition z3++.h:1723
bool is_finite_domain() const
Return true if this is a Finite-domain expression.
Definition z3++.h:887
expr operator[](expr_vector const &index) const
Definition z3++.h:1589
bool is_forall() const
Return true if this expression is a universal quantifier.
Definition z3++.h:929
bool is_implies() const
Definition z3++.h:1317
uint64_t as_uint64() const
Definition z3++.h:909
friend expr implies(expr const &a, expr const &b)
Definition z3++.h:1646
expr mk_is_subnormal() const
Return Boolean expression to test for whether an FP expression is a subnormal.
Definition z3++.h:986
uint64_t get_numeral_uint64() const
Return uint64_t value of numeral, throw if result cannot fit in uint64_t.
Definition z3++.h:1139
expr(context &c, Z3_ast n)
Definition z3++.h:831
friend expr bvadd_no_overflow(expr const &a, expr const &b, bool is_signed)
bit-vector overflow/underflow checks
Definition z3++.h:2264
bool is_datatype() const
Return true if this is a Datatype expression.
Definition z3++.h:865
bool is_not() const
Definition z3++.h:1313
bool is_string_value() const
Return true if this expression is a string literal. The string can be accessed using get_string() and...
Definition z3++.h:1174
expr simplify(params const &p) const
Return a simplified version of this expression. The parameter p is a set of parameters for the Z3 sim...
Definition z3++.h:1600
expr loop(unsigned lo)
create a looping regular expression.
Definition z3++.h:1567
expr sbvtos() const
Definition z3++.h:1537
expr mk_from_ieee_bv(sort const &s) const
Convert this IEEE BV into a fpa.
Definition z3++.h:1016
friend expr bvredand(expr const &a)
Definition z3++.h:2006
friend expr operator&(expr const &a, expr const &b)
Definition z3++.h:1953
friend expr operator-(expr const &a)
Definition z3++.h:1842
friend expr bvsdiv_no_overflow(expr const &a, expr const &b)
Definition z3++.h:2276
expr extract(expr const &offset, expr const &length) const
sequence and regular expression operations.
Definition z3++.h:1484
bool is_eq() const
Definition z3++.h:1318
expr unit() const
Definition z3++.h:1494
bool is_re() const
Return true if this is a regular expression.
Definition z3++.h:877
bool is_numeral_i64(int64_t &i) const
Definition z3++.h:899
bool as_binary(std::string &s) const
Definition z3++.h:906
unsigned id() const
retrieve unique identifier for expression.
Definition z3++.h:1074
friend expr rem(expr const &a, expr const &b)
Definition z3++.h:1674
friend expr operator!(expr const &a)
Return an expression representing not(a).
Definition z3++.h:1692
bool is_algebraic() const
Return true if expression is an algebraic number.
Definition z3++.h:946
friend expr mk_and(expr_vector const &args)
Definition z3++.h:2559
expr itos() const
Definition z3++.h:1527
bool is_false() const
Definition z3++.h:1312
int64_t as_int64() const
Definition z3++.h:910
double as_double() const
Definition z3++.h:908
iterator end()
Definition z3++.h:1635
expr mk_is_zero() const
Return Boolean expression to test for whether an FP expression is a zero.
Definition z3++.h:996
std::u32string get_u32string() const
for a string value expression return an unespaced string value.
Definition z3++.h:1193
std::string get_decimal_string(int precision) const
Return string representation of numeral or algebraic number This method assumes the expression is num...
Definition z3++.h:1029
Z3_lbool bool_value() const
Definition z3++.h:1150
expr replace(expr const &src, expr const &dst) const
Definition z3++.h:1488
iterator begin()
Definition z3++.h:1634
friend expr operator||(expr const &a, expr const &b)
Return an expression representing a or b.
Definition z3++.h:1710
bool is_array() const
Return true if this is a Array expression.
Definition z3++.h:861
bool is_xor() const
Definition z3++.h:1316
unsigned algebraic_i() const
Return i of an algebraic number (root-obj p i)
Definition z3++.h:1064
unsigned lo() const
Definition z3++.h:1436
friend expr ubv_to_fpa(expr const &t, sort s)
Conversion of an unsigned bit-vector term into a floating-point.
Definition z3++.h:2085
expr nth(expr const &index) const
Definition z3++.h:1511
friend expr fpa_to_sbv(expr const &t, unsigned sz)
Conversion of a floating-point term into a signed bit-vector.
Definition z3++.h:2064
bool is_seq() const
Return true if this is a sequence expression.
Definition z3++.h:873
friend expr operator|(expr const &a, expr const &b)
Definition z3++.h:1961
expr bit2bool(unsigned i) const
Definition z3++.h:1435
friend expr atmost(expr_vector const &es, unsigned bound)
Definition z3++.h:2447
friend expr range(expr const &lo, expr const &hi)
Definition z3++.h:4185
expr char_from_bv() const
Definition z3++.h:1552
friend expr atleast(expr_vector const &es, unsigned bound)
Definition z3++.h:2455
friend expr operator<(expr const &a, expr const &b)
Definition z3++.h:1909
expr mk_to_ieee_bv() const
Convert this fpa into an IEEE BV.
Definition z3++.h:1006
expr operator[](expr const &index) const
Definition z3++.h:1581
expr algebraic_upper(unsigned precision) const
Definition z3++.h:1044
bool is_numeral() const
Return true if this expression is a numeral. Specialized functions also return representations for th...
Definition z3++.h:898
bool is_fpa() const
Return true if this is a FloatingPoint expression. .
Definition z3++.h:891
func_decl decl() const
Return the declaration associated with this application. This method assumes the expression is an app...
Definition z3++.h:1210
expr char_to_bv() const
Definition z3++.h:1547
std::string to_string(expr_vector const &queries)
Definition z3++.h:3485
std::string help() const
Definition z3++.h:3482
fixedpoint & operator=(fixedpoint const &o)
Definition z3++.h:3440
expr_vector from_string(char const *s)
Definition z3++.h:3448
void add_fact(func_decl &f, unsigned *args)
Definition z3++.h:3459
void add_cover(int level, func_decl &p, expr &property)
Definition z3++.h:3476
expr_vector rules() const
Definition z3++.h:3480
stats statistics() const
Definition z3++.h:3477
expr get_answer()
Definition z3++.h:3467
~fixedpoint() override
Definition z3++.h:3439
expr get_cover_delta(int level, func_decl &p)
Definition z3++.h:3471
fixedpoint(context &c)
Definition z3++.h:3437
std::string reason_unknown()
Definition z3++.h:3468
check_result query(func_decl_vector &relations)
Definition z3++.h:3461
void register_relation(func_decl &p)
Definition z3++.h:3478
std::string to_string()
Definition z3++.h:3484
check_result query(expr &q)
Definition z3++.h:3460
param_descrs get_param_descrs()
Definition z3++.h:3483
expr_vector from_file(char const *s)
Definition z3++.h:3453
void update_rule(expr &rule, symbol const &name)
Definition z3++.h:3469
expr_vector assertions() const
Definition z3++.h:3479
fixedpoint(fixedpoint const &o)
Definition z3++.h:3438
unsigned get_num_levels(func_decl &p)
Definition z3++.h:3470
void add_rule(expr &rule, symbol const &name)
Definition z3++.h:3458
void set(params const &p)
Definition z3++.h:3481
Function declaration (aka function definition). It is the signature of interpreted and uninterpreted ...
Definition z3++.h:777
func_decl transitive_closure(func_decl const &)
Definition z3++.h:796
func_decl(context &c, Z3_func_decl n)
Definition z3++.h:780
symbol name() const
Definition z3++.h:791
expr operator()() const
Definition z3++.h:3899
bool is_const() const
Definition z3++.h:800
func_decl_vector accessors()
Definition z3++.h:4259
sort range() const
Definition z3++.h:790
func_decl(context &c)
Definition z3++.h:779
Z3_decl_kind decl_kind() const
Definition z3++.h:792
sort domain(unsigned i) const
Definition z3++.h:789
unsigned id() const
retrieve unique identifier for func_decl.
Definition z3++.h:786
unsigned num_parameters() const
Definition z3++.h:793
unsigned arity() const
Definition z3++.h:788
Definition z3++.h:2575
unsigned num_args() const
Definition z3++.h:2594
expr arg(unsigned i) const
Definition z3++.h:2595
~func_entry() override
Definition z3++.h:2584
func_entry(context &c, Z3_func_entry e)
Definition z3++.h:2582
expr value() const
Definition z3++.h:2593
func_entry & operator=(func_entry const &s)
Definition z3++.h:2586
func_entry(func_entry const &s)
Definition z3++.h:2583
expr else_value() const
Definition z3++.h:2616
void set_else(expr &value)
Definition z3++.h:2623
func_interp(context &c, Z3_func_interp e)
Definition z3++.h:2605
func_interp(func_interp const &s)
Definition z3++.h:2606
func_entry entry(unsigned i) const
Definition z3++.h:2618
void add_entry(expr_vector const &args, expr &value)
Definition z3++.h:2619
unsigned num_entries() const
Definition z3++.h:2617
func_interp & operator=(func_interp const &s)
Definition z3++.h:2609
~func_interp() override
Definition z3++.h:2607
void add(expr const &f)
Definition z3++.h:3044
unsigned size() const
Definition z3++.h:3046
Z3_goal_prec precision() const
Definition z3++.h:3048
model convert_model(model const &m) const
Definition z3++.h:3055
bool is_decided_unsat() const
Definition z3++.h:3054
goal(goal const &s)
Definition z3++.h:3034
bool inconsistent() const
Definition z3++.h:3049
~goal() override
Definition z3++.h:3035
model get_model() const
Definition z3++.h:3061
std::string dimacs(bool include_names=true) const
Definition z3++.h:3079
unsigned num_exprs() const
Definition z3++.h:3052
goal(context &c, Z3_goal s)
Definition z3++.h:3033
goal(context &c, bool models=true, bool unsat_cores=false, bool proofs=false)
Definition z3++.h:3032
void add(expr_vector const &v)
Definition z3++.h:3045
goal & operator=(goal const &s)
Definition z3++.h:3037
void reset()
Definition z3++.h:3051
friend std::ostream & operator<<(std::ostream &out, goal const &g)
Definition z3++.h:3082
unsigned depth() const
Definition z3++.h:3050
bool is_decided_sat() const
Definition z3++.h:3053
expr as_expr() const
Definition z3++.h:3066
expr operator[](int i) const
Definition z3++.h:3047
expr eval(expr const &n, bool model_completion=false) const
Definition z3++.h:2651
unsigned size() const
Definition z3++.h:2665
expr get_const_interp(func_decl c) const
Definition z3++.h:2674
unsigned num_consts() const
Definition z3++.h:2661
model & operator=(model const &s)
Definition z3++.h:2643
unsigned num_funcs() const
Definition z3++.h:2662
func_interp get_func_interp(func_decl f) const
Definition z3++.h:2680
func_decl get_func_decl(unsigned i) const
Definition z3++.h:2664
func_interp add_func_interp(func_decl &f, expr &else_val)
Definition z3++.h:2694
func_decl operator[](int i) const
Definition z3++.h:2666
friend std::ostream & operator<<(std::ostream &out, model const &m)
Definition z3++.h:2709
~model() override
Definition z3++.h:2641
model(model const &s)
Definition z3++.h:2639
model(context &c)
Definition z3++.h:2637
void add_const_interp(func_decl &f, expr &value)
Definition z3++.h:2700
func_decl get_const_decl(unsigned i) const
Definition z3++.h:2663
bool has_interp(func_decl f) const
Definition z3++.h:2689
std::string to_string() const
Definition z3++.h:2707
model(model &src, context &dst, translate)
Definition z3++.h:2640
model(context &c, Z3_model m)
Definition z3++.h:2638
context * m_ctx
Definition z3++.h:487
Z3_error_code check_error() const
Definition z3++.h:492
context & ctx() const
Definition z3++.h:491
object(context &c)
Definition z3++.h:489
friend void check_context(object const &a, object const &b)
Definition z3++.h:495
virtual ~object()=default
on_clause(solver &s, on_clause_eh_t &on_clause_eh)
Definition z3++.h:4333
handle(unsigned h)
Definition z3++.h:3320
unsigned h() const
Definition z3++.h:3321
std::string help() const
Definition z3++.h:3430
handle add_soft(expr const &e, char const *weight)
Definition z3++.h:3369
friend std::ostream & operator<<(std::ostream &out, optimize const &s)
Definition z3++.h:3432
~optimize() override
Definition z3++.h:3347
void add(expr const &e, expr const &t)
Definition z3++.h:3356
expr lower(handle const &h)
Definition z3++.h:3414
void pop()
Definition z3++.h:3396
expr_vector objectives() const
Definition z3++.h:3425
void add(expr_vector const &es)
Definition z3++.h:3353
void add(expr const &e, char const *p)
Definition z3++.h:3360
void set_initial_value(expr const &var, expr const &value)
Definition z3++.h:3376
model get_model() const
Definition z3++.h:3411
handle add(expr const &e, unsigned weight)
Definition z3++.h:3373
check_result check()
Definition z3++.h:3399
check_result check(expr_vector const &asms)
Definition z3++.h:3400
stats statistics() const
Definition z3++.h:3426
void add(expr const &e)
Definition z3++.h:3349
void set_initial_value(expr const &var, int i)
Definition z3++.h:3380
void push()
Definition z3++.h:3393
void set_initial_value(expr const &var, bool b)
Definition z3++.h:3383
optimize(context &c, optimize const &src, translate)
Definition z3++.h:3324
handle add_soft(expr const &e, unsigned weight)
Definition z3++.h:3364
handle maximize(expr const &e)
Definition z3++.h:3387
optimize(optimize const &o)
Definition z3++.h:3330
void from_file(char const *filename)
Definition z3++.h:3428
expr_vector assertions() const
Definition z3++.h:3424
optimize & operator=(optimize const &o)
Definition z3++.h:3340
void from_string(char const *constraints)
Definition z3++.h:3429
expr upper(handle const &h)
Definition z3++.h:3419
optimize(context &c, optimize &src)
Definition z3++.h:3333
handle minimize(expr const &e)
Definition z3++.h:3390
optimize(context &c)
Definition z3++.h:3323
void set(params const &p)
Definition z3++.h:3413
expr_vector unsat_core() const
Definition z3++.h:3412
param_descrs(param_descrs const &o)
Definition z3++.h:521
param_descrs(context &c, Z3_param_descrs d)
Definition z3++.h:520
Z3_param_kind kind(symbol const &s)
Definition z3++.h:535
std::string documentation(symbol const &s)
Definition z3++.h:536
symbol name(unsigned i)
Definition z3++.h:534
static param_descrs simplify_param_descrs(context &c)
Definition z3++.h:530
unsigned size()
Definition z3++.h:533
std::string to_string() const
Definition z3++.h:537
~param_descrs() override
Definition z3++.h:529
param_descrs & operator=(param_descrs const &o)
Definition z3++.h:522
static param_descrs global_param_descrs(context &c)
Definition z3++.h:531
class for auxiliary parameters associated with func_decl The class is initialized with a func_decl or...
Definition z3++.h:2758
int get_int() const
Definition z3++.h:2782
func_decl get_decl() const
Definition z3++.h:2778
sort get_sort() const
Definition z3++.h:2777
std::string get_rational() const
Definition z3++.h:2780
symbol get_symbol() const
Definition z3++.h:2779
Z3_parameter_kind kind() const
Definition z3++.h:2775
double get_double() const
Definition z3++.h:2781
parameter(func_decl const &d, unsigned idx)
Definition z3++.h:2765
expr get_expr() const
Definition z3++.h:2776
parameter(expr const &e, unsigned idx)
Definition z3++.h:2770
void set(char const *k, char const *s)
Definition z3++.h:560
params(context &c)
Definition z3++.h:545
params(params const &s)
Definition z3++.h:546
~params() override
Definition z3++.h:547
void set(char const *k, bool b)
Definition z3++.h:556
void set(char const *k, unsigned n)
Definition z3++.h:557
void set(char const *k, symbol const &s)
Definition z3++.h:559
params & operator=(params const &s)
Definition z3++.h:549
void set(char const *k, double n)
Definition z3++.h:558
friend std::ostream & operator<<(std::ostream &out, params const &p)
Definition z3++.h:564
probe & operator=(probe const &s)
Definition z3++.h:3248
friend probe operator<(probe const &p1, probe const &p2)
Definition z3++.h:3287
double operator()(goal const &g) const
Definition z3++.h:3256
friend probe operator==(probe const &p1, probe const &p2)
Definition z3++.h:3297
friend probe operator<=(probe const &p1, probe const &p2)
Definition z3++.h:3277
probe(context &c, Z3_probe s)
Definition z3++.h:3244
probe(context &c, double val)
Definition z3++.h:3243
probe(context &c, char const *name)
Definition z3++.h:3242
friend probe operator&&(probe const &p1, probe const &p2)
Definition z3++.h:3302
probe(probe const &s)
Definition z3++.h:3245
~probe() override
Definition z3++.h:3246
friend probe operator!(probe const &p)
Definition z3++.h:3308
double apply(goal const &g) const
Definition z3++.h:3255
friend probe operator>=(probe const &p1, probe const &p2)
Definition z3++.h:3282
friend probe operator>(probe const &p1, probe const &p2)
Definition z3++.h:3292
friend probe operator||(probe const &p1, probe const &p2)
Definition z3++.h:3305
std::string help() const
Definition z3++.h:3213
~simplifier() override
Definition z3++.h:3204
simplifier(context &c, char const *name)
Definition z3++.h:3201
friend simplifier with(simplifier const &t, params const &p)
Definition z3++.h:3229
simplifier(context &c, Z3_simplifier s)
Definition z3++.h:3202
simplifier(simplifier const &s)
Definition z3++.h:3203
param_descrs get_param_descrs()
Definition z3++.h:3216
simplifier & operator=(simplifier const &s)
Definition z3++.h:3206
friend simplifier operator&(simplifier const &t1, simplifier const &t2)
Definition z3++.h:3222
cube_iterator end()
Definition z3++.h:3015
cube_generator(solver &s, expr_vector &vars)
Definition z3++.h:3007
cube_iterator begin()
Definition z3++.h:3014
cube_generator(solver &s)
Definition z3++.h:3000
void set_cutoff(unsigned c) noexcept
Definition z3++.h:3016
expr_vector const * operator->() const
Definition z3++.h:2982
bool operator==(cube_iterator const &other) const noexcept
Definition z3++.h:2985
cube_iterator operator++(int)
Definition z3++.h:2981
cube_iterator & operator++()
Definition z3++.h:2971
bool operator!=(cube_iterator const &other) const noexcept
Definition z3++.h:2988
cube_iterator(solver &s, expr_vector &vars, unsigned &cutoff, bool end)
Definition z3++.h:2959
expr_vector const & operator*() const noexcept
Definition z3++.h:2983
void from_string(char const *s)
Definition z3++.h:2846
expr proof() const
Definition z3++.h:2904
cube_generator cubes(expr_vector &vars)
Definition z3++.h:3020
friend std::ostream & operator<<(std::ostream &out, solver const &s)
Definition z3++.h:3023
solver(context &c, solver const &src, translate)
Definition z3++.h:2800
expr_vector non_units() const
Definition z3++.h:2880
solver(context &c, simple)
Definition z3++.h:2797
solver(context &c, Z3_solver s)
Definition z3++.h:2798
solver(context &c, char const *logic)
Definition z3++.h:2799
void set(char const *k, bool v)
Definition z3++.h:2813
void add(expr const &e, expr const &p)
Definition z3++.h:2832
void add(expr const &e, char const *p)
Definition z3++.h:2837
check_result consequences(expr_vector &assumptions, expr_vector &vars, expr_vector &conseq)
Definition z3++.h:2871
void set_initial_value(expr const &var, expr const &value)
Definition z3++.h:2893
void set(char const *k, char const *v)
Definition z3++.h:2817
check_result check(unsigned n, expr *const assumptions)
Definition z3++.h:2849
model get_model() const
Definition z3++.h:2870
std::string dimacs(bool include_names=true) const
Definition z3++.h:2927
check_result check()
Definition z3++.h:2848
stats statistics() const
Definition z3++.h:2877
expr_vector units() const
Definition z3++.h:2881
expr_vector trail() const
Definition z3++.h:2882
void add(expr const &e)
Definition z3++.h:2831
void set_initial_value(expr const &var, int i)
Definition z3++.h:2897
solver & operator=(solver const &s)
Definition z3++.h:2805
void set(char const *k, double v)
Definition z3++.h:2815
void pop(unsigned n=1)
Definition z3++.h:2829
void push()
Create a backtracking point.
Definition z3++.h:2828
void set_initial_value(expr const &var, bool b)
Definition z3++.h:2900
~solver() override
Definition z3++.h:2803
std::string to_smt2(char const *status="unknown")
Definition z3++.h:2907
solver(context &c)
Definition z3++.h:2796
param_descrs get_param_descrs()
Definition z3++.h:2929
void set(char const *k, unsigned v)
Definition z3++.h:2814
void add(expr_vector const &v)
Definition z3++.h:2840
expr_vector assertions() const
Definition z3++.h:2879
void from_file(char const *file)
Definition z3++.h:2845
expr_vector trail(array< unsigned > &levels) const
Definition z3++.h:2883
void reset()
Definition z3++.h:2830
std::string reason_unknown() const
Definition z3++.h:2876
void set(params const &p)
Definition z3++.h:2812
expr_vector cube(expr_vector &vars, unsigned cutoff)
Definition z3++.h:2932
cube_generator cubes()
Definition z3++.h:3019
expr_vector unsat_core() const
Definition z3++.h:2878
solver(solver const &s)
Definition z3++.h:2801
void set(char const *k, symbol const &v)
Definition z3++.h:2816
check_result check(expr_vector const &assumptions)
Definition z3++.h:2859
A Z3 sort (aka type). Every expression (i.e., formula or term) in Z3 has a sort.
Definition z3++.h:674
sort(context &c, Z3_sort s)
Definition z3++.h:677
func_decl_vector constructors()
Definition z3++.h:4241
Z3_sort_kind sort_kind() const
Return the internal sort kind.
Definition z3++.h:689
unsigned bv_size() const
Return the size of this Bit-vector sort.
Definition z3++.h:748
bool is_int() const
Return true if this sort is the Integer sort.
Definition z3++.h:701
sort(context &c)
Definition z3++.h:676
bool is_real() const
Return true if this sort is the Real sort.
Definition z3++.h:705
sort(context &c, Z3_ast a)
Definition z3++.h:678
friend std::ostream & operator<<(std::ostream &out, sort const &s)
Definition z3++.h:766
func_decl_vector recognizers()
Definition z3++.h:4250
symbol name() const
Return name of sort.
Definition z3++.h:693
bool is_relation() const
Return true if this sort is a Relation sort.
Definition z3++.h:725
unsigned fpa_ebits() const
Definition z3++.h:750
sort array_range() const
Return the range of this Array sort.
Definition z3++.h:764
bool is_bool() const
Return true if this sort is the Boolean sort.
Definition z3++.h:697
bool is_arith() const
Return true if this sort is the Integer or Real sort.
Definition z3++.h:709
bool is_bv() const
Return true if this sort is a Bit-vector sort.
Definition z3++.h:713
sort array_domain() const
Return the domain of this Array sort.
Definition z3++.h:758
bool is_finite_domain() const
Return true if this sort is a Finite domain sort.
Definition z3++.h:737
bool is_datatype() const
Return true if this sort is a Datatype sort.
Definition z3++.h:721
bool is_re() const
Return true if this sort is a regular expression sort.
Definition z3++.h:733
unsigned id() const
retrieve unique identifier for func_decl.
Definition z3++.h:684
bool is_array() const
Return true if this sort is a Array sort.
Definition z3++.h:717
bool is_seq() const
Return true if this sort is a Sequence sort.
Definition z3++.h:729
unsigned fpa_sbits() const
Definition z3++.h:752
bool is_fpa() const
Return true if this sort is a Floating point sort.
Definition z3++.h:741
stats & operator=(stats const &s)
Definition z3++.h:2723
unsigned size() const
Definition z3++.h:2730
bool is_uint(unsigned i) const
Definition z3++.h:2732
bool is_double(unsigned i) const
Definition z3++.h:2733
~stats() override
Definition z3++.h:2721
stats(stats const &s)
Definition z3++.h:2720
double double_value(unsigned i) const
Definition z3++.h:2735
unsigned uint_value(unsigned i) const
Definition z3++.h:2734
stats(context &c, Z3_stats e)
Definition z3++.h:2719
friend std::ostream & operator<<(std::ostream &out, stats const &s)
Definition z3++.h:2738
std::string key(unsigned i) const
Definition z3++.h:2731
stats(context &c)
Definition z3++.h:2718
Z3_symbol_kind kind() const
Definition z3++.h:502
symbol(context &c, Z3_symbol s)
Definition z3++.h:500
int to_int() const
Definition z3++.h:504
friend std::ostream & operator<<(std::ostream &out, symbol const &s)
Definition z3++.h:508
std::string str() const
Definition z3++.h:503
friend tactic par_or(unsigned n, tactic const *tactics)
Definition z3++.h:3178
friend tactic par_and_then(tactic const &t1, tactic const &t2)
Definition z3++.h:3187
std::string help() const
Definition z3++.h:3137
solver mk_solver() const
Definition z3++.h:3127
tactic(context &c, char const *name)
Definition z3++.h:3115
tactic(context &c, Z3_tactic s)
Definition z3++.h:3116
friend tactic repeat(tactic const &t, unsigned max)
Definition z3++.h:3162
friend tactic with(tactic const &t, params const &p)
Definition z3++.h:3168
apply_result apply(goal const &g) const
Definition z3++.h:3128
friend tactic operator&(tactic const &t1, tactic const &t2)
Definition z3++.h:3148
friend tactic try_for(tactic const &t, unsigned ms)
Definition z3++.h:3173
param_descrs get_param_descrs()
Definition z3++.h:3145
~tactic() override
Definition z3++.h:3118
tactic & operator=(tactic const &s)
Definition z3++.h:3120
apply_result operator()(goal const &g) const
Definition z3++.h:3134
tactic(tactic const &s)
Definition z3++.h:3117
friend tactic operator|(tactic const &t1, tactic const &t2)
Definition z3++.h:3155
void register_decide(decide_eh_t &c)
Definition z3++.h:4543
bool propagate(expr_vector const &fixed, expr_vector const &lhs, expr_vector const &rhs, expr const &conseq)
Definition z3++.h:4631
void register_created(created_eh_t &c)
Definition z3++.h:4527
virtual ~user_propagator_base()
Definition z3++.h:4444
virtual void decide(expr const &, unsigned, bool)
Definition z3++.h:4575
virtual void eq(expr const &, expr const &)
Definition z3++.h:4569
void register_eq(eq_eh_t &f)
Definition z3++.h:4487
void add(expr const &e)
tracks e by a unique identifier that is returned by the call.
Definition z3++.h:4598
virtual void created(expr const &)
Definition z3++.h:4573
virtual void push()=0
void register_final(final_eh_t &f)
register a callback on final-check. During the final check stage, all propagations have been processe...
Definition z3++.h:4511
virtual void pop(unsigned num_scopes)=0
virtual bool on_binding(expr const &, expr const &)
Definition z3++.h:4577
virtual void fixed(expr const &, expr const &)
Definition z3++.h:4567
void conflict(expr_vector const &fixed)
Definition z3++.h:4607
bool propagate(expr_vector const &fixed, expr const &conseq)
Definition z3++.h:4624
user_propagator_base(solver *s)
Definition z3++.h:4437
virtual user_propagator_base * fresh(context &ctx)=0
user_propagators created using fresh() are created during search and their lifetimes are restricted t...
user_propagator_base(context &c)
Definition z3++.h:4435
void conflict(expr_vector const &fixed, expr_vector const &lhs, expr_vector const &rhs)
Definition z3++.h:4614
bool next_split(expr const &e, unsigned idx, Z3_lbool phase)
Definition z3++.h:4579
void register_fixed(fixed_eh_t &f)
register callbacks. Callbacks can only be registered with user_propagators that were created using a ...
Definition z3++.h:4471
Z3_ast Z3_API Z3_mk_exists_const(Z3_context c, unsigned weight, unsigned num_bound, Z3_app const bound[], unsigned num_patterns, Z3_pattern const patterns[], Z3_ast body)
Similar to Z3_mk_forall_const.
void Z3_API Z3_solver_propagate_on_binding(Z3_context c, Z3_solver s, Z3_on_binding_eh on_binding_eh)
register a callback when the solver instantiates a quantifier. If the callback returns false,...
Z3_ast Z3_API Z3_mk_pbeq(Z3_context c, unsigned num_args, Z3_ast const args[], int const coeffs[], int k)
Pseudo-Boolean relations.
Z3_ast_vector Z3_API Z3_optimize_get_assertions(Z3_context c, Z3_optimize o)
Return the set of asserted formulas on the optimization context.
Z3_ast_kind
The different kinds of Z3 AST (abstract syntax trees). That is, terms, formulas and types.
Definition z3_api.h:142
Z3_ast Z3_API Z3_model_get_const_interp(Z3_context c, Z3_model m, Z3_func_decl a)
Return the interpretation (i.e., assignment) of constant a in the model m. Return NULL,...
Z3_sort Z3_API Z3_mk_int_sort(Z3_context c)
Create the integer type.
Z3_simplifier Z3_API Z3_simplifier_and_then(Z3_context c, Z3_simplifier t1, Z3_simplifier t2)
Return a simplifier that applies t1 to a given goal and t2 to every subgoal produced by t1.
Z3_ast Z3_API Z3_mk_fpa_is_infinite(Z3_context c, Z3_ast t)
Predicate indicating whether t is a floating-point number representing +oo or -oo.
Z3_probe Z3_API Z3_probe_lt(Z3_context x, Z3_probe p1, Z3_probe p2)
Return a probe that evaluates to "true" when the value returned by p1 is less than the value returned...
Z3_sort Z3_API Z3_mk_array_sort_n(Z3_context c, unsigned n, Z3_sort const *domain, Z3_sort range)
Create an array type with N arguments.
Z3_ast Z3_API Z3_mk_bvxnor(Z3_context c, Z3_ast t1, Z3_ast t2)
Bitwise xnor.
Z3_string Z3_API Z3_get_error_msg(Z3_context c, Z3_error_code err)
Return a string describing the given error code.
Z3_parameter_kind Z3_API Z3_get_decl_parameter_kind(Z3_context c, Z3_func_decl d, unsigned idx)
Return the parameter type associated with a declaration.
bool Z3_API Z3_is_seq_sort(Z3_context c, Z3_sort s)
Check if s is a sequence sort.
Z3_ast Z3_API Z3_mk_bvnor(Z3_context c, Z3_ast t1, Z3_ast t2)
Bitwise nor.
Z3_ast Z3_API Z3_get_denominator(Z3_context c, Z3_ast a)
Return the denominator (as a numeral AST) of a numeral AST of sort Real.
Z3_probe Z3_API Z3_probe_not(Z3_context x, Z3_probe p)
Return a probe that evaluates to "true" when p does not evaluate to true.
Z3_decl_kind Z3_API Z3_get_decl_kind(Z3_context c, Z3_func_decl d)
Return declaration kind corresponding to declaration.
void Z3_API Z3_solver_assert_and_track(Z3_context c, Z3_solver s, Z3_ast a, Z3_ast p)
Assert a constraint a into the solver, and track it (in the unsat) core using the Boolean constant p.
Z3_ast Z3_API Z3_func_interp_get_else(Z3_context c, Z3_func_interp f)
Return the 'else' value of the given function interpretation.
Z3_ast Z3_API Z3_mk_char_to_bv(Z3_context c, Z3_ast ch)
Create a bit-vector (code point) from character.
Z3_ast Z3_API Z3_mk_bvsge(Z3_context c, Z3_ast t1, Z3_ast t2)
Two's complement signed greater than or equal to.
void Z3_API Z3_fixedpoint_inc_ref(Z3_context c, Z3_fixedpoint d)
Increment the reference counter of the given fixedpoint context.
Z3_tactic Z3_API Z3_tactic_using_params(Z3_context c, Z3_tactic t, Z3_params p)
Return a tactic that applies t using the given set of parameters.
Z3_ast Z3_API Z3_mk_const_array(Z3_context c, Z3_sort domain, Z3_ast v)
Create the constant array.
void Z3_API Z3_simplifier_inc_ref(Z3_context c, Z3_simplifier t)
Increment the reference counter of the given simplifier.
void Z3_API Z3_fixedpoint_add_rule(Z3_context c, Z3_fixedpoint d, Z3_ast rule, Z3_symbol name)
Add a universal Horn clause as a named rule. The horn_rule should be of the form:
Z3_probe Z3_API Z3_probe_eq(Z3_context x, Z3_probe p1, Z3_probe p2)
Return a probe that evaluates to "true" when the value returned by p1 is equal to the value returned ...
Z3_ast_vector Z3_API Z3_optimize_get_unsat_core(Z3_context c, Z3_optimize o)
Retrieve the unsat core for the last Z3_optimize_check The unsat core is a subset of the assumptions ...
Z3_sort Z3_API Z3_mk_char_sort(Z3_context c)
Create a sort for unicode characters.
Z3_ast Z3_API Z3_mk_unsigned_int(Z3_context c, unsigned v, Z3_sort ty)
Create a numeral of a int, bit-vector, or finite-domain sort.
Z3_ast Z3_API Z3_mk_re_option(Z3_context c, Z3_ast re)
Create the regular language [re].
Z3_ast Z3_API Z3_mk_bvsle(Z3_context c, Z3_ast t1, Z3_ast t2)
Two's complement signed less than or equal to.
void Z3_API Z3_query_constructor(Z3_context c, Z3_constructor constr, unsigned num_fields, Z3_func_decl *constructor, Z3_func_decl *tester, Z3_func_decl accessors[])
Query constructor for declared functions.
Z3_func_decl Z3_API Z3_get_app_decl(Z3_context c, Z3_app a)
Return the declaration of a constant or function application.
void Z3_API Z3_optimize_set_initial_value(Z3_context c, Z3_optimize o, Z3_ast v, Z3_ast val)
provide an initialization hint to the solver. The initialization hint is used to calibrate an initial...
void Z3_API Z3_del_context(Z3_context c)
Delete the given logical context.
Z3_ast Z3_API Z3_substitute(Z3_context c, Z3_ast a, unsigned num_exprs, Z3_ast const from[], Z3_ast const to[])
Substitute every occurrence of from[i] in a with to[i], for i smaller than num_exprs....
Z3_ast Z3_API Z3_mk_mul(Z3_context c, unsigned num_args, Z3_ast const args[])
Create an AST node representing args[0] * ... * args[num_args-1].
Z3_func_decl Z3_API Z3_get_decl_func_decl_parameter(Z3_context c, Z3_func_decl d, unsigned idx)
Return the expression value associated with an expression parameter.
Z3_goal_prec
Z3 custom error handler (See Z3_set_error_handler).
Definition z3_api.h:1388
Z3_ast Z3_API Z3_mk_fpa_to_fp_bv(Z3_context c, Z3_ast bv, Z3_sort s)
Conversion of a single IEEE 754-2008 bit-vector into a floating-point number.
Z3_ast Z3_API Z3_mk_seq_replace(Z3_context c, Z3_ast s, Z3_ast src, Z3_ast dst)
Replace the first occurrence of src with dst in s.
Z3_string Z3_API Z3_param_descrs_to_string(Z3_context c, Z3_param_descrs p)
Convert a parameter description set into a string. This function is mainly used for printing the cont...
Z3_ast Z3_API Z3_mk_zero_ext(Z3_context c, unsigned i, Z3_ast t1)
Extend the given bit-vector with zeros to the (unsigned) equivalent bit-vector of size m+i,...
void Z3_API Z3_solver_set_params(Z3_context c, Z3_solver s, Z3_params p)
Set the given solver using the given parameters.
Z3_ast Z3_API Z3_mk_set_intersect(Z3_context c, unsigned num_args, Z3_ast const args[])
Take the intersection of a list of sets.
Z3_params Z3_API Z3_mk_params(Z3_context c)
Create a Z3 (empty) parameter set. Starting at Z3 4.0, parameter sets are used to configure many comp...
Z3_ast Z3_API Z3_mk_fpa_is_subnormal(Z3_context c, Z3_ast t)
Predicate indicating whether t is a subnormal floating-point number.
unsigned Z3_API Z3_get_decl_num_parameters(Z3_context c, Z3_func_decl d)
Return the number of parameters associated with a declaration.
Z3_ast Z3_API Z3_mk_set_subset(Z3_context c, Z3_ast arg1, Z3_ast arg2)
Check for subsetness of sets.
Z3_ast Z3_API Z3_simplify(Z3_context c, Z3_ast a)
Interface to simplifier.
Z3_ast Z3_API Z3_mk_int(Z3_context c, int v, Z3_sort ty)
Create a numeral of an int, bit-vector, or finite-domain sort.
Z3_ast Z3_API Z3_mk_fpa_to_ieee_bv(Z3_context c, Z3_ast t)
Conversion of a floating-point term into a bit-vector term in IEEE 754-2008 format.
Z3_lbool Z3_API Z3_solver_get_consequences(Z3_context c, Z3_solver s, Z3_ast_vector assumptions, Z3_ast_vector variables, Z3_ast_vector consequences)
retrieve consequences from solver that determine values of the supplied function symbols.
Z3_ast_vector Z3_API Z3_fixedpoint_from_file(Z3_context c, Z3_fixedpoint f, Z3_string s)
Parse an SMT-LIB2 file with fixedpoint rules. Add the rules to the current fixedpoint context....
void Z3_API Z3_get_string_contents(Z3_context c, Z3_ast s, unsigned length, unsigned contents[])
Retrieve the unescaped string constant stored in s.
Z3_ast Z3_API Z3_mk_bvule(Z3_context c, Z3_ast t1, Z3_ast t2)
Unsigned less than or equal to.
Z3_ast Z3_API Z3_mk_full_set(Z3_context c, Z3_sort domain)
Create the full set.
Z3_param_kind Z3_API Z3_param_descrs_get_kind(Z3_context c, Z3_param_descrs p, Z3_symbol n)
Return the kind associated with the given parameter name n.
Z3_ast Z3_API Z3_mk_fpa_to_fp_signed(Z3_context c, Z3_ast rm, Z3_ast t, Z3_sort s)
Conversion of a 2's complement signed bit-vector term into a term of FloatingPoint sort.
bool Z3_API Z3_get_numeral_int64(Z3_context c, Z3_ast v, int64_t *i)
Similar to Z3_get_numeral_string, but only succeeds if the value can fit in a machine int64_t int....
void Z3_API Z3_add_rec_def(Z3_context c, Z3_func_decl f, unsigned n, Z3_ast args[], Z3_ast body)
Define the body of a recursive function.
Z3_param_descrs Z3_API Z3_solver_get_param_descrs(Z3_context c, Z3_solver s)
Return the parameter description set for the given solver object.
Z3_ast Z3_API Z3_mk_fpa_to_sbv(Z3_context c, Z3_ast rm, Z3_ast t, unsigned sz)
Conversion of a floating-point term into a signed bit-vector.
Z3_ast Z3_API Z3_mk_true(Z3_context c)
Create an AST node representing true.
Z3_ast Z3_API Z3_optimize_get_lower(Z3_context c, Z3_optimize o, unsigned idx)
Retrieve lower bound value or approximation for the i'th optimization objective.
Z3_ast Z3_API Z3_mk_set_union(Z3_context c, unsigned num_args, Z3_ast const args[])
Take the union of a list of sets.
Z3_model Z3_API Z3_optimize_get_model(Z3_context c, Z3_optimize o)
Retrieve the model for the last Z3_optimize_check.
void Z3_API Z3_apply_result_inc_ref(Z3_context c, Z3_apply_result r)
Increment the reference counter of the given Z3_apply_result object.
Z3_func_interp Z3_API Z3_add_func_interp(Z3_context c, Z3_model m, Z3_func_decl f, Z3_ast default_value)
Create a fresh func_interp object, add it to a model for a specified function. It has reference count...
Z3_ast Z3_API Z3_mk_bvsdiv_no_overflow(Z3_context c, Z3_ast t1, Z3_ast t2)
Create a predicate that checks that the bit-wise signed division of t1 and t2 does not overflow.
Z3_decl_kind
The different kinds of interpreted function kinds.
Definition z3_api.h:962
unsigned Z3_API Z3_get_arity(Z3_context c, Z3_func_decl d)
Alias for Z3_get_domain_size.
void Z3_API Z3_ast_vector_set(Z3_context c, Z3_ast_vector v, unsigned i, Z3_ast a)
Update position i of the AST vector v with the AST a.
Z3_ast Z3_API Z3_mk_bvxor(Z3_context c, Z3_ast t1, Z3_ast t2)
Bitwise exclusive-or.
Z3_string Z3_API Z3_stats_to_string(Z3_context c, Z3_stats s)
Convert a statistics into a string.
Z3_param_descrs Z3_API Z3_fixedpoint_get_param_descrs(Z3_context c, Z3_fixedpoint f)
Return the parameter description set for the given fixedpoint object.
Z3_sort Z3_API Z3_mk_real_sort(Z3_context c)
Create the real type.
void Z3_API Z3_optimize_from_file(Z3_context c, Z3_optimize o, Z3_string s)
Parse an SMT-LIB2 file with assertions, soft constraints and optimization objectives....
Z3_ast Z3_API Z3_mk_le(Z3_context c, Z3_ast t1, Z3_ast t2)
Create less than or equal to.
Z3_string Z3_API Z3_simplifier_get_help(Z3_context c, Z3_simplifier t)
Return a string containing a description of parameters accepted by the given simplifier.
bool Z3_API Z3_goal_inconsistent(Z3_context c, Z3_goal g)
Return true if the given goal contains the formula false.
Z3_ast Z3_API Z3_mk_lambda_const(Z3_context c, unsigned num_bound, Z3_app const bound[], Z3_ast body)
Create a lambda expression using a list of constants that form the set of bound variables.
Z3_tactic Z3_API Z3_tactic_par_and_then(Z3_context c, Z3_tactic t1, Z3_tactic t2)
Return a tactic that applies t1 to a given goal and then t2 to every subgoal produced by t1....
void Z3_API Z3_fixedpoint_update_rule(Z3_context c, Z3_fixedpoint d, Z3_ast a, Z3_symbol name)
Update a named rule. A rule with the same name must have been previously created.
void Z3_API Z3_solver_dec_ref(Z3_context c, Z3_solver s)
Decrement the reference counter of the given solver.
Z3_ast Z3_API Z3_mk_bvslt(Z3_context c, Z3_ast t1, Z3_ast t2)
Two's complement signed less than.
Z3_func_decl Z3_API Z3_model_get_func_decl(Z3_context c, Z3_model m, unsigned i)
Return the declaration of the i-th function in the given model.
Z3_ast Z3_API Z3_mk_seq_length(Z3_context c, Z3_ast s)
Return the length of the sequence s.
Z3_ast Z3_API Z3_mk_numeral(Z3_context c, Z3_string numeral, Z3_sort ty)
Create a numeral of a given sort.
unsigned Z3_API Z3_func_entry_get_num_args(Z3_context c, Z3_func_entry e)
Return the number of arguments in a Z3_func_entry object.
Z3_ast Z3_API Z3_simplify_ex(Z3_context c, Z3_ast a, Z3_params p)
Interface to simplifier.
Z3_symbol Z3_API Z3_get_decl_symbol_parameter(Z3_context c, Z3_func_decl d, unsigned idx)
Return the double value associated with an double parameter.
void Z3_API Z3_solver_from_string(Z3_context c, Z3_solver s, Z3_string str)
load solver assertions from a string.
Z3_ast Z3_API Z3_get_numerator(Z3_context c, Z3_ast a)
Return the numerator (as a numeral AST) of a numeral AST of sort Real.
Z3_ast Z3_API Z3_mk_unary_minus(Z3_context c, Z3_ast arg)
Create an AST node representing - arg.
Z3_ast Z3_API Z3_mk_fpa_rna(Z3_context c)
Create a numeral of RoundingMode sort which represents the NearestTiesToAway rounding mode.
Z3_probe Z3_API Z3_probe_ge(Z3_context x, Z3_probe p1, Z3_probe p2)
Return a probe that evaluates to "true" when the value returned by p1 is greater than or equal to the...
Z3_ast Z3_API Z3_mk_and(Z3_context c, unsigned num_args, Z3_ast const args[])
Create an AST node representing args[0] and ... and args[num_args-1].
void Z3_API Z3_simplifier_dec_ref(Z3_context c, Z3_simplifier g)
Decrement the reference counter of the given simplifier.
void Z3_API Z3_interrupt(Z3_context c)
Interrupt the execution of a Z3 procedure. This procedure can be used to interrupt: solvers,...
Z3_ast Z3_API Z3_mk_str_to_int(Z3_context c, Z3_ast s)
Convert string to integer.
Z3_ast Z3_API Z3_mk_fpa_sub(Z3_context c, Z3_ast rm, Z3_ast t1, Z3_ast t2)
Floating-point subtraction.
void Z3_API Z3_goal_assert(Z3_context c, Z3_goal g, Z3_ast a)
Add a new formula a to the given goal. The formula is split according to the following procedure that...
Z3_symbol Z3_API Z3_param_descrs_get_name(Z3_context c, Z3_param_descrs p, unsigned i)
Return the name of the parameter at given index i.
Z3_sort Z3_API Z3_mk_polymorphic_datatype(Z3_context c, Z3_symbol name, unsigned num_parameters, Z3_sort parameters[], unsigned num_constructors, Z3_constructor constructors[])
Create a parametric datatype with explicit type parameters.
Z3_ast Z3_API Z3_func_entry_get_value(Z3_context c, Z3_func_entry e)
Return the value of this point.
bool Z3_API Z3_is_quantifier_exists(Z3_context c, Z3_ast a)
Determine if ast is an existential quantifier.
Z3_ast_vector Z3_API Z3_fixedpoint_from_string(Z3_context c, Z3_fixedpoint f, Z3_string s)
Parse an SMT-LIB2 string with fixedpoint rules. Add the rules to the current fixedpoint context....
Z3_sort Z3_API Z3_mk_uninterpreted_sort(Z3_context c, Z3_symbol s)
Create a free (uninterpreted) type using the given name (symbol).
void Z3_API Z3_optimize_pop(Z3_context c, Z3_optimize d)
Backtrack one level.
Z3_ast Z3_API Z3_mk_fpa_is_normal(Z3_context c, Z3_ast t)
Predicate indicating whether t is a normal floating-point number.
Z3_ast Z3_API Z3_mk_false(Z3_context c)
Create an AST node representing false.
Z3_sort Z3_API Z3_mk_datatype(Z3_context c, Z3_symbol name, unsigned num_constructors, Z3_constructor constructors[])
Create datatype, such as lists, trees, records, enumerations or unions of records....
Z3_lbool Z3_API Z3_solver_check(Z3_context c, Z3_solver s)
Check whether the assertions in a given solver are consistent or not.
Z3_ast Z3_API Z3_mk_fpa_to_ubv(Z3_context c, Z3_ast rm, Z3_ast t, unsigned sz)
Conversion of a floating-point term into an unsigned bit-vector.
Z3_ast Z3_API Z3_mk_rotate_right(Z3_context c, unsigned i, Z3_ast t1)
Rotate bits of t1 to the right i times.
Z3_ast Z3_API Z3_mk_bvmul(Z3_context c, Z3_ast t1, Z3_ast t2)
Standard two's complement multiplication.
Z3_ast Z3_API Z3_mk_seq_at(Z3_context c, Z3_ast s, Z3_ast index)
Retrieve from s the unit sequence positioned at position index. The sequence is empty if the index is...
Z3_model Z3_API Z3_goal_convert_model(Z3_context c, Z3_goal g, Z3_model m)
Convert a model of the formulas of a goal to a model of an original goal. The model may be null,...
void Z3_API Z3_del_constructor(Z3_context c, Z3_constructor constr)
Reclaim memory allocated to constructor.
Z3_ast Z3_API Z3_mk_bvsgt(Z3_context c, Z3_ast t1, Z3_ast t2)
Two's complement signed greater than.
Z3_string Z3_API Z3_ast_to_string(Z3_context c, Z3_ast a)
Convert the given AST node into a string.
Z3_ast Z3_API Z3_mk_re_complement(Z3_context c, Z3_ast re)
Create the complement of the regular language re.
Z3_ast_vector Z3_API Z3_fixedpoint_get_assertions(Z3_context c, Z3_fixedpoint f)
Retrieve set of background assertions from fixedpoint context.
Z3_context Z3_API Z3_mk_context_rc(Z3_config c)
Create a context using the given configuration. This function is similar to Z3_mk_context....
unsigned Z3_API Z3_fpa_get_ebits(Z3_context c, Z3_sort s)
Retrieves the number of bits reserved for the exponent in a FloatingPoint sort.
Z3_ast_vector Z3_API Z3_solver_get_assertions(Z3_context c, Z3_solver s)
Return the set of asserted formulas on the solver.
Z3_solver Z3_API Z3_mk_solver_from_tactic(Z3_context c, Z3_tactic t)
Create a new solver that is implemented using the given tactic. The solver supports the commands Z3_s...
Z3_ast Z3_API Z3_mk_set_complement(Z3_context c, Z3_ast arg)
Take the complement of a set.
bool Z3_API Z3_stats_is_uint(Z3_context c, Z3_stats s, unsigned idx)
Return true if the given statistical data is a unsigned integer.
bool Z3_API Z3_stats_is_double(Z3_context c, Z3_stats s, unsigned idx)
Return true if the given statistical data is a double.
Z3_ast Z3_API Z3_mk_fpa_rtn(Z3_context c)
Create a numeral of RoundingMode sort which represents the TowardNegative rounding mode.
unsigned Z3_API Z3_model_get_num_consts(Z3_context c, Z3_model m)
Return the number of constants assigned by the given model.
Z3_ast Z3_API Z3_get_algebraic_number_lower(Z3_context c, Z3_ast a, unsigned precision)
Return a lower bound for the given real algebraic number. The interval isolating the number is smalle...
Z3_ast Z3_API Z3_mk_extract(Z3_context c, unsigned high, unsigned low, Z3_ast t1)
Extract the bits high down to low from a bit-vector of size m to yield a new bit-vector of size n,...
Z3_ast Z3_API Z3_mk_mod(Z3_context c, Z3_ast arg1, Z3_ast arg2)
Create an AST node representing arg1 mod arg2.
Z3_ast Z3_API Z3_mk_bvredand(Z3_context c, Z3_ast t1)
Take conjunction of bits in vector, return vector of length 1.
Z3_ast Z3_API Z3_mk_set_add(Z3_context c, Z3_ast set, Z3_ast elem)
Add an element to a set.
Z3_ast Z3_API Z3_mk_ge(Z3_context c, Z3_ast t1, Z3_ast t2)
Create greater than or equal to.
Z3_ast Z3_API Z3_mk_bvadd_no_underflow(Z3_context c, Z3_ast t1, Z3_ast t2)
Create a predicate that checks that the bit-wise signed addition of t1 and t2 does not underflow.
Z3_ast Z3_API Z3_mk_fpa_rtp(Z3_context c)
Create a numeral of RoundingMode sort which represents the TowardPositive rounding mode.
void Z3_API Z3_update_param_value(Z3_context c, Z3_string param_id, Z3_string param_value)
Set a value of a context parameter.
Z3_ast Z3_API Z3_mk_bvadd_no_overflow(Z3_context c, Z3_ast t1, Z3_ast t2, bool is_signed)
Create a predicate that checks that the bit-wise addition of t1 and t2 does not overflow.
void Z3_API Z3_set_ast_print_mode(Z3_context c, Z3_ast_print_mode mode)
Select mode for the format used for pretty-printing AST nodes.
bool Z3_API Z3_solver_propagate_consequence(Z3_context c, Z3_solver_callback cb, unsigned num_fixed, Z3_ast const *fixed, unsigned num_eqs, Z3_ast const *eq_lhs, Z3_ast const *eq_rhs, Z3_ast conseq)
propagate a consequence based on fixed values and equalities. A client may invoke it during the pro...
unsigned Z3_API Z3_fpa_get_sbits(Z3_context c, Z3_sort s)
Retrieves the number of bits reserved for the significand in a FloatingPoint sort.
Z3_ast Z3_API Z3_mk_forall_const(Z3_context c, unsigned weight, unsigned num_bound, Z3_app const bound[], unsigned num_patterns, Z3_pattern const patterns[], Z3_ast body)
Create a universal quantifier using a list of constants that will form the set of bound variables.
Z3_param_kind
The different kinds of parameters that can be associated with parameter sets. (see Z3_mk_params).
Definition z3_api.h:1305
const char * Z3_string
Z3 string type. It is just an alias for const char *.
Definition z3_api.h:50
Z3_param_descrs Z3_API Z3_tactic_get_param_descrs(Z3_context c, Z3_tactic t)
Return the parameter description set for the given tactic object.
Z3_sort Z3_API Z3_mk_tuple_sort(Z3_context c, Z3_symbol mk_tuple_name, unsigned num_fields, Z3_symbol const field_names[], Z3_sort const field_sorts[], Z3_func_decl *mk_tuple_decl, Z3_func_decl proj_decl[])
Create a tuple type.
Z3_ast_vector Z3_API Z3_ast_vector_translate(Z3_context s, Z3_ast_vector v, Z3_context t)
Translate the AST vector v from context s into an AST vector in context t.
void Z3_API Z3_func_entry_inc_ref(Z3_context c, Z3_func_entry e)
Increment the reference counter of the given Z3_func_entry object.
Z3_ast Z3_API Z3_mk_bvsub_no_overflow(Z3_context c, Z3_ast t1, Z3_ast t2)
Create a predicate that checks that the bit-wise signed subtraction of t1 and t2 does not overflow.
Z3_sort_kind
The different kinds of Z3 types (See Z3_get_sort_kind).
Definition z3_api.h:110
void Z3_API Z3_solver_push(Z3_context c, Z3_solver s)
Create a backtracking point.
Z3_ast Z3_API Z3_mk_bvsub_no_underflow(Z3_context c, Z3_ast t1, Z3_ast t2, bool is_signed)
Create a predicate that checks that the bit-wise subtraction of t1 and t2 does not underflow.
Z3_ast Z3_API Z3_mk_fpa_max(Z3_context c, Z3_ast t1, Z3_ast t2)
Maximum of floating-point numbers.
void Z3_API Z3_optimize_assert_and_track(Z3_context c, Z3_optimize o, Z3_ast a, Z3_ast t)
Assert tracked hard constraint to the optimization context.
unsigned Z3_API Z3_optimize_assert_soft(Z3_context c, Z3_optimize o, Z3_ast a, Z3_string weight, Z3_symbol id)
Assert soft constraint to the optimization context.
Z3_ast Z3_API Z3_mk_bvudiv(Z3_context c, Z3_ast t1, Z3_ast t2)
Unsigned division.
Z3_string Z3_API Z3_ast_vector_to_string(Z3_context c, Z3_ast_vector v)
Convert AST vector into a string.
Z3_ast_vector Z3_API Z3_solver_get_trail(Z3_context c, Z3_solver s)
Return the trail modulo model conversion, in order of decision level The decision level can be retrie...
Z3_ast Z3_API Z3_mk_bvshl(Z3_context c, Z3_ast t1, Z3_ast t2)
Shift left.
Z3_func_decl Z3_API Z3_mk_tree_order(Z3_context c, Z3_sort a, unsigned id)
create a tree ordering relation over signature a identified using index id.
Z3_ast Z3_API Z3_mk_bvsrem(Z3_context c, Z3_ast t1, Z3_ast t2)
Two's complement signed remainder (sign follows dividend).
Z3_func_decl Z3_API Z3_mk_func_decl(Z3_context c, Z3_symbol s, unsigned domain_size, Z3_sort const domain[], Z3_sort range)
Declare a constant or function.
unsigned Z3_API Z3_goal_num_exprs(Z3_context c, Z3_goal g)
Return the number of formulas, subformulas and terms in the given goal.
Z3_solver Z3_API Z3_mk_solver_for_logic(Z3_context c, Z3_symbol logic)
Create a new solver customized for the given logic. It behaves like Z3_mk_solver if the logic is unkn...
Z3_ast Z3_API Z3_mk_is_int(Z3_context c, Z3_ast t1)
Check if a real number is an integer.
void Z3_API Z3_params_set_bool(Z3_context c, Z3_params p, Z3_symbol k, bool v)
Add a Boolean parameter k with value v to the parameter set p.
unsigned Z3_API Z3_apply_result_get_num_subgoals(Z3_context c, Z3_apply_result r)
Return the number of subgoals in the Z3_apply_result object returned by Z3_tactic_apply.
Z3_ast Z3_API Z3_mk_ite(Z3_context c, Z3_ast t1, Z3_ast t2, Z3_ast t3)
Create an AST node representing an if-then-else: ite(t1, t2, t3).
Z3_ast Z3_API Z3_mk_select(Z3_context c, Z3_ast a, Z3_ast i)
Array read. The argument a is the array and i is the index of the array that gets read.
Z3_ast Z3_API Z3_mk_sign_ext(Z3_context c, unsigned i, Z3_ast t1)
Sign-extend of the given bit-vector to the (signed) equivalent bit-vector of size m+i,...
Z3_ast Z3_API Z3_mk_seq_unit(Z3_context c, Z3_ast a)
Create a unit sequence of a.
Z3_ast Z3_API Z3_mk_re_intersect(Z3_context c, unsigned n, Z3_ast const args[])
Create the intersection of the regular languages.
Z3_ast_vector Z3_API Z3_solver_cube(Z3_context c, Z3_solver s, Z3_ast_vector vars, unsigned backtrack_level)
extract a next cube for a solver. The last cube is the constant true or false. The number of (non-con...
Z3_ast Z3_API Z3_mk_u32string(Z3_context c, unsigned len, unsigned const chars[])
Create a string constant out of the string that is passed in It takes the length of the string as wel...
void Z3_API Z3_fixedpoint_add_fact(Z3_context c, Z3_fixedpoint d, Z3_func_decl r, unsigned num_args, unsigned args[])
Add a Database fact.
unsigned Z3_API Z3_goal_size(Z3_context c, Z3_goal g)
Return the number of formulas in the given goal.
Z3_func_decl Z3_API Z3_solver_propagate_declare(Z3_context c, Z3_symbol name, unsigned n, Z3_sort *domain, Z3_sort range)
void Z3_API Z3_stats_inc_ref(Z3_context c, Z3_stats s)
Increment the reference counter of the given statistics object.
Z3_ast Z3_API Z3_mk_select_n(Z3_context c, Z3_ast a, unsigned n, Z3_ast const *idxs)
n-ary Array read. The argument a is the array and idxs are the indices of the array that gets read.
Z3_ast_vector Z3_API Z3_algebraic_get_poly(Z3_context c, Z3_ast a)
Return the coefficients of the defining polynomial.
Z3_ast Z3_API Z3_mk_div(Z3_context c, Z3_ast arg1, Z3_ast arg2)
Create an AST node representing arg1 div arg2.
Z3_ast Z3_API Z3_mk_pbge(Z3_context c, unsigned num_args, Z3_ast const args[], int const coeffs[], int k)
Pseudo-Boolean relations.
Z3_sort Z3_API Z3_mk_re_sort(Z3_context c, Z3_sort seq)
Create a regular expression sort out of a sequence sort.
Z3_ast Z3_API Z3_mk_pble(Z3_context c, unsigned num_args, Z3_ast const args[], int const coeffs[], int k)
Pseudo-Boolean relations.
void Z3_API Z3_optimize_inc_ref(Z3_context c, Z3_optimize d)
Increment the reference counter of the given optimize context.
void Z3_API Z3_model_dec_ref(Z3_context c, Z3_model m)
Decrement the reference counter of the given model.
Z3_sort Z3_API Z3_mk_datatype_sort(Z3_context c, Z3_symbol name, unsigned num_params, Z3_sort const params[])
create a forward reference to a recursive datatype being declared. The forward reference can be used ...
Z3_ast Z3_API Z3_mk_fpa_inf(Z3_context c, Z3_sort s, bool negative)
Create a floating-point infinity of sort s.
void Z3_API Z3_func_interp_inc_ref(Z3_context c, Z3_func_interp f)
Increment the reference counter of the given Z3_func_interp object.
Z3_func_decl Z3_API Z3_mk_piecewise_linear_order(Z3_context c, Z3_sort a, unsigned id)
create a piecewise linear ordering relation over signature a and index id.
void Z3_API Z3_params_set_double(Z3_context c, Z3_params p, Z3_symbol k, double v)
Add a double parameter k with value v to the parameter set p.
Z3_string Z3_API Z3_param_descrs_get_documentation(Z3_context c, Z3_param_descrs p, Z3_symbol s)
Retrieve documentation string corresponding to parameter name s.
Z3_solver Z3_API Z3_mk_solver(Z3_context c)
Create a new solver. This solver is a "combined solver" (see combined_solver module) that internally ...
Z3_model Z3_API Z3_solver_get_model(Z3_context c, Z3_solver s)
Retrieve the model for the last Z3_solver_check or Z3_solver_check_assumptions.
int Z3_API Z3_get_symbol_int(Z3_context c, Z3_symbol s)
Return the symbol int value.
void Z3_API Z3_goal_inc_ref(Z3_context c, Z3_goal g)
Increment the reference counter of the given goal.
Z3_tactic Z3_API Z3_tactic_par_or(Z3_context c, unsigned num, Z3_tactic const ts[])
Return a tactic that applies the given tactics in parallel.
Z3_ast Z3_API Z3_mk_implies(Z3_context c, Z3_ast t1, Z3_ast t2)
Create an AST node representing t1 implies t2.
Z3_ast Z3_API Z3_mk_fpa_nan(Z3_context c, Z3_sort s)
Create a floating-point NaN of sort s.
unsigned Z3_API Z3_get_datatype_sort_num_constructors(Z3_context c, Z3_sort t)
Return number of constructors for datatype.
Z3_ast Z3_API Z3_optimize_get_upper(Z3_context c, Z3_optimize o, unsigned idx)
Retrieve upper bound value or approximation for the i'th optimization objective.
void Z3_API Z3_params_set_uint(Z3_context c, Z3_params p, Z3_symbol k, unsigned v)
Add a unsigned parameter k with value v to the parameter set p.
Z3_lbool Z3_API Z3_solver_check_assumptions(Z3_context c, Z3_solver s, unsigned num_assumptions, Z3_ast const assumptions[])
Check whether the assertions in the given solver and optional assumptions are consistent or not.
Z3_ast Z3_API Z3_mk_fpa_gt(Z3_context c, Z3_ast t1, Z3_ast t2)
Floating-point greater than.
Z3_ast Z3_API Z3_mk_bvashr(Z3_context c, Z3_ast t1, Z3_ast t2)
Arithmetic shift right.
Z3_simplifier Z3_API Z3_simplifier_using_params(Z3_context c, Z3_simplifier t, Z3_params p)
Return a simplifier that applies t using the given set of parameters.
Z3_ast Z3_API Z3_mk_bv2int(Z3_context c, Z3_ast t1, bool is_signed)
Create an integer from the bit-vector argument t1. If is_signed is false, then the bit-vector t1 is t...
Z3_ast Z3_API Z3_mk_sbv_to_str(Z3_context c, Z3_ast s)
Signed bit-vector to string conversion.
Z3_ast Z3_API Z3_mk_fpa_is_zero(Z3_context c, Z3_ast t)
Predicate indicating whether t is a floating-point number with zero value, i.e., +zero or -zero.
Z3_ast Z3_API Z3_mk_set_del(Z3_context c, Z3_ast set, Z3_ast elem)
Remove an element to a set.
Z3_ast Z3_API Z3_mk_bvmul_no_overflow(Z3_context c, Z3_ast t1, Z3_ast t2, bool is_signed)
Create a predicate that checks that the bit-wise multiplication of t1 and t2 does not overflow.
Z3_ast Z3_API Z3_mk_re_union(Z3_context c, unsigned n, Z3_ast const args[])
Create the union of the regular languages.
Z3_param_descrs Z3_API Z3_simplifier_get_param_descrs(Z3_context c, Z3_simplifier t)
Return the parameter description set for the given simplifier object.
void Z3_API Z3_optimize_set_params(Z3_context c, Z3_optimize o, Z3_params p)
Set parameters on optimization context.
Z3_ast Z3_API Z3_mk_bvor(Z3_context c, Z3_ast t1, Z3_ast t2)
Bitwise or.
int Z3_API Z3_get_decl_int_parameter(Z3_context c, Z3_func_decl d, unsigned idx)
Return the integer value associated with an integer parameter.
Z3_func_decl Z3_API Z3_get_datatype_sort_constructor(Z3_context c, Z3_sort t, unsigned idx)
Return idx'th constructor.
void Z3_API Z3_ast_vector_resize(Z3_context c, Z3_ast_vector v, unsigned n)
Resize the AST vector v.
Z3_lbool
Lifted Boolean type: false, undefined, true.
Definition z3_api.h:58
Z3_ast Z3_API Z3_mk_seq_empty(Z3_context c, Z3_sort seq)
Create an empty sequence of the sequence sort seq.
Z3_probe Z3_API Z3_mk_probe(Z3_context c, Z3_string name)
Return a probe associated with the given name. The complete list of probes may be obtained using the ...
Z3_tactic Z3_API Z3_tactic_when(Z3_context c, Z3_probe p, Z3_tactic t)
Return a tactic that applies t to a given goal is the probe p evaluates to true. If p evaluates to fa...
Z3_ast Z3_API Z3_mk_seq_suffix(Z3_context c, Z3_ast suffix, Z3_ast s)
Check if suffix is a suffix of s.
Z3_symbol_kind Z3_API Z3_get_symbol_kind(Z3_context c, Z3_symbol s)
Return Z3_INT_SYMBOL if the symbol was constructed using Z3_mk_int_symbol, and Z3_STRING_SYMBOL if th...
void Z3_API Z3_solver_set_initial_value(Z3_context c, Z3_solver s, Z3_ast v, Z3_ast val)
provide an initialization hint to the solver. The initialization hint is used to calibrate an initial...
bool Z3_API Z3_is_lambda(Z3_context c, Z3_ast a)
Determine if ast is a lambda expression.
Z3_solver Z3_API Z3_solver_translate(Z3_context source, Z3_solver s, Z3_context target)
Copy a solver s from the context source to the context target.
void Z3_API Z3_optimize_push(Z3_context c, Z3_optimize d)
Create a backtracking point.
unsigned Z3_API Z3_stats_get_uint_value(Z3_context c, Z3_stats s, unsigned idx)
Return the unsigned value of the given statistical data.
void Z3_API Z3_probe_inc_ref(Z3_context c, Z3_probe p)
Increment the reference counter of the given probe.
Z3_sort Z3_API Z3_get_array_sort_domain(Z3_context c, Z3_sort t)
Return the domain of the given array sort. In the case of a multi-dimensional array,...
Z3_ast Z3_API Z3_mk_fpa_eq(Z3_context c, Z3_ast t1, Z3_ast t2)
Floating-point equality.
void Z3_API Z3_solver_propagate_register_cb(Z3_context c, Z3_solver_callback cb, Z3_ast e)
register an expression to propagate on with the solver. Only expressions of type Bool and type Bit-Ve...
Z3_ast Z3_API Z3_mk_bvmul_no_underflow(Z3_context c, Z3_ast t1, Z3_ast t2)
Create a predicate that checks that the bit-wise signed multiplication of t1 and t2 does not underflo...
bool Z3_API Z3_get_numeral_uint64(Z3_context c, Z3_ast v, uint64_t *u)
Similar to Z3_get_numeral_string, but only succeeds if the value can fit in a machine uint64_t int....
void Z3_API Z3_add_const_interp(Z3_context c, Z3_model m, Z3_func_decl f, Z3_ast a)
Add a constant interpretation.
Z3_string Z3_API Z3_sort_to_string(Z3_context c, Z3_sort s)
Z3_ast Z3_API Z3_mk_bvadd(Z3_context c, Z3_ast t1, Z3_ast t2)
Standard two's complement addition.
unsigned Z3_API Z3_algebraic_get_i(Z3_context c, Z3_ast a)
Return which root of the polynomial the algebraic number represents.
void Z3_API Z3_params_dec_ref(Z3_context c, Z3_params p)
Decrement the reference counter of the given parameter set.
void Z3_API Z3_fixedpoint_dec_ref(Z3_context c, Z3_fixedpoint d)
Decrement the reference counter of the given fixedpoint context.
Z3_ast Z3_API Z3_get_app_arg(Z3_context c, Z3_app a, unsigned i)
Return the i-th argument of the given application.
Z3_string Z3_API Z3_model_to_string(Z3_context c, Z3_model m)
Convert the given model into a string.
unsigned Z3_API Z3_get_string_length(Z3_context c, Z3_ast s)
Retrieve the length of the unescaped string constant stored in s.
Z3_string Z3_API Z3_tactic_get_help(Z3_context c, Z3_tactic t)
Return a string containing a description of parameters accepted by the given tactic.
void Z3_API Z3_solver_propagate_final(Z3_context c, Z3_solver s, Z3_final_eh final_eh)
register a callback on final check. This provides freedom to the propagator to delay actions or imple...
unsigned Z3_API Z3_param_descrs_size(Z3_context c, Z3_param_descrs p)
Return the number of parameters in the given parameter description set.
Z3_parameter_kind
The different kinds of parameters that can be associated with function symbols.
Definition z3_api.h:94
Z3_ast_vector Z3_API Z3_parse_smtlib2_string(Z3_context c, Z3_string str, unsigned num_sorts, Z3_symbol const sort_names[], Z3_sort const sorts[], unsigned num_decls, Z3_symbol const decl_names[], Z3_func_decl const decls[])
Parse the given string using the SMT-LIB2 parser.
Z3_ast Z3_API Z3_mk_fpa_geq(Z3_context c, Z3_ast t1, Z3_ast t2)
Floating-point greater than or equal.
Z3_ast Z3_API Z3_mk_bit2bool(Z3_context c, unsigned i, Z3_ast t1)
Extracts the bit at position i of a bit-vector and yields a boolean.
void Z3_API Z3_solver_register_on_clause(Z3_context c, Z3_solver s, void *user_context, Z3_on_clause_eh on_clause_eh)
register a callback to that retrieves assumed, inferred and deleted clauses during search.
Z3_string Z3_API Z3_goal_to_dimacs_string(Z3_context c, Z3_goal g, bool include_names)
Convert a goal into a DIMACS formatted string. The goal must be in CNF. You can convert a goal to CNF...
Z3_ast Z3_API Z3_mk_lt(Z3_context c, Z3_ast t1, Z3_ast t2)
Create less than.
double Z3_API Z3_stats_get_double_value(Z3_context c, Z3_stats s, unsigned idx)
Return the double value of the given statistical data.
Z3_ast Z3_API Z3_mk_fpa_numeral_float(Z3_context c, float v, Z3_sort ty)
Create a numeral of FloatingPoint sort from a float.
Z3_ast Z3_API Z3_mk_bvugt(Z3_context c, Z3_ast t1, Z3_ast t2)
Unsigned greater than.
Z3_lbool Z3_API Z3_fixedpoint_query(Z3_context c, Z3_fixedpoint d, Z3_ast query)
Pose a query against the asserted rules.
unsigned Z3_API Z3_goal_depth(Z3_context c, Z3_goal g)
Return the depth of the given goal. It tracks how many transformations were applied to it.
Z3_ast Z3_API Z3_mk_fpa_rtz(Z3_context c)
Create a numeral of RoundingMode sort which represents the TowardZero rounding mode.
Z3_string Z3_API Z3_get_symbol_string(Z3_context c, Z3_symbol s)
Return the symbol name.
Z3_lbool Z3_API Z3_get_bool_value(Z3_context c, Z3_ast a)
Return Z3_L_TRUE if a is true, Z3_L_FALSE if it is false, and Z3_L_UNDEF otherwise.
Z3_simplifier Z3_API Z3_mk_simplifier(Z3_context c, Z3_string name)
Return a simplifier associated with the given name. The complete list of simplifiers may be obtained ...
Z3_ast Z3_API Z3_mk_bvnot(Z3_context c, Z3_ast t1)
Bitwise negation.
Z3_ast Z3_API Z3_mk_bvurem(Z3_context c, Z3_ast t1, Z3_ast t2)
Unsigned remainder.
Z3_ast Z3_API Z3_mk_seq_foldli(Z3_context c, Z3_ast f, Z3_ast i, Z3_ast a, Z3_ast s)
Create a fold with index tracking of the function f over the sequence s with accumulator a starting a...
void Z3_API Z3_mk_datatypes(Z3_context c, unsigned num_sorts, Z3_symbol const sort_names[], Z3_sort sorts[], Z3_constructor_list constructor_lists[])
Create mutually recursive datatypes.
Z3_ast_vector Z3_API Z3_solver_get_non_units(Z3_context c, Z3_solver s)
Return the set of non units in the solver state.
Z3_ast Z3_API Z3_mk_seq_to_re(Z3_context c, Z3_ast seq)
Create a regular expression that accepts the sequence seq.
Z3_ast Z3_API Z3_mk_bvsub(Z3_context c, Z3_ast t1, Z3_ast t2)
Standard two's complement subtraction.
Z3_ast_vector Z3_API Z3_optimize_get_objectives(Z3_context c, Z3_optimize o)
Return objectives on the optimization context. If the objective function is a max-sat objective it is...
Z3_ast Z3_API Z3_mk_seq_index(Z3_context c, Z3_ast s, Z3_ast substr, Z3_ast offset)
Return index of the first occurrence of substr in s starting from offset offset. If s does not contai...
Z3_ast Z3_API Z3_get_algebraic_number_upper(Z3_context c, Z3_ast a, unsigned precision)
Return a upper bound for the given real algebraic number. The interval isolating the number is smalle...
Z3_ast Z3_API Z3_mk_power(Z3_context c, Z3_ast arg1, Z3_ast arg2)
Create an AST node representing arg1 ^ arg2.
Z3_ast Z3_API Z3_mk_seq_concat(Z3_context c, unsigned n, Z3_ast const args[])
Concatenate sequences.
Z3_sort Z3_API Z3_mk_enumeration_sort(Z3_context c, Z3_symbol name, unsigned n, Z3_symbol const enum_names[], Z3_func_decl enum_consts[], Z3_func_decl enum_testers[])
Create a enumeration sort.
Z3_ast Z3_API Z3_mk_re_range(Z3_context c, Z3_ast lo, Z3_ast hi)
Create the range regular expression over two sequences of length 1.
unsigned Z3_API Z3_get_bv_sort_size(Z3_context c, Z3_sort t)
Return the size of the given bit-vector sort.
Z3_ast_vector Z3_API Z3_fixedpoint_get_rules(Z3_context c, Z3_fixedpoint f)
Retrieve set of rules from fixedpoint context.
Z3_ast Z3_API Z3_mk_set_member(Z3_context c, Z3_ast elem, Z3_ast set)
Check for set membership.
void Z3_API Z3_ast_vector_dec_ref(Z3_context c, Z3_ast_vector v)
Decrement the reference counter of the given AST vector.
Z3_tactic Z3_API Z3_tactic_fail_if(Z3_context c, Z3_probe p)
Return a tactic that fails if the probe p evaluates to false.
void Z3_API Z3_goal_reset(Z3_context c, Z3_goal g)
Erase all formulas from the given goal.
void Z3_API Z3_func_interp_dec_ref(Z3_context c, Z3_func_interp f)
Decrement the reference counter of the given Z3_func_interp object.
void Z3_API Z3_probe_dec_ref(Z3_context c, Z3_probe p)
Decrement the reference counter of the given probe.
void Z3_API Z3_params_inc_ref(Z3_context c, Z3_params p)
Increment the reference counter of the given parameter set.
void Z3_API Z3_set_error_handler(Z3_context c, Z3_error_handler h)
Register a Z3 error handler.
Z3_ast Z3_API Z3_mk_distinct(Z3_context c, unsigned num_args, Z3_ast const args[])
Create an AST node representing distinct(args[0], ..., args[num_args-1]).
Z3_ast Z3_API Z3_mk_seq_prefix(Z3_context c, Z3_ast prefix, Z3_ast s)
Check if prefix is a prefix of s.
Z3_config Z3_API Z3_mk_config(void)
Create a configuration object for the Z3 context object.
void Z3_API Z3_set_param_value(Z3_config c, Z3_string param_id, Z3_string param_value)
Set a configuration parameter.
Z3_sort Z3_API Z3_mk_bv_sort(Z3_context c, unsigned sz)
Create a bit-vector type of the given size.
Z3_ast Z3_API Z3_mk_fpa_rem(Z3_context c, Z3_ast t1, Z3_ast t2)
Floating-point remainder.
Z3_ast Z3_API Z3_mk_bvult(Z3_context c, Z3_ast t1, Z3_ast t2)
Unsigned less than.
Z3_probe Z3_API Z3_probe_or(Z3_context x, Z3_probe p1, Z3_probe p2)
Return a probe that evaluates to "true" when p1 or p2 evaluates to true.
Z3_fixedpoint Z3_API Z3_mk_fixedpoint(Z3_context c)
Create a new fixedpoint context.
Z3_string Z3_API Z3_params_to_string(Z3_context c, Z3_params p)
Convert a parameter set into a string. This function is mainly used for printing the contents of a pa...
Z3_param_descrs Z3_API Z3_get_global_param_descrs(Z3_context c)
Retrieve description of global parameters.
void Z3_API Z3_solver_propagate_init(Z3_context c, Z3_solver s, void *user_context, Z3_push_eh push_eh, Z3_pop_eh pop_eh, Z3_fresh_eh fresh_eh)
register a user-propagator with the solver.
Z3_func_decl Z3_API Z3_model_get_const_decl(Z3_context c, Z3_model m, unsigned i)
Return the i-th constant in the given model.
void Z3_API Z3_tactic_dec_ref(Z3_context c, Z3_tactic g)
Decrement the reference counter of the given tactic.
Z3_ast Z3_API Z3_mk_bvnand(Z3_context c, Z3_ast t1, Z3_ast t2)
Bitwise nand.
Z3_solver Z3_API Z3_mk_simple_solver(Z3_context c)
Create a new incremental solver.
Z3_sort Z3_API Z3_get_range(Z3_context c, Z3_func_decl d)
Return the range of the given declaration.
void Z3_API Z3_global_param_set(Z3_string param_id, Z3_string param_value)
Set a global (or module) parameter. This setting is shared by all Z3 contexts.
void Z3_API Z3_optimize_assert(Z3_context c, Z3_optimize o, Z3_ast a)
Assert hard constraint to the optimization context.
Z3_string Z3_API Z3_benchmark_to_smtlib_string(Z3_context c, Z3_string name, Z3_string logic, Z3_string status, Z3_string attributes, unsigned num_assumptions, Z3_ast const assumptions[], Z3_ast formula)
Convert the given benchmark into SMT-LIB formatted string.
Z3_ast Z3_API Z3_mk_re_star(Z3_context c, Z3_ast re)
Create the regular language re*.
Z3_ast Z3_API Z3_mk_bv_numeral(Z3_context c, unsigned sz, bool const *bits)
create a bit-vector numeral from a vector of Booleans.
void Z3_API Z3_func_entry_dec_ref(Z3_context c, Z3_func_entry e)
Decrement the reference counter of the given Z3_func_entry object.
unsigned Z3_API Z3_stats_size(Z3_context c, Z3_stats s)
Return the number of statistical data in s.
Z3_string Z3_API Z3_optimize_to_string(Z3_context c, Z3_optimize o)
Print the current context as a string.
Z3_ast Z3_API Z3_get_quantifier_body(Z3_context c, Z3_ast a)
Return body of quantifier.
void Z3_API Z3_param_descrs_dec_ref(Z3_context c, Z3_param_descrs p)
Decrement the reference counter of the given parameter description set.
Z3_ast Z3_API Z3_mk_re_full(Z3_context c, Z3_sort re)
Create an universal regular expression of sort re.
Z3_ast Z3_API Z3_mk_fpa_min(Z3_context c, Z3_ast t1, Z3_ast t2)
Minimum of floating-point numbers.
Z3_model Z3_API Z3_mk_model(Z3_context c)
Create a fresh model object. It has reference count 0.
Z3_symbol Z3_API Z3_get_decl_name(Z3_context c, Z3_func_decl d)
Return the constant declaration name as a symbol.
Z3_ast Z3_API Z3_mk_seq_mapi(Z3_context c, Z3_ast f, Z3_ast i, Z3_ast s)
Create a map of the function f over the sequence s starting at index i.
Z3_ast Z3_API Z3_mk_bvneg_no_overflow(Z3_context c, Z3_ast t1)
Check that bit-wise negation does not overflow when t1 is interpreted as a signed bit-vector.
Z3_ast Z3_API Z3_mk_fpa_round_to_integral(Z3_context c, Z3_ast rm, Z3_ast t)
Floating-point roundToIntegral. Rounds a floating-point number to the closest integer,...
Z3_string Z3_API Z3_stats_get_key(Z3_context c, Z3_stats s, unsigned idx)
Return the key (a string) for a particular statistical data.
Z3_ast Z3_API Z3_mk_re_diff(Z3_context c, Z3_ast re1, Z3_ast re2)
Create the difference of regular expressions.
unsigned Z3_API Z3_fixedpoint_get_num_levels(Z3_context c, Z3_fixedpoint d, Z3_func_decl pred)
Query the PDR engine for the maximal levels properties are known about predicate.
Z3_ast Z3_API Z3_mk_int64(Z3_context c, int64_t v, Z3_sort ty)
Create a numeral of a int, bit-vector, or finite-domain sort.
Z3_symbol_kind
The different kinds of symbol. In Z3, a symbol can be represented using integers and strings (See Z3_...
Definition z3_api.h:72
Z3_ast Z3_API Z3_mk_re_empty(Z3_context c, Z3_sort re)
Create an empty regular expression of sort re.
Z3_ast Z3_API Z3_mk_fpa_add(Z3_context c, Z3_ast rm, Z3_ast t1, Z3_ast t2)
Floating-point addition.
Z3_ast Z3_API Z3_mk_bvand(Z3_context c, Z3_ast t1, Z3_ast t2)
Bitwise and.
Z3_param_descrs Z3_API Z3_simplify_get_param_descrs(Z3_context c)
Return the parameter description set for the simplify procedure.
bool Z3_API Z3_goal_is_decided_unsat(Z3_context c, Z3_goal g)
Return true if the goal contains false, and it is precise or the product of an over approximation.
Z3_ast Z3_API Z3_mk_add(Z3_context c, unsigned num_args, Z3_ast const args[])
Create an AST node representing args[0] + ... + args[num_args-1].
Z3_ast_kind Z3_API Z3_get_ast_kind(Z3_context c, Z3_ast a)
Return the kind of the given AST.
Z3_ast_vector Z3_API Z3_parse_smtlib2_file(Z3_context c, Z3_string file_name, unsigned num_sorts, Z3_symbol const sort_names[], Z3_sort const sorts[], unsigned num_decls, Z3_symbol const decl_names[], Z3_func_decl const decls[])
Similar to Z3_parse_smtlib2_string, but reads the benchmark from a file.
Z3_ast Z3_API Z3_mk_bvsmod(Z3_context c, Z3_ast t1, Z3_ast t2)
Two's complement signed remainder (sign follows divisor).
Z3_tactic Z3_API Z3_tactic_cond(Z3_context c, Z3_probe p, Z3_tactic t1, Z3_tactic t2)
Return a tactic that applies t1 to a given goal if the probe p evaluates to true, and t2 if p evaluat...
Z3_model Z3_API Z3_model_translate(Z3_context c, Z3_model m, Z3_context dst)
translate model from context c to context dst.
Z3_string Z3_API Z3_fixedpoint_to_string(Z3_context c, Z3_fixedpoint f, unsigned num_queries, Z3_ast queries[])
Print the current rules and background axioms as a string.
void Z3_API Z3_solver_get_levels(Z3_context c, Z3_solver s, Z3_ast_vector literals, unsigned sz, unsigned levels[])
retrieve the decision depth of Boolean literals (variables or their negations). Assumes a check-sat c...
Z3_ast Z3_API Z3_fixedpoint_get_cover_delta(Z3_context c, Z3_fixedpoint d, int level, Z3_func_decl pred)
Z3_ast Z3_API Z3_mk_fpa_to_fp_unsigned(Z3_context c, Z3_ast rm, Z3_ast t, Z3_sort s)
Conversion of a 2's complement unsigned bit-vector term into a term of FloatingPoint sort.
Z3_ast Z3_API Z3_mk_int2bv(Z3_context c, unsigned n, Z3_ast t1)
Create an n bit bit-vector from the integer argument t1.
void Z3_API Z3_solver_assert(Z3_context c, Z3_solver s, Z3_ast a)
Assert a constraint into the solver.
Z3_tactic Z3_API Z3_mk_tactic(Z3_context c, Z3_string name)
Return a tactic associated with the given name. The complete list of tactics may be obtained using th...
Z3_ast Z3_API Z3_mk_fpa_abs(Z3_context c, Z3_ast t)
Floating-point absolute value.
unsigned Z3_API Z3_ast_vector_size(Z3_context c, Z3_ast_vector v)
Return the size of the given AST vector.
Z3_optimize Z3_API Z3_mk_optimize(Z3_context c)
Create a new optimize context.
bool Z3_API Z3_model_eval(Z3_context c, Z3_model m, Z3_ast t, bool model_completion, Z3_ast *v)
Evaluate the AST node t in the given model. Return true if succeeded, and store the result in v.
Z3_sort Z3_API Z3_get_array_sort_range(Z3_context c, Z3_sort t)
Return the range of the given array sort.
void Z3_API Z3_del_constructor_list(Z3_context c, Z3_constructor_list clist)
Reclaim memory allocated for constructor list.
Z3_ast Z3_API Z3_mk_bound(Z3_context c, unsigned index, Z3_sort ty)
Create a variable.
unsigned Z3_API Z3_get_app_num_args(Z3_context c, Z3_app a)
Return the number of argument of an application. If t is an constant, then the number of arguments is...
Z3_ast Z3_API Z3_substitute_funs(Z3_context c, Z3_ast a, unsigned num_funs, Z3_func_decl const from[], Z3_ast const to[])
Substitute functions in from with new expressions in to.
Z3_ast Z3_API Z3_func_entry_get_arg(Z3_context c, Z3_func_entry e, unsigned i)
Return an argument of a Z3_func_entry object.
Z3_error_code
Z3 error codes (See Z3_get_error_code).
Definition z3_api.h:1347
Z3_ast Z3_API Z3_mk_eq(Z3_context c, Z3_ast l, Z3_ast r)
Create an AST node representing l = r.
Z3_ast Z3_API Z3_mk_atleast(Z3_context c, unsigned num_args, Z3_ast const args[], unsigned k)
Pseudo-Boolean relations.
void Z3_API Z3_ast_vector_inc_ref(Z3_context c, Z3_ast_vector v)
Increment the reference counter of the given AST vector.
unsigned Z3_API Z3_model_get_num_funcs(Z3_context c, Z3_model m)
Return the number of function interpretations in the given model.
void Z3_API Z3_dec_ref(Z3_context c, Z3_ast a)
Decrement the reference counter of the given AST. The context c should have been created using Z3_mk_...
Z3_ast_vector Z3_API Z3_solver_get_unsat_core(Z3_context c, Z3_solver s)
Retrieve the unsat core for the last Z3_solver_check_assumptions The unsat core is a subset of the as...
Z3_ast_vector Z3_API Z3_mk_ast_vector(Z3_context c)
Return an empty AST vector.
void Z3_API Z3_optimize_dec_ref(Z3_context c, Z3_optimize d)
Decrement the reference counter of the given optimize context.
Z3_string Z3_API Z3_get_string(Z3_context c, Z3_ast s)
Retrieve the string constant stored in s. Characters outside the basic printable ASCII range are esca...
Z3_ast Z3_API Z3_mk_fpa_is_nan(Z3_context c, Z3_ast t)
Predicate indicating whether t is a NaN.
bool Z3_API Z3_get_numeral_int(Z3_context c, Z3_ast v, int *i)
Similar to Z3_get_numeral_string, but only succeeds if the value can fit in a machine int....
Z3_error_code Z3_API Z3_get_error_code(Z3_context c)
Return the error code for the last API call.
Z3_ast Z3_API Z3_mk_fpa_fp(Z3_context c, Z3_ast sgn, Z3_ast exp, Z3_ast sig)
Create an expression of FloatingPoint sort from three bit-vector expressions.
Z3_func_decl Z3_API Z3_mk_partial_order(Z3_context c, Z3_sort a, unsigned id)
create a partial ordering relation over signature a and index id.
Z3_ast Z3_API Z3_mk_empty_set(Z3_context c, Z3_sort domain)
Create the empty set.
bool Z3_API Z3_is_string(Z3_context c, Z3_ast s)
Determine if s is a string constant.
Z3_ast Z3_API Z3_mk_re_loop(Z3_context c, Z3_ast r, unsigned lo, unsigned hi)
Create a regular expression loop. The supplied regular expression r is repeated between lo and hi tim...
Z3_ast Z3_API Z3_mk_char_to_int(Z3_context c, Z3_ast ch)
Create an integer (code point) from character.
Z3_ast Z3_API Z3_mk_fpa_neg(Z3_context c, Z3_ast t)
Floating-point negation.
Z3_ast Z3_API Z3_mk_repeat(Z3_context c, unsigned i, Z3_ast t1)
Repeat the given bit-vector up length i.
Z3_ast Z3_API Z3_mk_re_plus(Z3_context c, Z3_ast re)
Create the regular language re+.
Z3_goal_prec Z3_API Z3_goal_precision(Z3_context c, Z3_goal g)
Return the "precision" of the given goal. Goals can be transformed using over and under approximation...
void Z3_API Z3_solver_pop(Z3_context c, Z3_solver s, unsigned n)
Backtrack n backtracking points.
Z3_ast Z3_API Z3_mk_int2real(Z3_context c, Z3_ast t1)
Coerce an integer to a real.
Z3_goal Z3_API Z3_mk_goal(Z3_context c, bool models, bool unsat_cores, bool proofs)
Create a goal (aka problem). A goal is essentially a set of formulas, that can be solved and/or trans...
double Z3_API Z3_get_decl_double_parameter(Z3_context c, Z3_func_decl d, unsigned idx)
Return the double value associated with an double parameter.
unsigned Z3_API Z3_get_ast_hash(Z3_context c, Z3_ast a)
Return a hash code for the given AST. The hash code is structural but two different AST objects can m...
Z3_ast Z3_API Z3_mk_fpa_lt(Z3_context c, Z3_ast t1, Z3_ast t2)
Floating-point less than.
Z3_ast Z3_API Z3_mk_unsigned_int64(Z3_context c, uint64_t v, Z3_sort ty)
Create a numeral of a int, bit-vector, or finite-domain sort.
Z3_string Z3_API Z3_optimize_get_help(Z3_context c, Z3_optimize t)
Return a string containing a description of parameters accepted by optimize.
Z3_symbol Z3_API Z3_get_sort_name(Z3_context c, Z3_sort d)
Return the sort name as a symbol.
Z3_func_decl Z3_API Z3_get_datatype_sort_recognizer(Z3_context c, Z3_sort t, unsigned idx)
Return idx'th recognizer.
void Z3_API Z3_global_param_reset_all(void)
Restore the value of all global (and module) parameters. This command will not affect already created...
Z3_ast Z3_API Z3_mk_gt(Z3_context c, Z3_ast t1, Z3_ast t2)
Create greater than.
Z3_stats Z3_API Z3_optimize_get_statistics(Z3_context c, Z3_optimize d)
Retrieve statistics information from the last call to Z3_optimize_check.
Z3_ast Z3_API Z3_mk_store(Z3_context c, Z3_ast a, Z3_ast i, Z3_ast v)
Array update.
Z3_probe Z3_API Z3_probe_gt(Z3_context x, Z3_probe p1, Z3_probe p2)
Return a probe that evaluates to "true" when the value returned by p1 is greater than the value retur...
Z3_ast Z3_API Z3_solver_get_proof(Z3_context c, Z3_solver s)
Retrieve the proof for the last Z3_solver_check or Z3_solver_check_assumptions.
Z3_string Z3_API Z3_get_decl_rational_parameter(Z3_context c, Z3_func_decl d, unsigned idx)
Return the rational value, as a string, associated with a rational parameter.
unsigned Z3_API Z3_optimize_minimize(Z3_context c, Z3_optimize o, Z3_ast t)
Add a minimization constraint.
Z3_stats Z3_API Z3_fixedpoint_get_statistics(Z3_context c, Z3_fixedpoint d)
Retrieve statistics information from the last call to Z3_fixedpoint_query.
bool Z3_API Z3_model_has_interp(Z3_context c, Z3_model m, Z3_func_decl a)
Test if there exists an interpretation (i.e., assignment) for a in the model m.
void Z3_API Z3_ast_vector_push(Z3_context c, Z3_ast_vector v, Z3_ast a)
Add the AST a in the end of the AST vector v. The size of v is increased by one.
bool Z3_API Z3_is_eq_ast(Z3_context c, Z3_ast t1, Z3_ast t2)
Compare terms.
bool Z3_API Z3_is_quantifier_forall(Z3_context c, Z3_ast a)
Determine if an ast is a universal quantifier.
void Z3_API Z3_tactic_inc_ref(Z3_context c, Z3_tactic t)
Increment the reference counter of the given tactic.
Z3_ast Z3_API Z3_mk_real_int64(Z3_context c, int64_t num, int64_t den)
Create a real from a fraction of int64.
void Z3_API Z3_solver_from_file(Z3_context c, Z3_solver s, Z3_string file_name)
load solver assertions from a file.
Z3_ast Z3_API Z3_mk_seq_last_index(Z3_context c, Z3_ast s, Z3_ast substr)
Return index of the last occurrence of substr in s. If s does not contain substr, then the value is -...
Z3_ast Z3_API Z3_mk_xor(Z3_context c, Z3_ast t1, Z3_ast t2)
Create an AST node representing t1 xor t2.
void Z3_API Z3_solver_propagate_eq(Z3_context c, Z3_solver s, Z3_eq_eh eq_eh)
register a callback on expression equalities.
Z3_ast Z3_API Z3_mk_string(Z3_context c, Z3_string s)
Create a string constant out of the string that is passed in The string may contain escape encoding f...
Z3_func_decl Z3_API Z3_mk_transitive_closure(Z3_context c, Z3_func_decl f)
create transitive closure of binary relation.
Z3_tactic Z3_API Z3_tactic_try_for(Z3_context c, Z3_tactic t, unsigned ms)
Return a tactic that applies t to a given goal for ms milliseconds. If t does not terminate in ms mil...
Z3_ast Z3_API Z3_mk_rotate_left(Z3_context c, unsigned i, Z3_ast t1)
Rotate bits of t1 to the left i times.
void Z3_API Z3_apply_result_dec_ref(Z3_context c, Z3_apply_result r)
Decrement the reference counter of the given Z3_apply_result object.
Z3_sort Z3_API Z3_mk_seq_sort(Z3_context c, Z3_sort s)
Create a sequence sort out of the sort for the elements.
unsigned Z3_API Z3_optimize_maximize(Z3_context c, Z3_optimize o, Z3_ast t)
Add a maximization constraint.
Z3_ast_vector Z3_API Z3_solver_get_units(Z3_context c, Z3_solver s)
Return the set of units modulo model conversion.
Z3_ast Z3_API Z3_mk_const(Z3_context c, Z3_symbol s, Z3_sort ty)
Declare and create a constant.
Z3_symbol Z3_API Z3_mk_string_symbol(Z3_context c, Z3_string s)
Create a Z3 symbol using a C string.
void Z3_API Z3_param_descrs_inc_ref(Z3_context c, Z3_param_descrs p)
Increment the reference counter of the given parameter description set.
Z3_goal Z3_API Z3_apply_result_get_subgoal(Z3_context c, Z3_apply_result r, unsigned i)
Return one of the subgoals in the Z3_apply_result object returned by Z3_tactic_apply.
Z3_probe Z3_API Z3_probe_le(Z3_context x, Z3_probe p1, Z3_probe p2)
Return a probe that evaluates to "true" when the value returned by p1 is less than or equal to the va...
void Z3_API Z3_stats_dec_ref(Z3_context c, Z3_stats s)
Decrement the reference counter of the given statistics object.
Z3_ast Z3_API Z3_mk_re_concat(Z3_context c, unsigned n, Z3_ast const args[])
Create the concatenation of the regular languages.
Z3_func_entry Z3_API Z3_func_interp_get_entry(Z3_context c, Z3_func_interp f, unsigned i)
Return a "point" of the given function interpretation. It represents the value of f in a particular p...
Z3_func_decl Z3_API Z3_mk_rec_func_decl(Z3_context c, Z3_symbol s, unsigned domain_size, Z3_sort const domain[], Z3_sort range)
Declare a recursive function.
unsigned Z3_API Z3_get_ast_id(Z3_context c, Z3_ast t)
Return a unique identifier for t. The identifier is unique up to structural equality....
Z3_ast Z3_API Z3_mk_concat(Z3_context c, Z3_ast t1, Z3_ast t2)
Concatenate the given bit-vectors.
Z3_ast Z3_API Z3_mk_fpa_to_fp_float(Z3_context c, Z3_ast rm, Z3_ast t, Z3_sort s)
Conversion of a FloatingPoint term into another term of different FloatingPoint sort.
Z3_sort Z3_API Z3_get_decl_sort_parameter(Z3_context c, Z3_func_decl d, unsigned idx)
Return the sort value associated with a sort parameter.
Z3_constructor_list Z3_API Z3_mk_constructor_list(Z3_context c, unsigned num_constructors, Z3_constructor const constructors[])
Create list of constructors.
Z3_apply_result Z3_API Z3_tactic_apply(Z3_context c, Z3_tactic t, Z3_goal g)
Apply tactic t to the goal g.
Z3_ast Z3_API Z3_mk_fpa_leq(Z3_context c, Z3_ast t1, Z3_ast t2)
Floating-point less than or equal.
void Z3_API Z3_solver_propagate_created(Z3_context c, Z3_solver s, Z3_created_eh created_eh)
register a callback when a new expression with a registered function is used by the solver The regist...
Z3_ast Z3_API Z3_mk_fpa_numeral_double(Z3_context c, double v, Z3_sort ty)
Create a numeral of FloatingPoint sort from a double.
unsigned Z3_API Z3_get_sort_id(Z3_context c, Z3_sort s)
Return a unique identifier for s.
Z3_ast Z3_API Z3_mk_fpa_mul(Z3_context c, Z3_ast rm, Z3_ast t1, Z3_ast t2)
Floating-point multiplication.
Z3_ast Z3_API Z3_mk_app(Z3_context c, Z3_func_decl d, unsigned num_args, Z3_ast const args[])
Create a constant or function application.
Z3_sort_kind Z3_API Z3_get_sort_kind(Z3_context c, Z3_sort t)
Return the sort kind (e.g., array, tuple, int, bool, etc).
Z3_stats Z3_API Z3_solver_get_statistics(Z3_context c, Z3_solver s)
Return statistics for the given solver.
Z3_ast Z3_API Z3_mk_bvneg(Z3_context c, Z3_ast t1)
Standard two's complement unary minus.
Z3_ast Z3_API Z3_mk_store_n(Z3_context c, Z3_ast a, unsigned n, Z3_ast const *idxs, Z3_ast v)
n-ary Array update.
Z3_string Z3_API Z3_fixedpoint_get_reason_unknown(Z3_context c, Z3_fixedpoint d)
Retrieve a string that describes the last status returned by Z3_fixedpoint_query.
Z3_func_decl Z3_API Z3_mk_linear_order(Z3_context c, Z3_sort a, unsigned id)
create a linear ordering relation over signature a. The relation is identified by the index id.
Z3_string Z3_API Z3_fixedpoint_get_help(Z3_context c, Z3_fixedpoint f)
Return a string describing all fixedpoint available parameters.
Z3_sort Z3_API Z3_get_domain(Z3_context c, Z3_func_decl d, unsigned i)
Return the sort of the i-th parameter of the given function declaration.
Z3_ast Z3_API Z3_mk_seq_in_re(Z3_context c, Z3_ast seq, Z3_ast re)
Check if seq is in the language generated by the regular expression re.
Z3_sort Z3_API Z3_mk_bool_sort(Z3_context c)
Create the Boolean type.
Z3_ast Z3_API Z3_mk_sub(Z3_context c, unsigned num_args, Z3_ast const args[])
Create an AST node representing args[0] - ... - args[num_args - 1].
void Z3_API Z3_params_set_symbol(Z3_context c, Z3_params p, Z3_symbol k, Z3_symbol v)
Add a symbol parameter k with value v to the parameter set p.
Z3_ast Z3_API Z3_ast_vector_get(Z3_context c, Z3_ast_vector v, unsigned i)
Return the AST at position i in the AST vector v.
Z3_string Z3_API Z3_solver_to_dimacs_string(Z3_context c, Z3_solver s, bool include_names)
Convert a solver into a DIMACS formatted string.
unsigned Z3_API Z3_get_func_decl_id(Z3_context c, Z3_func_decl f)
Return a unique identifier for f.
Z3_ast Z3_API Z3_mk_set_difference(Z3_context c, Z3_ast arg1, Z3_ast arg2)
Take the set difference between two sets.
void Z3_API Z3_solver_propagate_decide(Z3_context c, Z3_solver s, Z3_decide_eh decide_eh)
register a callback when the solver decides to split on a registered expression. The callback may cha...
Z3_ast Z3_API Z3_mk_lstring(Z3_context c, unsigned len, Z3_string s)
Create a string constant out of the string that is passed in It takes the length of the string as wel...
Z3_ast Z3_API Z3_mk_bvsdiv(Z3_context c, Z3_ast t1, Z3_ast t2)
Two's complement signed division.
Z3_ast Z3_API Z3_mk_bvlshr(Z3_context c, Z3_ast t1, Z3_ast t2)
Logical shift right.
Z3_ast Z3_API Z3_get_decl_ast_parameter(Z3_context c, Z3_func_decl d, unsigned idx)
Return the expression value associated with an expression parameter.
double Z3_API Z3_probe_apply(Z3_context c, Z3_probe p, Z3_goal g)
Execute the probe over the goal. The probe always produce a double value. "Boolean" probes return 0....
void Z3_API Z3_func_interp_set_else(Z3_context c, Z3_func_interp f, Z3_ast else_value)
Return the 'else' value of the given function interpretation.
void Z3_API Z3_goal_dec_ref(Z3_context c, Z3_goal g)
Decrement the reference counter of the given goal.
Z3_ast Z3_API Z3_mk_not(Z3_context c, Z3_ast a)
Create an AST node representing not(a).
void Z3_API Z3_solver_propagate_register(Z3_context c, Z3_solver s, Z3_ast e)
register an expression to propagate on with the solver. Only expressions of type Bool and type Bit-Ve...
Z3_ast Z3_API Z3_substitute_vars(Z3_context c, Z3_ast a, unsigned num_exprs, Z3_ast const to[])
Substitute the variables in a with the expressions in to. For every i smaller than num_exprs,...
Z3_ast Z3_API Z3_mk_or(Z3_context c, unsigned num_args, Z3_ast const args[])
Create an AST node representing args[0] or ... or args[num_args-1].
Z3_sort Z3_API Z3_mk_array_sort(Z3_context c, Z3_sort domain, Z3_sort range)
Create an array type.
Z3_tactic Z3_API Z3_tactic_or_else(Z3_context c, Z3_tactic t1, Z3_tactic t2)
Return a tactic that first applies t1 to a given goal, if it fails then returns the result of t2 appl...
void Z3_API Z3_model_inc_ref(Z3_context c, Z3_model m)
Increment the reference counter of the given model.
Z3_ast Z3_API Z3_mk_seq_extract(Z3_context c, Z3_ast s, Z3_ast offset, Z3_ast length)
Extract subsequence starting at offset of length.
Z3_ast Z3_API Z3_mk_fpa_div(Z3_context c, Z3_ast rm, Z3_ast t1, Z3_ast t2)
Floating-point division.
Z3_sort Z3_API Z3_mk_fpa_sort(Z3_context c, unsigned ebits, unsigned sbits)
Create a FloatingPoint sort.
Z3_ast Z3_API Z3_mk_fpa_sqrt(Z3_context c, Z3_ast rm, Z3_ast t)
Floating-point square root.
bool Z3_API Z3_goal_is_decided_sat(Z3_context c, Z3_goal g)
Return true if the goal is empty, and it is precise or the product of a under approximation.
void Z3_API Z3_fixedpoint_set_params(Z3_context c, Z3_fixedpoint f, Z3_params p)
Set parameters on fixedpoint context.
void Z3_API Z3_optimize_from_string(Z3_context c, Z3_optimize o, Z3_string s)
Parse an SMT-LIB2 string with assertions, soft constraints and optimization objectives....
Z3_solver Z3_API Z3_solver_add_simplifier(Z3_context c, Z3_solver solver, Z3_simplifier simplifier)
Attach simplifier to a solver. The solver will use the simplifier for incremental pre-processing.
Z3_ast Z3_API Z3_mk_rem(Z3_context c, Z3_ast arg1, Z3_ast arg2)
Create an AST node representing arg1 rem arg2.
Z3_ast Z3_API Z3_fixedpoint_get_answer(Z3_context c, Z3_fixedpoint d)
Retrieve a formula that encodes satisfying answers to the query.
Z3_ast Z3_API Z3_mk_int_to_str(Z3_context c, Z3_ast s)
Integer to string conversion.
bool Z3_API Z3_get_numeral_uint(Z3_context c, Z3_ast v, unsigned *u)
Similar to Z3_get_numeral_string, but only succeeds if the value can fit in a machine unsigned int....
Z3_string Z3_API Z3_get_numeral_string(Z3_context c, Z3_ast a)
Return numeral value, as a decimal string of a numeric constant term.
void Z3_API Z3_solver_propagate_fixed(Z3_context c, Z3_solver s, Z3_fixed_eh fixed_eh)
register a callback for when an expression is bound to a fixed value. The supported expression types ...
Z3_ast Z3_API Z3_mk_seq_map(Z3_context c, Z3_ast f, Z3_ast s)
Create a map of the function f over the sequence s.
void Z3_API Z3_fixedpoint_register_relation(Z3_context c, Z3_fixedpoint d, Z3_func_decl f)
Register relation as Fixedpoint defined. Fixedpoint defined relations have least-fixedpoint semantics...
Z3_ast Z3_API Z3_mk_char_is_digit(Z3_context c, Z3_ast ch)
Create a check if the character is a digit.
void Z3_API Z3_fixedpoint_add_cover(Z3_context c, Z3_fixedpoint d, int level, Z3_func_decl pred, Z3_ast property)
Add property about the predicate pred. Add a property of predicate pred at level. It gets pushed forw...
void Z3_API Z3_func_interp_add_entry(Z3_context c, Z3_func_interp fi, Z3_ast_vector args, Z3_ast value)
add a function entry to a function interpretation.
bool Z3_API Z3_is_well_sorted(Z3_context c, Z3_ast t)
Return true if the given expression t is well sorted.
Z3_ast Z3_API Z3_mk_bvuge(Z3_context c, Z3_ast t1, Z3_ast t2)
Unsigned greater than or equal to.
Z3_lbool Z3_API Z3_fixedpoint_query_relations(Z3_context c, Z3_fixedpoint d, unsigned num_relations, Z3_func_decl const relations[])
Pose multiple queries against the asserted rules.
Z3_ast Z3_API Z3_mk_as_array(Z3_context c, Z3_func_decl f)
Create array with the same interpretation as a function. The array satisfies the property (f x) = (se...
Z3_string Z3_API Z3_apply_result_to_string(Z3_context c, Z3_apply_result r)
Convert the Z3_apply_result object returned by Z3_tactic_apply into a string.
Z3_string Z3_API Z3_solver_to_string(Z3_context c, Z3_solver s)
Convert a solver into a string.
Z3_ast Z3_API Z3_mk_seq_foldl(Z3_context c, Z3_ast f, Z3_ast a, Z3_ast s)
Create a fold of the function f over the sequence s with accumulator a.
Z3_string Z3_API Z3_solver_get_reason_unknown(Z3_context c, Z3_solver s)
Return a brief justification for an "unknown" result (i.e., Z3_L_UNDEF) for the commands Z3_solver_ch...
Z3_ast Z3_API Z3_mk_fpa_fma(Z3_context c, Z3_ast rm, Z3_ast t1, Z3_ast t2, Z3_ast t3)
Floating-point fused multiply-add.
Z3_string Z3_API Z3_get_numeral_binary_string(Z3_context c, Z3_ast a)
Return numeral value, as a binary string of a numeric constant term.
Z3_tactic Z3_API Z3_tactic_repeat(Z3_context c, Z3_tactic t, unsigned max)
Return a tactic that keeps applying t until the goal is not modified anymore or the maximum number of...
Z3_ast Z3_API Z3_goal_formula(Z3_context c, Z3_goal g, unsigned idx)
Return a formula from the given goal.
Z3_lbool Z3_API Z3_optimize_check(Z3_context c, Z3_optimize o, unsigned num_assumptions, Z3_ast const assumptions[])
Check consistency and produce optimal values.
Z3_symbol Z3_API Z3_mk_int_symbol(Z3_context c, int i)
Create a Z3 symbol using an integer.
Z3_ast Z3_API Z3_mk_char_from_bv(Z3_context c, Z3_ast bv)
Create a character from a bit-vector (code point).
unsigned Z3_API Z3_func_interp_get_num_entries(Z3_context c, Z3_func_interp f)
Return the number of entries in the given function interpretation.
Z3_probe Z3_API Z3_probe_const(Z3_context x, double val)
Return a probe that always evaluates to val.
Z3_constructor Z3_API Z3_mk_constructor(Z3_context c, Z3_symbol name, Z3_symbol recognizer, unsigned num_fields, Z3_symbol const field_names[], Z3_sort const sorts[], unsigned sort_refs[])
Create a constructor.
Z3_sort Z3_API Z3_mk_fpa_rounding_mode_sort(Z3_context c)
Create the RoundingMode sort.
Z3_string Z3_API Z3_goal_to_string(Z3_context c, Z3_goal g)
Convert a goal into a string.
Z3_ast Z3_API Z3_mk_fpa_rne(Z3_context c)
Create a numeral of RoundingMode sort which represents the NearestTiesToEven rounding mode.
Z3_ast Z3_API Z3_mk_atmost(Z3_context c, unsigned num_args, Z3_ast const args[], unsigned k)
Pseudo-Boolean relations.
void Z3_API Z3_del_config(Z3_config c)
Delete the given configuration object.
double Z3_API Z3_get_numeral_double(Z3_context c, Z3_ast a)
Return numeral as a double.
void Z3_API Z3_inc_ref(Z3_context c, Z3_ast a)
Increment the reference counter of the given AST. The context c should have been created using Z3_mk_...
Z3_tactic Z3_API Z3_tactic_and_then(Z3_context c, Z3_tactic t1, Z3_tactic t2)
Return a tactic that applies t1 to a given goal and t2 to every subgoal produced by t1.
Z3_optimize Z3_API Z3_optimize_translate(Z3_context c, Z3_optimize o, Z3_context target)
Copy an optimization context from a source to a target context.
Z3_func_interp Z3_API Z3_model_get_func_interp(Z3_context c, Z3_model m, Z3_func_decl f)
Return the interpretation of the function f in the model m. Return NULL, if the model does not assign...
void Z3_API Z3_solver_inc_ref(Z3_context c, Z3_solver s)
Increment the reference counter of the given solver.
bool Z3_API Z3_solver_next_split(Z3_context c, Z3_solver_callback cb, Z3_ast t, unsigned idx, Z3_lbool phase)
Z3_probe Z3_API Z3_probe_and(Z3_context x, Z3_probe p1, Z3_probe p2)
Return a probe that evaluates to "true" when p1 and p2 evaluates to true.
bool Z3_API Z3_is_re_sort(Z3_context c, Z3_sort s)
Check if s is a regular expression sort.
Z3_ast Z3_API Z3_mk_ubv_to_str(Z3_context c, Z3_ast s)
Unsigned bit-vector to string conversion.
Z3_sort Z3_API Z3_mk_string_sort(Z3_context c)
Create a sort for unicode strings.
Z3_string Z3_API Z3_get_numeral_decimal_string(Z3_context c, Z3_ast a, unsigned precision)
Return numeral as a string in decimal notation. The result has at most precision decimal places.
Z3_sort Z3_API Z3_get_sort(Z3_context c, Z3_ast a)
Return the sort of an AST node.
Z3_func_decl Z3_API Z3_get_datatype_sort_constructor_accessor(Z3_context c, Z3_sort t, unsigned idx_c, unsigned idx_a)
Return idx_a'th accessor for the idx_c'th constructor.
Z3_ast Z3_API Z3_mk_bvredor(Z3_context c, Z3_ast t1)
Take disjunction of bits in vector, return vector of length 1.
Z3_ast Z3_API Z3_mk_seq_nth(Z3_context c, Z3_ast s, Z3_ast index)
Retrieve from s the element positioned at position index. The function is under-specified if the inde...
Z3_ast Z3_API Z3_mk_seq_contains(Z3_context c, Z3_ast container, Z3_ast containee)
Check if container contains containee.
void Z3_API Z3_solver_reset(Z3_context c, Z3_solver s)
Remove all assertions from the solver.
bool Z3_API Z3_is_algebraic_number(Z3_context c, Z3_ast a)
Return true if the given AST is a real algebraic number.
@ Z3_PRINT_SMTLIB2_COMPLIANT
Definition z3_api.h:1325
@ Z3_APP_AST
Definition z3_api.h:144
@ Z3_VAR_AST
Definition z3_api.h:145
@ Z3_SORT_AST
Definition z3_api.h:147
@ Z3_NUMERAL_AST
Definition z3_api.h:143
@ Z3_FUNC_DECL_AST
Definition z3_api.h:148
@ Z3_QUANTIFIER_AST
Definition z3_api.h:146
@ Z3_OP_DISTINCT
Definition z3_api.h:967
@ Z3_OP_AND
Definition z3_api.h:969
@ Z3_OP_FALSE
Definition z3_api.h:965
@ Z3_OP_XOR
Definition z3_api.h:972
@ Z3_OP_IMPLIES
Definition z3_api.h:974
@ Z3_OP_ITE
Definition z3_api.h:968
@ Z3_OP_EQ
Definition z3_api.h:966
@ Z3_OP_OR
Definition z3_api.h:970
@ Z3_OP_NOT
Definition z3_api.h:973
@ Z3_OP_TRUE
Definition z3_api.h:964
@ Z3_RELATION_SORT
Definition z3_api.h:118
@ Z3_BOOL_SORT
Definition z3_api.h:112
@ Z3_BV_SORT
Definition z3_api.h:115
@ Z3_DATATYPE_SORT
Definition z3_api.h:117
@ Z3_INT_SORT
Definition z3_api.h:113
@ Z3_FINITE_DOMAIN_SORT
Definition z3_api.h:119
@ Z3_RE_SORT
Definition z3_api.h:123
@ Z3_FLOATING_POINT_SORT
Definition z3_api.h:120
@ Z3_ARRAY_SORT
Definition z3_api.h:116
@ Z3_REAL_SORT
Definition z3_api.h:114
@ Z3_SEQ_SORT
Definition z3_api.h:122
@ Z3_L_TRUE
Definition z3_api.h:61
@ Z3_L_FALSE
Definition z3_api.h:59
@ Z3_STRING_SYMBOL
Definition z3_api.h:74
@ Z3_INT_SYMBOL
Definition z3_api.h:73
@ Z3_OK
Definition z3_api.h:1348
Z3 C++ namespace.
Definition z3++.h:49
expr set_intersect(expr const &a, expr const &b)
Definition z3++.h:4085
expr re_intersect(expr_vector const &args)
Definition z3++.h:4167
expr store(expr const &a, expr const &i, expr const &v)
Definition z3++.h:4020
expr pw(expr const &a, expr const &b)
Definition z3++.h:1654
expr sbv_to_fpa(expr const &t, sort s)
Definition z3++.h:2078
expr bvneg_no_overflow(expr const &a)
Definition z3++.h:2279
expr indexof(expr const &s, expr const &substr, expr const &offset)
Definition z3++.h:4130
tactic par_or(unsigned n, tactic const *tactics)
Definition z3++.h:3178
tactic par_and_then(tactic const &t1, tactic const &t2)
Definition z3++.h:3187
expr srem(expr const &a, expr const &b)
signed remainder operator for bitvectors
Definition z3++.h:2211
expr bvadd_no_underflow(expr const &a, expr const &b)
Definition z3++.h:2267
expr prefixof(expr const &a, expr const &b)
Definition z3++.h:4124
expr sum(expr_vector const &args)
Definition z3++.h:2463
expr ugt(expr const &a, expr const &b)
unsigned greater than operator for bitvectors.
Definition z3++.h:2190
expr operator/(expr const &a, expr const &b)
Definition z3++.h:1820
expr exists(expr const &x, expr const &b)
Definition z3++.h:2374
expr fp_eq(expr const &a, expr const &b)
Definition z3++.h:2039
func_decl tree_order(sort const &a, unsigned index)
Definition z3++.h:2304
expr concat(expr const &a, expr const &b)
Definition z3++.h:2481
expr bvmul_no_underflow(expr const &a, expr const &b)
Definition z3++.h:2285
expr lambda(expr const &x, expr const &b)
Definition z3++.h:2398
ast_vector_tpl< func_decl > func_decl_vector
Definition z3++.h:78
expr fpa_to_fpa(expr const &t, sort s)
Definition z3++.h:2092
void reset_params()
Definition z3++.h:83
expr operator&&(expr const &a, expr const &b)
Definition z3++.h:1698
std::function< void(expr const &proof, std::vector< unsigned > const &deps, expr_vector const &clause)> on_clause_eh_t
Definition z3++.h:4317
expr operator!=(expr const &a, expr const &b)
Definition z3++.h:1734
expr operator+(expr const &a, expr const &b)
Definition z3++.h:1746
expr set_complement(expr const &a)
Definition z3++.h:4097
check_result
Definition z3++.h:135
@ unknown
Definition z3++.h:136
@ sat
Definition z3++.h:136
@ unsat
Definition z3++.h:136
bool eq(ast const &a, ast const &b)
Definition z3++.h:601
func_decl recfun(symbol const &name, unsigned arity, sort const *domain, sort const &range)
Definition z3++.h:3990
expr const_array(sort const &d, expr const &v)
Definition z3++.h:4057
expr min(expr const &a, expr const &b)
Definition z3++.h:1968
expr set_difference(expr const &a, expr const &b)
Definition z3++.h:4093
expr forall(expr const &x, expr const &b)
Definition z3++.h:2350
expr operator>(expr const &a, expr const &b)
Definition z3++.h:1931
sort to_sort(context &c, Z3_sort s)
Definition z3++.h:2133
expr to_expr(context &c, Z3_ast a)
Wraps a Z3_ast as an expr object. It also checks for errors. This function allows the user to use the...
Definition z3++.h:2124
expr bv2int(expr const &a, bool is_signed)
bit-vector and integer conversions.
Definition z3++.h:2258
expr operator%(expr const &a, expr const &b)
Definition z3++.h:1669
expr operator~(expr const &a)
Definition z3++.h:2046
expr sle(expr const &a, expr const &b)
signed less than or equal to operator for bitvectors.
Definition z3++.h:2146
expr nor(expr const &a, expr const &b)
Definition z3++.h:1966
expr fpa_fp(expr const &sgn, expr const &exp, expr const &sig)
Definition z3++.h:2056
expr bvsub_no_underflow(expr const &a, expr const &b, bool is_signed)
Definition z3++.h:2273
expr mk_xor(expr_vector const &args)
Definition z3++.h:2565
expr lshr(expr const &a, expr const &b)
logic shift right operator for bitvectors
Definition z3++.h:2239
expr operator*(expr const &a, expr const &b)
Definition z3++.h:1776
expr nand(expr const &a, expr const &b)
Definition z3++.h:1965
expr fpa_to_ubv(expr const &t, unsigned sz)
Definition z3++.h:2071
expr bvredor(expr const &a)
Definition z3++.h:2000
ast_vector_tpl< sort > sort_vector
Definition z3++.h:77
func_decl piecewise_linear_order(sort const &a, unsigned index)
Definition z3++.h:2301
expr slt(expr const &a, expr const &b)
signed less than operator for bitvectors.
Definition z3++.h:2152
tactic when(probe const &p, tactic const &t)
Definition z3++.h:3497
expr last_indexof(expr const &s, expr const &substr)
Definition z3++.h:4136
expr int2bv(unsigned n, expr const &a)
Definition z3++.h:2259
expr max(expr const &a, expr const &b)
Definition z3++.h:1984
expr xnor(expr const &a, expr const &b)
Definition z3++.h:1967
expr udiv(expr const &a, expr const &b)
unsigned division operator for bitvectors.
Definition z3++.h:2204
expr abs(expr const &a)
Definition z3++.h:2012
expr pbge(expr_vector const &es, int const *coeffs, int bound)
Definition z3++.h:2431
expr round_fpa_to_closest_integer(expr const &t)
Definition z3++.h:2099
expr distinct(expr_vector const &args)
Definition z3++.h:2472
expr ashr(expr const &a, expr const &b)
arithmetic shift right operator for bitvectors
Definition z3++.h:2246
expr bvmul_no_overflow(expr const &a, expr const &b, bool is_signed)
Definition z3++.h:2282
expr bvsub_no_overflow(expr const &a, expr const &b)
Definition z3++.h:2270
expr star(expr const &re)
Definition z3++.h:4154
expr urem(expr const &a, expr const &b)
unsigned reminder operator for bitvectors
Definition z3++.h:2225
tactic repeat(tactic const &t, unsigned max=UINT_MAX)
Definition z3++.h:3162
expr mod(expr const &a, expr const &b)
Definition z3++.h:1658
expr fma(expr const &a, expr const &b, expr const &c, expr const &rm)
Definition z3++.h:2048
check_result to_check_result(Z3_lbool l)
Definition z3++.h:147
expr mk_or(expr_vector const &args)
Definition z3++.h:2553
expr to_re(expr const &s)
Definition z3++.h:4142
void check_context(object const &a, object const &b)
Definition z3++.h:495
std::ostream & operator<<(std::ostream &out, exception const &e)
Definition z3++.h:97
expr ule(expr const &a, expr const &b)
unsigned less than or equal to operator for bitvectors.
Definition z3++.h:2172
func_decl to_func_decl(context &c, Z3_func_decl f)
Definition z3++.h:2138
tactic with(tactic const &t, params const &p)
Definition z3++.h:3168
expr ite(expr const &c, expr const &t, expr const &e)
Create the if-then-else expression ite(c, t, e)
Definition z3++.h:2111
expr ult(expr const &a, expr const &b)
unsigned less than operator for bitvectors.
Definition z3++.h:2178
expr pbeq(expr_vector const &es, int const *coeffs, int bound)
Definition z3++.h:2439
expr operator^(expr const &a, expr const &b)
Definition z3++.h:1957
expr operator<=(expr const &a, expr const &b)
Definition z3++.h:1884
expr set_union(expr const &a, expr const &b)
Definition z3++.h:4077
expr operator>=(expr const &a, expr const &b)
Definition z3++.h:1800
func_decl linear_order(sort const &a, unsigned index)
Definition z3++.h:2295
expr sqrt(expr const &a, expr const &rm)
Definition z3++.h:2032
expr pble(expr_vector const &es, int const *coeffs, int bound)
Definition z3++.h:2423
expr operator==(expr const &a, expr const &b)
Definition z3++.h:1723
expr foldli(expr const &f, expr const &i, expr const &a, expr const &list)
Definition z3++.h:2546
expr full_set(sort const &s)
Definition z3++.h:4065
expr smod(expr const &a, expr const &b)
signed modulus operator for bitvectors
Definition z3++.h:2218
expr implies(expr const &a, expr const &b)
Definition z3++.h:1646
expr empty_set(sort const &s)
Definition z3++.h:4061
expr in_re(expr const &s, expr const &re)
Definition z3++.h:4145
expr bvadd_no_overflow(expr const &a, expr const &b, bool is_signed)
bit-vector overflow/underflow checks
Definition z3++.h:2264
expr suffixof(expr const &a, expr const &b)
Definition z3++.h:4118
expr re_diff(expr const &a, expr const &b)
Definition z3++.h:4175
expr set_add(expr const &s, expr const &e)
Definition z3++.h:4069
expr plus(expr const &re)
Definition z3++.h:4148
expr set_subset(expr const &a, expr const &b)
Definition z3++.h:4105
expr select(expr const &a, expr const &i)
forward declarations
Definition z3++.h:4003
expr bvredand(expr const &a)
Definition z3++.h:2006
expr operator&(expr const &a, expr const &b)
Definition z3++.h:1953
expr operator-(expr const &a)
Definition z3++.h:1842
expr set_member(expr const &s, expr const &e)
Definition z3++.h:4101
expr bvsdiv_no_overflow(expr const &a, expr const &b)
Definition z3++.h:2276
tactic try_for(tactic const &t, unsigned ms)
Definition z3++.h:3173
void set_param(char const *param, char const *value)
Definition z3++.h:80
expr sdiv(expr const &a, expr const &b)
signed division operator for bitvectors.
Definition z3++.h:2197
func_decl function(symbol const &name, unsigned arity, sort const *domain, sort const &range)
Definition z3++.h:3962
func_decl partial_order(sort const &a, unsigned index)
Definition z3++.h:2298
ast_vector_tpl< expr > expr_vector
Definition z3++.h:76
expr rem(expr const &a, expr const &b)
Definition z3++.h:1674
expr sge(expr const &a, expr const &b)
signed greater than or equal to operator for bitvectors.
Definition z3++.h:2158
expr is_int(expr const &e)
Definition z3++.h:1694
expr operator!(expr const &a)
Definition z3++.h:1692
expr re_empty(sort const &s)
Definition z3++.h:4157
expr foldl(expr const &f, expr const &a, expr const &list)
Definition z3++.h:2539
expr mk_and(expr_vector const &args)
Definition z3++.h:2559
rounding_mode
Definition z3++.h:139
@ RNE
Definition z3++.h:141
@ RNA
Definition z3++.h:140
@ RTZ
Definition z3++.h:144
@ RTN
Definition z3++.h:143
@ RTP
Definition z3++.h:142
expr sext(expr const &a, unsigned i)
Sign-extend of the given bit-vector to the (signed) equivalent bitvector of size m+i,...
Definition z3++.h:2293
expr to_real(expr const &a)
Definition z3++.h:3960
expr shl(expr const &a, expr const &b)
shift left operator for bitvectors
Definition z3++.h:2232
expr operator||(expr const &a, expr const &b)
Definition z3++.h:1710
expr set_del(expr const &s, expr const &e)
Definition z3++.h:4073
expr ubv_to_fpa(expr const &t, sort s)
Definition z3++.h:2085
expr map(expr const &f, expr const &list)
Definition z3++.h:2525
tactic cond(probe const &p, tactic const &t1, tactic const &t2)
Definition z3++.h:3503
expr as_array(func_decl &f)
Definition z3++.h:4040
expr sgt(expr const &a, expr const &b)
signed greater than operator for bitvectors.
Definition z3++.h:2164
expr fpa_to_sbv(expr const &t, unsigned sz)
Definition z3++.h:2064
ast_vector_tpl< ast > ast_vector
Definition z3++.h:75
expr operator|(expr const &a, expr const &b)
Definition z3++.h:1961
expr atmost(expr_vector const &es, unsigned bound)
Definition z3++.h:2447
expr range(expr const &lo, expr const &hi)
Definition z3++.h:4185
expr zext(expr const &a, unsigned i)
Extend the given bit-vector with zeros to the (unsigned) equivalent bitvector of size m+i,...
Definition z3++.h:2253
expr atleast(expr_vector const &es, unsigned bound)
Definition z3++.h:2455
expr uge(expr const &a, expr const &b)
unsigned greater than or equal to operator for bitvectors.
Definition z3++.h:2184
expr mapi(expr const &f, expr const &i, expr const &list)
Definition z3++.h:2532
expr operator<(expr const &a, expr const &b)
Definition z3++.h:1909
expr option(expr const &re)
Definition z3++.h:4151
expr re_full(sort const &s)
Definition z3++.h:4162
expr re_complement(expr const &a)
Definition z3++.h:4182
expr empty(sort const &s)
Definition z3++.h:4113
tactic fail_if(probe const &p)
Definition z3++.h:3492
#define _Z3_MK_BIN_(a, b, binop)
Definition z3++.h:1639
#define MK_EXPR1(_fn, _arg)
Definition z3++.h:4046
#define MK_EXPR2(_fn, _arg1, _arg2)
Definition z3++.h:4051
#define Z3_THROW(x)
Definition z3++.h:103
#define _Z3_MK_UN_(a, mkun)
Definition z3++.h:1686