memoize: A memoization library

[ bsd3, data, library ] [ Propose Tags ]

This library provides a type class Memoizable for memoizing functions, along with instances for a variety of argument types. It includes a Template Haskell function for deriving Memoizable instances for arbitrary algebraic datatypes.

The library constructs pure memo caches without the use of unsafePerformIO. This technique relies on implementation assumptions that, while not guaranteed by the semantics of Haskell, appear to be true.

Versions 0.1, 0.2, 0.3, 0.4, 0.6, 0.7, 0.8, 0.8.1
Dependencies base (>=3 && <5), template-haskell (==2.*) [details]
License BSD-3-Clause
Author Jesse A. Tov <jesse@eecs.northwestern.edu>
Maintainer jesse@eecs.northwestern.edu
Category Data
Source repo head: git clone git://github.com/tov/memoize.git
Uploaded by JesseTov at Sat Sep 3 15:55:54 UTC 2016
Distributions Debian:0.7, NixOS:0.8.1
Downloads 5246 total (48 in the last 30 days)
Rating (no votes yet) [estimated by rule of succession]
Your Rating
  • λ
  • λ
  • λ
Status Docs uploaded by user
Build status unknown [no reports yet]
Hackage Matrix CI

Modules

[Index]

Downloads

Maintainer's Corner

For package maintainers and hackage trustees