cache Option
|
Calling Sequence
|
|
option cache or options cache
option cache(n) or options cache(n)
|
|
Parameters
|
|
n
|
-
|
integer: the size of the cache table
|
|
|
|
|
Description
|
|
•
|
A procedure with option cache automatically uses a cache table as a remember table.
|
•
|
Using a cache table as a remember table is similar to using a standard remember table. At the end of each invocation of the procedure, an entry is added to the cache table. When the procedure is called, this table is checked to see if the result already exists in the table. If it does the result is returned without evaluating the function. For more information on remember tables, see remember.
|
|
The difference between a cache table and a standard remember table is that cache tables have a maximum size. As new elements are added old ones may be removed. Therefore, the cache table does not grow continuously as values are added.
|
•
|
Permanent entries can be inserted into a cache table by using the AddPermanent command. This allows cache remember tables to still be used for base cases in recursive functions and for storing commonly used values.
|
•
|
Cache remember tables attempt to solve the problems of standard remember tables and option system remember tables. The advantage over standard remember tables is that a cache table has a maximum size. This means that a cache table does not act as a memory trap, storing a large number of values that cannot be reclaimed by garbage collection. As cache tables allow permanent elements to be added, they can be used in procedures that cannot use option system remember tables.
|
•
|
When using option cache(n), the cache table can store at least n elements. This is the same as passing n into the Cache command.
|
•
|
The Cache command can also be used to create a procedure with a cache remember table, but without option cache. This behaves much like a procedure with a remember table, but no option remember. The table is checked when the procedure is invoked, but values are not automatically added to the table when the procedure returns.
|
•
|
Option cache is incompatible with option remember and option system. An error occurs if they are used together.
|
|
|
Examples
|
|
>
|
cacheFunc := proc() option cache; print(args); args; end proc;
|
| (1) |
>
|
|
| (2) |
>
|
|
| (3) |
>
|
|
| (4) |
>
|
|
| (5) |
>
|
|
| (6) |
>
|
|
| (7) |
>
|
|
| (8) |
>
|
|
| (9) |
>
|
|
| (10) |
>
|
|
| (11) |
>
|
cacheFunc := proc() option cache(16); args; end proc;
|
| (12) |
>
|
remFunc := proc() option remember; args; end proc;
|
| (13) |
>
|
|
| (14) |
>
|
|
| (15) |
|
|