package why3
Install
Dune Dependency
Authors
Maintainers
Sources
sha256=7b0d5e8f67aa3e964b44fe943cc7ea538a9ebef823713eda1b52fc0f0ccbec9b
md5=0c2a5c869e9cd168e850adc7e7f872a8
Description
Why3 provides a rich language for specification and programming, called WhyML, and relies on external theorem provers, both automated and interactive, to discharge verification conditions. Why3 comes with a standard library of logical theories (integer and real arithmetic, Boolean operations, sets and maps, etc.) and basic programming data structures (arrays, queues, hash tables, etc.). A user can write WhyML programs directly and get correct-by-construction OCaml programs through an automated extraction mechanism. WhyML is also used as an intermediate language for the verification of C, Java, or Ada programs.
Why3 is a complete reimplementation of the former Why platform. Among the new features are: numerous extensions to the input language, a new architecture for calling external provers, and a well-designed API, allowing to use Why3 as a software library. An important emphasis is put on modularity and genericity, giving the end user a possibility to easily reuse Why3 formalizations or to add support for a new external prover if wanted.
Tags
deductive program verification formal specification automated theorem prover interactive theorem proverPublished: 24 Mar 2020
Dev Dependencies (1)
-
conf-autoconf
build & dev
Used by (5)
-
frama-c
>= "21.0" & < "22.0"
-
frama-c-metacsl
< "0.3"
-
pilat
>= "1.6"
-
why3-coq
= "1.3.1"
-
why3-ide
= "1.3.1"
Conflicts (2)
-
ocamlgraph
< "1.8.2"
- why3-base