Z3
Public Member Functions | Friends
context Class Reference

A Context manages all other Z3 objects, global configuration options, etc. More...

Public Member Functions

 context ()
 
 context (config &c)
 
 context (context &&other) noexcept
 
contextoperator= (context &&other) noexcept
 
 ~context ()
 
 operator Z3_context () const
 
Z3_error_code check_error () const
 Auxiliary method used to check for API usage errors. More...
 
void check_parser_error () const
 
void set_enable_exceptions (bool f)
 The C++ API uses by defaults exceptions on errors. For applications that don't work well with exceptions (there should be only few) you have the ability to turn off exceptions. The tradeoffs are that applications have to be very careful about using check_error() after calls that may result in an erroneous state. More...
 
bool enable_exceptions () const
 
void set (char const *param, char const *value)
 Update global parameter param with string value. More...
 
void set (char const *param, bool value)
 Update global parameter param with Boolean value. More...
 
void set (char const *param, int value)
 Update global parameter param with Integer value. More...
 
void interrupt ()
 Interrupt the current procedure being executed by any object managed by this context. This is a soft interruption: there is no guarantee the object will actually stop. More...
 
symbol str_symbol (char const *s)
 Create a Z3 symbol based on the given string. More...
 
symbol int_symbol (int n)
 Create a Z3 symbol based on the given integer. More...
 
sort bool_sort ()
 Return the Boolean sort. More...
 
sort int_sort ()
 Return the integer sort. More...
 
sort real_sort ()
 Return the Real sort. More...
 
sort bv_sort (unsigned sz)
 Return the Bit-vector sort of size sz. That is, the sort for bit-vectors of size sz. More...
 
sort char_sort ()
 Return the sort for Unicode characters. More...
 
sort string_sort ()
 Return the sort for Unicode strings. More...
 
sort seq_sort (sort &s)
 Return a sequence sort over base sort s. More...
 
sort re_sort (sort &seq_sort)
 Return a regular expression sort over sequences seq_sort. More...
 
sort array_sort (sort d, sort r)
 Return an array sort for arrays from d to r. More...
 
sort array_sort (sort_vector const &d, sort r)
 
sort fpa_sort (unsigned ebits, unsigned sbits)
 Return a floating point sort. ebits is a number of exponent bits, sbits is a number of significand bits,. More...
 
template<size_t precision>
sort fpa_sort ()
 Return a FloatingPoint sort with given precision bitwidth (16, 32, 64 or 128). More...
 
sort fpa_rounding_mode_sort ()
 Return a RoundingMode sort. More...
 
void set_rounding_mode (rounding_mode rm)
 Sets RoundingMode of FloatingPoints. More...
 
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. The method stores in cs the constants corresponding to the enumerated elements, and in ts the predicates for testing if terms of the enumeration sort correspond to an enumeration. More...
 
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 arguments, names and sorts are their projected sorts. projs is an output parameter. It contains the set of projection functions. More...
 
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 number of constructors of the datatype cs - the n constructors used to define the datatype. More...
 
sort datatype (symbol const &name, sort_vector const &params, constructors const &cs)
 Create a parametric recursive datatype. name is the name of the recursive datatype params - the sort parameters of the datatype cs - the n constructors used to define the datatype References to the datatype and mutually recursive datatypes can be created using datatype_sort. More...
 
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 names of length n cons - array of constructor lists of length n. More...
 
sort datatype_sort (symbol const &name)
 a reference to a recursively defined datatype. Expect that it gets defined as a datatype. More...
 
sort datatype_sort (symbol const &name, sort_vector const &params)
 a reference to a recursively defined parametric datatype. Expect that it gets defined as a datatype. More...
 
sort uninterpreted_sort (char const *name)
 create an uninterpreted sort with the name given by the string or symbol. More...
 
sort uninterpreted_sort (symbol const &name)
 
func_decl function (symbol const &name, unsigned arity, sort const *domain, sort const &range)
 
func_decl function (char const *name, unsigned arity, sort const *domain, sort const &range)
 
func_decl function (symbol const &name, sort_vector const &domain, sort const &range)
 
func_decl function (char const *name, sort_vector const &domain, sort const &range)
 
func_decl function (char const *name, sort const &domain, sort const &range)
 
func_decl function (char const *name, sort const &d1, sort const &d2, sort const &range)
 
func_decl function (char const *name, sort const &d1, sort const &d2, sort const &d3, sort const &range)
 
func_decl function (char const *name, sort const &d1, sort const &d2, sort const &d3, sort const &d4, sort const &range)
 
func_decl function (char const *name, sort const &d1, sort const &d2, sort const &d3, sort const &d4, sort const &d5, sort const &range)
 
func_decl recfun (symbol const &name, unsigned arity, sort const *domain, sort const &range)
 
func_decl recfun (symbol const &name, const sort_vector &domain, sort const &range)
 
func_decl recfun (char const *name, sort_vector const &domain, sort const &range)
 
func_decl recfun (char const *name, unsigned arity, sort const *domain, sort const &range)
 
func_decl recfun (char const *name, sort const &domain, sort const &range)
 
func_decl recfun (char const *name, sort const &d1, sort const &d2, sort const &range)
 
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. More...
 
func_decl user_propagate_function (symbol const &name, sort_vector const &domain, sort const &range)
 
expr constant (symbol const &name, sort const &s)
 create an uninterpreted constant. More...
 
expr constant (char const *name, sort const &s)
 
expr bool_const (char const *name)
 create uninterpreted constants of a given sort. More...
 
expr int_const (char const *name)
 
expr real_const (char const *name)
 
expr string_const (char const *name)
 
expr bv_const (char const *name, unsigned sz)
 
expr fpa_const (char const *name, unsigned ebits, unsigned sbits)
 
template<size_t precision>
expr fpa_const (char const *name)
 
expr variable (unsigned index, sort const &s)
 create a de-Bruijn variable. More...
 
expr fpa_rounding_mode ()
 
expr bool_val (bool b)
 
expr int_val (int n)
 
expr int_val (unsigned n)
 
expr int_val (int64_t n)
 
expr int_val (uint64_t n)
 
expr int_val (char const *n)
 
expr real_val (int n)
 
expr real_val (unsigned n)
 
expr real_val (int64_t n)
 
expr real_val (uint64_t n)
 
expr real_val (int64_t n, int64_t d)
 
expr real_val (char const *n)
 
expr bv_val (int n, unsigned sz)
 
expr bv_val (unsigned n, unsigned sz)
 
expr bv_val (int64_t n, unsigned sz)
 
expr bv_val (uint64_t n, unsigned sz)
 
expr bv_val (char const *n, unsigned sz)
 
expr bv_val (unsigned n, bool const *bits)
 
expr fpa_val (double n)
 
expr fpa_val (float n)
 
expr fpa_nan (sort const &s)
 
expr fpa_inf (sort const &s, bool sgn)
 
expr string_val (char const *s)
 
expr string_val (char const *s, unsigned n)
 
expr string_val (std::string const &s)
 
expr string_val (std::u32string const &s)
 
expr num_val (int n, sort const &s)
 
