function [loss,times,X_ScaledGD] = ScaledGD_TC(X_star,Y,Omega,p,eta,k,T)  

% X_star = randn(10,10,3);
% Omega_seed = rand(10,10,3);
% Omega = Omega_seed < p;
% Y = Omega.*X_star;
% clear
% p = 0.1;k=60;T=500; thresh_low = 1e-10;thresh_up =1e6; eta =1e-1;
% 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(:)));
[n1,n2,n3] = size(X_star);
Omega_seed = rand(n1,n2,n3);
Omega = Omega_seed < p;
Y = Omega.*X_star;
% L = rand(n1,k,n3)*1e-1;
% R = rand(n2,k,n3)*1e-1;

[n1,n2,n3] = size(X_star);
[L,R] = spectral_ini(Y/p,k);


Z = Omega.*tprod(L,tran(R)) - Y;
loss = [];
times = [];
tcount = 0;
for t=1:T
    t1= tic;
    X = tprod(L,tran(R));
    obj = norm(Z, 'fro')^2/(2*p);
    if ~isfinite(obj) 
        break;
    end
    Z = Omega.*X - Y;
    L_plus = L - eta/p *tprod(tprod(Z,R), tinv(tprod(tran(R),R)));
    R = R- eta/p *tprod(tprod(tran(Z),L), tinv(tprod(tran(L),L)));
    L =L_plus;
    re = norm(X - X_star, 'fro')/norm(X_star, 'fro');
    loss = [loss,re^2];
    tcount = tcount + toc(t1);
    times = [times,tcount];
end
X_ScaledGD = tprod(L,tran(R));

end

% plot(1:T,loss(:,2),'-r')
% set(gca,'yscale','log')
