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

m = 10*d*rstar ;

A = randn(m,d^2) ;


y = A*X(:) ;



%r=60;
r=180
nu = 10^(-3)
number_of_iterations=4*10^5


counter=zeros(number_of_iterations/50,1);

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

tic
%for i=1:number_r_values
   
Ut = (1/sqrt(r))*nu*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;
loss_test=zeros(number_of_iterations/100,1);
loss_train=zeros(number_of_iterations/100,1);

while it_count<=number_of_iterations
   
        
        res = (A*Xt(:)-y) ;
        %Ut = Ut-mu*reshape(A'*(A*Xt(:)-y),[d,d])*Ut ;
        Zt=reshape(A'*res,[d,d]);
        Xt = Ut*Ut' ;
        Zt=1/2*(transpose(Zt)+Zt);
        
        gradt = Zt*Ut ;
        Ut = Ut-mu * gradt ;
  
        risk=(1/(4*m))*norm(res,'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 ;
        risk
        if rem(it_count, 50 )== 0 ;
            counter(it_count/50)=it_count;
            loss_test(it_count/50)=norm(X-Ut*transpose(Ut),'fro')^2;
            loss_train(it_count/50)=risk;
            norm(X-Ut*transpose(Ut),'fro')^2
            it_count
        end
        
end


dlmwrite('train_small.csv',[counter, loss_train], ' ');
dlmwrite('test_small.csv',[counter, loss_test], ' ');

norm(X-Ut*transpose(Ut),'fro')^2
risk
i
toc

