Selective Memoization¤ Umut A. Acar Guy E. Blelloch Robert Harper School of Computer Science Carnegie Mellon University Pittsburgh, PA 15213 fumut,blelloch,
[email protected] Abstract 1 Introduction We present a framework for applying memoization selectively. The Memoization is a fundamental and powerful technique for result framework provides programmer control over equality, space us- re-use. It dates back a half century [7, 24, 25] and has been used age, and identification of precise dependences so that memoiza- extensively in many areas such as dynamic programming [4, 9, 10, tion can be applied according to the needs of an application. Two 21], incremental computation [11, 37, 12, 39, 18, 1, 40, 22, 15, 16, key properties of the framework are that it is efficient and yields 2], and many others [8, 26, 19, 14, 23, 28, 29, 22]. In fact, lazy programs whose performance can be analyzed using standard tech- evaluation provides a limited form of memoization [20]. niques. Although memoization can dramatically improve performance and We describe the framework in the context of a functional language can require only small changes to the code, no language or library and an implementation as an SML library. The language is based support for memoization has gained broad acceptance. Instead, on a modal type system and allows the programmer to express pro- many successful uses of memoization rely on application-specific grams that reveal their true data dependences when executed. The support code. The underlying reason for this is one of control: since SML implementation cannot support this modal type system stati- memoization is all about performance, the user must be able to con- cally, but instead employs run-time checks to ensure correct usage trol the performance of memoization.