why3version
Why3 environment for deductive program verification
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 prover |
---|---|
Authors | François Bobot, Jean-Christophe Filliâtre, Claude Marché, Guillaume Melquiond and Andrei Paskevich |
License | LGPL-2.1-only |
Published | |
Homepage | https://www.why3.org/ |
Issue Tracker | https://gitlab.inria.fr/why3/why3/issues |
Maintainer | guillaume.melquiond@inria.fr |
Dependencies |
|
Optional dependencies | |
Conflicts | |
Source [http] | https://why3.gitlabpages.inria.fr/releases/why3-1.7.1.tar.gz sha256=ac6d617311614363e513d453cfd10b9620e30ae4b32e7275b6881163adfb714e md5=61397fa705f42f680d35aff29e8fd25c |
Edit | https://github.com/ocaml/opam-repository/tree/master/packages/why3/why3.1.7.1/opam |
- frama-c>=16.0 & <20.0
- frama-c-basebuild & >=13.1
- frama-c-metacsl>=0.4
- why=2.34