]> git.ipfire.org Git - thirdparty/glibc.git/blame - math/libm-test.inc
i386: Fail at configure time for i386 builds.
[thirdparty/glibc.git] / math / libm-test.inc
CommitLineData
568035b7 1/* Copyright (C) 1997-2013 Free Software Foundation, Inc.
8847214f 2 This file is part of the GNU C Library.
18394a08 3 Contributed by Andreas Jaeger <aj@suse.de>, 1997.
8847214f
UD
4
5 The GNU C Library is free software; you can redistribute it and/or
41bdb6e2
AJ
6 modify it under the terms of the GNU Lesser General Public
7 License as published by the Free Software Foundation; either
8 version 2.1 of the License, or (at your option) any later version.
8847214f
UD
9
10 The GNU C Library is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
41bdb6e2 13 Lesser General Public License for more details.
8847214f 14
41bdb6e2 15 You should have received a copy of the GNU Lesser General Public
59ba27a6
PE
16 License along with the GNU C Library; if not, see
17 <http://www.gnu.org/licenses/>. */
8847214f
UD
18
19/* Part of testsuite for libm.
20
21 This file is processed by a perl script. The resulting file has to
22 be included by a master file that defines:
23
f964490f 24 Macros:
8847214f
UD
25 FUNC(function): converts general function name (like cos) to
26 name with correct suffix (e.g. cosl or cosf)
27 MATHCONST(x): like FUNC but for constants (e.g convert 0.0 to 0.0L)
28 FLOAT: floating point type to test
29 - TEST_MSG: informal message to be displayed
30 CHOOSE(Clongdouble,Cdouble,Cfloat,Cinlinelongdouble,Cinlinedouble,Cinlinefloat):
31 chooses one of the parameters as delta for testing
32 equality
33 PRINTF_EXPR Floating point conversion specification to print a variable
34 of type FLOAT with printf. PRINTF_EXPR just contains
35 the specifier, not the percent and width arguments,
36 e.g. "f".
37 PRINTF_XEXPR Like PRINTF_EXPR, but print in hexadecimal format.
38 PRINTF_NEXPR Like PRINTF_EXPR, but print nice. */
39
40/* This testsuite has currently tests for:
41 acos, acosh, asin, asinh, atan, atan2, atanh,
42 cbrt, ceil, copysign, cos, cosh, erf, erfc, exp, exp10, exp2, expm1,
ef1bb361 43 fabs, fdim, finite, floor, fma, fmax, fmin, fmod, fpclassify,
8847214f 44 frexp, gamma, hypot,
57267616 45 ilogb, isfinite, isinf, isnan, isnormal, issignaling,
0e8e0c1c 46 isless, islessequal, isgreater, isgreaterequal, islessgreater, isunordered,
8847214f
UD
47 j0, j1, jn,
48 ldexp, lgamma, log, log10, log1p, log2, logb,
28234b07 49 modf, nearbyint, nextafter, nexttoward,
8847214f
UD
50 pow, remainder, remquo, rint, lrint, llrint,
51 round, lround, llround,
52 scalb, scalbn, scalbln, signbit, sin, sincos, sinh, sqrt, tan, tanh, tgamma, trunc,
e9c7764e 53 y0, y1, yn, significand
8847214f
UD
54
55 and for the following complex math functions:
56 cabs, cacos, cacosh, carg, casin, casinh, catan, catanh,
28234b07
JM
57 ccos, ccosh, cexp, cimag, clog, clog10, conj, cpow, cproj, creal,
58 csin, csinh, csqrt, ctan, ctanh.
8847214f 59
28234b07
JM
60 At the moment the following functions and macros aren't tested:
61 drem (alias for remainder),
28234b07
JM
62 lgamma_r,
63 nan,
64 pow10 (alias for exp10).
8847214f
UD
65
66 Parameter handling is primitive in the moment:
67 --verbose=[0..3] for different levels of output:
68 0: only error count
69 1: basic report on failed tests (default)
70 2: full report on all tests
71 -v for full output (equals --verbose=3)
72 -u for generation of an ULPs file
73 */
74
75/* "Philosophy":
76
77 This suite tests some aspects of the correct implementation of
78 mathematical functions in libm. Some simple, specific parameters
79 are tested for correctness but there's no exhaustive
80 testing. Handling of specific inputs (e.g. infinity, not-a-number)
81 is also tested. Correct handling of exceptions is checked
82 against. These implemented tests should check all cases that are
ec751a23 83 specified in ISO C99.
8847214f 84
80bad0cc
JM
85 Exception testing: At the moment only divide-by-zero, invalid,
86 overflow and underflow exceptions are tested. Inexact exceptions
8847214f
UD
87 aren't checked at the moment.
88
89 NaN values: There exist signalling and quiet NaNs. This implementation
57267616
TS
90 only uses quiet NaN as parameter. Where the sign of a NaN is
91 significant, this is not tested. The payload of NaNs is not examined.
8847214f
UD
92
93 Inline functions: Inlining functions should give an improvement in
94 speed - but not in precission. The inlined functions return
95 reasonable values for a reasonable range of input values. The
96 result is not necessarily correct for all values and exceptions are
97 not correctly raised in all cases. Problematic input and return
98 values are infinity, not-a-number and minus zero. This suite
99 therefore does not check these specific inputs and the exception
100 handling for inlined mathematical functions - just the "reasonable"
101 values are checked.
102
103 Beware: The tests might fail for any of the following reasons:
104 - Tests are wrong
105 - Functions are wrong
106 - Floating Point Unit not working properly
107 - Compiler has errors
108
109 With e.g. gcc 2.7.2.2 the test for cexp fails because of a compiler error.
33996419
AJ
110
111
112 To Do: All parameter should be numbers that can be represented as
2550dfe9
AJ
113 exact floating point values. Currently some values cannot be
114 represented exactly and therefore the result is not the expected
115 result. For this we will use 36 digits so that numbers can be
116 represented exactly. */
8847214f
UD
117
118#ifndef _GNU_SOURCE
119# define _GNU_SOURCE
120#endif
121
122#include "libm-test-ulps.h"
123#include <complex.h>
124#include <math.h>
125#include <float.h>
126#include <fenv.h>
601d2942 127#include <limits.h>
8847214f
UD
128
129#include <errno.h>
130#include <stdlib.h>
131#include <stdio.h>
bdf09fab 132#include <string.h>
8847214f 133#include <argp.h>
ef82f4da 134#include <tininess.h>
8847214f 135
0af797de
CM
136/* Allow platforms without all rounding modes to test properly,
137 assuming they provide an __FE_UNDEFINED in <bits/fenv.h> which
138 causes fesetround() to return failure. */
139#ifndef FE_TONEAREST
140# define FE_TONEAREST __FE_UNDEFINED
141#endif
142#ifndef FE_TOWARDZERO
143# define FE_TOWARDZERO __FE_UNDEFINED
144#endif
145#ifndef FE_UPWARD
146# define FE_UPWARD __FE_UNDEFINED
147#endif
148#ifndef FE_DOWNWARD
149# define FE_DOWNWARD __FE_UNDEFINED
150#endif
151
8847214f
UD
152/* Possible exceptions */
153#define NO_EXCEPTION 0x0
154#define INVALID_EXCEPTION 0x1
155#define DIVIDE_BY_ZERO_EXCEPTION 0x2
c135cc1b 156#define OVERFLOW_EXCEPTION 0x4
80bad0cc 157#define UNDERFLOW_EXCEPTION 0x8
8847214f 158/* The next flags signals that those exceptions are allowed but not required. */
80bad0cc
JM
159#define INVALID_EXCEPTION_OK 0x10
160#define DIVIDE_BY_ZERO_EXCEPTION_OK 0x20
161#define OVERFLOW_EXCEPTION_OK 0x40
162#define UNDERFLOW_EXCEPTION_OK 0x80
8847214f 163#define EXCEPTIONS_OK INVALID_EXCEPTION_OK+DIVIDE_BY_ZERO_EXCEPTION_OK
80bad0cc
JM
164/* Some special test flags, passed together with exceptions. */
165#define IGNORE_ZERO_INF_SIGN 0x100
166
167/* Values underflowing only for float. */
168#ifdef TEST_FLOAT
169# define UNDERFLOW_EXCEPTION_FLOAT UNDERFLOW_EXCEPTION
170# define UNDERFLOW_EXCEPTION_OK_FLOAT UNDERFLOW_EXCEPTION_OK
171#else
172# define UNDERFLOW_EXCEPTION_FLOAT 0
173# define UNDERFLOW_EXCEPTION_OK_FLOAT 0
174#endif
175/* Values underflowing only for double or types with a larger least
176 positive normal value. */
177#if defined TEST_FLOAT || defined TEST_DOUBLE \
178 || (defined TEST_LDOUBLE && LDBL_MIN_EXP >= DBL_MIN_EXP)
179# define UNDERFLOW_EXCEPTION_DOUBLE UNDERFLOW_EXCEPTION
ccc8cadf 180# define UNDERFLOW_EXCEPTION_OK_DOUBLE UNDERFLOW_EXCEPTION_OK
80bad0cc
JM
181#else
182# define UNDERFLOW_EXCEPTION_DOUBLE 0
ccc8cadf 183# define UNDERFLOW_EXCEPTION_OK_DOUBLE 0
80bad0cc
JM
184#endif
185/* Values underflowing only for IBM long double or types with a larger least
186 positive normal value. */
187#if defined TEST_FLOAT || (defined TEST_LDOUBLE && LDBL_MIN_EXP > DBL_MIN_EXP)
188# define UNDERFLOW_EXCEPTION_LDOUBLE_IBM UNDERFLOW_EXCEPTION
189#else
190# define UNDERFLOW_EXCEPTION_LDOUBLE_IBM 0
191#endif
ef82f4da
JM
192/* Values underflowing on architectures detecting tininess before
193 rounding, but not on those detecting tininess after rounding. */
194#define UNDERFLOW_EXCEPTION_BEFORE_ROUNDING (TININESS_AFTER_ROUNDING \
195 ? 0 \
196 : UNDERFLOW_EXCEPTION)
8847214f
UD
197
198/* Various constants (we must supply them precalculated for accuracy). */
42be70d4
UD
199#define M_PI_6l .52359877559829887307710723054658383L
200#define M_E2l 7.389056098930650227230427460575008L
201#define M_E3l 20.085536923187667740928529654581719L
202#define M_2_SQRT_PIl 3.5449077018110320545963349666822903L /* 2 sqrt (M_PIl) */
203#define M_SQRT_PIl 1.7724538509055160272981674833411451L /* sqrt (M_PIl) */
3c6cad26
UD
204#define M_LOG_SQRT_PIl 0.57236494292470008707171367567652933L /* log(sqrt(M_PIl)) */
205#define M_LOG_2_SQRT_PIl 1.265512123484645396488945797134706L /* log(2*sqrt(M_PIl)) */
8847214f
UD
206#define M_PI_34l (M_PIl - M_PI_4l) /* 3*pi/4 */
207#define M_PI_34_LOG10El (M_PIl - M_PI_4l) * M_LOG10El
208#define M_PI2_LOG10El M_PI_2l * M_LOG10El
209#define M_PI4_LOG10El M_PI_4l * M_LOG10El
210#define M_PI_LOG10El M_PIl * M_LOG10El
72c7a71d 211#define M_SQRT_2_2 0.70710678118654752440084436210484903L /* sqrt (2) / 2 */
8847214f
UD
212
213static FILE *ulps_file; /* File to document difference. */
214static int output_ulps; /* Should ulps printed? */
215
216static int noErrors; /* number of errors */
217static int noTests; /* number of tests (without testing exceptions) */
218static int noExcTests; /* number of tests for exception flags */
219static int noXFails; /* number of expected failures. */
220static int noXPasses; /* number of unexpected passes. */
221
222static int verbose;
223static int output_max_error; /* Should the maximal errors printed? */
224static int output_points; /* Should the single function results printed? */
cd33623e 225static int ignore_max_ulp; /* Should we ignore max_ulp? */
8847214f
UD
226
227static FLOAT minus_zero, plus_zero;
67e971f1 228static FLOAT plus_infty, minus_infty, qnan_value, max_value, min_value;
bec749fd 229static FLOAT min_subnorm_value;
8847214f 230
6815fabc 231static FLOAT max_error, real_max_error, imag_max_error;
8847214f
UD
232
233
234#define BUILD_COMPLEX(real, imag) \
235 ({ __complex__ FLOAT __retval; \
236 __real__ __retval = (real); \
237 __imag__ __retval = (imag); \
238 __retval; })
239
6815fabc
UD
240#define BUILD_COMPLEX_INT(real, imag) \
241 ({ __complex__ int __retval; \
242 __real__ __retval = (real); \
243 __imag__ __retval = (imag); \
244 __retval; })
245
8847214f
UD
246
247#define MANT_DIG CHOOSE ((LDBL_MANT_DIG-1), (DBL_MANT_DIG-1), (FLT_MANT_DIG-1), \
bf582445 248 (LDBL_MANT_DIG-1), (DBL_MANT_DIG-1), (FLT_MANT_DIG-1))
8847214f
UD
249
250static void
251init_max_error (void)
252{
253 max_error = 0;
6815fabc
UD
254 real_max_error = 0;
255 imag_max_error = 0;
aaca11d8 256 feclearexcept (FE_ALL_EXCEPT);
8847214f
UD
257}
258
259static void
6815fabc 260set_max_error (FLOAT current, FLOAT *curr_max_error)
8847214f 261{
6815fabc
UD
262 if (current > *curr_max_error)
263 *curr_max_error = current;
8847214f
UD
264}
265
266
57267616
TS
267/* Print a FLOAT. */
268static void
269print_float (FLOAT f)
270{
271 /* As printf doesn't differ between a sNaN and a qNaN, do this manually. */
272 if (issignaling (f))
273 printf ("sNaN\n");
274 else if (isnan (f))
275 printf ("qNaN\n");
276 else
277 printf ("% .20" PRINTF_EXPR " % .20" PRINTF_XEXPR "\n", f, f);
278}
279
8847214f
UD
280/* Should the message print to screen? This depends on the verbose flag,
281 and the test status. */
282static int
283print_screen (int ok, int xfail)
284{
285 if (output_points
286 && (verbose > 1
15daa639 287 || (verbose == 1 && ok == xfail)))
8847214f
UD
288 return 1;
289 return 0;
290}
291
292
293/* Should the message print to screen? This depends on the verbose flag,
294 and the test status. */
295static int
296print_screen_max_error (int ok, int xfail)
297{
298 if (output_max_error
299 && (verbose > 1
300 || ((verbose == 1) && (ok == xfail))))
301 return 1;
302 return 0;
303}
304
305/* Update statistic counters. */
306static void
307update_stats (int ok, int xfail)
308{
309 ++noTests;
310 if (ok && xfail)
311 ++noXPasses;
312 else if (!ok && xfail)
313 ++noXFails;
314 else if (!ok && !xfail)
315 ++noErrors;
316}
317
318static void
319print_ulps (const char *test_name, FLOAT ulp)
320{
321 if (output_ulps)
322 {
323 fprintf (ulps_file, "Test \"%s\":\n", test_name);
303f1335 324 fprintf (ulps_file, "%s: %.0" PRINTF_NEXPR "\n",
8847214f 325 CHOOSE("ldouble", "double", "float",
303f1335
AS
326 "ildouble", "idouble", "ifloat"),
327 FUNC(ceil) (ulp));
8847214f
UD
328 }
329}
330
331static void
332print_function_ulps (const char *function_name, FLOAT ulp)
333{
334 if (output_ulps)
335 {
6815fabc 336 fprintf (ulps_file, "Function: \"%s\":\n", function_name);
303f1335 337 fprintf (ulps_file, "%s: %.0" PRINTF_NEXPR "\n",
8847214f 338 CHOOSE("ldouble", "double", "float",
303f1335
AS
339 "ildouble", "idouble", "ifloat"),
340 FUNC(ceil) (ulp));
8847214f
UD
341 }
342}
343
344
6815fabc
UD
345static void
346print_complex_function_ulps (const char *function_name, FLOAT real_ulp,
347 FLOAT imag_ulp)
348{
349 if (output_ulps)
350 {
351 if (real_ulp != 0.0)
352 {
353 fprintf (ulps_file, "Function: Real part of \"%s\":\n", function_name);
303f1335 354 fprintf (ulps_file, "%s: %.0" PRINTF_NEXPR "\n",
6815fabc 355 CHOOSE("ldouble", "double", "float",
303f1335
AS
356 "ildouble", "idouble", "ifloat"),
357 FUNC(ceil) (real_ulp));
6815fabc
UD
358 }
359 if (imag_ulp != 0.0)
360 {
361 fprintf (ulps_file, "Function: Imaginary part of \"%s\":\n", function_name);
303f1335 362 fprintf (ulps_file, "%s: %.0" PRINTF_NEXPR "\n",
6815fabc 363 CHOOSE("ldouble", "double", "float",
303f1335
AS
364 "ildouble", "idouble", "ifloat"),
365 FUNC(ceil) (imag_ulp));
6815fabc 366 }
15daa639
UD
367
368
6815fabc
UD
369 }
370}
371
372
8847214f
UD
373
374/* Test if Floating-Point stack hasn't changed */
375static void
376fpstack_test (const char *test_name)
377{
64487e12 378#if defined (__i386__) || defined (__x86_64__)
8847214f
UD
379 static int old_stack;
380 int sw;
381
382 asm ("fnstsw" : "=a" (sw));
383 sw >>= 11;
384 sw &= 7;
385
386 if (sw != old_stack)
387 {
388 printf ("FP-Stack wrong after test %s (%d, should be %d)\n",
389 test_name, sw, old_stack);
390 ++noErrors;
391 old_stack = sw;
392 }
393#endif
394}
395
396
397static void
398print_max_error (const char *func_name, FLOAT allowed, int xfail)
399{
8847214f
UD
400 int ok = 0;
401
cd33623e 402 if (max_error == 0.0 || (max_error <= allowed && !ignore_max_ulp))
8847214f
UD
403 {
404 ok = 1;
405 }
406
407 if (!ok)
408 print_function_ulps (func_name, max_error);
409
410
411 if (print_screen_max_error (ok, xfail))
412 {
6815fabc 413 printf ("Maximal error of `%s'\n", func_name);
303f1335
AS
414 printf (" is : %.0" PRINTF_NEXPR " ulp\n", FUNC(ceil) (max_error));
415 printf (" accepted: %.0" PRINTF_NEXPR " ulp\n", FUNC(ceil) (allowed));
8847214f
UD
416 }
417
418 update_stats (ok, xfail);
419}
420
421
6815fabc
UD
422static void
423print_complex_max_error (const char *func_name, __complex__ FLOAT allowed,
424 __complex__ int xfail)
425{
426 int ok = 0;
427
303f1335
AS
428 if ((real_max_error == 0 && imag_max_error == 0)
429 || (real_max_error <= __real__ allowed
430 && imag_max_error <= __imag__ allowed
431 && !ignore_max_ulp))
6815fabc
UD
432 {
433 ok = 1;
434 }
435
436 if (!ok)
437 print_complex_function_ulps (func_name, real_max_error, imag_max_error);
438
439
440 if (print_screen_max_error (ok, xfail))
441 {
442 printf ("Maximal error of real part of: %s\n", func_name);
303f1335
AS
443 printf (" is : %.0" PRINTF_NEXPR " ulp\n",
444 FUNC(ceil) (real_max_error));
445 printf (" accepted: %.0" PRINTF_NEXPR " ulp\n",
446 FUNC(ceil) (__real__ allowed));
6815fabc 447 printf ("Maximal error of imaginary part of: %s\n", func_name);
303f1335
AS
448 printf (" is : %.0" PRINTF_NEXPR " ulp\n",
449 FUNC(ceil) (imag_max_error));
450 printf (" accepted: %.0" PRINTF_NEXPR " ulp\n",
451 FUNC(ceil) (__imag__ allowed));
6815fabc
UD
452 }
453
454 update_stats (ok, xfail);
455}
456
457
8847214f
UD
458/* Test whether a given exception was raised. */
459static void
460test_single_exception (const char *test_name,
461 int exception,
462 int exc_flag,
463 int fe_flag,
464 const char *flag_name)
465{
466#ifndef TEST_INLINE
467 int ok = 1;
468 if (exception & exc_flag)
469 {
470 if (fetestexcept (fe_flag))
471 {
472 if (print_screen (1, 0))
473 printf ("Pass: %s: Exception \"%s\" set\n", test_name, flag_name);
474 }
475 else
476 {
477 ok = 0;
478 if (print_screen (0, 0))
479 printf ("Failure: %s: Exception \"%s\" not set\n",
480 test_name, flag_name);
481 }
482 }
483 else
484 {
485 if (fetestexcept (fe_flag))
486 {
487 ok = 0;
488 if (print_screen (0, 0))
489 printf ("Failure: %s: Exception \"%s\" set\n",
490 test_name, flag_name);
491 }
492 else
493 {
494 if (print_screen (1, 0))
495 printf ("%s: Exception \"%s\" not set\n", test_name,
496 flag_name);
497 }
498 }
499 if (!ok)
500 ++noErrors;
501
502#endif
503}
504
505
506/* Test whether exceptions given by EXCEPTION are raised. Ignore thereby
507 allowed but not required exceptions.
508*/
509static void
510test_exceptions (const char *test_name, int exception)
511{
512 ++noExcTests;
513#ifdef FE_DIVBYZERO
514 if ((exception & DIVIDE_BY_ZERO_EXCEPTION_OK) == 0)
515 test_single_exception (test_name, exception,
516 DIVIDE_BY_ZERO_EXCEPTION, FE_DIVBYZERO,
517 "Divide by zero");
518#endif
519#ifdef FE_INVALID
520 if ((exception & INVALID_EXCEPTION_OK) == 0)
521 test_single_exception (test_name, exception, INVALID_EXCEPTION, FE_INVALID,
522 "Invalid operation");
c135cc1b
JM
523#endif
524#ifdef FE_OVERFLOW
525 if ((exception & OVERFLOW_EXCEPTION_OK) == 0)
526 test_single_exception (test_name, exception, OVERFLOW_EXCEPTION,
527 FE_OVERFLOW, "Overflow");
80bad0cc
JM
528#endif
529#ifdef FE_UNDERFLOW
530 if ((exception & UNDERFLOW_EXCEPTION_OK) == 0)
531 test_single_exception (test_name, exception, UNDERFLOW_EXCEPTION,
532 FE_UNDERFLOW, "Underflow");
8847214f
UD
533#endif
534 feclearexcept (FE_ALL_EXCEPT);
535}
536
537
538static void
6815fabc
UD
539check_float_internal (const char *test_name, FLOAT computed, FLOAT expected,
540 FLOAT max_ulp, int xfail, int exceptions,
541 FLOAT *curr_max_error)
8847214f
UD
542{
543 int ok = 0;
544 int print_diff = 0;
545 FLOAT diff = 0;
546 FLOAT ulp = 0;
547
548 test_exceptions (test_name, exceptions);
57267616
TS
549 if (issignaling (computed) && issignaling (expected))
550 ok = 1;
551 else if (issignaling (computed) || issignaling (expected))
552 ok = 0;
553 else if (isnan (computed) && isnan (expected))
8847214f
UD
554 ok = 1;
555 else if (isinf (computed) && isinf (expected))
556 {
557 /* Test for sign of infinities. */
ba3752d5
UD
558 if ((exceptions & IGNORE_ZERO_INF_SIGN) == 0
559 && signbit (computed) != signbit (expected))
8847214f
UD
560 {
561 ok = 0;
562 printf ("infinity has wrong sign.\n");
563 }
564 else
565 ok = 1;
566 }
57267616
TS
567 /* Don't calculate ULPs for infinities or any kind of NaNs. */
568 else if (isinf (computed) || isnan (computed)
569 || isinf (expected) || isnan (expected))
8847214f
UD
570 ok = 0;
571 else
572 {
573 diff = FUNC(fabs) (computed - expected);
e6b29af8
UD
574 switch (fpclassify (expected))
575 {
576 case FP_ZERO:
577 /* ilogb (0) isn't allowed. */
578 ulp = diff / FUNC(ldexp) (1.0, - MANT_DIG);
579 break;
580 case FP_NORMAL:
581 ulp = diff / FUNC(ldexp) (1.0, FUNC(ilogb) (expected) - MANT_DIG);
582 break;
583 case FP_SUBNORMAL:
6c23e11c
JM
584 /* 1ulp for a subnormal value, shifted by MANT_DIG, is the
585 least normal value. */
586 ulp = (FUNC(ldexp) (diff, MANT_DIG) / min_value);
e6b29af8
UD
587 break;
588 default:
589 /* It should never happen. */
590 abort ();
591 break;
592 }
6815fabc 593 set_max_error (ulp, curr_max_error);
8847214f 594 print_diff = 1;
ba3752d5
UD
595 if ((exceptions & IGNORE_ZERO_INF_SIGN) == 0
596 && computed == 0.0 && expected == 0.0
597 && signbit(computed) != signbit (expected))
3a8e65a0 598 ok = 0;
f964490f 599 else if (ulp <= 0.5 || (ulp <= max_ulp && !ignore_max_ulp))
8847214f
UD
600 ok = 1;
601 else
602 {
603 ok = 0;
604 print_ulps (test_name, ulp);
605 }
606
607 }
608 if (print_screen (ok, xfail))
609 {
610 if (!ok)
611 printf ("Failure: ");
612 printf ("Test: %s\n", test_name);
613 printf ("Result:\n");
57267616
TS
614 printf (" is: ");
615 print_float (computed);
616 printf (" should be: ");
617 print_float (expected);
8847214f
UD
618 if (print_diff)
619 {
620 printf (" difference: % .20" PRINTF_EXPR " % .20" PRINTF_XEXPR
621 "\n", diff, diff);
622 printf (" ulp : % .4" PRINTF_NEXPR "\n", ulp);
623 printf (" max.ulp : % .4" PRINTF_NEXPR "\n", max_ulp);
624 }
625 }
626 update_stats (ok, xfail);
627
628 fpstack_test (test_name);
629}
630
631
632static void
6815fabc
UD
633check_float (const char *test_name, FLOAT computed, FLOAT expected,
634 FLOAT max_ulp, int xfail, int exceptions)
635{
636 check_float_internal (test_name, computed, expected, max_ulp, xfail,
637 exceptions, &max_error);
638}
639
640
641static void
642check_complex (const char *test_name, __complex__ FLOAT computed,
643 __complex__ FLOAT expected,
644 __complex__ FLOAT max_ulp, __complex__ int xfail,
645 int exception)
8847214f 646{
6815fabc
UD
647 FLOAT part_comp, part_exp, part_max_ulp;
648 int part_xfail;
2fd89785
MS
649 char *str;
650
651 if (asprintf (&str, "Real part of: %s", test_name) == -1)
652 abort ();
8847214f 653
8847214f
UD
654 part_comp = __real__ computed;
655 part_exp = __real__ expected;
6815fabc
UD
656 part_max_ulp = __real__ max_ulp;
657 part_xfail = __real__ xfail;
15daa639 658
6815fabc
UD
659 check_float_internal (str, part_comp, part_exp, part_max_ulp, part_xfail,
660 exception, &real_max_error);
2fd89785
MS
661 free (str);
662
663 if (asprintf (&str, "Imaginary part of: %s", test_name) == -1)
664 abort ();
8847214f 665
8847214f
UD
666 part_comp = __imag__ computed;
667 part_exp = __imag__ expected;
6815fabc
UD
668 part_max_ulp = __imag__ max_ulp;
669 part_xfail = __imag__ xfail;
15daa639 670
8847214f
UD
671 /* Don't check again for exceptions, just pass through the
672 zero/inf sign test. */
6815fabc
UD
673 check_float_internal (str, part_comp, part_exp, part_max_ulp, part_xfail,
674 exception & IGNORE_ZERO_INF_SIGN,
675 &imag_max_error);
2fd89785 676 free (str);
8847214f
UD
677}
678
679
680/* Check that computed and expected values are equal (int values). */
681static void
682check_int (const char *test_name, int computed, int expected, int max_ulp,
683 int xfail, int exceptions)
684{
685 int diff = computed - expected;
686 int ok = 0;
687
688 test_exceptions (test_name, exceptions);
689 noTests++;
690 if (abs (diff) <= max_ulp)
691 ok = 1;
692
693 if (!ok)
694 print_ulps (test_name, diff);
695
696 if (print_screen (ok, xfail))
697 {
698 if (!ok)
699 printf ("Failure: ");
700 printf ("Test: %s\n", test_name);
701 printf ("Result:\n");
702 printf (" is: %d\n", computed);
703 printf (" should be: %d\n", expected);
704 }
705
706 update_stats (ok, xfail);
707 fpstack_test (test_name);
708}
709
710
711/* Check that computed and expected values are equal (long int values). */
712static void
713check_long (const char *test_name, long int computed, long int expected,
714 long int max_ulp, int xfail, int exceptions)
715{
716 long int diff = computed - expected;
717 int ok = 0;
718
719 test_exceptions (test_name, exceptions);
720 noTests++;
721 if (labs (diff) <= max_ulp)
722 ok = 1;
723
724 if (!ok)
725 print_ulps (test_name, diff);
726
727 if (print_screen (ok, xfail))
728 {
729 if (!ok)
730 printf ("Failure: ");
731 printf ("Test: %s\n", test_name);
732 printf ("Result:\n");
733 printf (" is: %ld\n", computed);
734 printf (" should be: %ld\n", expected);
735 }
736
737 update_stats (ok, xfail);
738 fpstack_test (test_name);
739}
740
741
742/* Check that computed value is true/false. */
743static void
744check_bool (const char *test_name, int computed, int expected,
745 long int max_ulp, int xfail, int exceptions)
746{
747 int ok = 0;
748
749 test_exceptions (test_name, exceptions);
750 noTests++;
751 if ((computed == 0) == (expected == 0))
752 ok = 1;
753
754 if (print_screen (ok, xfail))
755 {
756 if (!ok)
757 printf ("Failure: ");
758 printf ("Test: %s\n", test_name);
759 printf ("Result:\n");
760 printf (" is: %d\n", computed);
761 printf (" should be: %d\n", expected);
762 }
763
764 update_stats (ok, xfail);
765 fpstack_test (test_name);
766}
767
768
769/* check that computed and expected values are equal (long int values) */
770static void
771check_longlong (const char *test_name, long long int computed,
772 long long int expected,
773 long long int max_ulp, int xfail,
774 int exceptions)
775{
776 long long int diff = computed - expected;
777 int ok = 0;
778
779 test_exceptions (test_name, exceptions);
780 noTests++;
781 if (llabs (diff) <= max_ulp)
782 ok = 1;
783
784 if (!ok)
785 print_ulps (test_name, diff);
786
787 if (print_screen (ok, xfail))
788 {
789 if (!ok)
790 printf ("Failure:");
791 printf ("Test: %s\n", test_name);
792 printf ("Result:\n");
793 printf (" is: %lld\n", computed);
794 printf (" should be: %lld\n", expected);
795 }
796
797 update_stats (ok, xfail);
798 fpstack_test (test_name);
799}
800
801
802
803/* This is to prevent messages from the SVID libm emulation. */
804int
805matherr (struct exception *x __attribute__ ((unused)))
806{
807 return 1;
808}
809
810
811/****************************************************************************
812 Tests for single functions of libm.
813 Please keep them alphabetically sorted!
814****************************************************************************/
815
816static void
817acos_test (void)
818{
e6d3c4a7
AJ
819 errno = 0;
820 FUNC(acos) (0);
821 if (errno == ENOSYS)
822 /* Function not implemented. */
823 return;
824
8847214f
UD
825 START (acos);
826
67e971f1
TS
827 TEST_f_f (acos, plus_infty, qnan_value, INVALID_EXCEPTION);
828 TEST_f_f (acos, minus_infty, qnan_value, INVALID_EXCEPTION);
829 TEST_f_f (acos, qnan_value, qnan_value);
8847214f
UD
830
831 /* |x| > 1: */
67e971f1
TS
832 TEST_f_f (acos, 1.125L, qnan_value, INVALID_EXCEPTION);
833 TEST_f_f (acos, -1.125L, qnan_value, INVALID_EXCEPTION);
834 TEST_f_f (acos, max_value, qnan_value, INVALID_EXCEPTION);
835 TEST_f_f (acos, -max_value, qnan_value, INVALID_EXCEPTION);
8847214f
UD
836
837 TEST_f_f (acos, 0, M_PI_2l);
838 TEST_f_f (acos, minus_zero, M_PI_2l);
839 TEST_f_f (acos, 1, 0);
840 TEST_f_f (acos, -1, M_PIl);
841 TEST_f_f (acos, 0.5, M_PI_6l*2.0);
842 TEST_f_f (acos, -0.5, M_PI_6l*4.0);
2550dfe9 843 TEST_f_f (acos, 0.75L, 0.722734247813415611178377352641333362L);
b6550497 844 TEST_f_f (acos, 2e-17L, 1.57079632679489659923132169163975144L);
96d10bdf 845 TEST_f_f (acos, 0.0625L, 1.50825556499840522843072005474337068L);
adfbc8ac
JM
846 TEST_f_f (acos, 0x0.ffffffp0L, 3.4526698471620358760324948263873649728491e-4L);
847 TEST_f_f (acos, -0x0.ffffffp0L, 3.1412473866050770348750401337968641476999L);
848#ifndef TEST_FLOAT
849 TEST_f_f (acos, 0x0.ffffffff8p0L, 1.5258789062648029736620564947844627548516e-5L);
850 TEST_f_f (acos, -0x0.ffffffff8p0L, 3.1415773948007305904329067627145550395696L);
851 TEST_f_f (acos, 0x0.ffffffffffffp0L, 8.4293697021788088529885473244391795127130e-8L);
852 TEST_f_f (acos, -0x0.ffffffffffffp0L, 3.1415925692960962166745548533940296398054L);
853#endif
854#if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 64
855 TEST_f_f (acos, 0x0.ffffffffffffffffp0L, 3.2927225399135962333718255320079907245059e-10L);
856 TEST_f_f (acos, -0x0.ffffffffffffffffp0L, 3.1415926532605209844712837599423203309964L);
857#endif
8847214f
UD
858 END (acos);
859}
860
5ba3cc69
JM
861
862static void
863acos_test_tonearest (void)
864{
865 int save_round_mode;
866 errno = 0;
867 FUNC(acos) (0);
868 if (errno == ENOSYS)
869 /* Function not implemented. */
870 return;
871
872 START (acos_tonearest);
873
874 save_round_mode = fegetround ();
875
876 if (!fesetround (FE_TONEAREST))
877 {
878 TEST_f_f (acos, 0, M_PI_2l);
879 TEST_f_f (acos, minus_zero, M_PI_2l);
880 TEST_f_f (acos, 1, 0);
881 TEST_f_f (acos, -1, M_PIl);
882 TEST_f_f (acos, 0.5, M_PI_6l*2.0);
883 TEST_f_f (acos, -0.5, M_PI_6l*4.0);
884 }
885
886 fesetround (save_round_mode);
887
888 END (acos_tonearest);
889}
890
891
892static void
893acos_test_towardzero (void)
894{
895 int save_round_mode;
896 errno = 0;
897 FUNC(acos) (0);
898 if (errno == ENOSYS)
899 /* Function not implemented. */
900 return;
901
902 START (acos_towardzero);
903
904 save_round_mode = fegetround ();
905
906 if (!fesetround (FE_TOWARDZERO))
907 {
908 TEST_f_f (acos, 0, M_PI_2l);
909 TEST_f_f (acos, minus_zero, M_PI_2l);
910 TEST_f_f (acos, 1, 0);
911 TEST_f_f (acos, -1, M_PIl);
912 TEST_f_f (acos, 0.5, M_PI_6l*2.0);
913 TEST_f_f (acos, -0.5, M_PI_6l*4.0);
914 }
915
916 fesetround (save_round_mode);
917
918 END (acos_towardzero);
919}
920
921
922static void
923acos_test_downward (void)
924{
925 int save_round_mode;
926 errno = 0;
927 FUNC(acos) (0);
928 if (errno == ENOSYS)
929 /* Function not implemented. */
930 return;
931
932 START (acos_downward);
933
934 save_round_mode = fegetround ();
935
936 if (!fesetround (FE_DOWNWARD))
937 {
938 TEST_f_f (acos, 0, M_PI_2l);
939 TEST_f_f (acos, minus_zero, M_PI_2l);
940 TEST_f_f (acos, 1, 0);
941 TEST_f_f (acos, -1, M_PIl);
942 TEST_f_f (acos, 0.5, M_PI_6l*2.0);
943 TEST_f_f (acos, -0.5, M_PI_6l*4.0);
944 }
945
946 fesetround (save_round_mode);
947
948 END (acos_downward);
949}
950
951
952static void
953acos_test_upward (void)
954{
955 int save_round_mode;
956 errno = 0;
957 FUNC(acos) (0);
958 if (errno == ENOSYS)
959 /* Function not implemented. */
960 return;
961
962 START (acos_upward);
963
964 save_round_mode = fegetround ();
965
966 if (!fesetround (FE_UPWARD))
967 {
968 TEST_f_f (acos, 0, M_PI_2l);
969 TEST_f_f (acos, minus_zero, M_PI_2l);
970 TEST_f_f (acos, 1, 0);
971 TEST_f_f (acos, -1, M_PIl);
972 TEST_f_f (acos, 0.5, M_PI_6l*2.0);
973 TEST_f_f (acos, -0.5, M_PI_6l*4.0);
974 }
975
976 fesetround (save_round_mode);
977
978 END (acos_upward);
979}
980
8847214f
UD
981static void
982acosh_test (void)
983{
aaca11d8
UD
984 errno = 0;
985 FUNC(acosh) (7);
986 if (errno == ENOSYS)
987 /* Function not implemented. */
988 return;
989
8847214f
UD
990 START (acosh);
991
992 TEST_f_f (acosh, plus_infty, plus_infty);
67e971f1 993 TEST_f_f (acosh, minus_infty, qnan_value, INVALID_EXCEPTION);
64d063b8 994 TEST_f_f (acosh, qnan_value, qnan_value);
8847214f
UD
995
996 /* x < 1: */
67e971f1
TS
997 TEST_f_f (acosh, -1.125L, qnan_value, INVALID_EXCEPTION);
998 TEST_f_f (acosh, -max_value, qnan_value, INVALID_EXCEPTION);
8847214f
UD
999
1000 TEST_f_f (acosh, 1, 0);
2550dfe9 1001 TEST_f_f (acosh, 7, 2.63391579384963341725009269461593689L);
8847214f
UD
1002
1003 END (acosh);
1004}
1005
1006static void
1007asin_test (void)
1008{
e6d3c4a7
AJ
1009 errno = 0;
1010 FUNC(asin) (0);
1011 if (errno == ENOSYS)
1012 /* Function not implemented. */
1013 return;
8847214f
UD
1014
1015 START (asin);
1016
67e971f1
TS
1017 TEST_f_f (asin, plus_infty, qnan_value, INVALID_EXCEPTION);
1018 TEST_f_f (asin, minus_infty, qnan_value, INVALID_EXCEPTION);
1019 TEST_f_f (asin, qnan_value, qnan_value);
8847214f 1020
67e971f1
TS
1021 /* asin x == qNaN plus invalid exception for |x| > 1. */
1022 TEST_f_f (asin, 1.125L, qnan_value, INVALID_EXCEPTION);
1023 TEST_f_f (asin, -1.125L, qnan_value, INVALID_EXCEPTION);
1024 TEST_f_f (asin, max_value, qnan_value, INVALID_EXCEPTION);
1025 TEST_f_f (asin, -max_value, qnan_value, INVALID_EXCEPTION);
8847214f
UD
1026
1027 TEST_f_f (asin, 0, 0);
1028 TEST_f_f (asin, minus_zero, minus_zero);
1029 TEST_f_f (asin, 0.5, M_PI_6l);
1030 TEST_f_f (asin, -0.5, -M_PI_6l);
1031 TEST_f_f (asin, 1.0, M_PI_2l);
1032 TEST_f_f (asin, -1.0, -M_PI_2l);
2550dfe9 1033 TEST_f_f (asin, 0.75L, 0.848062078981481008052944338998418080L);
adfbc8ac
JM
1034 TEST_f_f (asin, 0x0.ffffffp0L, 1.5704510598101804156437184421571127056013L);
1035 TEST_f_f (asin, -0x0.ffffffp0L, -1.5704510598101804156437184421571127056013L);
1036#ifndef TEST_FLOAT
1037 TEST_f_f (asin, 0x0.ffffffff8p0L, 1.5707810680058339712015850710748035974710L);
1038 TEST_f_f (asin, -0x0.ffffffff8p0L, -1.5707810680058339712015850710748035974710L);
1039 TEST_f_f (asin, 0x0.ffffffffffffp0L, 1.5707962425011995974432331617542781977068L);
1040 TEST_f_f (asin, -0x0.ffffffffffffp0L, -1.5707962425011995974432331617542781977068L);
1041#endif
1042#if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 64
1043 TEST_f_f (asin, 0x0.ffffffffffffffffp0L, 1.5707963264656243652399620683025688888978L);
1044 TEST_f_f (asin, -0x0.ffffffffffffffffp0L, -1.5707963264656243652399620683025688888978L);
1045#endif
8847214f
UD
1046
1047 END (asin);
1048}
1049
5ba3cc69
JM
1050
1051static void
1052asin_test_tonearest (void)
1053{
1054 int save_round_mode;
1055 errno = 0;
1056 FUNC(asin) (0);
1057 if (errno == ENOSYS)
1058 /* Function not implemented. */
1059 return;
1060
1061 START (asin_tonearest);
1062
1063 save_round_mode = fegetround ();
1064
1065 if (!fesetround (FE_TONEAREST))
1066 {
1067 TEST_f_f (asin, 0, 0);
1068 TEST_f_f (asin, minus_zero, minus_zero);
1069 TEST_f_f (asin, 0.5, M_PI_6l);
1070 TEST_f_f (asin, -0.5, -M_PI_6l);
1071 TEST_f_f (asin, 1.0, M_PI_2l);
1072 TEST_f_f (asin, -1.0, -M_PI_2l);
1073 }
1074
1075 fesetround (save_round_mode);
1076
1077 END (asin_tonearest);
1078}
1079
1080
1081static void
1082asin_test_towardzero (void)
1083{
1084 int save_round_mode;
1085 errno = 0;
1086 FUNC(asin) (0);
1087 if (errno == ENOSYS)
1088 /* Function not implemented. */
1089 return;
1090
1091 START (asin_towardzero);
1092
1093 save_round_mode = fegetround ();
1094
1095 if (!fesetround (FE_TOWARDZERO))
1096 {
1097 TEST_f_f (asin, 0, 0);
1098 TEST_f_f (asin, minus_zero, minus_zero);
1099 TEST_f_f (asin, 0.5, M_PI_6l);
1100 TEST_f_f (asin, -0.5, -M_PI_6l);
1101 TEST_f_f (asin, 1.0, M_PI_2l);
1102 TEST_f_f (asin, -1.0, -M_PI_2l);
1103 }
1104
1105 fesetround (save_round_mode);
1106
1107 END (asin_towardzero);
1108}
1109
1110
1111static void
1112asin_test_downward (void)
1113{
1114 int save_round_mode;
1115 errno = 0;
1116 FUNC(asin) (0);
1117 if (errno == ENOSYS)
1118 /* Function not implemented. */
1119 return;
1120
1121 START (asin_downward);
1122
1123 save_round_mode = fegetround ();
1124
1125 if (!fesetround (FE_DOWNWARD))
1126 {
1127 TEST_f_f (asin, 0, 0);
1128 TEST_f_f (asin, minus_zero, minus_zero);
1129 TEST_f_f (asin, 0.5, M_PI_6l);
1130 TEST_f_f (asin, -0.5, -M_PI_6l);
1131 TEST_f_f (asin, 1.0, M_PI_2l);
1132 TEST_f_f (asin, -1.0, -M_PI_2l);
1133 }
1134
1135 fesetround (save_round_mode);
1136
1137 END (asin_downward);
1138}
1139
1140
1141static void
1142asin_test_upward (void)
1143{
1144 int save_round_mode;
1145 errno = 0;
1146 FUNC(asin) (0);
1147 if (errno == ENOSYS)
1148 /* Function not implemented. */
1149 return;
1150
1151 START (asin_upward);
1152
1153 save_round_mode = fegetround ();
1154
1155 if (!fesetround (FE_UPWARD))
1156 {
1157 TEST_f_f (asin, 0, 0);
1158 TEST_f_f (asin, minus_zero, minus_zero);
1159 TEST_f_f (asin, 0.5, M_PI_6l);
1160 TEST_f_f (asin, -0.5, -M_PI_6l);
1161 TEST_f_f (asin, 1.0, M_PI_2l);
1162 TEST_f_f (asin, -1.0, -M_PI_2l);
1163 }
1164
1165 fesetround (save_round_mode);
1166
1167 END (asin_upward);
1168}
1169
8847214f
UD
1170static void
1171asinh_test (void)
1172{
aaca11d8 1173 errno = 0;
3c6cad26 1174 FUNC(asinh) (0.7L);
aaca11d8
UD
1175 if (errno == ENOSYS)
1176 /* Function not implemented. */
1177 return;
1178
8847214f
UD
1179 START (asinh);
1180
1181 TEST_f_f (asinh, 0, 0);
1182 TEST_f_f (asinh, minus_zero, minus_zero);
15daa639 1183#ifndef TEST_INLINE
8847214f
UD
1184 TEST_f_f (asinh, plus_infty, plus_infty);
1185 TEST_f_f (asinh, minus_infty, minus_infty);
15daa639 1186#endif
67e971f1 1187 TEST_f_f (asinh, qnan_value, qnan_value);
2550dfe9 1188 TEST_f_f (asinh, 0.75L, 0.693147180559945309417232121458176568L);
8847214f
UD
1189
1190 END (asinh);
1191}
1192
1193static void
1194atan_test (void)
1195{
e6d3c4a7
AJ
1196 errno = 0;
1197 FUNC(atan) (0);
1198 if (errno == ENOSYS)
1199 /* Function not implemented. */
1200 return;
8847214f
UD
1201
1202 START (atan);
1203
1204 TEST_f_f (atan, 0, 0);
1205 TEST_f_f (atan, minus_zero, minus_zero);
1206
1207 TEST_f_f (atan, plus_infty, M_PI_2l);
1208 TEST_f_f (atan, minus_infty, -M_PI_2l);
67e971f1 1209 TEST_f_f (atan, qnan_value, qnan_value);
6d33cc9d
DM
1210 TEST_f_f (atan, max_value, M_PI_2l);
1211 TEST_f_f (atan, -max_value, -M_PI_2l);
8847214f
UD
1212
1213 TEST_f_f (atan, 1, M_PI_4l);
1214 TEST_f_f (atan, -1, -M_PI_4l);
1215
2550dfe9 1216 TEST_f_f (atan, 0.75L, 0.643501108793284386802809228717322638L);
8847214f 1217
0a42601f
JM
1218 TEST_f_f (atan, 0x1p-100L, 0x1p-100L);
1219#ifndef TEST_FLOAT
1220 TEST_f_f (atan, 0x1p-600L, 0x1p-600L);
1221#endif
1222#if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
1223 TEST_f_f (atan, 0x1p-10000L, 0x1p-10000L);
1224#endif
1225
8847214f
UD
1226 END (atan);
1227}
1228
1229
1230
1231static void
1232atanh_test (void)
1233{
aaca11d8 1234 errno = 0;
3c6cad26 1235 FUNC(atanh) (0.7L);
aaca11d8
UD
1236 if (errno == ENOSYS)
1237 /* Function not implemented. */
1238 return;
8847214f
UD
1239
1240 START (atanh);
1241
1242
1243 TEST_f_f (atanh, 0, 0);
1244 TEST_f_f (atanh, minus_zero, minus_zero);
1245
1246 TEST_f_f (atanh, 1, plus_infty, DIVIDE_BY_ZERO_EXCEPTION);
1247 TEST_f_f (atanh, -1, minus_infty, DIVIDE_BY_ZERO_EXCEPTION);
67e971f1 1248 TEST_f_f (atanh, qnan_value, qnan_value);
8847214f 1249
67e971f1
TS
1250 /* atanh (x) == qNaN plus invalid exception if |x| > 1. */
1251 TEST_f_f (atanh, 1.125L, qnan_value, INVALID_EXCEPTION);
1252 TEST_f_f (atanh, -1.125L, qnan_value, INVALID_EXCEPTION);
1253 TEST_f_f (atanh, max_value, qnan_value, INVALID_EXCEPTION);
1254 TEST_f_f (atanh, -max_value, qnan_value, INVALID_EXCEPTION);
8847214f 1255
2550dfe9 1256 TEST_f_f (atanh, 0.75L, 0.972955074527656652552676371721589865L);
8847214f
UD
1257
1258 END (atanh);
1259}
1260
1261static void
1262atan2_test (void)
1263{
aaca11d8
UD
1264 errno = 0;
1265 FUNC(atan2) (-0, 1);
1266 if (errno == ENOSYS)
1267 /* Function not implemented. */
1268 return;
1269
8847214f
UD
1270 START (atan2);
1271
1272 /* atan2 (0,x) == 0 for x > 0. */
1273 TEST_ff_f (atan2, 0, 1, 0);
1274
1275 /* atan2 (-0,x) == -0 for x > 0. */
1276 TEST_ff_f (atan2, minus_zero, 1, minus_zero);
1277
1278 TEST_ff_f (atan2, 0, 0, 0);
1279 TEST_ff_f (atan2, minus_zero, 0, minus_zero);
1280
1281 /* atan2 (+0,x) == +pi for x < 0. */
1282 TEST_ff_f (atan2, 0, -1, M_PIl);
1283
1284 /* atan2 (-0,x) == -pi for x < 0. */
1285 TEST_ff_f (atan2, minus_zero, -1, -M_PIl);
1286
1287 TEST_ff_f (atan2, 0, minus_zero, M_PIl);
1288 TEST_ff_f (atan2, minus_zero, minus_zero, -M_PIl);
1289
1290 /* atan2 (y,+0) == pi/2 for y > 0. */
1291 TEST_ff_f (atan2, 1, 0, M_PI_2l);
1292
1293 /* atan2 (y,-0) == pi/2 for y > 0. */
1294 TEST_ff_f (atan2, 1, minus_zero, M_PI_2l);
1295
1296 /* atan2 (y,+0) == -pi/2 for y < 0. */
1297 TEST_ff_f (atan2, -1, 0, -M_PI_2l);
1298
1299 /* atan2 (y,-0) == -pi/2 for y < 0. */
1300 TEST_ff_f (atan2, -1, minus_zero, -M_PI_2l);
1301
1302 /* atan2 (y,inf) == +0 for finite y > 0. */
1303 TEST_ff_f (atan2, 1, plus_infty, 0);
1304
1305 /* atan2 (y,inf) == -0 for finite y < 0. */
1306 TEST_ff_f (atan2, -1, plus_infty, minus_zero);
1307
1308 /* atan2(+inf, x) == pi/2 for finite x. */
1309 TEST_ff_f (atan2, plus_infty, -1, M_PI_2l);
1310
1311 /* atan2(-inf, x) == -pi/2 for finite x. */
1312 TEST_ff_f (atan2, minus_infty, 1, -M_PI_2l);
1313
1314 /* atan2 (y,-inf) == +pi for finite y > 0. */
1315 TEST_ff_f (atan2, 1, minus_infty, M_PIl);
1316
1317 /* atan2 (y,-inf) == -pi for finite y < 0. */
1318 TEST_ff_f (atan2, -1, minus_infty, -M_PIl);
1319
1320 TEST_ff_f (atan2, plus_infty, plus_infty, M_PI_4l);
1321 TEST_ff_f (atan2, minus_infty, plus_infty, -M_PI_4l);
1322 TEST_ff_f (atan2, plus_infty, minus_infty, M_PI_34l);
1323 TEST_ff_f (atan2, minus_infty, minus_infty, -M_PI_34l);
67e971f1 1324 TEST_ff_f (atan2, qnan_value, qnan_value, qnan_value);
8847214f 1325
7726d6a9
JM
1326 TEST_ff_f (atan2, max_value, max_value, M_PI_4l);
1327
6d33cc9d
DM
1328 TEST_ff_f (atan2, max_value, min_value, M_PI_2l);
1329 TEST_ff_f (atan2, -max_value, -min_value, -M_PI_2l);
1330
2550dfe9
AJ
1331 TEST_ff_f (atan2, 0.75L, 1, 0.643501108793284386802809228717322638L);
1332 TEST_ff_f (atan2, -0.75L, 1.0L, -0.643501108793284386802809228717322638L);
1333 TEST_ff_f (atan2, 0.75L, -1.0L, 2.49809154479650885165983415456218025L);
1334 TEST_ff_f (atan2, -0.75L, -1.0L, -2.49809154479650885165983415456218025L);
1335 TEST_ff_f (atan2, 0.390625L, .00029L, 1.57005392693128974780151246612928941L);
1336 TEST_ff_f (atan2, 1.390625L, 0.9296875L, 0.981498387184244311516296577615519772L);
8847214f 1337
3c8605c7 1338 TEST_ff_f (atan2, -0.00756827042671106339L, -.001792735857538728036L, -1.80338464113663849327153994379639112L);
16a0e2ec
JM
1339#if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 64
1340 TEST_ff_f (atan2, 0x1.00000000000001p0L, 0x1.00000000000001p0L, M_PI_4l);
1341#endif
bb3f4825 1342
8847214f
UD
1343 END (atan2);
1344}
1345
8847214f
UD
1346static void
1347cabs_test (void)
1348{
aaca11d8 1349 errno = 0;
3c6cad26 1350 FUNC(cabs) (BUILD_COMPLEX (0.7L, 12.4L));
aaca11d8
UD
1351 if (errno == ENOSYS)
1352 /* Function not implemented. */
1353 return;
1354
8847214f
UD
1355 START (cabs);
1356
1357 /* cabs (x + iy) is specified as hypot (x,y) */
1358
1359 /* cabs (+inf + i x) == +inf. */
1360 TEST_c_f (cabs, plus_infty, 1.0, plus_infty);
1361 /* cabs (-inf + i x) == +inf. */
1362 TEST_c_f (cabs, minus_infty, 1.0, plus_infty);
1363
67e971f1
TS
1364 TEST_c_f (cabs, minus_infty, qnan_value, plus_infty);
1365 TEST_c_f (cabs, minus_infty, qnan_value, plus_infty);
8847214f 1366
67e971f1 1367 TEST_c_f (cabs, qnan_value, qnan_value, qnan_value);
8847214f
UD
1368
1369 /* cabs (x,y) == cabs (y,x). */
2550dfe9 1370 TEST_c_f (cabs, 0.75L, 12.390625L, 12.4133028598606664302388810868156657L);
8847214f 1371 /* cabs (x,y) == cabs (-x,y). */
2550dfe9 1372 TEST_c_f (cabs, -12.390625L, 0.75L, 12.4133028598606664302388810868156657L);
8847214f 1373 /* cabs (x,y) == cabs (-y,x). */
2550dfe9 1374 TEST_c_f (cabs, -0.75L, 12.390625L, 12.4133028598606664302388810868156657L);
8847214f 1375 /* cabs (x,y) == cabs (-x,-y). */
2550dfe9 1376 TEST_c_f (cabs, -12.390625L, -0.75L, 12.4133028598606664302388810868156657L);
8847214f 1377 /* cabs (x,y) == cabs (-y,-x). */
2550dfe9 1378 TEST_c_f (cabs, -0.75L, -12.390625L, 12.4133028598606664302388810868156657L);
8847214f 1379 /* cabs (x,0) == fabs (x). */
2550dfe9
AJ
1380 TEST_c_f (cabs, -0.75L, 0, 0.75L);
1381 TEST_c_f (cabs, 0.75L, 0, 0.75L);
8847214f
UD
1382 TEST_c_f (cabs, -1.0L, 0, 1.0L);
1383 TEST_c_f (cabs, 1.0L, 0, 1.0L);
1384 TEST_c_f (cabs, -5.7e7L, 0, 5.7e7L);
1385 TEST_c_f (cabs, 5.7e7L, 0, 5.7e7L);
1386
2550dfe9 1387 TEST_c_f (cabs, 0.75L, 1.25L, 1.45773797371132511771853821938639577L);
8847214f
UD
1388
1389 END (cabs);
1390}
1391
2550dfe9 1392
8847214f
UD
1393static void
1394cacos_test (void)
1395{
aaca11d8 1396 errno = 0;
3c6cad26 1397 FUNC(cacos) (BUILD_COMPLEX (0.7L, 1.2L));
aaca11d8
UD
1398 if (errno == ENOSYS)
1399 /* Function not implemented. */
1400 return;
1401
8847214f
UD
1402 START (cacos);
1403
1404
1405 TEST_c_c (cacos, 0, 0, M_PI_2l, minus_zero);
1406 TEST_c_c (cacos, minus_zero, 0, M_PI_2l, minus_zero);
1407 TEST_c_c (cacos, minus_zero, minus_zero, M_PI_2l, 0.0);
1408 TEST_c_c (cacos, 0, minus_zero, M_PI_2l, 0.0);
1409
1410 TEST_c_c (cacos, minus_infty, plus_infty, M_PI_34l, minus_infty);
1411 TEST_c_c (cacos, minus_infty, minus_infty, M_PI_34l, plus_infty);
1412
1413 TEST_c_c (cacos, plus_infty, plus_infty, M_PI_4l, minus_infty);
1414 TEST_c_c (cacos, plus_infty, minus_infty, M_PI_4l, plus_infty);
1415
1416 TEST_c_c (cacos, -10.0, plus_infty, M_PI_2l, minus_infty);
1417 TEST_c_c (cacos, -10.0, minus_infty, M_PI_2l, plus_infty);
1418 TEST_c_c (cacos, 0, plus_infty, M_PI_2l, minus_infty);
1419 TEST_c_c (cacos, 0, minus_infty, M_PI_2l, plus_infty);
3c6cad26
UD
1420 TEST_c_c (cacos, 0.1L, plus_infty, M_PI_2l, minus_infty);
1421 TEST_c_c (cacos, 0.1L, minus_infty, M_PI_2l, plus_infty);
8847214f
UD
1422
1423 TEST_c_c (cacos, minus_infty, 0, M_PIl, minus_infty);
1424 TEST_c_c (cacos, minus_infty, minus_zero, M_PIl, plus_infty);
1425 TEST_c_c (cacos, minus_infty, 100, M_PIl, minus_infty);
1426 TEST_c_c (cacos, minus_infty, -100, M_PIl, plus_infty);
1427
1428 TEST_c_c (cacos, plus_infty, 0, 0.0, minus_infty);
1429 TEST_c_c (cacos, plus_infty, minus_zero, 0.0, plus_infty);
1430 TEST_c_c (cacos, plus_infty, 0.5, 0.0, minus_infty);
1431 TEST_c_c (cacos, plus_infty, -0.5, 0.0, plus_infty);
1432
67e971f1
TS
1433 TEST_c_c (cacos, plus_infty, qnan_value, qnan_value, plus_infty, IGNORE_ZERO_INF_SIGN);
1434 TEST_c_c (cacos, minus_infty, qnan_value, qnan_value, plus_infty, IGNORE_ZERO_INF_SIGN);
8847214f 1435
67e971f1
TS
1436 TEST_c_c (cacos, 0, qnan_value, M_PI_2l, qnan_value);
1437 TEST_c_c (cacos, minus_zero, qnan_value, M_PI_2l, qnan_value);
8847214f 1438
67e971f1
TS
1439 TEST_c_c (cacos, qnan_value, plus_infty, qnan_value, minus_infty);
1440 TEST_c_c (cacos, qnan_value, minus_infty, qnan_value, plus_infty);
8847214f 1441
67e971f1
TS
1442 TEST_c_c (cacos, 10.5, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
1443 TEST_c_c (cacos, -10.5, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
8847214f 1444
67e971f1
TS
1445 TEST_c_c (cacos, qnan_value, 0.75, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
1446 TEST_c_c (cacos, qnan_value, -0.75, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
8847214f 1447
67e971f1 1448 TEST_c_c (cacos, qnan_value, qnan_value, qnan_value, qnan_value);
8847214f 1449
d1d3431a
JM
1450 TEST_c_c (cacos, plus_zero, -1.5L, M_PI_2l, 1.194763217287109304111930828519090523536L);
1451 TEST_c_c (cacos, minus_zero, -1.5L, M_PI_2l, 1.194763217287109304111930828519090523536L);
1452 TEST_c_c (cacos, plus_zero, -1.0L, M_PI_2l, 0.8813735870195430252326093249797923090282L);
1453 TEST_c_c (cacos, minus_zero, -1.0L, M_PI_2l, 0.8813735870195430252326093249797923090282L);
1454 TEST_c_c (cacos, plus_zero, -0.5L, M_PI_2l, 0.4812118250596034474977589134243684231352L);
1455 TEST_c_c (cacos, minus_zero, -0.5L, M_PI_2l, 0.4812118250596034474977589134243684231352L);
1456 TEST_c_c (cacos, plus_zero, 0.5L, M_PI_2l, -0.4812118250596034474977589134243684231352L);
1457 TEST_c_c (cacos, minus_zero, 0.5L, M_PI_2l, -0.4812118250596034474977589134243684231352L);
1458 TEST_c_c (cacos, plus_zero, 1.0L, M_PI_2l, -0.8813735870195430252326093249797923090282L);
1459 TEST_c_c (cacos, minus_zero, 1.0L, M_PI_2l, -0.8813735870195430252326093249797923090282L);
1460 TEST_c_c (cacos, plus_zero, 1.5L, M_PI_2l, -1.194763217287109304111930828519090523536L);
1461 TEST_c_c (cacos, minus_zero, 1.5L, M_PI_2l, -1.194763217287109304111930828519090523536L);
1462
1463 TEST_c_c (cacos, -1.5L, plus_zero, M_PIl, -0.9624236501192068949955178268487368462704L);
1464 TEST_c_c (cacos, -1.5L, minus_zero, M_PIl, 0.9624236501192068949955178268487368462704L);
1465 TEST_c_c (cacos, -1.0L, plus_zero, M_PIl, minus_zero);
1466 TEST_c_c (cacos, -1.0L, minus_zero, M_PIl, plus_zero);
1467 TEST_c_c (cacos, -0.5L, plus_zero, 2.094395102393195492308428922186335256131L, minus_zero);
1468 TEST_c_c (cacos, -0.5L, minus_zero, 2.094395102393195492308428922186335256131L, plus_zero);
1469 TEST_c_c (cacos, 0.5L, plus_zero, 1.047197551196597746154214461093167628066L, minus_zero);
1470 TEST_c_c (cacos, 0.5L, minus_zero, 1.047197551196597746154214461093167628066L, plus_zero);
1471 TEST_c_c (cacos, 1.0L, plus_zero, plus_zero, minus_zero);
1472 TEST_c_c (cacos, 1.0L, minus_zero, plus_zero, plus_zero);
1473 TEST_c_c (cacos, 1.5L, plus_zero, plus_zero, -0.9624236501192068949955178268487368462704L);
1474 TEST_c_c (cacos, 1.5L, minus_zero, plus_zero, 0.9624236501192068949955178268487368462704L);
1475
728d7b43
JM
1476 TEST_c_c (cacos, 0x1p50L, 1.0L, 8.881784197001252323389053344727730248720e-16L, -3.535050620855721078027883819436720218708e1L);
1477 TEST_c_c (cacos, 0x1p50L, -1.0L, 8.881784197001252323389053344727730248720e-16L, 3.535050620855721078027883819436720218708e1L);
1478 TEST_c_c (cacos, -0x1p50L, 1.0L, 3.141592653589792350284223683154270545292L, -3.535050620855721078027883819436720218708e1L);
1479 TEST_c_c (cacos, -0x1p50L, -1.0L, 3.141592653589792350284223683154270545292L, 3.535050620855721078027883819436720218708e1L);
1480 TEST_c_c (cacos, 1.0L, 0x1p50L, 1.570796326794895731052901991514519103193L, -3.535050620855721078027883819436759661753e1L);
1481 TEST_c_c (cacos, -1.0L, 0x1p50L, 1.570796326794897507409741391764983781004L, -3.535050620855721078027883819436759661753e1L);
1482 TEST_c_c (cacos, 1.0L, -0x1p50L, 1.570796326794895731052901991514519103193L, 3.535050620855721078027883819436759661753e1L);
1483 TEST_c_c (cacos, -1.0L, -0x1p50L, 1.570796326794897507409741391764983781004L, 3.535050620855721078027883819436759661753e1L);
1484#ifndef TEST_FLOAT
1485 TEST_c_c (cacos, 0x1p500L, 1.0L, 3.054936363499604682051979393213617699789e-151L, -3.472667374605326000180332928505464606058e2L);
1486 TEST_c_c (cacos, 0x1p500L, -1.0L, 3.054936363499604682051979393213617699789e-151L, 3.472667374605326000180332928505464606058e2L);
1487 TEST_c_c (cacos, -0x1p500L, 1.0L, 3.141592653589793238462643383279502884197L, -3.472667374605326000180332928505464606058e2L);
1488 TEST_c_c (cacos, -0x1p500L, -1.0L, 3.141592653589793238462643383279502884197L, 3.472667374605326000180332928505464606058e2L);
1489 TEST_c_c (cacos, 1.0L, 0x1p500L, 1.570796326794896619231321691639751442099L, -3.472667374605326000180332928505464606058e2L);
1490 TEST_c_c (cacos, -1.0L, 0x1p500L, 1.570796326794896619231321691639751442099L, -3.472667374605326000180332928505464606058e2L);
1491 TEST_c_c (cacos, 1.0L, -0x1p500L, 1.570796326794896619231321691639751442099L, 3.472667374605326000180332928505464606058e2L);
1492 TEST_c_c (cacos, -1.0L, -0x1p500L, 1.570796326794896619231321691639751442099L, 3.472667374605326000180332928505464606058e2L);
1493#endif
1494#if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
1495 TEST_c_c (cacos, 0x1p5000L, 1.0L, 7.079811261048172892385615158694057552948e-1506L, -3.466429049980286492395577839412341016946e3L);
1496 TEST_c_c (cacos, 0x1p5000L, -1.0L, 7.079811261048172892385615158694057552948e-1506L, 3.466429049980286492395577839412341016946e3L);
1497 TEST_c_c (cacos, -0x1p5000L, 1.0L, 3.141592653589793238462643383279502884197L, -3.466429049980286492395577839412341016946e3L);
1498 TEST_c_c (cacos, -0x1p5000L, -1.0L, 3.141592653589793238462643383279502884197L, 3.466429049980286492395577839412341016946e3L);
1499 TEST_c_c (cacos, 1.0L, 0x1p5000L, 1.570796326794896619231321691639751442099L, -3.466429049980286492395577839412341016946e3L);
1500 TEST_c_c (cacos, -1.0L, 0x1p5000L, 1.570796326794896619231321691639751442099L, -3.466429049980286492395577839412341016946e3L);
1501 TEST_c_c (cacos, 1.0L, -0x1p5000L, 1.570796326794896619231321691639751442099L, 3.466429049980286492395577839412341016946e3L);
1502 TEST_c_c (cacos, -1.0L, -0x1p5000L, 1.570796326794896619231321691639751442099L, 3.466429049980286492395577839412341016946e3L);
1503#endif
1504
1505 TEST_c_c (cacos, 0x1.fp127L, 0x1.fp127L, 7.853981633974483096156608458198757210493e-1L, -8.973081118419833726837456344608533993585e1L);
1506#ifndef TEST_FLOAT
1507 TEST_c_c (cacos, 0x1.fp1023L, 0x1.fp1023L, 7.853981633974483096156608458198757210493e-1L, -7.107906849659093345062145442726115449315e2L);
1508#endif
1509#if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
1510 TEST_c_c (cacos, 0x1.fp16383L, 0x1.fp16383L, 7.853981633974483096156608458198757210493e-1L, -1.135753137836666928715489992987020363057e4L);
1511#endif
1512
8cf28c5e
JM
1513 TEST_c_c (cacos, 0x1.fp-129L, 1.5L, 1.570796326794896619231321691639751442097L, -1.194763217287109304111930828519090523536L);
1514 TEST_c_c (cacos, 0x1.fp-129L, -1.5L, 1.570796326794896619231321691639751442097L, 1.194763217287109304111930828519090523536L);
1515 TEST_c_c (cacos, -0x1.fp-129L, 1.5L, 1.570796326794896619231321691639751442100L, -1.194763217287109304111930828519090523536L);
1516 TEST_c_c (cacos, -0x1.fp-129L, -1.5L, 1.570796326794896619231321691639751442100L, 1.194763217287109304111930828519090523536L);
1517 TEST_c_c (cacos, 1.5L, 0x1.fp-129L, 2.546345110742945032959687790021055102355e-39L, -9.624236501192068949955178268487368462704e-1L, UNDERFLOW_EXCEPTION_FLOAT);
1518 TEST_c_c (cacos, -1.5L, 0x1.fp-129L, 3.141592653589793238462643383279502884195L, -9.624236501192068949955178268487368462704e-1L);
1519 TEST_c_c (cacos, 1.5L, -0x1.fp-129L, 2.546345110742945032959687790021055102355e-39L, 9.624236501192068949955178268487368462704e-1L, UNDERFLOW_EXCEPTION_FLOAT);
1520 TEST_c_c (cacos, -1.5L, -0x1.fp-129L, 3.141592653589793238462643383279502884195L, 9.624236501192068949955178268487368462704e-1L);
1521#ifndef TEST_FLOAT
1522 TEST_c_c (cacos, 0x1.fp-1025L, 1.5L, 1.570796326794896619231321691639751442099L, -1.194763217287109304111930828519090523536L);
1523 TEST_c_c (cacos, 0x1.fp-1025L, -1.5L, 1.570796326794896619231321691639751442099L, 1.194763217287109304111930828519090523536L);
1524 TEST_c_c (cacos, -0x1.fp-1025L, 1.5L, 1.570796326794896619231321691639751442099L, -1.194763217287109304111930828519090523536L);
1525 TEST_c_c (cacos, -0x1.fp-1025L, -1.5L, 1.570796326794896619231321691639751442099L, 1.194763217287109304111930828519090523536L);
1526 TEST_c_c (cacos, 1.5L, 0x1.fp-1025L, 4.819934639999230680322935210539402497827e-309L, -9.624236501192068949955178268487368462704e-1L, UNDERFLOW_EXCEPTION_DOUBLE);
1527 TEST_c_c (cacos, -1.5L, 0x1.fp-1025L, 3.141592653589793238462643383279502884197L, -9.624236501192068949955178268487368462704e-1L);
1528 TEST_c_c (cacos, 1.5L, -0x1.fp-1025L, 4.819934639999230680322935210539402497827e-309L, 9.624236501192068949955178268487368462704e-1L, UNDERFLOW_EXCEPTION_DOUBLE);
1529 TEST_c_c (cacos, -1.5L, -0x1.fp-1025L, 3.141592653589793238462643383279502884197L, 9.624236501192068949955178268487368462704e-1L);
1530#endif
1531#if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
1532 TEST_c_c (cacos, 0x1.fp-16385L, 1.5L, 1.570796326794896619231321691639751442099L, -1.194763217287109304111930828519090523536L);
1533 TEST_c_c (cacos, 0x1.fp-16385L, -1.5L, 1.570796326794896619231321691639751442099L, 1.194763217287109304111930828519090523536L);
1534 TEST_c_c (cacos, -0x1.fp-16385L, 1.5L, 1.570796326794896619231321691639751442099L, -1.194763217287109304111930828519090523536L);
1535 TEST_c_c (cacos, -0x1.fp-16385L, -1.5L, 1.570796326794896619231321691639751442099L, 1.194763217287109304111930828519090523536L);
1536 TEST_c_c (cacos, 1.5L, 0x1.fp-16385L, 7.282957076134209141226696333885150260319e-4933L, -9.624236501192068949955178268487368462704e-1L, UNDERFLOW_EXCEPTION);
1537 TEST_c_c (cacos, -1.5L, 0x1.fp-16385L, 3.141592653589793238462643383279502884197L, -9.624236501192068949955178268487368462704e-1L);
1538 TEST_c_c (cacos, 1.5L, -0x1.fp-16385L, 7.282957076134209141226696333885150260319e-4933L, 9.624236501192068949955178268487368462704e-1L, UNDERFLOW_EXCEPTION);
1539 TEST_c_c (cacos, -1.5L, -0x1.fp-16385L, 3.141592653589793238462643383279502884197L, 9.624236501192068949955178268487368462704e-1L);
1540#endif
1541
0a1b2ae6
JM
1542 TEST_c_c (cacos, 0.5L, 1.0L, 1.221357263937683325603909865564381489366L, -9.261330313501824245501244453057873152694e-1L);
1543 TEST_c_c (cacos, 0.5L, -1.0L, 1.221357263937683325603909865564381489366L, 9.261330313501824245501244453057873152694e-1L);
1544 TEST_c_c (cacos, -0.5L, 1.0L, 1.920235389652109912858733517715121394831L, -9.261330313501824245501244453057873152694e-1L);
1545 TEST_c_c (cacos, -0.5L, -1.0L, 1.920235389652109912858733517715121394831L, 9.261330313501824245501244453057873152694e-1L);
1546 TEST_c_c (cacos, 1.0L, 0.5L, 6.748888455860063801646649673121744318756e-1L, -7.328576759736452608886724437653071523305e-1L);
1547 TEST_c_c (cacos, -1.0L, 0.5L, 2.466703808003786858297978415967328452322L, -7.328576759736452608886724437653071523305e-1L);
1548 TEST_c_c (cacos, 1.0L, -0.5L, 6.748888455860063801646649673121744318756e-1L, 7.328576759736452608886724437653071523305e-1L);
1549 TEST_c_c (cacos, -1.0L, -0.5L, 2.466703808003786858297978415967328452322L, 7.328576759736452608886724437653071523305e-1L);
1550 TEST_c_c (cacos, 0.25L, 1.0L, 1.394493894017929688812643125003661339452L, -8.924633639033482359562124741744951972772e-1L);
1551 TEST_c_c (cacos, 0.25L, -1.0L, 1.394493894017929688812643125003661339452L, 8.924633639033482359562124741744951972772e-1L);
1552 TEST_c_c (cacos, -0.25L, 1.0L, 1.747098759571863549650000258275841544745L, -8.924633639033482359562124741744951972772e-1L);
1553 TEST_c_c (cacos, -0.25L, -1.0L, 1.747098759571863549650000258275841544745L, 8.924633639033482359562124741744951972772e-1L);
1554 TEST_c_c (cacos, 1.0L, 0.25L, 4.890443302710802929202843732146540079124e-1L, -5.097911466811016354623559941115413499164e-1L);
1555 TEST_c_c (cacos, -1.0L, 0.25L, 2.652548323318712945542359010064848876285L, -5.097911466811016354623559941115413499164e-1L);
1556 TEST_c_c (cacos, 1.0L, -0.25L, 4.890443302710802929202843732146540079124e-1L, 5.097911466811016354623559941115413499164e-1L);
1557 TEST_c_c (cacos, -1.0L, -0.25L, 2.652548323318712945542359010064848876285L, 5.097911466811016354623559941115413499164e-1L);
1558 TEST_c_c (cacos, 0x1.fp-10L, 1.0L, 1.569458417435338878318763342108699202986L, -8.813742198809567991336704287826445879025e-1L);
1559 TEST_c_c (cacos, 0x1.fp-10L, -1.0L, 1.569458417435338878318763342108699202986L, 8.813742198809567991336704287826445879025e-1L);
1560 TEST_c_c (cacos, -0x1.fp-10L, 1.0L, 1.572134236154454360143880041170803681211L, -8.813742198809567991336704287826445879025e-1L);
1561 TEST_c_c (cacos, -0x1.fp-10L, -1.0L, 1.572134236154454360143880041170803681211L, 8.813742198809567991336704287826445879025e-1L);
1562 TEST_c_c (cacos, 1.0L, 0x1.fp-10L, 4.349129763101882771258049954181971959031e-2L, -4.350501469856803800217957402220976497152e-2L);
1563 TEST_c_c (cacos, -1.0L, 0x1.fp-10L, 3.098101355958774410750062883737683164607L, -4.350501469856803800217957402220976497152e-2L);
1564 TEST_c_c (cacos, 1.0L, -0x1.fp-10L, 4.349129763101882771258049954181971959031e-2L, 4.350501469856803800217957402220976497152e-2L);
1565 TEST_c_c (cacos, -1.0L, -0x1.fp-10L, 3.098101355958774410750062883737683164607L, 4.350501469856803800217957402220976497152e-2L);
1566 TEST_c_c (cacos, 0x1.fp-30L, 1.0L, 1.570796325518966635014803151387033957091L, -8.813735870195430258081932989769495326854e-1L);
1567 TEST_c_c (cacos, 0x1.fp-30L, -1.0L, 1.570796325518966635014803151387033957091L, 8.813735870195430258081932989769495326854e-1L);
1568 TEST_c_c (cacos, -0x1.fp-30L, 1.0L, 1.570796328070826603447840231892468927106L, -8.813735870195430258081932989769495326854e-1L);
1569 TEST_c_c (cacos, -0x1.fp-30L, -1.0L, 1.570796328070826603447840231892468927106L, 8.813735870195430258081932989769495326854e-1L);
1570 TEST_c_c (cacos, 1.0L, 0x1.fp-30L, 4.247867097467650115899790787875186617316e-5L, -4.247867098745151888768727039216644758847e-5L);
1571 TEST_c_c (cacos, -1.0L, 0x1.fp-30L, 3.141550174918818561961484385371624132331L, -4.247867098745151888768727039216644758847e-5L);
1572 TEST_c_c (cacos, 1.0L, -0x1.fp-30L, 4.247867097467650115899790787875186617316e-5L, 4.247867098745151888768727039216644758847e-5L);
1573 TEST_c_c (cacos, -1.0L, -0x1.fp-30L, 3.141550174918818561961484385371624132331L, 4.247867098745151888768727039216644758847e-5L);
1574 TEST_c_c (cacos, 0x1.fp-100L, 1.0L, 1.570796326794896619231321691638670687364L, -8.813735870195430252326093249797923090282e-1L);
1575 TEST_c_c (cacos, 0x1.fp-100L, -1.0L, 1.570796326794896619231321691638670687364L, 8.813735870195430252326093249797923090282e-1L);
1576 TEST_c_c (cacos, -0x1.fp-100L, 1.0L, 1.570796326794896619231321691640832196834L, -8.813735870195430252326093249797923090282e-1L);
1577 TEST_c_c (cacos, -0x1.fp-100L, -1.0L, 1.570796326794896619231321691640832196834L, 8.813735870195430252326093249797923090282e-1L);
1578 TEST_c_c (cacos, 1.0L, 0x1.fp-100L, 1.236292038260260888664514866456887257525e-15L, -1.236292038260260888664514866457202186027e-15L);
1579 TEST_c_c (cacos, -1.0L, 0x1.fp-100L, 3.141592653589792002170605123018614219682L, -1.236292038260260888664514866457202186027e-15L);
1580 TEST_c_c (cacos, 1.0L, -0x1.fp-100L, 1.236292038260260888664514866456887257525e-15L, 1.236292038260260888664514866457202186027e-15L);
1581 TEST_c_c (cacos, -1.0L, -0x1.fp-100L, 3.141592653589792002170605123018614219682L, 1.236292038260260888664514866457202186027e-15L);
1582 TEST_c_c (cacos, 0x1.fp-129L, 1.0L, 1.570796326794896619231321691639751442097L, -8.813735870195430252326093249797923090282e-1L);
1583 TEST_c_c (cacos, 0x1.fp-129L, -1.0L, 1.570796326794896619231321691639751442097L, 8.813735870195430252326093249797923090282e-1L);
1584 TEST_c_c (cacos, -0x1.fp-129L, 1.0L, 1.570796326794896619231321691639751442101L, -8.813735870195430252326093249797923090282e-1L);
1585 TEST_c_c (cacos, -0x1.fp-129L, -1.0L, 1.570796326794896619231321691639751442101L, 8.813735870195430252326093249797923090282e-1L);
1586 TEST_c_c (cacos, 1.0L, 0x1.fp-129L, 5.335635276982233498398987585285818977930e-20L, -5.335635276982233498398987585285818977933e-20L);
1587 TEST_c_c (cacos, -1.0L, 0x1.fp-129L, 3.141592653589793238409287030509680549213L, -5.335635276982233498398987585285818977933e-20L);
1588 TEST_c_c (cacos, 1.0L, -0x1.fp-129L, 5.335635276982233498398987585285818977930e-20L, 5.335635276982233498398987585285818977933e-20L);
1589 TEST_c_c (cacos, -1.0L, -0x1.fp-129L, 3.141592653589793238409287030509680549213L, 5.335635276982233498398987585285818977933e-20L);
1590#ifndef TEST_FLOAT
1591 TEST_c_c (cacos, 0x1.fp-1000L, 1.0L, 1.570796326794896619231321691639751442099L, -8.813735870195430252326093249797923090282e-1L);
1592 TEST_c_c (cacos, 0x1.fp-1000L, -1.0L, 1.570796326794896619231321691639751442099L, 8.813735870195430252326093249797923090282e-1L);
1593 TEST_c_c (cacos, -0x1.fp-1000L, 1.0L, 1.570796326794896619231321691639751442099L, -8.813735870195430252326093249797923090282e-1L);
1594 TEST_c_c (cacos, -0x1.fp-1000L, -1.0L, 1.570796326794896619231321691639751442099L, 8.813735870195430252326093249797923090282e-1L);
1595 TEST_c_c (cacos, 1.0L, 0x1.fp-1000L, 4.252291453851660175550490409247739011867e-151L, -4.252291453851660175550490409247739011867e-151L);
1596 TEST_c_c (cacos, -1.0L, 0x1.fp-1000L, 3.141592653589793238462643383279502884197L, -4.252291453851660175550490409247739011867e-151L);
1597 TEST_c_c (cacos, 1.0L, -0x1.fp-1000L, 4.252291453851660175550490409247739011867e-151L, 4.252291453851660175550490409247739011867e-151L);
1598 TEST_c_c (cacos, -1.0L, -0x1.fp-1000L, 3.141592653589793238462643383279502884197L, 4.252291453851660175550490409247739011867e-151L);
1599 TEST_c_c (cacos, 0x1.fp-1025L, 1.0L, 1.570796326794896619231321691639751442099L, -8.813735870195430252326093249797923090282e-1L);
1600 TEST_c_c (cacos, 0x1.fp-1025L, -1.0L, 1.570796326794896619231321691639751442099L, 8.813735870195430252326093249797923090282e-1L);
1601 TEST_c_c (cacos, -0x1.fp-1025L, 1.0L, 1.570796326794896619231321691639751442099L, -8.813735870195430252326093249797923090282e-1L);
1602 TEST_c_c (cacos, -0x1.fp-1025L, -1.0L, 1.570796326794896619231321691639751442099L, 8.813735870195430252326093249797923090282e-1L);
1603 TEST_c_c (cacos, 1.0L, 0x1.fp-1025L, 7.340879205566679497036857179189356754017e-155L, -7.340879205566679497036857179189356754017e-155L);
1604 TEST_c_c (cacos, -1.0L, 0x1.fp-1025L, 3.141592653589793238462643383279502884197L, -7.340879205566679497036857179189356754017e-155L);
1605 TEST_c_c (cacos, 1.0L, -0x1.fp-1025L, 7.340879205566679497036857179189356754017e-155L, 7.340879205566679497036857179189356754017e-155L);
1606 TEST_c_c (cacos, -1.0L, -0x1.fp-1025L, 3.141592653589793238462643383279502884197L, 7.340879205566679497036857179189356754017e-155L);
1607#endif
1608#if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
1609 TEST_c_c (cacos, 0x1.fp-10000L, 1.0L, 1.570796326794896619231321691639751442099L, -8.813735870195430252326093249797923090282e-1L);
1610 TEST_c_c (cacos, 0x1.fp-10000L, -1.0L, 1.570796326794896619231321691639751442099L, 8.813735870195430252326093249797923090282e-1L);
1611 TEST_c_c (cacos, -0x1.fp-10000L, 1.0L, 1.570796326794896619231321691639751442099L, -8.813735870195430252326093249797923090282e-1L);
1612 TEST_c_c (cacos, -0x1.fp-10000L, -1.0L, 1.570796326794896619231321691639751442099L, 8.813735870195430252326093249797923090282e-1L);
1613 TEST_c_c (cacos, 1.0L, 0x1.fp-10000L, 9.854680208706673586644342922051388714633e-1506L, -9.854680208706673586644342922051388714633e-1506L);
1614 TEST_c_c (cacos, -1.0L, 0x1.fp-10000L, 3.141592653589793238462643383279502884197L, -9.854680208706673586644342922051388714633e-1506L);
1615 TEST_c_c (cacos, 1.0L, -0x1.fp-10000L, 9.854680208706673586644342922051388714633e-1506L, 9.854680208706673586644342922051388714633e-1506L);
1616 TEST_c_c (cacos, -1.0L, -0x1.fp-10000L, 3.141592653589793238462643383279502884197L, 9.854680208706673586644342922051388714633e-1506L);
1617 TEST_c_c (cacos, 0x1.fp-16385L, 1.0L, 1.570796326794896619231321691639751442099L, -8.813735870195430252326093249797923090282e-1L);
1618 TEST_c_c (cacos, 0x1.fp-16385L, -1.0L, 1.570796326794896619231321691639751442099L, 8.813735870195430252326093249797923090282e-1L);
1619 TEST_c_c (cacos, -0x1.fp-16385L, 1.0L, 1.570796326794896619231321691639751442099L, -8.813735870195430252326093249797923090282e-1L);
1620 TEST_c_c (cacos, -0x1.fp-16385L, -1.0L, 1.570796326794896619231321691639751442099L, 8.813735870195430252326093249797923090282e-1L);
1621 TEST_c_c (cacos, 1.0L, 0x1.fp-16385L, 9.023632056840860275214893047597614177639e-2467L, -9.023632056840860275214893047597614177639e-2467L);
1622 TEST_c_c (cacos, -1.0L, 0x1.fp-16385L, 3.141592653589793238462643383279502884197L, -9.023632056840860275214893047597614177639e-2467L);
1623 TEST_c_c (cacos, 1.0L, -0x1.fp-16385L, 9.023632056840860275214893047597614177639e-2467L, 9.023632056840860275214893047597614177639e-2467L);
1624 TEST_c_c (cacos, -1.0L, -0x1.fp-16385L, 3.141592653589793238462643383279502884197L, 9.023632056840860275214893047597614177639e-2467L);
1625#endif
1626
3a7182a1
JM
1627 TEST_c_c (cacos, 0x1p-23L, 0x1.000002p0L, 1.570796242501204621739026081991856762292L, -8.813736713132400470205730751186547909968e-1L)
1628 TEST_c_c (cacos, 0x1p-23L, -0x1.000002p0L, 1.570796242501204621739026081991856762292L, 8.813736713132400470205730751186547909968e-1L)
1629 TEST_c_c (cacos, -0x1p-23L, 0x1.000002p0L, 1.570796411088588616723617301287646121905L, -8.813736713132400470205730751186547909968e-1L)
1630 TEST_c_c (cacos, -0x1p-23L, -0x1.000002p0L, 1.570796411088588616723617301287646121905L, 8.813736713132400470205730751186547909968e-1L)
1631 TEST_c_c (cacos, 0x1.000002p0L, 0x1p-23L, 2.222118384408546368406374049167636760903e-4L, -5.364668491573609633134147164031476452679e-4L)
1632 TEST_c_c (cacos, -0x1.000002p0L, 0x1p-23L, 3.141370441751352383825802745874586120521L, -5.364668491573609633134147164031476452679e-4L)
1633 TEST_c_c (cacos, 0x1.000002p0L, -0x1p-23L, 2.222118384408546368406374049167636760903e-4L, 5.364668491573609633134147164031476452679e-4L)
1634 TEST_c_c (cacos, -0x1.000002p0L, -0x1p-23L, 3.141370441751352383825802745874586120521L, 5.364668491573609633134147164031476452679e-4L)
1635 TEST_c_c (cacos, 0x1.fp-129L, 0x1.000002p0L, 1.570796326794896619231321691639751442097L, -8.813736713132375348727889167749389235161e-1L)
1636 TEST_c_c (cacos, 0x1.fp-129L, -0x1.000002p0L, 1.570796326794896619231321691639751442097L, 8.813736713132375348727889167749389235161e-1L)
1637 TEST_c_c (cacos, -0x1.fp-129L, 0x1.000002p0L, 1.570796326794896619231321691639751442101L, -8.813736713132375348727889167749389235161e-1L)
1638 TEST_c_c (cacos, -0x1.fp-129L, -0x1.000002p0L, 1.570796326794896619231321691639751442101L, 8.813736713132375348727889167749389235161e-1L)
1639 TEST_c_c (cacos, 0x1.000002p0L, 0x1.fp-129L, 5.830451806317544230969669308596361881467e-36L, -4.882812451493617206486388134172712975070e-4L)
1640 TEST_c_c (cacos, -0x1.000002p0L, 0x1.fp-129L, 3.141592653589793238462643383279502878367L, -4.882812451493617206486388134172712975070e-4L)
1641 TEST_c_c (cacos, 0x1.000002p0L, -0x1.fp-129L, 5.830451806317544230969669308596361881467e-36L, 4.882812451493617206486388134172712975070e-4L)
1642 TEST_c_c (cacos, -0x1.000002p0L, -0x1.fp-129L, 3.141592653589793238462643383279502878367L, 4.882812451493617206486388134172712975070e-4L)
1643 TEST_c_c (cacos, 0.0L, 0x1.000002p0L, 1.570796326794896619231321691639751442099L, -8.813736713132375348727889167749389235161e-1L)
1644 TEST_c_c (cacos, 0.0L, -0x1.000002p0L, 1.570796326794896619231321691639751442099L, 8.813736713132375348727889167749389235161e-1L)
1645 TEST_c_c (cacos, -0.0L, 0x1.000002p0L, 1.570796326794896619231321691639751442099L, -8.813736713132375348727889167749389235161e-1L)
1646 TEST_c_c (cacos, -0.0L, -0x1.000002p0L, 1.570796326794896619231321691639751442099L, 8.813736713132375348727889167749389235161e-1L)
1647 TEST_c_c (cacos, 0x1.000002p0L, 0.0L, 0.0L, -4.882812451493617206486388134172712975070e-4L)
1648 TEST_c_c (cacos, -0x1.000002p0L, 0.0L, 3.141592653589793238462643383279502884197L, -4.882812451493617206486388134172712975070e-4L)
1649 TEST_c_c (cacos, 0x1.000002p0L, -0.0L, 0.0L, 4.882812451493617206486388134172712975070e-4L)
1650 TEST_c_c (cacos, -0x1.000002p0L, -0.0L, 3.141592653589793238462643383279502884197L, 4.882812451493617206486388134172712975070e-4L)
1651#ifndef TEST_FLOAT
1652 TEST_c_c (cacos, 0x1p-52L, 0x1.0000000000001p0L, 1.570796326794896462222075823262262934288L, -8.813735870195431822418551933572982483664e-1L)
1653 TEST_c_c (cacos, 0x1p-52L, -0x1.0000000000001p0L, 1.570796326794896462222075823262262934288L, 8.813735870195431822418551933572982483664e-1L)
1654 TEST_c_c (cacos, -0x1p-52L, 0x1.0000000000001p0L, 1.570796326794896776240567560017239949909L, -8.813735870195431822418551933572982483664e-1L)
1655 TEST_c_c (cacos, -0x1p-52L, -0x1.0000000000001p0L, 1.570796326794896776240567560017239949909L, 8.813735870195431822418551933572982483664e-1L)
1656 TEST_c_c (cacos, 0x1.0000000000001p0L, 0x1p-52L, 9.590301705980041385828904092662391018164e-9L, -2.315303644582684770975188768022139415020e-8L)
1657 TEST_c_c (cacos, -0x1.0000000000001p0L, 0x1p-52L, 3.141592643999491532482601997450598791535L, -2.315303644582684770975188768022139415020e-8L)
1658 TEST_c_c (cacos, 0x1.0000000000001p0L, -0x1p-52L, 9.590301705980041385828904092662391018164e-9L, 2.315303644582684770975188768022139415020e-8L)
1659 TEST_c_c (cacos, -0x1.0000000000001p0L, -0x1p-52L, 3.141592643999491532482601997450598791535L, 2.315303644582684770975188768022139415020e-8L)
1660 TEST_c_c (cacos, 0x1.fp-1025L, 0x1.0000000000001p0L, 1.570796326794896619231321691639751442099L, -8.813735870195431822418551933572895326024e-1L)
1661 TEST_c_c (cacos, 0x1.fp-1025L, -0x1.0000000000001p0L, 1.570796326794896619231321691639751442099L, 8.813735870195431822418551933572895326024e-1L)
1662 TEST_c_c (cacos, -0x1.fp-1025L, 0x1.0000000000001p0L, 1.570796326794896619231321691639751442099L, -8.813735870195431822418551933572895326024e-1L)
1663 TEST_c_c (cacos, -0x1.fp-1025L, -0x1.0000000000001p0L, 1.570796326794896619231321691639751442099L, 8.813735870195431822418551933572895326024e-1L)
1664 TEST_c_c (cacos, 0x1.0000000000001p0L, 0x1.fp-1025L, 2.557178503953494342609835913586108008322e-301L, -2.107342425544701550354780375182800088393e-8L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM)
1665 TEST_c_c (cacos, -0x1.0000000000001p0L, 0x1.fp-1025L, 3.141592653589793238462643383279502884197L, -2.107342425544701550354780375182800088393e-8L)
1666 TEST_c_c (cacos, 0x1.0000000000001p0L, -0x1.fp-1025L, 2.557178503953494342609835913586108008322e-301L, 2.107342425544701550354780375182800088393e-8L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM)
1667 TEST_c_c (cacos, -0x1.0000000000001p0L, -0x1.fp-1025L, 3.141592653589793238462643383279502884197L, 2.107342425544701550354780375182800088393e-8L)
1668 TEST_c_c (cacos, 0.0L, 0x1.0000000000001p0L, 1.570796326794896619231321691639751442099L, -8.813735870195431822418551933572895326024e-1L)
1669 TEST_c_c (cacos, 0.0L, -0x1.0000000000001p0L, 1.570796326794896619231321691639751442099L, 8.813735870195431822418551933572895326024e-1L)
1670 TEST_c_c (cacos, -0.0L, 0x1.0000000000001p0L, 1.570796326794896619231321691639751442099L, -8.813735870195431822418551933572895326024e-1L)
1671 TEST_c_c (cacos, -0.0L, -0x1.0000000000001p0L, 1.570796326794896619231321691639751442099L, 8.813735870195431822418551933572895326024e-1L)
1672 TEST_c_c (cacos, 0x1.0000000000001p0L, 0.0L, 0.0L, -2.107342425544701550354780375182800088393e-8L)
1673 TEST_c_c (cacos, -0x1.0000000000001p0L, 0.0L, 3.141592653589793238462643383279502884197L, -2.107342425544701550354780375182800088393e-8L)
1674 TEST_c_c (cacos, 0x1.0000000000001p0L, -0.0L, 0.0L, 2.107342425544701550354780375182800088393e-8L)
1675 TEST_c_c (cacos, -0x1.0000000000001p0L, -0.0L, 3.141592653589793238462643383279502884197L, 2.107342425544701550354780375182800088393e-8L)
1676#endif
1677#if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 64
1678 TEST_c_c (cacos, 0x1p-63L, 0x1.0000000000000002p0L, 1.570796326794896619154657020805582738031L, -8.813735870195430253092739958139610131001e-1L)
1679 TEST_c_c (cacos, 0x1p-63L, -0x1.0000000000000002p0L, 1.570796326794896619154657020805582738031L, 8.813735870195430253092739958139610131001e-1L)
1680 TEST_c_c (cacos, -0x1p-63L, 0x1.0000000000000002p0L, 1.570796326794896619307986362473920146166L, -8.813735870195430253092739958139610131001e-1L)
1681 TEST_c_c (cacos, -0x1p-63L, -0x1.0000000000000002p0L, 1.570796326794896619307986362473920146166L, 8.813735870195430253092739958139610131001e-1L)
1682 TEST_c_c (cacos, 0x1.0000000000000002p0L, 0x1p-63L, 2.119177303101063432592523199680782317447e-10L, -5.116146586219826555037807251857670783420e-10L)
1683 TEST_c_c (cacos, -0x1.0000000000000002p0L, 0x1p-63L, 3.141592653377875508152537040020250564229L, -5.116146586219826555037807251857670783420e-10L)
1684 TEST_c_c (cacos, 0x1.0000000000000002p0L, -0x1p-63L, 2.119177303101063432592523199680782317447e-10L, 5.116146586219826555037807251857670783420e-10L)
1685 TEST_c_c (cacos, -0x1.0000000000000002p0L, -0x1p-63L, 3.141592653377875508152537040020250564229L, 5.116146586219826555037807251857670783420e-10L)
1686# if LDBL_MIN_EXP <= -16381
1687 TEST_c_c (cacos, 0x1.fp-16385L, 0x1.0000000000000002p0L, 1.570796326794896619231321691639751442099L, -8.813735870195430253092739958139610130980e-1L)
1688 TEST_c_c (cacos, 0x1.fp-16385L, -0x1.0000000000000002p0L, 1.570796326794896619231321691639751442099L, 8.813735870195430253092739958139610130980e-1L)
1689 TEST_c_c (cacos, -0x1.fp-16385L, 0x1.0000000000000002p0L, 1.570796326794896619231321691639751442099L, -8.813735870195430253092739958139610130980e-1L)
1690 TEST_c_c (cacos, -0x1.fp-16385L, -0x1.0000000000000002p0L, 1.570796326794896619231321691639751442099L, 8.813735870195430253092739958139610130980e-1L)
1691 TEST_c_c (cacos, 0x1.0000000000000002p0L, 0x1.fp-16385L, 1.748608650034385653922359120438227480943e-4923L, -4.656612873077392578082927418388212703712e-10L)
1692 TEST_c_c (cacos, -0x1.0000000000000002p0L, 0x1.fp-16385L, 3.141592653589793238462643383279502884197L, -4.656612873077392578082927418388212703712e-10L)
1693 TEST_c_c (cacos, 0x1.0000000000000002p0L, -0x1.fp-16385L, 1.748608650034385653922359120438227480943e-4923L, 4.656612873077392578082927418388212703712e-10L)
1694 TEST_c_c (cacos, -0x1.0000000000000002p0L, -0x1.fp-16385L, 3.141592653589793238462643383279502884197L, 4.656612873077392578082927418388212703712e-10L)
1695# endif
1696 TEST_c_c (cacos, 0.0L, 0x1.0000000000000002p0L, 1.570796326794896619231321691639751442099L, -8.813735870195430253092739958139610130980e-1L)
1697 TEST_c_c (cacos, 0.0L, -0x1.0000000000000002p0L, 1.570796326794896619231321691639751442099L, 8.813735870195430253092739958139610130980e-1L)
1698 TEST_c_c (cacos, -0.0L, 0x1.0000000000000002p0L, 1.570796326794896619231321691639751442099L, -8.813735870195430253092739958139610130980e-1L)
1699 TEST_c_c (cacos, -0.0L, -0x1.0000000000000002p0L, 1.570796326794896619231321691639751442099L, 8.813735870195430253092739958139610130980e-1L)
1700 TEST_c_c (cacos, 0x1.0000000000000002p0L, 0.0L, 0.0L, -4.656612873077392578082927418388212703712e-10L)
1701 TEST_c_c (cacos, -0x1.0000000000000002p0L, 0.0L, 3.141592653589793238462643383279502884197L, -4.656612873077392578082927418388212703712e-10L)
1702 TEST_c_c (cacos, 0x1.0000000000000002p0L, -0.0L, 0.0L, 4.656612873077392578082927418388212703712e-10L)
1703 TEST_c_c (cacos, -0x1.0000000000000002p0L, -0.0L, 3.141592653589793238462643383279502884197L, 4.656612873077392578082927418388212703712e-10L)
1704#endif
1705#if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 106
1706 TEST_c_c (cacos, 0x1p-106L, 0x1.000000000000000000000000008p0L, 1.570796326794896619231321691639742726335L, -8.813735870195430252326093249798097405561e-1L)
1707 TEST_c_c (cacos, 0x1p-106L, -0x1.000000000000000000000000008p0L, 1.570796326794896619231321691639742726335L, 8.813735870195430252326093249798097405561e-1L)
1708 TEST_c_c (cacos, -0x1p-106L, 0x1.000000000000000000000000008p0L, 1.570796326794896619231321691639760157863L, -8.813735870195430252326093249798097405561e-1L)
1709 TEST_c_c (cacos, -0x1p-106L, -0x1.000000000000000000000000008p0L, 1.570796326794896619231321691639760157863L, 8.813735870195430252326093249798097405561e-1L)
1710 TEST_c_c (cacos, 0x1.000000000000000000000000008p0L, 0x1p-106L, 5.394221422390606848017034778914096659726e-17L, -2.285028863093221674154232933662774454211e-16L)
1711 TEST_c_c (cacos, -0x1.000000000000000000000000008p0L, 0x1p-106L, 3.141592653589793184520429159373434404027L, -2.285028863093221674154232933662774454211e-16L)
1712 TEST_c_c (cacos, 0x1.000000000000000000000000008p0L, -0x1p-106L, 5.394221422390606848017034778914096659726e-17L, 2.285028863093221674154232933662774454211e-16L)
1713 TEST_c_c (cacos, -0x1.000000000000000000000000008p0L, -0x1p-106L, 3.141592653589793184520429159373434404027L, 2.285028863093221674154232933662774454211e-16L)
1714 TEST_c_c (cacos, 0x1.fp-1025L, 0x1.000000000000000000000000008p0L, 1.570796326794896619231321691639751442099L, -8.813735870195430252326093249798097405561e-1L)
1715 TEST_c_c (cacos, 0x1.fp-1025L, -0x1.000000000000000000000000008p0L, 1.570796326794896619231321691639751442099L, 8.813735870195430252326093249798097405561e-1L)
1716 TEST_c_c (cacos, -0x1.fp-1025L, 0x1.000000000000000000000000008p0L, 1.570796326794896619231321691639751442099L, -8.813735870195430252326093249798097405561e-1L)
1717 TEST_c_c (cacos, -0x1.fp-1025L, -0x1.000000000000000000000000008p0L, 1.570796326794896619231321691639751442099L, 8.813735870195430252326093249798097405561e-1L)
1718 TEST_c_c (cacos, 0x1.000000000000000000000000008p0L, 0x1.fp-1025L, 2.426922623448365473354662093431821897807e-293L, -2.220446049250313080847263336181636063482e-16L)
1719 TEST_c_c (cacos, -0x1.000000000000000000000000008p0L, 0x1.fp-1025L, 3.141592653589793238462643383279502884197L, -2.220446049250313080847263336181636063482e-16L)
1720 TEST_c_c (cacos, 0x1.000000000000000000000000008p0L, -0x1.fp-1025L, 2.426922623448365473354662093431821897807e-293L, 2.220446049250313080847263336181636063482e-16L)
1721 TEST_c_c (cacos, -0x1.000000000000000000000000008p0L, -0x1.fp-1025L, 3.141592653589793238462643383279502884197L, 2.220446049250313080847263336181636063482e-16L)
1722 TEST_c_c (cacos, 0.0L, 0x1.000000000000000000000000008p0L, 1.570796326794896619231321691639751442099L, -8.813735870195430252326093249798097405561e-1L)
1723 TEST_c_c (cacos, 0.0L, -0x1.000000000000000000000000008p0L, 1.570796326794896619231321691639751442099L, 8.813735870195430252326093249798097405561e-1L)
1724 TEST_c_c (cacos, -0.0L, 0x1.000000000000000000000000008p0L, 1.570796326794896619231321691639751442099L, -8.813735870195430252326093249798097405561e-1L)
1725 TEST_c_c (cacos, -0.0L, -0x1.000000000000000000000000008p0L, 1.570796326794896619231321691639751442099L, 8.813735870195430252326093249798097405561e-1L)
1726 TEST_c_c (cacos, 0x1.000000000000000000000000008p0L, 0.0L, 0.0L, -2.220446049250313080847263336181636063482e-16L)
1727 TEST_c_c (cacos, -0x1.000000000000000000000000008p0L, 0.0L, 3.141592653589793238462643383279502884197L, -2.220446049250313080847263336181636063482e-16L)
1728 TEST_c_c (cacos, 0x1.000000000000000000000000008p0L, -0.0L, 0.0L, 2.220446049250313080847263336181636063482e-16L)
1729 TEST_c_c (cacos, -0x1.000000000000000000000000008p0L, -0.0L, 3.141592653589793238462643383279502884197L, 2.220446049250313080847263336181636063482e-16L)
1730#endif
1731#if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 113
1732 TEST_c_c (cacos, 0x1p-113L, 0x1.0000000000000000000000000001p0L, 1.570796326794896619231321691639751374007L, -8.813735870195430252326093249797924452120e-1L)
1733 TEST_c_c (cacos, 0x1p-113L, -0x1.0000000000000000000000000001p0L, 1.570796326794896619231321691639751374007L, 8.813735870195430252326093249797924452120e-1L)
1734 TEST_c_c (cacos, -0x1p-113L, 0x1.0000000000000000000000000001p0L, 1.570796326794896619231321691639751510190L, -8.813735870195430252326093249797924452120e-1L)
1735 TEST_c_c (cacos, -0x1p-113L, -0x1.0000000000000000000000000001p0L, 1.570796326794896619231321691639751510190L, 8.813735870195430252326093249797924452120e-1L)
1736 TEST_c_c (cacos, 0x1.0000000000000000000000000001p0L, 0x1p-113L, 4.767863183742677481693563511435642755521e-18L, -2.019699255375255198156433710951064632386e-17L)
1737 TEST_c_c (cacos, -0x1.0000000000000000000000000001p0L, 0x1p-113L, 3.141592653589793233694780199536825402504L, -2.019699255375255198156433710951064632386e-17L)
1738 TEST_c_c (cacos, 0x1.0000000000000000000000000001p0L, -0x1p-113L, 4.767863183742677481693563511435642755521e-18L, 2.019699255375255198156433710951064632386e-17L)
1739 TEST_c_c (cacos, -0x1.0000000000000000000000000001p0L, -0x1p-113L, 3.141592653589793233694780199536825402504L, 2.019699255375255198156433710951064632386e-17L)
1740 TEST_c_c (cacos, 0x1.fp-16385L, 0x1.0000000000000000000000000001p0L, 1.570796326794896619231321691639751442099L, -8.813735870195430252326093249797924452120e-1L)
1741 TEST_c_c (cacos, 0x1.fp-16385L, -0x1.0000000000000000000000000001p0L, 1.570796326794896619231321691639751442099L, 8.813735870195430252326093249797924452120e-1L)
1742 TEST_c_c (cacos, -0x1.fp-16385L, 0x1.0000000000000000000000000001p0L, 1.570796326794896619231321691639751442099L, -8.813735870195430252326093249797924452120e-1L)
1743 TEST_c_c (cacos, -0x1.fp-16385L, -0x1.0000000000000000000000000001p0L, 1.570796326794896619231321691639751442099L, 8.813735870195430252326093249797924452120e-1L)
1744 TEST_c_c (cacos, 0x1.0000000000000000000000000001p0L, 0x1.fp-16385L, 4.148847925325683229178506116378864361396e-4916L, -1.962615573354718824241727964954454332780e-17L)
1745 TEST_c_c (cacos, -0x1.0000000000000000000000000001p0L, 0x1.fp-16385L, 3.141592653589793238462643383279502884197L, -1.962615573354718824241727964954454332780e-17L)
1746 TEST_c_c (cacos, 0x1.0000000000000000000000000001p0L, -0x1.fp-16385L, 4.148847925325683229178506116378864361396e-4916L, 1.962615573354718824241727964954454332780e-17L)
1747 TEST_c_c (cacos, -0x1.0000000000000000000000000001p0L, -0x1.fp-16385L, 3.141592653589793238462643383279502884197L, 1.962615573354718824241727964954454332780e-17L)
1748 TEST_c_c (cacos, 0.0L, 0x1.0000000000000000000000000001p0L, 1.570796326794896619231321691639751442099L, -8.813735870195430252326093249797924452120e-1L)
1749 TEST_c_c (cacos, 0.0L, -0x1.0000000000000000000000000001p0L, 1.570796326794896619231321691639751442099L, 8.813735870195430252326093249797924452120e-1L)
1750 TEST_c_c (cacos, -0.0L, 0x1.0000000000000000000000000001p0L, 1.570796326794896619231321691639751442099L, -8.813735870195430252326093249797924452120e-1L)
1751 TEST_c_c (cacos, -0.0L, -0x1.0000000000000000000000000001p0L, 1.570796326794896619231321691639751442099L, 8.813735870195430252326093249797924452120e-1L)
1752 TEST_c_c (cacos, 0x1.0000000000000000000000000001p0L, 0.0L, 0.0L, -1.962615573354718824241727964954454332780e-17L)
1753 TEST_c_c (cacos, -0x1.0000000000000000000000000001p0L, 0.0L, 3.141592653589793238462643383279502884197L, -1.962615573354718824241727964954454332780e-17L)
1754 TEST_c_c (cacos, 0x1.0000000000000000000000000001p0L, -0.0L, 0.0L, 1.962615573354718824241727964954454332780e-17L)
1755 TEST_c_c (cacos, -0x1.0000000000000000000000000001p0L, -0.0L, 3.141592653589793238462643383279502884197L, 1.962615573354718824241727964954454332780e-17L)
1756#endif
1757
ccc8cadf
JM
1758 TEST_c_c (cacos, 0x1p-23L, 0x0.ffffffp0L, 1.570796242501197085295336701632142060969L, -8.813735448726963984495965873956465777250e-1L);
1759 TEST_c_c (cacos, 0x1p-23L, -0x0.ffffffp0L, 1.570796242501197085295336701632142060969L, 8.813735448726963984495965873956465777250e-1L);
1760 TEST_c_c (cacos, -0x1p-23L, 0x0.ffffffp0L, 1.570796411088596153167306681647360823228L, -8.813735448726963984495965873956465777250e-1L);
1761 TEST_c_c (cacos, -0x1p-23L, -0x0.ffffffp0L, 1.570796411088596153167306681647360823228L, 8.813735448726963984495965873956465777250e-1L);
1762 TEST_c_c (cacos, 0x0.ffffffp0L, 0x1p-23L, 4.391863861910487109445187743978204002614e-4L, -2.714321200917194650737217746780928423385e-4L);
1763 TEST_c_c (cacos, -0x0.ffffffp0L, 0x1p-23L, 3.141153467203602189751698864505105063797L, -2.714321200917194650737217746780928423385e-4L);
1764 TEST_c_c (cacos, 0x0.ffffffp0L, -0x1p-23L, 4.391863861910487109445187743978204002614e-4L, 2.714321200917194650737217746780928423385e-4L);
1765 TEST_c_c (cacos, -0x0.ffffffp0L, -0x1p-23L, 3.141153467203602189751698864505105063797L, 2.714321200917194650737217746780928423385e-4L);
1766 TEST_c_c (cacos, 0x1.fp-129L, 0x0.ffffffp0L, 1.570796326794896619231321691639751442097L, -8.813735448726938863015878255140556727969e-1L);
1767 TEST_c_c (cacos, 0x1.fp-129L, -0x0.ffffffp0L, 1.570796326794896619231321691639751442097L, 8.813735448726938863015878255140556727969e-1L);
1768 TEST_c_c (cacos, -0x1.fp-129L, 0x0.ffffffp0L, 1.570796326794896619231321691639751442101L, -8.813735448726938863015878255140556727969e-1L);
1769 TEST_c_c (cacos, -0x1.fp-129L, -0x0.ffffffp0L, 1.570796326794896619231321691639751442101L, 8.813735448726938863015878255140556727969e-1L);
1770 TEST_c_c (cacos, 0x0.ffffffp0L, 0x1.fp-129L, 3.452669847162035876032494826387364972849e-4L, -8.245504387859737323891843603996428534945e-36L);
1771 TEST_c_c (cacos, -0x0.ffffffp0L, 0x1.fp-129L, 3.141247386605077034875040133796864147700L, -8.245504387859737323891843603996428534945e-36L);
1772 TEST_c_c (cacos, 0x0.ffffffp0L, -0x1.fp-129L, 3.452669847162035876032494826387364972849e-4L, 8.245504387859737323891843603996428534945e-36L);
1773 TEST_c_c (cacos, -0x0.ffffffp0L, -0x1.fp-129L, 3.141247386605077034875040133796864147700L, 8.245504387859737323891843603996428534945e-36L);
1774 TEST_c_c (cacos, 0.0L, 0x0.ffffffp0L, 1.570796326794896619231321691639751442099L, -8.813735448726938863015878255140556727969e-1L);
1775 TEST_c_c (cacos, 0.0L, -0x0.ffffffp0L, 1.570796326794896619231321691639751442099L, 8.813735448726938863015878255140556727969e-1L);
1776 TEST_c_c (cacos, -0.0L, 0x0.ffffffp0L, 1.570796326794896619231321691639751442099L, -8.813735448726938863015878255140556727969e-1L);
1777 TEST_c_c (cacos, -0.0L, -0x0.ffffffp0L, 1.570796326794896619231321691639751442099L, 8.813735448726938863015878255140556727969e-1L);
1778 TEST_c_c (cacos, 0x0.ffffffp0L, 0.0L, 3.452669847162035876032494826387364972849e-4L, -0.0L);
1779 TEST_c_c (cacos, -0x0.ffffffp0L, 0.0L, 3.141247386605077034875040133796864147700L, -0.0L);
1780 TEST_c_c (cacos, 0x0.ffffffp0L, -0.0L, 3.452669847162035876032494826387364972849e-4L, 0.0L);
1781 TEST_c_c (cacos, -0x0.ffffffp0L, -0.0L, 3.141247386605077034875040133796864147700L, 0.0L);
1782 TEST_c_c (cacos, 0x1p-23L, 0.5L, 1.570796220170866625230343643673321150378L, -4.812118250596059896127318386463676808798e-1L);
1783 TEST_c_c (cacos, 0x1p-23L, -0.5L, 1.570796220170866625230343643673321150378L, 4.812118250596059896127318386463676808798e-1L);
1784 TEST_c_c (cacos, -0x1p-23L, 0.5L, 1.570796433418926613232299739606181733819L, -4.812118250596059896127318386463676808798e-1L);
1785 TEST_c_c (cacos, -0x1p-23L, -0.5L, 1.570796433418926613232299739606181733819L, 4.812118250596059896127318386463676808798e-1L);
1786 TEST_c_c (cacos, 0.5L, 0x1p-23L, 1.047197551196603215914744618665204532273L, -1.376510308240943236356088341381173571841e-7L);
1787 TEST_c_c (cacos, -0.5L, 0x1p-23L, 2.094395102393190022547898764614298351924L, -1.376510308240943236356088341381173571841e-7L);
1788 TEST_c_c (cacos, 0.5L, -0x1p-23L, 1.047197551196603215914744618665204532273L, 1.376510308240943236356088341381173571841e-7L);
1789 TEST_c_c (cacos, -0.5L, -0x1p-23L, 2.094395102393190022547898764614298351924L, 1.376510308240943236356088341381173571841e-7L);
1790 TEST_c_c (cacos, 0x1.fp-129L, 0.5L, 1.570796326794896619231321691639751442096L, -4.812118250596034474977589134243684231352e-1L);
1791 TEST_c_c (cacos, 0x1.fp-129L, -0.5L, 1.570796326794896619231321691639751442096L, 4.812118250596034474977589134243684231352e-1L);
1792 TEST_c_c (cacos, -0x1.fp-129L, 0.5L, 1.570796326794896619231321691639751442101L, -4.812118250596034474977589134243684231352e-1L);
1793 TEST_c_c (cacos, -0x1.fp-129L, -0.5L, 1.570796326794896619231321691639751442101L, 4.812118250596034474977589134243684231352e-1L);
1794 TEST_c_c (cacos, 0.5L, 0x1.fp-129L, 1.047197551196597746154214461093167628066L, -3.287317402534702257036015056278368274737e-39L, UNDERFLOW_EXCEPTION_FLOAT);
1795 TEST_c_c (cacos, -0.5L, 0x1.fp-129L, 2.094395102393195492308428922186335256131L, -3.287317402534702257036015056278368274737e-39L, UNDERFLOW_EXCEPTION_FLOAT);
1796 TEST_c_c (cacos, 0.5L, -0x1.fp-129L, 1.047197551196597746154214461093167628066L, 3.287317402534702257036015056278368274737e-39L, UNDERFLOW_EXCEPTION_FLOAT);
1797 TEST_c_c (cacos, -0.5L, -0x1.fp-129L, 2.094395102393195492308428922186335256131L, 3.287317402534702257036015056278368274737e-39L, UNDERFLOW_EXCEPTION_FLOAT);
1798 TEST_c_c (cacos, 0x1p-23L, 0x1p-23L, 1.570796207585607068450636380271254316214L, -1.192092895507818146886315028596704749235e-7L);
1799 TEST_c_c (cacos, 0x1p-23L, -0x1p-23L, 1.570796207585607068450636380271254316214L, 1.192092895507818146886315028596704749235e-7L);
1800 TEST_c_c (cacos, -0x1p-23L, 0x1p-23L, 1.570796446004186170012007003008248567984L, -1.192092895507818146886315028596704749235e-7L);
1801 TEST_c_c (cacos, -0x1p-23L, -0x1p-23L, 1.570796446004186170012007003008248567984L, 1.192092895507818146886315028596704749235e-7L);
1802 TEST_c_c (cacos, 0x1.fp-129L, 0x1p-23L, 1.570796326794896619231321691639751442096L, -1.192092895507809676556842485683592032154e-7L);
1803 TEST_c_c (cacos, 0x1.fp-129L, -0x1p-23L, 1.570796326794896619231321691639751442096L, 1.192092895507809676556842485683592032154e-7L);
1804 TEST_c_c (cacos, -0x1.fp-129L, 0x1p-23L, 1.570796326794896619231321691639751442101L, -1.192092895507809676556842485683592032154e-7L);
1805 TEST_c_c (cacos, -0x1.fp-129L, -0x1p-23L, 1.570796326794896619231321691639751442101L, 1.192092895507809676556842485683592032154e-7L);
1806 TEST_c_c (cacos, 0x1p-23L, 0x1.fp-129L, 1.570796207585607068449789347324000006847L, -2.846900380897747786805634596726756660388e-39L, UNDERFLOW_EXCEPTION_FLOAT);
1807 TEST_c_c (cacos, -0x1p-23L, 0x1.fp-129L, 1.570796446004186170012854035955502877351L, -2.846900380897747786805634596726756660388e-39L, UNDERFLOW_EXCEPTION_FLOAT);
1808 TEST_c_c (cacos, 0x1p-23L, -0x1.fp-129L, 1.570796207585607068449789347324000006847L, 2.846900380897747786805634596726756660388e-39L, UNDERFLOW_EXCEPTION_FLOAT);
1809 TEST_c_c (cacos, -0x1p-23L, -0x1.fp-129L, 1.570796446004186170012854035955502877351L, 2.846900380897747786805634596726756660388e-39L, UNDERFLOW_EXCEPTION_FLOAT);
1810 TEST_c_c (cacos, 0.0L, 0x1p-23L, 1.570796326794896619231321691639751442099L, -1.192092895507809676556842485683592032154e-7L);
1811 TEST_c_c (cacos, 0.0L, -0x1p-23L, 1.570796326794896619231321691639751442099L, 1.192092895507809676556842485683592032154e-7L);
1812 TEST_c_c (cacos, -0.0L, 0x1p-23L, 1.570796326794896619231321691639751442099L, -1.192092895507809676556842485683592032154e-7L);
1813 TEST_c_c (cacos, -0.0L, -0x1p-23L, 1.570796326794896619231321691639751442099L, 1.192092895507809676556842485683592032154e-7L);
1814 TEST_c_c (cacos, 0x1p-23L, 0.0L, 1.570796207585607068449789347324000006847L, -0.0L);
1815 TEST_c_c (cacos, -0x1p-23L, 0.0L, 1.570796446004186170012854035955502877351L, -0.0L);
1816 TEST_c_c (cacos, 0x1p-23L, -0.0L, 1.570796207585607068449789347324000006847L, 0.0L);
1817 TEST_c_c (cacos, -0x1p-23L, -0.0L, 1.570796446004186170012854035955502877351L, 0.0L);
1818 TEST_c_c (cacos, 0x1.fp-129L, 0x1.fp-129L, 1.570796326794896619231321691639751442096L, -2.846900380897727558361783801085126250967e-39L, UNDERFLOW_EXCEPTION_FLOAT);
1819 TEST_c_c (cacos, 0x1.fp-129L, -0x1.fp-129L, 1.570796326794896619231321691639751442096L, 2.846900380897727558361783801085126250967e-39L, UNDERFLOW_EXCEPTION_FLOAT);
1820 TEST_c_c (cacos, -0x1.fp-129L, 0x1.fp-129L, 1.570796326794896619231321691639751442101L, -2.846900380897727558361783801085126250967e-39L, UNDERFLOW_EXCEPTION_FLOAT);
1821 TEST_c_c (cacos, -0x1.fp-129L, -0x1.fp-129L, 1.570796326794896619231321691639751442101L, 2.846900380897727558361783801085126250967e-39L, UNDERFLOW_EXCEPTION_FLOAT);
1822#ifndef TEST_FLOAT
1823 TEST_c_c (cacos, 0x1p-52L, 0x0.fffffffffffff8p0L, 1.570796326794896462222075823262236786996L, -8.813735870195429467279863907910458761820e-1L);
1824 TEST_c_c (cacos, 0x1p-52L, -0x0.fffffffffffff8p0L, 1.570796326794896462222075823262236786996L, 8.813735870195429467279863907910458761820e-1L);
1825 TEST_c_c (cacos, -0x1p-52L, 0x0.fffffffffffff8p0L, 1.570796326794896776240567560017266097201L, -8.813735870195429467279863907910458761820e-1L);
1826 TEST_c_c (cacos, -0x1p-52L, -0x0.fffffffffffff8p0L, 1.570796326794896776240567560017266097201L, 8.813735870195429467279863907910458761820e-1L);
1827 TEST_c_c (cacos, 0x0.fffffffffffff8p0L, 0x1p-52L, 1.895456983915074112227925127005564372844e-8L, -1.171456840272878582596796205397918831268e-8L);
1828 TEST_c_c (cacos, -0x0.fffffffffffff8p0L, 0x1p-52L, 3.141592634635223399311902261000251614142L, -1.171456840272878582596796205397918831268e-8L);
1829 TEST_c_c (cacos, 0x0.fffffffffffff8p0L, -0x1p-52L, 1.895456983915074112227925127005564372844e-8L, 1.171456840272878582596796205397918831268e-8L);
1830 TEST_c_c (cacos, -0x0.fffffffffffff8p0L, -0x1p-52L, 3.141592634635223399311902261000251614142L, 1.171456840272878582596796205397918831268e-8L);
1831 TEST_c_c (cacos, 0x1.fp-1025L, 0x0.fffffffffffff8p0L, 1.570796326794896619231321691639751442099L, -8.813735870195429467279863907910371604180e-1L);
1832 TEST_c_c (cacos, 0x1.fp-1025L, -0x0.fffffffffffff8p0L, 1.570796326794896619231321691639751442099L, 8.813735870195429467279863907910371604180e-1L);
1833 TEST_c_c (cacos, -0x1.fp-1025L, 0x0.fffffffffffff8p0L, 1.570796326794896619231321691639751442099L, -8.813735870195429467279863907910371604180e-1L);
1834 TEST_c_c (cacos, -0x1.fp-1025L, -0x0.fffffffffffff8p0L, 1.570796326794896619231321691639751442099L, 8.813735870195429467279863907910371604180e-1L);
1835 TEST_c_c (cacos, 0x0.fffffffffffff8p0L, 0x1.fp-1025L, 1.490116119384765638786343542550461592240e-8L, -3.616396521699973256461764099945789620604e-301L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM);
1836 TEST_c_c (cacos, -0x0.fffffffffffff8p0L, 0x1.fp-1025L, 3.141592638688632044614986995416067458693L, -3.616396521699973256461764099945789620604e-301L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM);
1837 TEST_c_c (cacos, 0x0.fffffffffffff8p0L, -0x1.fp-1025L, 1.490116119384765638786343542550461592240e-8L, 3.616396521699973256461764099945789620604e-301L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM);
1838 TEST_c_c (cacos, -0x0.fffffffffffff8p0L, -0x1.fp-1025L, 3.141592638688632044614986995416067458693L, 3.616396521699973256461764099945789620604e-301L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM);
1839 TEST_c_c (cacos, 0.0L, 0x0.fffffffffffff8p0L, 1.570796326794896619231321691639751442099L, -8.813735870195429467279863907910371604180e-1L);
1840 TEST_c_c (cacos, 0.0L, -0x0.fffffffffffff8p0L, 1.570796326794896619231321691639751442099L, 8.813735870195429467279863907910371604180e-1L);
1841 TEST_c_c (cacos, -0.0L, 0x0.fffffffffffff8p0L, 1.570796326794896619231321691639751442099L, -8.813735870195429467279863907910371604180e-1L);
1842 TEST_c_c (cacos, -0.0L, -0x0.fffffffffffff8p0L, 1.570796326794896619231321691639751442099L, 8.813735870195429467279863907910371604180e-1L);
1843 TEST_c_c (cacos, 0x0.fffffffffffff8p0L, 0.0L, 1.490116119384765638786343542550461592240e-8L, -0.0L);
1844 TEST_c_c (cacos, -0x0.fffffffffffff8p0L, 0.0L, 3.141592638688632044614986995416067458693L, -0.0L);
1845 TEST_c_c (cacos, 0x0.fffffffffffff8p0L, -0.0L, 1.490116119384765638786343542550461592240e-8L, 0.0L);
1846 TEST_c_c (cacos, -0x0.fffffffffffff8p0L, -0.0L, 3.141592638688632044614986995416067458693L, 0.0L);
1847#endif
1848 TEST_c_c (cacos, 0x1p-52L, 0.5L, 1.570796326794896420628589431857911675917L, -4.812118250596034474977589134243772428682e-1L);
1849 TEST_c_c (cacos, 0x1p-52L, -0.5L, 1.570796326794896420628589431857911675917L, 4.812118250596034474977589134243772428682e-1L);
1850 TEST_c_c (cacos, -0x1p-52L, 0.5L, 1.570796326794896817834053951421591208280L, -4.812118250596034474977589134243772428682e-1L);
1851 TEST_c_c (cacos, -0x1p-52L, -0.5L, 1.570796326794896817834053951421591208280L, 4.812118250596034474977589134243772428682e-1L);
1852 TEST_c_c (cacos, 0.5L, 0x1p-52L, 1.047197551196597746154214461093186605110L, -2.563950248511418570403591756798643804971e-16L);
1853 TEST_c_c (cacos, -0.5L, 0x1p-52L, 2.094395102393195492308428922186316279087L, -2.563950248511418570403591756798643804971e-16L);
1854 TEST_c_c (cacos, 0.5L, -0x1p-52L, 1.047197551196597746154214461093186605110L, 2.563950248511418570403591756798643804971e-16L);
1855 TEST_c_c (cacos, -0.5L, -0x1p-52L, 2.094395102393195492308428922186316279087L, 2.563950248511418570403591756798643804971e-16L);
1856#ifndef TEST_FLOAT
1857 TEST_c_c (cacos, 0x1.fp-1025L, 0.5L, 1.570796326794896619231321691639751442099L, -4.812118250596034474977589134243684231352e-1L);
1858 TEST_c_c (cacos, 0x1.fp-1025L, -0.5L, 1.570796326794896619231321691639751442099L, 4.812118250596034474977589134243684231352e-1L);
1859 TEST_c_c (cacos, -0x1.fp-1025L, 0.5L, 1.570796326794896619231321691639751442099L, -4.812118250596034474977589134243684231352e-1L);
1860 TEST_c_c (cacos, -0x1.fp-1025L, -0.5L, 1.570796326794896619231321691639751442099L, 4.812118250596034474977589134243684231352e-1L);
1861 TEST_c_c (cacos, 0.5L, 0x1.fp-1025L, 1.047197551196597746154214461093167628066L, -6.222508863508420569166420770843207333493e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
1862 TEST_c_c (cacos, -0.5L, 0x1.fp-1025L, 2.094395102393195492308428922186335256131L, -6.222508863508420569166420770843207333493e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
1863 TEST_c_c (cacos, 0.5L, -0x1.fp-1025L, 1.047197551196597746154214461093167628066L, 6.222508863508420569166420770843207333493e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
1864 TEST_c_c (cacos, -0.5L, -0x1.fp-1025L, 2.094395102393195492308428922186335256131L, 6.222508863508420569166420770843207333493e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
1865#endif
1866 TEST_c_c (cacos, 0x1p-52L, 0x1p-52L, 1.570796326794896397186716766608443357372L, -2.220446049250313080847263336181677117148e-16L);
1867 TEST_c_c (cacos, 0x1p-52L, -0x1p-52L, 1.570796326794896397186716766608443357372L, 2.220446049250313080847263336181677117148e-16L);
1868 TEST_c_c (cacos, -0x1p-52L, 0x1p-52L, 1.570796326794896841275926616671059526825L, -2.220446049250313080847263336181677117148e-16L);
1869 TEST_c_c (cacos, -0x1p-52L, -0x1p-52L, 1.570796326794896841275926616671059526825L, 2.220446049250313080847263336181677117148e-16L);
1870#ifndef TEST_FLOAT
1871 TEST_c_c (cacos, 0x1.fp-1025L, 0x1p-52L, 1.570796326794896619231321691639751442099L, -2.220446049250313080847263336181622378926e-16L);
1872 TEST_c_c (cacos, 0x1.fp-1025L, -0x1p-52L, 1.570796326794896619231321691639751442099L, 2.220446049250313080847263336181622378926e-16L);
1873 TEST_c_c (cacos, -0x1.fp-1025L, 0x1p-52L, 1.570796326794896619231321691639751442099L, -2.220446049250313080847263336181622378926e-16L);
1874 TEST_c_c (cacos, -0x1.fp-1025L, -0x1p-52L, 1.570796326794896619231321691639751442099L, 2.220446049250313080847263336181622378926e-16L);
1875 TEST_c_c (cacos, 0x1p-52L, 0x1.fp-1025L, 1.570796326794896397186716766608443357372L, -5.388850751072128349671657362289548938458e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
1876 TEST_c_c (cacos, -0x1p-52L, 0x1.fp-1025L, 1.570796326794896841275926616671059526825L, -5.388850751072128349671657362289548938458e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
1877 TEST_c_c (cacos, 0x1p-52L, -0x1.fp-1025L, 1.570796326794896397186716766608443357372L, 5.388850751072128349671657362289548938458e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
1878 TEST_c_c (cacos, -0x1p-52L, -0x1.fp-1025L, 1.570796326794896841275926616671059526825L, 5.388850751072128349671657362289548938458e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
1879#endif
1880 TEST_c_c (cacos, 0.0L, 0x1p-52L, 1.570796326794896619231321691639751442099L, -2.220446049250313080847263336181622378926e-16L);
1881 TEST_c_c (cacos, 0.0L, -0x1p-52L, 1.570796326794896619231321691639751442099L, 2.220446049250313080847263336181622378926e-16L);
1882 TEST_c_c (cacos, -0.0L, 0x1p-52L, 1.570796326794896619231321691639751442099L, -2.220446049250313080847263336181622378926e-16L);
1883 TEST_c_c (cacos, -0.0L, -0x1p-52L, 1.570796326794896619231321691639751442099L, 2.220446049250313080847263336181622378926e-16L);
1884 TEST_c_c (cacos, 0x1p-52L, 0.0L, 1.570796326794896397186716766608443357372L, -0.0L);
1885 TEST_c_c (cacos, -0x1p-52L, 0.0L, 1.570796326794896841275926616671059526825L, -0.0L);
1886 TEST_c_c (cacos, 0x1p-52L, -0.0L, 1.570796326794896397186716766608443357372L, 0.0L);
1887 TEST_c_c (cacos, -0x1p-52L, -0.0L, 1.570796326794896841275926616671059526825L, 0.0L);
1888#ifndef TEST_FLOAT
1889 TEST_c_c (cacos, 0x1.fp-1025L, 0x1.fp-1025L, 1.570796326794896619231321691639751442099L, -5.388850751072128349671657362289416093031e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
1890 TEST_c_c (cacos, 0x1.fp-1025L, -0x1.fp-1025L, 1.570796326794896619231321691639751442099L, 5.388850751072128349671657362289416093031e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
1891 TEST_c_c (cacos, -0x1.fp-1025L, 0x1.fp-1025L, 1.570796326794896619231321691639751442099L, -5.388850751072128349671657362289416093031e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
1892 TEST_c_c (cacos, -0x1.fp-1025L, -0x1.fp-1025L, 1.570796326794896619231321691639751442099L, 5.388850751072128349671657362289416093031e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
1893#endif
1894#if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 64
1895 TEST_c_c (cacos, 0x1p-63L, 0x0.ffffffffffffffffp0L, 1.570796326794896619154657020805582738025L, -8.813735870195430251942769895627079569937e-1L);
1896 TEST_c_c (cacos, 0x1p-63L, -0x0.ffffffffffffffffp0L, 1.570796326794896619154657020805582738025L, 8.813735870195430251942769895627079569937e-1L);
1897 TEST_c_c (cacos, -0x1p-63L, 0x0.ffffffffffffffffp0L, 1.570796326794896619307986362473920146173L, -8.813735870195430251942769895627079569937e-1L);
1898 TEST_c_c (cacos, -0x1p-63L, -0x0.ffffffffffffffffp0L, 1.570796326794896619307986362473920146173L, 8.813735870195430251942769895627079569937e-1L);
1899 TEST_c_c (cacos, 0x0.ffffffffffffffffp0L, 0x1p-63L, 4.188407771167967636741951941902992986043e-10L, -2.588578361325995866221775673638805081337e-10L);
1900 TEST_c_c (cacos, -0x0.ffffffffffffffffp0L, 0x1p-63L, 3.141592653170952461345846619605307690007L, -2.588578361325995866221775673638805081337e-10L);
1901 TEST_c_c (cacos, 0x0.ffffffffffffffffp0L, -0x1p-63L, 4.188407771167967636741951941902992986043e-10L, 2.588578361325995866221775673638805081337e-10L);
1902 TEST_c_c (cacos, -0x0.ffffffffffffffffp0L, -0x1p-63L, 3.141592653170952461345846619605307690007L, 2.588578361325995866221775673638805081337e-10L);
1903# if LDBL_MIN_EXP <= -16381
1904 TEST_c_c (cacos, 0x1.fp-16385L, 0x0.ffffffffffffffffp0L, 1.570796326794896619231321691639751442099L, -8.813735870195430251942769895627079569917e-1L);
1905 TEST_c_c (cacos, 0x1.fp-16385L, -0x0.ffffffffffffffffp0L, 1.570796326794896619231321691639751442099L, 8.813735870195430251942769895627079569917e-1L);
1906 TEST_c_c (cacos, -0x1.fp-16385L, 0x0.ffffffffffffffffp0L, 1.570796326794896619231321691639751442099L, -8.813735870195430251942769895627079569917e-1L);
1907 TEST_c_c (cacos, -0x1.fp-16385L, -0x0.ffffffffffffffffp0L, 1.570796326794896619231321691639751442099L, 8.813735870195430251942769895627079569917e-1L);
1908 TEST_c_c (cacos, 0x0.ffffffffffffffffp0L, 0x1.fp-16385L, 3.292722539913596233371825532007990724506e-10L, -2.472906068161537187835415298076415423459e-4923L);
1909 TEST_c_c (cacos, -0x0.ffffffffffffffffp0L, 0x1.fp-16385L, 3.141592653260520984471283759942320330996L, -2.472906068161537187835415298076415423459e-4923L);
1910 TEST_c_c (cacos, 0x0.ffffffffffffffffp0L, -0x1.fp-16385L, 3.292722539913596233371825532007990724506e-10L, 2.472906068161537187835415298076415423459e-4923L);
1911 TEST_c_c (cacos, -0x0.ffffffffffffffffp0L, -0x1.fp-16385L, 3.141592653260520984471283759942320330996L, 2.472906068161537187835415298076415423459e-4923L);
1912# endif
1913 TEST_c_c (cacos, 0.0L, 0x0.ffffffffffffffffp0L, 1.570796326794896619231321691639751442099L, -8.813735870195430251942769895627079569917e-1L);
1914 TEST_c_c (cacos, 0.0L, -0x0.ffffffffffffffffp0L, 1.570796326794896619231321691639751442099L, 8.813735870195430251942769895627079569917e-1L);
1915 TEST_c_c (cacos, -0.0L, 0x0.ffffffffffffffffp0L, 1.570796326794896619231321691639751442099L, -8.813735870195430251942769895627079569917e-1L);
1916 TEST_c_c (cacos, -0.0L, -0x0.ffffffffffffffffp0L, 1.570796326794896619231321691639751442099L, 8.813735870195430251942769895627079569917e-1L);
1917 TEST_c_c (cacos, 0x0.ffffffffffffffffp0L, 0.0L, 3.292722539913596233371825532007990724506e-10L, -0.0L);
1918 TEST_c_c (cacos, -0x0.ffffffffffffffffp0L, 0.0L, 3.141592653260520984471283759942320330996L, -0.0L);
1919 TEST_c_c (cacos, 0x0.ffffffffffffffffp0L, -0.0L, 3.292722539913596233371825532007990724506e-10L, 0.0L);
1920 TEST_c_c (cacos, -0x0.ffffffffffffffffp0L, -0.0L, 3.141592653260520984471283759942320330996L, 0.0L);
1921#endif
1922 TEST_c_c (cacos, 0x1p-63L, 0.5L, 1.570796326794896619134347701278529840650L, -4.812118250596034474977589134243684231373e-1L);
1923 TEST_c_c (cacos, 0x1p-63L, -0.5L, 1.570796326794896619134347701278529840650L, 4.812118250596034474977589134243684231373e-1L);
1924 TEST_c_c (cacos, -0x1p-63L, 0.5L, 1.570796326794896619328295682000973043547L, -4.812118250596034474977589134243684231373e-1L);
1925 TEST_c_c (cacos, -0x1p-63L, -0.5L, 1.570796326794896619328295682000973043547L, 4.812118250596034474977589134243684231373e-1L);
1926 TEST_c_c (cacos, 0.5L, 0x1p-63L, 1.047197551196597746154214461093167628070L, -1.251928832280966098829878787499365228659e-19L);
1927 TEST_c_c (cacos, -0.5L, 0x1p-63L, 2.094395102393195492308428922186335256127L, -1.251928832280966098829878787499365228659e-19L);
1928 TEST_c_c (cacos, 0.5L, -0x1p-63L, 1.047197551196597746154214461093167628070L, 1.251928832280966098829878787499365228659e-19L);
1929 TEST_c_c (cacos, -0.5L, -0x1p-63L, 2.094395102393195492308428922186335256127L, 1.251928832280966098829878787499365228659e-19L);
1930#if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
1931 TEST_c_c (cacos, 0x1.fp-16385L, 0.5L, 1.570796326794896619231321691639751442099L, -4.812118250596034474977589134243684231352e-1L);
1932 TEST_c_c (cacos, 0x1.fp-16385L, -0.5L, 1.570796326794896619231321691639751442099L, 4.812118250596034474977589134243684231352e-1L);
1933 TEST_c_c (cacos, -0x1.fp-16385L, 0.5L, 1.570796326794896619231321691639751442099L, -4.812118250596034474977589134243684231352e-1L);
1934 TEST_c_c (cacos, -0x1.fp-16385L, -0.5L, 1.570796326794896619231321691639751442099L, 4.812118250596034474977589134243684231352e-1L);
1935 TEST_c_c (cacos, 0.5L, 0x1.fp-16385L, 1.047197551196597746154214461093167628066L, -9.402257155670418112159334875199821342890e-4933L, UNDERFLOW_EXCEPTION);
1936 TEST_c_c (cacos, -0.5L, 0x1.fp-16385L, 2.094395102393195492308428922186335256131L, -9.402257155670418112159334875199821342890e-4933L, UNDERFLOW_EXCEPTION);
1937 TEST_c_c (cacos, 0.5L, -0x1.fp-16385L, 1.047197551196597746154214461093167628066L, 9.402257155670418112159334875199821342890e-4933L, UNDERFLOW_EXCEPTION);
1938 TEST_c_c (cacos, -0.5L, -0x1.fp-16385L, 2.094395102393195492308428922186335256131L, 9.402257155670418112159334875199821342890e-4933L, UNDERFLOW_EXCEPTION);
1939#endif
1940 TEST_c_c (cacos, 0x1p-63L, 0x1p-63L, 1.570796326794896619122901474391200998698L, -1.084202172485504434007452800869941711430e-19L);
1941 TEST_c_c (cacos, 0x1p-63L, -0x1p-63L, 1.570796326794896619122901474391200998698L, 1.084202172485504434007452800869941711430e-19L);
1942 TEST_c_c (cacos, -0x1p-63L, 0x1p-63L, 1.570796326794896619339741908888301885499L, -1.084202172485504434007452800869941711430e-19L);
1943 TEST_c_c (cacos, -0x1p-63L, -0x1p-63L, 1.570796326794896619339741908888301885499L, 1.084202172485504434007452800869941711430e-19L);
1944#if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
1945 TEST_c_c (cacos, 0x1.fp-16385L, 0x1p-63L, 1.570796326794896619231321691639751442099L, -1.084202172485504434007452800869941711424e-19L);
1946 TEST_c_c (cacos, 0x1.fp-16385L, -0x1p-63L, 1.570796326794896619231321691639751442099L, 1.084202172485504434007452800869941711424e-19L);
1947 TEST_c_c (cacos, -0x1.fp-16385L, 0x1p-63L, 1.570796326794896619231321691639751442099L, -1.084202172485504434007452800869941711424e-19L);
1948 TEST_c_c (cacos, -0x1.fp-16385L, -0x1p-63L, 1.570796326794896619231321691639751442099L, 1.084202172485504434007452800869941711424e-19L);
1949 TEST_c_c (cacos, 0x1p-63L, 0x1.fp-16385L, 1.570796326794896619122901474391200998698L, -8.142593549724601460479922838826119584465e-4933L, UNDERFLOW_EXCEPTION);
1950 TEST_c_c (cacos, -0x1p-63L, 0x1.fp-16385L, 1.570796326794896619339741908888301885499L, -8.142593549724601460479922838826119584465e-4933L, UNDERFLOW_EXCEPTION);
1951 TEST_c_c (cacos, 0x1p-63L, -0x1.fp-16385L, 1.570796326794896619122901474391200998698L, 8.142593549724601460479922838826119584465e-4933L, UNDERFLOW_EXCEPTION);
1952 TEST_c_c (cacos, -0x1p-63L, -0x1.fp-16385L, 1.570796326794896619339741908888301885499L, 8.142593549724601460479922838826119584465e-4933L, UNDERFLOW_EXCEPTION);
1953#endif
1954 TEST_c_c (cacos, 0.0L, 0x1p-63L, 1.570796326794896619231321691639751442099L, -1.084202172485504434007452800869941711424e-19L);
1955 TEST_c_c (cacos, 0.0L, -0x1p-63L, 1.570796326794896619231321691639751442099L, 1.084202172485504434007452800869941711424e-19L);
1956 TEST_c_c (cacos, -0.0L, 0x1p-63L, 1.570796326794896619231321691639751442099L, -1.084202172485504434007452800869941711424e-19L);
1957 TEST_c_c (cacos, -0.0L, -0x1p-63L, 1.570796326794896619231321691639751442099L, 1.084202172485504434007452800869941711424e-19L);
1958 TEST_c_c (cacos, 0x1p-63L, 0.0L, 1.570796326794896619122901474391200998698L, -0.0L);
1959 TEST_c_c (cacos, -0x1p-63L, 0.0L, 1.570796326794896619339741908888301885499L, -0.0L);
1960 TEST_c_c (cacos, 0x1p-63L, -0.0L, 1.570796326794896619122901474391200998698L, 0.0L);
1961 TEST_c_c (cacos, -0x1p-63L, -0.0L, 1.570796326794896619339741908888301885499L, 0.0L);
1962#if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
1963 TEST_c_c (cacos, 0x1.fp-16385L, 0x1.fp-16385L, 1.570796326794896619231321691639751442099L, -8.142593549724601460479922838826119584417e-4933L, UNDERFLOW_EXCEPTION);
1964 TEST_c_c (cacos, 0x1.fp-16385L, -0x1.fp-16385L, 1.570796326794896619231321691639751442099L, 8.142593549724601460479922838826119584417e-4933L, UNDERFLOW_EXCEPTION);
1965 TEST_c_c (cacos, -0x1.fp-16385L, 0x1.fp-16385L, 1.570796326794896619231321691639751442099L, -8.142593549724601460479922838826119584417e-4933L, UNDERFLOW_EXCEPTION);
1966 TEST_c_c (cacos, -0x1.fp-16385L, -0x1.fp-16385L, 1.570796326794896619231321691639751442099L, 8.142593549724601460479922838826119584417e-4933L, UNDERFLOW_EXCEPTION);
1967#endif
1968#if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 106
1969 TEST_c_c (cacos, 0x1p-105L, 0x0.ffffffffffffffffffffffffffcp0L, 1.570796326794896619231321691639734010571L, -8.813735870195430252326093249797835932642e-1L);
1970 TEST_c_c (cacos, 0x1p-105L, -0x0.ffffffffffffffffffffffffffcp0L, 1.570796326794896619231321691639734010571L, 8.813735870195430252326093249797835932642e-1L);
1971 TEST_c_c (cacos, -0x1p-105L, 0x0.ffffffffffffffffffffffffffcp0L, 1.570796326794896619231321691639768873627L, -8.813735870195430252326093249797835932642e-1L);
1972 TEST_c_c (cacos, -0x1p-105L, -0x0.ffffffffffffffffffffffffffcp0L, 1.570796326794896619231321691639768873627L, 8.813735870195430252326093249797835932642e-1L);
1973 TEST_c_c (cacos, 0x0.ffffffffffffffffffffffffffcp0L, 0x1p-105L, 1.997188458999618357060632049675702684031e-16L, -1.234330349600789959989661887846005659983e-16L);
1974 TEST_c_c (cacos, -0x0.ffffffffffffffffffffffffffcp0L, 0x1p-105L, 3.141592653589793038743797483317667178134L, -1.234330349600789959989661887846005659983e-16L);
1975 TEST_c_c (cacos, 0x0.ffffffffffffffffffffffffffcp0L, -0x1p-105L, 1.997188458999618357060632049675702684031e-16L, 1.234330349600789959989661887846005659983e-16L);
1976 TEST_c_c (cacos, -0x0.ffffffffffffffffffffffffffcp0L, -0x1p-105L, 3.141592653589793038743797483317667178134L, 1.234330349600789959989661887846005659983e-16L);
1977 TEST_c_c (cacos, 0x1.fp-1025L, 0x0.ffffffffffffffffffffffffffcp0L, 1.570796326794896619231321691639751442099L, -8.813735870195430252326093249797835932642e-1L);
1978 TEST_c_c (cacos, 0x1.fp-1025L, -0x0.ffffffffffffffffffffffffffcp0L, 1.570796326794896619231321691639751442099L, 8.813735870195430252326093249797835932642e-1L);
1979 TEST_c_c (cacos, -0x1.fp-1025L, 0x0.ffffffffffffffffffffffffffcp0L, 1.570796326794896619231321691639751442099L, -8.813735870195430252326093249797835932642e-1L);
1980 TEST_c_c (cacos, -0x1.fp-1025L, -0x0.ffffffffffffffffffffffffffcp0L, 1.570796326794896619231321691639751442099L, 8.813735870195430252326093249797835932642e-1L);
1981 TEST_c_c (cacos, 0x0.ffffffffffffffffffffffffffcp0L, 0x1.fp-1025L, 1.570092458683775059393382371963565104164e-16L, -3.432186888910770473784103112009399360940e-293L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM);
1982 TEST_c_c (cacos, -0x0.ffffffffffffffffffffffffffcp0L, 0x1.fp-1025L, 3.141592653589793081453397514901996944859L, -3.432186888910770473784103112009399360940e-293L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM);
1983 TEST_c_c (cacos, 0x0.ffffffffffffffffffffffffffcp0L, -0x1.fp-1025L, 1.570092458683775059393382371963565104164e-16L, 3.432186888910770473784103112009399360940e-293L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM);
1984 TEST_c_c (cacos, -0x0.ffffffffffffffffffffffffffcp0L, -0x1.fp-1025L, 3.141592653589793081453397514901996944859L, 3.432186888910770473784103112009399360940e-293L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM);
1985 TEST_c_c (cacos, 0.0L, 0x0.ffffffffffffffffffffffffffcp0L, 1.570796326794896619231321691639751442099L, -8.813735870195430252326093249797835932642e-1L);
1986 TEST_c_c (cacos, 0.0L, -0x0.ffffffffffffffffffffffffffcp0L, 1.570796326794896619231321691639751442099L, 8.813735870195430252326093249797835932642e-1L);
1987 TEST_c_c (cacos, -0.0L, 0x0.ffffffffffffffffffffffffffcp0L, 1.570796326794896619231321691639751442099L, -8.813735870195430252326093249797835932642e-1L);
1988 TEST_c_c (cacos, -0.0L, -0x0.ffffffffffffffffffffffffffcp0L, 1.570796326794896619231321691639751442099L, 8.813735870195430252326093249797835932642e-1L);
1989 TEST_c_c (cacos, 0x0.ffffffffffffffffffffffffffcp0L, 0.0L, 1.570092458683775059393382371963565104164e-16L, -0.0L);
1990 TEST_c_c (cacos, -0x0.ffffffffffffffffffffffffffcp0L, 0.0L, 3.141592653589793081453397514901996944859L, -0.0L);
1991 TEST_c_c (cacos, 0x0.ffffffffffffffffffffffffffcp0L, -0.0L, 1.570092458683775059393382371963565104164e-16L, 0.0L);
1992 TEST_c_c (cacos, -0x0.ffffffffffffffffffffffffffcp0L, -0.0L, 3.141592653589793081453397514901996944859L, 0.0L);
1993#endif
1994 TEST_c_c (cacos, 0x1p-105L, 0.5L, 1.570796326794896619231321691639729392766L, -4.812118250596034474977589134243684231352e-1L);
1995 TEST_c_c (cacos, 0x1p-105L, -0.5L, 1.570796326794896619231321691639729392766L, 4.812118250596034474977589134243684231352e-1L);
1996 TEST_c_c (cacos, -0x1p-105L, 0.5L, 1.570796326794896619231321691639773491431L, -4.812118250596034474977589134243684231352e-1L);
1997 TEST_c_c (cacos, -0x1p-105L, -0.5L, 1.570796326794896619231321691639773491431L, 4.812118250596034474977589134243684231352e-1L);
1998 TEST_c_c (cacos, 0.5L, 0x1p-105L, 1.047197551196597746154214461093167628066L, -2.846556599890768890940941645338546615370e-32L);
1999 TEST_c_c (cacos, -0.5L, 0x1p-105L, 2.094395102393195492308428922186335256131L, -2.846556599890768890940941645338546615370e-32L);
2000 TEST_c_c (cacos, 0.5L, -0x1p-105L, 1.047197551196597746154214461093167628066L, 2.846556599890768890940941645338546615370e-32L);
2001 TEST_c_c (cacos, -0.5L, -0x1p-105L, 2.094395102393195492308428922186335256131L, 2.846556599890768890940941645338546615370e-32L);
2002 TEST_c_c (cacos, 0x1p-105L, 0x1p-105L, 1.570796326794896619231321691639726790195L, -2.465190328815661891911651766508706967729e-32L);
2003 TEST_c_c (cacos, 0x1p-105L, -0x1p-105L, 1.570796326794896619231321691639726790195L, 2.465190328815661891911651766508706967729e-32L);
2004 TEST_c_c (cacos, -0x1p-105L, 0x1p-105L, 1.570796326794896619231321691639776094002L, -2.465190328815661891911651766508706967729e-32L);
2005 TEST_c_c (cacos, -0x1p-105L, -0x1p-105L, 1.570796326794896619231321691639776094002L, 2.465190328815661891911651766508706967729e-32L);
2006#ifndef TEST_FLOAT
2007 TEST_c_c (cacos, 0x1.fp-1025L, 0x1p-105L, 1.570796326794896619231321691639751442099L, -2.465190328815661891911651766508706967729e-32L);
2008 TEST_c_c (cacos, 0x1.fp-1025L, -0x1p-105L, 1.570796326794896619231321691639751442099L, 2.465190328815661891911651766508706967729e-32L);
2009 TEST_c_c (cacos, -0x1.fp-1025L, 0x1p-105L, 1.570796326794896619231321691639751442099L, -2.465190328815661891911651766508706967729e-32L);
2010 TEST_c_c (cacos, -0x1.fp-1025L, -0x1p-105L, 1.570796326794896619231321691639751442099L, 2.465190328815661891911651766508706967729e-32L);
2011 TEST_c_c (cacos, 0x1p-105L, 0x1.fp-1025L, 1.570796326794896619231321691639726790195L, -5.388850751072128349671657362289416093031e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
2012 TEST_c_c (cacos, -0x1p-105L, 0x1.fp-1025L, 1.570796326794896619231321691639776094002L, -5.388850751072128349671657362289416093031e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
2013 TEST_c_c (cacos, 0x1p-105L, -0x1.fp-1025L, 1.570796326794896619231321691639726790195L, 5.388850751072128349671657362289416093031e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
2014 TEST_c_c (cacos, -0x1p-105L, -0x1.fp-1025L, 1.570796326794896619231321691639776094002L, 5.388850751072128349671657362289416093031e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
2015#endif
2016 TEST_c_c (cacos, 0.0L, 0x1p-105L, 1.570796326794896619231321691639751442099L, -2.465190328815661891911651766508706967729e-32L);
2017 TEST_c_c (cacos, 0.0L, -0x1p-105L, 1.570796326794896619231321691639751442099L, 2.465190328815661891911651766508706967729e-32L);
2018 TEST_c_c (cacos, -0.0L, 0x1p-105L, 1.570796326794896619231321691639751442099L, -2.465190328815661891911651766508706967729e-32L);
2019 TEST_c_c (cacos, -0.0L, -0x1p-105L, 1.570796326794896619231321691639751442099L, 2.465190328815661891911651766508706967729e-32L);
2020 TEST_c_c (cacos, 0x1p-105L, 0.0L, 1.570796326794896619231321691639726790195L, -0.0L);
2021 TEST_c_c (cacos, -0x1p-105L, 0.0L, 1.570796326794896619231321691639776094002L, -0.0L);
2022 TEST_c_c (cacos, 0x1p-105L, -0.0L, 1.570796326794896619231321691639726790195L, 0.0L);
2023 TEST_c_c (cacos, -0x1p-105L, -0.0L, 1.570796326794896619231321691639776094002L, 0.0L);
2024#if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 113
2025 TEST_c_c (cacos, 0x1p-112L, 0x0.ffffffffffffffffffffffffffff8p0L, 1.570796326794896619231321691639751305915L, -8.813735870195430252326093249797922409363e-1L);
2026 TEST_c_c (cacos, 0x1p-112L, -0x0.ffffffffffffffffffffffffffff8p0L, 1.570796326794896619231321691639751305915L, 8.813735870195430252326093249797922409363e-1L);
2027 TEST_c_c (cacos, -0x1p-112L, 0x0.ffffffffffffffffffffffffffff8p0L, 1.570796326794896619231321691639751578282L, -8.813735870195430252326093249797922409363e-1L);
2028 TEST_c_c (cacos, -0x1p-112L, -0x0.ffffffffffffffffffffffffffff8p0L, 1.570796326794896619231321691639751578282L, 8.813735870195430252326093249797922409363e-1L);
2029 TEST_c_c (cacos, 0x0.ffffffffffffffffffffffffffff8p0L, 0x1p-112L, 1.765281878332676474347460257221369818872e-17L, -1.091004200533850618345330909857103457781e-17L);
2030 TEST_c_c (cacos, -0x0.ffffffffffffffffffffffffffff8p0L, 0x1p-112L, 3.141592653589793220809824599952738140723L, -1.091004200533850618345330909857103457781e-17L);
2031 TEST_c_c (cacos, 0x0.ffffffffffffffffffffffffffff8p0L, -0x1p-112L, 1.765281878332676474347460257221369818872e-17L, 1.091004200533850618345330909857103457781e-17L);
2032 TEST_c_c (cacos, -0x0.ffffffffffffffffffffffffffff8p0L, -0x1p-112L, 3.141592653589793220809824599952738140723L, 1.091004200533850618345330909857103457781e-17L);
2033 TEST_c_c (cacos, 0x1.fp-16385L, 0x0.ffffffffffffffffffffffffffff8p0L, 1.570796326794896619231321691639751442099L, -8.813735870195430252326093249797922409363e-1L);
2034 TEST_c_c (cacos, 0x1.fp-16385L, -0x0.ffffffffffffffffffffffffffff8p0L, 1.570796326794896619231321691639751442099L, 8.813735870195430252326093249797922409363e-1L);
2035 TEST_c_c (cacos, -0x1.fp-16385L, 0x0.ffffffffffffffffffffffffffff8p0L, 1.570796326794896619231321691639751442099L, -8.813735870195430252326093249797922409363e-1L);
2036 TEST_c_c (cacos, -0x1.fp-16385L, -0x0.ffffffffffffffffffffffffffff8p0L, 1.570796326794896619231321691639751442099L, 8.813735870195430252326093249797922409363e-1L);
2037 TEST_c_c (cacos, 0x0.ffffffffffffffffffffffffffff8p0L, 0x1.fp-16385L, 1.387778780781445675529539585113525401762e-17L, -5.867357004219059108790368268900490184505e-4916L);
2038 TEST_c_c (cacos, -0x0.ffffffffffffffffffffffffffff8p0L, 0x1.fp-16385L, 3.141592653589793224584855575465046128902L, -5.867357004219059108790368268900490184505e-4916L);
2039 TEST_c_c (cacos, 0x0.ffffffffffffffffffffffffffff8p0L, -0x1.fp-16385L, 1.387778780781445675529539585113525401762e-17L, 5.867357004219059108790368268900490184505e-4916L);
2040 TEST_c_c (cacos, -0x0.ffffffffffffffffffffffffffff8p0L, -0x1.fp-16385L, 3.141592653589793224584855575465046128902L, 5.867357004219059108790368268900490184505e-4916L);
2041 TEST_c_c (cacos, 0.0L, 0x0.ffffffffffffffffffffffffffff8p0L, 1.570796326794896619231321691639751442099L, -8.813735870195430252326093249797922409363e-1L);
2042 TEST_c_c (cacos, 0.0L, -0x0.ffffffffffffffffffffffffffff8p0L, 1.570796326794896619231321691639751442099L, 8.813735870195430252326093249797922409363e-1L);
2043 TEST_c_c (cacos, -0.0L, 0x0.ffffffffffffffffffffffffffff8p0L, 1.570796326794896619231321691639751442099L, -8.813735870195430252326093249797922409363e-1L);
2044 TEST_c_c (cacos, -0.0L, -0x0.ffffffffffffffffffffffffffff8p0L, 1.570796326794896619231321691639751442099L, 8.813735870195430252326093249797922409363e-1L);
2045 TEST_c_c (cacos, 0x0.ffffffffffffffffffffffffffff8p0L, 0.0L, 1.387778780781445675529539585113525401762e-17L, -0.0L);
2046 TEST_c_c (cacos, -0x0.ffffffffffffffffffffffffffff8p0L, 0.0L, 3.141592653589793224584855575465046128902L, -0.0L);
2047 TEST_c_c (cacos, 0x0.ffffffffffffffffffffffffffff8p0L, -0.0L, 1.387778780781445675529539585113525401762e-17L, 0.0L);
2048 TEST_c_c (cacos, -0x0.ffffffffffffffffffffffffffff8p0L, -0.0L, 3.141592653589793224584855575465046128902L, 0.0L);
2049#endif
2050 TEST_c_c (cacos, 0x1p-112L, 0.5L, 1.570796326794896619231321691639751269838L, -4.812118250596034474977589134243684231352e-1L);
2051 TEST_c_c (cacos, 0x1p-112L, -0.5L, 1.570796326794896619231321691639751269838L, 4.812118250596034474977589134243684231352e-1L);
2052 TEST_c_c (cacos, -0x1p-112L, 0.5L, 1.570796326794896619231321691639751614359L, -4.812118250596034474977589134243684231352e-1L);
2053 TEST_c_c (cacos, -0x1p-112L, -0.5L, 1.570796326794896619231321691639751614359L, 4.812118250596034474977589134243684231352e-1L);
2054 TEST_c_c (cacos, 0.5L, 0x1p-112L, 1.047197551196597746154214461093167628066L, -2.223872343664663196047610660420739543258e-34L);
2055 TEST_c_c (cacos, -0.5L, 0x1p-112L, 2.094395102393195492308428922186335256131L, -2.223872343664663196047610660420739543258e-34L);
2056 TEST_c_c (cacos, 0.5L, -0x1p-112L, 1.047197551196597746154214461093167628066L, 2.223872343664663196047610660420739543258e-34L);
2057 TEST_c_c (cacos, -0.5L, -0x1p-112L, 2.094395102393195492308428922186335256131L, 2.223872343664663196047610660420739543258e-34L);
2058 TEST_c_c (cacos, 0x1p-112L, 0x1p-112L, 1.570796326794896619231321691639751249506L, -1.925929944387235853055977942584927318538e-34L);
2059 TEST_c_c (cacos, 0x1p-112L, -0x1p-112L, 1.570796326794896619231321691639751249506L, 1.925929944387235853055977942584927318538e-34L);
2060 TEST_c_c (cacos, -0x1p-112L, 0x1p-112L, 1.570796326794896619231321691639751634692L, -1.925929944387235853055977942584927318538e-34L);
2061 TEST_c_c (cacos, -0x1p-112L, -0x1p-112L, 1.570796326794896619231321691639751634692L, 1.925929944387235853055977942584927318538e-34L);
2062#if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
2063 TEST_c_c (cacos, 0x1.fp-16385L, 0x1p-112L, 1.570796326794896619231321691639751442099L, -1.925929944387235853055977942584927318538e-34L);
2064 TEST_c_c (cacos, 0x1.fp-16385L, -0x1p-112L, 1.570796326794896619231321691639751442099L, 1.925929944387235853055977942584927318538e-34L);
2065 TEST_c_c (cacos, -0x1.fp-16385L, 0x1p-112L, 1.570796326794896619231321691639751442099L, -1.925929944387235853055977942584927318538e-34L);
2066 TEST_c_c (cacos, -0x1.fp-16385L, -0x1p-112L, 1.570796326794896619231321691639751442099L, 1.925929944387235853055977942584927318538e-34L);
2067 TEST_c_c (cacos, 0x1p-112L, 0x1.fp-16385L, 1.570796326794896619231321691639751249506L, -8.142593549724601460479922838826119584417e-4933L, UNDERFLOW_EXCEPTION);
2068 TEST_c_c (cacos, -0x1p-112L, 0x1.fp-16385L, 1.570796326794896619231321691639751634692L, -8.142593549724601460479922838826119584417e-4933L, UNDERFLOW_EXCEPTION);
2069 TEST_c_c (cacos, 0x1p-112L, -0x1.fp-16385L, 1.570796326794896619231321691639751249506L, 8.142593549724601460479922838826119584417e-4933L, UNDERFLOW_EXCEPTION);
2070 TEST_c_c (cacos, -0x1p-112L, -0x1.fp-16385L, 1.570796326794896619231321691639751634692L, 8.142593549724601460479922838826119584417e-4933L, UNDERFLOW_EXCEPTION);
2071#endif
2072 TEST_c_c (cacos, 0.0L, 0x1p-112L, 1.570796326794896619231321691639751442099L, -1.925929944387235853055977942584927318538e-34L);
2073 TEST_c_c (cacos, 0.0L, -0x1p-112L, 1.570796326794896619231321691639751442099L, 1.925929944387235853055977942584927318538e-34L);
2074 TEST_c_c (cacos, -0.0L, 0x1p-112L, 1.570796326794896619231321691639751442099L, -1.925929944387235853055977942584927318538e-34L);
2075 TEST_c_c (cacos, -0.0L, -0x1p-112L, 1.570796326794896619231321691639751442099L, 1.925929944387235853055977942584927318538e-34L);
2076 TEST_c_c (cacos, 0x1p-112L, 0.0L, 1.570796326794896619231321691639751249506L, -0.0L);
2077 TEST_c_c (cacos, -0x1p-112L, 0.0L, 1.570796326794896619231321691639751634692L, -0.0L);
2078 TEST_c_c (cacos, 0x1p-112L, -0.0L, 1.570796326794896619231321691639751249506L, 0.0L);
2079 TEST_c_c (cacos, -0x1p-112L, -0.0L, 1.570796326794896619231321691639751634692L, 0.0L);
2080
2550dfe9 2081 TEST_c_c (cacos, 0.75L, 1.25L, 1.11752014915610270578240049553777969L, -1.13239363160530819522266333696834467L);
33e885db 2082 TEST_c_c (cacos, -2, -3, 2.1414491111159960199416055713254211L, 1.9833870299165354323470769028940395L);
8847214f 2083
6815fabc 2084 END (cacos, complex);
8847214f
UD
2085}
2086
8847214f
UD
2087static void
2088cacosh_test (void)
2089{
aaca11d8 2090 errno = 0;
3c6cad26 2091 FUNC(cacosh) (BUILD_COMPLEX (0.7L, 1.2L));
aaca11d8
UD
2092 if (errno == ENOSYS)
2093 /* Function not implemented. */
2094 return;
2095
8847214f
UD
2096 START (cacosh);
2097
2098
2099 TEST_c_c (cacosh, 0, 0, 0.0, M_PI_2l);
2100 TEST_c_c (cacosh, minus_zero, 0, 0.0, M_PI_2l);
2101 TEST_c_c (cacosh, 0, minus_zero, 0.0, -M_PI_2l);
2102 TEST_c_c (cacosh, minus_zero, minus_zero, 0.0, -M_PI_2l);
2103 TEST_c_c (cacosh, minus_infty, plus_infty, plus_infty, M_PI_34l);
2104 TEST_c_c (cacosh, minus_infty, minus_infty, plus_infty, -M_PI_34l);
2105
2106 TEST_c_c (cacosh, plus_infty, plus_infty, plus_infty, M_PI_4l);
2107 TEST_c_c (cacosh, plus_infty, minus_infty, plus_infty, -M_PI_4l);
2108
2109 TEST_c_c (cacosh, -10.0, plus_infty, plus_infty, M_PI_2l);
2110 TEST_c_c (cacosh, -10.0, minus_infty, plus_infty, -M_PI_2l);
2111 TEST_c_c (cacosh, 0, plus_infty, plus_infty, M_PI_2l);
2112 TEST_c_c (cacosh, 0, minus_infty, plus_infty, -M_PI_2l);
3c6cad26
UD
2113 TEST_c_c (cacosh, 0.1L, plus_infty, plus_infty, M_PI_2l);
2114 TEST_c_c (cacosh, 0.1L, minus_infty, plus_infty, -M_PI_2l);
8847214f
UD
2115
2116 TEST_c_c (cacosh, minus_infty, 0, plus_infty, M_PIl);
2117 TEST_c_c (cacosh, minus_infty, minus_zero, plus_infty, -M_PIl);
2118 TEST_c_c (cacosh, minus_infty, 100, plus_infty, M_PIl);
2119 TEST_c_c (cacosh, minus_infty, -100, plus_infty, -M_PIl);
2120
2121 TEST_c_c (cacosh, plus_infty, 0, plus_infty, 0.0);
2122 TEST_c_c (cacosh, plus_infty, minus_zero, plus_infty, minus_zero);
2123 TEST_c_c (cacosh, plus_infty, 0.5, plus_infty, 0.0);
2124 TEST_c_c (cacosh, plus_infty, -0.5, plus_infty, minus_zero);
2125
67e971f1
TS
2126 TEST_c_c (cacosh, plus_infty, qnan_value, plus_infty, qnan_value);
2127 TEST_c_c (cacosh, minus_infty, qnan_value, plus_infty, qnan_value);
8847214f 2128
67e971f1
TS
2129 TEST_c_c (cacosh, 0, qnan_value, qnan_value, qnan_value);
2130 TEST_c_c (cacosh, minus_zero, qnan_value, qnan_value, qnan_value);
8847214f 2131
67e971f1
TS
2132 TEST_c_c (cacosh, qnan_value, plus_infty, plus_infty, qnan_value);
2133 TEST_c_c (cacosh, qnan_value, minus_infty, plus_infty, qnan_value);
8847214f 2134
67e971f1
TS
2135 TEST_c_c (cacosh, 10.5, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
2136 TEST_c_c (cacosh, -10.5, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
8847214f 2137
67e971f1
TS
2138 TEST_c_c (cacosh, qnan_value, 0.75, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
2139 TEST_c_c (cacosh, qnan_value, -0.75, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
8847214f 2140
67e971f1 2141 TEST_c_c (cacosh, qnan_value, qnan_value, qnan_value, qnan_value);
8847214f 2142
d1d3431a
JM
2143 TEST_c_c (cacosh, plus_zero, -1.5L, 1.194763217287109304111930828519090523536L, -M_PI_2l);
2144 TEST_c_c (cacosh, minus_zero, -1.5L, 1.194763217287109304111930828519090523536L, -M_PI_2l);
2145 TEST_c_c (cacosh, plus_zero, -1.0L, 0.8813735870195430252326093249797923090282L, -M_PI_2l);
2146 TEST_c_c (cacosh, minus_zero, -1.0L, 0.8813735870195430252326093249797923090282L, -M_PI_2l);
2147 TEST_c_c (cacosh, plus_zero, -0.5L, 0.4812118250596034474977589134243684231352L, -M_PI_2l);
2148 TEST_c_c (cacosh, minus_zero, -0.5L, 0.4812118250596034474977589134243684231352L, -M_PI_2l);
2149 TEST_c_c (cacosh, plus_zero, 0.5L, 0.4812118250596034474977589134243684231352L, M_PI_2l);
2150 TEST_c_c (cacosh, minus_zero, 0.5L, 0.4812118250596034474977589134243684231352L, M_PI_2l);
2151 TEST_c_c (cacosh, plus_zero, 1.0L, 0.8813735870195430252326093249797923090282L, M_PI_2l);
2152 TEST_c_c (cacosh, minus_zero, 1.0L, 0.8813735870195430252326093249797923090282L, M_PI_2l);
2153 TEST_c_c (cacosh, plus_zero, 1.5L, 1.194763217287109304111930828519090523536L, M_PI_2l);
2154 TEST_c_c (cacosh, minus_zero, 1.5L, 1.194763217287109304111930828519090523536L, M_PI_2l);
2155
2156 TEST_c_c (cacosh, -1.5L, plus_zero, 0.9624236501192068949955178268487368462704L, M_PIl);
2157 TEST_c_c (cacosh, -1.5L, minus_zero, 0.9624236501192068949955178268487368462704L, -M_PIl);
2158 TEST_c_c (cacosh, -1.0L, plus_zero, plus_zero, M_PIl);
2159 TEST_c_c (cacosh, -1.0L, minus_zero, plus_zero, -M_PIl);
2160 TEST_c_c (cacosh, -0.5L, plus_zero, plus_zero, 2.094395102393195492308428922186335256131L);
2161 TEST_c_c (cacosh, -0.5L, minus_zero, plus_zero, -2.094395102393195492308428922186335256131L);
2162 TEST_c_c (cacosh, 0.5L, plus_zero, plus_zero, 1.047197551196597746154214461093167628066L);
2163 TEST_c_c (cacosh, 0.5L, minus_zero, plus_zero, -1.047197551196597746154214461093167628066L);
2164 TEST_c_c (cacosh, 1.0L, plus_zero, plus_zero, plus_zero);
2165 TEST_c_c (cacosh, 1.0L, minus_zero, plus_zero, minus_zero);
2166 TEST_c_c (cacosh, 1.5L, plus_zero, 0.9624236501192068949955178268487368462704L, plus_zero);
2167 TEST_c_c (cacosh, 1.5L, minus_zero, 0.9624236501192068949955178268487368462704L, minus_zero);
2168
52ce4860
JM
2169 TEST_c_c (cacosh, 0x1p50L, 1.0L, 3.535050620855721078027883819436720218708e1L, 8.881784197001252323389053344727730248720e-16L);
2170 TEST_c_c (cacosh, 0x1p50L, -1.0L, 3.535050620855721078027883819436720218708e1L, -8.881784197001252323389053344727730248720e-16L);
2171 TEST_c_c (cacosh, -0x1p50L, 1.0L, 3.535050620855721078027883819436720218708e1L, 3.141592653589792350284223683154270545292L);
2172 TEST_c_c (cacosh, -0x1p50L, -1.0L, 3.535050620855721078027883819436720218708e1L, -3.141592653589792350284223683154270545292L);
2173 TEST_c_c (cacosh, 1.0L, 0x1p50L, 3.535050620855721078027883819436759661753e1L, 1.570796326794895731052901991514519103193L);
2174 TEST_c_c (cacosh, -1.0L, 0x1p50L, 3.535050620855721078027883819436759661753e1L, 1.570796326794897507409741391764983781004L);
2175 TEST_c_c (cacosh, 1.0L, -0x1p50L, 3.535050620855721078027883819436759661753e1L, -1.570796326794895731052901991514519103193L);
2176 TEST_c_c (cacosh, -1.0L, -0x1p50L, 3.535050620855721078027883819436759661753e1L, -1.570796326794897507409741391764983781004L);
2177#ifndef TEST_FLOAT
2178 TEST_c_c (cacosh, 0x1p500L, 1.0L, 3.472667374605326000180332928505464606058e2L, 3.054936363499604682051979393213617699789e-151L);
2179 TEST_c_c (cacosh, 0x1p500L, -1.0L, 3.472667374605326000180332928505464606058e2L, -3.054936363499604682051979393213617699789e-151L);
2180 TEST_c_c (cacosh, -0x1p500L, 1.0L, 3.472667374605326000180332928505464606058e2L, 3.141592653589793238462643383279502884197L);
2181 TEST_c_c (cacosh, -0x1p500L, -1.0L, 3.472667374605326000180332928505464606058e2L, -3.141592653589793238462643383279502884197L);
2182 TEST_c_c (cacosh, 1.0L, 0x1p500L, 3.472667374605326000180332928505464606058e2L, 1.570796326794896619231321691639751442099L);
2183 TEST_c_c (cacosh, -1.0L, 0x1p500L, 3.472667374605326000180332928505464606058e2L, 1.570796326794896619231321691639751442099L);
2184 TEST_c_c (cacosh, 1.0L, -0x1p500L, 3.472667374605326000180332928505464606058e2L, -1.570796326794896619231321691639751442099L);
2185 TEST_c_c (cacosh, -1.0L, -0x1p500L, 3.472667374605326000180332928505464606058e2L, -1.570796326794896619231321691639751442099L);
2186#endif
2187#if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
2188 TEST_c_c (cacosh, 0x1p5000L, 1.0L, 3.466429049980286492395577839412341016946e3L, 7.079811261048172892385615158694057552948e-1506L);
2189 TEST_c_c (cacosh, 0x1p5000L, -1.0L, 3.466429049980286492395577839412341016946e3L, -7.079811261048172892385615158694057552948e-1506L);
2190 TEST_c_c (cacosh, -0x1p5000L, 1.0L, 3.466429049980286492395577839412341016946e3L, 3.141592653589793238462643383279502884197L);
2191 TEST_c_c (cacosh, -0x1p5000L, -1.0L, 3.466429049980286492395577839412341016946e3L, -3.141592653589793238462643383279502884197L);
2192 TEST_c_c (cacosh, 1.0L, 0x1p5000L, 3.466429049980286492395577839412341016946e3L, 1.570796326794896619231321691639751442099L);
2193 TEST_c_c (cacosh, -1.0L, 0x1p5000L, 3.466429049980286492395577839412341016946e3L, 1.570796326794896619231321691639751442099L);
2194 TEST_c_c (cacosh, 1.0L, -0x1p5000L, 3.466429049980286492395577839412341016946e3L, -1.570796326794896619231321691639751442099L);
2195 TEST_c_c (cacosh, -1.0L, -0x1p5000L, 3.466429049980286492395577839412341016946e3L, -1.570796326794896619231321691639751442099L);
2196#endif
2197 TEST_c_c (cacosh, 0x1.fp127L, 0x1.fp127L, 8.973081118419833726837456344608533993585e1L, 7.853981633974483096156608458198757210493e-1L);
2198#ifndef TEST_FLOAT
2199 TEST_c_c (cacosh, 0x1.fp1023L, 0x1.fp1023L, 7.107906849659093345062145442726115449315e2L, 7.853981633974483096156608458198757210493e-1L);
2200#endif
2201#if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
2202 TEST_c_c (cacosh, 0x1.fp16383L, 0x1.fp16383L, 1.135753137836666928715489992987020363057e4L, 7.853981633974483096156608458198757210493e-1L);
2203#endif
2204 TEST_c_c (cacosh, 0x1.fp-129L, 1.5L, 1.194763217287109304111930828519090523536L, 1.570796326794896619231321691639751442097L);
2205 TEST_c_c (cacosh, 0x1.fp-129L, -1.5L, 1.194763217287109304111930828519090523536L, -1.570796326794896619231321691639751442097L);
2206 TEST_c_c (cacosh, -0x1.fp-129L, 1.5L, 1.194763217287109304111930828519090523536L, 1.570796326794896619231321691639751442100L);
2207 TEST_c_c (cacosh, -0x1.fp-129L, -1.5L, 1.194763217287109304111930828519090523536L, -1.570796326794896619231321691639751442100L);
2208 TEST_c_c (cacosh, 1.5L, 0x1.fp-129L, 9.624236501192068949955178268487368462704e-1L, 2.546345110742945032959687790021055102355e-39L, UNDERFLOW_EXCEPTION_FLOAT);
2209 TEST_c_c (cacosh, -1.5L, 0x1.fp-129L, 9.624236501192068949955178268487368462704e-1L, 3.141592653589793238462643383279502884195L);
2210 TEST_c_c (cacosh, 1.5L, -0x1.fp-129L, 9.624236501192068949955178268487368462704e-1L, -2.546345110742945032959687790021055102355e-39L, UNDERFLOW_EXCEPTION_FLOAT);
2211 TEST_c_c (cacosh, -1.5L, -0x1.fp-129L, 9.624236501192068949955178268487368462704e-1L, -3.141592653589793238462643383279502884195L);
2212#ifndef TEST_FLOAT
2213 TEST_c_c (cacosh, 0x1.fp-1025L, 1.5L, 1.194763217287109304111930828519090523536L, 1.570796326794896619231321691639751442099L);
2214 TEST_c_c (cacosh, 0x1.fp-1025L, -1.5L, 1.194763217287109304111930828519090523536L, -1.570796326794896619231321691639751442099L);
2215 TEST_c_c (cacosh, -0x1.fp-1025L, 1.5L, 1.194763217287109304111930828519090523536L, 1.570796326794896619231321691639751442099L);
2216 TEST_c_c (cacosh, -0x1.fp-1025L, -1.5L, 1.194763217287109304111930828519090523536L, -1.570796326794896619231321691639751442099L);
2217 TEST_c_c (cacosh, 1.5L, 0x1.fp-1025L, 9.624236501192068949955178268487368462704e-1L, 4.819934639999230680322935210539402497827e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
2218 TEST_c_c (cacosh, -1.5L, 0x1.fp-1025L, 9.624236501192068949955178268487368462704e-1L, 3.141592653589793238462643383279502884197L);
2219 TEST_c_c (cacosh, 1.5L, -0x1.fp-1025L, 9.624236501192068949955178268487368462704e-1L, -4.819934639999230680322935210539402497827e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
2220 TEST_c_c (cacosh, -1.5L, -0x1.fp-1025L, 9.624236501192068949955178268487368462704e-1L, -3.141592653589793238462643383279502884197L);
2221#endif
2222#if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
2223 TEST_c_c (cacosh, 0x1.fp-16385L, 1.5L, 1.194763217287109304111930828519090523536L, 1.570796326794896619231321691639751442099L);
2224 TEST_c_c (cacosh, 0x1.fp-16385L, -1.5L, 1.194763217287109304111930828519090523536L, -1.570796326794896619231321691639751442099L);
2225 TEST_c_c (cacosh, -0x1.fp-16385L, 1.5L, 1.194763217287109304111930828519090523536L, 1.570796326794896619231321691639751442099L);
2226 TEST_c_c (cacosh, -0x1.fp-16385L, -1.5L, 1.194763217287109304111930828519090523536L, -1.570796326794896619231321691639751442099L);
2227 TEST_c_c (cacosh, 1.5L, 0x1.fp-16385L, 9.624236501192068949955178268487368462704e-1L, 7.282957076134209141226696333885150260319e-4933L, UNDERFLOW_EXCEPTION);
2228 TEST_c_c (cacosh, -1.5L, 0x1.fp-16385L, 9.624236501192068949955178268487368462704e-1L, 3.141592653589793238462643383279502884197L);
2229 TEST_c_c (cacosh, 1.5L, -0x1.fp-16385L, 9.624236501192068949955178268487368462704e-1L, -7.282957076134209141226696333885150260319e-4933L, UNDERFLOW_EXCEPTION);
2230 TEST_c_c (cacosh, -1.5L, -0x1.fp-16385L, 9.624236501192068949955178268487368462704e-1L, -3.141592653589793238462643383279502884197L);
2231#endif
2232 TEST_c_c (cacosh, 0.5L, 1.0L, 9.261330313501824245501244453057873152694e-1L, 1.221357263937683325603909865564381489366L);
2233 TEST_c_c (cacosh, 0.5L, -1.0L, 9.261330313501824245501244453057873152694e-1L, -1.221357263937683325603909865564381489366L);
2234 TEST_c_c (cacosh, -0.5L, 1.0L, 9.261330313501824245501244453057873152694e-1L, 1.920235389652109912858733517715121394831L);
2235 TEST_c_c (cacosh, -0.5L, -1.0L, 9.261330313501824245501244453057873152694e-1L, -1.920235389652109912858733517715121394831L);
2236 TEST_c_c (cacosh, 1.0L, 0.5L, 7.328576759736452608886724437653071523305e-1L, 6.748888455860063801646649673121744318756e-1L);
2237 TEST_c_c (cacosh, -1.0L, 0.5L, 7.328576759736452608886724437653071523305e-1L, 2.466703808003786858297978415967328452322L);
2238 TEST_c_c (cacosh, 1.0L, -0.5L, 7.328576759736452608886724437653071523305e-1L, -6.748888455860063801646649673121744318756e-1L);
2239 TEST_c_c (cacosh, -1.0L, -0.5L, 7.328576759736452608886724437653071523305e-1L, -2.466703808003786858297978415967328452322L);
2240 TEST_c_c (cacosh, 0.25L, 1.0L, 8.924633639033482359562124741744951972772e-1L, 1.394493894017929688812643125003661339452L);
2241 TEST_c_c (cacosh, 0.25L, -1.0L, 8.924633639033482359562124741744951972772e-1L, -1.394493894017929688812643125003661339452L);
2242 TEST_c_c (cacosh, -0.25L, 1.0L, 8.924633639033482359562124741744951972772e-1L, 1.747098759571863549650000258275841544745L);
2243 TEST_c_c (cacosh, -0.25L, -1.0L, 8.924633639033482359562124741744951972772e-1L, -1.747098759571863549650000258275841544745L);
2244 TEST_c_c (cacosh, 1.0L, 0.25L, 5.097911466811016354623559941115413499164e-1L, 4.890443302710802929202843732146540079124e-1L);
2245 TEST_c_c (cacosh, -1.0L, 0.25L, 5.097911466811016354623559941115413499164e-1L, 2.652548323318712945542359010064848876285L);
2246 TEST_c_c (cacosh, 1.0L, -0.25L, 5.097911466811016354623559941115413499164e-1L, -4.890443302710802929202843732146540079124e-1L);
2247 TEST_c_c (cacosh, -1.0L, -0.25L, 5.097911466811016354623559941115413499164e-1L, -2.652548323318712945542359010064848876285L);
2248 TEST_c_c (cacosh, 0x1.fp-10L, 1.0L, 8.813742198809567991336704287826445879025e-1L, 1.569458417435338878318763342108699202986L);
2249 TEST_c_c (cacosh, 0x1.fp-10L, -1.0L, 8.813742198809567991336704287826445879025e-1L, -1.569458417435338878318763342108699202986L);
2250 TEST_c_c (cacosh, -0x1.fp-10L, 1.0L, 8.813742198809567991336704287826445879025e-1L, 1.572134236154454360143880041170803681211L);
2251 TEST_c_c (cacosh, -0x1.fp-10L, -1.0L, 8.813742198809567991336704287826445879025e-1L, -1.572134236154454360143880041170803681211L);
2252 TEST_c_c (cacosh, 1.0L, 0x1.fp-10L, 4.350501469856803800217957402220976497152e-2L, 4.349129763101882771258049954181971959031e-2L);
2253 TEST_c_c (cacosh, -1.0L, 0x1.fp-10L, 4.350501469856803800217957402220976497152e-2L, 3.098101355958774410750062883737683164607L);
2254 TEST_c_c (cacosh, 1.0L, -0x1.fp-10L, 4.350501469856803800217957402220976497152e-2L, -4.349129763101882771258049954181971959031e-2L);
2255 TEST_c_c (cacosh, -1.0L, -0x1.fp-10L, 4.350501469856803800217957402220976497152e-2L, -3.098101355958774410750062883737683164607L);
2256 TEST_c_c (cacosh, 0x1.fp-30L, 1.0L, 8.813735870195430258081932989769495326854e-1L, 1.570796325518966635014803151387033957091L);
2257 TEST_c_c (cacosh, 0x1.fp-30L, -1.0L, 8.813735870195430258081932989769495326854e-1L, -1.570796325518966635014803151387033957091L);
2258 TEST_c_c (cacosh, -0x1.fp-30L, 1.0L, 8.813735870195430258081932989769495326854e-1L, 1.570796328070826603447840231892468927106L);
2259 TEST_c_c (cacosh, -0x1.fp-30L, -1.0L, 8.813735870195430258081932989769495326854e-1L, -1.570796328070826603447840231892468927106L);
2260 TEST_c_c (cacosh, 1.0L, 0x1.fp-30L, 4.247867098745151888768727039216644758847e-5L, 4.247867097467650115899790787875186617316e-5L);
2261 TEST_c_c (cacosh, -1.0L, 0x1.fp-30L, 4.247867098745151888768727039216644758847e-5L, 3.141550174918818561961484385371624132331L);
2262 TEST_c_c (cacosh, 1.0L, -0x1.fp-30L, 4.247867098745151888768727039216644758847e-5L, -4.247867097467650115899790787875186617316e-5L);
2263 TEST_c_c (cacosh, -1.0L, -0x1.fp-30L, 4.247867098745151888768727039216644758847e-5L, -3.141550174918818561961484385371624132331L);
2264 TEST_c_c (cacosh, 0x1.fp-100L, 1.0L, 8.813735870195430252326093249797923090282e-1L, 1.570796326794896619231321691638670687364L);
2265 TEST_c_c (cacosh, 0x1.fp-100L, -1.0L, 8.813735870195430252326093249797923090282e-1L, -1.570796326794896619231321691638670687364L);
2266 TEST_c_c (cacosh, -0x1.fp-100L, 1.0L, 8.813735870195430252326093249797923090282e-1L, 1.570796326794896619231321691640832196834L);
2267 TEST_c_c (cacosh, -0x1.fp-100L, -1.0L, 8.813735870195430252326093249797923090282e-1L, -1.570796326794896619231321691640832196834L);
2268 TEST_c_c (cacosh, 1.0L, 0x1.fp-100L, 1.236292038260260888664514866457202186027e-15L, 1.236292038260260888664514866456887257525e-15L);
2269 TEST_c_c (cacosh, -1.0L, 0x1.fp-100L, 1.236292038260260888664514866457202186027e-15L, 3.141592653589792002170605123018614219682L);
2270 TEST_c_c (cacosh, 1.0L, -0x1.fp-100L, 1.236292038260260888664514866457202186027e-15L, -1.236292038260260888664514866456887257525e-15L);
2271 TEST_c_c (cacosh, -1.0L, -0x1.fp-100L, 1.236292038260260888664514866457202186027e-15L, -3.141592653589792002170605123018614219682L);
2272 TEST_c_c (cacosh, 0x1.fp-129L, 1.0L, 8.813735870195430252326093249797923090282e-1L, 1.570796326794896619231321691639751442097L);
2273 TEST_c_c (cacosh, 0x1.fp-129L, -1.0L, 8.813735870195430252326093249797923090282e-1L, -1.570796326794896619231321691639751442097L);
2274 TEST_c_c (cacosh, -0x1.fp-129L, 1.0L, 8.813735870195430252326093249797923090282e-1L, 1.570796326794896619231321691639751442101L);
2275 TEST_c_c (cacosh, -0x1.fp-129L, -1.0L, 8.813735870195430252326093249797923090282e-1L, -1.570796326794896619231321691639751442101L);
2276 TEST_c_c (cacosh, 1.0L, 0x1.fp-129L, 5.335635276982233498398987585285818977933e-20L, 5.335635276982233498398987585285818977930e-20L);
2277 TEST_c_c (cacosh, -1.0L, 0x1.fp-129L, 5.335635276982233498398987585285818977933e-20L, 3.141592653589793238409287030509680549213L);
2278 TEST_c_c (cacosh, 1.0L, -0x1.fp-129L, 5.335635276982233498398987585285818977933e-20L, -5.335635276982233498398987585285818977930e-20L);
2279 TEST_c_c (cacosh, -1.0L, -0x1.fp-129L, 5.335635276982233498398987585285818977933e-20L, -3.141592653589793238409287030509680549213L);
2280#ifndef TEST_FLOAT
2281 TEST_c_c (cacosh, 0x1.fp-1000L, 1.0L, 8.813735870195430252326093249797923090282e-1L, 1.570796326794896619231321691639751442099L);
2282 TEST_c_c (cacosh, 0x1.fp-1000L, -1.0L, 8.813735870195430252326093249797923090282e-1L, -1.570796326794896619231321691639751442099L);
2283 TEST_c_c (cacosh, -0x1.fp-1000L, 1.0L, 8.813735870195430252326093249797923090282e-1L, 1.570796326794896619231321691639751442099L);
2284 TEST_c_c (cacosh, -0x1.fp-1000L, -1.0L, 8.813735870195430252326093249797923090282e-1L, -1.570796326794896619231321691639751442099L);
2285 TEST_c_c (cacosh, 1.0L, 0x1.fp-1000L, 4.252291453851660175550490409247739011867e-151L, 4.252291453851660175550490409247739011867e-151L);
2286 TEST_c_c (cacosh, -1.0L, 0x1.fp-1000L, 4.252291453851660175550490409247739011867e-151L, 3.141592653589793238462643383279502884197L);
2287 TEST_c_c (cacosh, 1.0L, -0x1.fp-1000L, 4.252291453851660175550490409247739011867e-151L, -4.252291453851660175550490409247739011867e-151L);
2288 TEST_c_c (cacosh, -1.0L, -0x1.fp-1000L, 4.252291453851660175550490409247739011867e-151L, -3.141592653589793238462643383279502884197L);
2289 TEST_c_c (cacosh, 0x1.fp-1025L, 1.0L, 8.813735870195430252326093249797923090282e-1L, 1.570796326794896619231321691639751442099L);
2290 TEST_c_c (cacosh, 0x1.fp-1025L, -1.0L, 8.813735870195430252326093249797923090282e-1L, -1.570796326794896619231321691639751442099L);
2291 TEST_c_c (cacosh, -0x1.fp-1025L, 1.0L, 8.813735870195430252326093249797923090282e-1L, 1.570796326794896619231321691639751442099L);
2292 TEST_c_c (cacosh, -0x1.fp-1025L, -1.0L, 8.813735870195430252326093249797923090282e-1L, -1.570796326794896619231321691639751442099L);
2293 TEST_c_c (cacosh, 1.0L, 0x1.fp-1025L, 7.340879205566679497036857179189356754017e-155L, 7.340879205566679497036857179189356754017e-155L);
2294 TEST_c_c (cacosh, -1.0L, 0x1.fp-1025L, 7.340879205566679497036857179189356754017e-155L, 3.141592653589793238462643383279502884197L);
2295 TEST_c_c (cacosh, 1.0L, -0x1.fp-1025L, 7.340879205566679497036857179189356754017e-155L, -7.340879205566679497036857179189356754017e-155L);
2296 TEST_c_c (cacosh, -1.0L, -0x1.fp-1025L, 7.340879205566679497036857179189356754017e-155L, -3.141592653589793238462643383279502884197L);
2297#endif
2298#if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
2299 TEST_c_c (cacosh, 0x1.fp-10000L, 1.0L, 8.813735870195430252326093249797923090282e-1L, 1.570796326794896619231321691639751442099L);
2300 TEST_c_c (cacosh, 0x1.fp-10000L, -1.0L, 8.813735870195430252326093249797923090282e-1L, -1.570796326794896619231321691639751442099L);
2301 TEST_c_c (cacosh, -0x1.fp-10000L, 1.0L, 8.813735870195430252326093249797923090282e-1L, 1.570796326794896619231321691639751442099L);
2302 TEST_c_c (cacosh, -0x1.fp-10000L, -1.0L, 8.813735870195430252326093249797923090282e-1L, -1.570796326794896619231321691639751442099L);
2303 TEST_c_c (cacosh, 1.0L, 0x1.fp-10000L, 9.854680208706673586644342922051388714633e-1506L, 9.854680208706673586644342922051388714633e-1506L);
2304 TEST_c_c (cacosh, -1.0L, 0x1.fp-10000L, 9.854680208706673586644342922051388714633e-1506L, 3.141592653589793238462643383279502884197L);
2305 TEST_c_c (cacosh, 1.0L, -0x1.fp-10000L, 9.854680208706673586644342922051388714633e-1506L, -9.854680208706673586644342922051388714633e-1506L);
2306 TEST_c_c (cacosh, -1.0L, -0x1.fp-10000L, 9.854680208706673586644342922051388714633e-1506L, -3.141592653589793238462643383279502884197L);
2307 TEST_c_c (cacosh, 0x1.fp-16385L, 1.0L, 8.813735870195430252326093249797923090282e-1L, 1.570796326794896619231321691639751442099L);
2308 TEST_c_c (cacosh, 0x1.fp-16385L, -1.0L, 8.813735870195430252326093249797923090282e-1L, -1.570796326794896619231321691639751442099L);
2309 TEST_c_c (cacosh, -0x1.fp-16385L, 1.0L, 8.813735870195430252326093249797923090282e-1L, 1.570796326794896619231321691639751442099L);
2310 TEST_c_c (cacosh, -0x1.fp-16385L, -1.0L, 8.813735870195430252326093249797923090282e-1L, -1.570796326794896619231321691639751442099L);
2311 TEST_c_c (cacosh, 1.0L, 0x1.fp-16385L, 9.023632056840860275214893047597614177639e-2467L, 9.023632056840860275214893047597614177639e-2467L);
2312 TEST_c_c (cacosh, -1.0L, 0x1.fp-16385L, 9.023632056840860275214893047597614177639e-2467L, 3.141592653589793238462643383279502884197L);
2313 TEST_c_c (cacosh, 1.0L, -0x1.fp-16385L, 9.023632056840860275214893047597614177639e-2467L, -9.023632056840860275214893047597614177639e-2467L);
2314 TEST_c_c (cacosh, -1.0L, -0x1.fp-16385L, 9.023632056840860275214893047597614177639e-2467L, -3.141592653589793238462643383279502884197L);
2315#endif
2316 TEST_c_c (cacosh, 0x1p-23L, 0x1.000002p0L, 8.813736713132400470205730751186547909968e-1L, 1.570796242501204621739026081991856762292L);
2317 TEST_c_c (cacosh, 0x1p-23L, -0x1.000002p0L, 8.813736713132400470205730751186547909968e-1L, -1.570796242501204621739026081991856762292L);
2318 TEST_c_c (cacosh, -0x1p-23L, 0x1.000002p0L, 8.813736713132400470205730751186547909968e-1L, 1.570796411088588616723617301287646121905L);
2319 TEST_c_c (cacosh, -0x1p-23L, -0x1.000002p0L, 8.813736713132400470205730751186547909968e-1L, -1.570796411088588616723617301287646121905L);
2320 TEST_c_c (cacosh, 0x1.000002p0L, 0x1p-23L, 5.364668491573609633134147164031476452679e-4L, 2.222118384408546368406374049167636760903e-4L);
2321 TEST_c_c (cacosh, -0x1.000002p0L, 0x1p-23L, 5.364668491573609633134147164031476452679e-4L, 3.141370441751352383825802745874586120521L);
2322 TEST_c_c (cacosh, 0x1.000002p0L, -0x1p-23L, 5.364668491573609633134147164031476452679e-4L, -2.222118384408546368406374049167636760903e-4L);
2323 TEST_c_c (cacosh, -0x1.000002p0L, -0x1p-23L, 5.364668491573609633134147164031476452679e-4L, -3.141370441751352383825802745874586120521L);
2324 TEST_c_c (cacosh, 0x1.fp-129L, 0x1.000002p0L, 8.813736713132375348727889167749389235161e-1L, 1.570796326794896619231321691639751442097L);
2325 TEST_c_c (cacosh, 0x1.fp-129L, -0x1.000002p0L, 8.813736713132375348727889167749389235161e-1L, -1.570796326794896619231321691639751442097L);
2326 TEST_c_c (cacosh, -0x1.fp-129L, 0x1.000002p0L, 8.813736713132375348727889167749389235161e-1L, 1.570796326794896619231321691639751442101L);
2327 TEST_c_c (cacosh, -0x1.fp-129L, -0x1.000002p0L, 8.813736713132375348727889167749389235161e-1L, -1.570796326794896619231321691639751442101L);
2328 TEST_c_c (cacosh, 0x1.000002p0L, 0x1.fp-129L, 4.882812451493617206486388134172712975070e-4L, 5.830451806317544230969669308596361881467e-36L);
2329 TEST_c_c (cacosh, -0x1.000002p0L, 0x1.fp-129L, 4.882812451493617206486388134172712975070e-4L, 3.141592653589793238462643383279502878367L);
2330 TEST_c_c (cacosh, 0x1.000002p0L, -0x1.fp-129L, 4.882812451493617206486388134172712975070e-4L, -5.830451806317544230969669308596361881467e-36L);
2331 TEST_c_c (cacosh, -0x1.000002p0L, -0x1.fp-129L, 4.882812451493617206486388134172712975070e-4L, -3.141592653589793238462643383279502878367L);
2332 TEST_c_c (cacosh, 0.0L, 0x1.000002p0L, 8.813736713132375348727889167749389235161e-1L, 1.570796326794896619231321691639751442099L);
2333 TEST_c_c (cacosh, 0.0L, -0x1.000002p0L, 8.813736713132375348727889167749389235161e-1L, -1.570796326794896619231321691639751442099L);
2334 TEST_c_c (cacosh, -0.0L, 0x1.000002p0L, 8.813736713132375348727889167749389235161e-1L, 1.570796326794896619231321691639751442099L);
2335 TEST_c_c (cacosh, -0.0L, -0x1.000002p0L, 8.813736713132375348727889167749389235161e-1L, -1.570796326794896619231321691639751442099L);
2336 TEST_c_c (cacosh, 0x1.000002p0L, 0.0L, 4.882812451493617206486388134172712975070e-4L, 0.0L);
2337 TEST_c_c (cacosh, -0x1.000002p0L, 0.0L, 4.882812451493617206486388134172712975070e-4L, 3.141592653589793238462643383279502884197L);
2338 TEST_c_c (cacosh, 0x1.000002p0L, -0.0L, 4.882812451493617206486388134172712975070e-4L, -0.0L);
2339 TEST_c_c (cacosh, -0x1.000002p0L, -0.0L, 4.882812451493617206486388134172712975070e-4L, -3.141592653589793238462643383279502884197L);
2340#ifndef TEST_FLOAT
2341 TEST_c_c (cacosh, 0x1p-52L, 0x1.0000000000001p0L, 8.813735870195431822418551933572982483664e-1L, 1.570796326794896462222075823262262934288L);
2342 TEST_c_c (cacosh, 0x1p-52L, -0x1.0000000000001p0L, 8.813735870195431822418551933572982483664e-1L, -1.570796326794896462222075823262262934288L);
2343 TEST_c_c (cacosh, -0x1p-52L, 0x1.0000000000001p0L, 8.813735870195431822418551933572982483664e-1L, 1.570796326794896776240567560017239949909L);
2344 TEST_c_c (cacosh, -0x1p-52L, -0x1.0000000000001p0L, 8.813735870195431822418551933572982483664e-1L, -1.570796326794896776240567560017239949909L);
2345 TEST_c_c (cacosh, 0x1.0000000000001p0L, 0x1p-52L, 2.315303644582684770975188768022139415020e-8L, 9.590301705980041385828904092662391018164e-9L);
2346 TEST_c_c (cacosh, -0x1.0000000000001p0L, 0x1p-52L, 2.315303644582684770975188768022139415020e-8L, 3.141592643999491532482601997450598791535L);
2347 TEST_c_c (cacosh, 0x1.0000000000001p0L, -0x1p-52L, 2.315303644582684770975188768022139415020e-8L, -9.590301705980041385828904092662391018164e-9L);
2348 TEST_c_c (cacosh, -0x1.0000000000001p0L, -0x1p-52L, 2.315303644582684770975188768022139415020e-8L, -3.141592643999491532482601997450598791535L);
2349 TEST_c_c (cacosh, 0x1.fp-1025L, 0x1.0000000000001p0L, 8.813735870195431822418551933572895326024e-1L, 1.570796326794896619231321691639751442099L);
2350 TEST_c_c (cacosh, 0x1.fp-1025L, -0x1.0000000000001p0L, 8.813735870195431822418551933572895326024e-1L, -1.570796326794896619231321691639751442099L);
2351 TEST_c_c (cacosh, -0x1.fp-1025L, 0x1.0000000000001p0L, 8.813735870195431822418551933572895326024e-1L, 1.570796326794896619231321691639751442099L);
2352 TEST_c_c (cacosh, -0x1.fp-1025L, -0x1.0000000000001p0L, 8.813735870195431822418551933572895326024e-1L, -1.570796326794896619231321691639751442099L);
2353 TEST_c_c (cacosh, 0x1.0000000000001p0L, 0x1.fp-1025L, 2.107342425544701550354780375182800088393e-8L, 2.557178503953494342609835913586108008322e-301L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM);
2354 TEST_c_c (cacosh, -0x1.0000000000001p0L, 0x1.fp-1025L, 2.107342425544701550354780375182800088393e-8L, 3.141592653589793238462643383279502884197L);
2355 TEST_c_c (cacosh, 0x1.0000000000001p0L, -0x1.fp-1025L, 2.107342425544701550354780375182800088393e-8L, -2.557178503953494342609835913586108008322e-301L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM);
2356 TEST_c_c (cacosh, -0x1.0000000000001p0L, -0x1.fp-1025L, 2.107342425544701550354780375182800088393e-8L, -3.141592653589793238462643383279502884197L);
2357 TEST_c_c (cacosh, 0.0L, 0x1.0000000000001p0L, 8.813735870195431822418551933572895326024e-1L, 1.570796326794896619231321691639751442099L);
2358 TEST_c_c (cacosh, 0.0L, -0x1.0000000000001p0L, 8.813735870195431822418551933572895326024e-1L, -1.570796326794896619231321691639751442099L);
2359 TEST_c_c (cacosh, -0.0L, 0x1.0000000000001p0L, 8.813735870195431822418551933572895326024e-1L, 1.570796326794896619231321691639751442099L);
2360 TEST_c_c (cacosh, -0.0L, -0x1.0000000000001p0L, 8.813735870195431822418551933572895326024e-1L, -1.570796326794896619231321691639751442099L);
2361 TEST_c_c (cacosh, 0x1.0000000000001p0L, 0.0L, 2.107342425544701550354780375182800088393e-8L, 0.0L);
2362 TEST_c_c (cacosh, -0x1.0000000000001p0L, 0.0L, 2.107342425544701550354780375182800088393e-8L, 3.141592653589793238462643383279502884197L);
2363 TEST_c_c (cacosh, 0x1.0000000000001p0L, -0.0L, 2.107342425544701550354780375182800088393e-8L, -0.0L);
2364 TEST_c_c (cacosh, -0x1.0000000000001p0L, -0.0L, 2.107342425544701550354780375182800088393e-8L, -3.141592653589793238462643383279502884197L);
2365#endif
2366#if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 64
2367 TEST_c_c (cacosh, 0x1p-63L, 0x1.0000000000000002p0L, 8.813735870195430253092739958139610131001e-1L, 1.570796326794896619154657020805582738031L);
2368 TEST_c_c (cacosh, 0x1p-63L, -0x1.0000000000000002p0L, 8.813735870195430253092739958139610131001e-1L, -1.570796326794896619154657020805582738031L);
2369 TEST_c_c (cacosh, -0x1p-63L, 0x1.0000000000000002p0L, 8.813735870195430253092739958139610131001e-1L, 1.570796326794896619307986362473920146166L);
2370 TEST_c_c (cacosh, -0x1p-63L, -0x1.0000000000000002p0L, 8.813735870195430253092739958139610131001e-1L, -1.570796326794896619307986362473920146166L);
2371 TEST_c_c (cacosh, 0x1.0000000000000002p0L, 0x1p-63L, 5.116146586219826555037807251857670783420e-10L, 2.119177303101063432592523199680782317447e-10L);
2372 TEST_c_c (cacosh, -0x1.0000000000000002p0L, 0x1p-63L, 5.116146586219826555037807251857670783420e-10L, 3.141592653377875508152537040020250564229L);
2373 TEST_c_c (cacosh, 0x1.0000000000000002p0L, -0x1p-63L, 5.116146586219826555037807251857670783420e-10L, -2.119177303101063432592523199680782317447e-10L);
2374 TEST_c_c (cacosh, -0x1.0000000000000002p0L, -0x1p-63L, 5.116146586219826555037807251857670783420e-10L, -3.141592653377875508152537040020250564229L);
2375# if LDBL_MIN_EXP <= -16381
2376 TEST_c_c (cacosh, 0x1.fp-16385L, 0x1.0000000000000002p0L, 8.813735870195430253092739958139610130980e-1L, 1.570796326794896619231321691639751442099L);
2377 TEST_c_c (cacosh, 0x1.fp-16385L, -0x1.0000000000000002p0L, 8.813735870195430253092739958139610130980e-1L, -1.570796326794896619231321691639751442099L);
2378 TEST_c_c (cacosh, -0x1.fp-16385L, 0x1.0000000000000002p0L, 8.813735870195430253092739958139610130980e-1L, 1.570796326794896619231321691639751442099L);
2379 TEST_c_c (cacosh, -0x1.fp-16385L, -0x1.0000000000000002p0L, 8.813735870195430253092739958139610130980e-1L, -1.570796326794896619231321691639751442099L);
2380 TEST_c_c (cacosh, 0x1.0000000000000002p0L, 0x1.fp-16385L, 4.656612873077392578082927418388212703712e-10L, 1.748608650034385653922359120438227480943e-4923L);
2381 TEST_c_c (cacosh, -0x1.0000000000000002p0L, 0x1.fp-16385L, 4.656612873077392578082927418388212703712e-10L, 3.141592653589793238462643383279502884197L);
2382 TEST_c_c (cacosh, 0x1.0000000000000002p0L, -0x1.fp-16385L, 4.656612873077392578082927418388212703712e-10L, -1.748608650034385653922359120438227480943e-4923L);
2383 TEST_c_c (cacosh, -0x1.0000000000000002p0L, -0x1.fp-16385L, 4.656612873077392578082927418388212703712e-10L, -3.141592653589793238462643383279502884197L);
2384# endif
2385 TEST_c_c (cacosh, 0.0L, 0x1.0000000000000002p0L, 8.813735870195430253092739958139610130980e-1L, 1.570796326794896619231321691639751442099L);
2386 TEST_c_c (cacosh, 0.0L, -0x1.0000000000000002p0L, 8.813735870195430253092739958139610130980e-1L, -1.570796326794896619231321691639751442099L);
2387 TEST_c_c (cacosh, -0.0L, 0x1.0000000000000002p0L, 8.813735870195430253092739958139610130980e-1L, 1.570796326794896619231321691639751442099L);
2388 TEST_c_c (cacosh, -0.0L, -0x1.0000000000000002p0L, 8.813735870195430253092739958139610130980e-1L, -1.570796326794896619231321691639751442099L);
2389 TEST_c_c (cacosh, 0x1.0000000000000002p0L, 0.0L, 4.656612873077392578082927418388212703712e-10L, 0.0L);
2390 TEST_c_c (cacosh, -0x1.0000000000000002p0L, 0.0L, 4.656612873077392578082927418388212703712e-10L, 3.141592653589793238462643383279502884197L);
2391 TEST_c_c (cacosh, 0x1.0000000000000002p0L, -0.0L, 4.656612873077392578082927418388212703712e-10L, -0.0L);
2392 TEST_c_c (cacosh, -0x1.0000000000000002p0L, -0.0L, 4.656612873077392578082927418388212703712e-10L, -3.141592653589793238462643383279502884197L);
2393#endif
2394#if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 106
2395 TEST_c_c (cacosh, 0x1p-106L, 0x1.000000000000000000000000008p0L, 8.813735870195430252326093249798097405561e-1L, 1.570796326794896619231321691639742726335L);
2396 TEST_c_c (cacosh, 0x1p-106L, -0x1.000000000000000000000000008p0L, 8.813735870195430252326093249798097405561e-1L, -1.570796326794896619231321691639742726335L);
2397 TEST_c_c (cacosh, -0x1p-106L, 0x1.000000000000000000000000008p0L, 8.813735870195430252326093249798097405561e-1L, 1.570796326794896619231321691639760157863L);
2398 TEST_c_c (cacosh, -0x1p-106L, -0x1.000000000000000000000000008p0L, 8.813735870195430252326093249798097405561e-1L, -1.570796326794896619231321691639760157863L);
2399 TEST_c_c (cacosh, 0x1.000000000000000000000000008p0L, 0x1p-106L, 2.285028863093221674154232933662774454211e-16L, 5.394221422390606848017034778914096659726e-17L);
2400 TEST_c_c (cacosh, -0x1.000000000000000000000000008p0L, 0x1p-106L, 2.285028863093221674154232933662774454211e-16L, 3.141592653589793184520429159373434404027L);
2401 TEST_c_c (cacosh, 0x1.000000000000000000000000008p0L, -0x1p-106L, 2.285028863093221674154232933662774454211e-16L, -5.394221422390606848017034778914096659726e-17L);
2402 TEST_c_c (cacosh, -0x1.000000000000000000000000008p0L, -0x1p-106L, 2.285028863093221674154232933662774454211e-16L, -3.141592653589793184520429159373434404027L);
2403 TEST_c_c (cacosh, 0x1.fp-1025L, 0x1.000000000000000000000000008p0L, 8.813735870195430252326093249798097405561e-1L, 1.570796326794896619231321691639751442099L);
2404 TEST_c_c (cacosh, 0x1.fp-1025L, -0x1.000000000000000000000000008p0L, 8.813735870195430252326093249798097405561e-1L, -1.570796326794896619231321691639751442099L);
2405 TEST_c_c (cacosh, -0x1.fp-1025L, 0x1.000000000000000000000000008p0L, 8.813735870195430252326093249798097405561e-1L, 1.570796326794896619231321691639751442099L);
2406 TEST_c_c (cacosh, -0x1.fp-1025L, -0x1.000000000000000000000000008p0L, 8.813735870195430252326093249798097405561e-1L, -1.570796326794896619231321691639751442099L);
2407 TEST_c_c (cacosh, 0x1.000000000000000000000000008p0L, 0x1.fp-1025L, 2.220446049250313080847263336181636063482e-16L, 2.426922623448365473354662093431821897807e-293L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM);
2408 TEST_c_c (cacosh, -0x1.000000000000000000000000008p0L, 0x1.fp-1025L, 2.220446049250313080847263336181636063482e-16L, 3.141592653589793238462643383279502884197L);
2409 TEST_c_c (cacosh, 0x1.000000000000000000000000008p0L, -0x1.fp-1025L, 2.220446049250313080847263336181636063482e-16L, -2.426922623448365473354662093431821897807e-293L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM);
2410 TEST_c_c (cacosh, -0x1.000000000000000000000000008p0L, -0x1.fp-1025L, 2.220446049250313080847263336181636063482e-16L, -3.141592653589793238462643383279502884197L);
2411 TEST_c_c (cacosh, 0.0L, 0x1.000000000000000000000000008p0L, 8.813735870195430252326093249798097405561e-1L, 1.570796326794896619231321691639751442099L);
2412 TEST_c_c (cacosh, 0.0L, -0x1.000000000000000000000000008p0L, 8.813735870195430252326093249798097405561e-1L, -1.570796326794896619231321691639751442099L);
2413 TEST_c_c (cacosh, -0.0L, 0x1.000000000000000000000000008p0L, 8.813735870195430252326093249798097405561e-1L, 1.570796326794896619231321691639751442099L);
2414 TEST_c_c (cacosh, -0.0L, -0x1.000000000000000000000000008p0L, 8.813735870195430252326093249798097405561e-1L, -1.570796326794896619231321691639751442099L);
2415 TEST_c_c (cacosh, 0x1.000000000000000000000000008p0L, 0.0L, 2.220446049250313080847263336181636063482e-16L, 0.0L);
2416 TEST_c_c (cacosh, -0x1.000000000000000000000000008p0L, 0.0L, 2.220446049250313080847263336181636063482e-16L, 3.141592653589793238462643383279502884197L);
2417 TEST_c_c (cacosh, 0x1.000000000000000000000000008p0L, -0.0L, 2.220446049250313080847263336181636063482e-16L, -0.0L);
2418 TEST_c_c (cacosh, -0x1.000000000000000000000000008p0L, -0.0L, 2.220446049250313080847263336181636063482e-16L, -3.141592653589793238462643383279502884197L);
2419#endif
2420#if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 113
2421 TEST_c_c (cacosh, 0x1p-113L, 0x1.0000000000000000000000000001p0L, 8.813735870195430252326093249797924452120e-1L, 1.570796326794896619231321691639751374007L);
2422 TEST_c_c (cacosh, 0x1p-113L, -0x1.0000000000000000000000000001p0L, 8.813735870195430252326093249797924452120e-1L, -1.570796326794896619231321691639751374007L);
2423 TEST_c_c (cacosh, -0x1p-113L, 0x1.0000000000000000000000000001p0L, 8.813735870195430252326093249797924452120e-1L, 1.570796326794896619231321691639751510190L);
2424 TEST_c_c (cacosh, -0x1p-113L, -0x1.0000000000000000000000000001p0L, 8.813735870195430252326093249797924452120e-1L, -1.570796326794896619231321691639751510190L);
2425 TEST_c_c (cacosh, 0x1.0000000000000000000000000001p0L, 0x1p-113L, 2.019699255375255198156433710951064632386e-17L, 4.767863183742677481693563511435642755521e-18L);
2426 TEST_c_c (cacosh, -0x1.0000000000000000000000000001p0L, 0x1p-113L, 2.019699255375255198156433710951064632386e-17L, 3.141592653589793233694780199536825402504L);
2427 TEST_c_c (cacosh, 0x1.0000000000000000000000000001p0L, -0x1p-113L, 2.019699255375255198156433710951064632386e-17L, -4.767863183742677481693563511435642755521e-18L);
2428 TEST_c_c (cacosh, -0x1.0000000000000000000000000001p0L, -0x1p-113L, 2.019699255375255198156433710951064632386e-17L, -3.141592653589793233694780199536825402504L);
2429 TEST_c_c (cacosh, 0x1.fp-16385L, 0x1.0000000000000000000000000001p0L, 8.813735870195430252326093249797924452120e-1L, 1.570796326794896619231321691639751442099L);
2430 TEST_c_c (cacosh, 0x1.fp-16385L, -0x1.0000000000000000000000000001p0L, 8.813735870195430252326093249797924452120e-1L, -1.570796326794896619231321691639751442099L);
2431 TEST_c_c (cacosh, -0x1.fp-16385L, 0x1.0000000000000000000000000001p0L, 8.813735870195430252326093249797924452120e-1L, 1.570796326794896619231321691639751442099L);
2432 TEST_c_c (cacosh, -0x1.fp-16385L, -0x1.0000000000000000000000000001p0L, 8.813735870195430252326093249797924452120e-1L, -1.570796326794896619231321691639751442099L);
2433 TEST_c_c (cacosh, 0x1.0000000000000000000000000001p0L, 0x1.fp-16385L, 1.962615573354718824241727964954454332780e-17L, 4.148847925325683229178506116378864361396e-4916L);
2434 TEST_c_c (cacosh, -0x1.0000000000000000000000000001p0L, 0x1.fp-16385L, 1.962615573354718824241727964954454332780e-17L, 3.141592653589793238462643383279502884197L);
2435 TEST_c_c (cacosh, 0x1.0000000000000000000000000001p0L, -0x1.fp-16385L, 1.962615573354718824241727964954454332780e-17L, -4.148847925325683229178506116378864361396e-4916L);
2436 TEST_c_c (cacosh, -0x1.0000000000000000000000000001p0L, -0x1.fp-16385L, 1.962615573354718824241727964954454332780e-17L, -3.141592653589793238462643383279502884197L);
2437 TEST_c_c (cacosh, 0.0L, 0x1.0000000000000000000000000001p0L, 8.813735870195430252326093249797924452120e-1L, 1.570796326794896619231321691639751442099L);
2438 TEST_c_c (cacosh, 0.0L, -0x1.0000000000000000000000000001p0L, 8.813735870195430252326093249797924452120e-1L, -1.570796326794896619231321691639751442099L);
2439 TEST_c_c (cacosh, -0.0L, 0x1.0000000000000000000000000001p0L, 8.813735870195430252326093249797924452120e-1L, 1.570796326794896619231321691639751442099L);
2440 TEST_c_c (cacosh, -0.0L, -0x1.0000000000000000000000000001p0L, 8.813735870195430252326093249797924452120e-1L, -1.570796326794896619231321691639751442099L);
2441 TEST_c_c (cacosh, 0x1.0000000000000000000000000001p0L, 0.0L, 1.962615573354718824241727964954454332780e-17L, 0.0L);
2442 TEST_c_c (cacosh, -0x1.0000000000000000000000000001p0L, 0.0L, 1.962615573354718824241727964954454332780e-17L, 3.141592653589793238462643383279502884197L);
2443 TEST_c_c (cacosh, 0x1.0000000000000000000000000001p0L, -0.0L, 1.962615573354718824241727964954454332780e-17L, -0.0L);
2444 TEST_c_c (cacosh, -0x1.0000000000000000000000000001p0L, -0.0L, 1.962615573354718824241727964954454332780e-17L, -3.141592653589793238462643383279502884197L);
2445#endif
2446 TEST_c_c (cacosh, 0x1p-23L, 0x0.ffffffp0L, 8.813735448726963984495965873956465777250e-1L, 1.570796242501197085295336701632142060969L);
2447 TEST_c_c (cacosh, 0x1p-23L, -0x0.ffffffp0L, 8.813735448726963984495965873956465777250e-1L, -1.570796242501197085295336701632142060969L);
2448 TEST_c_c (cacosh, -0x1p-23L, 0x0.ffffffp0L, 8.813735448726963984495965873956465777250e-1L, 1.570796411088596153167306681647360823228L);
2449 TEST_c_c (cacosh, -0x1p-23L, -0x0.ffffffp0L, 8.813735448726963984495965873956465777250e-1L, -1.570796411088596153167306681647360823228L);
2450 TEST_c_c (cacosh, 0x0.ffffffp0L, 0x1p-23L, 2.714321200917194650737217746780928423385e-4L, 4.391863861910487109445187743978204002614e-4L);
2451 TEST_c_c (cacosh, -0x0.ffffffp0L, 0x1p-23L, 2.714321200917194650737217746780928423385e-4L, 3.141153467203602189751698864505105063797L);
2452 TEST_c_c (cacosh, 0x0.ffffffp0L, -0x1p-23L, 2.714321200917194650737217746780928423385e-4L, -4.391863861910487109445187743978204002614e-4L);
2453 TEST_c_c (cacosh, -0x0.ffffffp0L, -0x1p-23L, 2.714321200917194650737217746780928423385e-4L, -3.141153467203602189751698864505105063797L);
2454 TEST_c_c (cacosh, 0x1.fp-129L, 0x0.ffffffp0L, 8.813735448726938863015878255140556727969e-1L, 1.570796326794896619231321691639751442097L);
2455 TEST_c_c (cacosh, 0x1.fp-129L, -0x0.ffffffp0L, 8.813735448726938863015878255140556727969e-1L, -1.570796326794896619231321691639751442097L);
2456 TEST_c_c (cacosh, -0x1.fp-129L, 0x0.ffffffp0L, 8.813735448726938863015878255140556727969e-1L, 1.570796326794896619231321691639751442101L);
2457 TEST_c_c (cacosh, -0x1.fp-129L, -0x0.ffffffp0L, 8.813735448726938863015878255140556727969e-1L, -1.570796326794896619231321691639751442101L);
2458 TEST_c_c (cacosh, 0x0.ffffffp0L, 0x1.fp-129L, 8.245504387859737323891843603996428534945e-36L, 3.452669847162035876032494826387364972849e-4L);
2459 TEST_c_c (cacosh, -0x0.ffffffp0L, 0x1.fp-129L, 8.245504387859737323891843603996428534945e-36L, 3.141247386605077034875040133796864147700L);
2460 TEST_c_c (cacosh, 0x0.ffffffp0L, -0x1.fp-129L, 8.245504387859737323891843603996428534945e-36L, -3.452669847162035876032494826387364972849e-4L);
2461 TEST_c_c (cacosh, -0x0.ffffffp0L, -0x1.fp-129L, 8.245504387859737323891843603996428534945e-36L, -3.141247386605077034875040133796864147700L);
2462 TEST_c_c (cacosh, 0.0L, 0x0.ffffffp0L, 8.813735448726938863015878255140556727969e-1L, 1.570796326794896619231321691639751442099L);
2463 TEST_c_c (cacosh, 0.0L, -0x0.ffffffp0L, 8.813735448726938863015878255140556727969e-1L, -1.570796326794896619231321691639751442099L);
2464 TEST_c_c (cacosh, -0.0L, 0x0.ffffffp0L, 8.813735448726938863015878255140556727969e-1L, 1.570796326794896619231321691639751442099L);
2465 TEST_c_c (cacosh, -0.0L, -0x0.ffffffp0L, 8.813735448726938863015878255140556727969e-1L, -1.570796326794896619231321691639751442099L);
2466 TEST_c_c (cacosh, 0x0.ffffffp0L, 0.0L, 0.0L, 3.452669847162035876032494826387364972849e-4L);
2467 TEST_c_c (cacosh, -0x0.ffffffp0L, 0.0L, 0.0L, 3.141247386605077034875040133796864147700L);
2468 TEST_c_c (cacosh, 0x0.ffffffp0L, -0.0L, 0.0L, -3.452669847162035876032494826387364972849e-4L);
2469 TEST_c_c (cacosh, -0x0.ffffffp0L, -0.0L, 0.0L, -3.141247386605077034875040133796864147700L);
2470 TEST_c_c (cacosh, 0x1p-23L, 0.5L, 4.812118250596059896127318386463676808798e-1L, 1.570796220170866625230343643673321150378L);
2471 TEST_c_c (cacosh, 0x1p-23L, -0.5L, 4.812118250596059896127318386463676808798e-1L, -1.570796220170866625230343643673321150378L);
2472 TEST_c_c (cacosh, -0x1p-23L, 0.5L, 4.812118250596059896127318386463676808798e-1L, 1.570796433418926613232299739606181733819L);
2473 TEST_c_c (cacosh, -0x1p-23L, -0.5L, 4.812118250596059896127318386463676808798e-1L, -1.570796433418926613232299739606181733819L);
2474 TEST_c_c (cacosh, 0.5L, 0x1p-23L, 1.376510308240943236356088341381173571841e-7L, 1.047197551196603215914744618665204532273L);
2475 TEST_c_c (cacosh, -0.5L, 0x1p-23L, 1.376510308240943236356088341381173571841e-7L, 2.094395102393190022547898764614298351924L);
2476 TEST_c_c (cacosh, 0.5L, -0x1p-23L, 1.376510308240943236356088341381173571841e-7L, -1.047197551196603215914744618665204532273L);
2477 TEST_c_c (cacosh, -0.5L, -0x1p-23L, 1.376510308240943236356088341381173571841e-7L, -2.094395102393190022547898764614298351924L);
2478 TEST_c_c (cacosh, 0x1.fp-129L, 0.5L, 4.812118250596034474977589134243684231352e-1L, 1.570796326794896619231321691639751442096L);
2479 TEST_c_c (cacosh, 0x1.fp-129L, -0.5L, 4.812118250596034474977589134243684231352e-1L, -1.570796326794896619231321691639751442096L);
2480 TEST_c_c (cacosh, -0x1.fp-129L, 0.5L, 4.812118250596034474977589134243684231352e-1L, 1.570796326794896619231321691639751442101L);
2481 TEST_c_c (cacosh, -0x1.fp-129L, -0.5L, 4.812118250596034474977589134243684231352e-1L, -1.570796326794896619231321691639751442101L);
2482 TEST_c_c (cacosh, 0.5L, 0x1.fp-129L, 3.287317402534702257036015056278368274737e-39L, 1.047197551196597746154214461093167628066L, UNDERFLOW_EXCEPTION_FLOAT);
2483 TEST_c_c (cacosh, -0.5L, 0x1.fp-129L, 3.287317402534702257036015056278368274737e-39L, 2.094395102393195492308428922186335256131L, UNDERFLOW_EXCEPTION_FLOAT);
2484 TEST_c_c (cacosh, 0.5L, -0x1.fp-129L, 3.287317402534702257036015056278368274737e-39L, -1.047197551196597746154214461093167628066L, UNDERFLOW_EXCEPTION_FLOAT);
2485 TEST_c_c (cacosh, -0.5L, -0x1.fp-129L, 3.287317402534702257036015056278368274737e-39L, -2.094395102393195492308428922186335256131L, UNDERFLOW_EXCEPTION_FLOAT);
2486 TEST_c_c (cacosh, 0x1p-23L, 0x1p-23L, 1.192092895507818146886315028596704749235e-7L, 1.570796207585607068450636380271254316214L);
2487 TEST_c_c (cacosh, 0x1p-23L, -0x1p-23L, 1.192092895507818146886315028596704749235e-7L, -1.570796207585607068450636380271254316214L);
2488 TEST_c_c (cacosh, -0x1p-23L, 0x1p-23L, 1.192092895507818146886315028596704749235e-7L, 1.570796446004186170012007003008248567984L);
2489 TEST_c_c (cacosh, -0x1p-23L, -0x1p-23L, 1.192092895507818146886315028596704749235e-7L, -1.570796446004186170012007003008248567984L);
2490 TEST_c_c (cacosh, 0x1.fp-129L, 0x1p-23L, 1.192092895507809676556842485683592032154e-7L, 1.570796326794896619231321691639751442096L);
2491 TEST_c_c (cacosh, 0x1.fp-129L, -0x1p-23L, 1.192092895507809676556842485683592032154e-7L, -1.570796326794896619231321691639751442096L);
2492 TEST_c_c (cacosh, -0x1.fp-129L, 0x1p-23L, 1.192092895507809676556842485683592032154e-7L, 1.570796326794896619231321691639751442101L);
2493 TEST_c_c (cacosh, -0x1.fp-129L, -0x1p-23L, 1.192092895507809676556842485683592032154e-7L, -1.570796326794896619231321691639751442101L);
2494 TEST_c_c (cacosh, 0x1p-23L, 0x1.fp-129L, 2.846900380897747786805634596726756660388e-39L, 1.570796207585607068449789347324000006847L, UNDERFLOW_EXCEPTION_FLOAT);
2495 TEST_c_c (cacosh, -0x1p-23L, 0x1.fp-129L, 2.846900380897747786805634596726756660388e-39L, 1.570796446004186170012854035955502877351L, UNDERFLOW_EXCEPTION_FLOAT);
2496 TEST_c_c (cacosh, 0x1p-23L, -0x1.fp-129L, 2.846900380897747786805634596726756660388e-39L, -1.570796207585607068449789347324000006847L, UNDERFLOW_EXCEPTION_FLOAT);
2497 TEST_c_c (cacosh, -0x1p-23L, -0x1.fp-129L, 2.846900380897747786805634596726756660388e-39L, -1.570796446004186170012854035955502877351L, UNDERFLOW_EXCEPTION_FLOAT);
2498 TEST_c_c (cacosh, 0.0L, 0x1p-23L, 1.192092895507809676556842485683592032154e-7L, 1.570796326794896619231321691639751442099L);
2499 TEST_c_c (cacosh, 0.0L, -0x1p-23L, 1.192092895507809676556842485683592032154e-7L, -1.570796326794896619231321691639751442099L);
2500 TEST_c_c (cacosh, -0.0L, 0x1p-23L, 1.192092895507809676556842485683592032154e-7L, 1.570796326794896619231321691639751442099L);
2501 TEST_c_c (cacosh, -0.0L, -0x1p-23L, 1.192092895507809676556842485683592032154e-7L, -1.570796326794896619231321691639751442099L);
2502 TEST_c_c (cacosh, 0x1p-23L, 0.0L, 0.0L, 1.570796207585607068449789347324000006847L);
2503 TEST_c_c (cacosh, -0x1p-23L, 0.0L, 0.0L, 1.570796446004186170012854035955502877351L);
2504 TEST_c_c (cacosh, 0x1p-23L, -0.0L, 0.0L, -1.570796207585607068449789347324000006847L);
2505 TEST_c_c (cacosh, -0x1p-23L, -0.0L, 0.0L, -1.570796446004186170012854035955502877351L);
2506 TEST_c_c (cacosh, 0x1.fp-129L, 0x1.fp-129L, 2.846900380897727558361783801085126250967e-39L, 1.570796326794896619231321691639751442096L, UNDERFLOW_EXCEPTION_FLOAT);
2507 TEST_c_c (cacosh, 0x1.fp-129L, -0x1.fp-129L, 2.846900380897727558361783801085126250967e-39L, -1.570796326794896619231321691639751442096L, UNDERFLOW_EXCEPTION_FLOAT);
2508 TEST_c_c (cacosh, -0x1.fp-129L, 0x1.fp-129L, 2.846900380897727558361783801085126250967e-39L, 1.570796326794896619231321691639751442101L, UNDERFLOW_EXCEPTION_FLOAT);
2509 TEST_c_c (cacosh, -0x1.fp-129L, -0x1.fp-129L, 2.846900380897727558361783801085126250967e-39L, -1.570796326794896619231321691639751442101L, UNDERFLOW_EXCEPTION_FLOAT);
2510#ifndef TEST_FLOAT
2511 TEST_c_c (cacosh, 0x1p-52L, 0x0.fffffffffffff8p0L, 8.813735870195429467279863907910458761820e-1L, 1.570796326794896462222075823262236786996L);
2512 TEST_c_c (cacosh, 0x1p-52L, -0x0.fffffffffffff8p0L, 8.813735870195429467279863907910458761820e-1L, -1.570796326794896462222075823262236786996L);
2513 TEST_c_c (cacosh, -0x1p-52L, 0x0.fffffffffffff8p0L, 8.813735870195429467279863907910458761820e-1L, 1.570796326794896776240567560017266097201L);
2514 TEST_c_c (cacosh, -0x1p-52L, -0x0.fffffffffffff8p0L, 8.813735870195429467279863907910458761820e-1L, -1.570796326794896776240567560017266097201L);
2515 TEST_c_c (cacosh, 0x0.fffffffffffff8p0L, 0x1p-52L, 1.171456840272878582596796205397918831268e-8L, 1.895456983915074112227925127005564372844e-8L);
2516 TEST_c_c (cacosh, -0x0.fffffffffffff8p0L, 0x1p-52L, 1.171456840272878582596796205397918831268e-8L, 3.141592634635223399311902261000251614142L);
2517 TEST_c_c (cacosh, 0x0.fffffffffffff8p0L, -0x1p-52L, 1.171456840272878582596796205397918831268e-8L, -1.895456983915074112227925127005564372844e-8L);
2518 TEST_c_c (cacosh, -0x0.fffffffffffff8p0L, -0x1p-52L, 1.171456840272878582596796205397918831268e-8L, -3.141592634635223399311902261000251614142L);
2519 TEST_c_c (cacosh, 0x1.fp-1025L, 0x0.fffffffffffff8p0L, 8.813735870195429467279863907910371604180e-1L, 1.570796326794896619231321691639751442099L);
2520 TEST_c_c (cacosh, 0x1.fp-1025L, -0x0.fffffffffffff8p0L, 8.813735870195429467279863907910371604180e-1L, -1.570796326794896619231321691639751442099L);
2521 TEST_c_c (cacosh, -0x1.fp-1025L, 0x0.fffffffffffff8p0L, 8.813735870195429467279863907910371604180e-1L, 1.570796326794896619231321691639751442099L);
2522 TEST_c_c (cacosh, -0x1.fp-1025L, -0x0.fffffffffffff8p0L, 8.813735870195429467279863907910371604180e-1L, -1.570796326794896619231321691639751442099L);
2523 TEST_c_c (cacosh, 0x0.fffffffffffff8p0L, 0x1.fp-1025L, 3.616396521699973256461764099945789620604e-301L, 1.490116119384765638786343542550461592240e-8L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM);
2524 TEST_c_c (cacosh, -0x0.fffffffffffff8p0L, 0x1.fp-1025L, 3.616396521699973256461764099945789620604e-301L, 3.141592638688632044614986995416067458693L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM);
2525 TEST_c_c (cacosh, 0x0.fffffffffffff8p0L, -0x1.fp-1025L, 3.616396521699973256461764099945789620604e-301L, -1.490116119384765638786343542550461592240e-8L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM);
2526 TEST_c_c (cacosh, -0x0.fffffffffffff8p0L, -0x1.fp-1025L, 3.616396521699973256461764099945789620604e-301L, -3.141592638688632044614986995416067458693L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM);
2527 TEST_c_c (cacosh, 0.0L, 0x0.fffffffffffff8p0L, 8.813735870195429467279863907910371604180e-1L, 1.570796326794896619231321691639751442099L);
2528 TEST_c_c (cacosh, 0.0L, -0x0.fffffffffffff8p0L, 8.813735870195429467279863907910371604180e-1L, -1.570796326794896619231321691639751442099L);
2529 TEST_c_c (cacosh, -0.0L, 0x0.fffffffffffff8p0L, 8.813735870195429467279863907910371604180e-1L, 1.570796326794896619231321691639751442099L);
2530 TEST_c_c (cacosh, -0.0L, -0x0.fffffffffffff8p0L, 8.813735870195429467279863907910371604180e-1L, -1.570796326794896619231321691639751442099L);
2531 TEST_c_c (cacosh, 0x0.fffffffffffff8p0L, 0.0L, 0.0L, 1.490116119384765638786343542550461592240e-8L);
2532 TEST_c_c (cacosh, -0x0.fffffffffffff8p0L, 0.0L, 0.0L, 3.141592638688632044614986995416067458693L);
2533 TEST_c_c (cacosh, 0x0.fffffffffffff8p0L, -0.0L, 0.0L, -1.490116119384765638786343542550461592240e-8L);
2534 TEST_c_c (cacosh, -0x0.fffffffffffff8p0L, -0.0L, 0.0L, -3.141592638688632044614986995416067458693L);
2535#endif
2536 TEST_c_c (cacosh, 0x1p-52L, 0.5L, 4.812118250596034474977589134243772428682e-1L, 1.570796326794896420628589431857911675917L);
2537 TEST_c_c (cacosh, 0x1p-52L, -0.5L, 4.812118250596034474977589134243772428682e-1L, -1.570796326794896420628589431857911675917L);
2538 TEST_c_c (cacosh, -0x1p-52L, 0.5L, 4.812118250596034474977589134243772428682e-1L, 1.570796326794896817834053951421591208280L);
2539 TEST_c_c (cacosh, -0x1p-52L, -0.5L, 4.812118250596034474977589134243772428682e-1L, -1.570796326794896817834053951421591208280L);
2540 TEST_c_c (cacosh, 0.5L, 0x1p-52L, 2.563950248511418570403591756798643804971e-16L, 1.047197551196597746154214461093186605110L);
2541 TEST_c_c (cacosh, -0.5L, 0x1p-52L, 2.563950248511418570403591756798643804971e-16L, 2.094395102393195492308428922186316279087L);
2542 TEST_c_c (cacosh, 0.5L, -0x1p-52L, 2.563950248511418570403591756798643804971e-16L, -1.047197551196597746154214461093186605110L);
2543 TEST_c_c (cacosh, -0.5L, -0x1p-52L, 2.563950248511418570403591756798643804971e-16L, -2.094395102393195492308428922186316279087L);
2544#ifndef TEST_FLOAT
2545 TEST_c_c (cacosh, 0x1.fp-1025L, 0.5L, 4.812118250596034474977589134243684231352e-1L, 1.570796326794896619231321691639751442099L);
2546 TEST_c_c (cacosh, 0x1.fp-1025L, -0.5L, 4.812118250596034474977589134243684231352e-1L, -1.570796326794896619231321691639751442099L);
2547 TEST_c_c (cacosh, -0x1.fp-1025L, 0.5L, 4.812118250596034474977589134243684231352e-1L, 1.570796326794896619231321691639751442099L);
2548 TEST_c_c (cacosh, -0x1.fp-1025L, -0.5L, 4.812118250596034474977589134243684231352e-1L, -1.570796326794896619231321691639751442099L);
2549 TEST_c_c (cacosh, 0.5L, 0x1.fp-1025L, 6.222508863508420569166420770843207333493e-309L, 1.047197551196597746154214461093167628066L, UNDERFLOW_EXCEPTION_DOUBLE);
2550 TEST_c_c (cacosh, -0.5L, 0x1.fp-1025L, 6.222508863508420569166420770843207333493e-309L, 2.094395102393195492308428922186335256131L, UNDERFLOW_EXCEPTION_DOUBLE);
2551 TEST_c_c (cacosh, 0.5L, -0x1.fp-1025L, 6.222508863508420569166420770843207333493e-309L, -1.047197551196597746154214461093167628066L, UNDERFLOW_EXCEPTION_DOUBLE);
2552 TEST_c_c (cacosh, -0.5L, -0x1.fp-1025L, 6.222508863508420569166420770843207333493e-309L, -2.094395102393195492308428922186335256131L, UNDERFLOW_EXCEPTION_DOUBLE);
2553#endif
2554 TEST_c_c (cacosh, 0x1p-52L, 0x1p-52L, 2.220446049250313080847263336181677117148e-16L, 1.570796326794896397186716766608443357372L);
2555 TEST_c_c (cacosh, 0x1p-52L, -0x1p-52L, 2.220446049250313080847263336181677117148e-16L, -1.570796326794896397186716766608443357372L);
2556 TEST_c_c (cacosh, -0x1p-52L, 0x1p-52L, 2.220446049250313080847263336181677117148e-16L, 1.570796326794896841275926616671059526825L);
2557 TEST_c_c (cacosh, -0x1p-52L, -0x1p-52L, 2.220446049250313080847263336181677117148e-16L, -1.570796326794896841275926616671059526825L);
2558#ifndef TEST_FLOAT
2559 TEST_c_c (cacosh, 0x1.fp-1025L, 0x1p-52L, 2.220446049250313080847263336181622378926e-16L, 1.570796326794896619231321691639751442099L);
2560 TEST_c_c (cacosh, 0x1.fp-1025L, -0x1p-52L, 2.220446049250313080847263336181622378926e-16L, -1.570796326794896619231321691639751442099L);
2561 TEST_c_c (cacosh, -0x1.fp-1025L, 0x1p-52L, 2.220446049250313080847263336181622378926e-16L, 1.570796326794896619231321691639751442099L);
2562 TEST_c_c (cacosh, -0x1.fp-1025L, -0x1p-52L, 2.220446049250313080847263336181622378926e-16L, -1.570796326794896619231321691639751442099L);
2563 TEST_c_c (cacosh, 0x1p-52L, 0x1.fp-1025L, 5.388850751072128349671657362289548938458e-309L, 1.570796326794896397186716766608443357372L, UNDERFLOW_EXCEPTION_DOUBLE);
2564 TEST_c_c (cacosh, -0x1p-52L, 0x1.fp-1025L, 5.388850751072128349671657362289548938458e-309L, 1.570796326794896841275926616671059526825L, UNDERFLOW_EXCEPTION_DOUBLE);
2565 TEST_c_c (cacosh, 0x1p-52L, -0x1.fp-1025L, 5.388850751072128349671657362289548938458e-309L, -1.570796326794896397186716766608443357372L, UNDERFLOW_EXCEPTION_DOUBLE);
2566 TEST_c_c (cacosh, -0x1p-52L, -0x1.fp-1025L, 5.388850751072128349671657362289548938458e-309L, -1.570796326794896841275926616671059526825L, UNDERFLOW_EXCEPTION_DOUBLE);
2567#endif
2568 TEST_c_c (cacosh, 0.0L, 0x1p-52L, 2.220446049250313080847263336181622378926e-16L, 1.570796326794896619231321691639751442099L);
2569 TEST_c_c (cacosh, 0.0L, -0x1p-52L, 2.220446049250313080847263336181622378926e-16L, -1.570796326794896619231321691639751442099L);
2570 TEST_c_c (cacosh, -0.0L, 0x1p-52L, 2.220446049250313080847263336181622378926e-16L, 1.570796326794896619231321691639751442099L);
2571 TEST_c_c (cacosh, -0.0L, -0x1p-52L, 2.220446049250313080847263336181622378926e-16L, -1.570796326794896619231321691639751442099L);
2572 TEST_c_c (cacosh, 0x1p-52L, 0.0L, 0.0L, 1.570796326794896397186716766608443357372L);
2573 TEST_c_c (cacosh, -0x1p-52L, 0.0L, 0.0L, 1.570796326794896841275926616671059526825L);
2574 TEST_c_c (cacosh, 0x1p-52L, -0.0L, 0.0L, -1.570796326794896397186716766608443357372L);
2575 TEST_c_c (cacosh, -0x1p-52L, -0.0L, 0.0L, -1.570796326794896841275926616671059526825L);
2576#ifndef TEST_FLOAT
2577 TEST_c_c (cacosh, 0x1.fp-1025L, 0x1.fp-1025L, 5.388850751072128349671657362289416093031e-309L, 1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION_DOUBLE);
2578 TEST_c_c (cacosh, 0x1.fp-1025L, -0x1.fp-1025L, 5.388850751072128349671657362289416093031e-309L, -1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION_DOUBLE);
2579 TEST_c_c (cacosh, -0x1.fp-1025L, 0x1.fp-1025L, 5.388850751072128349671657362289416093031e-309L, 1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION_DOUBLE);
2580 TEST_c_c (cacosh, -0x1.fp-1025L, -0x1.fp-1025L, 5.388850751072128349671657362289416093031e-309L, -1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION_DOUBLE);
2581#endif
2582#if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 64
2583 TEST_c_c (cacosh, 0x1p-63L, 0x0.ffffffffffffffffp0L, 8.813735870195430251942769895627079569937e-1L, 1.570796326794896619154657020805582738025L);
2584 TEST_c_c (cacosh, 0x1p-63L, -0x0.ffffffffffffffffp0L, 8.813735870195430251942769895627079569937e-1L, -1.570796326794896619154657020805582738025L);
2585 TEST_c_c (cacosh, -0x1p-63L, 0x0.ffffffffffffffffp0L, 8.813735870195430251942769895627079569937e-1L, 1.570796326794896619307986362473920146173L);
2586 TEST_c_c (cacosh, -0x1p-63L, -0x0.ffffffffffffffffp0L, 8.813735870195430251942769895627079569937e-1L, -1.570796326794896619307986362473920146173L);
2587 TEST_c_c (cacosh, 0x0.ffffffffffffffffp0L, 0x1p-63L, 2.588578361325995866221775673638805081337e-10L, 4.188407771167967636741951941902992986043e-10L);
2588 TEST_c_c (cacosh, -0x0.ffffffffffffffffp0L, 0x1p-63L, 2.588578361325995866221775673638805081337e-10L, 3.141592653170952461345846619605307690007L);
2589 TEST_c_c (cacosh, 0x0.ffffffffffffffffp0L, -0x1p-63L, 2.588578361325995866221775673638805081337e-10L, -4.188407771167967636741951941902992986043e-10L);
2590 TEST_c_c (cacosh, -0x0.ffffffffffffffffp0L, -0x1p-63L, 2.588578361325995866221775673638805081337e-10L, -3.141592653170952461345846619605307690007L);
2591# if LDBL_MIN_EXP <= -16381
2592 TEST_c_c (cacosh, 0x1.fp-16385L, 0x0.ffffffffffffffffp0L, 8.813735870195430251942769895627079569917e-1L, 1.570796326794896619231321691639751442099L);
2593 TEST_c_c (cacosh, 0x1.fp-16385L, -0x0.ffffffffffffffffp0L, 8.813735870195430251942769895627079569917e-1L, -1.570796326794896619231321691639751442099L);
2594 TEST_c_c (cacosh, -0x1.fp-16385L, 0x0.ffffffffffffffffp0L, 8.813735870195430251942769895627079569917e-1L, 1.570796326794896619231321691639751442099L);
2595 TEST_c_c (cacosh, -0x1.fp-16385L, -0x0.ffffffffffffffffp0L, 8.813735870195430251942769895627079569917e-1L, -1.570796326794896619231321691639751442099L);
2596 TEST_c_c (cacosh, 0x0.ffffffffffffffffp0L, 0x1.fp-16385L, 2.472906068161537187835415298076415423459e-4923L, 3.292722539913596233371825532007990724506e-10L);
2597 TEST_c_c (cacosh, -0x0.ffffffffffffffffp0L, 0x1.fp-16385L, 2.472906068161537187835415298076415423459e-4923L, 3.141592653260520984471283759942320330996L);
2598 TEST_c_c (cacosh, 0x0.ffffffffffffffffp0L, -0x1.fp-16385L, 2.472906068161537187835415298076415423459e-4923L, -3.292722539913596233371825532007990724506e-10L);
2599 TEST_c_c (cacosh, -0x0.ffffffffffffffffp0L, -0x1.fp-16385L, 2.472906068161537187835415298076415423459e-4923L, -3.141592653260520984471283759942320330996L);
2600# endif
2601 TEST_c_c (cacosh, 0.0L, 0x0.ffffffffffffffffp0L, 8.813735870195430251942769895627079569917e-1L, 1.570796326794896619231321691639751442099L);
2602 TEST_c_c (cacosh, 0.0L, -0x0.ffffffffffffffffp0L, 8.813735870195430251942769895627079569917e-1L, -1.570796326794896619231321691639751442099L);
2603 TEST_c_c (cacosh, -0.0L, 0x0.ffffffffffffffffp0L, 8.813735870195430251942769895627079569917e-1L, 1.570796326794896619231321691639751442099L);
2604 TEST_c_c (cacosh, -0.0L, -0x0.ffffffffffffffffp0L, 8.813735870195430251942769895627079569917e-1L, -1.570796326794896619231321691639751442099L);
2605 TEST_c_c (cacosh, 0x0.ffffffffffffffffp0L, 0.0L, 0.0L, 3.292722539913596233371825532007990724506e-10L);
2606 TEST_c_c (cacosh, -0x0.ffffffffffffffffp0L, 0.0L, 0.0L, 3.141592653260520984471283759942320330996L);
2607 TEST_c_c (cacosh, 0x0.ffffffffffffffffp0L, -0.0L, 0.0L, -3.292722539913596233371825532007990724506e-10L);
2608 TEST_c_c (cacosh, -0x0.ffffffffffffffffp0L, -0.0L, 0.0L, -3.141592653260520984471283759942320330996L);
2609#endif
2610 TEST_c_c (cacosh, 0x1p-63L, 0.5L, 4.812118250596034474977589134243684231373e-1L, 1.570796326794896619134347701278529840650L);
2611 TEST_c_c (cacosh, 0x1p-63L, -0.5L, 4.812118250596034474977589134243684231373e-1L, -1.570796326794896619134347701278529840650L);
2612 TEST_c_c (cacosh, -0x1p-63L, 0.5L, 4.812118250596034474977589134243684231373e-1L, 1.570796326794896619328295682000973043547L);
2613 TEST_c_c (cacosh, -0x1p-63L, -0.5L, 4.812118250596034474977589134243684231373e-1L, -1.570796326794896619328295682000973043547L);
2614 TEST_c_c (cacosh, 0.5L, 0x1p-63L, 1.251928832280966098829878787499365228659e-19L, 1.047197551196597746154214461093167628070L);
2615 TEST_c_c (cacosh, -0.5L, 0x1p-63L, 1.251928832280966098829878787499365228659e-19L, 2.094395102393195492308428922186335256127L);
2616 TEST_c_c (cacosh, 0.5L, -0x1p-63L, 1.251928832280966098829878787499365228659e-19L, -1.047197551196597746154214461093167628070L);
2617 TEST_c_c (cacosh, -0.5L, -0x1p-63L, 1.251928832280966098829878787499365228659e-19L, -2.094395102393195492308428922186335256127L);
2618#if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
2619 TEST_c_c (cacosh, 0x1.fp-16385L, 0.5L, 4.812118250596034474977589134243684231352e-1L, 1.570796326794896619231321691639751442099L);
2620 TEST_c_c (cacosh, 0x1.fp-16385L, -0.5L, 4.812118250596034474977589134243684231352e-1L, -1.570796326794896619231321691639751442099L);
2621 TEST_c_c (cacosh, -0x1.fp-16385L, 0.5L, 4.812118250596034474977589134243684231352e-1L, 1.570796326794896619231321691639751442099L);
2622 TEST_c_c (cacosh, -0x1.fp-16385L, -0.5L, 4.812118250596034474977589134243684231352e-1L, -1.570796326794896619231321691639751442099L);
2623 TEST_c_c (cacosh, 0.5L, 0x1.fp-16385L, 9.402257155670418112159334875199821342890e-4933L, 1.047197551196597746154214461093167628066L, UNDERFLOW_EXCEPTION);
2624 TEST_c_c (cacosh, -0.5L, 0x1.fp-16385L, 9.402257155670418112159334875199821342890e-4933L, 2.094395102393195492308428922186335256131L, UNDERFLOW_EXCEPTION);
2625 TEST_c_c (cacosh, 0.5L, -0x1.fp-16385L, 9.402257155670418112159334875199821342890e-4933L, -1.047197551196597746154214461093167628066L, UNDERFLOW_EXCEPTION);
2626 TEST_c_c (cacosh, -0.5L, -0x1.fp-16385L, 9.402257155670418112159334875199821342890e-4933L, -2.094395102393195492308428922186335256131L, UNDERFLOW_EXCEPTION);
2627#endif
2628 TEST_c_c (cacosh, 0x1p-63L, 0x1p-63L, 1.084202172485504434007452800869941711430e-19L, 1.570796326794896619122901474391200998698L);
2629 TEST_c_c (cacosh, 0x1p-63L, -0x1p-63L, 1.084202172485504434007452800869941711430e-19L, -1.570796326794896619122901474391200998698L);
2630 TEST_c_c (cacosh, -0x1p-63L, 0x1p-63L, 1.084202172485504434007452800869941711430e-19L, 1.570796326794896619339741908888301885499L);
2631 TEST_c_c (cacosh, -0x1p-63L, -0x1p-63L, 1.084202172485504434007452800869941711430e-19L, -1.570796326794896619339741908888301885499L);
2632#if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
2633 TEST_c_c (cacosh, 0x1.fp-16385L, 0x1p-63L, 1.084202172485504434007452800869941711424e-19L, 1.570796326794896619231321691639751442099L);
2634 TEST_c_c (cacosh, 0x1.fp-16385L, -0x1p-63L, 1.084202172485504434007452800869941711424e-19L, -1.570796326794896619231321691639751442099L);
2635 TEST_c_c (cacosh, -0x1.fp-16385L, 0x1p-63L, 1.084202172485504434007452800869941711424e-19L, 1.570796326794896619231321691639751442099L);
2636 TEST_c_c (cacosh, -0x1.fp-16385L, -0x1p-63L, 1.084202172485504434007452800869941711424e-19L, -1.570796326794896619231321691639751442099L);
2637 TEST_c_c (cacosh, 0x1p-63L, 0x1.fp-16385L, 8.142593549724601460479922838826119584465e-4933L, 1.570796326794896619122901474391200998698L, UNDERFLOW_EXCEPTION);
2638 TEST_c_c (cacosh, -0x1p-63L, 0x1.fp-16385L, 8.142593549724601460479922838826119584465e-4933L, 1.570796326794896619339741908888301885499L, UNDERFLOW_EXCEPTION);
2639 TEST_c_c (cacosh, 0x1p-63L, -0x1.fp-16385L, 8.142593549724601460479922838826119584465e-4933L, -1.570796326794896619122901474391200998698L, UNDERFLOW_EXCEPTION);
2640 TEST_c_c (cacosh, -0x1p-63L, -0x1.fp-16385L, 8.142593549724601460479922838826119584465e-4933L, -1.570796326794896619339741908888301885499L, UNDERFLOW_EXCEPTION);
2641#endif
2642 TEST_c_c (cacosh, 0.0L, 0x1p-63L, 1.084202172485504434007452800869941711424e-19L, 1.570796326794896619231321691639751442099L);
2643 TEST_c_c (cacosh, 0.0L, -0x1p-63L, 1.084202172485504434007452800869941711424e-19L, -1.570796326794896619231321691639751442099L);
2644 TEST_c_c (cacosh, -0.0L, 0x1p-63L, 1.084202172485504434007452800869941711424e-19L, 1.570796326794896619231321691639751442099L);
2645 TEST_c_c (cacosh, -0.0L, -0x1p-63L, 1.084202172485504434007452800869941711424e-19L, -1.570796326794896619231321691639751442099L);
2646 TEST_c_c (cacosh, 0x1p-63L, 0.0L, 0.0L, 1.570796326794896619122901474391200998698L);
2647 TEST_c_c (cacosh, -0x1p-63L, 0.0L, 0.0L, 1.570796326794896619339741908888301885499L);
2648 TEST_c_c (cacosh, 0x1p-63L, -0.0L, 0.0L, -1.570796326794896619122901474391200998698L);
2649 TEST_c_c (cacosh, -0x1p-63L, -0.0L, 0.0L, -1.570796326794896619339741908888301885499L);
2650#if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
2651 TEST_c_c (cacosh, 0x1.fp-16385L, 0x1.fp-16385L, 8.142593549724601460479922838826119584417e-4933L, 1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION);
2652 TEST_c_c (cacosh, 0x1.fp-16385L, -0x1.fp-16385L, 8.142593549724601460479922838826119584417e-4933L, -1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION);
2653 TEST_c_c (cacosh, -0x1.fp-16385L, 0x1.fp-16385L, 8.142593549724601460479922838826119584417e-4933L, 1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION);
2654 TEST_c_c (cacosh, -0x1.fp-16385L, -0x1.fp-16385L, 8.142593549724601460479922838826119584417e-4933L, -1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION);
2655#endif
2656#if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 106
2657 TEST_c_c (cacosh, 0x1p-105L, 0x0.ffffffffffffffffffffffffffcp0L, 8.813735870195430252326093249797835932642e-1L, 1.570796326794896619231321691639734010571L);
2658 TEST_c_c (cacosh, 0x1p-105L, -0x0.ffffffffffffffffffffffffffcp0L, 8.813735870195430252326093249797835932642e-1L, -1.570796326794896619231321691639734010571L);
2659 TEST_c_c (cacosh, -0x1p-105L, 0x0.ffffffffffffffffffffffffffcp0L, 8.813735870195430252326093249797835932642e-1L, 1.570796326794896619231321691639768873627L);
2660 TEST_c_c (cacosh, -0x1p-105L, -0x0.ffffffffffffffffffffffffffcp0L, 8.813735870195430252326093249797835932642e-1L, -1.570796326794896619231321691639768873627L);
2661 TEST_c_c (cacosh, 0x0.ffffffffffffffffffffffffffcp0L, 0x1p-105L, 1.234330349600789959989661887846005659983e-16L, 1.997188458999618357060632049675702684031e-16L);
2662 TEST_c_c (cacosh, -0x0.ffffffffffffffffffffffffffcp0L, 0x1p-105L, 1.234330349600789959989661887846005659983e-16L, 3.141592653589793038743797483317667178134L);
2663 TEST_c_c (cacosh, 0x0.ffffffffffffffffffffffffffcp0L, -0x1p-105L, 1.234330349600789959989661887846005659983e-16L, -1.997188458999618357060632049675702684031e-16L);
2664 TEST_c_c (cacosh, -0x0.ffffffffffffffffffffffffffcp0L, -0x1p-105L, 1.234330349600789959989661887846005659983e-16L, -3.141592653589793038743797483317667178134L);
2665 TEST_c_c (cacosh, 0x1.fp-1025L, 0x0.ffffffffffffffffffffffffffcp0L, 8.813735870195430252326093249797835932642e-1L, 1.570796326794896619231321691639751442099L);
2666 TEST_c_c (cacosh, 0x1.fp-1025L, -0x0.ffffffffffffffffffffffffffcp0L, 8.813735870195430252326093249797835932642e-1L, -1.570796326794896619231321691639751442099L);
2667 TEST_c_c (cacosh, -0x1.fp-1025L, 0x0.ffffffffffffffffffffffffffcp0L, 8.813735870195430252326093249797835932642e-1L, 1.570796326794896619231321691639751442099L);
2668 TEST_c_c (cacosh, -0x1.fp-1025L, -0x0.ffffffffffffffffffffffffffcp0L, 8.813735870195430252326093249797835932642e-1L, -1.570796326794896619231321691639751442099L);
2669 TEST_c_c (cacosh, 0x0.ffffffffffffffffffffffffffcp0L, 0x1.fp-1025L, 3.432186888910770473784103112009399360940e-293L, 1.570092458683775059393382371963565104164e-16L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM);
2670 TEST_c_c (cacosh, -0x0.ffffffffffffffffffffffffffcp0L, 0x1.fp-1025L, 3.432186888910770473784103112009399360940e-293L, 3.141592653589793081453397514901996944859L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM);
2671 TEST_c_c (cacosh, 0x0.ffffffffffffffffffffffffffcp0L, -0x1.fp-1025L, 3.432186888910770473784103112009399360940e-293L, -1.570092458683775059393382371963565104164e-16L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM);
2672 TEST_c_c (cacosh, -0x0.ffffffffffffffffffffffffffcp0L, -0x1.fp-1025L, 3.432186888910770473784103112009399360940e-293L, -3.141592653589793081453397514901996944859L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM);
2673 TEST_c_c (cacosh, 0.0L, 0x0.ffffffffffffffffffffffffffcp0L, 8.813735870195430252326093249797835932642e-1L, 1.570796326794896619231321691639751442099L);
2674 TEST_c_c (cacosh, 0.0L, -0x0.ffffffffffffffffffffffffffcp0L, 8.813735870195430252326093249797835932642e-1L, -1.570796326794896619231321691639751442099L);
2675 TEST_c_c (cacosh, -0.0L, 0x0.ffffffffffffffffffffffffffcp0L, 8.813735870195430252326093249797835932642e-1L, 1.570796326794896619231321691639751442099L);
2676 TEST_c_c (cacosh, -0.0L, -0x0.ffffffffffffffffffffffffffcp0L, 8.813735870195430252326093249797835932642e-1L, -1.570796326794896619231321691639751442099L);
2677 TEST_c_c (cacosh, 0x0.ffffffffffffffffffffffffffcp0L, 0.0L, 0.0L, 1.570092458683775059393382371963565104164e-16L);
2678 TEST_c_c (cacosh, -0x0.ffffffffffffffffffffffffffcp0L, 0.0L, 0.0L, 3.141592653589793081453397514901996944859L);
2679 TEST_c_c (cacosh, 0x0.ffffffffffffffffffffffffffcp0L, -0.0L, 0.0L, -1.570092458683775059393382371963565104164e-16L);
2680 TEST_c_c (cacosh, -0x0.ffffffffffffffffffffffffffcp0L, -0.0L, 0.0L, -3.141592653589793081453397514901996944859L);
2681#endif
2682 TEST_c_c (cacosh, 0x1p-105L, 0.5L, 4.812118250596034474977589134243684231352e-1L, 1.570796326794896619231321691639729392766L);
2683 TEST_c_c (cacosh, 0x1p-105L, -0.5L, 4.812118250596034474977589134243684231352e-1L, -1.570796326794896619231321691639729392766L);
2684 TEST_c_c (cacosh, -0x1p-105L, 0.5L, 4.812118250596034474977589134243684231352e-1L, 1.570796326794896619231321691639773491431L);
2685 TEST_c_c (cacosh, -0x1p-105L, -0.5L, 4.812118250596034474977589134243684231352e-1L, -1.570796326794896619231321691639773491431L);
2686 TEST_c_c (cacosh, 0.5L, 0x1p-105L, 2.846556599890768890940941645338546615370e-32L, 1.047197551196597746154214461093167628066L);
2687 TEST_c_c (cacosh, -0.5L, 0x1p-105L, 2.846556599890768890940941645338546615370e-32L, 2.094395102393195492308428922186335256131L);
2688 TEST_c_c (cacosh, 0.5L, -0x1p-105L, 2.846556599890768890940941645338546615370e-32L, -1.047197551196597746154214461093167628066L);
2689 TEST_c_c (cacosh, -0.5L, -0x1p-105L, 2.846556599890768890940941645338546615370e-32L, -2.094395102393195492308428922186335256131L);
2690 TEST_c_c (cacosh, 0x1p-105L, 0x1p-105L, 2.465190328815661891911651766508706967729e-32L, 1.570796326794896619231321691639726790195L);
2691 TEST_c_c (cacosh, 0x1p-105L, -0x1p-105L, 2.465190328815661891911651766508706967729e-32L, -1.570796326794896619231321691639726790195L);
2692 TEST_c_c (cacosh, -0x1p-105L, 0x1p-105L, 2.465190328815661891911651766508706967729e-32L, 1.570796326794896619231321691639776094002L);
2693 TEST_c_c (cacosh, -0x1p-105L, -0x1p-105L, 2.465190328815661891911651766508706967729e-32L, -1.570796326794896619231321691639776094002L);
2694#ifndef TEST_FLOAT
2695 TEST_c_c (cacosh, 0x1.fp-1025L, 0x1p-105L, 2.465190328815661891911651766508706967729e-32L, 1.570796326794896619231321691639751442099L);
2696 TEST_c_c (cacosh, 0x1.fp-1025L, -0x1p-105L, 2.465190328815661891911651766508706967729e-32L, -1.570796326794896619231321691639751442099L);
2697 TEST_c_c (cacosh, -0x1.fp-1025L, 0x1p-105L, 2.465190328815661891911651766508706967729e-32L, 1.570796326794896619231321691639751442099L);
2698 TEST_c_c (cacosh, -0x1.fp-1025L, -0x1p-105L, 2.465190328815661891911651766508706967729e-32L, -1.570796326794896619231321691639751442099L);
2699 TEST_c_c (cacosh, 0x1p-105L, 0x1.fp-1025L, 5.388850751072128349671657362289416093031e-309L, 1.570796326794896619231321691639726790195L, UNDERFLOW_EXCEPTION_DOUBLE);
2700 TEST_c_c (cacosh, -0x1p-105L, 0x1.fp-1025L, 5.388850751072128349671657362289416093031e-309L, 1.570796326794896619231321691639776094002L, UNDERFLOW_EXCEPTION_DOUBLE);
2701 TEST_c_c (cacosh, 0x1p-105L, -0x1.fp-1025L, 5.388850751072128349671657362289416093031e-309L, -1.570796326794896619231321691639726790195L, UNDERFLOW_EXCEPTION_DOUBLE);
2702 TEST_c_c (cacosh, -0x1p-105L, -0x1.fp-1025L, 5.388850751072128349671657362289416093031e-309L, -1.570796326794896619231321691639776094002L, UNDERFLOW_EXCEPTION_DOUBLE);
2703#endif
2704 TEST_c_c (cacosh, 0.0L, 0x1p-105L, 2.465190328815661891911651766508706967729e-32L, 1.570796326794896619231321691639751442099L);
2705 TEST_c_c (cacosh, 0.0L, -0x1p-105L, 2.465190328815661891911651766508706967729e-32L, -1.570796326794896619231321691639751442099L);
2706 TEST_c_c (cacosh, -0.0L, 0x1p-105L, 2.465190328815661891911651766508706967729e-32L, 1.570796326794896619231321691639751442099L);
2707 TEST_c_c (cacosh, -0.0L, -0x1p-105L, 2.465190328815661891911651766508706967729e-32L, -1.570796326794896619231321691639751442099L);
2708 TEST_c_c (cacosh, 0x1p-105L, 0.0L, 0.0L, 1.570796326794896619231321691639726790195L);
2709 TEST_c_c (cacosh, -0x1p-105L, 0.0L, 0.0L, 1.570796326794896619231321691639776094002L);
2710 TEST_c_c (cacosh, 0x1p-105L, -0.0L, 0.0L, -1.570796326794896619231321691639726790195L);
2711 TEST_c_c (cacosh, -0x1p-105L, -0.0L, 0.0L, -1.570796326794896619231321691639776094002L);
2712#if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 113
2713 TEST_c_c (cacosh, 0x1p-112L, 0x0.ffffffffffffffffffffffffffff8p0L, 8.813735870195430252326093249797922409363e-1L, 1.570796326794896619231321691639751305915L);
2714 TEST_c_c (cacosh, 0x1p-112L, -0x0.ffffffffffffffffffffffffffff8p0L, 8.813735870195430252326093249797922409363e-1L, -1.570796326794896619231321691639751305915L);
2715 TEST_c_c (cacosh, -0x1p-112L, 0x0.ffffffffffffffffffffffffffff8p0L, 8.813735870195430252326093249797922409363e-1L, 1.570796326794896619231321691639751578282L);
2716 TEST_c_c (cacosh, -0x1p-112L, -0x0.ffffffffffffffffffffffffffff8p0L, 8.813735870195430252326093249797922409363e-1L, -1.570796326794896619231321691639751578282L);
2717 TEST_c_c (cacosh, 0x0.ffffffffffffffffffffffffffff8p0L, 0x1p-112L, 1.091004200533850618345330909857103457781e-17L, 1.765281878332676474347460257221369818872e-17L);
2718 TEST_c_c (cacosh, -0x0.ffffffffffffffffffffffffffff8p0L, 0x1p-112L, 1.091004200533850618345330909857103457781e-17L, 3.141592653589793220809824599952738140723L);
2719 TEST_c_c (cacosh, 0x0.ffffffffffffffffffffffffffff8p0L, -0x1p-112L, 1.091004200533850618345330909857103457781e-17L, -1.765281878332676474347460257221369818872e-17L);
2720 TEST_c_c (cacosh, -0x0.ffffffffffffffffffffffffffff8p0L, -0x1p-112L, 1.091004200533850618345330909857103457781e-17L, -3.141592653589793220809824599952738140723L);
2721 TEST_c_c (cacosh, 0x1.fp-16385L, 0x0.ffffffffffffffffffffffffffff8p0L, 8.813735870195430252326093249797922409363e-1L, 1.570796326794896619231321691639751442099L);
2722 TEST_c_c (cacosh, 0x1.fp-16385L, -0x0.ffffffffffffffffffffffffffff8p0L, 8.813735870195430252326093249797922409363e-1L, -1.570796326794896619231321691639751442099L);
2723 TEST_c_c (cacosh, -0x1.fp-16385L, 0x0.ffffffffffffffffffffffffffff8p0L, 8.813735870195430252326093249797922409363e-1L, 1.570796326794896619231321691639751442099L);
2724 TEST_c_c (cacosh, -0x1.fp-16385L, -0x0.ffffffffffffffffffffffffffff8p0L, 8.813735870195430252326093249797922409363e-1L, -1.570796326794896619231321691639751442099L);
2725 TEST_c_c (cacosh, 0x0.ffffffffffffffffffffffffffff8p0L, 0x1.fp-16385L, 5.867357004219059108790368268900490184505e-4916L, 1.387778780781445675529539585113525401762e-17L);
2726 TEST_c_c (cacosh, -0x0.ffffffffffffffffffffffffffff8p0L, 0x1.fp-16385L, 5.867357004219059108790368268900490184505e-4916L, 3.141592653589793224584855575465046128902L);
2727 TEST_c_c (cacosh, 0x0.ffffffffffffffffffffffffffff8p0L, -0x1.fp-16385L, 5.867357004219059108790368268900490184505e-4916L, -1.387778780781445675529539585113525401762e-17L);
2728 TEST_c_c (cacosh, -0x0.ffffffffffffffffffffffffffff8p0L, -0x1.fp-16385L, 5.867357004219059108790368268900490184505e-4916L, -3.141592653589793224584855575465046128902L);
2729 TEST_c_c (cacosh, 0.0L, 0x0.ffffffffffffffffffffffffffff8p0L, 8.813735870195430252326093249797922409363e-1L, 1.570796326794896619231321691639751442099L);
2730 TEST_c_c (cacosh, 0.0L, -0x0.ffffffffffffffffffffffffffff8p0L, 8.813735870195430252326093249797922409363e-1L, -1.570796326794896619231321691639751442099L);
2731 TEST_c_c (cacosh, -0.0L, 0x0.ffffffffffffffffffffffffffff8p0L, 8.813735870195430252326093249797922409363e-1L, 1.570796326794896619231321691639751442099L);
2732 TEST_c_c (cacosh, -0.0L, -0x0.ffffffffffffffffffffffffffff8p0L, 8.813735870195430252326093249797922409363e-1L, -1.570796326794896619231321691639751442099L);
2733 TEST_c_c (cacosh, 0x0.ffffffffffffffffffffffffffff8p0L, 0.0L, 0.0L, 1.387778780781445675529539585113525401762e-17L);
2734 TEST_c_c (cacosh, -0x0.ffffffffffffffffffffffffffff8p0L, 0.0L, 0.0L, 3.141592653589793224584855575465046128902L);
2735 TEST_c_c (cacosh, 0x0.ffffffffffffffffffffffffffff8p0L, -0.0L, 0.0L, -1.387778780781445675529539585113525401762e-17L);
2736 TEST_c_c (cacosh, -0x0.ffffffffffffffffffffffffffff8p0L, -0.0L, 0.0L, -3.141592653589793224584855575465046128902L);
2737#endif
2738 TEST_c_c (cacosh, 0x1p-112L, 0.5L, 4.812118250596034474977589134243684231352e-1L, 1.570796326794896619231321691639751269838L);
2739 TEST_c_c (cacosh, 0x1p-112L, -0.5L, 4.812118250596034474977589134243684231352e-1L, -1.570796326794896619231321691639751269838L);
2740 TEST_c_c (cacosh, -0x1p-112L, 0.5L, 4.812118250596034474977589134243684231352e-1L, 1.570796326794896619231321691639751614359L);
2741 TEST_c_c (cacosh, -0x1p-112L, -0.5L, 4.812118250596034474977589134243684231352e-1L, -1.570796326794896619231321691639751614359L);
2742 TEST_c_c (cacosh, 0.5L, 0x1p-112L, 2.223872343664663196047610660420739543258e-34L, 1.047197551196597746154214461093167628066L);
2743 TEST_c_c (cacosh, -0.5L, 0x1p-112L, 2.223872343664663196047610660420739543258e-34L, 2.094395102393195492308428922186335256131L);
2744 TEST_c_c (cacosh, 0.5L, -0x1p-112L, 2.223872343664663196047610660420739543258e-34L, -1.047197551196597746154214461093167628066L);
2745 TEST_c_c (cacosh, -0.5L, -0x1p-112L, 2.223872343664663196047610660420739543258e-34L, -2.094395102393195492308428922186335256131L);
2746 TEST_c_c (cacosh, 0x1p-112L, 0x1p-112L, 1.925929944387235853055977942584927318538e-34L, 1.570796326794896619231321691639751249506L);
2747 TEST_c_c (cacosh, 0x1p-112L, -0x1p-112L, 1.925929944387235853055977942584927318538e-34L, -1.570796326794896619231321691639751249506L);
2748 TEST_c_c (cacosh, -0x1p-112L, 0x1p-112L, 1.925929944387235853055977942584927318538e-34L, 1.570796326794896619231321691639751634692L);
2749 TEST_c_c (cacosh, -0x1p-112L, -0x1p-112L, 1.925929944387235853055977942584927318538e-34L, -1.570796326794896619231321691639751634692L);
2750#if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
2751 TEST_c_c (cacosh, 0x1.fp-16385L, 0x1p-112L, 1.925929944387235853055977942584927318538e-34L, 1.570796326794896619231321691639751442099L);
2752 TEST_c_c (cacosh, 0x1.fp-16385L, -0x1p-112L, 1.925929944387235853055977942584927318538e-34L, -1.570796326794896619231321691639751442099L);
2753 TEST_c_c (cacosh, -0x1.fp-16385L, 0x1p-112L, 1.925929944387235853055977942584927318538e-34L, 1.570796326794896619231321691639751442099L);
2754 TEST_c_c (cacosh, -0x1.fp-16385L, -0x1p-112L, 1.925929944387235853055977942584927318538e-34L, -1.570796326794896619231321691639751442099L);
2755 TEST_c_c (cacosh, 0x1p-112L, 0x1.fp-16385L, 8.142593549724601460479922838826119584417e-4933L, 1.570796326794896619231321691639751249506L, UNDERFLOW_EXCEPTION);
2756 TEST_c_c (cacosh, -0x1p-112L, 0x1.fp-16385L, 8.142593549724601460479922838826119584417e-4933L, 1.570796326794896619231321691639751634692L, UNDERFLOW_EXCEPTION);
2757 TEST_c_c (cacosh, 0x1p-112L, -0x1.fp-16385L, 8.142593549724601460479922838826119584417e-4933L, -1.570796326794896619231321691639751249506L, UNDERFLOW_EXCEPTION);
2758 TEST_c_c (cacosh, -0x1p-112L, -0x1.fp-16385L, 8.142593549724601460479922838826119584417e-4933L, -1.570796326794896619231321691639751634692L, UNDERFLOW_EXCEPTION);
2759#endif
2760 TEST_c_c (cacosh, 0.0L, 0x1p-112L, 1.925929944387235853055977942584927318538e-34L, 1.570796326794896619231321691639751442099L);
2761 TEST_c_c (cacosh, 0.0L, -0x1p-112L, 1.925929944387235853055977942584927318538e-34L, -1.570796326794896619231321691639751442099L);
2762 TEST_c_c (cacosh, -0.0L, 0x1p-112L, 1.925929944387235853055977942584927318538e-34L, 1.570796326794896619231321691639751442099L);
2763 TEST_c_c (cacosh, -0.0L, -0x1p-112L, 1.925929944387235853055977942584927318538e-34L, -1.570796326794896619231321691639751442099L);
2764 TEST_c_c (cacosh, 0x1p-112L, 0.0L, 0.0L, 1.570796326794896619231321691639751249506L);
2765 TEST_c_c (cacosh, -0x1p-112L, 0.0L, 0.0L, 1.570796326794896619231321691639751634692L);
2766 TEST_c_c (cacosh, 0x1p-112L, -0.0L, 0.0L, -1.570796326794896619231321691639751249506L);
2767 TEST_c_c (cacosh, -0x1p-112L, -0.0L, 0.0L, -1.570796326794896619231321691639751634692L);
2768
2550dfe9 2769 TEST_c_c (cacosh, 0.75L, 1.25L, 1.13239363160530819522266333696834467L, 1.11752014915610270578240049553777969L);
4f7e7f8e 2770 TEST_c_c (cacosh, -2, -3, 1.9833870299165354323470769028940395L, -2.1414491111159960199416055713254211L);
8847214f 2771
6815fabc 2772 END (cacosh, complex);
8847214f
UD
2773}
2774
2550dfe9 2775
8847214f
UD
2776static void
2777carg_test (void)
2778{
2779 START (carg);
2780
2781 /* carg (x + iy) is specified as atan2 (y, x) */
2782
2783 /* carg (x + i 0) == 0 for x > 0. */
2784 TEST_c_f (carg, 2.0, 0, 0);
2785 /* carg (x - i 0) == -0 for x > 0. */
2786 TEST_c_f (carg, 2.0, minus_zero, minus_zero);
2787
2788 TEST_c_f (carg, 0, 0, 0);
2789 TEST_c_f (carg, 0, minus_zero, minus_zero);
2790
2791 /* carg (x + i 0) == +pi for x < 0. */
2792 TEST_c_f (carg, -2.0, 0, M_PIl);
2793
2794 /* carg (x - i 0) == -pi for x < 0. */
2795 TEST_c_f (carg, -2.0, minus_zero, -M_PIl);
2796
2797 TEST_c_f (carg, minus_zero, 0, M_PIl);
2798 TEST_c_f (carg, minus_zero, minus_zero, -M_PIl);
2799
2800 /* carg (+0 + i y) == pi/2 for y > 0. */
2801 TEST_c_f (carg, 0, 2.0, M_PI_2l);
2802
2803 /* carg (-0 + i y) == pi/2 for y > 0. */
2804 TEST_c_f (carg, minus_zero, 2.0, M_PI_2l);
2805
2806 /* carg (+0 + i y) == -pi/2 for y < 0. */
2807 TEST_c_f (carg, 0, -2.0, -M_PI_2l);
2808
2809 /* carg (-0 + i y) == -pi/2 for y < 0. */
2810 TEST_c_f (carg, minus_zero, -2.0, -M_PI_2l);
2811
2812 /* carg (inf + i y) == +0 for finite y > 0. */
2813 TEST_c_f (carg, plus_infty, 2.0, 0);
2814
2815 /* carg (inf + i y) == -0 for finite y < 0. */
2816 TEST_c_f (carg, plus_infty, -2.0, minus_zero);
2817
2818 /* carg(x + i inf) == pi/2 for finite x. */
2819 TEST_c_f (carg, 10.0, plus_infty, M_PI_2l);
2820
2821 /* carg(x - i inf) == -pi/2 for finite x. */
2822 TEST_c_f (carg, 10.0, minus_infty, -M_PI_2l);
2823
2824 /* carg (-inf + i y) == +pi for finite y > 0. */
2825 TEST_c_f (carg, minus_infty, 10.0, M_PIl);
2826
2827 /* carg (-inf + i y) == -pi for finite y < 0. */
2828 TEST_c_f (carg, minus_infty, -10.0, -M_PIl);
2829
2830 TEST_c_f (carg, plus_infty, plus_infty, M_PI_4l);
2831
2832 TEST_c_f (carg, plus_infty, minus_infty, -M_PI_4l);
2833
2834 TEST_c_f (carg, minus_infty, plus_infty, 3 * M_PI_4l);
2835
2836 TEST_c_f (carg, minus_infty, minus_infty, -3 * M_PI_4l);
2837
67e971f1 2838 TEST_c_f (carg, qnan_value, qnan_value, qnan_value);
15daa639 2839
8847214f
UD
2840 END (carg);
2841}
2842
2843static void
2844casin_test (void)
2845{
aaca11d8 2846 errno = 0;
3c6cad26 2847 FUNC(casin) (BUILD_COMPLEX (0.7L, 1.2L));
aaca11d8
UD
2848 if (errno == ENOSYS)
2849 /* Function not implemented. */
2850 return;
2851
8847214f
UD
2852 START (casin);
2853
2854 TEST_c_c (casin, 0, 0, 0.0, 0.0);
2855 TEST_c_c (casin, minus_zero, 0, minus_zero, 0.0);
2856 TEST_c_c (casin, 0, minus_zero, 0.0, minus_zero);
2857 TEST_c_c (casin, minus_zero, minus_zero, minus_zero, minus_zero);
2858
2859 TEST_c_c (casin, plus_infty, plus_infty, M_PI_4l, plus_infty);
2860 TEST_c_c (casin, plus_infty, minus_infty, M_PI_4l, minus_infty);
2861 TEST_c_c (casin, minus_infty, plus_infty, -M_PI_4l, plus_infty);
2862 TEST_c_c (casin, minus_infty, minus_infty, -M_PI_4l, minus_infty);
2863
2864 TEST_c_c (casin, -10.0, plus_infty, minus_zero, plus_infty);
2865 TEST_c_c (casin, -10.0, minus_infty, minus_zero, minus_infty);
2866 TEST_c_c (casin, 0, plus_infty, 0.0, plus_infty);
2867 TEST_c_c (casin, 0, minus_infty, 0.0, minus_infty);
2868 TEST_c_c (casin, minus_zero, plus_infty, minus_zero, plus_infty);
2869 TEST_c_c (casin, minus_zero, minus_infty, minus_zero, minus_infty);
3c6cad26
UD
2870 TEST_c_c (casin, 0.1L, plus_infty, 0.0, plus_infty);
2871 TEST_c_c (casin, 0.1L, minus_infty, 0.0, minus_infty);
8847214f
UD
2872
2873 TEST_c_c (casin, minus_infty, 0, -M_PI_2l, plus_infty);
2874 TEST_c_c (casin, minus_infty, minus_zero, -M_PI_2l, minus_infty);
2875 TEST_c_c (casin, minus_infty, 100, -M_PI_2l, plus_infty);
2876 TEST_c_c (casin, minus_infty, -100, -M_PI_2l, minus_infty);
2877
2878 TEST_c_c (casin, plus_infty, 0, M_PI_2l, plus_infty);
2879 TEST_c_c (casin, plus_infty, minus_zero, M_PI_2l, minus_infty);
2880 TEST_c_c (casin, plus_infty, 0.5, M_PI_2l, plus_infty);
2881 TEST_c_c (casin, plus_infty, -0.5, M_PI_2l, minus_infty);
2882
67e971f1
TS
2883 TEST_c_c (casin, qnan_value, plus_infty, qnan_value, plus_infty);
2884 TEST_c_c (casin, qnan_value, minus_infty, qnan_value, minus_infty);
8847214f 2885
67e971f1
TS
2886 TEST_c_c (casin, 0.0, qnan_value, 0.0, qnan_value);
2887 TEST_c_c (casin, minus_zero, qnan_value, minus_zero, qnan_value);
8847214f 2888
67e971f1
TS
2889 TEST_c_c (casin, plus_infty, qnan_value, qnan_value, plus_infty, IGNORE_ZERO_INF_SIGN);
2890 TEST_c_c (casin, minus_infty, qnan_value, qnan_value, plus_infty, IGNORE_ZERO_INF_SIGN);
8847214f 2891
67e971f1
TS
2892 TEST_c_c (casin, qnan_value, 10.5, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
2893 TEST_c_c (casin, qnan_value, -10.5, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
8847214f 2894
67e971f1
TS
2895 TEST_c_c (casin, 0.75, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
2896 TEST_c_c (casin, -0.75, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
8847214f 2897
67e971f1 2898 TEST_c_c (casin, qnan_value, qnan_value, qnan_value, qnan_value);
8847214f 2899
d1d3431a
JM
2900 TEST_c_c (casin, plus_zero, -1.5L, plus_zero, -1.194763217287109304111930828519090523536L);
2901 TEST_c_c (casin, minus_zero, -1.5L, minus_zero, -1.194763217287109304111930828519090523536L);
2902 TEST_c_c (casin, plus_zero, -1.0L, plus_zero, -0.8813735870195430252326093249797923090282L);
2903 TEST_c_c (casin, minus_zero, -1.0L, minus_zero, -0.8813735870195430252326093249797923090282L);
2904 TEST_c_c (casin, plus_zero, -0.5L, plus_zero, -0.4812118250596034474977589134243684231352L);
2905 TEST_c_c (casin, minus_zero, -0.5L, minus_zero, -0.4812118250596034474977589134243684231352L);
2906 TEST_c_c (casin, plus_zero, 0.5L, plus_zero, 0.4812118250596034474977589134243684231352L);
2907 TEST_c_c (casin, minus_zero, 0.5L, minus_zero, 0.4812118250596034474977589134243684231352L);
2908 TEST_c_c (casin, plus_zero, 1.0L, plus_zero, 0.8813735870195430252326093249797923090282L);
2909 TEST_c_c (casin, minus_zero, 1.0L, minus_zero, 0.8813735870195430252326093249797923090282L);
2910 TEST_c_c (casin, plus_zero, 1.5L, plus_zero, 1.194763217287109304111930828519090523536L);
2911 TEST_c_c (casin, minus_zero, 1.5L, minus_zero, 1.194763217287109304111930828519090523536L);
2912
2913 TEST_c_c (casin, -1.5L, plus_zero, -M_PI_2l, 0.9624236501192068949955178268487368462704L);
2914 TEST_c_c (casin, -1.5L, minus_zero, -M_PI_2l, -0.9624236501192068949955178268487368462704L);
2915 TEST_c_c (casin, -1.0L, plus_zero, -M_PI_2l, plus_zero);
2916 TEST_c_c (casin, -1.0L, minus_zero, -M_PI_2l, minus_zero);
2917 TEST_c_c (casin, -0.5L, plus_zero, -0.5235987755982988730771072305465838140329L, plus_zero);
2918 TEST_c_c (casin, -0.5L, minus_zero, -0.5235987755982988730771072305465838140329L, minus_zero);
2919 TEST_c_c (casin, 0.5L, plus_zero, 0.5235987755982988730771072305465838140329L, plus_zero);
2920 TEST_c_c (casin, 0.5L, minus_zero, 0.5235987755982988730771072305465838140329L, minus_zero);
2921 TEST_c_c (casin, 1.0L, plus_zero, M_PI_2l, plus_zero);
2922 TEST_c_c (casin, 1.0L, minus_zero, M_PI_2l, minus_zero);
2923 TEST_c_c (casin, 1.5L, plus_zero, M_PI_2l, 0.9624236501192068949955178268487368462704L);
2924 TEST_c_c (casin, 1.5L, minus_zero, M_PI_2l, -0.9624236501192068949955178268487368462704L);
2925
cdc1c96f
JM
2926 TEST_c_c (casin, 0x1p50L, 1.0L, 1.570796326794895731052901991514519103193L, 3.535050620855721078027883819436720218708e1L);
2927 TEST_c_c (casin, 0x1p50L, -1.0L, 1.570796326794895731052901991514519103193L, -3.535050620855721078027883819436720218708e1L);
2928 TEST_c_c (casin, -0x1p50L, 1.0L, -1.570796326794895731052901991514519103193L, 3.535050620855721078027883819436720218708e1L);
2929 TEST_c_c (casin, -0x1p50L, -1.0L, -1.570796326794895731052901991514519103193L, -3.535050620855721078027883819436720218708e1L);
2930 TEST_c_c (casin, 1.0L, 0x1p50L, 8.881784197001252323389053344720723756399e-16L, 3.535050620855721078027883819436759661753e1L);
2931 TEST_c_c (casin, -1.0L, 0x1p50L, -8.881784197001252323389053344720723756399e-16L, 3.535050620855721078027883819436759661753e1L);
2932 TEST_c_c (casin, 1.0L, -0x1p50L, 8.881784197001252323389053344720723756399e-16L, -3.535050620855721078027883819436759661753e1L);
2933 TEST_c_c (casin, -1.0L, -0x1p50L, -8.881784197001252323389053344720723756399e-16L, -3.535050620855721078027883819436759661753e1L);
2934#ifndef TEST_FLOAT
2935 TEST_c_c (casin, 0x1p500L, 1.0L, 1.570796326794896619231321691639751442099L, 3.472667374605326000180332928505464606058e2L);
2936 TEST_c_c (casin, 0x1p500L, -1.0L, 1.570796326794896619231321691639751442099L, -3.472667374605326000180332928505464606058e2L);
2937 TEST_c_c (casin, -0x1p500L, 1.0L, -1.570796326794896619231321691639751442099L, 3.472667374605326000180332928505464606058e2L);
2938 TEST_c_c (casin, -0x1p500L, -1.0L, -1.570796326794896619231321691639751442099L, -3.472667374605326000180332928505464606058e2L);
2939 TEST_c_c (casin, 1.0L, 0x1p500L, 3.054936363499604682051979393213617699789e-151L, 3.472667374605326000180332928505464606058e2L);
2940 TEST_c_c (casin, -1.0L, 0x1p500L, -3.054936363499604682051979393213617699789e-151L, 3.472667374605326000180332928505464606058e2L);
2941 TEST_c_c (casin, 1.0L, -0x1p500L, 3.054936363499604682051979393213617699789e-151L, -3.472667374605326000180332928505464606058e2L);
2942 TEST_c_c (casin, -1.0L, -0x1p500L, -3.054936363499604682051979393213617699789e-151L, -3.472667374605326000180332928505464606058e2L);
2943#endif
2944#if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
2945 TEST_c_c (casin, 0x1p5000L, 1.0L, 1.570796326794896619231321691639751442099L, 3.466429049980286492395577839412341016946e3L);
2946 TEST_c_c (casin, 0x1p5000L, -1.0L, 1.570796326794896619231321691639751442099L, -3.466429049980286492395577839412341016946e3L);
2947 TEST_c_c (casin, -0x1p5000L, 1.0L, -1.570796326794896619231321691639751442099L, 3.466429049980286492395577839412341016946e3L);
2948 TEST_c_c (casin, -0x1p5000L, -1.0L, -1.570796326794896619231321691639751442099L, -3.466429049980286492395577839412341016946e3L);
2949 TEST_c_c (casin, 1.0L, 0x1p5000L, 7.079811261048172892385615158694057552948e-1506L, 3.466429049980286492395577839412341016946e3L);
2950 TEST_c_c (casin, -1.0L, 0x1p5000L, -7.079811261048172892385615158694057552948e-1506L, 3.466429049980286492395577839412341016946e3L);
2951 TEST_c_c (casin, 1.0L, -0x1p5000L, 7.079811261048172892385615158694057552948e-1506L, -3.466429049980286492395577839412341016946e3L);
2952 TEST_c_c (casin, -1.0L, -0x1p5000L, -7.079811261048172892385615158694057552948e-1506L, -3.466429049980286492395577839412341016946e3L);
2953#endif
2954
a9708fed
JM
2955 TEST_c_c (casin, 0x1.fp127L, 0x1.fp127L, 7.853981633974483096156608458198757210493e-1L, 8.973081118419833726837456344608533993585e1L);
2956#ifndef TEST_FLOAT
2957 TEST_c_c (casin, 0x1.fp1023L, 0x1.fp1023L, 7.853981633974483096156608458198757210493e-1L, 7.107906849659093345062145442726115449315e2L);
2958#endif
2959#if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
2960 TEST_c_c (casin, 0x1.fp16383L, 0x1.fp16383L, 7.853981633974483096156608458198757210493e-1L, 1.135753137836666928715489992987020363057e4L);
2961#endif
2962
8cf28c5e
JM
2963 TEST_c_c (casin, 0x1.fp-129L, 1.5L, 1.579176199917649005841160751101628985741e-39L, 1.194763217287109304111930828519090523536L, UNDERFLOW_EXCEPTION_FLOAT);
2964 TEST_c_c (casin, 0x1.fp-129L, -1.5L, 1.579176199917649005841160751101628985741e-39L, -1.194763217287109304111930828519090523536L, UNDERFLOW_EXCEPTION_FLOAT);
2965 TEST_c_c (casin, -0x1.fp-129L, 1.5L, -1.579176199917649005841160751101628985741e-39L, 1.194763217287109304111930828519090523536L, UNDERFLOW_EXCEPTION_FLOAT);
2966 TEST_c_c (casin, -0x1.fp-129L, -1.5L, -1.579176199917649005841160751101628985741e-39L, -1.194763217287109304111930828519090523536L, UNDERFLOW_EXCEPTION_FLOAT);
2967 TEST_c_c (casin, 1.5L, 0x1.fp-129L, 1.570796326794896619231321691639751442096L, 9.624236501192068949955178268487368462704e-1L);
2968 TEST_c_c (casin, -1.5L, 0x1.fp-129L, -1.570796326794896619231321691639751442096L, 9.624236501192068949955178268487368462704e-1L);
2969 TEST_c_c (casin, 1.5L, -0x1.fp-129L, 1.570796326794896619231321691639751442096L, -9.624236501192068949955178268487368462704e-1L);
2970 TEST_c_c (casin, -1.5L, -0x1.fp-129L, -1.570796326794896619231321691639751442096L, -9.624236501192068949955178268487368462704e-1L);
2971#ifndef TEST_FLOAT
2972 TEST_c_c (casin, 0x1.fp-1025L, 1.5L, 2.989196569048182929051881765490354365918e-309L, 1.194763217287109304111930828519090523536L, UNDERFLOW_EXCEPTION_DOUBLE);
2973 TEST_c_c (casin, 0x1.fp-1025L, -1.5L, 2.989196569048182929051881765490354365918e-309L, -1.194763217287109304111930828519090523536L, UNDERFLOW_EXCEPTION_DOUBLE);
2974 TEST_c_c (casin, -0x1.fp-1025L, 1.5L, -2.989196569048182929051881765490354365918e-309L, 1.194763217287109304111930828519090523536L, UNDERFLOW_EXCEPTION_DOUBLE);
2975 TEST_c_c (casin, -0x1.fp-1025L, -1.5L, -2.989196569048182929051881765490354365918e-309L, -1.194763217287109304111930828519090523536L, UNDERFLOW_EXCEPTION_DOUBLE);
2976 TEST_c_c (casin, 1.5L, 0x1.fp-1025L, 1.570796326794896619231321691639751442099L, 9.624236501192068949955178268487368462704e-1L);
2977 TEST_c_c (casin, -1.5L, 0x1.fp-1025L, -1.570796326794896619231321691639751442099L, 9.624236501192068949955178268487368462704e-1L);
2978 TEST_c_c (casin, 1.5L, -0x1.fp-1025L, 1.570796326794896619231321691639751442099L, -9.624236501192068949955178268487368462704e-1L);
2979 TEST_c_c (casin, -1.5L, -0x1.fp-1025L, -1.570796326794896619231321691639751442099L, -9.624236501192068949955178268487368462704e-1L);
2980#endif
2981#if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
2982 TEST_c_c (casin, 0x1.fp-16385L, 1.5L, 4.516698239814521372306784062043266700598e-4933L, 1.194763217287109304111930828519090523536L, UNDERFLOW_EXCEPTION);
2983 TEST_c_c (casin, 0x1.fp-16385L, -1.5L, 4.516698239814521372306784062043266700598e-4933L, -1.194763217287109304111930828519090523536L, UNDERFLOW_EXCEPTION);
2984 TEST_c_c (casin, -0x1.fp-16385L, 1.5L, -4.516698239814521372306784062043266700598e-4933L, 1.194763217287109304111930828519090523536L, UNDERFLOW_EXCEPTION);
2985 TEST_c_c (casin, -0x1.fp-16385L, -1.5L, -4.516698239814521372306784062043266700598e-4933L, -1.194763217287109304111930828519090523536L, UNDERFLOW_EXCEPTION);
2986 TEST_c_c (casin, 1.5L, 0x1.fp-16385L, 1.570796326794896619231321691639751442099L, 9.624236501192068949955178268487368462704e-1L);
2987 TEST_c_c (casin, -1.5L, 0x1.fp-16385L, -1.570796326794896619231321691639751442099L, 9.624236501192068949955178268487368462704e-1L);
2988 TEST_c_c (casin, 1.5L, -0x1.fp-16385L, 1.570796326794896619231321691639751442099L, -9.624236501192068949955178268487368462704e-1L);
2989 TEST_c_c (casin, -1.5L, -0x1.fp-16385L, -1.570796326794896619231321691639751442099L, -9.624236501192068949955178268487368462704e-1L);
2990#endif
2991
0a1b2ae6
JM
2992 TEST_c_c (casin, 0.5L, 1.0L, 3.494390628572132936274118260753699527325e-1L, 9.261330313501824245501244453057873152694e-1L);
2993 TEST_c_c (casin, 0.5L, -1.0L, 3.494390628572132936274118260753699527325e-1L, -9.261330313501824245501244453057873152694e-1L);
2994 TEST_c_c (casin, -0.5L, 1.0L, -3.494390628572132936274118260753699527325e-1L, 9.261330313501824245501244453057873152694e-1L);
2995 TEST_c_c (casin, -0.5L, -1.0L, -3.494390628572132936274118260753699527325e-1L, -9.261330313501824245501244453057873152694e-1L);
2996 TEST_c_c (casin, 1.0L, 0.5L, 8.959074812088902390666567243275770102229e-1L, 7.328576759736452608886724437653071523305e-1L);
2997 TEST_c_c (casin, -1.0L, 0.5L, -8.959074812088902390666567243275770102229e-1L, 7.328576759736452608886724437653071523305e-1L);
2998 TEST_c_c (casin, 1.0L, -0.5L, 8.959074812088902390666567243275770102229e-1L, -7.328576759736452608886724437653071523305e-1L);
2999 TEST_c_c (casin, -1.0L, -0.5L, -8.959074812088902390666567243275770102229e-1L, -7.328576759736452608886724437653071523305e-1L);
3000 TEST_c_c (casin, 0.25L, 1.0L, 1.763024327769669304186785666360901026468e-1L, 8.924633639033482359562124741744951972772e-1L);
3001 TEST_c_c (casin, 0.25L, -1.0L, 1.763024327769669304186785666360901026468e-1L, -8.924633639033482359562124741744951972772e-1L);
3002 TEST_c_c (casin, -0.25L, 1.0L, -1.763024327769669304186785666360901026468e-1L, 8.924633639033482359562124741744951972772e-1L);
3003 TEST_c_c (casin, -0.25L, -1.0L, -1.763024327769669304186785666360901026468e-1L, -8.924633639033482359562124741744951972772e-1L);
3004 TEST_c_c (casin, 1.0L, 0.25L, 1.081751996523816326311037318425097434186L, 5.097911466811016354623559941115413499164e-1L);
3005 TEST_c_c (casin, -1.0L, 0.25L, -1.081751996523816326311037318425097434186L, 5.097911466811016354623559941115413499164e-1L);
3006 TEST_c_c (casin, 1.0L, -0.25L, 1.081751996523816326311037318425097434186L, -5.097911466811016354623559941115413499164e-1L);
3007 TEST_c_c (casin, -1.0L, -0.25L, -1.081751996523816326311037318425097434186L, -5.097911466811016354623559941115413499164e-1L);
3008 TEST_c_c (casin, 0x1.fp-10L, 1.0L, 1.337909359557740912558349531052239112857e-3L, 8.813742198809567991336704287826445879025e-1L);
3009 TEST_c_c (casin, 0x1.fp-10L, -1.0L, 1.337909359557740912558349531052239112857e-3L, -8.813742198809567991336704287826445879025e-1L);
3010 TEST_c_c (casin, -0x1.fp-10L, 1.0L, -1.337909359557740912558349531052239112857e-3L, 8.813742198809567991336704287826445879025e-1L);
3011 TEST_c_c (casin, -0x1.fp-10L, -1.0L, -1.337909359557740912558349531052239112857e-3L, -8.813742198809567991336704287826445879025e-1L);
3012 TEST_c_c (casin, 1.0L, 0x1.fp-10L, 1.527305029163877791518741192097931722508L, 4.350501469856803800217957402220976497152e-2L);
3013 TEST_c_c (casin, -1.0L, 0x1.fp-10L, -1.527305029163877791518741192097931722508L, 4.350501469856803800217957402220976497152e-2L);
3014 TEST_c_c (casin, 1.0L, -0x1.fp-10L, 1.527305029163877791518741192097931722508L, -4.350501469856803800217957402220976497152e-2L);
3015 TEST_c_c (casin, -1.0L, -0x1.fp-10L, -1.527305029163877791518741192097931722508L, -4.350501469856803800217957402220976497152e-2L);
3016 TEST_c_c (casin, 0x1.fp-30L, 1.0L, 1.275929984216518540252717485007112529021e-9L, 8.813735870195430258081932989769495326854e-1L);
3017 TEST_c_c (casin, 0x1.fp-30L, -1.0L, 1.275929984216518540252717485007112529021e-9L, -8.813735870195430258081932989769495326854e-1L);
3018 TEST_c_c (casin, -0x1.fp-30L, 1.0L, -1.275929984216518540252717485007112529021e-9L, 8.813735870195430258081932989769495326854e-1L);
3019 TEST_c_c (casin, -0x1.fp-30L, -1.0L, -1.275929984216518540252717485007112529021e-9L, -8.813735870195430258081932989769495326854e-1L);
3020 TEST_c_c (casin, 1.0L, 0x1.fp-30L, 1.570753848123921942730162693731872690232L, 4.247867098745151888768727039216644758847e-5L);
3021 TEST_c_c (casin, -1.0L, 0x1.fp-30L, -1.570753848123921942730162693731872690232L, 4.247867098745151888768727039216644758847e-5L);
3022 TEST_c_c (casin, 1.0L, -0x1.fp-30L, 1.570753848123921942730162693731872690232L, -4.247867098745151888768727039216644758847e-5L);
3023 TEST_c_c (casin, -1.0L, -0x1.fp-30L, -1.570753848123921942730162693731872690232L, -4.247867098745151888768727039216644758847e-5L);
3024 TEST_c_c (casin, 0x1.fp-100L, 1.0L, 1.080754735021050612990719608916167354321e-30L, 8.813735870195430252326093249797923090282e-1L);
3025 TEST_c_c (casin, 0x1.fp-100L, -1.0L, 1.080754735021050612990719608916167354321e-30L, -8.813735870195430252326093249797923090282e-1L);
3026 TEST_c_c (casin, -0x1.fp-100L, 1.0L, -1.080754735021050612990719608916167354321e-30L, 8.813735870195430252326093249797923090282e-1L);
3027 TEST_c_c (casin, -0x1.fp-100L, -1.0L, -1.080754735021050612990719608916167354321e-30L, -8.813735870195430252326093249797923090282e-1L);
3028 TEST_c_c (casin, 1.0L, 0x1.fp-100L, 1.570796326794895382939283431378862777584L, 1.236292038260260888664514866457202186027e-15L);
3029 TEST_c_c (casin, -1.0L, 0x1.fp-100L, -1.570796326794895382939283431378862777584L, 1.236292038260260888664514866457202186027e-15L);
3030 TEST_c_c (casin, 1.0L, -0x1.fp-100L, 1.570796326794895382939283431378862777584L, -1.236292038260260888664514866457202186027e-15L);
3031 TEST_c_c (casin, -1.0L, -0x1.fp-100L, -1.570796326794895382939283431378862777584L, -1.236292038260260888664514866457202186027e-15L);
3032 TEST_c_c (casin, 0x1.fp-129L, 1.0L, 2.013062564695348242280482517399205554874e-39L, 8.813735870195430252326093249797923090282e-1L, UNDERFLOW_EXCEPTION_FLOAT);
3033 TEST_c_c (casin, 0x1.fp-129L, -1.0L, 2.013062564695348242280482517399205554874e-39L, -8.813735870195430252326093249797923090282e-1L, UNDERFLOW_EXCEPTION_FLOAT);
3034 TEST_c_c (casin, -0x1.fp-129L, 1.0L, -2.013062564695348242280482517399205554874e-39L, 8.813735870195430252326093249797923090282e-1L, UNDERFLOW_EXCEPTION_FLOAT);
3035 TEST_c_c (casin, -0x1.fp-129L, -1.0L, -2.013062564695348242280482517399205554874e-39L, -8.813735870195430252326093249797923090282e-1L, UNDERFLOW_EXCEPTION_FLOAT);
3036 TEST_c_c (casin, 1.0L, 0x1.fp-129L, 1.570796326794896619177965338869929107115L, 5.335635276982233498398987585285818977933e-20L);
3037 TEST_c_c (casin, -1.0L, 0x1.fp-129L, -1.570796326794896619177965338869929107115L, 5.335635276982233498398987585285818977933e-20L);
3038 TEST_c_c (casin, 1.0L, -0x1.fp-129L, 1.570796326794896619177965338869929107115L, -5.335635276982233498398987585285818977933e-20L);
3039 TEST_c_c (casin, -1.0L, -0x1.fp-129L, -1.570796326794896619177965338869929107115L, -5.335635276982233498398987585285818977933e-20L);
3040#ifndef TEST_FLOAT
3041 TEST_c_c (casin, 0x1.fp-1000L, 1.0L, 1.278589251976747242280879285935084814093e-301L, 8.813735870195430252326093249797923090282e-1L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM);
3042 TEST_c_c (casin, 0x1.fp-1000L, -1.0L, 1.278589251976747242280879285935084814093e-301L, -8.813735870195430252326093249797923090282e-1L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM);
3043 TEST_c_c (casin, -0x1.fp-1000L, 1.0L, -1.278589251976747242280879285935084814093e-301L, 8.813735870195430252326093249797923090282e-1L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM);
3044 TEST_c_c (casin, -0x1.fp-1000L, -1.0L, -1.278589251976747242280879285935084814093e-301L, -8.813735870195430252326093249797923090282e-1L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM);
3045 TEST_c_c (casin, 1.0L, 0x1.fp-1000L, 1.570796326794896619231321691639751442099L, 4.252291453851660175550490409247739011867e-151L);
3046 TEST_c_c (casin, -1.0L, 0x1.fp-1000L, -1.570796326794896619231321691639751442099L, 4.252291453851660175550490409247739011867e-151L);
3047 TEST_c_c (casin, 1.0L, -0x1.fp-1000L, 1.570796326794896619231321691639751442099L, -4.252291453851660175550490409247739011867e-151L);
3048 TEST_c_c (casin, -1.0L, -0x1.fp-1000L, -1.570796326794896619231321691639751442099L, -4.252291453851660175550490409247739011867e-151L);
3049 TEST_c_c (casin, 0x1.fp-1025L, 1.0L, 3.810492908885321743133304375216617626230e-309L, 8.813735870195430252326093249797923090282e-1L, UNDERFLOW_EXCEPTION_DOUBLE);
3050 TEST_c_c (casin, 0x1.fp-1025L, -1.0L, 3.810492908885321743133304375216617626230e-309L, -8.813735870195430252326093249797923090282e-1L, UNDERFLOW_EXCEPTION_DOUBLE);
3051 TEST_c_c (casin, -0x1.fp-1025L, 1.0L, -3.810492908885321743133304375216617626230e-309L, 8.813735870195430252326093249797923090282e-1L, UNDERFLOW_EXCEPTION_DOUBLE);
3052 TEST_c_c (casin, -0x1.fp-1025L, -1.0L, -3.810492908885321743133304375216617626230e-309L, -8.813735870195430252326093249797923090282e-1L, UNDERFLOW_EXCEPTION_DOUBLE);
3053 TEST_c_c (casin, 1.0L, 0x1.fp-1025L, 1.570796326794896619231321691639751442099L, 7.340879205566679497036857179189356754017e-155L);
3054 TEST_c_c (casin, -1.0L, 0x1.fp-1025L, -1.570796326794896619231321691639751442099L, 7.340879205566679497036857179189356754017e-155L);
3055 TEST_c_c (casin, 1.0L, -0x1.fp-1025L, 1.570796326794896619231321691639751442099L, -7.340879205566679497036857179189356754017e-155L);
3056 TEST_c_c (casin, -1.0L, -0x1.fp-1025L, -1.570796326794896619231321691639751442099L, -7.340879205566679497036857179189356754017e-155L);
3057#endif
3058#if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
3059 TEST_c_c (casin, 0x1.fp-10000L, 1.0L, 6.867047849047171855399183659351043150871e-3011L, 8.813735870195430252326093249797923090282e-1L);
3060 TEST_c_c (casin, 0x1.fp-10000L, -1.0L, 6.867047849047171855399183659351043150871e-3011L, -8.813735870195430252326093249797923090282e-1L);
3061 TEST_c_c (casin, -0x1.fp-10000L, 1.0L, -6.867047849047171855399183659351043150871e-3011L, 8.813735870195430252326093249797923090282e-1L);
3062 TEST_c_c (casin, -0x1.fp-10000L, -1.0L, -6.867047849047171855399183659351043150871e-3011L, -8.813735870195430252326093249797923090282e-1L);
3063 TEST_c_c (casin, 1.0L, 0x1.fp-10000L, 1.570796326794896619231321691639751442099L, 9.854680208706673586644342922051388714633e-1506L);
3064 TEST_c_c (casin, -1.0L, 0x1.fp-10000L, -1.570796326794896619231321691639751442099L, 9.854680208706673586644342922051388714633e-1506L);
3065 TEST_c_c (casin, 1.0L, -0x1.fp-10000L, 1.570796326794896619231321691639751442099L, -9.854680208706673586644342922051388714633e-1506L);
3066 TEST_c_c (casin, -1.0L, -0x1.fp-10000L, -1.570796326794896619231321691639751442099L, -9.854680208706673586644342922051388714633e-1506L);
3067 TEST_c_c (casin, 0x1.fp-16385L, 1.0L, 5.757683115456107044131264955348448954458e-4933L, 8.813735870195430252326093249797923090282e-1L, UNDERFLOW_EXCEPTION);
3068 TEST_c_c (casin, 0x1.fp-16385L, -1.0L, 5.757683115456107044131264955348448954458e-4933L, -8.813735870195430252326093249797923090282e-1L, UNDERFLOW_EXCEPTION);
3069 TEST_c_c (casin, -0x1.fp-16385L, 1.0L, -5.757683115456107044131264955348448954458e-4933L, 8.813735870195430252326093249797923090282e-1L, UNDERFLOW_EXCEPTION);
3070 TEST_c_c (casin, -0x1.fp-16385L, -1.0L, -5.757683115456107044131264955348448954458e-4933L, -8.813735870195430252326093249797923090282e-1L, UNDERFLOW_EXCEPTION);
3071 TEST_c_c (casin, 1.0L, 0x1.fp-16385L, 1.570796326794896619231321691639751442099L, 9.023632056840860275214893047597614177639e-2467L);
3072 TEST_c_c (casin, -1.0L, 0x1.fp-16385L, -1.570796326794896619231321691639751442099L, 9.023632056840860275214893047597614177639e-2467L);
3073 TEST_c_c (casin, 1.0L, -0x1.fp-16385L, 1.570796326794896619231321691639751442099L, -9.023632056840860275214893047597614177639e-2467L);
3074 TEST_c_c (casin, -1.0L, -0x1.fp-16385L, -1.570796326794896619231321691639751442099L, -9.023632056840860275214893047597614177639e-2467L);
3075#endif
3076
3a7182a1
JM
3077 TEST_c_c (casin, 0x1p-23L, 0x1.000002p0L, 8.429369199749229560964789467980644296420e-8L, 8.813736713132400470205730751186547909968e-1L)
3078 TEST_c_c (casin, 0x1p-23L, -0x1.000002p0L, 8.429369199749229560964789467980644296420e-8L, -8.813736713132400470205730751186547909968e-1L)
3079 TEST_c_c (casin, -0x1p-23L, 0x1.000002p0L, -8.429369199749229560964789467980644296420e-8L, 8.813736713132400470205730751186547909968e-1L)
3080 TEST_c_c (casin, -0x1p-23L, -0x1.000002p0L, -8.429369199749229560964789467980644296420e-8L, -8.813736713132400470205730751186547909968e-1L)
3081 TEST_c_c (casin, 0x1.000002p0L, 0x1p-23L, 1.570574114956455764594481054234834678422L, 5.364668491573609633134147164031476452679e-4L)
3082 TEST_c_c (casin, -0x1.000002p0L, 0x1p-23L, -1.570574114956455764594481054234834678422L, 5.364668491573609633134147164031476452679e-4L)
3083 TEST_c_c (casin, 0x1.000002p0L, -0x1p-23L, 1.570574114956455764594481054234834678422L, -5.364668491573609633134147164031476452679e-4L)
3084 TEST_c_c (casin, -0x1.000002p0L, -0x1p-23L, -1.570574114956455764594481054234834678422L, -5.364668491573609633134147164031476452679e-4L)
3085 TEST_c_c (casin, 0x1.fp-129L, 0x1.000002p0L, 2.013062444707472738895109955455676357057e-39L, 8.813736713132375348727889167749389235161e-1L, UNDERFLOW_EXCEPTION_FLOAT)
3086 TEST_c_c (casin, 0x1.fp-129L, -0x1.000002p0L, 2.013062444707472738895109955455676357057e-39L, -8.813736713132375348727889167749389235161e-1L, UNDERFLOW_EXCEPTION_FLOAT)
3087 TEST_c_c (casin, -0x1.fp-129L, 0x1.000002p0L, -2.013062444707472738895109955455676357057e-39L, 8.813736713132375348727889167749389235161e-1L, UNDERFLOW_EXCEPTION_FLOAT)
3088 TEST_c_c (casin, -0x1.fp-129L, -0x1.000002p0L, -2.013062444707472738895109955455676357057e-39L, -8.813736713132375348727889167749389235161e-1L, UNDERFLOW_EXCEPTION_FLOAT)
3089 TEST_c_c (casin, 0x1.000002p0L, 0x1.fp-129L, 1.570796326794896619231321691639751436268L, 4.882812451493617206486388134172712975070e-4L)
3090 TEST_c_c (casin, -0x1.000002p0L, 0x1.fp-129L, -1.570796326794896619231321691639751436268L, 4.882812451493617206486388134172712975070e-4L)
3091 TEST_c_c (casin, 0x1.000002p0L, -0x1.fp-129L, 1.570796326794896619231321691639751436268L, -4.882812451493617206486388134172712975070e-4L)
3092 TEST_c_c (casin, -0x1.000002p0L, -0x1.fp-129L, -1.570796326794896619231321691639751436268L, -4.882812451493617206486388134172712975070e-4L)
3093 TEST_c_c (casin, 0.0L, 0x1.000002p0L, 0.0L, 8.813736713132375348727889167749389235161e-1L)
3094 TEST_c_c (casin, 0.0L, -0x1.000002p0L, 0.0L, -8.813736713132375348727889167749389235161e-1L)
3095 TEST_c_c (casin, -0.0L, 0x1.000002p0L, -0.0L, 8.813736713132375348727889167749389235161e-1L)
3096 TEST_c_c (casin, -0.0L, -0x1.000002p0L, -0.0L, -8.813736713132375348727889167749389235161e-1L)
3097 TEST_c_c (casin, 0x1.000002p0L, 0.0L, 1.570796326794896619231321691639751442099L, 4.882812451493617206486388134172712975070e-4L)
3098 TEST_c_c (casin, -0x1.000002p0L, 0.0L, -1.570796326794896619231321691639751442099L, 4.882812451493617206486388134172712975070e-4L)
3099 TEST_c_c (casin, 0x1.000002p0L, -0.0L, 1.570796326794896619231321691639751442099L, -4.882812451493617206486388134172712975070e-4L)
3100 TEST_c_c (casin, -0x1.000002p0L, -0.0L, -1.570796326794896619231321691639751442099L, -4.882812451493617206486388134172712975070e-4L)
3101#ifndef TEST_FLOAT
3102 TEST_c_c (casin, 0x1p-52L, 0x1.0000000000001p0L, 1.570092458683774885078102529858632363236e-16L, 8.813735870195431822418551933572982483664e-1L)
3103 TEST_c_c (casin, 0x1p-52L, -0x1.0000000000001p0L, 1.570092458683774885078102529858632363236e-16L, -8.813735870195431822418551933572982483664e-1L)
3104 TEST_c_c (casin, -0x1p-52L, 0x1.0000000000001p0L, -1.570092458683774885078102529858632363236e-16L, 8.813735870195431822418551933572982483664e-1L)
3105 TEST_c_c (casin, -0x1p-52L, -0x1.0000000000001p0L, -1.570092458683774885078102529858632363236e-16L, -8.813735870195431822418551933572982483664e-1L)
3106 TEST_c_c (casin, 0x1.0000000000001p0L, 0x1p-52L, 1.570796317204594913251280305810847349436L, 2.315303644582684770975188768022139415020e-8L)
3107 TEST_c_c (casin, -0x1.0000000000001p0L, 0x1p-52L, -1.570796317204594913251280305810847349436L, 2.315303644582684770975188768022139415020e-8L)
3108 TEST_c_c (casin, 0x1.0000000000001p0L, -0x1p-52L, 1.570796317204594913251280305810847349436L, -2.315303644582684770975188768022139415020e-8L)
3109 TEST_c_c (casin, -0x1.0000000000001p0L, -0x1p-52L, -1.570796317204594913251280305810847349436L, -2.315303644582684770975188768022139415020e-8L)
3110 TEST_c_c (casin, 0x1.fp-1025L, 0x1.0000000000001p0L, 3.810492908885321320083608113679347200012e-309L, 8.813735870195431822418551933572895326024e-1L, UNDERFLOW_EXCEPTION_DOUBLE)
3111 TEST_c_c (casin, 0x1.fp-1025L, -0x1.0000000000001p0L, 3.810492908885321320083608113679347200012e-309L, -8.813735870195431822418551933572895326024e-1L, UNDERFLOW_EXCEPTION_DOUBLE)
3112 TEST_c_c (casin, -0x1.fp-1025L, 0x1.0000000000001p0L, -3.810492908885321320083608113679347200012e-309L, 8.813735870195431822418551933572895326024e-1L, UNDERFLOW_EXCEPTION_DOUBLE)
3113 TEST_c_c (casin, -0x1.fp-1025L, -0x1.0000000000001p0L, -3.810492908885321320083608113679347200012e-309L, -8.813735870195431822418551933572895326024e-1L, UNDERFLOW_EXCEPTION_DOUBLE)
3114 TEST_c_c (casin, 0x1.0000000000001p0L, 0x1.fp-1025L, 1.570796326794896619231321691639751442099L, 2.107342425544701550354780375182800088393e-8L)
3115 TEST_c_c (casin, -0x1.0000000000001p0L, 0x1.fp-1025L, -1.570796326794896619231321691639751442099L, 2.107342425544701550354780375182800088393e-8L)
3116 TEST_c_c (casin, 0x1.0000000000001p0L, -0x1.fp-1025L, 1.570796326794896619231321691639751442099L, -2.107342425544701550354780375182800088393e-8L)
3117 TEST_c_c (casin, -0x1.0000000000001p0L, -0x1.fp-1025L, -1.570796326794896619231321691639751442099L, -2.107342425544701550354780375182800088393e-8L)
3118 TEST_c_c (casin, 0.0L, 0x1.0000000000001p0L, 0.0L, 8.813735870195431822418551933572895326024e-1L)
3119 TEST_c_c (casin, 0.0L, -0x1.0000000000001p0L, 0.0L, -8.813735870195431822418551933572895326024e-1L)
3120 TEST_c_c (casin, -0.0L, 0x1.0000000000001p0L, -0.0L, 8.813735870195431822418551933572895326024e-1L)
3121 TEST_c_c (casin, -0.0L, -0x1.0000000000001p0L, -0.0L, -8.813735870195431822418551933572895326024e-1L)
3122 TEST_c_c (casin, 0x1.0000000000001p0L, 0.0L, 1.570796326794896619231321691639751442099L, 2.107342425544701550354780375182800088393e-8L)
3123 TEST_c_c (casin, -0x1.0000000000001p0L, 0.0L, -1.570796326794896619231321691639751442099L, 2.107342425544701550354780375182800088393e-8L)
3124 TEST_c_c (casin, 0x1.0000000000001p0L, -0.0L, 1.570796326794896619231321691639751442099L, -2.107342425544701550354780375182800088393e-8L)
3125 TEST_c_c (casin, -0x1.0000000000001p0L, -0.0L, -1.570796326794896619231321691639751442099L, -2.107342425544701550354780375182800088393e-8L)
3126#endif
3127#if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 64
3128 TEST_c_c (casin, 0x1p-63L, 0x1.0000000000000002p0L, 7.666467083416870406778649849746878368519e-20L, 8.813735870195430253092739958139610131001e-1L)
3129 TEST_c_c (casin, 0x1p-63L, -0x1.0000000000000002p0L, 7.666467083416870406778649849746878368519e-20L, -8.813735870195430253092739958139610131001e-1L)
3130 TEST_c_c (casin, -0x1p-63L, 0x1.0000000000000002p0L, -7.666467083416870406778649849746878368519e-20L, 8.813735870195430253092739958139610131001e-1L)
3131 TEST_c_c (casin, -0x1p-63L, -0x1.0000000000000002p0L, -7.666467083416870406778649849746878368519e-20L, -8.813735870195430253092739958139610131001e-1L)
3132 TEST_c_c (casin, 0x1.0000000000000002p0L, 0x1p-63L, 1.570796326582978888921215348380499122131L, 5.116146586219826555037807251857670783420e-10L)
3133 TEST_c_c (casin, -0x1.0000000000000002p0L, 0x1p-63L, -1.570796326582978888921215348380499122131L, 5.116146586219826555037807251857670783420e-10L)
3134 TEST_c_c (casin, 0x1.0000000000000002p0L, -0x1p-63L, 1.570796326582978888921215348380499122131L, -5.116146586219826555037807251857670783420e-10L)
3135 TEST_c_c (casin, -0x1.0000000000000002p0L, -0x1p-63L, -1.570796326582978888921215348380499122131L, -5.116146586219826555037807251857670783420e-10L)
3136# if LDBL_MIN_EXP <= -16381
3137 TEST_c_c (casin, 0x1.fp-16385L, 0x1.0000000000000002p0L, 5.757683115456107043819140328235418018963e-4933L, 8.813735870195430253092739958139610130980e-1L, UNDERFLOW_EXCEPTION)
3138 TEST_c_c (casin, 0x1.fp-16385L, -0x1.0000000000000002p0L, 5.757683115456107043819140328235418018963e-4933L, -8.813735870195430253092739958139610130980e-1L, UNDERFLOW_EXCEPTION)
3139 TEST_c_c (casin, -0x1.fp-16385L, 0x1.0000000000000002p0L, -5.757683115456107043819140328235418018963e-4933L, 8.813735870195430253092739958139610130980e-1L, UNDERFLOW_EXCEPTION)
3140 TEST_c_c (casin, -0x1.fp-16385L, -0x1.0000000000000002p0L, -5.757683115456107043819140328235418018963e-4933L, -8.813735870195430253092739958139610130980e-1L, UNDERFLOW_EXCEPTION)
3141 TEST_c_c (casin, 0x1.0000000000000002p0L, 0x1.fp-16385L, 1.570796326794896619231321691639751442099L, 4.656612873077392578082927418388212703712e-10L)
3142 TEST_c_c (casin, -0x1.0000000000000002p0L, 0x1.fp-16385L, -1.570796326794896619231321691639751442099L, 4.656612873077392578082927418388212703712e-10L)
3143 TEST_c_c (casin, 0x1.0000000000000002p0L, -0x1.fp-16385L, 1.570796326794896619231321691639751442099L, -4.656612873077392578082927418388212703712e-10L)
3144 TEST_c_c (casin, -0x1.0000000000000002p0L, -0x1.fp-16385L, -1.570796326794896619231321691639751442099L, -4.656612873077392578082927418388212703712e-10L)
3145# endif
3146 TEST_c_c (casin, 0.0L, 0x1.0000000000000002p0L, 0.0L, 8.813735870195430253092739958139610130980e-1L)
3147 TEST_c_c (casin, 0.0L, -0x1.0000000000000002p0L, 0.0L, -8.813735870195430253092739958139610130980e-1L)
3148 TEST_c_c (casin, -0.0L, 0x1.0000000000000002p0L, -0.0L, 8.813735870195430253092739958139610130980e-1L)
3149 TEST_c_c (casin, -0.0L, -0x1.0000000000000002p0L, -0.0L, -8.813735870195430253092739958139610130980e-1L)
3150 TEST_c_c (casin, 0x1.0000000000000002p0L, 0.0L, 1.570796326794896619231321691639751442099L, 4.656612873077392578082927418388212703712e-10L)
3151 TEST_c_c (casin, -0x1.0000000000000002p0L, 0.0L, -1.570796326794896619231321691639751442099L, 4.656612873077392578082927418388212703712e-10L)
3152 TEST_c_c (casin, 0x1.0000000000000002p0L, -0.0L, 1.570796326794896619231321691639751442099L, -4.656612873077392578082927418388212703712e-10L)
3153 TEST_c_c (casin, -0x1.0000000000000002p0L, -0.0L, -1.570796326794896619231321691639751442099L, -4.656612873077392578082927418388212703712e-10L)
3154#endif
3155#if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 106
3156 TEST_c_c (casin, 0x1p-106L, 0x1.000000000000000000000000008p0L, 8.715763992105246878957416200936726072500e-33L, 8.813735870195430252326093249798097405561e-1L)
3157 TEST_c_c (casin, 0x1p-106L, -0x1.000000000000000000000000008p0L, 8.715763992105246878957416200936726072500e-33L, -8.813735870195430252326093249798097405561e-1L)
3158 TEST_c_c (casin, -0x1p-106L, 0x1.000000000000000000000000008p0L, -8.715763992105246878957416200936726072500e-33L, 8.813735870195430252326093249798097405561e-1L)
3159 TEST_c_c (casin, -0x1p-106L, -0x1.000000000000000000000000008p0L, -8.715763992105246878957416200936726072500e-33L, -8.813735870195430252326093249798097405561e-1L)
3160 TEST_c_c (casin, 0x1.000000000000000000000000008p0L, 0x1p-106L, 1.570796326794896565289107467733682961928L, 2.285028863093221674154232933662774454211e-16L)
3161 TEST_c_c (casin, -0x1.000000000000000000000000008p0L, 0x1p-106L, -1.570796326794896565289107467733682961928L, 2.285028863093221674154232933662774454211e-16L)
3162 TEST_c_c (casin, 0x1.000000000000000000000000008p0L, -0x1p-106L, 1.570796326794896565289107467733682961928L, -2.285028863093221674154232933662774454211e-16L)
3163 TEST_c_c (casin, -0x1.000000000000000000000000008p0L, -0x1p-106L, -1.570796326794896565289107467733682961928L, -2.285028863093221674154232933662774454211e-16L)
3164 TEST_c_c (casin, 0x1.fp-1025L, 0x1.000000000000000000000000008p0L, 3.810492908885321743133304375216570658278e-309L, 8.813735870195430252326093249798097405561e-1L, UNDERFLOW_EXCEPTION_DOUBLE)
3165 TEST_c_c (casin, 0x1.fp-1025L, -0x1.000000000000000000000000008p0L, 3.810492908885321743133304375216570658278e-309L, -8.813735870195430252326093249798097405561e-1L, UNDERFLOW_EXCEPTION_DOUBLE)
3166 TEST_c_c (casin, -0x1.fp-1025L, 0x1.000000000000000000000000008p0L, -3.810492908885321743133304375216570658278e-309L, 8.813735870195430252326093249798097405561e-1L, UNDERFLOW_EXCEPTION_DOUBLE)
3167 TEST_c_c (casin, -0x1.fp-1025L, -0x1.000000000000000000000000008p0L, -3.810492908885321743133304375216570658278e-309L, -8.813735870195430252326093249798097405561e-1L, UNDERFLOW_EXCEPTION_DOUBLE)
3168 TEST_c_c (casin, 0x1.000000000000000000000000008p0L, 0x1.fp-1025L, 1.570796326794896619231321691639751442099L, 2.220446049250313080847263336181636063482e-16L)
3169 TEST_c_c (casin, -0x1.000000000000000000000000008p0L, 0x1.fp-1025L, -1.570796326794896619231321691639751442099L, 2.220446049250313080847263336181636063482e-16L)
3170 TEST_c_c (casin, 0x1.000000000000000000000000008p0L, -0x1.fp-1025L, 1.570796326794896619231321691639751442099L, -2.220446049250313080847263336181636063482e-16L)
3171 TEST_c_c (casin, -0x1.000000000000000000000000008p0L, -0x1.fp-1025L, -1.570796326794896619231321691639751442099L, -2.220446049250313080847263336181636063482e-16L)
3172 TEST_c_c (casin, 0.0L, 0x1.000000000000000000000000008p0L, 0.0L, 8.813735870195430252326093249798097405561e-1L)
3173 TEST_c_c (casin, 0.0L, -0x1.000000000000000000000000008p0L, 0.0L, -8.813735870195430252326093249798097405561e-1L)
3174 TEST_c_c (casin, -0.0L, 0x1.000000000000000000000000008p0L, -0.0L, 8.813735870195430252326093249798097405561e-1L)
3175 TEST_c_c (casin, -0.0L, -0x1.000000000000000000000000008p0L, -0.0L, -8.813735870195430252326093249798097405561e-1L)
3176 TEST_c_c (casin, 0x1.000000000000000000000000008p0L, 0.0L, 1.570796326794896619231321691639751442099L, 2.220446049250313080847263336181636063482e-16L)
3177 TEST_c_c (casin, -0x1.000000000000000000000000008p0L, 0.0L, -1.570796326794896619231321691639751442099L, 2.220446049250313080847263336181636063482e-16L)
3178 TEST_c_c (casin, 0x1.000000000000000000000000008p0L, -0.0L, 1.570796326794896619231321691639751442099L, -2.220446049250313080847263336181636063482e-16L)
3179 TEST_c_c (casin, -0x1.000000000000000000000000008p0L, -0.0L, -1.570796326794896619231321691639751442099L, -2.220446049250313080847263336181636063482e-16L)
3180#endif
3181#if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 113
3182 TEST_c_c (casin, 0x1p-113L, 0x1.0000000000000000000000000001p0L, 6.809190618832224124185481406981900518193e-35L, 8.813735870195430252326093249797924452120e-1L)
3183 TEST_c_c (casin, 0x1p-113L, -0x1.0000000000000000000000000001p0L, 6.809190618832224124185481406981900518193e-35L, -8.813735870195430252326093249797924452120e-1L)
3184 TEST_c_c (casin, -0x1p-113L, 0x1.0000000000000000000000000001p0L, -6.809190618832224124185481406981900518193e-35L, 8.813735870195430252326093249797924452120e-1L)
3185 TEST_c_c (casin, -0x1p-113L, -0x1.0000000000000000000000000001p0L, -6.809190618832224124185481406981900518193e-35L, -8.813735870195430252326093249797924452120e-1L)
3186 TEST_c_c (casin, 0x1.0000000000000000000000000001p0L, 0x1p-113L, 1.570796326794896614463458507897073960405L, 2.019699255375255198156433710951064632386e-17L)
3187 TEST_c_c (casin, -0x1.0000000000000000000000000001p0L, 0x1p-113L, -1.570796326794896614463458507897073960405L, 2.019699255375255198156433710951064632386e-17L)
3188 TEST_c_c (casin, 0x1.0000000000000000000000000001p0L, -0x1p-113L, 1.570796326794896614463458507897073960405L, -2.019699255375255198156433710951064632386e-17L)
3189 TEST_c_c (casin, -0x1.0000000000000000000000000001p0L, -0x1p-113L, -1.570796326794896614463458507897073960405L, -2.019699255375255198156433710951064632386e-17L)
3190 TEST_c_c (casin, 0x1.fp-16385L, 0x1.0000000000000000000000000001p0L, 5.757683115456107044131264955348448400014e-4933L, 8.813735870195430252326093249797924452120e-1L, UNDERFLOW_EXCEPTION)
3191 TEST_c_c (casin, 0x1.fp-16385L, -0x1.0000000000000000000000000001p0L, 5.757683115456107044131264955348448400014e-4933L, -8.813735870195430252326093249797924452120e-1L, UNDERFLOW_EXCEPTION)
3192 TEST_c_c (casin, -0x1.fp-16385L, 0x1.0000000000000000000000000001p0L, -5.757683115456107044131264955348448400014e-4933L, 8.813735870195430252326093249797924452120e-1L, UNDERFLOW_EXCEPTION)
3193 TEST_c_c (casin, -0x1.fp-16385L, -0x1.0000000000000000000000000001p0L, -5.757683115456107044131264955348448400014e-4933L, -8.813735870195430252326093249797924452120e-1L, UNDERFLOW_EXCEPTION)
3194 TEST_c_c (casin, 0x1.0000000000000000000000000001p0L, 0x1.fp-16385L, 1.570796326794896619231321691639751442099L, 1.962615573354718824241727964954454332780e-17L)
3195 TEST_c_c (casin, -0x1.0000000000000000000000000001p0L, 0x1.fp-16385L, -1.570796326794896619231321691639751442099L, 1.962615573354718824241727964954454332780e-17L)
3196 TEST_c_c (casin, 0x1.0000000000000000000000000001p0L, -0x1.fp-16385L, 1.570796326794896619231321691639751442099L, -1.962615573354718824241727964954454332780e-17L)
3197 TEST_c_c (casin, -0x1.0000000000000000000000000001p0L, -0x1.fp-16385L, -1.570796326794896619231321691639751442099L, -1.962615573354718824241727964954454332780e-17L)
3198 TEST_c_c (casin, 0.0L, 0x1.0000000000000000000000000001p0L, 0.0L, 8.813735870195430252326093249797924452120e-1L)
3199 TEST_c_c (casin, 0.0L, -0x1.0000000000000000000000000001p0L, 0.0L, -8.813735870195430252326093249797924452120e-1L)
3200 TEST_c_c (casin, -0.0L, 0x1.0000000000000000000000000001p0L, -0.0L, 8.813735870195430252326093249797924452120e-1L)
3201 TEST_c_c (casin, -0.0L, -0x1.0000000000000000000000000001p0L, -0.0L, -8.813735870195430252326093249797924452120e-1L)
3202 TEST_c_c (casin, 0x1.0000000000000000000000000001p0L, 0.0L, 1.570796326794896619231321691639751442099L, 1.962615573354718824241727964954454332780e-17L)
3203 TEST_c_c (casin, -0x1.0000000000000000000000000001p0L, 0.0L, -1.570796326794896619231321691639751442099L, 1.962615573354718824241727964954454332780e-17L)
3204 TEST_c_c (casin, 0x1.0000000000000000000000000001p0L, -0.0L, 1.570796326794896619231321691639751442099L, -1.962615573354718824241727964954454332780e-17L)
3205 TEST_c_c (casin, -0x1.0000000000000000000000000001p0L, -0.0L, -1.570796326794896619231321691639751442099L, -1.962615573354718824241727964954454332780e-17L)
3206#endif
3207
ccc8cadf
JM
3208 TEST_c_c (casin, 0x1p-23L, 0x0.ffffffp0L, 8.429369953393598499000760938112968755257e-8L, 8.813735448726963984495965873956465777250e-1L);
3209 TEST_c_c (casin, 0x1p-23L, -0x0.ffffffp0L, 8.429369953393598499000760938112968755257e-8L, -8.813735448726963984495965873956465777250e-1L);
3210 TEST_c_c (casin, -0x1p-23L, 0x0.ffffffp0L, -8.429369953393598499000760938112968755257e-8L, 8.813735448726963984495965873956465777250e-1L);
3211 TEST_c_c (casin, -0x1p-23L, -0x0.ffffffp0L, -8.429369953393598499000760938112968755257e-8L, -8.813735448726963984495965873956465777250e-1L);
3212 TEST_c_c (casin, 0x0.ffffffp0L, 0x1p-23L, 1.570357140408705570520377172865353621698L, 2.714321200917194650737217746780928423385e-4L);
3213 TEST_c_c (casin, -0x0.ffffffp0L, 0x1p-23L, -1.570357140408705570520377172865353621698L, 2.714321200917194650737217746780928423385e-4L);
3214 TEST_c_c (casin, 0x0.ffffffp0L, -0x1p-23L, 1.570357140408705570520377172865353621698L, -2.714321200917194650737217746780928423385e-4L);
3215 TEST_c_c (casin, -0x0.ffffffp0L, -0x1p-23L, -1.570357140408705570520377172865353621698L, -2.714321200917194650737217746780928423385e-4L);
3216 TEST_c_c (casin, 0x1.fp-129L, 0x0.ffffffp0L, 2.013062624689288675911339929224634593425e-39L, 8.813735448726938863015878255140556727969e-1L, UNDERFLOW_EXCEPTION_FLOAT);
3217 TEST_c_c (casin, 0x1.fp-129L, -0x0.ffffffp0L, 2.013062624689288675911339929224634593425e-39L, -8.813735448726938863015878255140556727969e-1L, UNDERFLOW_EXCEPTION_FLOAT);
3218 TEST_c_c (casin, -0x1.fp-129L, 0x0.ffffffp0L, -2.013062624689288675911339929224634593425e-39L, 8.813735448726938863015878255140556727969e-1L, UNDERFLOW_EXCEPTION_FLOAT);
3219 TEST_c_c (casin, -0x1.fp-129L, -0x0.ffffffp0L, -2.013062624689288675911339929224634593425e-39L, -8.813735448726938863015878255140556727969e-1L, UNDERFLOW_EXCEPTION_FLOAT);
3220 TEST_c_c (casin, 0x0.ffffffp0L, 0x1.fp-129L, 1.570451059810180415643718442157112705601L, 8.245504387859737323891843603996428534945e-36L);
3221 TEST_c_c (casin, -0x0.ffffffp0L, 0x1.fp-129L, -1.570451059810180415643718442157112705601L, 8.245504387859737323891843603996428534945e-36L);
3222 TEST_c_c (casin, 0x0.ffffffp0L, -0x1.fp-129L, 1.570451059810180415643718442157112705601L, -8.245504387859737323891843603996428534945e-36L);
3223 TEST_c_c (casin, -0x0.ffffffp0L, -0x1.fp-129L, -1.570451059810180415643718442157112705601L, -8.245504387859737323891843603996428534945e-36L);
3224 TEST_c_c (casin, 0.0L, 0x0.ffffffp0L, 0.0L, 8.813735448726938863015878255140556727969e-1L);
3225 TEST_c_c (casin, 0.0L, -0x0.ffffffp0L, 0.0L, -8.813735448726938863015878255140556727969e-1L);
3226 TEST_c_c (casin, -0.0L, 0x0.ffffffp0L, -0.0L, 8.813735448726938863015878255140556727969e-1L);
3227 TEST_c_c (casin, -0.0L, -0x0.ffffffp0L, -0.0L, -8.813735448726938863015878255140556727969e-1L);
3228 TEST_c_c (casin, 0x0.ffffffp0L, 0.0L, 1.570451059810180415643718442157112705601L, 0.0L);
3229 TEST_c_c (casin, -0x0.ffffffp0L, 0.0L, -1.570451059810180415643718442157112705601L, 0.0L);
3230 TEST_c_c (casin, 0x0.ffffffp0L, -0.0L, 1.570451059810180415643718442157112705601L, -0.0L);
3231 TEST_c_c (casin, -0x0.ffffffp0L, -0.0L, -1.570451059810180415643718442157112705601L, -0.0L);
3232 TEST_c_c (casin, 0x1p-23L, 0.5L, 1.066240299940009780479664302917201696886e-7L, 4.812118250596059896127318386463676808798e-1L);
3233 TEST_c_c (casin, 0x1p-23L, -0.5L, 1.066240299940009780479664302917201696886e-7L, -4.812118250596059896127318386463676808798e-1L);
3234 TEST_c_c (casin, -0x1p-23L, 0.5L, -1.066240299940009780479664302917201696886e-7L, 4.812118250596059896127318386463676808798e-1L);
3235 TEST_c_c (casin, -0x1p-23L, -0.5L, -1.066240299940009780479664302917201696886e-7L, -4.812118250596059896127318386463676808798e-1L);
3236 TEST_c_c (casin, 0.5L, 0x1p-23L, 5.235987755982934033165770729745469098254e-1L, 1.376510308240943236356088341381173571841e-7L);
3237 TEST_c_c (casin, -0.5L, 0x1p-23L, -5.235987755982934033165770729745469098254e-1L, 1.376510308240943236356088341381173571841e-7L);
3238 TEST_c_c (casin, 0.5L, -0x1p-23L, 5.235987755982934033165770729745469098254e-1L, -1.376510308240943236356088341381173571841e-7L);
3239 TEST_c_c (casin, -0.5L, -0x1p-23L, -5.235987755982934033165770729745469098254e-1L, -1.376510308240943236356088341381173571841e-7L);
3240 TEST_c_c (casin, 0x1.fp-129L, 0.5L, 2.546345110742945032959687790021055102355e-39L, 4.812118250596034474977589134243684231352e-1L, UNDERFLOW_EXCEPTION_FLOAT);
3241 TEST_c_c (casin, 0x1.fp-129L, -0.5L, 2.546345110742945032959687790021055102355e-39L, -4.812118250596034474977589134243684231352e-1L, UNDERFLOW_EXCEPTION_FLOAT);
3242 TEST_c_c (casin, -0x1.fp-129L, 0.5L, -2.546345110742945032959687790021055102355e-39L, 4.812118250596034474977589134243684231352e-1L, UNDERFLOW_EXCEPTION_FLOAT);
3243 TEST_c_c (casin, -0x1.fp-129L, -0.5L, -2.546345110742945032959687790021055102355e-39L, -4.812118250596034474977589134243684231352e-1L, UNDERFLOW_EXCEPTION_FLOAT);
3244 TEST_c_c (casin, 0.5L, 0x1.fp-129L, 5.235987755982988730771072305465838140329e-1L, 3.287317402534702257036015056278368274737e-39L, UNDERFLOW_EXCEPTION_FLOAT);
3245 TEST_c_c (casin, -0.5L, 0x1.fp-129L, -5.235987755982988730771072305465838140329e-1L, 3.287317402534702257036015056278368274737e-39L, UNDERFLOW_EXCEPTION_FLOAT);
3246 TEST_c_c (casin, 0.5L, -0x1.fp-129L, 5.235987755982988730771072305465838140329e-1L, -3.287317402534702257036015056278368274737e-39L, UNDERFLOW_EXCEPTION_FLOAT);
3247 TEST_c_c (casin, -0.5L, -0x1.fp-129L, -5.235987755982988730771072305465838140329e-1L, -3.287317402534702257036015056278368274737e-39L, UNDERFLOW_EXCEPTION_FLOAT);
3248 TEST_c_c (casin, 0x1p-23L, 0x1p-23L, 1.192092895507806853113684971258850504935e-7L, 1.192092895507818146886315028596704749235e-7L);
3249 TEST_c_c (casin, 0x1p-23L, -0x1p-23L, 1.192092895507806853113684971258850504935e-7L, -1.192092895507818146886315028596704749235e-7L);
3250 TEST_c_c (casin, -0x1p-23L, 0x1p-23L, -1.192092895507806853113684971258850504935e-7L, 1.192092895507818146886315028596704749235e-7L);
3251 TEST_c_c (casin, -0x1p-23L, -0x1p-23L, -1.192092895507806853113684971258850504935e-7L, -1.192092895507818146886315028596704749235e-7L);
3252 /* Bug 15319: underflow exception may be missing. */
3253 TEST_c_c (casin, 0x1.fp-129L, 0x1p-23L, 2.846900380897707329917933005874691056564e-39L, 1.192092895507809676556842485683592032154e-7L, UNDERFLOW_EXCEPTION_OK_FLOAT);
3254 TEST_c_c (casin, 0x1.fp-129L, -0x1p-23L, 2.846900380897707329917933005874691056564e-39L, -1.192092895507809676556842485683592032154e-7L, UNDERFLOW_EXCEPTION_OK_FLOAT);
3255 TEST_c_c (casin, -0x1.fp-129L, 0x1p-23L, -2.846900380897707329917933005874691056564e-39L, 1.192092895507809676556842485683592032154e-7L, UNDERFLOW_EXCEPTION_OK_FLOAT);
3256 TEST_c_c (casin, -0x1.fp-129L, -0x1p-23L, -2.846900380897707329917933005874691056564e-39L, -1.192092895507809676556842485683592032154e-7L, UNDERFLOW_EXCEPTION_OK_FLOAT);
3257 TEST_c_c (casin, 0x1p-23L, 0x1.fp-129L, 1.192092895507815323443157514352519154304e-7L, 2.846900380897747786805634596726756660388e-39L, UNDERFLOW_EXCEPTION_FLOAT);
3258 TEST_c_c (casin, -0x1p-23L, 0x1.fp-129L, -1.192092895507815323443157514352519154304e-7L, 2.846900380897747786805634596726756660388e-39L, UNDERFLOW_EXCEPTION_FLOAT);
3259 TEST_c_c (casin, 0x1p-23L, -0x1.fp-129L, 1.192092895507815323443157514352519154304e-7L, -2.846900380897747786805634596726756660388e-39L, UNDERFLOW_EXCEPTION_FLOAT);
3260 TEST_c_c (casin, -0x1p-23L, -0x1.fp-129L, -1.192092895507815323443157514352519154304e-7L, -2.846900380897747786805634596726756660388e-39L, UNDERFLOW_EXCEPTION_FLOAT);
3261 TEST_c_c (casin, 0.0L, 0x1p-23L, 0.0L, 1.192092895507809676556842485683592032154e-7L);
3262 TEST_c_c (casin, 0.0L, -0x1p-23L, 0.0L, -1.192092895507809676556842485683592032154e-7L);
3263 TEST_c_c (casin, -0.0L, 0x1p-23L, -0.0L, 1.192092895507809676556842485683592032154e-7L);
3264 TEST_c_c (casin, -0.0L, -0x1p-23L, -0.0L, -1.192092895507809676556842485683592032154e-7L);
3265 TEST_c_c (casin, 0x1p-23L, 0.0L, 1.192092895507815323443157514352519154304e-7L, 0.0L);
3266 TEST_c_c (casin, -0x1p-23L, 0.0L, -1.192092895507815323443157514352519154304e-7L, 0.0L);
3267 TEST_c_c (casin, 0x1p-23L, -0.0L, 1.192092895507815323443157514352519154304e-7L, -0.0L);
3268 TEST_c_c (casin, -0x1p-23L, -0.0L, -1.192092895507815323443157514352519154304e-7L, -0.0L);
3269 TEST_c_c (casin, 0x1.fp-129L, 0x1.fp-129L, 2.846900380897727558361783801085126250967e-39L, 2.846900380897727558361783801085126250967e-39L, UNDERFLOW_EXCEPTION_FLOAT);
3270 TEST_c_c (casin, 0x1.fp-129L, -0x1.fp-129L, 2.846900380897727558361783801085126250967e-39L, -2.846900380897727558361783801085126250967e-39L, UNDERFLOW_EXCEPTION_FLOAT);
3271 TEST_c_c (casin, -0x1.fp-129L, 0x1.fp-129L, -2.846900380897727558361783801085126250967e-39L, 2.846900380897727558361783801085126250967e-39L, UNDERFLOW_EXCEPTION_FLOAT);
3272 TEST_c_c (casin, -0x1.fp-129L, -0x1.fp-129L, -2.846900380897727558361783801085126250967e-39L, -2.846900380897727558361783801085126250967e-39L, UNDERFLOW_EXCEPTION_FLOAT);
3273#ifndef TEST_FLOAT
3274 TEST_c_c (casin, 0x1p-52L, 0x0.fffffffffffff8p0L, 1.570092458683775146551022293016031474627e-16L, 8.813735870195429467279863907910458761820e-1L);
3275 TEST_c_c (casin, 0x1p-52L, -0x0.fffffffffffff8p0L, 1.570092458683775146551022293016031474627e-16L, -8.813735870195429467279863907910458761820e-1L);
3276 TEST_c_c (casin, -0x1p-52L, 0x0.fffffffffffff8p0L, -1.570092458683775146551022293016031474627e-16L, 8.813735870195429467279863907910458761820e-1L);
3277 TEST_c_c (casin, -0x1p-52L, -0x0.fffffffffffff8p0L, -1.570092458683775146551022293016031474627e-16L, -8.813735870195429467279863907910458761820e-1L);
3278 TEST_c_c (casin, 0x0.fffffffffffff8p0L, 0x1p-52L, 1.570796307840326780080580569360500172043L, 1.171456840272878582596796205397918831268e-8L);
3279 TEST_c_c (casin, -0x0.fffffffffffff8p0L, 0x1p-52L, -1.570796307840326780080580569360500172043L, 1.171456840272878582596796205397918831268e-8L);
3280 TEST_c_c (casin, 0x0.fffffffffffff8p0L, -0x1p-52L, 1.570796307840326780080580569360500172043L, -1.171456840272878582596796205397918831268e-8L);
3281 TEST_c_c (casin, -0x0.fffffffffffff8p0L, -0x1p-52L, -1.570796307840326780080580569360500172043L, -1.171456840272878582596796205397918831268e-8L);
3282 TEST_c_c (casin, 0x1.fp-1025L, 0x0.fffffffffffff8p0L, 3.810492908885321954658152505985270452320e-309L, 8.813735870195429467279863907910371604180e-1L, UNDERFLOW_EXCEPTION_DOUBLE);
3283 TEST_c_c (casin, 0x1.fp-1025L, -0x0.fffffffffffff8p0L, 3.810492908885321954658152505985270452320e-309L, -8.813735870195429467279863907910371604180e-1L, UNDERFLOW_EXCEPTION_DOUBLE);
3284 TEST_c_c (casin, -0x1.fp-1025L, 0x0.fffffffffffff8p0L, -3.810492908885321954658152505985270452320e-309L, 8.813735870195429467279863907910371604180e-1L, UNDERFLOW_EXCEPTION_DOUBLE);
3285 TEST_c_c (casin, -0x1.fp-1025L, -0x0.fffffffffffff8p0L, -3.810492908885321954658152505985270452320e-309L, -8.813735870195429467279863907910371604180e-1L, UNDERFLOW_EXCEPTION_DOUBLE);
3286 TEST_c_c (casin, 0x0.fffffffffffff8p0L, 0x1.fp-1025L, 1.570796311893735425383665303776316016594L, 3.616396521699973256461764099945789620604e-301L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM);
3287 TEST_c_c (casin, -0x0.fffffffffffff8p0L, 0x1.fp-1025L, -1.570796311893735425383665303776316016594L, 3.616396521699973256461764099945789620604e-301L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM);
3288 TEST_c_c (casin, 0x0.fffffffffffff8p0L, -0x1.fp-1025L, 1.570796311893735425383665303776316016594L, -3.616396521699973256461764099945789620604e-301L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM);
3289 TEST_c_c (casin, -0x0.fffffffffffff8p0L, -0x1.fp-1025L, -1.570796311893735425383665303776316016594L, -3.616396521699973256461764099945789620604e-301L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM);
3290 TEST_c_c (casin, 0.0L, 0x0.fffffffffffff8p0L, 0.0L, 8.813735870195429467279863907910371604180e-1L);
3291 TEST_c_c (casin, 0.0L, -0x0.fffffffffffff8p0L, 0.0L, -8.813735870195429467279863907910371604180e-1L);
3292 TEST_c_c (casin, -0.0L, 0x0.fffffffffffff8p0L, -0.0L, 8.813735870195429467279863907910371604180e-1L);
3293 TEST_c_c (casin, -0.0L, -0x0.fffffffffffff8p0L, -0.0L, -8.813735870195429467279863907910371604180e-1L);
3294 TEST_c_c (casin, 0x0.fffffffffffff8p0L, 0.0L, 1.570796311893735425383665303776316016594L, 0.0L);
3295 TEST_c_c (casin, -0x0.fffffffffffff8p0L, 0.0L, -1.570796311893735425383665303776316016594L, 0.0L);
3296 TEST_c_c (casin, 0x0.fffffffffffff8p0L, -0.0L, 1.570796311893735425383665303776316016594L, -0.0L);
3297 TEST_c_c (casin, -0x0.fffffffffffff8p0L, -0.0L, -1.570796311893735425383665303776316016594L, -0.0L);
3298#endif
3299 TEST_c_c (casin, 0x1p-52L, 0.5L, 1.986027322597818397661816253158024383707e-16L, 4.812118250596034474977589134243772428682e-1L);
3300 TEST_c_c (casin, 0x1p-52L, -0.5L, 1.986027322597818397661816253158024383707e-16L, -4.812118250596034474977589134243772428682e-1L);
3301 TEST_c_c (casin, -0x1p-52L, 0.5L, -1.986027322597818397661816253158024383707e-16L, 4.812118250596034474977589134243772428682e-1L);
3302 TEST_c_c (casin, -0x1p-52L, -0.5L, -1.986027322597818397661816253158024383707e-16L, -4.812118250596034474977589134243772428682e-1L);
3303 TEST_c_c (casin, 0.5L, 0x1p-52L, 5.235987755982988730771072305465648369889e-1L, 2.563950248511418570403591756798643804971e-16L);
3304 TEST_c_c (casin, -0.5L, 0x1p-52L, -5.235987755982988730771072305465648369889e-1L, 2.563950248511418570403591756798643804971e-16L);
3305 TEST_c_c (casin, 0.5L, -0x1p-52L, 5.235987755982988730771072305465648369889e-1L, -2.563950248511418570403591756798643804971e-16L);
3306 TEST_c_c (casin, -0.5L, -0x1p-52L, -5.235987755982988730771072305465648369889e-1L, -2.563950248511418570403591756798643804971e-16L);
3307#ifndef TEST_FLOAT
3308 TEST_c_c (casin, 0x1.fp-1025L, 0.5L, 4.819934639999230680322935210539402497827e-309L, 4.812118250596034474977589134243684231352e-1L, UNDERFLOW_EXCEPTION_DOUBLE);
3309 TEST_c_c (casin, 0x1.fp-1025L, -0.5L, 4.819934639999230680322935210539402497827e-309L, -4.812118250596034474977589134243684231352e-1L, UNDERFLOW_EXCEPTION_DOUBLE);
3310 TEST_c_c (casin, -0x1.fp-1025L, 0.5L, -4.819934639999230680322935210539402497827e-309L, 4.812118250596034474977589134243684231352e-1L, UNDERFLOW_EXCEPTION_DOUBLE);
3311 TEST_c_c (casin, -0x1.fp-1025L, -0.5L, -4.819934639999230680322935210539402497827e-309L, -4.812118250596034474977589134243684231352e-1L, UNDERFLOW_EXCEPTION_DOUBLE);
3312 TEST_c_c (casin, 0.5L, 0x1.fp-1025L, 5.235987755982988730771072305465838140329e-1L, 6.222508863508420569166420770843207333493e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
3313 TEST_c_c (casin, -0.5L, 0x1.fp-1025L, -5.235987755982988730771072305465838140329e-1L, 6.222508863508420569166420770843207333493e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
3314 TEST_c_c (casin, 0.5L, -0x1.fp-1025L, 5.235987755982988730771072305465838140329e-1L, -6.222508863508420569166420770843207333493e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
3315 TEST_c_c (casin, -0.5L, -0x1.fp-1025L, -5.235987755982988730771072305465838140329e-1L, -6.222508863508420569166420770843207333493e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
3316#endif
3317 TEST_c_c (casin, 0x1p-52L, 0x1p-52L, 2.220446049250313080847263336181604132852e-16L, 2.220446049250313080847263336181677117148e-16L);
3318 TEST_c_c (casin, 0x1p-52L, -0x1p-52L, 2.220446049250313080847263336181604132852e-16L, -2.220446049250313080847263336181677117148e-16L);
3319 TEST_c_c (casin, -0x1p-52L, 0x1p-52L, -2.220446049250313080847263336181604132852e-16L, 2.220446049250313080847263336181677117148e-16L);
3320 TEST_c_c (casin, -0x1p-52L, -0x1p-52L, -2.220446049250313080847263336181604132852e-16L, -2.220446049250313080847263336181677117148e-16L);
3321#ifndef TEST_FLOAT
3322 /* Bug 15319: underflow exception may be missing. */
3323 TEST_c_c (casin, 0x1.fp-1025L, 0x1p-52L, 5.388850751072128349671657362289283247603e-309L, 2.220446049250313080847263336181622378926e-16L, UNDERFLOW_EXCEPTION_OK_DOUBLE);
3324 TEST_c_c (casin, 0x1.fp-1025L, -0x1p-52L, 5.388850751072128349671657362289283247603e-309L, -2.220446049250313080847263336181622378926e-16L, UNDERFLOW_EXCEPTION_OK_DOUBLE);
3325 TEST_c_c (casin, -0x1.fp-1025L, 0x1p-52L, -5.388850751072128349671657362289283247603e-309L, 2.220446049250313080847263336181622378926e-16L, UNDERFLOW_EXCEPTION_OK_DOUBLE);
3326 TEST_c_c (casin, -0x1.fp-1025L, -0x1p-52L, -5.388850751072128349671657362289283247603e-309L, -2.220446049250313080847263336181622378926e-16L, UNDERFLOW_EXCEPTION_OK_DOUBLE);
3327 TEST_c_c (casin, 0x1p-52L, 0x1.fp-1025L, 2.220446049250313080847263336181658871074e-16L, 5.388850751072128349671657362289548938458e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
3328 TEST_c_c (casin, -0x1p-52L, 0x1.fp-1025L, -2.220446049250313080847263336181658871074e-16L, 5.388850751072128349671657362289548938458e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
3329 TEST_c_c (casin, 0x1p-52L, -0x1.fp-1025L, 2.220446049250313080847263336181658871074e-16L, -5.388850751072128349671657362289548938458e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
3330 TEST_c_c (casin, -0x1p-52L, -0x1.fp-1025L, -2.220446049250313080847263336181658871074e-16L, -5.388850751072128349671657362289548938458e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
3331#endif
3332 TEST_c_c (casin, 0.0L, 0x1p-52L, 0.0L, 2.220446049250313080847263336181622378926e-16L);
3333 TEST_c_c (casin, 0.0L, -0x1p-52L, 0.0L, -2.220446049250313080847263336181622378926e-16L);
3334 TEST_c_c (casin, -0.0L, 0x1p-52L, -0.0L, 2.220446049250313080847263336181622378926e-16L);
3335 TEST_c_c (casin, -0.0L, -0x1p-52L, -0.0L, -2.220446049250313080847263336181622378926e-16L);
3336 TEST_c_c (casin, 0x1p-52L, 0.0L, 2.220446049250313080847263336181658871074e-16L, 0.0L);
3337 TEST_c_c (casin, -0x1p-52L, 0.0L, -2.220446049250313080847263336181658871074e-16L, 0.0L);
3338 TEST_c_c (casin, 0x1p-52L, -0.0L, 2.220446049250313080847263336181658871074e-16L, -0.0L);
3339 TEST_c_c (casin, -0x1p-52L, -0.0L, -2.220446049250313080847263336181658871074e-16L, -0.0L);
3340#ifndef TEST_FLOAT
3341 TEST_c_c (casin, 0x1.fp-1025L, 0x1.fp-1025L, 5.388850751072128349671657362289416093031e-309L, 5.388850751072128349671657362289416093031e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
3342 TEST_c_c (casin, 0x1.fp-1025L, -0x1.fp-1025L, 5.388850751072128349671657362289416093031e-309L, -5.388850751072128349671657362289416093031e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
3343 TEST_c_c (casin, -0x1.fp-1025L, 0x1.fp-1025L, -5.388850751072128349671657362289416093031e-309L, 5.388850751072128349671657362289416093031e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
3344 TEST_c_c (casin, -0x1.fp-1025L, -0x1.fp-1025L, -5.388850751072128349671657362289416093031e-309L, -5.388850751072128349671657362289416093031e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
3345#endif
3346#if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 64
3347 TEST_c_c (casin, 0x1p-63L, 0x0.ffffffffffffffffp0L, 7.666467083416870407402049869781566856442e-20L, 8.813735870195430251942769895627079569937e-1L);
3348 TEST_c_c (casin, 0x1p-63L, -0x0.ffffffffffffffffp0L, 7.666467083416870407402049869781566856442e-20L, -8.813735870195430251942769895627079569937e-1L);
3349 TEST_c_c (casin, -0x1p-63L, 0x0.ffffffffffffffffp0L, -7.666467083416870407402049869781566856442e-20L, 8.813735870195430251942769895627079569937e-1L);
3350 TEST_c_c (casin, -0x1p-63L, -0x0.ffffffffffffffffp0L, -7.666467083416870407402049869781566856442e-20L, -8.813735870195430251942769895627079569937e-1L);
3351 TEST_c_c (casin, 0x0.ffffffffffffffffp0L, 0x1p-63L, 1.570796326376055842114524927965556247908L, 2.588578361325995866221775673638805081337e-10L);
3352 TEST_c_c (casin, -0x0.ffffffffffffffffp0L, 0x1p-63L, -1.570796326376055842114524927965556247908L, 2.588578361325995866221775673638805081337e-10L);
3353 TEST_c_c (casin, 0x0.ffffffffffffffffp0L, -0x1p-63L, 1.570796326376055842114524927965556247908L, -2.588578361325995866221775673638805081337e-10L);
3354 TEST_c_c (casin, -0x0.ffffffffffffffffp0L, -0x1p-63L, -1.570796326376055842114524927965556247908L, -2.588578361325995866221775673638805081337e-10L);
3355# if LDBL_MIN_EXP <= -16381
3356 TEST_c_c (casin, 0x1.fp-16385L, 0x0.ffffffffffffffffp0L, 5.757683115456107044287327268904964422212e-4933L, 8.813735870195430251942769895627079569917e-1L, UNDERFLOW_EXCEPTION);
3357 TEST_c_c (casin, 0x1.fp-16385L, -0x0.ffffffffffffffffp0L, 5.757683115456107044287327268904964422212e-4933L, -8.813735870195430251942769895627079569917e-1L, UNDERFLOW_EXCEPTION);
3358 TEST_c_c (casin, -0x1.fp-16385L, 0x0.ffffffffffffffffp0L, -5.757683115456107044287327268904964422212e-4933L, 8.813735870195430251942769895627079569917e-1L, UNDERFLOW_EXCEPTION);
3359 TEST_c_c (casin, -0x1.fp-16385L, -0x0.ffffffffffffffffp0L, -5.757683115456107044287327268904964422212e-4933L, -8.813735870195430251942769895627079569917e-1L, UNDERFLOW_EXCEPTION);
3360 TEST_c_c (casin, 0x0.ffffffffffffffffp0L, 0x1.fp-16385L, 1.570796326465624365239962068302568888898L, 2.472906068161537187835415298076415423459e-4923L);
3361 TEST_c_c (casin, -0x0.ffffffffffffffffp0L, 0x1.fp-16385L, -1.570796326465624365239962068302568888898L, 2.472906068161537187835415298076415423459e-4923L);
3362 TEST_c_c (casin, 0x0.ffffffffffffffffp0L, -0x1.fp-16385L, 1.570796326465624365239962068302568888898L, -2.472906068161537187835415298076415423459e-4923L);
3363 TEST_c_c (casin, -0x0.ffffffffffffffffp0L, -0x1.fp-16385L, -1.570796326465624365239962068302568888898L, -2.472906068161537187835415298076415423459e-4923L);
3364# endif
3365 TEST_c_c (casin, 0.0L, 0x0.ffffffffffffffffp0L, 0.0L, 8.813735870195430251942769895627079569917e-1L);
3366 TEST_c_c (casin, 0.0L, -0x0.ffffffffffffffffp0L, 0.0L, -8.813735870195430251942769895627079569917e-1L);
3367 TEST_c_c (casin, -0.0L, 0x0.ffffffffffffffffp0L, -0.0L, 8.813735870195430251942769895627079569917e-1L);
3368 TEST_c_c (casin, -0.0L, -0x0.ffffffffffffffffp0L, -0.0L, -8.813735870195430251942769895627079569917e-1L);
3369 TEST_c_c (casin, 0x0.ffffffffffffffffp0L, 0.0L, 1.570796326465624365239962068302568888898L, 0.0L);
3370 TEST_c_c (casin, -0x0.ffffffffffffffffp0L, 0.0L, -1.570796326465624365239962068302568888898L, 0.0L);
3371 TEST_c_c (casin, 0x0.ffffffffffffffffp0L, -0.0L, 1.570796326465624365239962068302568888898L, -0.0L);
3372 TEST_c_c (casin, -0x0.ffffffffffffffffp0L, -0.0L, -1.570796326465624365239962068302568888898L, -0.0L);
3373#endif
3374 TEST_c_c (casin, 0x1p-63L, 0.5L, 9.697399036122160144833087173623140436413e-20L, 4.812118250596034474977589134243684231373e-1L);
3375 TEST_c_c (casin, 0x1p-63L, -0.5L, 9.697399036122160144833087173623140436413e-20L, -4.812118250596034474977589134243684231373e-1L);
3376 TEST_c_c (casin, -0x1p-63L, 0.5L, -9.697399036122160144833087173623140436413e-20L, 4.812118250596034474977589134243684231373e-1L);
3377 TEST_c_c (casin, -0x1p-63L, -0.5L, -9.697399036122160144833087173623140436413e-20L, -4.812118250596034474977589134243684231373e-1L);
3378 TEST_c_c (casin, 0.5L, 0x1p-63L, 5.235987755982988730771072305465838140283e-1L, 1.251928832280966098829878787499365228659e-19L);
3379 TEST_c_c (casin, -0.5L, 0x1p-63L, -5.235987755982988730771072305465838140283e-1L, 1.251928832280966098829878787499365228659e-19L);
3380 TEST_c_c (casin, 0.5L, -0x1p-63L, 5.235987755982988730771072305465838140283e-1L, -1.251928832280966098829878787499365228659e-19L);
3381 TEST_c_c (casin, -0.5L, -0x1p-63L, -5.235987755982988730771072305465838140283e-1L, -1.251928832280966098829878787499365228659e-19L);
3382#if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
3383 TEST_c_c (casin, 0x1.fp-16385L, 0.5L, 7.282957076134209141226696333885150260319e-4933L, 4.812118250596034474977589134243684231352e-1L, UNDERFLOW_EXCEPTION);
3384 TEST_c_c (casin, 0x1.fp-16385L, -0.5L, 7.282957076134209141226696333885150260319e-4933L, -4.812118250596034474977589134243684231352e-1L, UNDERFLOW_EXCEPTION);
3385 TEST_c_c (casin, -0x1.fp-16385L, 0.5L, -7.282957076134209141226696333885150260319e-4933L, 4.812118250596034474977589134243684231352e-1L, UNDERFLOW_EXCEPTION);
3386 TEST_c_c (casin, -0x1.fp-16385L, -0.5L, -7.282957076134209141226696333885150260319e-4933L, -4.812118250596034474977589134243684231352e-1L, UNDERFLOW_EXCEPTION);
3387 TEST_c_c (casin, 0.5L, 0x1.fp-16385L, 5.235987755982988730771072305465838140329e-1L, 9.402257155670418112159334875199821342890e-4933L, UNDERFLOW_EXCEPTION);
3388 TEST_c_c (casin, -0.5L, 0x1.fp-16385L, -5.235987755982988730771072305465838140329e-1L, 9.402257155670418112159334875199821342890e-4933L, UNDERFLOW_EXCEPTION);
3389 TEST_c_c (casin, 0.5L, -0x1.fp-16385L, 5.235987755982988730771072305465838140329e-1L, -9.402257155670418112159334875199821342890e-4933L, UNDERFLOW_EXCEPTION);
3390 TEST_c_c (casin, -0.5L, -0x1.fp-16385L, -5.235987755982988730771072305465838140329e-1L, -9.402257155670418112159334875199821342890e-4933L, UNDERFLOW_EXCEPTION);
3391#endif
3392 TEST_c_c (casin, 0x1p-63L, 0x1p-63L, 1.084202172485504434007452800869941711422e-19L, 1.084202172485504434007452800869941711430e-19L);
3393 TEST_c_c (casin, 0x1p-63L, -0x1p-63L, 1.084202172485504434007452800869941711422e-19L, -1.084202172485504434007452800869941711430e-19L);
3394 TEST_c_c (casin, -0x1p-63L, 0x1p-63L, -1.084202172485504434007452800869941711422e-19L, 1.084202172485504434007452800869941711430e-19L);
3395 TEST_c_c (casin, -0x1p-63L, -0x1p-63L, -1.084202172485504434007452800869941711422e-19L, -1.084202172485504434007452800869941711430e-19L);
3396#if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
3397 TEST_c_c (casin, 0x1.fp-16385L, 0x1p-63L, 8.142593549724601460479922838826119584369e-4933L, 1.084202172485504434007452800869941711424e-19L, UNDERFLOW_EXCEPTION);
3398 TEST_c_c (casin, 0x1.fp-16385L, -0x1p-63L, 8.142593549724601460479922838826119584369e-4933L, -1.084202172485504434007452800869941711424e-19L, UNDERFLOW_EXCEPTION);
3399 TEST_c_c (casin, -0x1.fp-16385L, 0x1p-63L, -8.142593549724601460479922838826119584369e-4933L, 1.084202172485504434007452800869941711424e-19L, UNDERFLOW_EXCEPTION);
3400 TEST_c_c (casin, -0x1.fp-16385L, -0x1p-63L, -8.142593549724601460479922838826119584369e-4933L, -1.084202172485504434007452800869941711424e-19L, UNDERFLOW_EXCEPTION);
3401 TEST_c_c (casin, 0x1p-63L, 0x1.fp-16385L, 1.084202172485504434007452800869941711428e-19L, 8.142593549724601460479922838826119584465e-4933L, UNDERFLOW_EXCEPTION);
3402 TEST_c_c (casin, -0x1p-63L, 0x1.fp-16385L, -1.084202172485504434007452800869941711428e-19L, 8.142593549724601460479922838826119584465e-4933L, UNDERFLOW_EXCEPTION);
3403 TEST_c_c (casin, 0x1p-63L, -0x1.fp-16385L, 1.084202172485504434007452800869941711428e-19L, -8.142593549724601460479922838826119584465e-4933L, UNDERFLOW_EXCEPTION);
3404 TEST_c_c (casin, -0x1p-63L, -0x1.fp-16385L, -1.084202172485504434007452800869941711428e-19L, -8.142593549724601460479922838826119584465e-4933L, UNDERFLOW_EXCEPTION);
3405#endif
3406 TEST_c_c (casin, 0.0L, 0x1p-63L, 0.0L, 1.084202172485504434007452800869941711424e-19L);
3407 TEST_c_c (casin, 0.0L, -0x1p-63L, 0.0L, -1.084202172485504434007452800869941711424e-19L);
3408 TEST_c_c (casin, -0.0L, 0x1p-63L, -0.0L, 1.084202172485504434007452800869941711424e-19L);
3409 TEST_c_c (casin, -0.0L, -0x1p-63L, -0.0L, -1.084202172485504434007452800869941711424e-19L);
3410 TEST_c_c (casin, 0x1p-63L, 0.0L, 1.084202172485504434007452800869941711428e-19L, 0.0L);
3411 TEST_c_c (casin, -0x1p-63L, 0.0L, -1.084202172485504434007452800869941711428e-19L, 0.0L);
3412 TEST_c_c (casin, 0x1p-63L, -0.0L, 1.084202172485504434007452800869941711428e-19L, -0.0L);
3413 TEST_c_c (casin, -0x1p-63L, -0.0L, -1.084202172485504434007452800869941711428e-19L, -0.0L);
3414#if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
3415 TEST_c_c (casin, 0x1.fp-16385L, 0x1.fp-16385L, 8.142593549724601460479922838826119584417e-4933L, 8.142593549724601460479922838826119584417e-4933L, UNDERFLOW_EXCEPTION);
3416 TEST_c_c (casin, 0x1.fp-16385L, -0x1.fp-16385L, 8.142593549724601460479922838826119584417e-4933L, -8.142593549724601460479922838826119584417e-4933L, UNDERFLOW_EXCEPTION);
3417 TEST_c_c (casin, -0x1.fp-16385L, 0x1.fp-16385L, -8.142593549724601460479922838826119584417e-4933L, 8.142593549724601460479922838826119584417e-4933L, UNDERFLOW_EXCEPTION);
3418 TEST_c_c (casin, -0x1.fp-16385L, -0x1.fp-16385L, -8.142593549724601460479922838826119584417e-4933L, -8.142593549724601460479922838826119584417e-4933L, UNDERFLOW_EXCEPTION);
3419#endif
3420#if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 106
3421 TEST_c_c (casin, 0x1p-105L, 0x0.ffffffffffffffffffffffffffcp0L, 1.743152798421049375791483240187377443526e-32L, 8.813735870195430252326093249797835932642e-1L);
3422 TEST_c_c (casin, 0x1p-105L, -0x0.ffffffffffffffffffffffffffcp0L, 1.743152798421049375791483240187377443526e-32L, -8.813735870195430252326093249797835932642e-1L);
3423 TEST_c_c (casin, -0x1p-105L, 0x0.ffffffffffffffffffffffffffcp0L, -1.743152798421049375791483240187377443526e-32L, 8.813735870195430252326093249797835932642e-1L);
3424 TEST_c_c (casin, -0x1p-105L, -0x0.ffffffffffffffffffffffffffcp0L, -1.743152798421049375791483240187377443526e-32L, -8.813735870195430252326093249797835932642e-1L);
3425 TEST_c_c (casin, 0x0.ffffffffffffffffffffffffffcp0L, 0x1p-105L, 1.570796326794896419512475791677915736035L, 1.234330349600789959989661887846005659983e-16L);
3426 TEST_c_c (casin, -0x0.ffffffffffffffffffffffffffcp0L, 0x1p-105L, -1.570796326794896419512475791677915736035L, 1.234330349600789959989661887846005659983e-16L);
3427 TEST_c_c (casin, 0x0.ffffffffffffffffffffffffffcp0L, -0x1p-105L, 1.570796326794896419512475791677915736035L, -1.234330349600789959989661887846005659983e-16L);
3428 TEST_c_c (casin, -0x0.ffffffffffffffffffffffffffcp0L, -0x1p-105L, -1.570796326794896419512475791677915736035L, -1.234330349600789959989661887846005659983e-16L);
3429 TEST_c_c (casin, 0x1.fp-1025L, 0x0.ffffffffffffffffffffffffffcp0L, 3.810492908885321743133304375216641110205e-309L, 8.813735870195430252326093249797835932642e-1L, UNDERFLOW_EXCEPTION_DOUBLE);
3430 TEST_c_c (casin, 0x1.fp-1025L, -0x0.ffffffffffffffffffffffffffcp0L, 3.810492908885321743133304375216641110205e-309L, -8.813735870195430252326093249797835932642e-1L, UNDERFLOW_EXCEPTION_DOUBLE);
3431 TEST_c_c (casin, -0x1.fp-1025L, 0x0.ffffffffffffffffffffffffffcp0L, -3.810492908885321743133304375216641110205e-309L, 8.813735870195430252326093249797835932642e-1L, UNDERFLOW_EXCEPTION_DOUBLE);
3432 TEST_c_c (casin, -0x1.fp-1025L, -0x0.ffffffffffffffffffffffffffcp0L, -3.810492908885321743133304375216641110205e-309L, -8.813735870195430252326093249797835932642e-1L, UNDERFLOW_EXCEPTION_DOUBLE);
3433 TEST_c_c (casin, 0x0.ffffffffffffffffffffffffffcp0L, 0x1.fp-1025L, 1.570796326794896462222075823262245502760L, 3.432186888910770473784103112009399360940e-293L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM);
3434 TEST_c_c (casin, -0x0.ffffffffffffffffffffffffffcp0L, 0x1.fp-1025L, -1.570796326794896462222075823262245502760L, 3.432186888910770473784103112009399360940e-293L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM);
3435 TEST_c_c (casin, 0x0.ffffffffffffffffffffffffffcp0L, -0x1.fp-1025L, 1.570796326794896462222075823262245502760L, -3.432186888910770473784103112009399360940e-293L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM);
3436 TEST_c_c (casin, -0x0.ffffffffffffffffffffffffffcp0L, -0x1.fp-1025L, -1.570796326794896462222075823262245502760L, -3.432186888910770473784103112009399360940e-293L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM);
3437 TEST_c_c (casin, 0.0L, 0x0.ffffffffffffffffffffffffffcp0L, 0.0L, 8.813735870195430252326093249797835932642e-1L);
3438 TEST_c_c (casin, 0.0L, -0x0.ffffffffffffffffffffffffffcp0L, 0.0L, -8.813735870195430252326093249797835932642e-1L);
3439 TEST_c_c (casin, -0.0L, 0x0.ffffffffffffffffffffffffffcp0L, -0.0L, 8.813735870195430252326093249797835932642e-1L);
3440 TEST_c_c (casin, -0.0L, -0x0.ffffffffffffffffffffffffffcp0L, -0.0L, -8.813735870195430252326093249797835932642e-1L);
3441 TEST_c_c (casin, 0x0.ffffffffffffffffffffffffffcp0L, 0.0L, 1.570796326794896462222075823262245502760L, 0.0L);
3442 TEST_c_c (casin, -0x0.ffffffffffffffffffffffffffcp0L, 0.0L, -1.570796326794896462222075823262245502760L, 0.0L);
3443 TEST_c_c (casin, 0x0.ffffffffffffffffffffffffffcp0L, -0.0L, 1.570796326794896462222075823262245502760L, -0.0L);
3444 TEST_c_c (casin, -0x0.ffffffffffffffffffffffffffcp0L, -0.0L, -1.570796326794896462222075823262245502760L, -0.0L);
3445#endif
3446 TEST_c_c (casin, 0x1p-105L, 0.5L, 2.204933261082751447436996198490110245167e-32L, 4.812118250596034474977589134243684231352e-1L);
3447 TEST_c_c (casin, 0x1p-105L, -0.5L, 2.204933261082751447436996198490110245167e-32L, -4.812118250596034474977589134243684231352e-1L);
3448 TEST_c_c (casin, -0x1p-105L, 0.5L, -2.204933261082751447436996198490110245167e-32L, 4.812118250596034474977589134243684231352e-1L);
3449 TEST_c_c (casin, -0x1p-105L, -0.5L, -2.204933261082751447436996198490110245167e-32L, -4.812118250596034474977589134243684231352e-1L);
3450 TEST_c_c (casin, 0.5L, 0x1p-105L, 5.235987755982988730771072305465838140329e-1L, 2.846556599890768890940941645338546615370e-32L);
3451 TEST_c_c (casin, -0.5L, 0x1p-105L, -5.235987755982988730771072305465838140329e-1L, 2.846556599890768890940941645338546615370e-32L);
3452 TEST_c_c (casin, 0.5L, -0x1p-105L, 5.235987755982988730771072305465838140329e-1L, -2.846556599890768890940941645338546615370e-32L);
3453 TEST_c_c (casin, -0.5L, -0x1p-105L, -5.235987755982988730771072305465838140329e-1L, -2.846556599890768890940941645338546615370e-32L);
3454 TEST_c_c (casin, 0x1p-105L, 0x1p-105L, 2.465190328815661891911651766508706967729e-32L, 2.465190328815661891911651766508706967729e-32L);
3455 TEST_c_c (casin, 0x1p-105L, -0x1p-105L, 2.465190328815661891911651766508706967729e-32L, -2.465190328815661891911651766508706967729e-32L);
3456 TEST_c_c (casin, -0x1p-105L, 0x1p-105L, -2.465190328815661891911651766508706967729e-32L, 2.465190328815661891911651766508706967729e-32L);
3457 TEST_c_c (casin, -0x1p-105L, -0x1p-105L, -2.465190328815661891911651766508706967729e-32L, -2.465190328815661891911651766508706967729e-32L);
3458#ifndef TEST_FLOAT
3459 /* Bug 15319: underflow exception may be missing. */
3460 TEST_c_c (casin, 0x1.fp-1025L, 0x1p-105L, 5.388850751072128349671657362289416093031e-309L, 2.465190328815661891911651766508706967729e-32L, UNDERFLOW_EXCEPTION_OK_DOUBLE);
3461 TEST_c_c (casin, 0x1.fp-1025L, -0x1p-105L, 5.388850751072128349671657362289416093031e-309L, -2.465190328815661891911651766508706967729e-32L, UNDERFLOW_EXCEPTION_OK_DOUBLE);
3462 TEST_c_c (casin, -0x1.fp-1025L, 0x1p-105L, -5.388850751072128349671657362289416093031e-309L, 2.465190328815661891911651766508706967729e-32L, UNDERFLOW_EXCEPTION_OK_DOUBLE);
3463 TEST_c_c (casin, -0x1.fp-1025L, -0x1p-105L, -5.388850751072128349671657362289416093031e-309L, -2.465190328815661891911651766508706967729e-32L, UNDERFLOW_EXCEPTION_OK_DOUBLE);
3464 TEST_c_c (casin, 0x1p-105L, 0x1.fp-1025L, 2.465190328815661891911651766508706967729e-32L, 5.388850751072128349671657362289416093031e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
3465 TEST_c_c (casin, -0x1p-105L, 0x1.fp-1025L, -2.465190328815661891911651766508706967729e-32L, 5.388850751072128349671657362289416093031e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
3466 TEST_c_c (casin, 0x1p-105L, -0x1.fp-1025L, 2.465190328815661891911651766508706967729e-32L, -5.388850751072128349671657362289416093031e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
3467 TEST_c_c (casin, -0x1p-105L, -0x1.fp-1025L, -2.465190328815661891911651766508706967729e-32L, -5.388850751072128349671657362289416093031e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
3468#endif
3469 TEST_c_c (casin, 0.0L, 0x1p-105L, 0.0L, 2.465190328815661891911651766508706967729e-32L);
3470 TEST_c_c (casin, 0.0L, -0x1p-105L, 0.0L, -2.465190328815661891911651766508706967729e-32L);
3471 TEST_c_c (casin, -0.0L, 0x1p-105L, -0.0L, 2.465190328815661891911651766508706967729e-32L);
3472 TEST_c_c (casin, -0.0L, -0x1p-105L, -0.0L, -2.465190328815661891911651766508706967729e-32L);
3473 TEST_c_c (casin, 0x1p-105L, 0.0L, 2.465190328815661891911651766508706967729e-32L, 0.0L);
3474 TEST_c_c (casin, -0x1p-105L, 0.0L, -2.465190328815661891911651766508706967729e-32L, 0.0L);
3475 TEST_c_c (casin, 0x1p-105L, -0.0L, 2.465190328815661891911651766508706967729e-32L, -0.0L);
3476 TEST_c_c (casin, -0x1p-105L, -0.0L, -2.465190328815661891911651766508706967729e-32L, -0.0L);
3477#if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 113
3478 TEST_c_c (casin, 0x1p-112L, 0x0.ffffffffffffffffffffffffffff8p0L, 1.361838123766444824837096281396380300349e-34L, 8.813735870195430252326093249797922409363e-1L);
3479 TEST_c_c (casin, 0x1p-112L, -0x0.ffffffffffffffffffffffffffff8p0L, 1.361838123766444824837096281396380300349e-34L, -8.813735870195430252326093249797922409363e-1L);
3480 TEST_c_c (casin, -0x1p-112L, 0x0.ffffffffffffffffffffffffffff8p0L, -1.361838123766444824837096281396380300349e-34L, 8.813735870195430252326093249797922409363e-1L);
3481 TEST_c_c (casin, -0x1p-112L, -0x0.ffffffffffffffffffffffffffff8p0L, -1.361838123766444824837096281396380300349e-34L, -8.813735870195430252326093249797922409363e-1L);
3482 TEST_c_c (casin, 0x0.ffffffffffffffffffffffffffff8p0L, 0x1p-112L, 1.570796326794896601578502908312986698624L, 1.091004200533850618345330909857103457781e-17L);
3483 TEST_c_c (casin, -0x0.ffffffffffffffffffffffffffff8p0L, 0x1p-112L, -1.570796326794896601578502908312986698624L, 1.091004200533850618345330909857103457781e-17L);
3484 TEST_c_c (casin, 0x0.ffffffffffffffffffffffffffff8p0L, -0x1p-112L, 1.570796326794896601578502908312986698624L, -1.091004200533850618345330909857103457781e-17L);
3485 TEST_c_c (casin, -0x0.ffffffffffffffffffffffffffff8p0L, -0x1p-112L, -1.570796326794896601578502908312986698624L, -1.091004200533850618345330909857103457781e-17L);
3486 TEST_c_c (casin, 0x1.fp-16385L, 0x0.ffffffffffffffffffffffffffff8p0L, 5.757683115456107044131264955348449231681e-4933L, 8.813735870195430252326093249797922409363e-1L, UNDERFLOW_EXCEPTION);
3487 TEST_c_c (casin, 0x1.fp-16385L, -0x0.ffffffffffffffffffffffffffff8p0L, 5.757683115456107044131264955348449231681e-4933L, -8.813735870195430252326093249797922409363e-1L, UNDERFLOW_EXCEPTION);
3488 TEST_c_c (casin, -0x1.fp-16385L, 0x0.ffffffffffffffffffffffffffff8p0L, -5.757683115456107044131264955348449231681e-4933L, 8.813735870195430252326093249797922409363e-1L, UNDERFLOW_EXCEPTION);
3489 TEST_c_c (casin, -0x1.fp-16385L, -0x0.ffffffffffffffffffffffffffff8p0L, -5.757683115456107044131264955348449231681e-4933L, -8.813735870195430252326093249797922409363e-1L, UNDERFLOW_EXCEPTION);
3490 TEST_c_c (casin, 0x0.ffffffffffffffffffffffffffff8p0L, 0x1.fp-16385L, 1.570796326794896605353533883825294686803L, 5.867357004219059108790368268900490184505e-4916L);
3491 TEST_c_c (casin, -0x0.ffffffffffffffffffffffffffff8p0L, 0x1.fp-16385L, -1.570796326794896605353533883825294686803L, 5.867357004219059108790368268900490184505e-4916L);
3492 TEST_c_c (casin, 0x0.ffffffffffffffffffffffffffff8p0L, -0x1.fp-16385L, 1.570796326794896605353533883825294686803L, -5.867357004219059108790368268900490184505e-4916L);
3493 TEST_c_c (casin, -0x0.ffffffffffffffffffffffffffff8p0L, -0x1.fp-16385L, -1.570796326794896605353533883825294686803L, -5.867357004219059108790368268900490184505e-4916L);
3494 TEST_c_c (casin, 0.0L, 0x0.ffffffffffffffffffffffffffff8p0L, 0.0L, 8.813735870195430252326093249797922409363e-1L);
3495 TEST_c_c (casin, 0.0L, -0x0.ffffffffffffffffffffffffffff8p0L, 0.0L, -8.813735870195430252326093249797922409363e-1L);
3496 TEST_c_c (casin, -0.0L, 0x0.ffffffffffffffffffffffffffff8p0L, -0.0L, 8.813735870195430252326093249797922409363e-1L);
3497 TEST_c_c (casin, -0.0L, -0x0.ffffffffffffffffffffffffffff8p0L, -0.0L, -8.813735870195430252326093249797922409363e-1L);
3498 TEST_c_c (casin, 0x0.ffffffffffffffffffffffffffff8p0L, 0.0L, 1.570796326794896605353533883825294686803L, 0.0L);
3499 TEST_c_c (casin, -0x0.ffffffffffffffffffffffffffff8p0L, 0.0L, -1.570796326794896605353533883825294686803L, 0.0L);
3500 TEST_c_c (casin, 0x0.ffffffffffffffffffffffffffff8p0L, -0.0L, 1.570796326794896605353533883825294686803L, -0.0L);
3501 TEST_c_c (casin, -0x0.ffffffffffffffffffffffffffff8p0L, -0.0L, -1.570796326794896605353533883825294686803L, -0.0L);
3502#endif
3503 TEST_c_c (casin, 0x1p-112L, 0.5L, 1.722604110220899568310153280070398629037e-34L, 4.812118250596034474977589134243684231352e-1L);
3504 TEST_c_c (casin, 0x1p-112L, -0.5L, 1.722604110220899568310153280070398629037e-34L, -4.812118250596034474977589134243684231352e-1L);
3505 TEST_c_c (casin, -0x1p-112L, 0.5L, -1.722604110220899568310153280070398629037e-34L, 4.812118250596034474977589134243684231352e-1L);
3506 TEST_c_c (casin, -0x1p-112L, -0.5L, -1.722604110220899568310153280070398629037e-34L, -4.812118250596034474977589134243684231352e-1L);
3507 TEST_c_c (casin, 0.5L, 0x1p-112L, 5.235987755982988730771072305465838140329e-1L, 2.223872343664663196047610660420739543258e-34L);
3508 TEST_c_c (casin, -0.5L, 0x1p-112L, -5.235987755982988730771072305465838140329e-1L, 2.223872343664663196047610660420739543258e-34L);
3509 TEST_c_c (casin, 0.5L, -0x1p-112L, 5.235987755982988730771072305465838140329e-1L, -2.223872343664663196047610660420739543258e-34L);
3510 TEST_c_c (casin, -0.5L, -0x1p-112L, -5.235987755982988730771072305465838140329e-1L, -2.223872343664663196047610660420739543258e-34L);
3511 TEST_c_c (casin, 0x1p-112L, 0x1p-112L, 1.925929944387235853055977942584927318538e-34L, 1.925929944387235853055977942584927318538e-34L);
3512 TEST_c_c (casin, 0x1p-112L, -0x1p-112L, 1.925929944387235853055977942584927318538e-34L, -1.925929944387235853055977942584927318538e-34L);
3513 TEST_c_c (casin, -0x1p-112L, 0x1p-112L, -1.925929944387235853055977942584927318538e-34L, 1.925929944387235853055977942584927318538e-34L);
3514 TEST_c_c (casin, -0x1p-112L, -0x1p-112L, -1.925929944387235853055977942584927318538e-34L, -1.925929944387235853055977942584927318538e-34L);
3515#if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
3516 TEST_c_c (casin, 0x1.fp-16385L, 0x1p-112L, 8.142593549724601460479922838826119584417e-4933L, 1.925929944387235853055977942584927318538e-34L, UNDERFLOW_EXCEPTION);
3517 TEST_c_c (casin, 0x1.fp-16385L, -0x1p-112L, 8.142593549724601460479922838826119584417e-4933L, -1.925929944387235853055977942584927318538e-34L, UNDERFLOW_EXCEPTION);
3518 TEST_c_c (casin, -0x1.fp-16385L, 0x1p-112L, -8.142593549724601460479922838826119584417e-4933L, 1.925929944387235853055977942584927318538e-34L, UNDERFLOW_EXCEPTION);
3519 TEST_c_c (casin, -0x1.fp-16385L, -0x1p-112L, -8.142593549724601460479922838826119584417e-4933L, -1.925929944387235853055977942584927318538e-34L, UNDERFLOW_EXCEPTION);
3520 TEST_c_c (casin, 0x1p-112L, 0x1.fp-16385L, 1.925929944387235853055977942584927318538e-34L, 8.142593549724601460479922838826119584417e-4933L, UNDERFLOW_EXCEPTION);
3521 TEST_c_c (casin, -0x1p-112L, 0x1.fp-16385L, -1.925929944387235853055977942584927318538e-34L, 8.142593549724601460479922838826119584417e-4933L, UNDERFLOW_EXCEPTION);
3522 TEST_c_c (casin, 0x1p-112L, -0x1.fp-16385L, 1.925929944387235853055977942584927318538e-34L, -8.142593549724601460479922838826119584417e-4933L, UNDERFLOW_EXCEPTION);
3523 TEST_c_c (casin, -0x1p-112L, -0x1.fp-16385L, -1.925929944387235853055977942584927318538e-34L, -8.142593549724601460479922838826119584417e-4933L, UNDERFLOW_EXCEPTION);
3524#endif
3525 TEST_c_c (casin, 0.0L, 0x1p-112L, 0.0L, 1.925929944387235853055977942584927318538e-34L);
3526 TEST_c_c (casin, 0.0L, -0x1p-112L, 0.0L, -1.925929944387235853055977942584927318538e-34L);
3527 TEST_c_c (casin, -0.0L, 0x1p-112L, -0.0L, 1.925929944387235853055977942584927318538e-34L);
3528 TEST_c_c (casin, -0.0L, -0x1p-112L, -0.0L, -1.925929944387235853055977942584927318538e-34L);
3529 TEST_c_c (casin, 0x1p-112L, 0.0L, 1.925929944387235853055977942584927318538e-34L, 0.0L);
3530 TEST_c_c (casin, -0x1p-112L, 0.0L, -1.925929944387235853055977942584927318538e-34L, 0.0L);
3531 TEST_c_c (casin, 0x1p-112L, -0.0L, 1.925929944387235853055977942584927318538e-34L, -0.0L);
3532 TEST_c_c (casin, -0x1p-112L, -0.0L, -1.925929944387235853055977942584927318538e-34L, -0.0L);
3533
2550dfe9 3534 TEST_c_c (casin, 0.75L, 1.25L, 0.453276177638793913448921196101971749L, 1.13239363160530819522266333696834467L);
33e885db 3535 TEST_c_c (casin, -2, -3, -0.57065278432109940071028387968566963L, -1.9833870299165354323470769028940395L);
8847214f 3536
6815fabc 3537 END (casin, complex);
8847214f
UD
3538}
3539
3540
3541static void
3542casinh_test (void)
3543{
aaca11d8 3544 errno = 0;
3c6cad26 3545 FUNC(casinh) (BUILD_COMPLEX (0.7L, 1.2L));
aaca11d8
UD
3546 if (errno == ENOSYS)
3547 /* Function not implemented. */
3548 return;
3549
8847214f
UD
3550 START (casinh);
3551
3552 TEST_c_c (casinh, 0, 0, 0.0, 0.0);
3553 TEST_c_c (casinh, minus_zero, 0, minus_zero, 0);
3554 TEST_c_c (casinh, 0, minus_zero, 0.0, minus_zero);
3555 TEST_c_c (casinh, minus_zero, minus_zero, minus_zero, minus_zero);
3556
3557 TEST_c_c (casinh, plus_infty, plus_infty, plus_infty, M_PI_4l);
3558 TEST_c_c (casinh, plus_infty, minus_infty, plus_infty, -M_PI_4l);
3559 TEST_c_c (casinh, minus_infty, plus_infty, minus_infty, M_PI_4l);
3560 TEST_c_c (casinh, minus_infty, minus_infty, minus_infty, -M_PI_4l);
3561
3562 TEST_c_c (casinh, -10.0, plus_infty, minus_infty, M_PI_2l);
3563 TEST_c_c (casinh, -10.0, minus_infty, minus_infty, -M_PI_2l);
3564 TEST_c_c (casinh, 0, plus_infty, plus_infty, M_PI_2l);
3565 TEST_c_c (casinh, 0, minus_infty, plus_infty, -M_PI_2l);
3566 TEST_c_c (casinh, minus_zero, plus_infty, minus_infty, M_PI_2l);
3567 TEST_c_c (casinh, minus_zero, minus_infty, minus_infty, -M_PI_2l);
3c6cad26
UD
3568 TEST_c_c (casinh, 0.1L, plus_infty, plus_infty, M_PI_2l);
3569 TEST_c_c (casinh, 0.1L, minus_infty, plus_infty, -M_PI_2l);
8847214f
UD
3570
3571 TEST_c_c (casinh, minus_infty, 0, minus_infty, 0.0);
3572 TEST_c_c (casinh, minus_infty, minus_zero, minus_infty, minus_zero);
3573 TEST_c_c (casinh, minus_infty, 100, minus_infty, 0.0);
3574 TEST_c_c (casinh, minus_infty, -100, minus_infty, minus_zero);
3575
3576 TEST_c_c (casinh, plus_infty, 0, plus_infty, 0.0);
3577 TEST_c_c (casinh, plus_infty, minus_zero, plus_infty, minus_zero);
3578 TEST_c_c (casinh, plus_infty, 0.5, plus_infty, 0.0);
3579 TEST_c_c (casinh, plus_infty, -0.5, plus_infty, minus_zero);
3580
67e971f1
TS
3581 TEST_c_c (casinh, plus_infty, qnan_value, plus_infty, qnan_value);
3582 TEST_c_c (casinh, minus_infty, qnan_value, minus_infty, qnan_value);
8847214f 3583
67e971f1
TS
3584 TEST_c_c (casinh, qnan_value, 0, qnan_value, 0.0);
3585 TEST_c_c (casinh, qnan_value, minus_zero, qnan_value, minus_zero);
8847214f 3586
67e971f1
TS
3587 TEST_c_c (casinh, qnan_value, plus_infty, plus_infty, qnan_value, IGNORE_ZERO_INF_SIGN);
3588 TEST_c_c (casinh, qnan_value, minus_infty, plus_infty, qnan_value, IGNORE_ZERO_INF_SIGN);
8847214f 3589
67e971f1
TS
3590 TEST_c_c (casinh, 10.5, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
3591 TEST_c_c (casinh, -10.5, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
8847214f 3592
67e971f1
TS
3593 TEST_c_c (casinh, qnan_value, 0.75, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
3594 TEST_c_c (casinh, -0.75, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
8847214f 3595
67e971f1 3596 TEST_c_c (casinh, qnan_value, qnan_value, qnan_value, qnan_value);
8847214f 3597
d1d3431a
JM
3598 TEST_c_c (casinh, plus_zero, -1.5L, 0.9624236501192068949955178268487368462704L, -M_PI_2l);
3599 TEST_c_c (casinh, minus_zero, -1.5L, -0.9624236501192068949955178268487368462704L, -M_PI_2l);
3600 TEST_c_c (casinh, plus_zero, -1.0L, plus_zero, -M_PI_2l);
3601 TEST_c_c (casinh, minus_zero, -1.0L, minus_zero, -M_PI_2l);
3602 TEST_c_c (casinh, plus_zero, -0.5L, plus_zero, -0.5235987755982988730771072305465838140329L);
3603 TEST_c_c (casinh, minus_zero, -0.5L, minus_zero, -0.5235987755982988730771072305465838140329L);
3604 TEST_c_c (casinh, plus_zero, 0.5L, plus_zero, 0.5235987755982988730771072305465838140329L);
3605 TEST_c_c (casinh, minus_zero, 0.5L, minus_zero, 0.5235987755982988730771072305465838140329L);
3606 TEST_c_c (casinh, plus_zero, 1.0L, plus_zero, M_PI_2l);
3607 TEST_c_c (casinh, minus_zero, 1.0L, minus_zero, M_PI_2l);
3608 TEST_c_c (casinh, plus_zero, 1.5L, 0.9624236501192068949955178268487368462704L, M_PI_2l);
3609 TEST_c_c (casinh, minus_zero, 1.5L, -0.9624236501192068949955178268487368462704L, M_PI_2l);
3610
3611 TEST_c_c (casinh, -1.5L, plus_zero, -1.194763217287109304111930828519090523536L, plus_zero);
3612 TEST_c_c (casinh, -1.5L, minus_zero, -1.194763217287109304111930828519090523536L, minus_zero);
3613 TEST_c_c (casinh, -1.0L, plus_zero, -0.8813735870195430252326093249797923090282L, plus_zero);
3614 TEST_c_c (casinh, -1.0L, minus_zero, -0.8813735870195430252326093249797923090282L, minus_zero);
3615 TEST_c_c (casinh, -0.5L, plus_zero, -0.4812118250596034474977589134243684231352L, plus_zero);
3616 TEST_c_c (casinh, -0.5L, minus_zero, -0.4812118250596034474977589134243684231352L, minus_zero);
3617 TEST_c_c (casinh, 0.5L, plus_zero, 0.4812118250596034474977589134243684231352L, plus_zero);
3618 TEST_c_c (casinh, 0.5L, minus_zero, 0.4812118250596034474977589134243684231352L, minus_zero);
3619 TEST_c_c (casinh, 1.0L, plus_zero, 0.8813735870195430252326093249797923090282L, plus_zero);
3620 TEST_c_c (casinh, 1.0L, minus_zero, 0.8813735870195430252326093249797923090282L, minus_zero);
3621 TEST_c_c (casinh, 1.5L, plus_zero, 1.194763217287109304111930828519090523536L, plus_zero);
3622 TEST_c_c (casinh, 1.5L, minus_zero, 1.194763217287109304111930828519090523536L, minus_zero);
3623
cdc1c96f
JM
3624 TEST_c_c (casinh, 0x1p50L, 1.0L, 3.535050620855721078027883819436759661753e1L, 8.881784197001252323389053344720723756399e-16L);
3625 TEST_c_c (casinh, 0x1p50L, -1.0L, 3.535050620855721078027883819436759661753e1L, -8.881784197001252323389053344720723756399e-16L);
3626 TEST_c_c (casinh, -0x1p50L, 1.0L, -3.535050620855721078027883819436759661753e1L, 8.881784197001252323389053344720723756399e-16L);
3627 TEST_c_c (casinh, -0x1p50L, -1.0L, -3.535050620855721078027883819436759661753e1L, -8.881784197001252323389053344720723756399e-16L);
3628 TEST_c_c (casinh, 1.0L, 0x1p50L, 3.535050620855721078027883819436720218708e1L, 1.570796326794895731052901991514519103193L);
3629 TEST_c_c (casinh, -1.0L, 0x1p50L, -3.535050620855721078027883819436720218708e1L, 1.570796326794895731052901991514519103193L);
3630 TEST_c_c (casinh, 1.0L, -0x1p50L, 3.535050620855721078027883819436720218708e1L, -1.570796326794895731052901991514519103193L);
3631 TEST_c_c (casinh, -1.0L, -0x1p50L, -3.535050620855721078027883819436720218708e1L, -1.570796326794895731052901991514519103193L);
3632#ifndef TEST_FLOAT
3633 TEST_c_c (casinh, 0x1p500L, 1.0L, 3.472667374605326000180332928505464606058e2L, 3.054936363499604682051979393213617699789e-151L);
3634 TEST_c_c (casinh, 0x1p500L, -1.0L, 3.472667374605326000180332928505464606058e2L, -3.054936363499604682051979393213617699789e-151L);
3635 TEST_c_c (casinh, -0x1p500L, 1.0L, -3.472667374605326000180332928505464606058e2L, 3.054936363499604682051979393213617699789e-151L);
3636 TEST_c_c (casinh, -0x1p500L, -1.0L, -3.472667374605326000180332928505464606058e2L, -3.054936363499604682051979393213617699789e-151L);
3637 TEST_c_c (casinh, 1.0L, 0x1p500L, 3.472667374605326000180332928505464606058e2L, 1.570796326794896619231321691639751442099L);
3638 TEST_c_c (casinh, -1.0L, 0x1p500L, -3.472667374605326000180332928505464606058e2L, 1.570796326794896619231321691639751442099L);
3639 TEST_c_c (casinh, 1.0L, -0x1p500L, 3.472667374605326000180332928505464606058e2L, -1.570796326794896619231321691639751442099L);
3640 TEST_c_c (casinh, -1.0L, -0x1p500L, -3.472667374605326000180332928505464606058e2L, -1.570796326794896619231321691639751442099L);
3641#endif
3642#if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
3643 TEST_c_c (casinh, 0x1p5000L, 1.0L, 3.466429049980286492395577839412341016946e3L, 7.079811261048172892385615158694057552948e-1506L);
3644 TEST_c_c (casinh, 0x1p5000L, -1.0L, 3.466429049980286492395577839412341016946e3L, -7.079811261048172892385615158694057552948e-1506L);
3645 TEST_c_c (casinh, -0x1p5000L, 1.0L, -3.466429049980286492395577839412341016946e3L, 7.079811261048172892385615158694057552948e-1506L);
3646 TEST_c_c (casinh, -0x1p5000L, -1.0L, -3.466429049980286492395577839412341016946e3L, -7.079811261048172892385615158694057552948e-1506L);
3647 TEST_c_c (casinh, 1.0L, 0x1p5000L, 3.466429049980286492395577839412341016946e3L, 1.570796326794896619231321691639751442099L);
3648 TEST_c_c (casinh, -1.0L, 0x1p5000L, -3.466429049980286492395577839412341016946e3L, 1.570796326794896619231321691639751442099L);
3649 TEST_c_c (casinh, 1.0L, -0x1p5000L, 3.466429049980286492395577839412341016946e3L, -1.570796326794896619231321691639751442099L);
3650 TEST_c_c (casinh, -1.0L, -0x1p5000L, -3.466429049980286492395577839412341016946e3L, -1.570796326794896619231321691639751442099L);
3651#endif
3652
a9708fed
JM
3653 TEST_c_c (casinh, 0x1.fp127L, 0x1.fp127L, 8.973081118419833726837456344608533993585e1L, 7.853981633974483096156608458198757210493e-1L);
3654#ifndef TEST_FLOAT
3655 TEST_c_c (casinh, 0x1.fp1023L, 0x1.fp1023L, 7.107906849659093345062145442726115449315e2L, 7.853981633974483096156608458198757210493e-1L);
3656#endif
3657#if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
3658 TEST_c_c (casinh, 0x1.fp16383L, 0x1.fp16383L, 1.135753137836666928715489992987020363057e4L, 7.853981633974483096156608458198757210493e-1L);
3659#endif
3660
8cf28c5e
JM
3661 TEST_c_c (casinh, 0x1.fp-129L, 1.5L, 9.624236501192068949955178268487368462704e-1L, 1.570796326794896619231321691639751442096L);
3662 TEST_c_c (casinh, 0x1.fp-129L, -1.5L, 9.624236501192068949955178268487368462704e-1L, -1.570796326794896619231321691639751442096L);
3663 TEST_c_c (casinh, -0x1.fp-129L, 1.5L, -9.624236501192068949955178268487368462704e-1L, 1.570796326794896619231321691639751442096L);
3664 TEST_c_c (casinh, -0x1.fp-129L, -1.5L, -9.624236501192068949955178268487368462704e-1L, -1.570796326794896619231321691639751442096L);
3665 TEST_c_c (casinh, 1.5L, 0x1.fp-129L, 1.194763217287109304111930828519090523536L, 1.579176199917649005841160751101628985741e-39L, UNDERFLOW_EXCEPTION_FLOAT);
3666 TEST_c_c (casinh, -1.5L, 0x1.fp-129L, -1.194763217287109304111930828519090523536L, 1.579176199917649005841160751101628985741e-39L, UNDERFLOW_EXCEPTION_FLOAT);
3667 TEST_c_c (casinh, 1.5L, -0x1.fp-129L, 1.194763217287109304111930828519090523536L, -1.579176199917649005841160751101628985741e-39L, UNDERFLOW_EXCEPTION_FLOAT);
3668 TEST_c_c (casinh, -1.5L, -0x1.fp-129L, -1.194763217287109304111930828519090523536L, -1.579176199917649005841160751101628985741e-39L, UNDERFLOW_EXCEPTION_FLOAT);
3669#ifndef TEST_FLOAT
3670 TEST_c_c (casinh, 0x1.fp-1025L, 1.5L, 9.624236501192068949955178268487368462704e-1L, 1.570796326794896619231321691639751442099L);
3671 TEST_c_c (casinh, 0x1.fp-1025L, -1.5L, 9.624236501192068949955178268487368462704e-1L, -1.570796326794896619231321691639751442099L);
3672 TEST_c_c (casinh, -0x1.fp-1025L, 1.5L, -9.624236501192068949955178268487368462704e-1L, 1.570796326794896619231321691639751442099L);
3673 TEST_c_c (casinh, -0x1.fp-1025L, -1.5L, -9.624236501192068949955178268487368462704e-1L, -1.570796326794896619231321691639751442099L);
3674 TEST_c_c (casinh, 1.5L, 0x1.fp-1025L, 1.194763217287109304111930828519090523536L, 2.989196569048182929051881765490354365918e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
3675 TEST_c_c (casinh, -1.5L, 0x1.fp-1025L, -1.194763217287109304111930828519090523536L, 2.989196569048182929051881765490354365918e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
3676 TEST_c_c (casinh, 1.5L, -0x1.fp-1025L, 1.194763217287109304111930828519090523536L, -2.989196569048182929051881765490354365918e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
3677 TEST_c_c (casinh, -1.5L, -0x1.fp-1025L, -1.194763217287109304111930828519090523536L, -2.989196569048182929051881765490354365918e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
3678#endif
3679#if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
3680 TEST_c_c (casinh, 0x1.fp-16385L, 1.5L, 9.624236501192068949955178268487368462704e-1L, 1.570796326794896619231321691639751442099L);
3681 TEST_c_c (casinh, 0x1.fp-16385L, -1.5L, 9.624236501192068949955178268487368462704e-1L, -1.570796326794896619231321691639751442099L);
3682 TEST_c_c (casinh, -0x1.fp-16385L, 1.5L, -9.624236501192068949955178268487368462704e-1L, 1.570796326794896619231321691639751442099L);
3683 TEST_c_c (casinh, -0x1.fp-16385L, -1.5L, -9.624236501192068949955178268487368462704e-1L, -1.570796326794896619231321691639751442099L);
3684 TEST_c_c (casinh, 1.5L, 0x1.fp-16385L, 1.194763217287109304111930828519090523536L, 4.516698239814521372306784062043266700598e-4933L, UNDERFLOW_EXCEPTION);
3685 TEST_c_c (casinh, -1.5L, 0x1.fp-16385L, -1.194763217287109304111930828519090523536L, 4.516698239814521372306784062043266700598e-4933L, UNDERFLOW_EXCEPTION);
3686 TEST_c_c (casinh, 1.5L, -0x1.fp-16385L, 1.194763217287109304111930828519090523536L, -4.516698239814521372306784062043266700598e-4933L, UNDERFLOW_EXCEPTION);
3687 TEST_c_c (casinh, -1.5L, -0x1.fp-16385L, -1.194763217287109304111930828519090523536L, -4.516698239814521372306784062043266700598e-4933L, UNDERFLOW_EXCEPTION);
3688#endif
3689
0a1b2ae6
JM
3690 TEST_c_c (casinh, 0.5L, 1.0L, 7.328576759736452608886724437653071523305e-1L, 8.959074812088902390666567243275770102229e-1L);
3691 TEST_c_c (casinh, 0.5L, -1.0L, 7.328576759736452608886724437653071523305e-1L, -8.959074812088902390666567243275770102229e-1L);
3692 TEST_c_c (casinh, -0.5L, 1.0L, -7.328576759736452608886724437653071523305e-1L, 8.959074812088902390666567243275770102229e-1L);
3693 TEST_c_c (casinh, -0.5L, -1.0L, -7.328576759736452608886724437653071523305e-1L, -8.959074812088902390666567243275770102229e-1L);
3694 TEST_c_c (casinh, 1.0L, 0.5L, 9.261330313501824245501244453057873152694e-1L, 3.494390628572132936274118260753699527325e-1L);
3695 TEST_c_c (casinh, -1.0L, 0.5L, -9.261330313501824245501244453057873152694e-1L, 3.494390628572132936274118260753699527325e-1L);
3696 TEST_c_c (casinh, 1.0L, -0.5L, 9.261330313501824245501244453057873152694e-1L, -3.494390628572132936274118260753699527325e-1L);
3697 TEST_c_c (casinh, -1.0L, -0.5L, -9.261330313501824245501244453057873152694e-1L, -3.494390628572132936274118260753699527325e-1L);
3698 TEST_c_c (casinh, 0.25L, 1.0L, 5.097911466811016354623559941115413499164e-1L, 1.081751996523816326311037318425097434186L);
3699 TEST_c_c (casinh, 0.25L, -1.0L, 5.097911466811016354623559941115413499164e-1L, -1.081751996523816326311037318425097434186L);
3700 TEST_c_c (casinh, -0.25L, 1.0L, -5.097911466811016354623559941115413499164e-1L, 1.081751996523816326311037318425097434186L);
3701 TEST_c_c (casinh, -0.25L, -1.0L, -5.097911466811016354623559941115413499164e-1L, -1.081751996523816326311037318425097434186L);
3702 TEST_c_c (casinh, 1.0L, 0.25L, 8.924633639033482359562124741744951972772e-1L, 1.763024327769669304186785666360901026468e-1L);
3703 TEST_c_c (casinh, -1.0L, 0.25L, -8.924633639033482359562124741744951972772e-1L, 1.763024327769669304186785666360901026468e-1L);
3704 TEST_c_c (casinh, 1.0L, -0.25L, 8.924633639033482359562124741744951972772e-1L, -1.763024327769669304186785666360901026468e-1L);
3705 TEST_c_c (casinh, -1.0L, -0.25L, -8.924633639033482359562124741744951972772e-1L, -1.763024327769669304186785666360901026468e-1L);
3706 TEST_c_c (casinh, 0x1.fp-10L, 1.0L, 4.350501469856803800217957402220976497152e-2L, 1.527305029163877791518741192097931722508L);
3707 TEST_c_c (casinh, 0x1.fp-10L, -1.0L, 4.350501469856803800217957402220976497152e-2L, -1.527305029163877791518741192097931722508L);
3708 TEST_c_c (casinh, -0x1.fp-10L, 1.0L, -4.350501469856803800217957402220976497152e-2L, 1.527305029163877791518741192097931722508L);
3709 TEST_c_c (casinh, -0x1.fp-10L, -1.0L, -4.350501469856803800217957402220976497152e-2L, -1.527305029163877791518741192097931722508L);
3710 TEST_c_c (casinh, 1.0L, 0x1.fp-10L, 8.813742198809567991336704287826445879025e-1L, 1.337909359557740912558349531052239112857e-3L);
3711 TEST_c_c (casinh, -1.0L, 0x1.fp-10L, -8.813742198809567991336704287826445879025e-1L, 1.337909359557740912558349531052239112857e-3L);
3712 TEST_c_c (casinh, 1.0L, -0x1.fp-10L, 8.813742198809567991336704287826445879025e-1L, -1.337909359557740912558349531052239112857e-3L);
3713 TEST_c_c (casinh, -1.0L, -0x1.fp-10L, -8.813742198809567991336704287826445879025e-1L, -1.337909359557740912558349531052239112857e-3L);
3714 TEST_c_c (casinh, 0x1.fp-30L, 1.0L, 4.247867098745151888768727039216644758847e-5L, 1.570753848123921942730162693731872690232L);
3715 TEST_c_c (casinh, 0x1.fp-30L, -1.0L, 4.247867098745151888768727039216644758847e-5L, -1.570753848123921942730162693731872690232L);
3716 TEST_c_c (casinh, -0x1.fp-30L, 1.0L, -4.247867098745151888768727039216644758847e-5L, 1.570753848123921942730162693731872690232L);
3717 TEST_c_c (casinh, -0x1.fp-30L, -1.0L, -4.247867098745151888768727039216644758847e-5L, -1.570753848123921942730162693731872690232L);
3718 TEST_c_c (casinh, 1.0L, 0x1.fp-30L, 8.813735870195430258081932989769495326854e-1L, 1.275929984216518540252717485007112529021e-9L);
3719 TEST_c_c (casinh, -1.0L, 0x1.fp-30L, -8.813735870195430258081932989769495326854e-1L, 1.275929984216518540252717485007112529021e-9L);
3720 TEST_c_c (casinh, 1.0L, -0x1.fp-30L, 8.813735870195430258081932989769495326854e-1L, -1.275929984216518540252717485007112529021e-9L);
3721 TEST_c_c (casinh, -1.0L, -0x1.fp-30L, -8.813735870195430258081932989769495326854e-1L, -1.275929984216518540252717485007112529021e-9L);
3722 TEST_c_c (casinh, 0x1.fp-100L, 1.0L, 1.236292038260260888664514866457202186027e-15L, 1.570796326794895382939283431378862777584L);
3723 TEST_c_c (casinh, 0x1.fp-100L, -1.0L, 1.236292038260260888664514866457202186027e-15L, -1.570796326794895382939283431378862777584L);
3724 TEST_c_c (casinh, -0x1.fp-100L, 1.0L, -1.236292038260260888664514866457202186027e-15L, 1.570796326794895382939283431378862777584L);
3725 TEST_c_c (casinh, -0x1.fp-100L, -1.0L, -1.236292038260260888664514866457202186027e-15L, -1.570796326794895382939283431378862777584L);
3726 TEST_c_c (casinh, 1.0L, 0x1.fp-100L, 8.813735870195430252326093249797923090282e-1L, 1.080754735021050612990719608916167354321e-30L);
3727 TEST_c_c (casinh, -1.0L, 0x1.fp-100L, -8.813735870195430252326093249797923090282e-1L, 1.080754735021050612990719608916167354321e-30L);
3728 TEST_c_c (casinh, 1.0L, -0x1.fp-100L, 8.813735870195430252326093249797923090282e-1L, -1.080754735021050612990719608916167354321e-30L);
3729 TEST_c_c (casinh, -1.0L, -0x1.fp-100L, -8.813735870195430252326093249797923090282e-1L, -1.080754735021050612990719608916167354321e-30L);
3730 TEST_c_c (casinh, 0x1.fp-129L, 1.0L, 5.335635276982233498398987585285818977933e-20L, 1.570796326794896619177965338869929107115L);
3731 TEST_c_c (casinh, 0x1.fp-129L, -1.0L, 5.335635276982233498398987585285818977933e-20L, -1.570796326794896619177965338869929107115L);
3732 TEST_c_c (casinh, -0x1.fp-129L, 1.0L, -5.335635276982233498398987585285818977933e-20L, 1.570796326794896619177965338869929107115L);
3733 TEST_c_c (casinh, -0x1.fp-129L, -1.0L, -5.335635276982233498398987585285818977933e-20L, -1.570796326794896619177965338869929107115L);
3734 TEST_c_c (casinh, 1.0L, 0x1.fp-129L, 8.813735870195430252326093249797923090282e-1L, 2.013062564695348242280482517399205554874e-39L, UNDERFLOW_EXCEPTION_FLOAT);
3735 TEST_c_c (casinh, -1.0L, 0x1.fp-129L, -8.813735870195430252326093249797923090282e-1L, 2.013062564695348242280482517399205554874e-39L, UNDERFLOW_EXCEPTION_FLOAT);
3736 TEST_c_c (casinh, 1.0L, -0x1.fp-129L, 8.813735870195430252326093249797923090282e-1L, -2.013062564695348242280482517399205554874e-39L, UNDERFLOW_EXCEPTION_FLOAT);
3737 TEST_c_c (casinh, -1.0L, -0x1.fp-129L, -8.813735870195430252326093249797923090282e-1L, -2.013062564695348242280482517399205554874e-39L, UNDERFLOW_EXCEPTION_FLOAT);
3738#ifndef TEST_FLOAT
3739 TEST_c_c (casinh, 0x1.fp-1000L, 1.0L, 4.252291453851660175550490409247739011867e-151L, 1.570796326794896619231321691639751442099L);
3740 TEST_c_c (casinh, 0x1.fp-1000L, -1.0L, 4.252291453851660175550490409247739011867e-151L, -1.570796326794896619231321691639751442099L);
3741 TEST_c_c (casinh, -0x1.fp-1000L, 1.0L, -4.252291453851660175550490409247739011867e-151L, 1.570796326794896619231321691639751442099L);
3742 TEST_c_c (casinh, -0x1.fp-1000L, -1.0L, -4.252291453851660175550490409247739011867e-151L, -1.570796326794896619231321691639751442099L);
3743 TEST_c_c (casinh, 1.0L, 0x1.fp-1000L, 8.813735870195430252326093249797923090282e-1L, 1.278589251976747242280879285935084814093e-301L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM);
3744 TEST_c_c (casinh, -1.0L, 0x1.fp-1000L, -8.813735870195430252326093249797923090282e-1L, 1.278589251976747242280879285935084814093e-301L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM);
3745 TEST_c_c (casinh, 1.0L, -0x1.fp-1000L, 8.813735870195430252326093249797923090282e-1L, -1.278589251976747242280879285935084814093e-301L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM);
3746 TEST_c_c (casinh, -1.0L, -0x1.fp-1000L, -8.813735870195430252326093249797923090282e-1L, -1.278589251976747242280879285935084814093e-301L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM);
3747 TEST_c_c (casinh, 0x1.fp-1025L, 1.0L, 7.340879205566679497036857179189356754017e-155L, 1.570796326794896619231321691639751442099L);
3748 TEST_c_c (casinh, 0x1.fp-1025L, -1.0L, 7.340879205566679497036857179189356754017e-155L, -1.570796326794896619231321691639751442099L);
3749 TEST_c_c (casinh, -0x1.fp-1025L, 1.0L, -7.340879205566679497036857179189356754017e-155L, 1.570796326794896619231321691639751442099L);
3750 TEST_c_c (casinh, -0x1.fp-1025L, -1.0L, -7.340879205566679497036857179189356754017e-155L, -1.570796326794896619231321691639751442099L);
3751 TEST_c_c (casinh, 1.0L, 0x1.fp-1025L, 8.813735870195430252326093249797923090282e-1L, 3.810492908885321743133304375216617626230e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
3752 TEST_c_c (casinh, -1.0L, 0x1.fp-1025L, -8.813735870195430252326093249797923090282e-1L, 3.810492908885321743133304375216617626230e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
3753 TEST_c_c (casinh, 1.0L, -0x1.fp-1025L, 8.813735870195430252326093249797923090282e-1L, -3.810492908885321743133304375216617626230e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
3754 TEST_c_c (casinh, -1.0L, -0x1.fp-1025L, -8.813735870195430252326093249797923090282e-1L, -3.810492908885321743133304375216617626230e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
3755#endif
3756#if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
3757 TEST_c_c (casinh, 0x1.fp-10000L, 1.0L, 9.854680208706673586644342922051388714633e-1506L, 1.570796326794896619231321691639751442099L);
3758 TEST_c_c (casinh, 0x1.fp-10000L, -1.0L, 9.854680208706673586644342922051388714633e-1506L, -1.570796326794896619231321691639751442099L);
3759 TEST_c_c (casinh, -0x1.fp-10000L, 1.0L, -9.854680208706673586644342922051388714633e-1506L, 1.570796326794896619231321691639751442099L);
3760 TEST_c_c (casinh, -0x1.fp-10000L, -1.0L, -9.854680208706673586644342922051388714633e-1506L, -1.570796326794896619231321691639751442099L);
3761 TEST_c_c (casinh, 1.0L, 0x1.fp-10000L, 8.813735870195430252326093249797923090282e-1L, 6.867047849047171855399183659351043150871e-3011L);
3762 TEST_c_c (casinh, -1.0L, 0x1.fp-10000L, -8.813735870195430252326093249797923090282e-1L, 6.867047849047171855399183659351043150871e-3011L);
3763 TEST_c_c (casinh, 1.0L, -0x1.fp-10000L, 8.813735870195430252326093249797923090282e-1L, -6.867047849047171855399183659351043150871e-3011L);
3764 TEST_c_c (casinh, -1.0L, -0x1.fp-10000L, -8.813735870195430252326093249797923090282e-1L, -6.867047849047171855399183659351043150871e-3011L);
3765 TEST_c_c (casinh, 0x1.fp-16385L, 1.0L, 9.023632056840860275214893047597614177639e-2467L, 1.570796326794896619231321691639751442099L);
3766 TEST_c_c (casinh, 0x1.fp-16385L, -1.0L, 9.023632056840860275214893047597614177639e-2467L, -1.570796326794896619231321691639751442099L);
3767 TEST_c_c (casinh, -0x1.fp-16385L, 1.0L, -9.023632056840860275214893047597614177639e-2467L, 1.570796326794896619231321691639751442099L);
3768 TEST_c_c (casinh, -0x1.fp-16385L, -1.0L, -9.023632056840860275214893047597614177639e-2467L, -1.570796326794896619231321691639751442099L);
3769 TEST_c_c (casinh, 1.0L, 0x1.fp-16385L, 8.813735870195430252326093249797923090282e-1L, 5.757683115456107044131264955348448954458e-4933L, UNDERFLOW_EXCEPTION);
3770 TEST_c_c (casinh, -1.0L, 0x1.fp-16385L, -8.813735870195430252326093249797923090282e-1L, 5.757683115456107044131264955348448954458e-4933L, UNDERFLOW_EXCEPTION);
3771 TEST_c_c (casinh, 1.0L, -0x1.fp-16385L, 8.813735870195430252326093249797923090282e-1L, -5.757683115456107044131264955348448954458e-4933L, UNDERFLOW_EXCEPTION);
3772 TEST_c_c (casinh, -1.0L, -0x1.fp-16385L, -8.813735870195430252326093249797923090282e-1L, -5.757683115456107044131264955348448954458e-4933L, UNDERFLOW_EXCEPTION);
3773#endif
3774
3a7182a1
JM
3775 TEST_c_c (casinh, 0x1p-23L, 0x1.000002p0L, 5.364668491573609633134147164031476452679e-4L, 1.570574114956455764594481054234834678422L)
3776 TEST_c_c (casinh, 0x1p-23L, -0x1.000002p0L, 5.364668491573609633134147164031476452679e-4L, -1.570574114956455764594481054234834678422L)
3777 TEST_c_c (casinh, -0x1p-23L, 0x1.000002p0L, -5.364668491573609633134147164031476452679e-4L, 1.570574114956455764594481054234834678422L)
3778 TEST_c_c (casinh, -0x1p-23L, -0x1.000002p0L, -5.364668491573609633134147164031476452679e-4L, -1.570574114956455764594481054234834678422L)
3779 TEST_c_c (casinh, 0x1.000002p0L, 0x1p-23L, 8.813736713132400470205730751186547909968e-1L, 8.429369199749229560964789467980644296420e-8L)
3780 TEST_c_c (casinh, -0x1.000002p0L, 0x1p-23L, -8.813736713132400470205730751186547909968e-1L, 8.429369199749229560964789467980644296420e-8L)
3781 TEST_c_c (casinh, 0x1.000002p0L, -0x1p-23L, 8.813736713132400470205730751186547909968e-1L, -8.429369199749229560964789467980644296420e-8L)
3782 TEST_c_c (casinh, -0x1.000002p0L, -0x1p-23L, -8.813736713132400470205730751186547909968e-1L, -8.429369199749229560964789467980644296420e-8L)
3783 TEST_c_c (casinh, 0x1.fp-129L, 0x1.000002p0L, 4.882812451493617206486388134172712975070e-4L, 1.570796326794896619231321691639751436268L)
3784 TEST_c_c (casinh, 0x1.fp-129L, -0x1.000002p0L, 4.882812451493617206486388134172712975070e-4L, -1.570796326794896619231321691639751436268L)
3785 TEST_c_c (casinh, -0x1.fp-129L, 0x1.000002p0L, -4.882812451493617206486388134172712975070e-4L, 1.570796326794896619231321691639751436268L)
3786 TEST_c_c (casinh, -0x1.fp-129L, -0x1.000002p0L, -4.882812451493617206486388134172712975070e-4L, -1.570796326794896619231321691639751436268L)
3787 TEST_c_c (casinh, 0x1.000002p0L, 0x1.fp-129L, 8.813736713132375348727889167749389235161e-1L, 2.013062444707472738895109955455676357057e-39L, UNDERFLOW_EXCEPTION_FLOAT)
3788 TEST_c_c (casinh, -0x1.000002p0L, 0x1.fp-129L, -8.813736713132375348727889167749389235161e-1L, 2.013062444707472738895109955455676357057e-39L, UNDERFLOW_EXCEPTION_FLOAT)
3789 TEST_c_c (casinh, 0x1.000002p0L, -0x1.fp-129L, 8.813736713132375348727889167749389235161e-1L, -2.013062444707472738895109955455676357057e-39L, UNDERFLOW_EXCEPTION_FLOAT)
3790 TEST_c_c (casinh, -0x1.000002p0L, -0x1.fp-129L, -8.813736713132375348727889167749389235161e-1L, -2.013062444707472738895109955455676357057e-39L, UNDERFLOW_EXCEPTION_FLOAT)
3791 TEST_c_c (casinh, 0.0L, 0x1.000002p0L, 4.882812451493617206486388134172712975070e-4L, 1.570796326794896619231321691639751442099L)
3792 TEST_c_c (casinh, 0.0L, -0x1.000002p0L, 4.882812451493617206486388134172712975070e-4L, -1.570796326794896619231321691639751442099L)
3793 TEST_c_c (casinh, -0.0L, 0x1.000002p0L, -4.882812451493617206486388134172712975070e-4L, 1.570796326794896619231321691639751442099L)
3794 TEST_c_c (casinh, -0.0L, -0x1.000002p0L, -4.882812451493617206486388134172712975070e-4L, -1.570796326794896619231321691639751442099L)
3795 TEST_c_c (casinh, 0x1.000002p0L, 0.0L, 8.813736713132375348727889167749389235161e-1L, 0.0L)
3796 TEST_c_c (casinh, -0x1.000002p0L, 0.0L, -8.813736713132375348727889167749389235161e-1L, 0.0L)
3797 TEST_c_c (casinh, 0x1.000002p0L, -0.0L, 8.813736713132375348727889167749389235161e-1L, -0.0L)
3798 TEST_c_c (casinh, -0x1.000002p0L, -0.0L, -8.813736713132375348727889167749389235161e-1L, -0.0L)
3799#ifndef TEST_FLOAT
3800 TEST_c_c (casinh, 0x1p-52L, 0x1.0000000000001p0L, 2.315303644582684770975188768022139415020e-8L, 1.570796317204594913251280305810847349436L)
3801 TEST_c_c (casinh, 0x1p-52L, -0x1.0000000000001p0L, 2.315303644582684770975188768022139415020e-8L, -1.570796317204594913251280305810847349436L)
3802 TEST_c_c (casinh, -0x1p-52L, 0x1.0000000000001p0L, -2.315303644582684770975188768022139415020e-8L, 1.570796317204594913251280305810847349436L)
3803 TEST_c_c (casinh, -0x1p-52L, -0x1.0000000000001p0L, -2.315303644582684770975188768022139415020e-8L, -1.570796317204594913251280305810847349436L)
3804 TEST_c_c (casinh, 0x1.0000000000001p0L, 0x1p-52L, 8.813735870195431822418551933572982483664e-1L, 1.570092458683774885078102529858632363236e-16L)
3805 TEST_c_c (casinh, -0x1.0000000000001p0L, 0x1p-52L, -8.813735870195431822418551933572982483664e-1L, 1.570092458683774885078102529858632363236e-16L)
3806 TEST_c_c (casinh, 0x1.0000000000001p0L, -0x1p-52L, 8.813735870195431822418551933572982483664e-1L, -1.570092458683774885078102529858632363236e-16L)
3807 TEST_c_c (casinh, -0x1.0000000000001p0L, -0x1p-52L, -8.813735870195431822418551933572982483664e-1L, -1.570092458683774885078102529858632363236e-16L)
3808 TEST_c_c (casinh, 0x1.fp-1025L, 0x1.0000000000001p0L, 2.107342425544701550354780375182800088393e-8L, 1.570796326794896619231321691639751442099L)
3809 TEST_c_c (casinh, 0x1.fp-1025L, -0x1.0000000000001p0L, 2.107342425544701550354780375182800088393e-8L, -1.570796326794896619231321691639751442099L)
3810 TEST_c_c (casinh, -0x1.fp-1025L, 0x1.0000000000001p0L, -2.107342425544701550354780375182800088393e-8L, 1.570796326794896619231321691639751442099L)
3811 TEST_c_c (casinh, -0x1.fp-1025L, -0x1.0000000000001p0L, -2.107342425544701550354780375182800088393e-8L, -1.570796326794896619231321691639751442099L)
3812 TEST_c_c (casinh, 0x1.0000000000001p0L, 0x1.fp-1025L, 8.813735870195431822418551933572895326024e-1L, 3.810492908885321320083608113679347200012e-309L, UNDERFLOW_EXCEPTION_DOUBLE)
3813 TEST_c_c (casinh, -0x1.0000000000001p0L, 0x1.fp-1025L, -8.813735870195431822418551933572895326024e-1L, 3.810492908885321320083608113679347200012e-309L, UNDERFLOW_EXCEPTION_DOUBLE)
3814 TEST_c_c (casinh, 0x1.0000000000001p0L, -0x1.fp-1025L, 8.813735870195431822418551933572895326024e-1L, -3.810492908885321320083608113679347200012e-309L, UNDERFLOW_EXCEPTION_DOUBLE)
3815 TEST_c_c (casinh, -0x1.0000000000001p0L, -0x1.fp-1025L, -8.813735870195431822418551933572895326024e-1L, -3.810492908885321320083608113679347200012e-309L, UNDERFLOW_EXCEPTION_DOUBLE)
3816 TEST_c_c (casinh, 0.0L, 0x1.0000000000001p0L, 2.107342425544701550354780375182800088393e-8L, 1.570796326794896619231321691639751442099L)
3817 TEST_c_c (casinh, 0.0L, -0x1.0000000000001p0L, 2.107342425544701550354780375182800088393e-8L, -1.570796326794896619231321691639751442099L)
3818 TEST_c_c (casinh, -0.0L, 0x1.0000000000001p0L, -2.107342425544701550354780375182800088393e-8L, 1.570796326794896619231321691639751442099L)
3819 TEST_c_c (casinh, -0.0L, -0x1.0000000000001p0L, -2.107342425544701550354780375182800088393e-8L, -1.570796326794896619231321691639751442099L)
3820 TEST_c_c (casinh, 0x1.0000000000001p0L, 0.0L, 8.813735870195431822418551933572895326024e-1L, 0.0L)
3821 TEST_c_c (casinh, -0x1.0000000000001p0L, 0.0L, -8.813735870195431822418551933572895326024e-1L, 0.0L)
3822 TEST_c_c (casinh, 0x1.0000000000001p0L, -0.0L, 8.813735870195431822418551933572895326024e-1L, -0.0L)
3823 TEST_c_c (casinh, -0x1.0000000000001p0L, -0.0L, -8.813735870195431822418551933572895326024e-1L, -0.0L)
3824#endif
3825#if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 64
3826 TEST_c_c (casinh, 0x1p-63L, 0x1.0000000000000002p0L, 5.116146586219826555037807251857670783420e-10L, 1.570796326582978888921215348380499122131L)
3827 TEST_c_c (casinh, 0x1p-63L, -0x1.0000000000000002p0L, 5.116146586219826555037807251857670783420e-10L, -1.570796326582978888921215348380499122131L)
3828 TEST_c_c (casinh, -0x1p-63L, 0x1.0000000000000002p0L, -5.116146586219826555037807251857670783420e-10L, 1.570796326582978888921215348380499122131L)
3829 TEST_c_c (casinh, -0x1p-63L, -0x1.0000000000000002p0L, -5.116146586219826555037807251857670783420e-10L, -1.570796326582978888921215348380499122131L)
3830 TEST_c_c (casinh, 0x1.0000000000000002p0L, 0x1p-63L, 8.813735870195430253092739958139610131001e-1L, 7.666467083416870406778649849746878368519e-20L)
3831 TEST_c_c (casinh, -0x1.0000000000000002p0L, 0x1p-63L, -8.813735870195430253092739958139610131001e-1L, 7.666467083416870406778649849746878368519e-20L)
3832 TEST_c_c (casinh, 0x1.0000000000000002p0L, -0x1p-63L, 8.813735870195430253092739958139610131001e-1L, -7.666467083416870406778649849746878368519e-20L)
3833 TEST_c_c (casinh, -0x1.0000000000000002p0L, -0x1p-63L, -8.813735870195430253092739958139610131001e-1L, -7.666467083416870406778649849746878368519e-20L)
3834# if LDBL_MIN_EXP <= -16381
3835 TEST_c_c (casinh, 0x1.fp-16385L, 0x1.0000000000000002p0L, 4.656612873077392578082927418388212703712e-10L, 1.570796326794896619231321691639751442099L)
3836 TEST_c_c (casinh, 0x1.fp-16385L, -0x1.0000000000000002p0L, 4.656612873077392578082927418388212703712e-10L, -1.570796326794896619231321691639751442099L)
3837 TEST_c_c (casinh, -0x1.fp-16385L, 0x1.0000000000000002p0L, -4.656612873077392578082927418388212703712e-10L, 1.570796326794896619231321691639751442099L)
3838 TEST_c_c (casinh, -0x1.fp-16385L, -0x1.0000000000000002p0L, -4.656612873077392578082927418388212703712e-10L, -1.570796326794896619231321691639751442099L)
3839 TEST_c_c (casinh, 0x1.0000000000000002p0L, 0x1.fp-16385L, 8.813735870195430253092739958139610130980e-1L, 5.757683115456107043819140328235418018963e-4933L, UNDERFLOW_EXCEPTION)
3840 TEST_c_c (casinh, -0x1.0000000000000002p0L, 0x1.fp-16385L, -8.813735870195430253092739958139610130980e-1L, 5.757683115456107043819140328235418018963e-4933L, UNDERFLOW_EXCEPTION)
3841 TEST_c_c (casinh, 0x1.0000000000000002p0L, -0x1.fp-16385L, 8.813735870195430253092739958139610130980e-1L, -5.757683115456107043819140328235418018963e-4933L, UNDERFLOW_EXCEPTION)
3842 TEST_c_c (casinh, -0x1.0000000000000002p0L, -0x1.fp-16385L, -8.813735870195430253092739958139610130980e-1L, -5.757683115456107043819140328235418018963e-4933L, UNDERFLOW_EXCEPTION)
3843# endif
3844 TEST_c_c (casinh, 0.0L, 0x1.0000000000000002p0L, 4.656612873077392578082927418388212703712e-10L, 1.570796326794896619231321691639751442099L)
3845 TEST_c_c (casinh, 0.0L, -0x1.0000000000000002p0L, 4.656612873077392578082927418388212703712e-10L, -1.570796326794896619231321691639751442099L)
3846 TEST_c_c (casinh, -0.0L, 0x1.0000000000000002p0L, -4.656612873077392578082927418388212703712e-10L, 1.570796326794896619231321691639751442099L)
3847 TEST_c_c (casinh, -0.0L, -0x1.0000000000000002p0L, -4.656612873077392578082927418388212703712e-10L, -1.570796326794896619231321691639751442099L)
3848 TEST_c_c (casinh, 0x1.0000000000000002p0L, 0.0L, 8.813735870195430253092739958139610130980e-1L, 0.0L)
3849 TEST_c_c (casinh, -0x1.0000000000000002p0L, 0.0L, -8.813735870195430253092739958139610130980e-1L, 0.0L)
3850 TEST_c_c (casinh, 0x1.0000000000000002p0L, -0.0L, 8.813735870195430253092739958139610130980e-1L, -0.0L)
3851 TEST_c_c (casinh, -0x1.0000000000000002p0L, -0.0L, -8.813735870195430253092739958139610130980e-1L, -0.0L)
3852#endif
3853#if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 106
3854 TEST_c_c (casinh, 0x1p-106L, 0x1.000000000000000000000000008p0L, 2.285028863093221674154232933662774454211e-16L, 1.570796326794896565289107467733682961928L)
3855 TEST_c_c (casinh, 0x1p-106L, -0x1.000000000000000000000000008p0L, 2.285028863093221674154232933662774454211e-16L, -1.570796326794896565289107467733682961928L)
3856 TEST_c_c (casinh, -0x1p-106L, 0x1.000000000000000000000000008p0L, -2.285028863093221674154232933662774454211e-16L, 1.570796326794896565289107467733682961928L)
3857 TEST_c_c (casinh, -0x1p-106L, -0x1.000000000000000000000000008p0L, -2.285028863093221674154232933662774454211e-16L, -1.570796326794896565289107467733682961928L)
3858 TEST_c_c (casinh, 0x1.000000000000000000000000008p0L, 0x1p-106L, 8.813735870195430252326093249798097405561e-1L, 8.715763992105246878957416200936726072500e-33L)
3859 TEST_c_c (casinh, -0x1.000000000000000000000000008p0L, 0x1p-106L, -8.813735870195430252326093249798097405561e-1L, 8.715763992105246878957416200936726072500e-33L)
3860 TEST_c_c (casinh, 0x1.000000000000000000000000008p0L, -0x1p-106L, 8.813735870195430252326093249798097405561e-1L, -8.715763992105246878957416200936726072500e-33L)
3861 TEST_c_c (casinh, -0x1.000000000000000000000000008p0L, -0x1p-106L, -8.813735870195430252326093249798097405561e-1L, -8.715763992105246878957416200936726072500e-33L)
3862 TEST_c_c (casinh, 0x1.fp-1025L, 0x1.000000000000000000000000008p0L, 2.220446049250313080847263336181636063482e-16L, 1.570796326794896619231321691639751442099L)
3863 TEST_c_c (casinh, 0x1.fp-1025L, -0x1.000000000000000000000000008p0L, 2.220446049250313080847263336181636063482e-16L, -1.570796326794896619231321691639751442099L)
3864 TEST_c_c (casinh, -0x1.fp-1025L, 0x1.000000000000000000000000008p0L, -2.220446049250313080847263336181636063482e-16L, 1.570796326794896619231321691639751442099L)
3865 TEST_c_c (casinh, -0x1.fp-1025L, -0x1.000000000000000000000000008p0L, -2.220446049250313080847263336181636063482e-16L, -1.570796326794896619231321691639751442099L)
3866 TEST_c_c (casinh, 0x1.000000000000000000000000008p0L, 0x1.fp-1025L, 8.813735870195430252326093249798097405561e-1L, 3.810492908885321743133304375216570658278e-309L, UNDERFLOW_EXCEPTION_DOUBLE)
3867 TEST_c_c (casinh, -0x1.000000000000000000000000008p0L, 0x1.fp-1025L, -8.813735870195430252326093249798097405561e-1L, 3.810492908885321743133304375216570658278e-309L, UNDERFLOW_EXCEPTION_DOUBLE)
3868 TEST_c_c (casinh, 0x1.000000000000000000000000008p0L, -0x1.fp-1025L, 8.813735870195430252326093249798097405561e-1L, -3.810492908885321743133304375216570658278e-309L, UNDERFLOW_EXCEPTION_DOUBLE)
3869 TEST_c_c (casinh, -0x1.000000000000000000000000008p0L, -0x1.fp-1025L, -8.813735870195430252326093249798097405561e-1L, -3.810492908885321743133304375216570658278e-309L, UNDERFLOW_EXCEPTION_DOUBLE)
3870 TEST_c_c (casinh, 0.0L, 0x1.000000000000000000000000008p0L, 2.220446049250313080847263336181636063482e-16L, 1.570796326794896619231321691639751442099L)
3871 TEST_c_c (casinh, 0.0L, -0x1.000000000000000000000000008p0L, 2.220446049250313080847263336181636063482e-16L, -1.570796326794896619231321691639751442099L)
3872 TEST_c_c (casinh, -0.0L, 0x1.000000000000000000000000008p0L, -2.220446049250313080847263336181636063482e-16L, 1.570796326794896619231321691639751442099L)
3873 TEST_c_c (casinh, -0.0L, -0x1.000000000000000000000000008p0L, -2.220446049250313080847263336181636063482e-16L, -1.570796326794896619231321691639751442099L)
3874 TEST_c_c (casinh, 0x1.000000000000000000000000008p0L, 0.0L, 8.813735870195430252326093249798097405561e-1L, 0.0L)
3875 TEST_c_c (casinh, -0x1.000000000000000000000000008p0L, 0.0L, -8.813735870195430252326093249798097405561e-1L, 0.0L)
3876 TEST_c_c (casinh, 0x1.000000000000000000000000008p0L, -0.0L, 8.813735870195430252326093249798097405561e-1L, -0.0L)
3877 TEST_c_c (casinh, -0x1.000000000000000000000000008p0L, -0.0L, -8.813735870195430252326093249798097405561e-1L, -0.0L)
3878#endif
3879#if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 113
3880 TEST_c_c (casinh, 0x1p-113L, 0x1.0000000000000000000000000001p0L, 2.019699255375255198156433710951064632386e-17L, 1.570796326794896614463458507897073960405L)
3881 TEST_c_c (casinh, 0x1p-113L, -0x1.0000000000000000000000000001p0L, 2.019699255375255198156433710951064632386e-17L, -1.570796326794896614463458507897073960405L)
3882 TEST_c_c (casinh, -0x1p-113L, 0x1.0000000000000000000000000001p0L, -2.019699255375255198156433710951064632386e-17L, 1.570796326794896614463458507897073960405L)
3883 TEST_c_c (casinh, -0x1p-113L, -0x1.0000000000000000000000000001p0L, -2.019699255375255198156433710951064632386e-17L, -1.570796326794896614463458507897073960405L)
3884 TEST_c_c (casinh, 0x1.0000000000000000000000000001p0L, 0x1p-113L, 8.813735870195430252326093249797924452120e-1L, 6.809190618832224124185481406981900518193e-35L)
3885 TEST_c_c (casinh, -0x1.0000000000000000000000000001p0L, 0x1p-113L, -8.813735870195430252326093249797924452120e-1L, 6.809190618832224124185481406981900518193e-35L)
3886 TEST_c_c (casinh, 0x1.0000000000000000000000000001p0L, -0x1p-113L, 8.813735870195430252326093249797924452120e-1L, -6.809190618832224124185481406981900518193e-35L)
3887 TEST_c_c (casinh, -0x1.0000000000000000000000000001p0L, -0x1p-113L, -8.813735870195430252326093249797924452120e-1L, -6.809190618832224124185481406981900518193e-35L)
3888 TEST_c_c (casinh, 0x1.fp-16385L, 0x1.0000000000000000000000000001p0L, 1.962615573354718824241727964954454332780e-17L, 1.570796326794896619231321691639751442099L)
3889 TEST_c_c (casinh, 0x1.fp-16385L, -0x1.0000000000000000000000000001p0L, 1.962615573354718824241727964954454332780e-17L, -1.570796326794896619231321691639751442099L)
3890 TEST_c_c (casinh, -0x1.fp-16385L, 0x1.0000000000000000000000000001p0L, -1.962615573354718824241727964954454332780e-17L, 1.570796326794896619231321691639751442099L)
3891 TEST_c_c (casinh, -0x1.fp-16385L, -0x1.0000000000000000000000000001p0L, -1.962615573354718824241727964954454332780e-17L, -1.570796326794896619231321691639751442099L)
3892 TEST_c_c (casinh, 0x1.0000000000000000000000000001p0L, 0x1.fp-16385L, 8.813735870195430252326093249797924452120e-1L, 5.757683115456107044131264955348448400014e-4933L, UNDERFLOW_EXCEPTION)
3893 TEST_c_c (casinh, -0x1.0000000000000000000000000001p0L, 0x1.fp-16385L, -8.813735870195430252326093249797924452120e-1L, 5.757683115456107044131264955348448400014e-4933L, UNDERFLOW_EXCEPTION)
3894 TEST_c_c (casinh, 0x1.0000000000000000000000000001p0L, -0x1.fp-16385L, 8.813735870195430252326093249797924452120e-1L, -5.757683115456107044131264955348448400014e-4933L, UNDERFLOW_EXCEPTION)
3895 TEST_c_c (casinh, -0x1.0000000000000000000000000001p0L, -0x1.fp-16385L, -8.813735870195430252326093249797924452120e-1L, -5.757683115456107044131264955348448400014e-4933L, UNDERFLOW_EXCEPTION)
3896 TEST_c_c (casinh, 0.0L, 0x1.0000000000000000000000000001p0L, 1.962615573354718824241727964954454332780e-17L, 1.570796326794896619231321691639751442099L)
3897 TEST_c_c (casinh, 0.0L, -0x1.0000000000000000000000000001p0L, 1.962615573354718824241727964954454332780e-17L, -1.570796326794896619231321691639751442099L)
3898 TEST_c_c (casinh, -0.0L, 0x1.0000000000000000000000000001p0L, -1.962615573354718824241727964954454332780e-17L, 1.570796326794896619231321691639751442099L)
3899 TEST_c_c (casinh, -0.0L, -0x1.0000000000000000000000000001p0L, -1.962615573354718824241727964954454332780e-17L, -1.570796326794896619231321691639751442099L)
3900 TEST_c_c (casinh, 0x1.0000000000000000000000000001p0L, 0.0L, 8.813735870195430252326093249797924452120e-1L, 0.0L)
3901 TEST_c_c (casinh, -0x1.0000000000000000000000000001p0L, 0.0L, -8.813735870195430252326093249797924452120e-1L, 0.0L)
3902 TEST_c_c (casinh, 0x1.0000000000000000000000000001p0L, -0.0L, 8.813735870195430252326093249797924452120e-1L, -0.0L)
3903 TEST_c_c (casinh, -0x1.0000000000000000000000000001p0L, -0.0L, -8.813735870195430252326093249797924452120e-1L, -0.0L)
3904#endif
3905
ccc8cadf
JM
3906 TEST_c_c (casinh, 0x1p-23L, 0x0.ffffffp0L, 2.714321200917194650737217746780928423385e-4L, 1.570357140408705570520377172865353621698L);
3907 TEST_c_c (casinh, 0x1p-23L, -0x0.ffffffp0L, 2.714321200917194650737217746780928423385e-4L, -1.570357140408705570520377172865353621698L);
3908 TEST_c_c (casinh, -0x1p-23L, 0x0.ffffffp0L, -2.714321200917194650737217746780928423385e-4L, 1.570357140408705570520377172865353621698L);
3909 TEST_c_c (casinh, -0x1p-23L, -0x0.ffffffp0L, -2.714321200917194650737217746780928423385e-4L, -1.570357140408705570520377172865353621698L);
3910 TEST_c_c (casinh, 0x0.ffffffp0L, 0x1p-23L, 8.813735448726963984495965873956465777250e-1L, 8.429369953393598499000760938112968755257e-8L);
3911 TEST_c_c (casinh, -0x0.ffffffp0L, 0x1p-23L, -8.813735448726963984495965873956465777250e-1L, 8.429369953393598499000760938112968755257e-8L);
3912 TEST_c_c (casinh, 0x0.ffffffp0L, -0x1p-23L, 8.813735448726963984495965873956465777250e-1L, -8.429369953393598499000760938112968755257e-8L);
3913 TEST_c_c (casinh, -0x0.ffffffp0L, -0x1p-23L, -8.813735448726963984495965873956465777250e-1L, -8.429369953393598499000760938112968755257e-8L);
3914 TEST_c_c (casinh, 0x1.fp-129L, 0x0.ffffffp0L, 8.245504387859737323891843603996428534945e-36L, 1.570451059810180415643718442157112705601L);
3915 TEST_c_c (casinh, 0x1.fp-129L, -0x0.ffffffp0L, 8.245504387859737323891843603996428534945e-36L, -1.570451059810180415643718442157112705601L);
3916 TEST_c_c (casinh, -0x1.fp-129L, 0x0.ffffffp0L, -8.245504387859737323891843603996428534945e-36L, 1.570451059810180415643718442157112705601L);
3917 TEST_c_c (casinh, -0x1.fp-129L, -0x0.ffffffp0L, -8.245504387859737323891843603996428534945e-36L, -1.570451059810180415643718442157112705601L);
3918 TEST_c_c (casinh, 0x0.ffffffp0L, 0x1.fp-129L, 8.813735448726938863015878255140556727969e-1L, 2.013062624689288675911339929224634593425e-39L, UNDERFLOW_EXCEPTION_FLOAT);
3919 TEST_c_c (casinh, -0x0.ffffffp0L, 0x1.fp-129L, -8.813735448726938863015878255140556727969e-1L, 2.013062624689288675911339929224634593425e-39L, UNDERFLOW_EXCEPTION_FLOAT);
3920 TEST_c_c (casinh, 0x0.ffffffp0L, -0x1.fp-129L, 8.813735448726938863015878255140556727969e-1L, -2.013062624689288675911339929224634593425e-39L, UNDERFLOW_EXCEPTION_FLOAT);
3921 TEST_c_c (casinh, -0x0.ffffffp0L, -0x1.fp-129L, -8.813735448726938863015878255140556727969e-1L, -2.013062624689288675911339929224634593425e-39L, UNDERFLOW_EXCEPTION_FLOAT);
3922 TEST_c_c (casinh, 0.0L, 0x0.ffffffp0L, 0.0L, 1.570451059810180415643718442157112705601L);
3923 TEST_c_c (casinh, 0.0L, -0x0.ffffffp0L, 0.0L, -1.570451059810180415643718442157112705601L);
3924 TEST_c_c (casinh, -0.0L, 0x0.ffffffp0L, -0.0L, 1.570451059810180415643718442157112705601L);
3925 TEST_c_c (casinh, -0.0L, -0x0.ffffffp0L, -0.0L, -1.570451059810180415643718442157112705601L);
3926 TEST_c_c (casinh, 0x0.ffffffp0L, 0.0L, 8.813735448726938863015878255140556727969e-1L, 0.0L);
3927 TEST_c_c (casinh, -0x0.ffffffp0L, 0.0L, -8.813735448726938863015878255140556727969e-1L, 0.0L);
3928 TEST_c_c (casinh, 0x0.ffffffp0L, -0.0L, 8.813735448726938863015878255140556727969e-1L, -0.0L);
3929 TEST_c_c (casinh, -0x0.ffffffp0L, -0.0L, -8.813735448726938863015878255140556727969e-1L, -0.0L);
3930 TEST_c_c (casinh, 0x1p-23L, 0.5L, 1.376510308240943236356088341381173571841e-7L, 5.235987755982934033165770729745469098254e-1L);
3931 TEST_c_c (casinh, 0x1p-23L, -0.5L, 1.376510308240943236356088341381173571841e-7L, -5.235987755982934033165770729745469098254e-1L);
3932 TEST_c_c (casinh, -0x1p-23L, 0.5L, -1.376510308240943236356088341381173571841e-7L, 5.235987755982934033165770729745469098254e-1L);
3933 TEST_c_c (casinh, -0x1p-23L, -0.5L, -1.376510308240943236356088341381173571841e-7L, -5.235987755982934033165770729745469098254e-1L);
3934 TEST_c_c (casinh, 0.5L, 0x1p-23L, 4.812118250596059896127318386463676808798e-1L, 1.066240299940009780479664302917201696886e-7L);
3935 TEST_c_c (casinh, -0.5L, 0x1p-23L, -4.812118250596059896127318386463676808798e-1L, 1.066240299940009780479664302917201696886e-7L);
3936 TEST_c_c (casinh, 0.5L, -0x1p-23L, 4.812118250596059896127318386463676808798e-1L, -1.066240299940009780479664302917201696886e-7L);
3937 TEST_c_c (casinh, -0.5L, -0x1p-23L, -4.812118250596059896127318386463676808798e-1L, -1.066240299940009780479664302917201696886e-7L);
3938 TEST_c_c (casinh, 0x1.fp-129L, 0.5L, 3.287317402534702257036015056278368274737e-39L, 5.235987755982988730771072305465838140329e-1L, UNDERFLOW_EXCEPTION_FLOAT);
3939 TEST_c_c (casinh, 0x1.fp-129L, -0.5L, 3.287317402534702257036015056278368274737e-39L, -5.235987755982988730771072305465838140329e-1L, UNDERFLOW_EXCEPTION_FLOAT);
3940 TEST_c_c (casinh, -0x1.fp-129L, 0.5L, -3.287317402534702257036015056278368274737e-39L, 5.235987755982988730771072305465838140329e-1L, UNDERFLOW_EXCEPTION_FLOAT);
3941 TEST_c_c (casinh, -0x1.fp-129L, -0.5L, -3.287317402534702257036015056278368274737e-39L, -5.235987755982988730771072305465838140329e-1L, UNDERFLOW_EXCEPTION_FLOAT);
3942 TEST_c_c (casinh, 0.5L, 0x1.fp-129L, 4.812118250596034474977589134243684231352e-1L, 2.546345110742945032959687790021055102355e-39L, UNDERFLOW_EXCEPTION_FLOAT);
3943 TEST_c_c (casinh, -0.5L, 0x1.fp-129L, -4.812118250596034474977589134243684231352e-1L, 2.546345110742945032959687790021055102355e-39L, UNDERFLOW_EXCEPTION_FLOAT);
3944 TEST_c_c (casinh, 0.5L, -0x1.fp-129L, 4.812118250596034474977589134243684231352e-1L, -2.546345110742945032959687790021055102355e-39L, UNDERFLOW_EXCEPTION_FLOAT);
3945 TEST_c_c (casinh, -0.5L, -0x1.fp-129L, -4.812118250596034474977589134243684231352e-1L, -2.546345110742945032959687790021055102355e-39L, UNDERFLOW_EXCEPTION_FLOAT);
3946 TEST_c_c (casinh, 0x1p-23L, 0x1p-23L, 1.192092895507818146886315028596704749235e-7L, 1.192092895507806853113684971258850504935e-7L);
3947 TEST_c_c (casinh, 0x1p-23L, -0x1p-23L, 1.192092895507818146886315028596704749235e-7L, -1.192092895507806853113684971258850504935e-7L);
3948 TEST_c_c (casinh, -0x1p-23L, 0x1p-23L, -1.192092895507818146886315028596704749235e-7L, 1.192092895507806853113684971258850504935e-7L);
3949 TEST_c_c (casinh, -0x1p-23L, -0x1p-23L, -1.192092895507818146886315028596704749235e-7L, -1.192092895507806853113684971258850504935e-7L);
3950 TEST_c_c (casinh, 0x1.fp-129L, 0x1p-23L, 2.846900380897747786805634596726756660388e-39L, 1.192092895507815323443157514352519154304e-7L, UNDERFLOW_EXCEPTION_FLOAT);
3951 TEST_c_c (casinh, 0x1.fp-129L, -0x1p-23L, 2.846900380897747786805634596726756660388e-39L, -1.192092895507815323443157514352519154304e-7L, UNDERFLOW_EXCEPTION_FLOAT);
3952 TEST_c_c (casinh, -0x1.fp-129L, 0x1p-23L, -2.846900380897747786805634596726756660388e-39L, 1.192092895507815323443157514352519154304e-7L, UNDERFLOW_EXCEPTION_FLOAT);
3953 TEST_c_c (casinh, -0x1.fp-129L, -0x1p-23L, -2.846900380897747786805634596726756660388e-39L, -1.192092895507815323443157514352519154304e-7L, UNDERFLOW_EXCEPTION_FLOAT);
3954 /* Bug 15319: underflow exception may be missing. */
3955 TEST_c_c (casinh, 0x1p-23L, 0x1.fp-129L, 1.192092895507809676556842485683592032154e-7L, 2.846900380897707329917933005874691056564e-39L, UNDERFLOW_EXCEPTION_OK_FLOAT);
3956 TEST_c_c (casinh, -0x1p-23L, 0x1.fp-129L, -1.192092895507809676556842485683592032154e-7L, 2.846900380897707329917933005874691056564e-39L, UNDERFLOW_EXCEPTION_OK_FLOAT);
3957 TEST_c_c (casinh, 0x1p-23L, -0x1.fp-129L, 1.192092895507809676556842485683592032154e-7L, -2.846900380897707329917933005874691056564e-39L, UNDERFLOW_EXCEPTION_OK_FLOAT);
3958 TEST_c_c (casinh, -0x1p-23L, -0x1.fp-129L, -1.192092895507809676556842485683592032154e-7L, -2.846900380897707329917933005874691056564e-39L, UNDERFLOW_EXCEPTION_OK_FLOAT);
3959 TEST_c_c (casinh, 0.0L, 0x1p-23L, 0.0L, 1.192092895507815323443157514352519154304e-7L);
3960 TEST_c_c (casinh, 0.0L, -0x1p-23L, 0.0L, -1.192092895507815323443157514352519154304e-7L);
3961 TEST_c_c (casinh, -0.0L, 0x1p-23L, -0.0L, 1.192092895507815323443157514352519154304e-7L);
3962 TEST_c_c (casinh, -0.0L, -0x1p-23L, -0.0L, -1.192092895507815323443157514352519154304e-7L);
3963 TEST_c_c (casinh, 0x1p-23L, 0.0L, 1.192092895507809676556842485683592032154e-7L, 0.0L);
3964 TEST_c_c (casinh, -0x1p-23L, 0.0L, -1.192092895507809676556842485683592032154e-7L, 0.0L);
3965 TEST_c_c (casinh, 0x1p-23L, -0.0L, 1.192092895507809676556842485683592032154e-7L, -0.0L);
3966 TEST_c_c (casinh, -0x1p-23L, -0.0L, -1.192092895507809676556842485683592032154e-7L, -0.0L);
3967 TEST_c_c (casinh, 0x1.fp-129L, 0x1.fp-129L, 2.846900380897727558361783801085126250967e-39L, 2.846900380897727558361783801085126250967e-39L, UNDERFLOW_EXCEPTION_FLOAT);
3968 TEST_c_c (casinh, 0x1.fp-129L, -0x1.fp-129L, 2.846900380897727558361783801085126250967e-39L, -2.846900380897727558361783801085126250967e-39L, UNDERFLOW_EXCEPTION_FLOAT);
3969 TEST_c_c (casinh, -0x1.fp-129L, 0x1.fp-129L, -2.846900380897727558361783801085126250967e-39L, 2.846900380897727558361783801085126250967e-39L, UNDERFLOW_EXCEPTION_FLOAT);
3970 TEST_c_c (casinh, -0x1.fp-129L, -0x1.fp-129L, -2.846900380897727558361783801085126250967e-39L, -2.846900380897727558361783801085126250967e-39L, UNDERFLOW_EXCEPTION_FLOAT);
3971#ifndef TEST_FLOAT
3972 TEST_c_c (casinh, 0x1p-52L, 0x0.fffffffffffff8p0L, 1.171456840272878582596796205397918831268e-8L, 1.570796307840326780080580569360500172043L);
3973 TEST_c_c (casinh, 0x1p-52L, -0x0.fffffffffffff8p0L, 1.171456840272878582596796205397918831268e-8L, -1.570796307840326780080580569360500172043L);
3974 TEST_c_c (casinh, -0x1p-52L, 0x0.fffffffffffff8p0L, -1.171456840272878582596796205397918831268e-8L, 1.570796307840326780080580569360500172043L);
3975 TEST_c_c (casinh, -0x1p-52L, -0x0.fffffffffffff8p0L, -1.171456840272878582596796205397918831268e-8L, -1.570796307840326780080580569360500172043L);
3976 TEST_c_c (casinh, 0x0.fffffffffffff8p0L, 0x1p-52L, 8.813735870195429467279863907910458761820e-1L, 1.570092458683775146551022293016031474627e-16L);
3977 TEST_c_c (casinh, -0x0.fffffffffffff8p0L, 0x1p-52L, -8.813735870195429467279863907910458761820e-1L, 1.570092458683775146551022293016031474627e-16L);
3978 TEST_c_c (casinh, 0x0.fffffffffffff8p0L, -0x1p-52L, 8.813735870195429467279863907910458761820e-1L, -1.570092458683775146551022293016031474627e-16L);
3979 TEST_c_c (casinh, -0x0.fffffffffffff8p0L, -0x1p-52L, -8.813735870195429467279863907910458761820e-1L, -1.570092458683775146551022293016031474627e-16L);
3980 TEST_c_c (casinh, 0x1.fp-1025L, 0x0.fffffffffffff8p0L, 3.616396521699973256461764099945789620604e-301L, 1.570796311893735425383665303776316016594L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM);
3981 TEST_c_c (casinh, 0x1.fp-1025L, -0x0.fffffffffffff8p0L, 3.616396521699973256461764099945789620604e-301L, -1.570796311893735425383665303776316016594L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM);
3982 TEST_c_c (casinh, -0x1.fp-1025L, 0x0.fffffffffffff8p0L, -3.616396521699973256461764099945789620604e-301L, 1.570796311893735425383665303776316016594L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM);
3983 TEST_c_c (casinh, -0x1.fp-1025L, -0x0.fffffffffffff8p0L, -3.616396521699973256461764099945789620604e-301L, -1.570796311893735425383665303776316016594L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM);
3984 TEST_c_c (casinh, 0x0.fffffffffffff8p0L, 0x1.fp-1025L, 8.813735870195429467279863907910371604180e-1L, 3.810492908885321954658152505985270452320e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
3985 TEST_c_c (casinh, -0x0.fffffffffffff8p0L, 0x1.fp-1025L, -8.813735870195429467279863907910371604180e-1L, 3.810492908885321954658152505985270452320e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
3986 TEST_c_c (casinh, 0x0.fffffffffffff8p0L, -0x1.fp-1025L, 8.813735870195429467279863907910371604180e-1L, -3.810492908885321954658152505985270452320e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
3987 TEST_c_c (casinh, -0x0.fffffffffffff8p0L, -0x1.fp-1025L, -8.813735870195429467279863907910371604180e-1L, -3.810492908885321954658152505985270452320e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
3988 TEST_c_c (casinh, 0.0L, 0x0.fffffffffffff8p0L, 0.0L, 1.570796311893735425383665303776316016594L);
3989 TEST_c_c (casinh, 0.0L, -0x0.fffffffffffff8p0L, 0.0L, -1.570796311893735425383665303776316016594L);
3990 TEST_c_c (casinh, -0.0L, 0x0.fffffffffffff8p0L, -0.0L, 1.570796311893735425383665303776316016594L);
3991 TEST_c_c (casinh, -0.0L, -0x0.fffffffffffff8p0L, -0.0L, -1.570796311893735425383665303776316016594L);
3992 TEST_c_c (casinh, 0x0.fffffffffffff8p0L, 0.0L, 8.813735870195429467279863907910371604180e-1L, 0.0L);
3993 TEST_c_c (casinh, -0x0.fffffffffffff8p0L, 0.0L, -8.813735870195429467279863907910371604180e-1L, 0.0L);
3994 TEST_c_c (casinh, 0x0.fffffffffffff8p0L, -0.0L, 8.813735870195429467279863907910371604180e-1L, -0.0L);
3995 TEST_c_c (casinh, -0x0.fffffffffffff8p0L, -0.0L, -8.813735870195429467279863907910371604180e-1L, -0.0L);
3996#endif
3997 TEST_c_c (casinh, 0x1p-52L, 0.5L, 2.563950248511418570403591756798643804971e-16L, 5.235987755982988730771072305465648369889e-1L);
3998 TEST_c_c (casinh, 0x1p-52L, -0.5L, 2.563950248511418570403591756798643804971e-16L, -5.235987755982988730771072305465648369889e-1L);
3999 TEST_c_c (casinh, -0x1p-52L, 0.5L, -2.563950248511418570403591756798643804971e-16L, 5.235987755982988730771072305465648369889e-1L);
4000 TEST_c_c (casinh, -0x1p-52L, -0.5L, -2.563950248511418570403591756798643804971e-16L, -5.235987755982988730771072305465648369889e-1L);
4001 TEST_c_c (casinh, 0.5L, 0x1p-52L, 4.812118250596034474977589134243772428682e-1L, 1.986027322597818397661816253158024383707e-16L);
4002 TEST_c_c (casinh, -0.5L, 0x1p-52L, -4.812118250596034474977589134243772428682e-1L, 1.986027322597818397661816253158024383707e-16L);
4003 TEST_c_c (casinh, 0.5L, -0x1p-52L, 4.812118250596034474977589134243772428682e-1L, -1.986027322597818397661816253158024383707e-16L);
4004 TEST_c_c (casinh, -0.5L, -0x1p-52L, -4.812118250596034474977589134243772428682e-1L, -1.986027322597818397661816253158024383707e-16L);
4005#ifndef TEST_FLOAT
4006 TEST_c_c (casinh, 0x1.fp-1025L, 0.5L, 6.222508863508420569166420770843207333493e-309L, 5.235987755982988730771072305465838140329e-1L, UNDERFLOW_EXCEPTION_DOUBLE);
4007 TEST_c_c (casinh, 0x1.fp-1025L, -0.5L, 6.222508863508420569166420770843207333493e-309L, -5.235987755982988730771072305465838140329e-1L, UNDERFLOW_EXCEPTION_DOUBLE);
4008 TEST_c_c (casinh, -0x1.fp-1025L, 0.5L, -6.222508863508420569166420770843207333493e-309L, 5.235987755982988730771072305465838140329e-1L, UNDERFLOW_EXCEPTION_DOUBLE);
4009 TEST_c_c (casinh, -0x1.fp-1025L, -0.5L, -6.222508863508420569166420770843207333493e-309L, -5.235987755982988730771072305465838140329e-1L, UNDERFLOW_EXCEPTION_DOUBLE);
4010 TEST_c_c (casinh, 0.5L, 0x1.fp-1025L, 4.812118250596034474977589134243684231352e-1L, 4.819934639999230680322935210539402497827e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
4011 TEST_c_c (casinh, -0.5L, 0x1.fp-1025L, -4.812118250596034474977589134243684231352e-1L, 4.819934639999230680322935210539402497827e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
4012 TEST_c_c (casinh, 0.5L, -0x1.fp-1025L, 4.812118250596034474977589134243684231352e-1L, -4.819934639999230680322935210539402497827e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
4013 TEST_c_c (casinh, -0.5L, -0x1.fp-1025L, -4.812118250596034474977589134243684231352e-1L, -4.819934639999230680322935210539402497827e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
4014#endif
4015 TEST_c_c (casinh, 0x1p-52L, 0x1p-52L, 2.220446049250313080847263336181677117148e-16L, 2.220446049250313080847263336181604132852e-16L);
4016 TEST_c_c (casinh, 0x1p-52L, -0x1p-52L, 2.220446049250313080847263336181677117148e-16L, -2.220446049250313080847263336181604132852e-16L);
4017 TEST_c_c (casinh, -0x1p-52L, 0x1p-52L, -2.220446049250313080847263336181677117148e-16L, 2.220446049250313080847263336181604132852e-16L);
4018 TEST_c_c (casinh, -0x1p-52L, -0x1p-52L, -2.220446049250313080847263336181677117148e-16L, -2.220446049250313080847263336181604132852e-16L);
4019#ifndef TEST_FLOAT
4020 TEST_c_c (casinh, 0x1.fp-1025L, 0x1p-52L, 5.388850751072128349671657362289548938458e-309L, 2.220446049250313080847263336181658871074e-16L, UNDERFLOW_EXCEPTION_DOUBLE);
4021 TEST_c_c (casinh, 0x1.fp-1025L, -0x1p-52L, 5.388850751072128349671657362289548938458e-309L, -2.220446049250313080847263336181658871074e-16L, UNDERFLOW_EXCEPTION_DOUBLE);
4022 TEST_c_c (casinh, -0x1.fp-1025L, 0x1p-52L, -5.388850751072128349671657362289548938458e-309L, 2.220446049250313080847263336181658871074e-16L, UNDERFLOW_EXCEPTION_DOUBLE);
4023 TEST_c_c (casinh, -0x1.fp-1025L, -0x1p-52L, -5.388850751072128349671657362289548938458e-309L, -2.220446049250313080847263336181658871074e-16L, UNDERFLOW_EXCEPTION_DOUBLE);
4024 /* Bug 15319: underflow exception may be missing. */
4025 TEST_c_c (casinh, 0x1p-52L, 0x1.fp-1025L, 2.220446049250313080847263336181622378926e-16L, 5.388850751072128349671657362289283247603e-309L, UNDERFLOW_EXCEPTION_OK_DOUBLE);
4026 TEST_c_c (casinh, -0x1p-52L, 0x1.fp-1025L, -2.220446049250313080847263336181622378926e-16L, 5.388850751072128349671657362289283247603e-309L, UNDERFLOW_EXCEPTION_OK_DOUBLE);
4027 TEST_c_c (casinh, 0x1p-52L, -0x1.fp-1025L, 2.220446049250313080847263336181622378926e-16L, -5.388850751072128349671657362289283247603e-309L, UNDERFLOW_EXCEPTION_OK_DOUBLE);
4028 TEST_c_c (casinh, -0x1p-52L, -0x1.fp-1025L, -2.220446049250313080847263336181622378926e-16L, -5.388850751072128349671657362289283247603e-309L, UNDERFLOW_EXCEPTION_OK_DOUBLE);
4029#endif
4030 TEST_c_c (casinh, 0.0L, 0x1p-52L, 0.0L, 2.220446049250313080847263336181658871074e-16L);
4031 TEST_c_c (casinh, 0.0L, -0x1p-52L, 0.0L, -2.220446049250313080847263336181658871074e-16L);
4032 TEST_c_c (casinh, -0.0L, 0x1p-52L, -0.0L, 2.220446049250313080847263336181658871074e-16L);
4033 TEST_c_c (casinh, -0.0L, -0x1p-52L, -0.0L, -2.220446049250313080847263336181658871074e-16L);
4034 TEST_c_c (casinh, 0x1p-52L, 0.0L, 2.220446049250313080847263336181622378926e-16L, 0.0L);
4035 TEST_c_c (casinh, -0x1p-52L, 0.0L, -2.220446049250313080847263336181622378926e-16L, 0.0L);
4036 TEST_c_c (casinh, 0x1p-52L, -0.0L, 2.220446049250313080847263336181622378926e-16L, -0.0L);
4037 TEST_c_c (casinh, -0x1p-52L, -0.0L, -2.220446049250313080847263336181622378926e-16L, -0.0L);
4038#ifndef TEST_FLOAT
4039 TEST_c_c (casinh, 0x1.fp-1025L, 0x1.fp-1025L, 5.388850751072128349671657362289416093031e-309L, 5.388850751072128349671657362289416093031e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
4040 TEST_c_c (casinh, 0x1.fp-1025L, -0x1.fp-1025L, 5.388850751072128349671657362289416093031e-309L, -5.388850751072128349671657362289416093031e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
4041 TEST_c_c (casinh, -0x1.fp-1025L, 0x1.fp-1025L, -5.388850751072128349671657362289416093031e-309L, 5.388850751072128349671657362289416093031e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
4042 TEST_c_c (casinh, -0x1.fp-1025L, -0x1.fp-1025L, -5.388850751072128349671657362289416093031e-309L, -5.388850751072128349671657362289416093031e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
4043#endif
4044#if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 64
4045 TEST_c_c (casinh, 0x1p-63L, 0x0.ffffffffffffffffp0L, 2.588578361325995866221775673638805081337e-10L, 1.570796326376055842114524927965556247908L);
4046 TEST_c_c (casinh, 0x1p-63L, -0x0.ffffffffffffffffp0L, 2.588578361325995866221775673638805081337e-10L, -1.570796326376055842114524927965556247908L);
4047 TEST_c_c (casinh, -0x1p-63L, 0x0.ffffffffffffffffp0L, -2.588578361325995866221775673638805081337e-10L, 1.570796326376055842114524927965556247908L);
4048 TEST_c_c (casinh, -0x1p-63L, -0x0.ffffffffffffffffp0L, -2.588578361325995866221775673638805081337e-10L, -1.570796326376055842114524927965556247908L);
4049 TEST_c_c (casinh, 0x0.ffffffffffffffffp0L, 0x1p-63L, 8.813735870195430251942769895627079569937e-1L, 7.666467083416870407402049869781566856442e-20L);
4050 TEST_c_c (casinh, -0x0.ffffffffffffffffp0L, 0x1p-63L, -8.813735870195430251942769895627079569937e-1L, 7.666467083416870407402049869781566856442e-20L);
4051 TEST_c_c (casinh, 0x0.ffffffffffffffffp0L, -0x1p-63L, 8.813735870195430251942769895627079569937e-1L, -7.666467083416870407402049869781566856442e-20L);
4052 TEST_c_c (casinh, -0x0.ffffffffffffffffp0L, -0x1p-63L, -8.813735870195430251942769895627079569937e-1L, -7.666467083416870407402049869781566856442e-20L);
4053# if LDBL_MIN_EXP <= -16381
4054 TEST_c_c (casinh, 0x1.fp-16385L, 0x0.ffffffffffffffffp0L, 2.472906068161537187835415298076415423459e-4923L, 1.570796326465624365239962068302568888898L);
4055 TEST_c_c (casinh, 0x1.fp-16385L, -0x0.ffffffffffffffffp0L, 2.472906068161537187835415298076415423459e-4923L, -1.570796326465624365239962068302568888898L);
4056 TEST_c_c (casinh, -0x1.fp-16385L, 0x0.ffffffffffffffffp0L, -2.472906068161537187835415298076415423459e-4923L, 1.570796326465624365239962068302568888898L);
4057 TEST_c_c (casinh, -0x1.fp-16385L, -0x0.ffffffffffffffffp0L, -2.472906068161537187835415298076415423459e-4923L, -1.570796326465624365239962068302568888898L);
4058 TEST_c_c (casinh, 0x0.ffffffffffffffffp0L, 0x1.fp-16385L, 8.813735870195430251942769895627079569917e-1L, 5.757683115456107044287327268904964422212e-4933L, UNDERFLOW_EXCEPTION);
4059 TEST_c_c (casinh, -0x0.ffffffffffffffffp0L, 0x1.fp-16385L, -8.813735870195430251942769895627079569917e-1L, 5.757683115456107044287327268904964422212e-4933L, UNDERFLOW_EXCEPTION);
4060 TEST_c_c (casinh, 0x0.ffffffffffffffffp0L, -0x1.fp-16385L, 8.813735870195430251942769895627079569917e-1L, -5.757683115456107044287327268904964422212e-4933L, UNDERFLOW_EXCEPTION);
4061 TEST_c_c (casinh, -0x0.ffffffffffffffffp0L, -0x1.fp-16385L, -8.813735870195430251942769895627079569917e-1L, -5.757683115456107044287327268904964422212e-4933L, UNDERFLOW_EXCEPTION);
4062# endif
4063 TEST_c_c (casinh, 0.0L, 0x0.ffffffffffffffffp0L, 0.0L, 1.570796326465624365239962068302568888898L);
4064 TEST_c_c (casinh, 0.0L, -0x0.ffffffffffffffffp0L, 0.0L, -1.570796326465624365239962068302568888898L);
4065 TEST_c_c (casinh, -0.0L, 0x0.ffffffffffffffffp0L, -0.0L, 1.570796326465624365239962068302568888898L);
4066 TEST_c_c (casinh, -0.0L, -0x0.ffffffffffffffffp0L, -0.0L, -1.570796326465624365239962068302568888898L);
4067 TEST_c_c (casinh, 0x0.ffffffffffffffffp0L, 0.0L, 8.813735870195430251942769895627079569917e-1L, 0.0L);
4068 TEST_c_c (casinh, -0x0.ffffffffffffffffp0L, 0.0L, -8.813735870195430251942769895627079569917e-1L, 0.0L);
4069 TEST_c_c (casinh, 0x0.ffffffffffffffffp0L, -0.0L, 8.813735870195430251942769895627079569917e-1L, -0.0L);
4070 TEST_c_c (casinh, -0x0.ffffffffffffffffp0L, -0.0L, -8.813735870195430251942769895627079569917e-1L, -0.0L);
4071#endif
4072 TEST_c_c (casinh, 0x1p-63L, 0.5L, 1.251928832280966098829878787499365228659e-19L, 5.235987755982988730771072305465838140283e-1L);
4073 TEST_c_c (casinh, 0x1p-63L, -0.5L, 1.251928832280966098829878787499365228659e-19L, -5.235987755982988730771072305465838140283e-1L);
4074 TEST_c_c (casinh, -0x1p-63L, 0.5L, -1.251928832280966098829878787499365228659e-19L, 5.235987755982988730771072305465838140283e-1L);
4075 TEST_c_c (casinh, -0x1p-63L, -0.5L, -1.251928832280966098829878787499365228659e-19L, -5.235987755982988730771072305465838140283e-1L);
4076 TEST_c_c (casinh, 0.5L, 0x1p-63L, 4.812118250596034474977589134243684231373e-1L, 9.697399036122160144833087173623140436413e-20L);
4077 TEST_c_c (casinh, -0.5L, 0x1p-63L, -4.812118250596034474977589134243684231373e-1L, 9.697399036122160144833087173623140436413e-20L);
4078 TEST_c_c (casinh, 0.5L, -0x1p-63L, 4.812118250596034474977589134243684231373e-1L, -9.697399036122160144833087173623140436413e-20L);
4079 TEST_c_c (casinh, -0.5L, -0x1p-63L, -4.812118250596034474977589134243684231373e-1L, -9.697399036122160144833087173623140436413e-20L);
4080#if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
4081 TEST_c_c (casinh, 0x1.fp-16385L, 0.5L, 9.402257155670418112159334875199821342890e-4933L, 5.235987755982988730771072305465838140329e-1L, UNDERFLOW_EXCEPTION);
4082 TEST_c_c (casinh, 0x1.fp-16385L, -0.5L, 9.402257155670418112159334875199821342890e-4933L, -5.235987755982988730771072305465838140329e-1L, UNDERFLOW_EXCEPTION);
4083 TEST_c_c (casinh, -0x1.fp-16385L, 0.5L, -9.402257155670418112159334875199821342890e-4933L, 5.235987755982988730771072305465838140329e-1L, UNDERFLOW_EXCEPTION);
4084 TEST_c_c (casinh, -0x1.fp-16385L, -0.5L, -9.402257155670418112159334875199821342890e-4933L, -5.235987755982988730771072305465838140329e-1L, UNDERFLOW_EXCEPTION);
4085 TEST_c_c (casinh, 0.5L, 0x1.fp-16385L, 4.812118250596034474977589134243684231352e-1L, 7.282957076134209141226696333885150260319e-4933L, UNDERFLOW_EXCEPTION);
4086 TEST_c_c (casinh, -0.5L, 0x1.fp-16385L, -4.812118250596034474977589134243684231352e-1L, 7.282957076134209141226696333885150260319e-4933L, UNDERFLOW_EXCEPTION);
4087 TEST_c_c (casinh, 0.5L, -0x1.fp-16385L, 4.812118250596034474977589134243684231352e-1L, -7.282957076134209141226696333885150260319e-4933L, UNDERFLOW_EXCEPTION);
4088 TEST_c_c (casinh, -0.5L, -0x1.fp-16385L, -4.812118250596034474977589134243684231352e-1L, -7.282957076134209141226696333885150260319e-4933L, UNDERFLOW_EXCEPTION);
4089#endif
4090 TEST_c_c (casinh, 0x1p-63L, 0x1p-63L, 1.084202172485504434007452800869941711430e-19L, 1.084202172485504434007452800869941711422e-19L);
4091 TEST_c_c (casinh, 0x1p-63L, -0x1p-63L, 1.084202172485504434007452800869941711430e-19L, -1.084202172485504434007452800869941711422e-19L);
4092 TEST_c_c (casinh, -0x1p-63L, 0x1p-63L, -1.084202172485504434007452800869941711430e-19L, 1.084202172485504434007452800869941711422e-19L);
4093 TEST_c_c (casinh, -0x1p-63L, -0x1p-63L, -1.084202172485504434007452800869941711430e-19L, -1.084202172485504434007452800869941711422e-19L);
4094#if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
4095 TEST_c_c (casinh, 0x1.fp-16385L, 0x1p-63L, 8.142593549724601460479922838826119584465e-4933L, 1.084202172485504434007452800869941711428e-19L, UNDERFLOW_EXCEPTION);
4096 TEST_c_c (casinh, 0x1.fp-16385L, -0x1p-63L, 8.142593549724601460479922838826119584465e-4933L, -1.084202172485504434007452800869941711428e-19L, UNDERFLOW_EXCEPTION);
4097 TEST_c_c (casinh, -0x1.fp-16385L, 0x1p-63L, -8.142593549724601460479922838826119584465e-4933L, 1.084202172485504434007452800869941711428e-19L, UNDERFLOW_EXCEPTION);
4098 TEST_c_c (casinh, -0x1.fp-16385L, -0x1p-63L, -8.142593549724601460479922838826119584465e-4933L, -1.084202172485504434007452800869941711428e-19L, UNDERFLOW_EXCEPTION);
4099 TEST_c_c (casinh, 0x1p-63L, 0x1.fp-16385L, 1.084202172485504434007452800869941711424e-19L, 8.142593549724601460479922838826119584369e-4933L, UNDERFLOW_EXCEPTION);
4100 TEST_c_c (casinh, -0x1p-63L, 0x1.fp-16385L, -1.084202172485504434007452800869941711424e-19L, 8.142593549724601460479922838826119584369e-4933L, UNDERFLOW_EXCEPTION);
4101 TEST_c_c (casinh, 0x1p-63L, -0x1.fp-16385L, 1.084202172485504434007452800869941711424e-19L, -8.142593549724601460479922838826119584369e-4933L, UNDERFLOW_EXCEPTION);
4102 TEST_c_c (casinh, -0x1p-63L, -0x1.fp-16385L, -1.084202172485504434007452800869941711424e-19L, -8.142593549724601460479922838826119584369e-4933L, UNDERFLOW_EXCEPTION);
4103#endif
4104 TEST_c_c (casinh, 0.0L, 0x1p-63L, 0.0L, 1.084202172485504434007452800869941711428e-19L);
4105 TEST_c_c (casinh, 0.0L, -0x1p-63L, 0.0L, -1.084202172485504434007452800869941711428e-19L);
4106 TEST_c_c (casinh, -0.0L, 0x1p-63L, -0.0L, 1.084202172485504434007452800869941711428e-19L);
4107 TEST_c_c (casinh, -0.0L, -0x1p-63L, -0.0L, -1.084202172485504434007452800869941711428e-19L);
4108 TEST_c_c (casinh, 0x1p-63L, 0.0L, 1.084202172485504434007452800869941711424e-19L, 0.0L);
4109 TEST_c_c (casinh, -0x1p-63L, 0.0L, -1.084202172485504434007452800869941711424e-19L, 0.0L);
4110 TEST_c_c (casinh, 0x1p-63L, -0.0L, 1.084202172485504434007452800869941711424e-19L, -0.0L);
4111 TEST_c_c (casinh, -0x1p-63L, -0.0L, -1.084202172485504434007452800869941711424e-19L, -0.0L);
4112#if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
4113 TEST_c_c (casinh, 0x1.fp-16385L, 0x1.fp-16385L, 8.142593549724601460479922838826119584417e-4933L, 8.142593549724601460479922838826119584417e-4933L, UNDERFLOW_EXCEPTION);
4114 TEST_c_c (casinh, 0x1.fp-16385L, -0x1.fp-16385L, 8.142593549724601460479922838826119584417e-4933L, -8.142593549724601460479922838826119584417e-4933L, UNDERFLOW_EXCEPTION);
4115 TEST_c_c (casinh, -0x1.fp-16385L, 0x1.fp-16385L, -8.142593549724601460479922838826119584417e-4933L, 8.142593549724601460479922838826119584417e-4933L, UNDERFLOW_EXCEPTION);
4116 TEST_c_c (casinh, -0x1.fp-16385L, -0x1.fp-16385L, -8.142593549724601460479922838826119584417e-4933L, -8.142593549724601460479922838826119584417e-4933L, UNDERFLOW_EXCEPTION);
4117#endif
4118#if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 106
4119 TEST_c_c (casinh, 0x1p-105L, 0x0.ffffffffffffffffffffffffffcp0L, 1.234330349600789959989661887846005659983e-16L, 1.570796326794896419512475791677915736035L);
4120 TEST_c_c (casinh, 0x1p-105L, -0x0.ffffffffffffffffffffffffffcp0L, 1.234330349600789959989661887846005659983e-16L, -1.570796326794896419512475791677915736035L);
4121 TEST_c_c (casinh, -0x1p-105L, 0x0.ffffffffffffffffffffffffffcp0L, -1.234330349600789959989661887846005659983e-16L, 1.570796326794896419512475791677915736035L);
4122 TEST_c_c (casinh, -0x1p-105L, -0x0.ffffffffffffffffffffffffffcp0L, -1.234330349600789959989661887846005659983e-16L, -1.570796326794896419512475791677915736035L);
4123 TEST_c_c (casinh, 0x0.ffffffffffffffffffffffffffcp0L, 0x1p-105L, 8.813735870195430252326093249797835932642e-1L, 1.743152798421049375791483240187377443526e-32L);
4124 TEST_c_c (casinh, -0x0.ffffffffffffffffffffffffffcp0L, 0x1p-105L, -8.813735870195430252326093249797835932642e-1L, 1.743152798421049375791483240187377443526e-32L);
4125 TEST_c_c (casinh, 0x0.ffffffffffffffffffffffffffcp0L, -0x1p-105L, 8.813735870195430252326093249797835932642e-1L, -1.743152798421049375791483240187377443526e-32L);
4126 TEST_c_c (casinh, -0x0.ffffffffffffffffffffffffffcp0L, -0x1p-105L, -8.813735870195430252326093249797835932642e-1L, -1.743152798421049375791483240187377443526e-32L);
4127 TEST_c_c (casinh, 0x1.fp-1025L, 0x0.ffffffffffffffffffffffffffcp0L, 3.432186888910770473784103112009399360940e-293L, 1.570796326794896462222075823262245502760L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM);
4128 TEST_c_c (casinh, 0x1.fp-1025L, -0x0.ffffffffffffffffffffffffffcp0L, 3.432186888910770473784103112009399360940e-293L, -1.570796326794896462222075823262245502760L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM);
4129 TEST_c_c (casinh, -0x1.fp-1025L, 0x0.ffffffffffffffffffffffffffcp0L, -3.432186888910770473784103112009399360940e-293L, 1.570796326794896462222075823262245502760L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM);
4130 TEST_c_c (casinh, -0x1.fp-1025L, -0x0.ffffffffffffffffffffffffffcp0L, -3.432186888910770473784103112009399360940e-293L, -1.570796326794896462222075823262245502760L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM);
4131 TEST_c_c (casinh, 0x0.ffffffffffffffffffffffffffcp0L, 0x1.fp-1025L, 8.813735870195430252326093249797835932642e-1L, 3.810492908885321743133304375216641110205e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
4132 TEST_c_c (casinh, -0x0.ffffffffffffffffffffffffffcp0L, 0x1.fp-1025L, -8.813735870195430252326093249797835932642e-1L, 3.810492908885321743133304375216641110205e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
4133 TEST_c_c (casinh, 0x0.ffffffffffffffffffffffffffcp0L, -0x1.fp-1025L, 8.813735870195430252326093249797835932642e-1L, -3.810492908885321743133304375216641110205e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
4134 TEST_c_c (casinh, -0x0.ffffffffffffffffffffffffffcp0L, -0x1.fp-1025L, -8.813735870195430252326093249797835932642e-1L, -3.810492908885321743133304375216641110205e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
4135 TEST_c_c (casinh, 0.0L, 0x0.ffffffffffffffffffffffffffcp0L, 0.0L, 1.570796326794896462222075823262245502760L);
4136 TEST_c_c (casinh, 0.0L, -0x0.ffffffffffffffffffffffffffcp0L, 0.0L, -1.570796326794896462222075823262245502760L);
4137 TEST_c_c (casinh, -0.0L, 0x0.ffffffffffffffffffffffffffcp0L, -0.0L, 1.570796326794896462222075823262245502760L);
4138 TEST_c_c (casinh, -0.0L, -0x0.ffffffffffffffffffffffffffcp0L, -0.0L, -1.570796326794896462222075823262245502760L);
4139 TEST_c_c (casinh, 0x0.ffffffffffffffffffffffffffcp0L, 0.0L, 8.813735870195430252326093249797835932642e-1L, 0.0L);
4140 TEST_c_c (casinh, -0x0.ffffffffffffffffffffffffffcp0L, 0.0L, -8.813735870195430252326093249797835932642e-1L, 0.0L);
4141 TEST_c_c (casinh, 0x0.ffffffffffffffffffffffffffcp0L, -0.0L, 8.813735870195430252326093249797835932642e-1L, -0.0L);
4142 TEST_c_c (casinh, -0x0.ffffffffffffffffffffffffffcp0L, -0.0L, -8.813735870195430252326093249797835932642e-1L, -0.0L);
4143#endif
4144 TEST_c_c (casinh, 0x1p-105L, 0.5L, 2.846556599890768890940941645338546615370e-32L, 5.235987755982988730771072305465838140329e-1L);
4145 TEST_c_c (casinh, 0x1p-105L, -0.5L, 2.846556599890768890940941645338546615370e-32L, -5.235987755982988730771072305465838140329e-1L);
4146 TEST_c_c (casinh, -0x1p-105L, 0.5L, -2.846556599890768890940941645338546615370e-32L, 5.235987755982988730771072305465838140329e-1L);
4147 TEST_c_c (casinh, -0x1p-105L, -0.5L, -2.846556599890768890940941645338546615370e-32L, -5.235987755982988730771072305465838140329e-1L);
4148 TEST_c_c (casinh, 0.5L, 0x1p-105L, 4.812118250596034474977589134243684231352e-1L, 2.204933261082751447436996198490110245167e-32L);
4149 TEST_c_c (casinh, -0.5L, 0x1p-105L, -4.812118250596034474977589134243684231352e-1L, 2.204933261082751447436996198490110245167e-32L);
4150 TEST_c_c (casinh, 0.5L, -0x1p-105L, 4.812118250596034474977589134243684231352e-1L, -2.204933261082751447436996198490110245167e-32L);
4151 TEST_c_c (casinh, -0.5L, -0x1p-105L, -4.812118250596034474977589134243684231352e-1L, -2.204933261082751447436996198490110245167e-32L);
4152 TEST_c_c (casinh, 0x1p-105L, 0x1p-105L, 2.465190328815661891911651766508706967729e-32L, 2.465190328815661891911651766508706967729e-32L);
4153 TEST_c_c (casinh, 0x1p-105L, -0x1p-105L, 2.465190328815661891911651766508706967729e-32L, -2.465190328815661891911651766508706967729e-32L);
4154 TEST_c_c (casinh, -0x1p-105L, 0x1p-105L, -2.465190328815661891911651766508706967729e-32L, 2.465190328815661891911651766508706967729e-32L);
4155 TEST_c_c (casinh, -0x1p-105L, -0x1p-105L, -2.465190328815661891911651766508706967729e-32L, -2.465190328815661891911651766508706967729e-32L);
4156#ifndef TEST_FLOAT
4157 TEST_c_c (casinh, 0x1.fp-1025L, 0x1p-105L, 5.388850751072128349671657362289416093031e-309L, 2.465190328815661891911651766508706967729e-32L, UNDERFLOW_EXCEPTION_DOUBLE);
4158 TEST_c_c (casinh, 0x1.fp-1025L, -0x1p-105L, 5.388850751072128349671657362289416093031e-309L, -2.465190328815661891911651766508706967729e-32L, UNDERFLOW_EXCEPTION_DOUBLE);
4159 TEST_c_c (casinh, -0x1.fp-1025L, 0x1p-105L, -5.388850751072128349671657362289416093031e-309L, 2.465190328815661891911651766508706967729e-32L, UNDERFLOW_EXCEPTION_DOUBLE);
4160 TEST_c_c (casinh, -0x1.fp-1025L, -0x1p-105L, -5.388850751072128349671657362289416093031e-309L, -2.465190328815661891911651766508706967729e-32L, UNDERFLOW_EXCEPTION_DOUBLE);
4161 /* Bug 15319: underflow exception may be missing. */
4162 TEST_c_c (casinh, 0x1p-105L, 0x1.fp-1025L, 2.465190328815661891911651766508706967729e-32L, 5.388850751072128349671657362289416093031e-309L, UNDERFLOW_EXCEPTION_OK_DOUBLE);
4163 TEST_c_c (casinh, -0x1p-105L, 0x1.fp-1025L, -2.465190328815661891911651766508706967729e-32L, 5.388850751072128349671657362289416093031e-309L, UNDERFLOW_EXCEPTION_OK_DOUBLE);
4164 TEST_c_c (casinh, 0x1p-105L, -0x1.fp-1025L, 2.465190328815661891911651766508706967729e-32L, -5.388850751072128349671657362289416093031e-309L, UNDERFLOW_EXCEPTION_OK_DOUBLE);
4165 TEST_c_c (casinh, -0x1p-105L, -0x1.fp-1025L, -2.465190328815661891911651766508706967729e-32L, -5.388850751072128349671657362289416093031e-309L, UNDERFLOW_EXCEPTION_OK_DOUBLE);
4166#endif
4167 TEST_c_c (casinh, 0.0L, 0x1p-105L, 0.0L, 2.465190328815661891911651766508706967729e-32L);
4168 TEST_c_c (casinh, 0.0L, -0x1p-105L, 0.0L, -2.465190328815661891911651766508706967729e-32L);
4169 TEST_c_c (casinh, -0.0L, 0x1p-105L, -0.0L, 2.465190328815661891911651766508706967729e-32L);
4170 TEST_c_c (casinh, -0.0L, -0x1p-105L, -0.0L, -2.465190328815661891911651766508706967729e-32L);
4171 TEST_c_c (casinh, 0x1p-105L, 0.0L, 2.465190328815661891911651766508706967729e-32L, 0.0L);
4172 TEST_c_c (casinh, -0x1p-105L, 0.0L, -2.465190328815661891911651766508706967729e-32L, 0.0L);
4173 TEST_c_c (casinh, 0x1p-105L, -0.0L, 2.465190328815661891911651766508706967729e-32L, -0.0L);
4174 TEST_c_c (casinh, -0x1p-105L, -0.0L, -2.465190328815661891911651766508706967729e-32L, -0.0L);
4175#if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 113
4176 TEST_c_c (casinh, 0x1p-112L, 0x0.ffffffffffffffffffffffffffff8p0L, 1.091004200533850618345330909857103457781e-17L, 1.570796326794896601578502908312986698624L);
4177 TEST_c_c (casinh, 0x1p-112L, -0x0.ffffffffffffffffffffffffffff8p0L, 1.091004200533850618345330909857103457781e-17L, -1.570796326794896601578502908312986698624L);
4178 TEST_c_c (casinh, -0x1p-112L, 0x0.ffffffffffffffffffffffffffff8p0L, -1.091004200533850618345330909857103457781e-17L, 1.570796326794896601578502908312986698624L);
4179 TEST_c_c (casinh, -0x1p-112L, -0x0.ffffffffffffffffffffffffffff8p0L, -1.091004200533850618345330909857103457781e-17L, -1.570796326794896601578502908312986698624L);
4180 TEST_c_c (casinh, 0x0.ffffffffffffffffffffffffffff8p0L, 0x1p-112L, 8.813735870195430252326093249797922409363e-1L, 1.361838123766444824837096281396380300349e-34L);
4181 TEST_c_c (casinh, -0x0.ffffffffffffffffffffffffffff8p0L, 0x1p-112L, -8.813735870195430252326093249797922409363e-1L, 1.361838123766444824837096281396380300349e-34L);
4182 TEST_c_c (casinh, 0x0.ffffffffffffffffffffffffffff8p0L, -0x1p-112L, 8.813735870195430252326093249797922409363e-1L, -1.361838123766444824837096281396380300349e-34L);
4183 TEST_c_c (casinh, -0x0.ffffffffffffffffffffffffffff8p0L, -0x1p-112L, -8.813735870195430252326093249797922409363e-1L, -1.361838123766444824837096281396380300349e-34L);
4184 TEST_c_c (casinh, 0x1.fp-16385L, 0x0.ffffffffffffffffffffffffffff8p0L, 5.867357004219059108790368268900490184505e-4916L, 1.570796326794896605353533883825294686803L);
4185 TEST_c_c (casinh, 0x1.fp-16385L, -0x0.ffffffffffffffffffffffffffff8p0L, 5.867357004219059108790368268900490184505e-4916L, -1.570796326794896605353533883825294686803L);
4186 TEST_c_c (casinh, -0x1.fp-16385L, 0x0.ffffffffffffffffffffffffffff8p0L, -5.867357004219059108790368268900490184505e-4916L, 1.570796326794896605353533883825294686803L);
4187 TEST_c_c (casinh, -0x1.fp-16385L, -0x0.ffffffffffffffffffffffffffff8p0L, -5.867357004219059108790368268900490184505e-4916L, -1.570796326794896605353533883825294686803L);
4188 TEST_c_c (casinh, 0x0.ffffffffffffffffffffffffffff8p0L, 0x1.fp-16385L, 8.813735870195430252326093249797922409363e-1L, 5.757683115456107044131264955348449231681e-4933L, UNDERFLOW_EXCEPTION);
4189 TEST_c_c (casinh, -0x0.ffffffffffffffffffffffffffff8p0L, 0x1.fp-16385L, -8.813735870195430252326093249797922409363e-1L, 5.757683115456107044131264955348449231681e-4933L, UNDERFLOW_EXCEPTION);
4190 TEST_c_c (casinh, 0x0.ffffffffffffffffffffffffffff8p0L, -0x1.fp-16385L, 8.813735870195430252326093249797922409363e-1L, -5.757683115456107044131264955348449231681e-4933L, UNDERFLOW_EXCEPTION);
4191 TEST_c_c (casinh, -0x0.ffffffffffffffffffffffffffff8p0L, -0x1.fp-16385L, -8.813735870195430252326093249797922409363e-1L, -5.757683115456107044131264955348449231681e-4933L, UNDERFLOW_EXCEPTION);
4192 TEST_c_c (casinh, 0.0L, 0x0.ffffffffffffffffffffffffffff8p0L, 0.0L, 1.570796326794896605353533883825294686803L);
4193 TEST_c_c (casinh, 0.0L, -0x0.ffffffffffffffffffffffffffff8p0L, 0.0L, -1.570796326794896605353533883825294686803L);
4194 TEST_c_c (casinh, -0.0L, 0x0.ffffffffffffffffffffffffffff8p0L, -0.0L, 1.570796326794896605353533883825294686803L);
4195 TEST_c_c (casinh, -0.0L, -0x0.ffffffffffffffffffffffffffff8p0L, -0.0L, -1.570796326794896605353533883825294686803L);
4196 TEST_c_c (casinh, 0x0.ffffffffffffffffffffffffffff8p0L, 0.0L, 8.813735870195430252326093249797922409363e-1L, 0.0L);
4197 TEST_c_c (casinh, -0x0.ffffffffffffffffffffffffffff8p0L, 0.0L, -8.813735870195430252326093249797922409363e-1L, 0.0L);
4198 TEST_c_c (casinh, 0x0.ffffffffffffffffffffffffffff8p0L, -0.0L, 8.813735870195430252326093249797922409363e-1L, -0.0L);
4199 TEST_c_c (casinh, -0x0.ffffffffffffffffffffffffffff8p0L, -0.0L, -8.813735870195430252326093249797922409363e-1L, -0.0L);
4200#endif
4201 TEST_c_c (casinh, 0x1p-112L, 0.5L, 2.223872343664663196047610660420739543258e-34L, 5.235987755982988730771072305465838140329e-1L);
4202 TEST_c_c (casinh, 0x1p-112L, -0.5L, 2.223872343664663196047610660420739543258e-34L, -5.235987755982988730771072305465838140329e-1L);
4203 TEST_c_c (casinh, -0x1p-112L, 0.5L, -2.223872343664663196047610660420739543258e-34L, 5.235987755982988730771072305465838140329e-1L);
4204 TEST_c_c (casinh, -0x1p-112L, -0.5L, -2.223872343664663196047610660420739543258e-34L, -5.235987755982988730771072305465838140329e-1L);
4205 TEST_c_c (casinh, 0.5L, 0x1p-112L, 4.812118250596034474977589134243684231352e-1L, 1.722604110220899568310153280070398629037e-34L);
4206 TEST_c_c (casinh, -0.5L, 0x1p-112L, -4.812118250596034474977589134243684231352e-1L, 1.722604110220899568310153280070398629037e-34L);
4207 TEST_c_c (casinh, 0.5L, -0x1p-112L, 4.812118250596034474977589134243684231352e-1L, -1.722604110220899568310153280070398629037e-34L);
4208 TEST_c_c (casinh, -0.5L, -0x1p-112L, -4.812118250596034474977589134243684231352e-1L, -1.722604110220899568310153280070398629037e-34L);
4209 TEST_c_c (casinh, 0x1p-112L, 0x1p-112L, 1.925929944387235853055977942584927318538e-34L, 1.925929944387235853055977942584927318538e-34L);
4210 TEST_c_c (casinh, 0x1p-112L, -0x1p-112L, 1.925929944387235853055977942584927318538e-34L, -1.925929944387235853055977942584927318538e-34L);
4211 TEST_c_c (casinh, -0x1p-112L, 0x1p-112L, -1.925929944387235853055977942584927318538e-34L, 1.925929944387235853055977942584927318538e-34L);
4212 TEST_c_c (casinh, -0x1p-112L, -0x1p-112L, -1.925929944387235853055977942584927318538e-34L, -1.925929944387235853055977942584927318538e-34L);
4213#if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
4214 TEST_c_c (casinh, 0x1.fp-16385L, 0x1p-112L, 8.142593549724601460479922838826119584417e-4933L, 1.925929944387235853055977942584927318538e-34L, UNDERFLOW_EXCEPTION);
4215 TEST_c_c (casinh, 0x1.fp-16385L, -0x1p-112L, 8.142593549724601460479922838826119584417e-4933L, -1.925929944387235853055977942584927318538e-34L, UNDERFLOW_EXCEPTION);
4216 TEST_c_c (casinh, -0x1.fp-16385L, 0x1p-112L, -8.142593549724601460479922838826119584417e-4933L, 1.925929944387235853055977942584927318538e-34L, UNDERFLOW_EXCEPTION);
4217 TEST_c_c (casinh, -0x1.fp-16385L, -0x1p-112L, -8.142593549724601460479922838826119584417e-4933L, -1.925929944387235853055977942584927318538e-34L, UNDERFLOW_EXCEPTION);
4218 TEST_c_c (casinh, 0x1p-112L, 0x1.fp-16385L, 1.925929944387235853055977942584927318538e-34L, 8.142593549724601460479922838826119584417e-4933L, UNDERFLOW_EXCEPTION);
4219 TEST_c_c (casinh, -0x1p-112L, 0x1.fp-16385L, -1.925929944387235853055977942584927318538e-34L, 8.142593549724601460479922838826119584417e-4933L, UNDERFLOW_EXCEPTION);
4220 TEST_c_c (casinh, 0x1p-112L, -0x1.fp-16385L, 1.925929944387235853055977942584927318538e-34L, -8.142593549724601460479922838826119584417e-4933L, UNDERFLOW_EXCEPTION);
4221 TEST_c_c (casinh, -0x1p-112L, -0x1.fp-16385L, -1.925929944387235853055977942584927318538e-34L, -8.142593549724601460479922838826119584417e-4933L, UNDERFLOW_EXCEPTION);
4222#endif
4223 TEST_c_c (casinh, 0.0L, 0x1p-112L, 0.0L, 1.925929944387235853055977942584927318538e-34L);
4224 TEST_c_c (casinh, 0.0L, -0x1p-112L, 0.0L, -1.925929944387235853055977942584927318538e-34L);
4225 TEST_c_c (casinh, -0.0L, 0x1p-112L, -0.0L, 1.925929944387235853055977942584927318538e-34L);
4226 TEST_c_c (casinh, -0.0L, -0x1p-112L, -0.0L, -1.925929944387235853055977942584927318538e-34L);
4227 TEST_c_c (casinh, 0x1p-112L, 0.0L, 1.925929944387235853055977942584927318538e-34L, 0.0L);
4228 TEST_c_c (casinh, -0x1p-112L, 0.0L, -1.925929944387235853055977942584927318538e-34L, 0.0L);
4229 TEST_c_c (casinh, 0x1p-112L, -0.0L, 1.925929944387235853055977942584927318538e-34L, -0.0L);
4230 TEST_c_c (casinh, -0x1p-112L, -0.0L, -1.925929944387235853055977942584927318538e-34L, -0.0L);
4231
2550dfe9 4232 TEST_c_c (casinh, 0.75L, 1.25L, 1.03171853444778027336364058631006594L, 0.911738290968487636358489564316731207L);
33e885db 4233 TEST_c_c (casinh, -2, -3, -1.9686379257930962917886650952454982L, -0.96465850440760279204541105949953237L);
8847214f 4234
6815fabc 4235 END (casinh, complex);
8847214f
UD
4236}
4237
4238
4239static void
4240catan_test (void)
4241{
aaca11d8 4242 errno = 0;
3c6cad26 4243 FUNC(catan) (BUILD_COMPLEX (0.7L, 1.2L));
aaca11d8
UD
4244 if (errno == ENOSYS)
4245 /* Function not implemented. */
4246 return;
4247
8847214f
UD
4248 START (catan);
4249
4250 TEST_c_c (catan, 0, 0, 0, 0);
4251 TEST_c_c (catan, minus_zero, 0, minus_zero, 0);
4252 TEST_c_c (catan, 0, minus_zero, 0, minus_zero);
4253 TEST_c_c (catan, minus_zero, minus_zero, minus_zero, minus_zero);
4254
4255 TEST_c_c (catan, plus_infty, plus_infty, M_PI_2l, 0);
4256 TEST_c_c (catan, plus_infty, minus_infty, M_PI_2l, minus_zero);
4257 TEST_c_c (catan, minus_infty, plus_infty, -M_PI_2l, 0);
4258 TEST_c_c (catan, minus_infty, minus_infty, -M_PI_2l, minus_zero);
4259
4260
4261 TEST_c_c (catan, plus_infty, -10.0, M_PI_2l, minus_zero);
4262 TEST_c_c (catan, minus_infty, -10.0, -M_PI_2l, minus_zero);
4263 TEST_c_c (catan, plus_infty, minus_zero, M_PI_2l, minus_zero);
4264 TEST_c_c (catan, minus_infty, minus_zero, -M_PI_2l, minus_zero);
4265 TEST_c_c (catan, plus_infty, 0.0, M_PI_2l, 0);
4266 TEST_c_c (catan, minus_infty, 0.0, -M_PI_2l, 0);
3c6cad26
UD
4267 TEST_c_c (catan, plus_infty, 0.1L, M_PI_2l, 0);
4268 TEST_c_c (catan, minus_infty, 0.1L, -M_PI_2l, 0);
8847214f
UD
4269
4270 TEST_c_c (catan, 0.0, minus_infty, M_PI_2l, minus_zero);
4271 TEST_c_c (catan, minus_zero, minus_infty, -M_PI_2l, minus_zero);
4272 TEST_c_c (catan, 100.0, minus_infty, M_PI_2l, minus_zero);
4273 TEST_c_c (catan, -100.0, minus_infty, -M_PI_2l, minus_zero);
4274
4275 TEST_c_c (catan, 0.0, plus_infty, M_PI_2l, 0);
4276 TEST_c_c (catan, minus_zero, plus_infty, -M_PI_2l, 0);
4277 TEST_c_c (catan, 0.5, plus_infty, M_PI_2l, 0);
4278 TEST_c_c (catan, -0.5, plus_infty, -M_PI_2l, 0);
4279
67e971f1
TS
4280 TEST_c_c (catan, qnan_value, 0.0, qnan_value, 0);
4281 TEST_c_c (catan, qnan_value, minus_zero, qnan_value, minus_zero);
8847214f 4282
67e971f1
TS
4283 TEST_c_c (catan, qnan_value, plus_infty, qnan_value, 0);
4284 TEST_c_c (catan, qnan_value, minus_infty, qnan_value, minus_zero);
8847214f 4285
67e971f1
TS
4286 TEST_c_c (catan, 0.0, qnan_value, qnan_value, qnan_value);
4287 TEST_c_c (catan, minus_zero, qnan_value, qnan_value, qnan_value);
8847214f 4288
67e971f1
TS
4289 TEST_c_c (catan, plus_infty, qnan_value, M_PI_2l, 0, IGNORE_ZERO_INF_SIGN);
4290 TEST_c_c (catan, minus_infty, qnan_value, -M_PI_2l, 0, IGNORE_ZERO_INF_SIGN);
8847214f 4291
67e971f1
TS
4292 TEST_c_c (catan, qnan_value, 10.5, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
4293 TEST_c_c (catan, qnan_value, -10.5, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
8847214f 4294
67e971f1
TS
4295 TEST_c_c (catan, 0.75, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
4296 TEST_c_c (catan, -0.75, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
8847214f 4297
67e971f1 4298 TEST_c_c (catan, qnan_value, qnan_value, qnan_value, qnan_value);
8847214f 4299
2550dfe9 4300 TEST_c_c (catan, 0.75L, 1.25L, 1.10714871779409050301706546017853704L, 0.549306144334054845697622618461262852L);
33e885db 4301 TEST_c_c (catan, -2, -3, -1.4099210495965755225306193844604208L, -0.22907268296853876629588180294200276L);
8847214f 4302
6815fabc 4303 END (catan, complex);
8847214f
UD
4304}
4305
4306static void
4307catanh_test (void)
4308{
aaca11d8 4309 errno = 0;
3c6cad26 4310 FUNC(catanh) (BUILD_COMPLEX (0.7L, 1.2L));
aaca11d8
UD
4311 if (errno == ENOSYS)
4312 /* Function not implemented. */
4313 return;
4314
8847214f
UD
4315 START (catanh);
4316
4317 TEST_c_c (catanh, 0, 0, 0.0, 0.0);
4318 TEST_c_c (catanh, minus_zero, 0, minus_zero, 0.0);
4319 TEST_c_c (catanh, 0, minus_zero, 0.0, minus_zero);
4320 TEST_c_c (catanh, minus_zero, minus_zero, minus_zero, minus_zero);
4321
4322 TEST_c_c (catanh, plus_infty, plus_infty, 0.0, M_PI_2l);
4323 TEST_c_c (catanh, plus_infty, minus_infty, 0.0, -M_PI_2l);
4324 TEST_c_c (catanh, minus_infty, plus_infty, minus_zero, M_PI_2l);
4325 TEST_c_c (catanh, minus_infty, minus_infty, minus_zero, -M_PI_2l);
4326
4327 TEST_c_c (catanh, -10.0, plus_infty, minus_zero, M_PI_2l);
4328 TEST_c_c (catanh, -10.0, minus_infty, minus_zero, -M_PI_2l);
4329 TEST_c_c (catanh, minus_zero, plus_infty, minus_zero, M_PI_2l);
4330 TEST_c_c (catanh, minus_zero, minus_infty, minus_zero, -M_PI_2l);
4331 TEST_c_c (catanh, 0, plus_infty, 0.0, M_PI_2l);
4332 TEST_c_c (catanh, 0, minus_infty, 0.0, -M_PI_2l);
3c6cad26
UD
4333 TEST_c_c (catanh, 0.1L, plus_infty, 0.0, M_PI_2l);
4334 TEST_c_c (catanh, 0.1L, minus_infty, 0.0, -M_PI_2l);
8847214f
UD
4335
4336 TEST_c_c (catanh, minus_infty, 0, minus_zero, M_PI_2l);
4337 TEST_c_c (catanh, minus_infty, minus_zero, minus_zero, -M_PI_2l);
4338 TEST_c_c (catanh, minus_infty, 100, minus_zero, M_PI_2l);
4339 TEST_c_c (catanh, minus_infty, -100, minus_zero, -M_PI_2l);
4340
4341 TEST_c_c (catanh, plus_infty, 0, 0.0, M_PI_2l);
4342 TEST_c_c (catanh, plus_infty, minus_zero, 0.0, -M_PI_2l);
4343 TEST_c_c (catanh, plus_infty, 0.5, 0.0, M_PI_2l);
4344 TEST_c_c (catanh, plus_infty, -0.5, 0.0, -M_PI_2l);
4345
67e971f1
TS
4346 TEST_c_c (catanh, 0, qnan_value, 0.0, qnan_value);
4347 TEST_c_c (catanh, minus_zero, qnan_value, minus_zero, qnan_value);
8847214f 4348
67e971f1
TS
4349 TEST_c_c (catanh, plus_infty, qnan_value, 0.0, qnan_value);
4350 TEST_c_c (catanh, minus_infty, qnan_value, minus_zero, qnan_value);
8847214f 4351
67e971f1
TS
4352 TEST_c_c (catanh, qnan_value, 0, qnan_value, qnan_value);
4353 TEST_c_c (catanh, qnan_value, minus_zero, qnan_value, qnan_value);
8847214f 4354
67e971f1
TS
4355 TEST_c_c (catanh, qnan_value, plus_infty, 0.0, M_PI_2l, IGNORE_ZERO_INF_SIGN);
4356 TEST_c_c (catanh, qnan_value, minus_infty, 0.0, -M_PI_2l, IGNORE_ZERO_INF_SIGN);
8847214f 4357
67e971f1
TS
4358 TEST_c_c (catanh, 10.5, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
4359 TEST_c_c (catanh, -10.5, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
8847214f 4360
67e971f1
TS
4361 TEST_c_c (catanh, qnan_value, 0.75, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
4362 TEST_c_c (catanh, qnan_value, -0.75, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
8847214f 4363
67e971f1 4364 TEST_c_c (catanh, qnan_value, qnan_value, qnan_value, qnan_value);
8847214f 4365
2550dfe9 4366 TEST_c_c (catanh, 0.75L, 1.25L, 0.261492138795671927078652057366532140L, 0.996825126463918666098902241310446708L);
33e885db 4367 TEST_c_c (catanh, -2, -3, -0.14694666622552975204743278515471595L, -1.3389725222944935611241935759091443L);
8847214f 4368
6815fabc 4369 END (catanh, complex);
8847214f
UD
4370}
4371
4372static void
4373cbrt_test (void)
4374{
42be70d4
UD
4375 errno = 0;
4376 FUNC(cbrt) (8);
4377 if (errno == ENOSYS)
4378 /* Function not implemented. */
4379 return;
4380
8847214f
UD
4381 START (cbrt);
4382
4383 TEST_f_f (cbrt, 0.0, 0.0);
4384 TEST_f_f (cbrt, minus_zero, minus_zero);
4385
4386 TEST_f_f (cbrt, plus_infty, plus_infty);
4387 TEST_f_f (cbrt, minus_infty, minus_infty);
67e971f1 4388 TEST_f_f (cbrt, qnan_value, qnan_value);
8847214f 4389
3c6cad26 4390 TEST_f_f (cbrt, -0.001L, -0.1L);
8847214f
UD
4391 TEST_f_f (cbrt, 8, 2);
4392 TEST_f_f (cbrt, -27.0, -3.0);
2550dfe9
AJ
4393 TEST_f_f (cbrt, 0.9921875L, 0.997389022060725270579075195353955217L);
4394 TEST_f_f (cbrt, 0.75L, 0.908560296416069829445605878163630251L);
8847214f
UD
4395
4396 END (cbrt);
4397}
4398
2550dfe9 4399
8847214f
UD
4400static void
4401ccos_test (void)
4402{
aaca11d8
UD
4403 errno = 0;
4404 FUNC(ccos) (BUILD_COMPLEX (0, 0));
4405 if (errno == ENOSYS)
4406 /* Function not implemented. */
4407 return;
8847214f
UD
4408
4409 START (ccos);
4410
4411 TEST_c_c (ccos, 0.0, 0.0, 1.0, minus_zero);
4412 TEST_c_c (ccos, minus_zero, 0.0, 1.0, 0.0);
4413 TEST_c_c (ccos, 0.0, minus_zero, 1.0, 0.0);
4414 TEST_c_c (ccos, minus_zero, minus_zero, 1.0, minus_zero);
4415
67e971f1
TS
4416 TEST_c_c (ccos, plus_infty, 0.0, qnan_value, 0.0, INVALID_EXCEPTION|IGNORE_ZERO_INF_SIGN);
4417 TEST_c_c (ccos, plus_infty, minus_zero, qnan_value, 0.0, INVALID_EXCEPTION|IGNORE_ZERO_INF_SIGN);
4418 TEST_c_c (ccos, minus_infty, 0.0, qnan_value, 0.0, INVALID_EXCEPTION|IGNORE_ZERO_INF_SIGN);
4419 TEST_c_c (ccos, minus_infty, minus_zero, qnan_value, 0.0, INVALID_EXCEPTION|IGNORE_ZERO_INF_SIGN);
8847214f
UD
4420
4421 TEST_c_c (ccos, 0.0, plus_infty, plus_infty, minus_zero);
4422 TEST_c_c (ccos, 0.0, minus_infty, plus_infty, 0.0);
4423 TEST_c_c (ccos, minus_zero, plus_infty, plus_infty, 0.0);
4424 TEST_c_c (ccos, minus_zero, minus_infty, plus_infty, minus_zero);
4425
67e971f1
TS
4426 TEST_c_c (ccos, plus_infty, plus_infty, plus_infty, qnan_value, INVALID_EXCEPTION);
4427 TEST_c_c (ccos, minus_infty, plus_infty, plus_infty, qnan_value, INVALID_EXCEPTION);
4428 TEST_c_c (ccos, plus_infty, minus_infty, plus_infty, qnan_value, INVALID_EXCEPTION);
4429 TEST_c_c (ccos, minus_infty, minus_infty, plus_infty, qnan_value, INVALID_EXCEPTION);
8847214f
UD
4430
4431 TEST_c_c (ccos, 4.625, plus_infty, minus_infty, plus_infty);
4432 TEST_c_c (ccos, 4.625, minus_infty, minus_infty, minus_infty);
4433 TEST_c_c (ccos, -4.625, plus_infty, minus_infty, minus_infty);
4434 TEST_c_c (ccos, -4.625, minus_infty, minus_infty, plus_infty);
4435
67e971f1
TS
4436 TEST_c_c (ccos, plus_infty, 6.75, qnan_value, qnan_value, INVALID_EXCEPTION);
4437 TEST_c_c (ccos, plus_infty, -6.75, qnan_value, qnan_value, INVALID_EXCEPTION);
4438 TEST_c_c (ccos, minus_infty, 6.75, qnan_value, qnan_value, INVALID_EXCEPTION);
4439 TEST_c_c (ccos, minus_infty, -6.75, qnan_value, qnan_value, INVALID_EXCEPTION);
8847214f 4440
67e971f1
TS
4441 TEST_c_c (ccos, qnan_value, 0.0, qnan_value, 0.0, IGNORE_ZERO_INF_SIGN);
4442 TEST_c_c (ccos, qnan_value, minus_zero, qnan_value, 0.0, IGNORE_ZERO_INF_SIGN);
8847214f 4443
67e971f1
TS
4444 TEST_c_c (ccos, qnan_value, plus_infty, plus_infty, qnan_value);
4445 TEST_c_c (ccos, qnan_value, minus_infty, plus_infty, qnan_value);
8847214f 4446
67e971f1
TS
4447 TEST_c_c (ccos, qnan_value, 9.0, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
4448 TEST_c_c (ccos, qnan_value, -9.0, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
8847214f 4449
67e971f1
TS
4450 TEST_c_c (ccos, 0.0, qnan_value, qnan_value, 0.0, IGNORE_ZERO_INF_SIGN);
4451 TEST_c_c (ccos, minus_zero, qnan_value, qnan_value, 0.0, IGNORE_ZERO_INF_SIGN);
8847214f 4452
67e971f1
TS
4453 TEST_c_c (ccos, 10.0, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
4454 TEST_c_c (ccos, -10.0, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
8847214f 4455
67e971f1
TS
4456 TEST_c_c (ccos, plus_infty, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
4457 TEST_c_c (ccos, minus_infty, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
8847214f 4458
67e971f1 4459 TEST_c_c (ccos, qnan_value, qnan_value, qnan_value, qnan_value);
8847214f 4460
2550dfe9 4461 TEST_c_c (ccos, 0.75L, 1.25L, 1.38173873063425888530729933139078645L, -1.09193013555397466170919531722024128L);
79df8ce5 4462 TEST_c_c (ccos, -2, -3, -4.18962569096880723013255501961597373L, -9.10922789375533659797919726277886212L);
8847214f 4463
e0b16cc2
JM
4464 TEST_c_c (ccos, 0.75, 89.5, 2.708024460708609732016532185663087200560e38L, -2.522786001038096774676288412995370563339e38L);
4465 TEST_c_c (ccos, 0.75, -89.5, 2.708024460708609732016532185663087200560e38L, 2.522786001038096774676288412995370563339e38L);
4466 TEST_c_c (ccos, -0.75, 89.5, 2.708024460708609732016532185663087200560e38L, 2.522786001038096774676288412995370563339e38L);
4467 TEST_c_c (ccos, -0.75, -89.5, 2.708024460708609732016532185663087200560e38L, -2.522786001038096774676288412995370563339e38L);
4468
4469#ifndef TEST_FLOAT
4470 TEST_c_c (ccos, 0.75, 710.5, 1.347490911916428129246890157395342279438e308L, -1.255317763348154410745082950806112487736e308L);
4471 TEST_c_c (ccos, 0.75, -710.5, 1.347490911916428129246890157395342279438e308L, 1.255317763348154410745082950806112487736e308L);
4472 TEST_c_c (ccos, -0.75, 710.5, 1.347490911916428129246890157395342279438e308L, 1.255317763348154410745082950806112487736e308L);
4473 TEST_c_c (ccos, -0.75, -710.5, 1.347490911916428129246890157395342279438e308L, -1.255317763348154410745082950806112487736e308L);
4474#endif
4475
4476#if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
4477 TEST_c_c (ccos, 0.75, 11357.25, 9.001213196851067077465606717616495588201e4931L, -8.385498349388321535962327491346664141020e4931L);
4478 TEST_c_c (ccos, 0.75, -11357.25, 9.001213196851067077465606717616495588201e4931L, 8.385498349388321535962327491346664141020e4931L);
4479 TEST_c_c (ccos, -0.75, 11357.25, 9.001213196851067077465606717616495588201e4931L, 8.385498349388321535962327491346664141020e4931L);
4480 TEST_c_c (ccos, -0.75, -11357.25, 9.001213196851067077465606717616495588201e4931L, -8.385498349388321535962327491346664141020e4931L);
4481#endif
4482
4483#ifdef TEST_FLOAT
4484 TEST_c_c (ccos, 0x1p-149, 180, plus_infty, -1.043535896672617552965983803453927655332e33L, OVERFLOW_EXCEPTION);
4485#endif
4486
4487#if defined TEST_DOUBLE || (defined TEST_LDOUBLE && LDBL_MAX_EXP == 1024)
4488 TEST_c_c (ccos, 0x1p-1074, 1440, plus_infty, -5.981479269486130556466515778180916082415e301L, OVERFLOW_EXCEPTION);
4489#endif
4490
4491#if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
4492 TEST_c_c (ccos, 0x1p-16434L, 22730, plus_infty, -1.217853148905605987081057582351152052687e4924L, OVERFLOW_EXCEPTION);
4493#endif
4494
6815fabc 4495 END (ccos, complex);
8847214f
UD
4496}
4497
4498
4499static void
4500ccosh_test (void)
4501{
aaca11d8 4502 errno = 0;
3c6cad26 4503 FUNC(ccosh) (BUILD_COMPLEX (0.7L, 1.2L));
aaca11d8
UD
4504 if (errno == ENOSYS)
4505 /* Function not implemented. */
4506 return;
8847214f
UD
4507
4508 START (ccosh);
4509
4510 TEST_c_c (ccosh, 0.0, 0.0, 1.0, 0.0);
4511 TEST_c_c (ccosh, minus_zero, 0.0, 1.0, minus_zero);
4512 TEST_c_c (ccosh, 0.0, minus_zero, 1.0, minus_zero);
4513 TEST_c_c (ccosh, minus_zero, minus_zero, 1.0, 0.0);
4514
67e971f1
TS
4515 TEST_c_c (ccosh, 0.0, plus_infty, qnan_value, 0.0, INVALID_EXCEPTION|IGNORE_ZERO_INF_SIGN);
4516 TEST_c_c (ccosh, minus_zero, plus_infty, qnan_value, 0.0, INVALID_EXCEPTION|IGNORE_ZERO_INF_SIGN);
4517 TEST_c_c (ccosh, 0.0, minus_infty, qnan_value, 0.0, INVALID_EXCEPTION|IGNORE_ZERO_INF_SIGN);
4518 TEST_c_c (ccosh, minus_zero, minus_infty, qnan_value, 0.0, INVALID_EXCEPTION|IGNORE_ZERO_INF_SIGN);
8847214f
UD
4519
4520 TEST_c_c (ccosh, plus_infty, 0.0, plus_infty, 0.0);
4521 TEST_c_c (ccosh, minus_infty, 0.0, plus_infty, minus_zero);
4522 TEST_c_c (ccosh, plus_infty, minus_zero, plus_infty, minus_zero);
4523 TEST_c_c (ccosh, minus_infty, minus_zero, plus_infty, 0.0);
4524
67e971f1
TS
4525 TEST_c_c (ccosh, plus_infty, plus_infty, plus_infty, qnan_value, INVALID_EXCEPTION);
4526 TEST_c_c (ccosh, minus_infty, plus_infty, plus_infty, qnan_value, INVALID_EXCEPTION);
4527 TEST_c_c (ccosh, plus_infty, minus_infty, plus_infty, qnan_value, INVALID_EXCEPTION);
4528 TEST_c_c (ccosh, minus_infty, minus_infty, plus_infty, qnan_value, INVALID_EXCEPTION);
8847214f
UD
4529
4530 TEST_c_c (ccosh, plus_infty, 4.625, minus_infty, minus_infty);
4531 TEST_c_c (ccosh, minus_infty, 4.625, minus_infty, plus_infty);
4532 TEST_c_c (ccosh, plus_infty, -4.625, minus_infty, plus_infty);
4533 TEST_c_c (ccosh, minus_infty, -4.625, minus_infty, minus_infty);
4534
67e971f1
TS
4535 TEST_c_c (ccosh, 6.75, plus_infty, qnan_value, qnan_value, INVALID_EXCEPTION);
4536 TEST_c_c (ccosh, -6.75, plus_infty, qnan_value, qnan_value, INVALID_EXCEPTION);
4537 TEST_c_c (ccosh, 6.75, minus_infty, qnan_value, qnan_value, INVALID_EXCEPTION);
4538 TEST_c_c (ccosh, -6.75, minus_infty, qnan_value, qnan_value, INVALID_EXCEPTION);
8847214f 4539
67e971f1
TS
4540 TEST_c_c (ccosh, 0.0, qnan_value, qnan_value, 0.0, IGNORE_ZERO_INF_SIGN);
4541 TEST_c_c (ccosh, minus_zero, qnan_value, qnan_value, 0.0, IGNORE_ZERO_INF_SIGN);
8847214f 4542
67e971f1
TS
4543 TEST_c_c (ccosh, plus_infty, qnan_value, plus_infty, qnan_value);
4544 TEST_c_c (ccosh, minus_infty, qnan_value, plus_infty, qnan_value);
8847214f 4545
67e971f1
TS
4546 TEST_c_c (ccosh, 9.0, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
4547 TEST_c_c (ccosh, -9.0, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
8847214f 4548
67e971f1
TS
4549 TEST_c_c (ccosh, qnan_value, 0.0, qnan_value, 0.0, IGNORE_ZERO_INF_SIGN);
4550 TEST_c_c (ccosh, qnan_value, minus_zero, qnan_value, 0.0, IGNORE_ZERO_INF_SIGN);
8847214f 4551
67e971f1
TS
4552 TEST_c_c (ccosh, qnan_value, 10.0, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
4553 TEST_c_c (ccosh, qnan_value, -10.0, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
8847214f 4554
67e971f1
TS
4555 TEST_c_c (ccosh, qnan_value, plus_infty, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
4556 TEST_c_c (ccosh, qnan_value, minus_infty, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
8847214f 4557
67e971f1 4558 TEST_c_c (ccosh, qnan_value, qnan_value, qnan_value, qnan_value);
8847214f 4559
2550dfe9 4560 TEST_c_c (ccosh, 0.75L, 1.25L, 0.408242591877968807788852146397499084L, 0.780365930845853240391326216300863152L);
8847214f 4561
79df8ce5 4562 TEST_c_c (ccosh, -2, -3, -3.72454550491532256547397070325597253L, 0.511822569987384608834463849801875634L);
8847214f 4563
e0b16cc2
JM
4564 TEST_c_c (ccosh, 89.5, 0.75, 2.708024460708609732016532185663087200560e38L, 2.522786001038096774676288412995370563339e38L);
4565 TEST_c_c (ccosh, -89.5, 0.75, 2.708024460708609732016532185663087200560e38L, -2.522786001038096774676288412995370563339e38L);
4566 TEST_c_c (ccosh, 89.5, -0.75, 2.708024460708609732016532185663087200560e38L, -2.522786001038096774676288412995370563339e38L);
4567 TEST_c_c (ccosh, -89.5, -0.75, 2.708024460708609732016532185663087200560e38L, 2.522786001038096774676288412995370563339e38L);
4568
4569#ifndef TEST_FLOAT
4570 TEST_c_c (ccosh, 710.5, 0.75, 1.347490911916428129246890157395342279438e308L, 1.255317763348154410745082950806112487736e308L);
4571 TEST_c_c (ccosh, -710.5, 0.75, 1.347490911916428129246890157395342279438e308L, -1.255317763348154410745082950806112487736e308L);
4572 TEST_c_c (ccosh, 710.5, -0.75, 1.347490911916428129246890157395342279438e308L, -1.255317763348154410745082950806112487736e308L);
4573 TEST_c_c (ccosh, -710.5, -0.75, 1.347490911916428129246890157395342279438e308L, 1.255317763348154410745082950806112487736e308L);
4574#endif
4575
4576#if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
4577 TEST_c_c (ccosh, 11357.25, 0.75, 9.001213196851067077465606717616495588201e4931L, 8.385498349388321535962327491346664141020e4931L);
4578 TEST_c_c (ccosh, -11357.25, 0.75, 9.001213196851067077465606717616495588201e4931L, -8.385498349388321535962327491346664141020e4931L);
4579 TEST_c_c (ccosh, 11357.25, -0.75, 9.001213196851067077465606717616495588201e4931L, -8.385498349388321535962327491346664141020e4931L);
4580 TEST_c_c (ccosh, -11357.25, -0.75, 9.001213196851067077465606717616495588201e4931L, 8.385498349388321535962327491346664141020e4931L);
4581#endif
4582
4583#ifdef TEST_FLOAT
4584 TEST_c_c (ccosh, 180, 0x1p-149, plus_infty, 1.043535896672617552965983803453927655332e33L, OVERFLOW_EXCEPTION);
4585#endif
4586
4587#if defined TEST_DOUBLE || (defined TEST_LDOUBLE && LDBL_MAX_EXP == 1024)
4588 TEST_c_c (ccosh, 1440, 0x1p-1074, plus_infty, 5.981479269486130556466515778180916082415e301L, OVERFLOW_EXCEPTION);
4589#endif
4590
4591#if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
4592 TEST_c_c (ccosh, 22730, 0x1p-16434L, plus_infty, 1.217853148905605987081057582351152052687e4924L, OVERFLOW_EXCEPTION);
4593#endif
4594
6815fabc 4595 END (ccosh, complex);
8847214f
UD
4596}
4597
4598
4599static void
4600ceil_test (void)
4601{
4602 START (ceil);
4603
4604 TEST_f_f (ceil, 0.0, 0.0);
4605 TEST_f_f (ceil, minus_zero, minus_zero);
4606 TEST_f_f (ceil, plus_infty, plus_infty);
4607 TEST_f_f (ceil, minus_infty, minus_infty);
67e971f1 4608 TEST_f_f (ceil, qnan_value, qnan_value);
8847214f
UD
4609
4610 TEST_f_f (ceil, M_PIl, 4.0);
4611 TEST_f_f (ceil, -M_PIl, -3.0);
5c68d401 4612 TEST_f_f (ceil, 0.1, 1.0);
45740f46 4613 TEST_f_f (ceil, 0.25, 1.0);
5c68d401
RM
4614 TEST_f_f (ceil, 0.625, 1.0);
4615 TEST_f_f (ceil, -0.1, minus_zero);
97fd3a30 4616 TEST_f_f (ceil, -0.25, minus_zero);
5c68d401 4617 TEST_f_f (ceil, -0.625, minus_zero);
8847214f 4618
f964490f
RM
4619#ifdef TEST_LDOUBLE
4620 /* The result can only be represented in long double. */
4621 TEST_f_f (ceil, 4503599627370495.5L, 4503599627370496.0L);
4622 TEST_f_f (ceil, 4503599627370496.25L, 4503599627370497.0L);
4623 TEST_f_f (ceil, 4503599627370496.5L, 4503599627370497.0L);
4624 TEST_f_f (ceil, 4503599627370496.75L, 4503599627370497.0L);
4625 TEST_f_f (ceil, 4503599627370497.5L, 4503599627370498.0L);
4626
4627 TEST_f_f (ceil, -4503599627370495.5L, -4503599627370495.0L);
4628 TEST_f_f (ceil, -4503599627370496.25L, -4503599627370496.0L);
4629 TEST_f_f (ceil, -4503599627370496.5L, -4503599627370496.0L);
4630 TEST_f_f (ceil, -4503599627370496.75L, -4503599627370496.0L);
4631 TEST_f_f (ceil, -4503599627370497.5L, -4503599627370497.0L);
4632
5c68d401
RM
4633# if LDBL_MANT_DIG > 100
4634 TEST_f_f (ceil, 4503599627370494.5000000000001L, 4503599627370495.0L);
4635 TEST_f_f (ceil, 4503599627370495.5000000000001L, 4503599627370496.0L);
4636 TEST_f_f (ceil, 4503599627370496.5000000000001L, 4503599627370497.0L);
4637 TEST_f_f (ceil, -4503599627370494.5000000000001L, -4503599627370494.0L);
4638 TEST_f_f (ceil, -4503599627370495.5000000000001L, -4503599627370495.0L);
4639 TEST_f_f (ceil, -4503599627370496.5000000000001L, -4503599627370496.0L);
4640# endif
4641
f964490f
RM
4642 TEST_f_f (ceil, 9007199254740991.5L, 9007199254740992.0L);
4643 TEST_f_f (ceil, 9007199254740992.25L, 9007199254740993.0L);
4644 TEST_f_f (ceil, 9007199254740992.5L, 9007199254740993.0L);
4645 TEST_f_f (ceil, 9007199254740992.75L, 9007199254740993.0L);
4646 TEST_f_f (ceil, 9007199254740993.5L, 9007199254740994.0L);
4647
4648 TEST_f_f (ceil, -9007199254740991.5L, -9007199254740991.0L);
4649 TEST_f_f (ceil, -9007199254740992.25L, -9007199254740992.0L);
4650 TEST_f_f (ceil, -9007199254740992.5L, -9007199254740992.0L);
4651 TEST_f_f (ceil, -9007199254740992.75L, -9007199254740992.0L);
4652 TEST_f_f (ceil, -9007199254740993.5L, -9007199254740993.0L);
4653
5c68d401
RM
4654# if LDBL_MANT_DIG > 100
4655 TEST_f_f (ceil, 9007199254740991.0000000000001L, 9007199254740992.0L);
4656 TEST_f_f (ceil, 9007199254740992.0000000000001L, 9007199254740993.0L);
4657 TEST_f_f (ceil, 9007199254740993.0000000000001L, 9007199254740994.0L);
4658 TEST_f_f (ceil, 9007199254740991.5000000000001L, 9007199254740992.0L);
4659 TEST_f_f (ceil, 9007199254740992.5000000000001L, 9007199254740993.0L);
4660 TEST_f_f (ceil, 9007199254740993.5000000000001L, 9007199254740994.0L);
4661
4662 TEST_f_f (ceil, -9007199254740991.0000000000001L, -9007199254740991.0L);
4663 TEST_f_f (ceil, -9007199254740992.0000000000001L, -9007199254740992.0L);
4664 TEST_f_f (ceil, -9007199254740993.0000000000001L, -9007199254740993.0L);
4665 TEST_f_f (ceil, -9007199254740991.5000000000001L, -9007199254740991.0L);
4666 TEST_f_f (ceil, -9007199254740992.5000000000001L, -9007199254740992.0L);
4667 TEST_f_f (ceil, -9007199254740993.5000000000001L, -9007199254740993.0L);
4668# endif
4669
f964490f
RM
4670 TEST_f_f (ceil, 72057594037927935.5L, 72057594037927936.0L);
4671 TEST_f_f (ceil, 72057594037927936.25L, 72057594037927937.0L);
4672 TEST_f_f (ceil, 72057594037927936.5L, 72057594037927937.0L);
4673 TEST_f_f (ceil, 72057594037927936.75L, 72057594037927937.0L);
4674 TEST_f_f (ceil, 72057594037927937.5L, 72057594037927938.0L);
4675
4676 TEST_f_f (ceil, -72057594037927935.5L, -72057594037927935.0L);
4677 TEST_f_f (ceil, -72057594037927936.25L, -72057594037927936.0L);
4678 TEST_f_f (ceil, -72057594037927936.5L, -72057594037927936.0L);
4679 TEST_f_f (ceil, -72057594037927936.75L, -72057594037927936.0L);
4680 TEST_f_f (ceil, -72057594037927937.5L, -72057594037927937.0L);
4681
4682 TEST_f_f (ceil, 10141204801825835211973625643007.5L, 10141204801825835211973625643008.0L);
4683 TEST_f_f (ceil, 10141204801825835211973625643008.25L, 10141204801825835211973625643009.0L);
4684 TEST_f_f (ceil, 10141204801825835211973625643008.5L, 10141204801825835211973625643009.0L);
4685 TEST_f_f (ceil, 10141204801825835211973625643008.75L, 10141204801825835211973625643009.0L);
4686 TEST_f_f (ceil, 10141204801825835211973625643009.5L, 10141204801825835211973625643010.0L);
4687#endif
4688
8847214f
UD
4689 END (ceil);
4690}
4691
4692
4693static void
4694cexp_test (void)
4695{
aaca11d8
UD
4696 errno = 0;
4697 FUNC(cexp) (BUILD_COMPLEX (0, 0));
4698 if (errno == ENOSYS)
4699 /* Function not implemented. */
4700 return;
4701
8847214f
UD
4702 START (cexp);
4703
4704 TEST_c_c (cexp, plus_zero, plus_zero, 1, 0.0);
4705 TEST_c_c (cexp, minus_zero, plus_zero, 1, 0.0);
4706 TEST_c_c (cexp, plus_zero, minus_zero, 1, minus_zero);
4707 TEST_c_c (cexp, minus_zero, minus_zero, 1, minus_zero);
4708
4709 TEST_c_c (cexp, plus_infty, plus_zero, plus_infty, 0.0);
4710 TEST_c_c (cexp, plus_infty, minus_zero, plus_infty, minus_zero);
4711
4712 TEST_c_c (cexp, minus_infty, plus_zero, 0.0, 0.0);
4713 TEST_c_c (cexp, minus_infty, minus_zero, 0.0, minus_zero);
4714
67e971f1
TS
4715 TEST_c_c (cexp, 0.0, plus_infty, qnan_value, qnan_value, INVALID_EXCEPTION);
4716 TEST_c_c (cexp, minus_zero, plus_infty, qnan_value, qnan_value, INVALID_EXCEPTION);
8847214f 4717
67e971f1
TS
4718 TEST_c_c (cexp, 0.0, minus_infty, qnan_value, qnan_value, INVALID_EXCEPTION);
4719 TEST_c_c (cexp, minus_zero, minus_infty, qnan_value, qnan_value, INVALID_EXCEPTION);
8847214f 4720
67e971f1
TS
4721 TEST_c_c (cexp, 100.0, plus_infty, qnan_value, qnan_value, INVALID_EXCEPTION);
4722 TEST_c_c (cexp, -100.0, plus_infty, qnan_value, qnan_value, INVALID_EXCEPTION);
8847214f 4723
67e971f1
TS
4724 TEST_c_c (cexp, 100.0, minus_infty, qnan_value, qnan_value, INVALID_EXCEPTION);
4725 TEST_c_c (cexp, -100.0, minus_infty, qnan_value, qnan_value, INVALID_EXCEPTION);
8847214f
UD
4726
4727 TEST_c_c (cexp, minus_infty, 2.0, minus_zero, 0.0);
4728 TEST_c_c (cexp, minus_infty, 4.0, minus_zero, minus_zero);
4729 TEST_c_c (cexp, plus_infty, 2.0, minus_infty, plus_infty);
4730 TEST_c_c (cexp, plus_infty, 4.0, minus_infty, minus_infty);
4731
67e971f1
TS
4732 TEST_c_c (cexp, plus_infty, plus_infty, plus_infty, qnan_value, INVALID_EXCEPTION|IGNORE_ZERO_INF_SIGN);
4733 TEST_c_c (cexp, plus_infty, minus_infty, plus_infty, qnan_value, INVALID_EXCEPTION|IGNORE_ZERO_INF_SIGN);
8847214f
UD
4734
4735 TEST_c_c (cexp, minus_infty, plus_infty, 0.0, 0.0, IGNORE_ZERO_INF_SIGN);
4736 TEST_c_c (cexp, minus_infty, minus_infty, 0.0, minus_zero, IGNORE_ZERO_INF_SIGN);
4737
67e971f1 4738 TEST_c_c (cexp, minus_infty, qnan_value, 0, 0, IGNORE_ZERO_INF_SIGN);
8847214f 4739
67e971f1 4740 TEST_c_c (cexp, plus_infty, qnan_value, plus_infty, qnan_value);
8847214f 4741
67e971f1
TS
4742 TEST_c_c (cexp, qnan_value, 0.0, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
4743 TEST_c_c (cexp, qnan_value, 1.0, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
8847214f 4744
67e971f1
TS
4745 TEST_c_c (cexp, qnan_value, plus_infty, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
4746 TEST_c_c (cexp, 0, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
4747 TEST_c_c (cexp, 1, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
4748 TEST_c_c (cexp, qnan_value, qnan_value, qnan_value, qnan_value);
8847214f 4749
9d0c92b2 4750 TEST_c_c (cexp, 0.75L, 1.25L, 0.667537446429131586942201977015932112L, 2.00900045494094876258347228145863909L);
d8337213 4751 TEST_c_c (cexp, -2.0, -3.0, -0.13398091492954261346140525546115575L, -0.019098516261135196432576240858800925L);
8847214f 4752
1a4ac776
JM
4753 TEST_c_c (cexp, 0, 0x1p65, 0.99888622066058013610642172179340364209972L, -0.047183876212354673805106149805700013943218L);
4754 TEST_c_c (cexp, 0, -0x1p65, 0.99888622066058013610642172179340364209972L, 0.047183876212354673805106149805700013943218L);
4755 TEST_c_c (cexp, 50, 0x1p127, 4.053997150228616856622417636046265337193e21L, 3.232070315463388524466674772633810238819e21L);
4756
4757#ifndef TEST_FLOAT
4758 TEST_c_c (cexp, 0, 1e22, 0.5232147853951389454975944733847094921409L, -0.8522008497671888017727058937530293682618L);
4759 TEST_c_c (cexp, 0, 0x1p1023, -0.826369834614147994500785680811743734805L, 0.5631277798508840134529434079444683477104L);
4760 TEST_c_c (cexp, 500, 0x1p1023, -1.159886268932754433233243794561351783426e217L, 7.904017694554466595359379965081774849708e216L);
4761#endif
4762
4763#if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
4764 TEST_c_c (cexp, 0, 0x1p16383L, 0.9210843909921906206874509522505756251609L, 0.3893629985894208126948115852610595405563L);
4765 TEST_c_c (cexp, -10000, 0x1p16383L, 1.045876464564882298442774542991176546722e-4343L, 4.421154026488516836023811173959413420548e-4344L);
4766#endif
4767
7c69cd14 4768 TEST_c_c (cexp, 88.75, 0.75, 2.558360358486542817001900410314204322891e38L, 2.383359453227311447654736314679677655100e38L);
80bad0cc 4769 TEST_c_c (cexp, -95, 0.75, 4.039714446238306526889476684000081624047e-42L, 3.763383677300535390271646960780570275931e-42L, UNDERFLOW_EXCEPTION_FLOAT);
7c69cd14
JM
4770
4771#ifndef TEST_FLOAT
4772 TEST_c_c (cexp, 709.8125, 0.75, 1.355121963080879535248452862759108365762e308L, 1.262426823598609432507811340856186873507e308L);
80bad0cc 4773 TEST_c_c (cexp, -720, 0.75, 1.486960657116368433685753325516638551722e-313L, 1.385247284245720590980701226843815229385e-313L, UNDERFLOW_EXCEPTION_DOUBLE);
7c69cd14
JM
4774#endif
4775
4776#if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
4777 TEST_c_c (cexp, 11356.5625, 0.75, 9.052188470850960144814815984311663764287e4931L, 8.432986734191301036267148978260970230200e4931L);
80bad0cc 4778 TEST_c_c (cexp, -11370, 0.75, 8.631121063182211587489310508568170739592e-4939L, 8.040721827809267291427062346918413482824e-4939L, UNDERFLOW_EXCEPTION);
7c69cd14
JM
4779#endif
4780
4781#ifdef TEST_FLOAT
4782 TEST_c_c (cexp, 180, 0x1p-149, plus_infty, 2.087071793345235105931967606907855310664e33L, OVERFLOW_EXCEPTION);
4783#endif
4784
4785#if defined TEST_DOUBLE || (defined TEST_LDOUBLE && LDBL_MAX_EXP == 1024)
4786 TEST_c_c (cexp, 1440, 0x1p-1074, plus_infty, 1.196295853897226111293303155636183216483e302L, OVERFLOW_EXCEPTION);
4787#endif
4788
4789#if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
4790 TEST_c_c (cexp, 22730, 0x1p-16434L, plus_infty, 2.435706297811211974162115164702304105374e4924L, OVERFLOW_EXCEPTION);
4791#endif
4792
4793 TEST_c_c (cexp, 1e6, 0, plus_infty, 0, OVERFLOW_EXCEPTION);
4794 TEST_c_c (cexp, 1e6, min_value, plus_infty, plus_infty, OVERFLOW_EXCEPTION);
4795 TEST_c_c (cexp, 1e6, -min_value, plus_infty, minus_infty, OVERFLOW_EXCEPTION);
4796
05e166c8
JM
4797 TEST_c_c (cexp, min_value, min_subnorm_value, 1.0, min_subnorm_value, UNDERFLOW_EXCEPTION);
4798 TEST_c_c (cexp, min_value, -min_subnorm_value, 1.0, -min_subnorm_value, UNDERFLOW_EXCEPTION);
4799
6815fabc 4800 END (cexp, complex);
8847214f
UD
4801}
4802
2550dfe9 4803
0cdc8e6f
UD
4804static void
4805cimag_test (void)
4806{
4807 START (cimag);
4808 TEST_c_f (cimag, 1.0, 0.0, 0.0);
4809 TEST_c_f (cimag, 1.0, minus_zero, minus_zero);
67e971f1
TS
4810 TEST_c_f (cimag, 1.0, qnan_value, qnan_value);
4811 TEST_c_f (cimag, qnan_value, qnan_value, qnan_value);
0cdc8e6f
UD
4812 TEST_c_f (cimag, 1.0, plus_infty, plus_infty);
4813 TEST_c_f (cimag, 1.0, minus_infty, minus_infty);
4814 TEST_c_f (cimag, 2.0, 3.0, 3.0);
4815
4816 END (cimag);
4817}
4818
8847214f
UD
4819static void
4820clog_test (void)
4821{
aaca11d8
UD
4822 errno = 0;
4823 FUNC(clog) (BUILD_COMPLEX (-2, -3));
4824 if (errno == ENOSYS)
4825 /* Function not implemented. */
4826 return;
4827
8847214f
UD
4828 START (clog);
4829
4830 TEST_c_c (clog, minus_zero, 0, minus_infty, M_PIl, DIVIDE_BY_ZERO_EXCEPTION);
4831 TEST_c_c (clog, minus_zero, minus_zero, minus_infty, -M_PIl, DIVIDE_BY_ZERO_EXCEPTION);
4832
4833 TEST_c_c (clog, 0, 0, minus_infty, 0.0, DIVIDE_BY_ZERO_EXCEPTION);
4834 TEST_c_c (clog, 0, minus_zero, minus_infty, minus_zero, DIVIDE_BY_ZERO_EXCEPTION);
4835
4836 TEST_c_c (clog, minus_infty, plus_infty, plus_infty, M_PI_34l);
4837 TEST_c_c (clog, minus_infty, minus_infty, plus_infty, -M_PI_34l);
4838
4839 TEST_c_c (clog, plus_infty, plus_infty, plus_infty, M_PI_4l);
4840 TEST_c_c (clog, plus_infty, minus_infty, plus_infty, -M_PI_4l);
4841
4842 TEST_c_c (clog, 0, plus_infty, plus_infty, M_PI_2l);
4843 TEST_c_c (clog, 3, plus_infty, plus_infty, M_PI_2l);
4844 TEST_c_c (clog, minus_zero, plus_infty, plus_infty, M_PI_2l);
4845 TEST_c_c (clog, -3, plus_infty, plus_infty, M_PI_2l);
4846 TEST_c_c (clog, 0, minus_infty, plus_infty, -M_PI_2l);
4847 TEST_c_c (clog, 3, minus_infty, plus_infty, -M_PI_2l);
4848 TEST_c_c (clog, minus_zero, minus_infty, plus_infty, -M_PI_2l);
4849 TEST_c_c (clog, -3, minus_infty, plus_infty, -M_PI_2l);
4850
4851 TEST_c_c (clog, minus_infty, 0, plus_infty, M_PIl);
4852 TEST_c_c (clog, minus_infty, 1, plus_infty, M_PIl);
4853 TEST_c_c (clog, minus_infty, minus_zero, plus_infty, -M_PIl);
4854 TEST_c_c (clog, minus_infty, -1, plus_infty, -M_PIl);
4855
4856 TEST_c_c (clog, plus_infty, 0, plus_infty, 0.0);
4857 TEST_c_c (clog, plus_infty, 1, plus_infty, 0.0);
4858 TEST_c_c (clog, plus_infty, minus_zero, plus_infty, minus_zero);
4859 TEST_c_c (clog, plus_infty, -1, plus_infty, minus_zero);
4860
67e971f1
TS
4861 TEST_c_c (clog, plus_infty, qnan_value, plus_infty, qnan_value);
4862 TEST_c_c (clog, minus_infty, qnan_value, plus_infty, qnan_value);
8847214f 4863
67e971f1
TS
4864 TEST_c_c (clog, qnan_value, plus_infty, plus_infty, qnan_value);
4865 TEST_c_c (clog, qnan_value, minus_infty, plus_infty, qnan_value);
8847214f 4866
67e971f1
TS
4867 TEST_c_c (clog, 0, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
4868 TEST_c_c (clog, 3, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
4869 TEST_c_c (clog, minus_zero, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
4870 TEST_c_c (clog, -3, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
8847214f 4871
67e971f1
TS
4872 TEST_c_c (clog, qnan_value, 0, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
4873 TEST_c_c (clog, qnan_value, 5, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
4874 TEST_c_c (clog, qnan_value, minus_zero, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
4875 TEST_c_c (clog, qnan_value, -5, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
8847214f 4876
67e971f1 4877 TEST_c_c (clog, qnan_value, qnan_value, qnan_value, qnan_value);
2550dfe9
AJ
4878
4879 TEST_c_c (clog, 0.75L, 1.25L, 0.376885901188190075998919126749298416L, 1.03037682652431246378774332703115153L);
33e885db 4880 TEST_c_c (clog, -2, -3, 1.2824746787307683680267437207826593L, -2.1587989303424641704769327722648368L);
8847214f 4881
1897ad44 4882 TEST_c_c (clog, 0x1.fffffep+127L, 0x1.fffffep+127L, 89.06941264234832570836679262104313101776L, M_PI_4l);
80bad0cc 4883 TEST_c_c (clog, 0x1.fffffep+127L, 1.0L, 88.72283905206835305365817656031404273372L, 2.938736052218037251011746307725933020145e-39L, UNDERFLOW_EXCEPTION_FLOAT);
1897ad44
JM
4884 TEST_c_c (clog, 0x1p-149L, 0x1p-149L, -102.9323563131518784484589700365392203592L, M_PI_4l);
4885 TEST_c_c (clog, 0x1p-147L, 0x1p-147L, -101.5460619520319878296245057936228672231L, M_PI_4l);
4886
4887#ifndef TEST_FLOAT
4888 TEST_c_c (clog, 0x1.fffffffffffffp+1023L, 0x1.fffffffffffffp+1023L, 710.1292864836639693869320059713862337880L, M_PI_4l);
4889 TEST_c_c (clog, 0x1.fffffffffffffp+1023L, 0x1p+1023L, 709.8942846690411016323109979483151967689L, 0.4636476090008061606231772164674799632783L);
4890 TEST_c_c (clog, 0x1p-1074L, 0x1p-1074L, -744.0934983311012896593986823853525458290L, M_PI_4l);
4891 TEST_c_c (clog, 0x1p-1073L, 0x1p-1073L, -743.4003511505413443499814502638943692610L, M_PI_4l);
4892#endif
4893
4894#if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
4895 TEST_c_c (clog, 0x1.fp+16383L, 0x1.fp+16383L, 11356.83823118610934184548269774874545400L, M_PI_4l);
4896 TEST_c_c (clog, 0x1.fp+16383L, 0x1p+16383L, 11356.60974243783798653123798337822335902L, 0.4764674194737066993385333770295162295856L);
4897 TEST_c_c (clog, 0x1p-16440L, 0x1p-16441L, -11395.22807662984378194141292922726786191L, 0.4636476090008061162142562314612144020285L);
4898#endif
4899
638a572e
JM
4900 TEST_c_c (clog, 0x1p-149L, 0x1.fp+127L, 88.69109041335841930424871526389807508374L, M_PI_2l);
4901 TEST_c_c (clog, -0x1p-149L, 0x1.fp+127L, 88.69109041335841930424871526389807508374L, M_PI_2l);
4902 TEST_c_c (clog, 0x1p-149L, -0x1.fp+127L, 88.69109041335841930424871526389807508374L, -M_PI_2l);
4903 TEST_c_c (clog, -0x1p-149L, -0x1.fp+127L, 88.69109041335841930424871526389807508374L, -M_PI_2l);
4904 TEST_c_c (clog, -0x1.fp+127L, 0x1p-149L, 88.69109041335841930424871526389807508374L, M_PIl);
4905 TEST_c_c (clog, -0x1.fp+127L, -0x1p-149L, 88.69109041335841930424871526389807508374L, -M_PIl);
4906#ifdef TEST_FLOAT
4907 TEST_c_c (clog, 0x1.fp+127L, 0x1p-149L, 88.69109041335841930424871526389807508374L, plus_zero, UNDERFLOW_EXCEPTION);
4908 TEST_c_c (clog, 0x1.fp+127L, -0x1p-149L, 88.69109041335841930424871526389807508374L, minus_zero, UNDERFLOW_EXCEPTION);
4909#endif
4910
4911#ifndef TEST_FLOAT
4912 TEST_c_c (clog, 0x1p-1074L, 0x1.fp+1023L, 709.7509641950694165420886960904242800794L, M_PI_2l);
4913 TEST_c_c (clog, -0x1p-1074L, 0x1.fp+1023L, 709.7509641950694165420886960904242800794L, M_PI_2l);
4914 TEST_c_c (clog, 0x1p-1074L, -0x1.fp+1023L, 709.7509641950694165420886960904242800794L, -M_PI_2l);
4915 TEST_c_c (clog, -0x1p-1074L, -0x1.fp+1023L, 709.7509641950694165420886960904242800794L, -M_PI_2l);
4916 TEST_c_c (clog, -0x1.fp+1023L, 0x1p-1074L, 709.7509641950694165420886960904242800794L, M_PIl);
4917 TEST_c_c (clog, -0x1.fp+1023L, -0x1p-1074L, 709.7509641950694165420886960904242800794L, -M_PIl);
4918#endif
4919#if defined TEST_DOUBLE || (defined TEST_LDOUBLE && LDBL_MAX_EXP == 1024)
4920 TEST_c_c (clog, 0x1.fp+1023L, 0x1p-1074L, 709.7509641950694165420886960904242800794L, plus_zero, UNDERFLOW_EXCEPTION);
4921 TEST_c_c (clog, 0x1.fp+1023L, -0x1p-1074L, 709.7509641950694165420886960904242800794L, minus_zero, UNDERFLOW_EXCEPTION);
4922#endif
4923
4924#if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
4925 TEST_c_c (clog, 0x1p-16445L, 0x1.fp+16383L, 11356.49165759582936919077408168801636572L, M_PI_2l);
4926 TEST_c_c (clog, -0x1p-16445L, 0x1.fp+16383L, 11356.49165759582936919077408168801636572L, M_PI_2l);
4927 TEST_c_c (clog, 0x1p-16445L, -0x1.fp+16383L, 11356.49165759582936919077408168801636572L, -M_PI_2l);
4928 TEST_c_c (clog, -0x1p-16445L, -0x1.fp+16383L, 11356.49165759582936919077408168801636572L, -M_PI_2l);
4929 TEST_c_c (clog, -0x1.fp+16383L, 0x1p-16445L, 11356.49165759582936919077408168801636572L, M_PIl);
4930 TEST_c_c (clog, -0x1.fp+16383L, -0x1p-16445L, 11356.49165759582936919077408168801636572L, -M_PIl);
4931 TEST_c_c (clog, 0x1.fp+16383L, 0x1p-16445L, 11356.49165759582936919077408168801636572L, plus_zero, UNDERFLOW_EXCEPTION);
4932 TEST_c_c (clog, 0x1.fp+16383L, -0x1p-16445L, 11356.49165759582936919077408168801636572L, minus_zero, UNDERFLOW_EXCEPTION);
4933# if LDBL_MANT_DIG >= 113
4934 TEST_c_c (clog, 0x1p-16494L, 0x1.fp+16383L, 11356.49165759582936919077408168801636572L, M_PI_2l);
4935 TEST_c_c (clog, -0x1p-16494L, 0x1.fp+16383L, 11356.49165759582936919077408168801636572L, M_PI_2l);
4936 TEST_c_c (clog, 0x1p-16494L, -0x1.fp+16383L, 11356.49165759582936919077408168801636572L, -M_PI_2l);
4937 TEST_c_c (clog, -0x1p-16494L, -0x1.fp+16383L, 11356.49165759582936919077408168801636572L, -M_PI_2l);
4938 TEST_c_c (clog, -0x1.fp+16383L, 0x1p-16494L, 11356.49165759582936919077408168801636572L, M_PIl);
4939 TEST_c_c (clog, -0x1.fp+16383L, -0x1p-16494L, 11356.49165759582936919077408168801636572L, -M_PIl);
4940 TEST_c_c (clog, 0x1.fp+16383L, 0x1p-16494L, 11356.49165759582936919077408168801636572L, plus_zero, UNDERFLOW_EXCEPTION);
4941 TEST_c_c (clog, 0x1.fp+16383L, -0x1p-16494L, 11356.49165759582936919077408168801636572L, minus_zero, UNDERFLOW_EXCEPTION);
4942# endif
4943#endif
4944
da865e95
JM
4945 TEST_c_c (clog, 1.0L, 0x1.234566p-10L, 6.172834701221959432440126967147726538097e-7L, 1.111110564353742042376451655136933182201e-3L);
4946 TEST_c_c (clog, -1.0L, 0x1.234566p-20L, 5.886877547844618300918562490463748605537e-13L, 3.141591568520436206990380699322226378452L);
4947 TEST_c_c (clog, 0x1.234566p-30L, 1.0L, 5.614163921211322622623353961365728040115e-19L, 1.570796325735258575254858696548386439740L);
4948 TEST_c_c (clog, -0x1.234566p-40L, -1.0L, 5.354083939753840089583620652120903838944e-25L, -1.570796326795931422008642456283782656359L);
4949 TEST_c_c (clog, 0x1.234566p-50L, 1.0L, 5.106052341226425256332038420428899201070e-31L, 1.570796326794895608681734464330528755366L);
4950 TEST_c_c (clog, 0x1.234566p-60L, 1.0L, 4.869510976053643471080816669875627875933e-37L, 1.570796326794896618244456860363082279319L);
4951 TEST_c_c (clog, 0x1p-62L, 1.0L, 2.350988701644575015937473074444491355582e-38L, 1.570796326794896619014481257142650555297L);
4952 TEST_c_c (clog, 0x1p-63L, 1.0L, 5.877471754111437539843682686111228389059e-39L, 1.570796326794896619122901474391200998698L, UNDERFLOW_EXCEPTION_FLOAT);
4953 TEST_c_c (clog, 0x1p-64L, 1.0L, 1.469367938527859384960920671527807097271e-39L, 1.570796326794896619177111583015476220398L, UNDERFLOW_EXCEPTION_FLOAT);
4954#ifndef TEST_FLOAT
4955 TEST_c_c (clog, 0x1p-510L, 1.0L, 4.450147717014402766180465434664808128438e-308L, 1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM);
4956 TEST_c_c (clog, 0x1p-511L, 1.0L, 1.112536929253600691545116358666202032110e-308L, 1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION_DOUBLE);
4957 TEST_c_c (clog, 0x1p-512L, 1.0L, 2.781342323134001728862790896665505080274e-309L, 1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION_DOUBLE);
4958#endif
4959#if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
4960 TEST_c_c (clog, 0x1p-8190L, 1.0L, 6.724206286224187012525355634643505205196e-4932L, 1.570796326794896619231321691639751442099L);
4961 TEST_c_c (clog, 0x1p-8191L, 1.0L, 1.681051571556046753131338908660876301299e-4932L, 1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION);
4962 TEST_c_c (clog, 0x1p-8192L, 1.0L, 4.202628928890116882828347271652190753248e-4933L, 1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION);
4963#endif
4964
d0419dbf
JM
4965 TEST_c_c (clog, 0x1.000566p0L, 0x1.234p-10L, 8.298731898331237038231468223024422855654e-5L, 1.110938609507128729312743251313024793990e-3L);
4966 TEST_c_c (clog, 0x1.000566p0L, 0x1.234p-100L, 8.237022655933121125560939513260027133767e-5L, 8.974094312218060110948251664314290484113e-31L);
4967#ifndef TEST_FLOAT
4968 TEST_c_c (clog, -0x1.0000000123456p0L, 0x1.2345678p-30L, 2.649094282537168795982991778475646793277e-10L, 3.141592652530155111500161671113150737892L);
4969 TEST_c_c (clog, -0x1.0000000123456p0L, 0x1.2345678p-1000L, 2.649094276923003995420209214900915462737e-10L, 3.141592653589793238462643383279502884197L);
4970#endif
4971#if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 106
4972 TEST_c_c (clog, 0x1.00000000000000123456789abcp0L, 0x1.23456789p-60L, 9.868649107778739757272772275265050767867e-19L, 9.868649106423871142816660980898339912137e-19L);
c9c0279b 4973 TEST_c_c (clog, 0x1.00000000000000123456789abcp0L, 0x1.23456789p-1000L, 9.868649107778739752403260515979017248596e-19L, 1.061846605795612822522063052130030717368e-301L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM);
d0419dbf
JM
4974#endif
4975
d032e0d2
JM
4976 TEST_c_c (clog, 0x0.ffffffp0L, 0x0.ffffffp-100L, -5.960464655174753498633255797994360530379e-8L, 7.888609052210118054117285652827862296732e-31L);
4977#ifndef TEST_FLOAT
c9c0279b 4978 TEST_c_c (clog, 0x0.fffffffffffff8p0L, 0x0.fffffffffffff8p-1000L, -1.110223024625156602053389888482372171810e-16L, 9.332636185032188789900895447238171696171e-302L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM);
d032e0d2
JM
4979#endif
4980#if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
4981 TEST_c_c (clog, 0x0.ffffffffffffffffp0L, 0x0.ffffffffffffffffp-15000L, -5.421010862427522170184200798202494495630e-20L, 3.548665303440282824232502561095699343814e-4516L);
4982#endif
4983
4984 TEST_c_c (clog, 0x1a6p-10L, 0x3a5p-10L, -1.4305135209763571252847059962654228661815e-06L, 1.1460277178115757370775644871674016684074L);
4985 TEST_c_c (clog, 0xf2p-10L, 0x3e3p-10L, 6.1988446308070710970664736815277450078106e-06L, 1.3322126499153926210226335249558203898460L);
4986 TEST_c_c (clog, 0x4d4ep-15L, 0x6605p-15L, -1.6298145321400412054744424587143483169412e-08L, 0.9223574537155056772124552172295398141249L);
4987 TEST_c_c (clog, 0x2818p-15L, 0x798fp-15L, 1.5366822245016167178749091974664853785194e-08L, 1.2522014929038946066987318471922169174157L);
4988 TEST_c_c (clog, 0x9b57bp-20L, 0xcb7b4p-20L, -3.9563019528687610863490232935890272740908e-11L, 0.9187593477446338910857133065497364950682L);
4989 TEST_c_c (clog, 0x2731p-20L, 0xfffd0p-20L, 4.4110493034041283943115971658295280288115e-11L, 1.5612279663766352262688735061954290528838L);
4990 TEST_c_c (clog, 0x2ede88p-23L, 0x771c3fp-23L, -4.4764192352906350039050902870893173560494e-13L, 1.1959106857549200806818600493552847793381L);
4991 TEST_c_c (clog, 0x11682p-23L, 0x7ffed1p-23L, 1.1723955140027907954461000991619077811832e-12L, 1.5622968405332756349813737986164832897108L);
4992 TEST_c_c (clog, 0xa1f2c1p-24L, 0xc643aep-24L, -1.0480505352462576151523512837107080269981e-13L, 0.8858771987699967480545613322309315260313L);
4993 TEST_c_c (clog, 0x659feap-24L, 0xeaf6f9p-24L, 3.7303493627403868207597214252239749960738e-14L, 1.1625816408046866464773042283673653469061L);
4994#ifndef TEST_FLOAT
4995 TEST_c_c (clog, 0x4447d7175p-35L, 0x6c445e00ap-35L, -1.4823076576950255933915367361099865652625e-20L, 1.0081311552703893116404606212158840190615L);
4996 TEST_c_c (clog, 0x2dd46725bp-35L, 0x7783a1284p-35L, 4.4469229730850767799109418892826021157328e-20L, 1.2046235979300843056806465045930070146351L);
4997 TEST_c_c (clog, 0x164c74eea876p-45L, 0x16f393482f77p-45L, -3.0292258760486853327810377824479932031744e-26L, 0.7998237934177411746093524982030330293980L);
4998 TEST_c_c (clog, 0xfe961079616p-45L, 0x1bc37e09e6d1p-45L, 5.3718272201930019901317065495843842735179e-26L, 1.0503831592447830576186444373011142397404L);
4999 TEST_c_c (clog, 0xa4722f19346cp-51L, 0x7f9631c5e7f07p-51L, -6.2122796286154679676173624516405339768606e-30L, 1.4904138780720095276446375492434049214172L);
5000 TEST_c_c (clog, 0x10673dd0f2481p-51L, 0x7ef1d17cefbd2p-51L, 3.2047474274603604594851472963586149973093e-29L, 1.4422922682185099608731642353544207976604L);
5001 TEST_c_c (clog, 0x8ecbf810c4ae6p-52L, 0xd479468b09a37p-52L, -9.7375017988218644730510244778042114638107e-30L, 0.9790637929494922564724108399524154766631L);
5002 TEST_c_c (clog, 0x5b06b680ea2ccp-52L, 0xef452b965da9fp-52L, 8.3076914081087805757422664530653247447136e-30L, 1.2072712126771536614482822173033535043206L);
5003 TEST_c_c (clog, 0x659b70ab7971bp-53L, 0x1f5d111e08abecp-53L, -2.5083311595699359750201056724289010648701e-30L, 1.3710185432462268491534742969536240564640L);
5004 TEST_c_c (clog, 0x15cfbd1990d1ffp-53L, 0x176a3973e09a9ap-53L, 1.0168910106364605304135563536838075568606e-30L, 0.8208373755522359859870890246475340086663L);
5005 TEST_c_c (clog, 0x1367a310575591p-54L, 0x3cfcc0a0541f60p-54L, 5.0844550531823026520677817684239496041087e-32L, 1.2627468605458094918919206628466016525397L);
5006 TEST_c_c (clog, 0x55cb6d0c83af5p-55L, 0x7fe33c0c7c4e90p-55L, -5.2000108498455368032511404449795741611813e-32L, 1.5288921536982513453421343495466824420259L);
5007#endif
5008#if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 64
5009 TEST_c_c (clog, 0x298c62cb546588a7p-63L, 0x7911b1dfcc4ecdaep-63L, -1.1931267660846218205882675852805793644095e-36L, 1.2402109774337032400594953899784058127412L);
5010 TEST_c_c (clog, 0x4d9c37e2b5cb4533p-63L, 0x65c98be2385a042ep-63L, 6.4064442119814669184296141278612389400075e-37L, 0.9193591364645830864185131402313014890145L);
5011 TEST_c_c (clog, 0x602fd5037c4792efp-64L, 0xed3e2086dcca80b8p-64L, -2.3362950222592964220878638677292132852104e-37L, 1.1856121127236268105413184264288408265852L);
5012 TEST_c_c (clog, 0x6b10b4f3520217b6p-64L, 0xe8893cbb449253a1p-64L, 2.4244570985709679851855191080208817099132e-37L, 1.1393074519572050614551047548718495655972L);
5013 TEST_c_c (clog, 0x81b7efa81fc35ad1p-65L, 0x1ef4b835f1c79d812p-65L, -9.9182335850630508484862145328126979066934e-39L, 1.3146479888794807046338799047003947008804L);
5014#endif
5015#if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 106
5016 TEST_c_c (clog, 0x3f96469050f650869c2p-75L, 0x6f16b2c9c8b05988335p-75L, -1.0509738482436128031927971874674370984602e-45L, 1.0509191467640012308402149909370784281448L);
5017 TEST_c_c (clog, 0x3157fc1d73233e580c8p-75L, 0x761b52ccd435d7c7f5fp-75L, 1.3487497719126364307640897239165442763573e-43L, 1.1750493008528425228929764149024375035382L);
5018 TEST_c_c (clog, 0x155f8afc4c48685bf63610p-85L, 0x17d0cf2652cdbeb1294e19p-85L, -4.7775669192897997174762089350332738583822e-50L, 0.8393953487996880419413728440067635213372L);
5019 TEST_c_c (clog, 0x13836d58a13448d750b4b9p-85L, 0x195ca7bc3ab4f9161edbe6p-85L, 2.8398125044729578740243199963484494962411e-50L, 0.9149964976334130461795060758257083099706L);
5020 TEST_c_c (clog, 0x1df515eb171a808b9e400266p-95L, 0x7c71eb0cd4688dfe98581c77p-95L, -3.5048022044913950094635368750889659723004e-57L, 1.3345633256521815205858155673950177421079L);
5021 TEST_c_c (clog, 0xe33f66c9542ca25cc43c867p-95L, 0x7f35a68ebd3704a43c465864p-95L, 4.1101771307217268747345114262406964584250e-56L, 1.4596065864518742494094402406719567059585L);
5022 TEST_c_c (clog, 0x6771f22c64ed551b857c128b4cp-105L, 0x1f570e7a13cc3cf2f44fd793ea1p-105L, -1.4281333889622737316199756373421183559948e-62L, 1.3673546561165378090903506783353927980633L);
5023 TEST_c_c (clog, 0x15d8ab6ed05ca514086ac3a1e84p-105L, 0x1761e480aa094c0b10b34b09ce9p-105L, 1.0027319539522347477331743836657426754857e-62L, 0.8193464073721167323313606647411269414759L);
5024 TEST_c_c (clog, 0x187190c1a334497bdbde5a95f48p-106L, 0x3b25f08062d0a095c4cfbbc338dp-106L, -1.7471844652198029695350765775994001163767e-63L, 1.1789110097072986038243729592318526094314L);
5025 TEST_c_c (clog, 0x6241ef0da53f539f02fad67dabp-106L, 0x3fb46641182f7efd9caa769dac0p-106L, 4.3299788920664682288477984749202524623248e-63L, 1.4746938237585656250866370987773473745867L);
5026#endif
5027#if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 113
5028 TEST_c_c (clog, 0x3e1d0a105ac4ebeacd9c6952d34cp-112L, 0xf859b3d1b06d005dcbb5516d5479p-112L, -1.1683999374665377365054966073875064467108e-66L, 1.3257197596350832748781065387304444940172L);
5029 TEST_c_c (clog, 0x47017a2e36807acb1e5214b209dep-112L, 0xf5f4a550c9d75e3bb1839d865f0dp-112L, 1.5077923002544367932999503838191154621839e-65L, 1.2897445708311412721399861948957141824914L);
5030 TEST_c_c (clog, 0x148f818cb7a9258fca942ade2a0cap-113L, 0x18854a34780b8333ec53310ad7001p-113L, -7.1865869169568789348552370692485515571497e-67L, 0.8730167479365994646287897223471819363668L);
5031 TEST_c_c (clog, 0xfd95243681c055c2632286921092p-113L, 0x1bccabcd29ca2152860ec29e34ef7p-113L, 6.6255694866654064502633121109394710807528e-66L, 1.0526409614996288387567810726095850312049L);
5032 TEST_c_c (clog, 0xdb85c467ee2aadd5f425fe0f4b8dp-114L, 0x3e83162a0f95f1dcbf97dddf410eap-114L, 4.6017338806965821566734340588575402712716e-67L, 1.3547418904611758959096647942223384691728L);
5033 TEST_c_c (clog, 0x1415bcaf2105940d49a636e98ae59p-115L, 0x7e6a150adfcd1b0921d44b31f40f4p-115L, 2.5993421227864195179698176012564317527271e-67L, 1.4132318089683022770487383611430906982461L);
5034#endif
5035
6815fabc 5036 END (clog, complex);
8847214f
UD
5037}
5038
5039
5040static void
5041clog10_test (void)
5042{
aaca11d8 5043 errno = 0;
3c6cad26 5044 FUNC(clog10) (BUILD_COMPLEX (0.7L, 1.2L));
aaca11d8
UD
5045 if (errno == ENOSYS)
5046 /* Function not implemented. */
5047 return;
5048
8847214f
UD
5049 START (clog10);
5050
5051 TEST_c_c (clog10, minus_zero, 0, minus_infty, M_PIl, DIVIDE_BY_ZERO_EXCEPTION);
5052 TEST_c_c (clog10, minus_zero, minus_zero, minus_infty, -M_PIl, DIVIDE_BY_ZERO_EXCEPTION);
5053
5054 TEST_c_c (clog10, 0, 0, minus_infty, 0.0, DIVIDE_BY_ZERO_EXCEPTION);
5055 TEST_c_c (clog10, 0, minus_zero, minus_infty, minus_zero, DIVIDE_BY_ZERO_EXCEPTION);
5056
5057 TEST_c_c (clog10, minus_infty, plus_infty, plus_infty, M_PI_34_LOG10El);
5058
5059 TEST_c_c (clog10, plus_infty, plus_infty, plus_infty, M_PI4_LOG10El);
5060 TEST_c_c (clog10, plus_infty, minus_infty, plus_infty, -M_PI4_LOG10El);
5061
5062 TEST_c_c (clog10, 0, plus_infty, plus_infty, M_PI2_LOG10El);
5063 TEST_c_c (clog10, 3, plus_infty, plus_infty, M_PI2_LOG10El);
5064 TEST_c_c (clog10, minus_zero, plus_infty, plus_infty, M_PI2_LOG10El);
5065 TEST_c_c (clog10, -3, plus_infty, plus_infty, M_PI2_LOG10El);
5066 TEST_c_c (clog10, 0, minus_infty, plus_infty, -M_PI2_LOG10El);
5067 TEST_c_c (clog10, 3, minus_infty, plus_infty, -M_PI2_LOG10El);
5068 TEST_c_c (clog10, minus_zero, minus_infty, plus_infty, -M_PI2_LOG10El);
5069 TEST_c_c (clog10, -3, minus_infty, plus_infty, -M_PI2_LOG10El);
5070
5071 TEST_c_c (clog10, minus_infty, 0, plus_infty, M_PI_LOG10El);
5072 TEST_c_c (clog10, minus_infty, 1, plus_infty, M_PI_LOG10El);
5073 TEST_c_c (clog10, minus_infty, minus_zero, plus_infty, -M_PI_LOG10El);
5074 TEST_c_c (clog10, minus_infty, -1, plus_infty, -M_PI_LOG10El);
5075
5076 TEST_c_c (clog10, plus_infty, 0, plus_infty, 0.0);
5077 TEST_c_c (clog10, plus_infty, 1, plus_infty, 0.0);
5078 TEST_c_c (clog10, plus_infty, minus_zero, plus_infty, minus_zero);
5079 TEST_c_c (clog10, plus_infty, -1, plus_infty, minus_zero);
5080
67e971f1
TS
5081 TEST_c_c (clog10, plus_infty, qnan_value, plus_infty, qnan_value);
5082 TEST_c_c (clog10, minus_infty, qnan_value, plus_infty, qnan_value);
8847214f 5083
67e971f1
TS
5084 TEST_c_c (clog10, qnan_value, plus_infty, plus_infty, qnan_value);
5085 TEST_c_c (clog10, qnan_value, minus_infty, plus_infty, qnan_value);
8847214f 5086
67e971f1
TS
5087 TEST_c_c (clog10, 0, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
5088 TEST_c_c (clog10, 3, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
5089 TEST_c_c (clog10, minus_zero, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
5090 TEST_c_c (clog10, -3, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
8847214f 5091
67e971f1
TS
5092 TEST_c_c (clog10, qnan_value, 0, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
5093 TEST_c_c (clog10, qnan_value, 5, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
5094 TEST_c_c (clog10, qnan_value, minus_zero, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
5095 TEST_c_c (clog10, qnan_value, -5, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
8847214f 5096
67e971f1 5097 TEST_c_c (clog10, qnan_value, qnan_value, qnan_value, qnan_value);
8847214f 5098
2550dfe9 5099 TEST_c_c (clog10, 0.75L, 1.25L, 0.163679467193165171449476605077428975L, 0.447486970040493067069984724340855636L);
79df8ce5 5100 TEST_c_c (clog10, -2, -3, 0.556971676153418384603252578971164214L, -0.937554462986374708541507952140189646L);
8847214f 5101
1897ad44 5102 TEST_c_c (clog10, 0x1.fffffep+127L, 0x1.fffffep+127L, 38.68235441693561449174780668781319348761L, M_PI4_LOG10El);
80bad0cc 5103 TEST_c_c (clog10, 0x1.fffffep+127L, 1.0L, 38.53183941910362389414093724045094697423L, 1.276276851248440096917018665609900318458e-39L, UNDERFLOW_EXCEPTION_FLOAT);
1897ad44
JM
5104 TEST_c_c (clog10, 0x1p-149L, 0x1p-149L, -44.70295435610120748924022586658721447508L, M_PI4_LOG10El);
5105 TEST_c_c (clog10, 0x1p-147L, 0x1p-147L, -44.10089436477324509881274807713822842154L, M_PI4_LOG10El);
5106
5107#ifndef TEST_FLOAT
5108 TEST_c_c (clog10, 0x1.fffffffffffffp+1023L, 0x1.fffffffffffffp+1023L, 308.4052305577487344482591243175787477115L, M_PI4_LOG10El);
5109 TEST_c_c (clog10, 0x1.fffffffffffffp+1023L, 0x1p+1023L, 308.3031705664207720674749211936626341569L, 0.2013595981366865903254995612594728746470L);
5110 TEST_c_c (clog10, 0x1p-1074L, 0x1p-1074L, -323.1557003452838130619487034867432642357L, M_PI4_LOG10El);
5111 TEST_c_c (clog10, 0x1p-1073L, 0x1p-1073L, -322.8546703496198318667349645920187712089L, M_PI4_LOG10El);
5112#endif
5113
5114#if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
5115 TEST_c_c (clog10, 0x1.fp+16383L, 0x1.fp+16383L, 4932.212175672014259683102930239951947672L, M_PI4_LOG10El);
5116 TEST_c_c (clog10, 0x1.fp+16383L, 0x1p+16383L, 4932.112944269463028900262609694408579449L, 0.2069271710841128115912940666587802677383L);
5117 TEST_c_c (clog10, 0x1p-16440L, 0x1p-16441L, -4948.884673709346821106688037612752099609L, 0.2013595981366865710389502301937289472543L);
5118#endif
5119
638a572e
JM
5120 TEST_c_c (clog10, 0x1p-149L, 0x1.fp+127L, 38.51805116050395969095658815123105801479L, 0.6821881769209206737428918127156778851051L);
5121 TEST_c_c (clog10, -0x1p-149L, 0x1.fp+127L, 38.51805116050395969095658815123105801479L, 0.6821881769209206737428918127156778851051L);
5122 TEST_c_c (clog10, 0x1p-149L, -0x1.fp+127L, 38.51805116050395969095658815123105801479L, -0.6821881769209206737428918127156778851051L);
5123 TEST_c_c (clog10, -0x1p-149L, -0x1.fp+127L, 38.51805116050395969095658815123105801479L, -0.6821881769209206737428918127156778851051L);
5124 TEST_c_c (clog10, -0x1.fp+127L, 0x1p-149L, 38.51805116050395969095658815123105801479L, 1.364376353841841347485783625431355770210L);
5125 TEST_c_c (clog10, -0x1.fp+127L, -0x1p-149L, 38.51805116050395969095658815123105801479L, -1.364376353841841347485783625431355770210L);
5126#ifdef TEST_FLOAT
5127 TEST_c_c (clog10, 0x1.fp+127L, 0x1p-149L, 38.51805116050395969095658815123105801479L, plus_zero, UNDERFLOW_EXCEPTION);
5128 TEST_c_c (clog10, 0x1.fp+127L, -0x1p-149L, 38.51805116050395969095658815123105801479L, minus_zero, UNDERFLOW_EXCEPTION);
5129#endif
5130
5131#ifndef TEST_FLOAT
5132 TEST_c_c (clog10, 0x1p-1074L, 0x1.fp+1023L, 308.2409272754311106024666378243768099991L, 0.6821881769209206737428918127156778851051L);
5133 TEST_c_c (clog10, -0x1p-1074L, 0x1.fp+1023L, 308.2409272754311106024666378243768099991L, 0.6821881769209206737428918127156778851051L);
5134 TEST_c_c (clog10, 0x1p-1074L, -0x1.fp+1023L, 308.2409272754311106024666378243768099991L, -0.6821881769209206737428918127156778851051L);
5135 TEST_c_c (clog10, -0x1p-1074L, -0x1.fp+1023L, 308.2409272754311106024666378243768099991L, -0.6821881769209206737428918127156778851051L);
5136 TEST_c_c (clog10, -0x1.fp+1023L, 0x1p-1074L, 308.2409272754311106024666378243768099991L, 1.364376353841841347485783625431355770210L);
5137 TEST_c_c (clog10, -0x1.fp+1023L, -0x1p-1074L, 308.2409272754311106024666378243768099991L, -1.364376353841841347485783625431355770210L);
5138#endif
5139#if defined TEST_DOUBLE || (defined TEST_LDOUBLE && LDBL_MAX_EXP == 1024)
5140 TEST_c_c (clog10, 0x1.fp+1023L, 0x1p-1074L, 308.2409272754311106024666378243768099991L, plus_zero, UNDERFLOW_EXCEPTION);
5141 TEST_c_c (clog10, 0x1.fp+1023L, -0x1p-1074L, 308.2409272754311106024666378243768099991L, minus_zero, UNDERFLOW_EXCEPTION);
5142#endif
5143
5144#if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
5145 TEST_c_c (clog10, 0x1p-16445L, 0x1.fp+16383L, 4932.061660674182269085496060792589701158L, 0.6821881769209206737428918127156778851051L);
5146 TEST_c_c (clog10, -0x1p-16445L, 0x1.fp+16383L, 4932.061660674182269085496060792589701158L, 0.6821881769209206737428918127156778851051L);
5147 TEST_c_c (clog10, 0x1p-16445L, -0x1.fp+16383L, 4932.061660674182269085496060792589701158L, -0.6821881769209206737428918127156778851051L);
5148 TEST_c_c (clog10, -0x1p-16445L, -0x1.fp+16383L, 4932.061660674182269085496060792589701158L, -0.6821881769209206737428918127156778851051L);
5149 TEST_c_c (clog10, -0x1.fp+16383L, 0x1p-16445L, 4932.061660674182269085496060792589701158L, 1.364376353841841347485783625431355770210L);
5150 TEST_c_c (clog10, -0x1.fp+16383L, -0x1p-16445L, 4932.061660674182269085496060792589701158L, -1.364376353841841347485783625431355770210L);
5151 TEST_c_c (clog10, 0x1.fp+16383L, 0x1p-16445L, 4932.061660674182269085496060792589701158L, plus_zero, UNDERFLOW_EXCEPTION);
5152 TEST_c_c (clog10, 0x1.fp+16383L, -0x1p-16445L, 4932.061660674182269085496060792589701158L, minus_zero, UNDERFLOW_EXCEPTION);
5153# if LDBL_MANT_DIG >= 113
5154 TEST_c_c (clog10, 0x1p-16494L, 0x1.fp+16383L, 4932.061660674182269085496060792589701158L, 0.6821881769209206737428918127156778851051L);
5155 TEST_c_c (clog10, -0x1p-16494L, 0x1.fp+16383L, 4932.061660674182269085496060792589701158L, 0.6821881769209206737428918127156778851051L);
5156 TEST_c_c (clog10, 0x1p-16494L, -0x1.fp+16383L, 4932.061660674182269085496060792589701158L, -0.6821881769209206737428918127156778851051L);
5157 TEST_c_c (clog10, -0x1p-16494L, -0x1.fp+16383L, 4932.061660674182269085496060792589701158L, -0.6821881769209206737428918127156778851051L);
5158 TEST_c_c (clog10, -0x1.fp+16383L, 0x1p-16494L, 4932.061660674182269085496060792589701158L, 1.364376353841841347485783625431355770210L);
5159 TEST_c_c (clog10, -0x1.fp+16383L, -0x1p-16494L, 4932.061660674182269085496060792589701158L, -1.364376353841841347485783625431355770210L);
5160 TEST_c_c (clog10, 0x1.fp+16383L, 0x1p-16494L, 4932.061660674182269085496060792589701158L, plus_zero, UNDERFLOW_EXCEPTION);
5161 TEST_c_c (clog10, 0x1.fp+16383L, -0x1p-16494L, 4932.061660674182269085496060792589701158L, minus_zero, UNDERFLOW_EXCEPTION);
5162# endif
5163#endif
5164
da865e95
JM
5165 TEST_c_c (clog10, 1.0L, 0x1.234566p-10L, 2.680828048441605163181684680300513080769e-7L, 4.825491868832381486767558728169977751564e-4L);
5166 TEST_c_c (clog10, -1.0L, 0x1.234566p-20L, 2.556638434669064077889576526006849923281e-13L, 1.364375882602207106407956770293808181427L);
5167 TEST_c_c (clog10, 0x1.234566p-30L, 1.0L, 2.438200411482400072282924063740535840474e-19L, 6.821881764607257184291586401763604544928e-1L);
5168 TEST_c_c (clog10, -0x1.234566p-40L, -1.0L, 2.325249110681915353442924915876654139373e-25L, -6.821881769213700828789403802671540158935e-1L);
5169 TEST_c_c (clog10, 0x1.234566p-50L, 1.0L, 2.217530356103816369479108963807448194409e-31L, 6.821881769209202348667823902864283966959e-1L);
5170 TEST_c_c (clog10, 0x1.234566p-60L, 1.0L, 2.114801746467415208319767917450504756866e-37L, 6.821881769209206733143018621078368211515e-1L);
5171 TEST_c_c (clog10, 0x1p-61L, 1.0L, 4.084085680564517578238994467153626207224e-38L, 6.821881769209206735545466044044889962925e-1L);
5172 TEST_c_c (clog10, 0x1p-62L, 1.0L, 1.021021420141129394559748616788406551878e-38L, 6.821881769209206736487192085600834406988e-1L, UNDERFLOW_EXCEPTION_FLOAT);
5173 TEST_c_c (clog10, 0x1p-63L, 1.0L, 2.552553550352823486399371541971016379740e-39L, 6.821881769209206736958055106378806629019e-1L, UNDERFLOW_EXCEPTION_FLOAT);
5174#ifndef TEST_FLOAT
5175 TEST_c_c (clog10, 0x1p-509L, 1.0L, 7.730698388614835910296270976605350994446e-308L, 6.821881769209206737428918127156778851051e-1L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM);
5176 TEST_c_c (clog10, 0x1p-510L, 1.0L, 1.932674597153708977574067744151337748612e-308L, 6.821881769209206737428918127156778851051e-1L, UNDERFLOW_EXCEPTION_DOUBLE);
5177 TEST_c_c (clog10, 0x1p-511L, 1.0L, 4.831686492884272443935169360378344371529e-309L, 6.821881769209206737428918127156778851051e-1L, UNDERFLOW_EXCEPTION_DOUBLE);
5178#endif
5179#if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
5180 TEST_c_c (clog10, 0x1p-8189L, 1.0L, 1.168114274114528946314738738025008370069e-4931L, 6.821881769209206737428918127156778851051e-1L);
5181 TEST_c_c (clog10, 0x1p-8190L, 1.0L, 2.920285685286322365786846845062520925172e-4932L, 6.821881769209206737428918127156778851051e-1L, UNDERFLOW_EXCEPTION);
5182 TEST_c_c (clog10, 0x1p-8191L, 1.0L, 7.300714213215805914467117112656302312931e-4933L, 6.821881769209206737428918127156778851051e-1L, UNDERFLOW_EXCEPTION);
5183#endif
5184
d0419dbf
JM
5185 TEST_c_c (clog10, 0x1.000566p0L, 0x1.234p-10L, 3.604093470239754109961125085078190708674e-5L, 4.824745078422174667425851670822596859720e-4L);
5186 TEST_c_c (clog10, 0x1.000566p0L, 0x1.234p-100L, 3.577293486783822178310971763308187385546e-5L, 3.897399639875661463735636919790792140598e-31L);
5187#ifndef TEST_FLOAT
5188 TEST_c_c (clog10, -0x1.0000000123456p0L, 0x1.2345678p-30L, 1.150487028947346337782682105935961875822e-10L, 1.364376353381646356131680448946397884147L);
5189 TEST_c_c (clog10, -0x1.0000000123456p0L, 0x1.2345678p-1000L, 1.150487026509145544402795327729455391948e-10L, 1.364376353841841347485783625431355770210L);
5190#endif
5191#if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 106
5192 TEST_c_c (clog10, 0x1.00000000000000123456789abcp0L, 0x1.23456789p-60L, 4.285899851347756188767674032946882584784e-19L, 4.285899850759344225805480528847018395861e-19L);
c9c0279b 5193 TEST_c_c (clog10, 0x1.00000000000000123456789abcp0L, 0x1.23456789p-1000L, 4.285899851347756186652871946325962330640e-19L, 4.611541215247321502041995872887317363241e-302L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM);
d0419dbf
JM
5194#endif
5195
d032e0d2
JM
5196 TEST_c_c (clog10, 0x0.ffffffp0L, 0x0.ffffffp-100L, -2.588596909321764128428416045209904492216e-8L, 3.425979381266895667295625489912064603415e-31L);
5197#ifndef TEST_FLOAT
c9c0279b 5198 TEST_c_c (clog10, 0x0.fffffffffffff8p0L, 0x0.fffffffffffff8p-1000L, -4.821637332766435821255375046554377090472e-17L, 4.053112396770095089737411317782466262176e-302L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM);
d032e0d2
JM
5199#endif
5200#if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
5201 TEST_c_c (clog10, 0x0.ffffffffffffffffp0L, 0x0.ffffffffffffffffp-15000L, -2.354315103889861110220423157644627849164e-20L, 1.541165759405643564697852372112893034397e-4516L);
5202#endif
5203
5204 TEST_c_c (clog10, 0x1a6p-10L, 0x3a5p-10L, -6.2126412844802358329771948751248003038444e-07L, 0.4977135139537443711784513409096950995985L);
5205 TEST_c_c (clog10, 0xf2p-10L, 0x3e3p-10L, 2.6921240173351112953324592659528481616879e-06L, 0.5785726025799636431142862788413361783862L);
5206 TEST_c_c (clog10, 0x4d4ep-15L, 0x6605p-15L, -7.0781945783414996953799915941870192015212e-09L, 0.4005747524909781155537088181659175147564L);
5207 TEST_c_c (clog10, 0x2818p-15L, 0x798fp-15L, 6.6737261053986614395049481326819059203910e-09L, 0.5438241985991753781478398141908629586460L);
5208 TEST_c_c (clog10, 0x9b57bp-20L, 0xcb7b4p-20L, -1.7182001068739620267773842120965071561416e-11L, 0.3990121149225253562859800593935899629087L);
5209 TEST_c_c (clog10, 0x2731p-20L, 0xfffd0p-20L, 1.9156943718715958194239364991329064049438e-11L, 0.6780326907904082601285090019969008967595L);
5210 TEST_c_c (clog10, 0x2ede88p-23L, 0x771c3fp-23L, -1.9440841725722970687903291200493082253766e-13L, 0.5193774116724956222518530053006822210323L);
5211 TEST_c_c (clog10, 0x11682p-23L, 0x7ffed1p-23L, 5.0916490233953865181284669870035717560498e-13L, 0.6784968969384861816694467029319146542069L);
5212 TEST_c_c (clog10, 0xa1f2c1p-24L, 0xc643aep-24L, -4.5516256421319921959681423447271490869664e-14L, 0.3847315790697197749315054516562206543710L);
5213 TEST_c_c (clog10, 0x659feap-24L, 0xeaf6f9p-24L, 1.6200701438094619117335617123525612051457e-14L, 0.5049027913635038013499728086604870749732L);
5214#ifndef TEST_FLOAT
5215 TEST_c_c (clog10, 0x4447d7175p-35L, 0x6c445e00ap-35L, -6.4375803621988389731799033530075237868110e-21L, 0.4378257977686804492768642780897650927167L);
5216 TEST_c_c (clog10, 0x2dd46725bp-35L, 0x7783a1284p-35L, 1.9312741086596516918394613098872836703188e-20L, 0.5231613813514771042838490538484014771862L);
5217 TEST_c_c (clog10, 0x164c74eea876p-45L, 0x16f393482f77p-45L, -1.3155760824064879362415202279780039150764e-26L, 0.3473590599762514228227328130640352044313L);
5218 TEST_c_c (clog10, 0xfe961079616p-45L, 0x1bc37e09e6d1p-45L, 2.3329549194675052736016290082882121135546e-26L, 0.4561756099441139182878993697611751382976L);
5219 TEST_c_c (clog10, 0xa4722f19346cp-51L, 0x7f9631c5e7f07p-51L, -2.6979587627476803379953050733225113494503e-30L, 0.6472785229986997177606324374555347813105L);
5220 TEST_c_c (clog10, 0x10673dd0f2481p-51L, 0x7ef1d17cefbd2p-51L, 1.3918041236396763648388478552321724382899e-29L, 0.6263795733790237053262025311642907438291L);
5221 TEST_c_c (clog10, 0x8ecbf810c4ae6p-52L, 0xd479468b09a37p-52L, -4.2289432987513243393180377141513840878196e-30L, 0.4252020027092323591068799049905597805296L);
5222 TEST_c_c (clog10, 0x5b06b680ea2ccp-52L, 0xef452b965da9fp-52L, 3.6079845358966994996207055940336690133424e-30L, 0.5243112258263349992771652393178033846555L);
5223 TEST_c_c (clog10, 0x659b70ab7971bp-53L, 0x1f5d111e08abecp-53L, -1.0893543813872082317104059174982092534059e-30L, 0.5954257879188711495921161433751775633232L);
5224 TEST_c_c (clog10, 0x15cfbd1990d1ffp-53L, 0x176a3973e09a9ap-53L, 4.4163015461643576961232672330852798804976e-31L, 0.3564851427422832755956993418877523303529L);
5225 TEST_c_c (clog10, 0x1367a310575591p-54L, 0x3cfcc0a0541f60p-54L, 2.2081507730821788480616336165447731164865e-32L, 0.5484039935757001196548030312819898864760L);
5226 TEST_c_c (clog10, 0x55cb6d0c83af5p-55L, 0x7fe33c0c7c4e90p-55L, -2.2583360179249556400630343805573865814771e-32L, 0.6639894257763289307423302343317622430835L);
5227#endif
5228#if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 64
5229 TEST_c_c (clog10, 0x298c62cb546588a7p-63L, 0x7911b1dfcc4ecdaep-63L, -5.1816837072162316773907242302011632570857e-37L, 0.5386167838952956925896424154370364458140L);
5230 TEST_c_c (clog10, 0x4d9c37e2b5cb4533p-63L, 0x65c98be2385a042ep-63L, 2.7822833698845776001753149807484078521508e-37L, 0.3992725998539071066769046272515417679815L);
5231 TEST_c_c (clog10, 0x602fd5037c4792efp-64L, 0xed3e2086dcca80b8p-64L, -1.0146400362652473358437501879334790111898e-37L, 0.5149047982335273098246594109614460842099L);
5232 TEST_c_c (clog10, 0x6b10b4f3520217b6p-64L, 0xe8893cbb449253a1p-64L, 1.0529283395205396881397407610630442563938e-37L, 0.4947949395762683446121140513971996916447L);
5233 TEST_c_c (clog10, 0x81b7efa81fc35ad1p-65L, 0x1ef4b835f1c79d812p-65L, -4.3074341162203896332989394770760901408798e-39L, 0.5709443672155660428417571212549720987784L);
5234#endif
5235#if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 106
5236 TEST_c_c (clog10, 0x3f96469050f650869c2p-75L, 0x6f16b2c9c8b05988335p-75L, -4.5643214291682663316715446865040356750881e-46L, 0.4564083863660793840592614609053162690362L);
5237 TEST_c_c (clog10, 0x3157fc1d73233e580c8p-75L, 0x761b52ccd435d7c7f5fp-75L, 5.8575458340992751256451490143468457830297e-44L, 0.5103174273246635294300470585396890237265L);
5238 TEST_c_c (clog10, 0x155f8afc4c48685bf63610p-85L, 0x17d0cf2652cdbeb1294e19p-85L, -2.0748709499710785084693619097712106753591e-50L, 0.3645447681189598740620098186365764884771L);
5239 TEST_c_c (clog10, 0x13836d58a13448d750b4b9p-85L, 0x195ca7bc3ab4f9161edbe6p-85L, 1.2333149003324592532859843519619084433953e-50L, 0.3973779298829931059309198145608711073016L);
5240 TEST_c_c (clog10, 0x1df515eb171a808b9e400266p-95L, 0x7c71eb0cd4688dfe98581c77p-95L, -1.5221162575729652613635150540947625639689e-57L, 0.5795934880811949230121092882659698986043L);
5241 TEST_c_c (clog10, 0xe33f66c9542ca25cc43c867p-95L, 0x7f35a68ebd3704a43c465864p-95L, 1.7850272475173865337808494725293124613817e-56L, 0.6338990862456906754888183278564382516852L);
5242 TEST_c_c (clog10, 0x6771f22c64ed551b857c128b4cp-105L, 0x1f570e7a13cc3cf2f44fd793ea1p-105L, -6.2023045024810589256360494043570293518879e-63L, 0.5938345819561308555003145899438513900776L);
5243 TEST_c_c (clog10, 0x15d8ab6ed05ca514086ac3a1e84p-105L, 0x1761e480aa094c0b10b34b09ce9p-105L, 4.3548095442952115860848857519953610343042e-63L, 0.3558376234889641500775150477035448866763L);
5244 TEST_c_c (clog10, 0x187190c1a334497bdbde5a95f48p-106L, 0x3b25f08062d0a095c4cfbbc338dp-106L, -7.5879257211204444302994221436282805900756e-64L, 0.5119945461708707332160859198685423099187L);
5245 TEST_c_c (clog10, 0x6241ef0da53f539f02fad67dabp-106L, 0x3fb46641182f7efd9caa769dac0p-106L, 1.8804859395820231849002915747252695375405e-63L, 0.6404513901551516189871978418046651877394L);
5246#endif
5247#if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 113
5248 TEST_c_c (clog10, 0x3e1d0a105ac4ebeacd9c6952d34cp-112L, 0xf859b3d1b06d005dcbb5516d5479p-112L, -5.0742964549782184008668435276046798273476e-67L, 0.5757527761596220360985719127090110408283L);
5249 TEST_c_c (clog10, 0x47017a2e36807acb1e5214b209dep-112L, 0xf5f4a550c9d75e3bb1839d865f0dp-112L, 6.5482587585671294601662599808612773010057e-66L, 0.5601289501766423782280643144987875760229L);
5250 TEST_c_c (clog10, 0x148f818cb7a9258fca942ade2a0cap-113L, 0x18854a34780b8333ec53310ad7001p-113L, -3.1210950417524756037077807411854181477733e-67L, 0.3791463562379872585396164879981280044658L);
5251 TEST_c_c (clog10, 0xfd95243681c055c2632286921092p-113L, 0x1bccabcd29ca2152860ec29e34ef7p-113L, 2.8774482675253468630312378575186855052697e-66L, 0.4571561610046221605554903008571429975493L);
5252 TEST_c_c (clog10, 0xdb85c467ee2aadd5f425fe0f4b8dp-114L, 0x3e83162a0f95f1dcbf97dddf410eap-114L, 1.9985076315737626043096596036300177494613e-67L, 0.5883569274304683249184005177865521205198L);
5253 TEST_c_c (clog10, 0x1415bcaf2105940d49a636e98ae59p-115L, 0x7e6a150adfcd1b0921d44b31f40f4p-115L, 1.1288799405048268615023706955013387413519e-67L, 0.6137587762850841972073301550420510507903L);
5254#endif
5255
6815fabc 5256 END (clog10, complex);
8847214f
UD
5257}
5258
2550dfe9 5259
0cdc8e6f
UD
5260static void
5261conj_test (void)
5262{
5263 START (conj);
5264 TEST_c_c (conj, 0.0, 0.0, 0.0, minus_zero);
5265 TEST_c_c (conj, 0.0, minus_zero, 0.0, 0.0);
67e971f1 5266 TEST_c_c (conj, qnan_value, qnan_value, qnan_value, qnan_value);
0cdc8e6f
UD
5267 TEST_c_c (conj, plus_infty, minus_infty, plus_infty, plus_infty);
5268 TEST_c_c (conj, plus_infty, plus_infty, plus_infty, minus_infty);
5269 TEST_c_c (conj, 1.0, 2.0, 1.0, -2.0);
5270 TEST_c_c (conj, 3.0, -4.0, 3.0, 4.0);
5271
5272 END (conj, complex);
5273}
5274
5275
8847214f
UD
5276static void
5277copysign_test (void)
5278{
5279 START (copysign);
5280
5281 TEST_ff_f (copysign, 0, 4, 0);
5282 TEST_ff_f (copysign, 0, -4, minus_zero);
5283 TEST_ff_f (copysign, minus_zero, 4, 0);
5284 TEST_ff_f (copysign, minus_zero, -4, minus_zero);
5285
5286 TEST_ff_f (copysign, plus_infty, 0, plus_infty);
5287 TEST_ff_f (copysign, plus_infty, minus_zero, minus_infty);
5288 TEST_ff_f (copysign, minus_infty, 0, plus_infty);
5289 TEST_ff_f (copysign, minus_infty, minus_zero, minus_infty);
5290
5291 TEST_ff_f (copysign, 0, plus_infty, 0);
5292 TEST_ff_f (copysign, 0, minus_zero, minus_zero);
5293 TEST_ff_f (copysign, minus_zero, plus_infty, 0);
5294 TEST_ff_f (copysign, minus_zero, minus_zero, minus_zero);
5295
5296 /* XXX More correctly we would have to check the sign of the NaN. */
67e971f1
TS
5297 TEST_ff_f (copysign, qnan_value, 0, qnan_value);
5298 TEST_ff_f (copysign, qnan_value, minus_zero, qnan_value);
5299 TEST_ff_f (copysign, -qnan_value, 0, qnan_value);
5300 TEST_ff_f (copysign, -qnan_value, minus_zero, qnan_value);
8847214f
UD
5301
5302 END (copysign);
5303}
5304
2550dfe9 5305
8847214f
UD
5306static void
5307cos_test (void)
5308{
e6d3c4a7
AJ
5309 errno = 0;
5310 FUNC(cos) (0);
5311 if (errno == ENOSYS)
5312 /* Function not implemented. */
5313 return;
5314
8847214f
UD
5315 START (cos);
5316
5317 TEST_f_f (cos, 0, 1);
5318 TEST_f_f (cos, minus_zero, 1);
0c59a196 5319 errno = 0;
67e971f1 5320 TEST_f_f (cos, plus_infty, qnan_value, INVALID_EXCEPTION);
0c59a196
UD
5321 check_int ("errno for cos(+inf) == EDOM", errno, EDOM, 0, 0, 0);
5322 errno = 0;
67e971f1 5323 TEST_f_f (cos, minus_infty, qnan_value, INVALID_EXCEPTION);
0c59a196
UD
5324 check_int ("errno for cos(-inf) == EDOM", errno, EDOM, 0, 0, 0);
5325 errno = 0;
67e971f1
TS
5326 TEST_f_f (cos, qnan_value, qnan_value);
5327 check_int ("errno for cos(qNaN) unchanged", errno, 0, 0, 0, 0);
8847214f
UD
5328
5329 TEST_f_f (cos, M_PI_6l * 2.0, 0.5);
5330 TEST_f_f (cos, M_PI_6l * 4.0, -0.5);
5331 TEST_f_f (cos, M_PI_2l, 0);
5332
2550dfe9 5333 TEST_f_f (cos, 0.75L, 0.731688868873820886311838753000084544L);
8847214f 5334
ea40808a
AJ
5335 TEST_f_f (cos, 0x1p65, 0.99888622066058013610642172179340364209972L);
5336 TEST_f_f (cos, -0x1p65, 0.99888622066058013610642172179340364209972L);
8c0247db 5337
d32e4346
RM
5338#ifdef TEST_DOUBLE
5339 TEST_f_f (cos, 0.80190127184058835, 0.69534156199418473);
8848d99d
JM
5340#endif
5341
7a845b2c
JM
5342 TEST_f_f (cos, 0x1.442f74p+15, 2.4407839902314016628485779006274989801517e-06L);
5343
8848d99d
JM
5344#ifndef TEST_FLOAT
5345 TEST_f_f (cos, 1e22, 0.5232147853951389454975944733847094921409L);
5346 TEST_f_f (cos, 0x1p1023, -0.826369834614147994500785680811743734805L);
5347#endif
5348
5349#if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
5350 TEST_f_f (cos, 0x1p16383L, 0.9210843909921906206874509522505756251609L);
d32e4346
RM
5351#endif
5352
4ffffbd2
LD
5353 TEST_f_f (cos, 0x1p+120, -9.25879022854837867303861764107414946730833e-01L);
5354 TEST_f_f (cos, 0x1p+127, 7.81914638714960072263910298466369236613162e-01L);
5355 TEST_f_f (cos, 0x1.fffff8p+127, 9.98819362551949040703862043664101081064641e-01L);
5356 TEST_f_f (cos, 0x1.fffffep+127, 8.53021039830304158051791467692161107353094e-01L);
5357 TEST_f_f (cos, 0x1p+50, 8.68095904660550604334592502063501320395739e-01L);
5358 TEST_f_f (cos, 0x1p+28, -1.65568979490578758865468278195361551113358e-01L);
5359
8847214f
UD
5360 END (cos);
5361}
5362
2550dfe9 5363
804360ed
JM
5364static void
5365cos_test_tonearest (void)
5366{
5367 int save_round_mode;
5368 errno = 0;
5369 FUNC(cos) (0);
5370 if (errno == ENOSYS)
5371 /* Function not implemented. */
5372 return;
5373
5374 START (cos_tonearest);
5375
5376 save_round_mode = fegetround ();
5377
5378 if (!fesetround (FE_TONEAREST))
5379 {
5380 TEST_f_f (cos, 1, 0.5403023058681397174009366074429766037323L);
5381 TEST_f_f (cos, 2, -0.4161468365471423869975682295007621897660L);
5382 TEST_f_f (cos, 3, -0.9899924966004454572715727947312613023937L);
5383 TEST_f_f (cos, 4, -0.6536436208636119146391681830977503814241L);
5384 TEST_f_f (cos, 5, 0.2836621854632262644666391715135573083344L);
5385 TEST_f_f (cos, 6, 0.9601702866503660205456522979229244054519L);
5386 TEST_f_f (cos, 7, 0.7539022543433046381411975217191820122183L);
5387 TEST_f_f (cos, 8, -0.1455000338086135258688413818311946826093L);
5388 TEST_f_f (cos, 9, -0.9111302618846769883682947111811653112463L);
5389 TEST_f_f (cos, 10, -0.8390715290764524522588639478240648345199L);
5390 }
5391
5392 fesetround (save_round_mode);
5393
5394 END (cos_tonearest);
5395}
5396
5397
5398static void
5399cos_test_towardzero (void)
5400{
5401 int save_round_mode;
5402 errno = 0;
5403 FUNC(cos) (0);
5404 if (errno == ENOSYS)
5405 /* Function not implemented. */
5406 return;
5407
5408 START (cos_towardzero);
5409
5410 save_round_mode = fegetround ();
5411
5412 if (!fesetround (FE_TOWARDZERO))
5413 {
5414 TEST_f_f (cos, 1, 0.5403023058681397174009366074429766037323L);
5415 TEST_f_f (cos, 2, -0.4161468365471423869975682295007621897660L);
5416 TEST_f_f (cos, 3, -0.9899924966004454572715727947312613023937L);
5417 TEST_f_f (cos, 4, -0.6536436208636119146391681830977503814241L);
5418 TEST_f_f (cos, 5, 0.2836621854632262644666391715135573083344L);
5419 TEST_f_f (cos, 6, 0.9601702866503660205456522979229244054519L);
5420 TEST_f_f (cos, 7, 0.7539022543433046381411975217191820122183L);
5421 TEST_f_f (cos, 8, -0.1455000338086135258688413818311946826093L);
5422 TEST_f_f (cos, 9, -0.9111302618846769883682947111811653112463L);
5423 TEST_f_f (cos, 10, -0.8390715290764524522588639478240648345199L);
5424 }
5425
5426 fesetround (save_round_mode);
5427
5428 END (cos_towardzero);
5429}
5430
5431
5432static void
5433cos_test_downward (void)
5434{
5435 int save_round_mode;
5436 errno = 0;
5437 FUNC(cos) (0);
5438 if (errno == ENOSYS)
5439 /* Function not implemented. */
5440 return;
5441
5442 START (cos_downward);
5443
5444 save_round_mode = fegetround ();
5445
5446 if (!fesetround (FE_DOWNWARD))
5447 {
5448 TEST_f_f (cos, 1, 0.5403023058681397174009366074429766037323L);
5449 TEST_f_f (cos, 2, -0.4161468365471423869975682295007621897660L);
5450 TEST_f_f (cos, 3, -0.9899924966004454572715727947312613023937L);
5451 TEST_f_f (cos, 4, -0.6536436208636119146391681830977503814241L);
5452 TEST_f_f (cos, 5, 0.2836621854632262644666391715135573083344L);
5453 TEST_f_f (cos, 6, 0.9601702866503660205456522979229244054519L);
5454 TEST_f_f (cos, 7, 0.7539022543433046381411975217191820122183L);
5455 TEST_f_f (cos, 8, -0.1455000338086135258688413818311946826093L);
5456 TEST_f_f (cos, 9, -0.9111302618846769883682947111811653112463L);
5457 TEST_f_f (cos, 10, -0.8390715290764524522588639478240648345199L);
5458 }
5459
5460 fesetround (save_round_mode);
5461
5462 END (cos_downward);
5463}
5464
5465
5466static void
5467cos_test_upward (void)
5468{
5469 int save_round_mode;
5470 errno = 0;
5471 FUNC(cos) (0);
5472 if (errno == ENOSYS)
5473 /* Function not implemented. */
5474 return;
5475
5476 START (cos_upward);
5477
5478 save_round_mode = fegetround ();
5479
5480 if (!fesetround (FE_UPWARD))
5481 {
5482 TEST_f_f (cos, 1, 0.5403023058681397174009366074429766037323L);
5483 TEST_f_f (cos, 2, -0.4161468365471423869975682295007621897660L);
5484 TEST_f_f (cos, 3, -0.9899924966004454572715727947312613023937L);
5485 TEST_f_f (cos, 4, -0.6536436208636119146391681830977503814241L);
5486 TEST_f_f (cos, 5, 0.2836621854632262644666391715135573083344L);
5487 TEST_f_f (cos, 6, 0.9601702866503660205456522979229244054519L);
5488 TEST_f_f (cos, 7, 0.7539022543433046381411975217191820122183L);
5489 TEST_f_f (cos, 8, -0.1455000338086135258688413818311946826093L);
5490 TEST_f_f (cos, 9, -0.9111302618846769883682947111811653112463L);
5491 TEST_f_f (cos, 10, -0.8390715290764524522588639478240648345199L);
5492 }
5493
5494 fesetround (save_round_mode);
5495
5496 END (cos_upward);
5497}
5498
5499
8847214f
UD
5500static void
5501cosh_test (void)
5502{
aaca11d8 5503 errno = 0;
3c6cad26 5504 FUNC(cosh) (0.7L);
aaca11d8
UD
5505 if (errno == ENOSYS)
5506 /* Function not implemented. */
5507 return;
5508
8847214f
UD
5509 START (cosh);
5510 TEST_f_f (cosh, 0, 1);
5511 TEST_f_f (cosh, minus_zero, 1);
5512
15daa639 5513#ifndef TEST_INLINE
8847214f
UD
5514 TEST_f_f (cosh, plus_infty, plus_infty);
5515 TEST_f_f (cosh, minus_infty, plus_infty);
15daa639 5516#endif
67e971f1 5517 TEST_f_f (cosh, qnan_value, qnan_value);
8847214f 5518
2550dfe9
AJ
5519 TEST_f_f (cosh, 0.75L, 1.29468328467684468784170818539018176L);
5520
e2283f38
JM
5521#ifndef TEST_FLOAT
5522 TEST_f_f (cosh, 709.8893558127259666434838436543941497802734375L, 9.9999998999995070652573675944761818416035e+307L);
5523 TEST_f_f (cosh, -709.8893558127259666434838436543941497802734375L, 9.9999998999995070652573675944761818416035e+307L);
5524#endif
5525
8847214f
UD
5526 END (cosh);
5527}
5528
5529
ca811b22
JM
5530static void
5531cosh_test_tonearest (void)
5532{
5533 int save_round_mode;
5534 errno = 0;
5535 FUNC(cosh) (0);
5536 if (errno == ENOSYS)
5537 /* Function not implemented. */
5538 return;
5539
5540 START (cosh_tonearest);
5541
5542 save_round_mode = fegetround ();
5543
5544 if (!fesetround (FE_TONEAREST))
5545 {
5546 TEST_f_f (cosh, 22, 1792456423.065795780980053377632656584997L);
5547 TEST_f_f (cosh, 23, 4872401723.124451300068625740569997090344L);
5548 TEST_f_f (cosh, 24, 13244561064.92173614708845674912733665919L);
5549 }
5550
5551 fesetround (save_round_mode);
5552
5553 END (cosh_tonearest);
5554}
5555
5556
5557static void
5558cosh_test_towardzero (void)
5559{
5560 int save_round_mode;
5561 errno = 0;
5562 FUNC(cosh) (0);
5563 if (errno == ENOSYS)
5564 /* Function not implemented. */
5565 return;
5566
5567 START (cosh_towardzero);
5568
5569 save_round_mode = fegetround ();
5570
5571 if (!fesetround (FE_TOWARDZERO))
5572 {
5573 TEST_f_f (cosh, 22, 1792456423.065795780980053377632656584997L);
5574 TEST_f_f (cosh, 23, 4872401723.124451300068625740569997090344L);
5575 TEST_f_f (cosh, 24, 13244561064.92173614708845674912733665919L);
5576 }
5577
5578 fesetround (save_round_mode);
5579
5580 END (cosh_towardzero);
5581}
5582
5583
5584static void
5585cosh_test_downward (void)
5586{
5587 int save_round_mode;
5588 errno = 0;
5589 FUNC(cosh) (0);
5590 if (errno == ENOSYS)
5591 /* Function not implemented. */
5592 return;
5593
5594 START (cosh_downward);
5595
5596 save_round_mode = fegetround ();
5597
5598 if (!fesetround (FE_DOWNWARD))
5599 {
5600 TEST_f_f (cosh, 22, 1792456423.065795780980053377632656584997L);
5601 TEST_f_f (cosh, 23, 4872401723.124451300068625740569997090344L);
5602 TEST_f_f (cosh, 24, 13244561064.92173614708845674912733665919L);
5603 }
5604
5605 fesetround (save_round_mode);
5606
5607 END (cosh_downward);
5608}
5609
5610
5611static void
5612cosh_test_upward (void)
5613{
5614 int save_round_mode;
5615 errno = 0;
5616 FUNC(cosh) (0);
5617 if (errno == ENOSYS)
5618 /* Function not implemented. */
5619 return;
5620
5621 START (cosh_upward);
5622
5623 save_round_mode = fegetround ();
5624
5625 if (!fesetround (FE_UPWARD))
5626 {
5627 TEST_f_f (cosh, 22, 1792456423.065795780980053377632656584997L);
5628 TEST_f_f (cosh, 23, 4872401723.124451300068625740569997090344L);
5629 TEST_f_f (cosh, 24, 13244561064.92173614708845674912733665919L);
5630 }
5631
5632 fesetround (save_round_mode);
5633
5634 END (cosh_upward);
5635}
5636
5637
8847214f
UD
5638static void
5639cpow_test (void)
5640{
aaca11d8
UD
5641 errno = 0;
5642 FUNC(cpow) (BUILD_COMPLEX (1, 0), BUILD_COMPLEX (0, 0));
5643 if (errno == ENOSYS)
5644 /* Function not implemented. */
5645 return;
5646
8847214f
UD
5647 START (cpow);
5648
5649 TEST_cc_c (cpow, 1, 0, 0, 0, 1.0, 0.0);
5650 TEST_cc_c (cpow, 2, 0, 10, 0, 1024.0, 0.0);
5651
5652 TEST_cc_c (cpow, M_El, 0, 0, 2 * M_PIl, 1.0, 0.0);
5653 TEST_cc_c (cpow, 2, 3, 4, 0, -119.0, -120.0);
5654
67e971f1 5655 TEST_cc_c (cpow, qnan_value, qnan_value, qnan_value, qnan_value, qnan_value, qnan_value);
15daa639 5656
96d10bdf
AJ
5657 TEST_cc_c (cpow, 0.75L, 1.25L, 0.75L, 1.25L, 0.117506293914473555420279832210420483L, 0.346552747708338676483025352060418001L);
5658 TEST_cc_c (cpow, 0.75L, 1.25L, 1.0L, 1.0L, 0.0846958290317209430433805274189191353L, 0.513285749182902449043287190519090481L);
2550dfe9 5659 TEST_cc_c (cpow, 0.75L, 1.25L, 1.0L, 0.0L, 0.75L, 1.25L);
96d10bdf 5660 TEST_cc_c (cpow, 0.75L, 1.25L, 0.0L, 1.0L, 0.331825439177608832276067945276730566L, 0.131338600281188544930936345230903032L);
2550dfe9 5661
6815fabc 5662 END (cpow, complex);
8847214f
UD
5663}
5664
2550dfe9 5665
8847214f
UD
5666static void
5667cproj_test (void)
5668{
5669 START (cproj);
5670 TEST_c_c (cproj, 0.0, 0.0, 0.0, 0.0);
5671 TEST_c_c (cproj, minus_zero, minus_zero, minus_zero, minus_zero);
5672 TEST_c_c (cproj, 0.0, minus_zero, 0.0, minus_zero);
5673 TEST_c_c (cproj, minus_zero, 0.0, minus_zero, 0.0);
5674
67e971f1 5675 TEST_c_c (cproj, qnan_value, qnan_value, qnan_value, qnan_value);
8847214f
UD
5676
5677 TEST_c_c (cproj, plus_infty, plus_infty, plus_infty, 0.0);
5678 TEST_c_c (cproj, plus_infty, minus_infty, plus_infty, minus_zero);
5679 TEST_c_c (cproj, minus_infty, plus_infty, plus_infty, 0.0);
5680 TEST_c_c (cproj, minus_infty, minus_infty, plus_infty, minus_zero);
5681
5682 TEST_c_c (cproj, 1.0, 0.0, 1.0, 0.0);
88e236a6 5683 TEST_c_c (cproj, 2.0, 3.0, 2.0, 3.0);
8847214f 5684
6815fabc 5685 END (cproj, complex);
8847214f
UD
5686}
5687
2550dfe9 5688
0cdc8e6f
UD
5689static void
5690creal_test (void)
5691{
5692 START (creal);
5693 TEST_c_f (creal, 0.0, 1.0, 0.0);
5694 TEST_c_f (creal, minus_zero, 1.0, minus_zero);
67e971f1
TS
5695 TEST_c_f (creal, qnan_value, 1.0, qnan_value);
5696 TEST_c_f (creal, qnan_value, qnan_value, qnan_value);
0cdc8e6f
UD
5697 TEST_c_f (creal, plus_infty, 1.0, plus_infty);
5698 TEST_c_f (creal, minus_infty, 1.0, minus_infty);
5699 TEST_c_f (creal, 2.0, 3.0, 2.0);
5700
5701 END (creal);
5702}
8847214f
UD
5703
5704static void
5705csin_test (void)
5706{
aaca11d8 5707 errno = 0;
3c6cad26 5708 FUNC(csin) (BUILD_COMPLEX (0.7L, 1.2L));
aaca11d8
UD
5709 if (errno == ENOSYS)
5710 /* Function not implemented. */
5711 return;
8847214f
UD
5712
5713 START (csin);
5714
5715 TEST_c_c (csin, 0.0, 0.0, 0.0, 0.0);
5716 TEST_c_c (csin, minus_zero, 0.0, minus_zero, 0.0);
5717 TEST_c_c (csin, 0.0, minus_zero, 0, minus_zero);
5718 TEST_c_c (csin, minus_zero, minus_zero, minus_zero, minus_zero);
5719
5720 TEST_c_c (csin, 0.0, plus_infty, 0.0, plus_infty);
5721 TEST_c_c (csin, minus_zero, plus_infty, minus_zero, plus_infty);
5722 TEST_c_c (csin, 0.0, minus_infty, 0.0, minus_infty);
5723 TEST_c_c (csin, minus_zero, minus_infty, minus_zero, minus_infty);
5724
67e971f1
TS
5725 TEST_c_c (csin, plus_infty, 0.0, qnan_value, 0.0, INVALID_EXCEPTION|IGNORE_ZERO_INF_SIGN);
5726 TEST_c_c (csin, minus_infty, 0.0, qnan_value, 0.0, INVALID_EXCEPTION|IGNORE_ZERO_INF_SIGN);
5727 TEST_c_c (csin, plus_infty, minus_zero, qnan_value, 0.0, INVALID_EXCEPTION|IGNORE_ZERO_INF_SIGN);
5728 TEST_c_c (csin, minus_infty, minus_zero, qnan_value, 0.0, INVALID_EXCEPTION|IGNORE_ZERO_INF_SIGN);
8847214f 5729
67e971f1
TS
5730 TEST_c_c (csin, plus_infty, plus_infty, qnan_value, plus_infty, INVALID_EXCEPTION|IGNORE_ZERO_INF_SIGN);
5731 TEST_c_c (csin, minus_infty, plus_infty, qnan_value, plus_infty, INVALID_EXCEPTION|IGNORE_ZERO_INF_SIGN);
5732 TEST_c_c (csin, plus_infty, minus_infty, qnan_value, plus_infty, INVALID_EXCEPTION|IGNORE_ZERO_INF_SIGN);
5733 TEST_c_c (csin, minus_infty, minus_infty, qnan_value, plus_infty, INVALID_EXCEPTION|IGNORE_ZERO_INF_SIGN);
8847214f 5734
67e971f1
TS
5735 TEST_c_c (csin, plus_infty, 6.75, qnan_value, qnan_value, INVALID_EXCEPTION);
5736 TEST_c_c (csin, plus_infty, -6.75, qnan_value, qnan_value, INVALID_EXCEPTION);
5737 TEST_c_c (csin, minus_infty, 6.75, qnan_value, qnan_value, INVALID_EXCEPTION);
5738 TEST_c_c (csin, minus_infty, -6.75, qnan_value, qnan_value, INVALID_EXCEPTION);
8847214f
UD
5739
5740 TEST_c_c (csin, 4.625, plus_infty, minus_infty, minus_infty);
5741 TEST_c_c (csin, 4.625, minus_infty, minus_infty, plus_infty);
5742 TEST_c_c (csin, -4.625, plus_infty, plus_infty, minus_infty);
5743 TEST_c_c (csin, -4.625, minus_infty, plus_infty, plus_infty);
5744
67e971f1
TS
5745 TEST_c_c (csin, qnan_value, 0.0, qnan_value, 0.0, IGNORE_ZERO_INF_SIGN);
5746 TEST_c_c (csin, qnan_value, minus_zero, qnan_value, 0.0, IGNORE_ZERO_INF_SIGN);
8847214f 5747
67e971f1
TS
5748 TEST_c_c (csin, qnan_value, plus_infty, qnan_value, plus_infty, IGNORE_ZERO_INF_SIGN);
5749 TEST_c_c (csin, qnan_value, minus_infty, qnan_value, plus_infty, IGNORE_ZERO_INF_SIGN);
8847214f 5750
67e971f1
TS
5751 TEST_c_c (csin, qnan_value, 9.0, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
5752 TEST_c_c (csin, qnan_value, -9.0, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
8847214f 5753
67e971f1
TS
5754 TEST_c_c (csin, 0.0, qnan_value, 0.0, qnan_value);
5755 TEST_c_c (csin, minus_zero, qnan_value, minus_zero, qnan_value);
8847214f 5756
67e971f1
TS
5757 TEST_c_c (csin, 10.0, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
5758 TEST_c_c (csin, qnan_value, -10.0, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
8847214f 5759
67e971f1
TS
5760 TEST_c_c (csin, plus_infty, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
5761 TEST_c_c (csin, minus_infty, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
8847214f 5762
67e971f1 5763 TEST_c_c (csin, qnan_value, qnan_value, qnan_value, qnan_value);
8847214f 5764
2550dfe9 5765 TEST_c_c (csin, 0.75L, 1.25L, 1.28722291002649188575873510790565441L, 1.17210635989270256101081285116138863L);
79df8ce5 5766 TEST_c_c (csin, -2, -3, -9.15449914691142957346729954460983256L, 4.16890695996656435075481305885375484L);
8847214f 5767
e0b16cc2
JM
5768 TEST_c_c (csin, 0.75, 89.5, 2.522786001038096774676288412995370563339e38L, 2.708024460708609732016532185663087200560e38L);
5769 TEST_c_c (csin, 0.75, -89.5, 2.522786001038096774676288412995370563339e38L, -2.708024460708609732016532185663087200560e38L);
5770 TEST_c_c (csin, -0.75, 89.5, -2.522786001038096774676288412995370563339e38L, 2.708024460708609732016532185663087200560e38L);
5771 TEST_c_c (csin, -0.75, -89.5, -2.522786001038096774676288412995370563339e38L, -2.708024460708609732016532185663087200560e38L);
5772
5773#ifndef TEST_FLOAT
5774 TEST_c_c (csin, 0.75, 710.5, 1.255317763348154410745082950806112487736e308L, 1.347490911916428129246890157395342279438e308L);
5775 TEST_c_c (csin, 0.75, -710.5, 1.255317763348154410745082950806112487736e308L, -1.347490911916428129246890157395342279438e308L);
5776 TEST_c_c (csin, -0.75, 710.5, -1.255317763348154410745082950806112487736e308L, 1.347490911916428129246890157395342279438e308L);
5777 TEST_c_c (csin, -0.75, -710.5, -1.255317763348154410745082950806112487736e308L, -1.347490911916428129246890157395342279438e308L);
5778#endif
5779
5780#if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
5781 TEST_c_c (csin, 0.75, 11357.25, 8.385498349388321535962327491346664141020e4931L, 9.001213196851067077465606717616495588201e4931L);
5782 TEST_c_c (csin, 0.75, -11357.25, 8.385498349388321535962327491346664141020e4931L, -9.001213196851067077465606717616495588201e4931L);
5783 TEST_c_c (csin, -0.75, 11357.25, -8.385498349388321535962327491346664141020e4931L, 9.001213196851067077465606717616495588201e4931L);
5784 TEST_c_c (csin, -0.75, -11357.25, -8.385498349388321535962327491346664141020e4931L, -9.001213196851067077465606717616495588201e4931L);
5785#endif
5786
5787#ifdef TEST_FLOAT
5788 TEST_c_c (csin, 0x1p-149, 180, 1.043535896672617552965983803453927655332e33L, plus_infty, OVERFLOW_EXCEPTION);
5789#endif
5790
5791#if defined TEST_DOUBLE || (defined TEST_LDOUBLE && LDBL_MAX_EXP == 1024)
5792 TEST_c_c (csin, 0x1p-1074, 1440, 5.981479269486130556466515778180916082415e301L, plus_infty, OVERFLOW_EXCEPTION);
5793#endif
5794
5795#if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
5796 TEST_c_c (csin, 0x1p-16434L, 22730, 1.217853148905605987081057582351152052687e4924L, plus_infty, OVERFLOW_EXCEPTION);
5797#endif
5798
6815fabc 5799 END (csin, complex);
8847214f
UD
5800}
5801
5802
5803static void
5804csinh_test (void)
5805{
aaca11d8 5806 errno = 0;
3c6cad26 5807 FUNC(csinh) (BUILD_COMPLEX (0.7L, 1.2L));
aaca11d8
UD
5808 if (errno == ENOSYS)
5809 /* Function not implemented. */
5810 return;
8847214f
UD
5811
5812 START (csinh);
5813
5814 TEST_c_c (csinh, 0.0, 0.0, 0.0, 0.0);
5815 TEST_c_c (csinh, minus_zero, 0.0, minus_zero, 0.0);
5816 TEST_c_c (csinh, 0.0, minus_zero, 0.0, minus_zero);
5817 TEST_c_c (csinh, minus_zero, minus_zero, minus_zero, minus_zero);
5818
67e971f1
TS
5819 TEST_c_c (csinh, 0.0, plus_infty, 0.0, qnan_value, INVALID_EXCEPTION|IGNORE_ZERO_INF_SIGN);
5820 TEST_c_c (csinh, minus_zero, plus_infty, 0.0, qnan_value, INVALID_EXCEPTION|IGNORE_ZERO_INF_SIGN);
5821 TEST_c_c (csinh, 0.0, minus_infty, 0.0, qnan_value, INVALID_EXCEPTION|IGNORE_ZERO_INF_SIGN);
5822 TEST_c_c (csinh, minus_zero, minus_infty, 0.0, qnan_value, INVALID_EXCEPTION|IGNORE_ZERO_INF_SIGN);
8847214f
UD
5823
5824 TEST_c_c (csinh, plus_infty, 0.0, plus_infty, 0.0);
5825 TEST_c_c (csinh, minus_infty, 0.0, minus_infty, 0.0);
5826 TEST_c_c (csinh, plus_infty, minus_zero, plus_infty, minus_zero);
5827 TEST_c_c (csinh, minus_infty, minus_zero, minus_infty, minus_zero);
5828
67e971f1
TS
5829 TEST_c_c (csinh, plus_infty, plus_infty, plus_infty, qnan_value, INVALID_EXCEPTION|IGNORE_ZERO_INF_SIGN);
5830 TEST_c_c (csinh, minus_infty, plus_infty, plus_infty, qnan_value, INVALID_EXCEPTION|IGNORE_ZERO_INF_SIGN);
5831 TEST_c_c (csinh, plus_infty, minus_infty, plus_infty, qnan_value, INVALID_EXCEPTION|IGNORE_ZERO_INF_SIGN);
5832 TEST_c_c (csinh, minus_infty, minus_infty, plus_infty, qnan_value, INVALID_EXCEPTION|IGNORE_ZERO_INF_SIGN);
8847214f
UD
5833
5834 TEST_c_c (csinh, plus_infty, 4.625, minus_infty, minus_infty);
5835 TEST_c_c (csinh, minus_infty, 4.625, plus_infty, minus_infty);
5836 TEST_c_c (csinh, plus_infty, -4.625, minus_infty, plus_infty);
5837 TEST_c_c (csinh, minus_infty, -4.625, plus_infty, plus_infty);
5838
67e971f1
TS
5839 TEST_c_c (csinh, 6.75, plus_infty, qnan_value, qnan_value, INVALID_EXCEPTION);
5840 TEST_c_c (csinh, -6.75, plus_infty, qnan_value, qnan_value, INVALID_EXCEPTION);
5841 TEST_c_c (csinh, 6.75, minus_infty, qnan_value, qnan_value, INVALID_EXCEPTION);
5842 TEST_c_c (csinh, -6.75, minus_infty, qnan_value, qnan_value, INVALID_EXCEPTION);
8847214f 5843
67e971f1
TS
5844 TEST_c_c (csinh, 0.0, qnan_value, 0.0, qnan_value, IGNORE_ZERO_INF_SIGN);
5845 TEST_c_c (csinh, minus_zero, qnan_value, 0.0, qnan_value, IGNORE_ZERO_INF_SIGN);
8847214f 5846
67e971f1
TS
5847 TEST_c_c (csinh, plus_infty, qnan_value, plus_infty, qnan_value, IGNORE_ZERO_INF_SIGN);
5848 TEST_c_c (csinh, minus_infty, qnan_value, plus_infty, qnan_value, IGNORE_ZERO_INF_SIGN);
8847214f 5849
67e971f1
TS
5850 TEST_c_c (csinh, 9.0, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
5851 TEST_c_c (csinh, -9.0, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
8847214f 5852
67e971f1
TS
5853 TEST_c_c (csinh, qnan_value, 0.0, qnan_value, 0.0);
5854 TEST_c_c (csinh, qnan_value, minus_zero, qnan_value, minus_zero);
8847214f 5855
67e971f1
TS
5856 TEST_c_c (csinh, qnan_value, 10.0, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
5857 TEST_c_c (csinh, qnan_value, -10.0, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
8847214f 5858
67e971f1
TS
5859 TEST_c_c (csinh, qnan_value, plus_infty, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
5860 TEST_c_c (csinh, qnan_value, minus_infty, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
8847214f 5861
67e971f1 5862 TEST_c_c (csinh, qnan_value, qnan_value, qnan_value, qnan_value);
8847214f 5863
2550dfe9 5864 TEST_c_c (csinh, 0.75L, 1.25L, 0.259294854551162779153349830618433028L, 1.22863452409509552219214606515777594L);
79df8ce5 5865 TEST_c_c (csinh, -2, -3, 3.59056458998577995201256544779481679L, -0.530921086248519805267040090660676560L);
8847214f 5866
e0b16cc2
JM
5867 TEST_c_c (csinh, 89.5, 0.75, 2.708024460708609732016532185663087200560e38L, 2.522786001038096774676288412995370563339e38L);
5868 TEST_c_c (csinh, -89.5, 0.75, -2.708024460708609732016532185663087200560e38L, 2.522786001038096774676288412995370563339e38L);
5869 TEST_c_c (csinh, 89.5, -0.75, 2.708024460708609732016532185663087200560e38L, -2.522786001038096774676288412995370563339e38L);
5870 TEST_c_c (csinh, -89.5, -0.75, -2.708024460708609732016532185663087200560e38L, -2.522786001038096774676288412995370563339e38L);
5871
5872#ifndef TEST_FLOAT
5873 TEST_c_c (csinh, 710.5, 0.75, 1.347490911916428129246890157395342279438e308L, 1.255317763348154410745082950806112487736e308L);
5874 TEST_c_c (csinh, -710.5, 0.75, -1.347490911916428129246890157395342279438e308L, 1.255317763348154410745082950806112487736e308L);
5875 TEST_c_c (csinh, 710.5, -0.75, 1.347490911916428129246890157395342279438e308L, -1.255317763348154410745082950806112487736e308L);
5876 TEST_c_c (csinh, -710.5, -0.75, -1.347490911916428129246890157395342279438e308L, -1.255317763348154410745082950806112487736e308L);
5877#endif
5878
5879#if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
5880 TEST_c_c (csinh, 11357.25, 0.75, 9.001213196851067077465606717616495588201e4931L, 8.385498349388321535962327491346664141020e4931L);
5881 TEST_c_c (csinh, -11357.25, 0.75, -9.001213196851067077465606717616495588201e4931L, 8.385498349388321535962327491346664141020e4931L);
5882 TEST_c_c (csinh, 11357.25, -0.75, 9.001213196851067077465606717616495588201e4931L, -8.385498349388321535962327491346664141020e4931L);
5883 TEST_c_c (csinh, -11357.25, -0.75, -9.001213196851067077465606717616495588201e4931L, -8.385498349388321535962327491346664141020e4931L);
5884#endif
5885
5886#ifdef TEST_FLOAT
5887 TEST_c_c (csinh, 180, 0x1p-149, plus_infty, 1.043535896672617552965983803453927655332e33L, OVERFLOW_EXCEPTION);
5888#endif
5889
5890#if defined TEST_DOUBLE || (defined TEST_LDOUBLE && LDBL_MAX_EXP == 1024)
5891 TEST_c_c (csinh, 1440, 0x1p-1074, plus_infty, 5.981479269486130556466515778180916082415e301L, OVERFLOW_EXCEPTION);
5892#endif
5893
5894#if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
5895 TEST_c_c (csinh, 22730, 0x1p-16434L, plus_infty, 1.217853148905605987081057582351152052687e4924L, OVERFLOW_EXCEPTION);
5896#endif
5897
6815fabc 5898 END (csinh, complex);
8847214f
UD
5899}
5900
2550dfe9 5901
8847214f
UD
5902static void
5903csqrt_test (void)
5904{
aaca11d8
UD
5905 errno = 0;
5906 FUNC(csqrt) (BUILD_COMPLEX (-1, 0));
5907 if (errno == ENOSYS)
5908 /* Function not implemented. */
5909 return;
5910
8847214f
UD
5911 START (csqrt);
5912
5913 TEST_c_c (csqrt, 0, 0, 0.0, 0.0);
5914 TEST_c_c (csqrt, 0, minus_zero, 0, minus_zero);
5915 TEST_c_c (csqrt, minus_zero, 0, 0.0, 0.0);
5916 TEST_c_c (csqrt, minus_zero, minus_zero, 0.0, minus_zero);
5917
5918 TEST_c_c (csqrt, minus_infty, 0, 0.0, plus_infty);
5919 TEST_c_c (csqrt, minus_infty, 6, 0.0, plus_infty);
5920 TEST_c_c (csqrt, minus_infty, minus_zero, 0.0, minus_infty);
5921 TEST_c_c (csqrt, minus_infty, -6, 0.0, minus_infty);
5922
5923 TEST_c_c (csqrt, plus_infty, 0, plus_infty, 0.0);
5924 TEST_c_c (csqrt, plus_infty, 6, plus_infty, 0.0);
5925 TEST_c_c (csqrt, plus_infty, minus_zero, plus_infty, minus_zero);
5926 TEST_c_c (csqrt, plus_infty, -6, plus_infty, minus_zero);
5927
5928 TEST_c_c (csqrt, 0, plus_infty, plus_infty, plus_infty);
5929 TEST_c_c (csqrt, 4, plus_infty, plus_infty, plus_infty);
5930 TEST_c_c (csqrt, plus_infty, plus_infty, plus_infty, plus_infty);
5931 TEST_c_c (csqrt, minus_zero, plus_infty, plus_infty, plus_infty);
5932 TEST_c_c (csqrt, -4, plus_infty, plus_infty, plus_infty);
5933 TEST_c_c (csqrt, minus_infty, plus_infty, plus_infty, plus_infty);
5934 TEST_c_c (csqrt, 0, minus_infty, plus_infty, minus_infty);
5935 TEST_c_c (csqrt, 4, minus_infty, plus_infty, minus_infty);
5936 TEST_c_c (csqrt, plus_infty, minus_infty, plus_infty, minus_infty);
5937 TEST_c_c (csqrt, minus_zero, minus_infty, plus_infty, minus_infty);
5938 TEST_c_c (csqrt, -4, minus_infty, plus_infty, minus_infty);
5939 TEST_c_c (csqrt, minus_infty, minus_infty, plus_infty, minus_infty);
5940
67e971f1 5941 TEST_c_c (csqrt, minus_infty, qnan_value, qnan_value, plus_infty, IGNORE_ZERO_INF_SIGN);
8847214f 5942
67e971f1 5943 TEST_c_c (csqrt, plus_infty, qnan_value, plus_infty, qnan_value);
8847214f 5944
67e971f1
TS
5945 TEST_c_c (csqrt, 0, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
5946 TEST_c_c (csqrt, 1, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
5947 TEST_c_c (csqrt, minus_zero, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
5948 TEST_c_c (csqrt, -1, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
8847214f 5949
67e971f1
TS
5950 TEST_c_c (csqrt, qnan_value, 0, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
5951 TEST_c_c (csqrt, qnan_value, 8, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
5952 TEST_c_c (csqrt, qnan_value, minus_zero, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
5953 TEST_c_c (csqrt, qnan_value, -8, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
8847214f 5954
67e971f1 5955 TEST_c_c (csqrt, qnan_value, qnan_value, qnan_value, qnan_value);
8847214f
UD
5956
5957 TEST_c_c (csqrt, 16.0, -30.0, 5.0, -3.0);
5958 TEST_c_c (csqrt, -1, 0, 0.0, 1.0);
5959 TEST_c_c (csqrt, 0, 2, 1.0, 1.0);
5960 TEST_c_c (csqrt, 119, 120, 12.0, 5.0);
2550dfe9 5961 TEST_c_c (csqrt, 0.75L, 1.25L, 1.05065169626078392338656675760808326L, 0.594868882070379067881984030639932657L);
d8337213
UD
5962 TEST_c_c (csqrt, -2, -3, 0.89597747612983812471573375529004348L, -1.6741492280355400404480393008490519L);
5963 TEST_c_c (csqrt, -2, 3, 0.89597747612983812471573375529004348L, 1.6741492280355400404480393008490519L);
72c7a71d
UD
5964 /* Principal square root should be returned (i.e., non-negative real
5965 part). */
5966 TEST_c_c (csqrt, 0, -1, M_SQRT_2_2, -M_SQRT_2_2);
8847214f 5967
e456826d
JM
5968 TEST_c_c (csqrt, 0x1.fffffep+127L, 0x1.fffffep+127L, 2.026714405498316804978751017492482558075e+19L, 8.394925938143272988211878516208015586281e+18L);
5969 TEST_c_c (csqrt, 0x1.fffffep+127L, 1.0L, 1.844674352395372953599975585936590505260e+19L, 2.710505511993121390769065968615872097053e-20L);
5970 TEST_c_c (csqrt, 0x1p-149L, 0x1p-149L, 4.112805464342778798097003462770175200803e-23L, 1.703579802732953750368659735601389709551e-23L);
5971 TEST_c_c (csqrt, 0x1p-147L, 0x1p-147L, 8.225610928685557596194006925540350401606e-23L, 3.407159605465907500737319471202779419102e-23L);
5972
cdfe2c5e
JM
5973 TEST_c_c (csqrt, plus_zero, 0x1p-149L, 2.646977960169688559588507814623881131411e-23L, 2.646977960169688559588507814623881131411e-23L);
5974 TEST_c_c (csqrt, 0x1p-50L, 0x1p-149L, 2.980232238769531250000000000000000000000e-8L, 2.350988701644575015937473074444491355637e-38L);
5975#ifdef TEST_FLOAT
5976 TEST_c_c (csqrt, 0x1p+127L, 0x1p-149L, 1.304381782533278221234957180625250836888e19L, plus_zero, UNDERFLOW_EXCEPTION);
5977#endif
5978 TEST_c_c (csqrt, 0x1p-149L, 0x1p+127L, 9.223372036854775808000000000000000000000e18L, 9.223372036854775808000000000000000000000e18L);
5979 TEST_c_c (csqrt, 0x1.000002p-126L, 0x1.000002p-126L, 1.191195773697904627170323731331667740087e-19L, 4.934094449071842328766868579214125217132e-20L);
5980 TEST_c_c (csqrt, -0x1.000002p-126L, -0x1.000002p-126L, 4.934094449071842328766868579214125217132e-20L, -1.191195773697904627170323731331667740087e-19L);
5981
e456826d
JM
5982#ifndef TEST_FLOAT
5983 TEST_c_c (csqrt, 0x1.fffffffffffffp+1023L, 0x1.fffffffffffffp+1023L, 1.473094556905565378990473658199034571917e+154L, 6.101757441282702188537080005372547713595e+153L);
5984 TEST_c_c (csqrt, 0x1.fffffffffffffp+1023L, 0x1p+1023L, 1.379778091031440685006200821918878702861e+154L, 3.257214233483129514781233066898042490248e+153L);
cdfe2c5e
JM
5985 TEST_c_c (csqrt, 0x1p-1074L, 0x1p-1074L, 2.442109726130830256743814843868934877597e-162L, 1.011554969366634726113090867589031782487e-162L);
5986 TEST_c_c (csqrt, 0x1p-1073L, 0x1p-1073L, 3.453664695497464982856905711457966660085e-162L, 1.430554756764195530630723976279903095110e-162L);
5987
5988 TEST_c_c (csqrt, plus_zero, 0x1p-1074L, 1.571727784702628688909515672805082228285e-162L, 1.571727784702628688909515672805082228285e-162L);
5989 TEST_c_c (csqrt, 0x1p-500L, 0x1p-1074L, 5.527147875260444560247265192192255725514e-76L, 4.469444793151709302716387622440056066334e-249L);
5990#if defined TEST_DOUBLE || (defined TEST_LDOUBLE && LDBL_MAX_EXP == 1024)
5991 TEST_c_c (csqrt, 0x1p+1023L, 0x1p-1074L, 9.480751908109176726832526455652159260085e153L, plus_zero, UNDERFLOW_EXCEPTION);
5992#endif
5993 TEST_c_c (csqrt, 0x1p-1074L, 0x1p+1023L, 6.703903964971298549787012499102923063740e153L, 6.703903964971298549787012499102923063740e153L);
5994 TEST_c_c (csqrt, 0x1.0000000000001p-1022L, 0x1.0000000000001p-1022L, 1.638872094839911521020410942677082920935e-154L, 6.788430486774966350907249113759995429568e-155L);
5995 TEST_c_c (csqrt, -0x1.0000000000001p-1022L, -0x1.0000000000001p-1022L, 6.788430486774966350907249113759995429568e-155L, -1.638872094839911521020410942677082920935e-154L);
e456826d
JM
5996#endif
5997
5998#if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
5999 TEST_c_c (csqrt, 0x1.fp+16383L, 0x1.fp+16383L, 1.179514222452201722651836720466795901016e+2466L, 4.885707879516577666702435054303191575148e+2465L);
6000 TEST_c_c (csqrt, 0x1.fp+16383L, 0x1p+16383L, 1.106698967236475180613254276996359485630e+2466L, 2.687568007603946993388538156299100955642e+2465L);
6001 TEST_c_c (csqrt, 0x1p-16440L, 0x1p-16441L, 3.514690655930285351254618340783294558136e-2475L, 8.297059146828716918029689466551384219370e-2476L);
cdfe2c5e
JM
6002
6003 TEST_c_c (csqrt, plus_zero, 0x1p-16445L, 4.269191686890197837775136325621239761720e-2476L, 4.269191686890197837775136325621239761720e-2476L);
6004 TEST_c_c (csqrt, 0x1p-5000L, 0x1p-16445L, 2.660791472672778409283210520357607795518e-753L, 6.849840675828785164910701384823702064234e-4199L);
6005 TEST_c_c (csqrt, 0x1p+16383L, 0x1p-16445L, 7.712754032630730034273323365543179095045e2465L, plus_zero, UNDERFLOW_EXCEPTION);
6006 TEST_c_c (csqrt, 0x1p-16445L, 0x1p+16383L, 5.453740678097079647314921223668914312241e2465L, 5.453740678097079647314921223668914312241e2465L);
6007 TEST_c_c (csqrt, 0x1.0000000000000002p-16382L, 0x1.0000000000000002p-16382L, 2.014551439675644900131815801350165472778e-2466L, 8.344545284118961664300307045791497724440e-2467L);
6008 TEST_c_c (csqrt, -0x1.0000000000000002p-16382L, -0x1.0000000000000002p-16382L, 8.344545284118961664300307045791497724440e-2467L, -2.014551439675644900131815801350165472778e-2466L);
6009
6010# if LDBL_MANT_DIG >= 113
6011 TEST_c_c (csqrt, plus_zero, 0x1p-16494L, 1.799329752913293143453817328207572571442e-2483L, 1.799329752913293143453817328207572571442e-2483L);
6012 TEST_c_c (csqrt, 0x1p-5000L, 0x1p-16494L, 2.660791472672778409283210520357607795518e-753L, 1.216776133331049643422030716668249905907e-4213L);
6013 TEST_c_c (csqrt, 0x1p+16383L, 0x1p-16494L, 7.712754032630730034273323365543179095045e2465L, plus_zero, UNDERFLOW_EXCEPTION);
6014 TEST_c_c (csqrt, 0x1p-16494L, 0x1p+16383L, 5.453740678097079647314921223668914312241e2465L, 5.453740678097079647314921223668914312241e2465L);
6015 TEST_c_c (csqrt, 0x1.0000000000000000000000000001p-16382L, 0x1.0000000000000000000000000001p-16382L, 2.014551439675644900022606748976158925145e-2466L, 8.344545284118961663847948339519226074126e-2467L);
6016 TEST_c_c (csqrt, -0x1.0000000000000000000000000001p-16382L, -0x1.0000000000000000000000000001p-16382L, 8.344545284118961663847948339519226074126e-2467L, -2.014551439675644900022606748976158925145e-2466L);
6017# endif
e456826d
JM
6018#endif
6019
6815fabc 6020 END (csqrt, complex);
8847214f
UD
6021}
6022
6023static void
6024ctan_test (void)
6025{
aaca11d8 6026 errno = 0;
3c6cad26 6027 FUNC(ctan) (BUILD_COMPLEX (0.7L, 1.2L));
aaca11d8
UD
6028 if (errno == ENOSYS)
6029 /* Function not implemented. */
6030 return;
6031
8847214f
UD
6032 START (ctan);
6033
6034 TEST_c_c (ctan, 0, 0, 0.0, 0.0);
6035 TEST_c_c (ctan, 0, minus_zero, 0.0, minus_zero);
6036 TEST_c_c (ctan, minus_zero, 0, minus_zero, 0.0);
6037 TEST_c_c (ctan, minus_zero, minus_zero, minus_zero, minus_zero);
6038
6039 TEST_c_c (ctan, 0, plus_infty, 0.0, 1.0);
6040 TEST_c_c (ctan, 1, plus_infty, 0.0, 1.0);
6041 TEST_c_c (ctan, minus_zero, plus_infty, minus_zero, 1.0);
6042 TEST_c_c (ctan, -1, plus_infty, minus_zero, 1.0);
6043
6044 TEST_c_c (ctan, 0, minus_infty, 0.0, -1.0);
6045 TEST_c_c (ctan, 1, minus_infty, 0.0, -1.0);
6046 TEST_c_c (ctan, minus_zero, minus_infty, minus_zero, -1.0);
6047 TEST_c_c (ctan, -1, minus_infty, minus_zero, -1.0);
6048
67e971f1
TS
6049 TEST_c_c (ctan, plus_infty, 0, qnan_value, qnan_value, INVALID_EXCEPTION);
6050 TEST_c_c (ctan, plus_infty, 2, qnan_value, qnan_value, INVALID_EXCEPTION);
6051 TEST_c_c (ctan, minus_infty, 0, qnan_value, qnan_value, INVALID_EXCEPTION);
6052 TEST_c_c (ctan, minus_infty, 2, qnan_value, qnan_value, INVALID_EXCEPTION);
6053 TEST_c_c (ctan, plus_infty, minus_zero, qnan_value, qnan_value, INVALID_EXCEPTION);
6054 TEST_c_c (ctan, plus_infty, -2, qnan_value, qnan_value, INVALID_EXCEPTION);
6055 TEST_c_c (ctan, minus_infty, minus_zero, qnan_value, qnan_value, INVALID_EXCEPTION);
6056 TEST_c_c (ctan, minus_infty, -2, qnan_value, qnan_value, INVALID_EXCEPTION);
8847214f 6057
67e971f1
TS
6058 TEST_c_c (ctan, qnan_value, plus_infty, 0.0, 1.0, IGNORE_ZERO_INF_SIGN);
6059 TEST_c_c (ctan, qnan_value, minus_infty, 0.0, -1.0, IGNORE_ZERO_INF_SIGN);
8847214f 6060
67e971f1
TS
6061 TEST_c_c (ctan, 0, qnan_value, 0.0, qnan_value);
6062 TEST_c_c (ctan, minus_zero, qnan_value, minus_zero, qnan_value);
8847214f 6063
67e971f1
TS
6064 TEST_c_c (ctan, 0.5, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
6065 TEST_c_c (ctan, -4.5, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
8847214f 6066
67e971f1
TS
6067 TEST_c_c (ctan, qnan_value, 0, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
6068 TEST_c_c (ctan, qnan_value, 5, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
6069 TEST_c_c (ctan, qnan_value, minus_zero, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
6070 TEST_c_c (ctan, qnan_value, -0.25, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
8847214f 6071
67e971f1 6072 TEST_c_c (ctan, qnan_value, qnan_value, qnan_value, qnan_value);
8847214f 6073
2550dfe9 6074 TEST_c_c (ctan, 0.75L, 1.25L, 0.160807785916206426725166058173438663L, 0.975363285031235646193581759755216379L);
79df8ce5 6075 TEST_c_c (ctan, -2, -3, 0.376402564150424829275122113032269084e-2L, -1.00323862735360980144635859782192726L);
8847214f 6076
80bad0cc
JM
6077 TEST_c_c (ctan, 1, 45, 1.490158918874345552942703234806348520895e-39L, 1.000000000000000000000000000000000000001L, UNDERFLOW_EXCEPTION_FLOAT);
6078 TEST_c_c (ctan, 1, 47, 2.729321264492904590777293425576722354636e-41L, 1.0, UNDERFLOW_EXCEPTION_FLOAT);
bcc8d661
JM
6079
6080#ifndef TEST_FLOAT
80bad0cc
JM
6081 TEST_c_c (ctan, 1, 355, 8.140551093483276762350406321792653551513e-309L, 1.0, UNDERFLOW_EXCEPTION_DOUBLE);
6082 TEST_c_c (ctan, 1, 365, 1.677892637497921890115075995898773550884e-317L, 1.0, UNDERFLOW_EXCEPTION_DOUBLE);
bcc8d661
JM
6083#endif
6084
6085#if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
80bad0cc
JM
6086 TEST_c_c (ctan, 1, 5680, 4.725214596136812019616700920476949798307e-4934L, 1.0, UNDERFLOW_EXCEPTION);
6087 TEST_c_c (ctan, 1, 5690, 9.739393181626937151720816611272607059057e-4943L, 1.0, UNDERFLOW_EXCEPTION);
bcc8d661
JM
6088#endif
6089
6090 TEST_c_c (ctan, 0x3.243f6cp-1, 0, -2.287733242885645987394874673945769518150e7L, 0.0);
6091
6092 TEST_c_c (ctan, 0x1p127, 1, 0.2446359391192790896381501310437708987204L, 0.9101334047676183761532873794426475906201L);
6093
6094#ifndef TEST_FLOAT
6095 TEST_c_c (ctan, 0x1p1023, 1, -0.2254627924997545057926782581695274244229L, 0.8786063118883068695462540226219865087189L);
6096#endif
6097
6098#if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
6099 TEST_c_c (ctan, 0x1p16383L, 1, 0.1608598776370396607204448234354670036772L, 0.8133818522051542536316746743877629761488L);
6100#endif
6101
80bad0cc
JM
6102 TEST_c_c (ctan, 50000, 50000, plus_zero, 1.0, UNDERFLOW_EXCEPTION);
6103 TEST_c_c (ctan, 50000, -50000, plus_zero, -1.0, UNDERFLOW_EXCEPTION);
6104 TEST_c_c (ctan, -50000, 50000, minus_zero, 1.0, UNDERFLOW_EXCEPTION);
6105 TEST_c_c (ctan, -50000, -50000, minus_zero, -1.0, UNDERFLOW_EXCEPTION);
bcc8d661 6106
6815fabc 6107 END (ctan, complex);
8847214f
UD
6108}
6109
6110
ca61cf32
JM
6111static void
6112ctan_test_tonearest (void)
6113{
6114 int save_round_mode;
6115 errno = 0;
6116 FUNC(ctan) (BUILD_COMPLEX (0.7L, 1.2L));
6117 if (errno == ENOSYS)
6118 /* Function not implemented. */
6119 return;
6120
6121 START (ctan_tonearest);
6122
6123 save_round_mode = fegetround ();
6124
6125 if (!fesetround (FE_TONEAREST))
6126 {
6127 TEST_c_c (ctan, 0x1.921fb6p+0, 0x1p-149, -2.287733242885645987394874673945769518150e7L, 7.334008549954377778731880988481078535821e-31L);
6128
6129#ifndef TEST_FLOAT
6130 TEST_c_c (ctan, 0x1.921fb54442d18p+0, 0x1p-1074, 1.633123935319536975596773704152891653086e16L, 1.317719414943508315995636961402669067843e-291L);
6131#endif
6132
6133#if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
6134 TEST_c_c (ctan, 0x1.921fb54442d1846ap+0L, 0x1p-16445L, -3.986797629811710706723242948653362815645e19L, 5.793882568875674066286163141055208625180e-4912L);
6135#endif
6136 }
6137
6138 fesetround (save_round_mode);
6139
6140 END (ctan_tonearest, complex);
6141}
6142
6143
6144static void
6145ctan_test_towardzero (void)
6146{
6147 int save_round_mode;
6148 errno = 0;
6149 FUNC(ctan) (BUILD_COMPLEX (0.7L, 1.2L));
6150 if (errno == ENOSYS)
6151 /* Function not implemented. */
6152 return;
6153
6154 START (ctan_towardzero);
6155
6156 save_round_mode = fegetround ();
6157
6158 if (!fesetround (FE_TOWARDZERO))
6159 {
6160 TEST_c_c (ctan, 0x1.921fb6p+0, 0x1p-149, -2.287733242885645987394874673945769518150e7L, 7.334008549954377778731880988481078535821e-31L);
6161
6162#ifndef TEST_FLOAT
6163 TEST_c_c (ctan, 0x1.921fb54442d18p+0, 0x1p-1074, 1.633123935319536975596773704152891653086e16L, 1.317719414943508315995636961402669067843e-291L);
6164#endif
6165
6166#if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
6167 TEST_c_c (ctan, 0x1.921fb54442d1846ap+0L, 0x1p-16445L, -3.986797629811710706723242948653362815645e19L, 5.793882568875674066286163141055208625180e-4912L);
6168#endif
6169 }
6170
6171 fesetround (save_round_mode);
6172
6173 END (ctan_towardzero, complex);
6174}
6175
6176
6177static void
6178ctan_test_downward (void)
6179{
6180 int save_round_mode;
6181 errno = 0;
6182 FUNC(ctan) (BUILD_COMPLEX (0.7L, 1.2L));
6183 if (errno == ENOSYS)
6184 /* Function not implemented. */
6185 return;
6186
6187 START (ctan_downward);
6188
6189 save_round_mode = fegetround ();
6190
6191 if (!fesetround (FE_DOWNWARD))
6192 {
6193 TEST_c_c (ctan, 0x1.921fb6p+0, 0x1p-149, -2.287733242885645987394874673945769518150e7L, 7.334008549954377778731880988481078535821e-31L);
6194
6195#ifndef TEST_FLOAT
6196 TEST_c_c (ctan, 0x1.921fb54442d18p+0, 0x1p-1074, 1.633123935319536975596773704152891653086e16L, 1.317719414943508315995636961402669067843e-291L);
6197#endif
6198
6199#if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
6200 TEST_c_c (ctan, 0x1.921fb54442d1846ap+0L, 0x1p-16445L, -3.986797629811710706723242948653362815645e19L, 5.793882568875674066286163141055208625180e-4912L);
6201#endif
6202 }
6203
6204 fesetround (save_round_mode);
6205
6206 END (ctan_downward, complex);
6207}
6208
6209
6210static void
6211ctan_test_upward (void)
6212{
6213 int save_round_mode;
6214 errno = 0;
6215 FUNC(ctan) (BUILD_COMPLEX (0.7L, 1.2L));
6216 if (errno == ENOSYS)
6217 /* Function not implemented. */
6218 return;
6219
6220 START (ctan_upward);
6221
6222 save_round_mode = fegetround ();
6223
6224 if (!fesetround (FE_UPWARD))
6225 {
6226 TEST_c_c (ctan, 0x1.921fb6p+0, 0x1p-149, -2.287733242885645987394874673945769518150e7L, 7.334008549954377778731880988481078535821e-31L);
6227
6228#ifndef TEST_FLOAT
6229 TEST_c_c (ctan, 0x1.921fb54442d18p+0, 0x1p-1074, 1.633123935319536975596773704152891653086e16L, 1.317719414943508315995636961402669067843e-291L);
6230#endif
6231
6232#if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
6233 TEST_c_c (ctan, 0x1.921fb54442d1846ap+0L, 0x1p-16445L, -3.986797629811710706723242948653362815645e19L, 5.793882568875674066286163141055208625180e-4912L);
6234#endif
6235 }
6236
6237 fesetround (save_round_mode);
6238
6239 END (ctan_upward, complex);
6240}
6241
6242
8847214f
UD
6243static void
6244ctanh_test (void)
6245{
aaca11d8
UD
6246 errno = 0;
6247 FUNC(ctanh) (BUILD_COMPLEX (0, 0));
6248 if (errno == ENOSYS)
6249 /* Function not implemented. */
6250 return;
6251
8847214f
UD
6252 START (ctanh);
6253
6254 TEST_c_c (ctanh, 0, 0, 0.0, 0.0);
6255 TEST_c_c (ctanh, 0, minus_zero, 0.0, minus_zero);
6256 TEST_c_c (ctanh, minus_zero, 0, minus_zero, 0.0);
6257 TEST_c_c (ctanh, minus_zero, minus_zero, minus_zero, minus_zero);
6258
6259 TEST_c_c (ctanh, plus_infty, 0, 1.0, 0.0);
6260 TEST_c_c (ctanh, plus_infty, 1, 1.0, 0.0);
6261 TEST_c_c (ctanh, plus_infty, minus_zero, 1.0, minus_zero);
6262 TEST_c_c (ctanh, plus_infty, -1, 1.0, minus_zero);
6263 TEST_c_c (ctanh, minus_infty, 0, -1.0, 0.0);
6264 TEST_c_c (ctanh, minus_infty, 1, -1.0, 0.0);
6265 TEST_c_c (ctanh, minus_infty, minus_zero, -1.0, minus_zero);
6266 TEST_c_c (ctanh, minus_infty, -1, -1.0, minus_zero);
6267
67e971f1
TS
6268 TEST_c_c (ctanh, 0, plus_infty, qnan_value, qnan_value, INVALID_EXCEPTION);
6269 TEST_c_c (ctanh, 2, plus_infty, qnan_value, qnan_value, INVALID_EXCEPTION);
6270 TEST_c_c (ctanh, 0, minus_infty, qnan_value, qnan_value, INVALID_EXCEPTION);
6271 TEST_c_c (ctanh, 2, minus_infty, qnan_value, qnan_value, INVALID_EXCEPTION);
6272 TEST_c_c (ctanh, minus_zero, plus_infty, qnan_value, qnan_value, INVALID_EXCEPTION);
6273 TEST_c_c (ctanh, -2, plus_infty, qnan_value, qnan_value, INVALID_EXCEPTION);
6274 TEST_c_c (ctanh, minus_zero, minus_infty, qnan_value, qnan_value, INVALID_EXCEPTION);
6275 TEST_c_c (ctanh, -2, minus_infty, qnan_value, qnan_value, INVALID_EXCEPTION);
8847214f 6276
67e971f1
TS
6277 TEST_c_c (ctanh, plus_infty, qnan_value, 1.0, 0.0, IGNORE_ZERO_INF_SIGN);
6278 TEST_c_c (ctanh, minus_infty, qnan_value, -1.0, 0.0, IGNORE_ZERO_INF_SIGN);
8847214f 6279
67e971f1
TS
6280 TEST_c_c (ctanh, qnan_value, 0, qnan_value, 0.0);
6281 TEST_c_c (ctanh, qnan_value, minus_zero, qnan_value, minus_zero);
8847214f 6282
67e971f1
TS
6283 TEST_c_c (ctanh, qnan_value, 0.5, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
6284 TEST_c_c (ctanh, qnan_value, -4.5, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
8847214f 6285
67e971f1
TS
6286 TEST_c_c (ctanh, 0, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
6287 TEST_c_c (ctanh, 5, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
6288 TEST_c_c (ctanh, minus_zero, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
6289 TEST_c_c (ctanh, -0.25, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
8847214f 6290
67e971f1 6291 TEST_c_c (ctanh, qnan_value, qnan_value, qnan_value, qnan_value);
8847214f
UD
6292
6293 TEST_c_c (ctanh, 0, M_PI_4l, 0.0, 1.0);
6294
2550dfe9 6295 TEST_c_c (ctanh, 0.75L, 1.25L, 1.37260757053378320258048606571226857L, 0.385795952609750664177596760720790220L);
79df8ce5 6296 TEST_c_c (ctanh, -2, -3, -0.965385879022133124278480269394560686L, 0.988437503832249372031403430350121098e-2L);
8847214f 6297
80bad0cc
JM
6298 TEST_c_c (ctanh, 45, 1, 1.000000000000000000000000000000000000001L, 1.490158918874345552942703234806348520895e-39L, UNDERFLOW_EXCEPTION_FLOAT);
6299 TEST_c_c (ctanh, 47, 1, 1.0, 2.729321264492904590777293425576722354636e-41L, UNDERFLOW_EXCEPTION_FLOAT);
bcc8d661
JM
6300
6301#ifndef TEST_FLOAT
80bad0cc
JM
6302 TEST_c_c (ctanh, 355, 1, 1.0, 8.140551093483276762350406321792653551513e-309L, UNDERFLOW_EXCEPTION_DOUBLE);
6303 TEST_c_c (ctanh, 365, 1, 1.0, 1.677892637497921890115075995898773550884e-317L, UNDERFLOW_EXCEPTION_DOUBLE);
bcc8d661
JM
6304#endif
6305
6306#if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
80bad0cc
JM
6307 TEST_c_c (ctanh, 5680, 1, 1.0, 4.725214596136812019616700920476949798307e-4934L, UNDERFLOW_EXCEPTION);
6308 TEST_c_c (ctanh, 5690, 1, 1.0, 9.739393181626937151720816611272607059057e-4943L, UNDERFLOW_EXCEPTION);
bcc8d661
JM
6309#endif
6310
6311 TEST_c_c (ctanh, 0, 0x3.243f6cp-1, 0.0, -2.287733242885645987394874673945769518150e7L);
6312
6313 TEST_c_c (ctanh, 1, 0x1p127, 0.9101334047676183761532873794426475906201L, 0.2446359391192790896381501310437708987204L);
6314
6315#ifndef TEST_FLOAT
6316 TEST_c_c (ctanh, 1, 0x1p1023, 0.8786063118883068695462540226219865087189L, -0.2254627924997545057926782581695274244229L);
6317#endif
6318
6319#if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
6320 TEST_c_c (ctanh, 1, 0x1p16383L, 0.8133818522051542536316746743877629761488L, 0.1608598776370396607204448234354670036772L);
6321#endif
6322
80bad0cc
JM
6323 TEST_c_c (ctanh, 50000, 50000, 1.0, plus_zero, UNDERFLOW_EXCEPTION);
6324 TEST_c_c (ctanh, 50000, -50000, 1.0, minus_zero, UNDERFLOW_EXCEPTION);
6325 TEST_c_c (ctanh, -50000, 50000, -1.0, plus_zero, UNDERFLOW_EXCEPTION);
6326 TEST_c_c (ctanh, -50000, -50000, -1.0, minus_zero, UNDERFLOW_EXCEPTION);
bcc8d661 6327
6815fabc 6328 END (ctanh, complex);
8847214f
UD
6329}
6330
2550dfe9 6331
ca61cf32
JM
6332static void
6333ctanh_test_tonearest (void)
6334{
6335 int save_round_mode;
6336 errno = 0;
6337 FUNC(ctanh) (BUILD_COMPLEX (0.7L, 1.2L));
6338 if (errno == ENOSYS)
6339 /* Function not implemented. */
6340 return;
6341
6342 START (ctanh_tonearest);
6343
6344 save_round_mode = fegetround ();
6345
6346 if (!fesetround (FE_TONEAREST))
6347 {
6348 TEST_c_c (ctanh, 0x1p-149, 0x1.921fb6p+0, 7.334008549954377778731880988481078535821e-31L, -2.287733242885645987394874673945769518150e7L);
6349
6350#ifndef TEST_FLOAT
6351 TEST_c_c (ctanh, 0x1p-1074, 0x1.921fb54442d18p+0, 1.317719414943508315995636961402669067843e-291L, 1.633123935319536975596773704152891653086e16L);
6352#endif
6353
6354#if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
6355 TEST_c_c (ctanh, 0x1p-16445L, 0x1.921fb54442d1846ap+0L, 5.793882568875674066286163141055208625180e-4912L, -3.986797629811710706723242948653362815645e19L);
6356#endif
6357 }
6358
6359 fesetround (save_round_mode);
6360
6361 END (ctanh_tonearest, complex);
6362}
6363
6364
6365static void
6366ctanh_test_towardzero (void)
6367{
6368 int save_round_mode;
6369 errno = 0;
6370 FUNC(ctanh) (BUILD_COMPLEX (0.7L, 1.2L));
6371 if (errno == ENOSYS)
6372 /* Function not implemented. */
6373 return;
6374
6375 START (ctanh_towardzero);
6376
6377 save_round_mode = fegetround ();
6378
6379 if (!fesetround (FE_TOWARDZERO))
6380 {
6381 TEST_c_c (ctanh, 0x1p-149, 0x1.921fb6p+0, 7.334008549954377778731880988481078535821e-31L, -2.287733242885645987394874673945769518150e7L);
6382
6383#ifndef TEST_FLOAT
6384 TEST_c_c (ctanh, 0x1p-1074, 0x1.921fb54442d18p+0, 1.317719414943508315995636961402669067843e-291L, 1.633123935319536975596773704152891653086e16L);
6385#endif
6386
6387#if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
6388 TEST_c_c (ctanh, 0x1p-16445L, 0x1.921fb54442d1846ap+0L, 5.793882568875674066286163141055208625180e-4912L, -3.986797629811710706723242948653362815645e19L);
6389#endif
6390 }
6391
6392 fesetround (save_round_mode);
6393
6394 END (ctanh_towardzero, complex);
6395}
6396
6397
6398static void
6399ctanh_test_downward (void)
6400{
6401 int save_round_mode;
6402 errno = 0;
6403 FUNC(ctanh) (BUILD_COMPLEX (0.7L, 1.2L));
6404 if (errno == ENOSYS)
6405 /* Function not implemented. */
6406 return;
6407
6408 START (ctanh_downward);
6409
6410 save_round_mode = fegetround ();
6411
6412 if (!fesetround (FE_DOWNWARD))
6413 {
6414 TEST_c_c (ctanh, 0x1p-149, 0x1.921fb6p+0, 7.334008549954377778731880988481078535821e-31L, -2.287733242885645987394874673945769518150e7L);
6415
6416#ifndef TEST_FLOAT
6417 TEST_c_c (ctanh, 0x1p-1074, 0x1.921fb54442d18p+0, 1.317719414943508315995636961402669067843e-291L, 1.633123935319536975596773704152891653086e16L);
6418#endif
6419
6420#if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
6421 TEST_c_c (ctanh, 0x1p-16445L, 0x1.921fb54442d1846ap+0L, 5.793882568875674066286163141055208625180e-4912L, -3.986797629811710706723242948653362815645e19L);
6422#endif
6423 }
6424
6425 fesetround (save_round_mode);
6426
6427 END (ctanh_downward, complex);
6428}
6429
6430
6431static void
6432ctanh_test_upward (void)
6433{
6434 int save_round_mode;
6435 errno = 0;
6436 FUNC(ctanh) (BUILD_COMPLEX (0.7L, 1.2L));
6437 if (errno == ENOSYS)
6438 /* Function not implemented. */
6439 return;
6440
6441 START (ctanh_upward);
6442
6443 save_round_mode = fegetround ();
6444
6445 if (!fesetround (FE_UPWARD))
6446 {
6447 TEST_c_c (ctanh, 0x1p-149, 0x1.921fb6p+0, 7.334008549954377778731880988481078535821e-31L, -2.287733242885645987394874673945769518150e7L);
6448
6449#ifndef TEST_FLOAT
6450 TEST_c_c (ctanh, 0x1p-1074, 0x1.921fb54442d18p+0, 1.317719414943508315995636961402669067843e-291L, 1.633123935319536975596773704152891653086e16L);
6451#endif
6452
6453#if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
6454 TEST_c_c (ctanh, 0x1p-16445L, 0x1.921fb54442d1846ap+0L, 5.793882568875674066286163141055208625180e-4912L, -3.986797629811710706723242948653362815645e19L);
6455#endif
6456 }
6457
6458 fesetround (save_round_mode);
6459
6460 END (ctanh_upward, complex);
6461}
6462
6463
8847214f
UD
6464static void
6465erf_test (void)
6466{
6467 errno = 0;
6468 FUNC(erf) (0);
6469 if (errno == ENOSYS)
6470 /* Function not implemented. */
6471 return;
6472
6473 START (erf);
6474
6475 TEST_f_f (erf, 0, 0);
6476 TEST_f_f (erf, minus_zero, minus_zero);
6477 TEST_f_f (erf, plus_infty, 1);
6478 TEST_f_f (erf, minus_infty, -1);
67e971f1 6479 TEST_f_f (erf, qnan_value, qnan_value);
8847214f 6480
2550dfe9
AJ
6481 TEST_f_f (erf, 0.125L, 0.140316204801333817393029446521623398L);
6482 TEST_f_f (erf, 0.75L, 0.711155633653515131598937834591410777L);
6483 TEST_f_f (erf, 1.25L, 0.922900128256458230136523481197281140L);
6484 TEST_f_f (erf, 2.0L, 0.995322265018952734162069256367252929L);
6485 TEST_f_f (erf, 4.125L, 0.999999994576599200434933994687765914L);
6486 TEST_f_f (erf, 27.0L, 1.0L);
8847214f
UD
6487
6488 END (erf);
6489}
6490
6491
6492static void
6493erfc_test (void)
6494{
6495 errno = 0;
6496 FUNC(erfc) (0);
6497 if (errno == ENOSYS)
6498 /* Function not implemented. */
6499 return;
6500
6501 START (erfc);
6502
6503 TEST_f_f (erfc, plus_infty, 0.0);
6504 TEST_f_f (erfc, minus_infty, 2.0);
6505 TEST_f_f (erfc, 0.0, 1.0);
6506 TEST_f_f (erfc, minus_zero, 1.0);
67e971f1 6507 TEST_f_f (erfc, qnan_value, qnan_value);
8847214f 6508
2550dfe9
AJ
6509 TEST_f_f (erfc, 0.125L, 0.859683795198666182606970553478376602L);
6510 TEST_f_f (erfc, 0.75L, 0.288844366346484868401062165408589223L);
6511 TEST_f_f (erfc, 1.25L, 0.0770998717435417698634765188027188596L);
6512 TEST_f_f (erfc, 2.0L, 0.00467773498104726583793074363274707139L);
7b1902cb 6513 TEST_f_f (erfc, 0x1.f7303cp+1L, 2.705500297238986897105236321218861842255e-8L);
2550dfe9 6514 TEST_f_f (erfc, 4.125L, 0.542340079956506600531223408575531062e-8L);
7b1902cb
JM
6515 TEST_f_f (erfc, 0x1.ffa002p+2L, 1.233585992097580296336099501489175967033e-29L);
6516 TEST_f_f (erfc, 0x1.ffffc8p+2L, 1.122671365033056305522366683719541099329e-29L);
2550dfe9
AJ
6517#ifdef TEST_LDOUBLE
6518 /* The result can only be represented in long double. */
f964490f 6519# if LDBL_MIN_10_EXP < -319
2550dfe9 6520 TEST_f_f (erfc, 27.0L, 0.523704892378925568501606768284954709e-318L);
f964490f 6521# endif
7b1902cb
JM
6522# if LDBL_MANT_DIG >= 106
6523 TEST_f_f (erfc, 0x1.ffff56789abcdef0123456789a8p+2L, 1.123161416304655390092138725253789378459e-29L);
6524# endif
2550dfe9 6525#endif
8847214f
UD
6526
6527 END (erfc);
6528}
6529
2550dfe9 6530
8847214f
UD
6531static void
6532exp_test (void)
6533{
e6d3c4a7
AJ
6534 errno = 0;
6535 FUNC(exp) (0);
6536 if (errno == ENOSYS)
6537 /* Function not implemented. */
6538 return;
6539
8847214f
UD
6540 START (exp);
6541
6542 TEST_f_f (exp, 0, 1);
6543 TEST_f_f (exp, minus_zero, 1);
6544
15daa639 6545#ifndef TEST_INLINE
8847214f
UD
6546 TEST_f_f (exp, plus_infty, plus_infty);
6547 TEST_f_f (exp, minus_infty, 0);
15daa639 6548#endif
67e971f1 6549 TEST_f_f (exp, qnan_value, qnan_value);
8847214f
UD
6550 TEST_f_f (exp, 1, M_El);
6551
6552 TEST_f_f (exp, 2, M_E2l);
6553 TEST_f_f (exp, 3, M_E3l);
2550dfe9 6554 TEST_f_f (exp, 0.75L, 2.11700001661267466854536981983709561L);
4c95adde 6555 TEST_f_f (exp, 50.0L, 5184705528587072464087.45332293348538L);
a7eb802f 6556 TEST_f_f (exp, 88.72269439697265625L, 3.40233126623160774937554134772290447915e38L);
e42a38dd
AZ
6557#ifndef TEST_FLOAT
6558 TEST_f_f (exp, 709.75L, 1.739836873264160557698252711673830393864768e+308L);
6559#endif
8fb0af98
UD
6560#if defined TEST_LDOUBLE && __LDBL_MAX_EXP__ > 1024
6561 /* The result can only be represented in sane long double. */
4c95adde
AJ
6562 TEST_f_f (exp, 1000.0L, 0.197007111401704699388887935224332313e435L);
6563#endif
2550dfe9 6564
41498f4d
JM
6565#if !(defined TEST_LDOUBLE && LDBL_MAX_EXP > 1024)
6566 TEST_f_f (exp, 710, plus_infty, OVERFLOW_EXCEPTION);
7a25eb06 6567 TEST_f_f (exp, -1234, plus_zero, UNDERFLOW_EXCEPTION);
41498f4d
JM
6568#endif
6569 TEST_f_f (exp, 1e5, plus_infty, OVERFLOW_EXCEPTION);
6570 TEST_f_f (exp, max_value, plus_infty, OVERFLOW_EXCEPTION);
80bad0cc 6571 TEST_f_f (exp, -max_value, 0, UNDERFLOW_EXCEPTION);
41bf21a1 6572
8847214f
UD
6573 END (exp);
6574}
6575
6576
28afd92d
JM
6577static void
6578exp_test_tonearest (void)
6579{
6580 int save_round_mode;
6581 errno = 0;
6582 FUNC(exp) (0);
6583 if (errno == ENOSYS)
6584 /* Function not implemented. */
6585 return;
6586
6587 START (exp_tonearest);
6588
6589 save_round_mode = fegetround ();
6590
6591 if (!fesetround (FE_TONEAREST))
6592 {
6593 TEST_f_f (exp, 1, M_El);
6594 TEST_f_f (exp, 2, M_E2l);
6595 TEST_f_f (exp, 3, M_E3l);
6596 }
6597
6598 fesetround (save_round_mode);
6599
6600 END (exp_tonearest);
6601}
6602
6603
6604static void
6605exp_test_towardzero (void)
6606{
6607 int save_round_mode;
6608 errno = 0;
6609 FUNC(exp) (0);
6610 if (errno == ENOSYS)
6611 /* Function not implemented. */
6612 return;
6613
6614 START (exp_towardzero);
6615
6616 save_round_mode = fegetround ();
6617
6618 if (!fesetround (FE_TOWARDZERO))
6619 {
6620 TEST_f_f (exp, 1, M_El);
6621 TEST_f_f (exp, 2, M_E2l);
6622 TEST_f_f (exp, 3, M_E3l);
6623 }
6624
6625 fesetround (save_round_mode);
6626
6627 END (exp_towardzero);
6628}
6629
6630
6631static void
6632exp_test_downward (void)
6633{
6634 int save_round_mode;
6635 errno = 0;
6636 FUNC(exp) (0);
6637 if (errno == ENOSYS)
6638 /* Function not implemented. */
6639 return;
6640
6641 START (exp_downward);
6642
6643 save_round_mode = fegetround ();
6644
6645 if (!fesetround (FE_DOWNWARD))
6646 {
6647 TEST_f_f (exp, 1, M_El);
6648 TEST_f_f (exp, 2, M_E2l);
6649 TEST_f_f (exp, 3, M_E3l);
6650 }
6651
6652 fesetround (save_round_mode);
6653
6654 END (exp_downward);
6655}
6656
6657
6658static void
6659exp_test_upward (void)
6660{
6661 int save_round_mode;
6662 errno = 0;
6663 FUNC(exp) (0);
6664 if (errno == ENOSYS)
6665 /* Function not implemented. */
6666 return;
6667
6668 START (exp_upward);
6669
6670 save_round_mode = fegetround ();
6671
6672 if (!fesetround (FE_UPWARD))
6673 {
6674 TEST_f_f (exp, 1, M_El);
6675 TEST_f_f (exp, 2, M_E2l);
6676 TEST_f_f (exp, 3, M_E3l);
6677 }
6678
6679 fesetround (save_round_mode);
6680
6681 END (exp_upward);
6682}
6683
6684
8847214f
UD
6685static void
6686exp10_test (void)
6687{
6688 errno = 0;
6689 FUNC(exp10) (0);
6690 if (errno == ENOSYS)
6691 /* Function not implemented. */
6692 return;
6693
6694 START (exp10);
6695
6696 TEST_f_f (exp10, 0, 1);
6697 TEST_f_f (exp10, minus_zero, 1);
6698
6699 TEST_f_f (exp10, plus_infty, plus_infty);
6700 TEST_f_f (exp10, minus_infty, 0);
67e971f1 6701 TEST_f_f (exp10, qnan_value, qnan_value);
8847214f 6702 TEST_f_f (exp10, 3, 1000);
42be70d4 6703 TEST_f_f (exp10, -1, 0.1L);
9568c0c2 6704 TEST_f_f (exp10, 36, 1.0e36L);
d8b82cad
JM
6705 TEST_f_f (exp10, -36, 1.0e-36L);
6706#ifndef TEST_FLOAT
6707 TEST_f_f (exp10, 305, 1.0e305L);
80bad0cc 6708 TEST_f_f (exp10, -305, 1.0e-305L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM);
d8b82cad
JM
6709#endif
6710#if defined TEST_LDOUBLE && LDBL_MAX_10_EXP >= 4932
6711 TEST_f_f (exp10, 4932, 1.0e4932L);
80bad0cc 6712 TEST_f_f (exp10, -4932, 1.0e-4932L, UNDERFLOW_EXCEPTION);
9568c0c2 6713#endif
c135cc1b 6714 TEST_f_f (exp10, 1e6, plus_infty, OVERFLOW_EXCEPTION);
80bad0cc 6715 TEST_f_f (exp10, -1e6, 0, UNDERFLOW_EXCEPTION);
41bf21a1 6716 TEST_f_f (exp10, max_value, plus_infty, OVERFLOW_EXCEPTION);
80bad0cc 6717 TEST_f_f (exp10, -max_value, 0, UNDERFLOW_EXCEPTION);
2550dfe9 6718 TEST_f_f (exp10, 0.75L, 5.62341325190349080394951039776481231L);
8847214f
UD
6719
6720 END (exp10);
6721}
6722
2550dfe9 6723
8847214f
UD
6724static void
6725exp2_test (void)
6726{
6727 errno = 0;
6728 FUNC(exp2) (0);
6729 if (errno == ENOSYS)
6730 /* Function not implemented. */
6731 return;
6732
6733 START (exp2);
6734
6735 TEST_f_f (exp2, 0, 1);
6736 TEST_f_f (exp2, minus_zero, 1);
6737 TEST_f_f (exp2, plus_infty, plus_infty);
6738 TEST_f_f (exp2, minus_infty, 0);
67e971f1 6739 TEST_f_f (exp2, qnan_value, qnan_value);
15daa639 6740
8847214f
UD
6741 TEST_f_f (exp2, 10, 1024);
6742 TEST_f_f (exp2, -1, 0.5);
0cb7efc5 6743 TEST_f_f (exp2, 1e6, plus_infty, OVERFLOW_EXCEPTION);
80bad0cc 6744 TEST_f_f (exp2, -1e6, 0, UNDERFLOW_EXCEPTION);
41bf21a1 6745 TEST_f_f (exp2, max_value, plus_infty, OVERFLOW_EXCEPTION);
80bad0cc 6746 TEST_f_f (exp2, -max_value, 0, UNDERFLOW_EXCEPTION);
2550dfe9 6747 TEST_f_f (exp2, 0.75L, 1.68179283050742908606225095246642979L);
8847214f 6748
48e44791
JM
6749 TEST_f_f (exp2, 100.5, 1.792728671193156477399422023278661496394e+30L);
6750 TEST_f_f (exp2, 127, 0x1p127);
6751 TEST_f_f (exp2, -149, 0x1p-149);
6752
6753#ifndef TEST_FLOAT
6754 TEST_f_f (exp2, 1000.25, 1.274245659452564874772384918171765416737e+301L);
6755 TEST_f_f (exp2, 1023, 0x1p1023);
6756 TEST_f_f (exp2, -1074, 0x1p-1074);
6757#endif
6758
6759#if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
6760 TEST_f_f (exp2, 16383, 0x1p16383L);
6761 TEST_f_f (exp2, -16400, 0x1p-16400L);
6762#endif
6763
8847214f
UD
6764 END (exp2);
6765}
6766
2550dfe9 6767
8847214f
UD
6768static void
6769expm1_test (void)
6770{
e6d3c4a7
AJ
6771 errno = 0;
6772 FUNC(expm1) (0);
6773 if (errno == ENOSYS)
6774 /* Function not implemented. */
6775 return;
6776
8847214f
UD
6777 START (expm1);
6778
6779 TEST_f_f (expm1, 0, 0);
6780 TEST_f_f (expm1, minus_zero, minus_zero);
6781
15daa639 6782#ifndef TEST_INLINE
8847214f
UD
6783 TEST_f_f (expm1, plus_infty, plus_infty);
6784 TEST_f_f (expm1, minus_infty, -1);
15daa639 6785#endif
67e971f1 6786 TEST_f_f (expm1, qnan_value, qnan_value);
8847214f
UD
6787
6788 TEST_f_f (expm1, 1, M_El - 1.0);
2550dfe9 6789 TEST_f_f (expm1, 0.75L, 1.11700001661267466854536981983709561L);
8847214f 6790
495fd99f
JM
6791 TEST_f_f (expm1, 50.0L, 5.1847055285870724640864533229334853848275e+21L);
6792
6793#ifndef TEST_FLOAT
6794 TEST_f_f (expm1, 127.0L, 1.4302079958348104463583671072905261080748e+55L);
6795 TEST_f_f (expm1, 500.0L, 1.4035922178528374107397703328409120821806e+217L);
6796#endif
6797
0fcad3e2
JM
6798#if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
6799 TEST_f_f (expm1, 11356.25L, 9.05128237311923300051376115753226014206e+4931L);
6800#endif
6801
f17ac40d
JM
6802 TEST_f_f (expm1, -10.0, -0.9999546000702375151484644084844394493898L);
6803 TEST_f_f (expm1, -16.0, -0.9999998874648252807408854862248209398728L);
6804 TEST_f_f (expm1, -17.0, -0.9999999586006228121483334034897228104472L);
6805 TEST_f_f (expm1, -18.0, -0.9999999847700202552873715638633707664826L);
6806 TEST_f_f (expm1, -36.0, -0.9999999999999997680477169756430611687736L);
6807 TEST_f_f (expm1, -37.0, -0.9999999999999999146695237425593420572195L);
6808 TEST_f_f (expm1, -38.0, -0.9999999999999999686086720795197037129104L);
6809 TEST_f_f (expm1, -44.0, -0.9999999999999999999221886775886620348429L);
6810 TEST_f_f (expm1, -45.0, -0.9999999999999999999713748141945060635553L);
6811 TEST_f_f (expm1, -46.0, -0.9999999999999999999894693826424461876212L);
6812 TEST_f_f (expm1, -73.0, -0.9999999999999999999999999999999802074012L);
6813 TEST_f_f (expm1, -74.0, -0.9999999999999999999999999999999927187098L);
6814 TEST_f_f (expm1, -75.0, -0.9999999999999999999999999999999973213630L);
6815 TEST_f_f (expm1, -78.0, -0.9999999999999999999999999999999998666385L);
6816 TEST_f_f (expm1, -79.0, -0.9999999999999999999999999999999999509391L);
6817 TEST_f_f (expm1, -80.0, -0.9999999999999999999999999999999999819515L);
6818 TEST_f_f (expm1, -100.0, -1.0);
6819 TEST_f_f (expm1, -1000.0, -1.0);
6820 TEST_f_f (expm1, -10000.0, -1.0);
6821 TEST_f_f (expm1, -100000.0, -1.0);
6822
bbc5d74d 6823 errno = 0;
41498f4d 6824 TEST_f_f (expm1, 100000.0, plus_infty, OVERFLOW_EXCEPTION);
bbc5d74d 6825 check_int ("errno for expm1(large) == ERANGE", errno, ERANGE, 0, 0, 0);
41498f4d 6826 TEST_f_f (expm1, max_value, plus_infty, OVERFLOW_EXCEPTION);
f17ac40d 6827 TEST_f_f (expm1, -max_value, -1);
bbc5d74d 6828
8847214f
UD
6829 END (expm1);
6830}
6831
2550dfe9 6832
8847214f
UD
6833static void
6834fabs_test (void)
6835{
6836 START (fabs);
6837
6838 TEST_f_f (fabs, 0, 0);
6839 TEST_f_f (fabs, minus_zero, 0);
6840
6841 TEST_f_f (fabs, plus_infty, plus_infty);
6842 TEST_f_f (fabs, minus_infty, plus_infty);
67e971f1 6843 TEST_f_f (fabs, qnan_value, qnan_value);
8847214f
UD
6844
6845 TEST_f_f (fabs, 38.0, 38.0);
6846 TEST_f_f (fabs, -M_El, M_El);
6847
6848 END (fabs);
6849}
6850
2550dfe9 6851
8847214f
UD
6852static void
6853fdim_test (void)
6854{
6855 START (fdim);
6856
6857 TEST_ff_f (fdim, 0, 0, 0);
6858 TEST_ff_f (fdim, 9, 0, 9);
6859 TEST_ff_f (fdim, 0, 9, 0);
6860 TEST_ff_f (fdim, -9, 0, 0);
6861 TEST_ff_f (fdim, 0, -9, 9);
6862
6863 TEST_ff_f (fdim, plus_infty, 9, plus_infty);
6864 TEST_ff_f (fdim, plus_infty, -9, plus_infty);
6865 TEST_ff_f (fdim, minus_infty, 9, 0);
6866 TEST_ff_f (fdim, minus_infty, -9, 0);
6867 TEST_ff_f (fdim, 9, minus_infty, plus_infty);
6868 TEST_ff_f (fdim, -9, minus_infty, plus_infty);
6869 TEST_ff_f (fdim, 9, plus_infty, 0);
6870 TEST_ff_f (fdim, -9, plus_infty, 0);
6871
67e971f1
TS
6872 TEST_ff_f (fdim, 0, qnan_value, qnan_value);
6873 TEST_ff_f (fdim, 9, qnan_value, qnan_value);
6874 TEST_ff_f (fdim, -9, qnan_value, qnan_value);
6875 TEST_ff_f (fdim, qnan_value, 9, qnan_value);
6876 TEST_ff_f (fdim, qnan_value, -9, qnan_value);
6877 TEST_ff_f (fdim, plus_infty, qnan_value, qnan_value);
6878 TEST_ff_f (fdim, minus_infty, qnan_value, qnan_value);
6879 TEST_ff_f (fdim, qnan_value, plus_infty, qnan_value);
6880 TEST_ff_f (fdim, qnan_value, minus_infty, qnan_value);
6881 TEST_ff_f (fdim, qnan_value, qnan_value, qnan_value);
8847214f 6882
6497a1d0
UD
6883 TEST_ff_f (fdim, plus_infty, plus_infty, 0);
6884
8847214f
UD
6885 END (fdim);
6886}
6887
2550dfe9 6888
ef1bb361
JM
6889static void
6890finite_test (void)
6891{
6892 START (finite);
6893
6894 TEST_f_b (finite, 0, 1);
6895 TEST_f_b (finite, minus_zero, 1);
6896 TEST_f_b (finite, 10, 1);
6897 TEST_f_b (finite, min_subnorm_value, 1);
6898 TEST_f_b (finite, plus_infty, 0);
6899 TEST_f_b (finite, minus_infty, 0);
67e971f1 6900 TEST_f_b (finite, qnan_value, 0);
ef1bb361
JM
6901
6902 END (finite);
6903}
6904
6905
8847214f
UD
6906static void
6907floor_test (void)
6908{
6909 START (floor);
6910
6911 TEST_f_f (floor, 0.0, 0.0);
6912 TEST_f_f (floor, minus_zero, minus_zero);
6913 TEST_f_f (floor, plus_infty, plus_infty);
6914 TEST_f_f (floor, minus_infty, minus_infty);
67e971f1 6915 TEST_f_f (floor, qnan_value, qnan_value);
8847214f
UD
6916
6917 TEST_f_f (floor, M_PIl, 3.0);
6918 TEST_f_f (floor, -M_PIl, -4.0);
6919
5c68d401 6920 TEST_f_f (floor, 0.1, 0.0);
97fd3a30 6921 TEST_f_f (floor, 0.25, 0.0);
5c68d401
RM
6922 TEST_f_f (floor, 0.625, 0.0);
6923 TEST_f_f (floor, -0.1, -1.0);
97fd3a30 6924 TEST_f_f (floor, -0.25, -1.0);
5c68d401 6925 TEST_f_f (floor, -0.625, -1.0);
f964490f
RM
6926
6927#ifdef TEST_LDOUBLE
6928 /* The result can only be represented in long double. */
6929 TEST_f_f (floor, 4503599627370495.5L, 4503599627370495.0L);
6930 TEST_f_f (floor, 4503599627370496.25L, 4503599627370496.0L);
6931 TEST_f_f (floor, 4503599627370496.5L, 4503599627370496.0L);
6932 TEST_f_f (floor, 4503599627370496.75L, 4503599627370496.0L);
6933 TEST_f_f (floor, 4503599627370497.5L, 4503599627370497.0L);
5c68d401
RM
6934# if LDBL_MANT_DIG > 100
6935 TEST_f_f (floor, 4503599627370494.5000000000001L, 4503599627370494.0L);
6936 TEST_f_f (floor, 4503599627370495.5000000000001L, 4503599627370495.0L);
6937 TEST_f_f (floor, 4503599627370496.5000000000001L, 4503599627370496.0L);
6938# endif
f964490f
RM
6939
6940 TEST_f_f (floor, -4503599627370495.5L, -4503599627370496.0L);
6941 TEST_f_f (floor, -4503599627370496.25L, -4503599627370497.0L);
6942 TEST_f_f (floor, -4503599627370496.5L, -4503599627370497.0L);
6943 TEST_f_f (floor, -4503599627370496.75L, -4503599627370497.0L);
6944 TEST_f_f (floor, -4503599627370497.5L, -4503599627370498.0L);
5c68d401
RM
6945# if LDBL_MANT_DIG > 100
6946 TEST_f_f (floor, -4503599627370494.5000000000001L, -4503599627370495.0L);
6947 TEST_f_f (floor, -4503599627370495.5000000000001L, -4503599627370496.0L);
6948 TEST_f_f (floor, -4503599627370496.5000000000001L, -4503599627370497.0L);
6949# endif
f964490f
RM
6950
6951 TEST_f_f (floor, 9007199254740991.5L, 9007199254740991.0L);
6952 TEST_f_f (floor, 9007199254740992.25L, 9007199254740992.0L);
6953 TEST_f_f (floor, 9007199254740992.5L, 9007199254740992.0L);
6954 TEST_f_f (floor, 9007199254740992.75L, 9007199254740992.0L);
6955 TEST_f_f (floor, 9007199254740993.5L, 9007199254740993.0L);
6956
5c68d401
RM
6957# if LDBL_MANT_DIG > 100
6958 TEST_f_f (floor, 9007199254740991.0000000000001L, 9007199254740991.0L);
6959 TEST_f_f (floor, 9007199254740992.0000000000001L, 9007199254740992.0L);
6960 TEST_f_f (floor, 9007199254740993.0000000000001L, 9007199254740993.0L);
6961 TEST_f_f (floor, 9007199254740991.5000000000001L, 9007199254740991.0L);
6962 TEST_f_f (floor, 9007199254740992.5000000000001L, 9007199254740992.0L);
6963 TEST_f_f (floor, 9007199254740993.5000000000001L, 9007199254740993.0L);
6964# endif
6965
f964490f
RM
6966 TEST_f_f (floor, -9007199254740991.5L, -9007199254740992.0L);
6967 TEST_f_f (floor, -9007199254740992.25L, -9007199254740993.0L);
6968 TEST_f_f (floor, -9007199254740992.5L, -9007199254740993.0L);
6969 TEST_f_f (floor, -9007199254740992.75L, -9007199254740993.0L);
6970 TEST_f_f (floor, -9007199254740993.5L, -9007199254740994.0L);
6971
5c68d401
RM
6972# if LDBL_MANT_DIG > 100
6973 TEST_f_f (floor, -9007199254740991.0000000000001L, -9007199254740992.0L);
6974 TEST_f_f (floor, -9007199254740992.0000000000001L, -9007199254740993.0L);
6975 TEST_f_f (floor, -9007199254740993.0000000000001L, -9007199254740994.0L);
6976 TEST_f_f (floor, -9007199254740991.5000000000001L, -9007199254740992.0L);
6977 TEST_f_f (floor, -9007199254740992.5000000000001L, -9007199254740993.0L);
6978 TEST_f_f (floor, -9007199254740993.5000000000001L, -9007199254740994.0L);
6979# endif
6980
f964490f
RM
6981 TEST_f_f (floor, 72057594037927935.5L, 72057594037927935.0L);
6982 TEST_f_f (floor, 72057594037927936.25L, 72057594037927936.0L);
6983 TEST_f_f (floor, 72057594037927936.5L, 72057594037927936.0L);
6984 TEST_f_f (floor, 72057594037927936.75L, 72057594037927936.0L);
6985 TEST_f_f (floor, 72057594037927937.5L, 72057594037927937.0L);
6986
6987 TEST_f_f (floor, -72057594037927935.5L, -72057594037927936.0L);
6988 TEST_f_f (floor, -72057594037927936.25L, -72057594037927937.0L);
6989 TEST_f_f (floor, -72057594037927936.5L, -72057594037927937.0L);
6990 TEST_f_f (floor, -72057594037927936.75L, -72057594037927937.0L);
6991 TEST_f_f (floor, -72057594037927937.5L, -72057594037927938.0L);
6992
6993 TEST_f_f (floor, 10141204801825835211973625643007.5L, 10141204801825835211973625643007.0L);
6994 TEST_f_f (floor, 10141204801825835211973625643008.25L, 10141204801825835211973625643008.0L);
6995 TEST_f_f (floor, 10141204801825835211973625643008.5L, 10141204801825835211973625643008.0L);
6996 TEST_f_f (floor, 10141204801825835211973625643008.75L, 10141204801825835211973625643008.0L);
6997 TEST_f_f (floor, 10141204801825835211973625643009.5L, 10141204801825835211973625643009.0L);
94e02fc4
AZ
6998
6999 TEST_f_f (floor, 0xf.ffffffffffffff8p+47L, 0xf.fffffffffffep+47L);
7000 TEST_f_f (floor, -0x8.000000000000004p+48L, -0x8.000000000001p+48L);
f964490f
RM
7001#endif
7002
8847214f
UD
7003 END (floor);
7004}
7005
2550dfe9 7006
8847214f
UD
7007static void
7008fma_test (void)
7009{
7010 START (fma);
7011
7012 TEST_fff_f (fma, 1.0, 2.0, 3.0, 5.0);
67e971f1
TS
7013 TEST_fff_f (fma, qnan_value, 2.0, 3.0, qnan_value);
7014 TEST_fff_f (fma, 1.0, qnan_value, 3.0, qnan_value);
7015 TEST_fff_f (fma, 1.0, 2.0, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
7016 TEST_fff_f (fma, plus_infty, 0.0, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
7017 TEST_fff_f (fma, minus_infty, 0.0, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
7018 TEST_fff_f (fma, 0.0, plus_infty, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
7019 TEST_fff_f (fma, 0.0, minus_infty, qnan_value, qnan_value, INVALID_EXCEPTION_OK);
7020 TEST_fff_f (fma, plus_infty, 0.0, 1.0, qnan_value, INVALID_EXCEPTION);
7021 TEST_fff_f (fma, minus_infty, 0.0, 1.0, qnan_value, INVALID_EXCEPTION);
7022 TEST_fff_f (fma, 0.0, plus_infty, 1.0, qnan_value, INVALID_EXCEPTION);
7023 TEST_fff_f (fma, 0.0, minus_infty, 1.0, qnan_value, INVALID_EXCEPTION);
7024
7025 TEST_fff_f (fma, plus_infty, plus_infty, minus_infty, qnan_value, INVALID_EXCEPTION);
7026 TEST_fff_f (fma, minus_infty, plus_infty, plus_infty, qnan_value, INVALID_EXCEPTION);
7027 TEST_fff_f (fma, plus_infty, minus_infty, plus_infty, qnan_value, INVALID_EXCEPTION);
7028 TEST_fff_f (fma, minus_infty, minus_infty, minus_infty, qnan_value, INVALID_EXCEPTION);
7029 TEST_fff_f (fma, plus_infty, 3.5L, minus_infty, qnan_value, INVALID_EXCEPTION);
7030 TEST_fff_f (fma, minus_infty, -7.5L, minus_infty, qnan_value, INVALID_EXCEPTION);
7031 TEST_fff_f (fma, -13.5L, plus_infty, plus_infty, qnan_value, INVALID_EXCEPTION);
7032 TEST_fff_f (fma, minus_infty, 7.5L, plus_infty, qnan_value, INVALID_EXCEPTION);
8847214f 7033
2550dfe9 7034 TEST_fff_f (fma, 1.25L, 0.75L, 0.0625L, 1.0L);
3e692e05
JJ
7035
7036 FLOAT fltmax = CHOOSE (LDBL_MAX, DBL_MAX, FLT_MAX,
7037 LDBL_MAX, DBL_MAX, FLT_MAX);
7038 TEST_fff_f (fma, -fltmax, -fltmax, minus_infty, minus_infty);
7039 TEST_fff_f (fma, fltmax / 2, fltmax / 2, minus_infty, minus_infty);
7040 TEST_fff_f (fma, -fltmax, fltmax, plus_infty, plus_infty);
7041 TEST_fff_f (fma, fltmax / 2, -fltmax / 4, plus_infty, plus_infty);
7042 TEST_fff_f (fma, plus_infty, 4, plus_infty, plus_infty);
7043 TEST_fff_f (fma, 2, minus_infty, minus_infty, minus_infty);
7044 TEST_fff_f (fma, minus_infty, minus_infty, plus_infty, plus_infty);
7045 TEST_fff_f (fma, plus_infty, minus_infty, minus_infty, minus_infty);
7046
8ec5b013
JM
7047 TEST_fff_f (fma, plus_zero, plus_zero, plus_zero, plus_zero);
7048 TEST_fff_f (fma, plus_zero, plus_zero, minus_zero, plus_zero);
7049 TEST_fff_f (fma, plus_zero, minus_zero, plus_zero, plus_zero);
7050 TEST_fff_f (fma, plus_zero, minus_zero, minus_zero, minus_zero);
7051 TEST_fff_f (fma, minus_zero, plus_zero, plus_zero, plus_zero);
7052 TEST_fff_f (fma, minus_zero, plus_zero, minus_zero, minus_zero);
7053 TEST_fff_f (fma, minus_zero, minus_zero, plus_zero, plus_zero);
7054 TEST_fff_f (fma, minus_zero, minus_zero, minus_zero, plus_zero);
7055 TEST_fff_f (fma, 1.0, plus_zero, plus_zero, plus_zero);
7056 TEST_fff_f (fma, 1.0, plus_zero, minus_zero, plus_zero);
7057 TEST_fff_f (fma, 1.0, minus_zero, plus_zero, plus_zero);
7058 TEST_fff_f (fma, 1.0, minus_zero, minus_zero, minus_zero);
7059 TEST_fff_f (fma, -1.0, plus_zero, plus_zero, plus_zero);
7060 TEST_fff_f (fma, -1.0, plus_zero, minus_zero, minus_zero);
7061 TEST_fff_f (fma, -1.0, minus_zero, plus_zero, plus_zero);
7062 TEST_fff_f (fma, -1.0, minus_zero, minus_zero, plus_zero);
7063 TEST_fff_f (fma, plus_zero, 1.0, plus_zero, plus_zero);
7064 TEST_fff_f (fma, plus_zero, 1.0, minus_zero, plus_zero);
7065 TEST_fff_f (fma, plus_zero, -1.0, plus_zero, plus_zero);
7066 TEST_fff_f (fma, plus_zero, -1.0, minus_zero, minus_zero);
7067 TEST_fff_f (fma, minus_zero, 1.0, plus_zero, plus_zero);
7068 TEST_fff_f (fma, minus_zero, 1.0, minus_zero, minus_zero);
7069 TEST_fff_f (fma, minus_zero, -1.0, plus_zero, plus_zero);
7070 TEST_fff_f (fma, minus_zero, -1.0, minus_zero, plus_zero);
7071
7072 TEST_fff_f (fma, 1.0, 1.0, -1.0, plus_zero);
7073 TEST_fff_f (fma, 1.0, -1.0, 1.0, plus_zero);
7074 TEST_fff_f (fma, -1.0, 1.0, 1.0, plus_zero);
7075 TEST_fff_f (fma, -1.0, -1.0, -1.0, plus_zero);
7076
bec749fd
JM
7077 TEST_fff_f (fma, min_value, min_value, plus_zero, plus_zero, UNDERFLOW_EXCEPTION);
7078 TEST_fff_f (fma, min_value, min_value, minus_zero, plus_zero, UNDERFLOW_EXCEPTION);
7079 TEST_fff_f (fma, min_value, -min_value, plus_zero, minus_zero, UNDERFLOW_EXCEPTION);
7080 TEST_fff_f (fma, min_value, -min_value, minus_zero, minus_zero, UNDERFLOW_EXCEPTION);
7081 TEST_fff_f (fma, -min_value, min_value, plus_zero, minus_zero, UNDERFLOW_EXCEPTION);
7082 TEST_fff_f (fma, -min_value, min_value, minus_zero, minus_zero, UNDERFLOW_EXCEPTION);
7083 TEST_fff_f (fma, -min_value, -min_value, plus_zero, plus_zero, UNDERFLOW_EXCEPTION);
7084 TEST_fff_f (fma, -min_value, -min_value, minus_zero, plus_zero, UNDERFLOW_EXCEPTION);
7085
a0c2940d
JM
7086 TEST_fff_f (fma, max_value, max_value, min_value, plus_infty, OVERFLOW_EXCEPTION);
7087 TEST_fff_f (fma, max_value, max_value, -min_value, plus_infty, OVERFLOW_EXCEPTION);
7088 TEST_fff_f (fma, max_value, -max_value, min_value, minus_infty, OVERFLOW_EXCEPTION);
7089 TEST_fff_f (fma, max_value, -max_value, -min_value, minus_infty, OVERFLOW_EXCEPTION);
7090 TEST_fff_f (fma, -max_value, max_value, min_value, minus_infty, OVERFLOW_EXCEPTION);
7091 TEST_fff_f (fma, -max_value, max_value, -min_value, minus_infty, OVERFLOW_EXCEPTION);
7092 TEST_fff_f (fma, -max_value, -max_value, min_value, plus_infty, OVERFLOW_EXCEPTION);
7093 TEST_fff_f (fma, -max_value, -max_value, -min_value, plus_infty, OVERFLOW_EXCEPTION);
7094
5e908464 7095#if defined (TEST_FLOAT) && FLT_MANT_DIG == 24
9ff8d36f
JJ
7096 TEST_fff_f (fma, 0x1.7ff8p+13, 0x1.000002p+0, 0x1.ffffp-24, 0x1.7ff802p+13);
7097 TEST_fff_f (fma, 0x1.fffp+0, 0x1.00001p+0, -0x1.fffp+0, 0x1.fffp-20);
5e908464
JJ
7098 TEST_fff_f (fma, 0x1.9abcdep+127, 0x0.9abcdep-126, -0x1.f08948p+0, 0x1.bb421p-25);
7099 TEST_fff_f (fma, 0x1.9abcdep+100, 0x0.9abcdep-126, -0x1.f08948p-27, 0x1.bb421p-52);
7100 TEST_fff_f (fma, 0x1.fffffep+127, 0x1.001p+0, -0x1.fffffep+127, 0x1.fffffep+115);
7101 TEST_fff_f (fma, -0x1.fffffep+127, 0x1.fffffep+0, 0x1.fffffep+127, -0x1.fffffap+127);
7102 TEST_fff_f (fma, 0x1.fffffep+127, 2.0, -0x1.fffffep+127, 0x1.fffffep+127);
8627a232
JM
7103 TEST_fff_f (fma, 0x1.4p-126, 0x1.000004p-1, 0x1p-128, 0x1.c00004p-127, UNDERFLOW_EXCEPTION);
7104 TEST_fff_f (fma, -0x1.4p-126, 0x1.000004p-1, -0x1p-128, -0x1.c00004p-127, UNDERFLOW_EXCEPTION);
ef82f4da
JM
7105 TEST_fff_f (fma, 0x1.fffff8p-126, 0x1.000002p-1, 0x1p-149, 0x1p-126, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING);
7106 TEST_fff_f (fma, -0x1.fffff8p-126, 0x1.000002p-1, -0x1p-149, -0x1p-126, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING);
7107 TEST_fff_f (fma, 0x1p-149, 0x1p-1, 0x0.fffffep-126, 0x1p-126, UNDERFLOW_EXCEPTION);
7108 TEST_fff_f (fma, -0x1p-149, 0x1p-1, -0x0.fffffep-126, -0x1p-126, UNDERFLOW_EXCEPTION);
7109 TEST_fff_f (fma, 0x1p-149, 0x1.1p-1, 0x0.fffffep-126, 0x1p-126, UNDERFLOW_EXCEPTION);
7110 TEST_fff_f (fma, -0x1p-149, 0x1.1p-1, -0x0.fffffep-126, -0x1p-126, UNDERFLOW_EXCEPTION);
473611b2
JM
7111 TEST_fff_f (fma, 0x1p-149, 0x1p-149, 0x1p127, 0x1p127);
7112 TEST_fff_f (fma, 0x1p-149, -0x1p-149, 0x1p127, 0x1p127);
7113 TEST_fff_f (fma, 0x1p-149, 0x1p-149, -0x1p127, -0x1p127);
7114 TEST_fff_f (fma, 0x1p-149, -0x1p-149, -0x1p127, -0x1p127);
7115 TEST_fff_f (fma, 0x1p-149, 0x1p-149, 0x1p-126, 0x1p-126);
7116 TEST_fff_f (fma, 0x1p-149, -0x1p-149, 0x1p-126, 0x1p-126, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING);
7117 TEST_fff_f (fma, 0x1p-149, 0x1p-149, -0x1p-126, -0x1p-126, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING);
7118 TEST_fff_f (fma, 0x1p-149, -0x1p-149, -0x1p-126, -0x1p-126);
7119 TEST_fff_f (fma, 0x1p-149, 0x1p-149, 0x0.fffffep-126, 0x0.fffffep-126, UNDERFLOW_EXCEPTION);
7120 TEST_fff_f (fma, 0x1p-149, -0x1p-149, 0x0.fffffep-126, 0x0.fffffep-126, UNDERFLOW_EXCEPTION);
7121 TEST_fff_f (fma, 0x1p-149, 0x1p-149, -0x0.fffffep-126, -0x0.fffffep-126, UNDERFLOW_EXCEPTION);
7122 TEST_fff_f (fma, 0x1p-149, -0x1p-149, -0x0.fffffep-126, -0x0.fffffep-126, UNDERFLOW_EXCEPTION);
7123 TEST_fff_f (fma, 0x1p-149, 0x1p-149, 0x1p-149, 0x1p-149, UNDERFLOW_EXCEPTION);
7124 TEST_fff_f (fma, 0x1p-149, -0x1p-149, 0x1p-149, 0x1p-149, UNDERFLOW_EXCEPTION);
7125 TEST_fff_f (fma, 0x1p-149, 0x1p-149, -0x1p-149, -0x1p-149, UNDERFLOW_EXCEPTION);
7126 TEST_fff_f (fma, 0x1p-149, -0x1p-149, -0x1p-149, -0x1p-149, UNDERFLOW_EXCEPTION);
5b5b04d6
JM
7127 TEST_fff_f (fma, 0x0.fffp0, 0x0.fffp0, -0x0.ffep0, 0x1p-24);
7128 TEST_fff_f (fma, 0x0.fffp0, -0x0.fffp0, 0x0.ffep0, -0x1p-24);
7129 TEST_fff_f (fma, -0x0.fffp0, 0x0.fffp0, 0x0.ffep0, -0x1p-24);
7130 TEST_fff_f (fma, -0x0.fffp0, -0x0.fffp0, -0x0.ffep0, 0x1p-24);
82477c28
JM
7131 TEST_fff_f (fma, 0x1.000002p-126, 0x1.000002p-26, 0x1p127, 0x1p127);
7132 TEST_fff_f (fma, 0x1.000002p-126, -0x1.000002p-26, 0x1p127, 0x1p127);
7133 TEST_fff_f (fma, 0x1.000002p-126, 0x1.000002p-26, -0x1p127, -0x1p127);
7134 TEST_fff_f (fma, 0x1.000002p-126, -0x1.000002p-26, -0x1p127, -0x1p127);
7135 TEST_fff_f (fma, 0x1.000002p-126, 0x1.000002p-26, 0x1p103, 0x1p103);
7136 TEST_fff_f (fma, 0x1.000002p-126, -0x1.000002p-26, 0x1p103, 0x1p103);
7137 TEST_fff_f (fma, 0x1.000002p-126, 0x1.000002p-26, -0x1p103, -0x1p103);
7138 TEST_fff_f (fma, 0x1.000002p-126, -0x1.000002p-26, -0x1p103, -0x1p103);
5e908464
JJ
7139#endif
7140#if defined (TEST_DOUBLE) && DBL_MANT_DIG == 53
7141 TEST_fff_f (fma, 0x1.7fp+13, 0x1.0000000000001p+0, 0x1.ffep-48, 0x1.7f00000000001p+13);
7142 TEST_fff_f (fma, 0x1.fffp+0, 0x1.0000000000001p+0, -0x1.fffp+0, 0x1.fffp-52);
7143 TEST_fff_f (fma, 0x1.0000002p+0, 0x1.ffffffcp-1, 0x1p-300, 1.0);
7144 TEST_fff_f (fma, 0x1.0000002p+0, 0x1.ffffffcp-1, -0x1p-300, 0x1.fffffffffffffp-1);
7145 TEST_fff_f (fma, 0x1.deadbeef2feedp+1023, 0x0.deadbeef2feedp-1022, -0x1.a05f8c01a4bfbp+1, 0x1.0989687bc9da4p-53);
7146 TEST_fff_f (fma, 0x1.deadbeef2feedp+900, 0x0.deadbeef2feedp-1022, -0x1.a05f8c01a4bfbp-122, 0x1.0989687bc9da4p-176);
7147 TEST_fff_f (fma, 0x1.fffffffffffffp+1023, 0x1.001p+0, -0x1.fffffffffffffp+1023, 0x1.fffffffffffffp+1011);
7148 TEST_fff_f (fma, -0x1.fffffffffffffp+1023, 0x1.fffffffffffffp+0, 0x1.fffffffffffffp+1023, -0x1.ffffffffffffdp+1023);
7149 TEST_fff_f (fma, 0x1.fffffffffffffp+1023, 2.0, -0x1.fffffffffffffp+1023, 0x1.fffffffffffffp+1023);
80bad0cc
JM
7150 TEST_fff_f (fma, 0x1.6a09e667f3bccp-538, 0x1.6a09e667f3bccp-538, 0.0, 0.0, UNDERFLOW_EXCEPTION);
7151 TEST_fff_f (fma, 0x1.deadbeef2feedp-495, 0x1.deadbeef2feedp-495, -0x1.bf86a5786a574p-989, 0x0.0000042625a1fp-1022, UNDERFLOW_EXCEPTION);
7152 TEST_fff_f (fma, 0x1.deadbeef2feedp-503, 0x1.deadbeef2feedp-503, -0x1.bf86a5786a574p-1005, 0x0.0000000004262p-1022, UNDERFLOW_EXCEPTION);
7153 TEST_fff_f (fma, 0x1p-537, 0x1p-538, 0x1p-1074, 0x0.0000000000002p-1022, UNDERFLOW_EXCEPTION);
7154 TEST_fff_f (fma, 0x1.7fffff8p-968, 0x1p-106, 0x0.000001p-1022, 0x0.0000010000001p-1022, UNDERFLOW_EXCEPTION);
7155 TEST_fff_f (fma, 0x1.4000004p-967, 0x1p-106, 0x0.000001p-1022, 0x0.0000010000003p-1022, UNDERFLOW_EXCEPTION);
7156 TEST_fff_f (fma, 0x1.4p-967, -0x1p-106, -0x0.000001p-1022, -0x0.0000010000002p-1022, UNDERFLOW_EXCEPTION);
7157 TEST_fff_f (fma, -0x1.19cab66d73e17p-959, 0x1.c7108a8c5ff51p-107, -0x0.80b0ad65d9b64p-1022, -0x0.80b0ad65d9d59p-1022, UNDERFLOW_EXCEPTION);
8627a232 7158 TEST_fff_f (fma, -0x1.d2eaed6e8e9d3p-979, -0x1.4e066c62ac9ddp-63, -0x0.9245e6b003454p-1022, -0x0.9245c09c5fb5dp-1022, UNDERFLOW_EXCEPTION);
80bad0cc 7159 TEST_fff_f (fma, 0x1.153d650bb9f06p-907, 0x1.2d01230d48407p-125, -0x0.b278d5acfc3cp-1022, -0x0.b22757123bbe9p-1022, UNDERFLOW_EXCEPTION);
3e692e05 7160 TEST_fff_f (fma, -0x1.fffffffffffffp-711, 0x1.fffffffffffffp-275, 0x1.fffffe00007ffp-983, 0x1.7ffffe00007ffp-983);
8627a232
JM
7161 TEST_fff_f (fma, 0x1.4p-1022, 0x1.0000000000002p-1, 0x1p-1024, 0x1.c000000000002p-1023, UNDERFLOW_EXCEPTION);
7162 TEST_fff_f (fma, -0x1.4p-1022, 0x1.0000000000002p-1, -0x1p-1024, -0x1.c000000000002p-1023, UNDERFLOW_EXCEPTION);
ef82f4da
JM
7163 TEST_fff_f (fma, 0x1.ffffffffffffcp-1022, 0x1.0000000000001p-1, 0x1p-1074, 0x1p-1022, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING);
7164 TEST_fff_f (fma, -0x1.ffffffffffffcp-1022, 0x1.0000000000001p-1, -0x1p-1074, -0x1p-1022, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING);
7165 TEST_fff_f (fma, 0x1p-1074, 0x1p-1, 0x0.fffffffffffffp-1022, 0x1p-1022, UNDERFLOW_EXCEPTION);
7166 TEST_fff_f (fma, -0x1p-1074, 0x1p-1, -0x0.fffffffffffffp-1022, -0x1p-1022, UNDERFLOW_EXCEPTION);
7167 TEST_fff_f (fma, 0x1p-1074, 0x1.1p-1, 0x0.fffffffffffffp-1022, 0x1p-1022, UNDERFLOW_EXCEPTION);
7168 TEST_fff_f (fma, -0x1p-1074, 0x1.1p-1, -0x0.fffffffffffffp-1022, -0x1p-1022, UNDERFLOW_EXCEPTION);
473611b2
JM
7169 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, 0x1p1023, 0x1p1023);
7170 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, 0x1p1023, 0x1p1023);
7171 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, -0x1p1023, -0x1p1023);
7172 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, -0x1p1023, -0x1p1023);
7173 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, 0x1p-1022, 0x1p-1022);
7174 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, 0x1p-1022, 0x1p-1022, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING);
7175 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, -0x1p-1022, -0x1p-1022, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING);
7176 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, -0x1p-1022, -0x1p-1022);
7177 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, 0x0.fffffffffffffp-1022, 0x0.fffffffffffffp-1022, UNDERFLOW_EXCEPTION);
7178 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, 0x0.fffffffffffffp-1022, 0x0.fffffffffffffp-1022, UNDERFLOW_EXCEPTION);
7179 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, -0x0.fffffffffffffp-1022, -0x0.fffffffffffffp-1022, UNDERFLOW_EXCEPTION);
7180 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, -0x0.fffffffffffffp-1022, -0x0.fffffffffffffp-1022, UNDERFLOW_EXCEPTION);
7181 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, 0x1p-1074, 0x1p-1074, UNDERFLOW_EXCEPTION);
7182 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, 0x1p-1074, 0x1p-1074, UNDERFLOW_EXCEPTION);
7183 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, -0x1p-1074, -0x1p-1074, UNDERFLOW_EXCEPTION);
7184 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, -0x1p-1074, -0x1p-1074, UNDERFLOW_EXCEPTION);
5b5b04d6
JM
7185 TEST_fff_f (fma, 0x0.fffffffffffff8p0, 0x0.fffffffffffff8p0, -0x0.fffffffffffffp0, 0x1p-106);
7186 TEST_fff_f (fma, 0x0.fffffffffffff8p0, -0x0.fffffffffffff8p0, 0x0.fffffffffffffp0, -0x1p-106);
7187 TEST_fff_f (fma, -0x0.fffffffffffff8p0, 0x0.fffffffffffff8p0, 0x0.fffffffffffffp0, -0x1p-106);
7188 TEST_fff_f (fma, -0x0.fffffffffffff8p0, -0x0.fffffffffffff8p0, -0x0.fffffffffffffp0, 0x1p-106);
82477c28
JM
7189 TEST_fff_f (fma, 0x1.0000000000001p-1022, 0x1.0000000000001p-55, 0x1p1023, 0x1p1023);
7190 TEST_fff_f (fma, 0x1.0000000000001p-1022, -0x1.0000000000001p-55, 0x1p1023, 0x1p1023);
7191 TEST_fff_f (fma, 0x1.0000000000001p-1022, 0x1.0000000000001p-55, -0x1p1023, -0x1p1023);
7192 TEST_fff_f (fma, 0x1.0000000000001p-1022, -0x1.0000000000001p-55, -0x1p1023, -0x1p1023);
7193 TEST_fff_f (fma, 0x1.0000000000001p-1022, 0x1.0000000000001p-55, 0x1p970, 0x1p970);
7194 TEST_fff_f (fma, 0x1.0000000000001p-1022, -0x1.0000000000001p-55, 0x1p970, 0x1p970);
7195 TEST_fff_f (fma, 0x1.0000000000001p-1022, 0x1.0000000000001p-55, -0x1p970, -0x1p970);
7196 TEST_fff_f (fma, 0x1.0000000000001p-1022, -0x1.0000000000001p-55, -0x1p970, -0x1p970);
3e692e05
JJ
7197#endif
7198#if defined (TEST_LDOUBLE) && LDBL_MANT_DIG == 64
7199 TEST_fff_f (fma, -0x8.03fcp+3696L, 0xf.fffffffffffffffp-6140L, 0x8.3ffffffffffffffp-2450L, -0x8.01ecp-2440L);
7200 TEST_fff_f (fma, 0x9.fcp+2033L, -0x8.000e1f000ff800fp-3613L, -0xf.fffffffffffc0ffp-1579L, -0xd.fc119fb093ed092p-1577L);
7201 TEST_fff_f (fma, 0xc.7fc000003ffffffp-1194L, 0x8.1e0003fffffffffp+15327L, -0x8.fffep+14072L, 0xc.ae9f164020effffp+14136L);
7202 TEST_fff_f (fma, -0x8.0001fc000000003p+1798L, 0xcp-2230L, 0x8.f7e000000000007p-468L, -0xc.0002f9ffee10404p-429L);
7203 TEST_fff_f (fma, 0xc.0000000000007ffp+10130L, -0x8.000000000000001p+4430L, 0xc.07000000001ffffp+14513L, -0xb.fffffffffffd7e4p+14563L);
8627a232
JM
7204 TEST_fff_f (fma, 0xb.ffffp-4777L, 0x8.000000fffffffffp-11612L, -0x0.3800fff8p-16385L, 0x5.c7fe80c7ffeffffp-16385L, UNDERFLOW_EXCEPTION);
7205 TEST_fff_f (fma, 0x1.4p-16382L, 0x1.0000000000000004p-1L, 0x1p-16384L, 0x1.c000000000000004p-16383L, UNDERFLOW_EXCEPTION);
7206 TEST_fff_f (fma, -0x1.4p-16382L, 0x1.0000000000000004p-1L, -0x1p-16384L, -0x1.c000000000000004p-16383L, UNDERFLOW_EXCEPTION);
ef82f4da
JM
7207 TEST_fff_f (fma, 0x1.fffffffffffffff8p-16382L, 0x1.0000000000000002p-1L, 0x1p-16445L, 0x1p-16382L, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING);
7208 TEST_fff_f (fma, -0x1.fffffffffffffff8p-16382L, 0x1.0000000000000002p-1L, -0x1p-16445L, -0x1p-16382L, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING);
7209 TEST_fff_f (fma, 0x1p-16445L, 0x1p-1L, 0x0.fffffffffffffffep-16382L, 0x1p-16382L, UNDERFLOW_EXCEPTION);
7210 TEST_fff_f (fma, -0x1p-16445L, 0x1p-1L, -0x0.fffffffffffffffep-16382L, -0x1p-16382L, UNDERFLOW_EXCEPTION);
7211 TEST_fff_f (fma, 0x1p-16445L, 0x1.1p-1L, 0x0.fffffffffffffffep-16382L, 0x1p-16382L, UNDERFLOW_EXCEPTION);
7212 TEST_fff_f (fma, -0x1p-16445L, 0x1.1p-1L, -0x0.fffffffffffffffep-16382L, -0x1p-16382L, UNDERFLOW_EXCEPTION);
473611b2
JM
7213 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, 0x1p16383L, 0x1p16383L);
7214 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, 0x1p16383L, 0x1p16383L);
7215 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, -0x1p16383L, -0x1p16383L);
7216 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, -0x1p16383L, -0x1p16383L);
7217 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, 0x1p-16382L, 0x1p-16382L);
7218 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, 0x1p-16382L, 0x1p-16382L, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING);
7219 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, -0x1p-16382L, -0x1p-16382L, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING);
7220 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, -0x1p-16382L, -0x1p-16382L);
7221 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, 0x0.fffffffffffffffep-16382L, 0x0.fffffffffffffffep-16382L, UNDERFLOW_EXCEPTION);
7222 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, 0x0.fffffffffffffffep-16382L, 0x0.fffffffffffffffep-16382L, UNDERFLOW_EXCEPTION);
7223 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, -0x0.fffffffffffffffep-16382L, -0x0.fffffffffffffffep-16382L, UNDERFLOW_EXCEPTION);
7224 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, -0x0.fffffffffffffffep-16382L, -0x0.fffffffffffffffep-16382L, UNDERFLOW_EXCEPTION);
7225 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, 0x1p-16445L, 0x1p-16445L, UNDERFLOW_EXCEPTION);
7226 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, 0x1p-16445L, 0x1p-16445L, UNDERFLOW_EXCEPTION);
7227 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, -0x1p-16445L, -0x1p-16445L, UNDERFLOW_EXCEPTION);
7228 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, -0x1p-16445L, -0x1p-16445L, UNDERFLOW_EXCEPTION);
5b5b04d6
JM
7229 TEST_fff_f (fma, 0x0.ffffffffffffffffp0L, 0x0.ffffffffffffffffp0L, -0x0.fffffffffffffffep0L, 0x1p-128L);
7230 TEST_fff_f (fma, 0x0.ffffffffffffffffp0L, -0x0.ffffffffffffffffp0L, 0x0.fffffffffffffffep0L, -0x1p-128L);
7231 TEST_fff_f (fma, -0x0.ffffffffffffffffp0L, 0x0.ffffffffffffffffp0L, 0x0.fffffffffffffffep0L, -0x1p-128L);
7232 TEST_fff_f (fma, -0x0.ffffffffffffffffp0L, -0x0.ffffffffffffffffp0L, -0x0.fffffffffffffffep0L, 0x1p-128L);
82477c28
JM
7233 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, 0x1.0000000000000002p-66L, 0x1p16383L, 0x1p16383L);
7234 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, -0x1.0000000000000002p-66L, 0x1p16383L, 0x1p16383L);
7235 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, 0x1.0000000000000002p-66L, -0x1p16383L, -0x1p16383L);
7236 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, -0x1.0000000000000002p-66L, -0x1p16383L, -0x1p16383L);
7237 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, 0x1.0000000000000002p-66L, 0x1p16319L, 0x1p16319L);
7238 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, -0x1.0000000000000002p-66L, 0x1p16319L, 0x1p16319L);
7239 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, 0x1.0000000000000002p-66L, -0x1p16319L, -0x1p16319L);
7240 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, -0x1.0000000000000002p-66L, -0x1p16319L, -0x1p16319L);
9ff8d36f 7241#endif
7c08a05c
JJ
7242#if defined (TEST_LDOUBLE) && LDBL_MANT_DIG == 113
7243 TEST_fff_f (fma, 0x1.bb2de33e02ccbbfa6e245a7c1f71p-2584L, -0x1.6b500daf0580d987f1bc0cadfcddp-13777L, 0x1.613cd91d9fed34b33820e5ab9d8dp-16378L, -0x1.3a79fb50eb9ce887cffa0f09bd9fp-16360L);
80bad0cc
JM
7244 TEST_fff_f (fma, -0x1.f949b880cacb0f0c61540105321dp-5954L, -0x1.3876cec84b4140f3bd6198731b7ep-10525L, -0x0.a5dc1c6cfbc498c54fb0b504bf19p-16382L, -0x0.a5dc1c6cfbc498c54fb0b5038abbp-16382L, UNDERFLOW_EXCEPTION);
7245 TEST_fff_f (fma, -0x1.0000fffffffffp-16221L, 0x1.0000001fffff8007fep-239L, 0x0.ff87ffffffffffffe000003fffffp-16382L, 0x0.ff87ffffffffffffdffc003bff7fp-16382L, UNDERFLOW_EXCEPTION);
7c08a05c
JJ
7246 TEST_fff_f (fma, -0x1.ac79c9376ef447f3827c9e9de008p-2228L, -0x1.5ba830022b6139e21fbe7270cad8p-6314L, 0x1.e8282b6a26bb6a9daf5c8e73e9f9p-8616L, 0x1.22f14a0253878a730cd1aee373adp-8541L);
7247 TEST_fff_f (fma, -0x1.c69749ec574caaa2ab8e97ddb9f3p+2652L, 0x1.f34235ff9d095449c29b4831b62dp+3311L, 0x1.fbe4302df23354dbd0c4d3cfe606p+5879L, -0x1.bb473bfdfb7a6e18886ce6e57eafp+5964L);
7248 TEST_fff_f (fma, -0x1.ca8835fc6ecfb5398625fc891be5p-1686L, 0x1.621e1972bbe2180e5be9dd7d8df5p-7671L, -0x1.7d2d21b73b52cf20dec2a83902a4p-9395L, -0x1.3d2322191c9c88bc68a62ab8042cp-9356L);
7249 TEST_fff_f (fma, -0x1.55cff679ec49c2541fab41fc843ep-11819L, 0x1.e60e9f464f9e8df0509647c7c971p+12325L, 0x1.eaa2a7649d765c2f564f7a5beca7p+454L, -0x1.447e29fa7e406a285f4e350fcf86p+507L);
7250 TEST_fff_f (fma, 0x1.f0e7b1454908576f2537d863cf9bp+11432L, 0x1.cdce52f09d4ca76e68706f34b5d5p-1417L, -0x1.2e986187c70f146235ea2066e486p+9979L, 0x1.c030dad3cc5643f3dd0f5619f661p+10016L);
7251 TEST_fff_f (fma, 0x1.f102f7da4a57a3a4aab620e29452p-3098L, -0x1.cc06a4ff40248f9e2dcc4b6afd84p-11727L, 0x1.d512a11126b5ac8ed8973b8580c8p-14849L, -0x1.be8f1cf737ab4d1c31c54f5ec23bp-14824L);
7252 TEST_fff_f (fma, -0x1.fc47ac7434b993cd8dcb2b431f25p-3816L, 0x1.fbc9750da8468852d84558e1db6dp-5773L, -0x1.00a98abf783f75c40fe5b7a37d86p-9607L, -0x1.f81917b166f45e763cfcc057e2adp-9588L);
7253 TEST_fff_f (fma, 0x1.00000000000007ffffffffffffffp-9045L, -0x1.ffffffffffff80000001ffffffffp+4773L, -0x1.f8p-4316L, -0x1.00000000000f88000000fffffdffp-4271L);
7254 TEST_fff_f (fma, 0x1.4e922764c90701d4a2f21d01893dp-8683L, -0x1.955a12e2d7c9447c27fa022fc865p+212L, -0x1.e9634462eaef96528b90b6944578p-8521L, -0x1.08e1783184a371943d3598e10865p-8470L);
7255 TEST_fff_f (fma, 0x1.801181509c03bdbef10d6165588cp-15131L, 0x1.ad86f8e57d3d40bfa8007780af63p-368L, -0x1.6e9df0dab1c9f1d7a6043c390741p-15507L, 0x1.417c9b2b15e2ad57dc9e0e920844p-15498L);
8627a232
JM
7256 TEST_fff_f (fma, 0x1.4p-16382L, 0x1.0000000000000000000000000002p-1L, 0x1p-16384L, 0x1.c000000000000000000000000002p-16383L, UNDERFLOW_EXCEPTION);
7257 TEST_fff_f (fma, -0x1.4p-16382L, 0x1.0000000000000000000000000002p-1L, -0x1p-16384L, -0x1.c000000000000000000000000002p-16383L, UNDERFLOW_EXCEPTION);
ef82f4da
JM
7258 TEST_fff_f (fma, 0x1.fffffffffffffffffffffffffffcp-16382L, 0x1.0000000000000000000000000001p-1L, 0x1p-16494L, 0x1p-16382L, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING);
7259 TEST_fff_f (fma, -0x1.fffffffffffffffffffffffffffcp-16382L, 0x1.0000000000000000000000000001p-1L, -0x1p-16494L, -0x1p-16382L, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING);
7260 TEST_fff_f (fma, 0x1p-16494L, 0x1p-1L, 0x0.ffffffffffffffffffffffffffffp-16382L, 0x1p-16382L, UNDERFLOW_EXCEPTION);
7261 TEST_fff_f (fma, -0x1p-16494L, 0x1p-1L, -0x0.ffffffffffffffffffffffffffffp-16382L, -0x1p-16382L, UNDERFLOW_EXCEPTION);
7262 TEST_fff_f (fma, 0x1p-16494L, 0x1.1p-1L, 0x0.ffffffffffffffffffffffffffffp-16382L, 0x1p-16382L, UNDERFLOW_EXCEPTION);
7263 TEST_fff_f (fma, -0x1p-16494L, 0x1.1p-1L, -0x0.ffffffffffffffffffffffffffffp-16382L, -0x1p-16382L, UNDERFLOW_EXCEPTION);
473611b2
JM
7264 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, 0x1p16383L, 0x1p16383L);
7265 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, 0x1p16383L, 0x1p16383L);
7266 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, -0x1p16383L, -0x1p16383L);
7267 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, -0x1p16383L, -0x1p16383L);
7268 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, 0x1p-16382L, 0x1p-16382L);
7269 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, 0x1p-16382L, 0x1p-16382L, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING);
7270 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, -0x1p-16382L, -0x1p-16382L, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING);
7271 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, -0x1p-16382L, -0x1p-16382L);
7272 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, 0x0.ffffffffffffffffffffffffffffp-16382L, 0x0.ffffffffffffffffffffffffffffp-16382L, UNDERFLOW_EXCEPTION);
7273 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, 0x0.ffffffffffffffffffffffffffffp-16382L, 0x0.ffffffffffffffffffffffffffffp-16382L, UNDERFLOW_EXCEPTION);
7274 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, -0x0.ffffffffffffffffffffffffffffp-16382L, -0x0.ffffffffffffffffffffffffffffp-16382L, UNDERFLOW_EXCEPTION);
7275 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, -0x0.ffffffffffffffffffffffffffffp-16382L, -0x0.ffffffffffffffffffffffffffffp-16382L, UNDERFLOW_EXCEPTION);
7276 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, 0x1p-16494L, 0x1p-16494L, UNDERFLOW_EXCEPTION);
7277 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, 0x1p-16494L, 0x1p-16494L, UNDERFLOW_EXCEPTION);
7278 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, -0x1p-16494L, -0x1p-16494L, UNDERFLOW_EXCEPTION);
7279 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, -0x1p-16494L, -0x1p-16494L, UNDERFLOW_EXCEPTION);
5b5b04d6
JM
7280 TEST_fff_f (fma, 0x0.ffffffffffffffffffffffffffff8p0L, 0x0.ffffffffffffffffffffffffffff8p0L, -0x0.ffffffffffffffffffffffffffffp0L, 0x1p-226L);
7281 TEST_fff_f (fma, 0x0.ffffffffffffffffffffffffffff8p0L, -0x0.ffffffffffffffffffffffffffff8p0L, 0x0.ffffffffffffffffffffffffffffp0L, -0x1p-226L);
7282 TEST_fff_f (fma, -0x0.ffffffffffffffffffffffffffff8p0L, 0x0.ffffffffffffffffffffffffffff8p0L, 0x0.ffffffffffffffffffffffffffffp0L, -0x1p-226L);
7283 TEST_fff_f (fma, -0x0.ffffffffffffffffffffffffffff8p0L, -0x0.ffffffffffffffffffffffffffff8p0L, -0x0.ffffffffffffffffffffffffffffp0L, 0x1p-226L);
82477c28
JM
7284 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, 0x1.0000000000000000000000000001p-66L, 0x1p16383L, 0x1p16383L);
7285 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, -0x1.0000000000000000000000000001p-66L, 0x1p16383L, 0x1p16383L);
7286 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, 0x1.0000000000000000000000000001p-66L, -0x1p16383L, -0x1p16383L);
7287 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, -0x1.0000000000000000000000000001p-66L, -0x1p16383L, -0x1p16383L);
7288 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, 0x1.0000000000000000000000000001p-66L, 0x1p16319L, 0x1p16319L);
7289 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, -0x1.0000000000000000000000000001p-66L, 0x1p16319L, 0x1p16319L);
7290 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, 0x1.0000000000000000000000000001p-66L, -0x1p16319L, -0x1p16319L);
7291 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, -0x1.0000000000000000000000000001p-66L, -0x1p16319L, -0x1p16319L);
7c08a05c 7292#endif
2550dfe9 7293
8847214f
UD
7294 END (fma);
7295}
7296
7297
8ec5b013
JM
7298static void
7299fma_test_towardzero (void)
7300{
7301 int save_round_mode;
7302 START (fma_towardzero);
7303
7304 save_round_mode = fegetround ();
7305
7306 if (!fesetround (FE_TOWARDZERO))
7307 {
7308 TEST_fff_f (fma, plus_zero, plus_zero, plus_zero, plus_zero);
7309 TEST_fff_f (fma, plus_zero, plus_zero, minus_zero, plus_zero);
7310 TEST_fff_f (fma, plus_zero, minus_zero, plus_zero, plus_zero);
7311 TEST_fff_f (fma, plus_zero, minus_zero, minus_zero, minus_zero);
7312 TEST_fff_f (fma, minus_zero, plus_zero, plus_zero, plus_zero);
7313 TEST_fff_f (fma, minus_zero, plus_zero, minus_zero, minus_zero);
7314 TEST_fff_f (fma, minus_zero, minus_zero, plus_zero, plus_zero);
7315 TEST_fff_f (fma, minus_zero, minus_zero, minus_zero, plus_zero);
7316 TEST_fff_f (fma, 1.0, plus_zero, plus_zero, plus_zero);
7317 TEST_fff_f (fma, 1.0, plus_zero, minus_zero, plus_zero);
7318 TEST_fff_f (fma, 1.0, minus_zero, plus_zero, plus_zero);
7319 TEST_fff_f (fma, 1.0, minus_zero, minus_zero, minus_zero);
7320 TEST_fff_f (fma, -1.0, plus_zero, plus_zero, plus_zero);
7321 TEST_fff_f (fma, -1.0, plus_zero, minus_zero, minus_zero);
7322 TEST_fff_f (fma, -1.0, minus_zero, plus_zero, plus_zero);
7323 TEST_fff_f (fma, -1.0, minus_zero, minus_zero, plus_zero);
7324 TEST_fff_f (fma, plus_zero, 1.0, plus_zero, plus_zero);
7325 TEST_fff_f (fma, plus_zero, 1.0, minus_zero, plus_zero);
7326 TEST_fff_f (fma, plus_zero, -1.0, plus_zero, plus_zero);
7327 TEST_fff_f (fma, plus_zero, -1.0, minus_zero, minus_zero);
7328 TEST_fff_f (fma, minus_zero, 1.0, plus_zero, plus_zero);
7329 TEST_fff_f (fma, minus_zero, 1.0, minus_zero, minus_zero);
7330 TEST_fff_f (fma, minus_zero, -1.0, plus_zero, plus_zero);
7331 TEST_fff_f (fma, minus_zero, -1.0, minus_zero, plus_zero);
7332
7333 TEST_fff_f (fma, 1.0, 1.0, -1.0, plus_zero);
7334 TEST_fff_f (fma, 1.0, -1.0, 1.0, plus_zero);
7335 TEST_fff_f (fma, -1.0, 1.0, 1.0, plus_zero);
7336 TEST_fff_f (fma, -1.0, -1.0, -1.0, plus_zero);
bec749fd
JM
7337
7338 TEST_fff_f (fma, min_value, min_value, plus_zero, plus_zero, UNDERFLOW_EXCEPTION);
7339 TEST_fff_f (fma, min_value, min_value, minus_zero, plus_zero, UNDERFLOW_EXCEPTION);
7340 TEST_fff_f (fma, min_value, -min_value, plus_zero, minus_zero, UNDERFLOW_EXCEPTION);
7341 TEST_fff_f (fma, min_value, -min_value, minus_zero, minus_zero, UNDERFLOW_EXCEPTION);
7342 TEST_fff_f (fma, -min_value, min_value, plus_zero, minus_zero, UNDERFLOW_EXCEPTION);
7343 TEST_fff_f (fma, -min_value, min_value, minus_zero, minus_zero, UNDERFLOW_EXCEPTION);
7344 TEST_fff_f (fma, -min_value, -min_value, plus_zero, plus_zero, UNDERFLOW_EXCEPTION);
7345 TEST_fff_f (fma, -min_value, -min_value, minus_zero, plus_zero, UNDERFLOW_EXCEPTION);
8627a232 7346
7184dcdf 7347#if !(defined TEST_LDOUBLE && LDBL_MANT_DIG == 106) /* Bug 13304. */
a0c2940d
JM
7348 TEST_fff_f (fma, max_value, max_value, min_value, max_value, OVERFLOW_EXCEPTION);
7349 TEST_fff_f (fma, max_value, max_value, -min_value, max_value, OVERFLOW_EXCEPTION);
7350 TEST_fff_f (fma, max_value, -max_value, min_value, -max_value, OVERFLOW_EXCEPTION);
7351 TEST_fff_f (fma, max_value, -max_value, -min_value, -max_value, OVERFLOW_EXCEPTION);
7352 TEST_fff_f (fma, -max_value, max_value, min_value, -max_value, OVERFLOW_EXCEPTION);
7353 TEST_fff_f (fma, -max_value, max_value, -min_value, -max_value, OVERFLOW_EXCEPTION);
7354 TEST_fff_f (fma, -max_value, -max_value, min_value, max_value, OVERFLOW_EXCEPTION);
7355 TEST_fff_f (fma, -max_value, -max_value, -min_value, max_value, OVERFLOW_EXCEPTION);
7184dcdf 7356#endif
a0c2940d 7357
8627a232
JM
7358#if defined (TEST_FLOAT) && FLT_MANT_DIG == 24
7359 TEST_fff_f (fma, 0x1.4p-126, 0x1.000004p-1, 0x1p-128, 0x1.c00004p-127, UNDERFLOW_EXCEPTION);
7360 TEST_fff_f (fma, -0x1.4p-126, 0x1.000004p-1, -0x1p-128, -0x1.c00004p-127, UNDERFLOW_EXCEPTION);
ef82f4da
JM
7361 TEST_fff_f (fma, 0x1.fffff8p-126, 0x1.000002p-1, 0x1p-149, 0x0.fffffep-126, UNDERFLOW_EXCEPTION);
7362 TEST_fff_f (fma, -0x1.fffff8p-126, 0x1.000002p-1, -0x1p-149, -0x0.fffffep-126, UNDERFLOW_EXCEPTION);
7363 TEST_fff_f (fma, 0x1p-149, 0x1p-1, 0x0.fffffep-126, 0x0.fffffep-126, UNDERFLOW_EXCEPTION);
7364 TEST_fff_f (fma, -0x1p-149, 0x1p-1, -0x0.fffffep-126, -0x0.fffffep-126, UNDERFLOW_EXCEPTION);
7365 TEST_fff_f (fma, 0x1p-149, 0x1.1p-1, 0x0.fffffep-126, 0x0.fffffep-126, UNDERFLOW_EXCEPTION);
7366 TEST_fff_f (fma, -0x1p-149, 0x1.1p-1, -0x0.fffffep-126, -0x0.fffffep-126, UNDERFLOW_EXCEPTION);
473611b2
JM
7367 TEST_fff_f (fma, 0x1p-149, 0x1p-149, 0x1p127, 0x1p127);
7368 TEST_fff_f (fma, 0x1p-149, -0x1p-149, 0x1p127, 0x0.ffffffp127);
7369 TEST_fff_f (fma, 0x1p-149, 0x1p-149, -0x1p127, -0x0.ffffffp127);
7370 TEST_fff_f (fma, 0x1p-149, -0x1p-149, -0x1p127, -0x1p127);
7371 TEST_fff_f (fma, 0x1p-149, 0x1p-149, 0x1p-126, 0x1p-126);
7372 TEST_fff_f (fma, 0x1p-149, -0x1p-149, 0x1p-126, 0x0.fffffep-126, UNDERFLOW_EXCEPTION);
7373 TEST_fff_f (fma, 0x1p-149, 0x1p-149, -0x1p-126, -0x0.fffffep-126, UNDERFLOW_EXCEPTION);
7374 TEST_fff_f (fma, 0x1p-149, -0x1p-149, -0x1p-126, -0x1p-126);
7375 TEST_fff_f (fma, 0x1p-149, 0x1p-149, 0x0.fffffep-126, 0x0.fffffep-126, UNDERFLOW_EXCEPTION);
7376 TEST_fff_f (fma, 0x1p-149, -0x1p-149, 0x0.fffffep-126, 0x0.fffffcp-126, UNDERFLOW_EXCEPTION);
7377 TEST_fff_f (fma, 0x1p-149, 0x1p-149, -0x0.fffffep-126, -0x0.fffffcp-126, UNDERFLOW_EXCEPTION);
7378 TEST_fff_f (fma, 0x1p-149, -0x1p-149, -0x0.fffffep-126, -0x0.fffffep-126, UNDERFLOW_EXCEPTION);
7379 TEST_fff_f (fma, 0x1p-149, 0x1p-149, 0x1p-149, 0x1p-149, UNDERFLOW_EXCEPTION);
7380 TEST_fff_f (fma, 0x1p-149, -0x1p-149, 0x1p-149, plus_zero, UNDERFLOW_EXCEPTION);
7381 TEST_fff_f (fma, 0x1p-149, 0x1p-149, -0x1p-149, minus_zero, UNDERFLOW_EXCEPTION);
7382 TEST_fff_f (fma, 0x1p-149, -0x1p-149, -0x1p-149, -0x1p-149, UNDERFLOW_EXCEPTION);
5b5b04d6
JM
7383 TEST_fff_f (fma, 0x0.fffp0, 0x0.fffp0, -0x0.ffep0, 0x1p-24);
7384 TEST_fff_f (fma, 0x0.fffp0, -0x0.fffp0, 0x0.ffep0, -0x1p-24);
7385 TEST_fff_f (fma, -0x0.fffp0, 0x0.fffp0, 0x0.ffep0, -0x1p-24);
7386 TEST_fff_f (fma, -0x0.fffp0, -0x0.fffp0, -0x0.ffep0, 0x1p-24);
82477c28
JM
7387 TEST_fff_f (fma, 0x1.000002p-126, 0x1.000002p-26, 0x1p127, 0x1p127);
7388 TEST_fff_f (fma, 0x1.000002p-126, -0x1.000002p-26, 0x1p127, 0x0.ffffffp127);
7389 TEST_fff_f (fma, 0x1.000002p-126, 0x1.000002p-26, -0x1p127, -0x0.ffffffp127);
7390 TEST_fff_f (fma, 0x1.000002p-126, -0x1.000002p-26, -0x1p127, -0x1p127);
7391 TEST_fff_f (fma, 0x1.000002p-126, 0x1.000002p-26, 0x1p103, 0x1p103);
7392 TEST_fff_f (fma, 0x1.000002p-126, -0x1.000002p-26, 0x1p103, 0x0.ffffffp103);
7393 TEST_fff_f (fma, 0x1.000002p-126, 0x1.000002p-26, -0x1p103, -0x0.ffffffp103);
7394 TEST_fff_f (fma, 0x1.000002p-126, -0x1.000002p-26, -0x1p103, -0x1p103);
8627a232
JM
7395#endif
7396#if defined (TEST_DOUBLE) && DBL_MANT_DIG == 53
7397 TEST_fff_f (fma, 0x1.4p-1022, 0x1.0000000000002p-1, 0x1p-1024, 0x1.c000000000002p-1023, UNDERFLOW_EXCEPTION);
7398 TEST_fff_f (fma, -0x1.4p-1022, 0x1.0000000000002p-1, -0x1p-1024, -0x1.c000000000002p-1023, UNDERFLOW_EXCEPTION);
ef82f4da
JM
7399 TEST_fff_f (fma, 0x1.ffffffffffffcp-1022, 0x1.0000000000001p-1, 0x1p-1074, 0x0.fffffffffffffp-1022, UNDERFLOW_EXCEPTION);
7400 TEST_fff_f (fma, -0x1.ffffffffffffcp-1022, 0x1.0000000000001p-1, -0x1p-1074, -0x0.fffffffffffffp-1022, UNDERFLOW_EXCEPTION);
7401 TEST_fff_f (fma, 0x1p-1074, 0x1p-1, 0x0.fffffffffffffp-1022, 0x0.fffffffffffffp-1022, UNDERFLOW_EXCEPTION);
7402 TEST_fff_f (fma, -0x1p-1074, 0x1p-1, -0x0.fffffffffffffp-1022, -0x0.fffffffffffffp-1022, UNDERFLOW_EXCEPTION);
7403 TEST_fff_f (fma, 0x1p-1074, 0x1.1p-1, 0x0.fffffffffffffp-1022, 0x0.fffffffffffffp-1022, UNDERFLOW_EXCEPTION);
7404 TEST_fff_f (fma, -0x1p-1074, 0x1.1p-1, -0x0.fffffffffffffp-1022, -0x0.fffffffffffffp-1022, UNDERFLOW_EXCEPTION);
473611b2
JM
7405 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, 0x1p1023, 0x1p1023);
7406 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, 0x1p1023, 0x0.fffffffffffff8p1023);
7407 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, -0x1p1023, -0x0.fffffffffffff8p1023);
7408 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, -0x1p1023, -0x1p1023);
7409 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, 0x1p-1022, 0x1p-1022);
7410 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, 0x1p-1022, 0x0.fffffffffffffp-1022, UNDERFLOW_EXCEPTION);
7411 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, -0x1p-1022, -0x0.fffffffffffffp-1022, UNDERFLOW_EXCEPTION);
7412 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, -0x1p-1022, -0x1p-1022);
7413 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, 0x0.fffffffffffffp-1022, 0x0.fffffffffffffp-1022, UNDERFLOW_EXCEPTION);
7414 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, 0x0.fffffffffffffp-1022, 0x0.ffffffffffffep-1022, UNDERFLOW_EXCEPTION);
7415 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, -0x0.fffffffffffffp-1022, -0x0.ffffffffffffep-1022, UNDERFLOW_EXCEPTION);
7416 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, -0x0.fffffffffffffp-1022, -0x0.fffffffffffffp-1022, UNDERFLOW_EXCEPTION);
7417 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, 0x1p-1074, 0x1p-1074, UNDERFLOW_EXCEPTION);
7418 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, 0x1p-1074, plus_zero, UNDERFLOW_EXCEPTION);
7419 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, -0x1p-1074, minus_zero, UNDERFLOW_EXCEPTION);
7420 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, -0x1p-1074, -0x1p-1074, UNDERFLOW_EXCEPTION);
5b5b04d6
JM
7421 TEST_fff_f (fma, 0x0.fffffffffffff8p0, 0x0.fffffffffffff8p0, -0x0.fffffffffffffp0, 0x1p-106);
7422 TEST_fff_f (fma, 0x0.fffffffffffff8p0, -0x0.fffffffffffff8p0, 0x0.fffffffffffffp0, -0x1p-106);
7423 TEST_fff_f (fma, -0x0.fffffffffffff8p0, 0x0.fffffffffffff8p0, 0x0.fffffffffffffp0, -0x1p-106);
7424 TEST_fff_f (fma, -0x0.fffffffffffff8p0, -0x0.fffffffffffff8p0, -0x0.fffffffffffffp0, 0x1p-106);
82477c28
JM
7425 TEST_fff_f (fma, 0x1.0000000000001p-1022, 0x1.0000000000001p-55, 0x1p1023, 0x1p1023);
7426 TEST_fff_f (fma, 0x1.0000000000001p-1022, -0x1.0000000000001p-55, 0x1p1023, 0x0.fffffffffffff8p1023);
7427 TEST_fff_f (fma, 0x1.0000000000001p-1022, 0x1.0000000000001p-55, -0x1p1023, -0x0.fffffffffffff8p1023);
7428 TEST_fff_f (fma, 0x1.0000000000001p-1022, -0x1.0000000000001p-55, -0x1p1023, -0x1p1023);
7429 TEST_fff_f (fma, 0x1.0000000000001p-1022, 0x1.0000000000001p-55, 0x1p970, 0x1p970);
7430 TEST_fff_f (fma, 0x1.0000000000001p-1022, -0x1.0000000000001p-55, 0x1p970, 0x0.fffffffffffff8p970);
7431 TEST_fff_f (fma, 0x1.0000000000001p-1022, 0x1.0000000000001p-55, -0x1p970, -0x0.fffffffffffff8p970);
7432 TEST_fff_f (fma, 0x1.0000000000001p-1022, -0x1.0000000000001p-55, -0x1p970, -0x1p970);
8627a232
JM
7433#endif
7434#if defined (TEST_LDOUBLE) && LDBL_MANT_DIG == 64
7435 TEST_fff_f (fma, 0x1.4p-16382L, 0x1.0000000000000004p-1L, 0x1p-16384L, 0x1.c000000000000004p-16383L, UNDERFLOW_EXCEPTION);
7436 TEST_fff_f (fma, -0x1.4p-16382L, 0x1.0000000000000004p-1L, -0x1p-16384L, -0x1.c000000000000004p-16383L, UNDERFLOW_EXCEPTION);
ef82f4da
JM
7437 TEST_fff_f (fma, 0x1.fffffffffffffff8p-16382L, 0x1.0000000000000002p-1L, 0x1p-16445L, 0x0.fffffffffffffffep-16382L, UNDERFLOW_EXCEPTION);
7438 TEST_fff_f (fma, -0x1.fffffffffffffff8p-16382L, 0x1.0000000000000002p-1L, -0x1p-16445L, -0x0.fffffffffffffffep-16382L, UNDERFLOW_EXCEPTION);
7439 TEST_fff_f (fma, 0x1p-16445L, 0x1p-1L, 0x0.fffffffffffffffep-16382L, 0x0.fffffffffffffffep-16382L, UNDERFLOW_EXCEPTION);
7440 TEST_fff_f (fma, -0x1p-16445L, 0x1p-1L, -0x0.fffffffffffffffep-16382L, -0x0.fffffffffffffffep-16382L, UNDERFLOW_EXCEPTION);
7441 TEST_fff_f (fma, 0x1p-16445L, 0x1.1p-1L, 0x0.fffffffffffffffep-16382L, 0x0.fffffffffffffffep-16382L, UNDERFLOW_EXCEPTION);
7442 TEST_fff_f (fma, -0x1p-16445L, 0x1.1p-1L, -0x0.fffffffffffffffep-16382L, -0x0.fffffffffffffffep-16382L, UNDERFLOW_EXCEPTION);
473611b2
JM
7443 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, 0x1p16383L, 0x1p16383L);
7444 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, 0x1p16383L, 0x0.ffffffffffffffffp16383L);
7445 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, -0x1p16383L, -0x0.ffffffffffffffffp16383L);
7446 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, -0x1p16383L, -0x1p16383L);
7447 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, 0x1p-16382L, 0x1p-16382L);
7448 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, 0x1p-16382L, 0x0.fffffffffffffffep-16382L, UNDERFLOW_EXCEPTION);
7449 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, -0x1p-16382L, -0x0.fffffffffffffffep-16382L, UNDERFLOW_EXCEPTION);
7450 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, -0x1p-16382L, -0x1p-16382L);
7451 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, 0x0.fffffffffffffffep-16382L, 0x0.fffffffffffffffep-16382L, UNDERFLOW_EXCEPTION);
7452 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, 0x0.fffffffffffffffep-16382L, 0x0.fffffffffffffffcp-16382L, UNDERFLOW_EXCEPTION);
7453 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, -0x0.fffffffffffffffep-16382L, -0x0.fffffffffffffffcp-16382L, UNDERFLOW_EXCEPTION);
7454 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, -0x0.fffffffffffffffep-16382L, -0x0.fffffffffffffffep-16382L, UNDERFLOW_EXCEPTION);
7455 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, 0x1p-16445L, 0x1p-16445L, UNDERFLOW_EXCEPTION);
7456 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, 0x1p-16445L, plus_zero, UNDERFLOW_EXCEPTION);
7457 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, -0x1p-16445L, minus_zero, UNDERFLOW_EXCEPTION);
7458 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, -0x1p-16445L, -0x1p-16445L, UNDERFLOW_EXCEPTION);
5b5b04d6
JM
7459 TEST_fff_f (fma, 0x0.ffffffffffffffffp0L, 0x0.ffffffffffffffffp0L, -0x0.fffffffffffffffep0L, 0x1p-128L);
7460 TEST_fff_f (fma, 0x0.ffffffffffffffffp0L, -0x0.ffffffffffffffffp0L, 0x0.fffffffffffffffep0L, -0x1p-128L);
7461 TEST_fff_f (fma, -0x0.ffffffffffffffffp0L, 0x0.ffffffffffffffffp0L, 0x0.fffffffffffffffep0L, -0x1p-128L);
7462 TEST_fff_f (fma, -0x0.ffffffffffffffffp0L, -0x0.ffffffffffffffffp0L, -0x0.fffffffffffffffep0L, 0x1p-128L);
82477c28
JM
7463 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, 0x1.0000000000000002p-66L, 0x1p16383L, 0x1p16383L);
7464 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, -0x1.0000000000000002p-66L, 0x1p16383L, 0x0.ffffffffffffffffp16383L);
7465 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, 0x1.0000000000000002p-66L, -0x1p16383L, -0x0.ffffffffffffffffp16383L);
7466 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, -0x1.0000000000000002p-66L, -0x1p16383L, -0x1p16383L);
7467 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, 0x1.0000000000000002p-66L, 0x1p16319L, 0x1p16319L);
7468 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, -0x1.0000000000000002p-66L, 0x1p16319L, 0x0.ffffffffffffffffp16319L);
7469 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, 0x1.0000000000000002p-66L, -0x1p16319L, -0x0.ffffffffffffffffp16319L);
7470 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, -0x1.0000000000000002p-66L, -0x1p16319L, -0x1p16319L);
8627a232
JM
7471#endif
7472#if defined (TEST_LDOUBLE) && LDBL_MANT_DIG == 113
7473 TEST_fff_f (fma, 0x1.4p-16382L, 0x1.0000000000000000000000000002p-1L, 0x1p-16384L, 0x1.c000000000000000000000000002p-16383L, UNDERFLOW_EXCEPTION);
7474 TEST_fff_f (fma, -0x1.4p-16382L, 0x1.0000000000000000000000000002p-1L, -0x1p-16384L, -0x1.c000000000000000000000000002p-16383L, UNDERFLOW_EXCEPTION);
ef82f4da
JM
7475 TEST_fff_f (fma, 0x1.fffffffffffffffffffffffffffcp-16382L, 0x1.0000000000000000000000000001p-1L, 0x1p-16494L, 0x0.ffffffffffffffffffffffffffffp-16382L, UNDERFLOW_EXCEPTION);
7476 TEST_fff_f (fma, -0x1.fffffffffffffffffffffffffffcp-16382L, 0x1.0000000000000000000000000001p-1L, -0x1p-16494L, -0x0.ffffffffffffffffffffffffffffp-16382L, UNDERFLOW_EXCEPTION);
7477 TEST_fff_f (fma, 0x1p-16494L, 0x1p-1L, 0x0.ffffffffffffffffffffffffffffp-16382L, 0x0.ffffffffffffffffffffffffffffp-16382L, UNDERFLOW_EXCEPTION);
7478 TEST_fff_f (fma, -0x1p-16494L, 0x1p-1L, -0x0.ffffffffffffffffffffffffffffp-16382L, -0x0.ffffffffffffffffffffffffffffp-16382L, UNDERFLOW_EXCEPTION);
7479 TEST_fff_f (fma, 0x1p-16494L, 0x1.1p-1L, 0x0.ffffffffffffffffffffffffffffp-16382L, 0x0.ffffffffffffffffffffffffffffp-16382L, UNDERFLOW_EXCEPTION);
7480 TEST_fff_f (fma, -0x1p-16494L, 0x1.1p-1L, -0x0.ffffffffffffffffffffffffffffp-16382L, -0x0.ffffffffffffffffffffffffffffp-16382L, UNDERFLOW_EXCEPTION);
473611b2
JM
7481 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, 0x1p16383L, 0x1p16383L);
7482 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, 0x1p16383L, 0x0.ffffffffffffffffffffffffffff8p16383L);
7483 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, -0x1p16383L, -0x0.ffffffffffffffffffffffffffff8p16383L);
7484 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, -0x1p16383L, -0x1p16383L);
7485 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, 0x1p-16382L, 0x1p-16382L);
7486 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, 0x1p-16382L, 0x0.ffffffffffffffffffffffffffffp-16382L, UNDERFLOW_EXCEPTION);
7487 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, -0x1p-16382L, -0x0.ffffffffffffffffffffffffffffp-16382L, UNDERFLOW_EXCEPTION);
7488 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, -0x1p-16382L, -0x1p-16382L);
7489 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, 0x0.ffffffffffffffffffffffffffffp-16382L, 0x0.ffffffffffffffffffffffffffffp-16382L, UNDERFLOW_EXCEPTION);
7490 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, 0x0.ffffffffffffffffffffffffffffp-16382L, 0x0.fffffffffffffffffffffffffffep-16382L, UNDERFLOW_EXCEPTION);
7491 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, -0x0.ffffffffffffffffffffffffffffp-16382L, -0x0.fffffffffffffffffffffffffffep-16382L, UNDERFLOW_EXCEPTION);
7492 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, -0x0.ffffffffffffffffffffffffffffp-16382L, -0x0.ffffffffffffffffffffffffffffp-16382L, UNDERFLOW_EXCEPTION);
7493 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, 0x1p-16494L, 0x1p-16494L, UNDERFLOW_EXCEPTION);
7494 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, 0x1p-16494L, plus_zero, UNDERFLOW_EXCEPTION);
7495 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, -0x1p-16494L, minus_zero, UNDERFLOW_EXCEPTION);
7496 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, -0x1p-16494L, -0x1p-16494L, UNDERFLOW_EXCEPTION);
5b5b04d6
JM
7497 TEST_fff_f (fma, 0x0.ffffffffffffffffffffffffffff8p0L, 0x0.ffffffffffffffffffffffffffff8p0L, -0x0.ffffffffffffffffffffffffffffp0L, 0x1p-226L);
7498 TEST_fff_f (fma, 0x0.ffffffffffffffffffffffffffff8p0L, -0x0.ffffffffffffffffffffffffffff8p0L, 0x0.ffffffffffffffffffffffffffffp0L, -0x1p-226L);
7499 TEST_fff_f (fma, -0x0.ffffffffffffffffffffffffffff8p0L, 0x0.ffffffffffffffffffffffffffff8p0L, 0x0.ffffffffffffffffffffffffffffp0L, -0x1p-226L);
7500 TEST_fff_f (fma, -0x0.ffffffffffffffffffffffffffff8p0L, -0x0.ffffffffffffffffffffffffffff8p0L, -0x0.ffffffffffffffffffffffffffffp0L, 0x1p-226L);
82477c28
JM
7501 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, 0x1.0000000000000000000000000001p-66L, 0x1p16383L, 0x1p16383L);
7502 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, -0x1.0000000000000000000000000001p-66L, 0x1p16383L, 0x0.ffffffffffffffffffffffffffff8p16383L);
7503 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, 0x1.0000000000000000000000000001p-66L, -0x1p16383L, -0x0.ffffffffffffffffffffffffffff8p16383L);
7504 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, -0x1.0000000000000000000000000001p-66L, -0x1p16383L, -0x1p16383L);
7505 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, 0x1.0000000000000000000000000001p-66L, 0x1p16319L, 0x1p16319L);
7506 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, -0x1.0000000000000000000000000001p-66L, 0x1p16319L, 0x0.ffffffffffffffffffffffffffff8p16319L);
7507 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, 0x1.0000000000000000000000000001p-66L, -0x1p16319L, -0x0.ffffffffffffffffffffffffffff8p16319L);
7508 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, -0x1.0000000000000000000000000001p-66L, -0x1p16319L, -0x1p16319L);
8627a232 7509#endif
8ec5b013
JM
7510 }
7511
7512 fesetround (save_round_mode);
7513
7514 END (fma_towardzero);
7515}
7516
7517
7518static void
7519fma_test_downward (void)
7520{
7521 int save_round_mode;
7522 START (fma_downward);
7523
7524 save_round_mode = fegetround ();
7525
7526 if (!fesetround (FE_DOWNWARD))
7527 {
7528 TEST_fff_f (fma, plus_zero, plus_zero, plus_zero, plus_zero);
7529 TEST_fff_f (fma, plus_zero, plus_zero, minus_zero, minus_zero);
7530 TEST_fff_f (fma, plus_zero, minus_zero, plus_zero, minus_zero);
7531 TEST_fff_f (fma, plus_zero, minus_zero, minus_zero, minus_zero);
7532 TEST_fff_f (fma, minus_zero, plus_zero, plus_zero, minus_zero);
7533 TEST_fff_f (fma, minus_zero, plus_zero, minus_zero, minus_zero);
7534 TEST_fff_f (fma, minus_zero, minus_zero, plus_zero, plus_zero);
7535 TEST_fff_f (fma, minus_zero, minus_zero, minus_zero, minus_zero);
7536 TEST_fff_f (fma, 1.0, plus_zero, plus_zero, plus_zero);
7537 TEST_fff_f (fma, 1.0, plus_zero, minus_zero, minus_zero);
7538 TEST_fff_f (fma, 1.0, minus_zero, plus_zero, minus_zero);
7539 TEST_fff_f (fma, 1.0, minus_zero, minus_zero, minus_zero);
7540 TEST_fff_f (fma, -1.0, plus_zero, plus_zero, minus_zero);
7541 TEST_fff_f (fma, -1.0, plus_zero, minus_zero, minus_zero);
7542 TEST_fff_f (fma, -1.0, minus_zero, plus_zero, plus_zero);
7543 TEST_fff_f (fma, -1.0, minus_zero, minus_zero, minus_zero);
7544 TEST_fff_f (fma, plus_zero, 1.0, plus_zero, plus_zero);
7545 TEST_fff_f (fma, plus_zero, 1.0, minus_zero, minus_zero);
7546 TEST_fff_f (fma, plus_zero, -1.0, plus_zero, minus_zero);
7547 TEST_fff_f (fma, plus_zero, -1.0, minus_zero, minus_zero);
7548 TEST_fff_f (fma, minus_zero, 1.0, plus_zero, minus_zero);
7549 TEST_fff_f (fma, minus_zero, 1.0, minus_zero, minus_zero);
7550 TEST_fff_f (fma, minus_zero, -1.0, plus_zero, plus_zero);
7551 TEST_fff_f (fma, minus_zero, -1.0, minus_zero, minus_zero);
7552
7553 TEST_fff_f (fma, 1.0, 1.0, -1.0, minus_zero);
7554 TEST_fff_f (fma, 1.0, -1.0, 1.0, minus_zero);
7555 TEST_fff_f (fma, -1.0, 1.0, 1.0, minus_zero);
7556 TEST_fff_f (fma, -1.0, -1.0, -1.0, minus_zero);
bec749fd
JM
7557
7558 TEST_fff_f (fma, min_value, min_value, plus_zero, plus_zero, UNDERFLOW_EXCEPTION);
7559 TEST_fff_f (fma, min_value, min_value, minus_zero, plus_zero, UNDERFLOW_EXCEPTION);
7560 TEST_fff_f (fma, min_value, -min_value, plus_zero, -min_subnorm_value, UNDERFLOW_EXCEPTION);
7561 TEST_fff_f (fma, min_value, -min_value, minus_zero, -min_subnorm_value, UNDERFLOW_EXCEPTION);
7562 TEST_fff_f (fma, -min_value, min_value, plus_zero, -min_subnorm_value, UNDERFLOW_EXCEPTION);
7563 TEST_fff_f (fma, -min_value, min_value, minus_zero, -min_subnorm_value, UNDERFLOW_EXCEPTION);
7564 TEST_fff_f (fma, -min_value, -min_value, plus_zero, plus_zero, UNDERFLOW_EXCEPTION);
7565 TEST_fff_f (fma, -min_value, -min_value, minus_zero, plus_zero, UNDERFLOW_EXCEPTION);
8627a232 7566
7184dcdf 7567#if !(defined TEST_LDOUBLE && LDBL_MANT_DIG == 106) /* Bug 13304. */
a0c2940d
JM
7568 TEST_fff_f (fma, max_value, max_value, min_value, max_value, OVERFLOW_EXCEPTION);
7569 TEST_fff_f (fma, max_value, max_value, -min_value, max_value, OVERFLOW_EXCEPTION);
7570 TEST_fff_f (fma, max_value, -max_value, min_value, minus_infty, OVERFLOW_EXCEPTION);
7571 TEST_fff_f (fma, max_value, -max_value, -min_value, minus_infty, OVERFLOW_EXCEPTION);
7572 TEST_fff_f (fma, -max_value, max_value, min_value, minus_infty, OVERFLOW_EXCEPTION);
7573 TEST_fff_f (fma, -max_value, max_value, -min_value, minus_infty, OVERFLOW_EXCEPTION);
7574 TEST_fff_f (fma, -max_value, -max_value, min_value, max_value, OVERFLOW_EXCEPTION);
7575 TEST_fff_f (fma, -max_value, -max_value, -min_value, max_value, OVERFLOW_EXCEPTION);
7184dcdf 7576#endif
a0c2940d 7577
8627a232
JM
7578#if defined (TEST_FLOAT) && FLT_MANT_DIG == 24
7579 TEST_fff_f (fma, 0x1.4p-126, 0x1.000004p-1, 0x1p-128, 0x1.c00004p-127, UNDERFLOW_EXCEPTION);
7580 TEST_fff_f (fma, -0x1.4p-126, 0x1.000004p-1, -0x1p-128, -0x1.c00008p-127, UNDERFLOW_EXCEPTION);
ef82f4da
JM
7581 TEST_fff_f (fma, 0x1.fffff8p-126, 0x1.000002p-1, 0x1p-149, 0x0.fffffep-126, UNDERFLOW_EXCEPTION);
7582 TEST_fff_f (fma, -0x1.fffff8p-126, 0x1.000002p-1, -0x1p-149, -0x1p-126, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING);
7583 TEST_fff_f (fma, 0x1p-149, 0x1p-1, 0x0.fffffep-126, 0x0.fffffep-126, UNDERFLOW_EXCEPTION);
7584 TEST_fff_f (fma, -0x1p-149, 0x1p-1, -0x0.fffffep-126, -0x1p-126, UNDERFLOW_EXCEPTION);
7585 TEST_fff_f (fma, 0x1p-149, 0x1.1p-1, 0x0.fffffep-126, 0x0.fffffep-126, UNDERFLOW_EXCEPTION);
7586 TEST_fff_f (fma, -0x1p-149, 0x1.1p-1, -0x0.fffffep-126, -0x1p-126, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING);
473611b2
JM
7587 TEST_fff_f (fma, 0x1p-149, 0x1p-149, 0x1p127, 0x1p127);
7588 TEST_fff_f (fma, 0x1p-149, -0x1p-149, 0x1p127, 0x0.ffffffp127);
7589 TEST_fff_f (fma, 0x1p-149, 0x1p-149, -0x1p127, -0x1p127);
7590 TEST_fff_f (fma, 0x1p-149, -0x1p-149, -0x1p127, -0x1.000002p127);
7591 TEST_fff_f (fma, 0x1p-149, 0x1p-149, 0x1p-126, 0x1p-126);
7592 TEST_fff_f (fma, 0x1p-149, -0x1p-149, 0x1p-126, 0x0.fffffep-126, UNDERFLOW_EXCEPTION);
7593 TEST_fff_f (fma, 0x1p-149, 0x1p-149, -0x1p-126, -0x1p-126, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING);
7594 TEST_fff_f (fma, 0x1p-149, -0x1p-149, -0x1p-126, -0x1.000002p-126);
7595 TEST_fff_f (fma, 0x1p-149, 0x1p-149, 0x0.fffffep-126, 0x0.fffffep-126, UNDERFLOW_EXCEPTION);
7596 TEST_fff_f (fma, 0x1p-149, -0x1p-149, 0x0.fffffep-126, 0x0.fffffcp-126, UNDERFLOW_EXCEPTION);
7597 TEST_fff_f (fma, 0x1p-149, 0x1p-149, -0x0.fffffep-126, -0x0.fffffep-126, UNDERFLOW_EXCEPTION);
7598 TEST_fff_f (fma, 0x1p-149, -0x1p-149, -0x0.fffffep-126, -0x1p-126, UNDERFLOW_EXCEPTION);
7599 TEST_fff_f (fma, 0x1p-149, 0x1p-149, 0x1p-149, 0x1p-149, UNDERFLOW_EXCEPTION);
7600 TEST_fff_f (fma, 0x1p-149, -0x1p-149, 0x1p-149, plus_zero, UNDERFLOW_EXCEPTION);
7601 TEST_fff_f (fma, 0x1p-149, 0x1p-149, -0x1p-149, -0x1p-149, UNDERFLOW_EXCEPTION);
7602 TEST_fff_f (fma, 0x1p-149, -0x1p-149, -0x1p-149, -0x1p-148, UNDERFLOW_EXCEPTION);
5b5b04d6
JM
7603 TEST_fff_f (fma, 0x0.fffp0, 0x0.fffp0, -0x0.ffep0, 0x1p-24);
7604 TEST_fff_f (fma, 0x0.fffp0, -0x0.fffp0, 0x0.ffep0, -0x1p-24);
7605 TEST_fff_f (fma, -0x0.fffp0, 0x0.fffp0, 0x0.ffep0, -0x1p-24);
7606 TEST_fff_f (fma, -0x0.fffp0, -0x0.fffp0, -0x0.ffep0, 0x1p-24);
82477c28
JM
7607 TEST_fff_f (fma, 0x1.000002p-126, 0x1.000002p-26, 0x1p127, 0x1p127);
7608 TEST_fff_f (fma, 0x1.000002p-126, -0x1.000002p-26, 0x1p127, 0x0.ffffffp127);
7609 TEST_fff_f (fma, 0x1.000002p-126, 0x1.000002p-26, -0x1p127, -0x1p127);
7610 TEST_fff_f (fma, 0x1.000002p-126, -0x1.000002p-26, -0x1p127, -0x1.000002p127);
7611 TEST_fff_f (fma, 0x1.000002p-126, 0x1.000002p-26, 0x1p103, 0x1p103);
7612 TEST_fff_f (fma, 0x1.000002p-126, -0x1.000002p-26, 0x1p103, 0x0.ffffffp103);
7613 TEST_fff_f (fma, 0x1.000002p-126, 0x1.000002p-26, -0x1p103, -0x1p103);
7614 TEST_fff_f (fma, 0x1.000002p-126, -0x1.000002p-26, -0x1p103, -0x1.000002p103);
8627a232
JM
7615#endif
7616#if defined (TEST_DOUBLE) && DBL_MANT_DIG == 53
7617 TEST_fff_f (fma, 0x1.4p-1022, 0x1.0000000000002p-1, 0x1p-1024, 0x1.c000000000002p-1023, UNDERFLOW_EXCEPTION);
7618 TEST_fff_f (fma, -0x1.4p-1022, 0x1.0000000000002p-1, -0x1p-1024, -0x1.c000000000004p-1023, UNDERFLOW_EXCEPTION);
ef82f4da
JM
7619 TEST_fff_f (fma, 0x1.ffffffffffffcp-1022, 0x1.0000000000001p-1, 0x1p-1074, 0x0.fffffffffffffp-1022, UNDERFLOW_EXCEPTION);
7620 TEST_fff_f (fma, -0x1.ffffffffffffcp-1022, 0x1.0000000000001p-1, -0x1p-1074, -0x1p-1022, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING);
7621 TEST_fff_f (fma, 0x1p-1074, 0x1p-1, 0x0.fffffffffffffp-1022, 0x0.fffffffffffffp-1022, UNDERFLOW_EXCEPTION);
7622 TEST_fff_f (fma, -0x1p-1074, 0x1p-1, -0x0.fffffffffffffp-1022, -0x1p-1022, UNDERFLOW_EXCEPTION);
7623 TEST_fff_f (fma, 0x1p-1074, 0x1.1p-1, 0x0.fffffffffffffp-1022, 0x0.fffffffffffffp-1022, UNDERFLOW_EXCEPTION);
7624 TEST_fff_f (fma, -0x1p-1074, 0x1.1p-1, -0x0.fffffffffffffp-1022, -0x1p-1022, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING);
473611b2
JM
7625 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, 0x1p1023, 0x1p1023);
7626 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, 0x1p1023, 0x0.fffffffffffff8p1023);
7627 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, -0x1p1023, -0x1p1023);
7628 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, -0x1p1023, -0x1.0000000000001p1023);
7629 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, 0x1p-1022, 0x1p-1022);
7630 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, 0x1p-1022, 0x0.fffffffffffffp-1022, UNDERFLOW_EXCEPTION);
7631 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, -0x1p-1022, -0x1p-1022, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING);
7632 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, -0x1p-1022, -0x1.0000000000001p-1022);
7633 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, 0x0.fffffffffffffp-1022, 0x0.fffffffffffffp-1022, UNDERFLOW_EXCEPTION);
7634 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, 0x0.fffffffffffffp-1022, 0x0.ffffffffffffep-1022, UNDERFLOW_EXCEPTION);
7635 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, -0x0.fffffffffffffp-1022, -0x0.fffffffffffffp-1022, UNDERFLOW_EXCEPTION);
7636 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, -0x0.fffffffffffffp-1022, -0x1p-1022, UNDERFLOW_EXCEPTION);
7637 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, 0x1p-1074, 0x1p-1074, UNDERFLOW_EXCEPTION);
7638 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, 0x1p-1074, plus_zero, UNDERFLOW_EXCEPTION);
7639 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, -0x1p-1074, -0x1p-1074, UNDERFLOW_EXCEPTION);
7640 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, -0x1p-1074, -0x1p-1073, UNDERFLOW_EXCEPTION);
5b5b04d6
JM
7641 TEST_fff_f (fma, 0x0.fffffffffffff8p0, 0x0.fffffffffffff8p0, -0x0.fffffffffffffp0, 0x1p-106);
7642 TEST_fff_f (fma, 0x0.fffffffffffff8p0, -0x0.fffffffffffff8p0, 0x0.fffffffffffffp0, -0x1p-106);
7643 TEST_fff_f (fma, -0x0.fffffffffffff8p0, 0x0.fffffffffffff8p0, 0x0.fffffffffffffp0, -0x1p-106);
7644 TEST_fff_f (fma, -0x0.fffffffffffff8p0, -0x0.fffffffffffff8p0, -0x0.fffffffffffffp0, 0x1p-106);
82477c28
JM
7645 TEST_fff_f (fma, 0x1.0000000000001p-1022, 0x1.0000000000001p-55, 0x1p1023, 0x1p1023);
7646 TEST_fff_f (fma, 0x1.0000000000001p-1022, -0x1.0000000000001p-55, 0x1p1023, 0x0.fffffffffffff8p1023);
7647 TEST_fff_f (fma, 0x1.0000000000001p-1022, 0x1.0000000000001p-55, -0x1p1023, -0x1p1023);
7648 TEST_fff_f (fma, 0x1.0000000000001p-1022, -0x1.0000000000001p-55, -0x1p1023, -0x1.0000000000001p1023);
7649 TEST_fff_f (fma, 0x1.0000000000001p-1022, 0x1.0000000000001p-55, 0x1p970, 0x1p970);
7650 TEST_fff_f (fma, 0x1.0000000000001p-1022, -0x1.0000000000001p-55, 0x1p970, 0x0.fffffffffffff8p970);
7651 TEST_fff_f (fma, 0x1.0000000000001p-1022, 0x1.0000000000001p-55, -0x1p970, -0x1p970);
7652 TEST_fff_f (fma, 0x1.0000000000001p-1022, -0x1.0000000000001p-55, -0x1p970, -0x1.0000000000001p970);
8627a232
JM
7653#endif
7654#if defined (TEST_LDOUBLE) && LDBL_MANT_DIG == 64
7655 TEST_fff_f (fma, 0x1.4p-16382L, 0x1.0000000000000004p-1L, 0x1p-16384L, 0x1.c000000000000004p-16383L, UNDERFLOW_EXCEPTION);
7656 TEST_fff_f (fma, -0x1.4p-16382L, 0x1.0000000000000004p-1L, -0x1p-16384L, -0x1.c000000000000008p-16383L, UNDERFLOW_EXCEPTION);
ef82f4da
JM
7657 TEST_fff_f (fma, 0x1.fffffffffffffff8p-16382L, 0x1.0000000000000002p-1L, 0x1p-16445L, 0x0.fffffffffffffffep-16382L, UNDERFLOW_EXCEPTION);
7658 TEST_fff_f (fma, -0x1.fffffffffffffff8p-16382L, 0x1.0000000000000002p-1L, -0x1p-16445L, -0x1p-16382L, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING);
7659 TEST_fff_f (fma, 0x1p-16445L, 0x1p-1L, 0x0.fffffffffffffffep-16382L, 0x0.fffffffffffffffep-16382L, UNDERFLOW_EXCEPTION);
7660 TEST_fff_f (fma, -0x1p-16445L, 0x1p-1L, -0x0.fffffffffffffffep-16382L, -0x1p-16382L, UNDERFLOW_EXCEPTION);
7661 TEST_fff_f (fma, 0x1p-16445L, 0x1.1p-1L, 0x0.fffffffffffffffep-16382L, 0x0.fffffffffffffffep-16382L, UNDERFLOW_EXCEPTION);
7662 TEST_fff_f (fma, -0x1p-16445L, 0x1.1p-1L, -0x0.fffffffffffffffep-16382L, -0x1p-16382L, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING);
473611b2
JM
7663 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, 0x1p16383L, 0x1p16383L);
7664 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, 0x1p16383L, 0x0.ffffffffffffffffp16383L);
7665 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, -0x1p16383L, -0x1p16383L);
7666 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, -0x1p16383L, -0x1.0000000000000002p16383L);
7667 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, 0x1p-16382L, 0x1p-16382L);
7668 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, 0x1p-16382L, 0x0.fffffffffffffffep-16382L, UNDERFLOW_EXCEPTION);
7669 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, -0x1p-16382L, -0x1p-16382L, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING);
7670 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, -0x1p-16382L, -0x1.0000000000000002p-16382L);
7671 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, 0x0.fffffffffffffffep-16382L, 0x0.fffffffffffffffep-16382L, UNDERFLOW_EXCEPTION);
7672 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, 0x0.fffffffffffffffep-16382L, 0x0.fffffffffffffffcp-16382L, UNDERFLOW_EXCEPTION);
7673 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, -0x0.fffffffffffffffep-16382L, -0x0.fffffffffffffffep-16382L, UNDERFLOW_EXCEPTION);
7674 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, -0x0.fffffffffffffffep-16382L, -0x1p-16382L, UNDERFLOW_EXCEPTION);
7675 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, 0x1p-16445L, 0x1p-16445L, UNDERFLOW_EXCEPTION);
7676 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, 0x1p-16445L, plus_zero, UNDERFLOW_EXCEPTION);
7677 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, -0x1p-16445L, -0x1p-16445L, UNDERFLOW_EXCEPTION);
7678 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, -0x1p-16445L, -0x1p-16444L, UNDERFLOW_EXCEPTION);
5b5b04d6
JM
7679 TEST_fff_f (fma, 0x0.ffffffffffffffffp0L, 0x0.ffffffffffffffffp0L, -0x0.fffffffffffffffep0L, 0x1p-128L);
7680 TEST_fff_f (fma, 0x0.ffffffffffffffffp0L, -0x0.ffffffffffffffffp0L, 0x0.fffffffffffffffep0L, -0x1p-128L);
7681 TEST_fff_f (fma, -0x0.ffffffffffffffffp0L, 0x0.ffffffffffffffffp0L, 0x0.fffffffffffffffep0L, -0x1p-128L);
7682 TEST_fff_f (fma, -0x0.ffffffffffffffffp0L, -0x0.ffffffffffffffffp0L, -0x0.fffffffffffffffep0L, 0x1p-128L);
82477c28
JM
7683 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, 0x1.0000000000000002p-66L, 0x1p16383L, 0x1p16383L);
7684 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, -0x1.0000000000000002p-66L, 0x1p16383L, 0x0.ffffffffffffffffp16383L);
7685 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, 0x1.0000000000000002p-66L, -0x1p16383L, -0x1p16383L);
7686 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, -0x1.0000000000000002p-66L, -0x1p16383L, -0x1.0000000000000002p16383L);
7687 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, 0x1.0000000000000002p-66L, 0x1p16319L, 0x1p16319L);
7688 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, -0x1.0000000000000002p-66L, 0x1p16319L, 0x0.ffffffffffffffffp16319L);
7689 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, 0x1.0000000000000002p-66L, -0x1p16319L, -0x1p16319L);
7690 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, -0x1.0000000000000002p-66L, -0x1p16319L, -0x1.0000000000000002p16319L);
8627a232
JM
7691#endif
7692#if defined (TEST_LDOUBLE) && LDBL_MANT_DIG == 113
7693 TEST_fff_f (fma, 0x1.4p-16382L, 0x1.0000000000000000000000000002p-1L, 0x1p-16384L, 0x1.c000000000000000000000000002p-16383L, UNDERFLOW_EXCEPTION);
7694 TEST_fff_f (fma, -0x1.4p-16382L, 0x1.0000000000000000000000000002p-1L, -0x1p-16384L, -0x1.c000000000000000000000000004p-16383L, UNDERFLOW_EXCEPTION);
ef82f4da
JM
7695 TEST_fff_f (fma, 0x1.fffffffffffffffffffffffffffcp-16382L, 0x1.0000000000000000000000000001p-1L, 0x1p-16494L, 0x0.ffffffffffffffffffffffffffffp-16382L, UNDERFLOW_EXCEPTION);
7696 TEST_fff_f (fma, -0x1.fffffffffffffffffffffffffffcp-16382L, 0x1.0000000000000000000000000001p-1L, -0x1p-16494L, -0x1p-16382L, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING);
7697 TEST_fff_f (fma, 0x1p-16494L, 0x1p-1L, 0x0.ffffffffffffffffffffffffffffp-16382L, 0x0.ffffffffffffffffffffffffffffp-16382L, UNDERFLOW_EXCEPTION);
7698 TEST_fff_f (fma, -0x1p-16494L, 0x1p-1L, -0x0.ffffffffffffffffffffffffffffp-16382L, -0x1p-16382L, UNDERFLOW_EXCEPTION);
7699 TEST_fff_f (fma, 0x1p-16494L, 0x1.1p-1L, 0x0.ffffffffffffffffffffffffffffp-16382L, 0x0.ffffffffffffffffffffffffffffp-16382L, UNDERFLOW_EXCEPTION);
7700 TEST_fff_f (fma, -0x1p-16494L, 0x1.1p-1L, -0x0.ffffffffffffffffffffffffffffp-16382L, -0x1p-16382L, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING);
473611b2
JM
7701 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, 0x1p16383L, 0x1p16383L);
7702 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, 0x1p16383L, 0x0.ffffffffffffffffffffffffffff8p16383L);
7703 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, -0x1p16383L, -0x1p16383L);
7704 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, -0x1p16383L, -0x1.0000000000000000000000000001p16383L);
7705 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, 0x1p-16382L, 0x1p-16382L);
7706 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, 0x1p-16382L, 0x0.ffffffffffffffffffffffffffffp-16382L, UNDERFLOW_EXCEPTION);
7707 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, -0x1p-16382L, -0x1p-16382L, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING);
7708 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, -0x1p-16382L, -0x1.0000000000000000000000000001p-16382L);
7709 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, 0x0.ffffffffffffffffffffffffffffp-16382L, 0x0.ffffffffffffffffffffffffffffp-16382L, UNDERFLOW_EXCEPTION);
7710 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, 0x0.ffffffffffffffffffffffffffffp-16382L, 0x0.fffffffffffffffffffffffffffep-16382L, UNDERFLOW_EXCEPTION);
7711 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, -0x0.ffffffffffffffffffffffffffffp-16382L, -0x0.ffffffffffffffffffffffffffffp-16382L, UNDERFLOW_EXCEPTION);
7712 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, -0x0.ffffffffffffffffffffffffffffp-16382L, -0x1p-16382L, UNDERFLOW_EXCEPTION);
7713 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, 0x1p-16494L, 0x1p-16494L, UNDERFLOW_EXCEPTION);
7714 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, 0x1p-16494L, plus_zero, UNDERFLOW_EXCEPTION);
7715 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, -0x1p-16494L, -0x1p-16494L, UNDERFLOW_EXCEPTION);
7716 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, -0x1p-16494L, -0x1p-16493L, UNDERFLOW_EXCEPTION);
5b5b04d6
JM
7717 TEST_fff_f (fma, 0x0.ffffffffffffffffffffffffffff8p0L, 0x0.ffffffffffffffffffffffffffff8p0L, -0x0.ffffffffffffffffffffffffffffp0L, 0x1p-226L);
7718 TEST_fff_f (fma, 0x0.ffffffffffffffffffffffffffff8p0L, -0x0.ffffffffffffffffffffffffffff8p0L, 0x0.ffffffffffffffffffffffffffffp0L, -0x1p-226L);
7719 TEST_fff_f (fma, -0x0.ffffffffffffffffffffffffffff8p0L, 0x0.ffffffffffffffffffffffffffff8p0L, 0x0.ffffffffffffffffffffffffffffp0L, -0x1p-226L);
7720 TEST_fff_f (fma, -0x0.ffffffffffffffffffffffffffff8p0L, -0x0.ffffffffffffffffffffffffffff8p0L, -0x0.ffffffffffffffffffffffffffffp0L, 0x1p-226L);
82477c28
JM
7721 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, 0x1.0000000000000000000000000001p-66L, 0x1p16383L, 0x1p16383L);
7722 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, -0x1.0000000000000000000000000001p-66L, 0x1p16383L, 0x0.ffffffffffffffffffffffffffff8p16383L);
7723 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, 0x1.0000000000000000000000000001p-66L, -0x1p16383L, -0x1p16383L);
7724 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, -0x1.0000000000000000000000000001p-66L, -0x1p16383L, -0x1.0000000000000000000000000001p16383L);
7725 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, 0x1.0000000000000000000000000001p-66L, 0x1p16319L, 0x1p16319L);
7726 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, -0x1.0000000000000000000000000001p-66L, 0x1p16319L, 0x0.ffffffffffffffffffffffffffff8p16319L);
7727 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, 0x1.0000000000000000000000000001p-66L, -0x1p16319L, -0x1p16319L);
7728 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, -0x1.0000000000000000000000000001p-66L, -0x1p16319L, -0x1.0000000000000000000000000001p16319L);
8627a232 7729#endif
8ec5b013
JM
7730 }
7731
7732 fesetround (save_round_mode);
7733
7734 END (fma_downward);
7735}
7736
7737
7738static void
7739fma_test_upward (void)
7740{
7741 int save_round_mode;
7742 START (fma_upward);
7743
7744 save_round_mode = fegetround ();
7745
7746 if (!fesetround (FE_UPWARD))
7747 {
7748 TEST_fff_f (fma, plus_zero, plus_zero, plus_zero, plus_zero);
7749 TEST_fff_f (fma, plus_zero, plus_zero, minus_zero, plus_zero);
7750 TEST_fff_f (fma, plus_zero, minus_zero, plus_zero, plus_zero);
7751 TEST_fff_f (fma, plus_zero, minus_zero, minus_zero, minus_zero);
7752 TEST_fff_f (fma, minus_zero, plus_zero, plus_zero, plus_zero);
7753 TEST_fff_f (fma, minus_zero, plus_zero, minus_zero, minus_zero);
7754 TEST_fff_f (fma, minus_zero, minus_zero, plus_zero, plus_zero);
7755 TEST_fff_f (fma, minus_zero, minus_zero, minus_zero, plus_zero);
7756 TEST_fff_f (fma, 1.0, plus_zero, plus_zero, plus_zero);
7757 TEST_fff_f (fma, 1.0, plus_zero, minus_zero, plus_zero);
7758 TEST_fff_f (fma, 1.0, minus_zero, plus_zero, plus_zero);
7759 TEST_fff_f (fma, 1.0, minus_zero, minus_zero, minus_zero);
7760 TEST_fff_f (fma, -1.0, plus_zero, plus_zero, plus_zero);
7761 TEST_fff_f (fma, -1.0, plus_zero, minus_zero, minus_zero);
7762 TEST_fff_f (fma, -1.0, minus_zero, plus_zero, plus_zero);
7763 TEST_fff_f (fma, -1.0, minus_zero, minus_zero, plus_zero);
7764 TEST_fff_f (fma, plus_zero, 1.0, plus_zero, plus_zero);
7765 TEST_fff_f (fma, plus_zero, 1.0, minus_zero, plus_zero);
7766 TEST_fff_f (fma, plus_zero, -1.0, plus_zero, plus_zero);
7767 TEST_fff_f (fma, plus_zero, -1.0, minus_zero, minus_zero);
7768 TEST_fff_f (fma, minus_zero, 1.0, plus_zero, plus_zero);
7769 TEST_fff_f (fma, minus_zero, 1.0, minus_zero, minus_zero);
7770 TEST_fff_f (fma, minus_zero, -1.0, plus_zero, plus_zero);
7771 TEST_fff_f (fma, minus_zero, -1.0, minus_zero, plus_zero);
7772
7773 TEST_fff_f (fma, 1.0, 1.0, -1.0, plus_zero);
7774 TEST_fff_f (fma, 1.0, -1.0, 1.0, plus_zero);
7775 TEST_fff_f (fma, -1.0, 1.0, 1.0, plus_zero);
7776 TEST_fff_f (fma, -1.0, -1.0, -1.0, plus_zero);
bec749fd
JM
7777
7778 TEST_fff_f (fma, min_value, min_value, plus_zero, min_subnorm_value, UNDERFLOW_EXCEPTION);
7779 TEST_fff_f (fma, min_value, min_value, minus_zero, min_subnorm_value, UNDERFLOW_EXCEPTION);
7780 TEST_fff_f (fma, min_value, -min_value, plus_zero, minus_zero, UNDERFLOW_EXCEPTION);
7781 TEST_fff_f (fma, min_value, -min_value, minus_zero, minus_zero, UNDERFLOW_EXCEPTION);
7782 TEST_fff_f (fma, -min_value, min_value, plus_zero, minus_zero, UNDERFLOW_EXCEPTION);
7783 TEST_fff_f (fma, -min_value, min_value, minus_zero, minus_zero, UNDERFLOW_EXCEPTION);
7784 TEST_fff_f (fma, -min_value, -min_value, plus_zero, min_subnorm_value, UNDERFLOW_EXCEPTION);
7785 TEST_fff_f (fma, -min_value, -min_value, minus_zero, min_subnorm_value, UNDERFLOW_EXCEPTION);
8627a232 7786
7184dcdf 7787#if !(defined TEST_LDOUBLE && LDBL_MANT_DIG == 106) /* Bug 13304. */
a0c2940d
JM
7788 TEST_fff_f (fma, max_value, max_value, min_value, plus_infty, OVERFLOW_EXCEPTION);
7789 TEST_fff_f (fma, max_value, max_value, -min_value, plus_infty, OVERFLOW_EXCEPTION);
7790 TEST_fff_f (fma, max_value, -max_value, min_value, -max_value, OVERFLOW_EXCEPTION);
7791 TEST_fff_f (fma, max_value, -max_value, -min_value, -max_value, OVERFLOW_EXCEPTION);
7792 TEST_fff_f (fma, -max_value, max_value, min_value, -max_value, OVERFLOW_EXCEPTION);
7793 TEST_fff_f (fma, -max_value, max_value, -min_value, -max_value, OVERFLOW_EXCEPTION);
7794 TEST_fff_f (fma, -max_value, -max_value, min_value, plus_infty, OVERFLOW_EXCEPTION);
7795 TEST_fff_f (fma, -max_value, -max_value, -min_value, plus_infty, OVERFLOW_EXCEPTION);
7184dcdf 7796#endif
a0c2940d 7797
8627a232
JM
7798#if defined (TEST_FLOAT) && FLT_MANT_DIG == 24
7799 TEST_fff_f (fma, 0x1.4p-126, 0x1.000004p-1, 0x1p-128, 0x1.c00008p-127, UNDERFLOW_EXCEPTION);
7800 TEST_fff_f (fma, -0x1.4p-126, 0x1.000004p-1, -0x1p-128, -0x1.c00004p-127, UNDERFLOW_EXCEPTION);
ef82f4da
JM
7801 TEST_fff_f (fma, 0x1.fffff8p-126, 0x1.000002p-1, 0x1p-149, 0x1p-126, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING);
7802 TEST_fff_f (fma, -0x1.fffff8p-126, 0x1.000002p-1, -0x1p-149, -0x0.fffffep-126, UNDERFLOW_EXCEPTION);
7803 TEST_fff_f (fma, 0x1p-149, 0x1p-1, 0x0.fffffep-126, 0x1p-126, UNDERFLOW_EXCEPTION);
7804 TEST_fff_f (fma, -0x1p-149, 0x1p-1, -0x0.fffffep-126, -0x0.fffffep-126, UNDERFLOW_EXCEPTION);
7805 TEST_fff_f (fma, 0x1p-149, 0x1.1p-1, 0x0.fffffep-126, 0x1p-126, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING);
7806 TEST_fff_f (fma, -0x1p-149, 0x1.1p-1, -0x0.fffffep-126, -0x0.fffffep-126, UNDERFLOW_EXCEPTION);
473611b2
JM
7807 TEST_fff_f (fma, 0x1p-149, 0x1p-149, 0x1p127, 0x1.000002p127);
7808 TEST_fff_f (fma, 0x1p-149, -0x1p-149, 0x1p127, 0x1p127);
7809 TEST_fff_f (fma, 0x1p-149, 0x1p-149, -0x1p127, -0x0.ffffffp127);
7810 TEST_fff_f (fma, 0x1p-149, -0x1p-149, -0x1p127, -0x1p127);
7811 TEST_fff_f (fma, 0x1p-149, 0x1p-149, 0x1p-126, 0x1.000002p-126);
7812 TEST_fff_f (fma, 0x1p-149, -0x1p-149, 0x1p-126, 0x1p-126, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING);
7813 TEST_fff_f (fma, 0x1p-149, 0x1p-149, -0x1p-126, -0x0.fffffep-126, UNDERFLOW_EXCEPTION);
7814 TEST_fff_f (fma, 0x1p-149, -0x1p-149, -0x1p-126, -0x1p-126);
7815 TEST_fff_f (fma, 0x1p-149, 0x1p-149, 0x0.fffffep-126, 0x1p-126, UNDERFLOW_EXCEPTION);
7816 TEST_fff_f (fma, 0x1p-149, -0x1p-149, 0x0.fffffep-126, 0x0.fffffep-126, UNDERFLOW_EXCEPTION);
7817 TEST_fff_f (fma, 0x1p-149, 0x1p-149, -0x0.fffffep-126, -0x0.fffffcp-126, UNDERFLOW_EXCEPTION);
7818 TEST_fff_f (fma, 0x1p-149, -0x1p-149, -0x0.fffffep-126, -0x0.fffffep-126, UNDERFLOW_EXCEPTION);
7819 TEST_fff_f (fma, 0x1p-149, 0x1p-149, 0x1p-149, 0x1p-148, UNDERFLOW_EXCEPTION);
7820 TEST_fff_f (fma, 0x1p-149, -0x1p-149, 0x1p-149, 0x1p-149, UNDERFLOW_EXCEPTION);
7821 TEST_fff_f (fma, 0x1p-149, 0x1p-149, -0x1p-149, minus_zero, UNDERFLOW_EXCEPTION);
7822 TEST_fff_f (fma, 0x1p-149, -0x1p-149, -0x1p-149, -0x1p-149, UNDERFLOW_EXCEPTION);
5b5b04d6
JM
7823 TEST_fff_f (fma, 0x0.fffp0, 0x0.fffp0, -0x0.ffep0, 0x1p-24);
7824 TEST_fff_f (fma, 0x0.fffp0, -0x0.fffp0, 0x0.ffep0, -0x1p-24);
7825 TEST_fff_f (fma, -0x0.fffp0, 0x0.fffp0, 0x0.ffep0, -0x1p-24);
7826 TEST_fff_f (fma, -0x0.fffp0, -0x0.fffp0, -0x0.ffep0, 0x1p-24);
82477c28
JM
7827 TEST_fff_f (fma, 0x1.000002p-126, 0x1.000002p-26, 0x1p127, 0x1.000002p127);
7828 TEST_fff_f (fma, 0x1.000002p-126, -0x1.000002p-26, 0x1p127, 0x1p127);
7829 TEST_fff_f (fma, 0x1.000002p-126, 0x1.000002p-26, -0x1p127, -0x0.ffffffp127);
7830 TEST_fff_f (fma, 0x1.000002p-126, -0x1.000002p-26, -0x1p127, -0x1p127);
7831 TEST_fff_f (fma, 0x1.000002p-126, 0x1.000002p-26, 0x1p103, 0x1.000002p103);
7832 TEST_fff_f (fma, 0x1.000002p-126, -0x1.000002p-26, 0x1p103, 0x1p103);
7833 TEST_fff_f (fma, 0x1.000002p-126, 0x1.000002p-26, -0x1p103, -0x0.ffffffp103);
7834 TEST_fff_f (fma, 0x1.000002p-126, -0x1.000002p-26, -0x1p103, -0x1p103);
8627a232
JM
7835#endif
7836#if defined (TEST_DOUBLE) && DBL_MANT_DIG == 53
7837 TEST_fff_f (fma, 0x1.4p-1022, 0x1.0000000000002p-1, 0x1p-1024, 0x1.c000000000004p-1023, UNDERFLOW_EXCEPTION);
7838 TEST_fff_f (fma, -0x1.4p-1022, 0x1.0000000000002p-1, -0x1p-1024, -0x1.c000000000002p-1023, UNDERFLOW_EXCEPTION);
ef82f4da
JM
7839 TEST_fff_f (fma, 0x1.ffffffffffffcp-1022, 0x1.0000000000001p-1, 0x1p-1074, 0x1p-1022, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING);
7840 TEST_fff_f (fma, -0x1.ffffffffffffcp-1022, 0x1.0000000000001p-1, -0x1p-1074, -0x0.fffffffffffffp-1022, UNDERFLOW_EXCEPTION);
7841 TEST_fff_f (fma, 0x1p-1074, 0x1p-1, 0x0.fffffffffffffp-1022, 0x1p-1022, UNDERFLOW_EXCEPTION);
7842 TEST_fff_f (fma, -0x1p-1074, 0x1p-1, -0x0.fffffffffffffp-1022, -0x0.fffffffffffffp-1022, UNDERFLOW_EXCEPTION);
7843 TEST_fff_f (fma, 0x1p-1074, 0x1.1p-1, 0x0.fffffffffffffp-1022, 0x1p-1022, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING);
7844 TEST_fff_f (fma, -0x1p-1074, 0x1.1p-1, -0x0.fffffffffffffp-1022, -0x0.fffffffffffffp-1022, UNDERFLOW_EXCEPTION);
473611b2
JM
7845 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, 0x1p1023, 0x1.0000000000001p1023);
7846 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, 0x1p1023, 0x1p1023);
7847 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, -0x1p1023, -0x0.fffffffffffff8p1023);
7848 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, -0x1p1023, -0x1p1023);
7849 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, 0x1p-1022, 0x1.0000000000001p-1022);
7850 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, 0x1p-1022, 0x1p-1022, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING);
7851 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, -0x1p-1022, -0x0.fffffffffffffp-1022, UNDERFLOW_EXCEPTION);
7852 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, -0x1p-1022, -0x1p-1022);
7853 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, 0x0.fffffffffffffp-1022, 0x1p-1022, UNDERFLOW_EXCEPTION);
7854 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, 0x0.fffffffffffffp-1022, 0x0.fffffffffffffp-1022, UNDERFLOW_EXCEPTION);
7855 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, -0x0.fffffffffffffp-1022, -0x0.ffffffffffffep-1022, UNDERFLOW_EXCEPTION);
7856 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, -0x0.fffffffffffffp-1022, -0x0.fffffffffffffp-1022, UNDERFLOW_EXCEPTION);
7857 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, 0x1p-1074, 0x1p-1073, UNDERFLOW_EXCEPTION);
7858 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, 0x1p-1074, 0x1p-1074, UNDERFLOW_EXCEPTION);
7859 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, -0x1p-1074, minus_zero, UNDERFLOW_EXCEPTION);
7860 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, -0x1p-1074, -0x1p-1074, UNDERFLOW_EXCEPTION);
5b5b04d6
JM
7861 TEST_fff_f (fma, 0x0.fffffffffffff8p0, 0x0.fffffffffffff8p0, -0x0.fffffffffffffp0, 0x1p-106);
7862 TEST_fff_f (fma, 0x0.fffffffffffff8p0, -0x0.fffffffffffff8p0, 0x0.fffffffffffffp0, -0x1p-106);
7863 TEST_fff_f (fma, -0x0.fffffffffffff8p0, 0x0.fffffffffffff8p0, 0x0.fffffffffffffp0, -0x1p-106);
7864 TEST_fff_f (fma, -0x0.fffffffffffff8p0, -0x0.fffffffffffff8p0, -0x0.fffffffffffffp0, 0x1p-106);
82477c28
JM
7865 TEST_fff_f (fma, 0x1.0000000000001p-1022, 0x1.0000000000001p-55, 0x1p1023, 0x1.0000000000001p1023);
7866 TEST_fff_f (fma, 0x1.0000000000001p-1022, -0x1.0000000000001p-55, 0x1p1023, 0x1p1023);
7867 TEST_fff_f (fma, 0x1.0000000000001p-1022, 0x1.0000000000001p-55, -0x1p1023, -0x0.fffffffffffff8p1023);
7868 TEST_fff_f (fma, 0x1.0000000000001p-1022, -0x1.0000000000001p-55, -0x1p1023, -0x1p1023);
7869 TEST_fff_f (fma, 0x1.0000000000001p-1022, 0x1.0000000000001p-55, 0x1p970, 0x1.0000000000001p970);
7870 TEST_fff_f (fma, 0x1.0000000000001p-1022, -0x1.0000000000001p-55, 0x1p970, 0x1p970);
7871 TEST_fff_f (fma, 0x1.0000000000001p-1022, 0x1.0000000000001p-55, -0x1p970, -0x0.fffffffffffff8p970);
7872 TEST_fff_f (fma, 0x1.0000000000001p-1022, -0x1.0000000000001p-55, -0x1p970, -0x1p970);
8627a232
JM
7873#endif
7874#if defined (TEST_LDOUBLE) && LDBL_MANT_DIG == 64
7875 TEST_fff_f (fma, 0x1.4p-16382L, 0x1.0000000000000004p-1L, 0x1p-16384L, 0x1.c000000000000008p-16383L, UNDERFLOW_EXCEPTION);
7876 TEST_fff_f (fma, -0x1.4p-16382L, 0x1.0000000000000004p-1L, -0x1p-16384L, -0x1.c000000000000004p-16383L, UNDERFLOW_EXCEPTION);
ef82f4da
JM
7877 TEST_fff_f (fma, 0x1.fffffffffffffff8p-16382L, 0x1.0000000000000002p-1L, 0x1p-16445L, 0x1p-16382L, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING);
7878 TEST_fff_f (fma, -0x1.fffffffffffffff8p-16382L, 0x1.0000000000000002p-1L, -0x1p-16445L, -0x0.fffffffffffffffep-16382L, UNDERFLOW_EXCEPTION);
7879 TEST_fff_f (fma, 0x1p-16445L, 0x1p-1L, 0x0.fffffffffffffffep-16382L, 0x1p-16382L, UNDERFLOW_EXCEPTION);
7880 TEST_fff_f (fma, -0x1p-16445L, 0x1p-1L, -0x0.fffffffffffffffep-16382L, -0x0.fffffffffffffffep-16382L, UNDERFLOW_EXCEPTION);
7881 TEST_fff_f (fma, 0x1p-16445L, 0x1.1p-1L, 0x0.fffffffffffffffep-16382L, 0x1p-16382L, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING);
7882 TEST_fff_f (fma, -0x1p-16445L, 0x1.1p-1L, -0x0.fffffffffffffffep-16382L, -0x0.fffffffffffffffep-16382L, UNDERFLOW_EXCEPTION);
473611b2
JM
7883 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, 0x1p16383L, 0x1.0000000000000002p16383L);
7884 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, 0x1p16383L, 0x1p16383L);
7885 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, -0x1p16383L, -0x0.ffffffffffffffffp16383L);
7886 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, -0x1p16383L, -0x1p16383L);
7887 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, 0x1p-16382L, 0x1.0000000000000002p-16382L);
7888 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, 0x1p-16382L, 0x1p-16382L, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING);
7889 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, -0x1p-16382L, -0x0.fffffffffffffffep-16382L, UNDERFLOW_EXCEPTION);
7890 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, -0x1p-16382L, -0x1p-16382L);
7891 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, 0x0.fffffffffffffffep-16382L, 0x1p-16382L, UNDERFLOW_EXCEPTION);
7892 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, 0x0.fffffffffffffffep-16382L, 0x0.fffffffffffffffep-16382L, UNDERFLOW_EXCEPTION);
7893 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, -0x0.fffffffffffffffep-16382L, -0x0.fffffffffffffffcp-16382L, UNDERFLOW_EXCEPTION);
7894 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, -0x0.fffffffffffffffep-16382L, -0x0.fffffffffffffffep-16382L, UNDERFLOW_EXCEPTION);
7895 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, 0x1p-16445L, 0x1p-16444L, UNDERFLOW_EXCEPTION);
7896 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, 0x1p-16445L, 0x1p-16445L, UNDERFLOW_EXCEPTION);
7897 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, -0x1p-16445L, minus_zero, UNDERFLOW_EXCEPTION);
7898 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, -0x1p-16445L, -0x1p-16445L, UNDERFLOW_EXCEPTION);
5b5b04d6
JM
7899 TEST_fff_f (fma, 0x0.ffffffffffffffffp0L, 0x0.ffffffffffffffffp0L, -0x0.fffffffffffffffep0L, 0x1p-128L);
7900 TEST_fff_f (fma, 0x0.ffffffffffffffffp0L, -0x0.ffffffffffffffffp0L, 0x0.fffffffffffffffep0L, -0x1p-128L);
7901 TEST_fff_f (fma, -0x0.ffffffffffffffffp0L, 0x0.ffffffffffffffffp0L, 0x0.fffffffffffffffep0L, -0x1p-128L);
7902 TEST_fff_f (fma, -0x0.ffffffffffffffffp0L, -0x0.ffffffffffffffffp0L, -0x0.fffffffffffffffep0L, 0x1p-128L);
82477c28
JM
7903 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, 0x1.0000000000000002p-66L, 0x1p16383L, 0x1.0000000000000002p16383L);
7904 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, -0x1.0000000000000002p-66L, 0x1p16383L, 0x1p16383L);
7905 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, 0x1.0000000000000002p-66L, -0x1p16383L, -0x0.ffffffffffffffffp16383L);
7906 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, -0x1.0000000000000002p-66L, -0x1p16383L, -0x1p16383L);
7907 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, 0x1.0000000000000002p-66L, 0x1p16319L, 0x1.0000000000000002p16319L);
7908 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, -0x1.0000000000000002p-66L, 0x1p16319L, 0x1p16319L);
7909 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, 0x1.0000000000000002p-66L, -0x1p16319L, -0x0.ffffffffffffffffp16319L);
7910 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, -0x1.0000000000000002p-66L, -0x1p16319L, -0x1p16319L);
8627a232
JM
7911#endif
7912#if defined (TEST_LDOUBLE) && LDBL_MANT_DIG == 113
7913 TEST_fff_f (fma, 0x1.4p-16382L, 0x1.0000000000000000000000000002p-1L, 0x1p-16384L, 0x1.c000000000000000000000000004p-16383L, UNDERFLOW_EXCEPTION);
7914 TEST_fff_f (fma, -0x1.4p-16382L, 0x1.0000000000000000000000000002p-1L, -0x1p-16384L, -0x1.c000000000000000000000000002p-16383L, UNDERFLOW_EXCEPTION);
ef82f4da
JM
7915 TEST_fff_f (fma, 0x1.fffffffffffffffffffffffffffcp-16382L, 0x1.0000000000000000000000000001p-1L, 0x1p-16494L, 0x1p-16382L, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING);
7916 TEST_fff_f (fma, -0x1.fffffffffffffffffffffffffffcp-16382L, 0x1.0000000000000000000000000001p-1L, -0x1p-16494L, -0x0.ffffffffffffffffffffffffffffp-16382L, UNDERFLOW_EXCEPTION);
7917 TEST_fff_f (fma, 0x1p-16494L, 0x1p-1L, 0x0.ffffffffffffffffffffffffffffp-16382L, 0x1p-16382L, UNDERFLOW_EXCEPTION);
7918 TEST_fff_f (fma, -0x1p-16494L, 0x1p-1L, -0x0.ffffffffffffffffffffffffffffp-16382L, -0x0.ffffffffffffffffffffffffffffp-16382L, UNDERFLOW_EXCEPTION);
7919 TEST_fff_f (fma, 0x1p-16494L, 0x1.1p-1L, 0x0.ffffffffffffffffffffffffffffp-16382L, 0x1p-16382L, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING);
7920 TEST_fff_f (fma, -0x1p-16494L, 0x1.1p-1L, -0x0.ffffffffffffffffffffffffffffp-16382L, -0x0.ffffffffffffffffffffffffffffp-16382L, UNDERFLOW_EXCEPTION);
473611b2
JM
7921 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, 0x1p16383L, 0x1.0000000000000000000000000001p16383L);
7922 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, 0x1p16383L, 0x1p16383L);
7923 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, -0x1p16383L, -0x0.ffffffffffffffffffffffffffff8p16383L);
7924 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, -0x1p16383L, -0x1p16383L);
7925 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, 0x1p-16382L, 0x1.0000000000000000000000000001p-16382L);
7926 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, 0x1p-16382L, 0x1p-16382L, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING);
7927 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, -0x1p-16382L, -0x0.ffffffffffffffffffffffffffffp-16382L, UNDERFLOW_EXCEPTION);
7928 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, -0x1p-16382L, -0x1p-16382L);
7929 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, 0x0.ffffffffffffffffffffffffffffp-16382L, 0x1p-16382L, UNDERFLOW_EXCEPTION);
7930 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, 0x0.ffffffffffffffffffffffffffffp-16382L, 0x0.ffffffffffffffffffffffffffffp-16382L, UNDERFLOW_EXCEPTION);
7931 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, -0x0.ffffffffffffffffffffffffffffp-16382L, -0x0.fffffffffffffffffffffffffffep-16382L, UNDERFLOW_EXCEPTION);
7932 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, -0x0.ffffffffffffffffffffffffffffp-16382L, -0x0.ffffffffffffffffffffffffffffp-16382L, UNDERFLOW_EXCEPTION);
7933 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, 0x1p-16494L, 0x1p-16493L, UNDERFLOW_EXCEPTION);
7934 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, 0x1p-16494L, 0x1p-16494L, UNDERFLOW_EXCEPTION);
7935 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, -0x1p-16494L, minus_zero, UNDERFLOW_EXCEPTION);
7936 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, -0x1p-16494L, -0x1p-16494L, UNDERFLOW_EXCEPTION);
5b5b04d6
JM
7937 TEST_fff_f (fma, 0x0.ffffffffffffffffffffffffffff8p0L, 0x0.ffffffffffffffffffffffffffff8p0L, -0x0.ffffffffffffffffffffffffffffp0L, 0x1p-226L);
7938 TEST_fff_f (fma, 0x0.ffffffffffffffffffffffffffff8p0L, -0x0.ffffffffffffffffffffffffffff8p0L, 0x0.ffffffffffffffffffffffffffffp0L, -0x1p-226L);
7939 TEST_fff_f (fma, -0x0.ffffffffffffffffffffffffffff8p0L, 0x0.ffffffffffffffffffffffffffff8p0L, 0x0.ffffffffffffffffffffffffffffp0L, -0x1p-226L);
7940 TEST_fff_f (fma, -0x0.ffffffffffffffffffffffffffff8p0L, -0x0.ffffffffffffffffffffffffffff8p0L, -0x0.ffffffffffffffffffffffffffffp0L, 0x1p-226L);
82477c28
JM
7941 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, 0x1.0000000000000000000000000001p-66L, 0x1p16383L, 0x1.0000000000000000000000000001p16383L);
7942 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, -0x1.0000000000000000000000000001p-66L, 0x1p16383L, 0x1p16383L);
7943 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, 0x1.0000000000000000000000000001p-66L, -0x1p16383L, -0x0.ffffffffffffffffffffffffffff8p16383L);
7944 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, -0x1.0000000000000000000000000001p-66L, -0x1p16383L, -0x1p16383L);
7945 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, 0x1.0000000000000000000000000001p-66L, 0x1p16319L, 0x1.0000000000000000000000000001p16319L);
7946 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, -0x1.0000000000000000000000000001p-66L, 0x1p16319L, 0x1p16319L);
7947 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, 0x1.0000000000000000000000000001p-66L, -0x1p16319L, -0x0.ffffffffffffffffffffffffffff8p16319L);
7948 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, -0x1.0000000000000000000000000001p-66L, -0x1p16319L, -0x1p16319L);
8627a232 7949#endif
8ec5b013
JM
7950 }
7951
7952 fesetround (save_round_mode);
7953
7954 END (fma_upward);
7955}
7956
7957
8847214f
UD
7958static void
7959fmax_test (void)
7960{
7961 START (fmax);
7962
7963 TEST_ff_f (fmax, 0, 0, 0);
7964 TEST_ff_f (fmax, minus_zero, minus_zero, minus_zero);
7965 TEST_ff_f (fmax, 9, 0, 9);
7966 TEST_ff_f (fmax, 0, 9, 9);
7967 TEST_ff_f (fmax, -9, 0, 0);
7968 TEST_ff_f (fmax, 0, -9, 0);
7969
7970 TEST_ff_f (fmax, plus_infty, 9, plus_infty);
7971 TEST_ff_f (fmax, 0, plus_infty, plus_infty);
7972 TEST_ff_f (fmax, -9, plus_infty, plus_infty);
7973 TEST_ff_f (fmax, plus_infty, -9, plus_infty);
7974
7975 TEST_ff_f (fmax, minus_infty, 9, 9);
7976 TEST_ff_f (fmax, minus_infty, -9, -9);
7977 TEST_ff_f (fmax, 9, minus_infty, 9);
7978 TEST_ff_f (fmax, -9, minus_infty, -9);
7979
67e971f1
TS
7980 TEST_ff_f (fmax, 0, qnan_value, 0);
7981 TEST_ff_f (fmax, 9, qnan_value, 9);
7982 TEST_ff_f (fmax, -9, qnan_value, -9);
7983 TEST_ff_f (fmax, qnan_value, 0, 0);
7984 TEST_ff_f (fmax, qnan_value, 9, 9);
7985 TEST_ff_f (fmax, qnan_value, -9, -9);
7986 TEST_ff_f (fmax, plus_infty, qnan_value, plus_infty);
7987 TEST_ff_f (fmax, minus_infty, qnan_value, minus_infty);
7988 TEST_ff_f (fmax, qnan_value, plus_infty, plus_infty);
7989 TEST_ff_f (fmax, qnan_value, minus_infty, minus_infty);
7990 TEST_ff_f (fmax, qnan_value, qnan_value, qnan_value);
8847214f
UD
7991
7992 END (fmax);
7993}
7994
7995
7996static void
7997fmin_test (void)
7998{
7999 START (fmin);
8000
8001 TEST_ff_f (fmin, 0, 0, 0);
8002 TEST_ff_f (fmin, minus_zero, minus_zero, minus_zero);
8003 TEST_ff_f (fmin, 9, 0, 0);
8004 TEST_ff_f (fmin, 0, 9, 0);
8005 TEST_ff_f (fmin, -9, 0, -9);
8006 TEST_ff_f (fmin, 0, -9, -9);
8007
8008 TEST_ff_f (fmin, plus_infty, 9, 9);
8009 TEST_ff_f (fmin, 9, plus_infty, 9);
8010 TEST_ff_f (fmin, plus_infty, -9, -9);
8011 TEST_ff_f (fmin, -9, plus_infty, -9);
8012 TEST_ff_f (fmin, minus_infty, 9, minus_infty);
8013 TEST_ff_f (fmin, minus_infty, -9, minus_infty);
8014 TEST_ff_f (fmin, 9, minus_infty, minus_infty);
8015 TEST_ff_f (fmin, -9, minus_infty, minus_infty);
8016
67e971f1
TS
8017 TEST_ff_f (fmin, 0, qnan_value, 0);
8018 TEST_ff_f (fmin, 9, qnan_value, 9);
8019 TEST_ff_f (fmin, -9, qnan_value, -9);
8020 TEST_ff_f (fmin, qnan_value, 0, 0);
8021 TEST_ff_f (fmin, qnan_value, 9, 9);
8022 TEST_ff_f (fmin, qnan_value, -9, -9);
8023 TEST_ff_f (fmin, plus_infty, qnan_value, plus_infty);
8024 TEST_ff_f (fmin, minus_infty, qnan_value, minus_infty);
8025 TEST_ff_f (fmin, qnan_value, plus_infty, plus_infty);
8026 TEST_ff_f (fmin, qnan_value, minus_infty, minus_infty);
8027 TEST_ff_f (fmin, qnan_value, qnan_value, qnan_value);
8847214f
UD
8028
8029 END (fmin);
8030}
8031
8032
8033static void
8034fmod_test (void)
8035{
aaca11d8 8036 errno = 0;
3c6cad26 8037 FUNC(fmod) (6.5, 2.3L);
aaca11d8
UD
8038 if (errno == ENOSYS)
8039 /* Function not implemented. */
8040 return;
8041
8847214f
UD
8042 START (fmod);
8043
8044 /* fmod (+0, y) == +0 for y != 0. */
8045 TEST_ff_f (fmod, 0, 3, 0);
8046
8047 /* fmod (-0, y) == -0 for y != 0. */
8048 TEST_ff_f (fmod, minus_zero, 3, minus_zero);
8049
67e971f1 8050 /* fmod (+inf, y) == qNaN plus invalid exception. */
7095366d 8051 errno = 0;
67e971f1 8052 TEST_ff_f (fmod, plus_infty, 3, qnan_value, INVALID_EXCEPTION);
7095366d 8053 check_int ("errno for fmod(Inf,3) unchanged", errno, EDOM, 0, 0, 0);
67e971f1 8054 /* fmod (-inf, y) == qNaN plus invalid exception. */
7095366d 8055 errno = 0;
67e971f1 8056 TEST_ff_f (fmod, minus_infty, 3, qnan_value, INVALID_EXCEPTION);
7095366d 8057 check_int ("errno for fmod(-Inf,3) unchanged", errno, EDOM, 0, 0, 0);
67e971f1 8058 /* fmod (x, +0) == qNaN plus invalid exception. */
7095366d 8059 errno = 0;
67e971f1 8060 TEST_ff_f (fmod, 3, 0, qnan_value, INVALID_EXCEPTION);
7095366d 8061 check_int ("errno for fmod(3,0) unchanged", errno, EDOM, 0, 0, 0);
67e971f1
TS
8062 /* fmod (x, -0) == qNaN plus invalid exception. */
8063 TEST_ff_f (fmod, 3, minus_zero, qnan_value, INVALID_EXCEPTION);
8847214f
UD
8064
8065 /* fmod (x, +inf) == x for x not infinite. */
8066 TEST_ff_f (fmod, 3.0, plus_infty, 3.0);
8067 /* fmod (x, -inf) == x for x not infinite. */
8068 TEST_ff_f (fmod, 3.0, minus_infty, 3.0);
8069
67e971f1 8070 TEST_ff_f (fmod, qnan_value, qnan_value, qnan_value);
15daa639 8071
2550dfe9
AJ
8072 TEST_ff_f (fmod, 6.5, 2.25L, 2.0L);
8073 TEST_ff_f (fmod, -6.5, 2.25L, -2.0L);
8074 TEST_ff_f (fmod, 6.5, -2.25L, 2.0L);
8075 TEST_ff_f (fmod, -6.5, -2.25L, -2.0L);
8847214f 8076
c5bfe3d5
JM
8077 TEST_ff_f (fmod, 0x0.fffffep-126L, 0x1p-149L, plus_zero);
8078#ifndef TEST_FLOAT
8079 TEST_ff_f (fmod, 0x0.fffffffffffffp-1022L, 0x1p-1074L, plus_zero);
8080#endif
8081#if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
8082 TEST_ff_f (fmod, 0x0.fffffffffffffffep-16382L, 0x1p-16445L, plus_zero);
8083#endif
8084
8847214f
UD
8085 END (fmod);
8086}
8087
2550dfe9 8088
8847214f
UD
8089static void
8090fpclassify_test (void)
8091{
8092 START (fpclassify);
8093
67e971f1 8094 TEST_f_i (fpclassify, qnan_value, FP_NAN);
8847214f
UD
8095 TEST_f_i (fpclassify, plus_infty, FP_INFINITE);
8096 TEST_f_i (fpclassify, minus_infty, FP_INFINITE);
8097 TEST_f_i (fpclassify, plus_zero, FP_ZERO);
8098 TEST_f_i (fpclassify, minus_zero, FP_ZERO);
8099 TEST_f_i (fpclassify, 1000, FP_NORMAL);
ef1bb361 8100 TEST_f_i (fpclassify, min_subnorm_value, FP_SUBNORMAL);
8847214f
UD
8101
8102 END (fpclassify);
8103}
8104
8105
8106static void
8107frexp_test (void)
8108{
8109 int x;
8110
8111 START (frexp);
8112
8113 TEST_fI_f1 (frexp, plus_infty, plus_infty, IGNORE);
8114 TEST_fI_f1 (frexp, minus_infty, minus_infty, IGNORE);
67e971f1 8115 TEST_fI_f1 (frexp, qnan_value, qnan_value, IGNORE);
8847214f
UD
8116
8117 TEST_fI_f1 (frexp, 0.0, 0.0, 0.0);
8118 TEST_fI_f1 (frexp, minus_zero, minus_zero, 0.0);
8119
b15cb495
UD
8120 TEST_fI_f1 (frexp, 12.8L, 0.8L, 4);
8121 TEST_fI_f1 (frexp, -27.34L, -0.854375L, 5);
8847214f
UD
8122
8123 END (frexp);
8124}
8125
8126
8127static void
8128gamma_test (void)
8129{
8130 errno = 0;
8131 FUNC(gamma) (1);
8132
8133 if (errno == ENOSYS)
8134 /* Function not implemented. */
8135 return;
8847214f
UD
8136
8137 START (gamma);
8138
8139 TEST_f_f (gamma, plus_infty, plus_infty);
8140 TEST_f_f (gamma, 0, plus_infty, DIVIDE_BY_ZERO_EXCEPTION);
8141 TEST_f_f (gamma, -3, plus_infty, DIVIDE_BY_ZERO_EXCEPTION);
f30e0cd3 8142 TEST_f_f (gamma, minus_infty, plus_infty);
67e971f1 8143 TEST_f_f (gamma, qnan_value, qnan_value);
8847214f
UD
8144
8145 TEST_f_f1 (gamma, 1, 0, 1);
8146 TEST_f_f1 (gamma, 3, M_LN2l, 1);
8147
8148 TEST_f_f1 (gamma, 0.5, M_LOG_SQRT_PIl, 1);
f30e0cd3 8149 TEST_f_f1 (gamma, -0.5, M_LOG_2_SQRT_PIl, -1);
8847214f
UD
8150
8151 END (gamma);
8152}
8153
8154static void
8155hypot_test (void)
8156{
aaca11d8 8157 errno = 0;
3c6cad26 8158 FUNC(hypot) (0.7L, 12.4L);
aaca11d8
UD
8159 if (errno == ENOSYS)
8160 /* Function not implemented. */
8161 return;
8162
8847214f
UD
8163 START (hypot);
8164
8165 TEST_ff_f (hypot, plus_infty, 1, plus_infty, IGNORE_ZERO_INF_SIGN);
8166 TEST_ff_f (hypot, minus_infty, 1, plus_infty, IGNORE_ZERO_INF_SIGN);
8167
15daa639 8168#ifndef TEST_INLINE
67e971f1
TS
8169 TEST_ff_f (hypot, plus_infty, qnan_value, plus_infty);
8170 TEST_ff_f (hypot, minus_infty, qnan_value, plus_infty);
8171 TEST_ff_f (hypot, qnan_value, plus_infty, plus_infty);
8172 TEST_ff_f (hypot, qnan_value, minus_infty, plus_infty);
15daa639 8173#endif
8847214f 8174
67e971f1 8175 TEST_ff_f (hypot, qnan_value, qnan_value, qnan_value);
8847214f
UD
8176
8177 /* hypot (x,y) == hypot (+-x, +-y) */
d8337213
UD
8178 TEST_ff_f (hypot, 0.7L, 12.4L, 12.419742348374220601176836866763271L);
8179 TEST_ff_f (hypot, -0.7L, 12.4L, 12.419742348374220601176836866763271L);
8180 TEST_ff_f (hypot, 0.7L, -12.4L, 12.419742348374220601176836866763271L);
8181 TEST_ff_f (hypot, -0.7L, -12.4L, 12.419742348374220601176836866763271L);
8182 TEST_ff_f (hypot, 12.4L, 0.7L, 12.419742348374220601176836866763271L);
8183 TEST_ff_f (hypot, -12.4L, 0.7L, 12.419742348374220601176836866763271L);
8184 TEST_ff_f (hypot, 12.4L, -0.7L, 12.419742348374220601176836866763271L);
8185 TEST_ff_f (hypot, -12.4L, -0.7L, 12.419742348374220601176836866763271L);
8847214f
UD
8186
8187 /* hypot (x,0) == fabs (x) */
2550dfe9
AJ
8188 TEST_ff_f (hypot, 0.75L, 0, 0.75L);
8189 TEST_ff_f (hypot, -0.75L, 0, 0.75L);
3c6cad26 8190 TEST_ff_f (hypot, -5.7e7, 0, 5.7e7L);
8847214f 8191
2550dfe9 8192 TEST_ff_f (hypot, 0.75L, 1.25L, 1.45773797371132511771853821938639577L);
8847214f 8193
8e27e3cc 8194 TEST_ff_f (hypot, 1.0L, 0x1p-61L, 1.0L);
1468ded3
JM
8195#if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 106
8196 TEST_ff_f (hypot, 0x1.23456789abcdef0123456789ab8p-500L, 0x1.23456789abcdef0123456789ab8p-500L, 4.9155782399407039128612180934736799735113e-151L);
8197#endif
8e27e3cc 8198
aa4a2ae1
JM
8199#if !(defined TEST_FLOAT && defined TEST_INLINE)
8200 TEST_ff_f (hypot, 0x3p125L, 0x4p125L, 0x5p125L);
8201 TEST_ff_f (hypot, 0x1.234566p-126L, 0x1.234566p-126L, 1.891441686191081936598531534017449451173e-38L);
8202#endif
8203
5779f134 8204#if !defined TEST_FLOAT && !(defined TEST_DOUBLE && defined TEST_INLINE)
aa4a2ae1
JM
8205 TEST_ff_f (hypot, 0x3p1021L, 0x4p1021L, 0x5p1021L);
8206#endif
8207
8208#if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384 && !defined TEST_INLINE
8209 TEST_ff_f (hypot, 0x3p16381L, 0x4p16381L, 0x5p16381L);
8210#endif
8211
8847214f
UD
8212 END (hypot);
8213}
8214
8215
8216static void
8217ilogb_test (void)
8218{
8219 START (ilogb);
8220
8221 TEST_f_i (ilogb, 1, 0);
8222 TEST_f_i (ilogb, M_El, 1);
8223 TEST_f_i (ilogb, 1024, 10);
8224 TEST_f_i (ilogb, -2000, 10);
8225
76da7265
AZ
8226 /* ilogb (0.0) == FP_ILOGB0 plus invalid exception */
8227 errno = 0;
8228 TEST_f_i (ilogb, 0.0, FP_ILOGB0, INVALID_EXCEPTION);
8229 check_int ("errno for ilogb(0.0) unchanged", errno, EDOM, 0, 0, 0);
67e971f1 8230 /* ilogb (qNaN) == FP_ILOGBNAN plus invalid exception */
76da7265 8231 errno = 0;
67e971f1
TS
8232 TEST_f_i (ilogb, qnan_value, FP_ILOGBNAN, INVALID_EXCEPTION);
8233 check_int ("errno for ilogb(qNaN) unchanged", errno, EDOM, 0, 0, 0);
76da7265
AZ
8234 /* ilogb (inf) == INT_MAX plus invalid exception */
8235 errno = 0;
8236 TEST_f_i (ilogb, plus_infty, INT_MAX, INVALID_EXCEPTION);
8237 check_int ("errno for ilogb(Inf) unchanged", errno, EDOM, 0, 0, 0);
8238 /* ilogb (-inf) == INT_MAX plus invalid exception */
8239 errno = 0;
8240 TEST_f_i (ilogb, minus_infty, INT_MAX, INVALID_EXCEPTION);
8241 check_int ("errno for ilogb(-Inf) unchanged", errno, EDOM, 0, 0, 0);
8847214f
UD
8242
8243 END (ilogb);
8244}
8245
8246static void
8247isfinite_test (void)
8248{
8249 START (isfinite);
8250
8251 TEST_f_b (isfinite, 0, 1);
8252 TEST_f_b (isfinite, minus_zero, 1);
8253 TEST_f_b (isfinite, 10, 1);
ef1bb361 8254 TEST_f_b (isfinite, min_subnorm_value, 1);
8847214f
UD
8255 TEST_f_b (isfinite, plus_infty, 0);
8256 TEST_f_b (isfinite, minus_infty, 0);
67e971f1 8257 TEST_f_b (isfinite, qnan_value, 0);
8847214f
UD
8258
8259 END (isfinite);
8260}
8261
0e8e0c1c
JM
8262static void
8263isgreater_test (void)
8264{
8265 START (isgreater);
8266
8267 TEST_ff_i (isgreater, minus_zero, minus_zero, 0);
8268 TEST_ff_i (isgreater, minus_zero, plus_zero, 0);
8269 TEST_ff_i (isgreater, minus_zero, (FLOAT) 1, 0);
67e971f1 8270 TEST_ff_i (isgreater, minus_zero, qnan_value, 0);
0e8e0c1c
JM
8271 TEST_ff_i (isgreater, plus_zero, minus_zero, 0);
8272 TEST_ff_i (isgreater, plus_zero, plus_zero, 0);
8273 TEST_ff_i (isgreater, plus_zero, (FLOAT) 1, 0);
67e971f1 8274 TEST_ff_i (isgreater, plus_zero, qnan_value, 0);
0e8e0c1c
JM
8275 TEST_ff_i (isgreater, (FLOAT) 1, minus_zero, 1);
8276 TEST_ff_i (isgreater, (FLOAT) 1, plus_zero, 1);
8277 TEST_ff_i (isgreater, (FLOAT) 1, (FLOAT) 1, 0);
67e971f1
TS
8278 TEST_ff_i (isgreater, (FLOAT) 1, qnan_value, 0);
8279 TEST_ff_i (isgreater, qnan_value, minus_zero, 0);
8280 TEST_ff_i (isgreater, qnan_value, plus_zero, 0);
8281 TEST_ff_i (isgreater, qnan_value, (FLOAT) 1, 0);
8282 TEST_ff_i (isgreater, qnan_value, qnan_value, 0);
0e8e0c1c
JM
8283
8284 END (isgreater);
8285}
8286
8287static void
8288isgreaterequal_test (void)
8289{
8290 START (isgreaterequal);
8291
8292 TEST_ff_i (isgreaterequal, minus_zero, minus_zero, 1);
8293 TEST_ff_i (isgreaterequal, minus_zero, plus_zero, 1);
8294 TEST_ff_i (isgreaterequal, minus_zero, (FLOAT) 1, 0);
67e971f1 8295 TEST_ff_i (isgreaterequal, minus_zero, qnan_value, 0);
0e8e0c1c
JM
8296 TEST_ff_i (isgreaterequal, plus_zero, minus_zero, 1);
8297 TEST_ff_i (isgreaterequal, plus_zero, plus_zero, 1);
8298 TEST_ff_i (isgreaterequal, plus_zero, (FLOAT) 1, 0);
67e971f1 8299 TEST_ff_i (isgreaterequal, plus_zero, qnan_value, 0);
0e8e0c1c
JM
8300 TEST_ff_i (isgreaterequal, (FLOAT) 1, minus_zero, 1);
8301 TEST_ff_i (isgreaterequal, (FLOAT) 1, plus_zero, 1);
8302 TEST_ff_i (isgreaterequal, (FLOAT) 1, (FLOAT) 1, 1);
67e971f1
TS
8303 TEST_ff_i (isgreaterequal, (FLOAT) 1, qnan_value, 0);
8304 TEST_ff_i (isgreaterequal, qnan_value, minus_zero, 0);
8305 TEST_ff_i (isgreaterequal, qnan_value, plus_zero, 0);
8306 TEST_ff_i (isgreaterequal, qnan_value, (FLOAT) 1, 0);
8307 TEST_ff_i (isgreaterequal, qnan_value, qnan_value, 0);
0e8e0c1c
JM
8308
8309 END (isgreaterequal);
8310}
8311
ef1bb361
JM
8312static void
8313isinf_test (void)
8314{
8315 START (isinf);
8316
8317 TEST_f_b (isinf, 0, 0);
8318 TEST_f_b (isinf, minus_zero, 0);
8319 TEST_f_b (isinf, 10, 0);
8320 TEST_f_b (isinf, min_subnorm_value, 0);
8321 TEST_f_b (isinf, plus_infty, 1);
8322 TEST_f_b (isinf, minus_infty, 1);
67e971f1 8323 TEST_f_b (isinf, qnan_value, 0);
ef1bb361
JM
8324
8325 END (isinf);
8326}
8327
0e8e0c1c
JM
8328static void
8329isless_test (void)
8330{
8331 START (isless);
8332
8333 TEST_ff_i (isless, minus_zero, minus_zero, 0);
8334 TEST_ff_i (isless, minus_zero, plus_zero, 0);
8335 TEST_ff_i (isless, minus_zero, (FLOAT) 1, 1);
67e971f1 8336 TEST_ff_i (isless, minus_zero, qnan_value, 0);
0e8e0c1c
JM
8337 TEST_ff_i (isless, plus_zero, minus_zero, 0);
8338 TEST_ff_i (isless, plus_zero, plus_zero, 0);
8339 TEST_ff_i (isless, plus_zero, (FLOAT) 1, 1);
67e971f1 8340 TEST_ff_i (isless, plus_zero, qnan_value, 0);
0e8e0c1c
JM
8341 TEST_ff_i (isless, (FLOAT) 1, minus_zero, 0);
8342 TEST_ff_i (isless, (FLOAT) 1, plus_zero, 0);
8343 TEST_ff_i (isless, (FLOAT) 1, (FLOAT) 1, 0);
67e971f1
TS
8344 TEST_ff_i (isless, (FLOAT) 1, qnan_value, 0);
8345 TEST_ff_i (isless, qnan_value, minus_zero, 0);
8346 TEST_ff_i (isless, qnan_value, plus_zero, 0);
8347 TEST_ff_i (isless, qnan_value, (FLOAT) 1, 0);
8348 TEST_ff_i (isless, qnan_value, qnan_value, 0);
0e8e0c1c
JM
8349
8350 END (isless);
8351}
8352
8353static void
8354islessequal_test (void)
8355{
8356 START (islessequal);
8357
8358 TEST_ff_i (islessequal, minus_zero, minus_zero, 1);
8359 TEST_ff_i (islessequal, minus_zero, plus_zero, 1);
8360 TEST_ff_i (islessequal, minus_zero, (FLOAT) 1, 1);
67e971f1 8361 TEST_ff_i (islessequal, minus_zero, qnan_value, 0);
0e8e0c1c
JM
8362 TEST_ff_i (islessequal, plus_zero, minus_zero, 1);
8363 TEST_ff_i (islessequal, plus_zero, plus_zero, 1);
8364 TEST_ff_i (islessequal, plus_zero, (FLOAT) 1, 1);
67e971f1 8365 TEST_ff_i (islessequal, plus_zero, qnan_value, 0);
0e8e0c1c
JM
8366 TEST_ff_i (islessequal, (FLOAT) 1, minus_zero, 0);
8367 TEST_ff_i (islessequal, (FLOAT) 1, plus_zero, 0);
8368 TEST_ff_i (islessequal, (FLOAT) 1, (FLOAT) 1, 1);
67e971f1
TS
8369 TEST_ff_i (islessequal, (FLOAT) 1, qnan_value, 0);
8370 TEST_ff_i (islessequal, qnan_value, minus_zero, 0);
8371 TEST_ff_i (islessequal, qnan_value, plus_zero, 0);
8372 TEST_ff_i (islessequal, qnan_value, (FLOAT) 1, 0);
8373 TEST_ff_i (islessequal, qnan_value, qnan_value, 0);
0e8e0c1c
JM
8374
8375 END (islessequal);
8376}
8377
8378static void
8379islessgreater_test (void)
8380{
8381 START (islessgreater);
8382
8383 TEST_ff_i (islessgreater, minus_zero, minus_zero, 0);
8384 TEST_ff_i (islessgreater, minus_zero, plus_zero, 0);
8385 TEST_ff_i (islessgreater, minus_zero, (FLOAT) 1, 1);
67e971f1 8386 TEST_ff_i (islessgreater, minus_zero, qnan_value, 0);
0e8e0c1c
JM
8387 TEST_ff_i (islessgreater, plus_zero, minus_zero, 0);
8388 TEST_ff_i (islessgreater, plus_zero, plus_zero, 0);
8389 TEST_ff_i (islessgreater, plus_zero, (FLOAT) 1, 1);
67e971f1 8390 TEST_ff_i (islessgreater, plus_zero, qnan_value, 0);
0e8e0c1c
JM
8391 TEST_ff_i (islessgreater, (FLOAT) 1, minus_zero, 1);
8392 TEST_ff_i (islessgreater, (FLOAT) 1, plus_zero, 1);
8393 TEST_ff_i (islessgreater, (FLOAT) 1, (FLOAT) 1, 0);
67e971f1
TS
8394 TEST_ff_i (islessgreater, (FLOAT) 1, qnan_value, 0);
8395 TEST_ff_i (islessgreater, qnan_value, minus_zero, 0);
8396 TEST_ff_i (islessgreater, qnan_value, plus_zero, 0);
8397 TEST_ff_i (islessgreater, qnan_value, (FLOAT) 1, 0);
8398 TEST_ff_i (islessgreater, qnan_value, qnan_value, 0);
0e8e0c1c
JM
8399
8400 END (islessgreater);
8401}
8402
ef1bb361
JM
8403static void
8404isnan_test (void)
8405{
8406 START (isnan);
8407
8408 TEST_f_b (isnan, 0, 0);
8409 TEST_f_b (isnan, minus_zero, 0);
8410 TEST_f_b (isnan, 10, 0);
8411 TEST_f_b (isnan, min_subnorm_value, 0);
8412 TEST_f_b (isnan, plus_infty, 0);
8413 TEST_f_b (isnan, minus_infty, 0);
67e971f1 8414 TEST_f_b (isnan, qnan_value, 1);
ef1bb361
JM
8415
8416 END (isnan);
8417}
8418
8847214f
UD
8419static void
8420isnormal_test (void)
8421{
8422 START (isnormal);
8423
8424 TEST_f_b (isnormal, 0, 0);
8425 TEST_f_b (isnormal, minus_zero, 0);
8426 TEST_f_b (isnormal, 10, 1);
ef1bb361 8427 TEST_f_b (isnormal, min_subnorm_value, 0);
8847214f
UD
8428 TEST_f_b (isnormal, plus_infty, 0);
8429 TEST_f_b (isnormal, minus_infty, 0);
67e971f1 8430 TEST_f_b (isnormal, qnan_value, 0);
8847214f
UD
8431
8432 END (isnormal);
8433}
8434
57267616
TS
8435static void
8436issignaling_test (void)
8437{
8438 START (issignaling);
8439
8440 TEST_f_b (issignaling, 0, 0);
8441 TEST_f_b (issignaling, minus_zero, 0);
8442 TEST_f_b (issignaling, 10, 0);
8443 TEST_f_b (issignaling, min_subnorm_value, 0);
8444 TEST_f_b (issignaling, plus_infty, 0);
8445 TEST_f_b (issignaling, minus_infty, 0);
8446 TEST_f_b (issignaling, qnan_value, 0);
8447
8448 END (issignaling);
8449}
8450
0e8e0c1c
JM
8451static void
8452isunordered_test (void)
8453{
8454 START (isunordered);
8455
8456 TEST_ff_i (isunordered, minus_zero, minus_zero, 0);
8457 TEST_ff_i (isunordered, minus_zero, plus_zero, 0);
8458 TEST_ff_i (isunordered, minus_zero, (FLOAT) 1, 0);
67e971f1 8459 TEST_ff_i (isunordered, minus_zero, qnan_value, 1);
0e8e0c1c
JM
8460 TEST_ff_i (isunordered, plus_zero, minus_zero, 0);
8461 TEST_ff_i (isunordered, plus_zero, plus_zero, 0);
8462 TEST_ff_i (isunordered, plus_zero, (FLOAT) 1, 0);
67e971f1 8463 TEST_ff_i (isunordered, plus_zero, qnan_value, 1);
0e8e0c1c
JM
8464 TEST_ff_i (isunordered, (FLOAT) 1, minus_zero, 0);
8465 TEST_ff_i (isunordered, (FLOAT) 1, plus_zero, 0);
8466 TEST_ff_i (isunordered, (FLOAT) 1, (FLOAT) 1, 0);
67e971f1
TS
8467 TEST_ff_i (isunordered, (FLOAT) 1, qnan_value, 1);
8468 TEST_ff_i (isunordered, qnan_value, minus_zero, 1);
8469 TEST_ff_i (isunordered, qnan_value, plus_zero, 1);
8470 TEST_ff_i (isunordered, qnan_value, (FLOAT) 1, 1);
8471 TEST_ff_i (isunordered, qnan_value, qnan_value, 1);
0e8e0c1c
JM
8472
8473 END (isunordered);
8474}
8475
8847214f
UD
8476static void
8477j0_test (void)
8478{
cd53c157 8479 FLOAT s, c;
8847214f 8480 errno = 0;
cd53c157
UD
8481 FUNC (sincos) (0, &s, &c);
8482 if (errno == ENOSYS)
8483 /* Required function not implemented. */
8484 return;
8847214f
UD
8485 FUNC(j0) (0);
8486 if (errno == ENOSYS)
8487 /* Function not implemented. */
8488 return;
8489
8490 START (j0);
8491
8492 /* j0 is the Bessel function of the first kind of order 0 */
67e971f1 8493 TEST_f_f (j0, qnan_value, qnan_value);
8847214f 8494 TEST_f_f (j0, plus_infty, 0);
2550dfe9 8495 TEST_f_f (j0, -1.0, 0.765197686557966551449717526102663221L);
8847214f 8496 TEST_f_f (j0, 0.0, 1.0);
2550dfe9
AJ
8497 TEST_f_f (j0, 0.125L, 0.996097563041985204620768999453174712L);
8498 TEST_f_f (j0, 0.75L, 0.864242275166648623555731103820923211L);
8499 TEST_f_f (j0, 1.0, 0.765197686557966551449717526102663221L);
8500 TEST_f_f (j0, 1.5, 0.511827671735918128749051744283411720L);
8501 TEST_f_f (j0, 2.0, 0.223890779141235668051827454649948626L);
8502 TEST_f_f (j0, 8.0, 0.171650807137553906090869407851972001L);
8503 TEST_f_f (j0, 10.0, -0.245935764451348335197760862485328754L);
fa9ced58
AJ
8504 TEST_f_f (j0, 4.0, -3.9714980986384737228659076845169804197562E-1L);
8505 TEST_f_f (j0, -4.0, -3.9714980986384737228659076845169804197562E-1L);
8847214f 8506
41c7328e 8507 TEST_f_f (j0, 0x1.d7ce3ap+107L, 2.775523647291230802651040996274861694514e-17L);
c36e1d23
JM
8508
8509#ifndef TEST_FLOAT
2a185d32 8510 TEST_f_f (j0, -0x1.001000001p+593L, -3.927269966354206207832593635798954916263e-90L);
98c48fe5 8511 TEST_f_f (j0, 0x1p1023L, -1.5665258060609012834424478437196679802783e-155L);
c36e1d23
JM
8512#endif
8513
d2f9799e
JM
8514#if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
8515 TEST_f_f (j0, 0x1p16382L, -1.2193782500509000574176799046642541129387e-2466L);
8516 TEST_f_f (j0, 0x1p16383L, 9.5859502826270374691362975419147645151233e-2467L);
8517#endif
8518
8847214f
UD
8519 END (j0);
8520}
8521
8522
8523static void
8524j1_test (void)
8525{
8a216c1b 8526 FLOAT s, c;
8847214f 8527 errno = 0;
cd53c157
UD
8528 FUNC (sincos) (0, &s, &c);
8529 if (errno == ENOSYS)
8530 /* Required function not implemented. */
8531 return;
8847214f
UD
8532 FUNC(j1) (0);
8533 if (errno == ENOSYS)
8534 /* Function not implemented. */
8535 return;
8536
8537 /* j1 is the Bessel function of the first kind of order 1 */
8538
8539 START (j1);
8540
67e971f1 8541 TEST_f_f (j1, qnan_value, qnan_value);
8847214f
UD
8542 TEST_f_f (j1, plus_infty, 0);
8543
2550dfe9 8544 TEST_f_f (j1, -1.0, -0.440050585744933515959682203718914913L);
8847214f 8545 TEST_f_f (j1, 0.0, 0.0);
2550dfe9
AJ
8546 TEST_f_f (j1, 0.125L, 0.0623780091344946810942311355879361177L);
8547 TEST_f_f (j1, 0.75L, 0.349243602174862192523281016426251335L);
8548 TEST_f_f (j1, 1.0, 0.440050585744933515959682203718914913L);
8549 TEST_f_f (j1, 1.5, 0.557936507910099641990121213156089400L);
8550 TEST_f_f (j1, 2.0, 0.576724807756873387202448242269137087L);
8551 TEST_f_f (j1, 8.0, 0.234636346853914624381276651590454612L);
8552 TEST_f_f (j1, 10.0, 0.0434727461688614366697487680258592883L);
8847214f 8553
c36e1d23
JM
8554 TEST_f_f (j1, 0x1.3ffp+74L, 1.818984347516051243459364437186082741567e-12L);
8555
8556#ifndef TEST_FLOAT
2a185d32 8557 TEST_f_f (j1, 0x1.ff00000000002p+840L, 1.846591691699331493194965158699937660696e-127L);
98c48fe5 8558 TEST_f_f (j1, 0x1p1023L, 8.2687542933709649327986678723012001545638e-155L);
c36e1d23
JM
8559#endif
8560
d2f9799e
JM
8561#if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
8562 TEST_f_f (j1, 0x1p16382L, 8.0839224448726336195866026476176740513439e-2467L);
8563 TEST_f_f (j1, 0x1p16383L, -3.8895531955766020648617743624167352352217e-2467L);
8564#endif
8565
8847214f
UD
8566 END (j1);
8567}
8568
8569static void
8570jn_test (void)
8571{
8a216c1b 8572 FLOAT s, c;
8847214f 8573 errno = 0;
cd53c157
UD
8574 FUNC (sincos) (0, &s, &c);
8575 if (errno == ENOSYS)
8576 /* Required function not implemented. */
8577 return;
8847214f
UD
8578 FUNC(jn) (1, 1);
8579 if (errno == ENOSYS)
8580 /* Function not implemented. */
8581 return;
8582
8583 /* jn is the Bessel function of the first kind of order n. */
8584 START (jn);
8585
8586 /* jn (0, x) == j0 (x) */
67e971f1 8587 TEST_ff_f (jn, 0, qnan_value, qnan_value);
8847214f 8588 TEST_ff_f (jn, 0, plus_infty, 0);
2550dfe9 8589 TEST_ff_f (jn, 0, -1.0, 0.765197686557966551449717526102663221L);
8847214f 8590 TEST_ff_f (jn, 0, 0.0, 1.0);
2550dfe9
AJ
8591 TEST_ff_f (jn, 0, 0.125L, 0.996097563041985204620768999453174712L);
8592 TEST_ff_f (jn, 0, 0.75L, 0.864242275166648623555731103820923211L);
8593 TEST_ff_f (jn, 0, 1.0, 0.765197686557966551449717526102663221L);
8594 TEST_ff_f (jn, 0, 1.5, 0.511827671735918128749051744283411720L);
8595 TEST_ff_f (jn, 0, 2.0, 0.223890779141235668051827454649948626L);
8596 TEST_ff_f (jn, 0, 8.0, 0.171650807137553906090869407851972001L);
8597 TEST_ff_f (jn, 0, 10.0, -0.245935764451348335197760862485328754L);
8598 TEST_ff_f (jn, 0, 4.0, -3.9714980986384737228659076845169804197562E-1L);
8599 TEST_ff_f (jn, 0, -4.0, -3.9714980986384737228659076845169804197562E-1L);
8847214f
UD
8600
8601 /* jn (1, x) == j1 (x) */
67e971f1 8602 TEST_ff_f (jn, 1, qnan_value, qnan_value);
8847214f 8603 TEST_ff_f (jn, 1, plus_infty, 0);
2550dfe9 8604 TEST_ff_f (jn, 1, -1.0, -0.440050585744933515959682203718914913L);
8847214f 8605 TEST_ff_f (jn, 1, 0.0, 0.0);
2550dfe9
AJ
8606 TEST_ff_f (jn, 1, 0.125L, 0.0623780091344946810942311355879361177L);
8607 TEST_ff_f (jn, 1, 0.75L, 0.349243602174862192523281016426251335L);
8608 TEST_ff_f (jn, 1, 1.0, 0.440050585744933515959682203718914913L);
8609 TEST_ff_f (jn, 1, 1.5, 0.557936507910099641990121213156089400L);
8610 TEST_ff_f (jn, 1, 2.0, 0.576724807756873387202448242269137087L);
8611 TEST_ff_f (jn, 1, 8.0, 0.234636346853914624381276651590454612L);
8612 TEST_ff_f (jn, 1, 10.0, 0.0434727461688614366697487680258592883L);
8847214f
UD
8613
8614 /* jn (3, x) */
67e971f1 8615 TEST_ff_f (jn, 3, qnan_value, qnan_value);
8847214f
UD
8616 TEST_ff_f (jn, 3, plus_infty, 0);
8617
2550dfe9 8618 TEST_ff_f (jn, 3, -1.0, -0.0195633539826684059189053216217515083L);
8847214f 8619 TEST_ff_f (jn, 3, 0.0, 0.0);
2550dfe9
AJ
8620 TEST_ff_f (jn, 3, 0.125L, 0.406503832554912875023029337653442868e-4L);
8621 TEST_ff_f (jn, 3, 0.75L, 0.848438342327410884392755236884386804e-2L);
8622 TEST_ff_f (jn, 3, 1.0, 0.0195633539826684059189053216217515083L);
8623 TEST_ff_f (jn, 3, 2.0, 0.128943249474402051098793332969239835L);
8624 TEST_ff_f (jn, 3, 10.0, 0.0583793793051868123429354784103409563L);
8847214f
UD
8625
8626 /* jn (10, x) */
67e971f1 8627 TEST_ff_f (jn, 10, qnan_value, qnan_value);
8847214f
UD
8628 TEST_ff_f (jn, 10, plus_infty, 0);
8629
2550dfe9 8630 TEST_ff_f (jn, 10, -1.0, 0.263061512368745320699785368779050294e-9L);
8847214f 8631 TEST_ff_f (jn, 10, 0.0, 0.0);
2550dfe9
AJ
8632 TEST_ff_f (jn, 10, 0.125L, 0.250543369809369890173993791865771547e-18L);
8633 TEST_ff_f (jn, 10, 0.75L, 0.149621713117596814698712483621682835e-10L);
8634 TEST_ff_f (jn, 10, 1.0, 0.263061512368745320699785368779050294e-9L);
8635 TEST_ff_f (jn, 10, 2.0, 0.251538628271673670963516093751820639e-6L);
8636 TEST_ff_f (jn, 10, 10.0, 0.207486106633358857697278723518753428L);
8847214f 8637
1248c1c4 8638 /* BZ #11589 .*/
cfdc0dd7
AS
8639 TEST_ff_f (jn, 2, 2.4048255576957729L, 0.43175480701968038399746111312430703L);
8640 TEST_ff_f (jn, 3, 2.4048255576957729L, 0.19899990535769083404042146764530813L);
8641 TEST_ff_f (jn, 4, 2.4048255576957729L, 0.647466661641779720084932282551219891E-1L);
8642 TEST_ff_f (jn, 5, 2.4048255576957729L, 0.163892432048058525099230549946147698E-1L);
8643 TEST_ff_f (jn, 6, 2.4048255576957729L, 0.34048184720278336646673682895929161E-2L);
8644 TEST_ff_f (jn, 7, 2.4048255576957729L, 0.60068836573295394221291569249883076E-3L);
8645 TEST_ff_f (jn, 8, 2.4048255576957729L, 0.92165786705344923232879022467054148E-4L);
c36e1d23
JM
8646 TEST_ff_f (jn, 9, 2.4048255576957729L, 0.12517270977961513005428966643852564E-4L);
8647
80bad0cc
JM
8648 /* Bug 14155: spurious exception may occur. */
8649 TEST_ff_f (jn, 2, 0x1.ffff62p+99L, -4.43860668048170034334926693188979974489e-16L, UNDERFLOW_EXCEPTION_OK);
1248c1c4 8650
8847214f
UD
8651 END (jn);
8652}
8653
8654
8655static void
8656ldexp_test (void)
8657{
af00a34d
TS
8658 START (ldexp);
8659
8847214f
UD
8660 TEST_ff_f (ldexp, 0, 0, 0);
8661 TEST_ff_f (ldexp, minus_zero, 0, minus_zero);
8662
8663 TEST_ff_f (ldexp, plus_infty, 1, plus_infty);
8664 TEST_ff_f (ldexp, minus_infty, 1, minus_infty);
67e971f1 8665 TEST_ff_f (ldexp, qnan_value, 1, qnan_value);
8847214f
UD
8666
8667 TEST_ff_f (ldexp, 0.8L, 4, 12.8L);
8668 TEST_ff_f (ldexp, -0.854375L, 5, -27.34L);
8669
8670 /* ldexp (x, 0) == x. */
8671 TEST_ff_f (ldexp, 1.0L, 0L, 1.0L);
af00a34d
TS
8672
8673 END (ldexp);
8847214f
UD
8674}
8675
2550dfe9 8676
8847214f
UD
8677static void
8678lgamma_test (void)
8679{
8680 errno = 0;
8681 FUNC(lgamma) (0);
8682 if (errno == ENOSYS)
8683 /* Function not implemented. */
8684 return;
8847214f
UD
8685
8686 START (lgamma);
8687
8688 TEST_f_f (lgamma, plus_infty, plus_infty);
8689 TEST_f_f (lgamma, 0, plus_infty, DIVIDE_BY_ZERO_EXCEPTION);
c039eedd
UD
8690 check_int ("signgam for lgamma(0) == 1", signgam, 1, 0, 0, 0);
8691 TEST_f_f (lgamma, minus_zero, plus_infty, DIVIDE_BY_ZERO_EXCEPTION);
8692 check_int ("signgam for lgamma(-0) == -1", signgam, -1, 0, 0, 0);
67e971f1 8693 TEST_f_f (lgamma, qnan_value, qnan_value);
8847214f
UD
8694
8695 /* lgamma (x) == +inf plus divide by zero exception for integer x <= 0. */
e971e76d 8696 errno = 0;
8847214f 8697 TEST_f_f (lgamma, -3, plus_infty, DIVIDE_BY_ZERO_EXCEPTION);
e971e76d 8698 check_int ("errno for lgamma(-integer) == ERANGE", errno, ERANGE, 0, 0, 0);
8847214f 8699 TEST_f_f (lgamma, minus_infty, plus_infty);
41bf21a1
JM
8700 TEST_f_f (lgamma, -max_value, plus_infty, DIVIDE_BY_ZERO_EXCEPTION);
8701 TEST_f_f (lgamma, max_value, plus_infty, OVERFLOW_EXCEPTION);
8847214f
UD
8702
8703 TEST_f_f1 (lgamma, 1, 0, 1);
8704
8705 TEST_f_f1 (lgamma, 3, M_LN2l, 1);
8706
8707 TEST_f_f1 (lgamma, 0.5, M_LOG_SQRT_PIl, 1);
8708 TEST_f_f1 (lgamma, -0.5, M_LOG_2_SQRT_PIl, -1);
79df8ce5
AJ
8709 TEST_f_f1 (lgamma, 0.7L, 0.260867246531666514385732417016759578L, 1);
8710 TEST_f_f1 (lgamma, 1.2L, -0.853740900033158497197028392998854470e-1L, 1);
8847214f
UD
8711
8712 END (lgamma);
8713}
8714
2550dfe9 8715
8847214f
UD
8716static void
8717lrint_test (void)
8718{
8719 /* XXX this test is incomplete. We need to have a way to specifiy
8720 the rounding method and test the critical cases. So far, only
8721 unproblematic numbers are tested. */
64d063b8 8722 /* TODO: missing +/-Inf as well as qNaN tests. */
8847214f
UD
8723
8724 START (lrint);
8725
8726 TEST_f_l (lrint, 0.0, 0);
8727 TEST_f_l (lrint, minus_zero, 0);
3c6cad26
UD
8728 TEST_f_l (lrint, 0.2L, 0);
8729 TEST_f_l (lrint, -0.2L, 0);
8847214f 8730
3c6cad26
UD
8731 TEST_f_l (lrint, 1.4L, 1);
8732 TEST_f_l (lrint, -1.4L, -1);
8847214f 8733
3c6cad26
UD
8734 TEST_f_l (lrint, 8388600.3L, 8388600);
8735 TEST_f_l (lrint, -8388600.3L, -8388600);
8847214f 8736
3eb61415
UD
8737 TEST_f_l (lrint, 1071930.0008, 1071930);
8738#ifndef TEST_FLOAT
8739 TEST_f_l (lrint, 1073741824.01, 1073741824);
39007ae3
UD
8740# if LONG_MAX > 281474976710656
8741 TEST_f_l (lrint, 281474976710656.025, 281474976710656);
8742# endif
3eb61415
UD
8743#endif
8744
8847214f
UD
8745 END (lrint);
8746}
8747
2550dfe9 8748
6624dbc0
UD
8749static void
8750lrint_test_tonearest (void)
8751{
8752 int save_round_mode;
8753 START (lrint_tonearest);
8754
8755 save_round_mode = fegetround ();
8756
8757 if (!fesetround (FE_TONEAREST))
8758 {
8759 TEST_f_l (lrint, 0.0, 0);
8760 TEST_f_l (lrint, minus_zero, 0);
8761 TEST_f_l (lrint, 0.2L, 0);
8762 TEST_f_l (lrint, -0.2L, 0);
8763 TEST_f_l (lrint, 0.5L, 0);
8764 TEST_f_l (lrint, -0.5L, 0);
8765 TEST_f_l (lrint, 0.8L, 1);
8766 TEST_f_l (lrint, -0.8L, -1);
8767
8768 TEST_f_l (lrint, 1.4L, 1);
8769 TEST_f_l (lrint, -1.4L, -1);
8770
8771 TEST_f_l (lrint, 8388600.3L, 8388600);
8772 TEST_f_l (lrint, -8388600.3L, -8388600);
8773
8774 TEST_f_l (lrint, 1071930.0008, 1071930);
8775#ifndef TEST_FLOAT
8776 TEST_f_l (lrint, 1073741824.01, 1073741824);
8777# if LONG_MAX > 281474976710656
8778 TEST_f_l (lrint, 281474976710656.025, 281474976710656);
8779# endif
8780#endif
8781 }
8782
8783 fesetround (save_round_mode);
8784
8785 END (lrint_tonearest);
8786}
8787
8788
8789static void
8790lrint_test_towardzero (void)
8791{
8792 int save_round_mode;
8793 START (lrint_towardzero);
8794
8795 save_round_mode = fegetround ();
8796
8797 if (!fesetround (FE_TOWARDZERO))
8798 {
8799 TEST_f_l (lrint, 0.0, 0);
8800 TEST_f_l (lrint, minus_zero, 0);
8801 TEST_f_l (lrint, 0.2L, 0);
8802 TEST_f_l (lrint, -0.2L, 0);
8803 TEST_f_l (lrint, 0.5L, 0);
8804 TEST_f_l (lrint, -0.5L, 0);
8805 TEST_f_l (lrint, 0.8L, 0);
8806 TEST_f_l (lrint, -0.8L, 0);
8807
8808 TEST_f_l (lrint, 1.4L, 1);
8809 TEST_f_l (lrint, -1.4L, -1);
8810
8811 TEST_f_l (lrint, 8388600.3L, 8388600);
8812 TEST_f_l (lrint, -8388600.3L, -8388600);
8813
8814 TEST_f_l (lrint, 1071930.0008, 1071930);
8815#ifndef TEST_FLOAT
8816 TEST_f_l (lrint, 1073741824.01, 1073741824);
8817# if LONG_MAX > 281474976710656
8818 TEST_f_l (lrint, 281474976710656.025, 281474976710656);
8819# endif
8820#endif
8821 }
8822
8823 fesetround (save_round_mode);
8824
8825 END (lrint_towardzero);
8826}
8827
8828
8829static void
8830lrint_test_downward (void)
8831{
8832 int save_round_mode;
8833 START (lrint_downward);
8834
8835 save_round_mode = fegetround ();
8836
8837 if (!fesetround (FE_DOWNWARD))
8838 {
8839 TEST_f_l (lrint, 0.0, 0);
8840 TEST_f_l (lrint, minus_zero, 0);
8841 TEST_f_l (lrint, 0.2L, 0);
8842 TEST_f_l (lrint, -0.2L, -1);
8843 TEST_f_l (lrint, 0.5L, 0);
8844 TEST_f_l (lrint, -0.5L, -1);
8845 TEST_f_l (lrint, 0.8L, 0);
8846 TEST_f_l (lrint, -0.8L, -1);
8847
8848 TEST_f_l (lrint, 1.4L, 1);
8849 TEST_f_l (lrint, -1.4L, -2);
8850
8851 TEST_f_l (lrint, 8388600.3L, 8388600);
8852 TEST_f_l (lrint, -8388600.3L, -8388601);
8853
8854 TEST_f_l (lrint, 1071930.0008, 1071930);
8855#ifndef TEST_FLOAT
8856 TEST_f_l (lrint, 1073741824.01, 1073741824);
8857# if LONG_MAX > 281474976710656
8858 TEST_f_l (lrint, 281474976710656.025, 281474976710656);
8859# endif
8860#endif
8861 }
8862
8863 fesetround (save_round_mode);
8864
8865 END (lrint_downward);
8866}
8867
8868
8869static void
8870lrint_test_upward (void)
8871{
8872 int save_round_mode;
8873 START (lrint_upward);
8874
8875 save_round_mode = fegetround ();
8876
8877 if (!fesetround (FE_UPWARD))
8878 {
8879 TEST_f_l (lrint, 0.0, 0);
8880 TEST_f_l (lrint, minus_zero, 0);
8881 TEST_f_l (lrint, 0.2L, 1);
8882 TEST_f_l (lrint, -0.2L, 0);
8883 TEST_f_l (lrint, 0.5L, 1);
8884 TEST_f_l (lrint, -0.5L, 0);
8885 TEST_f_l (lrint, 0.8L, 1);
8886 TEST_f_l (lrint, -0.8L, 0);
8887
8888 TEST_f_l (lrint, 1.4L, 2);
8889 TEST_f_l (lrint, -1.4L, -1);
8890
8891 TEST_f_l (lrint, 8388600.3L, 8388601);
8892 TEST_f_l (lrint, -8388600.3L, -8388600);
8893
8894#ifndef TEST_FLOAT
8895 TEST_f_l (lrint, 1071930.0008, 1071931);
8896 TEST_f_l (lrint, 1073741824.01, 1073741825);
8897# if LONG_MAX > 281474976710656 && defined (TEST_LDOUBLE)
89210b4c 8898 TEST_f_l (lrint, 281474976710656.025, 281474976710656);
6624dbc0
UD
8899# endif
8900#endif
8901 }
8902
8903 fesetround (save_round_mode);
8904
8905 END (lrint_upward);
8906}
8907
8908
8847214f
UD
8909static void
8910llrint_test (void)
8911{
8912 /* XXX this test is incomplete. We need to have a way to specifiy
8913 the rounding method and test the critical cases. So far, only
8914 unproblematic numbers are tested. */
64d063b8 8915 /* TODO: missing +/-Inf as well as qNaN tests. */
8847214f
UD
8916
8917 START (llrint);
8918
8919 TEST_f_L (llrint, 0.0, 0);
8920 TEST_f_L (llrint, minus_zero, 0);
3c6cad26
UD
8921 TEST_f_L (llrint, 0.2L, 0);
8922 TEST_f_L (llrint, -0.2L, 0);
8847214f 8923
3c6cad26
UD
8924 TEST_f_L (llrint, 1.4L, 1);
8925 TEST_f_L (llrint, -1.4L, -1);
8847214f 8926
3c6cad26
UD
8927 TEST_f_L (llrint, 8388600.3L, 8388600);
8928 TEST_f_L (llrint, -8388600.3L, -8388600);
8847214f 8929
3eb61415
UD
8930 TEST_f_l (llrint, 1071930.0008, 1071930);
8931
8847214f
UD
8932 /* Test boundary conditions. */
8933 /* 0x1FFFFF */
8934 TEST_f_L (llrint, 2097151.0,2097151LL);
8935 /* 0x800000 */
8936 TEST_f_L (llrint, 8388608.0, 8388608LL);
8937 /* 0x1000000 */
8938 TEST_f_L (llrint, 16777216.0, 16777216LL);
8939 /* 0x20000000000 */
8940 TEST_f_L (llrint, 2199023255552.0, 2199023255552LL);
8941 /* 0x40000000000 */
8942 TEST_f_L (llrint, 4398046511104.0, 4398046511104LL);
39007ae3
UD
8943 /* 0x1000000000000 */
8944 TEST_f_L (llrint, 281474976710656.0, 281474976710656LL);
8847214f
UD
8945 /* 0x10000000000000 */
8946 TEST_f_L (llrint, 4503599627370496.0, 4503599627370496LL);
8947 /* 0x10000080000000 */
8948 TEST_f_L (llrint, 4503601774854144.0, 4503601774854144LL);
8949 /* 0x20000000000000 */
8950 TEST_f_L (llrint, 9007199254740992.0, 9007199254740992LL);
8951 /* 0x80000000000000 */
8952 TEST_f_L (llrint, 36028797018963968.0, 36028797018963968LL);
8953 /* 0x100000000000000 */
8954 TEST_f_L (llrint, 72057594037927936.0, 72057594037927936LL);
f964490f
RM
8955#ifdef TEST_LDOUBLE
8956 /* The input can only be represented in long double. */
8957 TEST_f_L (llrint, 4503599627370495.5L, 4503599627370496LL);
8958 TEST_f_L (llrint, 4503599627370496.25L, 4503599627370496LL);
8959 TEST_f_L (llrint, 4503599627370496.5L, 4503599627370496LL);
8960 TEST_f_L (llrint, 4503599627370496.75L, 4503599627370497LL);
8961 TEST_f_L (llrint, 4503599627370497.5L, 4503599627370498LL);
8962
8963 TEST_f_L (llrint, -4503599627370495.5L, -4503599627370496LL);
8964 TEST_f_L (llrint, -4503599627370496.25L, -4503599627370496LL);
8965 TEST_f_L (llrint, -4503599627370496.5L, -4503599627370496LL);
8966 TEST_f_L (llrint, -4503599627370496.75L, -4503599627370497LL);
8967 TEST_f_L (llrint, -4503599627370497.5L, -4503599627370498LL);
8968
830fce04
RM
8969# if LDBL_MANT_DIG > 100
8970 TEST_f_L (llrint, 4503599627370495.4999999999999L, 4503599627370495LL);
8971 TEST_f_L (llrint, 4503599627370496.4999999999999L, 4503599627370496LL);
8972 TEST_f_L (llrint, 4503599627370497.4999999999999L, 4503599627370497LL);
8973 TEST_f_L (llrint, 4503599627370494.5000000000001L, 4503599627370495LL);
8974 TEST_f_L (llrint, 4503599627370495.5000000000001L, 4503599627370496LL);
8975 TEST_f_L (llrint, 4503599627370496.5000000000001L, 4503599627370497LL);
8976
8977 TEST_f_L (llrint, -4503599627370495.4999999999999L, -4503599627370495LL);
8978 TEST_f_L (llrint, -4503599627370496.4999999999999L, -4503599627370496LL);
8979 TEST_f_L (llrint, -4503599627370497.4999999999999L, -4503599627370497LL);
8980 TEST_f_L (llrint, -4503599627370494.5000000000001L, -4503599627370495LL);
8981 TEST_f_L (llrint, -4503599627370495.5000000000001L, -4503599627370496LL);
8982 TEST_f_L (llrint, -4503599627370496.5000000000001L, -4503599627370497LL);
8983#endif
8984
f964490f
RM
8985 TEST_f_L (llrint, 9007199254740991.5L, 9007199254740992LL);
8986 TEST_f_L (llrint, 9007199254740992.25L, 9007199254740992LL);
8987 TEST_f_L (llrint, 9007199254740992.5L, 9007199254740992LL);
8988 TEST_f_L (llrint, 9007199254740992.75L, 9007199254740993LL);
8989 TEST_f_L (llrint, 9007199254740993.5L, 9007199254740994LL);
8990
8991 TEST_f_L (llrint, -9007199254740991.5L, -9007199254740992LL);
8992 TEST_f_L (llrint, -9007199254740992.25L, -9007199254740992LL);
8993 TEST_f_L (llrint, -9007199254740992.5L, -9007199254740992LL);
8994 TEST_f_L (llrint, -9007199254740992.75L, -9007199254740993LL);
8995 TEST_f_L (llrint, -9007199254740993.5L, -9007199254740994LL);
8996
830fce04
RM
8997# if LDBL_MANT_DIG > 100
8998 TEST_f_L (llrint, 9007199254740991.4999999999999L, 9007199254740991LL);
8999 TEST_f_L (llrint, 9007199254740992.4999999999999L, 9007199254740992LL);
9000 TEST_f_L (llrint, 9007199254740993.4999999999999L, 9007199254740993LL);
9001 TEST_f_L (llrint, 9007199254740991.5000000000001L, 9007199254740992LL);
9002 TEST_f_L (llrint, 9007199254740992.5000000000001L, 9007199254740993LL);
9003 TEST_f_L (llrint, 9007199254740993.5000000000001L, 9007199254740994LL);
9004
9005 TEST_f_L (llrint, -9007199254740991.4999999999999L, -9007199254740991LL);
9006 TEST_f_L (llrint, -9007199254740992.4999999999999L, -9007199254740992LL);
9007 TEST_f_L (llrint, -9007199254740993.4999999999999L, -9007199254740993LL);
9008 TEST_f_L (llrint, -9007199254740991.5000000000001L, -9007199254740992LL);
9009 TEST_f_L (llrint, -9007199254740992.5000000000001L, -9007199254740993LL);
9010 TEST_f_L (llrint, -9007199254740993.5000000000001L, -9007199254740994LL);
9011#endif
9012
f964490f
RM
9013 TEST_f_L (llrint, 72057594037927935.5L, 72057594037927936LL);
9014 TEST_f_L (llrint, 72057594037927936.25L, 72057594037927936LL);
9015 TEST_f_L (llrint, 72057594037927936.5L, 72057594037927936LL);
9016 TEST_f_L (llrint, 72057594037927936.75L, 72057594037927937LL);
9017 TEST_f_L (llrint, 72057594037927937.5L, 72057594037927938LL);
9018
9019 TEST_f_L (llrint, -72057594037927935.5L, -72057594037927936LL);
9020 TEST_f_L (llrint, -72057594037927936.25L, -72057594037927936LL);
9021 TEST_f_L (llrint, -72057594037927936.5L, -72057594037927936LL);
9022 TEST_f_L (llrint, -72057594037927936.75L, -72057594037927937LL);
9023 TEST_f_L (llrint, -72057594037927937.5L, -72057594037927938LL);
830fce04
RM
9024
9025# if LDBL_MANT_DIG > 100
9026 TEST_f_L (llrint, 9223372036854775805.5L, 9223372036854775806LL);
9027 TEST_f_L (llrint, -9223372036854775805.5L, -9223372036854775806LL);
9028 TEST_f_L (llrint, 9223372036854775806.0L, 9223372036854775806LL);
9029 TEST_f_L (llrint, -9223372036854775806.0L, -9223372036854775806LL);
9030 TEST_f_L (llrint, 9223372036854775806.25L, 9223372036854775806LL);
9031 TEST_f_L (llrint, -9223372036854775806.25L, -9223372036854775806LL);
9032 TEST_f_L (llrint, 9223372036854775806.5L, 9223372036854775806L);
9033 TEST_f_L (llrint, -9223372036854775806.5L, -9223372036854775806LL);
9034 TEST_f_L (llrint, 9223372036854775806.75L, 9223372036854775807LL);
9035 TEST_f_L (llrint, -9223372036854775806.75L, -9223372036854775807LL);
9036 TEST_f_L (llrint, 9223372036854775807.0L, 9223372036854775807LL);
9037 TEST_f_L (llrint, -9223372036854775807.0L, -9223372036854775807LL);
9038# endif
f964490f 9039#endif
8847214f
UD
9040
9041 END (llrint);
9042}
9043
830fce04
RM
9044static void
9045llrint_test_tonearest (void)
9046{
9047 int save_round_mode;
9048 START (llrint_tonearest);
9049
9050 save_round_mode = fegetround ();
9051
9052 if (!fesetround (FE_TONEAREST))
9053 {
9054 TEST_f_L (llrint, 0.0, 0);
9055 TEST_f_L (llrint, minus_zero, 0);
9056 TEST_f_L (llrint, 0.2L, 0);
9057 TEST_f_L (llrint, -0.2L, 0);
9058
9059 TEST_f_L (llrint, 1.4L, 1);
9060 TEST_f_L (llrint, -1.4L, -1);
9061
9062 TEST_f_L (llrint, 8388600.3L, 8388600);
9063 TEST_f_L (llrint, -8388600.3L, -8388600);
9064
9065 TEST_f_l (llrint, 1071930.0008, 1071930);
9066
9067 /* Test boundary conditions. */
9068 /* 0x1FFFFF */
9069 TEST_f_L (llrint, 2097151.0,2097151LL);
9070 /* 0x800000 */
9071 TEST_f_L (llrint, 8388608.0, 8388608LL);
9072 /* 0x1000000 */
9073 TEST_f_L (llrint, 16777216.0, 16777216LL);
9074 /* 0x20000000000 */
9075 TEST_f_L (llrint, 2199023255552.0, 2199023255552LL);
9076 /* 0x40000000000 */
9077 TEST_f_L (llrint, 4398046511104.0, 4398046511104LL);
9078 /* 0x1000000000000 */
9079 TEST_f_L (llrint, 281474976710656.0, 281474976710656LL);
9080 /* 0x10000000000000 */
9081 TEST_f_L (llrint, 4503599627370496.0, 4503599627370496LL);
9082 /* 0x10000080000000 */
9083 TEST_f_L (llrint, 4503601774854144.0, 4503601774854144LL);
9084 /* 0x20000000000000 */
9085 TEST_f_L (llrint, 9007199254740992.0, 9007199254740992LL);
9086 /* 0x80000000000000 */
9087 TEST_f_L (llrint, 36028797018963968.0, 36028797018963968LL);
9088 /* 0x100000000000000 */
9089 TEST_f_L (llrint, 72057594037927936.0, 72057594037927936LL);
9090#ifdef TEST_LDOUBLE
9091 /* The input can only be represented in long double. */
9092 TEST_f_L (llrint, 4503599627370495.5L, 4503599627370496LL);
9093 TEST_f_L (llrint, 4503599627370496.25L, 4503599627370496LL);
9094 TEST_f_L (llrint, 4503599627370496.5L, 4503599627370496LL);
9095 TEST_f_L (llrint, 4503599627370496.75L, 4503599627370497LL);
9096 TEST_f_L (llrint, 4503599627370497.5L, 4503599627370498LL);
9097
9098 TEST_f_L (llrint, -4503599627370495.5L, -4503599627370496LL);
9099 TEST_f_L (llrint, -4503599627370496.25L, -4503599627370496LL);
9100 TEST_f_L (llrint, -4503599627370496.5L, -4503599627370496LL);
9101 TEST_f_L (llrint, -4503599627370496.75L, -4503599627370497LL);
9102 TEST_f_L (llrint, -4503599627370497.5L, -4503599627370498LL);
9103
9104# if LDBL_MANT_DIG > 100
9105 TEST_f_L (llrint, 4503599627370495.4999999999999L, 4503599627370495LL);
9106 TEST_f_L (llrint, 4503599627370496.4999999999999L, 4503599627370496LL);
9107 TEST_f_L (llrint, 4503599627370497.4999999999999L, 4503599627370497LL);
9108 TEST_f_L (llrint, 4503599627370494.5000000000001L, 4503599627370495LL);
9109 TEST_f_L (llrint, 4503599627370495.5000000000001L, 4503599627370496LL);
9110 TEST_f_L (llrint, 4503599627370496.5000000000001L, 4503599627370497LL);
9111
9112 TEST_f_L (llrint, -4503599627370495.4999999999999L, -4503599627370495LL);
9113 TEST_f_L (llrint, -4503599627370496.4999999999999L, -4503599627370496LL);
9114 TEST_f_L (llrint, -4503599627370497.4999999999999L, -4503599627370497LL);
9115 TEST_f_L (llrint, -4503599627370494.5000000000001L, -4503599627370495LL);
9116 TEST_f_L (llrint, -4503599627370495.5000000000001L, -4503599627370496LL);
9117 TEST_f_L (llrint, -4503599627370496.5000000000001L, -4503599627370497LL);
9118#endif
9119
9120 TEST_f_L (llrint, 9007199254740991.5L, 9007199254740992LL);
9121 TEST_f_L (llrint, 9007199254740992.25L, 9007199254740992LL);
9122 TEST_f_L (llrint, 9007199254740992.5L, 9007199254740992LL);
9123 TEST_f_L (llrint, 9007199254740992.75L, 9007199254740993LL);
9124 TEST_f_L (llrint, 9007199254740993.5L, 9007199254740994LL);
9125
9126 TEST_f_L (llrint, -9007199254740991.5L, -9007199254740992LL);
9127 TEST_f_L (llrint, -9007199254740992.25L, -9007199254740992LL);
9128 TEST_f_L (llrint, -9007199254740992.5L, -9007199254740992LL);
9129 TEST_f_L (llrint, -9007199254740992.75L, -9007199254740993LL);
9130 TEST_f_L (llrint, -9007199254740993.5L, -9007199254740994LL);
9131
9132# if LDBL_MANT_DIG > 100
9133 TEST_f_L (llrint, 9007199254740991.4999999999999L, 9007199254740991LL);
9134 TEST_f_L (llrint, 9007199254740992.4999999999999L, 9007199254740992LL);
9135 TEST_f_L (llrint, 9007199254740993.4999999999999L, 9007199254740993LL);
9136 TEST_f_L (llrint, 9007199254740991.5000000000001L, 9007199254740992LL);
9137 TEST_f_L (llrint, 9007199254740992.5000000000001L, 9007199254740993LL);
9138 TEST_f_L (llrint, 9007199254740993.5000000000001L, 9007199254740994LL);
9139
9140 TEST_f_L (llrint, -9007199254740991.4999999999999L, -9007199254740991LL);
9141 TEST_f_L (llrint, -9007199254740992.4999999999999L, -9007199254740992LL);
9142 TEST_f_L (llrint, -9007199254740993.4999999999999L, -9007199254740993LL);
9143 TEST_f_L (llrint, -9007199254740991.5000000000001L, -9007199254740992LL);
9144 TEST_f_L (llrint, -9007199254740992.5000000000001L, -9007199254740993LL);
9145 TEST_f_L (llrint, -9007199254740993.5000000000001L, -9007199254740994LL);
9146#endif
9147
9148 TEST_f_L (llrint, 72057594037927935.5L, 72057594037927936LL);
9149 TEST_f_L (llrint, 72057594037927936.25L, 72057594037927936LL);
9150 TEST_f_L (llrint, 72057594037927936.5L, 72057594037927936LL);
9151 TEST_f_L (llrint, 72057594037927936.75L, 72057594037927937LL);
9152 TEST_f_L (llrint, 72057594037927937.5L, 72057594037927938LL);
9153
9154 TEST_f_L (llrint, -72057594037927935.5L, -72057594037927936LL);
9155 TEST_f_L (llrint, -72057594037927936.25L, -72057594037927936LL);
9156 TEST_f_L (llrint, -72057594037927936.5L, -72057594037927936LL);
9157 TEST_f_L (llrint, -72057594037927936.75L, -72057594037927937LL);
9158 TEST_f_L (llrint, -72057594037927937.5L, -72057594037927938LL);
9159
9160# if LDBL_MANT_DIG > 100
9161 TEST_f_L (llrint, 9223372036854775805.5L, 9223372036854775806LL);
9162 TEST_f_L (llrint, -9223372036854775805.5L, -9223372036854775806LL);
9163 TEST_f_L (llrint, 9223372036854775806.0L, 9223372036854775806LL);
9164 TEST_f_L (llrint, -9223372036854775806.0L, -9223372036854775806LL);
9165 TEST_f_L (llrint, 9223372036854775806.25L, 9223372036854775806LL);
9166 TEST_f_L (llrint, -9223372036854775806.25L, -9223372036854775806LL);
9167 TEST_f_L (llrint, 9223372036854775806.5L, 9223372036854775806L);
9168 TEST_f_L (llrint, -9223372036854775806.5L, -9223372036854775806LL);
9169 TEST_f_L (llrint, 9223372036854775806.75L, 9223372036854775807LL);
9170 TEST_f_L (llrint, -9223372036854775806.75L, -9223372036854775807LL);
9171 TEST_f_L (llrint, 9223372036854775807.0L, 9223372036854775807LL);
9172 TEST_f_L (llrint, -9223372036854775807.0L, -9223372036854775807LL);
9173# endif
9174#endif
9175 }
9176
9177 fesetround (save_round_mode);
9178
9179 END (llrint_tonearest);
9180}
9181
9182static void
9183llrint_test_towardzero (void)
9184{
9185 int save_round_mode;
9186 START (llrint_towardzero);
9187
9188 save_round_mode = fegetround ();
9189
9190 if (!fesetround (FE_TOWARDZERO))
9191 {
9192 TEST_f_L (llrint, 0.0, 0);
9193 TEST_f_L (llrint, minus_zero, 0);
9194 TEST_f_L (llrint, 0.2L, 0);
9195 TEST_f_L (llrint, -0.2L, 0);
9196
9197 TEST_f_L (llrint, 1.4L, 1);
9198 TEST_f_L (llrint, -1.4L, -1);
9199
9200 TEST_f_L (llrint, 8388600.3L, 8388600);
9201 TEST_f_L (llrint, -8388600.3L, -8388600);
9202
9203 TEST_f_l (llrint, 1071930.0008, 1071930);
9204
9205 /* Test boundary conditions. */
9206 /* 0x1FFFFF */
9207 TEST_f_L (llrint, 2097151.0,2097151LL);
9208 /* 0x800000 */
9209 TEST_f_L (llrint, 8388608.0, 8388608LL);
9210 /* 0x1000000 */
9211 TEST_f_L (llrint, 16777216.0, 16777216LL);
9212 /* 0x20000000000 */
9213 TEST_f_L (llrint, 2199023255552.0, 2199023255552LL);
9214 /* 0x40000000000 */
9215 TEST_f_L (llrint, 4398046511104.0, 4398046511104LL);
9216 /* 0x1000000000000 */
9217 TEST_f_L (llrint, 281474976710656.0, 281474976710656LL);
9218 /* 0x10000000000000 */
9219 TEST_f_L (llrint, 4503599627370496.0, 4503599627370496LL);
9220 /* 0x10000080000000 */
9221 TEST_f_L (llrint, 4503601774854144.0, 4503601774854144LL);
9222 /* 0x20000000000000 */
9223 TEST_f_L (llrint, 9007199254740992.0, 9007199254740992LL);
9224 /* 0x80000000000000 */
9225 TEST_f_L (llrint, 36028797018963968.0, 36028797018963968LL);
9226 /* 0x100000000000000 */
9227 TEST_f_L (llrint, 72057594037927936.0, 72057594037927936LL);
9228#ifdef TEST_LDOUBLE
9229 /* The input can only be represented in long double. */
9230 TEST_f_L (llrint, 4503599627370495.5L, 4503599627370495LL);
9231 TEST_f_L (llrint, 4503599627370496.25L, 4503599627370496LL);
9232 TEST_f_L (llrint, 4503599627370496.5L, 4503599627370496LL);
9233 TEST_f_L (llrint, 4503599627370496.75L, 4503599627370496LL);
9234 TEST_f_L (llrint, 4503599627370497.5L, 4503599627370497LL);
9235
9236 TEST_f_L (llrint, -4503599627370495.5L, -4503599627370495LL);
9237 TEST_f_L (llrint, -4503599627370496.25L, -4503599627370496LL);
9238 TEST_f_L (llrint, -4503599627370496.5L, -4503599627370496LL);
9239 TEST_f_L (llrint, -4503599627370496.75L, -4503599627370496LL);
9240 TEST_f_L (llrint, -4503599627370497.5L, -4503599627370497LL);
9241
9242# if LDBL_MANT_DIG > 100
9243 TEST_f_L (llrint, 4503599627370495.4999999999999L, 4503599627370495LL);
9244 TEST_f_L (llrint, 4503599627370496.4999999999999L, 4503599627370496LL);
9245 TEST_f_L (llrint, 4503599627370497.4999999999999L, 4503599627370497LL);
9246 TEST_f_L (llrint, 4503599627370494.5000000000001L, 4503599627370494LL);
9247 TEST_f_L (llrint, 4503599627370495.5000000000001L, 4503599627370495LL);
9248 TEST_f_L (llrint, 4503599627370496.5000000000001L, 4503599627370496LL);
9249
9250 TEST_f_L (llrint, -4503599627370495.4999999999999L, -4503599627370495LL);
9251 TEST_f_L (llrint, -4503599627370496.4999999999999L, -4503599627370496LL);
9252 TEST_f_L (llrint, -4503599627370497.4999999999999L, -4503599627370497LL);
9253 TEST_f_L (llrint, -4503599627370494.5000000000001L, -4503599627370494LL);
9254 TEST_f_L (llrint, -4503599627370495.5000000000001L, -4503599627370495LL);
9255 TEST_f_L (llrint, -4503599627370496.5000000000001L, -4503599627370496LL);
9256#endif
9257
9258 TEST_f_L (llrint, 9007199254740991.5L, 9007199254740991LL);
9259 TEST_f_L (llrint, 9007199254740992.25L, 9007199254740992LL);
9260 TEST_f_L (llrint, 9007199254740992.5L, 9007199254740992LL);
9261 TEST_f_L (llrint, 9007199254740992.75L, 9007199254740992LL);
9262 TEST_f_L (llrint, 9007199254740993.5L, 9007199254740993LL);
9263
9264 TEST_f_L (llrint, -9007199254740991.5L, -9007199254740991LL);
9265 TEST_f_L (llrint, -9007199254740992.25L, -9007199254740992LL);
9266 TEST_f_L (llrint, -9007199254740992.5L, -9007199254740992LL);
9267 TEST_f_L (llrint, -9007199254740992.75L, -9007199254740992LL);
9268 TEST_f_L (llrint, -9007199254740993.5L, -9007199254740993LL);
9269
9270# if LDBL_MANT_DIG > 100
9271 TEST_f_L (llrint, 9007199254740991.4999999999999L, 9007199254740991LL);
9272 TEST_f_L (llrint, 9007199254740992.4999999999999L, 9007199254740992LL);
9273 TEST_f_L (llrint, 9007199254740993.4999999999999L, 9007199254740993LL);
9274 TEST_f_L (llrint, 9007199254740991.5000000000001L, 9007199254740991LL);
9275 TEST_f_L (llrint, 9007199254740992.5000000000001L, 9007199254740992LL);
9276 TEST_f_L (llrint, 9007199254740993.5000000000001L, 9007199254740993LL);
9277
9278 TEST_f_L (llrint, -9007199254740991.4999999999999L, -9007199254740991LL);
9279 TEST_f_L (llrint, -9007199254740992.4999999999999L, -9007199254740992LL);
9280 TEST_f_L (llrint, -9007199254740993.4999999999999L, -9007199254740993LL);
9281 TEST_f_L (llrint, -9007199254740991.5000000000001L, -9007199254740991LL);
9282 TEST_f_L (llrint, -9007199254740992.5000000000001L, -9007199254740992LL);
9283 TEST_f_L (llrint, -9007199254740993.5000000000001L, -9007199254740993LL);
9284#endif
9285
9286 TEST_f_L (llrint, 72057594037927935.5L, 72057594037927935LL);
9287 TEST_f_L (llrint, 72057594037927936.25L, 72057594037927936LL);
9288 TEST_f_L (llrint, 72057594037927936.5L, 72057594037927936LL);
9289 TEST_f_L (llrint, 72057594037927936.75L, 72057594037927936LL);
9290 TEST_f_L (llrint, 72057594037927937.5L, 72057594037927937LL);
9291
9292 TEST_f_L (llrint, -72057594037927935.5L, -72057594037927935LL);
9293 TEST_f_L (llrint, -72057594037927936.25L, -72057594037927936LL);
9294 TEST_f_L (llrint, -72057594037927936.5L, -72057594037927936LL);
9295 TEST_f_L (llrint, -72057594037927936.75L, -72057594037927936LL);
9296 TEST_f_L (llrint, -72057594037927937.5L, -72057594037927937LL);
9297
9298# if LDBL_MANT_DIG > 100
9299 TEST_f_L (llrint, 9223372036854775805.5L, 9223372036854775805LL);
9300 TEST_f_L (llrint, -9223372036854775805.5L, -9223372036854775805LL);
9301 TEST_f_L (llrint, 9223372036854775806.0L, 9223372036854775806LL);
9302 TEST_f_L (llrint, -9223372036854775806.0L, -9223372036854775806LL);
9303 TEST_f_L (llrint, 9223372036854775806.25L, 9223372036854775806LL);
9304 TEST_f_L (llrint, -9223372036854775806.25L, -9223372036854775806LL);
9305 TEST_f_L (llrint, 9223372036854775806.5L, 9223372036854775806L);
9306 TEST_f_L (llrint, -9223372036854775806.5L, -9223372036854775806LL);
9307 TEST_f_L (llrint, 9223372036854775806.75L, 9223372036854775806LL);
9308 TEST_f_L (llrint, -9223372036854775806.75L, -9223372036854775806LL);
9309 TEST_f_L (llrint, 9223372036854775807.0L, 9223372036854775807LL);
9310 TEST_f_L (llrint, -9223372036854775807.0L, -9223372036854775807LL);
9311# endif
9312#endif
9313 }
9314
9315 fesetround (save_round_mode);
9316
9317 END (llrint_towardzero);
9318}
9319
9320static void
9321llrint_test_downward (void)
9322{
9323 int save_round_mode;
9324 START (llrint_downward);
9325
9326 save_round_mode = fegetround ();
9327
9328 if (!fesetround (FE_DOWNWARD))
9329 {
9330 TEST_f_L (llrint, 0.0, 0);
9331 TEST_f_L (llrint, minus_zero, 0);
9332 TEST_f_L (llrint, 0.2L, 0);
9333 TEST_f_L (llrint, -0.2L, -1);
9334
9335 TEST_f_L (llrint, 1.4L, 1);
9336 TEST_f_L (llrint, -1.4L, -2);
9337
9338 TEST_f_L (llrint, 8388600.3L, 8388600);
9339 TEST_f_L (llrint, -8388600.3L, -8388601);
9340
9341 TEST_f_l (llrint, 1071930.0008, 1071930);
9342
9343 /* Test boundary conditions. */
9344 /* 0x1FFFFF */
9345 TEST_f_L (llrint, 2097151.0,2097151LL);
9346 /* 0x800000 */
9347 TEST_f_L (llrint, 8388608.0, 8388608LL);
9348 /* 0x1000000 */
9349 TEST_f_L (llrint, 16777216.0, 16777216LL);
9350 /* 0x20000000000 */
9351 TEST_f_L (llrint, 2199023255552.0, 2199023255552LL);
9352 /* 0x40000000000 */
9353 TEST_f_L (llrint, 4398046511104.0, 4398046511104LL);
9354 /* 0x1000000000000 */
9355 TEST_f_L (llrint, 281474976710656.0, 281474976710656LL);
9356 /* 0x10000000000000 */
9357 TEST_f_L (llrint, 4503599627370496.0, 4503599627370496LL);
9358 /* 0x10000080000000 */
9359 TEST_f_L (llrint, 4503601774854144.0, 4503601774854144LL);
9360 /* 0x20000000000000 */
9361 TEST_f_L (llrint, 9007199254740992.0, 9007199254740992LL);
9362 /* 0x80000000000000 */
9363 TEST_f_L (llrint, 36028797018963968.0, 36028797018963968LL);
9364 /* 0x100000000000000 */
9365 TEST_f_L (llrint, 72057594037927936.0, 72057594037927936LL);
9366#ifdef TEST_LDOUBLE
9367 /* The input can only be represented in long double. */
9368 TEST_f_L (llrint, 4503599627370495.5L, 4503599627370495LL);
9369 TEST_f_L (llrint, 4503599627370496.25L, 4503599627370496LL);
9370 TEST_f_L (llrint, 4503599627370496.5L, 4503599627370496LL);
9371 TEST_f_L (llrint, 4503599627370496.75L, 4503599627370496LL);
9372 TEST_f_L (llrint, 4503599627370497.5L, 4503599627370497LL);
9373
9374 TEST_f_L (llrint, 4503599627370495.4999999999999L, 4503599627370495LL);
9375 TEST_f_L (llrint, 4503599627370496.4999999999999L, 4503599627370496LL);
9376 TEST_f_L (llrint, 4503599627370497.4999999999999L, 4503599627370497LL);
9377 TEST_f_L (llrint, 4503599627370494.5000000000001L, 4503599627370494LL);
9378 TEST_f_L (llrint, 4503599627370495.5000000000001L, 4503599627370495LL);
9379 TEST_f_L (llrint, 4503599627370496.5000000000001L, 4503599627370496LL);
9380
9381 TEST_f_L (llrint, -4503599627370495.5L, -4503599627370496LL);
9382 TEST_f_L (llrint, -4503599627370496.25L, -4503599627370497LL);
9383 TEST_f_L (llrint, -4503599627370496.5L, -4503599627370497LL);
9384 TEST_f_L (llrint, -4503599627370496.75L, -4503599627370497LL);
9385 TEST_f_L (llrint, -4503599627370497.5L, -4503599627370498LL);
9386
9387 TEST_f_L (llrint, -4503599627370495.4999999999999L, -4503599627370496LL);
9388 TEST_f_L (llrint, -4503599627370496.4999999999999L, -4503599627370497LL);
9389 TEST_f_L (llrint, -4503599627370497.4999999999999L, -4503599627370498LL);
9390 TEST_f_L (llrint, -4503599627370494.5000000000001L, -4503599627370495LL);
9391 TEST_f_L (llrint, -4503599627370495.5000000000001L, -4503599627370496LL);
9392 TEST_f_L (llrint, -4503599627370496.5000000000001L, -4503599627370497LL);
9393
9394 TEST_f_L (llrint, 9007199254740991.5L, 9007199254740991LL);
9395 TEST_f_L (llrint, 9007199254740992.25L, 9007199254740992LL);
9396 TEST_f_L (llrint, 9007199254740992.5L, 9007199254740992LL);
9397 TEST_f_L (llrint, 9007199254740992.75L, 9007199254740992LL);
9398 TEST_f_L (llrint, 9007199254740993.5L, 9007199254740993LL);
9399
9400 TEST_f_L (llrint, 9007199254740991.4999999999999L, 9007199254740991LL);
9401 TEST_f_L (llrint, 9007199254740992.4999999999999L, 9007199254740992LL);
9402 TEST_f_L (llrint, 9007199254740993.4999999999999L, 9007199254740993LL);
9403 TEST_f_L (llrint, 9007199254740991.5000000000001L, 9007199254740991LL);
9404 TEST_f_L (llrint, 9007199254740992.5000000000001L, 9007199254740992LL);
9405 TEST_f_L (llrint, 9007199254740993.5000000000001L, 9007199254740993LL);
9406
9407 TEST_f_L (llrint, -9007199254740991.5L, -9007199254740992LL);
9408 TEST_f_L (llrint, -9007199254740992.25L, -9007199254740993LL);
9409 TEST_f_L (llrint, -9007199254740992.5L, -9007199254740993LL);
9410 TEST_f_L (llrint, -9007199254740992.75L, -9007199254740993LL);
9411 TEST_f_L (llrint, -9007199254740993.5L, -9007199254740994LL);
9412
9413 TEST_f_L (llrint, -9007199254740991.4999999999999L, -9007199254740992LL);
9414 TEST_f_L (llrint, -9007199254740992.4999999999999L, -9007199254740993LL);
9415 TEST_f_L (llrint, -9007199254740993.4999999999999L, -9007199254740994LL);
9416 TEST_f_L (llrint, -9007199254740991.5000000000001L, -9007199254740992LL);
9417 TEST_f_L (llrint, -9007199254740992.5000000000001L, -9007199254740993LL);
9418 TEST_f_L (llrint, -9007199254740993.5000000000001L, -9007199254740994LL);
9419
9420 TEST_f_L (llrint, 72057594037927935.5L, 72057594037927935LL);
9421 TEST_f_L (llrint, 72057594037927936.25L, 72057594037927936LL);
9422 TEST_f_L (llrint, 72057594037927936.5L, 72057594037927936LL);
9423 TEST_f_L (llrint, 72057594037927936.75L, 72057594037927936LL);
9424 TEST_f_L (llrint, 72057594037927937.5L, 72057594037927937LL);
9425
9426 TEST_f_L (llrint, -72057594037927935.5L, -72057594037927936LL);
9427 TEST_f_L (llrint, -72057594037927936.25L, -72057594037927937LL);
9428 TEST_f_L (llrint, -72057594037927936.5L, -72057594037927937LL);
9429 TEST_f_L (llrint, -72057594037927936.75L, -72057594037927937LL);
9430 TEST_f_L (llrint, -72057594037927937.5L, -72057594037927938LL);
9431
9432# if LDBL_MANT_DIG > 100
9433 TEST_f_L (llrint, 9223372036854775805.5L, 9223372036854775805LL);
9434 TEST_f_L (llrint, -9223372036854775805.5L, -9223372036854775806LL);
9435 TEST_f_L (llrint, 9223372036854775806.0L, 9223372036854775806LL);
9436 TEST_f_L (llrint, -9223372036854775806.0L, -9223372036854775806LL);
9437 TEST_f_L (llrint, 9223372036854775806.25L, 9223372036854775806LL);
9438 TEST_f_L (llrint, -9223372036854775806.25L, -9223372036854775807LL);
9439 TEST_f_L (llrint, 9223372036854775806.5L, 9223372036854775806L);
9440 TEST_f_L (llrint, -9223372036854775806.5L, -9223372036854775807LL);
9441 TEST_f_L (llrint, 9223372036854775806.75L, 9223372036854775806LL);
9442 TEST_f_L (llrint, -9223372036854775806.75L, -9223372036854775807LL);
9443 TEST_f_L (llrint, 9223372036854775807.0L, 9223372036854775807LL);
9444 TEST_f_L (llrint, -9223372036854775807.0L, -9223372036854775807LL);
9445# endif
9446#endif
9447 }
9448
9449 fesetround (save_round_mode);
9450
9451 END (llrint_downward);
9452}
9453
9454static void
9455llrint_test_upward (void)
9456{
9457 int save_round_mode;
9458 START (llrint_upward);
9459
9460 save_round_mode = fegetround ();
9461
9462 if (!fesetround (FE_UPWARD))
9463 {
9464 TEST_f_L (llrint, 0.0, 0);
9465 TEST_f_L (llrint, minus_zero, 0);
9466 TEST_f_L (llrint, 0.2L, 1);
9467 TEST_f_L (llrint, -0.2L, 0);
9468
9469 TEST_f_L (llrint, 1.4L, 2);
9470 TEST_f_L (llrint, -1.4L, -1);
9471
9472 TEST_f_L (llrint, 8388600.3L, 8388601);
9473 TEST_f_L (llrint, -8388600.3L, -8388600);
9474#ifndef TEST_FLOAT
9475 TEST_f_l (llrint, 1071930.0008, 1071931);
9476#endif
9477 /* Test boundary conditions. */
9478 /* 0x1FFFFF */
9479 TEST_f_L (llrint, 2097151.0,2097151LL);
9480 /* 0x800000 */
9481 TEST_f_L (llrint, 8388608.0, 8388608LL);
9482 /* 0x1000000 */
9483 TEST_f_L (llrint, 16777216.0, 16777216LL);
9484 /* 0x20000000000 */
9485 TEST_f_L (llrint, 2199023255552.0, 2199023255552LL);
9486 /* 0x40000000000 */
9487 TEST_f_L (llrint, 4398046511104.0, 4398046511104LL);
9488 /* 0x1000000000000 */
9489 TEST_f_L (llrint, 281474976710656.0, 281474976710656LL);
9490 /* 0x10000000000000 */
9491 TEST_f_L (llrint, 4503599627370496.0, 4503599627370496LL);
9492 /* 0x10000080000000 */
9493 TEST_f_L (llrint, 4503601774854144.0, 4503601774854144LL);
9494 /* 0x20000000000000 */
9495 TEST_f_L (llrint, 9007199254740992.0, 9007199254740992LL);
9496 /* 0x80000000000000 */
9497 TEST_f_L (llrint, 36028797018963968.0, 36028797018963968LL);
9498 /* 0x100000000000000 */
9499 TEST_f_L (llrint, 72057594037927936.0, 72057594037927936LL);
9500#ifdef TEST_LDOUBLE
9501 /* The input can only be represented in long double. */
9502 TEST_f_L (llrint, 4503599627370495.5L, 4503599627370496LL);
9503 TEST_f_L (llrint, 4503599627370496.25L, 4503599627370497LL);
9504 TEST_f_L (llrint, 4503599627370496.5L, 4503599627370497LL);
9505 TEST_f_L (llrint, 4503599627370496.75L, 4503599627370497LL);
9506 TEST_f_L (llrint, 4503599627370497.5L, 4503599627370498LL);
9507
9508 TEST_f_L (llrint, 4503599627370495.4999999999999L, 4503599627370496LL);
9509 TEST_f_L (llrint, 4503599627370496.4999999999999L, 4503599627370497LL);
9510 TEST_f_L (llrint, 4503599627370497.4999999999999L, 4503599627370498LL);
9511 TEST_f_L (llrint, 4503599627370494.5000000000001L, 4503599627370495LL);
9512 TEST_f_L (llrint, 4503599627370495.5000000000001L, 4503599627370496LL);
9513 TEST_f_L (llrint, 4503599627370496.5000000000001L, 4503599627370497LL);
9514
9515 TEST_f_L (llrint, -4503599627370495.5L, -4503599627370495LL);
9516 TEST_f_L (llrint, -4503599627370496.25L, -4503599627370496LL);
9517 TEST_f_L (llrint, -4503599627370496.5L, -4503599627370496LL);
9518 TEST_f_L (llrint, -4503599627370496.75L, -4503599627370496LL);
9519 TEST_f_L (llrint, -4503599627370497.5L, -4503599627370497LL);
9520
9521 TEST_f_L (llrint, -4503599627370495.4999999999999L, -4503599627370495LL);
9522 TEST_f_L (llrint, -4503599627370496.4999999999999L, -4503599627370496LL);
9523 TEST_f_L (llrint, -4503599627370497.4999999999999L, -4503599627370497LL);
9524 TEST_f_L (llrint, -4503599627370494.5000000000001L, -4503599627370494LL);
9525 TEST_f_L (llrint, -4503599627370495.5000000000001L, -4503599627370495LL);
9526 TEST_f_L (llrint, -4503599627370496.5000000000001L, -4503599627370496LL);
9527
9528 TEST_f_L (llrint, 9007199254740991.5L, 9007199254740992LL);
9529 TEST_f_L (llrint, 9007199254740992.25L, 9007199254740993LL);
9530 TEST_f_L (llrint, 9007199254740992.5L, 9007199254740993LL);
9531 TEST_f_L (llrint, 9007199254740992.75L, 9007199254740993LL);
9532 TEST_f_L (llrint, 9007199254740993.5L, 9007199254740994LL);
9533
9534 TEST_f_L (llrint, 9007199254740991.4999999999999L, 9007199254740992LL);
9535 TEST_f_L (llrint, 9007199254740992.4999999999999L, 9007199254740993LL);
9536 TEST_f_L (llrint, 9007199254740993.4999999999999L, 9007199254740994LL);
9537 TEST_f_L (llrint, 9007199254740991.5000000000001L, 9007199254740992LL);
9538 TEST_f_L (llrint, 9007199254740992.5000000000001L, 9007199254740993LL);
9539 TEST_f_L (llrint, 9007199254740993.5000000000001L, 9007199254740994LL);
9540
9541 TEST_f_L (llrint, -9007199254740991.5L, -9007199254740991LL);
9542 TEST_f_L (llrint, -9007199254740992.25L, -9007199254740992LL);
9543 TEST_f_L (llrint, -9007199254740992.5L, -9007199254740992LL);
9544 TEST_f_L (llrint, -9007199254740992.75L, -9007199254740992LL);
9545 TEST_f_L (llrint, -9007199254740993.5L, -9007199254740993LL);
9546
9547 TEST_f_L (llrint, -9007199254740991.4999999999999L, -9007199254740991LL);
9548 TEST_f_L (llrint, -9007199254740992.4999999999999L, -9007199254740992LL);
9549 TEST_f_L (llrint, -9007199254740993.4999999999999L, -9007199254740993LL);
9550 TEST_f_L (llrint, -9007199254740991.5000000000001L, -9007199254740991LL);
9551 TEST_f_L (llrint, -9007199254740992.5000000000001L, -9007199254740992LL);
9552 TEST_f_L (llrint, -9007199254740993.5000000000001L, -9007199254740993LL);
9553
9554 TEST_f_L (llrint, 72057594037927935.5L, 72057594037927936LL);
9555 TEST_f_L (llrint, 72057594037927936.25L, 72057594037927937LL);
9556 TEST_f_L (llrint, 72057594037927936.5L, 72057594037927937LL);
9557 TEST_f_L (llrint, 72057594037927936.75L, 72057594037927937LL);
9558 TEST_f_L (llrint, 72057594037927937.5L, 72057594037927938LL);
9559
9560 TEST_f_L (llrint, -72057594037927935.5L, -72057594037927935LL);
9561 TEST_f_L (llrint, -72057594037927936.25L, -72057594037927936LL);
9562 TEST_f_L (llrint, -72057594037927936.5L, -72057594037927936LL);
9563 TEST_f_L (llrint, -72057594037927936.75L, -72057594037927936LL);
9564 TEST_f_L (llrint, -72057594037927937.5L, -72057594037927937LL);
9565
9566# if LDBL_MANT_DIG > 100
9567 TEST_f_L (llrint, 9223372036854775805.5L, 9223372036854775806LL);
9568 TEST_f_L (llrint, -9223372036854775805.5L, -9223372036854775805LL);
9569 TEST_f_L (llrint, 9223372036854775806.0L, 9223372036854775806LL);
9570 TEST_f_L (llrint, -9223372036854775806.0L, -9223372036854775806LL);
9571 TEST_f_L (llrint, 9223372036854775806.25L, 9223372036854775807LL);
9572 TEST_f_L (llrint, -9223372036854775806.25L, -9223372036854775806LL);
9573 TEST_f_L (llrint, 9223372036854775806.5L, 9223372036854775807L);
9574 TEST_f_L (llrint, -9223372036854775806.5L, -9223372036854775806LL);
9575 TEST_f_L (llrint, 9223372036854775806.75L, 9223372036854775807LL);
9576 TEST_f_L (llrint, -9223372036854775806.75L, -9223372036854775806LL);
9577 TEST_f_L (llrint, 9223372036854775807.0L, 9223372036854775807LL);
9578 TEST_f_L (llrint, -9223372036854775807.0L, -9223372036854775807LL);
9579# endif
9580#endif
9581 }
9582
9583 fesetround (save_round_mode);
9584
9585 END (llrint_upward);
9586}
9587
2550dfe9 9588
8847214f
UD
9589static void
9590log_test (void)
9591{
e6d3c4a7
AJ
9592 errno = 0;
9593 FUNC(log) (1);
9594 if (errno == ENOSYS)
9595 /* Function not implemented. */
9596 return;
8847214f
UD
9597 START (log);
9598
9599 TEST_f_f (log, 0, minus_infty, DIVIDE_BY_ZERO_EXCEPTION);
9600 TEST_f_f (log, minus_zero, minus_infty, DIVIDE_BY_ZERO_EXCEPTION);
9601
9602 TEST_f_f (log, 1, 0);
9603
67e971f1
TS
9604 TEST_f_f (log, -1, qnan_value, INVALID_EXCEPTION);
9605 TEST_f_f (log, -max_value, qnan_value, INVALID_EXCEPTION);
9606 TEST_f_f (log, minus_infty, qnan_value, INVALID_EXCEPTION);
8847214f 9607 TEST_f_f (log, plus_infty, plus_infty);
67e971f1 9608 TEST_f_f (log, qnan_value, qnan_value);
8847214f
UD
9609
9610 TEST_f_f (log, M_El, 1);
9611 TEST_f_f (log, 1.0 / M_El, -1);
9612 TEST_f_f (log, 2, M_LN2l);
9613 TEST_f_f (log, 10, M_LN10l);
2550dfe9 9614 TEST_f_f (log, 0.75L, -0.287682072451780927439219005993827432L);
8847214f
UD
9615
9616 END (log);
9617}
9618
9619
9620static void
9621log10_test (void)
9622{
e6d3c4a7
AJ
9623 errno = 0;
9624 FUNC(log10) (1);
9625 if (errno == ENOSYS)
9626 /* Function not implemented. */
9627 return;
9628
8847214f
UD
9629 START (log10);
9630
9631 TEST_f_f (log10, 0, minus_infty, DIVIDE_BY_ZERO_EXCEPTION);
9632 TEST_f_f (log10, minus_zero, minus_infty, DIVIDE_BY_ZERO_EXCEPTION);
9633
9634 TEST_f_f (log10, 1, 0);
9635
67e971f1
TS
9636 /* log10 (x) == qNaN plus invalid exception if x < 0. */
9637 TEST_f_f (log10, -1, qnan_value, INVALID_EXCEPTION);
9638 TEST_f_f (log10, -max_value, qnan_value, INVALID_EXCEPTION);
9639 TEST_f_f (log10, minus_infty, qnan_value, INVALID_EXCEPTION);
8847214f
UD
9640
9641 TEST_f_f (log10, plus_infty, plus_infty);
67e971f1 9642 TEST_f_f (log10, qnan_value, qnan_value);
8847214f
UD
9643
9644 TEST_f_f (log10, 0.1L, -1);
9645 TEST_f_f (log10, 10.0, 1);
9646 TEST_f_f (log10, 100.0, 2);
9647 TEST_f_f (log10, 10000.0, 4);
9648 TEST_f_f (log10, M_El, M_LOG10El);
2550dfe9 9649 TEST_f_f (log10, 0.75L, -0.124938736608299953132449886193870744L);
8847214f
UD
9650
9651 END (log10);
9652}
9653
9654
9655static void
9656log1p_test (void)
9657{
e6d3c4a7
AJ
9658 errno = 0;
9659 FUNC(log1p) (0);
9660 if (errno == ENOSYS)
9661 /* Function not implemented. */
9662 return;
9663
8847214f
UD
9664 START (log1p);
9665
9666 TEST_f_f (log1p, 0, 0);
9667 TEST_f_f (log1p, minus_zero, minus_zero);
9668
9669 TEST_f_f (log1p, -1, minus_infty, DIVIDE_BY_ZERO_EXCEPTION);
67e971f1
TS
9670 TEST_f_f (log1p, -2, qnan_value, INVALID_EXCEPTION);
9671 TEST_f_f (log1p, -max_value, qnan_value, INVALID_EXCEPTION);
9672 TEST_f_f (log1p, minus_infty, qnan_value, INVALID_EXCEPTION);
8847214f
UD
9673
9674 TEST_f_f (log1p, plus_infty, plus_infty);
67e971f1 9675 TEST_f_f (log1p, qnan_value, qnan_value);
8847214f
UD
9676
9677 TEST_f_f (log1p, M_El - 1.0, 1);
9678
2550dfe9
AJ
9679 TEST_f_f (log1p, -0.25L, -0.287682072451780927439219005993827432L);
9680 TEST_f_f (log1p, -0.875, -2.07944154167983592825169636437452970L);
8847214f
UD
9681
9682 END (log1p);
9683}
9684
9685
9686static void
9687log2_test (void)
9688{
e6d3c4a7
AJ
9689 errno = 0;
9690 FUNC(log2) (1);
9691 if (errno == ENOSYS)
9692 /* Function not implemented. */
9693 return;
9694
8847214f
UD
9695 START (log2);
9696
9697 TEST_f_f (log2, 0, minus_infty, DIVIDE_BY_ZERO_EXCEPTION);
9698 TEST_f_f (log2, minus_zero, minus_infty, DIVIDE_BY_ZERO_EXCEPTION);
9699
9700 TEST_f_f (log2, 1, 0);
9701
67e971f1
TS
9702 TEST_f_f (log2, -1, qnan_value, INVALID_EXCEPTION);
9703 TEST_f_f (log2, -max_value, qnan_value, INVALID_EXCEPTION);
9704 TEST_f_f (log2, minus_infty, qnan_value, INVALID_EXCEPTION);
8847214f
UD
9705
9706 TEST_f_f (log2, plus_infty, plus_infty);
67e971f1 9707 TEST_f_f (log2, qnan_value, qnan_value);
8847214f
UD
9708
9709 TEST_f_f (log2, M_El, M_LOG2El);
9710 TEST_f_f (log2, 2.0, 1);
9711 TEST_f_f (log2, 16.0, 4);
9712 TEST_f_f (log2, 256.0, 8);
2550dfe9 9713 TEST_f_f (log2, 0.75L, -.415037499278843818546261056052183492L);
8847214f
UD
9714
9715 END (log2);
9716}
9717
9718
9719static void
9720logb_test (void)
9721{
9722 START (logb);
9723
9724 TEST_f_f (logb, plus_infty, plus_infty);
9725 TEST_f_f (logb, minus_infty, plus_infty);
9726
9727 TEST_f_f (logb, 0, minus_infty, DIVIDE_BY_ZERO_EXCEPTION);
9728
9729 TEST_f_f (logb, minus_zero, minus_infty, DIVIDE_BY_ZERO_EXCEPTION);
67e971f1 9730 TEST_f_f (logb, qnan_value, qnan_value);
8847214f
UD
9731
9732 TEST_f_f (logb, 1, 0);
9733 TEST_f_f (logb, M_El, 1);
9734 TEST_f_f (logb, 1024, 10);
9735 TEST_f_f (logb, -2000, 10);
9736
89c9aa49
AZ
9737 TEST_f_f (logb, 0x0.1p-127, -131);
9738 TEST_f_f (logb, 0x0.01p-127, -135);
9739 TEST_f_f (logb, 0x0.011p-127, -135);
9740#ifndef TEST_FLOAT
9741 TEST_f_f (logb, 0x0.8p-1022, -1023);
9742 TEST_f_f (logb, 0x0.1p-1022, -1026);
9743 TEST_f_f (logb, 0x0.00111p-1022, -1034);
9744 TEST_f_f (logb, 0x0.00001p-1022, -1042);
9745 TEST_f_f (logb, 0x0.000011p-1022, -1042);
9746 TEST_f_f (logb, 0x0.0000000000001p-1022, -1074);
9747#endif
9748#if defined TEST_LDOUBLE && LDBL_MIN_EXP - LDBL_MANT_DIG <= -16400
9749 TEST_f_f (logb, 0x1p-16400L, -16400);
9750 TEST_f_f (logb, 0x.00000000001p-16382L, -16426);
9751#endif
9752
8847214f
UD
9753 END (logb);
9754}
9755
a462cb63
RA
9756static void
9757logb_test_downward (void)
9758{
9759 int save_round_mode;
9760 errno = 0;
9761
9762 FUNC(logb) (0);
9763 if (errno == ENOSYS)
9764 /* Function not implemented. */
9765 return;
9766
9767 START (logb_downward);
9768
9769 save_round_mode = fegetround ();
9770
9771 if (!fesetround (FE_DOWNWARD))
9772 {
9773
9774 /* IEEE 754-2008 says (section 5.3.3) that "logB(1) is +0.". Libm
9775 should not return -0 from logb in any rounding mode. PowerPC32 has
9776 failed with this test for power4 logb (and logbl on all PowerPC
9777 platforms) in the past due to instruction selection. GCC PR 52775
9778 provides the availability of the fcfid insn in 32-bit mode which
9779 eliminates the use of fsub in this instance and prevents the negative
9780 signed 0.0. */
9781
60c8fca7 9782 /* BZ #887 */
a462cb63
RA
9783 TEST_f_f (logb, 1.000e+0, plus_zero);
9784 }
9785
9786 fesetround (save_round_mode);
9787
9788 END (logb_downward);
9789}
2550dfe9 9790
8847214f
UD
9791static void
9792lround_test (void)
9793{
64d063b8
TS
9794 /* TODO: missing +/-Inf as well as qNaN tests. */
9795
8847214f
UD
9796 START (lround);
9797
9798 TEST_f_l (lround, 0, 0);
9799 TEST_f_l (lround, minus_zero, 0);
3c6cad26
UD
9800 TEST_f_l (lround, 0.2L, 0.0);
9801 TEST_f_l (lround, -0.2L, 0);
8847214f
UD
9802 TEST_f_l (lround, 0.5, 1);
9803 TEST_f_l (lround, -0.5, -1);
3c6cad26
UD
9804 TEST_f_l (lround, 0.8L, 1);
9805 TEST_f_l (lround, -0.8L, -1);
8847214f
UD
9806 TEST_f_l (lround, 1.5, 2);
9807 TEST_f_l (lround, -1.5, -2);
9808 TEST_f_l (lround, 22514.5, 22515);
9809 TEST_f_l (lround, -22514.5, -22515);
3eb61415 9810 TEST_f_l (lround, 1071930.0008, 1071930);
8847214f 9811#ifndef TEST_FLOAT
3eb61415 9812 TEST_f_l (lround, 1073741824.01, 1073741824);
39007ae3
UD
9813# if LONG_MAX > 281474976710656
9814 TEST_f_l (lround, 281474976710656.025, 281474976710656);
169d7f11 9815 TEST_f_l (lround, 18014398509481974, 18014398509481974);
39007ae3 9816# endif
8847214f
UD
9817 TEST_f_l (lround, 2097152.5, 2097153);
9818 TEST_f_l (lround, -2097152.5, -2097153);
c1e6b459
UD
9819 /* nextafter(0.5,-1) */
9820 TEST_f_l (lround, 0x1.fffffffffffffp-2, 0);
9821 /* nextafter(-0.5,1) */
9822 TEST_f_l (lround, -0x1.fffffffffffffp-2, 0);
9823#else
9824 /* nextafter(0.5,-1) */
9825 TEST_f_l (lround, 0x1.fffffp-2, 0);
9826 /* nextafter(-0.5,1) */
9827 TEST_f_l (lround, -0x1.fffffp-2, 0);
9828 TEST_f_l (lround, 0x1.fffffep+23, 16777215);
9829 TEST_f_l (lround, -0x1.fffffep+23, -16777215);
8847214f
UD
9830#endif
9831 END (lround);
9832}
9833
9834
9835static void
9836llround_test (void)
9837{
64d063b8
TS
9838 /* TODO: missing +/-Inf as well as qNaN tests. */
9839
8847214f
UD
9840 START (llround);
9841
9842 TEST_f_L (llround, 0, 0);
9843 TEST_f_L (llround, minus_zero, 0);
3c6cad26
UD
9844 TEST_f_L (llround, 0.2L, 0.0);
9845 TEST_f_L (llround, -0.2L, 0);
8847214f
UD
9846 TEST_f_L (llround, 0.5, 1);
9847 TEST_f_L (llround, -0.5, -1);
3c6cad26
UD
9848 TEST_f_L (llround, 0.8L, 1);
9849 TEST_f_L (llround, -0.8L, -1);
8847214f
UD
9850 TEST_f_L (llround, 1.5, 2);
9851 TEST_f_L (llround, -1.5, -2);
9852 TEST_f_L (llround, 22514.5, 22515);
9853 TEST_f_L (llround, -22514.5, -22515);
3eb61415 9854 TEST_f_l (llround, 1071930.0008, 1071930);
8847214f
UD
9855#ifndef TEST_FLOAT
9856 TEST_f_L (llround, 2097152.5, 2097153);
9857 TEST_f_L (llround, -2097152.5, -2097153);
9858 TEST_f_L (llround, 34359738368.5, 34359738369ll);
9859 TEST_f_L (llround, -34359738368.5, -34359738369ll);
169d7f11 9860 TEST_f_L (llround, -3.65309740835E17, -365309740835000000LL);
8847214f
UD
9861#endif
9862
9863 /* Test boundary conditions. */
9864 /* 0x1FFFFF */
9865 TEST_f_L (llround, 2097151.0, 2097151LL);
9866 /* 0x800000 */
9867 TEST_f_L (llround, 8388608.0, 8388608LL);
9868 /* 0x1000000 */
9869 TEST_f_L (llround, 16777216.0, 16777216LL);
9870 /* 0x20000000000 */
9871 TEST_f_L (llround, 2199023255552.0, 2199023255552LL);
9872 /* 0x40000000000 */
9873 TEST_f_L (llround, 4398046511104.0, 4398046511104LL);
39007ae3
UD
9874 /* 0x1000000000000 */
9875 TEST_f_L (llround, 281474976710656.0, 281474976710656LL);
8847214f
UD
9876 /* 0x10000000000000 */
9877 TEST_f_L (llround, 4503599627370496.0, 4503599627370496LL);
9878 /* 0x10000080000000 */
3eb61415 9879 TEST_f_L (llround, 4503601774854144.0, 4503601774854144LL);
8847214f
UD
9880 /* 0x20000000000000 */
9881 TEST_f_L (llround, 9007199254740992.0, 9007199254740992LL);
9882 /* 0x80000000000000 */
9883 TEST_f_L (llround, 36028797018963968.0, 36028797018963968LL);
9884 /* 0x100000000000000 */
9885 TEST_f_L (llround, 72057594037927936.0, 72057594037927936LL);
9886
601d2942
UD
9887#ifndef TEST_FLOAT
9888 /* 0x100000000 */
9889 TEST_f_L (llround, 4294967295.5, 4294967296LL);
9890 /* 0x200000000 */
9891 TEST_f_L (llround, 8589934591.5, 8589934592LL);
c1e6b459
UD
9892
9893 /* nextafter(0.5,-1) */
9894 TEST_f_L (llround, 0x1.fffffffffffffp-2, 0);
9895 /* nextafter(-0.5,1) */
9896 TEST_f_L (llround, -0x1.fffffffffffffp-2, 0);
9897 /* On PowerPC an exponent of '52' is the largest incrementally
9898 * representable sequence of whole-numbers in the 'double' range. We test
9899 * lround to make sure that a guard bit set during the lround operation
9900 * hasn't forced an erroneous shift giving us an incorrect result. The odd
9901 * numbers between +-(2^52+1 and 2^53-1) are affected since they have the
9902 * rightmost bit set. */
9903 /* +-(2^52+1) */
9904 TEST_f_L (llround, 0x1.0000000000001p+52,4503599627370497LL);
9905 TEST_f_L (llround, -0x1.0000000000001p+52,-4503599627370497LL);
9906 /* +-(2^53-1): Input is the last (positive and negative) incrementally
9907 * representable whole-number in the 'double' range that might round
9908 * erroneously. */
9909 TEST_f_L (llround, 0x1.fffffffffffffp+52, 9007199254740991LL);
9910 TEST_f_L (llround, -0x1.fffffffffffffp+52, -9007199254740991LL);
9911#else
9912 /* nextafter(0.5,-1) */
9913 TEST_f_L (llround, 0x1.fffffep-2, 0);
9914 /* nextafter(-0.5,1) */
9915 TEST_f_L (llround, -0x1.fffffep-2, 0);
9916 /* As above, on PowerPC an exponent of '23' is the largest incrementally
9917 * representable sequence of whole-numbers in the 'float' range.
9918 * Likewise, numbers between +-(2^23+1 and 2^24-1) are affected. */
9919 TEST_f_L (llround, 0x1.000002p+23,8388609);
9920 TEST_f_L (llround, -0x1.000002p+23,-8388609);
9921 TEST_f_L (llround, 0x1.fffffep+23, 16777215);
9922 TEST_f_L (llround, -0x1.fffffep+23, -16777215);
601d2942
UD
9923#endif
9924
c1e6b459 9925
f964490f
RM
9926#ifdef TEST_LDOUBLE
9927 /* The input can only be represented in long double. */
9928 TEST_f_L (llround, 4503599627370495.5L, 4503599627370496LL);
9929 TEST_f_L (llround, 4503599627370496.25L, 4503599627370496LL);
9930 TEST_f_L (llround, 4503599627370496.5L, 4503599627370497LL);
9931 TEST_f_L (llround, 4503599627370496.75L, 4503599627370497LL);
9932 TEST_f_L (llround, 4503599627370497.5L, 4503599627370498LL);
9933
830fce04
RM
9934# if LDBL_MANT_DIG > 100
9935 TEST_f_L (llround, 4503599627370495.4999999999999L, 4503599627370495LL);
9936 TEST_f_L (llround, 4503599627370496.4999999999999L, 4503599627370496LL);
9937 TEST_f_L (llround, 4503599627370497.4999999999999L, 4503599627370497LL);
9938 TEST_f_L (llround, 4503599627370494.5000000000001L, 4503599627370495LL);
9939 TEST_f_L (llround, 4503599627370495.5000000000001L, 4503599627370496LL);
9940 TEST_f_L (llround, 4503599627370496.5000000000001L, 4503599627370497LL);
9941
9942 TEST_f_L (llround, -4503599627370495.4999999999999L, -4503599627370495LL);
9943 TEST_f_L (llround, -4503599627370496.4999999999999L, -4503599627370496LL);
9944 TEST_f_L (llround, -4503599627370497.4999999999999L, -4503599627370497LL);
9945 TEST_f_L (llround, -4503599627370494.5000000000001L, -4503599627370495LL);
9946 TEST_f_L (llround, -4503599627370495.5000000000001L, -4503599627370496LL);
9947 TEST_f_L (llround, -4503599627370496.5000000000001L, -4503599627370497LL);
9948# endif
9949
f964490f
RM
9950 TEST_f_L (llround, -4503599627370495.5L, -4503599627370496LL);
9951 TEST_f_L (llround, -4503599627370496.25L, -4503599627370496LL);
9952 TEST_f_L (llround, -4503599627370496.5L, -4503599627370497LL);
9953 TEST_f_L (llround, -4503599627370496.75L, -4503599627370497LL);
9954 TEST_f_L (llround, -4503599627370497.5L, -4503599627370498LL);
9955
9956 TEST_f_L (llround, 9007199254740991.5L, 9007199254740992LL);
9957 TEST_f_L (llround, 9007199254740992.25L, 9007199254740992LL);
9958 TEST_f_L (llround, 9007199254740992.5L, 9007199254740993LL);
9959 TEST_f_L (llround, 9007199254740992.75L, 9007199254740993LL);
9960 TEST_f_L (llround, 9007199254740993.5L, 9007199254740994LL);
9961
830fce04
RM
9962# if LDBL_MANT_DIG > 100
9963 TEST_f_L (llround, 9007199254740991.4999999999999L, 9007199254740991LL);
9964 TEST_f_L (llround, 9007199254740992.4999999999999L, 9007199254740992LL);
9965 TEST_f_L (llround, 9007199254740993.4999999999999L, 9007199254740993LL);
9966 TEST_f_L (llround, 9007199254740991.5000000000001L, 9007199254740992LL);
9967 TEST_f_L (llround, 9007199254740992.5000000000001L, 9007199254740993LL);
9968 TEST_f_L (llround, 9007199254740993.5000000000001L, 9007199254740994LL);
9969
9970 TEST_f_L (llround, -9007199254740991.4999999999999L, -9007199254740991LL);
9971 TEST_f_L (llround, -9007199254740992.4999999999999L, -9007199254740992LL);
9972 TEST_f_L (llround, -9007199254740993.4999999999999L, -9007199254740993LL);
9973 TEST_f_L (llround, -9007199254740991.5000000000001L, -9007199254740992LL);
9974 TEST_f_L (llround, -9007199254740992.5000000000001L, -9007199254740993LL);
9975 TEST_f_L (llround, -9007199254740993.5000000000001L, -9007199254740994LL);
9976# endif
9977
f964490f
RM
9978 TEST_f_L (llround, -9007199254740991.5L, -9007199254740992LL);
9979 TEST_f_L (llround, -9007199254740992.25L, -9007199254740992LL);
9980 TEST_f_L (llround, -9007199254740992.5L, -9007199254740993LL);
9981 TEST_f_L (llround, -9007199254740992.75L, -9007199254740993LL);
9982 TEST_f_L (llround, -9007199254740993.5L, -9007199254740994LL);
9983
9984 TEST_f_L (llround, 72057594037927935.5L, 72057594037927936LL);
9985 TEST_f_L (llround, 72057594037927936.25L, 72057594037927936LL);
9986 TEST_f_L (llround, 72057594037927936.5L, 72057594037927937LL);
9987 TEST_f_L (llround, 72057594037927936.75L, 72057594037927937LL);
9988 TEST_f_L (llround, 72057594037927937.5L, 72057594037927938LL);
9989
9990 TEST_f_L (llround, -72057594037927935.5L, -72057594037927936LL);
9991 TEST_f_L (llround, -72057594037927936.25L, -72057594037927936LL);
9992 TEST_f_L (llround, -72057594037927936.5L, -72057594037927937LL);
9993 TEST_f_L (llround, -72057594037927936.75L, -72057594037927937LL);
9994 TEST_f_L (llround, -72057594037927937.5L, -72057594037927938LL);
1e832e37
RM
9995
9996 TEST_f_L (llround, 9223372036854775806.25L, 9223372036854775806LL);
9997 TEST_f_L (llround, -9223372036854775806.25L, -9223372036854775806LL);
9998 TEST_f_L (llround, 9223372036854775806.5L, 9223372036854775807LL);
9999 TEST_f_L (llround, -9223372036854775806.5L, -9223372036854775807LL);
10000 TEST_f_L (llround, 9223372036854775807.0L, 9223372036854775807LL);
10001 TEST_f_L (llround, -9223372036854775807.0L, -9223372036854775807LL);
f964490f
RM
10002#endif
10003
8847214f
UD
10004 END (llround);
10005}
10006
10007static void
10008modf_test (void)
10009{
10010 FLOAT x;
10011
10012 START (modf);
10013
10014 TEST_fF_f1 (modf, plus_infty, 0, plus_infty);
10015 TEST_fF_f1 (modf, minus_infty, minus_zero, minus_infty);
67e971f1 10016 TEST_fF_f1 (modf, qnan_value, qnan_value, qnan_value);
8847214f
UD
10017 TEST_fF_f1 (modf, 0, 0, 0);
10018 TEST_fF_f1 (modf, 1.5, 0.5, 1);
10019 TEST_fF_f1 (modf, 2.5, 0.5, 2);
10020 TEST_fF_f1 (modf, -2.5, -0.5, -2);
10021 TEST_fF_f1 (modf, 20, 0, 20);
10022 TEST_fF_f1 (modf, 21, 0, 21);
10023 TEST_fF_f1 (modf, 89.5, 0.5, 89);
10024
10025 END (modf);
10026}
10027
10028
10029static void
10030nearbyint_test (void)
10031{
10032 START (nearbyint);
10033
10034 TEST_f_f (nearbyint, 0.0, 0.0);
10035 TEST_f_f (nearbyint, minus_zero, minus_zero);
10036 TEST_f_f (nearbyint, plus_infty, plus_infty);
10037 TEST_f_f (nearbyint, minus_infty, minus_infty);
67e971f1 10038 TEST_f_f (nearbyint, qnan_value, qnan_value);
8847214f 10039
a1267ba1
AZ
10040 /* Subnormal values */
10041 TEST_f_f (nearbyint, -8.98847e+307, -8.98847e+307);
10042 TEST_f_f (nearbyint, -4.45015e-308, minus_zero);
10043
1dc23588
UD
10044 /* Default rounding mode is round to nearest. */
10045 TEST_f_f (nearbyint, 0.5, 0.0);
10046 TEST_f_f (nearbyint, 1.5, 2.0);
10047 TEST_f_f (nearbyint, -0.5, minus_zero);
10048 TEST_f_f (nearbyint, -1.5, -2.0);
bdf09fab 10049
af0498dc
UD
10050 TEST_f_f (nearbyint, 262144.75, 262145.0);
10051 TEST_f_f (nearbyint, 262142.75, 262143.0);
10052 TEST_f_f (nearbyint, 524286.75, 524287.0);
10053 TEST_f_f (nearbyint, 524288.75, 524289.0);
10054
6cbeae47
JM
10055 TEST_f_f (nearbyint, 1048576.75, 1048577.0);
10056 TEST_f_f (nearbyint, 2097152.75, 2097153.0);
10057 TEST_f_f (nearbyint, 2492472.75, 2492473.0);
10058 TEST_f_f (nearbyint, 2886220.75, 2886221.0);
10059 TEST_f_f (nearbyint, 3058792.75, 3058793.0);
10060 TEST_f_f (nearbyint, -1048576.75, -1048577.0);
10061 TEST_f_f (nearbyint, -2097152.75, -2097153.0);
10062 TEST_f_f (nearbyint, -2492472.75, -2492473.0);
10063 TEST_f_f (nearbyint, -2886220.75, -2886221.0);
10064 TEST_f_f (nearbyint, -3058792.75, -3058793.0);
10065#ifndef TEST_FLOAT
10066 TEST_f_f (nearbyint, 70368744177664.75, 70368744177665.0);
10067 TEST_f_f (nearbyint, 140737488355328.75, 140737488355329.0);
10068 TEST_f_f (nearbyint, 281474976710656.75, 281474976710657.0);
10069 TEST_f_f (nearbyint, 562949953421312.75, 562949953421313.0);
10070 TEST_f_f (nearbyint, 1125899906842624.75, 1125899906842625.0);
10071 TEST_f_f (nearbyint, -70368744177664.75, -70368744177665.0);
10072 TEST_f_f (nearbyint, -140737488355328.75, -140737488355329.0);
10073 TEST_f_f (nearbyint, -281474976710656.75, -281474976710657.0);
10074 TEST_f_f (nearbyint, -562949953421312.75, -562949953421313.0);
10075 TEST_f_f (nearbyint, -1125899906842624.75, -1125899906842625.0);
10076#endif
10077
8847214f
UD
10078 END (nearbyint);
10079}
10080
10081static void
10082nextafter_test (void)
10083{
10084
10085 START (nextafter);
10086
10087 TEST_ff_f (nextafter, 0, 0, 0);
10088 TEST_ff_f (nextafter, minus_zero, 0, 0);
10089 TEST_ff_f (nextafter, 0, minus_zero, minus_zero);
10090 TEST_ff_f (nextafter, minus_zero, minus_zero, minus_zero);
10091
10092 TEST_ff_f (nextafter, 9, 9, 9);
10093 TEST_ff_f (nextafter, -9, -9, -9);
10094 TEST_ff_f (nextafter, plus_infty, plus_infty, plus_infty);
10095 TEST_ff_f (nextafter, minus_infty, minus_infty, minus_infty);
10096
67e971f1
TS
10097 TEST_ff_f (nextafter, qnan_value, 1.1L, qnan_value);
10098 TEST_ff_f (nextafter, 1.1L, qnan_value, qnan_value);
10099 TEST_ff_f (nextafter, qnan_value, qnan_value, qnan_value);
8847214f 10100
64b02fd2
UD
10101 FLOAT fltmax = CHOOSE (LDBL_MAX, DBL_MAX, FLT_MAX,
10102 LDBL_MAX, DBL_MAX, FLT_MAX);
c135cc1b
JM
10103 TEST_ff_f (nextafter, fltmax, plus_infty, plus_infty, OVERFLOW_EXCEPTION);
10104 TEST_ff_f (nextafter, -fltmax, minus_infty, minus_infty, OVERFLOW_EXCEPTION);
64b02fd2 10105
757de559
UD
10106#ifdef TEST_LDOUBLE
10107 // XXX Enable once gcc is fixed.
10108 //TEST_ff_f (nextafter, 0x0.00000040000000000000p-16385L, -0.1L, 0x0.0000003ffffffff00000p-16385L);
10109#endif
10110
8847214f
UD
10111 /* XXX We need the hexadecimal FP number representation here for further
10112 tests. */
10113
10114 END (nextafter);
10115}
10116
fe559c5e 10117
8847214f
UD
10118static void
10119nexttoward_test (void)
10120{
10121 START (nexttoward);
10122 TEST_ff_f (nexttoward, 0, 0, 0);
10123 TEST_ff_f (nexttoward, minus_zero, 0, 0);
10124 TEST_ff_f (nexttoward, 0, minus_zero, minus_zero);
10125 TEST_ff_f (nexttoward, minus_zero, minus_zero, minus_zero);
10126
10127 TEST_ff_f (nexttoward, 9, 9, 9);
10128 TEST_ff_f (nexttoward, -9, -9, -9);
10129 TEST_ff_f (nexttoward, plus_infty, plus_infty, plus_infty);
10130 TEST_ff_f (nexttoward, minus_infty, minus_infty, minus_infty);
10131
67e971f1
TS
10132 TEST_ff_f (nexttoward, qnan_value, 1.1L, qnan_value);
10133 TEST_ff_f (nexttoward, 1.1L, qnan_value, qnan_value);
10134 TEST_ff_f (nexttoward, qnan_value, qnan_value, qnan_value);
8847214f 10135
7cb029ee
JM
10136#ifdef TEST_FLOAT
10137 TEST_ff_f (nexttoward, 1.0, 1.1L, 0x1.000002p0);
10138 TEST_ff_f (nexttoward, 1.0, LDBL_MAX, 0x1.000002p0);
10139 TEST_ff_f (nexttoward, 1.0, 0x1.0000000000001p0, 0x1.000002p0);
10140 TEST_ff_f (nexttoward, 1.0, 0.9L, 0x0.ffffffp0);
10141 TEST_ff_f (nexttoward, 1.0, -LDBL_MAX, 0x0.ffffffp0);
10142 TEST_ff_f (nexttoward, 1.0, 0x0.fffffffffffff8p0, 0x0.ffffffp0);
10143 TEST_ff_f (nexttoward, -1.0, -1.1L, -0x1.000002p0);
10144 TEST_ff_f (nexttoward, -1.0, -LDBL_MAX, -0x1.000002p0);
10145 TEST_ff_f (nexttoward, -1.0, -0x1.0000000000001p0, -0x1.000002p0);
10146 TEST_ff_f (nexttoward, -1.0, -0.9L, -0x0.ffffffp0);
10147 TEST_ff_f (nexttoward, -1.0, LDBL_MAX, -0x0.ffffffp0);
10148 TEST_ff_f (nexttoward, -1.0, -0x0.fffffffffffff8p0, -0x0.ffffffp0);
80bad0cc 10149 TEST_ff_f (nexttoward, -0x1.3p-145, -0xap-148L, -0x1.4p-145, UNDERFLOW_EXCEPTION);
7cb029ee
JM
10150# if LDBL_MANT_DIG >= 64
10151 TEST_ff_f (nexttoward, 1.0, 0x1.000000000000002p0L, 0x1.000002p0);
10152 TEST_ff_f (nexttoward, 1.0, 0x0.ffffffffffffffffp0L, 0x0.ffffffp0);
10153 TEST_ff_f (nexttoward, -1.0, -0x1.000000000000002p0L, -0x1.000002p0);
10154 TEST_ff_f (nexttoward, -1.0, -0x0.ffffffffffffffffp0L, -0x0.ffffffp0);
10155# endif
10156# if LDBL_MANT_DIG >= 106
10157 TEST_ff_f (nexttoward, 1.0, 0x1.000000000000000000000000008p0L, 0x1.000002p0);
10158 TEST_ff_f (nexttoward, 1.0, 0x0.ffffffffffffffffffffffffffcp0L, 0x0.ffffffp0);
10159 TEST_ff_f (nexttoward, -1.0, -0x1.000000000000000000000000008p0L, -0x1.000002p0);
10160 TEST_ff_f (nexttoward, -1.0, -0x0.ffffffffffffffffffffffffffcp0L, -0x0.ffffffp0);
10161# endif
10162# if LDBL_MANT_DIG >= 113
10163 TEST_ff_f (nexttoward, 1.0, 0x1.0000000000000000000000000001p0L, 0x1.000002p0);
10164 TEST_ff_f (nexttoward, 1.0, 0x0.ffffffffffffffffffffffffffff8p0L, 0x0.ffffffp0);
10165 TEST_ff_f (nexttoward, -1.0, -0x1.0000000000000000000000000001p0L, -0x1.000002p0);
10166 TEST_ff_f (nexttoward, -1.0, -0x0.ffffffffffffffffffffffffffff8p0L, -0x0.ffffffp0);
10167# endif
10168#endif
10169#ifdef TEST_DOUBLE
10170 TEST_ff_f (nexttoward, 1.0, 1.1L, 0x1.0000000000001p0);
10171 TEST_ff_f (nexttoward, 1.0, LDBL_MAX, 0x1.0000000000001p0);
10172 TEST_ff_f (nexttoward, 1.0, 0x1.0000000000001p0, 0x1.0000000000001p0);
10173 TEST_ff_f (nexttoward, 1.0, 0.9L, 0x0.fffffffffffff8p0);
10174 TEST_ff_f (nexttoward, 1.0, -LDBL_MAX, 0x0.fffffffffffff8p0);
10175 TEST_ff_f (nexttoward, 1.0, 0x0.fffffffffffff8p0, 0x0.fffffffffffff8p0);
10176 TEST_ff_f (nexttoward, -1.0, -1.1L, -0x1.0000000000001p0);
10177 TEST_ff_f (nexttoward, -1.0, -LDBL_MAX, -0x1.0000000000001p0);
10178 TEST_ff_f (nexttoward, -1.0, -0x1.0000000000001p0, -0x1.0000000000001p0);
10179 TEST_ff_f (nexttoward, -1.0, -0.9L, -0x0.fffffffffffff8p0);
10180 TEST_ff_f (nexttoward, -1.0, LDBL_MAX, -0x0.fffffffffffff8p0);
10181 TEST_ff_f (nexttoward, -1.0, -0x0.fffffffffffff8p0, -0x0.fffffffffffff8p0);
10182 TEST_ff_f (nexttoward, -1.0, -0x8.00346dc5d6388p-3L, -0x1.0000000000001p0);
80bad0cc 10183 TEST_ff_f (nexttoward, 0x1p-1074, 0x1p-1073L, 0x1p-1073, UNDERFLOW_EXCEPTION);
7cb029ee
JM
10184# if LDBL_MANT_DIG >= 64
10185 TEST_ff_f (nexttoward, 1.0, 0x1.000000000000002p0L, 0x1.0000000000001p0);
10186 TEST_ff_f (nexttoward, 1.0, 0x0.ffffffffffffffffp0L, 0x0.fffffffffffff8p0);
10187 TEST_ff_f (nexttoward, -1.0, -0x1.000000000000002p0L, -0x1.0000000000001p0);
10188 TEST_ff_f (nexttoward, -1.0, -0x0.ffffffffffffffffp0L, -0x0.fffffffffffff8p0);
10189# endif
10190# if LDBL_MANT_DIG >= 106
10191 TEST_ff_f (nexttoward, 1.0, 0x1.000000000000000000000000008p0L, 0x1.0000000000001p0);
10192 TEST_ff_f (nexttoward, 1.0, 0x0.ffffffffffffffffffffffffffcp0L, 0x0.fffffffffffff8p0);
10193 TEST_ff_f (nexttoward, -1.0, -0x1.000000000000000000000000008p0L, -0x1.0000000000001p0);
10194 TEST_ff_f (nexttoward, -1.0, -0x0.ffffffffffffffffffffffffffcp0L, -0x0.fffffffffffff8p0);
10195# endif
10196# if LDBL_MANT_DIG >= 113
10197 TEST_ff_f (nexttoward, 1.0, 0x1.0000000000000000000000000001p0L, 0x1.0000000000001p0);
10198 TEST_ff_f (nexttoward, 1.0, 0x0.ffffffffffffffffffffffffffff8p0L, 0x0.fffffffffffff8p0);
10199 TEST_ff_f (nexttoward, -1.0, -0x1.0000000000000000000000000001p0L, -0x1.0000000000001p0);
10200 TEST_ff_f (nexttoward, -1.0, -0x0.ffffffffffffffffffffffffffff8p0L, -0x0.fffffffffffff8p0);
10201# endif
10202#endif
8847214f
UD
10203
10204 END (nexttoward);
10205}
8847214f
UD
10206
10207
10208static void
10209pow_test (void)
10210{
10211
e6d3c4a7
AJ
10212 errno = 0;
10213 FUNC(pow) (0, 0);
10214 if (errno == ENOSYS)
10215 /* Function not implemented. */
10216 return;
10217
8847214f
UD
10218 START (pow);
10219
10220 TEST_ff_f (pow, 0, 0, 1);
10221 TEST_ff_f (pow, 0, minus_zero, 1);
10222 TEST_ff_f (pow, minus_zero, 0, 1);
10223 TEST_ff_f (pow, minus_zero, minus_zero, 1);
10224
10225 TEST_ff_f (pow, 10, 0, 1);
10226 TEST_ff_f (pow, 10, minus_zero, 1);
10227 TEST_ff_f (pow, -10, 0, 1);
10228 TEST_ff_f (pow, -10, minus_zero, 1);
10229
67e971f1
TS
10230 TEST_ff_f (pow, qnan_value, 0, 1);
10231 TEST_ff_f (pow, qnan_value, minus_zero, 1);
8847214f
UD
10232
10233
15daa639 10234#ifndef TEST_INLINE
3c6cad26 10235 TEST_ff_f (pow, 1.1L, plus_infty, plus_infty);
8847214f 10236 TEST_ff_f (pow, plus_infty, plus_infty, plus_infty);
3c6cad26 10237 TEST_ff_f (pow, -1.1L, plus_infty, plus_infty);
8847214f
UD
10238 TEST_ff_f (pow, minus_infty, plus_infty, plus_infty);
10239
10240 TEST_ff_f (pow, 0.9L, plus_infty, 0);
10241 TEST_ff_f (pow, 1e-7L, plus_infty, 0);
10242 TEST_ff_f (pow, -0.9L, plus_infty, 0);
10243 TEST_ff_f (pow, -1e-7L, plus_infty, 0);
10244
3c6cad26 10245 TEST_ff_f (pow, 1.1L, minus_infty, 0);
8847214f 10246 TEST_ff_f (pow, plus_infty, minus_infty, 0);
3c6cad26 10247 TEST_ff_f (pow, -1.1L, minus_infty, 0);
8847214f
UD
10248 TEST_ff_f (pow, minus_infty, minus_infty, 0);
10249
10250 TEST_ff_f (pow, 0.9L, minus_infty, plus_infty);
10251 TEST_ff_f (pow, 1e-7L, minus_infty, plus_infty);
10252 TEST_ff_f (pow, -0.9L, minus_infty, plus_infty);
10253 TEST_ff_f (pow, -1e-7L, minus_infty, plus_infty);
10254
10255 TEST_ff_f (pow, plus_infty, 1e-7L, plus_infty);
10256 TEST_ff_f (pow, plus_infty, 1, plus_infty);
10257 TEST_ff_f (pow, plus_infty, 1e7L, plus_infty);
60e235ee 10258 TEST_ff_f (pow, plus_infty, min_subnorm_value, plus_infty);
8847214f
UD
10259
10260 TEST_ff_f (pow, plus_infty, -1e-7L, 0);
10261 TEST_ff_f (pow, plus_infty, -1, 0);
10262 TEST_ff_f (pow, plus_infty, -1e7L, 0);
60e235ee 10263 TEST_ff_f (pow, plus_infty, -min_subnorm_value, 0);
8847214f
UD
10264
10265 TEST_ff_f (pow, minus_infty, 1, minus_infty);
10266 TEST_ff_f (pow, minus_infty, 11, minus_infty);
10267 TEST_ff_f (pow, minus_infty, 1001, minus_infty);
10268
10269 TEST_ff_f (pow, minus_infty, 2, plus_infty);
10270 TEST_ff_f (pow, minus_infty, 12, plus_infty);
10271 TEST_ff_f (pow, minus_infty, 1002, plus_infty);
3c6cad26
UD
10272 TEST_ff_f (pow, minus_infty, 0.1L, plus_infty);
10273 TEST_ff_f (pow, minus_infty, 1.1L, plus_infty);
10274 TEST_ff_f (pow, minus_infty, 11.1L, plus_infty);
10275 TEST_ff_f (pow, minus_infty, 1001.1L, plus_infty);
60e235ee 10276 TEST_ff_f (pow, minus_infty, min_subnorm_value, plus_infty);
8847214f
UD
10277
10278 TEST_ff_f (pow, minus_infty, -1, minus_zero);
10279 TEST_ff_f (pow, minus_infty, -11, minus_zero);
10280 TEST_ff_f (pow, minus_infty, -1001, minus_zero);
10281
10282 TEST_ff_f (pow, minus_infty, -2, 0);
10283 TEST_ff_f (pow, minus_infty, -12, 0);
10284 TEST_ff_f (pow, minus_infty, -1002, 0);
3c6cad26
UD
10285 TEST_ff_f (pow, minus_infty, -0.1L, 0);
10286 TEST_ff_f (pow, minus_infty, -1.1L, 0);
10287 TEST_ff_f (pow, minus_infty, -11.1L, 0);
10288 TEST_ff_f (pow, minus_infty, -1001.1L, 0);
60e235ee 10289 TEST_ff_f (pow, minus_infty, -min_subnorm_value, 0);
15daa639 10290#endif
8847214f 10291
67e971f1
TS
10292 TEST_ff_f (pow, qnan_value, qnan_value, qnan_value);
10293 TEST_ff_f (pow, 0, qnan_value, qnan_value);
10294 TEST_ff_f (pow, 1, qnan_value, 1);
10295 TEST_ff_f (pow, -1, qnan_value, qnan_value);
10296 TEST_ff_f (pow, qnan_value, 1, qnan_value);
10297 TEST_ff_f (pow, qnan_value, -1, qnan_value);
10298
10299 /* pow (x, qNaN) == qNaN. */
10300 TEST_ff_f (pow, 3.0, qnan_value, qnan_value);
10301 TEST_ff_f (pow, minus_zero, qnan_value, qnan_value);
10302 TEST_ff_f (pow, plus_infty, qnan_value, qnan_value);
10303 TEST_ff_f (pow, -3.0, qnan_value, qnan_value);
10304 TEST_ff_f (pow, minus_infty, qnan_value, qnan_value);
10305
10306 TEST_ff_f (pow, qnan_value, 3.0, qnan_value);
10307 TEST_ff_f (pow, qnan_value, -3.0, qnan_value);
10308 TEST_ff_f (pow, qnan_value, plus_infty, qnan_value);
10309 TEST_ff_f (pow, qnan_value, minus_infty, qnan_value);
10310 TEST_ff_f (pow, qnan_value, 2.5, qnan_value);
10311 TEST_ff_f (pow, qnan_value, -2.5, qnan_value);
10312 TEST_ff_f (pow, qnan_value, min_subnorm_value, qnan_value);
10313 TEST_ff_f (pow, qnan_value, -min_subnorm_value, qnan_value);
8847214f 10314
6571c570
UD
10315 TEST_ff_f (pow, 1, plus_infty, 1);
10316 TEST_ff_f (pow, -1, plus_infty, 1);
10317 TEST_ff_f (pow, 1, minus_infty, 1);
10318 TEST_ff_f (pow, -1, minus_infty, 1);
164f863e
UD
10319 TEST_ff_f (pow, 1, 1, 1);
10320 TEST_ff_f (pow, 1, -1, 1);
10321 TEST_ff_f (pow, 1, 1.25, 1);
10322 TEST_ff_f (pow, 1, -1.25, 1);
10323 TEST_ff_f (pow, 1, 0x1p62L, 1);
10324 TEST_ff_f (pow, 1, 0x1p63L, 1);
10325 TEST_ff_f (pow, 1, 0x1p64L, 1);
10326 TEST_ff_f (pow, 1, 0x1p72L, 1);
60e235ee
JM
10327 TEST_ff_f (pow, 1, min_subnorm_value, 1);
10328 TEST_ff_f (pow, 1, -min_subnorm_value, 1);
164f863e
UD
10329
10330 /* pow (x, +-0) == 1. */
10331 TEST_ff_f (pow, plus_infty, 0, 1);
10332 TEST_ff_f (pow, plus_infty, minus_zero, 1);
10333 TEST_ff_f (pow, minus_infty, 0, 1);
10334 TEST_ff_f (pow, minus_infty, minus_zero, 1);
10335 TEST_ff_f (pow, 32.75L, 0, 1);
10336 TEST_ff_f (pow, 32.75L, minus_zero, 1);
10337 TEST_ff_f (pow, -32.75L, 0, 1);
10338 TEST_ff_f (pow, -32.75L, minus_zero, 1);
10339 TEST_ff_f (pow, 0x1p72L, 0, 1);
10340 TEST_ff_f (pow, 0x1p72L, minus_zero, 1);
10341 TEST_ff_f (pow, 0x1p-72L, 0, 1);
10342 TEST_ff_f (pow, 0x1p-72L, minus_zero, 1);
8847214f 10343
67e971f1
TS
10344 TEST_ff_f (pow, -0.1L, 1.1L, qnan_value, INVALID_EXCEPTION);
10345 TEST_ff_f (pow, -0.1L, -1.1L, qnan_value, INVALID_EXCEPTION);
10346 TEST_ff_f (pow, -10.1L, 1.1L, qnan_value, INVALID_EXCEPTION);
10347 TEST_ff_f (pow, -10.1L, -1.1L, qnan_value, INVALID_EXCEPTION);
10348 TEST_ff_f (pow, -1.01L, min_subnorm_value, qnan_value, INVALID_EXCEPTION);
10349 TEST_ff_f (pow, -1.01L, -min_subnorm_value, qnan_value, INVALID_EXCEPTION);
10350 TEST_ff_f (pow, -1.0L, min_subnorm_value, qnan_value, INVALID_EXCEPTION);
10351 TEST_ff_f (pow, -1.0L, -min_subnorm_value, qnan_value, INVALID_EXCEPTION);
8847214f 10352
002a604f 10353 errno = 0;
8847214f 10354 TEST_ff_f (pow, 0, -1, plus_infty, DIVIDE_BY_ZERO_EXCEPTION);
002a604f
UD
10355 check_int ("errno for pow(0,-odd) == ERANGE", errno, ERANGE, 0, 0, 0);
10356 errno = 0;
8847214f 10357 TEST_ff_f (pow, 0, -11, plus_infty, DIVIDE_BY_ZERO_EXCEPTION);
002a604f
UD
10358 check_int ("errno for pow(0,-odd) == ERANGE", errno, ERANGE, 0, 0, 0);
10359 errno = 0;
2460d3aa
JM
10360 TEST_ff_f (pow, 0, -0xffffff, plus_infty, DIVIDE_BY_ZERO_EXCEPTION);
10361 check_int ("errno for pow(0,-odd) == ERANGE", errno, ERANGE, 0, 0, 0);
10362#ifndef TEST_FLOAT
10363 errno = 0;
10364 TEST_ff_f (pow, 0, -0x1.fffffffffffffp+52L, plus_infty, DIVIDE_BY_ZERO_EXCEPTION);
10365 check_int ("errno for pow(0,-odd) == ERANGE", errno, ERANGE, 0, 0, 0);
10366#endif
10367#ifdef TEST_LDOUBLE
10368# if LDBL_MANT_DIG >= 64
10369 errno = 0;
10370 TEST_ff_f (pow, 0, -0x1.fffffffffffffffep+63L, plus_infty, DIVIDE_BY_ZERO_EXCEPTION);
10371 check_int ("errno for pow(0,-odd) == ERANGE", errno, ERANGE, 0, 0, 0);
10372# endif
10373# if LDBL_MANT_DIG >= 106
10374 errno = 0;
10375 TEST_ff_f (pow, 0, -0x1.ffffffffffffffffffffffffff8p+105L, plus_infty, DIVIDE_BY_ZERO_EXCEPTION);
10376 check_int ("errno for pow(0,-odd) == ERANGE", errno, ERANGE, 0, 0, 0);
10377# endif
10378# if LDBL_MANT_DIG >= 113
10379 errno = 0;
10380 TEST_ff_f (pow, 0, -0x1.ffffffffffffffffffffffffffffp+112L, plus_infty, DIVIDE_BY_ZERO_EXCEPTION);
10381 check_int ("errno for pow(0,-odd) == ERANGE", errno, ERANGE, 0, 0, 0);
10382# endif
10383#endif
8847214f 10384 TEST_ff_f (pow, minus_zero, -1, minus_infty, DIVIDE_BY_ZERO_EXCEPTION);
002a604f
UD
10385 check_int ("errno for pow(-0,-odd) == ERANGE", errno, ERANGE, 0, 0, 0);
10386 errno = 0;
10387 TEST_ff_f (pow, minus_zero, -11L, minus_infty, DIVIDE_BY_ZERO_EXCEPTION);
10388 check_int ("errno for pow(-0,-odd) == ERANGE", errno, ERANGE, 0, 0, 0);
2460d3aa
JM
10389 errno = 0;
10390 TEST_ff_f (pow, minus_zero, -0xffffff, minus_infty, DIVIDE_BY_ZERO_EXCEPTION);
10391 check_int ("errno for pow(-0,-odd) == ERANGE", errno, ERANGE, 0, 0, 0);
10392 errno = 0;
10393 TEST_ff_f (pow, minus_zero, -0x1fffffe, plus_infty, DIVIDE_BY_ZERO_EXCEPTION);
10394 check_int ("errno for pow(-0,-even) == ERANGE", errno, ERANGE, 0, 0, 0);
10395#ifndef TEST_FLOAT
10396 errno = 0;
10397 TEST_ff_f (pow, minus_zero, -0x1.fffffffffffffp+52L, minus_infty, DIVIDE_BY_ZERO_EXCEPTION);
10398 check_int ("errno for pow(-0,-odd) == ERANGE", errno, ERANGE, 0, 0, 0);
10399 errno = 0;
10400 TEST_ff_f (pow, minus_zero, -0x1.fffffffffffffp+53L, plus_infty, DIVIDE_BY_ZERO_EXCEPTION);
10401 check_int ("errno for pow(-0,-even) == ERANGE", errno, ERANGE, 0, 0, 0);
10402#endif
10403#ifdef TEST_LDOUBLE
10404# if LDBL_MANT_DIG >= 64
10405 errno = 0;
10406 TEST_ff_f (pow, minus_zero, -0x1.fffffffffffffffep+63L, minus_infty, DIVIDE_BY_ZERO_EXCEPTION);
10407 check_int ("errno for pow(-0,-odd) == ERANGE", errno, ERANGE, 0, 0, 0);
10408 errno = 0;
10409 TEST_ff_f (pow, minus_zero, -0x1.fffffffffffffffep+64L, plus_infty, DIVIDE_BY_ZERO_EXCEPTION);
10410 check_int ("errno for pow(-0,-even) == ERANGE", errno, ERANGE, 0, 0, 0);
10411# endif
10412# if LDBL_MANT_DIG >= 106
10413 errno = 0;
10414 TEST_ff_f (pow, minus_zero, -0x1.ffffffffffffffffffffffffff8p+105L, minus_infty, DIVIDE_BY_ZERO_EXCEPTION);
10415 check_int ("errno for pow(-0,-odd) == ERANGE", errno, ERANGE, 0, 0, 0);
10416 errno = 0;
10417 TEST_ff_f (pow, minus_zero, -0x1.ffffffffffffffffffffffffff8p+106L, plus_infty, DIVIDE_BY_ZERO_EXCEPTION);
10418 check_int ("errno for pow(-0,-even) == ERANGE", errno, ERANGE, 0, 0, 0);
10419# endif
10420# if LDBL_MANT_DIG >= 113
10421 errno = 0;
10422 TEST_ff_f (pow, minus_zero, -0x1.ffffffffffffffffffffffffffffp+112L, minus_infty, DIVIDE_BY_ZERO_EXCEPTION);
10423 check_int ("errno for pow(-0,-odd) == ERANGE", errno, ERANGE, 0, 0, 0);
10424 errno = 0;
10425 TEST_ff_f (pow, minus_zero, -0x1.ffffffffffffffffffffffffffffp+113L, plus_infty, DIVIDE_BY_ZERO_EXCEPTION);
10426 check_int ("errno for pow(-0,-even) == ERANGE", errno, ERANGE, 0, 0, 0);
10427# endif
10428#endif
8847214f 10429
002a604f 10430 errno = 0;
8847214f 10431 TEST_ff_f (pow, 0, -2, plus_infty, DIVIDE_BY_ZERO_EXCEPTION);
002a604f
UD
10432 check_int ("errno for pow(0,-even) == ERANGE", errno, ERANGE, 0, 0, 0);
10433 errno = 0;
3c6cad26 10434 TEST_ff_f (pow, 0, -11.1L, plus_infty, DIVIDE_BY_ZERO_EXCEPTION);
002a604f
UD
10435 check_int ("errno for pow(0,-num) == ERANGE", errno, ERANGE, 0, 0, 0);
10436 errno = 0;
60e235ee
JM
10437 TEST_ff_f (pow, 0, -min_subnorm_value, plus_infty, DIVIDE_BY_ZERO_EXCEPTION);
10438 check_int ("errno for pow(0,-num) == ERANGE", errno, ERANGE, 0, 0, 0);
10439 errno = 0;
2460d3aa
JM
10440 TEST_ff_f (pow, 0, -0x1p24, plus_infty, DIVIDE_BY_ZERO_EXCEPTION);
10441 check_int ("errno for pow(0,-num) == ERANGE", errno, ERANGE, 0, 0, 0);
10442 errno = 0;
10443 TEST_ff_f (pow, 0, -0x1p127, plus_infty, DIVIDE_BY_ZERO_EXCEPTION);
10444 check_int ("errno for pow(0,-num) == ERANGE", errno, ERANGE, 0, 0, 0);
10445 errno = 0;
41bf21a1 10446 TEST_ff_f (pow, 0, -max_value, plus_infty, DIVIDE_BY_ZERO_EXCEPTION);
2460d3aa
JM
10447 check_int ("errno for pow(0,-num) == ERANGE", errno, ERANGE, 0, 0, 0);
10448 errno = 0;
8847214f 10449 TEST_ff_f (pow, minus_zero, -2, plus_infty, DIVIDE_BY_ZERO_EXCEPTION);
002a604f
UD
10450 check_int ("errno for pow(-0,-even) == ERANGE", errno, ERANGE, 0, 0, 0);
10451 errno = 0;
3c6cad26 10452 TEST_ff_f (pow, minus_zero, -11.1L, plus_infty, DIVIDE_BY_ZERO_EXCEPTION);
002a604f 10453 check_int ("errno for pow(-0,-num) == ERANGE", errno, ERANGE, 0, 0, 0);
2460d3aa 10454 errno = 0;
60e235ee
JM
10455 TEST_ff_f (pow, minus_zero, -min_subnorm_value, plus_infty, DIVIDE_BY_ZERO_EXCEPTION);
10456 check_int ("errno for pow(-0,-num) == ERANGE", errno, ERANGE, 0, 0, 0);
10457 errno = 0;
2460d3aa
JM
10458 TEST_ff_f (pow, minus_zero, -0x1p24, plus_infty, DIVIDE_BY_ZERO_EXCEPTION);
10459 check_int ("errno for pow(-0,-num) == ERANGE", errno, ERANGE, 0, 0, 0);
10460 errno = 0;
10461 TEST_ff_f (pow, minus_zero, -0x1p127, plus_infty, DIVIDE_BY_ZERO_EXCEPTION);
10462 check_int ("errno for pow(-0,-num) == ERANGE", errno, ERANGE, 0, 0, 0);
10463 errno = 0;
41bf21a1 10464 TEST_ff_f (pow, minus_zero, -max_value, plus_infty, DIVIDE_BY_ZERO_EXCEPTION);
2460d3aa 10465 check_int ("errno for pow(-0,-num) == ERANGE", errno, ERANGE, 0, 0, 0);
8847214f 10466
c135cc1b 10467 TEST_ff_f (pow, 0x1p72L, 0x1p72L, plus_infty, OVERFLOW_EXCEPTION);
80bad0cc 10468 TEST_ff_f (pow, 10, -0x1p72L, 0, UNDERFLOW_EXCEPTION);
d7dd9453 10469 TEST_ff_f (pow, max_value, max_value, plus_infty, OVERFLOW_EXCEPTION);
80bad0cc 10470 TEST_ff_f (pow, 10, -max_value, 0, UNDERFLOW_EXCEPTION);
8847214f
UD
10471
10472 TEST_ff_f (pow, 0, 1, 0);
10473 TEST_ff_f (pow, 0, 11, 0);
10474
10475 TEST_ff_f (pow, minus_zero, 1, minus_zero);
10476 TEST_ff_f (pow, minus_zero, 11, minus_zero);
10477
8847214f 10478 TEST_ff_f (pow, 0, 2, 0);
3c6cad26 10479 TEST_ff_f (pow, 0, 11.1L, 0);
8847214f 10480
8847214f 10481 TEST_ff_f (pow, minus_zero, 2, 0);
3c6cad26 10482 TEST_ff_f (pow, minus_zero, 11.1L, 0);
164f863e
UD
10483 TEST_ff_f (pow, 0, plus_infty, 0);
10484 TEST_ff_f (pow, minus_zero, plus_infty, 0);
10285c21
JM
10485 TEST_ff_f (pow, 0, minus_infty, plus_infty, DIVIDE_BY_ZERO_EXCEPTION_OK);
10486 TEST_ff_f (pow, minus_zero, minus_infty, plus_infty, DIVIDE_BY_ZERO_EXCEPTION_OK);
8847214f 10487
15daa639 10488#ifndef TEST_INLINE
8847214f
UD
10489 /* pow (x, +inf) == +inf for |x| > 1. */
10490 TEST_ff_f (pow, 1.5, plus_infty, plus_infty);
10491
10492 /* pow (x, +inf) == +0 for |x| < 1. */
10493 TEST_ff_f (pow, 0.5, plus_infty, 0.0);
10494
10495 /* pow (x, -inf) == +0 for |x| > 1. */
10496 TEST_ff_f (pow, 1.5, minus_infty, 0.0);
10497
10498 /* pow (x, -inf) == +inf for |x| < 1. */
10499 TEST_ff_f (pow, 0.5, minus_infty, plus_infty);
15daa639 10500#endif
8847214f
UD
10501
10502 /* pow (+inf, y) == +inf for y > 0. */
10503 TEST_ff_f (pow, plus_infty, 2, plus_infty);
2460d3aa
JM
10504 TEST_ff_f (pow, plus_infty, 0xffffff, plus_infty);
10505#ifndef TEST_FLOAT
10506 TEST_ff_f (pow, plus_infty, 0x1.fffffffffffffp+52L, plus_infty);
10507#endif
10508#ifdef TEST_LDOUBLE
10509# if LDBL_MANT_DIG >= 64
10510 TEST_ff_f (pow, plus_infty, 0x1.fffffffffffffffep+63L, plus_infty);
10511# endif
10512# if LDBL_MANT_DIG >= 106
10513 TEST_ff_f (pow, plus_infty, 0x1.ffffffffffffffffffffffffff8p+105L, plus_infty);
10514# endif
10515# if LDBL_MANT_DIG >= 113
10516 TEST_ff_f (pow, plus_infty, 0x1.ffffffffffffffffffffffffffffp+112L, plus_infty);
10517# endif
10518#endif
10519 TEST_ff_f (pow, plus_infty, 0x1p24, plus_infty);
10520 TEST_ff_f (pow, plus_infty, 0x1p127, plus_infty);
10521 TEST_ff_f (pow, plus_infty, max_value, plus_infty);
8847214f
UD
10522
10523 /* pow (+inf, y) == +0 for y < 0. */
10524 TEST_ff_f (pow, plus_infty, -1, 0.0);
2460d3aa
JM
10525 TEST_ff_f (pow, plus_infty, -0xffffff, 0.0);
10526#ifndef TEST_FLOAT
10527 TEST_ff_f (pow, plus_infty, -0x1.fffffffffffffp+52L, 0.0);
10528#endif
10529#ifdef TEST_LDOUBLE
10530# if LDBL_MANT_DIG >= 64
10531 TEST_ff_f (pow, plus_infty, -0x1.fffffffffffffffep+63L, 0.0);
10532# endif
10533# if LDBL_MANT_DIG >= 106
10534 TEST_ff_f (pow, plus_infty, -0x1.ffffffffffffffffffffffffff8p+105L, 0.0);
10535# endif
10536# if LDBL_MANT_DIG >= 113
10537 TEST_ff_f (pow, plus_infty, -0x1.ffffffffffffffffffffffffffffp+112L, 0.0);
10538# endif
10539#endif
10540 TEST_ff_f (pow, plus_infty, -0x1p24, 0.0);
10541 TEST_ff_f (pow, plus_infty, -0x1p127, 0.0);
10542 TEST_ff_f (pow, plus_infty, -max_value, 0.0);
8847214f
UD
10543
10544 /* pow (-inf, y) == -inf for y an odd integer > 0. */
10545 TEST_ff_f (pow, minus_infty, 27, minus_infty);
2460d3aa
JM
10546 TEST_ff_f (pow, minus_infty, 0xffffff, minus_infty);
10547 TEST_ff_f (pow, minus_infty, 0x1fffffe, plus_infty);
10548#ifndef TEST_FLOAT
10549 TEST_ff_f (pow, minus_infty, 0x1.fffffffffffffp+52L, minus_infty);
10550 TEST_ff_f (pow, minus_infty, 0x1.fffffffffffffp+53L, plus_infty);
10551#endif
10552#ifdef TEST_LDOUBLE
10553# if LDBL_MANT_DIG >= 64
10554 TEST_ff_f (pow, minus_infty, 0x1.fffffffffffffffep+63L, minus_infty);
10555 TEST_ff_f (pow, minus_infty, 0x1.fffffffffffffffep+64L, plus_infty);
10556# endif
10557# if LDBL_MANT_DIG >= 106
10558 TEST_ff_f (pow, minus_infty, 0x1.ffffffffffffffffffffffffff8p+105L, minus_infty);
10559 TEST_ff_f (pow, minus_infty, 0x1.ffffffffffffffffffffffffff8p+106L, plus_infty);
10560# endif
10561# if LDBL_MANT_DIG >= 113
10562 TEST_ff_f (pow, minus_infty, 0x1.ffffffffffffffffffffffffffffp+112L, minus_infty);
10563 TEST_ff_f (pow, minus_infty, 0x1.ffffffffffffffffffffffffffffp+113L, plus_infty);
10564# endif
10565#endif
8847214f
UD
10566
10567 /* pow (-inf, y) == +inf for y > 0 and not an odd integer. */
10568 TEST_ff_f (pow, minus_infty, 28, plus_infty);
2460d3aa
JM
10569 TEST_ff_f (pow, minus_infty, 0x1p24, plus_infty);
10570 TEST_ff_f (pow, minus_infty, 0x1p127, plus_infty);
10571 TEST_ff_f (pow, minus_infty, max_value, plus_infty);
8847214f
UD
10572
10573 /* pow (-inf, y) == -0 for y an odd integer < 0. */
10574 TEST_ff_f (pow, minus_infty, -3, minus_zero);
2460d3aa
JM
10575 TEST_ff_f (pow, minus_infty, -0xffffff, minus_zero);
10576 TEST_ff_f (pow, minus_infty, -0x1fffffe, plus_zero);
10577#ifndef TEST_FLOAT
10578 TEST_ff_f (pow, minus_infty, -0x1.fffffffffffffp+52L, minus_zero);
10579 TEST_ff_f (pow, minus_infty, -0x1.fffffffffffffp+53L, plus_zero);
10580#endif
10581#ifdef TEST_LDOUBLE
10582# if LDBL_MANT_DIG >= 64
10583 TEST_ff_f (pow, minus_infty, -0x1.fffffffffffffffep+63L, minus_zero);
10584 TEST_ff_f (pow, minus_infty, -0x1.fffffffffffffffep+64L, plus_zero);
10585# endif
10586# if LDBL_MANT_DIG >= 106
10587 TEST_ff_f (pow, minus_infty, -0x1.ffffffffffffffffffffffffff8p+105L, minus_zero);
10588 TEST_ff_f (pow, minus_infty, -0x1.ffffffffffffffffffffffffff8p+106L, plus_zero);
10589# endif
10590# if LDBL_MANT_DIG >= 113
10591 TEST_ff_f (pow, minus_infty, -0x1.ffffffffffffffffffffffffffffp+112L, minus_zero);
10592 TEST_ff_f (pow, minus_infty, -0x1.ffffffffffffffffffffffffffffp+113L, plus_zero);
10593# endif
10594#endif
8847214f
UD
10595 /* pow (-inf, y) == +0 for y < 0 and not an odd integer. */
10596 TEST_ff_f (pow, minus_infty, -2.0, 0.0);
2460d3aa
JM
10597 TEST_ff_f (pow, minus_infty, -0x1p24, 0.0);
10598 TEST_ff_f (pow, minus_infty, -0x1p127, 0.0);
10599 TEST_ff_f (pow, minus_infty, -max_value, 0.0);
8847214f
UD
10600
10601 /* pow (+0, y) == +0 for y an odd integer > 0. */
10602 TEST_ff_f (pow, 0.0, 27, 0.0);
2460d3aa
JM
10603 TEST_ff_f (pow, 0.0, 0xffffff, 0.0);
10604#ifndef TEST_FLOAT
10605 TEST_ff_f (pow, 0.0, 0x1.fffffffffffffp+52L, 0.0);
10606#endif
10607#ifdef TEST_LDOUBLE
10608# if LDBL_MANT_DIG >= 64
10609 TEST_ff_f (pow, 0.0, 0x1.fffffffffffffffep+63L, 0.0);
10610# endif
10611# if LDBL_MANT_DIG >= 106
10612 TEST_ff_f (pow, 0.0, 0x1.ffffffffffffffffffffffffff8p+105L, 0.0);
10613# endif
10614# if LDBL_MANT_DIG >= 113
10615 TEST_ff_f (pow, 0.0, 0x1.ffffffffffffffffffffffffffffp+112L, 0.0);
10616# endif
10617#endif
8847214f
UD
10618
10619 /* pow (-0, y) == -0 for y an odd integer > 0. */
10620 TEST_ff_f (pow, minus_zero, 27, minus_zero);
2460d3aa
JM
10621 TEST_ff_f (pow, minus_zero, 0xffffff, minus_zero);
10622 TEST_ff_f (pow, minus_zero, 0x1fffffe, plus_zero);
10623#ifndef TEST_FLOAT
10624 TEST_ff_f (pow, minus_zero, 0x1.fffffffffffffp+52L, minus_zero);
10625 TEST_ff_f (pow, minus_zero, 0x1.fffffffffffffp+53L, plus_zero);
10626#endif
10627#ifdef TEST_LDOUBLE
10628# if LDBL_MANT_DIG >= 64
10629 TEST_ff_f (pow, minus_zero, 0x1.fffffffffffffffep+63L, minus_zero);
10630 TEST_ff_f (pow, minus_zero, 0x1.fffffffffffffffep+64L, plus_zero);
10631# endif
10632# if LDBL_MANT_DIG >= 106
10633 TEST_ff_f (pow, minus_zero, 0x1.ffffffffffffffffffffffffff8p+105L, minus_zero);
10634 TEST_ff_f (pow, minus_zero, 0x1.ffffffffffffffffffffffffff8p+106L, plus_zero);
10635# endif
10636# if LDBL_MANT_DIG >= 113
10637 TEST_ff_f (pow, minus_zero, 0x1.ffffffffffffffffffffffffffffp+112L, minus_zero);
10638 TEST_ff_f (pow, minus_zero, 0x1.ffffffffffffffffffffffffffffp+113L, plus_zero);
10639# endif
10640#endif
8847214f
UD
10641
10642 /* pow (+0, y) == +0 for y > 0 and not an odd integer. */
10643 TEST_ff_f (pow, 0.0, 4, 0.0);
2460d3aa
JM
10644 TEST_ff_f (pow, 0.0, 0x1p24, 0.0);
10645 TEST_ff_f (pow, 0.0, 0x1p127, 0.0);
10646 TEST_ff_f (pow, 0.0, max_value, 0.0);
60e235ee 10647 TEST_ff_f (pow, 0.0, min_subnorm_value, 0.0);
8847214f
UD
10648
10649 /* pow (-0, y) == +0 for y > 0 and not an odd integer. */
10650 TEST_ff_f (pow, minus_zero, 4, 0.0);
2460d3aa
JM
10651 TEST_ff_f (pow, minus_zero, 0x1p24, 0.0);
10652 TEST_ff_f (pow, minus_zero, 0x1p127, 0.0);
10653 TEST_ff_f (pow, minus_zero, max_value, 0.0);
60e235ee 10654 TEST_ff_f (pow, minus_zero, min_subnorm_value, 0.0);
8847214f 10655
164f863e
UD
10656 TEST_ff_f (pow, 16, 0.25L, 2);
10657 TEST_ff_f (pow, 0x1p64L, 0.125L, 256);
10658 TEST_ff_f (pow, 2, 4, 16);
10659 TEST_ff_f (pow, 256, 8, 0x1p64L);
10660
2550dfe9 10661 TEST_ff_f (pow, 0.75L, 1.25L, 0.697953644326574699205914060237425566L);
8847214f 10662
4c95adde 10663#if defined TEST_DOUBLE || defined TEST_LDOUBLE
80bad0cc 10664 TEST_ff_f (pow, -7.49321e+133, -9.80818e+16, 0, UNDERFLOW_EXCEPTION);
8847214f
UD
10665#endif
10666
d6270972
JM
10667 TEST_ff_f (pow, -1.0, -0xffffff, -1.0);
10668 TEST_ff_f (pow, -1.0, -0x1fffffe, 1.0);
10669#ifndef TEST_FLOAT
10670 TEST_ff_f (pow, -1.0, -0x1.fffffffffffffp+52L, -1.0);
10671 TEST_ff_f (pow, -1.0, -0x1.fffffffffffffp+53L, 1.0);
10672#endif
10673#ifdef TEST_LDOUBLE
10674# if LDBL_MANT_DIG >= 64
10675 TEST_ff_f (pow, -1.0, -0x1.fffffffffffffffep+63L, -1.0);
10676 TEST_ff_f (pow, -1.0, -0x1.fffffffffffffffep+64L, 1.0);
10677# endif
10678# if LDBL_MANT_DIG >= 106
10679 TEST_ff_f (pow, -1.0, -0x1.ffffffffffffffffffffffffff8p+105L, -1.0);
10680 TEST_ff_f (pow, -1.0, -0x1.ffffffffffffffffffffffffff8p+106L, 1.0);
10681# endif
10682# if LDBL_MANT_DIG >= 113
10683 TEST_ff_f (pow, -1.0, -0x1.ffffffffffffffffffffffffffffp+112L, -1.0);
10684 TEST_ff_f (pow, -1.0, -0x1.ffffffffffffffffffffffffffffp+113L, 1.0);
10685# endif
10686#endif
10687 TEST_ff_f (pow, -1.0, -max_value, 1.0);
10688
10689 TEST_ff_f (pow, -1.0, 0xffffff, -1.0);
10690 TEST_ff_f (pow, -1.0, 0x1fffffe, 1.0);
10691#ifndef TEST_FLOAT
10692 TEST_ff_f (pow, -1.0, 0x1.fffffffffffffp+52L, -1.0);
10693 TEST_ff_f (pow, -1.0, 0x1.fffffffffffffp+53L, 1.0);
10694#endif
10695#ifdef TEST_LDOUBLE
10696# if LDBL_MANT_DIG >= 64
10697 TEST_ff_f (pow, -1.0, 0x1.fffffffffffffffep+63L, -1.0);
10698 TEST_ff_f (pow, -1.0, 0x1.fffffffffffffffep+64L, 1.0);
10699# endif
10700# if LDBL_MANT_DIG >= 106
10701 TEST_ff_f (pow, -1.0, 0x1.ffffffffffffffffffffffffff8p+105L, -1.0);
10702 TEST_ff_f (pow, -1.0, 0x1.ffffffffffffffffffffffffff8p+106L, 1.0);
10703# endif
10704# if LDBL_MANT_DIG >= 113
10705 TEST_ff_f (pow, -1.0, 0x1.ffffffffffffffffffffffffffffp+112L, -1.0);
10706 TEST_ff_f (pow, -1.0, 0x1.ffffffffffffffffffffffffffffp+113L, 1.0);
10707# endif
10708#endif
10709 TEST_ff_f (pow, -1.0, max_value, 1.0);
10710
10711 TEST_ff_f (pow, -2.0, 126, 0x1p126);
10712 TEST_ff_f (pow, -2.0, 127, -0x1p127);
80bad0cc
JM
10713 /* Allow inexact results for float to be considered to underflow. */
10714 TEST_ff_f (pow, -2.0, -126, 0x1p-126, UNDERFLOW_EXCEPTION_OK_FLOAT);
10715 TEST_ff_f (pow, -2.0, -127, -0x1p-127, UNDERFLOW_EXCEPTION_OK_FLOAT);
d6270972 10716
80bad0cc
JM
10717 TEST_ff_f (pow, -2.0, -0xffffff, minus_zero, UNDERFLOW_EXCEPTION);
10718 TEST_ff_f (pow, -2.0, -0x1fffffe, plus_zero, UNDERFLOW_EXCEPTION);
d6270972 10719#ifndef TEST_FLOAT
80bad0cc
JM
10720 TEST_ff_f (pow, -2.0, -0x1.fffffffffffffp+52L, minus_zero, UNDERFLOW_EXCEPTION);
10721 TEST_ff_f (pow, -2.0, -0x1.fffffffffffffp+53L, plus_zero, UNDERFLOW_EXCEPTION);
d6270972
JM
10722#endif
10723#ifdef TEST_LDOUBLE
10724# if LDBL_MANT_DIG >= 64
80bad0cc
JM
10725 TEST_ff_f (pow, -2.0, -0x1.fffffffffffffffep+63L, minus_zero, UNDERFLOW_EXCEPTION);
10726 TEST_ff_f (pow, -2.0, -0x1.fffffffffffffffep+64L, plus_zero, UNDERFLOW_EXCEPTION);
d6270972
JM
10727# endif
10728# if LDBL_MANT_DIG >= 106
80bad0cc
JM
10729 TEST_ff_f (pow, -2.0, -0x1.ffffffffffffffffffffffffff8p+105L, minus_zero, UNDERFLOW_EXCEPTION);
10730 TEST_ff_f (pow, -2.0, -0x1.ffffffffffffffffffffffffff8p+106L, plus_zero, UNDERFLOW_EXCEPTION);
d6270972
JM
10731# endif
10732# if LDBL_MANT_DIG >= 113
80bad0cc
JM
10733 TEST_ff_f (pow, -2.0, -0x1.ffffffffffffffffffffffffffffp+112L, minus_zero, UNDERFLOW_EXCEPTION);
10734 TEST_ff_f (pow, -2.0, -0x1.ffffffffffffffffffffffffffffp+113L, plus_zero, UNDERFLOW_EXCEPTION);
d6270972
JM
10735# endif
10736#endif
80bad0cc 10737 TEST_ff_f (pow, -2.0, -max_value, plus_zero, UNDERFLOW_EXCEPTION);
d6270972
JM
10738
10739 TEST_ff_f (pow, -2.0, 0xffffff, minus_infty, OVERFLOW_EXCEPTION);
10740 TEST_ff_f (pow, -2.0, 0x1fffffe, plus_infty, OVERFLOW_EXCEPTION);
10741#ifndef TEST_FLOAT
10742 TEST_ff_f (pow, -2.0, 0x1.fffffffffffffp+52L, minus_infty, OVERFLOW_EXCEPTION);
10743 TEST_ff_f (pow, -2.0, 0x1.fffffffffffffp+53L, plus_infty, OVERFLOW_EXCEPTION);
10744#endif
10745#ifdef TEST_LDOUBLE
10746# if LDBL_MANT_DIG >= 64
10747 TEST_ff_f (pow, -2.0, 0x1.fffffffffffffffep+63L, minus_infty, OVERFLOW_EXCEPTION);
10748 TEST_ff_f (pow, -2.0, 0x1.fffffffffffffffep+64L, plus_infty, OVERFLOW_EXCEPTION);
10749# endif
10750# if LDBL_MANT_DIG >= 106
10751 TEST_ff_f (pow, -2.0, 0x1.ffffffffffffffffffffffffff8p+105L, minus_infty, OVERFLOW_EXCEPTION);
10752 TEST_ff_f (pow, -2.0, 0x1.ffffffffffffffffffffffffff8p+106L, plus_infty, OVERFLOW_EXCEPTION);
10753# endif
10754# if LDBL_MANT_DIG >= 113
10755 TEST_ff_f (pow, -2.0, 0x1.ffffffffffffffffffffffffffffp+112L, minus_infty, OVERFLOW_EXCEPTION);
10756 TEST_ff_f (pow, -2.0, 0x1.ffffffffffffffffffffffffffffp+113L, plus_infty, OVERFLOW_EXCEPTION);
10757# endif
10758#endif
d7dd9453 10759 TEST_ff_f (pow, -2.0, max_value, plus_infty, OVERFLOW_EXCEPTION);
d6270972 10760
67e971f1
TS
10761 TEST_ff_f (pow, -max_value, 0.5, qnan_value, INVALID_EXCEPTION);
10762 TEST_ff_f (pow, -max_value, 1.5, qnan_value, INVALID_EXCEPTION);
10763 TEST_ff_f (pow, -max_value, 1000.5, qnan_value, INVALID_EXCEPTION);
80bad0cc
JM
10764 TEST_ff_f (pow, -max_value, -2, plus_zero, UNDERFLOW_EXCEPTION);
10765 TEST_ff_f (pow, -max_value, -3, minus_zero, UNDERFLOW_EXCEPTION);
d6270972
JM
10766 TEST_ff_f (pow, -max_value, 2, plus_infty, OVERFLOW_EXCEPTION);
10767 TEST_ff_f (pow, -max_value, 3, minus_infty, OVERFLOW_EXCEPTION);
10768
80bad0cc
JM
10769 TEST_ff_f (pow, -max_value, -0xffffff, minus_zero, UNDERFLOW_EXCEPTION);
10770 TEST_ff_f (pow, -max_value, -0x1fffffe, plus_zero, UNDERFLOW_EXCEPTION);
d6270972 10771#ifndef TEST_FLOAT
80bad0cc
JM
10772 TEST_ff_f (pow, -max_value, -0x1.fffffffffffffp+52L, minus_zero, UNDERFLOW_EXCEPTION);
10773 TEST_ff_f (pow, -max_value, -0x1.fffffffffffffp+53L, plus_zero, UNDERFLOW_EXCEPTION);
d6270972
JM
10774#endif
10775#ifdef TEST_LDOUBLE
10776# if LDBL_MANT_DIG >= 64
80bad0cc
JM
10777 TEST_ff_f (pow, -max_value, -0x1.fffffffffffffffep+63L, minus_zero, UNDERFLOW_EXCEPTION);
10778 TEST_ff_f (pow, -max_value, -0x1.fffffffffffffffep+64L, plus_zero, UNDERFLOW_EXCEPTION);
d6270972
JM
10779# endif
10780# if LDBL_MANT_DIG >= 106
80bad0cc
JM
10781 TEST_ff_f (pow, -max_value, -0x1.ffffffffffffffffffffffffff8p+105L, minus_zero, UNDERFLOW_EXCEPTION);
10782 TEST_ff_f (pow, -max_value, -0x1.ffffffffffffffffffffffffff8p+106L, plus_zero, UNDERFLOW_EXCEPTION);
d6270972
JM
10783# endif
10784# if LDBL_MANT_DIG >= 113
80bad0cc
JM
10785 TEST_ff_f (pow, -max_value, -0x1.ffffffffffffffffffffffffffffp+112L, minus_zero, UNDERFLOW_EXCEPTION);
10786 TEST_ff_f (pow, -max_value, -0x1.ffffffffffffffffffffffffffffp+113L, plus_zero, UNDERFLOW_EXCEPTION);
d6270972
JM
10787# endif
10788#endif
80bad0cc 10789 TEST_ff_f (pow, -max_value, -max_value, plus_zero, UNDERFLOW_EXCEPTION);
d6270972
JM
10790
10791 TEST_ff_f (pow, -max_value, 0xffffff, minus_infty, OVERFLOW_EXCEPTION);
10792 TEST_ff_f (pow, -max_value, 0x1fffffe, plus_infty, OVERFLOW_EXCEPTION);
10793#ifndef TEST_FLOAT
10794 TEST_ff_f (pow, -max_value, 0x1.fffffffffffffp+52L, minus_infty, OVERFLOW_EXCEPTION);
10795 TEST_ff_f (pow, -max_value, 0x1.fffffffffffffp+53L, plus_infty, OVERFLOW_EXCEPTION);
10796#endif
10797#ifdef TEST_LDOUBLE
10798# if LDBL_MANT_DIG >= 64
10799 TEST_ff_f (pow, -max_value, 0x1.fffffffffffffffep+63L, minus_infty, OVERFLOW_EXCEPTION);
10800 TEST_ff_f (pow, -max_value, 0x1.fffffffffffffffep+64L, plus_infty, OVERFLOW_EXCEPTION);
10801# endif
10802# if LDBL_MANT_DIG >= 106
10803 TEST_ff_f (pow, -max_value, 0x1.ffffffffffffffffffffffffff8p+105L, minus_infty, OVERFLOW_EXCEPTION);
10804 TEST_ff_f (pow, -max_value, 0x1.ffffffffffffffffffffffffff8p+106L, plus_infty, OVERFLOW_EXCEPTION);
10805# endif
10806# if LDBL_MANT_DIG >= 113
10807 TEST_ff_f (pow, -max_value, 0x1.ffffffffffffffffffffffffffffp+112L, minus_infty, OVERFLOW_EXCEPTION);
10808 TEST_ff_f (pow, -max_value, 0x1.ffffffffffffffffffffffffffffp+113L, plus_infty, OVERFLOW_EXCEPTION);
10809# endif
10810#endif
d7dd9453 10811 TEST_ff_f (pow, -max_value, max_value, plus_infty, OVERFLOW_EXCEPTION);
d6270972
JM
10812
10813 TEST_ff_f (pow, -0.5, 126, 0x1p-126);
10814 TEST_ff_f (pow, -0.5, 127, -0x1p-127);
10815 TEST_ff_f (pow, -0.5, -126, 0x1p126);
10816 TEST_ff_f (pow, -0.5, -127, -0x1p127);
10817
10818 TEST_ff_f (pow, -0.5, -0xffffff, minus_infty, OVERFLOW_EXCEPTION);
10819 TEST_ff_f (pow, -0.5, -0x1fffffe, plus_infty, OVERFLOW_EXCEPTION);
10820#ifndef TEST_FLOAT
10821 TEST_ff_f (pow, -0.5, -0x1.fffffffffffffp+52L, minus_infty, OVERFLOW_EXCEPTION);
10822 TEST_ff_f (pow, -0.5, -0x1.fffffffffffffp+53L, plus_infty, OVERFLOW_EXCEPTION);
10823#endif
10824#ifdef TEST_LDOUBLE
10825# if LDBL_MANT_DIG >= 64
10826 TEST_ff_f (pow, -0.5, -0x1.fffffffffffffffep+63L, minus_infty, OVERFLOW_EXCEPTION);
10827 TEST_ff_f (pow, -0.5, -0x1.fffffffffffffffep+64L, plus_infty, OVERFLOW_EXCEPTION);
10828# endif
10829# if LDBL_MANT_DIG >= 106
10830 TEST_ff_f (pow, -0.5, -0x1.ffffffffffffffffffffffffff8p+105L, minus_infty, OVERFLOW_EXCEPTION);
10831 TEST_ff_f (pow, -0.5, -0x1.ffffffffffffffffffffffffff8p+106L, plus_infty, OVERFLOW_EXCEPTION);
10832# endif
10833# if LDBL_MANT_DIG >= 113
10834 TEST_ff_f (pow, -0.5, -0x1.ffffffffffffffffffffffffffffp+112L, minus_infty, OVERFLOW_EXCEPTION);
10835 TEST_ff_f (pow, -0.5, -0x1.ffffffffffffffffffffffffffffp+113L, plus_infty, OVERFLOW_EXCEPTION);
10836# endif
10837#endif
d7dd9453 10838 TEST_ff_f (pow, -0.5, -max_value, plus_infty, OVERFLOW_EXCEPTION);
d6270972 10839
80bad0cc
JM
10840 TEST_ff_f (pow, -0.5, 0xffffff, minus_zero, UNDERFLOW_EXCEPTION);
10841 TEST_ff_f (pow, -0.5, 0x1fffffe, plus_zero, UNDERFLOW_EXCEPTION);
d6270972 10842#ifndef TEST_FLOAT
80bad0cc
JM
10843 TEST_ff_f (pow, -0.5, 0x1.fffffffffffffp+52L, minus_zero, UNDERFLOW_EXCEPTION);
10844 TEST_ff_f (pow, -0.5, 0x1.fffffffffffffp+53L, plus_zero, UNDERFLOW_EXCEPTION);
d6270972
JM
10845#endif
10846#ifdef TEST_LDOUBLE
10847# if LDBL_MANT_DIG >= 64
80bad0cc
JM
10848 TEST_ff_f (pow, -0.5, 0x1.fffffffffffffffep+63L, minus_zero, UNDERFLOW_EXCEPTION);
10849 TEST_ff_f (pow, -0.5, 0x1.fffffffffffffffep+64L, plus_zero, UNDERFLOW_EXCEPTION);
d6270972
JM
10850# endif
10851# if LDBL_MANT_DIG >= 106
80bad0cc
JM
10852 TEST_ff_f (pow, -0.5, 0x1.ffffffffffffffffffffffffff8p+105L, minus_zero, UNDERFLOW_EXCEPTION);
10853 TEST_ff_f (pow, -0.5, 0x1.ffffffffffffffffffffffffff8p+106L, plus_zero, UNDERFLOW_EXCEPTION);
d6270972
JM
10854# endif
10855# if LDBL_MANT_DIG >= 113
80bad0cc
JM
10856 TEST_ff_f (pow, -0.5, 0x1.ffffffffffffffffffffffffffffp+112L, minus_zero, UNDERFLOW_EXCEPTION);
10857 TEST_ff_f (pow, -0.5, 0x1.ffffffffffffffffffffffffffffp+113L, plus_zero, UNDERFLOW_EXCEPTION);
d6270972
JM
10858# endif
10859#endif
80bad0cc 10860 TEST_ff_f (pow, -0.5, max_value, plus_zero, UNDERFLOW_EXCEPTION);
d6270972 10861
67e971f1
TS
10862 TEST_ff_f (pow, -min_value, 0.5, qnan_value, INVALID_EXCEPTION);
10863 TEST_ff_f (pow, -min_value, 1.5, qnan_value, INVALID_EXCEPTION);
10864 TEST_ff_f (pow, -min_value, 1000.5, qnan_value, INVALID_EXCEPTION);
d6270972
JM
10865 TEST_ff_f (pow, -min_value, -2, plus_infty, OVERFLOW_EXCEPTION);
10866 TEST_ff_f (pow, -min_value, -3, minus_infty, OVERFLOW_EXCEPTION);
80bad0cc
JM
10867 /* Allow inexact results to be considered to underflow. */
10868 TEST_ff_f (pow, -min_value, 1, -min_value, UNDERFLOW_EXCEPTION_OK);
10869 TEST_ff_f (pow, -min_value, 2, plus_zero, UNDERFLOW_EXCEPTION);
10870 TEST_ff_f (pow, -min_value, 3, minus_zero, UNDERFLOW_EXCEPTION);
d6270972
JM
10871
10872 TEST_ff_f (pow, -min_value, -0xffffff, minus_infty, OVERFLOW_EXCEPTION);
10873 TEST_ff_f (pow, -min_value, -0x1fffffe, plus_infty, OVERFLOW_EXCEPTION);
10874#ifndef TEST_FLOAT
10875 TEST_ff_f (pow, -min_value, -0x1.fffffffffffffp+52L, minus_infty, OVERFLOW_EXCEPTION);
10876 TEST_ff_f (pow, -min_value, -0x1.fffffffffffffp+53L, plus_infty, OVERFLOW_EXCEPTION);
10877#endif
10878#ifdef TEST_LDOUBLE
10879# if LDBL_MANT_DIG >= 64
10880 TEST_ff_f (pow, -min_value, -0x1.fffffffffffffffep+63L, minus_infty, OVERFLOW_EXCEPTION);
10881 TEST_ff_f (pow, -min_value, -0x1.fffffffffffffffep+64L, plus_infty, OVERFLOW_EXCEPTION);
10882# endif
10883# if LDBL_MANT_DIG >= 106
10884 TEST_ff_f (pow, -min_value, -0x1.ffffffffffffffffffffffffff8p+105L, minus_infty, OVERFLOW_EXCEPTION);
10885 TEST_ff_f (pow, -min_value, -0x1.ffffffffffffffffffffffffff8p+106L, plus_infty, OVERFLOW_EXCEPTION);
10886# endif
10887# if LDBL_MANT_DIG >= 113
10888 TEST_ff_f (pow, -min_value, -0x1.ffffffffffffffffffffffffffffp+112L, minus_infty, OVERFLOW_EXCEPTION);
10889 TEST_ff_f (pow, -min_value, -0x1.ffffffffffffffffffffffffffffp+113L, plus_infty, OVERFLOW_EXCEPTION);
10890# endif
10891#endif
d7dd9453 10892 TEST_ff_f (pow, -min_value, -max_value, plus_infty, OVERFLOW_EXCEPTION);
d6270972 10893
80bad0cc
JM
10894 TEST_ff_f (pow, -min_value, 0xffffff, minus_zero, UNDERFLOW_EXCEPTION);
10895 TEST_ff_f (pow, -min_value, 0x1fffffe, plus_zero, UNDERFLOW_EXCEPTION);
d6270972 10896#ifndef TEST_FLOAT
80bad0cc
JM
10897 TEST_ff_f (pow, -min_value, 0x1.fffffffffffffp+52L, minus_zero, UNDERFLOW_EXCEPTION);
10898 TEST_ff_f (pow, -min_value, 0x1.fffffffffffffp+53L, plus_zero, UNDERFLOW_EXCEPTION);
d6270972
JM
10899#endif
10900#ifdef TEST_LDOUBLE
10901# if LDBL_MANT_DIG >= 64
80bad0cc
JM
10902 TEST_ff_f (pow, -min_value, 0x1.fffffffffffffffep+63L, minus_zero, UNDERFLOW_EXCEPTION);
10903 TEST_ff_f (pow, -min_value, 0x1.fffffffffffffffep+64L, plus_zero, UNDERFLOW_EXCEPTION);
d6270972
JM
10904# endif
10905# if LDBL_MANT_DIG >= 106
80bad0cc
JM
10906 TEST_ff_f (pow, -min_value, 0x1.ffffffffffffffffffffffffff8p+105L, minus_zero, UNDERFLOW_EXCEPTION);
10907 TEST_ff_f (pow, -min_value, 0x1.ffffffffffffffffffffffffff8p+106L, plus_zero, UNDERFLOW_EXCEPTION);
d6270972
JM
10908# endif
10909# if LDBL_MANT_DIG >= 113
80bad0cc
JM
10910 TEST_ff_f (pow, -min_value, 0x1.ffffffffffffffffffffffffffffp+112L, minus_zero, UNDERFLOW_EXCEPTION);
10911 TEST_ff_f (pow, -min_value, 0x1.ffffffffffffffffffffffffffffp+113L, plus_zero, UNDERFLOW_EXCEPTION);
d6270972
JM
10912# endif
10913#endif
80bad0cc 10914 TEST_ff_f (pow, -min_value, max_value, plus_zero, UNDERFLOW_EXCEPTION);
d6270972 10915
c483f6b4
JM
10916 TEST_ff_f (pow, 0x0.ffffffp0, 10, 0.999999403953712118183885036774764444747L);
10917 TEST_ff_f (pow, 0x0.ffffffp0, 100, 0.999994039553108359406305079606228341585L);
10918 TEST_ff_f (pow, 0x0.ffffffp0, 1000, 0.9999403971297699052276650144650733772182L);
10919 TEST_ff_f (pow, 0x0.ffffffp0, 0x1p24, 0.3678794302077803437135155590023422899744L);
10920 TEST_ff_f (pow, 0x0.ffffffp0, 0x1p30, 1.603807831524924233828134753069728224044e-28L);
10921 TEST_ff_f (pow, 0x0.ffffffp0, 0x1.234566p30, 2.374884712135295099971443365381007297732e-32L);
10922 TEST_ff_f (pow, 0x0.ffffffp0, -10, 1.000000596046643153205170848674671339688L);
10923 TEST_ff_f (pow, 0x0.ffffffp0, -100, 1.000005960482418779499387594989252621451L);
10924 TEST_ff_f (pow, 0x0.ffffffp0, -1000, 1.000059606422943986382898964231519867906L);
10925 TEST_ff_f (pow, 0x0.ffffffp0, -0x1p24, 2.7182819094701610539628664526874952929416L);
10926 TEST_ff_f (pow, 0x0.ffffffp0, -0x1p30, 6.2351609734265057988914412331288163636075e+27L);
10927 TEST_ff_f (pow, 0x0.ffffffp0, -0x1.234566p30, 4.2107307141696353498921307077142537353515e+31L);
10928 TEST_ff_f (pow, 0x1.000002p0, 0x1p24, 7.3890552180866447284268641248075832310141L);
10929 TEST_ff_f (pow, 0x1.000002p0, 0x1.234566p29, 4.2107033006507495188536371520637025716256e+31L);
10930 TEST_ff_f (pow, 0x1.000002p0, -0x1.234566p29, 2.3749001736727769098946062325205705312166e-32L);
c483f6b4 10931
1bead169 10932#if !defined TEST_FLOAT
c483f6b4
JM
10933 TEST_ff_f (pow, 0x0.fffffffffffff8p0L, 0x1.23456789abcdfp62L, 1.0118762747827252817436395051178295138220e-253L);
10934 TEST_ff_f (pow, 0x0.fffffffffffff8p0L, -0x1.23456789abcdfp62L, 9.8826311568054561811190162420900667121992e+252L);
10935 TEST_ff_f (pow, 0x1.0000000000001p0L, 0x1.23456789abcdfp61L, 9.8826311568044974397135026217687399395481e+252L);
10936 TEST_ff_f (pow, 0x1.0000000000001p0L, -0x1.23456789abcdfp61L, 1.0118762747828234466621210689458255908670e-253L);
10937#endif
10938
1bead169
JM
10939#if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 64 && LDBL_MAX_EXP >= 16384
10940 TEST_ff_f (pow, 0x0.ffffffffffffffffp0L, 0x1.23456789abcdef0ep77L, 1.2079212226420368189981778807634890018840e-4048L);
10941 TEST_ff_f (pow, 0x0.ffffffffffffffffp0L, -0x1.23456789abcdef0ep77L, 8.2786855736563746280496724205839522148001e+4047L);
10942 TEST_ff_f (pow, 0x1.0000000000000002p0L, 0x1.23456789abcdef0ep76L, 8.2786855736563683535324500168799315131570e+4047L);
10943 TEST_ff_f (pow, 0x1.0000000000000002p0L, -0x1.23456789abcdef0ep76L, 1.2079212226420377344964713407722652880280e-4048L);
10944#endif
10945
10946#if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 113
10947 TEST_ff_f (pow, 0x0.ffffffffffffffffffffffffffff8p0L, 0x1.23456789abcdef0123456789abcdp126L, 1.2079212226420440237790185999151440179953e-4048L);
10948 TEST_ff_f (pow, 0x0.ffffffffffffffffffffffffffff8p0L, -0x1.23456789abcdef0123456789abcdp126L, 8.2786855736563252489063231915535105363602e+4047L);
10949 TEST_ff_f (pow, 0x1.0000000000000000000000000001p0L, 0x1.23456789abcdef0123456789abcdp125L, 8.2786855736563252489063231915423647547782e+4047L);
10950 TEST_ff_f (pow, 0x1.0000000000000000000000000001p0L, -0x1.23456789abcdef0123456789abcdp125L, 1.2079212226420440237790185999167702696503e-4048L);
10951#endif
10952
10953#if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
10954 TEST_ff_f (pow, 1e4932L, 0.75L, 1e3699L);
10955 TEST_ff_f (pow, 1e4928L, 0.75L, 1e3696L);
10956 TEST_ff_f (pow, 1e4924L, 0.75L, 1e3693L);
10957 TEST_ff_f (pow, 1e4920L, 0.75L, 1e3690L);
10958 TEST_ff_f (pow, 10.0L, 4932.0L, 1e4932L);
10959 TEST_ff_f (pow, 10.0L, 4931.0L, 1e4931L);
10960 TEST_ff_f (pow, 10.0L, 4930.0L, 1e4930L);
10961 TEST_ff_f (pow, 10.0L, 4929.0L, 1e4929L);
10962 TEST_ff_f (pow, 10.0L, -4931.0L, 1e-4931L);
10963 TEST_ff_f (pow, 10.0L, -4930.0L, 1e-4930L);
10964 TEST_ff_f (pow, 10.0L, -4929.0L, 1e-4929L);
10965 TEST_ff_f (pow, 1e27L, 182.0L, 1e4914L);
10966 TEST_ff_f (pow, 1e27L, -182.0L, 1e-4914L);
10967#endif
10968
60e235ee
JM
10969 TEST_ff_f (pow, min_subnorm_value, min_subnorm_value, 1.0L);
10970 TEST_ff_f (pow, min_subnorm_value, -min_subnorm_value, 1.0L);
10971 TEST_ff_f (pow, max_value, min_subnorm_value, 1.0L);
10972 TEST_ff_f (pow, max_value, -min_subnorm_value, 1.0L);
10973 TEST_ff_f (pow, 0.99L, min_subnorm_value, 1.0L);
10974 TEST_ff_f (pow, 0.99L, -min_subnorm_value, 1.0L);
10975 TEST_ff_f (pow, 1.01L, min_subnorm_value, 1.0L);
10976 TEST_ff_f (pow, 1.01L, -min_subnorm_value, 1.0L);
10977
7a25eb06
JM
10978 TEST_ff_f (pow, 2.0L, -100000.0L, plus_zero, UNDERFLOW_EXCEPTION);
10979
8847214f
UD
10980 END (pow);
10981}
10982
b7cd39e8
JM
10983
10984static void
10985pow_test_tonearest (void)
10986{
10987 int save_round_mode;
10988 errno = 0;
10989 FUNC(pow) (0, 0);
10990 if (errno == ENOSYS)
10991 /* Function not implemented. */
10992 return;
10993
10994 START (pow_tonearest);
10995
10996 save_round_mode = fegetround ();
10997
10998 if (!fesetround (FE_TONEAREST))
10999 {
11000 TEST_ff_f (pow, 1.0625L, 1.125L, 1.070582293028761362162622578677070098674L);
11001 TEST_ff_f (pow, 1.5L, 1.03125L, 1.519127098714743184071644334163037684948L);
11002 }
11003
11004 fesetround (save_round_mode);
11005
11006 END (pow_tonearest);
11007}
11008
11009
11010static void
11011pow_test_towardzero (void)
11012{
11013 int save_round_mode;
11014 errno = 0;
11015 FUNC(pow) (0, 0);
11016 if (errno == ENOSYS)
11017 /* Function not implemented. */
11018 return;
11019
11020 START (pow_towardzero);
11021
11022 save_round_mode = fegetround ();
11023
11024 if (!fesetround (FE_TOWARDZERO))
11025 {
11026 TEST_ff_f (pow, 1.0625L, 1.125L, 1.070582293028761362162622578677070098674L);
11027 TEST_ff_f (pow, 1.5L, 1.03125L, 1.519127098714743184071644334163037684948L);
11028 }
11029
11030 fesetround (save_round_mode);
11031
11032 END (pow_towardzero);
11033}
11034
11035
11036static void
11037pow_test_downward (void)
11038{
11039 int save_round_mode;
11040 errno = 0;
11041 FUNC(pow) (0, 0);
11042 if (errno == ENOSYS)
11043 /* Function not implemented. */
11044 return;
11045
11046 START (pow_downward);
11047
11048 save_round_mode = fegetround ();
11049
11050 if (!fesetround (FE_DOWNWARD))
11051 {
11052 TEST_ff_f (pow, 1.0625L, 1.125L, 1.070582293028761362162622578677070098674L);
11053 TEST_ff_f (pow, 1.5L, 1.03125L, 1.519127098714743184071644334163037684948L);
11054 }
11055
11056 fesetround (save_round_mode);
11057
11058 END (pow_downward);
11059}
11060
11061
11062static void
11063pow_test_upward (void)
11064{
11065 int save_round_mode;
11066 errno = 0;
11067 FUNC(pow) (0, 0);
11068 if (errno == ENOSYS)
11069 /* Function not implemented. */
11070 return;
11071
11072 START (pow_upward);
11073
11074 save_round_mode = fegetround ();
11075
11076 if (!fesetround (FE_UPWARD))
11077 {
11078 TEST_ff_f (pow, 1.0625L, 1.125L, 1.070582293028761362162622578677070098674L);
11079 TEST_ff_f (pow, 1.5L, 1.03125L, 1.519127098714743184071644334163037684948L);
11080 }
11081
11082 fesetround (save_round_mode);
11083
11084 END (pow_upward);
11085}
11086
11087
8847214f
UD
11088static void
11089remainder_test (void)
11090{
aaca11d8
UD
11091 errno = 0;
11092 FUNC(remainder) (1.625, 1.0);
11093 if (errno == ENOSYS)
11094 /* Function not implemented. */
11095 return;
8847214f
UD
11096
11097 START (remainder);
11098
bf582445 11099 errno = 0;
67e971f1 11100 TEST_ff_f (remainder, 1, 0, qnan_value, INVALID_EXCEPTION);
bf582445
AJ
11101 check_int ("errno for remainder(1, 0) = EDOM ", errno, EDOM, 0, 0, 0);
11102 errno = 0;
67e971f1 11103 TEST_ff_f (remainder, 1, minus_zero, qnan_value, INVALID_EXCEPTION);
bf582445
AJ
11104 check_int ("errno for remainder(1, -0) = EDOM ", errno, EDOM, 0, 0, 0);
11105 errno = 0;
a1cbf437
TS
11106 TEST_ff_f (remainder, plus_infty, minus_zero, qnan_value, INVALID_EXCEPTION);
11107 check_int ("errno for remainder(INF, -0) = EDOM ", errno, EDOM, 0, 0, 0);
11108 errno = 0;
11109 TEST_ff_f (remainder, plus_infty, 0, qnan_value, INVALID_EXCEPTION);
11110 check_int ("errno for remainder(INF, 0) = EDOM ", errno, EDOM, 0, 0, 0);
11111 errno = 0;
67e971f1 11112 TEST_ff_f (remainder, plus_infty, 1, qnan_value, INVALID_EXCEPTION);
bf582445
AJ
11113 check_int ("errno for remainder(INF, 1) = EDOM ", errno, EDOM, 0, 0, 0);
11114 errno = 0;
a1cbf437
TS
11115 TEST_ff_f (remainder, plus_infty, 2, qnan_value, INVALID_EXCEPTION);
11116 check_int ("errno for remainder(INF, 2) = EDOM ", errno, EDOM, 0, 0, 0);
11117 errno = 0;
11118 TEST_ff_f (remainder, minus_infty, minus_zero, qnan_value, INVALID_EXCEPTION);
11119 check_int ("errno for remainder(-INF, -0) = EDOM ", errno, EDOM, 0, 0, 0);
11120 errno = 0;
11121 TEST_ff_f (remainder, minus_infty, 0, qnan_value, INVALID_EXCEPTION);
11122 check_int ("errno for remainder(-INF, 0) = EDOM ", errno, EDOM, 0, 0, 0);
11123 errno = 0;
67e971f1 11124 TEST_ff_f (remainder, minus_infty, 1, qnan_value, INVALID_EXCEPTION);
bf582445
AJ
11125 check_int ("errno for remainder(-INF, 1) = EDOM ", errno, EDOM, 0, 0, 0);
11126 errno = 0;
a1cbf437
TS
11127 TEST_ff_f (remainder, minus_infty, 2, qnan_value, INVALID_EXCEPTION);
11128 check_int ("errno for remainder(-INF, 2) = EDOM ", errno, EDOM, 0, 0, 0);
11129 errno = 0;
67e971f1
TS
11130 TEST_ff_f (remainder, qnan_value, qnan_value, qnan_value);
11131 check_int ("errno for remainder(qNAN, qNAN) unchanged", errno, 0, 0, 0, 0);
bf582445 11132 errno = 0;
67e971f1
TS
11133 TEST_ff_f (remainder, 0, qnan_value, qnan_value);
11134 check_int ("errno for remainder(0, qNAN) unchanged", errno, 0, 0, 0, 0);
bf582445 11135 errno = 0;
67e971f1
TS
11136 TEST_ff_f (remainder, qnan_value, 0, qnan_value);
11137 check_int ("errno for remainder(qNaN, 0) unchanged", errno, 0, 0, 0, 0);
8847214f 11138
a1cbf437
TS
11139 errno = 0;
11140 TEST_ff_f (remainder, 7.0, plus_infty, 7.0);
11141 check_int ("errno for remainder(7.0, INF) unchanged", errno, 0, 0, 0, 0);
11142 errno = 0;
11143 TEST_ff_f (remainder, 7.0, minus_infty, 7.0);
11144 check_int ("errno for remainder(7.0, -INF) unchanged", errno, 0, 0, 0, 0);
11145
8847214f
UD
11146 TEST_ff_f (remainder, 1.625, 1.0, -0.375);
11147 TEST_ff_f (remainder, -1.625, 1.0, 0.375);
11148 TEST_ff_f (remainder, 1.625, -1.0, -0.375);
11149 TEST_ff_f (remainder, -1.625, -1.0, 0.375);
11150 TEST_ff_f (remainder, 5.0, 2.0, 1.0);
11151 TEST_ff_f (remainder, 3.0, 2.0, -1.0);
11152
11153 END (remainder);
11154}
11155
11156static void
11157remquo_test (void)
11158{
11159 /* x is needed. */
11160 int x;
11161
aaca11d8
UD
11162 errno = 0;
11163 FUNC(remquo) (1.625, 1.0, &x);
11164 if (errno == ENOSYS)
11165 /* Function not implemented. */
11166 return;
11167
8847214f
UD
11168 START (remquo);
11169
67e971f1
TS
11170 TEST_ffI_f1 (remquo, 1, 0, qnan_value, IGNORE, INVALID_EXCEPTION);
11171 TEST_ffI_f1 (remquo, 1, minus_zero, qnan_value, IGNORE, INVALID_EXCEPTION);
11172 TEST_ffI_f1 (remquo, plus_infty, 1, qnan_value, IGNORE, INVALID_EXCEPTION);
11173 TEST_ffI_f1 (remquo, minus_infty, 1, qnan_value, IGNORE, INVALID_EXCEPTION);
11174 TEST_ffI_f1 (remquo, qnan_value, qnan_value, qnan_value, IGNORE);
8847214f
UD
11175
11176 TEST_ffI_f1 (remquo, 1.625, 1.0, -0.375, 2);
11177 TEST_ffI_f1 (remquo, -1.625, 1.0, 0.375, -2);
11178 TEST_ffI_f1 (remquo, 1.625, -1.0, -0.375, -2);
11179 TEST_ffI_f1 (remquo, -1.625, -1.0, 0.375, 2);
11180
11181 TEST_ffI_f1 (remquo, 5, 2, 1, 2);
11182 TEST_ffI_f1 (remquo, 3, 2, -1, 2);
11183
11184 END (remquo);
11185}
11186
11187static void
11188rint_test (void)
11189{
64d063b8
TS
11190 /* TODO: missing qNaN tests. */
11191
8847214f
UD
11192 START (rint);
11193
11194 TEST_f_f (rint, 0.0, 0.0);
11195 TEST_f_f (rint, minus_zero, minus_zero);
11196 TEST_f_f (rint, plus_infty, plus_infty);
11197 TEST_f_f (rint, minus_infty, minus_infty);
11198
9949bc63 11199 /* Default rounding mode is round to even. */
1dc23588
UD
11200 TEST_f_f (rint, 0.5, 0.0);
11201 TEST_f_f (rint, 1.5, 2.0);
9949bc63
UD
11202 TEST_f_f (rint, 2.5, 2.0);
11203 TEST_f_f (rint, 3.5, 4.0);
11204 TEST_f_f (rint, 4.5, 4.0);
1dc23588
UD
11205 TEST_f_f (rint, -0.5, -0.0);
11206 TEST_f_f (rint, -1.5, -2.0);
9949bc63
UD
11207 TEST_f_f (rint, -2.5, -2.0);
11208 TEST_f_f (rint, -3.5, -4.0);
11209 TEST_f_f (rint, -4.5, -4.0);
5c68d401
RM
11210 TEST_f_f (rint, 0.1, 0.0);
11211 TEST_f_f (rint, 0.25, 0.0);
11212 TEST_f_f (rint, 0.625, 1.0);
11213 TEST_f_f (rint, -0.1, -0.0);
11214 TEST_f_f (rint, -0.25, -0.0);
11215 TEST_f_f (rint, -0.625, -1.0);
af0498dc
UD
11216 TEST_f_f (rint, 262144.75, 262145.0);
11217 TEST_f_f (rint, 262142.75, 262143.0);
11218 TEST_f_f (rint, 524286.75, 524287.0);
11219 TEST_f_f (rint, 524288.75, 524289.0);
fe45ce09
JM
11220 TEST_f_f (rint, 1048576.75, 1048577.0);
11221 TEST_f_f (rint, 2097152.75, 2097153.0);
11222 TEST_f_f (rint, -1048576.75, -1048577.0);
11223 TEST_f_f (rint, -2097152.75, -2097153.0);
11224#ifndef TEST_FLOAT
11225 TEST_f_f (rint, 70368744177664.75, 70368744177665.0);
11226 TEST_f_f (rint, 140737488355328.75, 140737488355329.0);
11227 TEST_f_f (rint, 281474976710656.75, 281474976710657.0);
11228 TEST_f_f (rint, 562949953421312.75, 562949953421313.0);
11229 TEST_f_f (rint, 1125899906842624.75, 1125899906842625.0);
11230 TEST_f_f (rint, -70368744177664.75, -70368744177665.0);
11231 TEST_f_f (rint, -140737488355328.75, -140737488355329.0);
11232 TEST_f_f (rint, -281474976710656.75, -281474976710657.0);
11233 TEST_f_f (rint, -562949953421312.75, -562949953421313.0);
11234 TEST_f_f (rint, -1125899906842624.75, -1125899906842625.0);
11235#endif
f964490f
RM
11236#ifdef TEST_LDOUBLE
11237 /* The result can only be represented in long double. */
11238 TEST_f_f (rint, 4503599627370495.5L, 4503599627370496.0L);
11239 TEST_f_f (rint, 4503599627370496.25L, 4503599627370496.0L);
11240 TEST_f_f (rint, 4503599627370496.5L, 4503599627370496.0L);
11241 TEST_f_f (rint, 4503599627370496.75L, 4503599627370497.0L);
11242 TEST_f_f (rint, 4503599627370497.5L, 4503599627370498.0L);
830fce04 11243
5c68d401
RM
11244# if LDBL_MANT_DIG > 100
11245 TEST_f_f (rint, 4503599627370494.5000000000001L, 4503599627370495.0L);
11246 TEST_f_f (rint, 4503599627370495.5000000000001L, 4503599627370496.0L);
11247 TEST_f_f (rint, 4503599627370496.5000000000001L, 4503599627370497.0L);
11248# endif
f964490f
RM
11249
11250 TEST_f_f (rint, -4503599627370495.5L, -4503599627370496.0L);
11251 TEST_f_f (rint, -4503599627370496.25L, -4503599627370496.0L);
11252 TEST_f_f (rint, -4503599627370496.5L, -4503599627370496.0L);
11253 TEST_f_f (rint, -4503599627370496.75L, -4503599627370497.0L);
11254 TEST_f_f (rint, -4503599627370497.5L, -4503599627370498.0L);
830fce04 11255
5c68d401
RM
11256# if LDBL_MANT_DIG > 100
11257 TEST_f_f (rint, -4503599627370494.5000000000001L, -4503599627370495.0L);
11258 TEST_f_f (rint, -4503599627370495.5000000000001L, -4503599627370496.0L);
11259 TEST_f_f (rint, -4503599627370496.5000000000001L, -4503599627370497.0L);
11260
11261 TEST_f_f (rint, 9007199254740991.0000000000001L, 9007199254740991.0L);
11262 TEST_f_f (rint, 9007199254740992.0000000000001L, 9007199254740992.0L);
11263 TEST_f_f (rint, 9007199254740993.0000000000001L, 9007199254740993.0L);
11264 TEST_f_f (rint, 9007199254740991.5000000000001L, 9007199254740992.0L);
11265 TEST_f_f (rint, 9007199254740992.5000000000001L, 9007199254740993.0L);
11266 TEST_f_f (rint, 9007199254740993.5000000000001L, 9007199254740994.0L);
11267
11268 TEST_f_f (rint, -9007199254740991.0000000000001L, -9007199254740991.0L);
11269 TEST_f_f (rint, -9007199254740992.0000000000001L, -9007199254740992.0L);
11270 TEST_f_f (rint, -9007199254740993.0000000000001L, -9007199254740993.0L);
11271 TEST_f_f (rint, -9007199254740991.5000000000001L, -9007199254740992.0L);
11272 TEST_f_f (rint, -9007199254740992.5000000000001L, -9007199254740993.0L);
11273 TEST_f_f (rint, -9007199254740993.5000000000001L, -9007199254740994.0L);
11274# endif
f964490f
RM
11275
11276 TEST_f_f (rint, 9007199254740991.5L, 9007199254740992.0L);
11277 TEST_f_f (rint, 9007199254740992.25L, 9007199254740992.0L);
11278 TEST_f_f (rint, 9007199254740992.5L, 9007199254740992.0L);
11279 TEST_f_f (rint, 9007199254740992.75L, 9007199254740993.0L);
11280 TEST_f_f (rint, 9007199254740993.5L, 9007199254740994.0L);
11281
11282 TEST_f_f (rint, -9007199254740991.5L, -9007199254740992.0L);
11283 TEST_f_f (rint, -9007199254740992.25L, -9007199254740992.0L);
11284 TEST_f_f (rint, -9007199254740992.5L, -9007199254740992.0L);
11285 TEST_f_f (rint, -9007199254740992.75L, -9007199254740993.0L);
11286 TEST_f_f (rint, -9007199254740993.5L, -9007199254740994.0L);
11287
11288 TEST_f_f (rint, 72057594037927935.5L, 72057594037927936.0L);
11289 TEST_f_f (rint, 72057594037927936.25L, 72057594037927936.0L);
11290 TEST_f_f (rint, 72057594037927936.5L, 72057594037927936.0L);
11291 TEST_f_f (rint, 72057594037927936.75L, 72057594037927937.0L);
11292 TEST_f_f (rint, 72057594037927937.5L, 72057594037927938.0L);
11293
11294 TEST_f_f (rint, -72057594037927935.5L, -72057594037927936.0L);
11295 TEST_f_f (rint, -72057594037927936.25L, -72057594037927936.0L);
11296 TEST_f_f (rint, -72057594037927936.5L, -72057594037927936.0L);
11297 TEST_f_f (rint, -72057594037927936.75L, -72057594037927937.0L);
11298 TEST_f_f (rint, -72057594037927937.5L, -72057594037927938.0L);
11299
11300 TEST_f_f (rint, 10141204801825835211973625643007.5L, 10141204801825835211973625643008.0L);
11301 TEST_f_f (rint, 10141204801825835211973625643008.25L, 10141204801825835211973625643008.0L);
11302 TEST_f_f (rint, 10141204801825835211973625643008.5L, 10141204801825835211973625643008.0L);
11303 TEST_f_f (rint, 10141204801825835211973625643008.75L, 10141204801825835211973625643009.0L);
11304 TEST_f_f (rint, 10141204801825835211973625643009.5L, 10141204801825835211973625643010.0L);
11305#endif
1dc23588 11306
8847214f
UD
11307 END (rint);
11308}
11309
4d37c8aa
UD
11310static void
11311rint_test_tonearest (void)
11312{
11313 int save_round_mode;
11314 START (rint_tonearest);
11315
830fce04 11316 save_round_mode = fegetround ();
4d37c8aa
UD
11317
11318 if (!fesetround (FE_TONEAREST))
830fce04
RM
11319 {
11320 TEST_f_f (rint, 2.0, 2.0);
11321 TEST_f_f (rint, 1.5, 2.0);
11322 TEST_f_f (rint, 1.0, 1.0);
11323 TEST_f_f (rint, 0.5, 0.0);
11324 TEST_f_f (rint, 0.0, 0.0);
11325 TEST_f_f (rint, minus_zero, minus_zero);
11326 TEST_f_f (rint, -0.5, -0.0);
11327 TEST_f_f (rint, -1.0, -1.0);
11328 TEST_f_f (rint, -1.5, -2.0);
11329 TEST_f_f (rint, -2.0, -2.0);
11330 TEST_f_f (rint, 0.1, 0.0);
11331 TEST_f_f (rint, 0.25, 0.0);
11332 TEST_f_f (rint, 0.625, 1.0);
11333 TEST_f_f (rint, -0.1, -0.0);
11334 TEST_f_f (rint, -0.25, -0.0);
11335 TEST_f_f (rint, -0.625, -1.0);
fe45ce09
JM
11336 TEST_f_f (rint, 1048576.75, 1048577.0);
11337 TEST_f_f (rint, 2097152.75, 2097153.0);
11338 TEST_f_f (rint, -1048576.75, -1048577.0);
11339 TEST_f_f (rint, -2097152.75, -2097153.0);
11340#ifndef TEST_FLOAT
11341 TEST_f_f (rint, 70368744177664.75, 70368744177665.0);
11342 TEST_f_f (rint, 140737488355328.75, 140737488355329.0);
11343 TEST_f_f (rint, 281474976710656.75, 281474976710657.0);
11344 TEST_f_f (rint, 562949953421312.75, 562949953421313.0);
11345 TEST_f_f (rint, 1125899906842624.75, 1125899906842625.0);
11346 TEST_f_f (rint, -70368744177664.75, -70368744177665.0);
11347 TEST_f_f (rint, -140737488355328.75, -140737488355329.0);
11348 TEST_f_f (rint, -281474976710656.75, -281474976710657.0);
11349 TEST_f_f (rint, -562949953421312.75, -562949953421313.0);
11350 TEST_f_f (rint, -1125899906842624.75, -1125899906842625.0);
11351#endif
5c68d401 11352#ifdef TEST_LDOUBLE
830fce04
RM
11353 /* The result can only be represented in long double. */
11354 TEST_f_f (rint, 4503599627370495.5L, 4503599627370496.0L);
11355 TEST_f_f (rint, 4503599627370496.25L, 4503599627370496.0L);
11356 TEST_f_f (rint, 4503599627370496.5L, 4503599627370496.0L);
11357 TEST_f_f (rint, 4503599627370496.75L, 4503599627370497.0L);
11358 TEST_f_f (rint, 4503599627370497.5L, 4503599627370498.0L);
5c68d401 11359# if LDBL_MANT_DIG > 100
830fce04
RM
11360 TEST_f_f (rint, 4503599627370494.5000000000001L, 4503599627370495.0L);
11361 TEST_f_f (rint, 4503599627370495.5000000000001L, 4503599627370496.0L);
11362 TEST_f_f (rint, 4503599627370496.5000000000001L, 4503599627370497.0L);
5c68d401 11363# endif
830fce04
RM
11364 TEST_f_f (rint, -4503599627370495.5L, -4503599627370496.0L);
11365 TEST_f_f (rint, -4503599627370496.25L, -4503599627370496.0L);
11366 TEST_f_f (rint, -4503599627370496.5L, -4503599627370496.0L);
11367 TEST_f_f (rint, -4503599627370496.75L, -4503599627370497.0L);
11368 TEST_f_f (rint, -4503599627370497.5L, -4503599627370498.0L);
5c68d401 11369# if LDBL_MANT_DIG > 100
830fce04
RM
11370 TEST_f_f (rint, -4503599627370494.5000000000001L, -4503599627370495.0L);
11371 TEST_f_f (rint, -4503599627370495.5000000000001L, -4503599627370496.0L);
11372 TEST_f_f (rint, -4503599627370496.5000000000001L, -4503599627370497.0L);
11373
11374 TEST_f_f (rint, 9007199254740991.0000000000001L, 9007199254740991.0L);
11375 TEST_f_f (rint, 9007199254740992.0000000000001L, 9007199254740992.0L);
11376 TEST_f_f (rint, 9007199254740993.0000000000001L, 9007199254740993.0L);
11377 TEST_f_f (rint, 9007199254740991.5000000000001L, 9007199254740992.0L);
11378 TEST_f_f (rint, 9007199254740992.5000000000001L, 9007199254740993.0L);
11379 TEST_f_f (rint, 9007199254740993.5000000000001L, 9007199254740994.0L);
11380
11381 TEST_f_f (rint, -9007199254740991.0000000000001L, -9007199254740991.0L);
11382 TEST_f_f (rint, -9007199254740992.0000000000001L, -9007199254740992.0L);
11383 TEST_f_f (rint, -9007199254740993.0000000000001L, -9007199254740993.0L);
11384 TEST_f_f (rint, -9007199254740991.5000000000001L, -9007199254740992.0L);
11385 TEST_f_f (rint, -9007199254740992.5000000000001L, -9007199254740993.0L);
11386 TEST_f_f (rint, -9007199254740993.5000000000001L, -9007199254740994.0L);
5c68d401
RM
11387# endif
11388#endif
830fce04 11389 }
4d37c8aa 11390
830fce04 11391 fesetround (save_round_mode);
4d37c8aa
UD
11392
11393 END (rint_tonearest);
11394}
11395
11396static void
11397rint_test_towardzero (void)
11398{
11399 int save_round_mode;
11400 START (rint_towardzero);
11401
830fce04 11402 save_round_mode = fegetround ();
4d37c8aa
UD
11403
11404 if (!fesetround (FE_TOWARDZERO))
830fce04
RM
11405 {
11406 TEST_f_f (rint, 2.0, 2.0);
11407 TEST_f_f (rint, 1.5, 1.0);
11408 TEST_f_f (rint, 1.0, 1.0);
11409 TEST_f_f (rint, 0.5, 0.0);
11410 TEST_f_f (rint, 0.0, 0.0);
11411 TEST_f_f (rint, minus_zero, minus_zero);
11412 TEST_f_f (rint, -0.5, -0.0);
11413 TEST_f_f (rint, -1.0, -1.0);
11414 TEST_f_f (rint, -1.5, -1.0);
11415 TEST_f_f (rint, -2.0, -2.0);
11416 TEST_f_f (rint, 0.1, 0.0);
11417 TEST_f_f (rint, 0.25, 0.0);
11418 TEST_f_f (rint, 0.625, 0.0);
11419 TEST_f_f (rint, -0.1, -0.0);
11420 TEST_f_f (rint, -0.25, -0.0);
11421 TEST_f_f (rint, -0.625, -0.0);
fe45ce09
JM
11422 TEST_f_f (rint, 1048576.75, 1048576.0);
11423 TEST_f_f (rint, 2097152.75, 2097152.0);
11424 TEST_f_f (rint, -1048576.75, -1048576.0);
11425 TEST_f_f (rint, -2097152.75, -2097152.0);
11426#ifndef TEST_FLOAT
11427 TEST_f_f (rint, 70368744177664.75, 70368744177664.0);
11428 TEST_f_f (rint, 140737488355328.75, 140737488355328.0);
11429 TEST_f_f (rint, 281474976710656.75, 281474976710656.0);
11430 TEST_f_f (rint, 562949953421312.75, 562949953421312.0);
11431 TEST_f_f (rint, 1125899906842624.75, 1125899906842624.0);
11432 TEST_f_f (rint, -70368744177664.75, -70368744177664.0);
11433 TEST_f_f (rint, -140737488355328.75, -140737488355328.0);
11434 TEST_f_f (rint, -281474976710656.75, -281474976710656.0);
11435 TEST_f_f (rint, -562949953421312.75, -562949953421312.0);
11436 TEST_f_f (rint, -1125899906842624.75, -1125899906842624.0);
11437#endif
5c68d401 11438#ifdef TEST_LDOUBLE
830fce04
RM
11439 /* The result can only be represented in long double. */
11440 TEST_f_f (rint, 4503599627370495.5L, 4503599627370495.0L);
11441 TEST_f_f (rint, 4503599627370496.25L, 4503599627370496.0L);
11442 TEST_f_f (rint, 4503599627370496.5L, 4503599627370496.0L);
11443 TEST_f_f (rint, 4503599627370496.75L, 4503599627370496.0L);
11444 TEST_f_f (rint, 4503599627370497.5L, 4503599627370497.0L);
5c68d401 11445# if LDBL_MANT_DIG > 100
830fce04
RM
11446 TEST_f_f (rint, 4503599627370494.5000000000001L, 4503599627370494.0L);
11447 TEST_f_f (rint, 4503599627370495.5000000000001L, 4503599627370495.0L);
11448 TEST_f_f (rint, 4503599627370496.5000000000001L, 4503599627370496.0L);
5c68d401 11449# endif
830fce04
RM
11450 TEST_f_f (rint, -4503599627370495.5L, -4503599627370495.0L);
11451 TEST_f_f (rint, -4503599627370496.25L, -4503599627370496.0L);
11452 TEST_f_f (rint, -4503599627370496.5L, -4503599627370496.0L);
11453 TEST_f_f (rint, -4503599627370496.75L, -4503599627370496.0L);
11454 TEST_f_f (rint, -4503599627370497.5L, -4503599627370497.0L);
5c68d401 11455# if LDBL_MANT_DIG > 100
830fce04
RM
11456 TEST_f_f (rint, -4503599627370494.5000000000001L, -4503599627370494.0L);
11457 TEST_f_f (rint, -4503599627370495.5000000000001L, -4503599627370495.0L);
11458 TEST_f_f (rint, -4503599627370496.5000000000001L, -4503599627370496.0L);
11459
11460 TEST_f_f (rint, 9007199254740991.0000000000001L, 9007199254740991.0L);
11461 TEST_f_f (rint, 9007199254740992.0000000000001L, 9007199254740992.0L);
11462 TEST_f_f (rint, 9007199254740993.0000000000001L, 9007199254740993.0L);
11463 TEST_f_f (rint, 9007199254740991.5000000000001L, 9007199254740991.0L);
11464 TEST_f_f (rint, 9007199254740992.5000000000001L, 9007199254740992.0L);
11465 TEST_f_f (rint, 9007199254740993.5000000000001L, 9007199254740993.0L);
11466
11467 TEST_f_f (rint, -9007199254740991.0000000000001L, -9007199254740991.0L);
11468 TEST_f_f (rint, -9007199254740992.0000000000001L, -9007199254740992.0L);
11469 TEST_f_f (rint, -9007199254740993.0000000000001L, -9007199254740993.0L);
11470 TEST_f_f (rint, -9007199254740991.5000000000001L, -9007199254740991.0L);
11471 TEST_f_f (rint, -9007199254740992.5000000000001L, -9007199254740992.0L);
11472 TEST_f_f (rint, -9007199254740993.5000000000001L, -9007199254740993.0L);
5c68d401
RM
11473# endif
11474#endif
830fce04 11475 }
4d37c8aa 11476
830fce04 11477 fesetround (save_round_mode);
4d37c8aa
UD
11478
11479 END (rint_towardzero);
11480}
11481
11482static void
11483rint_test_downward (void)
11484{
11485 int save_round_mode;
11486 START (rint_downward);
11487
830fce04 11488 save_round_mode = fegetround ();
4d37c8aa
UD
11489
11490 if (!fesetround (FE_DOWNWARD))
830fce04
RM
11491 {
11492 TEST_f_f (rint, 2.0, 2.0);
11493 TEST_f_f (rint, 1.5, 1.0);
11494 TEST_f_f (rint, 1.0, 1.0);
11495 TEST_f_f (rint, 0.5, 0.0);
11496 TEST_f_f (rint, 0.0, 0.0);
11497 TEST_f_f (rint, minus_zero, minus_zero);
11498 TEST_f_f (rint, -0.5, -1.0);
11499 TEST_f_f (rint, -1.0, -1.0);
11500 TEST_f_f (rint, -1.5, -2.0);
11501 TEST_f_f (rint, -2.0, -2.0);
11502 TEST_f_f (rint, 0.1, 0.0);
11503 TEST_f_f (rint, 0.25, 0.0);
11504 TEST_f_f (rint, 0.625, 0.0);
11505 TEST_f_f (rint, -0.1, -1.0);
11506 TEST_f_f (rint, -0.25, -1.0);
11507 TEST_f_f (rint, -0.625, -1.0);
fe45ce09
JM
11508 TEST_f_f (rint, 1048576.75, 1048576.0);
11509 TEST_f_f (rint, 2097152.75, 2097152.0);
11510 TEST_f_f (rint, -1048576.75, -1048577.0);
11511 TEST_f_f (rint, -2097152.75, -2097153.0);
11512#ifndef TEST_FLOAT
11513 TEST_f_f (rint, 70368744177664.75, 70368744177664.0);
11514 TEST_f_f (rint, 140737488355328.75, 140737488355328.0);
11515 TEST_f_f (rint, 281474976710656.75, 281474976710656.0);
11516 TEST_f_f (rint, 562949953421312.75, 562949953421312.0);
11517 TEST_f_f (rint, 1125899906842624.75, 1125899906842624.0);
11518 TEST_f_f (rint, -70368744177664.75, -70368744177665.0);
11519 TEST_f_f (rint, -140737488355328.75, -140737488355329.0);
11520 TEST_f_f (rint, -281474976710656.75, -281474976710657.0);
11521 TEST_f_f (rint, -562949953421312.75, -562949953421313.0);
11522 TEST_f_f (rint, -1125899906842624.75, -1125899906842625.0);
11523#endif
5c68d401 11524#ifdef TEST_LDOUBLE
830fce04
RM
11525 /* The result can only be represented in long double. */
11526 TEST_f_f (rint, 4503599627370495.5L, 4503599627370495.0L);
11527 TEST_f_f (rint, 4503599627370496.25L, 4503599627370496.0L);
11528 TEST_f_f (rint, 4503599627370496.5L, 4503599627370496.0L);
11529 TEST_f_f (rint, 4503599627370496.75L, 4503599627370496.0L);
11530 TEST_f_f (rint, 4503599627370497.5L, 4503599627370497.0L);
5c68d401 11531# if LDBL_MANT_DIG > 100
830fce04
RM
11532 TEST_f_f (rint, 4503599627370494.5000000000001L, 4503599627370494.0L);
11533 TEST_f_f (rint, 4503599627370495.5000000000001L, 4503599627370495.0L);
11534 TEST_f_f (rint, 4503599627370496.5000000000001L, 4503599627370496.0L);
5c68d401 11535# endif
830fce04
RM
11536 TEST_f_f (rint, -4503599627370495.5L, -4503599627370496.0L);
11537 TEST_f_f (rint, -4503599627370496.25L, -4503599627370497.0L);
11538 TEST_f_f (rint, -4503599627370496.5L, -4503599627370497.0L);
11539 TEST_f_f (rint, -4503599627370496.75L, -4503599627370497.0L);
11540 TEST_f_f (rint, -4503599627370497.5L, -4503599627370498.0L);
5c68d401 11541# if LDBL_MANT_DIG > 100
830fce04
RM
11542 TEST_f_f (rint, -4503599627370494.5000000000001L, -4503599627370495.0L);
11543 TEST_f_f (rint, -4503599627370495.5000000000001L, -4503599627370496.0L);
11544 TEST_f_f (rint, -4503599627370496.5000000000001L, -4503599627370497.0L);
11545
11546 TEST_f_f (rint, 9007199254740991.0000000000001L, 9007199254740991.0L);
11547 TEST_f_f (rint, 9007199254740992.0000000000001L, 9007199254740992.0L);
11548 TEST_f_f (rint, 9007199254740993.0000000000001L, 9007199254740993.0L);
11549 TEST_f_f (rint, 9007199254740991.5000000000001L, 9007199254740991.0L);
11550 TEST_f_f (rint, 9007199254740992.5000000000001L, 9007199254740992.0L);
11551 TEST_f_f (rint, 9007199254740993.5000000000001L, 9007199254740993.0L);
11552
11553 TEST_f_f (rint, -9007199254740991.0000000000001L, -9007199254740992.0L);
11554 TEST_f_f (rint, -9007199254740992.0000000000001L, -9007199254740993.0L);
11555 TEST_f_f (rint, -9007199254740993.0000000000001L, -9007199254740994.0L);
11556 TEST_f_f (rint, -9007199254740991.5000000000001L, -9007199254740992.0L);
11557 TEST_f_f (rint, -9007199254740992.5000000000001L, -9007199254740993.0L);
11558 TEST_f_f (rint, -9007199254740993.5000000000001L, -9007199254740994.0L);
5c68d401
RM
11559# endif
11560#endif
830fce04 11561 }
4d37c8aa 11562
830fce04 11563 fesetround (save_round_mode);
4d37c8aa
UD
11564
11565 END (rint_downward);
11566}
11567
11568static void
11569rint_test_upward (void)
11570{
11571 int save_round_mode;
11572 START (rint_upward);
11573
830fce04 11574 save_round_mode = fegetround ();
4d37c8aa
UD
11575
11576 if (!fesetround (FE_UPWARD))
830fce04
RM
11577 {
11578 TEST_f_f (rint, 2.0, 2.0);
11579 TEST_f_f (rint, 1.5, 2.0);
11580 TEST_f_f (rint, 1.0, 1.0);
11581 TEST_f_f (rint, 0.5, 1.0);
11582 TEST_f_f (rint, 0.0, 0.0);
11583 TEST_f_f (rint, minus_zero, minus_zero);
11584 TEST_f_f (rint, -0.5, -0.0);
11585 TEST_f_f (rint, -1.0, -1.0);
11586 TEST_f_f (rint, -1.5, -1.0);
11587 TEST_f_f (rint, -2.0, -2.0);
11588 TEST_f_f (rint, 0.1, 1.0);
11589 TEST_f_f (rint, 0.25, 1.0);
11590 TEST_f_f (rint, 0.625, 1.0);
11591 TEST_f_f (rint, -0.1, -0.0);
11592 TEST_f_f (rint, -0.25, -0.0);
11593 TEST_f_f (rint, -0.625, -0.0);
fe45ce09
JM
11594 TEST_f_f (rint, 1048576.75, 1048577.0);
11595 TEST_f_f (rint, 2097152.75, 2097153.0);
11596 TEST_f_f (rint, -1048576.75, -1048576.0);
11597 TEST_f_f (rint, -2097152.75, -2097152.0);
11598#ifndef TEST_FLOAT
11599 TEST_f_f (rint, 70368744177664.75, 70368744177665.0);
11600 TEST_f_f (rint, 140737488355328.75, 140737488355329.0);
11601 TEST_f_f (rint, 281474976710656.75, 281474976710657.0);
11602 TEST_f_f (rint, 562949953421312.75, 562949953421313.0);
11603 TEST_f_f (rint, 1125899906842624.75, 1125899906842625.0);
11604 TEST_f_f (rint, -70368744177664.75, -70368744177664.0);
11605 TEST_f_f (rint, -140737488355328.75, -140737488355328.0);
11606 TEST_f_f (rint, -281474976710656.75, -281474976710656.0);
11607 TEST_f_f (rint, -562949953421312.75, -562949953421312.0);
11608 TEST_f_f (rint, -1125899906842624.75, -1125899906842624.0);
11609#endif
5c68d401 11610#ifdef TEST_LDOUBLE
830fce04
RM
11611 /* The result can only be represented in long double. */
11612 TEST_f_f (rint, 4503599627370495.5L, 4503599627370496.0L);
11613 TEST_f_f (rint, 4503599627370496.25L, 4503599627370497.0L);
11614 TEST_f_f (rint, 4503599627370496.5L, 4503599627370497.0L);
11615 TEST_f_f (rint, 4503599627370496.75L, 4503599627370497.0L);
11616 TEST_f_f (rint, 4503599627370497.5L, 4503599627370498.0L);
5c68d401 11617# if LDBL_MANT_DIG > 100
830fce04
RM
11618 TEST_f_f (rint, 4503599627370494.5000000000001L, 4503599627370495.0L);
11619 TEST_f_f (rint, 4503599627370495.5000000000001L, 4503599627370496.0L);
11620 TEST_f_f (rint, 4503599627370496.5000000000001L, 4503599627370497.0L);
5c68d401 11621# endif
830fce04
RM
11622 TEST_f_f (rint, -4503599627370495.5L, -4503599627370495.0L);
11623 TEST_f_f (rint, -4503599627370496.25L, -4503599627370496.0L);
11624 TEST_f_f (rint, -4503599627370496.5L, -4503599627370496.0L);
11625 TEST_f_f (rint, -4503599627370496.75L, -4503599627370496.0L);
11626 TEST_f_f (rint, -4503599627370497.5L, -4503599627370497.0L);
5c68d401 11627# if LDBL_MANT_DIG > 100
830fce04
RM
11628 TEST_f_f (rint, -4503599627370494.5000000000001L, -4503599627370494.0L);
11629 TEST_f_f (rint, -4503599627370495.5000000000001L, -4503599627370495.0L);
11630 TEST_f_f (rint, -4503599627370496.5000000000001L, -4503599627370496.0L);
11631
11632 TEST_f_f (rint, 9007199254740991.0000000000001L, 9007199254740992.0L);
11633 TEST_f_f (rint, 9007199254740992.0000000000001L, 9007199254740993.0L);
11634 TEST_f_f (rint, 9007199254740993.0000000000001L, 9007199254740994.0L);
11635 TEST_f_f (rint, 9007199254740991.5000000000001L, 9007199254740992.0L);
11636 TEST_f_f (rint, 9007199254740992.5000000000001L, 9007199254740993.0L);
11637 TEST_f_f (rint, 9007199254740993.5000000000001L, 9007199254740994.0L);
11638
11639 TEST_f_f (rint, -9007199254740991.0000000000001L, -9007199254740991.0L);
11640 TEST_f_f (rint, -9007199254740992.0000000000001L, -9007199254740992.0L);
11641 TEST_f_f (rint, -9007199254740993.0000000000001L, -9007199254740993.0L);
11642 TEST_f_f (rint, -9007199254740991.5000000000001L, -9007199254740991.0L);
11643 TEST_f_f (rint, -9007199254740992.5000000000001L, -9007199254740992.0L);
11644 TEST_f_f (rint, -9007199254740993.5000000000001L, -9007199254740993.0L);
5c68d401
RM
11645# endif
11646#endif
830fce04 11647 }
4d37c8aa 11648
830fce04 11649 fesetround (save_round_mode);
4d37c8aa
UD
11650
11651 END (rint_upward);
11652}
11653
8847214f
UD
11654static void
11655round_test (void)
11656{
64d063b8
TS
11657 /* TODO: missing +/-Inf as well as qNaN tests. */
11658
8847214f
UD
11659 START (round);
11660
11661 TEST_f_f (round, 0, 0);
11662 TEST_f_f (round, minus_zero, minus_zero);
3c6cad26
UD
11663 TEST_f_f (round, 0.2L, 0.0);
11664 TEST_f_f (round, -0.2L, minus_zero);
8847214f
UD
11665 TEST_f_f (round, 0.5, 1.0);
11666 TEST_f_f (round, -0.5, -1.0);
3c6cad26
UD
11667 TEST_f_f (round, 0.8L, 1.0);
11668 TEST_f_f (round, -0.8L, -1.0);
8847214f
UD
11669 TEST_f_f (round, 1.5, 2.0);
11670 TEST_f_f (round, -1.5, -2.0);
5c68d401
RM
11671 TEST_f_f (round, 0.1, 0.0);
11672 TEST_f_f (round, 0.25, 0.0);
11673 TEST_f_f (round, 0.625, 1.0);
11674 TEST_f_f (round, -0.1, -0.0);
11675 TEST_f_f (round, -0.25, -0.0);
11676 TEST_f_f (round, -0.625, -1.0);
8847214f
UD
11677 TEST_f_f (round, 2097152.5, 2097153);
11678 TEST_f_f (round, -2097152.5, -2097153);
11679
f964490f
RM
11680#ifdef TEST_LDOUBLE
11681 /* The result can only be represented in long double. */
11682 TEST_f_f (round, 4503599627370495.5L, 4503599627370496.0L);
11683 TEST_f_f (round, 4503599627370496.25L, 4503599627370496.0L);
830fce04 11684 TEST_f_f (round, 4503599627370496.5L, 4503599627370497.0L);
f964490f 11685 TEST_f_f (round, 4503599627370496.75L, 4503599627370497.0L);
5c68d401
RM
11686 TEST_f_f (round, 4503599627370497.5L, 4503599627370498.0L);
11687# if LDBL_MANT_DIG > 100
11688 TEST_f_f (round, 4503599627370494.5000000000001L, 4503599627370495.0L);
11689 TEST_f_f (round, 4503599627370495.5000000000001L, 4503599627370496.0L);
11690 TEST_f_f (round, 4503599627370496.5000000000001L, 4503599627370497.0L);
11691# endif
f964490f 11692
830fce04
RM
11693 TEST_f_f (round, -4503599627370495.5L, -4503599627370496.0L);
11694 TEST_f_f (round, -4503599627370496.25L, -4503599627370496.0L);
f964490f 11695 TEST_f_f (round, -4503599627370496.5L, -4503599627370497.0L);
830fce04 11696 TEST_f_f (round, -4503599627370496.75L, -4503599627370497.0L);
f964490f 11697 TEST_f_f (round, -4503599627370497.5L, -4503599627370498.0L);
5c68d401
RM
11698# if LDBL_MANT_DIG > 100
11699 TEST_f_f (round, -4503599627370494.5000000000001L, -4503599627370495.0L);
11700 TEST_f_f (round, -4503599627370495.5000000000001L, -4503599627370496.0L);
11701 TEST_f_f (round, -4503599627370496.5000000000001L, -4503599627370497.0L);
11702# endif
f964490f
RM
11703
11704 TEST_f_f (round, 9007199254740991.5L, 9007199254740992.0L);
11705 TEST_f_f (round, 9007199254740992.25L, 9007199254740992.0L);
11706 TEST_f_f (round, 9007199254740992.5L, 9007199254740993.0L);
11707 TEST_f_f (round, 9007199254740992.75L, 9007199254740993.0L);
11708 TEST_f_f (round, 9007199254740993.5L, 9007199254740994.0L);
11709
11710 TEST_f_f (round, -9007199254740991.5L, -9007199254740992.0L);
11711 TEST_f_f (round, -9007199254740992.25L, -9007199254740992.0L);
11712 TEST_f_f (round, -9007199254740992.5L, -9007199254740993.0L);
11713 TEST_f_f (round, -9007199254740992.75L, -9007199254740993.0L);
11714 TEST_f_f (round, -9007199254740993.5L, -9007199254740994.0L);
11715
5c68d401
RM
11716# if LDBL_MANT_DIG > 100
11717 TEST_f_f (round, 9007199254740991.0000000000001L, 9007199254740991.0L);
11718 TEST_f_f (round, 9007199254740992.0000000000001L, 9007199254740992.0L);
11719 TEST_f_f (round, 9007199254740993.0000000000001L, 9007199254740993.0L);
11720 TEST_f_f (round, 9007199254740991.5000000000001L, 9007199254740992.0L);
11721 TEST_f_f (round, 9007199254740992.5000000000001L, 9007199254740993.0L);
11722 TEST_f_f (round, 9007199254740993.5000000000001L, 9007199254740994.0L);
11723
11724 TEST_f_f (round, -9007199254740991.0000000000001L, -9007199254740991.0L);
11725 TEST_f_f (round, -9007199254740992.0000000000001L, -9007199254740992.0L);
11726 TEST_f_f (round, -9007199254740993.0000000000001L, -9007199254740993.0L);
11727 TEST_f_f (round, -9007199254740991.5000000000001L, -9007199254740992.0L);
11728 TEST_f_f (round, -9007199254740992.5000000000001L, -9007199254740993.0L);
11729 TEST_f_f (round, -9007199254740993.5000000000001L, -9007199254740994.0L);
11730# endif
11731
f964490f
RM
11732 TEST_f_f (round, 72057594037927935.5L, 72057594037927936.0L);
11733 TEST_f_f (round, 72057594037927936.25L, 72057594037927936.0L);
11734 TEST_f_f (round, 72057594037927936.5L, 72057594037927937.0L);
11735 TEST_f_f (round, 72057594037927936.75L, 72057594037927937.0L);
11736 TEST_f_f (round, 72057594037927937.5L, 72057594037927938.0L);
11737
11738 TEST_f_f (round, -72057594037927935.5L, -72057594037927936.0L);
11739 TEST_f_f (round, -72057594037927936.25L, -72057594037927936.0L);
11740 TEST_f_f (round, -72057594037927936.5L, -72057594037927937.0L);
11741 TEST_f_f (round, -72057594037927936.75L, -72057594037927937.0L);
11742 TEST_f_f (round, -72057594037927937.5L, -72057594037927938.0L);
11743
11744 TEST_f_f (round, 10141204801825835211973625643007.5L, 10141204801825835211973625643008.0L);
11745 TEST_f_f (round, 10141204801825835211973625643008.25L, 10141204801825835211973625643008.0L);
11746 TEST_f_f (round, 10141204801825835211973625643008.5L, 10141204801825835211973625643009.0L);
11747 TEST_f_f (round, 10141204801825835211973625643008.75L, 10141204801825835211973625643009.0L);
11748 TEST_f_f (round, 10141204801825835211973625643009.5L, 10141204801825835211973625643010.0L);
11749#endif
11750
8847214f
UD
11751 END (round);
11752}
11753
11754
11755static void
11756scalb_test (void)
11757{
11758
11759 START (scalb);
11760
67e971f1
TS
11761 TEST_ff_f (scalb, 2.0, 0.5, qnan_value, INVALID_EXCEPTION);
11762 TEST_ff_f (scalb, 3.0, -2.5, qnan_value, INVALID_EXCEPTION);
8847214f 11763
67e971f1
TS
11764 TEST_ff_f (scalb, 0, qnan_value, qnan_value);
11765 TEST_ff_f (scalb, 1, qnan_value, qnan_value);
8847214f
UD
11766
11767 TEST_ff_f (scalb, 1, 0, 1);
11768 TEST_ff_f (scalb, -1, 0, -1);
11769
67e971f1
TS
11770 TEST_ff_f (scalb, 0, plus_infty, qnan_value, INVALID_EXCEPTION);
11771 TEST_ff_f (scalb, minus_zero, plus_infty, qnan_value, INVALID_EXCEPTION);
8847214f
UD
11772
11773 TEST_ff_f (scalb, 0, 2, 0);
11774 TEST_ff_f (scalb, minus_zero, -4, minus_zero);
11775 TEST_ff_f (scalb, 0, 0, 0);
11776 TEST_ff_f (scalb, minus_zero, 0, minus_zero);
11777 TEST_ff_f (scalb, 0, -1, 0);
11778 TEST_ff_f (scalb, minus_zero, -10, minus_zero);
11779 TEST_ff_f (scalb, 0, minus_infty, 0);
11780 TEST_ff_f (scalb, minus_zero, minus_infty, minus_zero);
11781
11782 TEST_ff_f (scalb, plus_infty, -1, plus_infty);
11783 TEST_ff_f (scalb, minus_infty, -10, minus_infty);
11784 TEST_ff_f (scalb, plus_infty, 0, plus_infty);
11785 TEST_ff_f (scalb, minus_infty, 0, minus_infty);
11786 TEST_ff_f (scalb, plus_infty, 2, plus_infty);
11787 TEST_ff_f (scalb, minus_infty, 100, minus_infty);
11788
3c6cad26
UD
11789 TEST_ff_f (scalb, 0.1L, minus_infty, 0.0);
11790 TEST_ff_f (scalb, -0.1L, minus_infty, minus_zero);
8847214f
UD
11791
11792 TEST_ff_f (scalb, 1, plus_infty, plus_infty);
11793 TEST_ff_f (scalb, -1, plus_infty, minus_infty);
11794 TEST_ff_f (scalb, plus_infty, plus_infty, plus_infty);
11795 TEST_ff_f (scalb, minus_infty, plus_infty, minus_infty);
11796
67e971f1
TS
11797 TEST_ff_f (scalb, plus_infty, minus_infty, qnan_value, INVALID_EXCEPTION);
11798 TEST_ff_f (scalb, minus_infty, minus_infty, qnan_value, INVALID_EXCEPTION);
8847214f 11799
67e971f1
TS
11800 TEST_ff_f (scalb, qnan_value, 1, qnan_value);
11801 TEST_ff_f (scalb, 1, qnan_value, qnan_value);
11802 TEST_ff_f (scalb, qnan_value, 0, qnan_value);
11803 TEST_ff_f (scalb, 0, qnan_value, qnan_value);
11804 TEST_ff_f (scalb, qnan_value, plus_infty, qnan_value);
11805 TEST_ff_f (scalb, plus_infty, qnan_value, qnan_value);
11806 TEST_ff_f (scalb, qnan_value, qnan_value, qnan_value);
8847214f
UD
11807
11808 TEST_ff_f (scalb, 0.8L, 4, 12.8L);
11809 TEST_ff_f (scalb, -0.854375L, 5, -27.34L);
11810
11811 END (scalb);
11812}
11813
11814
11815static void
11816scalbn_test (void)
11817{
11818
11819 START (scalbn);
11820
11821 TEST_fi_f (scalbn, 0, 0, 0);
11822 TEST_fi_f (scalbn, minus_zero, 0, minus_zero);
11823
11824 TEST_fi_f (scalbn, plus_infty, 1, plus_infty);
11825 TEST_fi_f (scalbn, minus_infty, 1, minus_infty);
67e971f1 11826 TEST_fi_f (scalbn, qnan_value, 1, qnan_value);
8847214f
UD
11827
11828 TEST_fi_f (scalbn, 0.8L, 4, 12.8L);
11829 TEST_fi_f (scalbn, -0.854375L, 5, -27.34L);
11830
11831 TEST_fi_f (scalbn, 1, 0L, 1);
11832
c135cc1b 11833 TEST_fi_f (scalbn, 1, INT_MAX, plus_infty, OVERFLOW_EXCEPTION);
80bad0cc 11834 TEST_fi_f (scalbn, 1, INT_MIN, plus_zero, UNDERFLOW_EXCEPTION);
c135cc1b 11835 TEST_fi_f (scalbn, max_value, INT_MAX, plus_infty, OVERFLOW_EXCEPTION);
80bad0cc 11836 TEST_fi_f (scalbn, max_value, INT_MIN, plus_zero, UNDERFLOW_EXCEPTION);
c135cc1b 11837 TEST_fi_f (scalbn, min_value, INT_MAX, plus_infty, OVERFLOW_EXCEPTION);
80bad0cc 11838 TEST_fi_f (scalbn, min_value, INT_MIN, plus_zero, UNDERFLOW_EXCEPTION);
c135cc1b 11839 TEST_fi_f (scalbn, min_value / 4, INT_MAX, plus_infty, OVERFLOW_EXCEPTION);
80bad0cc 11840 TEST_fi_f (scalbn, min_value / 4, INT_MIN, plus_zero, UNDERFLOW_EXCEPTION);
a6d06d7b 11841
8847214f
UD
11842 END (scalbn);
11843}
11844
2550dfe9 11845
8847214f
UD
11846static void
11847scalbln_test (void)
11848{
11849
11850 START (scalbln);
11851
11852 TEST_fl_f (scalbln, 0, 0, 0);
11853 TEST_fl_f (scalbln, minus_zero, 0, minus_zero);
11854
11855 TEST_fl_f (scalbln, plus_infty, 1, plus_infty);
11856 TEST_fl_f (scalbln, minus_infty, 1, minus_infty);
67e971f1 11857 TEST_fl_f (scalbln, qnan_value, 1, qnan_value);
8847214f
UD
11858
11859 TEST_fl_f (scalbln, 0.8L, 4, 12.8L);
11860 TEST_fl_f (scalbln, -0.854375L, 5, -27.34L);
11861
11862 TEST_fl_f (scalbln, 1, 0L, 1);
11863
c135cc1b 11864 TEST_fi_f (scalbln, 1, INT_MAX, plus_infty, OVERFLOW_EXCEPTION);
80bad0cc 11865 TEST_fi_f (scalbln, 1, INT_MIN, plus_zero, UNDERFLOW_EXCEPTION);
c135cc1b 11866 TEST_fi_f (scalbln, max_value, INT_MAX, plus_infty, OVERFLOW_EXCEPTION);
80bad0cc 11867 TEST_fi_f (scalbln, max_value, INT_MIN, plus_zero, UNDERFLOW_EXCEPTION);
c135cc1b 11868 TEST_fi_f (scalbln, min_value, INT_MAX, plus_infty, OVERFLOW_EXCEPTION);
80bad0cc 11869 TEST_fi_f (scalbln, min_value, INT_MIN, plus_zero, UNDERFLOW_EXCEPTION);
c135cc1b 11870 TEST_fi_f (scalbln, min_value / 4, INT_MAX, plus_infty, OVERFLOW_EXCEPTION);
80bad0cc 11871 TEST_fi_f (scalbln, min_value / 4, INT_MIN, plus_zero, UNDERFLOW_EXCEPTION);
a6d06d7b 11872
c135cc1b 11873 TEST_fi_f (scalbln, 1, LONG_MAX, plus_infty, OVERFLOW_EXCEPTION);
80bad0cc 11874 TEST_fi_f (scalbln, 1, LONG_MIN, plus_zero, UNDERFLOW_EXCEPTION);
c135cc1b 11875 TEST_fi_f (scalbln, max_value, LONG_MAX, plus_infty, OVERFLOW_EXCEPTION);
80bad0cc 11876 TEST_fi_f (scalbln, max_value, LONG_MIN, plus_zero, UNDERFLOW_EXCEPTION);
c135cc1b 11877 TEST_fi_f (scalbln, min_value, LONG_MAX, plus_infty, OVERFLOW_EXCEPTION);
80bad0cc 11878 TEST_fi_f (scalbln, min_value, LONG_MIN, plus_zero, UNDERFLOW_EXCEPTION);
c135cc1b 11879 TEST_fi_f (scalbln, min_value / 4, LONG_MAX, plus_infty, OVERFLOW_EXCEPTION);
80bad0cc 11880 TEST_fi_f (scalbln, min_value / 4, LONG_MIN, plus_zero, UNDERFLOW_EXCEPTION);
a6d06d7b
JM
11881
11882#if LONG_MAX >= 0x100000000
c135cc1b 11883 TEST_fi_f (scalbln, 1, 0x88000000L, plus_infty, OVERFLOW_EXCEPTION);
80bad0cc 11884 TEST_fi_f (scalbln, 1, -0x88000000L, plus_zero, UNDERFLOW_EXCEPTION);
c135cc1b 11885 TEST_fi_f (scalbln, max_value, 0x88000000L, plus_infty, OVERFLOW_EXCEPTION);
80bad0cc 11886 TEST_fi_f (scalbln, max_value, -0x88000000L, plus_zero, UNDERFLOW_EXCEPTION);
c135cc1b 11887 TEST_fi_f (scalbln, min_value, 0x88000000L, plus_infty, OVERFLOW_EXCEPTION);
80bad0cc 11888 TEST_fi_f (scalbln, min_value, -0x88000000L, plus_zero, UNDERFLOW_EXCEPTION);
c135cc1b 11889 TEST_fi_f (scalbln, min_value / 4, 0x88000000L, plus_infty, OVERFLOW_EXCEPTION);
80bad0cc 11890 TEST_fi_f (scalbln, min_value / 4, -0x88000000L, plus_zero, UNDERFLOW_EXCEPTION);
a6d06d7b
JM
11891#endif
11892
8847214f
UD
11893 END (scalbn);
11894}
11895
2550dfe9 11896
8847214f
UD
11897static void
11898signbit_test (void)
11899{
64d063b8 11900 /* TODO: missing qNaN tests. */
8847214f
UD
11901
11902 START (signbit);
11903
11904 TEST_f_b (signbit, 0, 0);
11905 TEST_f_b (signbit, minus_zero, 1);
11906 TEST_f_b (signbit, plus_infty, 0);
11907 TEST_f_b (signbit, minus_infty, 1);
11908
11909 /* signbit (x) != 0 for x < 0. */
11910 TEST_f_b (signbit, -1, 1);
11911 /* signbit (x) == 0 for x >= 0. */
11912 TEST_f_b (signbit, 1, 0);
11913
11914 END (signbit);
11915}
11916
2550dfe9 11917
8847214f
UD
11918static void
11919sin_test (void)
11920{
e6d3c4a7
AJ
11921 errno = 0;
11922 FUNC(sin) (0);
11923 if (errno == ENOSYS)
11924 /* Function not implemented. */
11925 return;
11926
8847214f
UD
11927 START (sin);
11928
11929 TEST_f_f (sin, 0, 0);
11930 TEST_f_f (sin, minus_zero, minus_zero);
0c59a196 11931 errno = 0;
67e971f1 11932 TEST_f_f (sin, plus_infty, qnan_value, INVALID_EXCEPTION);
0c59a196
UD
11933 check_int ("errno for sin(+inf) == EDOM", errno, EDOM, 0, 0, 0);
11934 errno = 0;
67e971f1 11935 TEST_f_f (sin, minus_infty, qnan_value, INVALID_EXCEPTION);
0c59a196
UD
11936 check_int ("errno for sin(-inf) == EDOM", errno, EDOM, 0, 0, 0);
11937 errno = 0;
67e971f1
TS
11938 TEST_f_f (sin, qnan_value, qnan_value);
11939 check_int ("errno for sin(qNaN) unchanged", errno, 0, 0, 0, 0);
8847214f
UD
11940
11941 TEST_f_f (sin, M_PI_6l, 0.5);
11942 TEST_f_f (sin, -M_PI_6l, -0.5);
11943 TEST_f_f (sin, M_PI_2l, 1);
11944 TEST_f_f (sin, -M_PI_2l, -1);
2550dfe9 11945 TEST_f_f (sin, 0.75L, 0.681638760023334166733241952779893935L);
8847214f 11946
ea40808a
AJ
11947 TEST_f_f (sin, 0x1p65, -0.047183876212354673805106149805700013943218L);
11948 TEST_f_f (sin, -0x1p65, 0.047183876212354673805106149805700013943218L);
8c0247db 11949
7a845b2c
JM
11950 TEST_f_f (sin, 0x1.7f4134p+103, -6.6703229329788657073304190650534846045235e-08L);
11951
d32e4346
RM
11952#ifdef TEST_DOUBLE
11953 TEST_f_f (sin, 0.80190127184058835, 0.71867942238767868);
cb95113e 11954 TEST_f_f (sin, 2.522464e-1, 2.4957989804940911e-1);
8848d99d
JM
11955#endif
11956
11957#ifndef TEST_FLOAT
11958 TEST_f_f (sin, 1e22, -0.8522008497671888017727058937530293682618L);
11959 TEST_f_f (sin, 0x1p1023, 0.5631277798508840134529434079444683477104L);
11960#endif
11961
11962#if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
11963 TEST_f_f (sin, 0x1p16383L, 0.3893629985894208126948115852610595405563L);
d32e4346
RM
11964#endif
11965
4ffffbd2
LD
11966 TEST_f_f (sin, 0x1p+120, 3.77820109360752022655548470056922991960587e-01L);
11967 TEST_f_f (sin, 0x1p+127, 6.23385512955870240370428801097126489001833e-01L);
11968 TEST_f_f (sin, 0x1.fffff8p+127, 4.85786063130487339701113680434728152037092e-02L);
11969 TEST_f_f (sin, 0x1.fffffep+127, -5.21876523333658540551505357019806722935726e-01L);
11970 TEST_f_f (sin, 0x1p+50, 4.96396515208940840876821859865411368093356e-01L);
11971 TEST_f_f (sin, 0x1p+28, -9.86198211836975655703110310527108292055548e-01L);
11972
8847214f
UD
11973 END (sin);
11974
11975}
11976
2550dfe9 11977
804360ed
JM
11978static void
11979sin_test_tonearest (void)
11980{
11981 int save_round_mode;
11982 errno = 0;
11983 FUNC(sin) (0);
11984 if (errno == ENOSYS)
11985 /* Function not implemented. */
11986 return;
11987
11988 START (sin_tonearest);
11989
11990 save_round_mode = fegetround ();
11991
11992 if (!fesetround (FE_TONEAREST))
11993 {
11994 TEST_f_f (sin, 1, 0.8414709848078965066525023216302989996226L);
11995 TEST_f_f (sin, 2, 0.9092974268256816953960198659117448427023L);
11996 TEST_f_f (sin, 3, 0.1411200080598672221007448028081102798469L);
11997 TEST_f_f (sin, 4, -0.7568024953079282513726390945118290941359L);
11998 TEST_f_f (sin, 5, -0.9589242746631384688931544061559939733525L);
11999 TEST_f_f (sin, 6, -0.2794154981989258728115554466118947596280L);
12000 TEST_f_f (sin, 7, 0.6569865987187890903969990915936351779369L);
12001 TEST_f_f (sin, 8, 0.9893582466233817778081235982452886721164L);
12002 TEST_f_f (sin, 9, 0.4121184852417565697562725663524351793439L);
12003 TEST_f_f (sin, 10, -0.5440211108893698134047476618513772816836L);
12004 }
12005
12006 fesetround (save_round_mode);
12007
12008 END (sin_tonearest);
12009}
12010
12011
12012static void
12013sin_test_towardzero (void)
12014{
12015 int save_round_mode;
12016 errno = 0;
12017 FUNC(sin) (0);
12018 if (errno == ENOSYS)
12019 /* Function not implemented. */
12020 return;
12021
12022 START (sin_towardzero);
12023
12024 save_round_mode = fegetround ();
12025
12026 if (!fesetround (FE_TOWARDZERO))
12027 {
12028 TEST_f_f (sin, 1, 0.8414709848078965066525023216302989996226L);
12029 TEST_f_f (sin, 2, 0.9092974268256816953960198659117448427023L);
12030 TEST_f_f (sin, 3, 0.1411200080598672221007448028081102798469L);
12031 TEST_f_f (sin, 4, -0.7568024953079282513726390945118290941359L);
12032 TEST_f_f (sin, 5, -0.9589242746631384688931544061559939733525L);
12033 TEST_f_f (sin, 6, -0.2794154981989258728115554466118947596280L);
12034 TEST_f_f (sin, 7, 0.6569865987187890903969990915936351779369L);
12035 TEST_f_f (sin, 8, 0.9893582466233817778081235982452886721164L);
12036 TEST_f_f (sin, 9, 0.4121184852417565697562725663524351793439L);
12037 TEST_f_f (sin, 10, -0.5440211108893698134047476618513772816836L);
12038 }
12039
12040 fesetround (save_round_mode);
12041
12042 END (sin_towardzero);
12043}
12044
12045
12046static void
12047sin_test_downward (void)
12048{
12049 int save_round_mode;
12050 errno = 0;
12051 FUNC(sin) (0);
12052 if (errno == ENOSYS)
12053 /* Function not implemented. */
12054 return;
12055
12056 START (sin_downward);
12057
12058 save_round_mode = fegetround ();
12059
12060 if (!fesetround (FE_DOWNWARD))
12061 {
12062 TEST_f_f (sin, 1, 0.8414709848078965066525023216302989996226L);
12063 TEST_f_f (sin, 2, 0.9092974268256816953960198659117448427023L);
12064 TEST_f_f (sin, 3, 0.1411200080598672221007448028081102798469L);
12065 TEST_f_f (sin, 4, -0.7568024953079282513726390945118290941359L);
12066 TEST_f_f (sin, 5, -0.9589242746631384688931544061559939733525L);
12067 TEST_f_f (sin, 6, -0.2794154981989258728115554466118947596280L);
12068 TEST_f_f (sin, 7, 0.6569865987187890903969990915936351779369L);
12069 TEST_f_f (sin, 8, 0.9893582466233817778081235982452886721164L);
12070 TEST_f_f (sin, 9, 0.4121184852417565697562725663524351793439L);
12071 TEST_f_f (sin, 10, -0.5440211108893698134047476618513772816836L);
12072 }
12073
12074 fesetround (save_round_mode);
12075
12076 END (sin_downward);
12077}
12078
12079
12080static void
12081sin_test_upward (void)
12082{
12083 int save_round_mode;
12084 errno = 0;
12085 FUNC(sin) (0);
12086 if (errno == ENOSYS)
12087 /* Function not implemented. */
12088 return;
12089
12090 START (sin_upward);
12091
12092 save_round_mode = fegetround ();
12093
12094 if (!fesetround (FE_UPWARD))
12095 {
12096 TEST_f_f (sin, 1, 0.8414709848078965066525023216302989996226L);
12097 TEST_f_f (sin, 2, 0.9092974268256816953960198659117448427023L);
12098 TEST_f_f (sin, 3, 0.1411200080598672221007448028081102798469L);
12099 TEST_f_f (sin, 4, -0.7568024953079282513726390945118290941359L);
12100 TEST_f_f (sin, 5, -0.9589242746631384688931544061559939733525L);
12101 TEST_f_f (sin, 6, -0.2794154981989258728115554466118947596280L);
12102 TEST_f_f (sin, 7, 0.6569865987187890903969990915936351779369L);
12103 TEST_f_f (sin, 8, 0.9893582466233817778081235982452886721164L);
12104 TEST_f_f (sin, 9, 0.4121184852417565697562725663524351793439L);
12105 TEST_f_f (sin, 10, -0.5440211108893698134047476618513772816836L);
12106 }
12107
12108 fesetround (save_round_mode);
12109
12110 END (sin_upward);
12111}
12112
12113
8847214f
UD
12114static void
12115sincos_test (void)
12116{
12117 FLOAT sin_res, cos_res;
12118
aaca11d8
UD
12119 errno = 0;
12120 FUNC(sincos) (0, &sin_res, &cos_res);
12121 if (errno == ENOSYS)
12122 /* Function not implemented. */
12123 return;
12124
8847214f
UD
12125 START (sincos);
12126
12127 /* sincos is treated differently because it returns void. */
12128 TEST_extra (sincos, 0, 0, 1);
12129
12130 TEST_extra (sincos, minus_zero, minus_zero, 1);
67e971f1
TS
12131 TEST_extra (sincos, plus_infty, qnan_value, qnan_value, INVALID_EXCEPTION);
12132 TEST_extra (sincos, minus_infty, qnan_value, qnan_value, INVALID_EXCEPTION);
12133 TEST_extra (sincos, qnan_value, qnan_value, qnan_value);
8847214f
UD
12134
12135 TEST_extra (sincos, M_PI_2l, 1, 0);
3c6cad26
UD
12136 TEST_extra (sincos, M_PI_6l, 0.5, 0.86602540378443864676372317075293616L);
12137 TEST_extra (sincos, M_PI_6l*2.0, 0.86602540378443864676372317075293616L, 0.5);
2550dfe9 12138 TEST_extra (sincos, 0.75L, 0.681638760023334166733241952779893935L, 0.731688868873820886311838753000084544L);
8847214f 12139
ea40808a
AJ
12140 TEST_extra (sincos, 0x1p65, -0.047183876212354673805106149805700013943218L, 0.99888622066058013610642172179340364209972L);
12141 TEST_extra (sincos, -0x1p65, 0.047183876212354673805106149805700013943218L, 0.99888622066058013610642172179340364209972L);
8c0247db 12142
d32e4346
RM
12143#ifdef TEST_DOUBLE
12144 TEST_extra (sincos, 0.80190127184058835, 0.71867942238767868, 0.69534156199418473);
8848d99d
JM
12145#endif
12146
12147#ifndef TEST_FLOAT
12148 TEST_extra (sincos, 1e22, -0.8522008497671888017727058937530293682618L, 0.5232147853951389454975944733847094921409L);
12149 TEST_extra (sincos, 0x1p1023, 0.5631277798508840134529434079444683477104L, -0.826369834614147994500785680811743734805L);
12150#endif
12151
12152#if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
12153 TEST_extra (sincos, 0x1p16383L, 0.3893629985894208126948115852610595405563L, 0.9210843909921906206874509522505756251609L);
d32e4346
RM
12154#endif
12155
4ffffbd2
LD
12156 TEST_extra (sincos, 0x1p+120, 3.77820109360752022655548470056922991960587e-01L, -9.25879022854837867303861764107414946730833e-01L);
12157 TEST_extra (sincos, 0x1p+127, 6.23385512955870240370428801097126489001833e-01L, 7.81914638714960072263910298466369236613162e-01L);
12158 TEST_extra (sincos, 0x1.fffff8p+127, 4.85786063130487339701113680434728152037092e-02L, 9.98819362551949040703862043664101081064641e-01L);
12159 TEST_extra (sincos, 0x1.fffffep+127, -5.21876523333658540551505357019806722935726e-01L, 8.53021039830304158051791467692161107353094e-01L);
12160 TEST_extra (sincos, 0x1p+50, 4.96396515208940840876821859865411368093356e-01L, 8.68095904660550604334592502063501320395739e-01L);
12161 TEST_extra (sincos, 0x1p+28, -9.86198211836975655703110310527108292055548e-01L, -1.65568979490578758865468278195361551113358e-01L);
12162
8847214f
UD
12163 END (sincos);
12164}
12165
12166static void
12167sinh_test (void)
12168{
aaca11d8 12169 errno = 0;
3c6cad26 12170 FUNC(sinh) (0.7L);
aaca11d8
UD
12171 if (errno == ENOSYS)
12172 /* Function not implemented. */
12173 return;
12174
8847214f
UD
12175 START (sinh);
12176 TEST_f_f (sinh, 0, 0);
12177 TEST_f_f (sinh, minus_zero, minus_zero);
12178
15daa639 12179#ifndef TEST_INLINE
8847214f
UD
12180 TEST_f_f (sinh, plus_infty, plus_infty);
12181 TEST_f_f (sinh, minus_infty, minus_infty);
15daa639 12182#endif
67e971f1 12183 TEST_f_f (sinh, qnan_value, qnan_value);
8847214f 12184
2550dfe9 12185 TEST_f_f (sinh, 0.75L, 0.822316731935829980703661634446913849L);
c9bfaa1b 12186 TEST_f_f (sinh, 0x8p-32L, 1.86264514923095703232705808926175479e-9L);
30e5dcb7 12187
8847214f
UD
12188 END (sinh);
12189}
12190
ca811b22
JM
12191
12192static void
12193sinh_test_tonearest (void)
12194{
12195 int save_round_mode;
12196 errno = 0;
12197 FUNC(sinh) (0);
12198 if (errno == ENOSYS)
12199 /* Function not implemented. */
12200 return;
12201
12202 START (sinh_tonearest);
12203
12204 save_round_mode = fegetround ();
12205
12206 if (!fesetround (FE_TONEAREST))
12207 {
12208 TEST_f_f (sinh, 22, 1792456423.065795780701106568345764104225L);
12209 TEST_f_f (sinh, 23, 4872401723.124451299966006944252978187305L);
12210 TEST_f_f (sinh, 24, 13244561064.92173614705070540368454568168L);
12211 }
12212
12213 fesetround (save_round_mode);
12214
12215 END (sinh_tonearest);
12216}
12217
12218
12219static void
12220sinh_test_towardzero (void)
12221{
12222 int save_round_mode;
12223 errno = 0;
12224 FUNC(sinh) (0);
12225 if (errno == ENOSYS)
12226 /* Function not implemented. */
12227 return;
12228
12229 START (sinh_towardzero);
12230
12231 save_round_mode = fegetround ();
12232
12233 if (!fesetround (FE_TOWARDZERO))
12234 {
12235 TEST_f_f (sinh, 22, 1792456423.065795780701106568345764104225L);
12236 TEST_f_f (sinh, 23, 4872401723.124451299966006944252978187305L);
12237 TEST_f_f (sinh, 24, 13244561064.92173614705070540368454568168L);
12238 }
12239
12240 fesetround (save_round_mode);
12241
12242 END (sinh_towardzero);
12243}
12244
12245
12246static void
12247sinh_test_downward (void)
12248{
12249 int save_round_mode;
12250 errno = 0;
12251 FUNC(sinh) (0);
12252 if (errno == ENOSYS)
12253 /* Function not implemented. */
12254 return;
12255
12256 START (sinh_downward);
12257
12258 save_round_mode = fegetround ();
12259
12260 if (!fesetround (FE_DOWNWARD))
12261 {
12262 TEST_f_f (sinh, 22, 1792456423.065795780701106568345764104225L);
12263 TEST_f_f (sinh, 23, 4872401723.124451299966006944252978187305L);
12264 TEST_f_f (sinh, 24, 13244561064.92173614705070540368454568168L);
12265 }
12266
12267 fesetround (save_round_mode);
12268
12269 END (sinh_downward);
12270}
12271
12272
12273static void
12274sinh_test_upward (void)
12275{
12276 int save_round_mode;
12277 errno = 0;
12278 FUNC(sinh) (0);
12279 if (errno == ENOSYS)
12280 /* Function not implemented. */
12281 return;
12282
12283 START (sinh_upward);
12284
12285 save_round_mode = fegetround ();
12286
12287 if (!fesetround (FE_UPWARD))
12288 {
12289 TEST_f_f (sinh, 22, 1792456423.065795780701106568345764104225L);
12290 TEST_f_f (sinh, 23, 4872401723.124451299966006944252978187305L);
12291 TEST_f_f (sinh, 24, 13244561064.92173614705070540368454568168L);
12292 }
12293
12294 fesetround (save_round_mode);
12295
12296 END (sinh_upward);
12297}
12298
12299
8847214f
UD
12300static void
12301sqrt_test (void)
12302{
e6d3c4a7
AJ
12303 errno = 0;
12304 FUNC(sqrt) (1);
12305 if (errno == ENOSYS)
12306 /* Function not implemented. */
12307 return;
12308
8847214f
UD
12309 START (sqrt);
12310
12311 TEST_f_f (sqrt, 0, 0);
67e971f1 12312 TEST_f_f (sqrt, qnan_value, qnan_value);
8847214f
UD
12313 TEST_f_f (sqrt, plus_infty, plus_infty);
12314
12315 TEST_f_f (sqrt, minus_zero, minus_zero);
12316
67e971f1
TS
12317 /* sqrt (x) == qNaN plus invalid exception for x < 0. */
12318 TEST_f_f (sqrt, -1, qnan_value, INVALID_EXCEPTION);
12319 TEST_f_f (sqrt, -max_value, qnan_value, INVALID_EXCEPTION);
12320 TEST_f_f (sqrt, minus_infty, qnan_value, INVALID_EXCEPTION);
8847214f
UD
12321
12322 TEST_f_f (sqrt, 2209, 47);
12323 TEST_f_f (sqrt, 4, 2);
12324 TEST_f_f (sqrt, 2, M_SQRT2l);
12325 TEST_f_f (sqrt, 0.25, 0.5);
12326 TEST_f_f (sqrt, 6642.25, 81.5);
2550dfe9
AJ
12327 TEST_f_f (sqrt, 15190.5625L, 123.25L);
12328 TEST_f_f (sqrt, 0.75L, 0.866025403784438646763723170752936183L);
8847214f
UD
12329
12330 END (sqrt);
12331}
12332
2550dfe9 12333
8847214f
UD
12334static void
12335tan_test (void)
12336{
e6d3c4a7
AJ
12337 errno = 0;
12338 FUNC(tan) (0);
12339 if (errno == ENOSYS)
12340 /* Function not implemented. */
12341 return;
12342
8847214f
UD
12343 START (tan);
12344
12345 TEST_f_f (tan, 0, 0);
12346 TEST_f_f (tan, minus_zero, minus_zero);
337c2708 12347 errno = 0;
67e971f1 12348 TEST_f_f (tan, plus_infty, qnan_value, INVALID_EXCEPTION);
337c2708
UD
12349 check_int ("errno for tan(Inf) == EDOM", errno, EDOM, 0, 0, 0);
12350 errno = 0;
67e971f1 12351 TEST_f_f (tan, minus_infty, qnan_value, INVALID_EXCEPTION);
337c2708
UD
12352 check_int ("errno for tan(-Inf) == EDOM", errno, EDOM, 0, 0, 0);
12353 errno = 0;
67e971f1
TS
12354 TEST_f_f (tan, qnan_value, qnan_value);
12355 check_int ("errno for tan(qNaN) == 0", errno, 0, 0, 0, 0);
8847214f 12356
9ad63c23 12357 TEST_f_f (tan, M_PI_4l, 1);
2550dfe9 12358 TEST_f_f (tan, 0.75L, 0.931596459944072461165202756573936428L);
8847214f 12359
ea40808a
AJ
12360 TEST_f_f (tan, 0x1p65, -0.0472364872359047946798414219288370688827L);
12361 TEST_f_f (tan, -0x1p65, 0.0472364872359047946798414219288370688827L);
11b90b9f 12362
9ad63c23
JM
12363 TEST_f_f (tan, 0xc.9p-4, 0.9995162902115457818029468900654150261381L);
12364 TEST_f_f (tan, 0xc.908p-4, 0.9997603425502441410973077452249560802034L);
12365 TEST_f_f (tan, 0xc.90cp-4, 0.9998823910588060302788513970802357770031L);
12366 TEST_f_f (tan, 0xc.90ep-4, 0.9999434208994808753305784795924711152508L);
12367 TEST_f_f (tan, 0xc.90fp-4, 0.9999739372166156702433266059635165160515L);
12368 TEST_f_f (tan, 0xc.90f8p-4, 0.9999891957244072765118898375645469865764L);
12369 TEST_f_f (tan, 0xc.90fcp-4, 0.9999968250656122402859679132395522927393L);
12370 TEST_f_f (tan, 0xc.90fdp-4, 0.9999987324100083358016192309006353329444L);
12371 TEST_f_f (tan, 0xc.90fd8p-4, 0.9999996860835706212861509874451585282616L);
12372 TEST_f_f (tan, 0xc.90fdap-4, 0.9999999245021033010474530133665235922808L);
12373 TEST_f_f (tan, 0xc.ap-4, 1.0073556597407272165371804539701396631519L);
12374 TEST_f_f (tan, 0xc.98p-4, 1.0034282930863044654045449407466962736255L);
12375 TEST_f_f (tan, 0xc.94p-4, 1.0014703786820082237342656561856877993328L);
12376 TEST_f_f (tan, 0xc.92p-4, 1.0004928571392300571266638743539017593717L);
12377 TEST_f_f (tan, 0xc.91p-4, 1.0000044544650244953647966900221905361131L);
12378 TEST_f_f (tan, 0xc.90fep-4, 1.0000006397580424009014454926842136804016L);
12379 TEST_f_f (tan, 0xc.90fdcp-4, 1.0000001629206928242190327320047489394217L);
12380 TEST_f_f (tan, 0xc.90fdbp-4, 1.0000000437113909572052640953950483705005L);
12381
12382 TEST_f_f (tan, -0xc.9p-4, -0.9995162902115457818029468900654150261381L);
12383 TEST_f_f (tan, -0xc.908p-4, -0.9997603425502441410973077452249560802034L);
12384 TEST_f_f (tan, -0xc.90cp-4, -0.9998823910588060302788513970802357770031L);
12385 TEST_f_f (tan, -0xc.90ep-4, -0.9999434208994808753305784795924711152508L);
12386 TEST_f_f (tan, -0xc.90fp-4, -0.9999739372166156702433266059635165160515L);
12387 TEST_f_f (tan, -0xc.90f8p-4, -0.9999891957244072765118898375645469865764L);
12388 TEST_f_f (tan, -0xc.90fcp-4, -0.9999968250656122402859679132395522927393L);
12389 TEST_f_f (tan, -0xc.90fdp-4, -0.9999987324100083358016192309006353329444L);
12390 TEST_f_f (tan, -0xc.90fd8p-4, -0.9999996860835706212861509874451585282616L);
12391 TEST_f_f (tan, -0xc.90fdap-4, -0.9999999245021033010474530133665235922808L);
12392 TEST_f_f (tan, -0xc.ap-4, -1.0073556597407272165371804539701396631519L);
12393 TEST_f_f (tan, -0xc.98p-4, -1.0034282930863044654045449407466962736255L);
12394 TEST_f_f (tan, -0xc.94p-4, -1.0014703786820082237342656561856877993328L);
12395 TEST_f_f (tan, -0xc.92p-4, -1.0004928571392300571266638743539017593717L);
12396 TEST_f_f (tan, -0xc.91p-4, -1.0000044544650244953647966900221905361131L);
12397 TEST_f_f (tan, -0xc.90fep-4, -1.0000006397580424009014454926842136804016L);
12398 TEST_f_f (tan, -0xc.90fdcp-4, -1.0000001629206928242190327320047489394217L);
12399 TEST_f_f (tan, -0xc.90fdbp-4, -1.0000000437113909572052640953950483705005L);
12400
11b90b9f
JM
12401#ifndef TEST_FLOAT
12402 TEST_f_f (tan, 1e22, -1.628778225606898878549375936939548513545L);
12403 TEST_f_f (tan, 0x1p1023, -0.6814476476066215012854144040167365190368L);
12404#endif
12405
12406#if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
12407 TEST_f_f (tan, 0x1p16383L, 0.422722393732022337800504160054440141575L);
ee010c9e
AJ
12408#endif
12409
8847214f
UD
12410 END (tan);
12411}
12412
804360ed
JM
12413
12414static void
12415tan_test_tonearest (void)
12416{
12417 int save_round_mode;
12418 errno = 0;
12419 FUNC(tan) (0);
12420 if (errno == ENOSYS)
12421 /* Function not implemented. */
12422 return;
12423
12424 START (tan_tonearest);
12425
12426 save_round_mode = fegetround ();
12427
12428 if (!fesetround (FE_TONEAREST))
12429 {
12430 TEST_f_f (tan, 1, 1.5574077246549022305069748074583601730873L);
12431 TEST_f_f (tan, 2, -2.1850398632615189916433061023136825434320L);
12432 TEST_f_f (tan, 3, -0.1425465430742778052956354105339134932261L);
12433 TEST_f_f (tan, 4, 1.1578212823495775831373424182673239231198L);
12434 TEST_f_f (tan, 5, -3.3805150062465856369827058794473439087096L);
12435 TEST_f_f (tan, 6, -0.2910061913847491570536995888681755428312L);
12436 TEST_f_f (tan, 7, 0.8714479827243187364564508896003135663222L);
12437 TEST_f_f (tan, 8, -6.7997114552203786999252627596086333648814L);
12438 TEST_f_f (tan, 9, -0.4523156594418098405903708757987855343087L);
12439 TEST_f_f (tan, 10, 0.6483608274590866712591249330098086768169L);
12440 }
12441
12442 fesetround (save_round_mode);
12443
12444 END (tan_tonearest);
12445}
12446
12447
12448static void
12449tan_test_towardzero (void)
12450{
12451 int save_round_mode;
12452 errno = 0;
12453 FUNC(tan) (0);
12454 if (errno == ENOSYS)
12455 /* Function not implemented. */
12456 return;
12457
12458 START (tan_towardzero);
12459
12460 save_round_mode = fegetround ();
12461
12462 if (!fesetround (FE_TOWARDZERO))
12463 {
12464 TEST_f_f (tan, 1, 1.5574077246549022305069748074583601730873L);
12465 TEST_f_f (tan, 2, -2.1850398632615189916433061023136825434320L);
12466 TEST_f_f (tan, 3, -0.1425465430742778052956354105339134932261L);
12467 TEST_f_f (tan, 4, 1.1578212823495775831373424182673239231198L);
12468 TEST_f_f (tan, 5, -3.3805150062465856369827058794473439087096L);
12469 TEST_f_f (tan, 6, -0.2910061913847491570536995888681755428312L);
12470 TEST_f_f (tan, 7, 0.8714479827243187364564508896003135663222L);
12471 TEST_f_f (tan, 8, -6.7997114552203786999252627596086333648814L);
12472 TEST_f_f (tan, 9, -0.4523156594418098405903708757987855343087L);
12473 TEST_f_f (tan, 10, 0.6483608274590866712591249330098086768169L);
12474 }
12475
12476 fesetround (save_round_mode);
12477
12478 END (tan_towardzero);
12479}
12480
12481
12482static void
12483tan_test_downward (void)
12484{
12485 int save_round_mode;
12486 errno = 0;
12487 FUNC(tan) (0);
12488 if (errno == ENOSYS)
12489 /* Function not implemented. */
12490 return;
12491
12492 START (tan_downward);
12493
12494 save_round_mode = fegetround ();
12495
12496 if (!fesetround (FE_DOWNWARD))
12497 {
12498 TEST_f_f (tan, 1, 1.5574077246549022305069748074583601730873L);
12499 TEST_f_f (tan, 2, -2.1850398632615189916433061023136825434320L);
12500 TEST_f_f (tan, 3, -0.1425465430742778052956354105339134932261L);
12501 TEST_f_f (tan, 4, 1.1578212823495775831373424182673239231198L);
12502 TEST_f_f (tan, 5, -3.3805150062465856369827058794473439087096L);
12503 TEST_f_f (tan, 6, -0.2910061913847491570536995888681755428312L);
12504 TEST_f_f (tan, 7, 0.8714479827243187364564508896003135663222L);
12505 TEST_f_f (tan, 8, -6.7997114552203786999252627596086333648814L);
12506 TEST_f_f (tan, 9, -0.4523156594418098405903708757987855343087L);
12507 TEST_f_f (tan, 10, 0.6483608274590866712591249330098086768169L);
12508 }
12509
12510 fesetround (save_round_mode);
12511
12512 END (tan_downward);
12513}
12514
12515
12516static void
12517tan_test_upward (void)
12518{
12519 int save_round_mode;
12520 errno = 0;
12521 FUNC(tan) (0);
12522 if (errno == ENOSYS)
12523 /* Function not implemented. */
12524 return;
12525
12526 START (tan_upward);
12527
12528 save_round_mode = fegetround ();
12529
12530 if (!fesetround (FE_UPWARD))
12531 {
12532 TEST_f_f (tan, 1, 1.5574077246549022305069748074583601730873L);
12533 TEST_f_f (tan, 2, -2.1850398632615189916433061023136825434320L);
12534 TEST_f_f (tan, 3, -0.1425465430742778052956354105339134932261L);
12535 TEST_f_f (tan, 4, 1.1578212823495775831373424182673239231198L);
12536 TEST_f_f (tan, 5, -3.3805150062465856369827058794473439087096L);
12537 TEST_f_f (tan, 6, -0.2910061913847491570536995888681755428312L);
12538 TEST_f_f (tan, 7, 0.8714479827243187364564508896003135663222L);
12539 TEST_f_f (tan, 8, -6.7997114552203786999252627596086333648814L);
12540 TEST_f_f (tan, 9, -0.4523156594418098405903708757987855343087L);
12541 TEST_f_f (tan, 10, 0.6483608274590866712591249330098086768169L);
12542 }
12543
12544 fesetround (save_round_mode);
12545
12546 END (tan_upward);
12547}
12548
12549
8847214f
UD
12550static void
12551tanh_test (void)
12552{
aaca11d8 12553 errno = 0;
3c6cad26 12554 FUNC(tanh) (0.7L);
aaca11d8
UD
12555 if (errno == ENOSYS)
12556 /* Function not implemented. */
12557 return;
12558
8847214f
UD
12559 START (tanh);
12560
12561 TEST_f_f (tanh, 0, 0);
12562 TEST_f_f (tanh, minus_zero, minus_zero);
12563
15daa639 12564#ifndef TEST_INLINE
8847214f
UD
12565 TEST_f_f (tanh, plus_infty, 1);
12566 TEST_f_f (tanh, minus_infty, -1);
15daa639 12567#endif
67e971f1 12568 TEST_f_f (tanh, qnan_value, qnan_value);
8847214f 12569
2550dfe9
AJ
12570 TEST_f_f (tanh, 0.75L, 0.635148952387287319214434357312496495L);
12571 TEST_f_f (tanh, -0.75L, -0.635148952387287319214434357312496495L);
3eab00bd
AJ
12572
12573 TEST_f_f (tanh, 1.0L, 0.7615941559557648881194582826047935904L);
12574 TEST_f_f (tanh, -1.0L, -0.7615941559557648881194582826047935904L);
8847214f 12575
30e5dcb7 12576 /* 2^-57 */
2550dfe9 12577 TEST_f_f (tanh, 0x1p-57L, 6.938893903907228377647697925567626953125e-18L);
30e5dcb7 12578
8847214f
UD
12579 END (tanh);
12580}
12581
12582static void
12583tgamma_test (void)
12584{
12585 errno = 0;
12586 FUNC(tgamma) (1);
12587 if (errno == ENOSYS)
12588 /* Function not implemented. */
12589 return;
8847214f
UD
12590
12591 START (tgamma);
12592
12593 TEST_f_f (tgamma, plus_infty, plus_infty);
41bf21a1 12594 TEST_f_f (tgamma, max_value, plus_infty, OVERFLOW_EXCEPTION);
52495f29
UD
12595 TEST_f_f (tgamma, 0, plus_infty, DIVIDE_BY_ZERO_EXCEPTION);
12596 TEST_f_f (tgamma, minus_zero, minus_infty, DIVIDE_BY_ZERO_EXCEPTION);
67e971f1
TS
12597 /* tgamma (x) == qNaN plus invalid exception for integer x <= 0. */
12598 TEST_f_f (tgamma, -2, qnan_value, INVALID_EXCEPTION);
12599 TEST_f_f (tgamma, -max_value, qnan_value, INVALID_EXCEPTION);
12600 TEST_f_f (tgamma, minus_infty, qnan_value, INVALID_EXCEPTION);
12601 TEST_f_f (tgamma, qnan_value, qnan_value);
8847214f
UD
12602
12603 TEST_f_f (tgamma, 0.5, M_SQRT_PIl);
12604 TEST_f_f (tgamma, -0.5, -M_2_SQRT_PIl);
12605
12606 TEST_f_f (tgamma, 1, 1);
12607 TEST_f_f (tgamma, 4, 6);
12608
79df8ce5
AJ
12609 TEST_f_f (tgamma, 0.7L, 1.29805533264755778568117117915281162L);
12610 TEST_f_f (tgamma, 1.2L, 0.918168742399760610640951655185830401L);
8847214f
UD
12611
12612 END (tgamma);
12613}
12614
2550dfe9 12615
8847214f
UD
12616static void
12617trunc_test (void)
12618{
12619 START (trunc);
12620
12621 TEST_f_f (trunc, plus_infty, plus_infty);
12622 TEST_f_f (trunc, minus_infty, minus_infty);
67e971f1 12623 TEST_f_f (trunc, qnan_value, qnan_value);
8847214f
UD
12624
12625 TEST_f_f (trunc, 0, 0);
12626 TEST_f_f (trunc, minus_zero, minus_zero);
5c68d401
RM
12627 TEST_f_f (trunc, 0.1, 0);
12628 TEST_f_f (trunc, 0.25, 0);
8847214f 12629 TEST_f_f (trunc, 0.625, 0);
5c68d401
RM
12630 TEST_f_f (trunc, -0.1, minus_zero);
12631 TEST_f_f (trunc, -0.25, minus_zero);
8847214f
UD
12632 TEST_f_f (trunc, -0.625, minus_zero);
12633 TEST_f_f (trunc, 1, 1);
12634 TEST_f_f (trunc, -1, -1);
12635 TEST_f_f (trunc, 1.625, 1);
12636 TEST_f_f (trunc, -1.625, -1);
12637
12638 TEST_f_f (trunc, 1048580.625L, 1048580L);
12639 TEST_f_f (trunc, -1048580.625L, -1048580L);
12640
12641 TEST_f_f (trunc, 8388610.125L, 8388610.0L);
12642 TEST_f_f (trunc, -8388610.125L, -8388610.0L);
12643
12644 TEST_f_f (trunc, 4294967296.625L, 4294967296.0L);
12645 TEST_f_f (trunc, -4294967296.625L, -4294967296.0L);
12646
f964490f
RM
12647#ifdef TEST_LDOUBLE
12648 /* The result can only be represented in long double. */
12649 TEST_f_f (trunc, 4503599627370495.5L, 4503599627370495.0L);
12650 TEST_f_f (trunc, 4503599627370496.25L, 4503599627370496.0L);
12651 TEST_f_f (trunc, 4503599627370496.5L, 4503599627370496.0L);
12652 TEST_f_f (trunc, 4503599627370496.75L, 4503599627370496.0L);
12653 TEST_f_f (trunc, 4503599627370497.5L, 4503599627370497.0L);
12654
5c68d401
RM
12655# if LDBL_MANT_DIG > 100
12656 TEST_f_f (trunc, 4503599627370494.5000000000001L, 4503599627370494.0L);
12657 TEST_f_f (trunc, 4503599627370495.5000000000001L, 4503599627370495.0L);
12658 TEST_f_f (trunc, 4503599627370496.5000000000001L, 4503599627370496.0L);
12659# endif
830fce04 12660
f964490f
RM
12661 TEST_f_f (trunc, -4503599627370495.5L, -4503599627370495.0L);
12662 TEST_f_f (trunc, -4503599627370496.25L, -4503599627370496.0L);
12663 TEST_f_f (trunc, -4503599627370496.5L, -4503599627370496.0L);
12664 TEST_f_f (trunc, -4503599627370496.75L, -4503599627370496.0L);
12665 TEST_f_f (trunc, -4503599627370497.5L, -4503599627370497.0L);
830fce04 12666
5c68d401
RM
12667# if LDBL_MANT_DIG > 100
12668 TEST_f_f (trunc, -4503599627370494.5000000000001L, -4503599627370494.0L);
12669 TEST_f_f (trunc, -4503599627370495.5000000000001L, -4503599627370495.0L);
12670 TEST_f_f (trunc, -4503599627370496.5000000000001L, -4503599627370496.0L);
12671# endif
f964490f
RM
12672
12673 TEST_f_f (trunc, 9007199254740991.5L, 9007199254740991.0L);
12674 TEST_f_f (trunc, 9007199254740992.25L, 9007199254740992.0L);
12675 TEST_f_f (trunc, 9007199254740992.5L, 9007199254740992.0L);
12676 TEST_f_f (trunc, 9007199254740992.75L, 9007199254740992.0L);
12677 TEST_f_f (trunc, 9007199254740993.5L, 9007199254740993.0L);
12678
5c68d401
RM
12679# if LDBL_MANT_DIG > 100
12680 TEST_f_f (trunc, 9007199254740991.0000000000001L, 9007199254740991.0L);
12681 TEST_f_f (trunc, 9007199254740992.0000000000001L, 9007199254740992.0L);
12682 TEST_f_f (trunc, 9007199254740993.0000000000001L, 9007199254740993.0L);
12683 TEST_f_f (trunc, 9007199254740991.5000000000001L, 9007199254740991.0L);
12684 TEST_f_f (trunc, 9007199254740992.5000000000001L, 9007199254740992.0L);
12685 TEST_f_f (trunc, 9007199254740993.5000000000001L, 9007199254740993.0L);
12686# endif
12687
f964490f
RM
12688 TEST_f_f (trunc, -9007199254740991.5L, -9007199254740991.0L);
12689 TEST_f_f (trunc, -9007199254740992.25L, -9007199254740992.0L);
12690 TEST_f_f (trunc, -9007199254740992.5L, -9007199254740992.0L);
12691 TEST_f_f (trunc, -9007199254740992.75L, -9007199254740992.0L);
12692 TEST_f_f (trunc, -9007199254740993.5L, -9007199254740993.0L);
12693
5c68d401
RM
12694# if LDBL_MANT_DIG > 100
12695 TEST_f_f (trunc, -9007199254740991.0000000000001L, -9007199254740991.0L);
12696 TEST_f_f (trunc, -9007199254740992.0000000000001L, -9007199254740992.0L);
12697 TEST_f_f (trunc, -9007199254740993.0000000000001L, -9007199254740993.0L);
12698 TEST_f_f (trunc, -9007199254740991.5000000000001L, -9007199254740991.0L);
12699 TEST_f_f (trunc, -9007199254740992.5000000000001L, -9007199254740992.0L);
12700 TEST_f_f (trunc, -9007199254740993.5000000000001L, -9007199254740993.0L);
12701# endif
12702
f964490f
RM
12703 TEST_f_f (trunc, 72057594037927935.5L, 72057594037927935.0L);
12704 TEST_f_f (trunc, 72057594037927936.25L, 72057594037927936.0L);
12705 TEST_f_f (trunc, 72057594037927936.5L, 72057594037927936.0L);
12706 TEST_f_f (trunc, 72057594037927936.75L, 72057594037927936.0L);
12707 TEST_f_f (trunc, 72057594037927937.5L, 72057594037927937.0L);
12708
12709 TEST_f_f (trunc, -72057594037927935.5L, -72057594037927935.0L);
12710 TEST_f_f (trunc, -72057594037927936.25L, -72057594037927936.0L);
12711 TEST_f_f (trunc, -72057594037927936.5L, -72057594037927936.0L);
12712 TEST_f_f (trunc, -72057594037927936.75L, -72057594037927936.0L);
12713 TEST_f_f (trunc, -72057594037927937.5L, -72057594037927937.0L);
12714
12715 TEST_f_f (trunc, 10141204801825835211973625643007.5L, 10141204801825835211973625643007.0L);
12716 TEST_f_f (trunc, 10141204801825835211973625643008.25L, 10141204801825835211973625643008.0L);
12717 TEST_f_f (trunc, 10141204801825835211973625643008.5L, 10141204801825835211973625643008.0L);
12718 TEST_f_f (trunc, 10141204801825835211973625643008.75L, 10141204801825835211973625643008.0L);
830fce04 12719 TEST_f_f (trunc, 10141204801825835211973625643009.5L, 10141204801825835211973625643009.0L);
f964490f 12720#endif
8847214f
UD
12721
12722 END (trunc);
12723}
12724
12725static void
12726y0_test (void)
12727{
8a216c1b 12728 FLOAT s, c;
8847214f 12729 errno = 0;
cd53c157
UD
12730 FUNC (sincos) (0, &s, &c);
12731 if (errno == ENOSYS)
12732 /* Required function not implemented. */
12733 return;
8847214f
UD
12734 FUNC(y0) (1);
12735 if (errno == ENOSYS)
12736 /* Function not implemented. */
12737 return;
12738
12739 /* y0 is the Bessel function of the second kind of order 0 */
12740 START (y0);
12741
caac9ddb 12742 TEST_f_f (y0, -1.0, minus_infty, INVALID_EXCEPTION);
41bf21a1 12743 TEST_f_f (y0, -max_value, minus_infty, INVALID_EXCEPTION);
8847214f 12744 TEST_f_f (y0, 0.0, minus_infty);
67e971f1 12745 TEST_f_f (y0, qnan_value, qnan_value);
8847214f
UD
12746 TEST_f_f (y0, plus_infty, 0);
12747
2550dfe9
AJ
12748 TEST_f_f (y0, 0.125L, -1.38968062514384052915582277745018693L);
12749 TEST_f_f (y0, 0.75L, -0.137172769385772397522814379396581855L);
12750 TEST_f_f (y0, 1.0, 0.0882569642156769579829267660235151628L);
12751 TEST_f_f (y0, 1.5, 0.382448923797758843955068554978089862L);
12752 TEST_f_f (y0, 2.0, 0.510375672649745119596606592727157873L);
12753 TEST_f_f (y0, 8.0, 0.223521489387566220527323400498620359L);
12754 TEST_f_f (y0, 10.0, 0.0556711672835993914244598774101900481L);
8847214f 12755
c36e1d23
JM
12756 TEST_f_f (y0, 0x1.3ffp+74L, 1.818984347516051243459467456433028748678e-12L);
12757
12758#ifndef TEST_FLOAT
2a185d32 12759 TEST_f_f (y0, 0x1.ff00000000002p+840L, 1.846591691699331493194965158699937660696e-127L);
98c48fe5 12760 TEST_f_f (y0, 0x1p1023L, 8.2687542933709649327986678723012001545638e-155L);
c36e1d23
JM
12761#endif
12762
d2f9799e
JM
12763#if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
12764 TEST_f_f (y0, 0x1p16382L, 8.0839224448726336195866026476176740513439e-2467L);
12765 TEST_f_f (y0, 0x1p16383L, -3.8895531955766020648617743624167352352217e-2467L);
12766#endif
12767
05b227bd
DM
12768 TEST_f_f (y0, 0x1p-10L, -4.4865150767109739412411806297168793661098L);
12769 TEST_f_f (y0, 0x1p-20L, -8.8992283012125827603076426611387876938160L);
12770 TEST_f_f (y0, 0x1p-30L, -1.3311940304267782826037118027401817264906e+1L);
12771 TEST_f_f (y0, 0x1p-40L, -1.7724652307320814696990854700366226762563e+1L);
12772 TEST_f_f (y0, 0x1p-50L, -2.2137364310373846564919987139743760738155e+1L);
12773 TEST_f_f (y0, 0x1p-60L, -2.6550076313426878432849115782108205929120e+1L);
12774 TEST_f_f (y0, 0x1p-70L, -3.0962788316479910300778244424468159753887e+1L);
12775 TEST_f_f (y0, 0x1p-80L, -3.5375500319532942168707373066828113573541e+1L);
12776 TEST_f_f (y0, 0x1p-90L, -3.9788212322585974036636501709188067393195e+1L);
12777 TEST_f_f (y0, 0x1p-100L, -4.420092432563900590456563035154802121284e+1L);
12778 TEST_f_f (y0, 0x1p-110L, -4.861363632869203777249475899390797503250e+1L);
12779
8847214f
UD
12780 END (y0);
12781}
12782
12783
12784static void
12785y1_test (void)
12786{
8a216c1b 12787 FLOAT s, c;
8847214f 12788 errno = 0;
cd53c157
UD
12789 FUNC (sincos) (0, &s, &c);
12790 if (errno == ENOSYS)
12791 /* Required function not implemented. */
12792 return;
8847214f
UD
12793 FUNC(y1) (1);
12794 if (errno == ENOSYS)
12795 /* Function not implemented. */
12796 return;
12797
12798 /* y1 is the Bessel function of the second kind of order 1 */
12799 START (y1);
12800
caac9ddb 12801 TEST_f_f (y1, -1.0, minus_infty, INVALID_EXCEPTION);
41bf21a1 12802 TEST_f_f (y1, -max_value, minus_infty, INVALID_EXCEPTION);
8847214f
UD
12803 TEST_f_f (y1, 0.0, minus_infty);
12804 TEST_f_f (y1, plus_infty, 0);
67e971f1 12805 TEST_f_f (y1, qnan_value, qnan_value);
8847214f 12806
2550dfe9
AJ
12807 TEST_f_f (y1, 0.125L, -5.19993611253477499595928744876579921L);
12808 TEST_f_f (y1, 0.75L, -1.03759455076928541973767132140642198L);
12809 TEST_f_f (y1, 1.0, -0.781212821300288716547150000047964821L);
12810 TEST_f_f (y1, 1.5, -0.412308626973911295952829820633445323L);
12811 TEST_f_f (y1, 2.0, -0.107032431540937546888370772277476637L);
12812 TEST_f_f (y1, 8.0, -0.158060461731247494255555266187483550L);
12813 TEST_f_f (y1, 10.0, 0.249015424206953883923283474663222803L);
8847214f 12814
41c7328e 12815 TEST_f_f (y1, 0x1.27e204p+99L, -8.881610148467797208469612080785210013461e-16L);
c36e1d23
JM
12816
12817#ifndef TEST_FLOAT
2a185d32 12818 TEST_f_f (y1, 0x1.001000001p+593L, 3.927269966354206207832593635798954916263e-90L);
98c48fe5 12819 TEST_f_f (y1, 0x1p1023L, 1.5665258060609012834424478437196679802783e-155L);
c36e1d23
JM
12820#endif
12821
d2f9799e
JM
12822#if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
12823 TEST_f_f (y1, 0x1p16382L, 1.2193782500509000574176799046642541129387e-2466L);
12824 TEST_f_f (y1, 0x1p16383L, -9.5859502826270374691362975419147645151233e-2467L);
12825#endif
12826
05b227bd
DM
12827 TEST_f_f (y1, 0x1p-10L, -6.5190099301063115047395187618929589514382e+02L);
12828 TEST_f_f (y1, 0x1p-20L, -6.6754421443450423911167962313100637952285e+05L);
12829 TEST_f_f (y1, 0x1p-30L, -6.8356527557643159612937462812258975438856e+08L);
12830 TEST_f_f (y1, 0x1p-40L, -6.9997084219026594793707805777425993547887e+11L);
12831 TEST_f_f (y1, 0x1p-50L, -7.1677014240283233068755952926181262431559e+14L);
12832 TEST_f_f (y1, 0x1p-60L, -7.3397262582050030662406095795388448059822e+17L);
12833 TEST_f_f (y1, 0x1p-70L, -7.5158796884019231398303842094477769620063e+20L);
12834 TEST_f_f (y1, 0x1p-80L, -7.6962608009235692951863134304745236090943e+23L);
12835 TEST_f_f (y1, 0x1p-90L, -7.8809710601457349582707849528059121757126e+26L);
12836 TEST_f_f (y1, 0x1p-100L, -8.0701143655892325972692837916732540679297e+29L);
12837 TEST_f_f (y1, 0x1p-110L, -8.2637971103633741796037466026734121655600e+32L);
12838
8847214f
UD
12839 END (y1);
12840}
12841
2550dfe9 12842
8847214f
UD
12843static void
12844yn_test (void)
12845{
8a216c1b 12846 FLOAT s, c;
8847214f 12847 errno = 0;
cd53c157
UD
12848 FUNC (sincos) (0, &s, &c);
12849 if (errno == ENOSYS)
12850 /* Required function not implemented. */
12851 return;
8847214f
UD
12852 FUNC(yn) (1, 1);
12853 if (errno == ENOSYS)
12854 /* Function not implemented. */
12855 return;
12856
12857 /* yn is the Bessel function of the second kind of order n */
12858 START (yn);
12859
12860 /* yn (0, x) == y0 (x) */
caac9ddb 12861 TEST_ff_f (yn, 0, -1.0, minus_infty, INVALID_EXCEPTION);
41bf21a1 12862 TEST_ff_f (yn, 0, -max_value, minus_infty, INVALID_EXCEPTION);
8847214f 12863 TEST_ff_f (yn, 0, 0.0, minus_infty);
67e971f1 12864 TEST_ff_f (yn, 0, qnan_value, qnan_value);
8847214f
UD
12865 TEST_ff_f (yn, 0, plus_infty, 0);
12866
2550dfe9
AJ
12867 TEST_ff_f (yn, 0, 0.125L, -1.38968062514384052915582277745018693L);
12868 TEST_ff_f (yn, 0, 0.75L, -0.137172769385772397522814379396581855L);
12869 TEST_ff_f (yn, 0, 1.0, 0.0882569642156769579829267660235151628L);
12870 TEST_ff_f (yn, 0, 1.5, 0.382448923797758843955068554978089862L);
12871 TEST_ff_f (yn, 0, 2.0, 0.510375672649745119596606592727157873L);
12872 TEST_ff_f (yn, 0, 8.0, 0.223521489387566220527323400498620359L);
12873 TEST_ff_f (yn, 0, 10.0, 0.0556711672835993914244598774101900481L);
8847214f
UD
12874
12875 /* yn (1, x) == y1 (x) */
caac9ddb 12876 TEST_ff_f (yn, 1, -1.0, minus_infty, INVALID_EXCEPTION);
8847214f
UD
12877 TEST_ff_f (yn, 1, 0.0, minus_infty);
12878 TEST_ff_f (yn, 1, plus_infty, 0);
67e971f1 12879 TEST_ff_f (yn, 1, qnan_value, qnan_value);
8847214f 12880
2550dfe9
AJ
12881 TEST_ff_f (yn, 1, 0.125L, -5.19993611253477499595928744876579921L);
12882 TEST_ff_f (yn, 1, 0.75L, -1.03759455076928541973767132140642198L);
12883 TEST_ff_f (yn, 1, 1.0, -0.781212821300288716547150000047964821L);
12884 TEST_ff_f (yn, 1, 1.5, -0.412308626973911295952829820633445323L);
12885 TEST_ff_f (yn, 1, 2.0, -0.107032431540937546888370772277476637L);
12886 TEST_ff_f (yn, 1, 8.0, -0.158060461731247494255555266187483550L);
12887 TEST_ff_f (yn, 1, 10.0, 0.249015424206953883923283474663222803L);
8847214f
UD
12888
12889 /* yn (3, x) */
12890 TEST_ff_f (yn, 3, plus_infty, 0);
67e971f1 12891 TEST_ff_f (yn, 3, qnan_value, qnan_value);
8847214f 12892
2550dfe9
AJ
12893 TEST_ff_f (yn, 3, 0.125L, -2612.69757350066712600220955744091741L);
12894 TEST_ff_f (yn, 3, 0.75L, -12.9877176234475433186319774484809207L);
12895 TEST_ff_f (yn, 3, 1.0, -5.82151760596472884776175706442981440L);
12896 TEST_ff_f (yn, 3, 2.0, -1.12778377684042778608158395773179238L);
12897 TEST_ff_f (yn, 3, 10.0, -0.251362657183837329779204747654240998L);
8847214f
UD
12898
12899 /* yn (10, x) */
12900 TEST_ff_f (yn, 10, plus_infty, 0);
67e971f1 12901 TEST_ff_f (yn, 10, qnan_value, qnan_value);
8847214f 12902
2550dfe9
AJ
12903 TEST_ff_f (yn, 10, 0.125L, -127057845771019398.252538486899753195L);
12904 TEST_ff_f (yn, 10, 0.75L, -2133501638.90573424452445412893839236L);
12905 TEST_ff_f (yn, 10, 1.0, -121618014.278689189288130426667971145L);
12906 TEST_ff_f (yn, 10, 2.0, -129184.542208039282635913145923304214L);
12907 TEST_ff_f (yn, 10, 10.0, -0.359814152183402722051986577343560609L);
8847214f 12908
541428fe
MP
12909 /* Check whether yn returns correct value for LDBL_MIN, DBL_MIN,
12910 and FLT_MIN. See Bug 14173. */
12911 TEST_ff_f (yn, 10, min_value, minus_infty, OVERFLOW_EXCEPTION);
8847214f 12912
354691b7
MP
12913 errno = 0;
12914 TEST_ff_f (yn, 10, min_value, minus_infty, OVERFLOW_EXCEPTION);
12915 check_int ("errno for yn(10,-min) == ERANGE", errno, ERANGE, 0, 0, 0);
12916
541428fe 12917 END (yn);
8847214f
UD
12918}
12919
12920
f5c8f285
UD
12921static void
12922significand_test (void)
12923{
12924 /* significand returns the mantissa of the exponential representation. */
64d063b8
TS
12925
12926 /* TODO: missing +/-Inf as well as qNaN tests. */
12927
f5c8f285
UD
12928 START (significand);
12929
12930 TEST_f_f (significand, 4.0, 1.0);
12931 TEST_f_f (significand, 6.0, 1.5);
12932 TEST_f_f (significand, 8.0, 1.0);
12933
12934 END (significand);
12935}
12936
12937
8847214f
UD
12938static void
12939initialize (void)
12940{
12941 fpstack_test ("start *init*");
8847214f 12942
777b0332
TS
12943 plus_zero = 0.0;
12944 qnan_value = FUNC (__builtin_nan) ("");
12945 minus_zero = FUNC (copysign) (0.0, -1.0);
8847214f
UD
12946 plus_infty = CHOOSE (HUGE_VALL, HUGE_VAL, HUGE_VALF,
12947 HUGE_VALL, HUGE_VAL, HUGE_VALF);
12948 minus_infty = CHOOSE (-HUGE_VALL, -HUGE_VAL, -HUGE_VALF,
12949 -HUGE_VALL, -HUGE_VAL, -HUGE_VALF);
164f863e
UD
12950 max_value = CHOOSE (LDBL_MAX, DBL_MAX, FLT_MAX,
12951 LDBL_MAX, DBL_MAX, FLT_MAX);
12952 min_value = CHOOSE (LDBL_MIN, DBL_MIN, FLT_MIN,
12953 LDBL_MIN, DBL_MIN, FLT_MIN);
bec749fd
JM
12954 min_subnorm_value = CHOOSE (__LDBL_DENORM_MIN__,
12955 __DBL_DENORM_MIN__,
12956 __FLT_DENORM_MIN__,
12957 __LDBL_DENORM_MIN__,
12958 __DBL_DENORM_MIN__,
12959 __FLT_DENORM_MIN__);
8847214f
UD
12960
12961 (void) &plus_zero;
67e971f1 12962 (void) &qnan_value;
8847214f
UD
12963 (void) &minus_zero;
12964 (void) &plus_infty;
12965 (void) &minus_infty;
164f863e
UD
12966 (void) &max_value;
12967 (void) &min_value;
bec749fd 12968 (void) &min_subnorm_value;
8847214f
UD
12969
12970 /* Clear all exceptions. From now on we must not get random exceptions. */
12971 feclearexcept (FE_ALL_EXCEPT);
12972
12973 /* Test to make sure we start correctly. */
12974 fpstack_test ("end *init*");
12975}
12976
12977/* Definitions of arguments for argp functions. */
12978static const struct argp_option options[] =
12979{
12980 { "verbose", 'v', "NUMBER", 0, "Level of verbosity (0..3)"},
12981 { "ulps-file", 'u', NULL, 0, "Output ulps to file ULPs"},
12982 { "no-max-error", 'f', NULL, 0,
12983 "Don't output maximal errors of functions"},
12984 { "no-points", 'p', NULL, 0,
12985 "Don't output results of functions invocations"},
cd33623e
UD
12986 { "ignore-max-ulp", 'i', "yes/no", 0,
12987 "Ignore given maximal errors"},
8847214f
UD
12988 { NULL, 0, NULL, 0, NULL }
12989};
12990
12991/* Short description of program. */
12992static const char doc[] = "Math test suite: " TEST_MSG ;
12993
12994/* Prototype for option handler. */
fe559c5e 12995static error_t parse_opt (int key, char *arg, struct argp_state *state);
8847214f
UD
12996
12997/* Data structure to communicate with argp functions. */
12998static struct argp argp =
12999{
13000 options, parse_opt, NULL, doc,
13001};
13002
13003
13004/* Handle program arguments. */
13005static error_t
13006parse_opt (int key, char *arg, struct argp_state *state)
13007{
13008 switch (key)
13009 {
13010 case 'f':
6815fabc 13011 output_max_error = 0;
8847214f 13012 break;
cd33623e
UD
13013 case 'i':
13014 if (strcmp (arg, "yes") == 0)
13015 ignore_max_ulp = 1;
13016 else if (strcmp (arg, "no") == 0)
13017 ignore_max_ulp = 0;
13018 break;
8847214f 13019 case 'p':
6815fabc 13020 output_points = 0;
8847214f
UD
13021 break;
13022 case 'u':
13023 output_ulps = 1;
13024 break;
13025 case 'v':
13026 if (optarg)
13027 verbose = (unsigned int) strtoul (optarg, NULL, 0);
13028 else
13029 verbose = 3;
13030 break;
13031 default:
13032 return ARGP_ERR_UNKNOWN;
13033 }
13034 return 0;
13035}
13036
13037#if 0
13038/* function to check our ulp calculation. */
13039void
13040check_ulp (void)
13041{
13042 int i;
13043
13044 FLOAT u, diff, ulp;
13045 /* This gives one ulp. */
13046 u = FUNC(nextafter) (10, 20);
13047 check_equal (10.0, u, 1, &diff, &ulp);
13048 printf ("One ulp: % .4" PRINTF_NEXPR "\n", ulp);
13049
13050 /* This gives one more ulp. */
13051 u = FUNC(nextafter) (u, 20);
13052 check_equal (10.0, u, 2, &diff, &ulp);
13053 printf ("two ulp: % .4" PRINTF_NEXPR "\n", ulp);
13054
13055 /* And now calculate 100 ulp. */
13056 for (i = 2; i < 100; i++)
13057 u = FUNC(nextafter) (u, 20);
13058 check_equal (10.0, u, 100, &diff, &ulp);
13059 printf ("100 ulp: % .4" PRINTF_NEXPR "\n", ulp);
13060}
13061#endif
13062
13063int
13064main (int argc, char **argv)
13065{
13066
13067 int remaining;
13068
13069 verbose = 1;
13070 output_ulps = 0;
13071 output_max_error = 1;
13072 output_points = 1;
cd33623e
UD
13073 /* XXX set to 0 for releases. */
13074 ignore_max_ulp = 0;
bdf09fab 13075
8847214f
UD
13076 /* Parse and process arguments. */
13077 argp_parse (&argp, argc, argv, 0, &remaining, NULL);
13078
13079 if (remaining != argc)
13080 {
13081 fprintf (stderr, "wrong number of arguments");
13082 argp_help (&argp, stdout, ARGP_HELP_SEE, program_invocation_short_name);
13083 exit (EXIT_FAILURE);
13084 }
13085
13086 if (output_ulps)
13087 {
13088 ulps_file = fopen ("ULPs", "a");
13089 if (ulps_file == NULL)
13090 {
13091 perror ("can't open file `ULPs' for writing: ");
13092 exit (1);
13093 }
13094 }
13095
13096
13097 initialize ();
13098 printf (TEST_MSG);
13099
13100#if 0
13101 check_ulp ();
13102#endif
13103
ec751a23 13104 /* Keep the tests a wee bit ordered (according to ISO C99). */
8847214f 13105 /* Classification macros: */
ef1bb361 13106 finite_test ();
8847214f
UD
13107 fpclassify_test ();
13108 isfinite_test ();
ef1bb361
JM
13109 isinf_test ();
13110 isnan_test ();
8847214f 13111 isnormal_test ();
57267616 13112 issignaling_test ();
8847214f
UD
13113 signbit_test ();
13114
13115 /* Trigonometric functions: */
13116 acos_test ();
5ba3cc69
JM
13117 acos_test_tonearest ();
13118 acos_test_towardzero ();
13119 acos_test_downward ();
13120 acos_test_upward ();
8847214f 13121 asin_test ();
5ba3cc69
JM
13122 asin_test_tonearest ();
13123 asin_test_towardzero ();
13124 asin_test_downward ();
13125 asin_test_upward ();
8847214f
UD
13126 atan_test ();
13127 atan2_test ();
13128 cos_test ();
804360ed
JM
13129 cos_test_tonearest ();
13130 cos_test_towardzero ();
13131 cos_test_downward ();
13132 cos_test_upward ();
8847214f 13133 sin_test ();
804360ed
JM
13134 sin_test_tonearest ();
13135 sin_test_towardzero ();
13136 sin_test_downward ();
13137 sin_test_upward ();
8847214f
UD
13138 sincos_test ();
13139 tan_test ();
804360ed
JM
13140 tan_test_tonearest ();
13141 tan_test_towardzero ();
13142 tan_test_downward ();
13143 tan_test_upward ();
8847214f
UD
13144
13145 /* Hyperbolic functions: */
13146 acosh_test ();
13147 asinh_test ();
13148 atanh_test ();
13149 cosh_test ();
ca811b22
JM
13150 cosh_test_tonearest ();
13151 cosh_test_towardzero ();
13152 cosh_test_downward ();
13153 cosh_test_upward ();
8847214f 13154 sinh_test ();
ca811b22
JM
13155 sinh_test_tonearest ();
13156 sinh_test_towardzero ();
13157 sinh_test_downward ();
13158 sinh_test_upward ();
8847214f
UD
13159 tanh_test ();
13160
13161 /* Exponential and logarithmic functions: */
13162 exp_test ();
28afd92d
JM
13163 exp_test_tonearest ();
13164 exp_test_towardzero ();
13165 exp_test_downward ();
13166 exp_test_upward ();
8847214f
UD
13167 exp10_test ();
13168 exp2_test ();
13169 expm1_test ();
13170 frexp_test ();
13171 ldexp_test ();
13172 log_test ();
13173 log10_test ();
13174 log1p_test ();
13175 log2_test ();
13176 logb_test ();
a462cb63 13177 logb_test_downward ();
8847214f
UD
13178 modf_test ();
13179 ilogb_test ();
13180 scalb_test ();
13181 scalbn_test ();
13182 scalbln_test ();
f5c8f285 13183 significand_test ();
8847214f
UD
13184
13185 /* Power and absolute value functions: */
13186 cbrt_test ();
13187 fabs_test ();
13188 hypot_test ();
13189 pow_test ();
b7cd39e8
JM
13190 pow_test_tonearest ();
13191 pow_test_towardzero ();
13192 pow_test_downward ();
13193 pow_test_upward ();
8847214f
UD
13194 sqrt_test ();
13195
13196 /* Error and gamma functions: */
13197 erf_test ();
13198 erfc_test ();
13199 gamma_test ();
13200 lgamma_test ();
13201 tgamma_test ();
13202
13203 /* Nearest integer functions: */
13204 ceil_test ();
13205 floor_test ();
13206 nearbyint_test ();
13207 rint_test ();
4d37c8aa
UD
13208 rint_test_tonearest ();
13209 rint_test_towardzero ();
13210 rint_test_downward ();
13211 rint_test_upward ();
8847214f 13212 lrint_test ();
6624dbc0
UD
13213 lrint_test_tonearest ();
13214 lrint_test_towardzero ();
13215 lrint_test_downward ();
13216 lrint_test_upward ();
8847214f 13217 llrint_test ();
830fce04
RM
13218 llrint_test_tonearest ();
13219 llrint_test_towardzero ();
13220 llrint_test_downward ();
13221 llrint_test_upward ();
8847214f
UD
13222 round_test ();
13223 lround_test ();
13224 llround_test ();
13225 trunc_test ();
13226
13227 /* Remainder functions: */
13228 fmod_test ();
13229 remainder_test ();
13230 remquo_test ();
13231
13232 /* Manipulation functions: */
13233 copysign_test ();
13234 nextafter_test ();
fe559c5e 13235 nexttoward_test ();
8847214f
UD
13236
13237 /* maximum, minimum and positive difference functions */
13238 fdim_test ();
13239 fmax_test ();
13240 fmin_test ();
13241
13242 /* Multiply and add: */
13243 fma_test ();
8ec5b013
JM
13244 fma_test_towardzero ();
13245 fma_test_downward ();
13246 fma_test_upward ();
8847214f 13247
0e8e0c1c
JM
13248 /* Comparison macros: */
13249 isgreater_test ();
13250 isgreaterequal_test ();
13251 isless_test ();
13252 islessequal_test ();
13253 islessgreater_test ();
13254 isunordered_test ();
13255
8847214f
UD
13256 /* Complex functions: */
13257 cabs_test ();
13258 cacos_test ();
13259 cacosh_test ();
13260 carg_test ();
13261 casin_test ();
13262 casinh_test ();
13263 catan_test ();
13264 catanh_test ();
13265 ccos_test ();
13266 ccosh_test ();
13267 cexp_test ();
0cdc8e6f 13268 cimag_test ();
8847214f
UD
13269 clog10_test ();
13270 clog_test ();
0cdc8e6f 13271 conj_test ();
8847214f
UD
13272 cpow_test ();
13273 cproj_test ();
0cdc8e6f 13274 creal_test ();
8847214f
UD
13275 csin_test ();
13276 csinh_test ();
13277 csqrt_test ();
13278 ctan_test ();
ca61cf32
JM
13279 ctan_test_tonearest ();
13280 ctan_test_towardzero ();
13281 ctan_test_downward ();
13282 ctan_test_upward ();
8847214f 13283 ctanh_test ();
ca61cf32
JM
13284 ctanh_test_tonearest ();
13285 ctanh_test_towardzero ();
13286 ctanh_test_downward ();
13287 ctanh_test_upward ();
8847214f
UD
13288
13289 /* Bessel functions: */
13290 j0_test ();
13291 j1_test ();
13292 jn_test ();
13293 y0_test ();
13294 y1_test ();
13295 yn_test ();
13296
13297 if (output_ulps)
13298 fclose (ulps_file);
13299
13300 printf ("\nTest suite completed:\n");
13301 printf (" %d test cases plus %d tests for exception flags executed.\n",
13302 noTests, noExcTests);
13303 if (noXFails)
a9a56960 13304 printf (" %d expected failures occurred.\n", noXFails);
8847214f 13305 if (noXPasses)
a9a56960 13306 printf (" %d unexpected passes occurred.\n", noXPasses);
8847214f
UD
13307 if (noErrors)
13308 {
a9a56960 13309 printf (" %d errors occurred.\n", noErrors);
cf3141a5 13310 return 1;
8847214f
UD
13311 }
13312 printf (" All tests passed successfully.\n");
cf3141a5
AJ
13313
13314 return 0;
8847214f
UD
13315}
13316
13317/*
13318 * Local Variables:
13319 * mode:c
13320 * End:
13321 */