
function [errors,times,X_UTF] = UTF(X_star,Y,Omega,k,max_iter)

[n1,n2,n3] = size(X_star);
T = Y;


lambda= 1e-1;



mu = 1e0; rho = 1.02; epsilon = 1e-5; mu_max = 1e8;
X = rand(n1,n2,n3)/n1;
U = rand(n1,k,n3)/n1;
V = rand(k,n2,n3)/n1;
Y = rand(n1,n2,n3)/n1;
tI = teye(k,n3);
errors = [];
times = [];
tcount = 0;
for i = 1 : max_iter
    t1 = tic;
    Z = tprod(U,V);
    temp = tprod((Y+mu*X),tran(V));
    U1 = tprod(temp,tinv(lambda*tI+mu*tprod(V,tran(V))));
    temp = tprod(tran(U1),mu*X+Y);
    V1 = tprod(tinv(mu*tprod(tran(U1),U1)+lambda*tI),temp);
    A = double(Omega==0);
    Z1 = tprod(U1,V1);
    X1 = Omega.*(T-max(0,T-Z+Y/mu - 1/mu )) + double(Omega==0).*(Z-Y/mu);
    
   
    Y = Y + rho*(X-tprod(U1,V1));
    mu = min(rho*mu,mu_max);
    error = norm(X(:)-X_star(:))/norm(X_star(:));
    errors = [errors,error];
    tcount = tcount + toc(t1);
    times = [times,tcount];
    if abs(max(X1(:)-Z1(:))) <= epsilon && abs(max(X1(:)-X(:))) <= epsilon && abs(max(Z1(:)-Z(:))) <= epsilon
        max(X1(:)-Z1(:));
        max(X1(:)-X(:));
        max(Z1(:)-Z(:));
        break;
    end
    X =X1;Z =Z1; U =U1; V=V1;

    
end
X_UTF = Z1;
norm(X(:)-X_star(:))/norm(X_star(:));

function X = SVT(U,A)
X = sign(U).*max(abs(U)-A,0);
end

end