function MF_rule_te = FCM_te(X_te, ex_w, V, distance_type)
%% =================== 输入检查 ===================
if nargin < 4, distance_type = 1; end
if distance_type ~= 1
    error('FCM_te: 仅支持 distance_type=1 (平方欧氏距离)');
end

[n_te, d] = size(X_te);
No_C = size(V, 1);

if ~isa(V, class(X_te))
    V = cast(V, 'like', X_te);
end

if isa(X_te, 'single')
    eps0 = eps('single');
else
    eps0 = eps('double');
end


x2 = sum(X_te.^2, 2);           
v2 = sum(V.^2, 2)';              
dist2 = x2 + v2 - 2 * (X_te * V'); 
dist2 = max(dist2, eps0);         

expo = -1 / (ex_w - 1);
W = dist2 .^ expo;
U = W ./ (sum(W, 2) + eps0);    

zeroMask = dist2 <= eps0;
hasZero = any(zeroMask, 2);

if any(hasZero)
    if isa(hasZero, 'gpuArray')
        hasZero = gather(hasZero);
        zeroMask = gather(zeroMask);
    end
    
    idx = find(hasZero);
    for i = 1:numel(idx)
        row = idx(i);
        col = find(zeroMask(row, :), 1, 'first');
        U(row, :) = 0;
        U(row, col) = 1;
    end
end

MF_rule_te = U;
end