function g = get_grad(a_list,pred_theta_list,x,x0)
n = length(a_list);
g = zeros([1 n]);
g(1) = (a_list(1)+1)*x(1) -a_list(1) * pred_theta_list(1) - x0/2 - x(2)/2;
for i = 2:(n-1)
    g(i) = (a_list(i)+1)*x(i) -a_list(i) * pred_theta_list(i) - x(i-1)/2 - x(i+1)/2;
end
g(n) = (a_list(n)+1/2)*x(n) -a_list(n) * pred_theta_list(n) - x(n-1)/2; 