123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778 |
- #if defined(LIBM_SCCS) && !defined(lint)
- static char rcsid[] = "$NetBSD: s_tan.c,v 1.7 1995/05/10 20:48:18 jtc Exp $";
- #endif
- #include "math.h"
- #include "math_private.h"
- libm_hidden_proto(tan)
- #ifdef __STDC__
- double tan(double x)
- #else
- double tan(x)
- double x;
- #endif
- {
- double y[2],z=0.0;
- int32_t n, ix;
-
- GET_HIGH_WORD(ix,x);
-
- ix &= 0x7fffffff;
- if(ix <= 0x3fe921fb) return __kernel_tan(x,z,1);
-
- else if (ix>=0x7ff00000) return x-x;
-
- else {
- n = __ieee754_rem_pio2(x,y);
- return __kernel_tan(y[0],y[1],1-((n&1)<<1));
- }
- }
- libm_hidden_def(tan)
|