Javascript must be enabled to continue!
Type soundness proofs with definitional interpreters
View through CrossRef
While type soundness proofs are taught in every graduate PL class, the gap between realistic languages and what is accessible to formal proofs is large. In the case of Scala, it has been shown that its formal model, the Dependent Object Types (DOT) calculus, cannot simultaneously support key metatheoretic properties such as environment narrowing and subtyping transitivity, which are usually required for a type soundness proof. Moreover, Scala and many other realistic languages lack a general substitution property.
The first contribution of this paper is to demonstrate how type soundness proofs for advanced, polymorphic, type systems can be carried out with an operational semantics based on high-level, definitional interpreters, implemented in Coq. We present the first mechanized soundness proofs in this style for System F and several extensions, including mutable references. Our proofs use only straightforward induction, which is significant, as the combination of big-step semantics, mutable references, and polymorphism is commonly believed to require coinductive proof techniques.
The second main contribution of this paper is to show how DOT-like calculi emerge from straightforward generalizations of the operational aspects of F, exposing a rich design space of calculi with path-dependent types inbetween System F and DOT, which we dub the System D Square.
By working directly on the target language, definitional interpreters can focus the design space and expose the invariants that actually matter at runtime. Looking at such runtime invariants is an exciting new avenue for type system design.
Title: Type soundness proofs with definitional interpreters
Description:
While type soundness proofs are taught in every graduate PL class, the gap between realistic languages and what is accessible to formal proofs is large.
In the case of Scala, it has been shown that its formal model, the Dependent Object Types (DOT) calculus, cannot simultaneously support key metatheoretic properties such as environment narrowing and subtyping transitivity, which are usually required for a type soundness proof.
Moreover, Scala and many other realistic languages lack a general substitution property.
The first contribution of this paper is to demonstrate how type soundness proofs for advanced, polymorphic, type systems can be carried out with an operational semantics based on high-level, definitional interpreters, implemented in Coq.
We present the first mechanized soundness proofs in this style for System F and several extensions, including mutable references.
Our proofs use only straightforward induction, which is significant, as the combination of big-step semantics, mutable references, and polymorphism is commonly believed to require coinductive proof techniques.
The second main contribution of this paper is to show how DOT-like calculi emerge from straightforward generalizations of the operational aspects of F, exposing a rich design space of calculi with path-dependent types inbetween System F and DOT, which we dub the System D Square.
By working directly on the target language, definitional interpreters can focus the design space and expose the invariants that actually matter at runtime.
Looking at such runtime invariants is an exciting new avenue for type system design.
Related Results
Interpreting Impoliteness: Interpreters’ Voices
Interpreting Impoliteness: Interpreters’ Voices
Interpreters in the public sector in Norway interpret in a variety of institutional encounters, and the interpreters evaluate the majority of these encounters as polite. However, s...
Effect of The Board of Director's Characteristic On Islamic Bank's Financial Soundness
Effect of The Board of Director's Characteristic On Islamic Bank's Financial Soundness
The aims of this study is to diagnose the Board of Director’s characteristics and its impact on the financial soundness of Islamic banks. Regression analysis are applied to test th...
Social Work with Interpreters
Social Work with Interpreters
Social workers help very culturally diverse populations. Therefore social workers are likely to work with language interpreters in various settings such as mental health agencies, ...
Prediction of Financial Soundness Index for Viability in the European Banking System Using Machine Learning
Prediction of Financial Soundness Index for Viability in the European Banking System Using Machine Learning
This study aims to predict financial soundness for sustainability of European banking system using machine learning techniques. A sustainable banking system ensures the efficient u...
Financial Regulations, Profit Efficiency, and Financial Soundness: Empirical Evidence from Commercial Banks of Pakistan
Financial Regulations, Profit Efficiency, and Financial Soundness: Empirical Evidence from Commercial Banks of Pakistan
The purpose of this paper is threefold. First, it measures profit efficiency and financial stability of commercial banks of Pakistan. Second, it empirically estimates the effect of...
Can a computer proof be elegant?
Can a computer proof be elegant?
In computer science, proofs about computer algorithms are par for the course. Proofs
by
computer algorithms, on the other hand, are not so readily accepted....
Proof by analogy in mural
Proof by analogy in mural
Abstract
An important advantage of using a formal method of developing software is that one can prove that development steps are correct with respect to their specificati...
War and interpreters
War and interpreters
This paper attempts to shed light on issues of trust, control, ethics and identity concerning military interpreters who use their language skills against the country or people of t...

