Best way to do memory testing?

10 views (last 30 days)
Shaun VanWeelden
Shaun VanWeelden on 31 Jan 2013
Hi,
My name is Shaun VanWeelden and I am working on a project to look at script performance. A large part of what I do is gather code to evaluate and see what errors are thrown, etc. I also try and do performance testing (using tic toc) and memory usage. We currently do memory testing the following way:
%Get initial memory being used
[user, sys] = memory ;
mStart = user.MemUsedMATLAB ;
%Get initial start time
tic
%Run the actual script, the 'evalc" suppresses all output,
%do "eval" without the c to see program output
evalc(the script);
%Figure out how long script took to run
time=toc;
%Calculate total memory used and add it to the cell array
[user, sys] = memory ;
mtotal = user.MemUsedMATLAB - mStart;
But this has provided very inconsistent results due to the large number of other things going on inside the testing script. I was wondering if there was a better way to get the individual scripts we are testing’s memory use.
Thank you and let me know if you have any additional questions!
-Shaun VanWeelden
  2 Comments
Shashank Prasanna
Shashank Prasanna on 31 Jan 2013
what does a typical "the script" look like?
Shaun VanWeelden
Shaun VanWeelden on 31 Jan 2013
Almost anything to be honest, lets just say if I wanted to run every product demo and evaluate it or something like that, it needs to be a pretty flexible program, whats your ideas? Even if it won't work completely with what I am trying to do

Sign in to comment.

Accepted Answer

Jan
Jan on 31 Jan 2013
A lot of important details of the memory usage cannot be measured by calling memory before and after calling a script or a function. Example:
function out = func1
out = rand(1000, 1000);
for ii = 1:numel(out)
out(ii) = sqrt(sin(abs(out(ii) - 1)));
end
end
function out = func2
tmp = rand(1000, 1000);
out = sqrt(sin(abs(tmp - 1)));
end

More Answers (2)

Image Analyst
Image Analyst on 1 Feb 2013
Did you see the "profile" function in the help?

Shashank Prasanna
Shashank Prasanna on 1 Feb 2013
Since we are talking undocumented, do check out feature('memstats') I am not sure how you will use this, but it gives a lot more information than memory does.
  1 Comment
Cedric
Cedric on 1 Feb 2013
Edited: Cedric on 1 Feb 2013
Interesting to compare to structs returned by memory() ..
>> T = evalc('feature(''memstats'')') ;
>> str2mat(regexp(T, '(?<=Use:\s*)\d+', 'match'))

Sign in to comment.

Categories

Find more on Structures in Help Center and File Exchange

Community Treasure Hunt

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

Start Hunting!