function [L,R] = spectral_ini(Y,k)
[n1,n2,n3] = size(Y);
tubal_r = k;
X = fft(Y,[],3);
U = zeros(n1,tubal_r,n3);
S = zeros(tubal_r,tubal_r,n3);
V = zeros(n2,tubal_r,n3);
S_hat = zeros(tubal_r,tubal_r,n3);

% i=1 
[U(:,:,1),S(:,:,1),V(:,:,1)] = svds(Y(:,:,1),tubal_r);
S_hat(:,:,1) = sqrt(S(:,:,1));

halfn3 = round(n3/2);
for i = 2 : halfn3
    [U(:,:,i),S(:,:,i),V(:,:,i)] = svds(X(:,:,i),tubal_r);
    S_hat(:,:,i) = sqrt(S(:,:,i));
    U(:,:,n3+2-i) = conj(U(:,:,i));
    V(:,:,n3+2-i) = conj(V(:,:,i));
    S(:,:,n3+2-i) = S(:,:,i);
    S_hat(:,:,n3+2-i) = sqrt(S_hat(:,:,i));
end    
% if n3 is even
if mod(n3,2) == 0
    i = halfn3+1;
    [U(:,:,i),S(:,:,i),V(:,:,i)] = svds(X(:,:,i),tubal_r);
    S_hat(:,:,i) = sqrt(S(:,:,i));
end

U = ifft(U,[],3);
S_hat = ifft(S_hat,[],3);
V = ifft(V,[],3);


L = tprod(U,S_hat);
R = tprod(V,S_hat);

 
end