Type inhabitation explained

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

\tau

and a typing environment

\Gamma

, does there exist a

λ

-term M such that

\Gamma\vdashM:\tau

? With an empty type environment, such an M is said to be an inhabitant of

\tau

.

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

Notes and References

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