function [X_hat ,error]= GD_TC_best(X_star,Y,Omega,p,eta,k,T)  



[n1,n2,n3] = size(Y);
L = rand(n1,k,n3)/k*1e-5;
R = rand(n2,k,n3)/k*1e-5;
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) 
        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
