Publications:Implicitly Heterogeneous Multi-stage Programming

From CERES
Jump to: navigation, search

Do not edit this section

Keep all hand-made modifications below

Title Implicitly Heterogeneous Multi-stage Programming
Author Jason Eckhardt and Roumen Kaiabachev and Emir Pasalic and Kedar Swadi and Walid Taha
Year 2007
PublicationType Journal Paper
Journal New generation computing
HostPublication
DOI http://dx.doi.org/10.1007/s00354-007-0020-x
Conference
Diva url http://hh.diva-portal.org/smash/record.jsf?searchId=1&pid=diva2:396141
Abstract Previous work on semantics-based multi-stage programming (MSP) language design focused on homogeneous designs, where the generating and the generated languages are the same. Homogeneous designs simply add a hygienic quasi-quotation and evaluation mechanism to a base language. An apparent disadvantage of this approach is that the programmer is bound to both the expressivity and performance characteristics of the base language. This paper proposes a practical means to avoid this by providing specialized translations from subsets of the base language to different target languages. This approach preserves the homogeneous “look” of multi-stage programs, and, more importantly, the static guarantees about the generated code. In addition, compared to an explicitly heterogeneous approach, it promotes reuse of generator source code and systematic exploration of the performance characteristics of the target languages.To illustrate the proposed approach, we design and implement a translation to a subset of C suitable for numerical computation, and show that it preserves static typing. The translation is implemented, and evaluated with several benchmarks. The implementation is available in the online distribution of MetaOCaml.