
function [Y_mat, Y_mat_te, PI, E_PI, SSC, Entropy] = ...
    serial_eval_combinations(X, Y, X_te, Y_te, input_m, num_comb, in, setup, fourier_params)

    data_num = size(X, 1);
    data_num_te = size(X_te, 1);
    
    Y_mat = zeros(data_num, num_comb);
    Y_mat_te = zeros(data_num_te, num_comb);
    PI = zeros(1, num_comb);
    E_PI = zeros(1, num_comb);
    SSC = zeros(1, num_comb);
    Entropy = zeros(1, num_comb);
    
    for k = 1:num_comb
        result = eval_single_combination(...
            X, Y, X_te, Y_te, input_m(k, :), in, setup, fourier_params);
        
        Y_mat(:, k) = result.Y_out;
        Y_mat_te(:, k) = result.Y_out_te;
        PI(k) = result.pi_val;
        E_PI(k) = result.e_pi_val;
        SSC(k) = result.ssc_val;
        Entropy(k) = result.entropy_val;
        
        if mod(k, 100) == 0
            fprintf('.');
        end
    end
    
    if num_comb > 100
        fprintf('\n');
    end
end
