Why does MATLAB slow down when printing lots of (.

2019-06-23 21:03发布

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

2条回答
迷人小祖宗
2楼-- · 2019-06-23 21:12

This seems like a memory leak. You may be able to help Matlab release the leaked memory by creating and closing each figure in the loop.

for i = 1:n
    f = figure;
    % plot
    % print
    close(f)
end

Update: Here's a question and answer saying that this technique works.

查看更多
时光不老,我们不散
3楼-- · 2019-06-23 21:17

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.

查看更多
登录 后发表回答