Type inhabitation

From HandWiki
Revision as of 16:05, 6 February 2024 by Ohm (talk | contribs) (simplify)
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)

In type theory, a branch of mathematical logic, in a given typed calculus, the type inhabitation problem for this calculus is the following problem:[1] given a type [math]\displaystyle{ \tau }[/math] and a typing environment [math]\displaystyle{ \Gamma }[/math], does there exist a [math]\displaystyle{ \lambda }[/math]-term M such that [math]\displaystyle{ \Gamma \vdash M : \tau }[/math]? With an empty type environment, such an M is said to be an inhabitant of [math]\displaystyle{ \tau }[/math].

Relationship to logic

In the case of simply typed lambda calculus, a type has an inhabitant if and only if its corresponding proposition is a tautology of minimal implicative logic. Similarly, a System F type has an inhabitant if and only if its corresponding proposition is a tautology of intuitionistic second-order logic.

Girard's paradox shows that type inhabitation is strongly related to the consistency of a type system with Curry–Howard correspondence. To be sound, such a system must have uninhabited types.

Formal properties

For most typed calculi, the type inhabitation problem is very hard. Richard Statman proved that for simply typed lambda calculus the type inhabitation problem is PSPACE-complete. For other calculi, like System F, the problem is even undecidable.

See also

  • Curry–Howard isomorphism

References

  1. Pawel Urzyczyn (1997). "Inhabitation in typed lambda-calculi (A syntactic approach)". Typed Lambda Calculi and Applications. Lecture Notes in Computer Science. 1210. Springer. pp. 373–389. doi:10.1007/3-540-62688-3_47. ISBN 978-3-540-62688-6. https://doi.org/10.1007%2F3-540-62688-3_47.