aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorscgilardi <scgilardi@gmail.com>2008-06-03 04:19:36 +0000
committerscgilardi <scgilardi@gmail.com>2008-06-03 04:19:36 +0000
commit7d3ef537294ca215958098d7215680a52ff6c0ab (patch)
treec04770e0b705d93fae36b2d9177b3d9c6bb99e47
parent4ec57b53c248954845d064ee4a44ba7b49bc67e2 (diff)
add memoize.clj
-rw-r--r--memoize.clj33
1 files changed, 33 insertions, 0 deletions
diff --git a/memoize.clj b/memoize.clj
new file mode 100644
index 00000000..dcaf642b
--- /dev/null
+++ b/memoize.clj
@@ -0,0 +1,33 @@
+;; Copyright (c) Stephen C. Gilardi. All rights reserved.
+;; The use and distribution terms for this software are covered by the
+;; Common Public License 1.0 (http://opensource.org/licenses/cpl.php)
+;; which can be found in the file CPL.TXT at the root of this distribution.
+;; By using this software in any fashion, you are agreeing to be bound by
+;; the terms of this license.
+;; You must not remove this notice, or any other, from this software.
+;;
+;; File: memoize.clj
+;;
+;; scgilardi (gmail)
+;; 02 June 2008
+;;
+;; Based on Common Lisp code from:
+;; http://asymmetrical-view.com/talks/lisp-presentation/lisp-presentation.pdf
+
+(clojure/in-ns 'memoize)
+(clojure/refer 'clojure)
+
+(defn memoize
+ "Returns a memoized version of a referentially transparent function. The
+ memoized version of the function keeps a cache of the mapping from arguments
+ to results and, when calls with the same arguments are repeated often, has
+ higher performance at the expense of higher memory use."
+ [function]
+ (let [cache (ref {})]
+ (fn [& args]
+ (if-let cached (@cache args)
+ cached
+ (let [result (apply function args)]
+ (dosync
+ (commute cache assoc args result))
+ result)))))