package why3

  1. Overview
  2. No Docs
Why3 environment for deductive program verification

Install

Dune Dependency

Authors

Maintainers

Sources

why3-1.2.1.tar.gz
sha256=8798ffbe1c455d7ab39692c1d09f15e0267196cfb37f41c6e8055ca9239f8f04
md5=0ba29f2d7084f7171d50271c77304cdf

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.

Dependencies (5)

  1. conf-autoconf
  2. num
  3. menhir >= "20151112" & < "20200123"
  4. ocamlfind build
  5. ocaml >= "4.02.3"

Dev Dependencies

None

Used by (4)

  1. archetype < "0.1.4"
  2. frama-c = "20.0"
  3. why3-coq = "1.2.1"
  4. why3-ide = "1.2.1"

Conflicts (2)

  1. ocamlgraph < "1.8.2"
  2. why3-base
OCaml

Innovation. Community. Security.