Home My Page Projects Code Snippets Project Openings SML/NJ
Summary Activity Forums Tracker Lists Tasks Docs Surveys News SCM Files

SCM Repository

[smlnj] View of /sml/branches/primop-branch-gkuan/cm/util/memoize.sml
ViewVC logotype

View of /sml/branches/primop-branch-gkuan/cm/util/memoize.sml

Parent Directory Parent Directory | Revision Log Revision Log

Revision 2787 - (download) (annotate)
Sat Sep 29 05:18:54 2007 UTC (13 years, 6 months ago) by gkuan
File size: 785 byte(s)
Creating private branch of sml/branches/primop-branch-3 for experimental Translate rewrite
 * Simple memoization.
 * (C) 1999 Lucent Technologies, Bell Laboratories
 * Author: Matthias Blume (blume@kurims.kyoto-u.ac.jp)
structure Memoize :> sig
    (* If g is the result of (memoize f), then calling g the first time
     * will result in f being called with the same argument.
     * Any subsequent call to g simply returns the result that was
     * computed during the first call.  Thus, f will be called at most
     * once on g's behalf. *)
    val memoize : ('a -> 'b) -> ('a -> 'b)
end = struct
    fun memoize f = let
	val cache = ref (fn _ => raise Fail "Memoize.memoize: uninitialized")
	fun first_time x = let
	    val v = f x
	    fun later_on _ = v
	    cache := later_on;
	cache := first_time;
	(fn x => !cache x)

ViewVC Help
Powered by ViewVC 1.0.0