Abstract
We show that a type system based on the intuitionistic modal logic S4 provides an expressive framework for specifying and analyzing computation stages in the context of typed lambda -calculi and functional languages. We directly demonstrate the sense in which our lambda (--> square)(e)-calculus captures staging, and also give a conservative embedding of Nielson and Nielson's two-level functional language in our functional language Mini-MLsquare, thus proving that binding-time correctness is equivalent to modal correctness on this fragment. In addition, Mini-MLsquare can also express immediate evaluation and sharing of code across multiple stages, thus supporting run-time code generation as well as partial evaluation.
Original language | English |
---|---|
Pages (from-to) | 555-604 |
Journal | Journal of the ACM |
Volume | 48 |
Issue number | 3 |
DOIs | |
Publication status | Published - 2001 |