forked from vdaneshpajooh/NORST-rmc
-
Notifications
You must be signed in to change notification settings - Fork 1
/
DisplayVideo.m
57 lines (44 loc) · 1.55 KB
/
DisplayVideo.m
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
function DisplayVideo( Data1, Data2, Data3, Data4, imSize, VideoName )
% This MATLAB code displays video frames of four data matrices.
%
% Input:
% Data1-4 = data matrix corresponding to each video
% We use it in this way:
% Data1 = original video
% Data2 = missing/corruption entries support
% Data3 = corrupted video
% Data4 = reconstructed video
% imSize = size of each frame of videos, i.e., [height,width]
% (NOTE: they should all have the same sizes.)
% VideoName = name for the output video file.
writerObj = VideoWriter(VideoName);
writerObj.FrameRate = 60; % FPS: frames per second
open(writerObj);
figure;
for i = 1: size(Data1,2)
img1 = Data1(:,i);
img1 = reshape(img1,imSize);
img2 = Data2(:,i);
img2 = reshape(img2,imSize);
img3 = Data3(:,i);
img3 = reshape(img3, imSize);
img4 = Data4(:,i);
img4 = reshape(img4, imSize);
h = subplot('position',[0.01,0.50,0.47, 0.42]);
imshow(img1/255);
title(['data stream (time:',num2str(i),')'])
h = subplot('position',[0.49,0.50,0.47, 0.42]);
imshow(img2/255,[]);
title('missing entries support')
h = subplot('position',[0.01,0.001,0.47, 0.42]);
imshow(img3/255);
title('corrupted data')
h = subplot('position',[0.49,0.001,0.47, 0.42]);
imshow(img4/255);
title('reconstructed data')
frame = getframe(gcf); % 'gcf' can handle if you zoom in to take a movie.
writeVideo(writerObj, frame);
end
hold off
close(writerObj);
close all