18package com.microsoft.z3;
20import static com.microsoft.z3.Constructor.of;
22import com.microsoft.z3.enumerations.Z3_ast_print_mode;
35@SuppressWarnings(
"unchecked")
38 static final Object creation_lock =
new Object();
41 synchronized (creation_lock) {
42 m_ctx = Native.mkContextRc(0);
48 synchronized (creation_lock) {
72 public Context(Map<String, String> settings) {
73 synchronized (creation_lock) {
74 long cfg = Native.mkConfig();
75 for (Map.Entry<String, String> kv : settings.entrySet()) {
76 Native.setParamValue(cfg, kv.getKey(), kv.getValue());
78 m_ctx = Native.mkContextRc(cfg);
79 Native.delConfig(cfg);
86 Native.setInternalErrorHandler(m_ctx);
110 Symbol[] mkSymbols(String[] names)
115 for (
int i = 0; i < names.length; ++i)
116 result[i] = mkSymbol(names[i]);
120 private BoolSort m_boolSort =
null;
121 private IntSort m_intSort =
null;
122 private RealSort m_realSort =
null;
123 private SeqSort<CharSort> m_stringSort =
null;
130 if (m_boolSort ==
null) {
141 if (m_intSort ==
null) {
152 if (m_realSort ==
null) {
180 if (m_stringSort ==
null) {
181 m_stringSort = mkStringSort();
191 checkContextMatch(s);
200 return mkUninterpretedSort(mkSymbol(str));
224 return new BitVecSort(
this, Native.mkBvSort(nCtx(), size));
232 checkContextMatch(domain);
233 checkContextMatch(range);
243 checkContextMatch(domains);
244 checkContextMatch(range);
253 return new SeqSort<>(
this, Native.mkStringSort(nCtx()));
261 return new SeqSort<>(
this, Native.mkSeqSort(nCtx(), s.getNativeObject()));
269 return new ReSort<>(
this, Native.mkReSort(nCtx(), s.getNativeObject()));
279 checkContextMatch(name);
280 checkContextMatch(fieldNames);
281 checkContextMatch(fieldSorts);
282 return new TupleSort(
this, name, fieldNames.length, fieldNames,
292 checkContextMatch(name);
293 checkContextMatch(enumNames);
303 return new EnumSort<>(
this, mkSymbol(name), mkSymbols(enumNames));
311 checkContextMatch(name);
312 checkContextMatch(elemSort);
321 checkContextMatch(elemSort);
322 return new ListSort<>(
this, mkSymbol(name), elemSort);
331 checkContextMatch(name);
356 Symbol[] fieldNames,
Sort[] sorts,
int[] sortRefs)
359 return of(
this, name, recognizer, fieldNames, sorts, sortRefs);
366 String[] fieldNames,
Sort[] sorts,
int[] sortRefs)
368 return of(
this, mkSymbol(name), mkSymbol(recognizer), mkSymbols(fieldNames), sorts, sortRefs);
376 checkContextMatch(name);
377 checkContextMatch(constructors);
387 checkContextMatch(constructors);
399 checkContextMatch(name);
401 checkContextMatch(params);
403 int numParams = (params ==
null) ? 0 : params.length;
404 long[] paramsNative = (params ==
null) ?
new long[0] :
AST.arrayToNative(params);
405 return new DatatypeSort<>(
this, Native.mkDatatypeSort(nCtx(), name.getNativeObject(), numParams, paramsNative));
413 public <R> DatatypeSort<R> mkDatatypeSortRef(Symbol name)
415 return mkDatatypeSortRef(name,
null);
424 public <R> DatatypeSort<R> mkDatatypeSortRef(String name, Sort[] params)
426 return mkDatatypeSortRef(mkSymbol(name), params);
434 public <R> DatatypeSort<R> mkDatatypeSortRef(String name)
436 return mkDatatypeSortRef(name,
null);
446 checkContextMatch(names);
447 int n = names.length;
449 long[] n_constr =
new long[n];
450 for (
int i = 0; i < n; i++)
454 checkContextMatch(constructor);
456 n_constr[i] = cla[i].getNativeObject();
458 long[] n_res =
new long[n];
462 for (
int i = 0; i < n; i++)
473 return mkDatatypeSorts(mkSymbols(names), c);
484 checkContextMatch(name);
496 return mkTypeVariable(mkSymbol(name));
524 checkContextMatch(name);
525 checkContextMatch(parameters);
526 checkContextMatch(constructors);
528 int numParams = parameters.length;
531 int numConstructors = constructors.length;
532 long[] constructorsNative =
new long[numConstructors];
533 for (
int i = 0; i < numConstructors; i++) {
534 constructorsNative[i] = constructors[i].getNativeObject();
537 long nativeSort = Native.mkPolymorphicDatatype(nCtx(), name.getNativeObject(),
538 numParams, paramsNative, numConstructors, constructorsNative);
540 return new DatatypeSort<>(
this, nativeSort);
553 public <R> DatatypeSort<R> mkPolymorphicDatatypeSort(String name, Sort[] parameters, Constructor<R>[] constructors)
555 return mkPolymorphicDatatypeSort(mkSymbol(name), parameters, constructors);
568 Native.datatypeUpdateField
569 (nCtx(), field.getNativeObject(),
570 t.getNativeObject(), v.getNativeObject()));
579 checkContextMatch(name);
580 checkContextMatch(domain);
581 checkContextMatch(range);
582 return new FuncDecl<>(
this, name, domain, range);
587 checkContextMatch(name);
588 checkContextMatch(domain);
589 checkContextMatch(range);
590 long f = Native.solverPropagateDeclare(
592 name.getNativeObject(),
595 range.getNativeObject());
606 checkContextMatch(name);
607 checkContextMatch(domain);
608 checkContextMatch(range);
619 checkContextMatch(domain);
620 checkContextMatch(range);
621 return new FuncDecl<>(
this, mkSymbol(name), domain, range);
630 checkContextMatch(domain);
631 checkContextMatch(range);
633 return new FuncDecl<>(
this, mkSymbol(name), q, range);
641 checkContextMatch(name);
642 checkContextMatch(domain);
643 checkContextMatch(range);
644 return new FuncDecl<>(
this, name, domain, range,
true);
656 checkContextMatch(f);
657 checkContextMatch(args);
658 checkContextMatch(body);
660 Native.addRecDef(nCtx(), f.getNativeObject(), args.length, argsNative, body.getNativeObject());
672 checkContextMatch(domain);
673 checkContextMatch(range);
674 return new FuncDecl<>(
this, prefix, domain, range);
682 checkContextMatch(name);
683 checkContextMatch(range);
684 return new FuncDecl<>(
this, name,
null, range);
692 checkContextMatch(range);
693 return new FuncDecl<>(
this, mkSymbol(name),
null, range);
705 checkContextMatch(range);
706 return new FuncDecl<>(
this, prefix,
null, range);
717 Native.mkBound(nCtx(), index, ty.getNativeObject()));
726 if (terms.length == 0)
727 throw new Z3Exception(
"Cannot create a pattern from zero terms");
730 return new Pattern(
this, Native.mkPattern(nCtx(), terms.length,
740 checkContextMatch(name);
741 checkContextMatch(range);
745 Native.mkConst(nCtx(), name.getNativeObject(),
746 range.getNativeObject()));
755 return mkConst(mkSymbol(name), range);
764 checkContextMatch(range);
766 Native.mkFreshConst(nCtx(), prefix, range.getNativeObject()));
775 return mkApp(f, (
Expr<?>[])
null);
783 return (
BoolExpr) mkConst(name, getBoolSort());
791 return (
BoolExpr) mkConst(mkSymbol(name), getBoolSort());
799 return (
IntExpr) mkConst(name, getIntSort());
807 return (
IntExpr) mkConst(name, getIntSort());
815 return (
RealExpr) mkConst(name, getRealSort());
823 return (
RealExpr) mkConst(name, getRealSort());
831 return (
BitVecExpr) mkConst(name, mkBitVecSort(size));
839 return (
BitVecExpr) mkConst(name, mkBitVecSort(size));
848 checkContextMatch(f);
849 checkContextMatch(args);
850 return Expr.create(
this, f, args);
858 return new BoolExpr(
this, Native.mkTrue(nCtx()));
866 return new BoolExpr(
this, Native.mkFalse(nCtx()));
874 return value ? mkTrue() : mkFalse();
882 checkContextMatch(x);
883 checkContextMatch(y);
884 return new BoolExpr(
this, Native.mkEq(nCtx(), x.getNativeObject(),
885 y.getNativeObject()));
894 checkContextMatch(args);
895 return new BoolExpr(
this, Native.mkDistinct(nCtx(), args.length,
904 checkContextMatch(a);
905 return new BoolExpr(
this, Native.mkNot(nCtx(), a.getNativeObject()));
917 checkContextMatch(t1);
918 checkContextMatch(t2);
919 checkContextMatch(t3);
920 return (
Expr<R>)
Expr.create(
this, Native.mkIte(nCtx(), t1.getNativeObject(),
921 t2.getNativeObject(), t3.getNativeObject()));
929 checkContextMatch(t1);
930 checkContextMatch(t2);
931 return new BoolExpr(
this, Native.mkIff(nCtx(), t1.getNativeObject(),
932 t2.getNativeObject()));
940 checkContextMatch(t1);
941 checkContextMatch(t2);
942 return new BoolExpr(
this, Native.mkImplies(nCtx(),
943 t1.getNativeObject(), t2.getNativeObject()));
951 checkContextMatch(t1);
952 checkContextMatch(t2);
953 return new BoolExpr(
this, Native.mkXor(nCtx(), t1.getNativeObject(),
954 t2.getNativeObject()));
963 checkContextMatch(t);
964 return new BoolExpr(
this, Native.mkAnd(nCtx(), t.length,
974 checkContextMatch(t);
975 return new BoolExpr(
this, Native.mkOr(nCtx(), t.length,
985 checkContextMatch(t);
996 checkContextMatch(t);
1007 checkContextMatch(t);
1017 checkContextMatch(t);
1019 Native.mkUnaryMinus(nCtx(), t.getNativeObject()));
1027 checkContextMatch(t1);
1028 checkContextMatch(t2);
1030 t1.getNativeObject(), t2.getNativeObject()));
1040 checkContextMatch(t1);
1041 checkContextMatch(t2);
1042 return new IntExpr(
this, Native.mkMod(nCtx(), t1.getNativeObject(),
1043 t2.getNativeObject()));
1053 checkContextMatch(t1);
1054 checkContextMatch(t2);
1055 return new IntExpr(
this, Native.mkRem(nCtx(), t1.getNativeObject(),
1056 t2.getNativeObject()));
1065 checkContextMatch(t1);
1066 checkContextMatch(t2);
1069 Native.mkPower(nCtx(), t1.getNativeObject(),
1070 t2.getNativeObject()));
1078 checkContextMatch(t1);
1079 checkContextMatch(t2);
1080 return new BoolExpr(
this, Native.mkLt(nCtx(), t1.getNativeObject(),
1081 t2.getNativeObject()));
1089 checkContextMatch(t1);
1090 checkContextMatch(t2);
1091 return new BoolExpr(
this, Native.mkLe(nCtx(), t1.getNativeObject(),
1092 t2.getNativeObject()));
1100 checkContextMatch(t1);
1101 checkContextMatch(t2);
1102 return new BoolExpr(
this, Native.mkGt(nCtx(), t1.getNativeObject(),
1103 t2.getNativeObject()));
1111 checkContextMatch(t1);
1112 checkContextMatch(t2);
1113 return new BoolExpr(
this, Native.mkGe(nCtx(), t1.getNativeObject(),
1114 t2.getNativeObject()));
1129 checkContextMatch(t);
1131 Native.mkInt2real(nCtx(), t.getNativeObject()));
1142 checkContextMatch(t);
1143 return new IntExpr(
this, Native.mkReal2int(nCtx(), t.getNativeObject()));
1151 checkContextMatch(t);
1152 return new BoolExpr(
this, Native.mkIsInt(nCtx(), t.getNativeObject()));
1162 checkContextMatch(t);
1163 return new BitVecExpr(
this, Native.mkBvnot(nCtx(), t.getNativeObject()));
1173 checkContextMatch(t);
1174 return new BitVecExpr(
this, Native.mkBvredand(nCtx(),
1175 t.getNativeObject()));
1185 checkContextMatch(t);
1186 return new BitVecExpr(
this, Native.mkBvredor(nCtx(),
1187 t.getNativeObject()));
1197 checkContextMatch(t1);
1198 checkContextMatch(t2);
1199 return new BitVecExpr(
this, Native.mkBvand(nCtx(),
1200 t1.getNativeObject(), t2.getNativeObject()));
1210 checkContextMatch(t1);
1211 checkContextMatch(t2);
1212 return new BitVecExpr(
this, Native.mkBvor(nCtx(), t1.getNativeObject(),
1213 t2.getNativeObject()));
1223 checkContextMatch(t1);
1224 checkContextMatch(t2);
1225 return new BitVecExpr(
this, Native.mkBvxor(nCtx(),
1226 t1.getNativeObject(), t2.getNativeObject()));
1236 checkContextMatch(t1);
1237 checkContextMatch(t2);
1238 return new BitVecExpr(
this, Native.mkBvnand(nCtx(),
1239 t1.getNativeObject(), t2.getNativeObject()));
1249 checkContextMatch(t1);
1250 checkContextMatch(t2);
1251 return new BitVecExpr(
this, Native.mkBvnor(nCtx(),
1252 t1.getNativeObject(), t2.getNativeObject()));
1262 checkContextMatch(t1);
1263 checkContextMatch(t2);
1264 return new BitVecExpr(
this, Native.mkBvxnor(nCtx(),
1265 t1.getNativeObject(), t2.getNativeObject()));
1275 checkContextMatch(t);
1276 return new BitVecExpr(
this, Native.mkBvneg(nCtx(), t.getNativeObject()));
1286 checkContextMatch(t1);
1287 checkContextMatch(t2);
1288 return new BitVecExpr(
this, Native.mkBvadd(nCtx(),
1289 t1.getNativeObject(), t2.getNativeObject()));
1299 checkContextMatch(t1);
1300 checkContextMatch(t2);
1301 return new BitVecExpr(
this, Native.mkBvsub(nCtx(),
1302 t1.getNativeObject(), t2.getNativeObject()));
1312 checkContextMatch(t1);
1313 checkContextMatch(t2);
1314 return new BitVecExpr(
this, Native.mkBvmul(nCtx(),
1315 t1.getNativeObject(), t2.getNativeObject()));
1327 checkContextMatch(t1);
1328 checkContextMatch(t2);
1329 return new BitVecExpr(
this, Native.mkBvudiv(nCtx(),
1330 t1.getNativeObject(), t2.getNativeObject()));
1348 checkContextMatch(t1);
1349 checkContextMatch(t2);
1350 return new BitVecExpr(
this, Native.mkBvsdiv(nCtx(),
1351 t1.getNativeObject(), t2.getNativeObject()));
1363 checkContextMatch(t1);
1364 checkContextMatch(t2);
1365 return new BitVecExpr(
this, Native.mkBvurem(nCtx(),
1366 t1.getNativeObject(), t2.getNativeObject()));
1381 checkContextMatch(t1);
1382 checkContextMatch(t2);
1383 return new BitVecExpr(
this, Native.mkBvsrem(nCtx(),
1384 t1.getNativeObject(), t2.getNativeObject()));
1395 checkContextMatch(t1);
1396 checkContextMatch(t2);
1397 return new BitVecExpr(
this, Native.mkBvsmod(nCtx(),
1398 t1.getNativeObject(), t2.getNativeObject()));
1408 checkContextMatch(t1);
1409 checkContextMatch(t2);
1410 return new BoolExpr(
this, Native.mkBvult(nCtx(), t1.getNativeObject(),
1411 t2.getNativeObject()));
1421 checkContextMatch(t1);
1422 checkContextMatch(t2);
1423 return new BoolExpr(
this, Native.mkBvslt(nCtx(), t1.getNativeObject(),
1424 t2.getNativeObject()));
1434 checkContextMatch(t1);
1435 checkContextMatch(t2);
1436 return new BoolExpr(
this, Native.mkBvule(nCtx(), t1.getNativeObject(),
1437 t2.getNativeObject()));
1447 checkContextMatch(t1);
1448 checkContextMatch(t2);
1449 return new BoolExpr(
this, Native.mkBvsle(nCtx(), t1.getNativeObject(),
1450 t2.getNativeObject()));
1460 checkContextMatch(t1);
1461 checkContextMatch(t2);
1462 return new BoolExpr(
this, Native.mkBvuge(nCtx(), t1.getNativeObject(),
1463 t2.getNativeObject()));
1473 checkContextMatch(t1);
1474 checkContextMatch(t2);
1475 return new BoolExpr(
this, Native.mkBvsge(nCtx(), t1.getNativeObject(),
1476 t2.getNativeObject()));
1486 checkContextMatch(t1);
1487 checkContextMatch(t2);
1488 return new BoolExpr(
this, Native.mkBvugt(nCtx(), t1.getNativeObject(),
1489 t2.getNativeObject()));
1499 checkContextMatch(t1);
1500 checkContextMatch(t2);
1501 return new BoolExpr(
this, Native.mkBvsgt(nCtx(), t1.getNativeObject(),
1502 t2.getNativeObject()));
1517 checkContextMatch(t1);
1518 checkContextMatch(t2);
1519 return new BitVecExpr(
this, Native.mkConcat(nCtx(),
1520 t1.getNativeObject(), t2.getNativeObject()));
1534 checkContextMatch(t);
1535 return new BitVecExpr(
this, Native.mkExtract(nCtx(), high, low,
1536 t.getNativeObject()));
1548 checkContextMatch(t);
1549 return new BitVecExpr(
this, Native.mkSignExt(nCtx(), i,
1550 t.getNativeObject()));
1562 checkContextMatch(t);
1563 return new BitVecExpr(
this, Native.mkZeroExt(nCtx(), i,
1564 t.getNativeObject()));
1574 checkContextMatch(t);
1575 return new BitVecExpr(
this, Native.mkRepeat(nCtx(), i,
1576 t.getNativeObject()));
1592 checkContextMatch(t1);
1593 checkContextMatch(t2);
1594 return new BitVecExpr(
this, Native.mkBvshl(nCtx(),
1595 t1.getNativeObject(), t2.getNativeObject()));
1611 checkContextMatch(t1);
1612 checkContextMatch(t2);
1613 return new BitVecExpr(
this, Native.mkBvlshr(nCtx(),
1614 t1.getNativeObject(), t2.getNativeObject()));
1631 checkContextMatch(t1);
1632 checkContextMatch(t2);
1633 return new BitVecExpr(
this, Native.mkBvashr(nCtx(),
1634 t1.getNativeObject(), t2.getNativeObject()));
1644 checkContextMatch(t);
1645 return new BitVecExpr(
this, Native.mkRotateLeft(nCtx(), i,
1646 t.getNativeObject()));
1656 checkContextMatch(t);
1657 return new BitVecExpr(
this, Native.mkRotateRight(nCtx(), i,
1658 t.getNativeObject()));
1670 checkContextMatch(t1);
1671 checkContextMatch(t2);
1672 return new BitVecExpr(
this, Native.mkExtRotateLeft(nCtx(),
1673 t1.getNativeObject(), t2.getNativeObject()));
1685 checkContextMatch(t1);
1686 checkContextMatch(t2);
1687 return new BitVecExpr(
this, Native.mkExtRotateRight(nCtx(),
1688 t1.getNativeObject(), t2.getNativeObject()));
1702 checkContextMatch(t);
1703 return new BitVecExpr(
this, Native.mkInt2bv(nCtx(), n,
1704 t.getNativeObject()));
1723 checkContextMatch(t);
1724 return new IntExpr(
this, Native.mkBv2int(nCtx(), t.getNativeObject(),
1736 checkContextMatch(t1);
1737 checkContextMatch(t2);
1738 return new BoolExpr(
this, Native.mkBvaddNoOverflow(nCtx(), t1
1739 .getNativeObject(), t2.getNativeObject(), (isSigned)));
1750 checkContextMatch(t1);
1751 checkContextMatch(t2);
1752 return new BoolExpr(
this, Native.mkBvaddNoUnderflow(nCtx(),
1753 t1.getNativeObject(), t2.getNativeObject()));
1764 checkContextMatch(t1);
1765 checkContextMatch(t2);
1766 return new BoolExpr(
this, Native.mkBvsubNoOverflow(nCtx(),
1767 t1.getNativeObject(), t2.getNativeObject()));
1778 checkContextMatch(t1);
1779 checkContextMatch(t2);
1780 return new BoolExpr(
this, Native.mkBvsubNoUnderflow(nCtx(), t1
1781 .getNativeObject(), t2.getNativeObject(), (isSigned)));
1792 checkContextMatch(t1);
1793 checkContextMatch(t2);
1794 return new BoolExpr(
this, Native.mkBvsdivNoOverflow(nCtx(),
1795 t1.getNativeObject(), t2.getNativeObject()));
1805 checkContextMatch(t);
1806 return new BoolExpr(
this, Native.mkBvnegNoOverflow(nCtx(),
1807 t.getNativeObject()));
1818 checkContextMatch(t1);
1819 checkContextMatch(t2);
1820 return new BoolExpr(
this, Native.mkBvmulNoOverflow(nCtx(), t1
1821 .getNativeObject(), t2.getNativeObject(), (isSigned)));
1832 checkContextMatch(t1);
1833 checkContextMatch(t2);
1834 return new BoolExpr(
this, Native.mkBvmulNoUnderflow(nCtx(),
1835 t1.getNativeObject(), t2.getNativeObject()));
1853 return (
ArrayExpr<D, R>) mkConst(mkSymbol(name), mkArraySort(domain, range));
1870 checkContextMatch(a);
1871 checkContextMatch(i);
1874 Native.mkSelect(nCtx(), a.getNativeObject(),
1875 i.getNativeObject()));
1892 checkContextMatch(a);
1893 checkContextMatch(args);
1896 Native.mkSelectN(nCtx(), a.getNativeObject(), args.length,
AST.
arrayToNative(args)));
1917 checkContextMatch(a);
1918 checkContextMatch(i);
1919 checkContextMatch(v);
1920 return new ArrayExpr<>(
this, Native.mkStore(nCtx(), a.getNativeObject(),
1921 i.getNativeObject(), v.getNativeObject()));
1942 checkContextMatch(a);
1943 checkContextMatch(args);
1944 checkContextMatch(v);
1945 return new ArrayExpr<>(
this, Native.mkStoreN(nCtx(), a.getNativeObject(),
1960 checkContextMatch(domain);
1961 checkContextMatch(v);
1962 return new ArrayExpr<>(
this, Native.mkConstArray(nCtx(),
1963 domain.getNativeObject(), v.getNativeObject()));
1982 checkContextMatch(f);
1983 checkContextMatch(args);
1997 checkContextMatch(array);
1999 Native.mkArrayDefault(nCtx(), array.getNativeObject()));
2007 checkContextMatch(arg1);
2008 checkContextMatch(arg2);
2009 return (
Expr<D>)
Expr.create(
this, Native.mkArrayExt(nCtx(), arg1.getNativeObject(), arg2.getNativeObject()));
2018 checkContextMatch(ty);
2027 checkContextMatch(domain);
2029 Native.mkEmptySet(nCtx(), domain.getNativeObject()));
2037 checkContextMatch(domain);
2039 Native.mkFullSet(nCtx(), domain.getNativeObject()));
2047 checkContextMatch(
set);
2048 checkContextMatch(element);
2050 Native.mkSetAdd(nCtx(),
set.getNativeObject(),
2051 element.getNativeObject()));
2059 checkContextMatch(
set);
2060 checkContextMatch(element);
2062 Native.mkSetDel(nCtx(),
set.getNativeObject(),
2063 element.getNativeObject()));
2072 checkContextMatch(args);
2074 Native.mkSetUnion(nCtx(), args.length,
2084 checkContextMatch(args);
2086 Native.mkSetIntersect(nCtx(), args.length,
2095 checkContextMatch(arg1);
2096 checkContextMatch(arg2);
2098 Native.mkSetDifference(nCtx(), arg1.getNativeObject(),
2099 arg2.getNativeObject()));
2107 checkContextMatch(arg);
2109 Native.mkSetComplement(nCtx(), arg.getNativeObject()));
2117 checkContextMatch(elem);
2118 checkContextMatch(
set);
2120 Native.mkSetMember(nCtx(), elem.getNativeObject(),
2121 set.getNativeObject()));
2129 checkContextMatch(arg1);
2130 checkContextMatch(arg2);
2132 Native.mkSetSubset(nCtx(), arg1.getNativeObject(),
2133 arg2.getNativeObject()));
2146 checkContextMatch(s);
2147 return (
SeqExpr<R>)
Expr.create(
this, Native.mkSeqEmpty(nCtx(), s.getNativeObject()));
2155 checkContextMatch(elem);
2156 return (
SeqExpr<R>)
Expr.create(
this, Native.mkSeqUnit(nCtx(), elem.getNativeObject()));
2164 StringBuilder buf =
new StringBuilder();
2165 for (
int i = 0; i < s.length(); i += Character.charCount(s.codePointAt(i))) {
2166 int code = s.codePointAt(i);
2167 if (code <= 32 || 127 < code)
2168 buf.append(String.format(
"\\u{%x}", code));
2170 buf.append(s.charAt(i));
2204 return (
IntExpr)
Expr.create(
this, Native.mkStrToInt(nCtx(), e.getNativeObject()));
2213 checkContextMatch(t);
2223 checkContextMatch(s);
2224 return (
IntExpr)
Expr.create(
this, Native.mkSeqLength(nCtx(), s.getNativeObject()));
2232 checkContextMatch(s1, s2);
2233 return (
BoolExpr)
Expr.create(
this, Native.mkSeqPrefix(nCtx(), s1.getNativeObject(), s2.getNativeObject()));
2241 checkContextMatch(s1, s2);
2242 return (
BoolExpr)
Expr.create(
this, Native.mkSeqSuffix(nCtx(), s1.getNativeObject(), s2.getNativeObject()));
2250 checkContextMatch(s1, s2);
2251 return (
BoolExpr)
Expr.create(
this, Native.mkSeqContains(nCtx(), s1.getNativeObject(), s2.getNativeObject()));
2260 checkContextMatch(s1, s2);
2261 return new BoolExpr(
this, Native.mkStrLt(nCtx(), s1.getNativeObject(), s2.getNativeObject()));
2269 checkContextMatch(s1, s2);
2270 return new BoolExpr(
this, Native.mkStrLe(nCtx(), s1.getNativeObject(), s2.getNativeObject()));
2279 checkContextMatch(s, index);
2280 return (
SeqExpr<R>)
Expr.create(
this, Native.mkSeqAt(nCtx(), s.getNativeObject(), index.getNativeObject()));
2288 checkContextMatch(s, index);
2289 return (
Expr<R>)
Expr.create(
this, Native.mkSeqNth(nCtx(), s.getNativeObject(), index.getNativeObject()));
2298 checkContextMatch(s, offset, length);
2299 return (
SeqExpr<R>)
Expr.create(
this, Native.mkSeqExtract(nCtx(), s.getNativeObject(), offset.getNativeObject(), length.getNativeObject()));
2307 checkContextMatch(s, substr, offset);
2308 return (
IntExpr)
Expr.create(
this, Native.mkSeqIndex(nCtx(), s.getNativeObject(), substr.getNativeObject(), offset.getNativeObject()));
2316 checkContextMatch(s, substr);
2317 return (
IntExpr)
Expr.create(
this, Native.mkSeqLastIndex(nCtx(), s.getNativeObject(), substr.getNativeObject()));
2326 checkContextMatch(f, s);
2327 return (
SeqExpr<R>)
Expr.create(
this, Native.mkSeqMap(nCtx(), f.getNativeObject(), s.getNativeObject()));
2336 checkContextMatch(f, i, s);
2337 return (
SeqExpr<R>)
Expr.create(
this, Native.mkSeqMapi(nCtx(), f.getNativeObject(), i.getNativeObject(), s.getNativeObject()));
2346 checkContextMatch(f, a, s);
2347 return (
Expr<A>)
Expr.create(
this, Native.mkSeqFoldl(nCtx(), f.getNativeObject(), a.getNativeObject(), s.getNativeObject()));
2356 checkContextMatch(f, i, a, s);
2357 return (
Expr<A>)
Expr.create(
this, Native.mkSeqFoldli(nCtx(), f.getNativeObject(), i.getNativeObject(), a.getNativeObject(), s.getNativeObject()));
2365 checkContextMatch(s, src, dst);
2366 return (
SeqExpr<R>)
Expr.create(
this, Native.mkSeqReplace(nCtx(), s.getNativeObject(), src.getNativeObject(), dst.getNativeObject()));
2374 checkContextMatch(s, src, dst);
2375 return (
SeqExpr<R>)
Expr.create(
this, Native.mkSeqReplaceAll(nCtx(), s.getNativeObject(), src.getNativeObject(), dst.getNativeObject()));
2383 checkContextMatch(s, re, dst);
2384 return (
SeqExpr<R>)
Expr.create(
this, Native.mkSeqReplaceRe(nCtx(), s.getNativeObject(), re.getNativeObject(), dst.getNativeObject()));
2392 checkContextMatch(s, re, dst);
2393 return (
SeqExpr<R>)
Expr.create(
this, Native.mkSeqReplaceReAll(nCtx(), s.getNativeObject(), re.getNativeObject(), dst.getNativeObject()));
2401 checkContextMatch(s);
2411 checkContextMatch(s, re);
2412 return (
BoolExpr)
Expr.create(
this, Native.mkSeqInRe(nCtx(), s.getNativeObject(), re.getNativeObject()));
2420 checkContextMatch(re);
2421 return (
ReExpr<R>)
Expr.create(
this, Native.mkReStar(nCtx(), re.getNativeObject()));
2429 return (
ReExpr<R>)
Expr.create(
this, Native.mkRePower(nCtx(), re.getNativeObject(), n));
2437 return (
ReExpr<R>)
Expr.create(
this, Native.mkReLoop(nCtx(), re.getNativeObject(), lo, hi));
2445 return (
ReExpr<R>)
Expr.create(
this, Native.mkReLoop(nCtx(), re.getNativeObject(), lo, 0));
2454 checkContextMatch(re);
2455 return (
ReExpr<R>)
Expr.create(
this, Native.mkRePlus(nCtx(), re.getNativeObject()));
2463 checkContextMatch(re);
2464 return (
ReExpr<R>)
Expr.create(
this, Native.mkReOption(nCtx(), re.getNativeObject()));
2472 checkContextMatch(re);
2473 return (
ReExpr<R>)
Expr.create(
this, Native.mkReComplement(nCtx(), re.getNativeObject()));
2482 checkContextMatch(t);
2492 checkContextMatch(t);
2502 checkContextMatch(t);
2511 checkContextMatch(a, b);
2512 return (
ReExpr<R>)
Expr.create(
this, Native.mkReDiff(nCtx(), a.getNativeObject(), b.getNativeObject()));
2522 return (
ReExpr<R>)
Expr.create(
this, Native.mkReEmpty(nCtx(), s.getNativeObject()));
2531 return (
ReExpr<R>)
Expr.create(
this, Native.mkReFull(nCtx(), s.getNativeObject()));
2541 return (
ReExpr<R>)
Expr.create(
this, Native.mkReAllchar(nCtx(), s.getNativeObject()));
2549 checkContextMatch(lo, hi);
2558 checkContextMatch(ch1, ch2);
2559 return (
BoolExpr)
Expr.create(
this, Native.mkCharLe(nCtx(), ch1.getNativeObject(), ch2.getNativeObject()));
2567 checkContextMatch(ch);
2568 return (
IntExpr)
Expr.create(
this, Native.mkCharToInt(nCtx(), ch.getNativeObject()));
2576 checkContextMatch(ch);
2577 return (
BitVecExpr)
Expr.create(
this, Native.mkCharToBv(nCtx(), ch.getNativeObject()));
2585 checkContextMatch(bv);
2586 return (
Expr<CharSort>)
Expr.create(
this, Native.mkCharFromBv(nCtx(), bv.getNativeObject()));
2594 checkContextMatch(ch);
2595 return (
BoolExpr)
Expr.create(
this, Native.mkCharIsDigit(nCtx(), ch.getNativeObject()));
2603 checkContextMatch(args);
2612 checkContextMatch(args);
2621 checkContextMatch(args);
2630 checkContextMatch(args);
2639 checkContextMatch(args);
2656 checkContextMatch(ty);
2658 Native.mkNumeral(nCtx(), v, ty.getNativeObject()));
2673 checkContextMatch(ty);
2674 return (
Expr<R>)
Expr.create(
this, Native.mkInt(nCtx(), v, ty.getNativeObject()));
2689 checkContextMatch(ty);
2691 Native.mkInt64(nCtx(), v, ty.getNativeObject()));
2709 return new RatNum(
this, Native.mkReal(nCtx(), num, den));
2721 return new RatNum(
this, Native.mkNumeral(nCtx(), v, getRealSort()
2722 .getNativeObject()));
2734 return new RatNum(
this, Native.mkInt(nCtx(), v, getRealSort()
2735 .getNativeObject()));
2747 return new RatNum(
this, Native.mkInt64(nCtx(), v, getRealSort()
2748 .getNativeObject()));
2758 return new IntNum(
this, Native.mkNumeral(nCtx(), v, getIntSort()
2759 .getNativeObject()));
2771 return new IntNum(
this, Native.mkInt(nCtx(), v, getIntSort()
2772 .getNativeObject()));
2784 return new IntNum(
this, Native.mkInt64(nCtx(), v, getIntSort()
2785 .getNativeObject()));
2795 return (
BitVecNum) mkNumeral(v, mkBitVecSort(size));
2805 return (
BitVecNum) mkNumeral(v, mkBitVecSort(size));
2815 return (
BitVecNum) mkNumeral(v, mkBitVecSort(size));
2847 return Quantifier.
of(
this,
true, sorts, names, body, weight, patterns,
2848 noPatterns, quantifierID, skolemID);
2860 return Quantifier.
of(
this,
true, boundConstants, body, weight,
2861 patterns, noPatterns, quantifierID, skolemID);
2873 return Quantifier.
of(
this,
false, sorts, names, body, weight,
2874 patterns, noPatterns, quantifierID, skolemID);
2886 return Quantifier.
of(
this,
false, boundConstants, body, weight,
2887 patterns, noPatterns, quantifierID, skolemID);
2901 return mkForall(sorts, names, body, weight, patterns, noPatterns,
2902 quantifierID, skolemID);
2904 return mkExists(sorts, names, body, weight, patterns, noPatterns,
2905 quantifierID, skolemID);
2918 return mkForall(boundConstants, body, weight, patterns, noPatterns,
2919 quantifierID, skolemID);
2921 return mkExists(boundConstants, body, weight, patterns, noPatterns,
2922 quantifierID, skolemID);
2944 return Lambda.
of(
this, sorts, names, body);
2955 return Lambda.
of(
this, boundConstants, body);
2975 Native.setAstPrintMode(nCtx(), value.toInt());
2996 return Native.benchmarkToSmtlibString(nCtx(), name, logic, status,
2997 attributes, assumptions.length,
3017 if (csn != cs || cdn != cd) {
3038 if (csn != cs || cdn != cd)
3058 public Goal mkGoal(
boolean models,
boolean unsatCores,
boolean proofs)
3060 return new Goal(
this, models, unsatCores, proofs);
3076 return Native.getNumTactics(nCtx());
3085 int n = getNumTactics();
3086 String[] res =
new String[n];
3087 for (
int i = 0; i < n; i++)
3088 res[i] = Native.getTacticName(nCtx(), i);
3098 return Native.tacticGetDescr(nCtx(), name);
3106 return new Tactic(
this, name);
3116 checkContextMatch(t1);
3117 checkContextMatch(t2);
3118 checkContextMatch(ts);
3121 if (ts !=
null && ts.length > 0)
3123 last = ts[ts.length - 1].getNativeObject();
3124 for (
int i = ts.length - 2; i >= 0; i--) {
3125 last = Native.tacticAndThen(nCtx(), ts[i].getNativeObject(),
3131 last = Native.tacticAndThen(nCtx(), t2.getNativeObject(), last);
3132 return new Tactic(
this, Native.tacticAndThen(nCtx(),
3133 t1.getNativeObject(), last));
3135 return new Tactic(
this, Native.tacticAndThen(nCtx(),
3136 t1.getNativeObject(), t2.getNativeObject()));
3147 return andThen(t1, t2, ts);
3157 checkContextMatch(t1);
3158 checkContextMatch(t2);
3159 return new Tactic(
this, Native.tacticOrElse(nCtx(),
3160 t1.getNativeObject(), t2.getNativeObject()));
3171 checkContextMatch(t);
3172 return new Tactic(
this, Native.tacticTryFor(nCtx(),
3173 t.getNativeObject(), ms));
3184 checkContextMatch(t);
3185 checkContextMatch(p);
3186 return new Tactic(
this, Native.tacticWhen(nCtx(), p.getNativeObject(),
3187 t.getNativeObject()));
3197 checkContextMatch(p);
3198 checkContextMatch(t1);
3199 checkContextMatch(t2);
3200 return new Tactic(
this, Native.tacticCond(nCtx(), p.getNativeObject(),
3201 t1.getNativeObject(), t2.getNativeObject()));
3210 checkContextMatch(t);
3211 return new Tactic(
this, Native.tacticRepeat(nCtx(),
3212 t.getNativeObject(), max));
3220 return new Tactic(
this, Native.tacticSkip(nCtx()));
3228 return new Tactic(
this, Native.tacticFail(nCtx()));
3237 checkContextMatch(p);
3239 Native.tacticFailIf(nCtx(), p.getNativeObject()));
3248 return new Tactic(
this, Native.tacticFailIfNotDecided(nCtx()));
3257 checkContextMatch(t);
3258 checkContextMatch(p);
3259 return new Tactic(
this, Native.tacticUsingParams(nCtx(),
3260 t.getNativeObject(), p.getNativeObject()));
3271 return usingParams(t, p);
3279 checkContextMatch(t);
3280 return new Tactic(
this, Native.tacticParOr(nCtx(),
3290 checkContextMatch(t1);
3291 checkContextMatch(t2);
3292 return new Tactic(
this, Native.tacticParAndThen(nCtx(),
3293 t1.getNativeObject(), t2.getNativeObject()));
3303 Native.interrupt(nCtx());
3311 return Native.getNumSimplifiers(nCtx());
3320 int n = getNumSimplifiers();
3321 String[] res =
new String[n];
3322 for (
int i = 0; i < n; i++)
3323 res[i] = Native.getSimplifierName(nCtx(), i);
3333 return Native.simplifierGetDescr(nCtx(), name);
3350 checkContextMatch(t1);
3351 checkContextMatch(t2);
3352 checkContextMatch(ts);
3355 if (ts !=
null && ts.length > 0)
3357 last = ts[ts.length - 1].getNativeObject();
3358 for (
int i = ts.length - 2; i >= 0; i--) {
3359 last = Native.simplifierAndThen(nCtx(), ts[i].getNativeObject(),
3365 last = Native.simplifierAndThen(nCtx(), t2.getNativeObject(), last);
3366 return new Simplifier(
this, Native.simplifierAndThen(nCtx(),
3367 t1.getNativeObject(), last));
3369 return new Simplifier(
this, Native.simplifierAndThen(nCtx(),
3370 t1.getNativeObject(), t2.getNativeObject()));
3380 return andThen(t1, t2, ts);
3389 checkContextMatch(t);
3390 checkContextMatch(p);
3391 return new Simplifier(
this, Native.simplifierUsingParams(nCtx(),
3392 t.getNativeObject(), p.getNativeObject()));
3403 return usingParams(t, p);
3411 return Native.getNumProbes(nCtx());
3420 int n = getNumProbes();
3421 String[] res =
new String[n];
3422 for (
int i = 0; i < n; i++)
3423 res[i] = Native.getProbeName(nCtx(), i);
3433 return Native.probeGetDescr(nCtx(), name);
3441 return new Probe(
this, name);
3449 return new Probe(
this, Native.probeConst(nCtx(), val));
3458 checkContextMatch(p1);
3459 checkContextMatch(p2);
3460 return new Probe(
this, Native.probeLt(nCtx(), p1.getNativeObject(),
3461 p2.getNativeObject()));
3470 checkContextMatch(p1);
3471 checkContextMatch(p2);
3472 return new Probe(
this, Native.probeGt(nCtx(), p1.getNativeObject(),
3473 p2.getNativeObject()));
3483 checkContextMatch(p1);
3484 checkContextMatch(p2);
3485 return new Probe(
this, Native.probeLe(nCtx(), p1.getNativeObject(),
3486 p2.getNativeObject()));
3496 checkContextMatch(p1);
3497 checkContextMatch(p2);
3498 return new Probe(
this, Native.probeGe(nCtx(), p1.getNativeObject(),
3499 p2.getNativeObject()));
3508 checkContextMatch(p1);
3509 checkContextMatch(p2);
3510 return new Probe(
this, Native.probeEq(nCtx(), p1.getNativeObject(),
3511 p2.getNativeObject()));
3519 checkContextMatch(p1);
3520 checkContextMatch(p2);
3521 return new Probe(
this, Native.probeAnd(nCtx(), p1.getNativeObject(),
3522 p2.getNativeObject()));
3530 checkContextMatch(p1);
3531 checkContextMatch(p2);
3532 return new Probe(
this, Native.probeOr(nCtx(), p1.getNativeObject(),
3533 p2.getNativeObject()));
3541 checkContextMatch(p);
3542 return new Probe(
this, Native.probeNot(nCtx(), p.getNativeObject()));
3554 return mkSolver((
Symbol)
null);
3568 return new Solver(
this, Native.mkSolver(nCtx()));
3570 return new Solver(
this, Native.mkSolverForLogic(nCtx(),
3571 logic.getNativeObject()));
3580 return mkSolver(mkSymbol(logic));
3588 return new Solver(
this, Native.mkSimpleSolver(nCtx()));
3600 return new Solver(
this, Native.mkSolverFromTactic(nCtx(),
3601 t.getNativeObject()));
3609 return new Solver(
this, Native.solverAddSimplifier(nCtx(), s.getNativeObject(), simp.getNativeObject()));
3644 return new FPRMExpr(
this, Native.mkFpaRoundNearestTiesToEven(nCtx()));
3653 return new FPRMNum(
this, Native.mkFpaRne(nCtx()));
3662 return new FPRMNum(
this, Native.mkFpaRoundNearestTiesToAway(nCtx()));
3671 return new FPRMNum(
this, Native.mkFpaRna(nCtx()));
3680 return new FPRMNum(
this, Native.mkFpaRoundTowardPositive(nCtx()));
3689 return new FPRMNum(
this, Native.mkFpaRtp(nCtx()));
3698 return new FPRMNum(
this, Native.mkFpaRoundTowardNegative(nCtx()));
3707 return new FPRMNum(
this, Native.mkFpaRtn(nCtx()));
3716 return new FPRMNum(
this, Native.mkFpaRoundTowardZero(nCtx()));
3725 return new FPRMNum(
this, Native.mkFpaRtz(nCtx()));
3736 return new FPSort(
this, ebits, sbits);
3745 return new FPSort(
this, Native.mkFpaSortHalf(nCtx()));
3754 return new FPSort(
this, Native.mkFpaSort16(nCtx()));
3763 return new FPSort(
this, Native.mkFpaSortSingle(nCtx()));
3772 return new FPSort(
this, Native.mkFpaSort32(nCtx()));
3781 return new FPSort(
this, Native.mkFpaSortDouble(nCtx()));
3790 return new FPSort(
this, Native.mkFpaSort64(nCtx()));
3799 return new FPSort(
this, Native.mkFpaSortQuadruple(nCtx()));
3808 return new FPSort(
this, Native.mkFpaSort128(nCtx()));
3819 return new FPNum(
this, Native.mkFpaNan(nCtx(), s.getNativeObject()));
3830 return new FPNum(
this, Native.mkFpaInf(nCtx(), s.getNativeObject(), negative));
3841 return new FPNum(
this, Native.mkFpaZero(nCtx(), s.getNativeObject(), negative));
3852 return new FPNum(
this, Native.mkFpaNumeralFloat(nCtx(), v, s.getNativeObject()));
3863 return new FPNum(
this, Native.mkFpaNumeralDouble(nCtx(), v, s.getNativeObject()));
3874 return new FPNum(
this, Native.mkFpaNumeralInt(nCtx(), v, s.getNativeObject()));
3887 return new FPNum(
this, Native.mkFpaNumeralIntUint(nCtx(), sgn, exp, sig, s.getNativeObject()));
3900 return new FPNum(
this, Native.mkFpaNumeralInt64Uint64(nCtx(), sgn, exp, sig, s.getNativeObject()));
3911 return mkFPNumeral(v, s);
3922 return mkFPNumeral(v, s);
3934 return mkFPNumeral(v, s);
3947 return mkFPNumeral(sgn, exp, sig, s);
3960 return mkFPNumeral(sgn, exp, sig, s);
3971 return new FPExpr(
this, Native.mkFpaAbs(nCtx(), t.getNativeObject()));
3981 return new FPExpr(
this, Native.mkFpaNeg(nCtx(), t.getNativeObject()));
3993 return new FPExpr(
this, Native.mkFpaAdd(nCtx(), rm.getNativeObject(), t1.getNativeObject(), t2.getNativeObject()));
4005 return new FPExpr(
this, Native.mkFpaSub(nCtx(), rm.getNativeObject(), t1.getNativeObject(), t2.getNativeObject()));
4017 return new FPExpr(
this, Native.mkFpaMul(nCtx(), rm.getNativeObject(), t1.getNativeObject(), t2.getNativeObject()));
4029 return new FPExpr(
this, Native.mkFpaDiv(nCtx(), rm.getNativeObject(), t1.getNativeObject(), t2.getNativeObject()));
4044 return new FPExpr(
this, Native.mkFpaFma(nCtx(), rm.getNativeObject(), t1.getNativeObject(), t2.getNativeObject(), t3.getNativeObject()));
4055 return new FPExpr(
this, Native.mkFpaSqrt(nCtx(), rm.getNativeObject(), t.getNativeObject()));
4066 return new FPExpr(
this, Native.mkFpaRem(nCtx(), t1.getNativeObject(), t2.getNativeObject()));
4078 return new FPExpr(
this, Native.mkFpaRoundToIntegral(nCtx(), rm.getNativeObject(), t.getNativeObject()));
4089 return new FPExpr(
this, Native.mkFpaMin(nCtx(), t1.getNativeObject(), t2.getNativeObject()));
4100 return new FPExpr(
this, Native.mkFpaMax(nCtx(), t1.getNativeObject(), t2.getNativeObject()));
4111 return new BoolExpr(
this, Native.mkFpaLeq(nCtx(), t1.getNativeObject(), t2.getNativeObject()));
4122 return new BoolExpr(
this, Native.mkFpaLt(nCtx(), t1.getNativeObject(), t2.getNativeObject()));
4133 return new BoolExpr(
this, Native.mkFpaGeq(nCtx(), t1.getNativeObject(), t2.getNativeObject()));
4144 return new BoolExpr(
this, Native.mkFpaGt(nCtx(), t1.getNativeObject(), t2.getNativeObject()));
4157 return new BoolExpr(
this, Native.mkFpaEq(nCtx(), t1.getNativeObject(), t2.getNativeObject()));
4167 return new BoolExpr(
this, Native.mkFpaIsNormal(nCtx(), t.getNativeObject()));
4177 return new BoolExpr(
this, Native.mkFpaIsSubnormal(nCtx(), t.getNativeObject()));
4187 return new BoolExpr(
this, Native.mkFpaIsZero(nCtx(), t.getNativeObject()));
4197 return new BoolExpr(
this, Native.mkFpaIsInfinite(nCtx(), t.getNativeObject()));
4207 return new BoolExpr(
this, Native.mkFpaIsNan(nCtx(), t.getNativeObject()));
4217 return new BoolExpr(
this, Native.mkFpaIsNegative(nCtx(), t.getNativeObject()));
4227 return new BoolExpr(
this, Native.mkFpaIsPositive(nCtx(), t.getNativeObject()));
4245 return new FPExpr(
this, Native.mkFpaFp(nCtx(), sgn.getNativeObject(), sig.getNativeObject(), exp.getNativeObject()));
4261 return new FPExpr(
this, Native.mkFpaToFpBv(nCtx(), bv.getNativeObject(), s.getNativeObject()));
4277 return new FPExpr(
this, Native.mkFpaToFpFloat(nCtx(), rm.getNativeObject(), t.getNativeObject(), s.getNativeObject()));
4293 return new FPExpr(
this, Native.mkFpaToFpReal(nCtx(), rm.getNativeObject(), t.getNativeObject(), s.getNativeObject()));
4312 return new FPExpr(
this, Native.mkFpaToFpSigned(nCtx(), rm.getNativeObject(), t.getNativeObject(), s.getNativeObject()));
4314 return new FPExpr(
this, Native.mkFpaToFpUnsigned(nCtx(), rm.getNativeObject(), t.getNativeObject(), s.getNativeObject()));
4329 return new FPExpr(
this, Native.mkFpaToFpFloat(nCtx(), s.getNativeObject(), rm.getNativeObject(), t.getNativeObject()));
4347 return new BitVecExpr(
this, Native.mkFpaToSbv(nCtx(), rm.getNativeObject(), t.getNativeObject(), sz));
4349 return new BitVecExpr(
this, Native.mkFpaToUbv(nCtx(), rm.getNativeObject(), t.getNativeObject(), sz));
4363 return new RealExpr(
this, Native.mkFpaToReal(nCtx(), t.getNativeObject()));
4378 return new BitVecExpr(
this, Native.mkFpaToIeeeBv(nCtx(), t.getNativeObject()));
4396 return new BitVecExpr(
this, Native.mkFpaToFpIntReal(nCtx(), rm.getNativeObject(), exp.getNativeObject(), sig.getNativeObject(), s.getNativeObject()));
4407 Native.mkLinearOrder(
4409 sort.getNativeObject(),
4423 Native.mkPartialOrder(
4425 sort.getNativeObject(),
4439 Native.mkTransitiveClosure(
4456 Native.polynomialSubresultants(
4458 p.getNativeObject(),
4459 q.getNativeObject(),
4477 return AST.create(
this, nativeObject);
4494 return a.getNativeObject();
4503 return Native.simplifyGetHelp(nCtx());
4511 return new ParamDescrs(
this, Native.simplifyGetParamDescrs(nCtx()));
4524 Native.updateParamValue(nCtx(),
id, value);
4536 void checkContextMatch(
Z3Object other)
4538 if (
this != other.getContext())
4542 void checkContextMatch(Z3Object other1, Z3Object other2)
4544 checkContextMatch(other1);
4545 checkContextMatch(other2);
4548 void checkContextMatch(Z3Object other1, Z3Object other2, Z3Object other3)
4550 checkContextMatch(other1);
4551 checkContextMatch(other2);
4552 checkContextMatch(other3);
4555 void checkContextMatch(Z3Object other1, Z3Object other2, Z3Object other3, Z3Object other4)
4557 checkContextMatch(other1);
4558 checkContextMatch(other2);
4559 checkContextMatch(other3);
4560 checkContextMatch(other4);
4563 void checkContextMatch(Z3Object[] arr)
4566 for (Z3Object a : arr)
4567 checkContextMatch(a);
4570 private Z3ReferenceQueue m_RefQueue =
new Z3ReferenceQueue(
this);
4572 Z3ReferenceQueue getReferenceQueue() {
return m_RefQueue; }
4583 m_RefQueue.forceClear();
4588 m_stringSort =
null;
4591 synchronized (creation_lock) {
4592 Native.delContext(m_ctx);
BoolExpr[] ToBoolExprArray()
final< R extends Sort > FuncDecl< R > mkFuncDecl(String name, Sort[] domain, R range)
final ReExpr< SeqSort< CharSort > > mkRange(Expr< SeqSort< CharSort > > lo, Expr< SeqSort< CharSort > > hi)
Probe ge(Probe p1, Probe p2)
final< R extends Sort > ListSort< R > mkListSort(Symbol name, R elemSort)
final< D extends Sort > ArrayExpr< D, BoolSort > mkSetAdd(Expr< ArraySort< D, BoolSort > > set, Expr< D > element)
Solver mkSolver(String logic)
Tactic repeat(Tactic t, int max)
BitVecExpr mkBVXOR(Expr< BitVecSort > t1, Expr< BitVecSort > t2)
final BoolExpr mkDistinct(Expr<?>... args)
BoolExpr MkStringLe(Expr< SeqSort< CharSort > > s1, Expr< SeqSort< CharSort > > s2)
final< F extends Sort, R extends Sort > Expr< R > mkUpdateField(FuncDecl< F > field, Expr< R > t, Expr< F > v)
String[] getSimplifierNames()
final< R extends Sort > SeqExpr< R > mkAt(Expr< SeqSort< R > > s, Expr< IntSort > index)
BitVecExpr mkBVUDiv(Expr< BitVecSort > t1, Expr< BitVecSort > t2)
final< R extends Sort > Expr< R > mkNumeral(long v, R ty)
String getProbeDescription(String name)
FPNum mkFP(boolean sgn, long exp, long sig, FPSort s)
final< D extends Sort > ArrayExpr< D, BoolSort > mkSetIntersection(Expr< ArraySort< D, BoolSort > >... args)
BoolExpr mkFPIsPositive(Expr< FPSort > t)
BitVecExpr mkBVNOR(Expr< BitVecSort > t1, Expr< BitVecSort > t2)
FPExpr mkFPToFP(Expr< FPRMSort > rm, Expr< BitVecSort > t, FPSort s, boolean signed)
FPRMExpr mkFPRoundNearestTiesToEven()
Expr< CharSort > charFromBv(BitVecExpr bv)
IntExpr stringToInt(Expr< SeqSort< CharSort > > e)
final< R > EnumSort< R > mkEnumSort(Symbol name, Symbol... enumNames)
final< R extends Sort > Expr< R > mkFreshConst(String prefix, R range)
Fixedpoint mkFixedpoint()
Tactic usingParams(Tactic t, Params p)
Tactic parOr(Tactic... t)
BoolExpr mkBVULE(Expr< BitVecSort > t1, Expr< BitVecSort > t2)
BoolExpr mkBVSubNoOverflow(Expr< BitVecSort > t1, Expr< BitVecSort > t2)
final< R extends Sort > SeqExpr< R > mkReplaceReAll(Expr< SeqSort< R > > s, ReExpr< SeqSort< R > > re, Expr< SeqSort< R > > dst)
final< R extends Sort, A extends Sort > Expr< A > mkSeqFoldl(Expr<?> f, Expr< A > a, Expr< SeqSort< R > > s)
BoolExpr mkBVNegNoOverflow(Expr< BitVecSort > t)
final< R extends Sort > ReExpr< SeqSort< R > > mkToRe(Expr< SeqSort< R > > s)
final< D extends Sort > ArrayExpr< D, BoolSort > mkSetComplement(Expr< ArraySort< D, BoolSort > > arg)
final< D extends Sort, R extends Sort > Expr< R > mkSelect(Expr< ArraySort< D, R > > a, Expr< D > i)
Tactic then(Tactic t1, Tactic t2, Tactic... ts)
FPExpr mkFPMax(Expr< FPSort > t1, Expr< FPSort > t2)
final< R extends Sort > FuncDecl< BoolSort > mkPartialOrder(R sort, int index)
IntExpr mkBV2Int(Expr< BitVecSort > t, boolean signed)
final< R extends Sort > ReExpr< R > mkLoop(Expr< ReSort< R > > re, int lo)
final< R extends Sort > ReExpr< R > mkComplement(Expr< ReSort< R > > re)
FPSort mkFPSort(int ebits, int sbits)
final< R extends Sort > FuncDecl< R > mkFreshConstDecl(String prefix, R range)
BoolExpr mkBVSDivNoOverflow(Expr< BitVecSort > t1, Expr< BitVecSort > t2)
Probe le(Probe p1, Probe p2)
SeqExpr< CharSort > mkString(String s)
final< R extends Sort > BoolExpr mkPrefixOf(Expr< SeqSort< R > > s1, Expr< SeqSort< R > > s2)
AST wrapAST(long nativeObject)
final< R extends Sort > SeqExpr< R > mkReplace(Expr< SeqSort< R > > s, Expr< SeqSort< R > > src, Expr< SeqSort< R > > dst)
UninterpretedSort mkUninterpretedSort(Symbol s)
BitVecExpr mkBVXNOR(Expr< BitVecSort > t1, Expr< BitVecSort > t2)
BoolExpr mkImplies(Expr< BoolSort > t1, Expr< BoolSort > t2)
BoolExpr mkBVAddNoOverflow(Expr< BitVecSort > t1, Expr< BitVecSort > t2, boolean isSigned)
Simplifier mkSimplifier(String name)
BitVecExpr mkBVRotateRight(int i, Expr< BitVecSort > t)
RealExpr mkInt2Real(Expr< IntSort > t)
final< R extends Sort > Expr< R > mkITE(Expr< BoolSort > t1, Expr<? extends R > t2, Expr<? extends R > t3)
BitVecExpr mkBVLSHR(Expr< BitVecSort > t1, Expr< BitVecSort > t2)
FPNum mkFPNumeral(boolean sgn, int exp, int sig, FPSort s)
FPNum mkFP(double v, FPSort s)
BoolExpr mkLe(Expr<? extends ArithSort > t1, Expr<? extends ArithSort > t2)
IntExpr mkReal2Int(Expr< RealSort > t)
final< D extends Sort > BoolExpr mkSetSubset(Expr< ArraySort< D, BoolSort > > arg1, Expr< ArraySort< D, BoolSort > > arg2)
FPNum mkFPInf(FPSort s, boolean negative)
FPExpr mkFPRoundToIntegral(Expr< FPRMSort > rm, Expr< FPSort > t)
BoolExpr mkAtLeast(Expr< BoolSort >[] args, int k)
BitVecExpr mkBVSMod(Expr< BitVecSort > t1, Expr< BitVecSort > t2)
BitVecExpr mkInt2BV(int n, Expr< IntSort > t)
BoolExpr mkBVSGE(Expr< BitVecSort > t1, Expr< BitVecSort > t2)
BitVecExpr mkBVConst(Symbol name, int size)
BitVecExpr mkExtract(int high, int low, Expr< BitVecSort > t)
FPRMNum mkFPRoundTowardZero()
BoolExpr mkFPGEq(Expr< FPSort > t1, Expr< FPSort > t2)
final< R extends Sort > SeqExpr< R > mkUnit(Expr< R > elem)
Probe or(Probe p1, Probe p2)
BitVecExpr mkBVURem(Expr< BitVecSort > t1, Expr< BitVecSort > t2)
final< D extends Sort, R1 extends Sort, R2 extends Sort > ArrayExpr< D, R2 > mkMap(FuncDecl< R2 > f, Expr< ArraySort< D, R1 > >... args)
final< D extends Sort, R extends Sort > ArrayExpr< D, R > mkConstArray(D domain, Expr< R > v)
TypeVarSort mkTypeVariable(String name)
Tactic cond(Probe p, Tactic t1, Tactic t2)
BoolExpr mkBVSGT(Expr< BitVecSort > t1, Expr< BitVecSort > t2)
BitVecExpr mkBVConst(String name, int size)
final< R extends Sort > SeqSort< R > mkSeqSort(R s)
BoolExpr mkAtMost(Expr< BoolSort >[] args, int k)
final< R extends Sort > Expr< R > mkSelect(Expr< ArraySort< Sort, R > > a, Expr<?>[] args)
BoolExpr mkFPIsSubnormal(Expr< FPSort > t)
IntExpr mkMod(Expr< IntSort > t1, Expr< IntSort > t2)
FPExpr mkFPToFP(Expr< FPRMSort > rm, RealExpr t, FPSort s)
FPExpr mkFPSub(Expr< FPRMSort > rm, Expr< FPSort > t1, Expr< FPSort > t2)
final< R extends Sort > ReExpr< R > mkAllcharRe(ReSort< R > s)
SeqExpr< CharSort > intToString(Expr< IntSort > e)
BoolExpr mkBVMulNoOverflow(Expr< BitVecSort > t1, Expr< BitVecSort > t2, boolean isSigned)
FPExpr mkFPSqrt(Expr< FPRMSort > rm, Expr< FPSort > t)
FPNum mkFPNumeral(int v, FPSort s)
final< R extends Sort > SeqExpr< R > mkSeqMap(Expr<?> f, Expr< SeqSort< R > > s)
final< R extends Sort > Expr< R > mkConst(String name, R range)
FPExpr mkFPMul(Expr< FPRMSort > rm, Expr< FPSort > t1, Expr< FPSort > t2)
final< R extends Sort > ReExpr< R > mkStar(Expr< ReSort< R > > re)
BitVecExpr mkConcat(Expr< BitVecSort > t1, Expr< BitVecSort > t2)
BitVecExpr mkSignExt(int i, Expr< BitVecSort > t)
BitVecExpr mkBVAdd(Expr< BitVecSort > t1, Expr< BitVecSort > t2)
FPNum mkFP(boolean sgn, int exp, int sig, FPSort s)
final< R extends Sort > FuncDecl< R > mkFreshFuncDecl(String prefix, Sort[] domain, R range)
final< R extends Sort > Expr< R > mkBound(int index, R ty)
final< R extends Sort > SeqExpr< R > mkReplaceAll(Expr< SeqSort< R > > s, Expr< SeqSort< R > > src, Expr< SeqSort< R > > dst)
void updateParamValue(String id, String value)
BitVecExpr mkZeroExt(int i, Expr< BitVecSort > t)
Simplifier andThen(Simplifier t1, Simplifier t2, Simplifier... ts)
SeqExpr< CharSort > ubvToString(Expr< BitVecSort > e)
final< R extends Sort > ASTVector polynomialSubresultants(Expr< R > p, Expr< R > q, Expr< R > x)
final< R extends Sort > Lambda< R > mkLambda(Sort[] sorts, Symbol[] names, Expr< R > body)
final< R extends Sort > ReExpr< R > mkConcat(ReExpr< R >... t)
BoolExpr mkFPLt(Expr< FPSort > t1, Expr< FPSort > t2)
final< R extends Sort > ReExpr< R > mkFullRe(ReSort< R > s)
BitVecExpr mkBVRedAND(Expr< BitVecSort > t)
BitVecNum mkBV(long v, int size)
BitVecExpr mkBVSRem(Expr< BitVecSort > t1, Expr< BitVecSort > t2)
FPNum mkFPNumeral(float v, FPSort s)
Tactic when(Probe p, Tactic t)
final< R extends Sort > ReExpr< R > mkPlus(Expr< ReSort< R > > re)
Probe mkProbe(String name)
BoolExpr mkPBLe(int[] coeffs, Expr< BoolSort >[] args, int k)
RealExpr mkRealConst(String name)
final< R extends Sort > SeqExpr< R > mkSeqMapi(Expr<?> f, Expr< IntSort > i, Expr< SeqSort< R > > s)
final< R extends Sort > IntExpr mkLength(Expr< SeqSort< R > > s)
final< R extends Sort, A extends Sort > Expr< A > mkSeqFoldli(Expr<?> f, Expr< IntSort > i, Expr< A > a, Expr< SeqSort< R > > s)
final< R extends ArithSort > ArithExpr< R > mkAdd(Expr<? extends R >... t)
Tactic failIfNotDecided()
ParamDescrs getSimplifyParameterDescriptions()
BitVecExpr mkBVRotateRight(Expr< BitVecSort > t1, Expr< BitVecSort > t2)
final< D extends Sort > ArrayExpr< D, BoolSort > mkFullSet(D domain)
SeqExpr< CharSort > sbvToString(Expr< BitVecSort > e)
Probe gt(Probe p1, Probe p2)
BoolExpr mkFPIsNaN(Expr< FPSort > t)
BoolExpr mkEq(Expr<?> x, Expr<?> y)
Tactic with(Tactic t, Params p)
final BoolExpr mkNot(Expr< BoolSort > a)
BitVecExpr mkBVASHR(Expr< BitVecSort > t1, Expr< BitVecSort > t2)
BoolExpr[] parseSMTLIB2String(String str, Symbol[] sortNames, Sort[] sorts, Symbol[] declNames, FuncDecl<?>[] decls)
final< R > DatatypeSort< R > mkDatatypeSort(Symbol name, Constructor< R >[] constructors)
String[] getTacticNames()
Solver mkSolver(Solver s, Simplifier simp)
String benchmarkToSMTString(String name, String logic, String status, String attributes, Expr< BoolSort >[] assumptions, Expr< BoolSort > formula)
final< R extends Sort > ArraySort< Sort, R > mkArraySort(Sort[] domains, R range)
FPRMNum mkFPRoundNearestTiesToAway()
BoolExpr mkIsDigit(Expr< CharSort > ch)
BoolExpr mkBool(boolean value)
final< R extends Sort > BoolExpr mkInRe(Expr< SeqSort< R > > s, ReExpr< SeqSort< R > > re)
final< D extends Sort, R extends Sort > ArraySort< D, R > mkArraySort(D domain, R range)
BitVecExpr mkBVMul(Expr< BitVecSort > t1, Expr< BitVecSort > t2)
final< R extends Sort > Expr< R > mkNumeral(int v, R ty)
BitVecExpr mkBVSub(Expr< BitVecSort > t1, Expr< BitVecSort > t2)
TupleSort mkTupleSort(Symbol name, Symbol[] fieldNames, Sort[] fieldSorts)
BitVecExpr mkBVOR(Expr< BitVecSort > t1, Expr< BitVecSort > t2)
BoolExpr mkLt(Expr<? extends ArithSort > t1, Expr<? extends ArithSort > t2)
final Pattern mkPattern(Expr<?>... terms)
final< D extends Sort, R extends Sort > ArrayExpr< D, R > mkArrayConst(Symbol name, D domain, R range)
final< R > Constructor< R > mkConstructor(String name, String recognizer, String[] fieldNames, Sort[] sorts, int[] sortRefs)
BitVecExpr mkRepeat(int i, Expr< BitVecSort > t)
final< R extends Sort > IntExpr mkLastIndexOf(Expr< SeqSort< R > > s, Expr< SeqSort< R > > substr)
final< R extends Sort > Expr< R > mkNumeral(String v, R ty)
BoolExpr mkXor(Expr< BoolSort > t1, Expr< BoolSort > t2)
Simplifier then(Simplifier t1, Simplifier t2, Simplifier... ts)
FPRMNum mkFPRoundTowardNegative()
Probe eq(Probe p1, Probe p2)
Quantifier mkForall(Sort[] sorts, Symbol[] names, Expr< BoolSort > body, int weight, Pattern[] patterns, Expr<?>[] noPatterns, Symbol quantifierID, Symbol skolemID)
BitVecExpr mkBVRotateLeft(Expr< BitVecSort > t1, Expr< BitVecSort > t2)
final< R extends Sort > FuncDecl< BoolSort > mkLinearOrder(R sort, int index)
final< R extends Sort > FuncDecl< R > mkFuncDecl(String name, Sort domain, R range)
final< R extends Sort > Expr< R > mkNth(Expr< SeqSort< R > > s, Expr< IntSort > index)
final< R extends Sort > ReExpr< R > mkEmptyRe(ReSort< R > s)
Quantifier mkQuantifier(boolean universal, Expr<?>[] boundConstants, Expr< BoolSort > body, int weight, Pattern[] patterns, Expr<?>[] noPatterns, Symbol quantifierID, Symbol skolemID)
BitVecExpr mkBVRedOR(Expr< BitVecSort > t)
BoolExpr mkBVUGE(Expr< BitVecSort > t1, Expr< BitVecSort > t2)
FPExpr mkFPDiv(Expr< FPRMSort > rm, Expr< FPSort > t1, Expr< FPSort > t2)
final< R extends Sort > SeqExpr< R > mkExtract(Expr< SeqSort< R > > s, Expr< IntSort > offset, Expr< IntSort > length)
BitVecExpr mkBVNAND(Expr< BitVecSort > t1, Expr< BitVecSort > t2)
final< R extends Sort > SeqExpr< R > mkEmptySeq(R s)
final< R extends ArithSort > ArithExpr< R > mkDiv(Expr<? extends R > t1, Expr<? extends R > t2)
FPExpr mkFPRem(Expr< FPSort > t1, Expr< FPSort > t2)
SeqSort< CharSort > getStringSort()
final< D extends Sort, R extends Sort > Expr< D > mkArrayExt(Expr< ArraySort< D, R > > arg1, Expr< ArraySort< D, R > > arg2)
final< R extends Sort > ReExpr< R > mkLoop(Expr< ReSort< R > > re, int lo, int hi)
Quantifier mkQuantifier(boolean universal, Sort[] sorts, Symbol[] names, Expr< BoolSort > body, int weight, Pattern[] patterns, Expr<?>[] noPatterns, Symbol quantifierID, Symbol skolemID)
IntExpr mkIntConst(String name)
Solver mkSolver(Tactic t)
BoolExpr[] parseSMTLIB2File(String fileName, Symbol[] sortNames, Sort[] sorts, Symbol[] declNames, FuncDecl<?>[] decls)
Tactic andThen(Tactic t1, Tactic t2, Tactic... ts)
final< R extends Sort > Expr< R > mkApp(FuncDecl< R > f, Expr<?>... args)
BoolExpr mkBVAddNoUnderflow(Expr< BitVecSort > t1, Expr< BitVecSort > t2)
BoolExpr mkBVSubNoUnderflow(Expr< BitVecSort > t1, Expr< BitVecSort > t2, boolean isSigned)
BoolExpr mkFPIsZero(Expr< FPSort > t)
final< R > DatatypeSort< R > mkDatatypeSort(String name, Constructor< R >[] constructors)
final< R extends Sort > Expr< R > mkConst(FuncDecl< R > f)
BitVecExpr charToBv(Expr< CharSort > ch)
IntExpr mkIntConst(Symbol name)
final< R > FiniteDomainSort< R > mkFiniteDomainSort(Symbol name, long size)
final< R extends Sort > ReExpr< R > mkPower(Expr< ReSort< R > > re, int n)
final< R extends Sort > FuncDecl< R > mkConstDecl(String name, R range)
Simplifier with(Simplifier t, Params p)
BitVecExpr mkBVNeg(Expr< BitVecSort > t)
Tactic mkTactic(String name)
BoolExpr mkBVSLE(Expr< BitVecSort > t1, Expr< BitVecSort > t2)
FPNum mkFPNumeral(double v, FPSort s)
final< R extends Sort > ListSort< R > mkListSort(String name, R elemSort)
Tactic parAndThen(Tactic t1, Tactic t2)
BoolExpr mkGt(Expr<? extends ArithSort > t1, Expr<? extends ArithSort > t2)
BitVecNum mkBV(int v, int size)
final< R extends ArithSort > ArithExpr< R > mkPower(Expr<? extends R > t1, Expr<? extends R > t2)
Context(Map< String, String > settings)
final< R extends Sort > ReExpr< R > mkIntersect(Expr< ReSort< R > >... t)
final< R extends Sort > FuncDecl< R > mkFuncDecl(Symbol name, Sort domain, R range)
final< R extends ArithSort > ArithExpr< R > mkMul(Expr<? extends R >... t)
BoolExpr mkBVMulNoUnderflow(Expr< BitVecSort > t1, Expr< BitVecSort > t2)
BitVecExpr mkBVSDiv(Expr< BitVecSort > t1, Expr< BitVecSort > t2)
FPRMSort mkFPRoundingModeSort()
RealExpr mkRealConst(Symbol name)
String getTacticDescription(String name)
Solver mkSolver(Symbol logic)
BoolExpr mkFPEq(Expr< FPSort > t1, Expr< FPSort > t2)
final< R extends Sort > IntExpr mkIndexOf(Expr< SeqSort< R > > s, Expr< SeqSort< R > > substr, Expr< IntSort > offset)
BoolExpr mkFPLEq(Expr< FPSort > t1, Expr< FPSort > t2)
RatNum mkReal(int num, int den)
BitVecSort mkBitVecSort(int size)
final< D extends Sort, R extends Sort > ArrayExpr< D, R > mkStore(Expr< ArraySort< D, R > > a, Expr< D > i, Expr< R > v)
FPExpr mkFPToFP(Expr< BitVecSort > bv, FPSort s)
BoolExpr mkBVSLT(Expr< BitVecSort > t1, Expr< BitVecSort > t2)
BoolExpr mkFPGt(Expr< FPSort > t1, Expr< FPSort > t2)
BoolExpr mkIff(Expr< BoolSort > t1, Expr< BoolSort > t2)
BoolExpr mkGe(Expr<? extends ArithSort > t1, Expr<? extends ArithSort > t2)
BitVecExpr mkFPToFP(Expr< FPRMSort > rm, Expr< IntSort > exp, Expr< RealSort > sig, FPSort s)
BoolExpr mkIsInteger(Expr< RealSort > t)
FPExpr mkFPToFP(Expr< FPRMSort > rm, FPExpr t, FPSort s)
Probe constProbe(double val)
BoolExpr mkFPIsNegative(Expr< FPSort > t)
final< D extends Sort, R extends Sort > ArrayExpr< D, R > mkArrayConst(String name, D domain, R range)
BoolExpr mkBoolConst(String name)
RealExpr mkFPToReal(Expr< FPSort > t)
BoolExpr MkStringLt(Expr< SeqSort< CharSort > > s1, Expr< SeqSort< CharSort > > s2)
FPExpr mkFP(Expr< BitVecSort > sgn, Expr< BitVecSort > sig, Expr< BitVecSort > exp)
FPExpr mkFPToFP(FPSort s, Expr< FPRMSort > rm, Expr< FPSort > t)
FPExpr mkFPNeg(Expr< FPSort > t)
final< R extends Sort > FuncDecl< BoolSort > mkTransitiveClosure(FuncDecl< BoolSort > f)
final< R extends Sort > SeqExpr< R > mkConcat(Expr< SeqSort< R > >... t)
BoolExpr mkCharLe(Expr< CharSort > ch1, Expr< CharSort > ch2)
FPNum mkFPNumeral(boolean sgn, long exp, long sig, FPSort s)
final< R extends Sort > BoolExpr mkSuffixOf(Expr< SeqSort< R > > s1, Expr< SeqSort< R > > s2)
SeqSort< CharSort > mkStringSort()
final< R extends Sort > BoolExpr mkContains(Expr< SeqSort< R > > s1, Expr< SeqSort< R > > s2)
FPSort mkFPSortQuadruple()
FPRMNum mkFPRoundTowardPositive()
final< D extends Sort > SetSort< D > mkSetSort(D ty)
Quantifier mkExists(Expr<?>[] boundConstants, Expr< BoolSort > body, int weight, Pattern[] patterns, Expr<?>[] noPatterns, Symbol quantifierID, Symbol skolemID)
final< D extends Sort > BoolExpr mkSetMembership(Expr< D > elem, Expr< ArraySort< D, BoolSort > > set)
final< R > Constructor< R > mkConstructor(Symbol name, Symbol recognizer, Symbol[] fieldNames, Sort[] sorts, int[] sortRefs)
final< D extends Sort > ArrayExpr< D, BoolSort > mkSetUnion(Expr< ArraySort< D, BoolSort > >... args)
BoolExpr mkBVULT(Expr< BitVecSort > t1, Expr< BitVecSort > t2)
final< R extends Sort > ArrayExpr< Sort, R > mkStore(Expr< ArraySort< Sort, R > > a, Expr<?>[] args, Expr< R > v)
final< R extends Sort > ReExpr< R > mkOption(Expr< ReSort< R > > re)
BoolExpr mkFPIsNormal(Expr< FPSort > t)
DatatypeSort< Object >[] mkDatatypeSorts(String[] names, Constructor< Object >[][] c)
final< R extends Sort > SeqExpr< R > mkReplaceRe(Expr< SeqSort< R > > s, ReExpr< SeqSort< R > > re, Expr< SeqSort< R > > dst)
Probe and(Probe p1, Probe p2)
IntExpr charToInt(Expr< CharSort > ch)
Tactic tryFor(Tactic t, int ms)
FPExpr mkFPFMA(Expr< FPRMSort > rm, Expr< FPSort > t1, Expr< FPSort > t2, Expr< FPSort > t3)
UninterpretedSort mkUninterpretedSort(String str)
void setPrintMode(Z3_ast_print_mode value)
DatatypeSort< Object >[] mkDatatypeSorts(Symbol[] names, Constructor< Object >[][] c)
final BoolExpr mkAnd(Expr< BoolSort >... t)
final< R extends Sort > FuncDecl< R > mkConstDecl(Symbol name, R range)
BitVecNum mkBV(String v, int size)
BitVecExpr mkBVRotateLeft(int i, Expr< BitVecSort > t)
Probe lt(Probe p1, Probe p2)
final< D extends Sort > ArrayExpr< D, BoolSort > mkSetDel(Expr< ArraySort< D, BoolSort > > set, Expr< D > element)
Quantifier mkForall(Expr<?>[] boundConstants, Expr< BoolSort > body, int weight, Pattern[] patterns, Expr<?>[] noPatterns, Symbol quantifierID, Symbol skolemID)
final< R extends Sort > void AddRecDef(FuncDecl< R > f, Expr<?>[] args, Expr< R > body)
final< R extends Sort > ReSort< R > mkReSort(R s)
IntExpr mkRem(Expr< IntSort > t1, Expr< IntSort > t2)
BitVecExpr mkBVNot(Expr< BitVecSort > t)
final< R extends ArithSort > ArithExpr< R > mkSub(Expr<? extends R >... t)
BitVecExpr mkBVAND(Expr< BitVecSort > t1, Expr< BitVecSort > t2)
final< R extends Sort > FuncDecl< R > mkFuncDecl(Symbol name, Sort[] domain, R range)
FPExpr mkFPAbs(Expr< FPSort > t)
BoolExpr mkPBEq(int[] coeffs, Expr< BoolSort >[] args, int k)
Goal mkGoal(boolean models, boolean unsatCores, boolean proofs)
final< R extends ArithSort > ArithExpr< R > mkUnaryMinus(Expr< R > t)
FPExpr mkFPAdd(Expr< FPRMSort > rm, Expr< FPSort > t1, Expr< FPSort > t2)
BoolExpr mkBVUGT(Expr< BitVecSort > t1, Expr< BitVecSort > t2)
FPNum mkFP(float v, FPSort s)
final BoolExpr mkOr(Expr< BoolSort >... t)
BitVecExpr mkBVSHL(Expr< BitVecSort > t1, Expr< BitVecSort > t2)
String getSimplifierDescription(String name)
final< R extends Sort > Expr< R > mkConst(Symbol name, R range)
final< D extends Sort > ArrayExpr< D, BoolSort > mkEmptySet(D domain)
Quantifier mkExists(Sort[] sorts, Symbol[] names, Expr< BoolSort > body, int weight, Pattern[] patterns, Expr<?>[] noPatterns, Symbol quantifierID, Symbol skolemID)
BitVecExpr mkFPToIEEEBV(Expr< FPSort > t)
final< R extends Sort > Lambda< R > mkLambda(Expr<?>[] boundConstants, Expr< R > body)
FPExpr mkFPMin(Expr< FPSort > t1, Expr< FPSort > t2)
Tactic orElse(Tactic t1, Tactic t2)
final< R extends Sort > FuncDecl< R > mkRecFuncDecl(Symbol name, Sort[] domain, R range)
final< R extends Sort > FuncDecl< R > mkPropagateFunction(Symbol name, Sort[] domain, R range)
TypeVarSort mkTypeVariable(Symbol name)
FPNum mkFP(int v, FPSort s)
final< D extends Sort, R extends Sort > Expr< R > mkTermArray(Expr< ArraySort< D, R > > array)
final< R extends Sort > ReExpr< R > mkUnion(Expr< ReSort< R > >... t)
IntSymbol mkSymbol(int i)
final< R extends Sort > ReExpr< R > mkDiff(Expr< ReSort< R > > a, Expr< ReSort< R > > b)
StringSymbol mkSymbol(String name)
FPNum mkFPZero(FPSort s, boolean negative)
final< D extends Sort > ArrayExpr< D, BoolSort > mkSetDifference(Expr< ArraySort< D, BoolSort > > arg1, Expr< ArraySort< D, BoolSort > > arg2)
BoolExpr mkFPIsInfinite(Expr< FPSort > t)
final< R > FiniteDomainSort< R > mkFiniteDomainSort(String name, long size)
Simplifier usingParams(Simplifier t, Params p)
BoolExpr mkBoolConst(Symbol name)
final< R > EnumSort< R > mkEnumSort(String name, String... enumNames)
BitVecExpr mkFPToBV(Expr< FPRMSort > rm, Expr< FPSort > t, int sz, boolean signed)
BoolExpr mkPBGe(int[] coeffs, Expr< BoolSort >[] args, int k)
static< R extends Sort > Lambda< R > of(Context ctx, Sort[] sorts, Symbol[] names, Expr< R > body)
static Quantifier of(Context ctx, boolean isForall, Sort[] sorts, Symbol[] names, Expr< BoolSort > body, int weight, Pattern[] patterns, Expr<?>[] noPatterns, Symbol quantifierID, Symbol skolemID)
static long[] arrayToNative(Z3Object[] a)
static int arrayLength(Z3Object[] a)
Z3_ast_print_mode
Z3 pretty printing modes (See Z3_set_ast_print_mode).