expr_vector parse_string (char const *s)
 parsing More...
 
expr_vector parse_file (char const *file)
 
expr_vector parse_string (char const *s, sort_vector const &sorts, func_decl_vector const &decls)
 
expr_vector parse_file (char const *s, sort_vector const &sorts, func_decl_vector const &decls)
 
template<>
sort fpa_sort ()
 
template<>
sort fpa_sort ()
 
template<>
sort fpa_sort ()
 
template<>
sort fpa_sort ()
 

Friends

class user_propagator_base
 

Detailed Description

A Context manages all other Z3 objects, global configuration options, etc.

Definition at line 191 of file z3++.h.

Constructor & Destructor Documentation

context ( )
inline

Definition at line 215 of file z3++.h.

215 { config c; init(c); }
context ( config c)
inline

Definition at line 216 of file z3++.h.

216 { init(c); }
context ( context &&  other)
inlinenoexcept

Definition at line 218 of file z3++.h.

219  : m_enable_exceptions(other.m_enable_exceptions),
220  m_rounding_mode(other.m_rounding_mode),
221  m_ctx(other.m_ctx) {
222  other.m_ctx = nullptr;
223  }
~context ( )
inline

Definition at line 235 of file z3++.h.

235 { if (m_ctx) Z3_del_context(m_ctx); }
void Z3_API Z3_del_context(Z3_context c)
Delete the given logical context.

Member Function Documentation

sort array_sort ( sort  d,
sort  r 
)
inline

Return an array sort for arrays from d to r.

Example: Given a context c, c.array_sort(c.int_sort(), c.bool_sort()) is an array sort from integer to Boolean.

Definition at line 3682 of file z3++.h.

3682 { Z3_sort s = Z3_mk_array_sort(m_ctx, d, r); check_error(); return sort(*this, s); }
Z3_sort Z3_API Z3_mk_array_sort(Z3_context c, Z3_sort domain, Z3_sort range)
Create an array type.
Z3_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
sort array_sort ( sort_vector const &  d,
sort  r 
)
inline

Definition at line 3683 of file z3++.h.

3683  {
3684  array<Z3_sort> dom(d);
3685  Z3_sort s = Z3_mk_array_sort_n(m_ctx, dom.size(), dom.ptr(), r); check_error(); return sort(*this, s);
3686  }
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_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
expr bool_const ( char const *  name)
inline

create uninterpreted constants of a given sort.

Definition at line 3962 of file z3++.h.

3962 { return constant(name, bool_sort()); }
sort bool_sort()
Return the Boolean sort.
Definition: z3++.h:3658
expr constant(symbol const &name, sort const &s)
create an uninterpreted constant.
Definition: z3++.h:3951
sort bool_sort ( )
inline

Return the Boolean sort.

Definition at line 3658 of file z3++.h.

Referenced by context::bool_const().

3658 { Z3_sort s = Z3_mk_bool_sort(m_ctx); check_error(); return sort(*this, s); }
Z3_sort Z3_API Z3_mk_bool_sort(Z3_context c)
Create the Boolean type.
Z3_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
expr bool_val ( bool  b)
inline

Definition at line 3985 of file z3++.h.

Referenced by goal::as_expr(), user_propagator_base::conflict(), z3::implies(), z3::mk_xor(), z3::operator&&(), z3::operator||(), and solver::to_smt2().

3985 { return b ? expr(*this, Z3_mk_true(m_ctx)) : expr(*this, Z3_mk_false(m_ctx)); }
Z3_ast Z3_API Z3_mk_true(Z3_context c)
Create an AST node representing true.
Z3_ast Z3_API Z3_mk_false(Z3_context c)
Create an AST node representing false.
expr bv_const ( char const *  name,
unsigned  sz 
)
inline

Definition at line 3966 of file z3++.h.

3966 { return constant(name, bv_sort(sz)); }
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:3661
expr constant(symbol const &name, sort const &s)
create an uninterpreted constant.
Definition: z3++.h:3951
sort bv_sort ( unsigned  sz)
inline

Return the Bit-vector sort of size sz. That is, the sort for bit-vectors of size sz.

Definition at line 3661 of file z3++.h.

Referenced by context::bv_const(), and context::bv_val().

3661 { Z3_sort s = Z3_mk_bv_sort(m_ctx, sz); check_error(); return sort(*this, s); }
Z3_sort Z3_API Z3_mk_bv_sort(Z3_context c, unsigned sz)
Create a bit-vector type of the given size.
Z3_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
expr bv_val ( int  n,
unsigned  sz 
)
inline

Definition at line 4000 of file z3++.h.

4000 { sort s = bv_sort(sz); Z3_ast r = Z3_mk_int(m_ctx, n, s); check_error(); return expr(*this, r); }
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:3661
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_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
expr bv_val ( unsigned  n,
unsigned  sz 
)
inline

Definition at line 4001 of file z3++.h.

4001 { sort s = bv_sort(sz); Z3_ast r = Z3_mk_unsigned_int(m_ctx, n, s); check_error(); return expr(*this, r); }
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.
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:3661
Z3_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
expr bv_val ( int64_t  n,
unsigned  sz 
)
inline

Definition at line 4002 of file z3++.h.

4002 { sort s = bv_sort(sz); Z3_ast r = Z3_mk_int64(m_ctx, n, s); check_error(); return expr(*this, r); }
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.
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:3661
Z3_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
expr bv_val ( uint64_t  n,
unsigned  sz 
)
inline

Definition at line 4003 of file z3++.h.

4003 { sort s = bv_sort(sz); Z3_ast r = Z3_mk_unsigned_int64(m_ctx, n, s); check_error(); return expr(*this, r); }
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:3661
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_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
expr bv_val ( char const *  n,
unsigned  sz 
)
inline

Definition at line 4004 of file z3++.h.

4004 { sort s = bv_sort(sz); Z3_ast r = Z3_mk_numeral(m_ctx, n, s); check_error(); return expr(*this, r); }
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:3661
Z3_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
Z3_ast Z3_API Z3_mk_numeral(Z3_context c, Z3_string numeral, Z3_sort ty)
Create a numeral of a given sort.
expr bv_val ( unsigned  n,
bool const *  bits 
)
inline

Definition at line 4005 of file z3++.h.

4005  {
4006  array<bool> _bits(n);
4007  for (unsigned i = 0; i < n; ++i) _bits[i] = bits[i] ? 1 : 0;
4008  Z3_ast r = Z3_mk_bv_numeral(m_ctx, n, _bits.ptr()); check_error(); return expr(*this, r);
4009  }
Z3_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
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.
sort char_sort ( )
inline

Return the sort for Unicode characters.

Definition at line 3663 of file z3++.h.

3663 { Z3_sort s = Z3_mk_char_sort(m_ctx); check_error(); return sort(*this, s); }
Z3_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
Z3_sort Z3_API Z3_mk_char_sort(Z3_context c)
Create a sort for unicode characters.
Z3_error_code check_error ( ) const
inline

Auxiliary method used to check for API usage errors.

Definition at line 241 of file z3++.h.

