The stable-memo package

[Tags: library, mit]

Whereas most memo combinators memoize based on equality, stable-memo does it based on whether the exact same argument has been passed to the function before (that is, is the same argument in memory).

For motivation, here is an implementation of map that preserves sharing of the spine for cyclic lists. It should even be safe to use this on arbitrarily long, acyclic lists since as long as the garbage collector is chasing you, the size of the memo table should stay under control, too.

 map :: (a -> b) -> [a] -> [b]
 map f = go
   where go = memo map'
         map' []     = []
         map' (x:xs) = f x : go xs

This library is largely based on the implementation of memo found in "Stretching the storage manager: weak pointers and stable names in Haskell", from Simon Peyton Jones, Simon Marlow, and Conal Elliott (http://community.haskell.org/~simonmar/papers/weak.pdf).

Properties

Versions0.1.1, 0.1.2, 0.1.3, 0.2.0, 0.2.1, 0.2.2, 0.2.3, 0.2.4, 0.3.0, 0.3.1
Change logNone available
Dependenciesbase (>=4.6 && <5), ghc-prim (>=0.3 && <0.5), hashtables (>=1.0 && <1.3) [details]
LicenseMIT
AuthorJake McArthur <Jake.McArthur@gmail.com>
MaintainerJake McArthur <Jake.McArthur@gmail.com>
CategoryData
Source repositoryhead: darcs get http://hub.darcs.net/jmcarthur/stable-memo
this: darcs get http://patch-tag.com/r/jmcarthur/stable-memo --tag v0.3.1
UploadedSun Jul 12 19:27:24 UTC 2015 by JakeMcArthur
DistributionsNixOS:0.3.1
Downloads1212 total (85 in last 30 days)
Votes
0 []
StatusDocs available [build log]
Last success reported on 2015-07-12 [all 1 reports]

Modules

[Index]

Downloads

Maintainers' corner

For package maintainers and hackage trustees