Update.
[kopensolaris-gnu/glibc.git] / math / test-math.c
1 #include <stdio.h>
2 #include <math.h>
3 #include <stdlib.h>
4 #include <errno.h>
5 #include <string.h>
6
7 void print_trig_stuff __P ((void));
8
9 int
10 main (int argc, char *argv[])
11 {
12   const char str[] = "123.456";
13   double x,h,li,lr,a,lrr;
14
15   if (signbit (argc < 1 ? -0.0 : 0.0))
16     /* I don't make this an error for now.  --drepper */
17     fputs ("\n*** Your compiler has a bug.  Consider upgrading\n\n", stderr);
18
19   x = atof (str);
20
21   printf ("%g %g\n", x, pow (10.0, 3.0));
22
23   x = sinh(2.0);
24
25   printf("sinh(2.0) = %g\n", x);
26
27   x = sinh(3.0);
28
29   printf("sinh(3.0) = %g\n", x);
30
31   h = hypot(2.0,3.0);
32
33   printf("h=%g\n", h);
34
35   a = atan2(3.0, 2.0);
36
37   printf("atan2(3,2) = %g\n", a);
38
39   lr = pow(h,4.0);
40
41   printf("pow(%g,4.0) = %g\n", h, lr);
42
43   lrr = lr;
44
45   li = 4.0 * a;
46
47   lr = lr / exp(a*5.0);
48
49   printf("%g / exp(%g * 5) = %g\n", lrr, a, lr);
50
51   lrr = li;
52
53   li += 5.0 * log(h);
54
55   printf("%g + 5*log(%g) = %g\n", lrr, h, li);
56
57   printf("cos(%g) = %g,  sin(%g) = %g\n", li, cos(li), li, sin(li));
58
59   x = drem(10.3435,6.2831852);
60
61   printf("drem(10.3435,6.2831852) = %g\n", x);
62
63   x = drem(-10.3435,6.2831852);
64
65   printf("drem(-10.3435,6.2831852) = %g\n", x);
66
67   x = drem(-10.3435,-6.2831852);
68
69   printf("drem(-10.3435,-6.2831852) = %g\n", x);
70
71   x = drem(10.3435,-6.2831852);
72
73   printf("drem(10.3435,-6.2831852) = %g\n", x);
74
75
76   printf("x%8.6gx\n", .5);
77   printf("x%-8.6gx\n", .5);
78   printf("x%6.6gx\n", .5);
79
80   {
81     double x = atof ("-1e-17-");
82     printf ("%g %c= %g %s!\n",
83             x,
84             x == -1e-17 ? '=' : '!',
85             -1e-17,
86             x == -1e-17 ? "Worked" : "Failed");
87   }
88
89   print_trig_stuff ();
90
91   return 0;
92 }
93 \f
94
95 const double RAD[5] = { 0, M_PI/2, M_PI, (3*M_PI)/2, 2*M_PI };
96
97 #define PRINT_IT_1_ARG(_func, _arg, _value) \
98     (_value) = (_func) ((_arg)); \
99     if (errno) { \
100       errno = 0; \
101       printf ("%s = ERROR %s\n", #_func, strerror (errno)); \
102     } else \
103       printf ("%s(%g) = %g\n", #_func, _arg, (_value)); \
104
105 #define PRINT_IT_2_ARG(_func, _arg1, _arg2, _value) \
106     (_value) = (_func) ((_arg1),(_arg2)); \
107     if (errno) { \
108       errno = 0; \
109       printf ("%s = ERROR %s\n", #_func, strerror (errno)); \
110     } else \
111       printf ("%s(%g, %g) = %g\n", #_func, _arg1, _arg2, (_value)); \
112
113 void
114 print_trig_stuff(void)
115 {
116   double value, arg1, arg2;
117   int i;
118
119   puts ("\n\nMath Test");
120
121   errno = 0;                    /* automatically reset on error condition */
122   for (i=0; i<4; i++)
123     {
124       PRINT_IT_1_ARG (sin, RAD[i], value);
125       PRINT_IT_1_ARG (cos, RAD[i], value);
126       PRINT_IT_1_ARG (tan, RAD[i], value);
127       PRINT_IT_1_ARG (asin, RAD[i], value);
128       PRINT_IT_1_ARG (acos, RAD[i], value);
129       PRINT_IT_1_ARG (atan, RAD[i], value);
130       PRINT_IT_2_ARG (atan2, RAD[i], -RAD[i % 4], value);
131     }
132
133   arg1 = 16;
134   arg2 = 3;
135   PRINT_IT_1_ARG (exp, arg1, value);
136   PRINT_IT_1_ARG (log, arg1, value);
137   PRINT_IT_1_ARG (log10, arg1, value);
138   PRINT_IT_2_ARG (pow, arg1, arg2, value);
139   PRINT_IT_1_ARG (sqrt, arg1, value);
140   PRINT_IT_1_ARG (cbrt, arg1, value);
141   PRINT_IT_2_ARG (hypot, arg1, arg2, value);
142   PRINT_IT_1_ARG (expm1, arg1, value);
143   PRINT_IT_1_ARG (log1p, arg1, value);
144   PRINT_IT_1_ARG (sinh, arg1, value);
145   PRINT_IT_1_ARG (cosh, arg1, value);
146   PRINT_IT_1_ARG (tanh, arg1, value);
147   PRINT_IT_1_ARG (asinh, arg1, value);
148   PRINT_IT_1_ARG (acosh, arg1, value);
149   PRINT_IT_1_ARG (atanh, arg1, value);
150 }