Referenced by context::array_sort(), expr::bit2bool(), context::bool_sort(), context::bv_sort(), context::bv_val(), context::char_sort(), object::check_error(), context::check_parser_error(), z3::concat(), context::constant(), context::datatype(), context::datatype_sort(), context::enumeration_sort(), expr::extract(), z3::foldl(), z3::foldli(), context::fpa_inf(), context::fpa_nan(), context::fpa_rounding_mode_sort(), context::fpa_sort(), context::fpa_val(), context::function(), context::int_sort(), context::int_symbol(), context::int_val(), z3::map(), z3::mapi(), context::num_val(), on_clause::on_clause(), func_decl::operator()(), context::parse_file(), context::parse_string(), z3::re_diff(), context::re_sort(), context::real_sort(), context::real_val(), context::recfun(), expr::repeat(), expr::rotate_left(), expr::rotate_right(), context::seq_sort(), context::str_symbol(), context::string_sort(), context::string_val(), z3::to_expr(), z3::to_func_decl(), z3::to_sort(), context::tuple_sort(), context::user_propagate_function(), and context::variable().

241  {
242  Z3_error_code e = Z3_get_error_code(m_ctx);
243  if (e != Z3_OK && enable_exceptions())
244  Z3_THROW(exception(Z3_get_error_msg(m_ctx, e)));
245  return e;
246  }
Z3_string Z3_API Z3_get_error_msg(Z3_context c, Z3_error_code err)
Return a string describing the given error code.
#define Z3_THROW(x)
Definition: z3++.h:134
Definition: z3_api.h:1348
Z3_error_code
Z3 error codes (See Z3_get_error_code).
Definition: z3_api.h:1346
bool enable_exceptions() const
Definition: z3++.h:261
Z3_error_code Z3_API Z3_get_error_code(Z3_context c)
Return the error code for the last API call.
void check_parser_error ( ) const
inline

Definition at line 248 of file z3++.h.

Referenced by solver::from_file(), and solver::from_string().

248  {
249  check_error();
250  }
Z3_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
expr constant ( symbol const &  name,
sort const &  s 
)
inline

create an uninterpreted constant.

Definition at line 3951 of file z3++.h.

Referenced by context::bool_const(), context::bv_const(), context::constant(), context::fpa_const(), context::int_const(), context::real_const(), and context::string_const().

3951  {
3952  Z3_ast r = Z3_mk_const(m_ctx, name, s);
3953  check_error();
3954  return expr(*this, r);
3955  }
Z3_ast Z3_API Z3_mk_const(Z3_context c, Z3_symbol s, Z3_sort ty)
Declare and create a constant.
Z3_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
expr constant ( char const *  name,
sort const &  s 
)
inline

Definition at line 3956 of file z3++.h.

3956 { return constant(str_symbol(name), s); }
symbol str_symbol(char const *s)
Create a Z3 symbol based on the given string.
Definition: z3++.h:3655
expr constant(symbol const &name, sort const &s)
create an uninterpreted constant.
Definition: z3++.h:3951
sort datatype ( symbol const &  name,
constructors const &  cs 
)
inline

Create a recursive datatype over a single sort. name is the name of the recursive datatype n - the number of constructors of the datatype cs - the n constructors used to define the datatype.

References to the datatype can be created using datatype_sort.

Definition at line 3772 of file z3++.h.

3772  {
3773  array<Z3_constructor> _cs(cs.size());
3774  for (unsigned i = 0; i < cs.size(); ++i) _cs[i] = cs[i];
3775  Z3_sort s = Z3_mk_datatype(*this, name, cs.size(), _cs.ptr());
3776  check_error();
3777  return sort(*this, s);
3778  }
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. The datatype may be recursive. Return the datatype sort.
Z3_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
sort datatype ( symbol const &  name,
sort_vector const &  params,
constructors const &  cs 
)
inline

Create a parametric recursive datatype. name is the name of the recursive datatype params - the sort parameters of the datatype cs - the n constructors used to define the datatype References to the datatype and mutually recursive datatypes can be created using datatype_sort.

Definition at line 3780 of file z3++.h.

3780  {
3781  array<Z3_sort> _params(params);
3782  array<Z3_constructor> _cs(cs.size());
3783  for (unsigned i = 0; i < cs.size(); ++i)
3784  _cs[i] = cs[i];
3785  Z3_sort s = Z3_mk_polymorphic_datatype(*this, name, _params.size(), _params.ptr(), cs.size(), _cs.ptr());
3786  check_error();
3787  return sort(*this, s);
3788  }
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_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
sort datatype_sort ( symbol const &  name)
inline

a reference to a recursively defined datatype. Expect that it gets defined as a datatype.

Definition at line 3806 of file z3++.h.

3806  {
3807  Z3_sort s = Z3_mk_datatype_sort(*this, name, 0, nullptr);
3808  check_error();
3809  return sort(*this, s);
3810  }
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_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
sort datatype_sort ( symbol const &  name,
sort_vector const &  params 
)
inline

a reference to a recursively defined parametric datatype. Expect that it gets defined as a datatype.

Parameters
namename of the datatype
paramssort parameters

Definition at line 3812 of file z3++.h.

3812  {
3813  array<Z3_sort> _params(params);
3814  Z3_sort s = Z3_mk_datatype_sort(*this, name, _params.size(), _params.ptr());
3815  check_error();
3816  return sort(*this, s);
3817  }
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_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
sort_vector datatypes ( unsigned  n,
symbol const *  names,
constructor_list *const *  cons 
)
inline

Create a set of mutually recursive datatypes. n - number of recursive datatypes names - array of names of length n cons - array of constructor lists of length n.

Definition at line 3790 of file z3++.h.

3792  {
3793  sort_vector result(*this);
3794  array<Z3_symbol> _names(n);
3795  array<Z3_sort> _sorts(n);
3796  array<Z3_constructor_list> _cons(n);
3797  for (unsigned i = 0; i < n; ++i)
3798  _names[i] = names[i], _cons[i] = *cons[i];
3799  Z3_mk_datatypes(*this, n, _names.ptr(), _sorts.ptr(), _cons.ptr());
3800  for (unsigned i = 0; i < n; ++i)
3801  result.push_back(sort(*this, _sorts[i]));
3802  return result;
3803  }
ast_vector_tpl< sort > sort_vector
Definition: z3++.h:78
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.
bool enable_exceptions ( ) const
inline

Definition at line 261 of file z3++.h.

Referenced by context::check_error().

261 { return m_enable_exceptions; }
sort enumeration_sort ( char const *  name,
unsigned  n,
char const *const *  enum_names,
func_decl_vector cs,
func_decl_vector ts 
)
inline

Return an enumeration sort: enum_names[0], ..., enum_names[n-1]. cs and ts are output parameters. The method stores in cs the constants corresponding to the enumerated elements, and in ts the predicates for testing if terms of the enumeration sort correspond to an enumeration.

Definition at line 3687 of file z3++.h.

