annotate tests/test-expm1-ieee.h @ 17907:0a1c2535cad9

euidaccess: Fix Android build * modules/euidaccess (Depends-on): Add fcntl-h to ensure that AT_EACCESS gets declared.
author Kevin Cernekee <cernekee@google.com>
date Wed, 11 Feb 2015 15:22:54 -0800
parents ab58d4870664
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
16589
338bc8a6f860 Tests for module 'expm1-ieee'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
1 /* Test of expm1*() function family.
17848
ab58d4870664 version-etc: new year
Paul Eggert <eggert@cs.ucla.edu>
parents: 17587
diff changeset
2 Copyright (C) 2012-2015 Free Software Foundation, Inc.
16589
338bc8a6f860 Tests for module 'expm1-ieee'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
3
338bc8a6f860 Tests for module 'expm1-ieee'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
4 This program is free software: you can redistribute it and/or modify
338bc8a6f860 Tests for module 'expm1-ieee'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
5 it under the terms of the GNU General Public License as published by
338bc8a6f860 Tests for module 'expm1-ieee'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
6 the Free Software Foundation; either version 3 of the License, or
338bc8a6f860 Tests for module 'expm1-ieee'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
7 (at your option) any later version.
338bc8a6f860 Tests for module 'expm1-ieee'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
8
338bc8a6f860 Tests for module 'expm1-ieee'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
9 This program is distributed in the hope that it will be useful,
338bc8a6f860 Tests for module 'expm1-ieee'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
10 but WITHOUT ANY WARRANTY; without even the implied warranty of
338bc8a6f860 Tests for module 'expm1-ieee'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
338bc8a6f860 Tests for module 'expm1-ieee'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
12 GNU General Public License for more details.
338bc8a6f860 Tests for module 'expm1-ieee'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
13
338bc8a6f860 Tests for module 'expm1-ieee'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
14 You should have received a copy of the GNU General Public License
338bc8a6f860 Tests for module 'expm1-ieee'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
15 along with this program. If not, see <http://www.gnu.org/licenses/>. */
338bc8a6f860 Tests for module 'expm1-ieee'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
16
338bc8a6f860 Tests for module 'expm1-ieee'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
17 static void
338bc8a6f860 Tests for module 'expm1-ieee'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
18 test_function (void)
338bc8a6f860 Tests for module 'expm1-ieee'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
19 {
338bc8a6f860 Tests for module 'expm1-ieee'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
20 /* [MX] shaded specification in POSIX. */
338bc8a6f860 Tests for module 'expm1-ieee'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
21
338bc8a6f860 Tests for module 'expm1-ieee'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
22 /* Underflow. */
338bc8a6f860 Tests for module 'expm1-ieee'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
23 ASSERT (EXPM1 (-100000.0) == - L_(1.0));
338bc8a6f860 Tests for module 'expm1-ieee'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
24
338bc8a6f860 Tests for module 'expm1-ieee'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
25 /* NaN. */
338bc8a6f860 Tests for module 'expm1-ieee'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
26 ASSERT (ISNAN (EXPM1 (NAN)));
338bc8a6f860 Tests for module 'expm1-ieee'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
27
338bc8a6f860 Tests for module 'expm1-ieee'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
28 /* Zero. */
338bc8a6f860 Tests for module 'expm1-ieee'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
29 {
338bc8a6f860 Tests for module 'expm1-ieee'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
30 DOUBLE z = EXPM1 (L_(0.0));
338bc8a6f860 Tests for module 'expm1-ieee'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
31 ASSERT (z == L_(0.0));
338bc8a6f860 Tests for module 'expm1-ieee'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
32 ASSERT (!signbit (z));
338bc8a6f860 Tests for module 'expm1-ieee'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
33 }
338bc8a6f860 Tests for module 'expm1-ieee'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
34 {
338bc8a6f860 Tests for module 'expm1-ieee'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
35 DOUBLE z = EXPM1 (MINUS_ZERO);
338bc8a6f860 Tests for module 'expm1-ieee'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
36 ASSERT (z == L_(0.0));
338bc8a6f860 Tests for module 'expm1-ieee'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
37 ASSERT (!!signbit (z) == !!signbit (MINUS_ZERO));
338bc8a6f860 Tests for module 'expm1-ieee'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
38 }
338bc8a6f860 Tests for module 'expm1-ieee'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
39
338bc8a6f860 Tests for module 'expm1-ieee'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
40 /* Infinity. */
338bc8a6f860 Tests for module 'expm1-ieee'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
41 ASSERT (EXPM1 (- INFINITY) == - L_(1.0));
338bc8a6f860 Tests for module 'expm1-ieee'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
42 ASSERT (EXPM1 (INFINITY) == INFINITY);
338bc8a6f860 Tests for module 'expm1-ieee'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
43 }