We introduce an automatic method for producing stateful ML programs together with proofs of correctness from monadic functions in HOL. Our mechanism supports references, exceptions, and I/O operations, and can generate functions manipulating local state, which can then be encapsulated for use in a pure context. We apply this approach to several non-trivial examples, including the instruction encoder and register allocator of the otherwise pure CakeML compiler, which now benefits from better runtime performance. This development has been carried out in the HOL4 theorem prover
We have developed and mechanically verified a new compiler backend for CakeML. Our new compiler feat...
This thesis is about mechanically establishing the correctness of computer programs.\ua0In particula...
Software veri?cation tools that build machine-checked proofs of functional correctness usually focus...
We introduce an automatic method for producing stateful ML programs together with proofs of correctn...
We introduce an automatic method for producing stateful ML programs together with proofs of correctn...
Many theorem provers can generate functional programs from definitions or proofs. However, this code...
We have designed an intermediate language (IL) for the CakeML compiler that supports the verified, e...
We have designed an intermediate language (IL) for the CakeML compiler that supports the verified, e...
We have developed and mechanically verified a new compiler backend for CakeML. Our new compiler feat...
The CakeML compiler is, to the best of our knowledge, the most realistic veri?ed compiler for a func...
This thesis is about verified computer-aided checking of mathematical proofs. We build on tools for ...
The CakeML compiler is, to the best of our knowledge, the most realistic verified compiler for a fun...
We have developed and mechanically verified a new compiler backend for CakeML. Our new compiler feat...
We have developed and mechanically verified a new compiler backend for CakeML. Our new compiler feat...
We have developed and mechanically verified a new compiler backend for CakeML. Our new compiler feat...
We have developed and mechanically verified a new compiler backend for CakeML. Our new compiler feat...
This thesis is about mechanically establishing the correctness of computer programs.\ua0In particula...
Software veri?cation tools that build machine-checked proofs of functional correctness usually focus...
We introduce an automatic method for producing stateful ML programs together with proofs of correctn...
We introduce an automatic method for producing stateful ML programs together with proofs of correctn...
Many theorem provers can generate functional programs from definitions or proofs. However, this code...
We have designed an intermediate language (IL) for the CakeML compiler that supports the verified, e...
We have designed an intermediate language (IL) for the CakeML compiler that supports the verified, e...
We have developed and mechanically verified a new compiler backend for CakeML. Our new compiler feat...
The CakeML compiler is, to the best of our knowledge, the most realistic veri?ed compiler for a func...
This thesis is about verified computer-aided checking of mathematical proofs. We build on tools for ...
The CakeML compiler is, to the best of our knowledge, the most realistic verified compiler for a fun...
We have developed and mechanically verified a new compiler backend for CakeML. Our new compiler feat...
We have developed and mechanically verified a new compiler backend for CakeML. Our new compiler feat...
We have developed and mechanically verified a new compiler backend for CakeML. Our new compiler feat...
We have developed and mechanically verified a new compiler backend for CakeML. Our new compiler feat...
This thesis is about mechanically establishing the correctness of computer programs.\ua0In particula...
Software veri?cation tools that build machine-checked proofs of functional correctness usually focus...