From: Bruno Haible Date: Fri, 30 Mar 2007 00:21:34 +0000 (+0000) Subject: Tests for module 'ldexpl'. X-Git-Tag: cvs-readonly~628 X-Git-Url: http://erislabs.org.uk/gitweb/?a=commitdiff_plain;h=7fda7e7c8c8596d22343980cdfbdd7f3968cfbd3;p=gnulib.git Tests for module 'ldexpl'. --- diff --git a/ChangeLog b/ChangeLog index 70487b307..b0bb7a757 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,5 +1,10 @@ 2007-03-29 Bruno Haible + * modules/ldexpl-tests: New file. + * tests/test-ldexpl.c: New file. + +2007-03-29 Bruno Haible + * lib/ldexpl.c: Include fpucw.h. (ldexpl): Use BEGIN/END_LONG_DOUBLE_ROUNDING. Skip the last unneeded multiplication. diff --git a/modules/ldexpl-tests b/modules/ldexpl-tests new file mode 100644 index 000000000..3b5efba48 --- /dev/null +++ b/modules/ldexpl-tests @@ -0,0 +1,15 @@ +Files: +tests/test-ldexpl.c + +Depends-on: +fpucw +isnanl-nolibm + +configure.ac: + +Makefile.am: +TESTS += test-ldexpl +check_PROGRAMS += test-ldexpl + +License: +LGPL diff --git a/tests/test-ldexpl.c b/tests/test-ldexpl.c new file mode 100644 index 000000000..bc1aeae60 --- /dev/null +++ b/tests/test-ldexpl.c @@ -0,0 +1,113 @@ +/* Test of multiplying a 'long double' by a power of 2. + Copyright (C) 2007 Free Software Foundation, Inc. + + This program is free software; you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation; either version 2, or (at your option) + any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program; if not, write to the Free Software Foundation, + Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ + +/* Written by Bruno Haible , 2007. */ + +#include + +#include + +#include +#include + +#include "fpucw.h" +#include "isnanl-nolibm.h" + +#define ASSERT(expr) if (!(expr)) abort (); + +int +main () +{ + int i; + long double x; + long double y; + DECL_LONG_DOUBLE_ROUNDING + + BEGIN_LONG_DOUBLE_ROUNDING (); + + { /* NaN. */ + x = 0.0L / 0.0L; + y = ldexpl (x, 0); ASSERT (isnanl (y)); + y = ldexpl (x, 5); ASSERT (isnanl (y)); + y = ldexpl (x, -5); ASSERT (isnanl (y)); + } + + { /* Positive infinity. */ + x = 1.0L / 0.0L; + y = ldexpl (x, 0); ASSERT (y == x); + y = ldexpl (x, 5); ASSERT (y == x); + y = ldexpl (x, -5); ASSERT (y == x); + } + + { /* Negative infinity. */ + x = -1.0L / 0.0L; + y = ldexpl (x, 0); ASSERT (y == x); + y = ldexpl (x, 5); ASSERT (y == x); + y = ldexpl (x, -5); ASSERT (y == x); + } + + { /* Positive zero. */ + x = 0.0L; + y = ldexpl (x, 0); ASSERT (y == x); + y = ldexpl (x, 5); ASSERT (y == x); + y = ldexpl (x, -5); ASSERT (y == x); + } + + { /* Negative zero. */ + x = -0.0L; + y = ldexpl (x, 0); ASSERT (y == x); + y = ldexpl (x, 5); ASSERT (y == x); + y = ldexpl (x, -5); ASSERT (y == x); + } + + { /* Positive finite number. */ + x = 1.73205L; + y = ldexpl (x, 0); ASSERT (y == x); + y = ldexpl (x, 5); ASSERT (y == x * 32.0L); + y = ldexpl (x, -5); ASSERT (y == x * 0.03125L); + } + + { /* Negative finite number. */ + x = -20.085536923187667742L; + y = ldexpl (x, 0); ASSERT (y == x); + y = ldexpl (x, 5); ASSERT (y == x * 32.0L); + y = ldexpl (x, -5); ASSERT (y == x * 0.03125L); + } + + for (i = 1, x = 1.73205L; i <= LDBL_MAX_EXP; i++, x *= 2.0L) + { + y = ldexpl (x, 0); ASSERT (y == x); + y = ldexpl (x, 5); ASSERT (y == x * 32.0L); + y = ldexpl (x, -5); ASSERT (y == x * 0.03125L); + } + for (i = 1, x = 1.73205L; i >= LDBL_MIN_EXP; i--, x *= 0.5L) + { + y = ldexpl (x, 0); ASSERT (y == x); + y = ldexpl (x, 5); ASSERT (y == x * 32.0L); + if (i - 5 >= LDBL_MIN_EXP) + { + y = ldexpl (x, -5); ASSERT (y == x * 0.03125L); + } + } + for (; i >= LDBL_MIN_EXP - 100 && x > 0.0L; i--, x *= 0.5L) + { + y = ldexpl (x, 0); ASSERT (y == x); + y = ldexpl (x, 5); ASSERT (y == x * 32.0L); + } + + return 0; +}