function Y_out = FFPNN_predict(X, MF_rule, coeff, omega, V)

[N, d] = size(X);
No_C = size(MF_rule, 2);

den = sum(MF_rule, 2);
den(den < eps) = eps;
beta = MF_rule ./ den;  

Y_out = zeros(N, H, 'like', X);

for j = 1:No_C

    y_j = repmat(reshape(coeff3(1, j, :), 1, H), N, 1);


    for m = 1:d
        x_shifted = X(:, m) - V(j, m);        
        c = cos(omega(j,m) * x_shifted);   
        w = reshape(coeff3(1+m, j, :), 1, H); 
        y_j = y_j + c * w;                    
    end

    Y_out = Y_out + beta(:, j) .* y_j;      
end

end