3687  {
3688  array<Z3_symbol> _enum_names(n);
3689  for (unsigned i = 0; i < n; ++i) { _enum_names[i] = Z3_mk_string_symbol(*this, enum_names[i]); }
3690  array<Z3_func_decl> _cs(n);
3691  array<Z3_func_decl> _ts(n);
3692  Z3_symbol _name = Z3_mk_string_symbol(*this, name);
3693  sort s = to_sort(*this, Z3_mk_enumeration_sort(*this, _name, n, _enum_names.ptr(), _cs.ptr(), _ts.ptr()));
3694  check_error();
3695  for (unsigned i = 0; i < n; ++i) { cs.push_back(func_decl(*this, _cs[i])); ts.push_back(func_decl(*this, _ts[i])); }
3696  return s;
3697  }
Z3_symbol Z3_API Z3_mk_string_symbol(Z3_context c, Z3_string s)
Create a Z3 symbol using a C string.
Z3_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
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.
sort to_sort(context &c, Z3_sort s)
Definition: z3++.h:2203
expr fpa_const ( char const *  name,
unsigned  ebits,
unsigned  sbits 
)
inline

Definition at line 3967 of file z3++.h.

3967 { return constant(name, fpa_sort(ebits, sbits)); }
expr constant(symbol const &name, sort const &s)
create an uninterpreted constant.
Definition: z3++.h:3951
sort fpa_sort()
Return a FloatingPoint sort with given precision bitwidth (16, 32, 64 or 128).
expr fpa_const ( char const *  name)
inline

Definition at line 3970 of file z3++.h.

3970 { return constant(name, fpa_sort<precision>()); }
expr constant(symbol const &name, sort const &s)
create an uninterpreted constant.
Definition: z3++.h:3951
expr fpa_inf ( sort const &  s,
bool  sgn 
)
inline

Definition at line 4014 of file z3++.h.

4014 { Z3_ast r = Z3_mk_fpa_inf(m_ctx, s, sgn); check_error(); return expr(*this, r); }
Z3_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
Z3_ast Z3_API Z3_mk_fpa_inf(Z3_context c, Z3_sort s, bool negative)
Create a floating-point infinity of sort s.
expr fpa_nan ( sort const &  s)
inline

Definition at line 4013 of file z3++.h.

4013 { Z3_ast r = Z3_mk_fpa_nan(m_ctx, s); check_error(); return expr(*this, r); }
Z3_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
Z3_ast Z3_API Z3_mk_fpa_nan(Z3_context c, Z3_sort s)
Create a floating-point NaN of sort s.
expr fpa_rounding_mode ( )
inline

Definition at line 3974 of file z3++.h.

Referenced by z3::fpa_to_fpa(), z3::fpa_to_sbv(), z3::fpa_to_ubv(), z3::operator*(), z3::operator+(), z3::operator-(), z3::operator/(), z3::round_fpa_to_closest_integer(), z3::sbv_to_fpa(), and z3::ubv_to_fpa().

3974  {
3975  switch (m_rounding_mode) {
3976  case RNA: return expr(*this, Z3_mk_fpa_rna(m_ctx));
3977  case RNE: return expr(*this, Z3_mk_fpa_rne(m_ctx));
3978  case RTP: return expr(*this, Z3_mk_fpa_rtp(m_ctx));
3979  case RTN: return expr(*this, Z3_mk_fpa_rtn(m_ctx));
3980  case RTZ: return expr(*this, Z3_mk_fpa_rtz(m_ctx));
3981  default: return expr(*this);
3982  }
3983  }
Z3_ast Z3_API Z3_mk_fpa_rtz(Z3_context c)
Create a numeral of RoundingMode sort which represents the TowardZero rounding mode.
Definition: z3++.h:174
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_fpa_rtn(Z3_context c)
Create a numeral of RoundingMode sort which represents the TowardNegative rounding mode...
Z3_ast Z3_API Z3_mk_fpa_rtp(Z3_context c)
Create a numeral of RoundingMode sort which represents the TowardPositive rounding mode...
Definition: z3++.h:171
Z3_ast Z3_API Z3_mk_fpa_rna(Z3_context c)
Create a numeral of RoundingMode sort which represents the NearestTiesToAway rounding mode...
Definition: z3++.h:175
Definition: z3++.h:173
Definition: z3++.h:172
sort fpa_rounding_mode_sort ( )
inline

Return a RoundingMode sort.

Definition at line 3680 of file z3++.h.

3680 { Z3_sort r = Z3_mk_fpa_rounding_mode_sort(m_ctx); check_error(); return sort(*this, r); }
Z3_sort Z3_API Z3_mk_fpa_rounding_mode_sort(Z3_context c)
Create the RoundingMode sort.
Z3_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
sort fpa_sort ( unsigned  ebits,
unsigned  sbits 
)
inline

Return a floating point sort. ebits is a number of exponent bits, sbits is a number of significand bits,.

Precondition
where ebits must be larger than 1 and sbits must be larger than 2.

Definition at line 3666 of file z3++.h.

3666 { Z3_sort s = Z3_mk_fpa_sort(m_ctx, ebits, sbits); check_error(); return sort(*this, s); }
Z3_sort Z3_API Z3_mk_fpa_sort(Z3_context c, unsigned ebits, unsigned sbits)
Create a FloatingPoint sort.
Z3_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
sort fpa_sort ( )

Return a FloatingPoint sort with given precision bitwidth (16, 32, 64 or 128).

Referenced by context::fpa_const().

sort fpa_sort ( )
inline

Definition at line 3669 of file z3++.h.

Referenced by context::fpa_sort().

3669 { return fpa_sort(5, 11); }
sort fpa_sort()
Return a FloatingPoint sort with given precision bitwidth (16, 32, 64 or 128).
sort fpa_sort ( )
inline

Definition at line 3672 of file z3++.h.

Referenced by context::fpa_sort().

3672 { return fpa_sort(8, 24); }
sort fpa_sort()
Return a FloatingPoint sort with given precision bitwidth (16, 32, 64 or 128).
sort fpa_sort ( )
inline

Definition at line 3675 of file z3++.h.

Referenced by context::fpa_sort().

3675 { return fpa_sort(11, 53); }
sort fpa_sort()
Return a FloatingPoint sort with given precision bitwidth (16, 32, 64 or 128).
sort fpa_sort ( )
inline

Definition at line 3678 of file z3++.h.

Referenced by context::fpa_sort().

3678 { return fpa_sort(15, 113); }
sort fpa_sort()
Return a FloatingPoint sort with given precision bitwidth (16, 32, 64 or 128).
expr fpa_val ( double  n)
inline

Definition at line 4011 of file z3++.h.

Referenced by z3::operator!=(), and z3::operator==().

4011 { sort s = fpa_sort<64>(); Z3_ast r = Z3_mk_fpa_numeral_double(m_ctx, n, s); check_error(); return expr(*this, r); }
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.
Z3_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
expr fpa_val ( float  n)
inline

Definition at line 4012 of file z3++.h.

4012 { sort s = fpa_sort<32>(); Z3_ast r = Z3_mk_fpa_numeral_float(m_ctx, n, s); check_error(); return expr(*this, r); }
Z3_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
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.
func_decl function ( symbol const &  name,
unsigned  arity,
sort const *  domain,
sort const &  range 
)
inline

