funcmemoize[Tcomparable, Uany](f func(T) U) func(T) U {
memory := make(map[T]U)
returnfunc(t T) U {
if u, seen := memory[t]; seen {
return u
}
u := f(t)
memory[t] = u
return u
}
}
memoize is generic but requires that f accepts a single argument of type T and returns a single result of type U.
type
TCache = specialize TFPGMap<TKey, TData>;
var
Cache: TCache;
...
function m(Key: TKey): TData;
begin
if not Assigned(Cache) then
Cache := TCache.Create;
if not Cache.TryGetData(Key, Result) then
begin
Result := f(Key);
Cache.Add(Key, Result);
end;
end;
TKey and TData can be of any kind (as long as they are not a class).
The variable Cache should be freed upon exiting the program.
Custom memoization of a Fibonacci function, using a hash to cache result values. Should work for any pure function; i.e. stateless and with no side-effects.
func memoize[T comparable, U any](f func(T) U) func(T) U {
memory := make(map[T]U)
return func(t T) U {
if u, seen := memory[t]; seen {
return u
}
u := f(t)
memory[t] = u
return u
}
}
type
TCache = specialize TFPGMap<TKey, TData>;
var
Cache: TCache;
...
function m(Key: TKey): TData;
begin
if not Assigned(Cache) then
Cache := TCache.Create;
if not Cache.TryGetData(Key, Result) then
begin
Result := f(Key);
Cache.Add(Key, Result);
end;
end;