summaryrefslogtreecommitdiff
path: root/math
diff options
context:
space:
mode:
Diffstat (limited to 'math')
-rw-r--r--math/complex.h2
-rw-r--r--math/libm-test.c108
-rw-r--r--math/test-math.c6
-rw-r--r--math/tgmath.h6
4 files changed, 99 insertions, 23 deletions
diff --git a/math/complex.h b/math/complex.h
index fe4c4ce545..f4b1d4640c 100644
--- a/math/complex.h
+++ b/math/complex.h
@@ -38,7 +38,7 @@ __BEGIN_DECLS
/* Narrowest imaginary unit. This depends on the floating-point
evaluation method.
XXX This probably has to go into a gcc related file. */
-#define _Imaginary_I (1.0iF)
+#define _Complex_I (1.0iF)
/* Another more descriptive name is `I'. */
#undef I
diff --git a/math/libm-test.c b/math/libm-test.c
index c80ed7d261..c77cbee855 100644
--- a/math/libm-test.c
+++ b/math/libm-test.c
@@ -856,6 +856,8 @@ asin_test (void)
#endif
check ("asin (0) == 0", FUNC(asin) (0), 0);
+ check ("asin (0.5) == pi/6", FUNC(asin) (0.5), M_PI_6);
+ check ("asin (1.0) == pi/2", FUNC(asin) (1.0), M_PI_2);
}
@@ -2297,6 +2299,7 @@ sqrt_test (void)
x = random_value (0, 10000);
check_ext ("sqrt (x*x) == x", FUNC(sqrt) (x*x), x, x);
check ("sqrt (4) == 2", FUNC(sqrt) (4), 2);
+ check ("sqrt (0.25) == 0.5", FUNC(sqrt) (0.25), 0.5);
}
@@ -4638,16 +4641,16 @@ lrint_test (void)
the rounding method and test the critical cases. So far, only
unproblematic numbers are tested. */
- check_long ("lrint(0) = 0", lrint (0.0), 0);
- check_long ("lrint(-0) = 0", lrint (minus_zero), 0);
- check_long ("lrint(0.2) = 0", lrint (0.2), 0);
- check_long ("lrint(-0.2) = 0", lrint (-0.2), 0);
+ check_long ("lrint(0) = 0", FUNC(lrint) (0.0), 0);
+ check_long ("lrint(-0) = 0", FUNC(lrint) (minus_zero), 0);
+ check_long ("lrint(0.2) = 0", FUNC(lrint) (0.2), 0);
+ check_long ("lrint(-0.2) = 0", FUNC(lrint) (-0.2), 0);
- check_long ("lrint(1.4) = 1", lrint (1.4), 1);
- check_long ("lrint(-1.4) = -1", lrint (-1.4), -1);
+ check_long ("lrint(1.4) = 1", FUNC(lrint) (1.4), 1);
+ check_long ("lrint(-1.4) = -1", FUNC(lrint) (-1.4), -1);
- check_long ("lrint(8388600.3) = 8388600", lrint (8388600.3), 8388600);
- check_long ("lrint(-8388600.3) = -8388600", lrint (-8388600.3),
+ check_long ("lrint(8388600.3) = 8388600", FUNC(lrint) (8388600.3), 8388600);
+ check_long ("lrint(-8388600.3) = -8388600", FUNC(lrint) (-8388600.3),
-8388600);
}
@@ -4659,18 +4662,50 @@ llrint_test (void)
the rounding method and test the critical cases. So far, only
unproblematic numbers are tested. */
- check_longlong ("llrint(0) = 0", llrint (0.0), 0);
- check_longlong ("llrint(-0) = 0", llrint (minus_zero), 0);
- check_longlong ("llrint(0.2) = 0", llrint (0.2), 0);
- check_longlong ("llrint(-0.2) = 0", llrint (-0.2), 0);
+ check_longlong ("llrint(0) = 0", FUNC(llrint) (0.0), 0);
+ check_longlong ("llrint(-0) = 0", FUNC(llrint) (minus_zero), 0);
+ check_longlong ("llrint(0.2) = 0", FUNC(llrint) (0.2), 0);
+ check_longlong ("llrint(-0.2) = 0", FUNC(llrint) (-0.2), 0);
- check_longlong ("llrint(1.4) = 1", llrint (1.4), 1);
- check_longlong ("llrint(-1.4) = -1", llrint (-1.4), -1);
+ check_longlong ("llrint(1.4) = 1", FUNC(llrint) (1.4), 1);
+ check_longlong ("llrint(-1.4) = -1", FUNC(llrint) (-1.4), -1);
- check_longlong ("llrint(8388600.3) = 8388600", llrint (8388600.3),
+ check_longlong ("llrint(8388600.3) = 8388600", FUNC(llrint) (8388600.3),
8388600);
- check_longlong ("llrint(-8388600.3) = -8388600", llrint (-8388600.3),
+ check_longlong ("llrint(-8388600.3) = -8388600", FUNC(llrint) (-8388600.3),
-8388600);
+
+ /* Test boundary conditions. */
+ /* 0x1FFFFF */
+ check_longlong ("llrint(2097151.0) = 2097151", FUNC(llrint) (2097151.0),
+ 2097151LL);
+ /* 0x800000 */
+ check_longlong ("llrint(8388608.0) = 8388608", FUNC(llrint) (8388608.0),
+ 8388608LL);
+ /* 0x1000000 */
+ check_longlong ("llrint(16777216.0) = 16777216",
+ FUNC(llrint) (16777216.0), 16777216LL);
+ /* 0x20000000000 */
+ check_longlong ("llrint(2199023255552.0) = 2199023255552",
+ FUNC(llrint) (2199023255552.0), 2199023255552LL);
+ /* 0x40000000000 */
+ check_longlong ("llrint(4398046511104.0) = 4398046511104",
+ FUNC(llrint) (4398046511104.0), 4398046511104LL);
+ /* 0x10000000000000 */
+ check_longlong ("llrint(4503599627370496.0) = 4503599627370496",
+ FUNC(llrint) (4503599627370496.0), 4503599627370496LL);
+ /* 0x10000080000000 */
+ check_longlong ("llrint(4503601774854144.0) = 4503601774854144",
+ FUNC(llrint) (4503601774854144.0), 4503601774854144LL);
+ /* 0x20000000000000 */
+ check_longlong ("llrint(9007199254740992.0) = 9007199254740992",
+ FUNC(llrint) (9007199254740992.0), 9007199254740992LL);
+ /* 0x80000000000000 */
+ check_longlong ("llrint(36028797018963968.0) = 36028797018963968",
+ FUNC(llrint) (36028797018963968.0), 36028797018963968LL);
+ /* 0x100000000000000 */
+ check_longlong ("llrint(72057594037927936.0) = 72057594037927936",
+ FUNC(llrint) (72057594037927936.0), 72057594037927936LL);
}
@@ -4705,8 +4740,8 @@ lround_test (void)
check_long ("lround(-0.8) = -1", FUNC(lround) (-0.8), -1);
check_long ("lround(1.5) = 2", FUNC(lround) (1.5), 2);
check_long ("lround(-1.5) = -2", FUNC(lround) (-1.5), -2);
- check_long ("lround(22514.5) = 22514", FUNC(lround) (1.5), 2);
- check_long ("lround(-22514.5) = -22514", FUNC(lround) (-1.5), -2);
+ check_long ("lround(22514.5) = 22515", FUNC(lround) (22514.5), 22515);
+ check_long ("lround(-22514.5) = -22515", FUNC(lround) (-22514.5), -22515);
#ifndef TEST_FLOAT
check_long ("lround(2097152.5) = 2097153", FUNC(lround) (2097152.5),
2097153);
@@ -4729,8 +4764,9 @@ llround_test (void)
check_longlong ("llround(-0.8) = -1", FUNC(llround) (-0.8), -1);
check_longlong ("llround(1.5) = 2", FUNC(llround) (1.5), 2);
check_longlong ("llround(-1.5) = -2", FUNC(llround) (-1.5), -2);
- check_longlong ("llround(22514.5) = 22514", FUNC(llround) (1.5), 2);
- check_longlong ("llround(-22514.5) = -22514", FUNC(llround) (-1.5), -2);
+ check_longlong ("llround(22514.5) = 22515", FUNC(llround) (22514.5), 22515);
+ check_longlong ("llround(-22514.5) = -22515", FUNC(llround) (-22514.5),
+ -22515);
#ifndef TEST_FLOAT
check_longlong ("llround(2097152.5) = 2097153",
FUNC(llround) (2097152.5), 2097153);
@@ -4741,6 +4777,38 @@ llround_test (void)
check_longlong ("llround(-34359738368.5) = -34359738369",
FUNC(llround) (-34359738368.5), -34359738369ll);
#endif
+
+ /* Test boundary conditions. */
+ /* 0x1FFFFF */
+ check_longlong ("llround(2097151.0) = 2097151", FUNC(llround) (2097151.0),
+ 2097151LL);
+ /* 0x800000 */
+ check_longlong ("llround(8388608.0) = 8388608", FUNC(llround) (8388608.0),
+ 8388608LL);
+ /* 0x1000000 */
+ check_longlong ("llround(16777216.0) = 16777216",
+ FUNC(llround) (16777216.0), 16777216LL);
+ /* 0x20000000000 */
+ check_longlong ("llround(2199023255552.0) = 2199023255552",
+ FUNC(llround) (2199023255552.0), 2199023255552LL);
+ /* 0x40000000000 */
+ check_longlong ("llround(4398046511104.0) = 4398046511104",
+ FUNC(llround) (4398046511104.0), 4398046511104LL);
+ /* 0x10000000000000 */
+ check_longlong ("llround(4503599627370496.0) = 4503599627370496",
+ FUNC(llround) (4503599627370496.0), 4503599627370496LL);
+ /* 0x10000080000000 */
+ check_longlong ("llrint(4503601774854144.0) = 4503601774854144",
+ FUNC(llrint) (4503601774854144.0), 4503601774854144LL);
+ /* 0x20000000000000 */
+ check_longlong ("llround(9007199254740992.0) = 9007199254740992",
+ FUNC(llround) (9007199254740992.0), 9007199254740992LL);
+ /* 0x80000000000000 */
+ check_longlong ("llround(36028797018963968.0) = 36028797018963968",
+ FUNC(llround) (36028797018963968.0), 36028797018963968LL);
+ /* 0x100000000000000 */
+ check_longlong ("llround(72057594037927936.0) = 72057594037927936",
+ FUNC(llround) (72057594037927936.0), 72057594037927936LL);
}
diff --git a/math/test-math.c b/math/test-math.c
index aa5aeaaafd..edd82a3d1e 100644
--- a/math/test-math.c
+++ b/math/test-math.c
@@ -7,11 +7,15 @@
void print_trig_stuff __P ((void));
int
-main (void)
+main (int argc, char *argv[])
{
const char str[] = "123.456";
double x,h,li,lr,a,lrr;
+ if (signbit (argc < 1 ? -0.0 : 0.0))
+ /* I don't make this an error for now. --drepper */
+ fputs ("\n*** Your compiler has a bug. Consider upgrading\n\n", stderr);
+
x = atof (str);
printf ("%g %g\n", x, pow (10.0, 3.0));
diff --git a/math/tgmath.h b/math/tgmath.h
index 4c7d957b37..b0ce202d35 100644
--- a/math/tgmath.h
+++ b/math/tgmath.h
@@ -167,7 +167,11 @@
#define log(Val) __TGMATH_UNARY_REAL_IMAG (Val, log, clog)
/* Base-ten logarithm of X. */
-#define log10(Val) __TGMATH_UNARY_REAL_IMAG (Val, log10, __clog10)
+#ifdef __USE_GNU
+# define log10(Val) __TGMATH_UNARY_REAL_IMAG (Val, log10, __clog10)
+#else
+# define log10(Val) __TGMATH_UNARY_REAL_ONLY (Val, log10)
+#endif
/* Return exp(X) - 1. */
#define expm1(Val) __TGMATH_UNARY_REAL_ONLY (Val, expm1)