pith. sign in

arxiv: 1501.02925 · v2 · pith:6ZBBYL5Tnew · submitted 2015-01-13 · 💻 cs.PL · cs.LO

Programming and Reasoning with Guarded Recursion for Coinductive Types

classification 💻 cs.PL cs.LO
keywords guardedtypescoinductiverecursivecalculuslambda-calculuslogicprogram
0
0 comments X
read the original abstract

We present the guarded lambda-calculus, an extension of the simply typed lambda-calculus with guarded recursive and coinductive types. The use of guarded recursive types ensures the productivity of well-typed programs. Guarded recursive types may be transformed into coinductive types by a type-former inspired by modal logic and Atkey-McBride clock quantification, allowing the typing of acausal functions. We give a call-by-name operational semantics for the calculus, and define adequate denotational semantics in the topos of trees. The adequacy proof entails that the evaluation of a program always terminates. We demonstrate the expressiveness of the calculus by showing the definability of solutions to Rutten's behavioural differential equations. We introduce a program logic with L\"{o}b induction for reasoning about the contextual equivalence of programs.

This paper has not been read by Pith yet.

discussion (0)

Sign in with ORCID, Apple, or X to comment. Anyone can read and Pith papers without signing in.