function g = get_partial_derivative(a_list,pred_theta_list,x,x0,index)
n = length(a_list);
x_bound = 1e6;
left_ind = max(1,index - 1);
right_ind = min(n,index +1);
if min(x(left_ind:right_ind)) <= -x_bound
    display("Wrong input, some entry not computed yet!");
end

if index ==1
    g = a_list(1) * (x(1) - pred_theta_list(1)) + (x(1) - x0)/2 + (x(1) - x(2))/2;
else if index == n
        g = a_list(n) * (x(n) - pred_theta_list(n)) + (x(n) - x(n-1))/2 ;
    else
        g = a_list(index) * (x(index) - pred_theta_list(index)) + (x(index) - x(index-1))/2 + (x(index) - x(index+1))/2;
    end
end

    