Definition at line 3828 of file z3++.h.

Referenced by z3::function().

3828  {
3829  array<Z3_sort> args(arity);
3830  for (unsigned i = 0; i < arity; ++i) {
3831  check_context(domain[i], range);
3832  args[i] = domain[i];
3833  }
3834  Z3_func_decl f = Z3_mk_func_decl(m_ctx, name, arity, args.ptr(), range);
3835  check_error();
3836  return func_decl(*this, f);
3837  }
expr range(expr const &lo, expr const &hi)
Definition: z3++.h:4343
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.
void check_context(object const &a, object const &b)
Definition: z3++.h:544
Z3_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
func_decl function ( char const *  name,
unsigned  arity,
sort const *  domain,
sort const &  range 
)
inline

Definition at line 3839 of file z3++.h.

3839  {
3840  return function(range.ctx().str_symbol(name), arity, domain, range);
3841  }
symbol str_symbol(char const *s)
Create a Z3 symbol based on the given string.
Definition: z3++.h:3655
expr range(expr const &lo, expr const &hi)
Definition: z3++.h:4343
context & ctx() const
Definition: z3++.h:540
func_decl function ( symbol const &  name,
sort_vector const &  domain,
sort const &  range 
)
inline

Definition at line 3843 of file z3++.h.

3843  {
3844  array<Z3_sort> args(domain.size());
3845  for (unsigned i = 0; i < domain.size(); ++i) {
3846  check_context(domain[i], range);
3847  args[i] = domain[i];
3848  }
3849  Z3_func_decl f = Z3_mk_func_decl(m_ctx, name, domain.size(), args.ptr(), range);
3850  check_error();
3851  return func_decl(*this, f);
3852  }
expr range(expr const &lo, expr const &hi)
Definition: z3++.h:4343
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.
void check_context(object const &a, object const &b)
Definition: z3++.h:544
Z3_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
func_decl function ( char const *  name,
sort_vector const &  domain,
sort const &  range 
)
inline

Definition at line 3854 of file z3++.h.

3854  {
3855  return function(range.ctx().str_symbol(name), domain, range);
3856  }
symbol str_symbol(char const *s)
Create a Z3 symbol based on the given string.
Definition: z3++.h:3655
expr range(expr const &lo, expr const &hi)
Definition: z3++.h:4343
context & ctx() const
Definition: z3++.h:540
func_decl function ( char const *  name,
sort const &  domain,
sort const &  range 
)
inline

Definition at line 3859 of file z3++.h.

3859  {
3860  check_context(domain, range);
3861  Z3_sort args[1] = { domain };
3862  Z3_func_decl f = Z3_mk_func_decl(m_ctx, str_symbol(name), 1, args, range);
3863  check_error();
3864  return func_decl(*this, f);
3865  }
symbol str_symbol(char const *s)
Create a Z3 symbol based on the given string.
Definition: z3++.h:3655
expr range(expr const &lo, expr const &hi)
Definition: z3++.h:4343
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.
void check_context(object const &a, object const &b)
Definition: z3++.h:544
Z3_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
func_decl function ( char const *  name,
sort const &  d1,
sort const &  d2,
sort const &  range 
)
inline

Definition at line 3867 of file z3++.h.

3867  {
3869  Z3_sort args[2] = { d1, d2 };
3870  Z3_func_decl f = Z3_mk_func_decl(m_ctx, str_symbol(name), 2, args, range);
3871  check_error();
3872  return func_decl(*this, f);
3873  }
symbol str_symbol(char const *s)
Create a Z3 symbol based on the given string.
Definition: z3++.h:3655
expr range(expr const &lo, expr const &hi)
Definition: z3++.h:4343
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.
void check_context(object const &a, object const &b)
Definition: z3++.h:544
Z3_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
func_decl function ( char const *  name,
sort const &  d1,
sort const &  d2,
sort const &  d3,
sort const &  range 
)
inline

Definition at line 3875 of file z3++.h.

3875  {
3877  Z3_sort args[3] = { d1, d2, d3 };
3878  Z3_func_decl f = Z3_mk_func_decl(m_ctx, str_symbol(name), 3, args, range);
3879  check_error();
3880  return func_decl(*this, f);
3881  }
symbol str_symbol(char const *s)
Create a Z3 symbol based on the given string.
Definition: z3++.h:3655
expr range(expr const &lo, expr const &hi)
Definition: z3++.h:4343
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.
void check_context(object const &a, object const &b)
Definition: z3++.h:544
Z3_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
func_decl function ( char const *  name,
sort const &  d1,
sort const &  d2,
sort const &  d3,
sort const &  d4,
sort const &  range 
)
inline

Definition at line 3883 of file z3++.h.

3883  {
3885  Z3_sort args[4] = { d1, d2, d3, d4 };
3886  Z3_func_decl f = Z3_mk_func_decl(m_ctx, str_symbol(name), 4, args, range);
3887  check_error();
3888  return func_decl(*this, f);
3889  }
symbol str_symbol(char const *s)
Create a Z3 symbol based on the given string.
Definition: z3++.h:3655
expr range(expr const &lo, expr const &hi)
Definition: z3++.h:4343
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.
void check_context(object const &a, object const &b)
Definition: z3++.h:544
Z3_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
func_decl function ( char const *  name,
sort const &  d1,
sort const &  d2,
sort const &  d3,
sort const &  d4,
sort const &  d5,
sort const &  range 
)
inline

Definition at line 3891 of file z3++.h.

3891  {
3893  Z3_sort args[5] = { d1, d2, d3, d4, d5 };
3894  Z3_func_decl f = Z3_mk_func_decl(m_ctx, str_symbol(name), 5, args, range);
3895  check_error();
3896  return func_decl(*this, f);
3897  }
symbol str_symbol(char const *s)
Create a Z3 symbol based on the given string.
Definition: z3++.h:3655
expr range(expr const &lo, expr const &hi)
Definition: z3++.h:4343
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.
void check_context(object const &a, object const &b)
Definition: z3++.h:544
Z3_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
expr int_const ( char const *  name)
inline

Definition at line 3963 of file z3++.h.

3963 { return constant(name, int_sort()); }
expr constant(symbol const &name, sort const &s)
create an uninterpreted constant.
Definition: z3++.h:3951
sort int_sort()
Return the integer sort.
Definition: z3++.h:3659
sort int_sort ( )
inline

Return the integer sort.

Definition at line 3659 of file z3++.h.

Referenced by context::int_const(), and context::int_val().

3659 { Z3_sort s = Z3_mk_int_sort(m_ctx); check_error(); return sort(*this, s); }
Z3_sort Z3_API Z3_mk_int_sort(Z3_context c)
Create the integer type.
Z3_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
symbol int_symbol ( int  n)
inline

Create a Z3 symbol based on the given integer.

Definition at line 3656 of file z3++.h.

3656 { Z3_symbol r = Z3_mk_int_symbol(m_ctx, n); check_error(); return symbol(*this, r); }
Z3_symbol Z3_API Z3_mk_int_symbol(Z3_context c, int i)
Create a Z3 symbol using an integer.
Z3_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
expr int_val ( int  n)
inline

