aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorscgilardi <scgilardi@gmail.com>2008-07-26 14:41:02 +0000
committerscgilardi <scgilardi@gmail.com>2008-07-26 14:41:02 +0000
commit8c2ff30f8de9b700d8ad45c8c5e8d2660abd152d (patch)
treed1efe5c97d0bebf942a5d7f728fbc472ea2d09b1
parente34e8b58f7d214541af08461d60004936dd340c7 (diff)
updates for my remaining libs to the new namespace organization
-rw-r--r--memoize/memoize.clj32
1 files changed, 32 insertions, 0 deletions
diff --git a/memoize/memoize.clj b/memoize/memoize.clj
new file mode 100644
index 00000000..93978c6c
--- /dev/null
+++ b/memoize/memoize.clj
@@ -0,0 +1,32 @@
+;; 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 'clojure-contrib.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]
+ (or (@cache args)
+ (let [result (apply function args)]
+ (dosync
+ (commute cache assoc args result))
+ result)))))