
function [regrets_track, arm_track] = gp_ucb(B,f_test,kernel,T,lambda,epsilon,R,max_value, options)
   
        data_mean = options(1);
        data_stdv = options(2);
        
        [~, arms] = size(f_test(1,:));
        %[max_value,max_arm] = max(f_test);
        %kernel_t = kernel;
        mu_t = zeros(arms,1); sigma_t = zeros(arms,1);
        mu_t2 = zeros(arms,1); sigma2_t2 = zeros(arms,1);
        
        regrets_cumula = 0;
        regrets_track = zeros(T,1);

        rewards_cumula = 0;
        rewards_track = zeros(T,1);
        
        arm_track = zeros(T,1);
        y_track = zeros(T,1);
        
        num_func = size(B,1);
        iter_func = 0;
        

        
        for t = 1 : T
                
                iter_func = iter_func+1;
            
                gamma_t =  log(t);  % x_t only 1 dimension
                
                beta_t = B(iter_func)+   R/sqrt(lambda) *sqrt(2*gamma_t + 2);   %%%?
                if t == 1
                    arm_t = randi(arms);
                else
                    [~,arm_t] = max( mu_t2 +  beta_t*sqrt(sigma2_t2) );
                end
                arm_track(t) = arm_t;
                
%                 rewards_cumula = rewards_cumula + f_test(iter_func,arm_t);
%                 rewards_track(t) = rewards_cumula;
%                                
                
                regrets_cumula = regrets_cumula + (max_value(iter_func) - f_test(iter_func,arm_t))*data_stdv;
                regrets_track(t) = regrets_cumula;

                noise = randn;  %sub-gaussian  normal 
                %y_t = f_test(iter_func,arm_t) + epsilon* noise;
                
                y_t = f_test(iter_func,arm_t) + epsilon* noise; %epsilon*noise;

                y_track(t) = y_t;
               
                
                y1t = y_track(1:t);
                
                ktx = zeros(t, arms);
                Kt = zeros(t, t);
                for i = 1 : t
                    ktx(i, :) = kernel(arm_track(i),:);
                    for j = 1 : t
                        Kt(i,j) = kernel(arm_track(i), arm_track(j));
                    end
                end
                
                
                inverse_K = inv(Kt + lambda*eye(t));
                for k = 1 : arms
                    mu_t2 (k) = transpose( ktx(:, k) ) * inverse_K * y1t;
                    sigma2_t2(k) = kernel(k,k) - transpose( ktx(:, k) )* inverse_K * ktx(:, k);
                end
                
                
%                 L = chol(Kt + lambda*eye(t));
%                 alpha = L' \ (L\y1t);
%                 mu_t = transpose(ktx) * alpha;
% 
%                 v = L \ ktx;
%                 sigma_t = diag(kernel - v'*v);
% 
%                 
%                 all(abs(mu_t-mu_t2) < 0.1)
%                 all(abs(sigma_t-sigma2_t2) < 0.1)
        end
        
end

    

