The array-memoize package
Memoization combinators are great for providing high-performance Haskell programs, but they can be even faster if memoization is performed on a finite, discrete domain since an array can then be used to store results.
This package provides various combinators for doing just this, including also combinators for quanitzing and discretizing Float/Double-valued functions.
fib' :: (Int -> Int) -> Int -> Int fib' _ 0 = 1 fib' _ 1 = 1 fib' rec n = rec (n - 1) + rec (n - 2) fib :: Int -> Int fib = arrayMemoFix (0, 1000) fib'
|Dependencies||array (>=0.4), base (<5) [details]|
|Copyright||Dominic Orchard, 2014|
|Source repository||head: git clone https://github.com/dorchard/array-memoize|
|Uploaded||Fri Apr 4 15:58:23 UTC 2014 by DominicOrchard|
|Distributions||LTSHaskell:0.6.0, NixOS:0.6.0, Stackage:0.6.0, Tumbleweed:0.6.0|
|Downloads||748 total (6 in the last 30 days)|
|Rating||0.0 (0 ratings) [clear rating]|
|Status||Docs available [build log]
Successful builds reported [all 1 reports]
Hackage Matrix CI
For package maintainers and hackage trustees