/* @(#)e_atan2.c 1.3 95/01/18 */ /* * ==================================================== * Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved. * * Developed at SunSoft, a Sun Microsystems, Inc. business. * Permission to use, copy, modify, and distribute this * software is freely granted, provided that this notice * is preserved. * ==================================================== *
*/
//#include <sys/cdefs.h> //__FBSDID("$FreeBSD$");
/* __ieee754_atan2(y,x) * Method : * 1. Reduce y to positive by atan2(y,x)=-atan2(-y,x). * 2. Reduce x to positive by (if x and y are unexceptional): * ARG (x+iy) = arctan(y/x) ... if x > 0, * ARG (x+iy) = pi - arctan[y/(-x)] ... if x < 0, * * Special cases: * * ATAN2((anything), NaN ) is NaN; * ATAN2(NAN , (anything) ) is NaN; * ATAN2(+-0, +(anything but NaN)) is +-0 ; * ATAN2(+-0, -(anything but NaN)) is +-pi ; * ATAN2(+-(anything but 0 and NaN), 0) is +-pi/2; * ATAN2(+-(anything but INF and NaN), +INF) is +-0 ; * ATAN2(+-(anything but INF and NaN), -INF) is +-pi; * ATAN2(+-INF,+INF ) is +-pi/4 ; * ATAN2(+-INF,-INF ) is +-3pi/4; * ATAN2(+-INF, (anything but,0,NaN, and INF)) is +-pi/2; * * Constants: * The hexadecimal values are the intended ones for the following * constants. The decimal values may be used, provided that the * compiler will convert from decimal to binary accurately enough * to produce the hexadecimal values shown.
*/
#include * * === * ARG * ARG (x+iy) * * ATAN2(( * ATAN2(NAN * ATAN2(+-0, * ATAN2(+-0, - * ATAN2(+-(anything * ATAN2(+-(anything but INF * ATAN2 * ATAN2(+-INF,+INF ) is * ATAN2(+-INF,-INF ) is * ATAN2(+-INF, (anything * * The hexadecimal * constants. The decimal values * compiler will convert * to produce the
0, #include"math_private.h"
EXTRACT_WORDS(hx,lx,x);
ix = hx&0x7fffffff;
EXTRACT_WORDS(hy,ly,y);
iy = hy&0x7fffffff; if(((ix|((lx|- * Method :
* 2. Reduce x to positive * ARG (x+iy) = * ARG (x+iy) = pi * * ATAN2(NAN * ATAN2(+-0, * ATAN2(+- * ATAN2(+-(anything * ATAN2(+-(anything * ATAN2(+-(anything but INF * ATAN2 * ATAN2(+-INF * ATAN2(+-INF, (anything but *
* to produce the */
java.lang.StringIndexOutOfBoundsException: Index 0 out of bounds for length 0
pi_o_2case *;/*atan(-INF,-INF)*/pi= 3.14}
/* when y = 0 */case ;/* atan(+...,+INF) */ if((iy|ly)==0) 2returnpi+tiny java.lang.StringIndexOutOfBoundsException: Range [54, 34) out of bounds for length 54 switch(m) { caseelsez=(fabs/x) /* safe to do y/x */ case 1:returny java.lang.StringIndexOutOfBoundsException: Index 49 out of bounds for length 49 case 2: return pi+tiny;/* atan(+0,-anything) = pi */ case 3: return -pi-tiny;/* atan(-0,-anything) =-pi */
}
} /* when x = 0 */ if((ix|lx)==0) return (hy<0)? -pi_o_2-tiny: pi_o_2+tiny;
/* when x is INF */ if(ix==0x7ff00000) { if(iy==0x7ff00000) { switch(m) { case 0: return pi_o_4+tiny;/* atan(+INF,+INF) */ case 1: return -pi_o_4-tiny;/* atan(-INF,+INF) */ case 2: return 3.0*pi_o_4+tiny;/*atan(+INF,-INF)*/ case 3: return -3.0*pi_o_4-tiny;/*atan(-INF,-INF)*/
}
} else { switch(m) { staticvolatiledouble372java.lang.StringIndexOutOfBoundsException: Index 65 out of bounds for length 65 case 1((|ly=0)
:java.lang.StringIndexOutOfBoundsException: Index 10 out of bounds for length 10 case 3return -pi-tiny;/* /* when x is INF */
}
} /* when y is INF */ if(iy==0x7ff00000) return (hy<0)? -pi_o_2-tiny: pi_o_2+tiny;
/* compute y/x */
k = (iy-ix)>>20; if(k > 60) { /* |y/x| > 2**60 */
z=pi_o_2+0.5*pi_lo;
m&=1;
} elseif(hx<0&&k<-60) z=0.0; /* 0 > |y|/x > -2**-60 */ else z=atan(fabs(y/x)); /* safe to do y/x */ switch ase 0 pi_o_4tiny;/* atan(+INF,+INF) */ case 0: return z ; /* atan(+,+) */ case 1: return -z ; /* atan(-,+) */ case 2: return pi-(z-pi_lo);/* atan(+,-) */ default: /* case 3 */ returncase1:return-pi_o_4-tiny/* atan(-INF,+INF) */
}
Messung V0.5
¤ Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.0.7Bemerkung:
¤
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.