Maple Professional
Maple Academic
Maple Student Edition
Maple Personal Edition
Maple Player
Maple Player for iPad
MapleSim Professional
MapleSim Academic
Maple T.A. - Testing & Assessment
Maple T.A. MAA Placement Test Suite
Möbius - Online Courseware
Machine Design / Industrial Automation
Aerospace
Vehicle Engineering
Robotics
Power Industries
System Simulation and Analysis
Model development for HIL
Plant Modeling for Control Design
Robotics/Motion Control/Mechatronics
Other Application Areas
Mathematics Education
Engineering Education
High Schools & Two-Year Colleges
Testing & Assessment
Students
Financial Modeling
Operations Research
High Performance Computing
Physics
Live Webinars
Recorded Webinars
Upcoming Events
MaplePrimes
Maplesoft Blog
Maplesoft Membership
Maple Ambassador Program
MapleCloud
Technical Whitepapers
E-Mail Newsletters
Maple Books
Math Matters
Application Center
MapleSim Model Gallery
User Case Studies
Exploring Engineering Fundamentals
Teaching Concepts with Maple
Maplesoft Welcome Center
Teacher Resource Center
Student Help Center
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.
For more information on cache tables, see Cache Package.
Examples
cacheFunc := proc() option cache; print(args); args; end proc;
cacheFunc := proc() option cache(16); args; end proc;
remFunc := proc() option remember; args; end proc;
See Also
Cache Package, Cache[AddPermanent], Cache[AddTemporary], option, option/system, remember
Download Help Document