Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Why does MATLAB slow down when printing lots of (.png) figures?

I am printing a large series of figures as .png files. Each figure is a plot of a column from a data matrix, and I take the .png files and string them together into an animation.

My problem is that the first few hundred images print quickly, but the amount of time to create each new figure increases rapidly, from ~0.2 sec for the first few hundred .png files to 2 sec or more at around the 800th figure.

Memory usage increases during the run of the script, but only by 1MB every few seconds or so. This is on Windows running R2009b 64-bit.

My code looks something like:

n = 1000;
matrix = rand(n);

f = figure('Visible','off');    % create the figure

for i_ =1:n
    plot(1:n,matrix(:,i_));
    ylim([0 1]);
    set(f,'PaperUnits','inches','PaperPosition',[0 0 6 4]);
    png_name = [ 'img/timestep_' sprintf('%05d',i_) ];
    print('-dpng', png_name);
end
like image 783
andyras Avatar asked Apr 05 '12 16:04

andyras


1 Answers

Try not to regenerate the plot, but only change the XData and YData properties at each iteration:

set(f,'PaperUnits','inches','PaperPosition',[0 0 6 4]);
h = plot(1, matrix(:,1));
ylim([0 1]);

for i_ = 1:n
    set(h, 'XData', 1:n, 'YData', matrix(:,i_))
    png_name = sprintf('img/timestep_%05d',i_);
    print('-dpng', png_name);
end

Another suggestion. If you want to create an animation, why are you generating png files? Use GETFRAME and make a MOVIE directly in MATLAB.

like image 51
yuk Avatar answered Sep 28 '22 15:09

yuk