
d = 200      ;
rstar = 5      ;
X = zeros(d) ;
U = orth(randn(d,rstar)) ;
X = U*U' ;

m = 10*d*rstar ;

A = randn(m,d^2) ;


y = A*X(:) ;

%nu=2;



iters = 800 ;
angle=zeros(iters,6);



%r=60;
r=180

number_r_values=6;
loss_train=zeros(number_r_values,1);
loss_test=zeros(number_r_values,1);
nu_saved=zeros(number_r_values,1);
number_iterations=zeros(number_r_values,1);

eps=5*10^(-9); %stopping_criterion

tic
%for i=1:number_r_values
    
    nu = 5^(-i+1);
    nu_saved(i)=nu;
    Ut = nu*orth(randn(d,r)) ;
    Xt = Ut*Ut' ;
    
    mu = 1/(4*m) ;
    
    
    M=(1/m)*reshape(A'*(A*X(:)),[d,d]);
    M=1/2*(M+transpose(M));
    [V_M,Sigma_M,W_M] = svd(M);
    
    
    stopping_criterion=1;
    it_count=0
   while stopping_criterion>eps
   %while it_count<200
        
        r = (A*Xt(:)-y) ;
        %Ut = Ut-mu*reshape(A'*(A*Xt(:)-y),[d,d])*Ut ;
        Zt=reshape(A'*r,[d,d]);
        Xt = Ut*Ut' ;
        Zt=1/2*(transpose(Zt)+Zt);
        
        gradt = Zt*Ut ;
        Ut = Ut-mu * gradt ;
  
        risk=(1/(4*m))*norm(r,'fro')^2;

        
        it_count=it_count+1 ;
        grad_norm=(1/m)*norm(gradt,'fro');
        function_value=risk;
        %stopping_criterion=grad_norm^2/(1+function_value)
        stopping_criterion=risk ;
        
        if rem(it_count, 50 )== 0 ;
            it_count
            stopping_criterion
            norm(X-Ut*transpose(Ut),'fro')^2
        end
        
    end
    loss_test=norm(X-Ut*transpose(Ut),'fro')^2
    loss_train=stopping_criterion
    number_iterations=it_count
    i
    nu_saved
toc


disp([loss_test,loss_train,i,number_iterations])