Definition at line 3987 of file z3++.h.

Referenced by z3::abs().

3987 { Z3_ast r = Z3_mk_int(m_ctx, n, int_sort()); check_error(); return expr(*this, r); }
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_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
sort int_sort()
Return the integer sort.
Definition: z3++.h:3659
expr int_val ( unsigned  n)
inline

Definition at line 3988 of file z3++.h.

3988 { Z3_ast r = Z3_mk_unsigned_int(m_ctx, n, int_sort()); check_error(); return expr(*this, r); }
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_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
sort int_sort()
Return the integer sort.
Definition: z3++.h:3659
expr int_val ( int64_t  n)
inline

Definition at line 3989 of file z3++.h.

3989 { Z3_ast r = Z3_mk_int64(m_ctx, n, int_sort()); check_error(); return expr(*this, r); }
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_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
sort int_sort()
Return the integer sort.
Definition: z3++.h:3659
expr int_val ( uint64_t  n)
inline

Definition at line 3990 of file z3++.h.

3990 { Z3_ast r = Z3_mk_unsigned_int64(m_ctx, n, int_sort()); check_error(); return expr(*this, r); }
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_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
sort int_sort()
Return the integer sort.
Definition: z3++.h:3659
expr int_val ( char const *  n)
inline

Definition at line 3991 of file z3++.h.

3991 { Z3_ast r = Z3_mk_numeral(m_ctx, n, int_sort()); check_error(); return expr(*this, r); }
Z3_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
Z3_ast Z3_API Z3_mk_numeral(Z3_context c, Z3_string numeral, Z3_sort ty)
Create a numeral of a given sort.
sort int_sort()
Return the integer sort.
Definition: z3++.h:3659
void interrupt ( )
inline

Interrupt the current procedure being executed by any object managed by this context. This is a soft interruption: there is no guarantee the object will actually stop.

Definition at line 283 of file z3++.h.

283 { Z3_interrupt(m_ctx); }
void Z3_API Z3_interrupt(Z3_context c)
Interrupt the execution of a Z3 procedure. This procedure can be used to interrupt: solvers...
expr num_val ( int  n,
sort const &  s 
)
inline

Definition at line 4021 of file z3++.h.

Referenced by z3::ashr(), z3::lshr(), z3::mod(), z3::operator!=(), z3::operator&(), func_decl::operator()(), z3::operator*(), z3::operator+(), z3::operator-(), z3::operator/(), z3::operator<(), z3::operator<=(), z3::operator==(), z3::operator>(), z3::operator>=(), z3::operator^(), z3::operator|(), z3::pw(), z3::rem(), z3::sdiv(), z3::select(), z3::sge(), z3::sgt(), z3::shl(), z3::sle(), z3::slt(), z3::smod(), z3::srem(), z3::store(), z3::udiv(), z3::uge(), z3::ugt(), z3::ule(), z3::ult(), and z3::urem().

4021 { Z3_ast r = Z3_mk_int(m_ctx, n, s); check_error(); return expr(*this, r); }
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_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
operator Z3_context ( ) const
inline

Definition at line 236 of file z3++.h.

236 { return m_ctx; }
context& operator= ( context &&  other)
inlinenoexcept

Definition at line 225 of file z3++.h.

225  {
226  if (this != &other) {
227  if (m_ctx) Z3_del_context(m_ctx);
228  m_enable_exceptions = other.m_enable_exceptions;
229  m_rounding_mode = other.m_rounding_mode;
230  m_ctx = other.m_ctx;
231  other.m_ctx = nullptr;
232  }
233  return *this;
234  }
void Z3_API Z3_del_context(Z3_context c)
Delete the given logical context.
expr_vector parse_file ( char const *  file)
inline

Definition at line 4360 of file z3++.h.

4360  {
4361  Z3_ast_vector r = Z3_parse_smtlib2_file(*this, s, 0, 0, 0, 0, 0, 0);
4362  check_error();
4363  return expr_vector(*this, r);
4364  }
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_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
ast_vector_tpl< expr > expr_vector
Definition: z3++.h:77
expr_vector parse_file ( char const *  s,
sort_vector const &  sorts,
func_decl_vector const &  decls 
)
inline

Definition at line 4383 of file z3++.h.

4383  {
4384  array<Z3_symbol> sort_names(sorts.size());
4385  array<Z3_symbol> decl_names(decls.size());
4386  array<Z3_sort> sorts1(sorts);
4387  array<Z3_func_decl> decls1(decls);
4388  for (unsigned i = 0; i < sorts.size(); ++i) {
4389  sort_names[i] = sorts[i].name();
4390  }
4391  for (unsigned i = 0; i < decls.size(); ++i) {
4392  decl_names[i] = decls[i].name();
4393  }
4394  Z3_ast_vector r = Z3_parse_smtlib2_file(*this, s, sorts.size(), sort_names.ptr(), sorts1.ptr(), decls.size(), decl_names.ptr(), decls1.ptr());
4395  check_error();
4396  return expr_vector(*this, r);
4397  }
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_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
ast_vector_tpl< expr > expr_vector
Definition: z3++.h:77
expr_vector parse_string ( char const *  s)
inline

parsing

Definition at line 4354 of file z3++.h.

4354  {
4355  Z3_ast_vector r = Z3_parse_smtlib2_string(*this, s, 0, 0, 0, 0, 0, 0);
4356  check_error();
4357  return expr_vector(*this, r);
4358 
4359  }
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_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
ast_vector_tpl< expr > expr_vector
Definition: z3++.h:77
expr_vector parse_string ( char const *  s,
sort_vector const &  sorts,
func_decl_vector const &  decls 
)
inline

Definition at line 4366 of file z3++.h.

4366  {
4367  array<Z3_symbol> sort_names(sorts.size());
4368  array<Z3_symbol> decl_names(decls.size());
4369  array<Z3_sort> sorts1(sorts);
4370  array<Z3_func_decl> decls1(decls);
4371  for (unsigned i = 0; i < sorts.size(); ++i) {
4372  sort_names[i] = sorts[i].name();
4373  }
4374  for (unsigned i = 0; i < decls.size(); ++i) {
4375  decl_names[i] = decls[i].name();
4376  }
4377 
4378  Z3_ast_vector r = Z3_parse_smtlib2_string(*this, s, sorts.size(), sort_names.ptr(), sorts1.ptr(), decls.size(), decl_names.ptr(), decls1.ptr());
4379  check_error();
4380  return expr_vector(*this, r);
4381  }
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_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
ast_vector_tpl< expr > expr_vector
Definition: z3++.h:77
sort re_sort ( sort seq_sort)
inline

Return a regular expression sort over sequences seq_sort.

Definition at line 3665 of file z3++.h.

3665 { Z3_sort r = Z3_mk_re_sort(m_ctx, s); check_error(); return sort(*this, r); }
Z3_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
Z3_sort Z3_API Z3_mk_re_sort(Z3_context c, Z3_sort seq)
Create a regular expression sort out of a sequence sort.
expr real_const ( char const *  name)
inline

