Java API
The Java API of cvc5 mostly mirrors the C++ API and supports operator overloading, iterators, and exceptions. There are a few differences from the C++ API, such as using arbitrary-precision integer pairs, specifically, pairs of Java BigInteger objects, to represent rational numbers. The quickstart guide gives a short introduction, and more examples can be found here.
For most applications, the Solver class is the main entry point to cvc5. The class hierarchy of cvc5 package provides more details on the individual classes.
Using the cvc5 Java API in a Maven project
To use a release version of the library in your Maven project, add the following dependencies to your POM file:
<dependencies>
<!-- cvc5 Java bindings (pure Java API) -->
<dependency>
<groupId>io.github.cvc5</groupId>
<artifactId>cvc5</artifactId>
<version>${cvc5.version}</version>
</dependency>
<!-- cvc5 native JNI library for the target platform -->
<dependency>
<groupId>io.github.cvc5</groupId>
<artifactId>cvc5</artifactId>
<version>${cvc5.version}</version>
<classifier>${os.classifier}</classifier>
</dependency>
</dependencies>
Here, ${cvc5.version} refers to one of the versions published in
Maven Central
(e.g., 1.3.2-1). The ${os.classifier} variable specifies
the operating system and CPU architecture
(e.g., linux-x86_64 or osx-aarch_64).
You can make Maven automatically retrieve the correct classifier using the os-maven-plugin:
<build>
<extensions>
<extension>
<groupId>kr.motd.maven</groupId>
<artifactId>os-maven-plugin</artifactId>
<version>1.7.0</version>
</extension>
</extensions>
</build>
After adding this plugin, use the ${os.detected.classifier} property
as the classifier value.
To use the latest development version of the library, as opposed to a release version, add also the following repository to your POM file:
<repositories>
<repository>
<name>Central Portal Snapshots</name>
<id>central-portal-snapshots</id>
<url>https://central.sonatype.com/repository/maven-snapshots/</url>
<releases>
<enabled>false</enabled>
</releases>
<snapshots>
<enabled>true</enabled>
</snapshots>
</repository>
</repositories>
Then, use ${next.cvc5.version}-SNAPSHOT as the version for the library
dependencies, where ${next.cvc5.version} must be the version following
the latest release (e.g., use 1.3.3 if the latest release version is
1.3.2).
Using self-contained cvc5 Java API JAR
Starting from version 1.2.1, a JAR file containing the cvc5 Java API and all required native libraries is available on the release page for each version. To use it, download the appropriate JAR file for your platform. For example, if your computer runs Linux x86_64, download cvc5-Linux-x86_64-java-api.jar to a working directory.
To compile the QuickStart.java example provided in the quickstart guide, ensure the file is in the same directory as the JAR. Then, run:
$ javac -cp "cvc5-Linux-x86_64-java-api.jar" ./QuickStart.java -d .
After compilation, execute the example with:
$ java -cp "cvc5-Linux-x86_64-java-api.jar:." QuickStart # Replace : with ; on Windows
expected: sat
result: sat
value for x: 1/6
value for y: 1/6
value for x - y: 0/1
computed correctly
expected: unsat
result: unsat
unsat core size: 3
unsat core:
(< 0 a)
(< 0 b)
(< (+ a b) 1)
Building cvc5 Java API
This section describes how to build the cvc5 Java bindings from source.
If you want to create a single JNI native library file that includes
all required library dependencies, pass the --static option to configure.sh
in the steps below. This option also generates a JAR file that bundles the JNI library,
which can be installed into a Maven repository.
When using --static, you may need to recompile some external cvc5 dependencies from
source rather than relying on the static versions
provided by your operating system. This ensures that all dependencies are compiled as
Position-Independent Code (PIC).
For instance, to statically compile the GMP library with PIC enabled,
pass the --static and --auto-download options, along with
-DBUILD_GMP=1. This forces GMP to be built from source with the PIC option enabled.
To additionally generate the sources and javadoc JAR files,
pass the --docs option.
The following example shows a typical build workflow for compiling and installing
the cvc5 Java bindings with shared libraries. Adjust the configuration options as
needed (e.g., add --static or --docs) depending on your desired
build artifacts.
$ git clone https://github.com/cvc5/cvc5
$ cd cvc5
$ ./configure.sh production --java-bindings --auto-download --prefix=build/install
$ cd build
$ make
$ make install
$ ls install/lib
cmake libcvc5parser.so.1 libpoly.so libpolyxx.so
libcvc5jni.so libcvc5.so libpoly.so.0 libpolyxx.so.0
libcvc5parser.so libcvc5.so.1 libpoly.so.0.2.1 libpolyxx.so.0.2.1
$ ls install/share/java/
cvc5-1.3.2-SNAPSHOT.jar cvc5.jar
# compile example QuickStart.java with cvc5 jar file
$ javac -cp "install/share/java/cvc5.jar" ../examples/api/java/QuickStart.java -d .
# run example QuickStart with cvc5 jar file and cvc5 shared libraries
$ java -cp "install/share/java/cvc5.jar:." "-Djava.library.path=install/lib" QuickStart
expected: sat
result: sat
value for x: 1/6
value for y: 1/6
value for x - y: 0/1
computed correctly
expected: unsat
result: unsat
unsat core size: 3
unsat core:
(< 0 a)
(< 0 b)
(< (+ a b) 1)
After building the project with make, you can install
the generated artifacts into your local Maven repository by running
mvn install from within the build directory.
Javadoc API Documentation
Package io.github.cvc5
class AbstractPlugin
class Command
class Datatype
class DatatypeConstructor
class DatatypeConstructorDecl
class DatatypeDecl
class DatatypeSelector
class Grammar
class InputParser
class Op
class OptionInfo
class Pair<K,V>
class Proof
class Result
class Solver
class Sort
class Stat
class Statistics
class SymbolManager
class SynthResult
class Term
class TermManager
class Triplet<A,B,C>
class Utils
enum Kind
enum RoundingMode
enum ProofRule
exception CVC5ApiException
exception CVC5ApiOptionException
exception CVC5ApiRecoverableException
Package io.github.cvc5.modes
enum BlockModelsMode
enum FindSynthTarget
enum InputLanguage
enum LearnedLitType
enum OptionCategory
enum ProofComponent
enum ProofFormat