Lars Birkedal ; Rasmus Ejlers Møgelberg ; Jan Schwinghammer ; Kristian Støvring - First steps in synthetic guarded domain theory: step-indexing in the topos of trees

lmcs:1041 - Logical Methods in Computer Science, October 3, 2012, Volume 8, Issue 4 - https://doi.org/10.2168/LMCS-8(4:1)2012
First steps in synthetic guarded domain theory: step-indexing in the topos of trees

Authors: Lars Birkedal ; Rasmus Ejlers Møgelberg ; Jan Schwinghammer ; Kristian Støvring

    We present the topos S of trees as a model of guarded recursion. We study the internal dependently-typed higher-order logic of S and show that S models two modal operators, on predicates and types, which serve as guards in recursive definitions of terms, predicates, and types. In particular, we show how to solve recursive type equations involving dependent types. We propose that the internal logic of S provides the right setting for the synthetic construction of abstract versions of step-indexed models of programming languages and program logics. As an example, we show how to construct a model of a programming language with higher-order store and recursive types entirely inside the internal logic of S. Moreover, we give an axiomatic categorical treatment of models of synthetic guarded domain theory and prove that, for any complete Heyting algebra A with a well-founded basis, the topos of sheaves over A forms a model of synthetic guarded domain theory, generalizing the results for S.


    Volume: Volume 8, Issue 4
    Published on: October 3, 2012
    Accepted on: June 25, 2015
    Submitted on: December 21, 2011
    Keywords: Computer Science - Logic in Computer Science,D.3.1,F.3.2

    Linked data

    Source : ScholeXplorer IsCitedBy DOI 10.4230/lipics.fscd.2022.23
    • 10.4230/lipics.fscd.2022.23
    A Stratified Approach to Löb Induction
    Gratzer, Daniel ; Birkedal, Lars ;

    39 Documents citing this article

    Share

    Consultation statistics

    This page has been seen 1624 times.
    This article's PDF has been downloaded 444 times.