

function x = prox_lp(a,alpha)
beta = 1;
% min_x 0.5 alpha ||x-a||_2^2 + beta ||x||_{0.5}^0.5
% min_x ||x-a||_2^2 + beta / (0.5 alpha) ||x||_{0.5}^0.5
x = prox_lp_closed_form(a,beta/ (0.5*alpha));


function x = prox_lp_closed_form(a,lambda)
% min_x sum_i^n   lambda*|x(i)|^0.5 + |x(i)-a(i)|^2;
ths = (54^(1/3))/4 * (lambda)^(2/3);
fi =  acos((abs(a)/3).^(-1.5).*lambda./8);
fi = real(fi);
x = (2/3).*a.*(1+cos(2*pi/3-(2/3).*fi));
x(abs(a)<=ths)=0;


