forked from CakeML/cakeml
-
Notifications
You must be signed in to change notification settings - Fork 0
CakeML: A Verified Implementation of ML
License
useada/cakeml
Folders and files
Name | Name | Last commit message | Last commit date | |
---|---|---|---|---|
Repository files navigation
The CakeML project (https://cakeml.org). A verified implementation of a significant subset of Standard ML in the HOL4 theorem prover (http://hol-theorem-prover.org). We build CakeML using the latest development version of HOL4. We build HOL on PolyML 5.5.2 (http://www.polyml.org). Example build instructions can be found in build-instructions.sh. This branch (master) contains the latest development version of CakeML. See the version1 branch for the previous version. Directory structure: - semantics The definition of CakeML, including - its concrete syntax - its abstract syntax - small step semantics - big step semantics (both functional and relational) - semantics of FFI calls - a type system The definition is (mostly) expressed in Lem (http://www.cs.kent.ac.uk/~sao/lem), but the generated HOL is also included. - semantics/proofs Metatheory of CakeML and other proofs about the semantics - a verified, clocked interpreter - determinism - type soundness - equivalence of the big and small step semantics - equivalence of functional and relational semantics - compiler A verified compiler for CakeML, including: - parsing: lexer and PEG parser - inference: type inferencer - backend: compilation to ASM assembly language - targets: code generation to x86, ARM, and more - translator A proof-producing translator from HOL functions to CakeML. - unverified/interp Unverified implementation, in Haskell, of the CakeML frontend augmented with informative error messages. - unverified/bytecode An unverified implementation of CakeML bytecode, written in C - candle Verification of a HOL theorem prover, based on HOL Light (http://www.cl.cam.ac.uk/~jrh13/hol-light/), implemented in CakeML. - explorer Tools for stepping through execution of the compiler from one intermediate language to the next, and pretty-printing the intermediate results. An instance is available on the CakeML website. - mlstringScript.sml, mlstringLib.sml, mlstringSyntax.sml Small theory of wrapped strings, so the translator can distinguish them from char lists and target CakeML strings. - compute_basicLib.sml Build compsets for evaluation in the logic. - miscLib.sml, miscScript.sml, preamble.sml Theorems and proof tools (e.g. tactics) used throughout the development. - lem_lib_stub empty versions of the Lem libraries (which we don't use, but building with Lem requires) - developers scripts for running regression tests and other miscellany - COPYING Copyright notice, license, and disclaimer.
About
CakeML: A Verified Implementation of ML
Resources
License
Stars
Watchers
Forks
Releases
No releases published
Packages 0
No packages published
Languages
- Standard ML 93.9%
- OCaml 3.3%
- Haskell 2.6%
- Shell 0.1%
- PHP 0.1%
- Assembly 0.0%