The main interaction with Z3 happens via the Context. More...
Inheritance diagram for Context:Public Member Functions | |
| Context () | |
| Constructor. | |
| Context (Dictionary< string, string > settings) | |
| Constructor. | |
| IntSymbol | MkSymbol (int i) |
| Creates a new symbol using an integer. | |
| StringSymbol | MkSymbol (string name) |
| Create a symbol using a string. | |
| BoolSort | MkBoolSort () |
| Create a new Boolean sort. | |
| UninterpretedSort | MkUninterpretedSort (Symbol s) |
| Create a new uninterpreted sort. | |
| UninterpretedSort | MkUninterpretedSort (string str) |
| Create a new uninterpreted sort. | |
| IntSort | MkIntSort () |
| Create a new integer sort. | |
| RealSort | MkRealSort () |
| Create a real sort. | |
| BitVecSort | MkBitVecSort (uint size) |
| Create a new bit-vector sort. | |
| SeqSort | MkSeqSort (Sort s) |
| Create a new sequence sort. | |
| ReSort | MkReSort (SeqSort s) |
| Create a new regular expression sort. | |
| ArraySort | MkArraySort (Sort domain, Sort range) |
| Create a new array sort. | |
| ArraySort | MkArraySort (Sort[] domain, Sort range) |
| Create a new n-ary array sort. | |
| TupleSort | MkTupleSort (Symbol name, Symbol[] fieldNames, Sort[] fieldSorts) |
| Create a new tuple sort. | |
| EnumSort | MkEnumSort (Symbol name, params Symbol[] enumNames) |
| Create a new enumeration sort. | |
| EnumSort | MkEnumSort (string name, params string[] enumNames) |
| Create a new enumeration sort. | |
| ListSort | MkListSort (Symbol name, Sort elemSort) |
| Create a new list sort. | |
| ListSort | MkListSort (string name, Sort elemSort) |
| Create a new list sort. | |
| FiniteDomainSort | MkFiniteDomainSort (Symbol name, ulong size) |
Create a new finite domain sort.
| |
| FiniteDomainSort | MkFiniteDomainSort (string name, ulong size) |
Create a new finite domain sort.
Elements of the sort are created using
, and the elements range from 0 to | |
| Constructor | MkConstructor (Symbol name, Symbol recognizer, Symbol[] fieldNames=null, Sort[] sorts=null, uint[] sortRefs=null) |
| Create a datatype constructor. | |
| Constructor | MkConstructor (string name, string recognizer, string[] fieldNames=null, Sort[] sorts=null, uint[] sortRefs=null) |
| Create a datatype constructor. | |
| DatatypeSort | MkDatatypeSort (Symbol name, Constructor[] constructors) |
| Create a new datatype sort. | |
| DatatypeSort | MkDatatypeSort (string name, Constructor[] constructors) |
| Create a new datatype sort. | |
| DatatypeSort | MkDatatypeSortRef (Symbol name, Sort[] parameters=null) |
| Create a forward reference to a datatype sort. This is useful for creating recursive datatypes or parametric datatypes. | |
| DatatypeSort | MkDatatypeSortRef (string name, Sort[] parameters=null) |
| Create a forward reference to a datatype sort. This is useful for creating recursive datatypes or parametric datatypes. | |
| DatatypeSort[] | MkDatatypeSorts (Symbol[] names, Constructor[][] c) |
| Create mutually recursive datatypes. | |
| DatatypeSort[] | MkDatatypeSorts (string[] names, Constructor[][] c) |
| Create mutually recursive data-types. | |
| Expr | MkUpdateField (FuncDecl field, Expr t, Expr v) |
| Update a datatype field at expression t with value v. The function performs a record update at t. The field that is passed in as argument is updated with value v, the remaining fields of t are unchanged. | |
| FuncDecl | MkFuncDecl (Symbol name, Sort[] domain, Sort range) |
| Creates a new function declaration. | |
| FuncDecl | MkFuncDecl (Symbol name, Sort domain, Sort range) |
| Creates a new function declaration. | |
| FuncDecl | MkFuncDecl (string name, Sort[] domain, Sort range) |
| Creates a new function declaration. | |
| FuncDecl | MkRecFuncDecl (string name, Sort[] domain, Sort range) |
| Creates a new recursive function declaration. | |
| void | AddRecDef (FuncDecl f, Expr[] args, Expr body) |
| Bind a definition to a recursive function declaration. The function must have previously been created using MkRecFuncDecl. The body may contain recursive uses of the function or other mutually recursive functions. | |
| FuncDecl | MkFuncDecl (string name, Sort domain, Sort range) |
| Creates a new function declaration. | |
| FuncDecl | MkFreshFuncDecl (string prefix, Sort[] domain, Sort range) |
| Creates a fresh function declaration with a name prefixed with prefix . | |
| FuncDecl | MkConstDecl (Symbol name, Sort range) |
| Creates a new constant function declaration. | |
| FuncDecl | MkConstDecl (string name, Sort range) |
| Creates a new constant function declaration. | |
| FuncDecl | MkFreshConstDecl (string prefix, Sort range) |
| Creates a fresh constant function declaration with a name prefixed with prefix . | |
| FuncDecl | MkUserPropagatorFuncDecl (string name, Sort[] domain, Sort range) |
| Declare a function to be processed by the user propagator plugin. | |
| Expr | MkBound (uint index, Sort ty) |
| Creates a new bound variable. | |
| Pattern | MkPattern (params Expr[] terms) |
| Create a quantifier pattern. | |
| Expr | MkConst (Symbol name, Sort range) |
| Creates a new Constant of sort range and named name . | |
| Expr | MkConst (string name, Sort range) |
| Creates a new Constant of sort range and named name . | |
| Expr | MkFreshConst (string prefix, Sort range) |
| Creates a fresh Constant of sort range and a name prefixed with prefix . | |
| Expr | MkConst (FuncDecl f) |
| Creates a fresh constant from the FuncDecl f . | |
| BoolExpr | MkBoolConst (Symbol name) |
| Create a Boolean constant. | |
| BoolExpr | MkBoolConst (string name) |
| Create a Boolean constant. | |
| IntExpr | MkIntConst (Symbol name) |
| Creates an integer constant. | |
| IntExpr | MkIntConst (string name) |
| Creates an integer constant. | |
| RealExpr | MkRealConst (Symbol name) |
| Creates a real constant. | |
| RealExpr | MkRealConst (string name) |
| Creates a real constant. | |
| BitVecExpr | MkBVConst (Symbol name, uint size) |
| Creates a bit-vector constant. | |
| BitVecExpr | MkBVConst (string name, uint size) |
| Creates a bit-vector constant. | |
| Expr | MkApp (FuncDecl f, params Expr[] args) |
| Create a new function application. | |
| Expr | MkApp (FuncDecl f, IEnumerable< Expr > args) |
| Create a new function application. | |
| BoolExpr | MkTrue () |
| The true Term. | |
| BoolExpr | MkFalse () |
| The false Term. | |
| BoolExpr | MkBool (bool value) |
| Creates a Boolean value. | |
| BoolExpr | MkEq (Expr x, Expr y) |
| Creates the equality x = y . | |
| BoolExpr | MkDistinct (params Expr[] args) |
Creates a distinct term. | |
| BoolExpr | MkDistinct (IEnumerable< Expr > args) |
Creates a distinct term. | |
| BoolExpr | MkNot (BoolExpr a) |
Mk an expression representing not(a). | |
| Expr | MkITE (BoolExpr t1, Expr t2, Expr t3) |
Create an expression representing an if-then-else: ite(t1, t2, t3). | |
| BoolExpr | MkIff (BoolExpr t1, BoolExpr t2) |
Create an expression representing t1 iff t2. | |
| BoolExpr | MkImplies (BoolExpr t1, BoolExpr t2) |
Create an expression representing t1 -> t2. | |
| BoolExpr | MkXor (BoolExpr t1, BoolExpr t2) |
Create an expression representing t1 xor t2. | |
| BoolExpr | MkXor (IEnumerable< BoolExpr > args) |
Create an expression representing t1 xor t2 xor t3 ... . | |
| BoolExpr | MkAnd (params BoolExpr[] ts) |
Create an expression representing t[0] and t[1] and .... | |
| BoolExpr | MkAnd (IEnumerable< BoolExpr > t) |
Create an expression representing t[0] and t[1] and .... | |
| BoolExpr | MkOr (params BoolExpr[] ts) |
Create an expression representing t[0] or t[1] or .... | |
| BoolExpr | MkOr (IEnumerable< BoolExpr > ts) |
Create an expression representing t[0] or t[1] or .... | |
| ArithExpr | MkAdd (params ArithExpr[] ts) |
Create an expression representing t[0] + t[1] + .... | |
| ArithExpr | MkAdd (IEnumerable< ArithExpr > ts) |
Create an expression representing t[0] + t[1] + .... | |
| ArithExpr | MkMul (params ArithExpr[] ts) |
Create an expression representing t[0] * t[1] * .... | |
| ArithExpr | MkMul (IEnumerable< ArithExpr > ts) |
Create an expression representing t[0] * t[1] * .... | |
| ArithExpr | MkSub (params ArithExpr[] ts) |
Create an expression representing t[0] - t[1] - .... | |
| ArithExpr | MkUnaryMinus (ArithExpr t) |
Create an expression representing -t. | |
| ArithExpr | MkDiv (ArithExpr t1, ArithExpr t2) |
Create an expression representing t1 / t2. | |
| IntExpr | MkMod (IntExpr t1, IntExpr t2) |
Create an expression representing t1 mod t2. | |
| IntExpr | MkRem (IntExpr t1, IntExpr t2) |
Create an expression representing t1 rem t2. | |
| ArithExpr | MkPower (ArithExpr t1, ArithExpr t2) |
Create an expression representing t1 ^ t2. | |
| BoolExpr | MkLt (ArithExpr t1, ArithExpr t2) |
Create an expression representing t1 < t2 | |
| BoolExpr | MkLe (ArithExpr t1, ArithExpr t2) |
Create an expression representing t1 <= t2 | |
| BoolExpr | MkGt (ArithExpr t1, ArithExpr t2) |
Create an expression representing t1 > t2 | |
| BoolExpr | MkGe (ArithExpr t1, ArithExpr t2) |
Create an expression representing t1 >= t2 | |
| RealExpr | MkInt2Real (IntExpr t) |
| Coerce an integer to a real. | |
| IntExpr | MkReal2Int (RealExpr t) |
| Coerce a real to an integer. | |
| BoolExpr | MkIsInteger (RealExpr t) |
| Creates an expression that checks whether a real number is an integer. | |
| BitVecExpr | MkBVNot (BitVecExpr t) |
| Bitwise negation. | |
| BitVecExpr | MkBVRedAND (BitVecExpr t) |
| Take conjunction of bits in a vector, return vector of length 1. | |
| BitVecExpr | MkBVRedOR (BitVecExpr t) |
| Take disjunction of bits in a vector, return vector of length 1. | |
| BitVecExpr | MkBVAND (BitVecExpr t1, BitVecExpr t2) |
| Bitwise conjunction. | |
| BitVecExpr | MkBVOR (BitVecExpr t1, BitVecExpr t2) |
| Bitwise disjunction. | |
| BitVecExpr | MkBVXOR (BitVecExpr t1, BitVecExpr t2) |
| Bitwise XOR. | |
| BitVecExpr | MkBVNAND (BitVecExpr t1, BitVecExpr t2) |
| Bitwise NAND. | |
| BitVecExpr | MkBVNOR (BitVecExpr t1, BitVecExpr t2) |
| Bitwise NOR. | |
| BitVecExpr | MkBVXNOR (BitVecExpr t1, BitVecExpr t2) |
| Bitwise XNOR. | |
| BitVecExpr | MkBVNeg (BitVecExpr t) |
| Standard two's complement unary minus. | |
| BitVecExpr | MkBVAdd (BitVecExpr t1, BitVecExpr t2) |
| Two's complement addition. | |
| BitVecExpr | MkBVSub (BitVecExpr t1, BitVecExpr t2) |
| Two's complement subtraction. | |
| BitVecExpr | MkBVMul (BitVecExpr t1, BitVecExpr t2) |
| Two's complement multiplication. | |
| BitVecExpr | MkBVUDiv (BitVecExpr t1, BitVecExpr t2) |
| Unsigned division. | |
| BitVecExpr | MkBVSDiv (BitVecExpr t1, BitVecExpr t2) |
| Signed division. | |
| BitVecExpr | MkBVURem (BitVecExpr t1, BitVecExpr t2) |
| Unsigned remainder. | |
| BitVecExpr | MkBVSRem (BitVecExpr t1, BitVecExpr t2) |
| Signed remainder. | |
| BitVecExpr | MkBVSMod (BitVecExpr t1, BitVecExpr t2) |
| Two's complement signed remainder (sign follows divisor). | |
| BoolExpr | MkBVULT (BitVecExpr t1, BitVecExpr t2) |
| Unsigned less-than. | |
| BoolExpr | MkBVSLT (BitVecExpr t1, BitVecExpr t2) |
| Two's complement signed less-than. | |
| BoolExpr | MkBVULE (BitVecExpr t1, BitVecExpr t2) |
| Unsigned less-than or equal to. | |
| BoolExpr | MkBVSLE (BitVecExpr t1, BitVecExpr t2) |
| Two's complement signed less-than or equal to. | |
| BoolExpr | MkBVUGE (BitVecExpr t1, BitVecExpr t2) |
| Unsigned greater than or equal to. | |
| BoolExpr | MkBVSGE (BitVecExpr t1, BitVecExpr t2) |
| Two's complement signed greater than or equal to. | |
| BoolExpr | MkBVUGT (BitVecExpr t1, BitVecExpr t2) |
| Unsigned greater-than. | |
| BoolExpr | MkBVSGT (BitVecExpr t1, BitVecExpr t2) |
| Two's complement signed greater-than. | |
| BitVecExpr | MkConcat (BitVecExpr t1, BitVecExpr t2) |
| Bit-vector concatenation. | |
| BitVecExpr | MkExtract (uint high, uint low, BitVecExpr t) |
| Bit-vector extraction. | |
| BitVecExpr | MkSignExt (uint i, BitVecExpr t) |
| Bit-vector sign extension. | |
| BitVecExpr | MkZeroExt (uint i, BitVecExpr t) |
| Bit-vector zero extension. | |
| BitVecExpr | MkRepeat (uint i, BitVecExpr t) |
| Bit-vector repetition. | |
| BitVecExpr | MkBVSHL (BitVecExpr t1, BitVecExpr t2) |
| Shift left. | |
| BitVecExpr | MkBVLSHR (BitVecExpr t1, BitVecExpr t2) |
| Logical shift right. | |
| BitVecExpr | MkBVASHR (BitVecExpr t1, BitVecExpr t2) |
| Arithmetic shift right. | |
| BitVecExpr | MkBVRotateLeft (uint i, BitVecExpr t) |
| Rotate Left. | |
| BitVecExpr | MkBVRotateRight (uint i, BitVecExpr t) |
| Rotate Right. | |
| BitVecExpr | MkBVRotateLeft (BitVecExpr t1, BitVecExpr t2) |
| Rotate Left. | |
| BitVecExpr | MkBVRotateRight (BitVecExpr t1, BitVecExpr t2) |
| Rotate Right. | |
| BitVecExpr | MkInt2BV (uint n, IntExpr t) |
| Create an n bit bit-vector from the integer argument t . | |
| IntExpr | MkBV2Int (BitVecExpr t, bool signed) |
| Create an integer from the bit-vector argument t . | |
| BoolExpr | MkBVAddNoOverflow (BitVecExpr t1, BitVecExpr t2, bool isSigned) |
| Create a predicate that checks that the bit-wise addition does not overflow. | |
| BoolExpr | MkBVAddNoUnderflow (BitVecExpr t1, BitVecExpr t2) |
| Create a predicate that checks that the bit-wise addition does not underflow. | |
| BoolExpr | MkBVSubNoOverflow (BitVecExpr t1, BitVecExpr t2) |
| Create a predicate that checks that the bit-wise subtraction does not overflow. | |
| BoolExpr | MkBVSubNoUnderflow (BitVecExpr t1, BitVecExpr t2, bool isSigned) |
| Create a predicate that checks that the bit-wise subtraction does not underflow. | |
| BoolExpr | MkBVSDivNoOverflow (BitVecExpr t1, BitVecExpr t2) |
| Create a predicate that checks that the bit-wise signed division does not overflow. | |
| BoolExpr | MkBVNegNoOverflow (BitVecExpr t) |
| Create a predicate that checks that the bit-wise negation does not overflow. | |
| BoolExpr | MkBVMulNoOverflow (BitVecExpr t1, BitVecExpr t2, bool isSigned) |
| Create a predicate that checks that the bit-wise multiplication does not overflow. | |
| BoolExpr | MkBVMulNoUnderflow (BitVecExpr t1, BitVecExpr t2) |
| Create a predicate that checks that the bit-wise multiplication does not underflow. | |
| ArrayExpr | MkArrayConst (Symbol name, Sort domain, Sort range) |
| Create an array constant. | |
| ArrayExpr | MkArrayConst (string name, Sort domain, Sort range) |
| Create an array constant. | |
| Expr | MkSelect (ArrayExpr a, Expr i) |
| Array read. | |
| Expr | MkSelect (ArrayExpr a, params Expr[] args) |
| Array read. | |
| ArrayExpr | MkStore (ArrayExpr a, Expr i, Expr v) |
| Array update. | |
| ArrayExpr | MkStore (ArrayExpr a, Expr[] args, Expr v) |
| Array update. | |
| ArrayExpr | MkConstArray (Sort domain, Expr v) |
| Create a constant array. | |
| ArrayExpr | MkMap (FuncDecl f, params ArrayExpr[] args) |
| Maps f on the argument arrays. | |
| Expr | MkTermArray (ArrayExpr array) |
| Access the array default value. | |
| Expr | MkArrayExt (ArrayExpr arg1, ArrayExpr arg2) |
| Create Extentionality index. Two arrays are equal if and only if they are equal on the index returned by MkArrayExt. | |
| SetSort | MkSetSort (Sort ty) |
| Create a set type. | |
| ArrayExpr | MkEmptySet (Sort domain) |
| Create an empty set. | |
| ArrayExpr | MkFullSet (Sort domain) |
| Create the full set. | |
| ArrayExpr | MkSetAdd (ArrayExpr set, Expr element) |
| Add an element to the set. | |
| ArrayExpr | MkSetDel (ArrayExpr set, Expr element) |
| Remove an element from a set. | |
| ArrayExpr | MkSetUnion (params ArrayExpr[] args) |
| Take the union of a list of sets. | |
| ArrayExpr | MkSetIntersection (params ArrayExpr[] args) |
| Take the intersection of a list of sets. | |
| ArrayExpr | MkSetDifference (ArrayExpr arg1, ArrayExpr arg2) |
| Take the difference between two sets. | |
| ArrayExpr | MkSetComplement (ArrayExpr arg) |
| Take the complement of a set. | |
| BoolExpr | MkSetMembership (Expr elem, ArrayExpr set) |
| Check for set membership. | |
| BoolExpr | MkSetSubset (ArrayExpr arg1, ArrayExpr arg2) |
| Check for subsetness of sets. | |
| SeqExpr | MkEmptySeq (Sort s) |
| Create the empty sequence. | |
| SeqExpr | MkUnit (Expr elem) |
| Create the singleton sequence. | |
| SeqExpr | MkString (string s) |
| Create a string constant. | |
| SeqExpr | IntToString (Expr e) |
| Convert an integer expression to a string. | |
| SeqExpr | UbvToString (Expr e) |
| Convert a bit-vector expression, represented as an unsigned number, to a string. | |
| SeqExpr | SbvToString (Expr e) |
| Convert a bit-vector expression, represented as an signed number, to a string. | |
| IntExpr | StringToInt (Expr e) |
| Convert an integer expression to a string. | |
| SeqExpr | MkConcat (params SeqExpr[] t) |
| Concatenate sequences. | |
| IntExpr | MkLength (SeqExpr s) |
| Retrieve the length of a given sequence. | |
| BoolExpr | MkPrefixOf (SeqExpr s1, SeqExpr s2) |
| Check for sequence prefix. | |
| BoolExpr | MkSuffixOf (SeqExpr s1, SeqExpr s2) |
| Check for sequence suffix. | |
| BoolExpr | MkContains (SeqExpr s1, SeqExpr s2) |
| Check for sequence containment of s2 in s1. | |
| BoolExpr | MkStringLt (SeqExpr s1, SeqExpr s2) |
| Check if the string s1 is lexicographically strictly less than s2. | |
| BoolExpr | MkStringLe (SeqExpr s1, SeqExpr s2) |
| Check if the string s1 is lexicographically less or equal to s2. | |
| SeqExpr | MkAt (SeqExpr s, Expr index) |
| Retrieve sequence of length one at index. | |
| Expr | MkNth (SeqExpr s, Expr index) |
| Retrieve element at index. | |
| SeqExpr | MkExtract (SeqExpr s, IntExpr offset, IntExpr length) |
| Extract subsequence. | |
| IntExpr | MkIndexOf (SeqExpr s, SeqExpr substr, ArithExpr offset) |
| Extract index of sub-string starting at offset. | |
| SeqExpr | MkReplace (SeqExpr s, SeqExpr src, SeqExpr dst) |
| Replace the first occurrence of src by dst in s. | |
| ReExpr | MkToRe (SeqExpr s) |
| Convert a regular expression that accepts sequence s. | |
| BoolExpr | MkInRe (SeqExpr s, ReExpr re) |
| Check for regular expression membership. | |
| ReExpr | MkStar (ReExpr re) |
| Take the Kleene star of a regular expression. | |
| ReExpr | MkLoop (ReExpr re, uint lo, uint hi=0) |
| Take the bounded Kleene star of a regular expression. | |
| ReExpr | MkPlus (ReExpr re) |
| Take the Kleene plus of a regular expression. | |
| ReExpr | MkOption (ReExpr re) |
| Create the optional regular expression. | |
| ReExpr | MkComplement (ReExpr re) |
| Create the complement regular expression. | |
| ReExpr | MkConcat (params ReExpr[] t) |
| Create the concatenation of regular languages. | |
| ReExpr | MkUnion (params ReExpr[] t) |
| Create the union of regular languages. | |
| ReExpr | MkIntersect (params ReExpr[] t) |
| Create the intersection of regular languages. | |
| ReExpr | MkDiff (ReExpr a, ReExpr b) |
| Create a difference regular expression. | |
| ReExpr | MkEmptyRe (Sort s) |
| Create the empty regular expression. The sort s should be a regular expression. | |
| ReExpr | MkFullRe (Sort s) |
| Create the full regular expression. The sort s should be a regular expression. | |
| ReExpr | MkRange (SeqExpr lo, SeqExpr hi) |
| Create a range expression. | |
| BoolExpr | MkCharLe (Expr ch1, Expr ch2) |
| Create less than or equal to between two characters. | |
| IntExpr | CharToInt (Expr ch) |
| Create an integer (code point) from character. | |
| BitVecExpr | CharToBV (Expr ch) |
| Create a bit-vector (code point) from character. | |
| Expr | CharFromBV (BitVecExpr bv) |
| Create a character from a bit-vector (code point). | |
| BoolExpr | MkIsDigit (Expr ch) |
| Create a check if the character is a digit. | |
| BoolExpr | MkAtMost (IEnumerable< BoolExpr > args, uint k) |
| Create an at-most-k constraint. | |
| BoolExpr | MkAtLeast (IEnumerable< BoolExpr > args, uint k) |
| Create an at-least-k constraint. | |
| BoolExpr | MkPBLe (int[] coeffs, BoolExpr[] args, int k) |
| Create a pseudo-Boolean less-or-equal constraint. | |
| BoolExpr | MkPBGe (int[] coeffs, BoolExpr[] args, int k) |
| Create a pseudo-Boolean greater-or-equal constraint. | |
| BoolExpr | MkPBEq (int[] coeffs, BoolExpr[] args, int k) |
| Create a pseudo-Boolean equal constraint. | |
| Expr | MkNumeral (string v, Sort ty) |
| Create a Term of a given sort. | |
| Expr | MkNumeral (int v, Sort ty) |
Create a Term of a given sort. This function can be used to create numerals that fit in a machine integer. It is slightly faster than MakeNumeral since it is not necessary to parse a string. | |
| Expr | MkNumeral (uint v, Sort ty) |
Create a Term of a given sort. This function can be used to create numerals that fit in a machine integer. It is slightly faster than MakeNumeral since it is not necessary to parse a string. | |
| Expr | MkNumeral (long v, Sort ty) |
Create a Term of a given sort. This function can be used to create numerals that fit in a machine integer. It is slightly faster than MakeNumeral since it is not necessary to parse a string. | |
| Expr | MkNumeral (ulong v, Sort ty) |
Create a Term of a given sort. This function can be used to create numerals that fit in a machine integer. It is slightly faster than MakeNumeral since it is not necessary to parse a string. | |
| RatNum | MkReal (int num, int den) |
| Create a real from a fraction. | |
| RatNum | MkReal (string v) |
| Create a real numeral. | |
| RatNum | MkReal (int v) |
| Create a real numeral. | |
| RatNum | MkReal (uint v) |
| Create a real numeral. | |
| RatNum | MkReal (long v) |
| Create a real numeral. | |
| RatNum | MkReal (ulong v) |
| Create a real numeral. | |
| IntNum | MkInt (string v) |
| Create an integer numeral. | |
| IntNum | MkInt (int v) |
| Create an integer numeral. | |
| IntNum | MkInt (uint v) |
| Create an integer numeral. | |
| IntNum | MkInt (long v) |
| Create an integer numeral. | |
| IntNum | MkInt (ulong v) |
| Create an integer numeral. | |
| BitVecNum | MkBV (string v, uint size) |
| Create a bit-vector numeral. | |
| BitVecNum | MkBV (int v, uint size) |
| Create a bit-vector numeral. | |
| BitVecNum | MkBV (uint v, uint size) |
| Create a bit-vector numeral. | |
| BitVecNum | MkBV (long v, uint size) |
| Create a bit-vector numeral. | |
| BitVecNum | MkBV (ulong v, uint size) |
| Create a bit-vector numeral. | |
| BitVecNum | MkBV (bool[] bits) |
| Create a bit-vector numeral. | |
| Quantifier | MkForall (Sort[] sorts, Symbol[] names, Expr body, uint weight=1, Pattern[] patterns=null, Expr[] noPatterns=null, Symbol quantifierID=null, Symbol skolemID=null) |
| Create a universal Quantifier. | |
| Quantifier | MkForall (Expr[] boundConstants, Expr body, uint weight=1, Pattern[] patterns=null, Expr[] noPatterns=null, Symbol quantifierID=null, Symbol skolemID=null) |
| Create a universal Quantifier. | |
| Quantifier | MkExists (Sort[] sorts, Symbol[] names, Expr body, uint weight=1, Pattern[] patterns=null, Expr[] noPatterns=null, Symbol quantifierID=null, Symbol skolemID=null) |
| Create an existential Quantifier. | |
| Quantifier | MkExists (Expr[] boundConstants, Expr body, uint weight=1, Pattern[] patterns=null, Expr[] noPatterns=null, Symbol quantifierID=null, Symbol skolemID=null) |
| Create an existential Quantifier. | |
| Quantifier | MkQuantifier (bool universal, Sort[] sorts, Symbol[] names, Expr body, uint weight=1, Pattern[] patterns=null, Expr[] noPatterns=null, Symbol quantifierID=null, Symbol skolemID=null) |
| Create a Quantifier. | |
| Quantifier | MkQuantifier (bool universal, Expr[] boundConstants, Expr body, uint weight=1, Pattern[] patterns=null, Expr[] noPatterns=null, Symbol quantifierID=null, Symbol skolemID=null) |
| Create a Quantifier. | |
| Lambda | MkLambda (Sort[] sorts, Symbol[] names, Expr body) |
| Create a lambda expression. | |
| Lambda | MkLambda (Expr[] boundConstants, Expr body) |
| Create a lambda expression. | |
| BoolExpr[] | ParseSMTLIB2String (string str, Symbol[] sortNames=null, Sort[] sorts=null, Symbol[] declNames=null, FuncDecl[] decls=null) |
| Parse the given string using the SMT-LIB2 parser. | |
| BoolExpr[] | ParseSMTLIB2File (string fileName, Symbol[] sortNames=null, Sort[] sorts=null, Symbol[] declNames=null, FuncDecl[] decls=null) |
| Parse the given file using the SMT-LIB2 parser. | |
| Goal | MkGoal (bool models=true, bool unsatCores=false, bool proofs=false) |
| Creates a new Goal. | |
| Params | MkParams () |
| Creates a new ParameterSet. | |
| string | TacticDescription (string name) |
| Returns a string containing a description of the tactic with the given name. | |
| Tactic | MkTactic (string name) |
| Creates a new Tactic. | |
| Tactic | AndThen (Tactic t1, Tactic t2, params Tactic[] ts) |
| Create a tactic that applies t1 to a Goal and then t2 to every subgoal produced by t1 . | |
| Tactic | Then (Tactic t1, Tactic t2, params Tactic[] ts) |
| Create a tactic that applies t1 to a Goal and then t2 to every subgoal produced by t1 . | |
| Tactic | OrElse (Tactic t1, Tactic t2) |
| Create a tactic that first applies t1 to a Goal and if it fails then returns the result of t2 applied to the Goal. | |
| Tactic | TryFor (Tactic t, uint ms) |
| Create a tactic that applies t to a goal for ms milliseconds. | |
| Tactic | When (Probe p, Tactic t) |
| Create a tactic that applies t to a given goal if the probe p evaluates to true. | |
| Tactic | Cond (Probe p, Tactic t1, Tactic t2) |
| Create a tactic that applies t1 to a given goal if the probe p evaluates to true and t2 otherwise. | |
| Tactic | Repeat (Tactic t, uint max=uint.MaxValue) |
| Create a tactic that keeps applying t until the goal is not modified anymore or the maximum number of iterations max is reached. | |
| Tactic | Skip () |
| Create a tactic that just returns the given goal. | |
| Tactic | Fail () |
| Create a tactic always fails. | |
| Tactic | FailIf (Probe p) |
| Create a tactic that fails if the probe p evaluates to false. | |
| Tactic | FailIfNotDecided () |
| Create a tactic that fails if the goal is not trivially satisfiable (i.e., empty) or trivially unsatisfiable (i.e., contains ‘false’). | |
| Tactic | UsingParams (Tactic t, Params p) |
| Create a tactic that applies t using the given set of parameters p . | |
| Tactic | With (Tactic t, Params p) |
| Create a tactic that applies t using the given set of parameters p . | |
| Tactic | ParOr (params Tactic[] t) |
| Create a tactic that applies the given tactics in parallel until one of them succeeds (i.e., the first that doesn't fail). | |
| Tactic | ParAndThen (Tactic t1, Tactic t2) |
| Create a tactic that applies t1 to a given goal and then t2 to every subgoal produced by t1 . The subgoals are processed in parallel. | |
| void | Interrupt () |
| Interrupt the execution of a Z3 procedure. | |
| string | SimplifierDescription (string name) |
| Returns a string containing a description of the simplifier with the given name. | |
| Simplifier | MkSimplifier (string name) |
| Creates a new Tactic. | |
| Simplifier | AndThen (Simplifier t1, Simplifier t2, params Simplifier[] ts) |
| Create a simplifier that applies t1 and then t2 . | |
| Simplifier | Then (Simplifier t1, Simplifier t2, params Simplifier[] ts) |
| Create a simplifier that applies t1 and then then t2 . | |
| Simplifier | UsingParams (Simplifier t, Params p) |
| Create a tactic that applies t using the given set of parameters p . | |
| string | ProbeDescription (string name) |
| Returns a string containing a description of the probe with the given name. | |
| Probe | MkProbe (string name) |
| Creates a new Probe. | |
| Probe | ConstProbe (double val) |
| Create a probe that always evaluates to val . | |
| Probe | Lt (Probe p1, Probe p2) |
| Create a probe that evaluates to "true" when the value returned by p1 is less than the value returned by p2 | |
| Probe | Gt (Probe p1, Probe p2) |
| Create a probe that evaluates to "true" when the value returned by p1 is greater than the value returned by p2 | |
| Probe | Le (Probe p1, Probe p2) |
| Create a probe that evaluates to "true" when the value returned by p1 is less than or equal the value returned by p2 | |
| Probe | Ge (Probe p1, Probe p2) |
| Create a probe that evaluates to "true" when the value returned by p1 is greater than or equal the value returned by p2 | |
| Probe | Eq (Probe p1, Probe p2) |
| Create a probe that evaluates to "true" when the value returned by p1 is equal to the value returned by p2 | |
| Probe | And (Probe p1, Probe p2) |
| Create a probe that evaluates to "true" when the value p1 and p2 evaluate to "true". | |
| Probe | Or (Probe p1, Probe p2) |
| Create a probe that evaluates to "true" when the value p1 or p2 evaluate to "true". | |
| Probe | Not (Probe p) |
| Create a probe that evaluates to "true" when the value p does not evaluate to "true". | |
| Solver | MkSolver (Symbol logic=null) |
| Creates a new (incremental) solver. | |
| Solver | MkSolver (string logic) |
| Creates a new (incremental) solver. | |
| Solver | MkSimpleSolver () |
| Creates a new (incremental) solver. | |
| Solver | MkSolver (Solver s, Simplifier t) |
| Creates a solver that uses an incremental simplifier. | |
| Solver | MkSolver (Tactic t) |
| Creates a solver that is implemented using the given tactic. | |
| Fixedpoint | MkFixedpoint () |
| Create a Fixedpoint context. | |
| Optimize | MkOptimize () |
| Create an Optimization context. | |
| FPRMSort | MkFPRoundingModeSort () |
| Create the floating-point RoundingMode sort. | |
| FPRMExpr | MkFPRoundNearestTiesToEven () |
| Create a numeral of RoundingMode sort which represents the NearestTiesToEven rounding mode. | |
| FPRMNum | MkFPRNE () |
| Create a numeral of RoundingMode sort which represents the NearestTiesToEven rounding mode. | |
| FPRMNum | MkFPRoundNearestTiesToAway () |
| Create a numeral of RoundingMode sort which represents the NearestTiesToAway rounding mode. | |
| FPRMNum | MkFPRNA () |
| Create a numeral of RoundingMode sort which represents the NearestTiesToAway rounding mode. | |
| FPRMNum | MkFPRoundTowardPositive () |
| Create a numeral of RoundingMode sort which represents the RoundTowardPositive rounding mode. | |
| FPRMNum | MkFPRTP () |
| Create a numeral of RoundingMode sort which represents the RoundTowardPositive rounding mode. | |
| FPRMNum | MkFPRoundTowardNegative () |
| Create a numeral of RoundingMode sort which represents the RoundTowardNegative rounding mode. | |
| FPRMNum | MkFPRTN () |
| Create a numeral of RoundingMode sort which represents the RoundTowardNegative rounding mode. | |
| FPRMNum | MkFPRoundTowardZero () |
| Create a numeral of RoundingMode sort which represents the RoundTowardZero rounding mode. | |
| FPRMNum | MkFPRTZ () |
| Create a numeral of RoundingMode sort which represents the RoundTowardZero rounding mode. | |
| FPSort | MkFPSort (uint ebits, uint sbits) |
| Create a FloatingPoint sort. | |
| FPSort | MkFPSortHalf () |
| Create the half-precision (16-bit) FloatingPoint sort. | |
| FPSort | MkFPSort16 () |
| Create the half-precision (16-bit) FloatingPoint sort. | |
| FPSort | MkFPSortSingle () |
| Create the single-precision (32-bit) FloatingPoint sort. | |
| FPSort | MkFPSort32 () |
| Create the single-precision (32-bit) FloatingPoint sort. | |
| FPSort | MkFPSortDouble () |
| Create the double-precision (64-bit) FloatingPoint sort. | |
| FPSort | MkFPSort64 () |
| Create the double-precision (64-bit) FloatingPoint sort. | |
| FPSort | MkFPSortQuadruple () |
| Create the quadruple-precision (128-bit) FloatingPoint sort. | |
| FPSort | MkFPSort128 () |
| Create the quadruple-precision (128-bit) FloatingPoint sort. | |
| FPNum | MkFPNaN (FPSort s) |
| Create a NaN of sort s. | |
| FPNum | MkFPInf (FPSort s, bool negative) |
| Create a floating-point infinity of sort s. | |
| FPNum | MkFPZero (FPSort s, bool negative) |
| Create a floating-point zero of sort s. | |
| FPNum | MkFPNumeral (float v, FPSort s) |
| Create a numeral of FloatingPoint sort from a float. | |
| FPNum | MkFPNumeral (double v, FPSort s) |
| Create a numeral of FloatingPoint sort from a float. | |
| FPNum | MkFPNumeral (int v, FPSort s) |
| Create a numeral of FloatingPoint sort from an int. | |
| FPNum | MkFPNumeral (bool sgn, uint sig, int exp, FPSort s) |
| Create a numeral of FloatingPoint sort from a sign bit and two integers. | |
| FPNum | MkFPNumeral (bool sgn, Int64 exp, UInt64 sig, FPSort s) |
| Create a numeral of FloatingPoint sort from a sign bit and two 64-bit integers. | |
| FPNum | MkFP (float v, FPSort s) |
| Create a numeral of FloatingPoint sort from a float. | |
| FPNum | MkFP (double v, FPSort s) |
| Create a numeral of FloatingPoint sort from a float. | |
| FPNum | MkFP (int v, FPSort s) |
| Create a numeral of FloatingPoint sort from an int. | |
| FPNum | MkFP (bool sgn, int exp, uint sig, FPSort s) |
| Create a numeral of FloatingPoint sort from a sign bit and two integers. | |
| FPNum | MkFP (bool sgn, Int64 exp, UInt64 sig, FPSort s) |
| Create a numeral of FloatingPoint sort from a sign bit and two 64-bit integers. | |
| FPExpr | MkFPAbs (FPExpr t) |
| Floating-point absolute value. | |
| FPExpr | MkFPNeg (FPExpr t) |
| Floating-point negation. | |
| FPExpr | MkFPAdd (FPRMExpr rm, FPExpr t1, FPExpr t2) |
| Floating-point addition. | |
| FPExpr | MkFPSub (FPRMExpr rm, FPExpr t1, FPExpr t2) |
| Floating-point subtraction. | |
| FPExpr | MkFPMul (FPRMExpr rm, FPExpr t1, FPExpr t2) |
| Floating-point multiplication. | |
| FPExpr | MkFPDiv (FPRMExpr rm, FPExpr t1, FPExpr t2) |
| Floating-point division. | |
| FPExpr | MkFPFMA (FPRMExpr rm, FPExpr t1, FPExpr t2, FPExpr t3) |
| Floating-point fused multiply-add. | |
| FPExpr | MkFPSqrt (FPRMExpr rm, FPExpr t) |
| Floating-point square root. | |
| FPExpr | MkFPRem (FPExpr t1, FPExpr t2) |
| Floating-point remainder. | |
| FPExpr | MkFPRoundToIntegral (FPRMExpr rm, FPExpr t) |
| Floating-point roundToIntegral. Rounds a floating-point number to the closest integer, again represented as a floating-point number. | |
| FPExpr | MkFPMin (FPExpr t1, FPExpr t2) |
| Minimum of floating-point numbers. | |
| FPExpr | MkFPMax (FPExpr t1, FPExpr t2) |
| Maximum of floating-point numbers. | |
| BoolExpr | MkFPLEq (FPExpr t1, FPExpr t2) |
| Floating-point less than or equal. | |
| BoolExpr | MkFPLt (FPExpr t1, FPExpr t2) |
| Floating-point less than. | |
| BoolExpr | MkFPGEq (FPExpr t1, FPExpr t2) |
| Floating-point greater than or equal. | |
| BoolExpr | MkFPGt (FPExpr t1, FPExpr t2) |
| Floating-point greater than. | |
| BoolExpr | MkFPEq (FPExpr t1, FPExpr t2) |
| Floating-point equality. | |
| BoolExpr | MkFPIsNormal (FPExpr t) |
| Predicate indicating whether t is a normal floating-point number. | |
| BoolExpr | MkFPIsSubnormal (FPExpr t) |
| Predicate indicating whether t is a subnormal floating-point number. | |
| BoolExpr | MkFPIsZero (FPExpr t) |
| Predicate indicating whether t is a floating-point number with zero value, i.e., +0 or -0. | |
| BoolExpr | MkFPIsInfinite (FPExpr t) |
| Predicate indicating whether t is a floating-point number representing +oo or -oo. | |
| BoolExpr | MkFPIsNaN (FPExpr t) |
| Predicate indicating whether t is a NaN. | |
| BoolExpr | MkFPIsNegative (FPExpr t) |
| Predicate indicating whether t is a negative floating-point number. | |
| BoolExpr | MkFPIsPositive (FPExpr t) |
| Predicate indicating whether t is a positive floating-point number. | |
| FPExpr | MkFP (BitVecExpr sgn, BitVecExpr sig, BitVecExpr exp) |
| Create an expression of FloatingPoint sort from three bit-vector expressions. | |
| FPExpr | MkFPToFP (BitVecExpr bv, FPSort s) |
| Conversion of a single IEEE 754-2008 bit-vector into a floating-point number. | |
| FPExpr | MkFPToFP (FPRMExpr rm, FPExpr t, FPSort s) |
| Conversion of a FloatingPoint term into another term of different FloatingPoint sort. | |
| FPExpr | MkFPToFP (FPRMExpr rm, RealExpr t, FPSort s) |
| Conversion of a term of real sort into a term of FloatingPoint sort. | |
| FPExpr | MkFPToFP (FPRMExpr rm, BitVecExpr t, FPSort s, bool signed) |
| Conversion of a 2's complement signed bit-vector term into a term of FloatingPoint sort. | |
| FPExpr | MkFPToFP (FPSort s, FPRMExpr rm, FPExpr t) |
| Conversion of a floating-point number to another FloatingPoint sort s. | |
| BitVecExpr | MkFPToBV (FPRMExpr rm, FPExpr t, uint sz, bool sign) |
| Conversion of a floating-point term into a bit-vector. | |
| RealExpr | MkFPToReal (FPExpr t) |
| Conversion of a floating-point term into a real-numbered term. | |
| BitVecExpr | MkFPToIEEEBV (FPExpr t) |
| Conversion of a floating-point term into a bit-vector term in IEEE 754-2008 format. | |
| BitVecExpr | MkFPToFP (FPRMExpr rm, IntExpr exp, RealExpr sig, FPSort s) |
| Conversion of a real-sorted significand and an integer-sorted exponent into a term of FloatingPoint sort. | |
| AST | WrapAST (IntPtr nativeObject) |
| Wraps an AST. | |
| IntPtr | UnwrapAST (AST a) |
| Unwraps an AST. | |
| string | SimplifyHelp () |
Return a string describing all available parameters to Expr.Simplify. | |
| void | UpdateParamValue (string id, string value) |
| Update a mutable configuration parameter. | |
| void | Dispose () |
| Disposes of the context. | |
Properties | |
| BoolSort | BoolSort [get] |
| Retrieves the Boolean sort of the context. | |
| IntSort | IntSort [get] |
| Retrieves the Integer sort of the context. | |
| RealSort | RealSort [get] |
| Retrieves the Real sort of the context. | |
| CharSort | CharSort [get] |
| Retrieves the String sort of the context. | |
| SeqSort | StringSort [get] |
| Retrieves the String sort of the context. | |
| Z3_ast_print_mode | PrintMode [set] |
| Selects the format used for pretty-printing expressions. | |
| uint | NumTactics [get] |
| The number of supported tactics. | |
| string[] | TacticNames [get] |
| The names of all supported tactics. | |
| uint | NumSimplifiers [get] |
| The number of supported simplifiers. | |
| string[] | SimplifierNames [get] |
| The names of all supported tactics. | |
| uint | NumProbes [get] |
| The number of supported Probes. | |
| string[] | ProbeNames [get] |
| The names of all supported Probes. | |
| ParamDescrs | SimplifyParameterDescriptions [get] |
| Retrieves parameter descriptions for simplifier. | |
The main interaction with Z3 happens via the Context.
Definition at line 33 of file Context.cs.
|
inline |
Constructor.
Definition at line 39 of file Context.cs.
|
inline |
Constructor.
The following parameters can be set:
Definition at line 68 of file Context.cs.
Bind a definition to a recursive function declaration. The function must have previously been created using MkRecFuncDecl. The body may contain recursive uses of the function or other mutually recursive functions.
Definition at line 647 of file Context.cs.
Create a probe that evaluates to "true" when the value p1 and p2 evaluate to "true".
Definition at line 3964 of file Context.cs.
|
inline |
Create a simplifier that applies t1 and then t2 .
Definition at line 3781 of file Context.cs.
Create a tactic that applies t1 to a Goal and then t2 to every subgoal produced by t1 .
Definition at line 3519 of file Context.cs.
Referenced by Context.Then(), and Context.Then().
|
inline |
Create a character from a bit-vector (code point).
Definition at line 2826 of file Context.cs.
|
inline |
Create a bit-vector (code point) from character.
Definition at line 2817 of file Context.cs.
Create an integer (code point) from character.
Definition at line 2808 of file Context.cs.
Create a tactic that applies t1 to a given goal if the probe p evaluates to true and t2 otherwise.
Definition at line 3611 of file Context.cs.
|
inline |
Create a probe that always evaluates to val .
Definition at line 3884 of file Context.cs.
|
inline |
Disposes of the context.
Definition at line 4992 of file Context.cs.
Create a probe that evaluates to "true" when the value returned by p1 is equal to the value returned by p2
Definition at line 3950 of file Context.cs.
|
inline |
Create a tactic always fails.
Definition at line 3647 of file Context.cs.
Create a tactic that fails if the probe p evaluates to false.
Definition at line 3656 of file Context.cs.
|
inline |
Create a tactic that fails if the goal is not trivially satisfiable (i.e., empty) or trivially unsatisfiable (i.e., contains ‘false’).
Definition at line 3668 of file Context.cs.
Create a probe that evaluates to "true" when the value returned by p1 is greater than or equal the value returned by p2
Definition at line 3936 of file Context.cs.
Create a probe that evaluates to "true" when the value returned by p1 is greater than the value returned by p2
Definition at line 3908 of file Context.cs.
|
inline |
Interrupt the execution of a Z3 procedure.
This procedure can be used to interrupt: solvers, simplifiers and tactics.
Definition at line 3728 of file Context.cs.
Convert an integer expression to a string.
Definition at line 2477 of file Context.cs.
Create a probe that evaluates to "true" when the value returned by p1 is less than or equal the value returned by p2
Definition at line 3922 of file Context.cs.
Create a probe that evaluates to "true" when the value returned by p1 is less than the value returned by p2
Definition at line 3894 of file Context.cs.
Create an expression representing t[0] + t[1] + ....
Definition at line 1118 of file Context.cs.
Create an expression representing t[0] + t[1] + ....
Definition at line 1106 of file Context.cs.
Referenced by Context.MkAdd(), and ArithExpr.operator+().
Create an expression representing t[0] and t[1] and ....
Definition at line 1072 of file Context.cs.
Create an expression representing t[0] and t[1] and ....
Definition at line 1060 of file Context.cs.
Referenced by Goal.AsBoolExpr(), Context.MkAnd(), and BoolExpr.operator&().
Create a new function application.
Definition at line 908 of file Context.cs.
Create a new function application.
Definition at line 896 of file Context.cs.
Referenced by EnumSort.Const(), Context.MkApp(), and Context.MkConst().
Create an array constant.
Definition at line 2120 of file Context.cs.
Create an array constant.
Definition at line 2107 of file Context.cs.
Create Extentionality index. Two arrays are equal if and only if they are equal on the index returned by MkArrayExt.
Definition at line 2296 of file Context.cs.
Create a new array sort.
Definition at line 276 of file Context.cs.
Referenced by Context.MkArrayConst(), and Context.MkArrayConst().
Create a new n-ary array sort.
Definition at line 289 of file Context.cs.
Retrieve sequence of length one at index.
Definition at line 2595 of file Context.cs.
Create an at-least-k constraint.
Definition at line 2860 of file Context.cs.
Create an at-most-k constraint.
Definition at line 2848 of file Context.cs.
|
inline |
Create a new bit-vector sort.
Definition at line 250 of file Context.cs.
Referenced by Context.MkBV(), Context.MkBV(), Context.MkBV(), Context.MkBV(), Context.MkBV(), Context.MkBVConst(), and Context.MkBVConst().
|
inline |
|
inline |
Create a Boolean constant.
Definition at line 826 of file Context.cs.
Create a Boolean constant.
Definition at line 816 of file Context.cs.
|
inline |
Create a new Boolean sort.
Definition at line 205 of file Context.cs.
Creates a new bound variable.
| index | The de-Bruijn index of the variable |
| ty | The sort of the variable |
Definition at line 741 of file Context.cs.
|
inline |
Create a bit-vector numeral.
| bits | An array of bits representing the bit-vector. Least significant bit is at position 0. |
Definition at line 3177 of file Context.cs.
|
inline |
Create a bit-vector numeral.
| v | value of the numeral. |
| size | the size of the bit-vector |
Definition at line 3134 of file Context.cs.
|
inline |
Create a bit-vector numeral.
| v | value of the numeral. |
| size | the size of the bit-vector |
Definition at line 3156 of file Context.cs.
|
inline |
Create a bit-vector numeral.
| v | A string representing the value in decimal notation. |
| size | the size of the bit-vector |
Definition at line 3123 of file Context.cs.
|
inline |
Create a bit-vector numeral.
| v | value of the numeral. |
| size | the size of the bit-vector |
Definition at line 3145 of file Context.cs.
|
inline |
Create a bit-vector numeral.
| v | value of the numeral. |
| size | the size of the bit-vector |
Definition at line 3167 of file Context.cs.
|
inline |
Create an integer from the bit-vector argument t .
If is_signed is false, then the bit-vector t1 is treated as unsigned. So the result is non-negative and in the range [0..2^N-1], where N are the number of bits in t . If is_signed is true, t1 is treated as a signed bit-vector.
NB. This function is essentially treated as uninterpreted. So you cannot expect Z3 to precisely reflect the semantics of this function when solving constraints with this function.
The argument must be of bit-vector sort.
Definition at line 1968 of file Context.cs.
|
inline |
Two's complement addition.
The arguments must have the same bit-vector sort.
Definition at line 1456 of file Context.cs.
|
inline |
Create a predicate that checks that the bit-wise addition does not overflow.
The arguments must be of bit-vector sort.
Definition at line 1982 of file Context.cs.
|
inline |
Create a predicate that checks that the bit-wise addition does not underflow.
The arguments must be of bit-vector sort.
Definition at line 1998 of file Context.cs.
|
inline |
Bitwise conjunction.
The arguments must have a bit-vector sort.
Definition at line 1360 of file Context.cs.
|
inline |
Arithmetic shift right.
It is like logical shift right except that the most significant bits of the result always copy the most significant bit of the second argument.
NB. The semantics of shift operations varies between environments. This definition does not necessarily capture directly the semantics of the programming language or assembly architecture you are modeling.
The arguments must have a bit-vector sort.
Definition at line 1861 of file Context.cs.
|
inline |
Creates a bit-vector constant.
Definition at line 885 of file Context.cs.
|
inline |
Creates a bit-vector constant.
Definition at line 874 of file Context.cs.
|
inline |
Logical shift right.
It is equivalent to unsigned division by 2^x where x is the value of t2 .
NB. The semantics of shift operations varies between environments. This definition does not necessarily capture directly the semantics of the programming language or assembly architecture you are modeling.
The arguments must have a bit-vector sort.
Definition at line 1837 of file Context.cs.
|
inline |
Two's complement multiplication.
The arguments must have the same bit-vector sort.
Definition at line 1484 of file Context.cs.
|
inline |
Create a predicate that checks that the bit-wise multiplication does not overflow.
The arguments must be of bit-vector sort.
Definition at line 2076 of file Context.cs.
|
inline |
Create a predicate that checks that the bit-wise multiplication does not underflow.
The arguments must be of bit-vector sort.
Definition at line 2092 of file Context.cs.
|
inline |
Bitwise NAND.
The arguments must have a bit-vector sort.
Definition at line 1402 of file Context.cs.
|
inline |
Standard two's complement unary minus.
The arguments must have a bit-vector sort.
Definition at line 1444 of file Context.cs.
|
inline |
Create a predicate that checks that the bit-wise negation does not overflow.
The arguments must be of bit-vector sort.
Definition at line 2062 of file Context.cs.
|
inline |
Bitwise NOR.
The arguments must have a bit-vector sort.
Definition at line 1416 of file Context.cs.
|
inline |
Bitwise negation.
The argument must have a bit-vector sort.
Definition at line 1324 of file Context.cs.
|
inline |
Bitwise disjunction.
The arguments must have a bit-vector sort.
Definition at line 1374 of file Context.cs.
|
inline |
Take conjunction of bits in a vector, return vector of length 1.
The argument must have a bit-vector sort.
Definition at line 1336 of file Context.cs.
|
inline |
Take disjunction of bits in a vector, return vector of length 1.
The argument must have a bit-vector sort.
Definition at line 1348 of file Context.cs.
|
inline |
Rotate Left.
Rotate bits of t1 to the left t2 times. The arguments must have the same bit-vector sort.
Definition at line 1908 of file Context.cs.
|
inline |
Rotate Left.
Rotate bits of t to the left i times. The argument t must have a bit-vector sort.
Definition at line 1878 of file Context.cs.
|
inline |
Rotate Right.
Rotate bits of t1 to the rightt2 times. The arguments must have the same bit-vector sort.
Definition at line 1925 of file Context.cs.
|
inline |
Rotate Right.
Rotate bits of t to the right i times. The argument t must have a bit-vector sort.
Definition at line 1893 of file Context.cs.
|
inline |
Signed division.
It is defined in the following way:
floor of t1/t2 if t2 is different from zero, and t1*t2 >= 0.ceiling of t1/t2 if t2 is different from zero, and t1*t2 < 0.If t2 is zero, then the result is undefined. The arguments must have the same bit-vector sort.
Definition at line 1526 of file Context.cs.
|
inline |
Create a predicate that checks that the bit-wise signed division does not overflow.
The arguments must be of bit-vector sort.
Definition at line 2046 of file Context.cs.
|
inline |
Two's complement signed greater than or equal to.
The arguments must have the same bit-vector sort.
Definition at line 1677 of file Context.cs.
|
inline |
Two's complement signed greater-than.
The arguments must have the same bit-vector sort.
Definition at line 1709 of file Context.cs.
|
inline |
Shift left.
It is equivalent to multiplication by 2^x where x is the value of t2 .
NB. The semantics of shift operations varies between environments. This definition does not necessarily capture directly the semantics of the programming language or assembly architecture you are modeling.
The arguments must have a bit-vector sort.
Definition at line 1815 of file Context.cs.
|
inline |
Two's complement signed less-than or equal to.
The arguments must have the same bit-vector sort.
Definition at line 1645 of file Context.cs.
|
inline |
Two's complement signed less-than.
The arguments must have the same bit-vector sort.
Definition at line 1613 of file Context.cs.
|
inline |
Two's complement signed remainder (sign follows divisor).
If t2 is zero, then the result is undefined. The arguments must have the same bit-vector sort.
Definition at line 1581 of file Context.cs.
|
inline |
Signed remainder.
It is defined as t1 - (t1 /s t2) * t2, where /s represents signed division. The most significant bit (sign) of the result is equal to the most significant bit of t1.
If t2 is zero, then the result is undefined. The arguments must have the same bit-vector sort.
Definition at line 1564 of file Context.cs.
|
inline |
Two's complement subtraction.
The arguments must have the same bit-vector sort.
Definition at line 1470 of file Context.cs.
|
inline |
Create a predicate that checks that the bit-wise subtraction does not overflow.
The arguments must be of bit-vector sort.
Definition at line 2014 of file Context.cs.
|
inline |
Create a predicate that checks that the bit-wise subtraction does not underflow.
The arguments must be of bit-vector sort.
Definition at line 2030 of file Context.cs.
|
inline |
Unsigned division.
It is defined as the floor of t1/t2 if t2 is different from zero. If t2 is zero, then the result is undefined. The arguments must have the same bit-vector sort.
Definition at line 1503 of file Context.cs.
|
inline |
Unsigned greater than or equal to.
The arguments must have the same bit-vector sort.
Definition at line 1661 of file Context.cs.
|
inline |
Unsigned greater-than.
The arguments must have the same bit-vector sort.
Definition at line 1693 of file Context.cs.
|
inline |
Unsigned less-than or equal to.
The arguments must have the same bit-vector sort.
Definition at line 1629 of file Context.cs.
|
inline |
Unsigned less-than.
The arguments must have the same bit-vector sort.
Definition at line 1597 of file Context.cs.
|
inline |
Unsigned remainder.
It is defined as t1 - (t1 /u t2) * t2, where /u represents unsigned division. If t2 is zero, then the result is undefined. The arguments must have the same bit-vector sort.
Definition at line 1544 of file Context.cs.
|
inline |
Bitwise XNOR.
The arguments must have a bit-vector sort.
Definition at line 1430 of file Context.cs.
|
inline |
Bitwise XOR.
The arguments must have a bit-vector sort.
Definition at line 1388 of file Context.cs.
Create less than or equal to between two characters.
Definition at line 2798 of file Context.cs.
Create the complement regular expression.
Definition at line 2710 of file Context.cs.
|
inline |
Bit-vector concatenation.
The arguments must have a bit-vector sort.
n1+n2, where n1 (n2) is the size of t1 (t2). Definition at line 1729 of file Context.cs.
Create the concatenation of regular languages.
Definition at line 2719 of file Context.cs.
Concatenate sequences.
Definition at line 2518 of file Context.cs.
Creates a fresh constant from the FuncDecl f .
| f | A decl of a 0-arity function |
Definition at line 806 of file Context.cs.
Creates a new Constant of sort range and named name .
Definition at line 782 of file Context.cs.
Creates a new Constant of sort range and named name .
Definition at line 768 of file Context.cs.
Referenced by Context.MkArrayConst(), Context.MkArrayConst(), Context.MkBoolConst(), Context.MkBoolConst(), Context.MkBVConst(), Context.MkBVConst(), Context.MkConst(), Context.MkIntConst(), Context.MkIntConst(), Context.MkRealConst(), and Context.MkRealConst().
Create a constant array.
The resulting term is an array, such that a selecton an arbitrary index produces the value v.
Definition at line 2247 of file Context.cs.
Creates a new constant function declaration.
Definition at line 702 of file Context.cs.
Creates a new constant function declaration.
Definition at line 689 of file Context.cs.
|
inline |
Create a datatype constructor.
| name | |
| recognizer | |
| fieldNames | |
| sorts | |
| sortRefs |
Definition at line 432 of file Context.cs.
|
inline |
Create a datatype constructor.
| name | constructor name |
| recognizer | name of recognizer function. |
| fieldNames | names of the constructor fields. |
| sorts | field sorts, 0 if the field sort refers to a recursive sort. |
| sortRefs | reference to datatype sort that is an argument to the constructor; if the corresponding sort reference is 0, then the value in sort_refs should be an index referring to one of the recursive datatypes that is declared. |
Definition at line 415 of file Context.cs.
Check for sequence containment of s2 in s1.
Definition at line 2562 of file Context.cs.
|
inline |
Create a new datatype sort.
Definition at line 467 of file Context.cs.
|
inline |
Create a new datatype sort.
Definition at line 452 of file Context.cs.
|
inline |
Create a forward reference to a datatype sort. This is useful for creating recursive datatypes or parametric datatypes.
| name | name of the datatype sort |
| parameters | optional array of sort parameters for parametric datatypes |
Definition at line 501 of file Context.cs.
|
inline |
Create a forward reference to a datatype sort. This is useful for creating recursive datatypes or parametric datatypes.
| name | name of the datatype sort |
| parameters | optional array of sort parameters for parametric datatypes |
Definition at line 483 of file Context.cs.
Referenced by Context.MkDatatypeSortRef().
|
inline |
Create mutually recursive data-types.
| names | |
| c |
Definition at line 545 of file Context.cs.
|
inline |
Create mutually recursive datatypes.
| names | names of datatype sorts |
| c | list of constructors, one list per sort. |
Definition at line 512 of file Context.cs.
Referenced by Context.MkDatatypeSorts().
Create a difference regular expression.
Definition at line 2755 of file Context.cs.
Creates a distinct term.
Definition at line 967 of file Context.cs.
Creates a distinct term.
Definition at line 955 of file Context.cs.
Referenced by Context.MkDistinct().
Create an expression representing t1 / t2.
Definition at line 1171 of file Context.cs.
Referenced by ArithExpr.operator/().
Create the empty regular expression. The sort s should be a regular expression.
Definition at line 2767 of file Context.cs.
Create the empty sequence.
Definition at line 2450 of file Context.cs.
Create an empty set.
Definition at line 2323 of file Context.cs.
|
inline |
Create a new enumeration sort.
Definition at line 333 of file Context.cs.
Create a new enumeration sort.
Definition at line 318 of file Context.cs.
Creates the equality x = y .
Definition at line 942 of file Context.cs.
|
inline |
Create an existential Quantifier.
Creates an existential quantifier using a list of constants that will form the set of bound variables.
Definition at line 3278 of file Context.cs.
|
inline |
Create an existential Quantifier.
Creates an existential quantifier using de-Bruijn indexed variables. (MkForall(Sort[], Symbol[], Expr, uint, Pattern[], Expr[], Symbol, Symbol)).
Definition at line 3256 of file Context.cs.
Referenced by Context.MkQuantifier(), and Context.MkQuantifier().
Extract subsequence.
Definition at line 2617 of file Context.cs.
|
inline |
Bit-vector extraction.
Extract the bits high down to low from a bitvector of size m to yield a new bitvector of size n, where n = high - low + 1. The argument t must have a bit-vector sort.
Definition at line 1748 of file Context.cs.
|
inline |
The false Term.
Definition at line 926 of file Context.cs.
Referenced by Context.MkBool(), and Context.MkXor().
|
inline |
Create a new finite domain sort.
Elements of the sort are created using
, and the elements range from 0 to size-1.
| name | The name used to identify the sort |
| size | The size of the sort |
Definition at line 397 of file Context.cs.
|
inline |
Create a new finite domain sort.
| name | The name used to identify the sort |
| size | The size of the sort |
Definition at line 381 of file Context.cs.
|
inline |
Create a Fixedpoint context.
Definition at line 4069 of file Context.cs.
|
inline |
Create a universal Quantifier.
Creates a universal quantifier using a list of constants that will form the set of bound variables.
Definition at line 3238 of file Context.cs.
|
inline |
Create a universal Quantifier.
Creates a forall formula, where weight is the weight, patterns is an array of patterns, sorts is an array with the sorts of the bound variables, names is an array with the 'names' of the bound variables, and body is the body of the quantifier. Quantifiers are associated with weights indicating the importance of using the quantifier during instantiation. Note that the bound variables are de-Bruijn indices created using MkBound. Z3 applies the convention that the last element in names and sorts refers to the variable with index 0, the second to last element of names and sorts refers to the variable with index 1, etc.
| sorts | the sorts of the bound variables. |
| names | names of the bound variables |
| body | the body of the quantifier. |
| weight | quantifiers are associated with weights indicating the importance of using the quantifier during instantiation. By default, pass the weight 0. |
| patterns | array containing the patterns created using MkPattern. |
| noPatterns | array containing the anti-patterns created using MkPattern. |
| quantifierID | optional symbol to track quantifier. |
| skolemID | optional symbol to track skolem constants. |
Definition at line 3214 of file Context.cs.
Referenced by Context.MkQuantifier(), and Context.MkQuantifier().
|
inline |
Create an expression of FloatingPoint sort from three bit-vector expressions.
This is the operator named ‘fp’ in the SMT FP theory definition. Note that sgn is required to be a bit-vector of size 1. Significand and exponent are required to be greater than 1 and 2 respectively. The FloatingPoint sort of the resulting expression is automatically determined from the bit-vector sizes of the arguments.
| sgn | bit-vector term (of size 1) representing the sign. |
| sig | bit-vector term representing the significand. |
| exp | bit-vector term representing the exponent. |
Definition at line 4659 of file Context.cs.
Create a numeral of FloatingPoint sort from a sign bit and two integers.
| sgn | the sign. |
| exp | the exponent. |
| sig | the significand. |
| s | FloatingPoint sort. |
Definition at line 4380 of file Context.cs.
Create a numeral of FloatingPoint sort from a sign bit and two 64-bit integers.
| sgn | the sign. |
| exp | the exponent. |
| sig | the significand. |
| s | FloatingPoint sort. |
Definition at line 4392 of file Context.cs.
Create a numeral of FloatingPoint sort from a float.
| v | numeral value. |
| s | FloatingPoint sort. |
Definition at line 4358 of file Context.cs.
Create a numeral of FloatingPoint sort from a float.
| v | numeral value. |
| s | FloatingPoint sort. |
Definition at line 4348 of file Context.cs.
Create a numeral of FloatingPoint sort from an int.
| v | numeral value. |
| s | FloatingPoint sort. |
Definition at line 4368 of file Context.cs.
Floating-point absolute value.
| t | floating-point term |
Definition at line 4404 of file Context.cs.
Floating-point addition.
| rm | rounding mode term |
| t1 | floating-point term |
| t2 | floating-point term |
Definition at line 4424 of file Context.cs.
Floating-point division.
| rm | rounding mode term |
| t1 | floating-point term |
| t2 | floating-point term |
Definition at line 4457 of file Context.cs.
Floating-point equality.
Note that this is IEEE 754 equality (as opposed to standard =).
| t1 | floating-point term |
| t2 | floating-point term |
Definition at line 4576 of file Context.cs.
Floating-point fused multiply-add.
The result is round((t1 * t2) + t3)
| rm | rounding mode term |
| t1 | floating-point term |
| t2 | floating-point term |
| t3 | floating-point term |
Definition at line 4472 of file Context.cs.
Floating-point greater than or equal.
| t1 | floating-point term |
| t2 | floating-point term |
Definition at line 4553 of file Context.cs.
Floating-point greater than.
| t1 | floating-point term |
| t2 | floating-point term |
Definition at line 4563 of file Context.cs.
Create a floating-point infinity of sort s.
| s | FloatingPoint sort. |
| negative | indicates whether the result should be negative. |
Definition at line 4274 of file Context.cs.
Predicate indicating whether t is a floating-point number representing +oo or -oo.
| t | floating-point term |
Definition at line 4612 of file Context.cs.
Predicate indicating whether t is a NaN.
| t | floating-point term |
Definition at line 4621 of file Context.cs.
Predicate indicating whether t is a negative floating-point number.
| t | floating-point term |
Definition at line 4630 of file Context.cs.
Predicate indicating whether t is a normal floating-point number.
| t | floating-point term |
Definition at line 4585 of file Context.cs.
Predicate indicating whether t is a positive floating-point number.
| t | floating-point term |
Definition at line 4639 of file Context.cs.
Predicate indicating whether t is a subnormal floating-point number.
| t | floating-point term |
Definition at line 4594 of file Context.cs.
Predicate indicating whether t is a floating-point number with zero value, i.e., +0 or -0.
| t | floating-point term |
Definition at line 4603 of file Context.cs.
Floating-point less than or equal.
| t1 | floating-point term |
| t2 | floating-point term |
Definition at line 4533 of file Context.cs.
Floating-point less than.
| t1 | floating-point term |
| t2 | floating-point term |
Definition at line 4543 of file Context.cs.
Maximum of floating-point numbers.
| t1 | floating-point term |
| t2 | floating-point term |
Definition at line 4523 of file Context.cs.
Minimum of floating-point numbers.
| t1 | floating-point term |
| t2 | floating-point term |
Definition at line 4513 of file Context.cs.
Floating-point multiplication.
| rm | rounding mode term |
| t1 | floating-point term |
| t2 | floating-point term |
Definition at line 4446 of file Context.cs.
Create a NaN of sort s.
| s | FloatingPoint sort. |
Definition at line 4264 of file Context.cs.
Floating-point negation.
| t | floating-point term |
Definition at line 4413 of file Context.cs.
Create a numeral of FloatingPoint sort from a sign bit and two 64-bit integers.
| sgn | the sign. |
| sig | the significand. |
| exp | the exponent. |
| s | FloatingPoint sort. |
Definition at line 4338 of file Context.cs.
Create a numeral of FloatingPoint sort from a sign bit and two integers.
| sgn | the sign. |
| sig | the significand. |
| exp | the exponent. |
| s | FloatingPoint sort. |
Definition at line 4326 of file Context.cs.
Create a numeral of FloatingPoint sort from a float.
| v | numeral value. |
| s | FloatingPoint sort. |
Definition at line 4304 of file Context.cs.
Create a numeral of FloatingPoint sort from a float.
| v | numeral value. |
| s | FloatingPoint sort. |
Definition at line 4294 of file Context.cs.
Referenced by Context.MkFP(), Context.MkFP(), Context.MkFP(), Context.MkFP(), and Context.MkFP().
Create a numeral of FloatingPoint sort from an int.
| v | numeral value. |
| s | FloatingPoint sort. |
Definition at line 4314 of file Context.cs.
Floating-point remainder.
| t1 | floating-point term |
| t2 | floating-point term |
Definition at line 4492 of file Context.cs.
|
inline |
Create a numeral of RoundingMode sort which represents the NearestTiesToAway rounding mode.
Definition at line 4128 of file Context.cs.
|
inline |
Create a numeral of RoundingMode sort which represents the NearestTiesToEven rounding mode.
Definition at line 4112 of file Context.cs.
|
inline |
Create the floating-point RoundingMode sort.
Definition at line 4094 of file Context.cs.
|
inline |
Create a numeral of RoundingMode sort which represents the NearestTiesToAway rounding mode.
Definition at line 4120 of file Context.cs.
|
inline |
Create a numeral of RoundingMode sort which represents the NearestTiesToEven rounding mode.
Definition at line 4104 of file Context.cs.
Floating-point roundToIntegral. Rounds a floating-point number to the closest integer, again represented as a floating-point number.
| rm | term of RoundingMode sort |
| t | floating-point term |
Definition at line 4503 of file Context.cs.
|
inline |
Create a numeral of RoundingMode sort which represents the RoundTowardNegative rounding mode.
Definition at line 4152 of file Context.cs.
|
inline |
Create a numeral of RoundingMode sort which represents the RoundTowardPositive rounding mode.
Definition at line 4136 of file Context.cs.
|
inline |
Create a numeral of RoundingMode sort which represents the RoundTowardZero rounding mode.
Definition at line 4168 of file Context.cs.
|
inline |
Create a numeral of RoundingMode sort which represents the RoundTowardNegative rounding mode.
Definition at line 4160 of file Context.cs.
|
inline |
Create a numeral of RoundingMode sort which represents the RoundTowardPositive rounding mode.
Definition at line 4144 of file Context.cs.
|
inline |
Create a numeral of RoundingMode sort which represents the RoundTowardZero rounding mode.
Definition at line 4176 of file Context.cs.
|
inline |
Create a FloatingPoint sort.
| ebits | exponent bits in the FloatingPoint sort. |
| sbits | significand bits in the FloatingPoint sort. |
Definition at line 4189 of file Context.cs.
|
inline |
Create the quadruple-precision (128-bit) FloatingPoint sort.
Definition at line 4253 of file Context.cs.
|
inline |
Create the half-precision (16-bit) FloatingPoint sort.
Definition at line 4205 of file Context.cs.
|
inline |
Create the single-precision (32-bit) FloatingPoint sort.
Definition at line 4221 of file Context.cs.
|
inline |
Create the double-precision (64-bit) FloatingPoint sort.
Definition at line 4237 of file Context.cs.
|
inline |
Create the double-precision (64-bit) FloatingPoint sort.
Definition at line 4229 of file Context.cs.
|
inline |
Create the half-precision (16-bit) FloatingPoint sort.
Definition at line 4197 of file Context.cs.
|
inline |
Create the quadruple-precision (128-bit) FloatingPoint sort.
Definition at line 4245 of file Context.cs.
|
inline |
Create the single-precision (32-bit) FloatingPoint sort.
Definition at line 4213 of file Context.cs.
Floating-point square root.
| rm | rounding mode term |
| t | floating-point term |
Definition at line 4482 of file Context.cs.
Floating-point subtraction.
| rm | rounding mode term |
| t1 | floating-point term |
| t2 | floating-point term |
Definition at line 4435 of file Context.cs.
|
inline |
Conversion of a floating-point term into a bit-vector.
Produces a term that represents the conversion of the floating-point term t into a bit-vector term of size sz in 2's complement format (signed when sign==true). If necessary, the result will be rounded according to rounding mode rm.
| rm | RoundingMode term. |
| t | FloatingPoint term |
| sz | Size of the resulting bit-vector. |
| sign | Indicates whether the result is a signed or unsigned bit-vector. |
Definition at line 4762 of file Context.cs.
|
inline |
Conversion of a single IEEE 754-2008 bit-vector into a floating-point number.
Produces a term that represents the conversion of a bit-vector term bv to a floating-point term of sort s. The bit-vector size of bv (m) must be equal to ebits+sbits of s. The format of the bit-vector is as defined by the IEEE 754-2008 interchange format.
| bv | bit-vector value (of size m). |
| s | FloatingPoint sort (ebits+sbits == m) |
Definition at line 4675 of file Context.cs.
|
inline |
Conversion of a 2's complement signed bit-vector term into a term of FloatingPoint sort.
Produces a term that represents the conversion of the bit-vector term t into a floating-point term of sort s. The bit-vector t is taken to be in signed 2's complement format (when signed==true, otherwise unsigned). If necessary, the result will be rounded according to rounding mode rm.
| rm | RoundingMode term. |
| t | term of bit-vector sort. |
| s | FloatingPoint sort. |
| signed | flag indicating whether t is interpreted as signed or unsigned bit-vector. |
Definition at line 4725 of file Context.cs.
Conversion of a FloatingPoint term into another term of different FloatingPoint sort.
Produces a term that represents the conversion of a floating-point term t to a floating-point term of sort s. If necessary, the result will be rounded according to rounding mode rm.
| rm | RoundingMode term. |
| t | FloatingPoint term. |
| s | FloatingPoint sort. |
Definition at line 4691 of file Context.cs.
|
inline |
Conversion of a real-sorted significand and an integer-sorted exponent into a term of FloatingPoint sort.
Produces a term that represents the conversion of sig * 2^exp into a floating-point term of sort s. If necessary, the result will be rounded according to rounding mode rm.
| rm | RoundingMode term. |
| exp | Exponent term of Int sort. |
| sig | Significand term of Real sort. |
| s | FloatingPoint sort. |
Definition at line 4813 of file Context.cs.
Conversion of a term of real sort into a term of FloatingPoint sort.
Produces a term that represents the conversion of term t of real sort into a floating-point term of sort s. If necessary, the result will be rounded according to rounding mode rm.
| rm | RoundingMode term. |
| t | term of Real sort. |
| s | FloatingPoint sort. |
Definition at line 4707 of file Context.cs.
Conversion of a floating-point number to another FloatingPoint sort s.
Produces a term that represents the conversion of a floating-point term t to a different FloatingPoint sort s. If necessary, rounding according to rm is applied.
| s | FloatingPoint sort |
| rm | floating-point rounding mode term |
| t | floating-point term |
Definition at line 4743 of file Context.cs.
|
inline |
Conversion of a floating-point term into a bit-vector term in IEEE 754-2008 format.
The size of the resulting bit-vector is automatically determined. Note that IEEE 754-2008 allows multiple different representations of NaN. This conversion knows only one NaN and it will always produce the same bit-vector representation of that NaN.
| t | FloatingPoint term. |
Definition at line 4796 of file Context.cs.
Conversion of a floating-point term into a real-numbered term.
Produces a term that represents the conversion of the floating-point term t into a real number. Note that this type of conversion will often result in non-linear constraints over real terms.
| t | FloatingPoint term |
Definition at line 4779 of file Context.cs.
Create a floating-point zero of sort s.
| s | FloatingPoint sort. |
| negative | indicates whether the result should be negative. |
Definition at line 4284 of file Context.cs.
Creates a fresh Constant of sort range and a name prefixed with prefix .
Definition at line 794 of file Context.cs.
Creates a fresh constant function declaration with a name prefixed with prefix .
Definition at line 716 of file Context.cs.
Creates a fresh function declaration with a name prefixed with prefix .
Definition at line 676 of file Context.cs.
Create the full regular expression. The sort s should be a regular expression.
Definition at line 2777 of file Context.cs.
Create the full set.
Definition at line 2334 of file Context.cs.
Creates a new function declaration.
Definition at line 659 of file Context.cs.
Creates a new function declaration.
Definition at line 616 of file Context.cs.
Creates a new function declaration.
Definition at line 600 of file Context.cs.
Creates a new function declaration.
Definition at line 585 of file Context.cs.
Create an expression representing t1 >= t2
Definition at line 1264 of file Context.cs.
Referenced by ArithExpr.operator>=().
|
inline |
Creates a new Goal.
Note that the Context must have been created with proof generation support if proofs is set to true here.
| models | Indicates whether model generation should be enabled. |
| unsatCores | Indicates whether unsat core generation should be enabled. |
| proofs | Indicates whether proof generation should be enabled. |
Definition at line 3454 of file Context.cs.
Create an expression representing t1 > t2
Definition at line 1251 of file Context.cs.
Referenced by ArithExpr.operator>().
Create an expression representing t1 iff t2.
Definition at line 1004 of file Context.cs.
Create an expression representing t1 -> t2.
Definition at line 1017 of file Context.cs.
Extract index of sub-string starting at offset.
Definition at line 2629 of file Context.cs.
Check for regular expression membership.
Definition at line 2663 of file Context.cs.
|
inline |
Create an integer numeral.
| v | value of the numeral. |
Definition at line 3077 of file Context.cs.
|
inline |
Create an integer numeral.
| v | value of the numeral. |
Definition at line 3099 of file Context.cs.
|
inline |
Create an integer numeral.
| v | A string representing the Term value in decimal notation. |
Definition at line 3066 of file Context.cs.
|
inline |
Create an integer numeral.
| v | value of the numeral. |
Definition at line 3088 of file Context.cs.
|
inline |
Create an integer numeral.
| v | value of the numeral. |
Definition at line 3110 of file Context.cs.
|
inline |
Create an n bit bit-vector from the integer argument t .
NB. This function is essentially treated as uninterpreted. So you cannot expect Z3 to precisely reflect the semantics of this function when solving constraints with this function.
The argument must be of integer sort.
Definition at line 1945 of file Context.cs.
Coerce an integer to a real.
There is also a converse operation exposed. It follows the semantics prescribed by the SMT-LIB standard.
You can take the floor of a real by creating an auxiliary integer Term k and and asserting MakeInt2Real(k) <= t1 < MkInt2Real(k)+1. The argument must be of integer sort.
Definition at line 1284 of file Context.cs.
|
inline |
Creates an integer constant.
Definition at line 845 of file Context.cs.
Creates an integer constant.
Definition at line 835 of file Context.cs.
Create the intersection of regular languages.
Definition at line 2743 of file Context.cs.
|
inline |
Create a new integer sort.
Definition at line 233 of file Context.cs.
Create a check if the character is a digit.
Definition at line 2835 of file Context.cs.
Creates an expression that checks whether a real number is an integer.
Definition at line 1310 of file Context.cs.
Create an expression representing an if-then-else: ite(t1, t2, t3).
| t1 | An expression with Boolean sort |
| t2 | An expression |
| t3 | An expression with the same sort as t2 |
Definition at line 989 of file Context.cs.
Create a lambda expression.
Creates a lambda expression using a list of constants that will form the set of bound variables.
Definition at line 3367 of file Context.cs.
Create a lambda expression.
Creates a lambda expression. sorts is an array with the sorts of the bound variables, names is an array with the 'names' of the bound variables, and body is the body of the lambda. Note that the bound variables are de-Bruijn indices created using MkBound. Z3 applies the convention that the last element in names and sorts refers to the variable with index 0, the second to last element of names and sorts refers to the variable with index 1, etc.
| sorts | the sorts of the bound variables. |
| names | names of the bound variables |
| body | the body of the quantifier. |
Definition at line 3348 of file Context.cs.
Create an expression representing t1 <= t2
Definition at line 1238 of file Context.cs.
Referenced by ArithExpr.operator<=().
Retrieve the length of a given sequence.
Definition at line 2531 of file Context.cs.
Create a new list sort.
Definition at line 366 of file Context.cs.
Create a new list sort.
Definition at line 353 of file Context.cs.
Take the bounded Kleene star of a regular expression.
Definition at line 2683 of file Context.cs.
Create an expression representing t1 < t2
Definition at line 1225 of file Context.cs.
Referenced by ArithExpr.operator<().
Maps f on the argument arrays.
Each element of args must be of an array sort [domain_i -> range_i]. The function declaration f must have type range_1 .. range_n -> range. v must have sort range. The sort of the result is [domain_i -> range].
Definition at line 2268 of file Context.cs.
Create an expression representing t1 mod t2.
The arguments must have int type.
Definition at line 1185 of file Context.cs.
Create an expression representing t[0] * t[1] * ....
Definition at line 1139 of file Context.cs.
Create an expression representing t[0] * t[1] * ....
Definition at line 1127 of file Context.cs.
Referenced by Context.MkMul(), and ArithExpr.operator*().
Mk an expression representing not(a).
Definition at line 976 of file Context.cs.
Referenced by BoolExpr.operator!().
Retrieve element at index.
Definition at line 2606 of file Context.cs.
Create a Term of a given sort. This function can be used to create numerals that fit in a machine integer. It is slightly faster than MakeNumeral since it is not necessary to parse a string.
| v | Value of the numeral |
| ty | Sort of the numeral |
Definition at line 2935 of file Context.cs.
Create a Term of a given sort. This function can be used to create numerals that fit in a machine integer. It is slightly faster than MakeNumeral since it is not necessary to parse a string.
| v | Value of the numeral |
| ty | Sort of the numeral |
Definition at line 2965 of file Context.cs.
Create a Term of a given sort.
| v | A string representing the Term value in decimal notation. If the given sort is a real, then the Term can be a rational, that is, a string of the form [num]* / [num]*. |
| ty | The sort of the numeral. In the current implementation, the given sort can be an int, real, or bit-vectors of arbitrary size. |
Definition at line 2920 of file Context.cs.
Referenced by Context.MkBV(), Context.MkBV(), Context.MkBV(), Context.MkBV(), and Context.MkBV().
Create a Term of a given sort. This function can be used to create numerals that fit in a machine integer. It is slightly faster than MakeNumeral since it is not necessary to parse a string.
| v | Value of the numeral |
| ty | Sort of the numeral |
Definition at line 2950 of file Context.cs.
Create a Term of a given sort. This function can be used to create numerals that fit in a machine integer. It is slightly faster than MakeNumeral since it is not necessary to parse a string.
| v | Value of the numeral |
| ty | Sort of the numeral |
Definition at line 2980 of file Context.cs.
|
inline |
Create an Optimization context.
Definition at line 4080 of file Context.cs.
Create the optional regular expression.
Definition at line 2701 of file Context.cs.
Create an expression representing t[0] or t[1] or ....
Definition at line 1094 of file Context.cs.
Create an expression representing t[0] or t[1] or ....
Definition at line 1081 of file Context.cs.
Referenced by Context.MkOr(), and BoolExpr.operator|().
|
inline |
Creates a new ParameterSet.
Definition at line 3465 of file Context.cs.
Referenced by Optimize.Set(), Solver.Set(), Optimize.Set(), Solver.Set(), Optimize.Set(), Solver.Set(), Optimize.Set(), Solver.Set(), Optimize.Set(), Solver.Set(), Optimize.Set(), Solver.Set(), Optimize.Set(), Solver.Set(), Optimize.Set(), Solver.Set(), Optimize.Set(), Solver.Set(), Optimize.Set(), and Solver.Set().
Create a quantifier pattern.
Definition at line 753 of file Context.cs.
Create a pseudo-Boolean equal constraint.
Definition at line 2899 of file Context.cs.
Create a pseudo-Boolean greater-or-equal constraint.
Definition at line 2886 of file Context.cs.
Create a pseudo-Boolean less-or-equal constraint.
Definition at line 2872 of file Context.cs.
Take the Kleene plus of a regular expression.
Definition at line 2692 of file Context.cs.
Create an expression representing t1 ^ t2.
Definition at line 1212 of file Context.cs.
Check for sequence prefix.
Definition at line 2540 of file Context.cs.
|
inline |
Creates a new Probe.
Definition at line 3875 of file Context.cs.
|
inline |
Create a Quantifier.
MkForall(Sort[], Symbol[], Expr, uint, Pattern[], Expr[], Symbol, Symbol)
Definition at line 3316 of file Context.cs.
|
inline |
Create a Quantifier.
MkForall(Sort[], Symbol[], Expr, uint, Pattern[], Expr[], Symbol, Symbol)
Definition at line 3293 of file Context.cs.
Create a range expression.
Definition at line 2787 of file Context.cs.
|
inline |
Create a real from a fraction.
| num | numerator of rational. |
| den | denominator of rational. |
Definition at line 2997 of file Context.cs.
|
inline |
Create a real numeral.
| v | value of the numeral. |
Definition at line 3021 of file Context.cs.
|
inline |
Create a real numeral.
| v | value of the numeral. |
Definition at line 3043 of file Context.cs.
|
inline |
Create a real numeral.
| v | A string representing the Term value in decimal notation. |
Definition at line 3010 of file Context.cs.
|
inline |
Create a real numeral.
| v | value of the numeral. |
Definition at line 3032 of file Context.cs.
|
inline |
Create a real numeral.
| v | value of the numeral. |
Definition at line 3054 of file Context.cs.
Coerce a real to an integer.
The semantics of this function follows the SMT-LIB standard for the function to_int. The argument must be of real sort.
Definition at line 1299 of file Context.cs.
|
inline |
Creates a real constant.
Definition at line 865 of file Context.cs.
Creates a real constant.
Definition at line 855 of file Context.cs.
|
inline |
Create a real sort.
Definition at line 242 of file Context.cs.
Creates a new recursive function declaration.
Definition at line 630 of file Context.cs.
Create an expression representing t1 rem t2.
The arguments must have int type.
Definition at line 1199 of file Context.cs.
|
inline |
Bit-vector repetition.
The argument t must have a bit-vector sort.
Definition at line 1795 of file Context.cs.
Replace the first occurrence of src by dst in s.
Definition at line 2641 of file Context.cs.
Create a new regular expression sort.
Definition at line 267 of file Context.cs.
Array read.
The argument a is the array and i is the index of the array that gets read.
The node a must have an array sort [domain -> range], and i must have the sort domain. The sort of the result is range.
Definition at line 2144 of file Context.cs.
Array read.
The argument a is the array and args are the indices of the array that gets read.
The node a must have an array sort [domain1,..,domaink -> range], and args must have the sort domain1,..,domaink. The sort of the result is range.
Definition at line 2167 of file Context.cs.
Create a new sequence sort.
Definition at line 258 of file Context.cs.
Add an element to the set.
Definition at line 2345 of file Context.cs.
Take the complement of a set.
Definition at line 2409 of file Context.cs.
Remove an element from a set.
Definition at line 2359 of file Context.cs.
Take the difference between two sets.
Definition at line 2396 of file Context.cs.
Take the intersection of a list of sets.
Definition at line 2384 of file Context.cs.
Check for set membership.
Definition at line 2420 of file Context.cs.
Create a set type.
Definition at line 2312 of file Context.cs.
Check for subsetness of sets.
Definition at line 2433 of file Context.cs.
Take the union of a list of sets.
Definition at line 2372 of file Context.cs.
|
inline |
Bit-vector sign extension.
Sign-extends the given bit-vector to the (signed) equivalent bitvector of size m+i, where m is the size of the given bit-vector. The argument t must have a bit-vector sort.
Definition at line 1764 of file Context.cs.
|
inline |
Creates a new (incremental) solver.
Definition at line 4032 of file Context.cs.
|
inline |
Creates a new Tactic.
Definition at line 3771 of file Context.cs.
|
inline |
Creates a solver that uses an incremental simplifier.
Definition at line 4041 of file Context.cs.
|
inline |
Creates a new (incremental) solver.
Definition at line 4023 of file Context.cs.
Creates a new (incremental) solver.
This solver also uses a set of builtin tactics for handling the first check-sat command, and check-sat commands that take more than a given number of milliseconds to be solved.
Definition at line 4010 of file Context.cs.
Referenced by Context.MkSolver().
Creates a solver that is implemented using the given tactic.
The solver supports the commands Push and Pop, but it will always solve each check from scratch.
Definition at line 4055 of file Context.cs.
Take the Kleene star of a regular expression.
Definition at line 2674 of file Context.cs.
Array update.
The node a must have an array sort [domain -> range], i must have sort domain, v must have sort range. The sort of the result is [domain -> range]. The semantics of this function is given by the theory of arrays described in the SMT-LIB standard. See http://smtlib.org for more details. The result of this function is an array that is equal to a (with respect to select) on all indices except for i, where it maps to v (and the select of a with respect to i may be a different value).
Definition at line 2196 of file Context.cs.
Array update.
The node a must have an array sort [domain1,..,domaink -> range], args must have sort domain1,..,domaink, v must have sort range. The sort of the result is [domain -> range]. The semantics of this function is given by the theory of arrays described in the SMT-LIB standard. See http://smtlib.org for more details. The result of this function is an array that is equal to a (with respect to select) on all indices except for args, where it maps to v (and the select of a with respect to args may be a different value).
Definition at line 2226 of file Context.cs.
|
inline |
Create a string constant.
Definition at line 2468 of file Context.cs.
Check if the string s1 is lexicographically less or equal to s2.
Definition at line 2584 of file Context.cs.
Check if the string s1 is lexicographically strictly less than s2.
Definition at line 2573 of file Context.cs.
Create an expression representing t[0] - t[1] - ....
Definition at line 1148 of file Context.cs.
Referenced by ArithExpr.operator-().
Check for sequence suffix.
Definition at line 2551 of file Context.cs.
|
inline |
Creates a new symbol using an integer.
Not all integers can be passed to this function. The legal range of unsigned integers is 0 to 2^30-1.
Definition at line 111 of file Context.cs.
Referenced by Params.Add(), Params.Add(), Params.Add(), Params.Add(), Params.Add(), Params.Add(), Optimize.AssertSoft(), Context.MkArrayConst(), Context.MkBoolConst(), Context.MkConst(), Context.MkConstDecl(), Context.MkConstructor(), Context.MkDatatypeSort(), Context.MkDatatypeSortRef(), Context.MkEnumSort(), Context.MkFiniteDomainSort(), Context.MkFuncDecl(), Context.MkFuncDecl(), Context.MkListSort(), Context.MkRecFuncDecl(), Context.MkSolver(), Context.MkUninterpretedSort(), and Context.MkUserPropagatorFuncDecl().
|
inline |
Create a symbol using a string.
Definition at line 119 of file Context.cs.
|
inline |
Creates a new Tactic.
Definition at line 3509 of file Context.cs.
Referenced by Goal.Simplify().
Access the array default value.
Produces the default range value, for arrays that can be represented as finite maps with a default range value.
Definition at line 2285 of file Context.cs.
Convert a regular expression that accepts sequence s.
Definition at line 2653 of file Context.cs.
|
inline |
The true Term.
Definition at line 918 of file Context.cs.
Referenced by Goal.AsBoolExpr(), and Context.MkBool().
Create a new tuple sort.
Definition at line 302 of file Context.cs.
Create an expression representing -t.
Definition at line 1160 of file Context.cs.
Referenced by ArithExpr.operator-().
|
inline |
Create a new uninterpreted sort.
Definition at line 224 of file Context.cs.
|
inline |
Create a new uninterpreted sort.
Definition at line 213 of file Context.cs.
Referenced by Context.MkUninterpretedSort().
Create the union of regular languages.
Definition at line 2731 of file Context.cs.
Create the singleton sequence.
Definition at line 2459 of file Context.cs.
Update a datatype field at expression t with value v. The function performs a record update at t. The field that is passed in as argument is updated with value v, the remaining fields of t are unchanged.
Definition at line 571 of file Context.cs.
Declare a function to be processed by the user propagator plugin.
Definition at line 727 of file Context.cs.
Create an expression representing t1 xor t2.
Definition at line 1030 of file Context.cs.
Referenced by Context.MkXor(), and BoolExpr.operator^().
Create an expression representing t1 xor t2 xor t3 ... .
Definition at line 1043 of file Context.cs.
|
inline |
Bit-vector zero extension.
Extend the given bit-vector with zeros to the (unsigned) equivalent bitvector of size m+i, where m is the size of the given bit-vector. The argument t must have a bit-vector sort.
Definition at line 1781 of file Context.cs.
Create a probe that evaluates to "true" when the value p does not evaluate to "true".
Definition at line 3992 of file Context.cs.
Create a probe that evaluates to "true" when the value p1 or p2 evaluate to "true".
Definition at line 3978 of file Context.cs.
Create a tactic that first applies t1 to a Goal and if it fails then returns the result of t2 applied to the Goal.
Definition at line 3566 of file Context.cs.
Create a tactic that applies t1 to a given goal and then t2 to every subgoal produced by t1 . The subgoals are processed in parallel.
Definition at line 3714 of file Context.cs.
Create a tactic that applies the given tactics in parallel until one of them succeeds (i.e., the first that doesn't fail).
Definition at line 3702 of file Context.cs.
|
inline |
Parse the given file using the SMT-LIB2 parser.
Definition at line 3427 of file Context.cs.
|
inline |
Parse the given string using the SMT-LIB2 parser.
Definition at line 3408 of file Context.cs.
|
inline |
Returns a string containing a description of the probe with the given name.
Definition at line 3866 of file Context.cs.
Create a tactic that keeps applying t until the goal is not modified anymore or the maximum number of iterations max is reached.
Definition at line 3627 of file Context.cs.
Convert a bit-vector expression, represented as an signed number, to a string.
Definition at line 2497 of file Context.cs.
|
inline |
Returns a string containing a description of the simplifier with the given name.
Definition at line 3762 of file Context.cs.
|
inline |
Return a string describing all available parameters to Expr.Simplify.
Definition at line 4855 of file Context.cs.
|
inline |
Create a tactic that just returns the given goal.
Definition at line 3638 of file Context.cs.
Convert an integer expression to a string.
Definition at line 2507 of file Context.cs.
|
inline |
Returns a string containing a description of the tactic with the given name.
Definition at line 3500 of file Context.cs.
|
inline |
Create a simplifier that applies t1 and then then t2 .
Shorthand for AndThen.
Definition at line 3815 of file Context.cs.
Create a tactic that applies t1 to a Goal and then t2 to every subgoal produced by t1 .
Shorthand for AndThen.
Definition at line 3553 of file Context.cs.
Create a tactic that applies t to a goal for ms milliseconds.
If t does not terminate within ms milliseconds, then it fails.
Definition at line 3582 of file Context.cs.
Convert a bit-vector expression, represented as an unsigned number, to a string.
Definition at line 2487 of file Context.cs.
|
inline |
Unwraps an AST.
This function is used for transitions between native and managed objects. It returns the native pointer to the AST. Note that AST objects are reference counted and unwrapping an AST disables automatic reference counting, i.e., all references to the IntPtr that is returned must be handled externally and through native calls (see e.g.,
).
| a | The AST to unwrap. |
Definition at line 4847 of file Context.cs.
|
inline |
Update a mutable configuration parameter.
The list of all configuration parameters can be obtained using the Z3 executable: z3.exe -p Only a few configuration parameters are mutable once the context is created. An exception is thrown when trying to modify an immutable parameter.
Definition at line 4896 of file Context.cs.
|
inline |
Create a tactic that applies t using the given set of parameters p .
Definition at line 3827 of file Context.cs.
Create a tactic that applies t using the given set of parameters p .
Definition at line 3677 of file Context.cs.
Referenced by Context.With().
Create a tactic that applies t to a given goal if the probe p evaluates to true.
If p evaluates to false, then the new tactic behaves like the skip tactic.
Definition at line 3597 of file Context.cs.
Create a tactic that applies t using the given set of parameters p .
Alias for UsingParams
Definition at line 3691 of file Context.cs.
|
inline |
Wraps an AST.
This function is used for transitions between native and managed objects. Note that nativeObject must be a native object obtained from Z3 (e.g., through
) and that it must have a correct reference count (see e.g., .
| nativeObject | The native pointer to wrap. |
Definition at line 4831 of file Context.cs.
Retrieves the Boolean sort of the context.
Definition at line 146 of file Context.cs.
Referenced by Context.MkBoolSort().
Retrieves the String sort of the context.
Definition at line 180 of file Context.cs.
Retrieves the Integer sort of the context.
Definition at line 157 of file Context.cs.
Referenced by Context.MkIntSort().
|
get |
The number of supported Probes.
Definition at line 3842 of file Context.cs.
|
get |
The number of supported simplifiers.
Definition at line 3738 of file Context.cs.
|
get |
The number of supported tactics.
Definition at line 3476 of file Context.cs.
|
set |
Selects the format used for pretty-printing expressions.
The default mode for pretty printing expressions is to produce SMT-LIB style output where common subexpressions are printed at each occurrence. The mode is called Z3_PRINT_SMTLIB_FULL. To print shared common subexpressions only once, use the Z3_PRINT_LOW_LEVEL mode. To print in way that conforms to SMT-LIB standards and uses let expressions to share common sub-expressions use Z3_PRINT_SMTLIB_COMPLIANT.
Definition at line 3396 of file Context.cs.
|
get |
The names of all supported Probes.
Definition at line 3850 of file Context.cs.
Retrieves the Real sort of the context.
Definition at line 169 of file Context.cs.
Referenced by Context.MkRealSort().
|
get |
The names of all supported tactics.
Definition at line 3746 of file Context.cs.
|
get |
Retrieves parameter descriptions for simplifier.
Definition at line 4864 of file Context.cs.
|
get |
Retrieves the String sort of the context.
Definition at line 192 of file Context.cs.
|
get |
The names of all supported tactics.
Definition at line 3484 of file Context.cs.