ack/lang/basic/lib/atn.c

69 lines
1.3 KiB
C
Raw Normal View History

1984-11-29 14:22:02 +00:00
/*
* (c) copyright 1988 by the Vrije Universiteit, Amsterdam, The Netherlands.
* See the copyright notice in the ACK home directory, in the file "Copyright".
1984-11-29 14:22:02 +00:00
*
* Author: Ceriel J.H. Jacobs
1984-11-29 14:22:02 +00:00
*/
1985-01-21 12:47:04 +00:00
/* $Header$ */
1984-11-29 14:22:02 +00:00
1988-07-25 11:40:57 +00:00
#define __NO_DEFS
#include <math.h>
1984-11-29 14:22:02 +00:00
double
_atn(x)
double x;
{
1989-06-19 15:56:30 +00:00
/* Algorithm and coefficients from:
"Software manual for the elementary functions"
by W.J. Cody and W. Waite, Prentice-Hall, 1980
*/
1984-11-29 14:22:02 +00:00
1989-06-19 15:56:30 +00:00
static double p[] = {
-0.13688768894191926929e+2,
-0.20505855195861651981e+2,
-0.84946240351320683534e+1,
-0.83758299368150059274e+0
};
1989-06-19 15:56:30 +00:00
static double q[] = {
0.41066306682575781263e+2,
0.86157349597130242515e+2,
0.59578436142597344465e+2,
0.15024001160028576121e+2,
1.0
};
static double a[] = {
0.0,
0.52359877559829887307710723554658381, /* pi/6 */
M_PI_2,
1.04719755119659774615421446109316763 /* pi/3 */
};
1984-11-29 14:22:02 +00:00
1989-06-19 15:56:30 +00:00
int neg = x < 0;
int n;
double g;
1984-11-29 14:22:02 +00:00
1989-06-19 15:56:30 +00:00
if (neg) {
x = -x;
}
1989-06-19 15:56:30 +00:00
if (x > 1.0) {
x = 1.0/x;
n = 2;
}
1989-06-19 15:56:30 +00:00
else n = 0;
1984-11-29 14:22:02 +00:00
1989-06-19 15:56:30 +00:00
if (x > 0.26794919243112270647) { /* 2-sqtr(3) */
n = n + 1;
x = (((0.73205080756887729353*x-0.5)-0.5)+x)/
(1.73205080756887729353+x);
}
1989-06-19 15:56:30 +00:00
/* ??? avoid underflow ??? */
g = x * x;
x += x * g * POLYNOM3(g, p) / POLYNOM4(g, q);
if (n > 1) x = -x;
x += a[n];
return neg ? -x : x;
1984-11-29 14:22:02 +00:00
}