Definition at line 3964 of file z3++.h.

3964 { return constant(name, real_sort()); }
expr constant(symbol const &name, sort const &s)
create an uninterpreted constant.
Definition: z3++.h:3951
sort real_sort()
Return the Real sort.
Definition: z3++.h:3660
sort real_sort ( )
inline

Return the Real sort.

Definition at line 3660 of file z3++.h.

Referenced by context::real_const(), and context::real_val().

3660 { Z3_sort s = Z3_mk_real_sort(m_ctx); check_error(); return sort(*this, s); }
Z3_sort Z3_API Z3_mk_real_sort(Z3_context c)
Create the real type.
Z3_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
expr real_val ( int  n)
inline

Definition at line 3994 of file z3++.h.

Referenced by z3::abs().

3994 { Z3_ast r = Z3_mk_int(m_ctx, n, real_sort()); check_error(); return expr(*this, r); }
sort real_sort()
Return the Real sort.
Definition: z3++.h:3660
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_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
expr real_val ( unsigned  n)
inline

Definition at line 3995 of file z3++.h.

3995 { Z3_ast r = Z3_mk_unsigned_int(m_ctx, n, real_sort()); check_error(); return expr(*this, r); }
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.
sort real_sort()
Return the Real sort.
Definition: z3++.h:3660
Z3_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
expr real_val ( int64_t  n)
inline

Definition at line 3996 of file z3++.h.

3996 { Z3_ast r = Z3_mk_int64(m_ctx, n, real_sort()); check_error(); return expr(*this, r); }
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.
sort real_sort()
Return the Real sort.
Definition: z3++.h:3660
Z3_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
expr real_val ( uint64_t  n)
inline

Definition at line 3997 of file z3++.h.

3997 { Z3_ast r = Z3_mk_unsigned_int64(m_ctx, n, real_sort()); check_error(); return expr(*this, r); }
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.
sort real_sort()
Return the Real sort.
Definition: z3++.h:3660
Z3_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
expr real_val ( int64_t  n,
int64_t  d 
)
inline

Definition at line 3993 of file z3++.h.

3993 { Z3_ast r = Z3_mk_real_int64(m_ctx, n, d); check_error(); return expr(*this, r); }
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.
Z3_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
expr real_val ( char const *  n)
inline

Definition at line 3998 of file z3++.h.

3998 { Z3_ast r = Z3_mk_numeral(m_ctx, n, real_sort()); check_error(); return expr(*this, r); }
sort real_sort()
Return the Real sort.
Definition: z3++.h:3660
Z3_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
Z3_ast Z3_API Z3_mk_numeral(Z3_context c, Z3_string numeral, Z3_sort ty)
Create a numeral of a given sort.
void recdef ( func_decl  decl,
expr_vector const &  args,
expr const &  body 
)
inline

add function definition body to declaration decl. decl needs to be declared using context::recfun.

Parameters
decl
args
body

Definition at line 3937 of file z3++.h.

3937  {
3938  check_context(f, args); check_context(f, body);
3939  array<Z3_ast> vars(args);
3940  Z3_add_rec_def(f.ctx(), f, vars.size(), vars.ptr(), body);
3941  }
void check_context(object const &a, object const &b)
Definition: z3++.h:544
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.
func_decl recfun ( symbol const &  name,
unsigned  arity,
sort const *  domain,
sort const &  range 
)
inline

Definition at line 3899 of file z3++.h.

Referenced by context::recfun(), and z3::recfun().

3899  {
3900  array<Z3_sort> args(arity);
3901  for (unsigned i = 0; i < arity; ++i) {
3902  check_context(domain[i], range);
3903  args[i] = domain[i];
3904  }
3905  Z3_func_decl f = Z3_mk_rec_func_decl(m_ctx, name, arity, args.ptr(), range);
3906  check_error();
3907  return func_decl(*this, f);
3908 
3909  }
expr range(expr const &lo, expr const &hi)
Definition: z3++.h:4343
void check_context(object const &a, object const &b)
Definition: z3++.h:544
Z3_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
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.
func_decl recfun ( symbol const &  name,
const sort_vector domain,
sort const &  range 
)
func_decl recfun ( char const *  name,
sort_vector const &  domain,
sort const &  range 
)
inline

Definition at line 3919 of file z3++.h.

3919  {
3920  return recfun(str_symbol(name), domain, range);
3921 
3922  }
symbol str_symbol(char const *s)
Create a Z3 symbol based on the given string.
Definition: z3++.h:3655
expr range(expr const &lo, expr const &hi)
Definition: z3++.h:4343
func_decl recfun(symbol const &name, unsigned arity, sort const *domain, sort const &range)
Definition: z3++.h:3899
func_decl recfun ( char const *  name,
unsigned  arity,
sort const *  domain,
sort const &  range 
)
inline

Definition at line 3924 of file z3++.h.

3924  {
3925  return recfun(str_symbol(name), arity, domain, range);
3926  }
symbol str_symbol(char const *s)
Create a Z3 symbol based on the given string.
Definition: z3++.h:3655
expr range(expr const &lo, expr const &hi)
Definition: z3++.h:4343
func_decl recfun(symbol const &name, unsigned arity, sort const *domain, sort const &range)
Definition: z3++.h:3899
func_decl recfun ( char const *  name,
sort const &  domain,
sort const &  range 
)
inline

Definition at line 3928 of file z3++.h.

3928  {
3929  return recfun(str_symbol(name), 1, &d1, range);
3930  }
symbol str_symbol(char const *s)
Create a Z3 symbol based on the given string.
Definition: z3++.h:3655
expr range(expr const &lo, expr const &hi)
Definition: z3++.h:4343
func_decl recfun(symbol const &name, unsigned arity, sort const *domain, sort const &range)
Definition: z3++.h:3899
func_decl recfun ( char const *  name,
sort const &  d1,
sort const &  d2,
sort const &  range 
)
inline

Definition at line 3932 of file z3++.h.

3932  {
3933  sort dom[2] = { d1, d2 };
3934  return recfun(str_symbol(name), 2, dom, range);
3935  }
symbol str_symbol(char const *s)
Create a Z3 symbol based on the given string.
Definition: z3++.h:3655
expr range(expr const &lo, expr const &hi)
Definition: z3++.h:4343
func_decl recfun(symbol const &name, unsigned arity, sort const *domain, sort const &range)
Definition: z3++.h:3899
sort seq_sort ( sort s)
inline

Return a sequence sort over base sort s.

Definition at line 3664 of file z3++.h.

3664 { Z3_sort r = Z3_mk_seq_sort(m_ctx, s); check_error(); return sort(*this, r); }
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.
Z3_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
void set ( char const *  param,
char const *  value 
)
inline

Update global parameter param with string value.

Definition at line 266 of file z3++.h.

266 { Z3_update_param_value(m_ctx, param, value); }
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.
void set ( char const *  param,
bool  value 
)
inline

Update global parameter param with Boolean value.

Definition at line 270 of file z3++.h.

270 { Z3_update_param_value(m_ctx, param, value ? "true" : "false"); }
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.
void set ( char const *  param,
int  value 
)
inline

