function beta = AdaptivePenaltyUpdateRule(beta,beta0,e,xi,iter)
% assert: iter >= 1


% Adaptive quadratic Rule
varthe = beta0*xi*xi/(1+xi);
beta = beta + min(beta*xi,varthe*(2*iter+1)+e);

% varthe = xi*beta0 / (sqrt(2)-1);
% beta = beta0 + varthe*sqrt(iter);


% Adaptive sqrt(k) Rule
% varthe = xi*beta0 / (sqrt(2)-1);
% beta = beta + min(xi*beta, varthe*(sqrt(iter+1)-sqrt(iter))+e);