clc;clear;close all;
addpath(genpath('comparison_methods'));




tubal_r=2; %% exact rank 
k=tubal_r*2; %% over estimated rank
n1=20;n2=n1;n3=3; 
ite=8000;
repeat_time=1;





error_GD=zeros(ite,2);
loss_GD=zeros(ite,2);

for i =1:repeat_time
    [error_GD_temp,loss_GD_temp] = LRTR(n1,n2,n3,tubal_r,k,ite);
    error_GD =   error_GD + error_GD_temp;
    loss_GD =   loss_GD + loss_GD_temp;
end

error_GD =  error_GD/repeat_time;
loss_GD = loss_GD/repeat_time;



marker_indices = 1:ite/5:ite;
x=1:ite;

subplot(1,2,1)
hold on;


p1=plot(x,error_GD(:,1),':o','MarkerIndices',marker_indices,'MarkerSize',18,'LineWidth',2,'Color',[189,30,30]/255);
p2=plot(x,error_GD(:,2),':*','MarkerIndices',marker_indices,'MarkerSize',18,'LineWidth',2,'Color',[55 103 149]/255);

p3=plot(x,loss_GD(:,1),'-s','MarkerIndices',marker_indices,'MarkerSize',18,'LineWidth',2,'Color',[189,30,30]/255);
p4=plot(x,loss_GD(:,2),'-+','MarkerIndices',marker_indices,'MarkerSize',18,'LineWidth',2,'Color',[55 103 149]/255);

y = min(error_GD(:,1)).*ones(ite,1);
p5=plot(x,y,'--','LineWidth',2,'Color',[255,0,0]/255);
set(gca,'yscale','log');
% ylim([1e-5,1]);


lgd = legend('Test error,small ini','Test error, large ini','Train error, small ini','Train error, large ini','Optimal error');
lgd.FontSize = 14;
lgd.FontName = 'Times New Roman';  

xlabel('Iterations','FontName', 'Times New Roman');
ylabel('Relative Error','FontName', 'Times New Roman');
% ylim([1e-10,10]);
% xlim([0,3e2])
box on
set(gca, 'FontSize', 12,'FontName', 'Times New Roman');          
set(gca, 'LineWidth', 2);      
xlim([0,500])

subplot(1,2,2)
hold on;


p1=plot(x,error_GD(:,1),':o','MarkerIndices',marker_indices,'MarkerSize',18,'LineWidth',2,'Color',[189,30,30]/255);
p2=plot(x,error_GD(:,2),':*','MarkerIndices',marker_indices,'MarkerSize',18,'LineWidth',2,'Color',[55 103 149]/255);

p3=plot(x,loss_GD(:,1),'-s','MarkerIndices',marker_indices,'MarkerSize',18,'LineWidth',2,'Color',[189,30,30]/255);
p4=plot(x,loss_GD(:,2),'-+','MarkerIndices',marker_indices,'MarkerSize',18,'LineWidth',2,'Color',[55 103 149]/255);

y = min(error_GD(:,1)).*ones(ite,1);
p5=plot(x,y,'--','LineWidth',2,'Color',[255,0,0]/255);
set(gca,'yscale','log');
% ylim([1e-5,1]);


lgd = legend('Test error, small ini','Test error, spectral ini','Train error, small ini','Train error, spectral ini','Optimal test error');
lgd.FontSize = 14;
lgd.FontName = 'Times New Roman';  

xlabel('Iterations','FontName', 'Times New Roman');
ylabel('Relative Error','FontName', 'Times New Roman');
% ylim([1e-10,10]);
% xlim([0,3e2])
box on
set(gca, 'FontSize', 12,'FontName', 'Times New Roman');         
set(gca, 'LineWidth', 2);       
set(gcf, 'Position', [100, 100, 600, 600]);  






function [error_GD,loss_GD]=LRTR(n1,n2,n3,tubal_r,k,ite)

%% init X_*, A_i and y
m=5*tubal_r*(n1+n2-tubal_r)*n3;
U_star=randn(n1,tubal_r,n3);
X_star=tprod(U_star,tran(U_star));
X_star = X_star/norm(X_star(:));
% X_star = data_gen(n1,n2,n3,kappa,tubal_r);



s1 = laprnd(m, 1, 0, 1e-3);

A=normrnd(0,sqrt(1/m),m,n1*n2*n3);
s=normrnd(0,1e-3,m,1); % noise
y=A*X_star(:) + s;


error_GD=zeros(ite,2);
loss_GD = zeros(ite,2);

%% Gradient descent with samll ini
Ft = randn(n1,k,n3)*1e-10;


mu=5e-1;



for i=1:ite

    Xt = tprod(Ft,tran(Ft));
    error_GD(i,1)=norm(X_star-Xt,'fro')^2/norm(X_star,'fro')^2;
    res = A * Xt(:) - y;
    loss_GD(i,1) = norm(res(:))^2;
    A_star=reshape(A'*res,[n1,n1,n3]);
    Ft = Ft- mu * tprod(A_star,Ft);
end



%% spectral ini

Y = A'*y;
Y = reshape(Y,[n1,n2,n3]);
[U,S,~] = tsvd_r(Y,k);
S1 = fft(S,[],3);
S1 = S1.^0.5;
S = ifft(S1,[],3);

Ft = tprod(U(:,1:k,:),S(1:k,1:k,:));

Xt=tprod(Ft,tran(Ft));
norm(Xt(:)-X_star(:))




for i=1:ite

    Xt = tprod(Ft,tran(Ft));
    error_GD(i,2)=norm(X_star-Xt,'fro')^2/norm(X_star,'fro')^2;

    res = A * Xt(:) - y;
    loss_GD(i,2) = norm(res(:))^2;
    A_star=reshape(A'*res,[n1,n1,n3]);
    Ft = Ft- mu * tprod(A_star,Ft);
end


end




