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
|
/******************************************************************************
* Top contributors (to current version):
* Daniel Larraz, Mudathir Mohamed, Morgan Deters
*
* This file is part of the cvc5 project.
*
* Copyright (c) 2009-2025 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.
* ****************************************************************************
*
* A simple demonstration of the Java interface.
*
* To run the resulting class file, you need to do something like the
* following:
* javac "-cp" "../build/src/api/java/cvc5.jar" SimpleVC.java
* java \
* "-Djava.library.path=../build/src/api/java" "-cp" "../build/src/api/java/cvc5.jar:." \
* SimpleVC
*/
import static io.github.cvc5.Kind.*;
import io.github.cvc5.*;
public class SimpleVC
{
public static void main(String[] args)
{
TermManager tm = new TermManager();
Solver slv = new Solver(tm);
{
// Prove that for integers x and y:
// x > 0 AND y > 0 => 2x + y >= 3
Sort integer = tm.getIntegerSort();
Term x = tm.mkConst(integer, "x");
Term y = tm.mkConst(integer, "y");
Term zero = tm.mkInteger(0);
Term x_positive = tm.mkTerm(Kind.GT, x, zero);
Term y_positive = tm.mkTerm(Kind.GT, y, zero);
Term two = tm.mkInteger(2);
Term twox = tm.mkTerm(Kind.MULT, two, x);
Term twox_plus_y = tm.mkTerm(Kind.ADD, twox, y);
Term three = tm.mkInteger(3);
Term twox_plus_y_geq_3 = tm.mkTerm(Kind.GEQ, twox_plus_y, three);
Term formula = tm.mkTerm(Kind.AND, x_positive, y_positive).impTerm(twox_plus_y_geq_3);
System.out.println("Checking entailment of formula " + formula + " with cvc5.");
System.out.println("cvc5 should report UNSAT.");
System.out.println(
"Result from cvc5 is: " + slv.checkSatAssuming(formula.notTerm()));
}
}
}
|