File: proj-issue612.cpp

package info (click to toggle)
cvc5 1.1.2-3
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 80,856 kB
  • sloc: cpp: 339,634; java: 10,248; python: 10,063; sh: 6,726; ansic: 1,622; lisp: 763; perl: 207; makefile: 33
file content (97 lines) | stat: -rw-r--r-- 3,587 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
/******************************************************************************
 * Top contributors (to current version):
 *   Andrew Reynolds
 *
 * This file is part of the cvc5 project.
 *
 * Copyright (c) 2009-2023 by the authors listed in the file AUTHORS
 * in the top-level source directory and their institutional affiliations.
 * All rights reserved.  See the file COPYING in the top-level source
 * directory for licensing information.
 * ****************************************************************************
 *
 * Test for project issue #612
 *
 */
#include <cvc5/cvc5.h>

using namespace cvc5;
int main(void)
{
  Solver solver;
  solver.setOption("incremental", "false");
  solver.setOption("produce-models", "true");
  Sort s0 = solver.getRealSort();
  Term t1 = solver.mkConst(s0, "_x0");
  Term t2 = solver.mkReal(181067, 804);
  Term t3 = solver.mkConst(s0, "_x1");
  Term t4 = solver.mkTerm(Kind::SET_SINGLETON, {t1});
  Sort s5 = t4.getSort();
  Term t6 = solver.mkTerm(Kind::SET_COMPLEMENT, {t4});
  Op o7 = solver.mkOp(Kind::REGEXP_ALLCHAR);
  Term t8 = solver.mkTerm(o7, {});
  Sort s9 = t8.getSort();
  Term t10 = solver.mkTerm(Kind::SET_SINGLETON, {t1});
  Term t11 = solver.mkVar(s0, "_f2_0");
  Term t12 = solver.mkVar(s5, "_f2_1");
  Term t13 = solver.mkVar(s0, "_f2_2");
  Term t14 = solver.mkVar(s0, "_f2_3");
  Op o15 = solver.mkOp(Kind::SET_CHOOSE);
  Term t16 = solver.mkTerm(o15, {t12});
  Term t17 = solver.mkPi();
  Op o18 = solver.mkOp(Kind::ARCCOSECANT);
  Term t19 = solver.mkTerm(o18, {t2});
  Op o20 = solver.mkOp(Kind::SET_CHOOSE);
  Term t21 = solver.mkTerm(o15, {t4});
  Op o22 = solver.mkOp(Kind::DIVISION);
  Term t23 = solver.mkTerm(o22, {t1, t11});
  Op o24 = solver.mkOp(Kind::SUB);
  Term t25 = solver.mkTerm(o24, {t14, t13});
  Op o26 = solver.mkOp(Kind::NEG);
  Term t27 = solver.mkTerm(o26, {t1});
  Op o28 = solver.mkOp(Kind::ARCSECANT);
  Term t29 = solver.mkTerm(o28, {t1});
  Op o30 = solver.mkOp(Kind::SUB);
  Term t31 = solver.mkTerm(o24, {t1, t1});
  Op o32 = solver.mkOp(Kind::SUB);
  Term t33 = solver.mkTerm(o24, {t1, t14});
  Op o34 = solver.mkOp(Kind::DIVISION);
  Term t35 = solver.mkTerm(o22, {t1, t1});
  Op o36 = solver.mkOp(Kind::ARCSINE);
  Term t37 = solver.mkTerm(o36, {t1});
  Op o38 = solver.mkOp(Kind::NEG);
  Term t39 = solver.mkTerm(o26, {t1});
  Op o40 = solver.mkOp(Kind::DIVISION);
  Term t41 = solver.mkTerm(o22, {t1, t1});
  Op o42 = solver.mkOp(Kind::SET_CHOOSE);
  Term t43 = solver.mkTerm(o15, {t4});
  Op o44 = solver.mkOp(Kind::SUB);
  Term t45 = solver.mkTerm(o24, {t11, t1});
  Op o46 = solver.mkOp(Kind::SET_CHOOSE);
  Term t47 = solver.mkTerm(o15, {t4});
  Op o48 = solver.mkOp(Kind::SET_CHOOSE);
  Term t49 = solver.mkTerm(o15, {t4});
  Op o50 = solver.mkOp(Kind::ARCSINE);
  Term t51 = solver.mkTerm(o36, {t1});
  Op o52 = solver.mkOp(Kind::DIVISION);
  Term t53 = solver.mkTerm(o22, {t1, t1});
  Op o54 = solver.mkOp(Kind::ADD);
  Term t55 = solver.mkTerm(o54, {t14, t1});
  Op o56 = solver.mkOp(Kind::SET_CHOOSE);
  Term t57 = solver.mkTerm(o15, {t4});
  Op o58 = solver.mkOp(Kind::ARCCOTANGENT);
  Term t59 = solver.mkTerm(o58, {t1});
  Op o60 = solver.mkOp(Kind::SET_CHOOSE);
  Term t61 = solver.mkTerm(o15, {t4});
  Op o62 = solver.mkOp(Kind::LT);
  Term t63 = solver.mkTerm(o62, {t1, t29, t29});
  Sort s64 = t63.getSort();
  Op o65 = solver.mkOp(Kind::NOT);
  Term t66 = solver.mkTerm(o65, {t63});
  Term t67 = solver.mkTerm(Kind::REGEXP_INTER, {t8, t8});
  solver.assertFormula(t66);
  solver.checkSat();
  solver.blockModel(cvc5::modes::BlockModelsMode::LITERALS);

  return 0;
}