
Memoization in Type-Directed Partial Evaluation
Author(s) -
Vincent Balat,
Olivier Danvy
Publication year - 2002
Publication title -
brics report series
Language(s) - English
Resource type - Journals
eISSN - 1601-5355
pISSN - 0909-0878
DOI - 10.7146/brics.v9i33.21748
Subject(s) - partial evaluation , type (biology) , computer science , memoization , functional programming , partial function , function (biology) , generator (circuit theory) , arithmetic , code (set theory) , algorithm , programming language , mathematics , discrete mathematics , power (physics) , ecology , physics , set (abstract data type) , quantum mechanics , evolutionary biology , parsing , top down parsing , biology
We use a code generator--type-directed partial evaluation--to verify conversions between isomorphic types, or more precisely to verify that a composite function is the identity function at some complicated type. A typed functional language such as ML provides a natural support to express the functions and type-directed partial evaluation provides a convenient setting to obtain the normal form of their composition. However, off-the-shelf type-directed partial evaluation turns out to yield gigantic normal forms. We identify that this gigantism is due to redundancies, and that these redundancies originate in the handling of sums, which uses delimited continuations. We successfully eliminate these redundancies by extending type-directed partial evaluation with memoization capabilities. The result only works for pure functional programs, but it provides an unexpected use of code generation and it yields orders-of-magnitude improvements both in time and in space for type isomorphisms.