function U_perp = torthc(U)
% U: n1 x r x n3   (来自 t-SVD 的正交张量: tran(U)*U = I_r)
% 返回 U_perp: n1 x (n1-r) x n3，满足 tran(U)*U_perp ≈ 0 且 [U, U_perp] 正交

[n1, r, n3] = size(U);
assert(r <= n1, '列数 r 不能超过 n1');
if r == n1
    U_perp = zeros(n1,0,n3);  % 无正交补
    return;
end

Uhat = fft(U, [], 3);
Uperp_hat = complex(zeros(n1, n1-r, n3));

half = floor(n3/2) + 1;           % 频域独立片的上半部（含 DC 与 Nyquist）
hasNyq = mod(n3,2) == 0;          % 偶数长度时有 Nyquist 片

for f = 1:half
    Uf = Uhat(:,:,f);             % n1 x r
    % 补成 n1 维正交基：对 [Uf, 随机] 做 QR
    [Q,~] = qr([Uf, randn(n1, n1-r)], 0);  % Q: n1 x n1
    Uperp_hat(:,:,f) = Q(:, r+1:end);      % 后 n1-r 列作为正交补

    if f == 1 || (hasNyq && f == half)     % DC 或 Nyquist 频率：应为实
        Uperp_hat(:,:,f) = real(Uperp_hat(:,:,f));
    end
end

% 用共轭对称填充下半部频率片
for f = 2:half - hasNyq
    Uperp_hat(:,:,n3 - f + 2) = conj(Uperp_hat(:,:,f));
end

U_perp = ifft(Uperp_hat, [], 3, 'symmetric');
end
