function [ TC,errors,times ] = TCTF( Y,X,Omega,T )

%% produce data
data=Y;
known=Omega;
[n1,n2,n3]=size(X);

%% our method 
opts = [];
opts.maxIter=T;
opts.tol = -1e-5; % run to maxit by using negative tolerance
opts.Mtr = X; % pass the true tensor to calculate the fitting
opts.alpha_adj = 0;
opts.rank_adj = -1*ones(1,n3);
opts.rank_inc = 1*ones(1,n3);
opts.rank_min = [20,5,5];
opts.rank_max = [100,100,100];

EstCoreNway = round(30*ones(1,n3));
Nway=[n1,n2,n3];
[TC,errors,times] = TCTF_solver(data,known,Nway,EstCoreNway,opts, X);

%% compute PSNR
maxP=max(X(:));
TC = max(TC,0);
TC = min(TC,maxP);

psnr= PSNR(X,TC,maxP);

end

