CINXE.COM

Dependent Types and Multi-monadic Effects in F*

<html> <header> <title>Dependent Types and Multi-monadic Effects in F*</title> </header> <body> <center> <div style="text-align: justify; width: min(90%, 50em)"> <h1 style="text-align: center"> Dependent Types and Multi-monadic Effects in F&#11089; </h1> <div> <a href="artifacts"> <img src="../aec-badge-popl.png" alt="Artifact Evaluation Badge" style="float:right;width:7em;height:7em;"> </a> </div> <p style="text-align: center"> <a href="http://research.microsoft.com/en-us/people/nswamy/">Nikhil Swamy</a><sup>1</sup>&nbsp;&nbsp;&nbsp; <a href="http://prosecco.gforge.inria.fr/personal/hritcu/">C&#259;t&#259;lin Hri&#355;cu</a><sup>2</sup>&nbsp;&nbsp;&nbsp; <a href="http://prosecco.gforge.inria.fr/personal/ckeller/">Chantal Keller</a><sup>1,3</sup>&nbsp;&nbsp;&nbsp; <a href="https://www.cs.umd.edu/~aseem/">Aseem Rastogi</a><sup>4</sup><br/> <a href="http://antoine.delignat-lavaud.fr/">Antoine Delignat-Lavaud</a><sup>2,5</sup>&nbsp;&nbsp;&nbsp; <a href="http://www.eleves.ens.fr/home/forest">Simon Forest</a><sup>2,5</sup>&nbsp;&nbsp;&nbsp; <a href="http://prosecco.gforge.inria.fr/personal/karthik/">Karthikeyan Bhargavan</a><sup>2</sup>&nbsp;&nbsp;&nbsp; <a href="http://research.microsoft.com/en-us/um/people/fournet/">C&eacute;dric Fournet</a><sup>1,3</sup><br/> <a href="http://www.strub.nu/">Pierre-Yves Strub</a><sup>6</sup>&nbsp;&nbsp;&nbsp; <a href="http://research.microsoft.com/en-us/people/markulf/">Markulf Kohlweiss</a><sup>1</sup>&nbsp;&nbsp;&nbsp; Jean-Karim Zinzindohoue<sup>2,5</sup>&nbsp;&nbsp;&nbsp; Santiago Zanella-B&eacute;guelin<sup>1</sup> <br/><br/> <font size="2"> <sup>1</sup>Microsoft Research&nbsp;&nbsp;&nbsp; <sup>2</sup>Inria&nbsp;&nbsp;&nbsp; <sup>3</sup>MSR-Inria&nbsp;&nbsp;&nbsp; <sup>4</sup>UMD&nbsp;&nbsp;&nbsp; <sup>5</sup>ENS Paris&nbsp;&nbsp;&nbsp; <sup>6</sup>IMDEA Software Institute </font> </p> <p style="text-align: center"> <b><a href="http://conf.researchr.org/home/POPL-2016"> Symposium on Principles of Programming Languages, POPL 2016</a></b> </p> <h3>Abstract</h3> <p> We present a new, completely redesigned, version of F&#11089;, a language that works both as a proof assistant as well as a general-purpose, verification-oriented, effectful programming language. </p> <p> In support of these complementary roles, F&#11089; is a dependently typed, higher-order, call-by-value language with <i>primitive</i> effects including state, exceptions, divergence and IO. Although primitive, programmers choose the granularity at which to specify effects by equipping each effect with a <i>monadic</i>, predicate transformer semantics. F&#11089; uses this to efficiently compute weakest preconditions and discharges the resulting proof obligations using a combination of SMT solving and manual proofs. Isolated from the effects, the core of F&#11089; is a language of pure functions used to write specifications and proof terms---its consistency is maintained by a semantic termination check based on a well-founded order. </p> <p> We evaluate our design on more than 55,000 lines of F&#11089; we have authored in the last year, focusing on three main case studies. Showcasing its use as a general-purpose programming language, F&#11089; is programmed (but not verified) in F&#11089;, and bootstraps in both OCaml and F#. Our experience confirms F&#11089;'s pay-as-you-go cost model: writing idiomatic ML-like code with no finer specifications imposes no user burden. As a verification-oriented language, our most significant evaluation of F&#11089; is in verifying several key modules in an implementation of the TLS-1.2 protocol standard. For the modules we considered, we are able to prove more properties, with fewer annotations using F&#11089; than in a prior verified implementation of TLS-1.2. Finally, as a proof assistant, we discuss our use of F&#11089; in mechanizing the metatheory of a range of lambda calculi, starting from the simply typed lambda calculus to System F-omega and even micro-F&#11089;, a sizeable fragment of F&#11089; itself---these proofs make essential use of F&#11089;'s flexible combination of SMT automation and constructive proofs, enabling a tactic-free style of programming and proving at a relatively large scale. </p> <ul> <li><a href="paper.pdf">Paper (PDF)</a></li> <li><a href="artifacts">Online materials (artifact evaluated)</a></li> <li><a href="popl2016.html?transition=none">POPL 2016 slides</a></li> <li><a href="http://fstar-lang.org/">F&#11089; project page</a></li> <li><a href="https://github.com/FStarLang/FStar">F&#11089; on GitHub</a></li> </ul> </div> </center> </body> </html>

Pages: 1 2 3 4 5 6 7 8 9 10