All Downloads are FREE. Search and download functionalities are using the official Maven repository.

cvc5-cvc5-1.2.0.docs.api.c.quickstart.rst Maven / Gradle / Ivy

The newest version!
Quickstart Guide
================

First, create a cvc5 :cpp:type:`Cvc5TermManager` instance:

.. literalinclude:: ../../../examples/api/c/quickstart.c
   :language: c
   :dedent: 2
   :start-after: docs-c-quickstart-0 start
   :end-before: docs-c-quickstart-0 end

Then, create a :cpp:type:`Cvc5` solver instance:

.. literalinclude:: ../../../examples/api/c/quickstart.c
   :language: c
   :dedent: 2
   :start-after: docs-c-quickstart-1 start
   :end-before: docs-c-quickstart-1 end

We will ask the solver to produce models and unsat cores in the following,
and for this we have to enable the following options.

.. literalinclude:: ../../../examples/api/c/quickstart.c
   :language: c
   :dedent: 2
   :start-after: docs-c-quickstart-2 start
   :end-before: docs-c-quickstart-2 end

Next we set the logic.
The simplest way to set a logic for the solver is to choose "ALL".
This enables all logics in the solver.
Alternatively, ``"QF_ALL"`` enables all logics without quantifiers.
To optimize the solver's behavior for a more specific logic,
use the logic name, e.g. ``"QF_BV"`` or ``"QF_AUFBV"``.

.. literalinclude:: ../../../examples/api/c/quickstart.c
   :language: c
   :dedent: 2
   :start-after: docs-c-quickstart-3 start
   :end-before: docs-c-quickstart-3 end

In the following, we will define constraints of reals and integers.
For this, we first query the solver for the corresponding sorts.

.. literalinclude:: ../../../examples/api/c/quickstart.c
   :language: c
   :dedent: 2
   :start-after: docs-c-quickstart-4 start
   :end-before: docs-c-quickstart-4 end

Now, we create two constants ``x`` and ``y`` of sort ``Real``,
and two constants ``a`` and ``b`` of sort ``Integer``.
Notice that these are *symbolic* constants, but not actual values.

.. literalinclude:: ../../../examples/api/c/quickstart.c
   :language: c
   :dedent: 2
   :start-after: docs-c-quickstart-5 start
   :end-before: docs-c-quickstart-5 end

We define the following constraints regarding ``x`` and ``y``:

.. math::

  (0 < x) \wedge (0 < y) \wedge (x + y < 1) \wedge (x \leq y)

We construct the required terms and assert them as follows:

.. literalinclude:: ../../../examples/api/c/quickstart.c
   :language: c
   :dedent: 2
   :start-after: docs-c-quickstart-6 start
   :end-before: docs-c-quickstart-6 end

Now we check if the asserted formula is satisfiable, that is, we check if
there exist values of sort ``Real`` for ``x`` and ``y`` that satisfy all
the constraints.

.. literalinclude:: ../../../examples/api/c/quickstart.c
   :language: c
   :dedent: 2
   :start-after: docs-c-quickstart-7 start
   :end-before: docs-c-quickstart-7 end

The result we get from this satisfiability check is either ``sat``, ``unsat``
or ``unknown``.
It's status can be queried via
:cpp:func:`cvc5_result_is_sat`,
:cpp:func:`cvc5_result_is_unsat` and
:cpp:func:`cvc5_result_is_unknown`.
Alternatively, it can also be printed.

.. literalinclude:: ../../../examples/api/c/quickstart.c
   :language: c
   :dedent: 2
   :start-after: docs-c-quickstart-8 start
   :end-before: docs-c-quickstart-8 end

This will print:

.. code:: text

  expected: sat
  result: sat

Now, we query the solver for the values for ``x`` and ``y`` that satisfy
the constraints.

.. literalinclude:: ../../../examples/api/c/quickstart.c
   :language: c
   :dedent: 2
   :start-after: docs-c-quickstart-9 start
   :end-before: docs-c-quickstart-9 end

It is also possible to get values for terms that do not appear in the original
formula.

.. literalinclude:: ../../../examples/api/c/quickstart.c
   :language: c
   :dedent: 2
   :start-after: docs-c-quickstart-10 start
   :end-before: docs-c-quickstart-10 end

We can retrieve the string representation of these values as follows.

.. literalinclude:: ../../../examples/api/c/quickstart.c
   :language: c
   :dedent: 2
   :start-after: docs-c-quickstart-11 start
   :end-before: docs-c-quickstart-11 end

This will print the following:

.. code:: text

  value for x: 1/6
  value for y: 1/6
  value for x - y: 0.0

We can convert these values to C++ types.

.. literalinclude:: ../../../examples/api/c/quickstart.c
   :language: c
   :dedent: 2
   :start-after: docs-c-quickstart-12 start
   :end-before: docs-c-quickstart-12 end

Another way to independently compute the value of ``x - y`` would be to
perform the (rational) arithmetic manually.
However, for more complex terms, it is easier to let the solver do the
evaluation.

.. literalinclude:: ../../../examples/api/c/quickstart.c
   :language: c
   :dedent: 2
   :start-after: docs-c-quickstart-13 start
   :end-before: docs-c-quickstart-13 end

This will print:

.. code:: text

  computed correctly

Next, we will check satisfiability of the same formula,
only this time over integer variables ``a`` and ``b``.
For this, we first reset the assertions added to the solver.

.. literalinclude:: ../../../examples/api/c/quickstart.c
   :language: c
   :dedent: 2
   :start-after: docs-c-quickstart-14 start
   :end-before: docs-c-quickstart-14 end

Next, we assert the same assertions as above, but with integers.
This time, we inline the construction of terms
to the assertion command.

.. literalinclude:: ../../../examples/api/c/quickstart.c
   :language: c
   :dedent: 2
   :start-after: docs-c-quickstart-15 start
   :end-before: docs-c-quickstart-15 end

Now, we check whether the revised assertion is satisfiable.

.. literalinclude:: ../../../examples/api/c/quickstart.c
   :language: c
   :dedent: 2
   :start-after: docs-c-quickstart-16 start
   :end-before: docs-c-quickstart-16 end

.. literalinclude:: ../../../examples/api/c/quickstart.c
   :language: c
   :dedent: 2
   :start-after: docs-c-quickstart-17 start
   :end-before: docs-c-quickstart-17 end

This time the asserted formula is unsatisfiable:

.. code:: text

  expected: unsat
  result: unsat

We can query the solver for an unsatisfiable core, that is, a subset
of the assertions that is already unsatisfiable.

.. literalinclude:: ../../../examples/api/c/quickstart.c
   :language: c
   :dedent: 2
   :start-after: docs-c-quickstart-18 start
   :end-before: docs-c-quickstart-18 end

This will print:

.. code:: text

  unsat core size: 3
  unsat core:
  (< 0 a)
  (< 0 b)
  (< (+ a b) 1)

Example
-------

.. api-examples::
    /api/cpp/quickstart.cpp
    /api/c/quickstart.c
    /api/java/QuickStart.java
    /test/pgms/example_quickstart.py
    /api/python/quickstart.py
    /api/smtlib/quickstart.smt2




© 2015 - 2024 Weber Informatics LLC | Privacy Policy