Computer Science – Programming Languages
Scientific paper
2010-07-16
Computer Science
Programming Languages
12 pages
Scientific paper
Multi-level languages and Arrows both facilitate metaprogramming, the act of writing a program which generates a program. The arr function required of all Arrows turns arbitrary host language expressions into guest language expressions; because of this, Arrows may be used for metaprogramming only when the guest language is a superset of the host language. This restriction is also present in multi-level languages which offer unlimited cross-level persistence.
This paper introduces generalized arrows and proves that they generalize Arrows in the following sense: every Arrow in a programming language arises from a generalized arrow with that language's term category as its codomain. Generalized arrows impose no containment relationship between the guest language and host language; they facilitate heterogeneous metaprogramming. The category having all generalized arrows as its morphisms and the category having all multi-level languages as its morphisms are isomorphic categories. This is proven formally in Coq, and the proof is offered as justification for the assertion that multi-level languages are generalized arrows.
Combined with the existence of a particular kind of retraction in the host language, this proof can be used to define an invertible translation from two-level terms to one-level terms parameterized by a generalized arrow instance. This is ergonomically significant: it lets guest language providers write generalized arrow instances while the users of those guest languages write multi-level terms. This is beneficial because implementing a generalized arrow instance is easier than modifying a compiler, whereas writing two-level terms is easier than manipulating generalized arrow terms.
No associations
LandOfFree
Multi-Level Languages are Generalized Arrows does not yet have a rating. At this time, there are no reviews or comments for this scientific paper.
If you have personal experience with Multi-Level Languages are Generalized Arrows, we encourage you to share that experience with our LandOfFree.com community. Your opinion is very important and Multi-Level Languages are Generalized Arrows will most certainly appreciate the feedback.
Profile ID: LFWR-SCP-O-658374