function smin = min_singular(X, opt)
% tminsingval_fftS  给出 fft(S,[],3) 的最小奇异值（标量）。
% 
% [smin, smin_each] = tminsingval_fftS(X, opt)
%   X   : n1 x n2 x n3 张量
%   opt : 传给你现有的 tsvd(X,opt) 的选项（'full' | 'econ' | 'skinny'），默认 'econ'
%
% 输出：
%   smin      : 所有频率片奇异值中的总体最小值（标量）
%   smin_each : 每个频率片的最小奇异值（n3 x 1），便于你检查或画图
%
% 说明：
%   根据你的 tsvd 实现，S 是 “f-对角” 张量：其在频域（fft 第3维）上每个切片都是对角矩阵，
%   对角线上元素就是该频率片的奇异值。因此对 fft(S,[],3) 逐片取 diag 再取 min 即可。

    if nargin < 2
        opt = 'econ';
    end

    % 调用你现有的 tsvd（返回的是时域的 U,S,V）
    [~, S, ~] = tsvd(X, opt);

    % 回到频域：此时每个切片 S_hat(:,:,f) 都应为对角矩阵（数值上可能有极小的非零）
    S_hat = fft(S, [], 3);

    n3 = size(S_hat, 3);
    smin_each = inf(n3, 1);

    for f = 1:n3
        % 取对角线（奇异值应为实非负；数值误差下取实部并下限到 0）
        d = real(diag(S_hat(:,:,f)));
        d(d < 0 & abs(d) < 1e-12) = 0;  % 数值护栏：极小负值视为 0
        if isempty(d)
            smin_each(f) = inf;       % 防御：空对角（不太会发生）
        else
            smin_each(f) = min(d);
        end
    end

    smin = min(smin_each);
end
