function X_hat = GD_TC_ES(X_star,Y,Omega,p,eta,k,T)  

% p = 0.1;k=60;T=500; thresh_low = 1e-10;thresh_up =1e7; eta =1e-4;
% X_star1 = double(imread('testimg.jpg'));
% 
% X_star = tsvd_r(X_star1,k);
% 
% norm(X_star(:)-X_star1(:))^2/norm(X_star1(:))^2
% X_star = X_star/255; 
% maxP = max(abs(X_star(:)));

% img = double(imread('1.jpg'));
% img = img/255;
% [n1,n2,n3] = size(img);
% r = 50;
% X_star = tsvd_r(img,r);
% % X_star = tprod(tprod(U,S),tran(V));
% norm(X_star(:)-img(:))^2/norm(img(:))^2;
% 
% maxP = max(abs(X_star(:)));
% 
% p=0.3;
% 
% Omega_seed = rand(n1,n2,n3);
% Omega = Omega_seed < p;
% Y = Omega.*(X_star +normrnd(0,0,[n1,n2,n3])); % missing
% 
% T = 100;
% eta = 0.001;


[n1,n2,n3] = size(Y);
L = rand(n1,k,n3)/k*1e-10;
R = rand(n2,k,n3)/k*1e-10;
X = tprod(L,tran(R));
X1 = X;


Z = Omega.*tprod(L,tran(R)) - Y;
loss = [];
error = [];
X_hat = zeros(n1,n2,n3);
for t=1:T
    t1 = tic;
    
    obj = norm(Z, 'fro')^2/(2*p);
    if ~isfinite(obj) 
        break;
    end
    Z = Omega.*X - Y;
    L = L - eta/p *tprod(Z,R);
    R = R- eta/p *tprod(tran(Z),L);
    X = tprod(L,tran(R));

    re = norm(X - X_star, 'fro')/norm(X_star, 'fro');
    error = [error,re^2];
    
    if t>1
        if error(t)<=error(t-1)
           X_hat = X;
    end

    end

end
errors = min(error);
norm(X_hat - X_star, 'fro')^2/norm(X_star, 'fro')^2;
end
