Сначала вы должны сделать кадры (изображения) каждого временного шага вашего моделирования.
Поскольку у вас есть декартовы координаты, вы должны преобразовать свои координаты x и y в индексы пикселей и создать матрицу изображенияот них.См. Мой ответ на соответствующий вопрос для примера того, как это сделать.Вы также можете изменить код так, чтобы ваши точки были больше пикселя, имели формы и т. Д., Возможно, с помощью strel
или [a,b,~] = sphere(N)
.
Получив кадры, вы можете легко создать файл AVI.(без сжатия или в формате MPEG) в MATLAB:
aviOutput = fullfile('path','to','file.avi');
aviobj = VideoWriter(aviOutput);
aviobj.Quality = 100;
aviobj.FrameRate = 24; %# arbitrary
open(aviobj);
for i=1:length(frames)
writeVideo(aviobj,frames{i}); %# or frames(:,:,i) etc.
end
close(aviobj);
Обновление
В приведенном выше примере все временные шаги доступны.Например:
files = dir('path/to/dir');
files(1:2) = []; %# . and ..
orderedfiles = cell(length(files),1);
for i=1:length(files)
ind = sscanf(files(i).name,[name '%*[_]%u%*s']);
orderedfiles{ind+1} = files(i).name;
end
timeSteps = zeros(numPoints,2,length(orderedfiles));
for i=1:length(orderedfiles)
temp = load(orderedfiles(i).name);
timeSteps(:,:,i) = temp.matrixName %# All the same name?
end
Код из связанного ответа написан для работы с двумя векторами x
и y
с координатами, которые вы получите с помощью timeSteps(:,1,i)
и timeSteps(:,2,i)
, иделать для каждого временного шага.