Abstract
Arity raising, also known as variable splitting or flattening, is the program optimization which transforms a function of one argument into a function of several arguments by decomposing the structure of the original one argument into individual components in that structure. This optimization eliminates the need for the structuring of the components and also allows more arguments to be passed in registers during a function call. We present a formal specification of arity raising for a higher-order functional language. This specification supports the general arity raising of functions, even for functions which are passed as arguments or returned as values. We define a practical algorithm, based on algorithm W, which implements arity raising, and we prove this algorithm sound with respect to the deductive system. These results provide a declarative framework for reasoning about arity raising and support a richer form of the transformation than is currently found in compilers for functional languages.
Original language | English (US) |
---|---|
Pages | 27-38 |
Number of pages | 12 |
DOIs | |
State | Published - 1998 |
Event | Proceedings of the 1998 3rd ACM SIGPLAN International Conference on Functional Programming, ICFP-98 - Baltimore, MD, USA Duration: Sep 27 1998 → Sep 29 1998 |
Conference
Conference | Proceedings of the 1998 3rd ACM SIGPLAN International Conference on Functional Programming, ICFP-98 |
---|---|
City | Baltimore, MD, USA |
Period | 9/27/98 → 9/29/98 |
All Science Journal Classification (ASJC) codes
- Software