/* @(#)z_atan2.c 1.0 98/08/13 */ /* FUNCTION <>, <>---arc tangent of y/x INDEX atan2 INDEX atan2f ANSI_SYNOPSIS #include double atan2(double <[y]>,double <[x]>); float atan2f(float <[y]>,float <[x]>); TRAD_SYNOPSIS #include double atan2(<[y]>,<[x]>); double <[y]>; double <[x]>; float atan2f(<[y]>,<[x]>); float <[y]>; float <[x]>; DESCRIPTION <> computes the inverse tangent (arc tangent) of <[y]>/<[x]>. <> produces the correct result even for angles near @ifinfo pi/2 or -pi/2 @end ifinfo @tex $\pi/2$ or $-\pi/2$ @end tex (that is, when <[x]> is near 0). <> is identical to <>, save that it takes and returns <>. RETURNS <> and <> return a value in radians, in the range of @ifinfo -pi to pi. @end ifinfo @tex $-\pi$ to $\pi$. @end tex If both <[x]> and <[y]> are 0.0, <> causes a <> error. You can modify error handling for these functions using <>. PORTABILITY <> is ANSI C. <> is an extension. */ /****************************************************************** * Arctangent2 * * Input: * v, u - floating point values * * Output: * arctan2 of v / u * * Description: * This routine returns the arctan2 of v / u. * *****************************************************************/ #include "fdlibm.h" #include "zmath.h" #ifndef _DOUBLE_IS_32BITS double _DEFUN (atan2, (double, double), double v _AND double u) { return (atangent (0.0, v, u, 1)); } #endif /* _DOUBLE_IS_32BITS */