B=xlsread('B.xlsx');
obs=xlsread('obs.xlsx');
n=1000; % iteration number
m=size(B,1);
m_obs=0.1*m*m;
X=zeros(3,m,m);
s=1.3;
lambda=0.005;
t=zeros(n,1);
for i=1:2
    for j=1:m_obs
        t(i)=t(i)+0.5*(X(mod(i,3)+1,obs(j,1),obs(j,2))-B(obs(j,1),obs(j,2)))^2;
    end
end
theta=zeros(n,1);
theta(2)=1;
Y=zeros(m,m);
for i=2:n
    nabla_fy=zeros(m,m);
    for j=1:m_obs
        nabla_fy(obs(j,1),obs(j,2))=Y(obs(j,1),obs(j,2))-B(obs(j,1),obs(j,2));
    end  %compute \nabla f(Y)
    grad_f=Y-s*nabla_fy; % Y-\frac{ns}{2n+4}\nabla f(Z)
    [U,Sigma,V]=svd(grad_f);
    Sigma=max(Sigma-s*lambda*eye(m),zeros(m));
    X(mod(i,3)+1,:,:)=U*Sigma*V';
    theta(i+1)=(1+sqrt(1+4*theta(i)*theta(i)))/2;
    Y=X(mod(i,3)+1,:,:)+((theta(i)-1)/theta(i+1))*(X(mod(i,3)+1,:,:)-X(mod(i-1,3)+1,:,:));
    Y=reshape(Y,100,100);
    for j=1:m_obs
        t(i)=t(i)+0.5*(X(mod(i,3)+1,obs(j,1),obs(j,2))-B(obs(j,1),obs(j,2)))^2;
    end
    t(i)=t(i)+lambda*sum(diag(Sigma));
end
semilogy((1:4:n/2),t(1:4:n/2)-0.02810523108535746203417993,'ok','MarkerSize',3);
xlabel('n');
ylabel('$|F-F^*|$','Interpreter','LaTeX');
hold on;
%plot(t);