clear all
clc

randn('state',1); rand('state',1); %#ok<RAND>
caseIDs=1:10;
nrRuns = size(caseIDs, 2);
%% Generate CP tensor
% load('100100100R5.mat')

X0 = imread("D:\SynchroFile\project\tensor_sensing_optimal_error\comparison_methods\TCTF-code\test_image\1.jpg");
X0 = double(X0);
X                    =        X0/255;

ObsRatio = 0.1;

maxP = max(abs(X(:)));

DIM = size(X);
Omega0 = randperm(prod(DIM));
Omega0 = Omega0(1:round(ObsRatio*prod(DIM)));
O = zeros(DIM);
O(Omega0) = 1;
Omega=logical(O);
%% Generate observation tensor Y
T=X.*O;


maxIter = 500;
epsilon = 1e-15;
InitialR =round(0.5*mean(size(X)));
fr= 1e-3*(ObsRatio);  % threhold for rank estimation, it could be even smaller;
mu    =10/(sqrt(mean(size(X))*(1-ObsRatio)))*(max(T(:)));

tic
[Z,TubalR,TimeRE] = TC_RE(...
    T,...                     % The incomplete matrix whose elements in Omega are used for estimating missing value;
    Omega,...                 % The index set of the obeserved elements: known 1, unkown, 0;
    mu,...                    % The parameter of the L1-norm regularzation term; always set it as 30;
    maxIter,...               % The maximum iterations;
    epsilon,...               % The stop tolerance of the error of approximation Z and input X on observed entries;
    InitialR);                    % The initial maximum rank for target matrix);

norm(Z-X,'fro')/norm(Z,'fro')
PSNR(Z,X,maxP)
TimeRE