function [coeff, omega] = reg_Fourier(X, Y, MF_rule, V, setup, fourier_params)

[N, d] = size(X);
No_C = size(MF_rule, 2);

if isvector(Y), Y = Y(:); end
H = size(Y, 2);

MF_sum = sum(MF_rule, 2);
MF_sum(MF_sum < eps) = eps;
beta = MF_rule ./ MF_sum;    

k_min = fourier_params.k_range(1);
k_max = fourier_params.k_range(2);

omega = zeros(No_C, d, 'like', X);
sigma_floor = 1e-6;

for j = 1:No_C

    mu_j = sum(beta(:,j) .* X, 1);                      % [1 x d]
    diff_j = X - mu_j;
    sigma_j = sqrt(sum(beta(:,j) .* diff_j.^2, 1));     % [1 x d]
    sigma_j(sigma_j < sigma_floor) = sigma_floor;

    k_j = k_min + (k_max - k_min) * rand(1, d, 'like', X);


    sigma_bar = mean(sigma_j);
    omega_j = k_j .* (sigma_bar ./ (sigma_j + sigma_floor));


    omega_j = min(max(omega_j, k_min), 4 * k_max);
    omega(j,:) = omega_j;
end


terms_per_rule = 1 + d;
M = No_C * terms_per_rule;
Phi_mat = zeros(N, M, 'like', X);

for j = 1:No_C
    col_start = (j-1) * terms_per_rule + 1;
     Phi_mat(:, col_start) = beta(:, j);
    
   for m = 1:d
        x_shifted = X(:, m) - V(j, m);
        Phi_mat(:, col_start + m) = beta(:, j) .* cos(omega(j,m) * x_shifted);
    end
end


lambda = max(setup.L, 1e-12);

A = Phi_mat' * Phi_mat + lambda * eye(M, 'like', Phi_mat); 
b = Phi_mat' * Y;                                            

[RR, p] = chol(A);
if p == 0
    alpha = RR \ (RR' \ b);
else
    alpha = A \ b;
end
coeff = reshape(alpha, terms_per_rule, No_C, H);

end