summaryrefslogtreecommitdiff
path: root/examples/api/extract.cpp
diff options
context:
space:
mode:
authorClark Barrett <barrett@cs.nyu.edu>2015-12-23 08:56:15 -0800
committerClark Barrett <barrett@cs.nyu.edu>2015-12-23 08:56:15 -0800
commit0879991984ebc0687faec90b44c85f2389931207 (patch)
tree00f431d1749182d6ca4df5f6d773e1adab198cb2 /examples/api/extract.cpp
parenteb97dc0a80f70f2be34f1b85341edb44fcea3b68 (diff)
Added extract.cpp example
Diffstat (limited to 'examples/api/extract.cpp')
-rw-r--r--examples/api/extract.cpp56
1 files changed, 56 insertions, 0 deletions
diff --git a/examples/api/extract.cpp b/examples/api/extract.cpp
new file mode 100644
index 000000000..fac242b76
--- /dev/null
+++ b/examples/api/extract.cpp
@@ -0,0 +1,56 @@
+/********************* */
+/*! \file bitvectors.cpp
+ ** \verbatim
+ ** Original author: Liana Hadarean
+ ** Major contributors: Morgan Deters
+ ** Minor contributors (to current version): none
+ ** This file is part of the CVC4 project.
+ ** Copyright (c) 2009-2014 New York University and The University of Iowa
+ ** See the file COPYING in the top-level source directory for licensing
+ ** information.\endverbatim
+ **
+ ** \brief A simple demonstration of the solving capabilities of the CVC4
+ ** bit-vector solver.
+ **
+ **/
+
+#include <iostream>
+
+//#include <cvc4/cvc4.h> // use this after CVC4 is properly installed
+#include "smt/smt_engine.h"
+
+using namespace std;
+using namespace CVC4;
+
+int main() {
+ ExprManager em;
+ SmtEngine smt(&em);
+ smt.setLogic("QF_BV"); // Set the logic
+
+ Type bitvector32 = em.mkBitVectorType(32);
+
+ Expr x = em.mkVar("a", bitvector32);
+
+ Expr ext_31_1 = em.mkConst(CVC4::BitVectorExtract(31,1));
+ Expr x_31_1 = em.mkExpr(ext_31_1, x);
+
+ Expr ext_30_0 = em.mkConst(CVC4::BitVectorExtract(30,0));
+ Expr x_30_0 = em.mkExpr(ext_30_0, x);
+
+ Expr ext_31_31 = em.mkConst(CVC4::BitVectorExtract(31,31));
+ Expr x_31_31 = em.mkExpr(ext_31_31, x);
+
+ Expr ext_0_0 = em.mkConst(CVC4::BitVectorExtract(0,0));
+ Expr x_0_0 = em.mkExpr(ext_0_0, x);
+
+ Expr eq = em.mkExpr(kind::EQUAL, x_31_1, x_30_0);
+ cout << " Asserting: " << eq << endl;
+ smt.assertFormula(eq);
+
+ Expr eq2 = em.mkExpr(kind::EQUAL, x_31_31, x_0_0);
+ cout << " Querying: " << eq2 << endl;
+ cout << " Expect valid. " << endl;
+ cout << " CVC4: " << smt.query(eq2) << endl;
+
+ return 0;
+}
generated by cgit on debian on lair
contact matthew@masot.net with questions or feedback