function y = gramactcor(s_pre,sx_pre,sxp_pre,flag,flag2)
s_pre = s_pre + 10^(-10);
sx_pre = sx_pre + 10^(-10);
sxp_pre = sxp_pre + 10^(-10);
if flag2 == 1
    if flag == 1
       c1 = sqrt(sx_pre);
       c2 = sqrt(sxp_pre);
       lambda = s_pre./(c1*c2');
       lambda(lambda > 1) = 1;
       lambda(lambda < -1) = -1;
       y = ((c1*c2')/(2*pi)).*(lambda.*(pi - acos(lambda)) + sqrt(1 - lambda.^2)); 
    end
    if flag == 2
        y = (2/pi)*asin( s_pre./(sqrt((sx_pre + 0.5)*(sxp_pre + 0.5)))); %todo
    end
end
if flag2 == 2
     if flag == 1
       c1 = sqrt(sx_pre);
       c2 = sqrt(sxp_pre);
       lambda = s_pre./(c1*c2');
       lambda(lambda > 1) = 1;
       lambda(lambda < -1) = -1;
       y = (pi - acos(lambda))/(2*pi);
    end
    if flag == 2
        y = (4/pi)*( 1/( sqrt( (1+ 2*sx_pre).*(1+2*sxp_pre) - 4*s_pre.^2) )); %todo
    end    
end
end
