/* * asin(arg) and acos(arg) return the arcsin, arccos, * respectively of their arguments. * * Arctan is called after appropriate range reduction. */ #include #include double math·asin(double arg) { double temp; int sign; sign = 0; if(arg < 0) { arg = -arg; sign++; } if(arg > 1) return math·NaN(); temp = math·sqrt(1 - arg*arg); if(arg > 0.7) temp = math·PIO2 - math·atan(temp/arg); else temp = math·atan(arg/temp); if(sign) temp = -temp; return temp; } double math·acos(double arg) { if(arg > 1 || arg < -1) return math·NaN(); return math·PIO2 - math·asin(arg); }