% applying tnsor completion for image inpainting

clear
data = load('mask.mat');
X_star = data;




maxP = max(abs(X_star(:)));
[n1,n2,n3] = size(X_star);

p = 0.5; % sampling rate

omega = find(rand(n1*n2*n3,1)<p);
M = zeros(n1,n2,n3);
M(omega) = X_star(omega);

M2 = Frontal2Lateral(M); % each lateral slice is a channel of the image
omega2 = zeros(n1,n2,n3);
Iones = ones(n1,n2,n3);
omega2(omega) = Iones(omega);
omega2 = Frontal2Lateral(omega2);
omega2 = find(omega2==1);

opts.DEBUG = 1;
opts.max_iter =300;
[Xhat, ~,~,~,errors,times]= lrtc_tnn(M2,omega2,X_star,opts);
Xhat = max(Xhat,0);
Xhat = min(Xhat,maxP);
Xhat = Lateral2Frontal(Xhat); % each lateral slice is a channel of the image

sum(abs(Xhat(:)-X_star(:)))/sum(abs(X_star(:)))

% psnr = PSNR(X_star,Xhat,maxP)

x=1:length(errors);
plot(x,errors,'-r')

% figure(1)
% subplot(1,3,1)
% imshow(X)
% subplot(1,3,2)
% imshow(M)
% subplot(1,3,3)
% imshow(Xhat)


