function invX = tpinv(X)

% tpinv(X) is the moore-Penrose inverse of the tensor X of size n*n*n3.


[n1,n2,n3] = size(X);
if n1 ~= n2
    error('Error using tinv. Tensor must be square.');
end

X = fft(X,[],3);
invX = zeros(n1,n2,n3);
I = eye(n1);
% first frontal slice
invX(:,:,1) = pinv(X(:,:,1));
% i=2,...,halfn3
halfn3 = round(n3/2);
for i = 2 : halfn3
    invX(:,:,i) = pinv(X(:,:,i));
    invX(:,:,n3+2-i) = conj(invX(:,:,i));
end
% if n3 is even
if mod(n3,2) == 0
    i = halfn3+1;
    invX(:,:,i) = pinv(X(:,:,i));
end
invX = ifft(invX,[],3);