Update global parameter param with Integer value.

Definition at line 274 of file z3++.h.

274  {
275  auto str = std::to_string(value);
276  Z3_update_param_value(m_ctx, param, str.c_str());
277  }
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.
void set_enable_exceptions ( bool  f)
inline

The C++ API uses by defaults exceptions on errors. For applications that don't work well with exceptions (there should be only few) you have the ability to turn off exceptions. The tradeoffs are that applications have to be very careful about using check_error() after calls that may result in an erroneous state.

Definition at line 259 of file z3++.h.

259 { m_enable_exceptions = f; }
void set_rounding_mode ( rounding_mode  rm)
inline

Sets RoundingMode of FloatingPoints.

Definition at line 3972 of file z3++.h.

3972 { m_rounding_mode = rm; }
symbol str_symbol ( char const *  s)
inline

Create a Z3 symbol based on the given string.

Definition at line 3655 of file z3++.h.

Referenced by context::constant(), context::function(), context::recfun(), and solver::solver().

3655 { Z3_symbol r = Z3_mk_string_symbol(m_ctx, s); check_error(); return symbol(*this, r); }
Z3_symbol Z3_API Z3_mk_string_symbol(Z3_context c, Z3_string s)
Create a Z3 symbol using a C string.
Z3_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
expr string_const ( char const *  name)
inline

Definition at line 3965 of file z3++.h.

3965 { return constant(name, string_sort()); }
expr constant(symbol const &name, sort const &s)
create an uninterpreted constant.
Definition: z3++.h:3951
sort string_sort()
Return the sort for Unicode strings.
Definition: z3++.h:3662
sort string_sort ( )
inline

Return the sort for Unicode strings.

Definition at line 3662 of file z3++.h.

Referenced by context::string_const().

3662 { Z3_sort s = Z3_mk_string_sort(m_ctx); check_error(); return sort(*this, s); }
Z3_sort Z3_API Z3_mk_string_sort(Z3_context c)
Create a sort for unicode strings.
Z3_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
expr string_val ( char const *  s)
inline

Definition at line 4017 of file z3++.h.

4017 { Z3_ast r = Z3_mk_string(m_ctx, s); check_error(); return expr(*this, r); }
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_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
expr string_val ( char const *  s,
unsigned  n 
)
inline

Definition at line 4016 of file z3++.h.

4016 { Z3_ast r = Z3_mk_lstring(m_ctx, n, s); check_error(); return expr(*this, r); }
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_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
expr string_val ( std::string const &  s)
inline

Definition at line 4018 of file z3++.h.

4018 { Z3_ast r = Z3_mk_string(m_ctx, s.c_str()); check_error(); return expr(*this, r); }
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_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
expr string_val ( std::u32string const &  s)
inline

Definition at line 4019 of file z3++.h.

4019 { Z3_ast r = Z3_mk_u32string(m_ctx, (unsigned)s.size(), (unsigned const*)s.c_str()); check_error(); return expr(*this, r); }
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...
Z3_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
func_decl tuple_sort ( char const *  name,
unsigned  n,
char const *const *  names,
sort const *  sorts,
func_decl_vector projs 
)
inline

Return a tuple constructor. name is the name of the returned constructor, n are the number of arguments, names and sorts are their projected sorts. projs is an output parameter. It contains the set of projection functions.

Definition at line 3698 of file z3++.h.

3698  {
3699  array<Z3_symbol> _names(n);
3700  array<Z3_sort> _sorts(n);
3701  for (unsigned i = 0; i < n; ++i) { _names[i] = Z3_mk_string_symbol(*this, names[i]); _sorts[i] = sorts[i]; }
3702  array<Z3_func_decl> _projs(n);
3703  Z3_symbol _name = Z3_mk_string_symbol(*this, name);
3704  Z3_func_decl tuple;
3705  sort _ignore_s = to_sort(*this, Z3_mk_tuple_sort(*this, _name, n, _names.ptr(), _sorts.ptr(), &tuple, _projs.ptr()));
3706  check_error();
3707  for (unsigned i = 0; i < n; ++i) { projs.push_back(func_decl(*this, _projs[i])); }
3708  return func_decl(*this, tuple);
3709  }
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_symbol Z3_API Z3_mk_string_symbol(Z3_context c, Z3_string s)
Create a Z3 symbol using a C string.
Z3_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
sort to_sort(context &c, Z3_sort s)
Definition: z3++.h:2203
sort uninterpreted_sort ( char const *  name)
inline

create an uninterpreted sort with the name given by the string or symbol.

Definition at line 3820 of file z3++.h.

3820  {
3821  Z3_symbol _name = Z3_mk_string_symbol(*this, name);
3822  return to_sort(*this, Z3_mk_uninterpreted_sort(*this, _name));
3823  }
Z3_symbol Z3_API Z3_mk_string_symbol(Z3_context c, Z3_string s)
Create a Z3 symbol using a C string.
Z3_sort Z3_API Z3_mk_uninterpreted_sort(Z3_context c, Z3_symbol s)
Create a free (uninterpreted) type using the given name (symbol).
sort to_sort(context &c, Z3_sort s)
Definition: z3++.h:2203
sort uninterpreted_sort ( symbol const &  name)
inline

Definition at line 3824 of file z3++.h.

3824  {
3825  return to_sort(*this, Z3_mk_uninterpreted_sort(*this, name));
3826  }
Z3_sort Z3_API Z3_mk_uninterpreted_sort(Z3_context c, Z3_symbol s)
Create a free (uninterpreted) type using the given name (symbol).
sort to_sort(context &c, Z3_sort s)
Definition: z3++.h:2203
func_decl user_propagate_function ( symbol const &  name,
sort_vector const &  domain,
sort const &  range 
)
inline

Definition at line 3943 of file z3++.h.

3943  {
3944  check_context(domain, range);
3945  array<Z3_sort> domain1(domain);
3946  Z3_func_decl f = Z3_solver_propagate_declare(range.ctx(), name, domain1.size(), domain1.ptr(), range);
3947  check_error();
3948  return func_decl(*this, f);
3949  }
expr range(expr const &lo, expr const &hi)
Definition: z3++.h:4343
context & ctx() const
Definition: z3++.h:540
void check_context(object const &a, object const &b)
Definition: z3++.h:544
Z3_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241
Z3_func_decl Z3_API Z3_solver_propagate_declare(Z3_context c, Z3_symbol name, unsigned n, Z3_sort *domain, Z3_sort range)
expr variable ( unsigned  index,
sort const &  s 
)
inline

create a de-Bruijn variable.

Definition at line 3957 of file z3++.h.

3957  {
3958  Z3_ast r = Z3_mk_bound(m_ctx, idx, s);
3959  check_error();
3960  return expr(*this, r);
3961  }
Z3_ast Z3_API Z3_mk_bound(Z3_context c, unsigned index, Z3_sort ty)
Create a variable.
Z3_error_code check_error() const
Auxiliary method used to check for API usage errors.
Definition: z3++.h:241

Friends And Related Function Documentation

friend class user_propagator_base
friend

Definition at line 193 of file z3++.h.