clear all;
close all;
clc      ;

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(:) ;

nu = 1/(140*d);
%nu=2;
Ut = nu*orth(randn(d,r)) ;
Xt = Ut*Ut' ;

mu = 1/(4*m) ;

iters = 100 ;

%approx=zeros(iters,1);
%normperp=zeros(iters,1);
%effectrank=zeros(iters,1);
%effectrankfull=zeros(iters,1);
%n=zeros(iters,1);
%correlation=zeros(iters,1);
%innerproduct=zeros(iters,1);

M=(1/m)*reshape(A'*(A*X(:)),[d,d]);
M=1/2*(M+transpose(M));
[V_M,Sigma_M,W_M] = svd(M);

VMperp=transpose(V_M(:,(rstar+1):d));
angle=zeros(iters,1);
angle_tilde=zeros(iters,1);
sigma_min=zeros(iters,1);
Uttilde=Ut;
for t = 1 : iters
 
    %Ut = Ut-mu*reshape(A'*(A*Xt(:)-y),[d,d])*Ut ;
    Zt=reshape(A'*(A*Xt(:)-y),[d,d]);
    Xt = Ut*Ut' ;
    Zt=1/2*(transpose(Zt)+Zt);
    Ut = Ut-mu*Zt*Ut ;
    [V_Ut,Sigma_Ut,W_Ut] = svd(Ut);
    V_Utperp=transpose(V_Ut(:,(rstar+1):d));
    angle(t)=norm(VMperp*V_Ut(:,1:rstar));
    
    sigma_min(t)=Sigma_Ut(rstar,rstar);
    
    Zttilde=reshape(A'*(-y),[d,d]);
    Xttilde = Uttilde*Uttilde' ;
    Zttilde=1/2*(transpose(Zttilde)+Zttilde);
    Uttilde=Uttilde-mu*Zttilde*Uttilde ;
    [V_Uttilde,Sigma_Uttilde,W_Uttilde] = svd(Uttilde,'econ');
    angle_tilde(t)=norm(VMperp*V_Uttilde(:,1:rstar));
    
    %angle(t)=norm(V_Utperp*V_Uttilde(:,1:rstar));
    %Xt = Ut*Ut' ;
    %Xtperp= (eye(d)-U*U')*Ut*Ut'*(eye(d)-U*U');
    %norm(Xt-X,'fro')/norm(X,'fro')
    %approx(t)=norm(Xt-X,'fro')/norm(X,'fro');
    %risk=norm(A*Xt(:)-y,'fro')/norm(y,'fro')
    %effectrank(t)=(trace(Xtperp)/norm(Xtperp,'fro'))^2;
    %effectrankfull(t)=(trace(Xt)/norm(Xt,'fro'))^2;
    %normperp(t)=trace(Xtperp);
    %normfull(t)=trace(Xt);
    %innerproduct(t)=trace((eye(d)-U*U')*(Xt*reshape(A'*(A*Xt(:)-y),[d,d]))*(eye(d)-U*U'));
    %correlation(t)=trace(Xt*X)/(norm(Xt,'fro')*norm(X,'fro'));
    
end
dlmwrite('sigma_min.csv',[transpose(1:iters), sigma_min], ' ')
dlmwrite('angle_tilde.csv',[transpose(1:iters), angle_tilde], ' ')
dlmwrite('angle.csv',[transpose(1:iters), angle], ' ')
dlmwrite('first_line.csv',[20 0; 20 0.5; 20 1], ' ')
dlmwrite('second_line.csv',[45 0; 45 0.5; 45 1], ' ')