How to use memoization in MatLab?
12 次查看(过去 30 天)
显示 更早的评论
if I have some function substantially more complicated than
function out = y(x)
out = 2*x;
end
but let's just go with this one... is there a way to save the value y(1) for example, so that if I call y(5) and then y(1) again, it's not going to CALCULATE y(1) but pull it from memory? Maybe have a function create a separate variable "y1" and store it? The problem is that I would like to not have to create empty variable BEFORE running the function (because i may not know what names they should have), i want it to create them by itself. Is there a way to do it? I guess one way would be to maybe create an empty array "y" and then store each value in its respective cell? So solution to y(1) would go to cell #1 in the array, and so on... This doesn't feel right tho. And I still don't know how that would prevent the function from doing the same calculation over and over again rather than just doing it once.
Any hints would be appreciated :]
0 个评论
回答(2 个)
Prabhakar
2018-7-24
Memoize was added to MATLAB in R2017a.
The documentation is a good resource to begin with, or if you prefer here is a blog which walks you through it.
1 个评论
Walter Roberson
2018-7-24
For earlier versions
See also https://www.mathworks.com/matlabcentral/answers/345464-recurrence-relation-for-any-given-n#comment_467043 in which I present the memoized version of a recursive relationship, and code that emulates memoize() for use with earlier versions.
另请参阅
类别
在 Help Center 和 File Exchange 中查找有关 Performance and Memory 的更多信息
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!