Coinductive subtyping for abstract compilation of object-oriented languages into Horn formulas

10Citations
Citations of this article
6Readers
Mendeley users who have this article in their library.

Abstract

In recent work we have shown how it is possible to define very precise type systems for objectoriented languages by abstractly compiling a program into a Horn formula f. Then type inference amounts to resolving a certain goal w.r.t. the coinductive (that is, the greatest) Herbrand model of f. Type systems defined in this way are idealized, since in the most interesting instantiations both the terms of the coinductive Herbrand universe and goal derivations cannot be finitely represented. However, sound and quite expressive approximations can be implemented by considering only regular terms and derivations. In doing so, it is essential to introduce a proper subtyping relation formalizing the notion of approximation between types. In this paper we study a subtyping relation on coinductive terms built on union and object type constructors. We define an interpretation of types as set of values induced by a quite intuitive relation of membership of values to types, and prove that the definition of subtyping is sound w.r.t. subset inclusion between type interpretations. The proof of soundness has allowed us to simplify the notion of contractive derivation and to discover that the previously given definition of subtyping did not cover all possible representations of the empty type.

Cite

CITATION STYLE

APA

Ancona, D., & Lagorio, G. (2010). Coinductive subtyping for abstract compilation of object-oriented languages into Horn formulas. In Electronic Proceedings in Theoretical Computer Science, EPTCS (Vol. 25, pp. 214–230). Open Publishing Association. https://doi.org/10.4204/EPTCS.25.20

Register to see more suggestions

Mendeley helps you to discover research relevant for your work.

Already have an account?

Save time finding and organizing research with Mendeley

Sign up for free