Micro-cache: memoize/cache function results

A simple helper to avoid re-calculating the same results repeatedly.
249 Downloads
Updated 12 Jan 2012

View License

This is a lightweight mechanism to memoize results of functions that are often repeatedly called with the same arguments. It is indended for small-scale situations -- i.e., the function is called only with a small variety of arguments, for example less than 100, and the arguments (as well as results) are not too big (e.g., no large matrices or data sets). If too many different calls are to be cached, hlp_microcache "forgets about" the oldest ones. Its memory is also lost after MATLAB is closed or after typing "clear all". Different places of a program can independently memoize results of their functions, by calling hlp_microcache with their own unique 'domain' identifier. The overhead is in the ballpark of MATLAB's num2str(), i.e., very low.

Example:

% if this line is executed for the first time, it is as slow as magic(2000)
m = hlp_microcache('test',@magic,2000);

% if it is executed a second time, it is ca. three orders of magnitude faster than m=magic(2000)
m = hlp_microcache('test',@magic,2000);

Cite As

Christian Kothe (2024). Micro-cache: memoize/cache function results (https://www.mathworks.com/matlabcentral/fileexchange/34565-micro-cache-memoize-cache-function-results), MATLAB Central File Exchange. Retrieved .

MATLAB Release Compatibility
Created with R2008a
Compatible with any release
Platform Compatibility
Windows macOS Linux
Categories
Find more on Fortran with MATLAB in Help Center and MATLAB Answers

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!
Version Published Release Notes
1.0.0.0