function [s,sd] = act(s_pre,sx_pre,sxp_pre,flag)
if flag == 1
   c1 = sqrt(sx_pre);
   c2 = sqrt(sxp_pre);
   lambda = s_pre/(c1*c2);
   if lambda > 1
       lambda = 1;
   end
   if lambda < -1
       lambda = -1;
   end
   s = (c1*c2/(2*pi))*(lambda*(pi - acos(lambda)) + sqrt(1 - lambda^2)); 
   sd = (pi - acos(lambda))/(2*pi);
end
if flag == 2
    s = (2/pi)*asin( s_pre/(sqrt((sx_pre + 0.5)*(sxp_pre + 0.5))));
    sd = (4/pi)*( 1/( sqrt( (1+ 2*sx_pre)*(1+2*sxp_pre) - 4*s_pre^2) ));
end

