]> git.ipfire.org Git - thirdparty/glibc.git/blob - math/libm-test.inc
Remove libm-test support for TEST_* inside functions.
[thirdparty/glibc.git] / math / libm-test.inc
1 /* Copyright (C) 1997-2013 Free Software Foundation, Inc.
2 This file is part of the GNU C Library.
3 Contributed by Andreas Jaeger <aj@suse.de>, 1997.
4
5 The GNU C Library is free software; you can redistribute it and/or
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.
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
13 Lesser General Public License for more details.
14
15 You should have received a copy of the GNU Lesser General Public
16 License along with the GNU C Library; if not, see
17 <http://www.gnu.org/licenses/>. */
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
24 Macros:
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,
43 fabs, fdim, finite, floor, fma, fmax, fmin, fmod, fpclassify,
44 frexp, gamma, hypot,
45 ilogb, isfinite, isinf, isnan, isnormal, issignaling,
46 isless, islessequal, isgreater, isgreaterequal, islessgreater, isunordered,
47 j0, j1, jn,
48 ldexp, lgamma, log, log10, log1p, log2, logb,
49 modf, nearbyint, nextafter, nexttoward,
50 pow, remainder, remquo, rint, lrint, llrint,
51 round, lround, llround,
52 scalb, scalbn, scalbln, signbit, sin, sincos, sinh, sqrt, tan, tanh, tgamma, trunc,
53 y0, y1, yn, significand
54
55 and for the following complex math functions:
56 cabs, cacos, cacosh, carg, casin, casinh, catan, catanh,
57 ccos, ccosh, cexp, cimag, clog, clog10, conj, cpow, cproj, creal,
58 csin, csinh, csqrt, ctan, ctanh.
59
60 At the moment the following functions and macros aren't tested:
61 drem (alias for remainder),
62 lgamma_r,
63 nan,
64 pow10 (alias for exp10).
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
83 specified in ISO C99.
84
85 NaN values: There exist signalling and quiet NaNs. This implementation
86 only uses quiet NaN as parameter. Where the sign of a NaN is
87 significant, this is not tested. The payload of NaNs is not examined.
88
89 Inline functions: Inlining functions should give an improvement in
90 speed - but not in precission. The inlined functions return
91 reasonable values for a reasonable range of input values. The
92 result is not necessarily correct for all values and exceptions are
93 not correctly raised in all cases. Problematic input and return
94 values are infinity, not-a-number and minus zero. This suite
95 therefore does not check these specific inputs and the exception
96 handling for inlined mathematical functions - just the "reasonable"
97 values are checked.
98
99 Beware: The tests might fail for any of the following reasons:
100 - Tests are wrong
101 - Functions are wrong
102 - Floating Point Unit not working properly
103 - Compiler has errors
104
105 With e.g. gcc 2.7.2.2 the test for cexp fails because of a compiler error.
106
107
108 To Do: All parameter should be numbers that can be represented as
109 exact floating point values. Currently some values cannot be
110 represented exactly and therefore the result is not the expected
111 result. For this we will use 36 digits so that numbers can be
112 represented exactly. */
113
114 #ifndef _GNU_SOURCE
115 # define _GNU_SOURCE
116 #endif
117
118 #include "libm-test-ulps.h"
119 #include <complex.h>
120 #include <math.h>
121 #include <float.h>
122 #include <fenv.h>
123 #include <limits.h>
124
125 #include <errno.h>
126 #include <stdlib.h>
127 #include <stdio.h>
128 #include <string.h>
129 #include <argp.h>
130 #include <tininess.h>
131
132 /* Allow platforms without all rounding modes to test properly,
133 assuming they provide an __FE_UNDEFINED in <bits/fenv.h> which
134 causes fesetround() to return failure. */
135 #ifndef FE_TONEAREST
136 # define FE_TONEAREST __FE_UNDEFINED
137 #endif
138 #ifndef FE_TOWARDZERO
139 # define FE_TOWARDZERO __FE_UNDEFINED
140 #endif
141 #ifndef FE_UPWARD
142 # define FE_UPWARD __FE_UNDEFINED
143 #endif
144 #ifndef FE_DOWNWARD
145 # define FE_DOWNWARD __FE_UNDEFINED
146 #endif
147
148 /* Possible exceptions */
149 #define NO_EXCEPTION 0x0
150 #define INVALID_EXCEPTION 0x1
151 #define DIVIDE_BY_ZERO_EXCEPTION 0x2
152 #define OVERFLOW_EXCEPTION 0x4
153 #define UNDERFLOW_EXCEPTION 0x8
154 #define INEXACT_EXCEPTION 0x10
155 /* The next flags signals that those exceptions are allowed but not required. */
156 #define INVALID_EXCEPTION_OK 0x20
157 #define DIVIDE_BY_ZERO_EXCEPTION_OK 0x40
158 #define OVERFLOW_EXCEPTION_OK 0x80
159 #define UNDERFLOW_EXCEPTION_OK 0x100
160 /* For "inexact" exceptions, the default is allowed but not required
161 unless INEXACT_EXCEPTION or NO_INEXACT_EXCEPTION is specified. */
162 #define NO_INEXACT_EXCEPTION 0x200
163 #define EXCEPTIONS_OK INVALID_EXCEPTION_OK+DIVIDE_BY_ZERO_EXCEPTION_OK
164 /* Some special test flags, passed together with exceptions. */
165 #define IGNORE_ZERO_INF_SIGN 0x400
166 /* Indicate errno settings required or disallowed. */
167 #define ERRNO_UNCHANGED 0x800
168 #define ERRNO_EDOM 0x1000
169 #define ERRNO_ERANGE 0x2000
170
171 /* Values underflowing only for float. */
172 #ifdef TEST_FLOAT
173 # define UNDERFLOW_EXCEPTION_FLOAT UNDERFLOW_EXCEPTION
174 # define UNDERFLOW_EXCEPTION_OK_FLOAT UNDERFLOW_EXCEPTION_OK
175 #else
176 # define UNDERFLOW_EXCEPTION_FLOAT 0
177 # define UNDERFLOW_EXCEPTION_OK_FLOAT 0
178 #endif
179 /* Values underflowing only for double or types with a larger least
180 positive normal value. */
181 #if defined TEST_FLOAT || defined TEST_DOUBLE \
182 || (defined TEST_LDOUBLE && LDBL_MIN_EXP >= DBL_MIN_EXP)
183 # define UNDERFLOW_EXCEPTION_DOUBLE UNDERFLOW_EXCEPTION
184 # define UNDERFLOW_EXCEPTION_OK_DOUBLE UNDERFLOW_EXCEPTION_OK
185 #else
186 # define UNDERFLOW_EXCEPTION_DOUBLE 0
187 # define UNDERFLOW_EXCEPTION_OK_DOUBLE 0
188 #endif
189 /* Values underflowing only for IBM long double or types with a larger least
190 positive normal value. */
191 #if defined TEST_FLOAT || (defined TEST_LDOUBLE && LDBL_MIN_EXP > DBL_MIN_EXP)
192 # define UNDERFLOW_EXCEPTION_LDOUBLE_IBM UNDERFLOW_EXCEPTION
193 #else
194 # define UNDERFLOW_EXCEPTION_LDOUBLE_IBM 0
195 #endif
196 /* Values underflowing on architectures detecting tininess before
197 rounding, but not on those detecting tininess after rounding. */
198 #define UNDERFLOW_EXCEPTION_BEFORE_ROUNDING (TININESS_AFTER_ROUNDING \
199 ? 0 \
200 : UNDERFLOW_EXCEPTION)
201
202 /* Various constants (we must supply them precalculated for accuracy). */
203 #define M_PI_6l .52359877559829887307710723054658383L
204 #define M_E2l 7.389056098930650227230427460575008L
205 #define M_E3l 20.085536923187667740928529654581719L
206 #define M_2_SQRT_PIl 3.5449077018110320545963349666822903L /* 2 sqrt (M_PIl) */
207 #define M_SQRT_PIl 1.7724538509055160272981674833411451L /* sqrt (M_PIl) */
208 #define M_LOG_SQRT_PIl 0.57236494292470008707171367567652933L /* log(sqrt(M_PIl)) */
209 #define M_LOG_2_SQRT_PIl 1.265512123484645396488945797134706L /* log(2*sqrt(M_PIl)) */
210 #define M_PI_34l 2.356194490192344928846982537459627163L /* 3*pi/4 */
211 #define M_PI_34_LOG10El 1.023282265381381010614337719073516828L
212 #define M_PI2_LOG10El 0.682188176920920673742891812715677885L
213 #define M_PI4_LOG10El 0.341094088460460336871445906357838943L
214 #define M_PI_LOG10El 1.364376353841841347485783625431355770L
215 #define M_1_DIV_El 0.367879441171442321595523770161460867L /* 1 div e */
216
217 #define ulps_file_name "ULPs" /* Name of the ULPs file. */
218 static FILE *ulps_file; /* File to document difference. */
219 static int output_ulps; /* Should ulps printed? */
220 static char *output_dir; /* Directory where generated files will be written. */
221
222 static int noErrors; /* number of errors */
223 static int noTests; /* number of tests (without testing exceptions) */
224 static int noExcTests; /* number of tests for exception flags */
225 static int noErrnoTests;/* number of tests for errno values */
226
227 static int verbose;
228 static int output_max_error; /* Should the maximal errors printed? */
229 static int output_points; /* Should the single function results printed? */
230 static int ignore_max_ulp; /* Should we ignore max_ulp? */
231
232 #define plus_zero CHOOSE (0.0L, 0.0, 0.0f, \
233 0.0L, 0.0, 0.0f)
234 #define minus_zero CHOOSE (-0.0L, -0.0, -0.0f, \
235 -0.0L, -0.0, -0.0f)
236 #define plus_infty CHOOSE (HUGE_VALL, HUGE_VAL, HUGE_VALF, \
237 HUGE_VALL, HUGE_VAL, HUGE_VALF)
238 #define minus_infty CHOOSE (-HUGE_VALL, -HUGE_VAL, -HUGE_VALF, \
239 -HUGE_VALL, -HUGE_VAL, -HUGE_VALF)
240 #define qnan_value FUNC (__builtin_nan) ("")
241 #define max_value CHOOSE (LDBL_MAX, DBL_MAX, FLT_MAX, \
242 LDBL_MAX, DBL_MAX, FLT_MAX)
243 #define min_value CHOOSE (LDBL_MIN, DBL_MIN, FLT_MIN, \
244 LDBL_MIN, DBL_MIN, FLT_MIN)
245 #define min_subnorm_value CHOOSE (__LDBL_DENORM_MIN__, \
246 __DBL_DENORM_MIN__, \
247 __FLT_DENORM_MIN__, \
248 __LDBL_DENORM_MIN__, \
249 __DBL_DENORM_MIN__, \
250 __FLT_DENORM_MIN__)
251
252 static FLOAT max_error, real_max_error, imag_max_error;
253
254
255 #define BUILD_COMPLEX(real, imag) \
256 ({ __complex__ FLOAT __retval; \
257 __real__ __retval = (real); \
258 __imag__ __retval = (imag); \
259 __retval; })
260 #define BUILD_COMPLEX_ULP(real, imag) ((real) + I * (imag))
261
262 #define MANT_DIG CHOOSE ((LDBL_MANT_DIG-1), (DBL_MANT_DIG-1), (FLT_MANT_DIG-1), \
263 (LDBL_MANT_DIG-1), (DBL_MANT_DIG-1), (FLT_MANT_DIG-1))
264
265 static void
266 init_max_error (void)
267 {
268 max_error = 0;
269 real_max_error = 0;
270 imag_max_error = 0;
271 feclearexcept (FE_ALL_EXCEPT);
272 errno = 0;
273 }
274
275 static void
276 set_max_error (FLOAT current, FLOAT *curr_max_error)
277 {
278 if (current > *curr_max_error)
279 *curr_max_error = current;
280 }
281
282
283 /* Print a FLOAT. */
284 static void
285 print_float (FLOAT f)
286 {
287 /* As printf doesn't differ between a sNaN and a qNaN, do this manually. */
288 if (issignaling (f))
289 printf ("sNaN\n");
290 else if (isnan (f))
291 printf ("qNaN\n");
292 else
293 printf ("% .20" PRINTF_EXPR " % .20" PRINTF_XEXPR "\n", f, f);
294 }
295
296 /* Should the message print to screen? This depends on the verbose flag,
297 and the test status. */
298 static int
299 print_screen (int ok)
300 {
301 if (output_points
302 && (verbose > 1
303 || (verbose == 1 && ok == 0)))
304 return 1;
305 return 0;
306 }
307
308
309 /* Should the message print to screen? This depends on the verbose flag,
310 and the test status. */
311 static int
312 print_screen_max_error (int ok)
313 {
314 if (output_max_error
315 && (verbose > 1
316 || ((verbose == 1) && (ok == 0))))
317 return 1;
318 return 0;
319 }
320
321 /* Update statistic counters. */
322 static void
323 update_stats (int ok)
324 {
325 ++noTests;
326 if (!ok)
327 ++noErrors;
328 }
329
330 static void
331 print_ulps (const char *test_name, FLOAT ulp)
332 {
333 if (output_ulps)
334 {
335 fprintf (ulps_file, "Test \"%s\":\n", test_name);
336 fprintf (ulps_file, "%s: %.0" PRINTF_NEXPR "\n",
337 CHOOSE("ldouble", "double", "float",
338 "ildouble", "idouble", "ifloat"),
339 FUNC(ceil) (ulp));
340 }
341 }
342
343 static void
344 print_function_ulps (const char *function_name, FLOAT ulp)
345 {
346 if (output_ulps)
347 {
348 fprintf (ulps_file, "Function: \"%s\":\n", function_name);
349 fprintf (ulps_file, "%s: %.0" PRINTF_NEXPR "\n",
350 CHOOSE("ldouble", "double", "float",
351 "ildouble", "idouble", "ifloat"),
352 FUNC(ceil) (ulp));
353 }
354 }
355
356
357 static void
358 print_complex_function_ulps (const char *function_name, FLOAT real_ulp,
359 FLOAT imag_ulp)
360 {
361 if (output_ulps)
362 {
363 if (real_ulp != 0.0)
364 {
365 fprintf (ulps_file, "Function: Real part of \"%s\":\n", function_name);
366 fprintf (ulps_file, "%s: %.0" PRINTF_NEXPR "\n",
367 CHOOSE("ldouble", "double", "float",
368 "ildouble", "idouble", "ifloat"),
369 FUNC(ceil) (real_ulp));
370 }
371 if (imag_ulp != 0.0)
372 {
373 fprintf (ulps_file, "Function: Imaginary part of \"%s\":\n", function_name);
374 fprintf (ulps_file, "%s: %.0" PRINTF_NEXPR "\n",
375 CHOOSE("ldouble", "double", "float",
376 "ildouble", "idouble", "ifloat"),
377 FUNC(ceil) (imag_ulp));
378 }
379
380
381 }
382 }
383
384
385
386 /* Test if Floating-Point stack hasn't changed */
387 static void
388 fpstack_test (const char *test_name)
389 {
390 #if defined (__i386__) || defined (__x86_64__)
391 static int old_stack;
392 int sw;
393
394 asm ("fnstsw" : "=a" (sw));
395 sw >>= 11;
396 sw &= 7;
397
398 if (sw != old_stack)
399 {
400 printf ("FP-Stack wrong after test %s (%d, should be %d)\n",
401 test_name, sw, old_stack);
402 ++noErrors;
403 old_stack = sw;
404 }
405 #endif
406 }
407
408
409 static void
410 print_max_error (const char *func_name, FLOAT allowed)
411 {
412 int ok = 0;
413
414 if (max_error == 0.0 || (max_error <= allowed && !ignore_max_ulp))
415 {
416 ok = 1;
417 }
418
419 if (!ok)
420 print_function_ulps (func_name, max_error);
421
422
423 if (print_screen_max_error (ok))
424 {
425 printf ("Maximal error of `%s'\n", func_name);
426 printf (" is : %.0" PRINTF_NEXPR " ulp\n", FUNC(ceil) (max_error));
427 printf (" accepted: %.0" PRINTF_NEXPR " ulp\n", FUNC(ceil) (allowed));
428 }
429
430 update_stats (ok);
431 }
432
433
434 static void
435 print_complex_max_error (const char *func_name, __complex__ FLOAT allowed)
436 {
437 int ok = 0;
438
439 if ((real_max_error == 0 && imag_max_error == 0)
440 || (real_max_error <= __real__ allowed
441 && imag_max_error <= __imag__ allowed
442 && !ignore_max_ulp))
443 {
444 ok = 1;
445 }
446
447 if (!ok)
448 print_complex_function_ulps (func_name, real_max_error, imag_max_error);
449
450
451 if (print_screen_max_error (ok))
452 {
453 printf ("Maximal error of real part of: %s\n", func_name);
454 printf (" is : %.0" PRINTF_NEXPR " ulp\n",
455 FUNC(ceil) (real_max_error));
456 printf (" accepted: %.0" PRINTF_NEXPR " ulp\n",
457 FUNC(ceil) (__real__ allowed));
458 printf ("Maximal error of imaginary part of: %s\n", func_name);
459 printf (" is : %.0" PRINTF_NEXPR " ulp\n",
460 FUNC(ceil) (imag_max_error));
461 printf (" accepted: %.0" PRINTF_NEXPR " ulp\n",
462 FUNC(ceil) (__imag__ allowed));
463 }
464
465 update_stats (ok);
466 }
467
468
469 /* Test whether a given exception was raised. */
470 static void
471 test_single_exception (const char *test_name,
472 int exception,
473 int exc_flag,
474 int fe_flag,
475 const char *flag_name)
476 {
477 #ifndef TEST_INLINE
478 int ok = 1;
479 if (exception & exc_flag)
480 {
481 if (fetestexcept (fe_flag))
482 {
483 if (print_screen (1))
484 printf ("Pass: %s: Exception \"%s\" set\n", test_name, flag_name);
485 }
486 else
487 {
488 ok = 0;
489 if (print_screen (0))
490 printf ("Failure: %s: Exception \"%s\" not set\n",
491 test_name, flag_name);
492 }
493 }
494 else
495 {
496 if (fetestexcept (fe_flag))
497 {
498 ok = 0;
499 if (print_screen (0))
500 printf ("Failure: %s: Exception \"%s\" set\n",
501 test_name, flag_name);
502 }
503 else
504 {
505 if (print_screen (1))
506 printf ("%s: Exception \"%s\" not set\n", test_name,
507 flag_name);
508 }
509 }
510 if (!ok)
511 ++noErrors;
512
513 #endif
514 }
515
516
517 /* Test whether exceptions given by EXCEPTION are raised. Ignore thereby
518 allowed but not required exceptions.
519 */
520 static void
521 test_exceptions (const char *test_name, int exception)
522 {
523 ++noExcTests;
524 #ifdef FE_DIVBYZERO
525 if ((exception & DIVIDE_BY_ZERO_EXCEPTION_OK) == 0)
526 test_single_exception (test_name, exception,
527 DIVIDE_BY_ZERO_EXCEPTION, FE_DIVBYZERO,
528 "Divide by zero");
529 #endif
530 #ifdef FE_INVALID
531 if ((exception & INVALID_EXCEPTION_OK) == 0)
532 test_single_exception (test_name, exception, INVALID_EXCEPTION, FE_INVALID,
533 "Invalid operation");
534 #endif
535 #ifdef FE_OVERFLOW
536 if ((exception & OVERFLOW_EXCEPTION_OK) == 0)
537 test_single_exception (test_name, exception, OVERFLOW_EXCEPTION,
538 FE_OVERFLOW, "Overflow");
539 #endif
540 #ifdef FE_UNDERFLOW
541 if ((exception & UNDERFLOW_EXCEPTION_OK) == 0)
542 test_single_exception (test_name, exception, UNDERFLOW_EXCEPTION,
543 FE_UNDERFLOW, "Underflow");
544 #endif
545 #ifdef FE_INEXACT
546 if ((exception & (INEXACT_EXCEPTION | NO_INEXACT_EXCEPTION)) != 0)
547 test_single_exception (test_name, exception, INEXACT_EXCEPTION,
548 FE_INEXACT, "Inexact");
549 #endif
550 feclearexcept (FE_ALL_EXCEPT);
551 }
552
553 /* Test whether errno for TEST_NAME, set to ERRNO_VALUE, has value
554 EXPECTED_VALUE (description EXPECTED_NAME). */
555 static void
556 test_single_errno (const char *test_name, int errno_value,
557 int expected_value, const char *expected_name)
558 {
559 #ifndef TEST_INLINE
560 if (errno_value == expected_value)
561 {
562 if (print_screen (1))
563 printf ("Pass: %s: errno set to %d (%s)\n", test_name, errno_value,
564 expected_name);
565 }
566 else
567 {
568 ++noErrors;
569 if (print_screen (0))
570 printf ("Failure: %s: errno set to %d, expected %d (%s)\n",
571 test_name, errno_value, expected_value, expected_name);
572 }
573 #endif
574 }
575
576 /* Test whether errno (value ERRNO_VALUE) has been for TEST_NAME set
577 as required by EXCEPTIONS. */
578 static void
579 test_errno (const char *test_name, int errno_value, int exceptions)
580 {
581 ++noErrnoTests;
582 if (exceptions & ERRNO_UNCHANGED)
583 test_single_errno (test_name, errno_value, 0, "unchanged");
584 if (exceptions & ERRNO_EDOM)
585 test_single_errno (test_name, errno_value, EDOM, "EDOM");
586 if (exceptions & ERRNO_ERANGE)
587 test_single_errno (test_name, errno_value, ERANGE, "ERANGE");
588 }
589
590 static void
591 check_float_internal (const char *test_name, FLOAT computed, FLOAT expected,
592 FLOAT max_ulp, int exceptions,
593 FLOAT *curr_max_error)
594 {
595 int ok = 0;
596 int print_diff = 0;
597 FLOAT diff = 0;
598 FLOAT ulp = 0;
599 int errno_value = errno;
600
601 test_exceptions (test_name, exceptions);
602 test_errno (test_name, errno_value, exceptions);
603 if (issignaling (computed) && issignaling (expected))
604 ok = 1;
605 else if (issignaling (computed) || issignaling (expected))
606 ok = 0;
607 else if (isnan (computed) && isnan (expected))
608 ok = 1;
609 else if (isinf (computed) && isinf (expected))
610 {
611 /* Test for sign of infinities. */
612 if ((exceptions & IGNORE_ZERO_INF_SIGN) == 0
613 && signbit (computed) != signbit (expected))
614 {
615 ok = 0;
616 printf ("infinity has wrong sign.\n");
617 }
618 else
619 ok = 1;
620 }
621 /* Don't calculate ULPs for infinities or any kind of NaNs. */
622 else if (isinf (computed) || isnan (computed)
623 || isinf (expected) || isnan (expected))
624 ok = 0;
625 else
626 {
627 diff = FUNC(fabs) (computed - expected);
628 switch (fpclassify (expected))
629 {
630 case FP_ZERO:
631 /* ilogb (0) isn't allowed. */
632 ulp = diff / FUNC(ldexp) (1.0, - MANT_DIG);
633 break;
634 case FP_NORMAL:
635 ulp = diff / FUNC(ldexp) (1.0, FUNC(ilogb) (expected) - MANT_DIG);
636 break;
637 case FP_SUBNORMAL:
638 /* 1ulp for a subnormal value, shifted by MANT_DIG, is the
639 least normal value. */
640 ulp = (FUNC(ldexp) (diff, MANT_DIG) / min_value);
641 break;
642 default:
643 /* It should never happen. */
644 abort ();
645 break;
646 }
647 set_max_error (ulp, curr_max_error);
648 print_diff = 1;
649 if ((exceptions & IGNORE_ZERO_INF_SIGN) == 0
650 && computed == 0.0 && expected == 0.0
651 && signbit(computed) != signbit (expected))
652 ok = 0;
653 else if (ulp <= 0.5 || (ulp <= max_ulp && !ignore_max_ulp))
654 ok = 1;
655 else
656 {
657 ok = 0;
658 print_ulps (test_name, ulp);
659 }
660
661 }
662 if (print_screen (ok))
663 {
664 if (!ok)
665 printf ("Failure: ");
666 printf ("Test: %s\n", test_name);
667 printf ("Result:\n");
668 printf (" is: ");
669 print_float (computed);
670 printf (" should be: ");
671 print_float (expected);
672 if (print_diff)
673 {
674 printf (" difference: % .20" PRINTF_EXPR " % .20" PRINTF_XEXPR
675 "\n", diff, diff);
676 printf (" ulp : % .4" PRINTF_NEXPR "\n", ulp);
677 printf (" max.ulp : % .4" PRINTF_NEXPR "\n", max_ulp);
678 }
679 }
680 update_stats (ok);
681
682 fpstack_test (test_name);
683 errno = 0;
684 }
685
686
687 static void
688 check_float (const char *test_name, FLOAT computed, FLOAT expected,
689 FLOAT max_ulp, int exceptions)
690 {
691 check_float_internal (test_name, computed, expected, max_ulp,
692 exceptions, &max_error);
693 }
694
695
696 static void
697 check_complex (const char *test_name, __complex__ FLOAT computed,
698 __complex__ FLOAT expected,
699 __complex__ FLOAT max_ulp,
700 int exception)
701 {
702 FLOAT part_comp, part_exp, part_max_ulp;
703 char *str;
704
705 if (asprintf (&str, "Real part of: %s", test_name) == -1)
706 abort ();
707
708 part_comp = __real__ computed;
709 part_exp = __real__ expected;
710 part_max_ulp = __real__ max_ulp;
711
712 check_float_internal (str, part_comp, part_exp, part_max_ulp,
713 exception, &real_max_error);
714 free (str);
715
716 if (asprintf (&str, "Imaginary part of: %s", test_name) == -1)
717 abort ();
718
719 part_comp = __imag__ computed;
720 part_exp = __imag__ expected;
721 part_max_ulp = __imag__ max_ulp;
722
723 /* Don't check again for exceptions or errno, just pass through the
724 zero/inf sign test. */
725 check_float_internal (str, part_comp, part_exp, part_max_ulp,
726 exception & IGNORE_ZERO_INF_SIGN,
727 &imag_max_error);
728 free (str);
729 }
730
731
732 /* Check that computed and expected values are equal (int values). */
733 static void
734 check_int (const char *test_name, int computed, int expected, int max_ulp,
735 int exceptions)
736 {
737 int diff = computed - expected;
738 int ok = 0;
739 int errno_value = errno;
740
741 test_exceptions (test_name, exceptions);
742 test_errno (test_name, errno_value, exceptions);
743 noTests++;
744 if (abs (diff) <= max_ulp)
745 ok = 1;
746
747 if (!ok)
748 print_ulps (test_name, diff);
749
750 if (print_screen (ok))
751 {
752 if (!ok)
753 printf ("Failure: ");
754 printf ("Test: %s\n", test_name);
755 printf ("Result:\n");
756 printf (" is: %d\n", computed);
757 printf (" should be: %d\n", expected);
758 }
759
760 update_stats (ok);
761 fpstack_test (test_name);
762 errno = 0;
763 }
764
765
766 /* Check that computed and expected values are equal (long int values). */
767 static void
768 check_long (const char *test_name, long int computed, long int expected,
769 long int max_ulp, int exceptions)
770 {
771 long int diff = computed - expected;
772 int ok = 0;
773 int errno_value = errno;
774
775 test_exceptions (test_name, exceptions);
776 test_errno (test_name, errno_value, exceptions);
777 noTests++;
778 if (labs (diff) <= max_ulp)
779 ok = 1;
780
781 if (!ok)
782 print_ulps (test_name, diff);
783
784 if (print_screen (ok))
785 {
786 if (!ok)
787 printf ("Failure: ");
788 printf ("Test: %s\n", test_name);
789 printf ("Result:\n");
790 printf (" is: %ld\n", computed);
791 printf (" should be: %ld\n", expected);
792 }
793
794 update_stats (ok);
795 fpstack_test (test_name);
796 errno = 0;
797 }
798
799
800 /* Check that computed value is true/false. */
801 static void
802 check_bool (const char *test_name, int computed, int expected,
803 long int max_ulp, int exceptions)
804 {
805 int ok = 0;
806 int errno_value = errno;
807
808 test_exceptions (test_name, exceptions);
809 test_errno (test_name, errno_value, exceptions);
810 noTests++;
811 if ((computed == 0) == (expected == 0))
812 ok = 1;
813
814 if (print_screen (ok))
815 {
816 if (!ok)
817 printf ("Failure: ");
818 printf ("Test: %s\n", test_name);
819 printf ("Result:\n");
820 printf (" is: %d\n", computed);
821 printf (" should be: %d\n", expected);
822 }
823
824 update_stats (ok);
825 fpstack_test (test_name);
826 errno = 0;
827 }
828
829
830 /* check that computed and expected values are equal (long int values) */
831 static void
832 check_longlong (const char *test_name, long long int computed,
833 long long int expected,
834 long long int max_ulp,
835 int exceptions)
836 {
837 long long int diff = computed - expected;
838 int ok = 0;
839 int errno_value = errno;
840
841 test_exceptions (test_name, exceptions);
842 test_errno (test_name, errno_value, exceptions);
843 noTests++;
844 if (llabs (diff) <= max_ulp)
845 ok = 1;
846
847 if (!ok)
848 print_ulps (test_name, diff);
849
850 if (print_screen (ok))
851 {
852 if (!ok)
853 printf ("Failure:");
854 printf ("Test: %s\n", test_name);
855 printf ("Result:\n");
856 printf (" is: %lld\n", computed);
857 printf (" should be: %lld\n", expected);
858 }
859
860 update_stats (ok);
861 fpstack_test (test_name);
862 errno = 0;
863 }
864
865 /* Structures for each kind of test. */
866 struct test_f_f_data
867 {
868 const char *test_name;
869 FLOAT arg;
870 FLOAT expected;
871 FLOAT max_ulp;
872 int exceptions;
873 };
874 struct test_ff_f_data
875 {
876 const char *test_name;
877 FLOAT arg1, arg2;
878 FLOAT expected;
879 FLOAT max_ulp;
880 int exceptions;
881 };
882 struct test_ff_f_data_nexttoward
883 {
884 const char *test_name;
885 FLOAT arg1;
886 long double arg2;
887 FLOAT expected;
888 FLOAT max_ulp;
889 int exceptions;
890 };
891 struct test_fi_f_data
892 {
893 const char *test_name;
894 FLOAT arg1;
895 int arg2;
896 FLOAT expected;
897 FLOAT max_ulp;
898 int exceptions;
899 };
900 struct test_fl_f_data
901 {
902 const char *test_name;
903 FLOAT arg1;
904 long int arg2;
905 FLOAT expected;
906 FLOAT max_ulp;
907 int exceptions;
908 };
909 struct test_if_f_data
910 {
911 const char *test_name;
912 int arg1;
913 FLOAT arg2;
914 FLOAT expected;
915 FLOAT max_ulp;
916 int exceptions;
917 };
918 struct test_fff_f_data
919 {
920 const char *test_name;
921 FLOAT arg1, arg2, arg3;
922 FLOAT expected;
923 FLOAT max_ulp;
924 int exceptions;
925 };
926 struct test_c_f_data
927 {
928 const char *test_name;
929 FLOAT argr, argc;
930 FLOAT expected;
931 FLOAT max_ulp;
932 int exceptions;
933 };
934 /* Used for both RUN_TEST_LOOP_f_f1 and RUN_TEST_LOOP_fI_f1. */
935 struct test_f_f1_data
936 {
937 const char *test_name;
938 FLOAT arg;
939 FLOAT expected;
940 FLOAT max_ulp;
941 int exceptions;
942 const char *extra_name;
943 int extra_init;
944 int extra_test;
945 int extra_expected;
946 int extra_ulp;
947 };
948 struct test_fF_f1_data
949 {
950 const char *test_name;
951 FLOAT arg;
952 FLOAT expected;
953 FLOAT max_ulp;
954 int exceptions;
955 const char *extra_name;
956 FLOAT extra_init;
957 int extra_test;
958 FLOAT extra_expected;
959 FLOAT extra_ulp;
960 };
961 struct test_ffI_f1_data
962 {
963 const char *test_name;
964 FLOAT arg1, arg2;
965 FLOAT expected;
966 FLOAT max_ulp;
967 int exceptions;
968 const char *extra_name;
969 int extra_init;
970 int extra_test;
971 int extra_expected;
972 int extra_ulp;
973 };
974 struct test_c_c_data
975 {
976 const char *test_name;
977 FLOAT argr, argc;
978 FLOAT expr, expc;
979 __complex__ FLOAT max_ulp;
980 int exceptions;
981 };
982 struct test_cc_c_data
983 {
984 const char *test_name;
985 FLOAT arg1r, arg1c, arg2r, arg2c;
986 FLOAT expr, expc;
987 __complex__ FLOAT max_ulp;
988 int exceptions;
989 };
990 /* Used for all of RUN_TEST_LOOP_f_i, RUN_TEST_LOOP_f_i_tg,
991 RUN_TEST_LOOP_f_b and RUN_TEST_LOOP_f_b_tg. */
992 struct test_f_i_data
993 {
994 const char *test_name;
995 FLOAT arg;
996 int expected;
997 int max_ulp;
998 int exceptions;
999 };
1000 struct test_ff_i_data
1001 {
1002 const char *test_name;
1003 FLOAT arg1, arg2;
1004 int expected;
1005 int max_ulp;
1006 int exceptions;
1007 };
1008 struct test_f_l_data
1009 {
1010 const char *test_name;
1011 FLOAT arg;
1012 long int expected;
1013 long int max_ulp;
1014 int exceptions;
1015 };
1016 struct test_f_L_data
1017 {
1018 const char *test_name;
1019 FLOAT arg;
1020 long long int expected;
1021 long long int max_ulp;
1022 int exceptions;
1023 };
1024 struct test_sincos_data
1025 {
1026 FLOAT arg;
1027 const char *test_name_sin;
1028 FLOAT expected_sin;
1029 FLOAT max_ulp_sin;
1030 const char *test_name_cos;
1031 FLOAT expected_cos;
1032 FLOAT max_ulp_cos;
1033 int exceptions;
1034 };
1035
1036 /* Set the rounding mode, or restore the saved value. */
1037 #define IF_ROUND_INIT_ /* Empty. */
1038 #define IF_ROUND_INIT_FE_DOWNWARD \
1039 int save_round_mode = fegetround (); \
1040 if (fesetround (FE_DOWNWARD) == 0)
1041 #define IF_ROUND_INIT_FE_TONEAREST \
1042 int save_round_mode = fegetround (); \
1043 if (fesetround (FE_TONEAREST) == 0)
1044 #define IF_ROUND_INIT_FE_TOWARDZERO \
1045 int save_round_mode = fegetround (); \
1046 if (fesetround (FE_TOWARDZERO) == 0)
1047 #define IF_ROUND_INIT_FE_UPWARD \
1048 int save_round_mode = fegetround (); \
1049 if (fesetround (FE_UPWARD) == 0)
1050 #define ROUND_RESTORE_ /* Empty. */
1051 #define ROUND_RESTORE_FE_DOWNWARD \
1052 fesetround (save_round_mode)
1053 #define ROUND_RESTORE_FE_TONEAREST \
1054 fesetround (save_round_mode)
1055 #define ROUND_RESTORE_FE_TOWARDZERO \
1056 fesetround (save_round_mode)
1057 #define ROUND_RESTORE_FE_UPWARD \
1058 fesetround (save_round_mode)
1059
1060 /* Run an individual test, including any required setup and checking
1061 of results, or loop over all tests in an array. */
1062 #define RUN_TEST_f_f(TEST_NAME, FUNC_NAME, ARG, EXPECTED, \
1063 MAX_ULP, EXCEPTIONS) \
1064 check_float (TEST_NAME, FUNC (FUNC_NAME) (ARG), EXPECTED, \
1065 MAX_ULP, EXCEPTIONS)
1066 #define RUN_TEST_LOOP_f_f(FUNC_NAME, ARRAY, ROUNDING_MODE) \
1067 IF_ROUND_INIT_ ## ROUNDING_MODE \
1068 for (size_t i = 0; i < sizeof (ARRAY) / sizeof (ARRAY)[0]; i++) \
1069 RUN_TEST_f_f ((ARRAY)[i].test_name, FUNC_NAME, (ARRAY)[i].arg, \
1070 (ARRAY)[i].expected, (ARRAY)[i].max_ulp, \
1071 (ARRAY)[i].exceptions); \
1072 ROUND_RESTORE_ ## ROUNDING_MODE
1073 #define RUN_TEST_2_f(TEST_NAME, FUNC_NAME, ARG1, ARG2, EXPECTED, \
1074 MAX_ULP, EXCEPTIONS) \
1075 check_float (TEST_NAME, FUNC (FUNC_NAME) (ARG1, ARG2), EXPECTED, \
1076 MAX_ULP, EXCEPTIONS)
1077 #define RUN_TEST_LOOP_2_f(FUNC_NAME, ARRAY, ROUNDING_MODE) \
1078 IF_ROUND_INIT_ ## ROUNDING_MODE \
1079 for (size_t i = 0; i < sizeof (ARRAY) / sizeof (ARRAY)[0]; i++) \
1080 RUN_TEST_2_f ((ARRAY)[i].test_name, FUNC_NAME, (ARRAY)[i].arg1, \
1081 (ARRAY)[i].arg2, (ARRAY)[i].expected, \
1082 (ARRAY)[i].max_ulp, (ARRAY)[i].exceptions); \
1083 ROUND_RESTORE_ ## ROUNDING_MODE
1084 #define RUN_TEST_ff_f RUN_TEST_2_f
1085 #define RUN_TEST_LOOP_ff_f RUN_TEST_LOOP_2_f
1086 #define RUN_TEST_fi_f RUN_TEST_2_f
1087 #define RUN_TEST_LOOP_fi_f RUN_TEST_LOOP_2_f
1088 #define RUN_TEST_fl_f RUN_TEST_2_f
1089 #define RUN_TEST_LOOP_fl_f RUN_TEST_LOOP_2_f
1090 #define RUN_TEST_if_f RUN_TEST_2_f
1091 #define RUN_TEST_LOOP_if_f RUN_TEST_LOOP_2_f
1092 #define RUN_TEST_fff_f(TEST_NAME, FUNC_NAME, ARG1, ARG2, ARG3, \
1093 EXPECTED, MAX_ULP, EXCEPTIONS) \
1094 check_float (TEST_NAME, FUNC (FUNC_NAME) (ARG1, ARG2, ARG3), \
1095 EXPECTED, MAX_ULP, EXCEPTIONS)
1096 #define RUN_TEST_LOOP_fff_f(FUNC_NAME, ARRAY, ROUNDING_MODE) \
1097 IF_ROUND_INIT_ ## ROUNDING_MODE \
1098 for (size_t i = 0; i < sizeof (ARRAY) / sizeof (ARRAY)[0]; i++) \
1099 RUN_TEST_fff_f ((ARRAY)[i].test_name, FUNC_NAME, (ARRAY)[i].arg1, \
1100 (ARRAY)[i].arg2, (ARRAY)[i].arg3, \
1101 (ARRAY)[i].expected, (ARRAY)[i].max_ulp, \
1102 (ARRAY)[i].exceptions); \
1103 ROUND_RESTORE_ ## ROUNDING_MODE
1104 #define RUN_TEST_c_f(TEST_NAME, FUNC_NAME, ARG1, ARG2, EXPECTED, \
1105 MAX_ULP, EXCEPTIONS) \
1106 check_float (TEST_NAME, \
1107 FUNC (FUNC_NAME) (BUILD_COMPLEX (ARG1, ARG2)), \
1108 EXPECTED, MAX_ULP, EXCEPTIONS)
1109 #define RUN_TEST_LOOP_c_f(FUNC_NAME, ARRAY, ROUNDING_MODE) \
1110 IF_ROUND_INIT_ ## ROUNDING_MODE \
1111 for (size_t i = 0; i < sizeof (ARRAY) / sizeof (ARRAY)[0]; i++) \
1112 RUN_TEST_c_f ((ARRAY)[i].test_name, FUNC_NAME, (ARRAY)[i].argr, \
1113 (ARRAY)[i].argc, (ARRAY)[i].expected, \
1114 (ARRAY)[i].max_ulp, (ARRAY)[i].exceptions); \
1115 ROUND_RESTORE_ ## ROUNDING_MODE
1116 #define RUN_TEST_f_f1(TEST_NAME, FUNC_NAME, ARG, EXPECTED, \
1117 MAX_ULP, EXCEPTIONS, \
1118 EXTRA_NAME, EXTRA_VAR, EXTRA_INIT, EXTRA_TEST, \
1119 EXTRA_EXPECTED, EXTRA_ULP) \
1120 do \
1121 { \
1122 (EXTRA_VAR) = (EXTRA_INIT); \
1123 check_float (TEST_NAME, FUNC (FUNC_NAME) (ARG), EXPECTED, \
1124 MAX_ULP, EXCEPTIONS); \
1125 if (EXTRA_TEST) \
1126 check_int (EXTRA_NAME, EXTRA_VAR, EXTRA_EXPECTED, \
1127 EXTRA_ULP, 0); \
1128 } \
1129 while (0)
1130 #define RUN_TEST_LOOP_f_f1(FUNC_NAME, ARRAY, ROUNDING_MODE, EXTRA_VAR) \
1131 IF_ROUND_INIT_ ## ROUNDING_MODE \
1132 for (size_t i = 0; i < sizeof (ARRAY) / sizeof (ARRAY)[0]; i++) \
1133 RUN_TEST_f_f1 ((ARRAY)[i].test_name, FUNC_NAME, (ARRAY)[i].arg, \
1134 (ARRAY)[i].expected, (ARRAY)[i].max_ulp, \
1135 (ARRAY)[i].exceptions, (ARRAY)[i].extra_name, \
1136 EXTRA_VAR, (ARRAY)[i].extra_init, \
1137 (ARRAY)[i].extra_test, (ARRAY)[i].extra_expected, \
1138 (ARRAY)[i].extra_ulp); \
1139 ROUND_RESTORE_ ## ROUNDING_MODE
1140 #define RUN_TEST_fF_f1(TEST_NAME, FUNC_NAME, ARG, EXPECTED, \
1141 MAX_ULP, EXCEPTIONS, \
1142 EXTRA_NAME, EXTRA_VAR, EXTRA_INIT, EXTRA_TEST, \
1143 EXTRA_EXPECTED, EXTRA_ULP) \
1144 do \
1145 { \
1146 (EXTRA_VAR) = (EXTRA_INIT); \
1147 check_float (TEST_NAME, FUNC (FUNC_NAME) (ARG, &(EXTRA_VAR)), \
1148 EXPECTED, MAX_ULP, EXCEPTIONS); \
1149 if (EXTRA_TEST) \
1150 check_float (EXTRA_NAME, EXTRA_VAR, EXTRA_EXPECTED, \
1151 EXTRA_ULP, 0); \
1152 } \
1153 while (0)
1154 #define RUN_TEST_LOOP_fF_f1(FUNC_NAME, ARRAY, ROUNDING_MODE, EXTRA_VAR) \
1155 IF_ROUND_INIT_ ## ROUNDING_MODE \
1156 for (size_t i = 0; i < sizeof (ARRAY) / sizeof (ARRAY)[0]; i++) \
1157 RUN_TEST_fF_f1 ((ARRAY)[i].test_name, FUNC_NAME, (ARRAY)[i].arg, \
1158 (ARRAY)[i].expected, (ARRAY)[i].max_ulp, \
1159 (ARRAY)[i].exceptions, (ARRAY)[i].extra_name, \
1160 EXTRA_VAR, (ARRAY)[i].extra_init, \
1161 (ARRAY)[i].extra_test, (ARRAY)[i].extra_expected, \
1162 (ARRAY)[i].extra_ulp); \
1163 ROUND_RESTORE_ ## ROUNDING_MODE
1164 #define RUN_TEST_fI_f1(TEST_NAME, FUNC_NAME, ARG, EXPECTED, \
1165 MAX_ULP, EXCEPTIONS, \
1166 EXTRA_NAME, EXTRA_VAR, EXTRA_INIT, EXTRA_TEST, \
1167 EXTRA_EXPECTED, EXTRA_ULP) \
1168 do \
1169 { \
1170 (EXTRA_VAR) = (EXTRA_INIT); \
1171 check_float (TEST_NAME, FUNC (FUNC_NAME) (ARG, &(EXTRA_VAR)), \
1172 EXPECTED, MAX_ULP, EXCEPTIONS); \
1173 if (EXTRA_TEST) \
1174 check_int (EXTRA_NAME, EXTRA_VAR, EXTRA_EXPECTED, \
1175 EXTRA_ULP, 0); \
1176 } \
1177 while (0)
1178 #define RUN_TEST_LOOP_fI_f1(FUNC_NAME, ARRAY, ROUNDING_MODE, EXTRA_VAR) \
1179 IF_ROUND_INIT_ ## ROUNDING_MODE \
1180 for (size_t i = 0; i < sizeof (ARRAY) / sizeof (ARRAY)[0]; i++) \
1181 RUN_TEST_fI_f1 ((ARRAY)[i].test_name, FUNC_NAME, (ARRAY)[i].arg, \
1182 (ARRAY)[i].expected, (ARRAY)[i].max_ulp, \
1183 (ARRAY)[i].exceptions, (ARRAY)[i].extra_name, \
1184 EXTRA_VAR, (ARRAY)[i].extra_init, \
1185 (ARRAY)[i].extra_test, (ARRAY)[i].extra_expected, \
1186 (ARRAY)[i].extra_ulp); \
1187 ROUND_RESTORE_ ## ROUNDING_MODE
1188 #define RUN_TEST_ffI_f1(TEST_NAME, FUNC_NAME, ARG1, ARG2, EXPECTED, \
1189 MAX_ULP, EXCEPTIONS, \
1190 EXTRA_NAME, EXTRA_VAR, EXTRA_INIT, EXTRA_TEST, \
1191 EXTRA_EXPECTED, EXTRA_ULP) \
1192 do \
1193 { \
1194 (EXTRA_VAR) = (EXTRA_INIT); \
1195 check_float (TEST_NAME, \
1196 FUNC (FUNC_NAME) (ARG1, ARG2, &(EXTRA_VAR)), \
1197 EXPECTED, MAX_ULP, EXCEPTIONS); \
1198 if (EXTRA_TEST) \
1199 check_int (EXTRA_NAME, EXTRA_VAR, EXTRA_EXPECTED, \
1200 EXTRA_ULP, 0); \
1201 } \
1202 while (0)
1203 #define RUN_TEST_LOOP_ffI_f1(FUNC_NAME, ARRAY, ROUNDING_MODE, \
1204 EXTRA_VAR) \
1205 IF_ROUND_INIT_ ## ROUNDING_MODE \
1206 for (size_t i = 0; i < sizeof (ARRAY) / sizeof (ARRAY)[0]; i++) \
1207 RUN_TEST_ffI_f1 ((ARRAY)[i].test_name, FUNC_NAME, \
1208 (ARRAY)[i].arg1, (ARRAY)[i].arg2, \
1209 (ARRAY)[i].expected, (ARRAY)[i].max_ulp, \
1210 (ARRAY)[i].exceptions, (ARRAY)[i].extra_name, \
1211 EXTRA_VAR, (ARRAY)[i].extra_init, \
1212 (ARRAY)[i].extra_test, \
1213 (ARRAY)[i].extra_expected, \
1214 (ARRAY)[i].extra_ulp); \
1215 ROUND_RESTORE_ ## ROUNDING_MODE
1216 #define RUN_TEST_c_c(TEST_NAME, FUNC_NAME, ARGR, ARGC, EXPR, EXPC, \
1217 MAX_ULP, EXCEPTIONS) \
1218 check_complex (TEST_NAME, \
1219 FUNC (FUNC_NAME) (BUILD_COMPLEX (ARGR, ARGC)), \
1220 BUILD_COMPLEX (EXPR, EXPC), \
1221 MAX_ULP, EXCEPTIONS)
1222 #define RUN_TEST_LOOP_c_c(FUNC_NAME, ARRAY, ROUNDING_MODE) \
1223 IF_ROUND_INIT_ ## ROUNDING_MODE \
1224 for (size_t i = 0; i < sizeof (ARRAY) / sizeof (ARRAY)[0]; i++) \
1225 RUN_TEST_c_c ((ARRAY)[i].test_name, FUNC_NAME, (ARRAY)[i].argr, \
1226 (ARRAY)[i].argc, (ARRAY)[i].expr, (ARRAY)[i].expc, \
1227 (ARRAY)[i].max_ulp, (ARRAY)[i].exceptions); \
1228 ROUND_RESTORE_ ## ROUNDING_MODE
1229 #define RUN_TEST_cc_c(TEST_NAME, FUNC_NAME, ARG1R, ARG1C, ARG2R, ARG2C, \
1230 EXPR, EXPC, MAX_ULP, EXCEPTIONS) \
1231 check_complex (TEST_NAME, \
1232 FUNC (FUNC_NAME) (BUILD_COMPLEX (ARG1R, ARG1C), \
1233 BUILD_COMPLEX (ARG2R, ARG2C)), \
1234 BUILD_COMPLEX (EXPR, EXPC), \
1235 MAX_ULP, EXCEPTIONS)
1236 #define RUN_TEST_LOOP_cc_c(FUNC_NAME, ARRAY, ROUNDING_MODE) \
1237 IF_ROUND_INIT_ ## ROUNDING_MODE \
1238 for (size_t i = 0; i < sizeof (ARRAY) / sizeof (ARRAY)[0]; i++) \
1239 RUN_TEST_cc_c ((ARRAY)[i].test_name, FUNC_NAME, (ARRAY)[i].arg1r, \
1240 (ARRAY)[i].arg1c, (ARRAY)[i].arg2r, \
1241 (ARRAY)[i].arg2c, (ARRAY)[i].expr, \
1242 (ARRAY)[i].expc, (ARRAY)[i].max_ulp, \
1243 (ARRAY)[i].exceptions); \
1244 ROUND_RESTORE_ ## ROUNDING_MODE
1245 #define RUN_TEST_f_i(TEST_NAME, FUNC_NAME, ARG, EXPECTED, \
1246 MAX_ULP, EXCEPTIONS) \
1247 check_int (TEST_NAME, FUNC (FUNC_NAME) (ARG), EXPECTED, \
1248 MAX_ULP, EXCEPTIONS)
1249 #define RUN_TEST_LOOP_f_i(FUNC_NAME, ARRAY, ROUNDING_MODE) \
1250 IF_ROUND_INIT_ ## ROUNDING_MODE \
1251 for (size_t i = 0; i < sizeof (ARRAY) / sizeof (ARRAY)[0]; i++) \
1252 RUN_TEST_f_i ((ARRAY)[i].test_name, FUNC_NAME, (ARRAY)[i].arg, \
1253 (ARRAY)[i].expected, (ARRAY)[i].max_ulp, \
1254 (ARRAY)[i].exceptions); \
1255 ROUND_RESTORE_ ## ROUNDING_MODE
1256 #define RUN_TEST_f_i_tg(TEST_NAME, FUNC_NAME, ARG, EXPECTED, \
1257 MAX_ULP, EXCEPTIONS) \
1258 check_int (TEST_NAME, FUNC_NAME (ARG), EXPECTED, \
1259 MAX_ULP, EXCEPTIONS)
1260 #define RUN_TEST_LOOP_f_i_tg(FUNC_NAME, ARRAY, ROUNDING_MODE) \
1261 IF_ROUND_INIT_ ## ROUNDING_MODE \
1262 for (size_t i = 0; i < sizeof (ARRAY) / sizeof (ARRAY)[0]; i++) \
1263 RUN_TEST_f_i_tg ((ARRAY)[i].test_name, FUNC_NAME, (ARRAY)[i].arg, \
1264 (ARRAY)[i].expected, (ARRAY)[i].max_ulp, \
1265 (ARRAY)[i].exceptions); \
1266 ROUND_RESTORE_ ## ROUNDING_MODE
1267 #define RUN_TEST_ff_i_tg(TEST_NAME, FUNC_NAME, ARG1, ARG2, EXPECTED, \
1268 MAX_ULP, EXCEPTIONS) \
1269 check_int (TEST_NAME, FUNC_NAME (ARG1, ARG2), EXPECTED, \
1270 MAX_ULP, EXCEPTIONS)
1271 #define RUN_TEST_LOOP_ff_i_tg(FUNC_NAME, ARRAY, ROUNDING_MODE) \
1272 IF_ROUND_INIT_ ## ROUNDING_MODE \
1273 for (size_t i = 0; i < sizeof (ARRAY) / sizeof (ARRAY)[0]; i++) \
1274 RUN_TEST_ff_i_tg ((ARRAY)[i].test_name, FUNC_NAME, \
1275 (ARRAY)[i].arg1, (ARRAY)[i].arg2, \
1276 (ARRAY)[i].expected, (ARRAY)[i].max_ulp, \
1277 (ARRAY)[i].exceptions); \
1278 ROUND_RESTORE_ ## ROUNDING_MODE
1279 #define RUN_TEST_f_b(TEST_NAME, FUNC_NAME, ARG, EXPECTED, \
1280 MAX_ULP, EXCEPTIONS) \
1281 check_bool (TEST_NAME, FUNC (FUNC_NAME) (ARG), EXPECTED, \
1282 MAX_ULP, EXCEPTIONS)
1283 #define RUN_TEST_LOOP_f_b(FUNC_NAME, ARRAY, ROUNDING_MODE) \
1284 IF_ROUND_INIT_ ## ROUNDING_MODE \
1285 for (size_t i = 0; i < sizeof (ARRAY) / sizeof (ARRAY)[0]; i++) \
1286 RUN_TEST_f_b ((ARRAY)[i].test_name, FUNC_NAME, (ARRAY)[i].arg, \
1287 (ARRAY)[i].expected, (ARRAY)[i].max_ulp, \
1288 (ARRAY)[i].exceptions); \
1289 ROUND_RESTORE_ ## ROUNDING_MODE
1290 #define RUN_TEST_f_b_tg(TEST_NAME, FUNC_NAME, ARG, EXPECTED, \
1291 MAX_ULP, EXCEPTIONS) \
1292 check_bool (TEST_NAME, FUNC_NAME (ARG), EXPECTED, \
1293 MAX_ULP, EXCEPTIONS)
1294 #define RUN_TEST_LOOP_f_b_tg(FUNC_NAME, ARRAY, ROUNDING_MODE) \
1295 IF_ROUND_INIT_ ## ROUNDING_MODE \
1296 for (size_t i = 0; i < sizeof (ARRAY) / sizeof (ARRAY)[0]; i++) \
1297 RUN_TEST_f_b_tg ((ARRAY)[i].test_name, FUNC_NAME, (ARRAY)[i].arg, \
1298 (ARRAY)[i].expected, (ARRAY)[i].max_ulp, \
1299 (ARRAY)[i].exceptions); \
1300 ROUND_RESTORE_ ## ROUNDING_MODE
1301 #define RUN_TEST_f_l(TEST_NAME, FUNC_NAME, ARG, EXPECTED, \
1302 MAX_ULP, EXCEPTIONS) \
1303 check_long (TEST_NAME, FUNC (FUNC_NAME) (ARG), EXPECTED, \
1304 MAX_ULP, EXCEPTIONS)
1305 #define RUN_TEST_LOOP_f_l(FUNC_NAME, ARRAY, ROUNDING_MODE) \
1306 IF_ROUND_INIT_ ## ROUNDING_MODE \
1307 for (size_t i = 0; i < sizeof (ARRAY) / sizeof (ARRAY)[0]; i++) \
1308 RUN_TEST_f_l ((ARRAY)[i].test_name, FUNC_NAME, (ARRAY)[i].arg, \
1309 (ARRAY)[i].expected, (ARRAY)[i].max_ulp, \
1310 (ARRAY)[i].exceptions); \
1311 ROUND_RESTORE_ ## ROUNDING_MODE
1312 #define RUN_TEST_f_L(TEST_NAME, FUNC_NAME, ARG, EXPECTED, \
1313 MAX_ULP, EXCEPTIONS) \
1314 check_longlong (TEST_NAME, FUNC (FUNC_NAME) (ARG), EXPECTED, \
1315 MAX_ULP, EXCEPTIONS)
1316 #define RUN_TEST_LOOP_f_L(FUNC_NAME, ARRAY, ROUNDING_MODE) \
1317 IF_ROUND_INIT_ ## ROUNDING_MODE \
1318 for (size_t i = 0; i < sizeof (ARRAY) / sizeof (ARRAY)[0]; i++) \
1319 RUN_TEST_f_L ((ARRAY)[i].test_name, FUNC_NAME, (ARRAY)[i].arg, \
1320 (ARRAY)[i].expected, (ARRAY)[i].max_ulp, \
1321 (ARRAY)[i].exceptions); \
1322 ROUND_RESTORE_ ## ROUNDING_MODE
1323 #define RUN_TEST_sincos(ARG, TEST_NAME_SIN, SIN_RES_VAR, EXPECTED_SIN, \
1324 MAX_ULP_SIN, TEST_NAME_COS, COS_RES_VAR, \
1325 EXPECTED_COS, MAX_ULP_COS, EXCEPTIONS) \
1326 do \
1327 { \
1328 FUNC (sincos) (ARG, &(SIN_RES_VAR), &(COS_RES_VAR)); \
1329 check_float (TEST_NAME_SIN, SIN_RES_VAR, \
1330 EXPECTED_SIN, MAX_ULP_SIN, EXCEPTIONS); \
1331 check_float (TEST_NAME_COS, COS_RES_VAR, \
1332 EXPECTED_COS, MAX_ULP_COS, 0); \
1333 } \
1334 while (0)
1335 #define RUN_TEST_LOOP_sincos(ARRAY, ROUNDING_MODE, SIN_RES_VAR, \
1336 COS_RES_VAR) \
1337 IF_ROUND_INIT_ ## ROUNDING_MODE \
1338 for (size_t i = 0; i < sizeof (ARRAY) / sizeof (ARRAY)[0]; i++) \
1339 RUN_TEST_sincos ((ARRAY)[i].arg, (ARRAY)[i].test_name_sin, \
1340 SIN_RES_VAR, (ARRAY)[i].expected_sin, \
1341 (ARRAY)[i].max_ulp_sin, \
1342 (ARRAY)[i].test_name_cos, COS_RES_VAR, \
1343 (ARRAY)[i].expected_cos, (ARRAY)[i].max_ulp_cos, \
1344 (ARRAY)[i].exceptions); \
1345 ROUND_RESTORE_ ## ROUNDING_MODE
1346
1347
1348
1349 /* This is to prevent messages from the SVID libm emulation. */
1350 int
1351 matherr (struct exception *x __attribute__ ((unused)))
1352 {
1353 return 1;
1354 }
1355
1356
1357 /****************************************************************************
1358 Tests for single functions of libm.
1359 Please keep them alphabetically sorted!
1360 ****************************************************************************/
1361
1362 static const struct test_f_f_data acos_test_data[] =
1363 {
1364 START_DATA (acos),
1365 TEST_f_f (acos, plus_infty, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
1366 TEST_f_f (acos, minus_infty, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
1367 TEST_f_f (acos, qnan_value, qnan_value),
1368
1369 /* |x| > 1: */
1370 TEST_f_f (acos, 1.125L, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
1371 TEST_f_f (acos, -1.125L, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
1372 TEST_f_f (acos, max_value, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
1373 TEST_f_f (acos, -max_value, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
1374
1375 TEST_f_f (acos, 0, M_PI_2l),
1376 TEST_f_f (acos, minus_zero, M_PI_2l),
1377 TEST_f_f (acos, 1, 0),
1378 TEST_f_f (acos, -1, M_PIl),
1379 TEST_f_f (acos, 0.5, M_PI_6l*2.0),
1380 TEST_f_f (acos, -0.5, M_PI_6l*4.0),
1381 TEST_f_f (acos, 0.75L, 0.722734247813415611178377352641333362L),
1382 TEST_f_f (acos, 2e-17L, 1.57079632679489659923132169163975144L),
1383 TEST_f_f (acos, 0.0625L, 1.50825556499840522843072005474337068L),
1384 TEST_f_f (acos, 0x0.ffffffp0L, 3.4526698471620358760324948263873649728491e-4L),
1385 TEST_f_f (acos, -0x0.ffffffp0L, 3.1412473866050770348750401337968641476999L),
1386 #ifndef TEST_FLOAT
1387 TEST_f_f (acos, 0x0.ffffffff8p0L, 1.5258789062648029736620564947844627548516e-5L),
1388 TEST_f_f (acos, -0x0.ffffffff8p0L, 3.1415773948007305904329067627145550395696L),
1389 TEST_f_f (acos, 0x0.ffffffffffffp0L, 8.4293697021788088529885473244391795127130e-8L),
1390 TEST_f_f (acos, -0x0.ffffffffffffp0L, 3.1415925692960962166745548533940296398054L),
1391 #endif
1392 #if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 64
1393 TEST_f_f (acos, 0x0.ffffffffffffffffp0L, 3.2927225399135962333718255320079907245059e-10L),
1394 TEST_f_f (acos, -0x0.ffffffffffffffffp0L, 3.1415926532605209844712837599423203309964L),
1395 #endif
1396 END_DATA (acos)
1397 };
1398
1399 static void
1400 acos_test (void)
1401 {
1402 errno = 0;
1403 FUNC(acos) (0);
1404 if (errno == ENOSYS)
1405 /* Function not implemented. */
1406 return;
1407
1408 START (acos);
1409 RUN_TEST_LOOP_f_f (acos, acos_test_data, );
1410 END (acos);
1411 }
1412
1413
1414 static const struct test_f_f_data acos_tonearest_test_data[] =
1415 {
1416 START_DATA (acos_tonearest),
1417 TEST_f_f (acos, 0, M_PI_2l),
1418 TEST_f_f (acos, minus_zero, M_PI_2l),
1419 TEST_f_f (acos, 1, 0),
1420 TEST_f_f (acos, -1, M_PIl),
1421 TEST_f_f (acos, 0.5, M_PI_6l*2.0),
1422 TEST_f_f (acos, -0.5, M_PI_6l*4.0),
1423 END_DATA (acos_tonearest)
1424 };
1425
1426 static void
1427 acos_test_tonearest (void)
1428 {
1429 errno = 0;
1430 FUNC(acos) (0);
1431 if (errno == ENOSYS)
1432 /* Function not implemented. */
1433 return;
1434
1435 START (acos_tonearest);
1436 RUN_TEST_LOOP_f_f (acos, acos_tonearest_test_data, FE_TONEAREST);
1437 END (acos_tonearest);
1438 }
1439
1440
1441 static const struct test_f_f_data acos_towardzero_test_data[] =
1442 {
1443 START_DATA (acos_towardzero),
1444 TEST_f_f (acos, 0, M_PI_2l),
1445 TEST_f_f (acos, minus_zero, M_PI_2l),
1446 TEST_f_f (acos, 1, 0),
1447 TEST_f_f (acos, -1, M_PIl),
1448 TEST_f_f (acos, 0.5, M_PI_6l*2.0),
1449 TEST_f_f (acos, -0.5, M_PI_6l*4.0),
1450 END_DATA (acos_towardzero)
1451 };
1452
1453 static void
1454 acos_test_towardzero (void)
1455 {
1456 errno = 0;
1457 FUNC(acos) (0);
1458 if (errno == ENOSYS)
1459 /* Function not implemented. */
1460 return;
1461
1462 START (acos_towardzero);
1463 RUN_TEST_LOOP_f_f (acos, acos_towardzero_test_data, FE_TOWARDZERO);
1464 END (acos_towardzero);
1465 }
1466
1467
1468 static const struct test_f_f_data acos_downward_test_data[] =
1469 {
1470 START_DATA (acos_downward),
1471 TEST_f_f (acos, 0, M_PI_2l),
1472 TEST_f_f (acos, minus_zero, M_PI_2l),
1473 TEST_f_f (acos, 1, 0),
1474 TEST_f_f (acos, -1, M_PIl),
1475 TEST_f_f (acos, 0.5, M_PI_6l*2.0),
1476 TEST_f_f (acos, -0.5, M_PI_6l*4.0),
1477 END_DATA (acos_downward)
1478 };
1479
1480 static void
1481 acos_test_downward (void)
1482 {
1483 errno = 0;
1484 FUNC(acos) (0);
1485 if (errno == ENOSYS)
1486 /* Function not implemented. */
1487 return;
1488
1489 START (acos_downward);
1490 RUN_TEST_LOOP_f_f (acos, acos_downward_test_data, FE_DOWNWARD);
1491 END (acos_downward);
1492 }
1493
1494
1495 static const struct test_f_f_data acos_upward_test_data[] =
1496 {
1497 START_DATA (acos_upward),
1498 TEST_f_f (acos, 0, M_PI_2l),
1499 TEST_f_f (acos, minus_zero, M_PI_2l),
1500 TEST_f_f (acos, 1, 0),
1501 TEST_f_f (acos, -1, M_PIl),
1502 TEST_f_f (acos, 0.5, M_PI_6l*2.0),
1503 TEST_f_f (acos, -0.5, M_PI_6l*4.0),
1504 END_DATA (acos_upward)
1505 };
1506
1507 static void
1508 acos_test_upward (void)
1509 {
1510 errno = 0;
1511 FUNC(acos) (0);
1512 if (errno == ENOSYS)
1513 /* Function not implemented. */
1514 return;
1515
1516 START (acos_upward);
1517 RUN_TEST_LOOP_f_f (acos, acos_upward_test_data, FE_UPWARD);
1518 END (acos_upward);
1519 }
1520
1521 static const struct test_f_f_data acosh_test_data[] =
1522 {
1523 START_DATA (acosh),
1524 TEST_f_f (acosh, plus_infty, plus_infty),
1525 TEST_f_f (acosh, minus_infty, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
1526 TEST_f_f (acosh, qnan_value, qnan_value),
1527
1528 /* x < 1: */
1529 TEST_f_f (acosh, -1.125L, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
1530 TEST_f_f (acosh, -max_value, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
1531
1532 TEST_f_f (acosh, 1, 0),
1533 TEST_f_f (acosh, 7, 2.63391579384963341725009269461593689L),
1534 END_DATA (acosh)
1535 };
1536
1537 static void
1538 acosh_test (void)
1539 {
1540 errno = 0;
1541 FUNC(acosh) (7);
1542 if (errno == ENOSYS)
1543 /* Function not implemented. */
1544 return;
1545
1546 START (acosh);
1547 RUN_TEST_LOOP_f_f (acosh, acosh_test_data, );
1548 END (acosh);
1549 }
1550
1551 static const struct test_f_f_data asin_test_data[] =
1552 {
1553 START_DATA (asin),
1554 TEST_f_f (asin, plus_infty, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
1555 TEST_f_f (asin, minus_infty, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
1556 TEST_f_f (asin, qnan_value, qnan_value),
1557
1558 /* asin x == qNaN plus invalid exception for |x| > 1. */
1559 TEST_f_f (asin, 1.125L, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
1560 TEST_f_f (asin, -1.125L, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
1561 TEST_f_f (asin, max_value, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
1562 TEST_f_f (asin, -max_value, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
1563
1564 TEST_f_f (asin, 0, 0),
1565 TEST_f_f (asin, minus_zero, minus_zero),
1566 TEST_f_f (asin, 0.5, M_PI_6l),
1567 TEST_f_f (asin, -0.5, -M_PI_6l),
1568 TEST_f_f (asin, 1.0, M_PI_2l),
1569 TEST_f_f (asin, -1.0, -M_PI_2l),
1570 TEST_f_f (asin, 0.75L, 0.848062078981481008052944338998418080L),
1571 TEST_f_f (asin, 0x0.ffffffp0L, 1.5704510598101804156437184421571127056013L),
1572 TEST_f_f (asin, -0x0.ffffffp0L, -1.5704510598101804156437184421571127056013L),
1573 #ifndef TEST_FLOAT
1574 TEST_f_f (asin, 0x0.ffffffff8p0L, 1.5707810680058339712015850710748035974710L),
1575 TEST_f_f (asin, -0x0.ffffffff8p0L, -1.5707810680058339712015850710748035974710L),
1576 TEST_f_f (asin, 0x0.ffffffffffffp0L, 1.5707962425011995974432331617542781977068L),
1577 TEST_f_f (asin, -0x0.ffffffffffffp0L, -1.5707962425011995974432331617542781977068L),
1578 #endif
1579 #if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 64
1580 TEST_f_f (asin, 0x0.ffffffffffffffffp0L, 1.5707963264656243652399620683025688888978L),
1581 TEST_f_f (asin, -0x0.ffffffffffffffffp0L, -1.5707963264656243652399620683025688888978L),
1582 #endif
1583 END_DATA (asin)
1584 };
1585
1586 static void
1587 asin_test (void)
1588 {
1589 errno = 0;
1590 FUNC(asin) (0);
1591 if (errno == ENOSYS)
1592 /* Function not implemented. */
1593 return;
1594
1595 START (asin);
1596 RUN_TEST_LOOP_f_f (asin, asin_test_data, );
1597 END (asin);
1598 }
1599
1600
1601 static const struct test_f_f_data asin_tonearest_test_data[] =
1602 {
1603 START_DATA (asin_tonearest),
1604 TEST_f_f (asin, 0, 0),
1605 TEST_f_f (asin, minus_zero, minus_zero),
1606 TEST_f_f (asin, 0.5, M_PI_6l),
1607 TEST_f_f (asin, -0.5, -M_PI_6l),
1608 TEST_f_f (asin, 1.0, M_PI_2l),
1609 TEST_f_f (asin, -1.0, -M_PI_2l),
1610 END_DATA (asin_tonearest)
1611 };
1612
1613 static void
1614 asin_test_tonearest (void)
1615 {
1616 errno = 0;
1617 FUNC(asin) (0);
1618 if (errno == ENOSYS)
1619 /* Function not implemented. */
1620 return;
1621
1622 START (asin_tonearest);
1623 RUN_TEST_LOOP_f_f (asin, asin_tonearest_test_data, FE_TONEAREST);
1624 END (asin_tonearest);
1625 }
1626
1627
1628 static const struct test_f_f_data asin_towardzero_test_data[] =
1629 {
1630 START_DATA (asin_towardzero),
1631 TEST_f_f (asin, 0, 0),
1632 TEST_f_f (asin, minus_zero, minus_zero),
1633 TEST_f_f (asin, 0.5, M_PI_6l),
1634 TEST_f_f (asin, -0.5, -M_PI_6l),
1635 TEST_f_f (asin, 1.0, M_PI_2l),
1636 TEST_f_f (asin, -1.0, -M_PI_2l),
1637 END_DATA (asin_towardzero)
1638 };
1639
1640 static void
1641 asin_test_towardzero (void)
1642 {
1643 errno = 0;
1644 FUNC(asin) (0);
1645 if (errno == ENOSYS)
1646 /* Function not implemented. */
1647 return;
1648
1649 START (asin_towardzero);
1650 RUN_TEST_LOOP_f_f (asin, asin_towardzero_test_data, FE_TOWARDZERO);
1651 END (asin_towardzero);
1652 }
1653
1654
1655 static const struct test_f_f_data asin_downward_test_data[] =
1656 {
1657 START_DATA (asin_downward),
1658 TEST_f_f (asin, 0, 0),
1659 TEST_f_f (asin, minus_zero, minus_zero),
1660 TEST_f_f (asin, 0.5, M_PI_6l),
1661 TEST_f_f (asin, -0.5, -M_PI_6l),
1662 TEST_f_f (asin, 1.0, M_PI_2l),
1663 TEST_f_f (asin, -1.0, -M_PI_2l),
1664 END_DATA (asin_downward)
1665 };
1666
1667 static void
1668 asin_test_downward (void)
1669 {
1670 errno = 0;
1671 FUNC(asin) (0);
1672 if (errno == ENOSYS)
1673 /* Function not implemented. */
1674 return;
1675
1676 START (asin_downward);
1677 RUN_TEST_LOOP_f_f (asin, asin_downward_test_data, FE_DOWNWARD);
1678 END (asin_downward);
1679 }
1680
1681
1682 static const struct test_f_f_data asin_upward_test_data[] =
1683 {
1684 START_DATA (asin_upward),
1685 TEST_f_f (asin, 0, 0),
1686 TEST_f_f (asin, minus_zero, minus_zero),
1687 TEST_f_f (asin, 0.5, M_PI_6l),
1688 TEST_f_f (asin, -0.5, -M_PI_6l),
1689 TEST_f_f (asin, 1.0, M_PI_2l),
1690 TEST_f_f (asin, -1.0, -M_PI_2l),
1691 END_DATA (asin_upward)
1692 };
1693
1694 static void
1695 asin_test_upward (void)
1696 {
1697 errno = 0;
1698 FUNC(asin) (0);
1699 if (errno == ENOSYS)
1700 /* Function not implemented. */
1701 return;
1702
1703 START (asin_upward);
1704 RUN_TEST_LOOP_f_f (asin, asin_upward_test_data, FE_UPWARD);
1705 END (asin_upward);
1706 }
1707
1708 static const struct test_f_f_data asinh_test_data[] =
1709 {
1710 START_DATA (asinh),
1711 TEST_f_f (asinh, 0, 0),
1712 TEST_f_f (asinh, minus_zero, minus_zero),
1713 #ifndef TEST_INLINE
1714 TEST_f_f (asinh, plus_infty, plus_infty),
1715 TEST_f_f (asinh, minus_infty, minus_infty),
1716 #endif
1717 TEST_f_f (asinh, qnan_value, qnan_value),
1718 TEST_f_f (asinh, 0.75L, 0.693147180559945309417232121458176568L),
1719 END_DATA (asinh)
1720 };
1721
1722 static void
1723 asinh_test (void)
1724 {
1725 errno = 0;
1726 FUNC(asinh) (0.7L);
1727 if (errno == ENOSYS)
1728 /* Function not implemented. */
1729 return;
1730
1731 START (asinh);
1732 RUN_TEST_LOOP_f_f (asinh, asinh_test_data, );
1733 END (asinh);
1734 }
1735
1736 static const struct test_f_f_data atan_test_data[] =
1737 {
1738 START_DATA (atan),
1739 TEST_f_f (atan, 0, 0),
1740 TEST_f_f (atan, minus_zero, minus_zero),
1741
1742 TEST_f_f (atan, plus_infty, M_PI_2l),
1743 TEST_f_f (atan, minus_infty, -M_PI_2l),
1744 TEST_f_f (atan, qnan_value, qnan_value),
1745 TEST_f_f (atan, max_value, M_PI_2l),
1746 TEST_f_f (atan, -max_value, -M_PI_2l),
1747
1748 TEST_f_f (atan, 1, M_PI_4l),
1749 TEST_f_f (atan, -1, -M_PI_4l),
1750
1751 TEST_f_f (atan, 0.75L, 0.643501108793284386802809228717322638L),
1752
1753 TEST_f_f (atan, 0x1p-100L, 0x1p-100L),
1754 #ifndef TEST_FLOAT
1755 TEST_f_f (atan, 0x1p-600L, 0x1p-600L),
1756 #endif
1757 #if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
1758 TEST_f_f (atan, 0x1p-10000L, 0x1p-10000L),
1759 #endif
1760 END_DATA (atan)
1761 };
1762
1763 static void
1764 atan_test (void)
1765 {
1766 errno = 0;
1767 FUNC(atan) (0);
1768 if (errno == ENOSYS)
1769 /* Function not implemented. */
1770 return;
1771
1772 START (atan);
1773 RUN_TEST_LOOP_f_f (atan, atan_test_data, );
1774 END (atan);
1775 }
1776
1777
1778
1779 static const struct test_f_f_data atanh_test_data[] =
1780 {
1781 START_DATA (atanh),
1782 TEST_f_f (atanh, 0, 0),
1783 TEST_f_f (atanh, minus_zero, minus_zero),
1784
1785 TEST_f_f (atanh, 1, plus_infty, DIVIDE_BY_ZERO_EXCEPTION),
1786 TEST_f_f (atanh, -1, minus_infty, DIVIDE_BY_ZERO_EXCEPTION),
1787 TEST_f_f (atanh, qnan_value, qnan_value),
1788
1789 /* atanh (x) == qNaN plus invalid exception if |x| > 1. */
1790 TEST_f_f (atanh, 1.125L, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
1791 TEST_f_f (atanh, -1.125L, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
1792 TEST_f_f (atanh, max_value, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
1793 TEST_f_f (atanh, -max_value, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
1794
1795 TEST_f_f (atanh, 0.75L, 0.972955074527656652552676371721589865L),
1796 END_DATA (atanh)
1797 };
1798
1799 static void
1800 atanh_test (void)
1801 {
1802 errno = 0;
1803 FUNC(atanh) (0.7L);
1804 if (errno == ENOSYS)
1805 /* Function not implemented. */
1806 return;
1807
1808 START (atanh);
1809 RUN_TEST_LOOP_f_f (atanh, atanh_test_data, );
1810 END (atanh);
1811 }
1812
1813 static const struct test_ff_f_data atan2_test_data[] =
1814 {
1815 START_DATA (atan2),
1816 /* atan2 (0,x) == 0 for x > 0. */
1817 TEST_ff_f (atan2, 0, 1, 0),
1818
1819 /* atan2 (-0,x) == -0 for x > 0. */
1820 TEST_ff_f (atan2, minus_zero, 1, minus_zero),
1821
1822 TEST_ff_f (atan2, 0, 0, 0),
1823 TEST_ff_f (atan2, minus_zero, 0, minus_zero),
1824
1825 /* atan2 (+0,x) == +pi for x < 0. */
1826 TEST_ff_f (atan2, 0, -1, M_PIl),
1827
1828 /* atan2 (-0,x) == -pi for x < 0. */
1829 TEST_ff_f (atan2, minus_zero, -1, -M_PIl),
1830
1831 TEST_ff_f (atan2, 0, minus_zero, M_PIl),
1832 TEST_ff_f (atan2, minus_zero, minus_zero, -M_PIl),
1833
1834 /* atan2 (y,+0) == pi/2 for y > 0. */
1835 TEST_ff_f (atan2, 1, 0, M_PI_2l),
1836
1837 /* atan2 (y,-0) == pi/2 for y > 0. */
1838 TEST_ff_f (atan2, 1, minus_zero, M_PI_2l),
1839
1840 /* atan2 (y,+0) == -pi/2 for y < 0. */
1841 TEST_ff_f (atan2, -1, 0, -M_PI_2l),
1842
1843 /* atan2 (y,-0) == -pi/2 for y < 0. */
1844 TEST_ff_f (atan2, -1, minus_zero, -M_PI_2l),
1845
1846 /* atan2 (y,inf) == +0 for finite y > 0. */
1847 TEST_ff_f (atan2, 1, plus_infty, 0),
1848
1849 /* atan2 (y,inf) == -0 for finite y < 0. */
1850 TEST_ff_f (atan2, -1, plus_infty, minus_zero),
1851
1852 /* atan2(+inf, x) == pi/2 for finite x. */
1853 TEST_ff_f (atan2, plus_infty, -1, M_PI_2l),
1854
1855 /* atan2(-inf, x) == -pi/2 for finite x. */
1856 TEST_ff_f (atan2, minus_infty, 1, -M_PI_2l),
1857
1858 /* atan2 (y,-inf) == +pi for finite y > 0. */
1859 TEST_ff_f (atan2, 1, minus_infty, M_PIl),
1860
1861 /* atan2 (y,-inf) == -pi for finite y < 0. */
1862 TEST_ff_f (atan2, -1, minus_infty, -M_PIl),
1863
1864 TEST_ff_f (atan2, plus_infty, plus_infty, M_PI_4l),
1865 TEST_ff_f (atan2, minus_infty, plus_infty, -M_PI_4l),
1866 TEST_ff_f (atan2, plus_infty, minus_infty, M_PI_34l),
1867 TEST_ff_f (atan2, minus_infty, minus_infty, -M_PI_34l),
1868 TEST_ff_f (atan2, qnan_value, qnan_value, qnan_value),
1869
1870 TEST_ff_f (atan2, max_value, max_value, M_PI_4l),
1871
1872 TEST_ff_f (atan2, max_value, min_value, M_PI_2l),
1873 TEST_ff_f (atan2, -max_value, -min_value, -M_PI_2l),
1874
1875 TEST_ff_f (atan2, 0.75L, 1, 0.643501108793284386802809228717322638L),
1876 TEST_ff_f (atan2, -0.75L, 1.0L, -0.643501108793284386802809228717322638L),
1877 TEST_ff_f (atan2, 0.75L, -1.0L, 2.49809154479650885165983415456218025L),
1878 TEST_ff_f (atan2, -0.75L, -1.0L, -2.49809154479650885165983415456218025L),
1879 TEST_ff_f (atan2, 0.390625L, .00029L, 1.57005392693128974780151246612928941L),
1880 TEST_ff_f (atan2, 1.390625L, 0.9296875L, 0.981498387184244311516296577615519772L),
1881
1882 TEST_ff_f (atan2, -0.00756827042671106339L, -.001792735857538728036L, -1.80338464113663849327153994379639112L),
1883 #if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 64
1884 TEST_ff_f (atan2, 0x1.00000000000001p0L, 0x1.00000000000001p0L, M_PI_4l),
1885 #endif
1886 END_DATA (atan2)
1887 };
1888
1889 static void
1890 atan2_test (void)
1891 {
1892 errno = 0;
1893 FUNC(atan2) (-0, 1);
1894 if (errno == ENOSYS)
1895 /* Function not implemented. */
1896 return;
1897
1898 START (atan2);
1899 RUN_TEST_LOOP_ff_f (atan2, atan2_test_data, );
1900 END (atan2);
1901 }
1902
1903 static const struct test_c_f_data cabs_test_data[] =
1904 {
1905 START_DATA (cabs);
1906 /* cabs (x + iy) is specified as hypot (x,y) */
1907
1908 /* cabs (+inf + i x) == +inf. */
1909 TEST_c_f (cabs, plus_infty, 1.0, plus_infty),
1910 /* cabs (-inf + i x) == +inf. */
1911 TEST_c_f (cabs, minus_infty, 1.0, plus_infty),
1912
1913 TEST_c_f (cabs, minus_infty, qnan_value, plus_infty),
1914 TEST_c_f (cabs, minus_infty, qnan_value, plus_infty),
1915
1916 TEST_c_f (cabs, qnan_value, qnan_value, qnan_value),
1917
1918 /* cabs (x,y) == cabs (y,x). */
1919 TEST_c_f (cabs, 0.75L, 12.390625L, 12.4133028598606664302388810868156657L),
1920 /* cabs (x,y) == cabs (-x,y). */
1921 TEST_c_f (cabs, -12.390625L, 0.75L, 12.4133028598606664302388810868156657L),
1922 /* cabs (x,y) == cabs (-y,x). */
1923 TEST_c_f (cabs, -0.75L, 12.390625L, 12.4133028598606664302388810868156657L),
1924 /* cabs (x,y) == cabs (-x,-y). */
1925 TEST_c_f (cabs, -12.390625L, -0.75L, 12.4133028598606664302388810868156657L),
1926 /* cabs (x,y) == cabs (-y,-x). */
1927 TEST_c_f (cabs, -0.75L, -12.390625L, 12.4133028598606664302388810868156657L),
1928 /* cabs (x,0) == fabs (x). */
1929 TEST_c_f (cabs, -0.75L, 0, 0.75L),
1930 TEST_c_f (cabs, 0.75L, 0, 0.75L),
1931 TEST_c_f (cabs, -1.0L, 0, 1.0L),
1932 TEST_c_f (cabs, 1.0L, 0, 1.0L),
1933 TEST_c_f (cabs, -5.7e7L, 0, 5.7e7L),
1934 TEST_c_f (cabs, 5.7e7L, 0, 5.7e7L),
1935
1936 TEST_c_f (cabs, 0.75L, 1.25L, 1.45773797371132511771853821938639577L),
1937 END_DATA (cabs);
1938 };
1939
1940 static void
1941 cabs_test (void)
1942 {
1943 errno = 0;
1944 FUNC(cabs) (BUILD_COMPLEX (0.7L, 12.4L));
1945 if (errno == ENOSYS)
1946 /* Function not implemented. */
1947 return;
1948
1949 START (cabs);
1950 RUN_TEST_LOOP_c_f (cabs, cabs_test_data, );
1951 END (cabs);
1952 }
1953
1954
1955 static const struct test_c_c_data cacos_test_data[] =
1956 {
1957 START_DATA (cacos),
1958 TEST_c_c (cacos, 0, 0, M_PI_2l, minus_zero),
1959 TEST_c_c (cacos, minus_zero, 0, M_PI_2l, minus_zero),
1960 TEST_c_c (cacos, minus_zero, minus_zero, M_PI_2l, 0.0),
1961 TEST_c_c (cacos, 0, minus_zero, M_PI_2l, 0.0),
1962
1963 TEST_c_c (cacos, minus_infty, plus_infty, M_PI_34l, minus_infty),
1964 TEST_c_c (cacos, minus_infty, minus_infty, M_PI_34l, plus_infty),
1965
1966 TEST_c_c (cacos, plus_infty, plus_infty, M_PI_4l, minus_infty),
1967 TEST_c_c (cacos, plus_infty, minus_infty, M_PI_4l, plus_infty),
1968
1969 TEST_c_c (cacos, -10.0, plus_infty, M_PI_2l, minus_infty),
1970 TEST_c_c (cacos, -10.0, minus_infty, M_PI_2l, plus_infty),
1971 TEST_c_c (cacos, 0, plus_infty, M_PI_2l, minus_infty),
1972 TEST_c_c (cacos, 0, minus_infty, M_PI_2l, plus_infty),
1973 TEST_c_c (cacos, 0.1L, plus_infty, M_PI_2l, minus_infty),
1974 TEST_c_c (cacos, 0.1L, minus_infty, M_PI_2l, plus_infty),
1975
1976 TEST_c_c (cacos, minus_infty, 0, M_PIl, minus_infty),
1977 TEST_c_c (cacos, minus_infty, minus_zero, M_PIl, plus_infty),
1978 TEST_c_c (cacos, minus_infty, 100, M_PIl, minus_infty),
1979 TEST_c_c (cacos, minus_infty, -100, M_PIl, plus_infty),
1980
1981 TEST_c_c (cacos, plus_infty, 0, 0.0, minus_infty),
1982 TEST_c_c (cacos, plus_infty, minus_zero, 0.0, plus_infty),
1983 TEST_c_c (cacos, plus_infty, 0.5, 0.0, minus_infty),
1984 TEST_c_c (cacos, plus_infty, -0.5, 0.0, plus_infty),
1985
1986 TEST_c_c (cacos, plus_infty, qnan_value, qnan_value, plus_infty, IGNORE_ZERO_INF_SIGN),
1987 TEST_c_c (cacos, minus_infty, qnan_value, qnan_value, plus_infty, IGNORE_ZERO_INF_SIGN),
1988
1989 TEST_c_c (cacos, 0, qnan_value, M_PI_2l, qnan_value),
1990 TEST_c_c (cacos, minus_zero, qnan_value, M_PI_2l, qnan_value),
1991
1992 TEST_c_c (cacos, qnan_value, plus_infty, qnan_value, minus_infty),
1993 TEST_c_c (cacos, qnan_value, minus_infty, qnan_value, plus_infty),
1994
1995 TEST_c_c (cacos, 10.5, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
1996 TEST_c_c (cacos, -10.5, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
1997
1998 TEST_c_c (cacos, qnan_value, 0.75, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
1999 TEST_c_c (cacos, qnan_value, -0.75, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
2000
2001 TEST_c_c (cacos, qnan_value, qnan_value, qnan_value, qnan_value),
2002
2003 TEST_c_c (cacos, plus_zero, -1.5L, M_PI_2l, 1.194763217287109304111930828519090523536L),
2004 TEST_c_c (cacos, minus_zero, -1.5L, M_PI_2l, 1.194763217287109304111930828519090523536L),
2005 TEST_c_c (cacos, plus_zero, -1.0L, M_PI_2l, 0.8813735870195430252326093249797923090282L),
2006 TEST_c_c (cacos, minus_zero, -1.0L, M_PI_2l, 0.8813735870195430252326093249797923090282L),
2007 TEST_c_c (cacos, plus_zero, -0.5L, M_PI_2l, 0.4812118250596034474977589134243684231352L),
2008 TEST_c_c (cacos, minus_zero, -0.5L, M_PI_2l, 0.4812118250596034474977589134243684231352L),
2009 TEST_c_c (cacos, plus_zero, 0.5L, M_PI_2l, -0.4812118250596034474977589134243684231352L),
2010 TEST_c_c (cacos, minus_zero, 0.5L, M_PI_2l, -0.4812118250596034474977589134243684231352L),
2011 TEST_c_c (cacos, plus_zero, 1.0L, M_PI_2l, -0.8813735870195430252326093249797923090282L),
2012 TEST_c_c (cacos, minus_zero, 1.0L, M_PI_2l, -0.8813735870195430252326093249797923090282L),
2013 TEST_c_c (cacos, plus_zero, 1.5L, M_PI_2l, -1.194763217287109304111930828519090523536L),
2014 TEST_c_c (cacos, minus_zero, 1.5L, M_PI_2l, -1.194763217287109304111930828519090523536L),
2015
2016 TEST_c_c (cacos, -1.5L, plus_zero, M_PIl, -0.9624236501192068949955178268487368462704L),
2017 TEST_c_c (cacos, -1.5L, minus_zero, M_PIl, 0.9624236501192068949955178268487368462704L),
2018 TEST_c_c (cacos, -1.0L, plus_zero, M_PIl, minus_zero),
2019 TEST_c_c (cacos, -1.0L, minus_zero, M_PIl, plus_zero),
2020 TEST_c_c (cacos, -0.5L, plus_zero, 2.094395102393195492308428922186335256131L, minus_zero),
2021 TEST_c_c (cacos, -0.5L, minus_zero, 2.094395102393195492308428922186335256131L, plus_zero),
2022 TEST_c_c (cacos, 0.5L, plus_zero, 1.047197551196597746154214461093167628066L, minus_zero),
2023 TEST_c_c (cacos, 0.5L, minus_zero, 1.047197551196597746154214461093167628066L, plus_zero),
2024 TEST_c_c (cacos, 1.0L, plus_zero, plus_zero, minus_zero),
2025 TEST_c_c (cacos, 1.0L, minus_zero, plus_zero, plus_zero),
2026 TEST_c_c (cacos, 1.5L, plus_zero, plus_zero, -0.9624236501192068949955178268487368462704L),
2027 TEST_c_c (cacos, 1.5L, minus_zero, plus_zero, 0.9624236501192068949955178268487368462704L),
2028
2029 TEST_c_c (cacos, 0x1p50L, 1.0L, 8.881784197001252323389053344727730248720e-16L, -3.535050620855721078027883819436720218708e1L),
2030 TEST_c_c (cacos, 0x1p50L, -1.0L, 8.881784197001252323389053344727730248720e-16L, 3.535050620855721078027883819436720218708e1L),
2031 TEST_c_c (cacos, -0x1p50L, 1.0L, 3.141592653589792350284223683154270545292L, -3.535050620855721078027883819436720218708e1L),
2032 TEST_c_c (cacos, -0x1p50L, -1.0L, 3.141592653589792350284223683154270545292L, 3.535050620855721078027883819436720218708e1L),
2033 TEST_c_c (cacos, 1.0L, 0x1p50L, 1.570796326794895731052901991514519103193L, -3.535050620855721078027883819436759661753e1L),
2034 TEST_c_c (cacos, -1.0L, 0x1p50L, 1.570796326794897507409741391764983781004L, -3.535050620855721078027883819436759661753e1L),
2035 TEST_c_c (cacos, 1.0L, -0x1p50L, 1.570796326794895731052901991514519103193L, 3.535050620855721078027883819436759661753e1L),
2036 TEST_c_c (cacos, -1.0L, -0x1p50L, 1.570796326794897507409741391764983781004L, 3.535050620855721078027883819436759661753e1L),
2037 #ifndef TEST_FLOAT
2038 TEST_c_c (cacos, 0x1p500L, 1.0L, 3.054936363499604682051979393213617699789e-151L, -3.472667374605326000180332928505464606058e2L),
2039 TEST_c_c (cacos, 0x1p500L, -1.0L, 3.054936363499604682051979393213617699789e-151L, 3.472667374605326000180332928505464606058e2L),
2040 TEST_c_c (cacos, -0x1p500L, 1.0L, 3.141592653589793238462643383279502884197L, -3.472667374605326000180332928505464606058e2L),
2041 TEST_c_c (cacos, -0x1p500L, -1.0L, 3.141592653589793238462643383279502884197L, 3.472667374605326000180332928505464606058e2L),
2042 TEST_c_c (cacos, 1.0L, 0x1p500L, 1.570796326794896619231321691639751442099L, -3.472667374605326000180332928505464606058e2L),
2043 TEST_c_c (cacos, -1.0L, 0x1p500L, 1.570796326794896619231321691639751442099L, -3.472667374605326000180332928505464606058e2L),
2044 TEST_c_c (cacos, 1.0L, -0x1p500L, 1.570796326794896619231321691639751442099L, 3.472667374605326000180332928505464606058e2L),
2045 TEST_c_c (cacos, -1.0L, -0x1p500L, 1.570796326794896619231321691639751442099L, 3.472667374605326000180332928505464606058e2L),
2046 #endif
2047 #if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
2048 TEST_c_c (cacos, 0x1p5000L, 1.0L, 7.079811261048172892385615158694057552948e-1506L, -3.466429049980286492395577839412341016946e3L),
2049 TEST_c_c (cacos, 0x1p5000L, -1.0L, 7.079811261048172892385615158694057552948e-1506L, 3.466429049980286492395577839412341016946e3L),
2050 TEST_c_c (cacos, -0x1p5000L, 1.0L, 3.141592653589793238462643383279502884197L, -3.466429049980286492395577839412341016946e3L),
2051 TEST_c_c (cacos, -0x1p5000L, -1.0L, 3.141592653589793238462643383279502884197L, 3.466429049980286492395577839412341016946e3L),
2052 TEST_c_c (cacos, 1.0L, 0x1p5000L, 1.570796326794896619231321691639751442099L, -3.466429049980286492395577839412341016946e3L),
2053 TEST_c_c (cacos, -1.0L, 0x1p5000L, 1.570796326794896619231321691639751442099L, -3.466429049980286492395577839412341016946e3L),
2054 TEST_c_c (cacos, 1.0L, -0x1p5000L, 1.570796326794896619231321691639751442099L, 3.466429049980286492395577839412341016946e3L),
2055 TEST_c_c (cacos, -1.0L, -0x1p5000L, 1.570796326794896619231321691639751442099L, 3.466429049980286492395577839412341016946e3L),
2056 #endif
2057
2058 TEST_c_c (cacos, 0x1.fp127L, 0x1.fp127L, 7.853981633974483096156608458198757210493e-1L, -8.973081118419833726837456344608533993585e1L),
2059 #ifndef TEST_FLOAT
2060 TEST_c_c (cacos, 0x1.fp1023L, 0x1.fp1023L, 7.853981633974483096156608458198757210493e-1L, -7.107906849659093345062145442726115449315e2L),
2061 #endif
2062 #if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
2063 TEST_c_c (cacos, 0x1.fp16383L, 0x1.fp16383L, 7.853981633974483096156608458198757210493e-1L, -1.135753137836666928715489992987020363057e4L),
2064 #endif
2065
2066 TEST_c_c (cacos, 0x1.fp-129L, 1.5L, 1.570796326794896619231321691639751442097L, -1.194763217287109304111930828519090523536L),
2067 TEST_c_c (cacos, 0x1.fp-129L, -1.5L, 1.570796326794896619231321691639751442097L, 1.194763217287109304111930828519090523536L),
2068 TEST_c_c (cacos, -0x1.fp-129L, 1.5L, 1.570796326794896619231321691639751442100L, -1.194763217287109304111930828519090523536L),
2069 TEST_c_c (cacos, -0x1.fp-129L, -1.5L, 1.570796326794896619231321691639751442100L, 1.194763217287109304111930828519090523536L),
2070 TEST_c_c (cacos, 1.5L, 0x1.fp-129L, 2.546345110742945032959687790021055102355e-39L, -9.624236501192068949955178268487368462704e-1L, UNDERFLOW_EXCEPTION_FLOAT),
2071 TEST_c_c (cacos, -1.5L, 0x1.fp-129L, 3.141592653589793238462643383279502884195L, -9.624236501192068949955178268487368462704e-1L),
2072 TEST_c_c (cacos, 1.5L, -0x1.fp-129L, 2.546345110742945032959687790021055102355e-39L, 9.624236501192068949955178268487368462704e-1L, UNDERFLOW_EXCEPTION_FLOAT),
2073 TEST_c_c (cacos, -1.5L, -0x1.fp-129L, 3.141592653589793238462643383279502884195L, 9.624236501192068949955178268487368462704e-1L),
2074 #ifndef TEST_FLOAT
2075 TEST_c_c (cacos, 0x1.fp-1025L, 1.5L, 1.570796326794896619231321691639751442099L, -1.194763217287109304111930828519090523536L),
2076 TEST_c_c (cacos, 0x1.fp-1025L, -1.5L, 1.570796326794896619231321691639751442099L, 1.194763217287109304111930828519090523536L),
2077 TEST_c_c (cacos, -0x1.fp-1025L, 1.5L, 1.570796326794896619231321691639751442099L, -1.194763217287109304111930828519090523536L),
2078 TEST_c_c (cacos, -0x1.fp-1025L, -1.5L, 1.570796326794896619231321691639751442099L, 1.194763217287109304111930828519090523536L),
2079 TEST_c_c (cacos, 1.5L, 0x1.fp-1025L, 4.819934639999230680322935210539402497827e-309L, -9.624236501192068949955178268487368462704e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
2080 TEST_c_c (cacos, -1.5L, 0x1.fp-1025L, 3.141592653589793238462643383279502884197L, -9.624236501192068949955178268487368462704e-1L),
2081 TEST_c_c (cacos, 1.5L, -0x1.fp-1025L, 4.819934639999230680322935210539402497827e-309L, 9.624236501192068949955178268487368462704e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
2082 TEST_c_c (cacos, -1.5L, -0x1.fp-1025L, 3.141592653589793238462643383279502884197L, 9.624236501192068949955178268487368462704e-1L),
2083 #endif
2084 #if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
2085 TEST_c_c (cacos, 0x1.fp-16385L, 1.5L, 1.570796326794896619231321691639751442099L, -1.194763217287109304111930828519090523536L),
2086 TEST_c_c (cacos, 0x1.fp-16385L, -1.5L, 1.570796326794896619231321691639751442099L, 1.194763217287109304111930828519090523536L),
2087 TEST_c_c (cacos, -0x1.fp-16385L, 1.5L, 1.570796326794896619231321691639751442099L, -1.194763217287109304111930828519090523536L),
2088 TEST_c_c (cacos, -0x1.fp-16385L, -1.5L, 1.570796326794896619231321691639751442099L, 1.194763217287109304111930828519090523536L),
2089 TEST_c_c (cacos, 1.5L, 0x1.fp-16385L, 7.282957076134209141226696333885150260319e-4933L, -9.624236501192068949955178268487368462704e-1L, UNDERFLOW_EXCEPTION),
2090 TEST_c_c (cacos, -1.5L, 0x1.fp-16385L, 3.141592653589793238462643383279502884197L, -9.624236501192068949955178268487368462704e-1L),
2091 TEST_c_c (cacos, 1.5L, -0x1.fp-16385L, 7.282957076134209141226696333885150260319e-4933L, 9.624236501192068949955178268487368462704e-1L, UNDERFLOW_EXCEPTION),
2092 TEST_c_c (cacos, -1.5L, -0x1.fp-16385L, 3.141592653589793238462643383279502884197L, 9.624236501192068949955178268487368462704e-1L),
2093 #endif
2094
2095 TEST_c_c (cacos, 0.5L, 1.0L, 1.221357263937683325603909865564381489366L, -9.261330313501824245501244453057873152694e-1L),
2096 TEST_c_c (cacos, 0.5L, -1.0L, 1.221357263937683325603909865564381489366L, 9.261330313501824245501244453057873152694e-1L),
2097 TEST_c_c (cacos, -0.5L, 1.0L, 1.920235389652109912858733517715121394831L, -9.261330313501824245501244453057873152694e-1L),
2098 TEST_c_c (cacos, -0.5L, -1.0L, 1.920235389652109912858733517715121394831L, 9.261330313501824245501244453057873152694e-1L),
2099 TEST_c_c (cacos, 1.0L, 0.5L, 6.748888455860063801646649673121744318756e-1L, -7.328576759736452608886724437653071523305e-1L),
2100 TEST_c_c (cacos, -1.0L, 0.5L, 2.466703808003786858297978415967328452322L, -7.328576759736452608886724437653071523305e-1L),
2101 TEST_c_c (cacos, 1.0L, -0.5L, 6.748888455860063801646649673121744318756e-1L, 7.328576759736452608886724437653071523305e-1L),
2102 TEST_c_c (cacos, -1.0L, -0.5L, 2.466703808003786858297978415967328452322L, 7.328576759736452608886724437653071523305e-1L),
2103 TEST_c_c (cacos, 0.25L, 1.0L, 1.394493894017929688812643125003661339452L, -8.924633639033482359562124741744951972772e-1L),
2104 TEST_c_c (cacos, 0.25L, -1.0L, 1.394493894017929688812643125003661339452L, 8.924633639033482359562124741744951972772e-1L),
2105 TEST_c_c (cacos, -0.25L, 1.0L, 1.747098759571863549650000258275841544745L, -8.924633639033482359562124741744951972772e-1L),
2106 TEST_c_c (cacos, -0.25L, -1.0L, 1.747098759571863549650000258275841544745L, 8.924633639033482359562124741744951972772e-1L),
2107 TEST_c_c (cacos, 1.0L, 0.25L, 4.890443302710802929202843732146540079124e-1L, -5.097911466811016354623559941115413499164e-1L),
2108 TEST_c_c (cacos, -1.0L, 0.25L, 2.652548323318712945542359010064848876285L, -5.097911466811016354623559941115413499164e-1L),
2109 TEST_c_c (cacos, 1.0L, -0.25L, 4.890443302710802929202843732146540079124e-1L, 5.097911466811016354623559941115413499164e-1L),
2110 TEST_c_c (cacos, -1.0L, -0.25L, 2.652548323318712945542359010064848876285L, 5.097911466811016354623559941115413499164e-1L),
2111 TEST_c_c (cacos, 0x1.fp-10L, 1.0L, 1.569458417435338878318763342108699202986L, -8.813742198809567991336704287826445879025e-1L),
2112 TEST_c_c (cacos, 0x1.fp-10L, -1.0L, 1.569458417435338878318763342108699202986L, 8.813742198809567991336704287826445879025e-1L),
2113 TEST_c_c (cacos, -0x1.fp-10L, 1.0L, 1.572134236154454360143880041170803681211L, -8.813742198809567991336704287826445879025e-1L),
2114 TEST_c_c (cacos, -0x1.fp-10L, -1.0L, 1.572134236154454360143880041170803681211L, 8.813742198809567991336704287826445879025e-1L),
2115 TEST_c_c (cacos, 1.0L, 0x1.fp-10L, 4.349129763101882771258049954181971959031e-2L, -4.350501469856803800217957402220976497152e-2L),
2116 TEST_c_c (cacos, -1.0L, 0x1.fp-10L, 3.098101355958774410750062883737683164607L, -4.350501469856803800217957402220976497152e-2L),
2117 TEST_c_c (cacos, 1.0L, -0x1.fp-10L, 4.349129763101882771258049954181971959031e-2L, 4.350501469856803800217957402220976497152e-2L),
2118 TEST_c_c (cacos, -1.0L, -0x1.fp-10L, 3.098101355958774410750062883737683164607L, 4.350501469856803800217957402220976497152e-2L),
2119 TEST_c_c (cacos, 0x1.fp-30L, 1.0L, 1.570796325518966635014803151387033957091L, -8.813735870195430258081932989769495326854e-1L),
2120 TEST_c_c (cacos, 0x1.fp-30L, -1.0L, 1.570796325518966635014803151387033957091L, 8.813735870195430258081932989769495326854e-1L),
2121 TEST_c_c (cacos, -0x1.fp-30L, 1.0L, 1.570796328070826603447840231892468927106L, -8.813735870195430258081932989769495326854e-1L),
2122 TEST_c_c (cacos, -0x1.fp-30L, -1.0L, 1.570796328070826603447840231892468927106L, 8.813735870195430258081932989769495326854e-1L),
2123 TEST_c_c (cacos, 1.0L, 0x1.fp-30L, 4.247867097467650115899790787875186617316e-5L, -4.247867098745151888768727039216644758847e-5L),
2124 TEST_c_c (cacos, -1.0L, 0x1.fp-30L, 3.141550174918818561961484385371624132331L, -4.247867098745151888768727039216644758847e-5L),
2125 TEST_c_c (cacos, 1.0L, -0x1.fp-30L, 4.247867097467650115899790787875186617316e-5L, 4.247867098745151888768727039216644758847e-5L),
2126 TEST_c_c (cacos, -1.0L, -0x1.fp-30L, 3.141550174918818561961484385371624132331L, 4.247867098745151888768727039216644758847e-5L),
2127 TEST_c_c (cacos, 0x1.fp-100L, 1.0L, 1.570796326794896619231321691638670687364L, -8.813735870195430252326093249797923090282e-1L),
2128 TEST_c_c (cacos, 0x1.fp-100L, -1.0L, 1.570796326794896619231321691638670687364L, 8.813735870195430252326093249797923090282e-1L),
2129 TEST_c_c (cacos, -0x1.fp-100L, 1.0L, 1.570796326794896619231321691640832196834L, -8.813735870195430252326093249797923090282e-1L),
2130 TEST_c_c (cacos, -0x1.fp-100L, -1.0L, 1.570796326794896619231321691640832196834L, 8.813735870195430252326093249797923090282e-1L),
2131 TEST_c_c (cacos, 1.0L, 0x1.fp-100L, 1.236292038260260888664514866456887257525e-15L, -1.236292038260260888664514866457202186027e-15L),
2132 TEST_c_c (cacos, -1.0L, 0x1.fp-100L, 3.141592653589792002170605123018614219682L, -1.236292038260260888664514866457202186027e-15L),
2133 TEST_c_c (cacos, 1.0L, -0x1.fp-100L, 1.236292038260260888664514866456887257525e-15L, 1.236292038260260888664514866457202186027e-15L),
2134 TEST_c_c (cacos, -1.0L, -0x1.fp-100L, 3.141592653589792002170605123018614219682L, 1.236292038260260888664514866457202186027e-15L),
2135 TEST_c_c (cacos, 0x1.fp-129L, 1.0L, 1.570796326794896619231321691639751442097L, -8.813735870195430252326093249797923090282e-1L),
2136 TEST_c_c (cacos, 0x1.fp-129L, -1.0L, 1.570796326794896619231321691639751442097L, 8.813735870195430252326093249797923090282e-1L),
2137 TEST_c_c (cacos, -0x1.fp-129L, 1.0L, 1.570796326794896619231321691639751442101L, -8.813735870195430252326093249797923090282e-1L),
2138 TEST_c_c (cacos, -0x1.fp-129L, -1.0L, 1.570796326794896619231321691639751442101L, 8.813735870195430252326093249797923090282e-1L),
2139 TEST_c_c (cacos, 1.0L, 0x1.fp-129L, 5.335635276982233498398987585285818977930e-20L, -5.335635276982233498398987585285818977933e-20L),
2140 TEST_c_c (cacos, -1.0L, 0x1.fp-129L, 3.141592653589793238409287030509680549213L, -5.335635276982233498398987585285818977933e-20L),
2141 TEST_c_c (cacos, 1.0L, -0x1.fp-129L, 5.335635276982233498398987585285818977930e-20L, 5.335635276982233498398987585285818977933e-20L),
2142 TEST_c_c (cacos, -1.0L, -0x1.fp-129L, 3.141592653589793238409287030509680549213L, 5.335635276982233498398987585285818977933e-20L),
2143 #ifndef TEST_FLOAT
2144 TEST_c_c (cacos, 0x1.fp-1000L, 1.0L, 1.570796326794896619231321691639751442099L, -8.813735870195430252326093249797923090282e-1L),
2145 TEST_c_c (cacos, 0x1.fp-1000L, -1.0L, 1.570796326794896619231321691639751442099L, 8.813735870195430252326093249797923090282e-1L),
2146 TEST_c_c (cacos, -0x1.fp-1000L, 1.0L, 1.570796326794896619231321691639751442099L, -8.813735870195430252326093249797923090282e-1L),
2147 TEST_c_c (cacos, -0x1.fp-1000L, -1.0L, 1.570796326794896619231321691639751442099L, 8.813735870195430252326093249797923090282e-1L),
2148 TEST_c_c (cacos, 1.0L, 0x1.fp-1000L, 4.252291453851660175550490409247739011867e-151L, -4.252291453851660175550490409247739011867e-151L),
2149 TEST_c_c (cacos, -1.0L, 0x1.fp-1000L, 3.141592653589793238462643383279502884197L, -4.252291453851660175550490409247739011867e-151L),
2150 TEST_c_c (cacos, 1.0L, -0x1.fp-1000L, 4.252291453851660175550490409247739011867e-151L, 4.252291453851660175550490409247739011867e-151L),
2151 TEST_c_c (cacos, -1.0L, -0x1.fp-1000L, 3.141592653589793238462643383279502884197L, 4.252291453851660175550490409247739011867e-151L),
2152 TEST_c_c (cacos, 0x1.fp-1025L, 1.0L, 1.570796326794896619231321691639751442099L, -8.813735870195430252326093249797923090282e-1L),
2153 TEST_c_c (cacos, 0x1.fp-1025L, -1.0L, 1.570796326794896619231321691639751442099L, 8.813735870195430252326093249797923090282e-1L),
2154 TEST_c_c (cacos, -0x1.fp-1025L, 1.0L, 1.570796326794896619231321691639751442099L, -8.813735870195430252326093249797923090282e-1L),
2155 TEST_c_c (cacos, -0x1.fp-1025L, -1.0L, 1.570796326794896619231321691639751442099L, 8.813735870195430252326093249797923090282e-1L),
2156 TEST_c_c (cacos, 1.0L, 0x1.fp-1025L, 7.340879205566679497036857179189356754017e-155L, -7.340879205566679497036857179189356754017e-155L),
2157 TEST_c_c (cacos, -1.0L, 0x1.fp-1025L, 3.141592653589793238462643383279502884197L, -7.340879205566679497036857179189356754017e-155L),
2158 TEST_c_c (cacos, 1.0L, -0x1.fp-1025L, 7.340879205566679497036857179189356754017e-155L, 7.340879205566679497036857179189356754017e-155L),
2159 TEST_c_c (cacos, -1.0L, -0x1.fp-1025L, 3.141592653589793238462643383279502884197L, 7.340879205566679497036857179189356754017e-155L),
2160 #endif
2161 #if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
2162 TEST_c_c (cacos, 0x1.fp-10000L, 1.0L, 1.570796326794896619231321691639751442099L, -8.813735870195430252326093249797923090282e-1L),
2163 TEST_c_c (cacos, 0x1.fp-10000L, -1.0L, 1.570796326794896619231321691639751442099L, 8.813735870195430252326093249797923090282e-1L),
2164 TEST_c_c (cacos, -0x1.fp-10000L, 1.0L, 1.570796326794896619231321691639751442099L, -8.813735870195430252326093249797923090282e-1L),
2165 TEST_c_c (cacos, -0x1.fp-10000L, -1.0L, 1.570796326794896619231321691639751442099L, 8.813735870195430252326093249797923090282e-1L),
2166 TEST_c_c (cacos, 1.0L, 0x1.fp-10000L, 9.854680208706673586644342922051388714633e-1506L, -9.854680208706673586644342922051388714633e-1506L),
2167 TEST_c_c (cacos, -1.0L, 0x1.fp-10000L, 3.141592653589793238462643383279502884197L, -9.854680208706673586644342922051388714633e-1506L),
2168 TEST_c_c (cacos, 1.0L, -0x1.fp-10000L, 9.854680208706673586644342922051388714633e-1506L, 9.854680208706673586644342922051388714633e-1506L),
2169 TEST_c_c (cacos, -1.0L, -0x1.fp-10000L, 3.141592653589793238462643383279502884197L, 9.854680208706673586644342922051388714633e-1506L),
2170 TEST_c_c (cacos, 0x1.fp-16385L, 1.0L, 1.570796326794896619231321691639751442099L, -8.813735870195430252326093249797923090282e-1L),
2171 TEST_c_c (cacos, 0x1.fp-16385L, -1.0L, 1.570796326794896619231321691639751442099L, 8.813735870195430252326093249797923090282e-1L),
2172 TEST_c_c (cacos, -0x1.fp-16385L, 1.0L, 1.570796326794896619231321691639751442099L, -8.813735870195430252326093249797923090282e-1L),
2173 TEST_c_c (cacos, -0x1.fp-16385L, -1.0L, 1.570796326794896619231321691639751442099L, 8.813735870195430252326093249797923090282e-1L),
2174 TEST_c_c (cacos, 1.0L, 0x1.fp-16385L, 9.023632056840860275214893047597614177639e-2467L, -9.023632056840860275214893047597614177639e-2467L),
2175 TEST_c_c (cacos, -1.0L, 0x1.fp-16385L, 3.141592653589793238462643383279502884197L, -9.023632056840860275214893047597614177639e-2467L),
2176 TEST_c_c (cacos, 1.0L, -0x1.fp-16385L, 9.023632056840860275214893047597614177639e-2467L, 9.023632056840860275214893047597614177639e-2467L),
2177 TEST_c_c (cacos, -1.0L, -0x1.fp-16385L, 3.141592653589793238462643383279502884197L, 9.023632056840860275214893047597614177639e-2467L),
2178 #endif
2179
2180 TEST_c_c (cacos, 0x1p-23L, 0x1.000002p0L, 1.570796242501204621739026081991856762292L, -8.813736713132400470205730751186547909968e-1L),
2181 TEST_c_c (cacos, 0x1p-23L, -0x1.000002p0L, 1.570796242501204621739026081991856762292L, 8.813736713132400470205730751186547909968e-1L),
2182 TEST_c_c (cacos, -0x1p-23L, 0x1.000002p0L, 1.570796411088588616723617301287646121905L, -8.813736713132400470205730751186547909968e-1L),
2183 TEST_c_c (cacos, -0x1p-23L, -0x1.000002p0L, 1.570796411088588616723617301287646121905L, 8.813736713132400470205730751186547909968e-1L),
2184 TEST_c_c (cacos, 0x1.000002p0L, 0x1p-23L, 2.222118384408546368406374049167636760903e-4L, -5.364668491573609633134147164031476452679e-4L),
2185 TEST_c_c (cacos, -0x1.000002p0L, 0x1p-23L, 3.141370441751352383825802745874586120521L, -5.364668491573609633134147164031476452679e-4L),
2186 TEST_c_c (cacos, 0x1.000002p0L, -0x1p-23L, 2.222118384408546368406374049167636760903e-4L, 5.364668491573609633134147164031476452679e-4L),
2187 TEST_c_c (cacos, -0x1.000002p0L, -0x1p-23L, 3.141370441751352383825802745874586120521L, 5.364668491573609633134147164031476452679e-4L),
2188 TEST_c_c (cacos, 0x1.fp-129L, 0x1.000002p0L, 1.570796326794896619231321691639751442097L, -8.813736713132375348727889167749389235161e-1L),
2189 TEST_c_c (cacos, 0x1.fp-129L, -0x1.000002p0L, 1.570796326794896619231321691639751442097L, 8.813736713132375348727889167749389235161e-1L),
2190 TEST_c_c (cacos, -0x1.fp-129L, 0x1.000002p0L, 1.570796326794896619231321691639751442101L, -8.813736713132375348727889167749389235161e-1L),
2191 TEST_c_c (cacos, -0x1.fp-129L, -0x1.000002p0L, 1.570796326794896619231321691639751442101L, 8.813736713132375348727889167749389235161e-1L),
2192 TEST_c_c (cacos, 0x1.000002p0L, 0x1.fp-129L, 5.830451806317544230969669308596361881467e-36L, -4.882812451493617206486388134172712975070e-4L),
2193 TEST_c_c (cacos, -0x1.000002p0L, 0x1.fp-129L, 3.141592653589793238462643383279502878367L, -4.882812451493617206486388134172712975070e-4L),
2194 TEST_c_c (cacos, 0x1.000002p0L, -0x1.fp-129L, 5.830451806317544230969669308596361881467e-36L, 4.882812451493617206486388134172712975070e-4L),
2195 TEST_c_c (cacos, -0x1.000002p0L, -0x1.fp-129L, 3.141592653589793238462643383279502878367L, 4.882812451493617206486388134172712975070e-4L),
2196 TEST_c_c (cacos, 0.0L, 0x1.000002p0L, 1.570796326794896619231321691639751442099L, -8.813736713132375348727889167749389235161e-1L),
2197 TEST_c_c (cacos, 0.0L, -0x1.000002p0L, 1.570796326794896619231321691639751442099L, 8.813736713132375348727889167749389235161e-1L),
2198 TEST_c_c (cacos, -0.0L, 0x1.000002p0L, 1.570796326794896619231321691639751442099L, -8.813736713132375348727889167749389235161e-1L),
2199 TEST_c_c (cacos, -0.0L, -0x1.000002p0L, 1.570796326794896619231321691639751442099L, 8.813736713132375348727889167749389235161e-1L),
2200 TEST_c_c (cacos, 0x1.000002p0L, 0.0L, 0.0L, -4.882812451493617206486388134172712975070e-4L),
2201 TEST_c_c (cacos, -0x1.000002p0L, 0.0L, 3.141592653589793238462643383279502884197L, -4.882812451493617206486388134172712975070e-4L),
2202 TEST_c_c (cacos, 0x1.000002p0L, -0.0L, 0.0L, 4.882812451493617206486388134172712975070e-4L),
2203 TEST_c_c (cacos, -0x1.000002p0L, -0.0L, 3.141592653589793238462643383279502884197L, 4.882812451493617206486388134172712975070e-4L),
2204 #ifndef TEST_FLOAT
2205 TEST_c_c (cacos, 0x1p-52L, 0x1.0000000000001p0L, 1.570796326794896462222075823262262934288L, -8.813735870195431822418551933572982483664e-1L),
2206 TEST_c_c (cacos, 0x1p-52L, -0x1.0000000000001p0L, 1.570796326794896462222075823262262934288L, 8.813735870195431822418551933572982483664e-1L),
2207 TEST_c_c (cacos, -0x1p-52L, 0x1.0000000000001p0L, 1.570796326794896776240567560017239949909L, -8.813735870195431822418551933572982483664e-1L),
2208 TEST_c_c (cacos, -0x1p-52L, -0x1.0000000000001p0L, 1.570796326794896776240567560017239949909L, 8.813735870195431822418551933572982483664e-1L),
2209 TEST_c_c (cacos, 0x1.0000000000001p0L, 0x1p-52L, 9.590301705980041385828904092662391018164e-9L, -2.315303644582684770975188768022139415020e-8L),
2210 TEST_c_c (cacos, -0x1.0000000000001p0L, 0x1p-52L, 3.141592643999491532482601997450598791535L, -2.315303644582684770975188768022139415020e-8L),
2211 TEST_c_c (cacos, 0x1.0000000000001p0L, -0x1p-52L, 9.590301705980041385828904092662391018164e-9L, 2.315303644582684770975188768022139415020e-8L),
2212 TEST_c_c (cacos, -0x1.0000000000001p0L, -0x1p-52L, 3.141592643999491532482601997450598791535L, 2.315303644582684770975188768022139415020e-8L),
2213 TEST_c_c (cacos, 0x1.fp-1025L, 0x1.0000000000001p0L, 1.570796326794896619231321691639751442099L, -8.813735870195431822418551933572895326024e-1L),
2214 TEST_c_c (cacos, 0x1.fp-1025L, -0x1.0000000000001p0L, 1.570796326794896619231321691639751442099L, 8.813735870195431822418551933572895326024e-1L),
2215 TEST_c_c (cacos, -0x1.fp-1025L, 0x1.0000000000001p0L, 1.570796326794896619231321691639751442099L, -8.813735870195431822418551933572895326024e-1L),
2216 TEST_c_c (cacos, -0x1.fp-1025L, -0x1.0000000000001p0L, 1.570796326794896619231321691639751442099L, 8.813735870195431822418551933572895326024e-1L),
2217 TEST_c_c (cacos, 0x1.0000000000001p0L, 0x1.fp-1025L, 2.557178503953494342609835913586108008322e-301L, -2.107342425544701550354780375182800088393e-8L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
2218 TEST_c_c (cacos, -0x1.0000000000001p0L, 0x1.fp-1025L, 3.141592653589793238462643383279502884197L, -2.107342425544701550354780375182800088393e-8L),
2219 TEST_c_c (cacos, 0x1.0000000000001p0L, -0x1.fp-1025L, 2.557178503953494342609835913586108008322e-301L, 2.107342425544701550354780375182800088393e-8L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
2220 TEST_c_c (cacos, -0x1.0000000000001p0L, -0x1.fp-1025L, 3.141592653589793238462643383279502884197L, 2.107342425544701550354780375182800088393e-8L),
2221 TEST_c_c (cacos, 0.0L, 0x1.0000000000001p0L, 1.570796326794896619231321691639751442099L, -8.813735870195431822418551933572895326024e-1L),
2222 TEST_c_c (cacos, 0.0L, -0x1.0000000000001p0L, 1.570796326794896619231321691639751442099L, 8.813735870195431822418551933572895326024e-1L),
2223 TEST_c_c (cacos, -0.0L, 0x1.0000000000001p0L, 1.570796326794896619231321691639751442099L, -8.813735870195431822418551933572895326024e-1L),
2224 TEST_c_c (cacos, -0.0L, -0x1.0000000000001p0L, 1.570796326794896619231321691639751442099L, 8.813735870195431822418551933572895326024e-1L),
2225 TEST_c_c (cacos, 0x1.0000000000001p0L, 0.0L, 0.0L, -2.107342425544701550354780375182800088393e-8L),
2226 TEST_c_c (cacos, -0x1.0000000000001p0L, 0.0L, 3.141592653589793238462643383279502884197L, -2.107342425544701550354780375182800088393e-8L),
2227 TEST_c_c (cacos, 0x1.0000000000001p0L, -0.0L, 0.0L, 2.107342425544701550354780375182800088393e-8L),
2228 TEST_c_c (cacos, -0x1.0000000000001p0L, -0.0L, 3.141592653589793238462643383279502884197L, 2.107342425544701550354780375182800088393e-8L),
2229 #endif
2230 #if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 64
2231 TEST_c_c (cacos, 0x1p-63L, 0x1.0000000000000002p0L, 1.570796326794896619154657020805582738031L, -8.813735870195430253092739958139610131001e-1L),
2232 TEST_c_c (cacos, 0x1p-63L, -0x1.0000000000000002p0L, 1.570796326794896619154657020805582738031L, 8.813735870195430253092739958139610131001e-1L),
2233 TEST_c_c (cacos, -0x1p-63L, 0x1.0000000000000002p0L, 1.570796326794896619307986362473920146166L, -8.813735870195430253092739958139610131001e-1L),
2234 TEST_c_c (cacos, -0x1p-63L, -0x1.0000000000000002p0L, 1.570796326794896619307986362473920146166L, 8.813735870195430253092739958139610131001e-1L),
2235 TEST_c_c (cacos, 0x1.0000000000000002p0L, 0x1p-63L, 2.119177303101063432592523199680782317447e-10L, -5.116146586219826555037807251857670783420e-10L),
2236 TEST_c_c (cacos, -0x1.0000000000000002p0L, 0x1p-63L, 3.141592653377875508152537040020250564229L, -5.116146586219826555037807251857670783420e-10L),
2237 TEST_c_c (cacos, 0x1.0000000000000002p0L, -0x1p-63L, 2.119177303101063432592523199680782317447e-10L, 5.116146586219826555037807251857670783420e-10L),
2238 TEST_c_c (cacos, -0x1.0000000000000002p0L, -0x1p-63L, 3.141592653377875508152537040020250564229L, 5.116146586219826555037807251857670783420e-10L),
2239 # if LDBL_MIN_EXP <= -16381
2240 TEST_c_c (cacos, 0x1.fp-16385L, 0x1.0000000000000002p0L, 1.570796326794896619231321691639751442099L, -8.813735870195430253092739958139610130980e-1L),
2241 TEST_c_c (cacos, 0x1.fp-16385L, -0x1.0000000000000002p0L, 1.570796326794896619231321691639751442099L, 8.813735870195430253092739958139610130980e-1L),
2242 TEST_c_c (cacos, -0x1.fp-16385L, 0x1.0000000000000002p0L, 1.570796326794896619231321691639751442099L, -8.813735870195430253092739958139610130980e-1L),
2243 TEST_c_c (cacos, -0x1.fp-16385L, -0x1.0000000000000002p0L, 1.570796326794896619231321691639751442099L, 8.813735870195430253092739958139610130980e-1L),
2244 TEST_c_c (cacos, 0x1.0000000000000002p0L, 0x1.fp-16385L, 1.748608650034385653922359120438227480943e-4923L, -4.656612873077392578082927418388212703712e-10L),
2245 TEST_c_c (cacos, -0x1.0000000000000002p0L, 0x1.fp-16385L, 3.141592653589793238462643383279502884197L, -4.656612873077392578082927418388212703712e-10L),
2246 TEST_c_c (cacos, 0x1.0000000000000002p0L, -0x1.fp-16385L, 1.748608650034385653922359120438227480943e-4923L, 4.656612873077392578082927418388212703712e-10L),
2247 TEST_c_c (cacos, -0x1.0000000000000002p0L, -0x1.fp-16385L, 3.141592653589793238462643383279502884197L, 4.656612873077392578082927418388212703712e-10L),
2248 # endif
2249 TEST_c_c (cacos, 0.0L, 0x1.0000000000000002p0L, 1.570796326794896619231321691639751442099L, -8.813735870195430253092739958139610130980e-1L),
2250 TEST_c_c (cacos, 0.0L, -0x1.0000000000000002p0L, 1.570796326794896619231321691639751442099L, 8.813735870195430253092739958139610130980e-1L),
2251 TEST_c_c (cacos, -0.0L, 0x1.0000000000000002p0L, 1.570796326794896619231321691639751442099L, -8.813735870195430253092739958139610130980e-1L),
2252 TEST_c_c (cacos, -0.0L, -0x1.0000000000000002p0L, 1.570796326794896619231321691639751442099L, 8.813735870195430253092739958139610130980e-1L),
2253 TEST_c_c (cacos, 0x1.0000000000000002p0L, 0.0L, 0.0L, -4.656612873077392578082927418388212703712e-10L),
2254 TEST_c_c (cacos, -0x1.0000000000000002p0L, 0.0L, 3.141592653589793238462643383279502884197L, -4.656612873077392578082927418388212703712e-10L),
2255 TEST_c_c (cacos, 0x1.0000000000000002p0L, -0.0L, 0.0L, 4.656612873077392578082927418388212703712e-10L),
2256 TEST_c_c (cacos, -0x1.0000000000000002p0L, -0.0L, 3.141592653589793238462643383279502884197L, 4.656612873077392578082927418388212703712e-10L),
2257 #endif
2258 #if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 106
2259 TEST_c_c (cacos, 0x1p-106L, 0x1.000000000000000000000000008p0L, 1.570796326794896619231321691639742726335L, -8.813735870195430252326093249798097405561e-1L),
2260 TEST_c_c (cacos, 0x1p-106L, -0x1.000000000000000000000000008p0L, 1.570796326794896619231321691639742726335L, 8.813735870195430252326093249798097405561e-1L),
2261 TEST_c_c (cacos, -0x1p-106L, 0x1.000000000000000000000000008p0L, 1.570796326794896619231321691639760157863L, -8.813735870195430252326093249798097405561e-1L),
2262 TEST_c_c (cacos, -0x1p-106L, -0x1.000000000000000000000000008p0L, 1.570796326794896619231321691639760157863L, 8.813735870195430252326093249798097405561e-1L),
2263 TEST_c_c (cacos, 0x1.000000000000000000000000008p0L, 0x1p-106L, 5.394221422390606848017034778914096659726e-17L, -2.285028863093221674154232933662774454211e-16L),
2264 TEST_c_c (cacos, -0x1.000000000000000000000000008p0L, 0x1p-106L, 3.141592653589793184520429159373434404027L, -2.285028863093221674154232933662774454211e-16L),
2265 TEST_c_c (cacos, 0x1.000000000000000000000000008p0L, -0x1p-106L, 5.394221422390606848017034778914096659726e-17L, 2.285028863093221674154232933662774454211e-16L),
2266 TEST_c_c (cacos, -0x1.000000000000000000000000008p0L, -0x1p-106L, 3.141592653589793184520429159373434404027L, 2.285028863093221674154232933662774454211e-16L),
2267 TEST_c_c (cacos, 0x1.fp-1025L, 0x1.000000000000000000000000008p0L, 1.570796326794896619231321691639751442099L, -8.813735870195430252326093249798097405561e-1L),
2268 TEST_c_c (cacos, 0x1.fp-1025L, -0x1.000000000000000000000000008p0L, 1.570796326794896619231321691639751442099L, 8.813735870195430252326093249798097405561e-1L),
2269 TEST_c_c (cacos, -0x1.fp-1025L, 0x1.000000000000000000000000008p0L, 1.570796326794896619231321691639751442099L, -8.813735870195430252326093249798097405561e-1L),
2270 TEST_c_c (cacos, -0x1.fp-1025L, -0x1.000000000000000000000000008p0L, 1.570796326794896619231321691639751442099L, 8.813735870195430252326093249798097405561e-1L),
2271 TEST_c_c (cacos, 0x1.000000000000000000000000008p0L, 0x1.fp-1025L, 2.426922623448365473354662093431821897807e-293L, -2.220446049250313080847263336181636063482e-16L),
2272 TEST_c_c (cacos, -0x1.000000000000000000000000008p0L, 0x1.fp-1025L, 3.141592653589793238462643383279502884197L, -2.220446049250313080847263336181636063482e-16L),
2273 TEST_c_c (cacos, 0x1.000000000000000000000000008p0L, -0x1.fp-1025L, 2.426922623448365473354662093431821897807e-293L, 2.220446049250313080847263336181636063482e-16L),
2274 TEST_c_c (cacos, -0x1.000000000000000000000000008p0L, -0x1.fp-1025L, 3.141592653589793238462643383279502884197L, 2.220446049250313080847263336181636063482e-16L),
2275 TEST_c_c (cacos, 0.0L, 0x1.000000000000000000000000008p0L, 1.570796326794896619231321691639751442099L, -8.813735870195430252326093249798097405561e-1L),
2276 TEST_c_c (cacos, 0.0L, -0x1.000000000000000000000000008p0L, 1.570796326794896619231321691639751442099L, 8.813735870195430252326093249798097405561e-1L),
2277 TEST_c_c (cacos, -0.0L, 0x1.000000000000000000000000008p0L, 1.570796326794896619231321691639751442099L, -8.813735870195430252326093249798097405561e-1L),
2278 TEST_c_c (cacos, -0.0L, -0x1.000000000000000000000000008p0L, 1.570796326794896619231321691639751442099L, 8.813735870195430252326093249798097405561e-1L),
2279 TEST_c_c (cacos, 0x1.000000000000000000000000008p0L, 0.0L, 0.0L, -2.220446049250313080847263336181636063482e-16L),
2280 TEST_c_c (cacos, -0x1.000000000000000000000000008p0L, 0.0L, 3.141592653589793238462643383279502884197L, -2.220446049250313080847263336181636063482e-16L),
2281 TEST_c_c (cacos, 0x1.000000000000000000000000008p0L, -0.0L, 0.0L, 2.220446049250313080847263336181636063482e-16L),
2282 TEST_c_c (cacos, -0x1.000000000000000000000000008p0L, -0.0L, 3.141592653589793238462643383279502884197L, 2.220446049250313080847263336181636063482e-16L),
2283 #endif
2284 #if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 113
2285 TEST_c_c (cacos, 0x1p-113L, 0x1.0000000000000000000000000001p0L, 1.570796326794896619231321691639751374007L, -8.813735870195430252326093249797924452120e-1L),
2286 TEST_c_c (cacos, 0x1p-113L, -0x1.0000000000000000000000000001p0L, 1.570796326794896619231321691639751374007L, 8.813735870195430252326093249797924452120e-1L),
2287 TEST_c_c (cacos, -0x1p-113L, 0x1.0000000000000000000000000001p0L, 1.570796326794896619231321691639751510190L, -8.813735870195430252326093249797924452120e-1L),
2288 TEST_c_c (cacos, -0x1p-113L, -0x1.0000000000000000000000000001p0L, 1.570796326794896619231321691639751510190L, 8.813735870195430252326093249797924452120e-1L),
2289 TEST_c_c (cacos, 0x1.0000000000000000000000000001p0L, 0x1p-113L, 4.767863183742677481693563511435642755521e-18L, -2.019699255375255198156433710951064632386e-17L),
2290 TEST_c_c (cacos, -0x1.0000000000000000000000000001p0L, 0x1p-113L, 3.141592653589793233694780199536825402504L, -2.019699255375255198156433710951064632386e-17L),
2291 TEST_c_c (cacos, 0x1.0000000000000000000000000001p0L, -0x1p-113L, 4.767863183742677481693563511435642755521e-18L, 2.019699255375255198156433710951064632386e-17L),
2292 TEST_c_c (cacos, -0x1.0000000000000000000000000001p0L, -0x1p-113L, 3.141592653589793233694780199536825402504L, 2.019699255375255198156433710951064632386e-17L),
2293 TEST_c_c (cacos, 0x1.fp-16385L, 0x1.0000000000000000000000000001p0L, 1.570796326794896619231321691639751442099L, -8.813735870195430252326093249797924452120e-1L),
2294 TEST_c_c (cacos, 0x1.fp-16385L, -0x1.0000000000000000000000000001p0L, 1.570796326794896619231321691639751442099L, 8.813735870195430252326093249797924452120e-1L),
2295 TEST_c_c (cacos, -0x1.fp-16385L, 0x1.0000000000000000000000000001p0L, 1.570796326794896619231321691639751442099L, -8.813735870195430252326093249797924452120e-1L),
2296 TEST_c_c (cacos, -0x1.fp-16385L, -0x1.0000000000000000000000000001p0L, 1.570796326794896619231321691639751442099L, 8.813735870195430252326093249797924452120e-1L),
2297 TEST_c_c (cacos, 0x1.0000000000000000000000000001p0L, 0x1.fp-16385L, 4.148847925325683229178506116378864361396e-4916L, -1.962615573354718824241727964954454332780e-17L),
2298 TEST_c_c (cacos, -0x1.0000000000000000000000000001p0L, 0x1.fp-16385L, 3.141592653589793238462643383279502884197L, -1.962615573354718824241727964954454332780e-17L),
2299 TEST_c_c (cacos, 0x1.0000000000000000000000000001p0L, -0x1.fp-16385L, 4.148847925325683229178506116378864361396e-4916L, 1.962615573354718824241727964954454332780e-17L),
2300 TEST_c_c (cacos, -0x1.0000000000000000000000000001p0L, -0x1.fp-16385L, 3.141592653589793238462643383279502884197L, 1.962615573354718824241727964954454332780e-17L),
2301 TEST_c_c (cacos, 0.0L, 0x1.0000000000000000000000000001p0L, 1.570796326794896619231321691639751442099L, -8.813735870195430252326093249797924452120e-1L),
2302 TEST_c_c (cacos, 0.0L, -0x1.0000000000000000000000000001p0L, 1.570796326794896619231321691639751442099L, 8.813735870195430252326093249797924452120e-1L),
2303 TEST_c_c (cacos, -0.0L, 0x1.0000000000000000000000000001p0L, 1.570796326794896619231321691639751442099L, -8.813735870195430252326093249797924452120e-1L),
2304 TEST_c_c (cacos, -0.0L, -0x1.0000000000000000000000000001p0L, 1.570796326794896619231321691639751442099L, 8.813735870195430252326093249797924452120e-1L),
2305 TEST_c_c (cacos, 0x1.0000000000000000000000000001p0L, 0.0L, 0.0L, -1.962615573354718824241727964954454332780e-17L),
2306 TEST_c_c (cacos, -0x1.0000000000000000000000000001p0L, 0.0L, 3.141592653589793238462643383279502884197L, -1.962615573354718824241727964954454332780e-17L),
2307 TEST_c_c (cacos, 0x1.0000000000000000000000000001p0L, -0.0L, 0.0L, 1.962615573354718824241727964954454332780e-17L),
2308 TEST_c_c (cacos, -0x1.0000000000000000000000000001p0L, -0.0L, 3.141592653589793238462643383279502884197L, 1.962615573354718824241727964954454332780e-17L),
2309 #endif
2310
2311 TEST_c_c (cacos, 0x1p-23L, 0x0.ffffffp0L, 1.570796242501197085295336701632142060969L, -8.813735448726963984495965873956465777250e-1L),
2312 TEST_c_c (cacos, 0x1p-23L, -0x0.ffffffp0L, 1.570796242501197085295336701632142060969L, 8.813735448726963984495965873956465777250e-1L),
2313 TEST_c_c (cacos, -0x1p-23L, 0x0.ffffffp0L, 1.570796411088596153167306681647360823228L, -8.813735448726963984495965873956465777250e-1L),
2314 TEST_c_c (cacos, -0x1p-23L, -0x0.ffffffp0L, 1.570796411088596153167306681647360823228L, 8.813735448726963984495965873956465777250e-1L),
2315 TEST_c_c (cacos, 0x0.ffffffp0L, 0x1p-23L, 4.391863861910487109445187743978204002614e-4L, -2.714321200917194650737217746780928423385e-4L),
2316 TEST_c_c (cacos, -0x0.ffffffp0L, 0x1p-23L, 3.141153467203602189751698864505105063797L, -2.714321200917194650737217746780928423385e-4L),
2317 TEST_c_c (cacos, 0x0.ffffffp0L, -0x1p-23L, 4.391863861910487109445187743978204002614e-4L, 2.714321200917194650737217746780928423385e-4L),
2318 TEST_c_c (cacos, -0x0.ffffffp0L, -0x1p-23L, 3.141153467203602189751698864505105063797L, 2.714321200917194650737217746780928423385e-4L),
2319 TEST_c_c (cacos, 0x1.fp-129L, 0x0.ffffffp0L, 1.570796326794896619231321691639751442097L, -8.813735448726938863015878255140556727969e-1L),
2320 TEST_c_c (cacos, 0x1.fp-129L, -0x0.ffffffp0L, 1.570796326794896619231321691639751442097L, 8.813735448726938863015878255140556727969e-1L),
2321 TEST_c_c (cacos, -0x1.fp-129L, 0x0.ffffffp0L, 1.570796326794896619231321691639751442101L, -8.813735448726938863015878255140556727969e-1L),
2322 TEST_c_c (cacos, -0x1.fp-129L, -0x0.ffffffp0L, 1.570796326794896619231321691639751442101L, 8.813735448726938863015878255140556727969e-1L),
2323 TEST_c_c (cacos, 0x0.ffffffp0L, 0x1.fp-129L, 3.452669847162035876032494826387364972849e-4L, -8.245504387859737323891843603996428534945e-36L),
2324 TEST_c_c (cacos, -0x0.ffffffp0L, 0x1.fp-129L, 3.141247386605077034875040133796864147700L, -8.245504387859737323891843603996428534945e-36L),
2325 TEST_c_c (cacos, 0x0.ffffffp0L, -0x1.fp-129L, 3.452669847162035876032494826387364972849e-4L, 8.245504387859737323891843603996428534945e-36L),
2326 TEST_c_c (cacos, -0x0.ffffffp0L, -0x1.fp-129L, 3.141247386605077034875040133796864147700L, 8.245504387859737323891843603996428534945e-36L),
2327 TEST_c_c (cacos, 0.0L, 0x0.ffffffp0L, 1.570796326794896619231321691639751442099L, -8.813735448726938863015878255140556727969e-1L),
2328 TEST_c_c (cacos, 0.0L, -0x0.ffffffp0L, 1.570796326794896619231321691639751442099L, 8.813735448726938863015878255140556727969e-1L),
2329 TEST_c_c (cacos, -0.0L, 0x0.ffffffp0L, 1.570796326794896619231321691639751442099L, -8.813735448726938863015878255140556727969e-1L),
2330 TEST_c_c (cacos, -0.0L, -0x0.ffffffp0L, 1.570796326794896619231321691639751442099L, 8.813735448726938863015878255140556727969e-1L),
2331 TEST_c_c (cacos, 0x0.ffffffp0L, 0.0L, 3.452669847162035876032494826387364972849e-4L, -0.0L),
2332 TEST_c_c (cacos, -0x0.ffffffp0L, 0.0L, 3.141247386605077034875040133796864147700L, -0.0L),
2333 TEST_c_c (cacos, 0x0.ffffffp0L, -0.0L, 3.452669847162035876032494826387364972849e-4L, 0.0L),
2334 TEST_c_c (cacos, -0x0.ffffffp0L, -0.0L, 3.141247386605077034875040133796864147700L, 0.0L),
2335 TEST_c_c (cacos, 0x1p-23L, 0.5L, 1.570796220170866625230343643673321150378L, -4.812118250596059896127318386463676808798e-1L),
2336 TEST_c_c (cacos, 0x1p-23L, -0.5L, 1.570796220170866625230343643673321150378L, 4.812118250596059896127318386463676808798e-1L),
2337 TEST_c_c (cacos, -0x1p-23L, 0.5L, 1.570796433418926613232299739606181733819L, -4.812118250596059896127318386463676808798e-1L),
2338 TEST_c_c (cacos, -0x1p-23L, -0.5L, 1.570796433418926613232299739606181733819L, 4.812118250596059896127318386463676808798e-1L),
2339 TEST_c_c (cacos, 0.5L, 0x1p-23L, 1.047197551196603215914744618665204532273L, -1.376510308240943236356088341381173571841e-7L),
2340 TEST_c_c (cacos, -0.5L, 0x1p-23L, 2.094395102393190022547898764614298351924L, -1.376510308240943236356088341381173571841e-7L),
2341 TEST_c_c (cacos, 0.5L, -0x1p-23L, 1.047197551196603215914744618665204532273L, 1.376510308240943236356088341381173571841e-7L),
2342 TEST_c_c (cacos, -0.5L, -0x1p-23L, 2.094395102393190022547898764614298351924L, 1.376510308240943236356088341381173571841e-7L),
2343 TEST_c_c (cacos, 0x1.fp-129L, 0.5L, 1.570796326794896619231321691639751442096L, -4.812118250596034474977589134243684231352e-1L),
2344 TEST_c_c (cacos, 0x1.fp-129L, -0.5L, 1.570796326794896619231321691639751442096L, 4.812118250596034474977589134243684231352e-1L),
2345 TEST_c_c (cacos, -0x1.fp-129L, 0.5L, 1.570796326794896619231321691639751442101L, -4.812118250596034474977589134243684231352e-1L),
2346 TEST_c_c (cacos, -0x1.fp-129L, -0.5L, 1.570796326794896619231321691639751442101L, 4.812118250596034474977589134243684231352e-1L),
2347 TEST_c_c (cacos, 0.5L, 0x1.fp-129L, 1.047197551196597746154214461093167628066L, -3.287317402534702257036015056278368274737e-39L, UNDERFLOW_EXCEPTION_FLOAT),
2348 TEST_c_c (cacos, -0.5L, 0x1.fp-129L, 2.094395102393195492308428922186335256131L, -3.287317402534702257036015056278368274737e-39L, UNDERFLOW_EXCEPTION_FLOAT),
2349 TEST_c_c (cacos, 0.5L, -0x1.fp-129L, 1.047197551196597746154214461093167628066L, 3.287317402534702257036015056278368274737e-39L, UNDERFLOW_EXCEPTION_FLOAT),
2350 TEST_c_c (cacos, -0.5L, -0x1.fp-129L, 2.094395102393195492308428922186335256131L, 3.287317402534702257036015056278368274737e-39L, UNDERFLOW_EXCEPTION_FLOAT),
2351 TEST_c_c (cacos, 0x1p-23L, 0x1p-23L, 1.570796207585607068450636380271254316214L, -1.192092895507818146886315028596704749235e-7L),
2352 TEST_c_c (cacos, 0x1p-23L, -0x1p-23L, 1.570796207585607068450636380271254316214L, 1.192092895507818146886315028596704749235e-7L),
2353 TEST_c_c (cacos, -0x1p-23L, 0x1p-23L, 1.570796446004186170012007003008248567984L, -1.192092895507818146886315028596704749235e-7L),
2354 TEST_c_c (cacos, -0x1p-23L, -0x1p-23L, 1.570796446004186170012007003008248567984L, 1.192092895507818146886315028596704749235e-7L),
2355 TEST_c_c (cacos, 0x1.fp-129L, 0x1p-23L, 1.570796326794896619231321691639751442096L, -1.192092895507809676556842485683592032154e-7L),
2356 TEST_c_c (cacos, 0x1.fp-129L, -0x1p-23L, 1.570796326794896619231321691639751442096L, 1.192092895507809676556842485683592032154e-7L),
2357 TEST_c_c (cacos, -0x1.fp-129L, 0x1p-23L, 1.570796326794896619231321691639751442101L, -1.192092895507809676556842485683592032154e-7L),
2358 TEST_c_c (cacos, -0x1.fp-129L, -0x1p-23L, 1.570796326794896619231321691639751442101L, 1.192092895507809676556842485683592032154e-7L),
2359 TEST_c_c (cacos, 0x1p-23L, 0x1.fp-129L, 1.570796207585607068449789347324000006847L, -2.846900380897747786805634596726756660388e-39L, UNDERFLOW_EXCEPTION_FLOAT),
2360 TEST_c_c (cacos, -0x1p-23L, 0x1.fp-129L, 1.570796446004186170012854035955502877351L, -2.846900380897747786805634596726756660388e-39L, UNDERFLOW_EXCEPTION_FLOAT),
2361 TEST_c_c (cacos, 0x1p-23L, -0x1.fp-129L, 1.570796207585607068449789347324000006847L, 2.846900380897747786805634596726756660388e-39L, UNDERFLOW_EXCEPTION_FLOAT),
2362 TEST_c_c (cacos, -0x1p-23L, -0x1.fp-129L, 1.570796446004186170012854035955502877351L, 2.846900380897747786805634596726756660388e-39L, UNDERFLOW_EXCEPTION_FLOAT),
2363 TEST_c_c (cacos, 0.0L, 0x1p-23L, 1.570796326794896619231321691639751442099L, -1.192092895507809676556842485683592032154e-7L),
2364 TEST_c_c (cacos, 0.0L, -0x1p-23L, 1.570796326794896619231321691639751442099L, 1.192092895507809676556842485683592032154e-7L),
2365 TEST_c_c (cacos, -0.0L, 0x1p-23L, 1.570796326794896619231321691639751442099L, -1.192092895507809676556842485683592032154e-7L),
2366 TEST_c_c (cacos, -0.0L, -0x1p-23L, 1.570796326794896619231321691639751442099L, 1.192092895507809676556842485683592032154e-7L),
2367 TEST_c_c (cacos, 0x1p-23L, 0.0L, 1.570796207585607068449789347324000006847L, -0.0L),
2368 TEST_c_c (cacos, -0x1p-23L, 0.0L, 1.570796446004186170012854035955502877351L, -0.0L),
2369 TEST_c_c (cacos, 0x1p-23L, -0.0L, 1.570796207585607068449789347324000006847L, 0.0L),
2370 TEST_c_c (cacos, -0x1p-23L, -0.0L, 1.570796446004186170012854035955502877351L, 0.0L),
2371 TEST_c_c (cacos, 0x1.fp-129L, 0x1.fp-129L, 1.570796326794896619231321691639751442096L, -2.846900380897727558361783801085126250967e-39L, UNDERFLOW_EXCEPTION_FLOAT),
2372 TEST_c_c (cacos, 0x1.fp-129L, -0x1.fp-129L, 1.570796326794896619231321691639751442096L, 2.846900380897727558361783801085126250967e-39L, UNDERFLOW_EXCEPTION_FLOAT),
2373 TEST_c_c (cacos, -0x1.fp-129L, 0x1.fp-129L, 1.570796326794896619231321691639751442101L, -2.846900380897727558361783801085126250967e-39L, UNDERFLOW_EXCEPTION_FLOAT),
2374 TEST_c_c (cacos, -0x1.fp-129L, -0x1.fp-129L, 1.570796326794896619231321691639751442101L, 2.846900380897727558361783801085126250967e-39L, UNDERFLOW_EXCEPTION_FLOAT),
2375 #ifndef TEST_FLOAT
2376 TEST_c_c (cacos, 0x1p-52L, 0x0.fffffffffffff8p0L, 1.570796326794896462222075823262236786996L, -8.813735870195429467279863907910458761820e-1L),
2377 TEST_c_c (cacos, 0x1p-52L, -0x0.fffffffffffff8p0L, 1.570796326794896462222075823262236786996L, 8.813735870195429467279863907910458761820e-1L),
2378 TEST_c_c (cacos, -0x1p-52L, 0x0.fffffffffffff8p0L, 1.570796326794896776240567560017266097201L, -8.813735870195429467279863907910458761820e-1L),
2379 TEST_c_c (cacos, -0x1p-52L, -0x0.fffffffffffff8p0L, 1.570796326794896776240567560017266097201L, 8.813735870195429467279863907910458761820e-1L),
2380 TEST_c_c (cacos, 0x0.fffffffffffff8p0L, 0x1p-52L, 1.895456983915074112227925127005564372844e-8L, -1.171456840272878582596796205397918831268e-8L),
2381 TEST_c_c (cacos, -0x0.fffffffffffff8p0L, 0x1p-52L, 3.141592634635223399311902261000251614142L, -1.171456840272878582596796205397918831268e-8L),
2382 TEST_c_c (cacos, 0x0.fffffffffffff8p0L, -0x1p-52L, 1.895456983915074112227925127005564372844e-8L, 1.171456840272878582596796205397918831268e-8L),
2383 TEST_c_c (cacos, -0x0.fffffffffffff8p0L, -0x1p-52L, 3.141592634635223399311902261000251614142L, 1.171456840272878582596796205397918831268e-8L),
2384 TEST_c_c (cacos, 0x1.fp-1025L, 0x0.fffffffffffff8p0L, 1.570796326794896619231321691639751442099L, -8.813735870195429467279863907910371604180e-1L),
2385 TEST_c_c (cacos, 0x1.fp-1025L, -0x0.fffffffffffff8p0L, 1.570796326794896619231321691639751442099L, 8.813735870195429467279863907910371604180e-1L),
2386 TEST_c_c (cacos, -0x1.fp-1025L, 0x0.fffffffffffff8p0L, 1.570796326794896619231321691639751442099L, -8.813735870195429467279863907910371604180e-1L),
2387 TEST_c_c (cacos, -0x1.fp-1025L, -0x0.fffffffffffff8p0L, 1.570796326794896619231321691639751442099L, 8.813735870195429467279863907910371604180e-1L),
2388 TEST_c_c (cacos, 0x0.fffffffffffff8p0L, 0x1.fp-1025L, 1.490116119384765638786343542550461592240e-8L, -3.616396521699973256461764099945789620604e-301L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
2389 TEST_c_c (cacos, -0x0.fffffffffffff8p0L, 0x1.fp-1025L, 3.141592638688632044614986995416067458693L, -3.616396521699973256461764099945789620604e-301L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
2390 TEST_c_c (cacos, 0x0.fffffffffffff8p0L, -0x1.fp-1025L, 1.490116119384765638786343542550461592240e-8L, 3.616396521699973256461764099945789620604e-301L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
2391 TEST_c_c (cacos, -0x0.fffffffffffff8p0L, -0x1.fp-1025L, 3.141592638688632044614986995416067458693L, 3.616396521699973256461764099945789620604e-301L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
2392 TEST_c_c (cacos, 0.0L, 0x0.fffffffffffff8p0L, 1.570796326794896619231321691639751442099L, -8.813735870195429467279863907910371604180e-1L),
2393 TEST_c_c (cacos, 0.0L, -0x0.fffffffffffff8p0L, 1.570796326794896619231321691639751442099L, 8.813735870195429467279863907910371604180e-1L),
2394 TEST_c_c (cacos, -0.0L, 0x0.fffffffffffff8p0L, 1.570796326794896619231321691639751442099L, -8.813735870195429467279863907910371604180e-1L),
2395 TEST_c_c (cacos, -0.0L, -0x0.fffffffffffff8p0L, 1.570796326794896619231321691639751442099L, 8.813735870195429467279863907910371604180e-1L),
2396 TEST_c_c (cacos, 0x0.fffffffffffff8p0L, 0.0L, 1.490116119384765638786343542550461592240e-8L, -0.0L),
2397 TEST_c_c (cacos, -0x0.fffffffffffff8p0L, 0.0L, 3.141592638688632044614986995416067458693L, -0.0L),
2398 TEST_c_c (cacos, 0x0.fffffffffffff8p0L, -0.0L, 1.490116119384765638786343542550461592240e-8L, 0.0L),
2399 TEST_c_c (cacos, -0x0.fffffffffffff8p0L, -0.0L, 3.141592638688632044614986995416067458693L, 0.0L),
2400 #endif
2401 TEST_c_c (cacos, 0x1p-52L, 0.5L, 1.570796326794896420628589431857911675917L, -4.812118250596034474977589134243772428682e-1L),
2402 TEST_c_c (cacos, 0x1p-52L, -0.5L, 1.570796326794896420628589431857911675917L, 4.812118250596034474977589134243772428682e-1L),
2403 TEST_c_c (cacos, -0x1p-52L, 0.5L, 1.570796326794896817834053951421591208280L, -4.812118250596034474977589134243772428682e-1L),
2404 TEST_c_c (cacos, -0x1p-52L, -0.5L, 1.570796326794896817834053951421591208280L, 4.812118250596034474977589134243772428682e-1L),
2405 TEST_c_c (cacos, 0.5L, 0x1p-52L, 1.047197551196597746154214461093186605110L, -2.563950248511418570403591756798643804971e-16L),
2406 TEST_c_c (cacos, -0.5L, 0x1p-52L, 2.094395102393195492308428922186316279087L, -2.563950248511418570403591756798643804971e-16L),
2407 TEST_c_c (cacos, 0.5L, -0x1p-52L, 1.047197551196597746154214461093186605110L, 2.563950248511418570403591756798643804971e-16L),
2408 TEST_c_c (cacos, -0.5L, -0x1p-52L, 2.094395102393195492308428922186316279087L, 2.563950248511418570403591756798643804971e-16L),
2409 #ifndef TEST_FLOAT
2410 TEST_c_c (cacos, 0x1.fp-1025L, 0.5L, 1.570796326794896619231321691639751442099L, -4.812118250596034474977589134243684231352e-1L),
2411 TEST_c_c (cacos, 0x1.fp-1025L, -0.5L, 1.570796326794896619231321691639751442099L, 4.812118250596034474977589134243684231352e-1L),
2412 TEST_c_c (cacos, -0x1.fp-1025L, 0.5L, 1.570796326794896619231321691639751442099L, -4.812118250596034474977589134243684231352e-1L),
2413 TEST_c_c (cacos, -0x1.fp-1025L, -0.5L, 1.570796326794896619231321691639751442099L, 4.812118250596034474977589134243684231352e-1L),
2414 TEST_c_c (cacos, 0.5L, 0x1.fp-1025L, 1.047197551196597746154214461093167628066L, -6.222508863508420569166420770843207333493e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
2415 TEST_c_c (cacos, -0.5L, 0x1.fp-1025L, 2.094395102393195492308428922186335256131L, -6.222508863508420569166420770843207333493e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
2416 TEST_c_c (cacos, 0.5L, -0x1.fp-1025L, 1.047197551196597746154214461093167628066L, 6.222508863508420569166420770843207333493e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
2417 TEST_c_c (cacos, -0.5L, -0x1.fp-1025L, 2.094395102393195492308428922186335256131L, 6.222508863508420569166420770843207333493e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
2418 #endif
2419 TEST_c_c (cacos, 0x1p-52L, 0x1p-52L, 1.570796326794896397186716766608443357372L, -2.220446049250313080847263336181677117148e-16L),
2420 TEST_c_c (cacos, 0x1p-52L, -0x1p-52L, 1.570796326794896397186716766608443357372L, 2.220446049250313080847263336181677117148e-16L),
2421 TEST_c_c (cacos, -0x1p-52L, 0x1p-52L, 1.570796326794896841275926616671059526825L, -2.220446049250313080847263336181677117148e-16L),
2422 TEST_c_c (cacos, -0x1p-52L, -0x1p-52L, 1.570796326794896841275926616671059526825L, 2.220446049250313080847263336181677117148e-16L),
2423 #ifndef TEST_FLOAT
2424 TEST_c_c (cacos, 0x1.fp-1025L, 0x1p-52L, 1.570796326794896619231321691639751442099L, -2.220446049250313080847263336181622378926e-16L),
2425 TEST_c_c (cacos, 0x1.fp-1025L, -0x1p-52L, 1.570796326794896619231321691639751442099L, 2.220446049250313080847263336181622378926e-16L),
2426 TEST_c_c (cacos, -0x1.fp-1025L, 0x1p-52L, 1.570796326794896619231321691639751442099L, -2.220446049250313080847263336181622378926e-16L),
2427 TEST_c_c (cacos, -0x1.fp-1025L, -0x1p-52L, 1.570796326794896619231321691639751442099L, 2.220446049250313080847263336181622378926e-16L),
2428 TEST_c_c (cacos, 0x1p-52L, 0x1.fp-1025L, 1.570796326794896397186716766608443357372L, -5.388850751072128349671657362289548938458e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
2429 TEST_c_c (cacos, -0x1p-52L, 0x1.fp-1025L, 1.570796326794896841275926616671059526825L, -5.388850751072128349671657362289548938458e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
2430 TEST_c_c (cacos, 0x1p-52L, -0x1.fp-1025L, 1.570796326794896397186716766608443357372L, 5.388850751072128349671657362289548938458e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
2431 TEST_c_c (cacos, -0x1p-52L, -0x1.fp-1025L, 1.570796326794896841275926616671059526825L, 5.388850751072128349671657362289548938458e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
2432 #endif
2433 TEST_c_c (cacos, 0.0L, 0x1p-52L, 1.570796326794896619231321691639751442099L, -2.220446049250313080847263336181622378926e-16L),
2434 TEST_c_c (cacos, 0.0L, -0x1p-52L, 1.570796326794896619231321691639751442099L, 2.220446049250313080847263336181622378926e-16L),
2435 TEST_c_c (cacos, -0.0L, 0x1p-52L, 1.570796326794896619231321691639751442099L, -2.220446049250313080847263336181622378926e-16L),
2436 TEST_c_c (cacos, -0.0L, -0x1p-52L, 1.570796326794896619231321691639751442099L, 2.220446049250313080847263336181622378926e-16L),
2437 TEST_c_c (cacos, 0x1p-52L, 0.0L, 1.570796326794896397186716766608443357372L, -0.0L),
2438 TEST_c_c (cacos, -0x1p-52L, 0.0L, 1.570796326794896841275926616671059526825L, -0.0L),
2439 TEST_c_c (cacos, 0x1p-52L, -0.0L, 1.570796326794896397186716766608443357372L, 0.0L),
2440 TEST_c_c (cacos, -0x1p-52L, -0.0L, 1.570796326794896841275926616671059526825L, 0.0L),
2441 #ifndef TEST_FLOAT
2442 TEST_c_c (cacos, 0x1.fp-1025L, 0x1.fp-1025L, 1.570796326794896619231321691639751442099L, -5.388850751072128349671657362289416093031e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
2443 TEST_c_c (cacos, 0x1.fp-1025L, -0x1.fp-1025L, 1.570796326794896619231321691639751442099L, 5.388850751072128349671657362289416093031e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
2444 TEST_c_c (cacos, -0x1.fp-1025L, 0x1.fp-1025L, 1.570796326794896619231321691639751442099L, -5.388850751072128349671657362289416093031e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
2445 TEST_c_c (cacos, -0x1.fp-1025L, -0x1.fp-1025L, 1.570796326794896619231321691639751442099L, 5.388850751072128349671657362289416093031e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
2446 #endif
2447 #if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 64
2448 TEST_c_c (cacos, 0x1p-63L, 0x0.ffffffffffffffffp0L, 1.570796326794896619154657020805582738025L, -8.813735870195430251942769895627079569937e-1L),
2449 TEST_c_c (cacos, 0x1p-63L, -0x0.ffffffffffffffffp0L, 1.570796326794896619154657020805582738025L, 8.813735870195430251942769895627079569937e-1L),
2450 TEST_c_c (cacos, -0x1p-63L, 0x0.ffffffffffffffffp0L, 1.570796326794896619307986362473920146173L, -8.813735870195430251942769895627079569937e-1L),
2451 TEST_c_c (cacos, -0x1p-63L, -0x0.ffffffffffffffffp0L, 1.570796326794896619307986362473920146173L, 8.813735870195430251942769895627079569937e-1L),
2452 TEST_c_c (cacos, 0x0.ffffffffffffffffp0L, 0x1p-63L, 4.188407771167967636741951941902992986043e-10L, -2.588578361325995866221775673638805081337e-10L),
2453 TEST_c_c (cacos, -0x0.ffffffffffffffffp0L, 0x1p-63L, 3.141592653170952461345846619605307690007L, -2.588578361325995866221775673638805081337e-10L),
2454 TEST_c_c (cacos, 0x0.ffffffffffffffffp0L, -0x1p-63L, 4.188407771167967636741951941902992986043e-10L, 2.588578361325995866221775673638805081337e-10L),
2455 TEST_c_c (cacos, -0x0.ffffffffffffffffp0L, -0x1p-63L, 3.141592653170952461345846619605307690007L, 2.588578361325995866221775673638805081337e-10L),
2456 # if LDBL_MIN_EXP <= -16381
2457 TEST_c_c (cacos, 0x1.fp-16385L, 0x0.ffffffffffffffffp0L, 1.570796326794896619231321691639751442099L, -8.813735870195430251942769895627079569917e-1L),
2458 TEST_c_c (cacos, 0x1.fp-16385L, -0x0.ffffffffffffffffp0L, 1.570796326794896619231321691639751442099L, 8.813735870195430251942769895627079569917e-1L),
2459 TEST_c_c (cacos, -0x1.fp-16385L, 0x0.ffffffffffffffffp0L, 1.570796326794896619231321691639751442099L, -8.813735870195430251942769895627079569917e-1L),
2460 TEST_c_c (cacos, -0x1.fp-16385L, -0x0.ffffffffffffffffp0L, 1.570796326794896619231321691639751442099L, 8.813735870195430251942769895627079569917e-1L),
2461 TEST_c_c (cacos, 0x0.ffffffffffffffffp0L, 0x1.fp-16385L, 3.292722539913596233371825532007990724506e-10L, -2.472906068161537187835415298076415423459e-4923L),
2462 TEST_c_c (cacos, -0x0.ffffffffffffffffp0L, 0x1.fp-16385L, 3.141592653260520984471283759942320330996L, -2.472906068161537187835415298076415423459e-4923L),
2463 TEST_c_c (cacos, 0x0.ffffffffffffffffp0L, -0x1.fp-16385L, 3.292722539913596233371825532007990724506e-10L, 2.472906068161537187835415298076415423459e-4923L),
2464 TEST_c_c (cacos, -0x0.ffffffffffffffffp0L, -0x1.fp-16385L, 3.141592653260520984471283759942320330996L, 2.472906068161537187835415298076415423459e-4923L),
2465 # endif
2466 TEST_c_c (cacos, 0.0L, 0x0.ffffffffffffffffp0L, 1.570796326794896619231321691639751442099L, -8.813735870195430251942769895627079569917e-1L),
2467 TEST_c_c (cacos, 0.0L, -0x0.ffffffffffffffffp0L, 1.570796326794896619231321691639751442099L, 8.813735870195430251942769895627079569917e-1L),
2468 TEST_c_c (cacos, -0.0L, 0x0.ffffffffffffffffp0L, 1.570796326794896619231321691639751442099L, -8.813735870195430251942769895627079569917e-1L),
2469 TEST_c_c (cacos, -0.0L, -0x0.ffffffffffffffffp0L, 1.570796326794896619231321691639751442099L, 8.813735870195430251942769895627079569917e-1L),
2470 TEST_c_c (cacos, 0x0.ffffffffffffffffp0L, 0.0L, 3.292722539913596233371825532007990724506e-10L, -0.0L),
2471 TEST_c_c (cacos, -0x0.ffffffffffffffffp0L, 0.0L, 3.141592653260520984471283759942320330996L, -0.0L),
2472 TEST_c_c (cacos, 0x0.ffffffffffffffffp0L, -0.0L, 3.292722539913596233371825532007990724506e-10L, 0.0L),
2473 TEST_c_c (cacos, -0x0.ffffffffffffffffp0L, -0.0L, 3.141592653260520984471283759942320330996L, 0.0L),
2474 #endif
2475 TEST_c_c (cacos, 0x1p-63L, 0.5L, 1.570796326794896619134347701278529840650L, -4.812118250596034474977589134243684231373e-1L),
2476 TEST_c_c (cacos, 0x1p-63L, -0.5L, 1.570796326794896619134347701278529840650L, 4.812118250596034474977589134243684231373e-1L),
2477 TEST_c_c (cacos, -0x1p-63L, 0.5L, 1.570796326794896619328295682000973043547L, -4.812118250596034474977589134243684231373e-1L),
2478 TEST_c_c (cacos, -0x1p-63L, -0.5L, 1.570796326794896619328295682000973043547L, 4.812118250596034474977589134243684231373e-1L),
2479 TEST_c_c (cacos, 0.5L, 0x1p-63L, 1.047197551196597746154214461093167628070L, -1.251928832280966098829878787499365228659e-19L),
2480 TEST_c_c (cacos, -0.5L, 0x1p-63L, 2.094395102393195492308428922186335256127L, -1.251928832280966098829878787499365228659e-19L),
2481 TEST_c_c (cacos, 0.5L, -0x1p-63L, 1.047197551196597746154214461093167628070L, 1.251928832280966098829878787499365228659e-19L),
2482 TEST_c_c (cacos, -0.5L, -0x1p-63L, 2.094395102393195492308428922186335256127L, 1.251928832280966098829878787499365228659e-19L),
2483 #if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
2484 TEST_c_c (cacos, 0x1.fp-16385L, 0.5L, 1.570796326794896619231321691639751442099L, -4.812118250596034474977589134243684231352e-1L),
2485 TEST_c_c (cacos, 0x1.fp-16385L, -0.5L, 1.570796326794896619231321691639751442099L, 4.812118250596034474977589134243684231352e-1L),
2486 TEST_c_c (cacos, -0x1.fp-16385L, 0.5L, 1.570796326794896619231321691639751442099L, -4.812118250596034474977589134243684231352e-1L),
2487 TEST_c_c (cacos, -0x1.fp-16385L, -0.5L, 1.570796326794896619231321691639751442099L, 4.812118250596034474977589134243684231352e-1L),
2488 TEST_c_c (cacos, 0.5L, 0x1.fp-16385L, 1.047197551196597746154214461093167628066L, -9.402257155670418112159334875199821342890e-4933L, UNDERFLOW_EXCEPTION),
2489 TEST_c_c (cacos, -0.5L, 0x1.fp-16385L, 2.094395102393195492308428922186335256131L, -9.402257155670418112159334875199821342890e-4933L, UNDERFLOW_EXCEPTION),
2490 TEST_c_c (cacos, 0.5L, -0x1.fp-16385L, 1.047197551196597746154214461093167628066L, 9.402257155670418112159334875199821342890e-4933L, UNDERFLOW_EXCEPTION),
2491 TEST_c_c (cacos, -0.5L, -0x1.fp-16385L, 2.094395102393195492308428922186335256131L, 9.402257155670418112159334875199821342890e-4933L, UNDERFLOW_EXCEPTION),
2492 #endif
2493 TEST_c_c (cacos, 0x1p-63L, 0x1p-63L, 1.570796326794896619122901474391200998698L, -1.084202172485504434007452800869941711430e-19L),
2494 TEST_c_c (cacos, 0x1p-63L, -0x1p-63L, 1.570796326794896619122901474391200998698L, 1.084202172485504434007452800869941711430e-19L),
2495 TEST_c_c (cacos, -0x1p-63L, 0x1p-63L, 1.570796326794896619339741908888301885499L, -1.084202172485504434007452800869941711430e-19L),
2496 TEST_c_c (cacos, -0x1p-63L, -0x1p-63L, 1.570796326794896619339741908888301885499L, 1.084202172485504434007452800869941711430e-19L),
2497 #if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
2498 TEST_c_c (cacos, 0x1.fp-16385L, 0x1p-63L, 1.570796326794896619231321691639751442099L, -1.084202172485504434007452800869941711424e-19L),
2499 TEST_c_c (cacos, 0x1.fp-16385L, -0x1p-63L, 1.570796326794896619231321691639751442099L, 1.084202172485504434007452800869941711424e-19L),
2500 TEST_c_c (cacos, -0x1.fp-16385L, 0x1p-63L, 1.570796326794896619231321691639751442099L, -1.084202172485504434007452800869941711424e-19L),
2501 TEST_c_c (cacos, -0x1.fp-16385L, -0x1p-63L, 1.570796326794896619231321691639751442099L, 1.084202172485504434007452800869941711424e-19L),
2502 TEST_c_c (cacos, 0x1p-63L, 0x1.fp-16385L, 1.570796326794896619122901474391200998698L, -8.142593549724601460479922838826119584465e-4933L, UNDERFLOW_EXCEPTION),
2503 TEST_c_c (cacos, -0x1p-63L, 0x1.fp-16385L, 1.570796326794896619339741908888301885499L, -8.142593549724601460479922838826119584465e-4933L, UNDERFLOW_EXCEPTION),
2504 TEST_c_c (cacos, 0x1p-63L, -0x1.fp-16385L, 1.570796326794896619122901474391200998698L, 8.142593549724601460479922838826119584465e-4933L, UNDERFLOW_EXCEPTION),
2505 TEST_c_c (cacos, -0x1p-63L, -0x1.fp-16385L, 1.570796326794896619339741908888301885499L, 8.142593549724601460479922838826119584465e-4933L, UNDERFLOW_EXCEPTION),
2506 #endif
2507 TEST_c_c (cacos, 0.0L, 0x1p-63L, 1.570796326794896619231321691639751442099L, -1.084202172485504434007452800869941711424e-19L),
2508 TEST_c_c (cacos, 0.0L, -0x1p-63L, 1.570796326794896619231321691639751442099L, 1.084202172485504434007452800869941711424e-19L),
2509 TEST_c_c (cacos, -0.0L, 0x1p-63L, 1.570796326794896619231321691639751442099L, -1.084202172485504434007452800869941711424e-19L),
2510 TEST_c_c (cacos, -0.0L, -0x1p-63L, 1.570796326794896619231321691639751442099L, 1.084202172485504434007452800869941711424e-19L),
2511 TEST_c_c (cacos, 0x1p-63L, 0.0L, 1.570796326794896619122901474391200998698L, -0.0L),
2512 TEST_c_c (cacos, -0x1p-63L, 0.0L, 1.570796326794896619339741908888301885499L, -0.0L),
2513 TEST_c_c (cacos, 0x1p-63L, -0.0L, 1.570796326794896619122901474391200998698L, 0.0L),
2514 TEST_c_c (cacos, -0x1p-63L, -0.0L, 1.570796326794896619339741908888301885499L, 0.0L),
2515 #if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
2516 TEST_c_c (cacos, 0x1.fp-16385L, 0x1.fp-16385L, 1.570796326794896619231321691639751442099L, -8.142593549724601460479922838826119584417e-4933L, UNDERFLOW_EXCEPTION),
2517 TEST_c_c (cacos, 0x1.fp-16385L, -0x1.fp-16385L, 1.570796326794896619231321691639751442099L, 8.142593549724601460479922838826119584417e-4933L, UNDERFLOW_EXCEPTION),
2518 TEST_c_c (cacos, -0x1.fp-16385L, 0x1.fp-16385L, 1.570796326794896619231321691639751442099L, -8.142593549724601460479922838826119584417e-4933L, UNDERFLOW_EXCEPTION),
2519 TEST_c_c (cacos, -0x1.fp-16385L, -0x1.fp-16385L, 1.570796326794896619231321691639751442099L, 8.142593549724601460479922838826119584417e-4933L, UNDERFLOW_EXCEPTION),
2520 #endif
2521 #if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 106
2522 TEST_c_c (cacos, 0x1p-105L, 0x0.ffffffffffffffffffffffffffcp0L, 1.570796326794896619231321691639734010571L, -8.813735870195430252326093249797835932642e-1L),
2523 TEST_c_c (cacos, 0x1p-105L, -0x0.ffffffffffffffffffffffffffcp0L, 1.570796326794896619231321691639734010571L, 8.813735870195430252326093249797835932642e-1L),
2524 TEST_c_c (cacos, -0x1p-105L, 0x0.ffffffffffffffffffffffffffcp0L, 1.570796326794896619231321691639768873627L, -8.813735870195430252326093249797835932642e-1L),
2525 TEST_c_c (cacos, -0x1p-105L, -0x0.ffffffffffffffffffffffffffcp0L, 1.570796326794896619231321691639768873627L, 8.813735870195430252326093249797835932642e-1L),
2526 TEST_c_c (cacos, 0x0.ffffffffffffffffffffffffffcp0L, 0x1p-105L, 1.997188458999618357060632049675702684031e-16L, -1.234330349600789959989661887846005659983e-16L),
2527 TEST_c_c (cacos, -0x0.ffffffffffffffffffffffffffcp0L, 0x1p-105L, 3.141592653589793038743797483317667178134L, -1.234330349600789959989661887846005659983e-16L),
2528 TEST_c_c (cacos, 0x0.ffffffffffffffffffffffffffcp0L, -0x1p-105L, 1.997188458999618357060632049675702684031e-16L, 1.234330349600789959989661887846005659983e-16L),
2529 TEST_c_c (cacos, -0x0.ffffffffffffffffffffffffffcp0L, -0x1p-105L, 3.141592653589793038743797483317667178134L, 1.234330349600789959989661887846005659983e-16L),
2530 TEST_c_c (cacos, 0x1.fp-1025L, 0x0.ffffffffffffffffffffffffffcp0L, 1.570796326794896619231321691639751442099L, -8.813735870195430252326093249797835932642e-1L),
2531 TEST_c_c (cacos, 0x1.fp-1025L, -0x0.ffffffffffffffffffffffffffcp0L, 1.570796326794896619231321691639751442099L, 8.813735870195430252326093249797835932642e-1L),
2532 TEST_c_c (cacos, -0x1.fp-1025L, 0x0.ffffffffffffffffffffffffffcp0L, 1.570796326794896619231321691639751442099L, -8.813735870195430252326093249797835932642e-1L),
2533 TEST_c_c (cacos, -0x1.fp-1025L, -0x0.ffffffffffffffffffffffffffcp0L, 1.570796326794896619231321691639751442099L, 8.813735870195430252326093249797835932642e-1L),
2534 TEST_c_c (cacos, 0x0.ffffffffffffffffffffffffffcp0L, 0x1.fp-1025L, 1.570092458683775059393382371963565104164e-16L, -3.432186888910770473784103112009399360940e-293L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
2535 TEST_c_c (cacos, -0x0.ffffffffffffffffffffffffffcp0L, 0x1.fp-1025L, 3.141592653589793081453397514901996944859L, -3.432186888910770473784103112009399360940e-293L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
2536 TEST_c_c (cacos, 0x0.ffffffffffffffffffffffffffcp0L, -0x1.fp-1025L, 1.570092458683775059393382371963565104164e-16L, 3.432186888910770473784103112009399360940e-293L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
2537 TEST_c_c (cacos, -0x0.ffffffffffffffffffffffffffcp0L, -0x1.fp-1025L, 3.141592653589793081453397514901996944859L, 3.432186888910770473784103112009399360940e-293L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
2538 TEST_c_c (cacos, 0.0L, 0x0.ffffffffffffffffffffffffffcp0L, 1.570796326794896619231321691639751442099L, -8.813735870195430252326093249797835932642e-1L),
2539 TEST_c_c (cacos, 0.0L, -0x0.ffffffffffffffffffffffffffcp0L, 1.570796326794896619231321691639751442099L, 8.813735870195430252326093249797835932642e-1L),
2540 TEST_c_c (cacos, -0.0L, 0x0.ffffffffffffffffffffffffffcp0L, 1.570796326794896619231321691639751442099L, -8.813735870195430252326093249797835932642e-1L),
2541 TEST_c_c (cacos, -0.0L, -0x0.ffffffffffffffffffffffffffcp0L, 1.570796326794896619231321691639751442099L, 8.813735870195430252326093249797835932642e-1L),
2542 TEST_c_c (cacos, 0x0.ffffffffffffffffffffffffffcp0L, 0.0L, 1.570092458683775059393382371963565104164e-16L, -0.0L),
2543 TEST_c_c (cacos, -0x0.ffffffffffffffffffffffffffcp0L, 0.0L, 3.141592653589793081453397514901996944859L, -0.0L),
2544 TEST_c_c (cacos, 0x0.ffffffffffffffffffffffffffcp0L, -0.0L, 1.570092458683775059393382371963565104164e-16L, 0.0L),
2545 TEST_c_c (cacos, -0x0.ffffffffffffffffffffffffffcp0L, -0.0L, 3.141592653589793081453397514901996944859L, 0.0L),
2546 #endif
2547 TEST_c_c (cacos, 0x1p-105L, 0.5L, 1.570796326794896619231321691639729392766L, -4.812118250596034474977589134243684231352e-1L),
2548 TEST_c_c (cacos, 0x1p-105L, -0.5L, 1.570796326794896619231321691639729392766L, 4.812118250596034474977589134243684231352e-1L),
2549 TEST_c_c (cacos, -0x1p-105L, 0.5L, 1.570796326794896619231321691639773491431L, -4.812118250596034474977589134243684231352e-1L),
2550 TEST_c_c (cacos, -0x1p-105L, -0.5L, 1.570796326794896619231321691639773491431L, 4.812118250596034474977589134243684231352e-1L),
2551 TEST_c_c (cacos, 0.5L, 0x1p-105L, 1.047197551196597746154214461093167628066L, -2.846556599890768890940941645338546615370e-32L),
2552 TEST_c_c (cacos, -0.5L, 0x1p-105L, 2.094395102393195492308428922186335256131L, -2.846556599890768890940941645338546615370e-32L),
2553 TEST_c_c (cacos, 0.5L, -0x1p-105L, 1.047197551196597746154214461093167628066L, 2.846556599890768890940941645338546615370e-32L),
2554 TEST_c_c (cacos, -0.5L, -0x1p-105L, 2.094395102393195492308428922186335256131L, 2.846556599890768890940941645338546615370e-32L),
2555 TEST_c_c (cacos, 0x1p-105L, 0x1p-105L, 1.570796326794896619231321691639726790195L, -2.465190328815661891911651766508706967729e-32L),
2556 TEST_c_c (cacos, 0x1p-105L, -0x1p-105L, 1.570796326794896619231321691639726790195L, 2.465190328815661891911651766508706967729e-32L),
2557 TEST_c_c (cacos, -0x1p-105L, 0x1p-105L, 1.570796326794896619231321691639776094002L, -2.465190328815661891911651766508706967729e-32L),
2558 TEST_c_c (cacos, -0x1p-105L, -0x1p-105L, 1.570796326794896619231321691639776094002L, 2.465190328815661891911651766508706967729e-32L),
2559 #ifndef TEST_FLOAT
2560 TEST_c_c (cacos, 0x1.fp-1025L, 0x1p-105L, 1.570796326794896619231321691639751442099L, -2.465190328815661891911651766508706967729e-32L),
2561 TEST_c_c (cacos, 0x1.fp-1025L, -0x1p-105L, 1.570796326794896619231321691639751442099L, 2.465190328815661891911651766508706967729e-32L),
2562 TEST_c_c (cacos, -0x1.fp-1025L, 0x1p-105L, 1.570796326794896619231321691639751442099L, -2.465190328815661891911651766508706967729e-32L),
2563 TEST_c_c (cacos, -0x1.fp-1025L, -0x1p-105L, 1.570796326794896619231321691639751442099L, 2.465190328815661891911651766508706967729e-32L),
2564 TEST_c_c (cacos, 0x1p-105L, 0x1.fp-1025L, 1.570796326794896619231321691639726790195L, -5.388850751072128349671657362289416093031e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
2565 TEST_c_c (cacos, -0x1p-105L, 0x1.fp-1025L, 1.570796326794896619231321691639776094002L, -5.388850751072128349671657362289416093031e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
2566 TEST_c_c (cacos, 0x1p-105L, -0x1.fp-1025L, 1.570796326794896619231321691639726790195L, 5.388850751072128349671657362289416093031e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
2567 TEST_c_c (cacos, -0x1p-105L, -0x1.fp-1025L, 1.570796326794896619231321691639776094002L, 5.388850751072128349671657362289416093031e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
2568 #endif
2569 TEST_c_c (cacos, 0.0L, 0x1p-105L, 1.570796326794896619231321691639751442099L, -2.465190328815661891911651766508706967729e-32L),
2570 TEST_c_c (cacos, 0.0L, -0x1p-105L, 1.570796326794896619231321691639751442099L, 2.465190328815661891911651766508706967729e-32L),
2571 TEST_c_c (cacos, -0.0L, 0x1p-105L, 1.570796326794896619231321691639751442099L, -2.465190328815661891911651766508706967729e-32L),
2572 TEST_c_c (cacos, -0.0L, -0x1p-105L, 1.570796326794896619231321691639751442099L, 2.465190328815661891911651766508706967729e-32L),
2573 TEST_c_c (cacos, 0x1p-105L, 0.0L, 1.570796326794896619231321691639726790195L, -0.0L),
2574 TEST_c_c (cacos, -0x1p-105L, 0.0L, 1.570796326794896619231321691639776094002L, -0.0L),
2575 TEST_c_c (cacos, 0x1p-105L, -0.0L, 1.570796326794896619231321691639726790195L, 0.0L),
2576 TEST_c_c (cacos, -0x1p-105L, -0.0L, 1.570796326794896619231321691639776094002L, 0.0L),
2577 #if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 113
2578 TEST_c_c (cacos, 0x1p-112L, 0x0.ffffffffffffffffffffffffffff8p0L, 1.570796326794896619231321691639751305915L, -8.813735870195430252326093249797922409363e-1L),
2579 TEST_c_c (cacos, 0x1p-112L, -0x0.ffffffffffffffffffffffffffff8p0L, 1.570796326794896619231321691639751305915L, 8.813735870195430252326093249797922409363e-1L),
2580 TEST_c_c (cacos, -0x1p-112L, 0x0.ffffffffffffffffffffffffffff8p0L, 1.570796326794896619231321691639751578282L, -8.813735870195430252326093249797922409363e-1L),
2581 TEST_c_c (cacos, -0x1p-112L, -0x0.ffffffffffffffffffffffffffff8p0L, 1.570796326794896619231321691639751578282L, 8.813735870195430252326093249797922409363e-1L),
2582 TEST_c_c (cacos, 0x0.ffffffffffffffffffffffffffff8p0L, 0x1p-112L, 1.765281878332676474347460257221369818872e-17L, -1.091004200533850618345330909857103457781e-17L),
2583 TEST_c_c (cacos, -0x0.ffffffffffffffffffffffffffff8p0L, 0x1p-112L, 3.141592653589793220809824599952738140723L, -1.091004200533850618345330909857103457781e-17L),
2584 TEST_c_c (cacos, 0x0.ffffffffffffffffffffffffffff8p0L, -0x1p-112L, 1.765281878332676474347460257221369818872e-17L, 1.091004200533850618345330909857103457781e-17L),
2585 TEST_c_c (cacos, -0x0.ffffffffffffffffffffffffffff8p0L, -0x1p-112L, 3.141592653589793220809824599952738140723L, 1.091004200533850618345330909857103457781e-17L),
2586 TEST_c_c (cacos, 0x1.fp-16385L, 0x0.ffffffffffffffffffffffffffff8p0L, 1.570796326794896619231321691639751442099L, -8.813735870195430252326093249797922409363e-1L),
2587 TEST_c_c (cacos, 0x1.fp-16385L, -0x0.ffffffffffffffffffffffffffff8p0L, 1.570796326794896619231321691639751442099L, 8.813735870195430252326093249797922409363e-1L),
2588 TEST_c_c (cacos, -0x1.fp-16385L, 0x0.ffffffffffffffffffffffffffff8p0L, 1.570796326794896619231321691639751442099L, -8.813735870195430252326093249797922409363e-1L),
2589 TEST_c_c (cacos, -0x1.fp-16385L, -0x0.ffffffffffffffffffffffffffff8p0L, 1.570796326794896619231321691639751442099L, 8.813735870195430252326093249797922409363e-1L),
2590 TEST_c_c (cacos, 0x0.ffffffffffffffffffffffffffff8p0L, 0x1.fp-16385L, 1.387778780781445675529539585113525401762e-17L, -5.867357004219059108790368268900490184505e-4916L),
2591 TEST_c_c (cacos, -0x0.ffffffffffffffffffffffffffff8p0L, 0x1.fp-16385L, 3.141592653589793224584855575465046128902L, -5.867357004219059108790368268900490184505e-4916L),
2592 TEST_c_c (cacos, 0x0.ffffffffffffffffffffffffffff8p0L, -0x1.fp-16385L, 1.387778780781445675529539585113525401762e-17L, 5.867357004219059108790368268900490184505e-4916L),
2593 TEST_c_c (cacos, -0x0.ffffffffffffffffffffffffffff8p0L, -0x1.fp-16385L, 3.141592653589793224584855575465046128902L, 5.867357004219059108790368268900490184505e-4916L),
2594 TEST_c_c (cacos, 0.0L, 0x0.ffffffffffffffffffffffffffff8p0L, 1.570796326794896619231321691639751442099L, -8.813735870195430252326093249797922409363e-1L),
2595 TEST_c_c (cacos, 0.0L, -0x0.ffffffffffffffffffffffffffff8p0L, 1.570796326794896619231321691639751442099L, 8.813735870195430252326093249797922409363e-1L),
2596 TEST_c_c (cacos, -0.0L, 0x0.ffffffffffffffffffffffffffff8p0L, 1.570796326794896619231321691639751442099L, -8.813735870195430252326093249797922409363e-1L),
2597 TEST_c_c (cacos, -0.0L, -0x0.ffffffffffffffffffffffffffff8p0L, 1.570796326794896619231321691639751442099L, 8.813735870195430252326093249797922409363e-1L),
2598 TEST_c_c (cacos, 0x0.ffffffffffffffffffffffffffff8p0L, 0.0L, 1.387778780781445675529539585113525401762e-17L, -0.0L),
2599 TEST_c_c (cacos, -0x0.ffffffffffffffffffffffffffff8p0L, 0.0L, 3.141592653589793224584855575465046128902L, -0.0L),
2600 TEST_c_c (cacos, 0x0.ffffffffffffffffffffffffffff8p0L, -0.0L, 1.387778780781445675529539585113525401762e-17L, 0.0L),
2601 TEST_c_c (cacos, -0x0.ffffffffffffffffffffffffffff8p0L, -0.0L, 3.141592653589793224584855575465046128902L, 0.0L),
2602 #endif
2603 TEST_c_c (cacos, 0x1p-112L, 0.5L, 1.570796326794896619231321691639751269838L, -4.812118250596034474977589134243684231352e-1L),
2604 TEST_c_c (cacos, 0x1p-112L, -0.5L, 1.570796326794896619231321691639751269838L, 4.812118250596034474977589134243684231352e-1L),
2605 TEST_c_c (cacos, -0x1p-112L, 0.5L, 1.570796326794896619231321691639751614359L, -4.812118250596034474977589134243684231352e-1L),
2606 TEST_c_c (cacos, -0x1p-112L, -0.5L, 1.570796326794896619231321691639751614359L, 4.812118250596034474977589134243684231352e-1L),
2607 TEST_c_c (cacos, 0.5L, 0x1p-112L, 1.047197551196597746154214461093167628066L, -2.223872343664663196047610660420739543258e-34L),
2608 TEST_c_c (cacos, -0.5L, 0x1p-112L, 2.094395102393195492308428922186335256131L, -2.223872343664663196047610660420739543258e-34L),
2609 TEST_c_c (cacos, 0.5L, -0x1p-112L, 1.047197551196597746154214461093167628066L, 2.223872343664663196047610660420739543258e-34L),
2610 TEST_c_c (cacos, -0.5L, -0x1p-112L, 2.094395102393195492308428922186335256131L, 2.223872343664663196047610660420739543258e-34L),
2611 TEST_c_c (cacos, 0x1p-112L, 0x1p-112L, 1.570796326794896619231321691639751249506L, -1.925929944387235853055977942584927318538e-34L),
2612 TEST_c_c (cacos, 0x1p-112L, -0x1p-112L, 1.570796326794896619231321691639751249506L, 1.925929944387235853055977942584927318538e-34L),
2613 TEST_c_c (cacos, -0x1p-112L, 0x1p-112L, 1.570796326794896619231321691639751634692L, -1.925929944387235853055977942584927318538e-34L),
2614 TEST_c_c (cacos, -0x1p-112L, -0x1p-112L, 1.570796326794896619231321691639751634692L, 1.925929944387235853055977942584927318538e-34L),
2615 #if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
2616 TEST_c_c (cacos, 0x1.fp-16385L, 0x1p-112L, 1.570796326794896619231321691639751442099L, -1.925929944387235853055977942584927318538e-34L),
2617 TEST_c_c (cacos, 0x1.fp-16385L, -0x1p-112L, 1.570796326794896619231321691639751442099L, 1.925929944387235853055977942584927318538e-34L),
2618 TEST_c_c (cacos, -0x1.fp-16385L, 0x1p-112L, 1.570796326794896619231321691639751442099L, -1.925929944387235853055977942584927318538e-34L),
2619 TEST_c_c (cacos, -0x1.fp-16385L, -0x1p-112L, 1.570796326794896619231321691639751442099L, 1.925929944387235853055977942584927318538e-34L),
2620 TEST_c_c (cacos, 0x1p-112L, 0x1.fp-16385L, 1.570796326794896619231321691639751249506L, -8.142593549724601460479922838826119584417e-4933L, UNDERFLOW_EXCEPTION),
2621 TEST_c_c (cacos, -0x1p-112L, 0x1.fp-16385L, 1.570796326794896619231321691639751634692L, -8.142593549724601460479922838826119584417e-4933L, UNDERFLOW_EXCEPTION),
2622 TEST_c_c (cacos, 0x1p-112L, -0x1.fp-16385L, 1.570796326794896619231321691639751249506L, 8.142593549724601460479922838826119584417e-4933L, UNDERFLOW_EXCEPTION),
2623 TEST_c_c (cacos, -0x1p-112L, -0x1.fp-16385L, 1.570796326794896619231321691639751634692L, 8.142593549724601460479922838826119584417e-4933L, UNDERFLOW_EXCEPTION),
2624 #endif
2625 TEST_c_c (cacos, 0.0L, 0x1p-112L, 1.570796326794896619231321691639751442099L, -1.925929944387235853055977942584927318538e-34L),
2626 TEST_c_c (cacos, 0.0L, -0x1p-112L, 1.570796326794896619231321691639751442099L, 1.925929944387235853055977942584927318538e-34L),
2627 TEST_c_c (cacos, -0.0L, 0x1p-112L, 1.570796326794896619231321691639751442099L, -1.925929944387235853055977942584927318538e-34L),
2628 TEST_c_c (cacos, -0.0L, -0x1p-112L, 1.570796326794896619231321691639751442099L, 1.925929944387235853055977942584927318538e-34L),
2629 TEST_c_c (cacos, 0x1p-112L, 0.0L, 1.570796326794896619231321691639751249506L, -0.0L),
2630 TEST_c_c (cacos, -0x1p-112L, 0.0L, 1.570796326794896619231321691639751634692L, -0.0L),
2631 TEST_c_c (cacos, 0x1p-112L, -0.0L, 1.570796326794896619231321691639751249506L, 0.0L),
2632 TEST_c_c (cacos, -0x1p-112L, -0.0L, 1.570796326794896619231321691639751634692L, 0.0L),
2633
2634 TEST_c_c (cacos, 0.75L, 1.25L, 1.11752014915610270578240049553777969L, -1.13239363160530819522266333696834467L),
2635 TEST_c_c (cacos, -2, -3, 2.1414491111159960199416055713254211L, 1.9833870299165354323470769028940395L),
2636 END_DATA (cacos)
2637 };
2638
2639 static void
2640 cacos_test (void)
2641 {
2642 errno = 0;
2643 FUNC(cacos) (BUILD_COMPLEX (0.7L, 1.2L));
2644 if (errno == ENOSYS)
2645 /* Function not implemented. */
2646 return;
2647
2648 START (cacos);
2649 RUN_TEST_LOOP_c_c (cacos, cacos_test_data, );
2650 END (cacos, complex);
2651 }
2652
2653 static const struct test_c_c_data cacosh_test_data[] =
2654 {
2655 START_DATA (cacosh),
2656 TEST_c_c (cacosh, 0, 0, 0.0, M_PI_2l),
2657 TEST_c_c (cacosh, minus_zero, 0, 0.0, M_PI_2l),
2658 TEST_c_c (cacosh, 0, minus_zero, 0.0, -M_PI_2l),
2659 TEST_c_c (cacosh, minus_zero, minus_zero, 0.0, -M_PI_2l),
2660 TEST_c_c (cacosh, minus_infty, plus_infty, plus_infty, M_PI_34l),
2661 TEST_c_c (cacosh, minus_infty, minus_infty, plus_infty, -M_PI_34l),
2662
2663 TEST_c_c (cacosh, plus_infty, plus_infty, plus_infty, M_PI_4l),
2664 TEST_c_c (cacosh, plus_infty, minus_infty, plus_infty, -M_PI_4l),
2665
2666 TEST_c_c (cacosh, -10.0, plus_infty, plus_infty, M_PI_2l),
2667 TEST_c_c (cacosh, -10.0, minus_infty, plus_infty, -M_PI_2l),
2668 TEST_c_c (cacosh, 0, plus_infty, plus_infty, M_PI_2l),
2669 TEST_c_c (cacosh, 0, minus_infty, plus_infty, -M_PI_2l),
2670 TEST_c_c (cacosh, 0.1L, plus_infty, plus_infty, M_PI_2l),
2671 TEST_c_c (cacosh, 0.1L, minus_infty, plus_infty, -M_PI_2l),
2672
2673 TEST_c_c (cacosh, minus_infty, 0, plus_infty, M_PIl),
2674 TEST_c_c (cacosh, minus_infty, minus_zero, plus_infty, -M_PIl),
2675 TEST_c_c (cacosh, minus_infty, 100, plus_infty, M_PIl),
2676 TEST_c_c (cacosh, minus_infty, -100, plus_infty, -M_PIl),
2677
2678 TEST_c_c (cacosh, plus_infty, 0, plus_infty, 0.0),
2679 TEST_c_c (cacosh, plus_infty, minus_zero, plus_infty, minus_zero),
2680 TEST_c_c (cacosh, plus_infty, 0.5, plus_infty, 0.0),
2681 TEST_c_c (cacosh, plus_infty, -0.5, plus_infty, minus_zero),
2682
2683 TEST_c_c (cacosh, plus_infty, qnan_value, plus_infty, qnan_value),
2684 TEST_c_c (cacosh, minus_infty, qnan_value, plus_infty, qnan_value),
2685
2686 TEST_c_c (cacosh, 0, qnan_value, qnan_value, qnan_value),
2687 TEST_c_c (cacosh, minus_zero, qnan_value, qnan_value, qnan_value),
2688
2689 TEST_c_c (cacosh, qnan_value, plus_infty, plus_infty, qnan_value),
2690 TEST_c_c (cacosh, qnan_value, minus_infty, plus_infty, qnan_value),
2691
2692 TEST_c_c (cacosh, 10.5, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
2693 TEST_c_c (cacosh, -10.5, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
2694
2695 TEST_c_c (cacosh, qnan_value, 0.75, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
2696 TEST_c_c (cacosh, qnan_value, -0.75, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
2697
2698 TEST_c_c (cacosh, qnan_value, qnan_value, qnan_value, qnan_value),
2699
2700 TEST_c_c (cacosh, plus_zero, -1.5L, 1.194763217287109304111930828519090523536L, -M_PI_2l),
2701 TEST_c_c (cacosh, minus_zero, -1.5L, 1.194763217287109304111930828519090523536L, -M_PI_2l),
2702 TEST_c_c (cacosh, plus_zero, -1.0L, 0.8813735870195430252326093249797923090282L, -M_PI_2l),
2703 TEST_c_c (cacosh, minus_zero, -1.0L, 0.8813735870195430252326093249797923090282L, -M_PI_2l),
2704 TEST_c_c (cacosh, plus_zero, -0.5L, 0.4812118250596034474977589134243684231352L, -M_PI_2l),
2705 TEST_c_c (cacosh, minus_zero, -0.5L, 0.4812118250596034474977589134243684231352L, -M_PI_2l),
2706 TEST_c_c (cacosh, plus_zero, 0.5L, 0.4812118250596034474977589134243684231352L, M_PI_2l),
2707 TEST_c_c (cacosh, minus_zero, 0.5L, 0.4812118250596034474977589134243684231352L, M_PI_2l),
2708 TEST_c_c (cacosh, plus_zero, 1.0L, 0.8813735870195430252326093249797923090282L, M_PI_2l),
2709 TEST_c_c (cacosh, minus_zero, 1.0L, 0.8813735870195430252326093249797923090282L, M_PI_2l),
2710 TEST_c_c (cacosh, plus_zero, 1.5L, 1.194763217287109304111930828519090523536L, M_PI_2l),
2711 TEST_c_c (cacosh, minus_zero, 1.5L, 1.194763217287109304111930828519090523536L, M_PI_2l),
2712
2713 TEST_c_c (cacosh, -1.5L, plus_zero, 0.9624236501192068949955178268487368462704L, M_PIl),
2714 TEST_c_c (cacosh, -1.5L, minus_zero, 0.9624236501192068949955178268487368462704L, -M_PIl),
2715 TEST_c_c (cacosh, -1.0L, plus_zero, plus_zero, M_PIl),
2716 TEST_c_c (cacosh, -1.0L, minus_zero, plus_zero, -M_PIl),
2717 TEST_c_c (cacosh, -0.5L, plus_zero, plus_zero, 2.094395102393195492308428922186335256131L),
2718 TEST_c_c (cacosh, -0.5L, minus_zero, plus_zero, -2.094395102393195492308428922186335256131L),
2719 TEST_c_c (cacosh, 0.5L, plus_zero, plus_zero, 1.047197551196597746154214461093167628066L),
2720 TEST_c_c (cacosh, 0.5L, minus_zero, plus_zero, -1.047197551196597746154214461093167628066L),
2721 TEST_c_c (cacosh, 1.0L, plus_zero, plus_zero, plus_zero),
2722 TEST_c_c (cacosh, 1.0L, minus_zero, plus_zero, minus_zero),
2723 TEST_c_c (cacosh, 1.5L, plus_zero, 0.9624236501192068949955178268487368462704L, plus_zero),
2724 TEST_c_c (cacosh, 1.5L, minus_zero, 0.9624236501192068949955178268487368462704L, minus_zero),
2725
2726 TEST_c_c (cacosh, 0x1p50L, 1.0L, 3.535050620855721078027883819436720218708e1L, 8.881784197001252323389053344727730248720e-16L),
2727 TEST_c_c (cacosh, 0x1p50L, -1.0L, 3.535050620855721078027883819436720218708e1L, -8.881784197001252323389053344727730248720e-16L),
2728 TEST_c_c (cacosh, -0x1p50L, 1.0L, 3.535050620855721078027883819436720218708e1L, 3.141592653589792350284223683154270545292L),
2729 TEST_c_c (cacosh, -0x1p50L, -1.0L, 3.535050620855721078027883819436720218708e1L, -3.141592653589792350284223683154270545292L),
2730 TEST_c_c (cacosh, 1.0L, 0x1p50L, 3.535050620855721078027883819436759661753e1L, 1.570796326794895731052901991514519103193L),
2731 TEST_c_c (cacosh, -1.0L, 0x1p50L, 3.535050620855721078027883819436759661753e1L, 1.570796326794897507409741391764983781004L),
2732 TEST_c_c (cacosh, 1.0L, -0x1p50L, 3.535050620855721078027883819436759661753e1L, -1.570796326794895731052901991514519103193L),
2733 TEST_c_c (cacosh, -1.0L, -0x1p50L, 3.535050620855721078027883819436759661753e1L, -1.570796326794897507409741391764983781004L),
2734 #ifndef TEST_FLOAT
2735 TEST_c_c (cacosh, 0x1p500L, 1.0L, 3.472667374605326000180332928505464606058e2L, 3.054936363499604682051979393213617699789e-151L),
2736 TEST_c_c (cacosh, 0x1p500L, -1.0L, 3.472667374605326000180332928505464606058e2L, -3.054936363499604682051979393213617699789e-151L),
2737 TEST_c_c (cacosh, -0x1p500L, 1.0L, 3.472667374605326000180332928505464606058e2L, 3.141592653589793238462643383279502884197L),
2738 TEST_c_c (cacosh, -0x1p500L, -1.0L, 3.472667374605326000180332928505464606058e2L, -3.141592653589793238462643383279502884197L),
2739 TEST_c_c (cacosh, 1.0L, 0x1p500L, 3.472667374605326000180332928505464606058e2L, 1.570796326794896619231321691639751442099L),
2740 TEST_c_c (cacosh, -1.0L, 0x1p500L, 3.472667374605326000180332928505464606058e2L, 1.570796326794896619231321691639751442099L),
2741 TEST_c_c (cacosh, 1.0L, -0x1p500L, 3.472667374605326000180332928505464606058e2L, -1.570796326794896619231321691639751442099L),
2742 TEST_c_c (cacosh, -1.0L, -0x1p500L, 3.472667374605326000180332928505464606058e2L, -1.570796326794896619231321691639751442099L),
2743 #endif
2744 #if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
2745 TEST_c_c (cacosh, 0x1p5000L, 1.0L, 3.466429049980286492395577839412341016946e3L, 7.079811261048172892385615158694057552948e-1506L),
2746 TEST_c_c (cacosh, 0x1p5000L, -1.0L, 3.466429049980286492395577839412341016946e3L, -7.079811261048172892385615158694057552948e-1506L),
2747 TEST_c_c (cacosh, -0x1p5000L, 1.0L, 3.466429049980286492395577839412341016946e3L, 3.141592653589793238462643383279502884197L),
2748 TEST_c_c (cacosh, -0x1p5000L, -1.0L, 3.466429049980286492395577839412341016946e3L, -3.141592653589793238462643383279502884197L),
2749 TEST_c_c (cacosh, 1.0L, 0x1p5000L, 3.466429049980286492395577839412341016946e3L, 1.570796326794896619231321691639751442099L),
2750 TEST_c_c (cacosh, -1.0L, 0x1p5000L, 3.466429049980286492395577839412341016946e3L, 1.570796326794896619231321691639751442099L),
2751 TEST_c_c (cacosh, 1.0L, -0x1p5000L, 3.466429049980286492395577839412341016946e3L, -1.570796326794896619231321691639751442099L),
2752 TEST_c_c (cacosh, -1.0L, -0x1p5000L, 3.466429049980286492395577839412341016946e3L, -1.570796326794896619231321691639751442099L),
2753 #endif
2754 TEST_c_c (cacosh, 0x1.fp127L, 0x1.fp127L, 8.973081118419833726837456344608533993585e1L, 7.853981633974483096156608458198757210493e-1L),
2755 #ifndef TEST_FLOAT
2756 TEST_c_c (cacosh, 0x1.fp1023L, 0x1.fp1023L, 7.107906849659093345062145442726115449315e2L, 7.853981633974483096156608458198757210493e-1L),
2757 #endif
2758 #if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
2759 TEST_c_c (cacosh, 0x1.fp16383L, 0x1.fp16383L, 1.135753137836666928715489992987020363057e4L, 7.853981633974483096156608458198757210493e-1L),
2760 #endif
2761 TEST_c_c (cacosh, 0x1.fp-129L, 1.5L, 1.194763217287109304111930828519090523536L, 1.570796326794896619231321691639751442097L),
2762 TEST_c_c (cacosh, 0x1.fp-129L, -1.5L, 1.194763217287109304111930828519090523536L, -1.570796326794896619231321691639751442097L),
2763 TEST_c_c (cacosh, -0x1.fp-129L, 1.5L, 1.194763217287109304111930828519090523536L, 1.570796326794896619231321691639751442100L),
2764 TEST_c_c (cacosh, -0x1.fp-129L, -1.5L, 1.194763217287109304111930828519090523536L, -1.570796326794896619231321691639751442100L),
2765 TEST_c_c (cacosh, 1.5L, 0x1.fp-129L, 9.624236501192068949955178268487368462704e-1L, 2.546345110742945032959687790021055102355e-39L, UNDERFLOW_EXCEPTION_FLOAT),
2766 TEST_c_c (cacosh, -1.5L, 0x1.fp-129L, 9.624236501192068949955178268487368462704e-1L, 3.141592653589793238462643383279502884195L),
2767 TEST_c_c (cacosh, 1.5L, -0x1.fp-129L, 9.624236501192068949955178268487368462704e-1L, -2.546345110742945032959687790021055102355e-39L, UNDERFLOW_EXCEPTION_FLOAT),
2768 TEST_c_c (cacosh, -1.5L, -0x1.fp-129L, 9.624236501192068949955178268487368462704e-1L, -3.141592653589793238462643383279502884195L),
2769 #ifndef TEST_FLOAT
2770 TEST_c_c (cacosh, 0x1.fp-1025L, 1.5L, 1.194763217287109304111930828519090523536L, 1.570796326794896619231321691639751442099L),
2771 TEST_c_c (cacosh, 0x1.fp-1025L, -1.5L, 1.194763217287109304111930828519090523536L, -1.570796326794896619231321691639751442099L),
2772 TEST_c_c (cacosh, -0x1.fp-1025L, 1.5L, 1.194763217287109304111930828519090523536L, 1.570796326794896619231321691639751442099L),
2773 TEST_c_c (cacosh, -0x1.fp-1025L, -1.5L, 1.194763217287109304111930828519090523536L, -1.570796326794896619231321691639751442099L),
2774 TEST_c_c (cacosh, 1.5L, 0x1.fp-1025L, 9.624236501192068949955178268487368462704e-1L, 4.819934639999230680322935210539402497827e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
2775 TEST_c_c (cacosh, -1.5L, 0x1.fp-1025L, 9.624236501192068949955178268487368462704e-1L, 3.141592653589793238462643383279502884197L),
2776 TEST_c_c (cacosh, 1.5L, -0x1.fp-1025L, 9.624236501192068949955178268487368462704e-1L, -4.819934639999230680322935210539402497827e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
2777 TEST_c_c (cacosh, -1.5L, -0x1.fp-1025L, 9.624236501192068949955178268487368462704e-1L, -3.141592653589793238462643383279502884197L),
2778 #endif
2779 #if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
2780 TEST_c_c (cacosh, 0x1.fp-16385L, 1.5L, 1.194763217287109304111930828519090523536L, 1.570796326794896619231321691639751442099L),
2781 TEST_c_c (cacosh, 0x1.fp-16385L, -1.5L, 1.194763217287109304111930828519090523536L, -1.570796326794896619231321691639751442099L),
2782 TEST_c_c (cacosh, -0x1.fp-16385L, 1.5L, 1.194763217287109304111930828519090523536L, 1.570796326794896619231321691639751442099L),
2783 TEST_c_c (cacosh, -0x1.fp-16385L, -1.5L, 1.194763217287109304111930828519090523536L, -1.570796326794896619231321691639751442099L),
2784 TEST_c_c (cacosh, 1.5L, 0x1.fp-16385L, 9.624236501192068949955178268487368462704e-1L, 7.282957076134209141226696333885150260319e-4933L, UNDERFLOW_EXCEPTION),
2785 TEST_c_c (cacosh, -1.5L, 0x1.fp-16385L, 9.624236501192068949955178268487368462704e-1L, 3.141592653589793238462643383279502884197L),
2786 TEST_c_c (cacosh, 1.5L, -0x1.fp-16385L, 9.624236501192068949955178268487368462704e-1L, -7.282957076134209141226696333885150260319e-4933L, UNDERFLOW_EXCEPTION),
2787 TEST_c_c (cacosh, -1.5L, -0x1.fp-16385L, 9.624236501192068949955178268487368462704e-1L, -3.141592653589793238462643383279502884197L),
2788 #endif
2789 TEST_c_c (cacosh, 0.5L, 1.0L, 9.261330313501824245501244453057873152694e-1L, 1.221357263937683325603909865564381489366L),
2790 TEST_c_c (cacosh, 0.5L, -1.0L, 9.261330313501824245501244453057873152694e-1L, -1.221357263937683325603909865564381489366L),
2791 TEST_c_c (cacosh, -0.5L, 1.0L, 9.261330313501824245501244453057873152694e-1L, 1.920235389652109912858733517715121394831L),
2792 TEST_c_c (cacosh, -0.5L, -1.0L, 9.261330313501824245501244453057873152694e-1L, -1.920235389652109912858733517715121394831L),
2793 TEST_c_c (cacosh, 1.0L, 0.5L, 7.328576759736452608886724437653071523305e-1L, 6.748888455860063801646649673121744318756e-1L),
2794 TEST_c_c (cacosh, -1.0L, 0.5L, 7.328576759736452608886724437653071523305e-1L, 2.466703808003786858297978415967328452322L),
2795 TEST_c_c (cacosh, 1.0L, -0.5L, 7.328576759736452608886724437653071523305e-1L, -6.748888455860063801646649673121744318756e-1L),
2796 TEST_c_c (cacosh, -1.0L, -0.5L, 7.328576759736452608886724437653071523305e-1L, -2.466703808003786858297978415967328452322L),
2797 TEST_c_c (cacosh, 0.25L, 1.0L, 8.924633639033482359562124741744951972772e-1L, 1.394493894017929688812643125003661339452L),
2798 TEST_c_c (cacosh, 0.25L, -1.0L, 8.924633639033482359562124741744951972772e-1L, -1.394493894017929688812643125003661339452L),
2799 TEST_c_c (cacosh, -0.25L, 1.0L, 8.924633639033482359562124741744951972772e-1L, 1.747098759571863549650000258275841544745L),
2800 TEST_c_c (cacosh, -0.25L, -1.0L, 8.924633639033482359562124741744951972772e-1L, -1.747098759571863549650000258275841544745L),
2801 TEST_c_c (cacosh, 1.0L, 0.25L, 5.097911466811016354623559941115413499164e-1L, 4.890443302710802929202843732146540079124e-1L),
2802 TEST_c_c (cacosh, -1.0L, 0.25L, 5.097911466811016354623559941115413499164e-1L, 2.652548323318712945542359010064848876285L),
2803 TEST_c_c (cacosh, 1.0L, -0.25L, 5.097911466811016354623559941115413499164e-1L, -4.890443302710802929202843732146540079124e-1L),
2804 TEST_c_c (cacosh, -1.0L, -0.25L, 5.097911466811016354623559941115413499164e-1L, -2.652548323318712945542359010064848876285L),
2805 TEST_c_c (cacosh, 0x1.fp-10L, 1.0L, 8.813742198809567991336704287826445879025e-1L, 1.569458417435338878318763342108699202986L),
2806 TEST_c_c (cacosh, 0x1.fp-10L, -1.0L, 8.813742198809567991336704287826445879025e-1L, -1.569458417435338878318763342108699202986L),
2807 TEST_c_c (cacosh, -0x1.fp-10L, 1.0L, 8.813742198809567991336704287826445879025e-1L, 1.572134236154454360143880041170803681211L),
2808 TEST_c_c (cacosh, -0x1.fp-10L, -1.0L, 8.813742198809567991336704287826445879025e-1L, -1.572134236154454360143880041170803681211L),
2809 TEST_c_c (cacosh, 1.0L, 0x1.fp-10L, 4.350501469856803800217957402220976497152e-2L, 4.349129763101882771258049954181971959031e-2L),
2810 TEST_c_c (cacosh, -1.0L, 0x1.fp-10L, 4.350501469856803800217957402220976497152e-2L, 3.098101355958774410750062883737683164607L),
2811 TEST_c_c (cacosh, 1.0L, -0x1.fp-10L, 4.350501469856803800217957402220976497152e-2L, -4.349129763101882771258049954181971959031e-2L),
2812 TEST_c_c (cacosh, -1.0L, -0x1.fp-10L, 4.350501469856803800217957402220976497152e-2L, -3.098101355958774410750062883737683164607L),
2813 TEST_c_c (cacosh, 0x1.fp-30L, 1.0L, 8.813735870195430258081932989769495326854e-1L, 1.570796325518966635014803151387033957091L),
2814 TEST_c_c (cacosh, 0x1.fp-30L, -1.0L, 8.813735870195430258081932989769495326854e-1L, -1.570796325518966635014803151387033957091L),
2815 TEST_c_c (cacosh, -0x1.fp-30L, 1.0L, 8.813735870195430258081932989769495326854e-1L, 1.570796328070826603447840231892468927106L),
2816 TEST_c_c (cacosh, -0x1.fp-30L, -1.0L, 8.813735870195430258081932989769495326854e-1L, -1.570796328070826603447840231892468927106L),
2817 TEST_c_c (cacosh, 1.0L, 0x1.fp-30L, 4.247867098745151888768727039216644758847e-5L, 4.247867097467650115899790787875186617316e-5L),
2818 TEST_c_c (cacosh, -1.0L, 0x1.fp-30L, 4.247867098745151888768727039216644758847e-5L, 3.141550174918818561961484385371624132331L),
2819 TEST_c_c (cacosh, 1.0L, -0x1.fp-30L, 4.247867098745151888768727039216644758847e-5L, -4.247867097467650115899790787875186617316e-5L),
2820 TEST_c_c (cacosh, -1.0L, -0x1.fp-30L, 4.247867098745151888768727039216644758847e-5L, -3.141550174918818561961484385371624132331L),
2821 TEST_c_c (cacosh, 0x1.fp-100L, 1.0L, 8.813735870195430252326093249797923090282e-1L, 1.570796326794896619231321691638670687364L),
2822 TEST_c_c (cacosh, 0x1.fp-100L, -1.0L, 8.813735870195430252326093249797923090282e-1L, -1.570796326794896619231321691638670687364L),
2823 TEST_c_c (cacosh, -0x1.fp-100L, 1.0L, 8.813735870195430252326093249797923090282e-1L, 1.570796326794896619231321691640832196834L),
2824 TEST_c_c (cacosh, -0x1.fp-100L, -1.0L, 8.813735870195430252326093249797923090282e-1L, -1.570796326794896619231321691640832196834L),
2825 TEST_c_c (cacosh, 1.0L, 0x1.fp-100L, 1.236292038260260888664514866457202186027e-15L, 1.236292038260260888664514866456887257525e-15L),
2826 TEST_c_c (cacosh, -1.0L, 0x1.fp-100L, 1.236292038260260888664514866457202186027e-15L, 3.141592653589792002170605123018614219682L),
2827 TEST_c_c (cacosh, 1.0L, -0x1.fp-100L, 1.236292038260260888664514866457202186027e-15L, -1.236292038260260888664514866456887257525e-15L),
2828 TEST_c_c (cacosh, -1.0L, -0x1.fp-100L, 1.236292038260260888664514866457202186027e-15L, -3.141592653589792002170605123018614219682L),
2829 TEST_c_c (cacosh, 0x1.fp-129L, 1.0L, 8.813735870195430252326093249797923090282e-1L, 1.570796326794896619231321691639751442097L),
2830 TEST_c_c (cacosh, 0x1.fp-129L, -1.0L, 8.813735870195430252326093249797923090282e-1L, -1.570796326794896619231321691639751442097L),
2831 TEST_c_c (cacosh, -0x1.fp-129L, 1.0L, 8.813735870195430252326093249797923090282e-1L, 1.570796326794896619231321691639751442101L),
2832 TEST_c_c (cacosh, -0x1.fp-129L, -1.0L, 8.813735870195430252326093249797923090282e-1L, -1.570796326794896619231321691639751442101L),
2833 TEST_c_c (cacosh, 1.0L, 0x1.fp-129L, 5.335635276982233498398987585285818977933e-20L, 5.335635276982233498398987585285818977930e-20L),
2834 TEST_c_c (cacosh, -1.0L, 0x1.fp-129L, 5.335635276982233498398987585285818977933e-20L, 3.141592653589793238409287030509680549213L),
2835 TEST_c_c (cacosh, 1.0L, -0x1.fp-129L, 5.335635276982233498398987585285818977933e-20L, -5.335635276982233498398987585285818977930e-20L),
2836 TEST_c_c (cacosh, -1.0L, -0x1.fp-129L, 5.335635276982233498398987585285818977933e-20L, -3.141592653589793238409287030509680549213L),
2837 #ifndef TEST_FLOAT
2838 TEST_c_c (cacosh, 0x1.fp-1000L, 1.0L, 8.813735870195430252326093249797923090282e-1L, 1.570796326794896619231321691639751442099L),
2839 TEST_c_c (cacosh, 0x1.fp-1000L, -1.0L, 8.813735870195430252326093249797923090282e-1L, -1.570796326794896619231321691639751442099L),
2840 TEST_c_c (cacosh, -0x1.fp-1000L, 1.0L, 8.813735870195430252326093249797923090282e-1L, 1.570796326794896619231321691639751442099L),
2841 TEST_c_c (cacosh, -0x1.fp-1000L, -1.0L, 8.813735870195430252326093249797923090282e-1L, -1.570796326794896619231321691639751442099L),
2842 TEST_c_c (cacosh, 1.0L, 0x1.fp-1000L, 4.252291453851660175550490409247739011867e-151L, 4.252291453851660175550490409247739011867e-151L),
2843 TEST_c_c (cacosh, -1.0L, 0x1.fp-1000L, 4.252291453851660175550490409247739011867e-151L, 3.141592653589793238462643383279502884197L),
2844 TEST_c_c (cacosh, 1.0L, -0x1.fp-1000L, 4.252291453851660175550490409247739011867e-151L, -4.252291453851660175550490409247739011867e-151L),
2845 TEST_c_c (cacosh, -1.0L, -0x1.fp-1000L, 4.252291453851660175550490409247739011867e-151L, -3.141592653589793238462643383279502884197L),
2846 TEST_c_c (cacosh, 0x1.fp-1025L, 1.0L, 8.813735870195430252326093249797923090282e-1L, 1.570796326794896619231321691639751442099L),
2847 TEST_c_c (cacosh, 0x1.fp-1025L, -1.0L, 8.813735870195430252326093249797923090282e-1L, -1.570796326794896619231321691639751442099L),
2848 TEST_c_c (cacosh, -0x1.fp-1025L, 1.0L, 8.813735870195430252326093249797923090282e-1L, 1.570796326794896619231321691639751442099L),
2849 TEST_c_c (cacosh, -0x1.fp-1025L, -1.0L, 8.813735870195430252326093249797923090282e-1L, -1.570796326794896619231321691639751442099L),
2850 TEST_c_c (cacosh, 1.0L, 0x1.fp-1025L, 7.340879205566679497036857179189356754017e-155L, 7.340879205566679497036857179189356754017e-155L),
2851 TEST_c_c (cacosh, -1.0L, 0x1.fp-1025L, 7.340879205566679497036857179189356754017e-155L, 3.141592653589793238462643383279502884197L),
2852 TEST_c_c (cacosh, 1.0L, -0x1.fp-1025L, 7.340879205566679497036857179189356754017e-155L, -7.340879205566679497036857179189356754017e-155L),
2853 TEST_c_c (cacosh, -1.0L, -0x1.fp-1025L, 7.340879205566679497036857179189356754017e-155L, -3.141592653589793238462643383279502884197L),
2854 #endif
2855 #if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
2856 TEST_c_c (cacosh, 0x1.fp-10000L, 1.0L, 8.813735870195430252326093249797923090282e-1L, 1.570796326794896619231321691639751442099L),
2857 TEST_c_c (cacosh, 0x1.fp-10000L, -1.0L, 8.813735870195430252326093249797923090282e-1L, -1.570796326794896619231321691639751442099L),
2858 TEST_c_c (cacosh, -0x1.fp-10000L, 1.0L, 8.813735870195430252326093249797923090282e-1L, 1.570796326794896619231321691639751442099L),
2859 TEST_c_c (cacosh, -0x1.fp-10000L, -1.0L, 8.813735870195430252326093249797923090282e-1L, -1.570796326794896619231321691639751442099L),
2860 TEST_c_c (cacosh, 1.0L, 0x1.fp-10000L, 9.854680208706673586644342922051388714633e-1506L, 9.854680208706673586644342922051388714633e-1506L),
2861 TEST_c_c (cacosh, -1.0L, 0x1.fp-10000L, 9.854680208706673586644342922051388714633e-1506L, 3.141592653589793238462643383279502884197L),
2862 TEST_c_c (cacosh, 1.0L, -0x1.fp-10000L, 9.854680208706673586644342922051388714633e-1506L, -9.854680208706673586644342922051388714633e-1506L),
2863 TEST_c_c (cacosh, -1.0L, -0x1.fp-10000L, 9.854680208706673586644342922051388714633e-1506L, -3.141592653589793238462643383279502884197L),
2864 TEST_c_c (cacosh, 0x1.fp-16385L, 1.0L, 8.813735870195430252326093249797923090282e-1L, 1.570796326794896619231321691639751442099L),
2865 TEST_c_c (cacosh, 0x1.fp-16385L, -1.0L, 8.813735870195430252326093249797923090282e-1L, -1.570796326794896619231321691639751442099L),
2866 TEST_c_c (cacosh, -0x1.fp-16385L, 1.0L, 8.813735870195430252326093249797923090282e-1L, 1.570796326794896619231321691639751442099L),
2867 TEST_c_c (cacosh, -0x1.fp-16385L, -1.0L, 8.813735870195430252326093249797923090282e-1L, -1.570796326794896619231321691639751442099L),
2868 TEST_c_c (cacosh, 1.0L, 0x1.fp-16385L, 9.023632056840860275214893047597614177639e-2467L, 9.023632056840860275214893047597614177639e-2467L),
2869 TEST_c_c (cacosh, -1.0L, 0x1.fp-16385L, 9.023632056840860275214893047597614177639e-2467L, 3.141592653589793238462643383279502884197L),
2870 TEST_c_c (cacosh, 1.0L, -0x1.fp-16385L, 9.023632056840860275214893047597614177639e-2467L, -9.023632056840860275214893047597614177639e-2467L),
2871 TEST_c_c (cacosh, -1.0L, -0x1.fp-16385L, 9.023632056840860275214893047597614177639e-2467L, -3.141592653589793238462643383279502884197L),
2872 #endif
2873 TEST_c_c (cacosh, 0x1p-23L, 0x1.000002p0L, 8.813736713132400470205730751186547909968e-1L, 1.570796242501204621739026081991856762292L),
2874 TEST_c_c (cacosh, 0x1p-23L, -0x1.000002p0L, 8.813736713132400470205730751186547909968e-1L, -1.570796242501204621739026081991856762292L),
2875 TEST_c_c (cacosh, -0x1p-23L, 0x1.000002p0L, 8.813736713132400470205730751186547909968e-1L, 1.570796411088588616723617301287646121905L),
2876 TEST_c_c (cacosh, -0x1p-23L, -0x1.000002p0L, 8.813736713132400470205730751186547909968e-1L, -1.570796411088588616723617301287646121905L),
2877 TEST_c_c (cacosh, 0x1.000002p0L, 0x1p-23L, 5.364668491573609633134147164031476452679e-4L, 2.222118384408546368406374049167636760903e-4L),
2878 TEST_c_c (cacosh, -0x1.000002p0L, 0x1p-23L, 5.364668491573609633134147164031476452679e-4L, 3.141370441751352383825802745874586120521L),
2879 TEST_c_c (cacosh, 0x1.000002p0L, -0x1p-23L, 5.364668491573609633134147164031476452679e-4L, -2.222118384408546368406374049167636760903e-4L),
2880 TEST_c_c (cacosh, -0x1.000002p0L, -0x1p-23L, 5.364668491573609633134147164031476452679e-4L, -3.141370441751352383825802745874586120521L),
2881 TEST_c_c (cacosh, 0x1.fp-129L, 0x1.000002p0L, 8.813736713132375348727889167749389235161e-1L, 1.570796326794896619231321691639751442097L),
2882 TEST_c_c (cacosh, 0x1.fp-129L, -0x1.000002p0L, 8.813736713132375348727889167749389235161e-1L, -1.570796326794896619231321691639751442097L),
2883 TEST_c_c (cacosh, -0x1.fp-129L, 0x1.000002p0L, 8.813736713132375348727889167749389235161e-1L, 1.570796326794896619231321691639751442101L),
2884 TEST_c_c (cacosh, -0x1.fp-129L, -0x1.000002p0L, 8.813736713132375348727889167749389235161e-1L, -1.570796326794896619231321691639751442101L),
2885 TEST_c_c (cacosh, 0x1.000002p0L, 0x1.fp-129L, 4.882812451493617206486388134172712975070e-4L, 5.830451806317544230969669308596361881467e-36L),
2886 TEST_c_c (cacosh, -0x1.000002p0L, 0x1.fp-129L, 4.882812451493617206486388134172712975070e-4L, 3.141592653589793238462643383279502878367L),
2887 TEST_c_c (cacosh, 0x1.000002p0L, -0x1.fp-129L, 4.882812451493617206486388134172712975070e-4L, -5.830451806317544230969669308596361881467e-36L),
2888 TEST_c_c (cacosh, -0x1.000002p0L, -0x1.fp-129L, 4.882812451493617206486388134172712975070e-4L, -3.141592653589793238462643383279502878367L),
2889 TEST_c_c (cacosh, 0.0L, 0x1.000002p0L, 8.813736713132375348727889167749389235161e-1L, 1.570796326794896619231321691639751442099L),
2890 TEST_c_c (cacosh, 0.0L, -0x1.000002p0L, 8.813736713132375348727889167749389235161e-1L, -1.570796326794896619231321691639751442099L),
2891 TEST_c_c (cacosh, -0.0L, 0x1.000002p0L, 8.813736713132375348727889167749389235161e-1L, 1.570796326794896619231321691639751442099L),
2892 TEST_c_c (cacosh, -0.0L, -0x1.000002p0L, 8.813736713132375348727889167749389235161e-1L, -1.570796326794896619231321691639751442099L),
2893 TEST_c_c (cacosh, 0x1.000002p0L, 0.0L, 4.882812451493617206486388134172712975070e-4L, 0.0L),
2894 TEST_c_c (cacosh, -0x1.000002p0L, 0.0L, 4.882812451493617206486388134172712975070e-4L, 3.141592653589793238462643383279502884197L),
2895 TEST_c_c (cacosh, 0x1.000002p0L, -0.0L, 4.882812451493617206486388134172712975070e-4L, -0.0L),
2896 TEST_c_c (cacosh, -0x1.000002p0L, -0.0L, 4.882812451493617206486388134172712975070e-4L, -3.141592653589793238462643383279502884197L),
2897 #ifndef TEST_FLOAT
2898 TEST_c_c (cacosh, 0x1p-52L, 0x1.0000000000001p0L, 8.813735870195431822418551933572982483664e-1L, 1.570796326794896462222075823262262934288L),
2899 TEST_c_c (cacosh, 0x1p-52L, -0x1.0000000000001p0L, 8.813735870195431822418551933572982483664e-1L, -1.570796326794896462222075823262262934288L),
2900 TEST_c_c (cacosh, -0x1p-52L, 0x1.0000000000001p0L, 8.813735870195431822418551933572982483664e-1L, 1.570796326794896776240567560017239949909L),
2901 TEST_c_c (cacosh, -0x1p-52L, -0x1.0000000000001p0L, 8.813735870195431822418551933572982483664e-1L, -1.570796326794896776240567560017239949909L),
2902 TEST_c_c (cacosh, 0x1.0000000000001p0L, 0x1p-52L, 2.315303644582684770975188768022139415020e-8L, 9.590301705980041385828904092662391018164e-9L),
2903 TEST_c_c (cacosh, -0x1.0000000000001p0L, 0x1p-52L, 2.315303644582684770975188768022139415020e-8L, 3.141592643999491532482601997450598791535L),
2904 TEST_c_c (cacosh, 0x1.0000000000001p0L, -0x1p-52L, 2.315303644582684770975188768022139415020e-8L, -9.590301705980041385828904092662391018164e-9L),
2905 TEST_c_c (cacosh, -0x1.0000000000001p0L, -0x1p-52L, 2.315303644582684770975188768022139415020e-8L, -3.141592643999491532482601997450598791535L),
2906 TEST_c_c (cacosh, 0x1.fp-1025L, 0x1.0000000000001p0L, 8.813735870195431822418551933572895326024e-1L, 1.570796326794896619231321691639751442099L),
2907 TEST_c_c (cacosh, 0x1.fp-1025L, -0x1.0000000000001p0L, 8.813735870195431822418551933572895326024e-1L, -1.570796326794896619231321691639751442099L),
2908 TEST_c_c (cacosh, -0x1.fp-1025L, 0x1.0000000000001p0L, 8.813735870195431822418551933572895326024e-1L, 1.570796326794896619231321691639751442099L),
2909 TEST_c_c (cacosh, -0x1.fp-1025L, -0x1.0000000000001p0L, 8.813735870195431822418551933572895326024e-1L, -1.570796326794896619231321691639751442099L),
2910 TEST_c_c (cacosh, 0x1.0000000000001p0L, 0x1.fp-1025L, 2.107342425544701550354780375182800088393e-8L, 2.557178503953494342609835913586108008322e-301L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
2911 TEST_c_c (cacosh, -0x1.0000000000001p0L, 0x1.fp-1025L, 2.107342425544701550354780375182800088393e-8L, 3.141592653589793238462643383279502884197L),
2912 TEST_c_c (cacosh, 0x1.0000000000001p0L, -0x1.fp-1025L, 2.107342425544701550354780375182800088393e-8L, -2.557178503953494342609835913586108008322e-301L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
2913 TEST_c_c (cacosh, -0x1.0000000000001p0L, -0x1.fp-1025L, 2.107342425544701550354780375182800088393e-8L, -3.141592653589793238462643383279502884197L),
2914 TEST_c_c (cacosh, 0.0L, 0x1.0000000000001p0L, 8.813735870195431822418551933572895326024e-1L, 1.570796326794896619231321691639751442099L),
2915 TEST_c_c (cacosh, 0.0L, -0x1.0000000000001p0L, 8.813735870195431822418551933572895326024e-1L, -1.570796326794896619231321691639751442099L),
2916 TEST_c_c (cacosh, -0.0L, 0x1.0000000000001p0L, 8.813735870195431822418551933572895326024e-1L, 1.570796326794896619231321691639751442099L),
2917 TEST_c_c (cacosh, -0.0L, -0x1.0000000000001p0L, 8.813735870195431822418551933572895326024e-1L, -1.570796326794896619231321691639751442099L),
2918 TEST_c_c (cacosh, 0x1.0000000000001p0L, 0.0L, 2.107342425544701550354780375182800088393e-8L, 0.0L),
2919 TEST_c_c (cacosh, -0x1.0000000000001p0L, 0.0L, 2.107342425544701550354780375182800088393e-8L, 3.141592653589793238462643383279502884197L),
2920 TEST_c_c (cacosh, 0x1.0000000000001p0L, -0.0L, 2.107342425544701550354780375182800088393e-8L, -0.0L),
2921 TEST_c_c (cacosh, -0x1.0000000000001p0L, -0.0L, 2.107342425544701550354780375182800088393e-8L, -3.141592653589793238462643383279502884197L),
2922 #endif
2923 #if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 64
2924 TEST_c_c (cacosh, 0x1p-63L, 0x1.0000000000000002p0L, 8.813735870195430253092739958139610131001e-1L, 1.570796326794896619154657020805582738031L),
2925 TEST_c_c (cacosh, 0x1p-63L, -0x1.0000000000000002p0L, 8.813735870195430253092739958139610131001e-1L, -1.570796326794896619154657020805582738031L),
2926 TEST_c_c (cacosh, -0x1p-63L, 0x1.0000000000000002p0L, 8.813735870195430253092739958139610131001e-1L, 1.570796326794896619307986362473920146166L),
2927 TEST_c_c (cacosh, -0x1p-63L, -0x1.0000000000000002p0L, 8.813735870195430253092739958139610131001e-1L, -1.570796326794896619307986362473920146166L),
2928 TEST_c_c (cacosh, 0x1.0000000000000002p0L, 0x1p-63L, 5.116146586219826555037807251857670783420e-10L, 2.119177303101063432592523199680782317447e-10L),
2929 TEST_c_c (cacosh, -0x1.0000000000000002p0L, 0x1p-63L, 5.116146586219826555037807251857670783420e-10L, 3.141592653377875508152537040020250564229L),
2930 TEST_c_c (cacosh, 0x1.0000000000000002p0L, -0x1p-63L, 5.116146586219826555037807251857670783420e-10L, -2.119177303101063432592523199680782317447e-10L),
2931 TEST_c_c (cacosh, -0x1.0000000000000002p0L, -0x1p-63L, 5.116146586219826555037807251857670783420e-10L, -3.141592653377875508152537040020250564229L),
2932 # if LDBL_MIN_EXP <= -16381
2933 TEST_c_c (cacosh, 0x1.fp-16385L, 0x1.0000000000000002p0L, 8.813735870195430253092739958139610130980e-1L, 1.570796326794896619231321691639751442099L),
2934 TEST_c_c (cacosh, 0x1.fp-16385L, -0x1.0000000000000002p0L, 8.813735870195430253092739958139610130980e-1L, -1.570796326794896619231321691639751442099L),
2935 TEST_c_c (cacosh, -0x1.fp-16385L, 0x1.0000000000000002p0L, 8.813735870195430253092739958139610130980e-1L, 1.570796326794896619231321691639751442099L),
2936 TEST_c_c (cacosh, -0x1.fp-16385L, -0x1.0000000000000002p0L, 8.813735870195430253092739958139610130980e-1L, -1.570796326794896619231321691639751442099L),
2937 TEST_c_c (cacosh, 0x1.0000000000000002p0L, 0x1.fp-16385L, 4.656612873077392578082927418388212703712e-10L, 1.748608650034385653922359120438227480943e-4923L),
2938 TEST_c_c (cacosh, -0x1.0000000000000002p0L, 0x1.fp-16385L, 4.656612873077392578082927418388212703712e-10L, 3.141592653589793238462643383279502884197L),
2939 TEST_c_c (cacosh, 0x1.0000000000000002p0L, -0x1.fp-16385L, 4.656612873077392578082927418388212703712e-10L, -1.748608650034385653922359120438227480943e-4923L),
2940 TEST_c_c (cacosh, -0x1.0000000000000002p0L, -0x1.fp-16385L, 4.656612873077392578082927418388212703712e-10L, -3.141592653589793238462643383279502884197L),
2941 # endif
2942 TEST_c_c (cacosh, 0.0L, 0x1.0000000000000002p0L, 8.813735870195430253092739958139610130980e-1L, 1.570796326794896619231321691639751442099L),
2943 TEST_c_c (cacosh, 0.0L, -0x1.0000000000000002p0L, 8.813735870195430253092739958139610130980e-1L, -1.570796326794896619231321691639751442099L),
2944 TEST_c_c (cacosh, -0.0L, 0x1.0000000000000002p0L, 8.813735870195430253092739958139610130980e-1L, 1.570796326794896619231321691639751442099L),
2945 TEST_c_c (cacosh, -0.0L, -0x1.0000000000000002p0L, 8.813735870195430253092739958139610130980e-1L, -1.570796326794896619231321691639751442099L),
2946 TEST_c_c (cacosh, 0x1.0000000000000002p0L, 0.0L, 4.656612873077392578082927418388212703712e-10L, 0.0L),
2947 TEST_c_c (cacosh, -0x1.0000000000000002p0L, 0.0L, 4.656612873077392578082927418388212703712e-10L, 3.141592653589793238462643383279502884197L),
2948 TEST_c_c (cacosh, 0x1.0000000000000002p0L, -0.0L, 4.656612873077392578082927418388212703712e-10L, -0.0L),
2949 TEST_c_c (cacosh, -0x1.0000000000000002p0L, -0.0L, 4.656612873077392578082927418388212703712e-10L, -3.141592653589793238462643383279502884197L),
2950 #endif
2951 #if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 106
2952 TEST_c_c (cacosh, 0x1p-106L, 0x1.000000000000000000000000008p0L, 8.813735870195430252326093249798097405561e-1L, 1.570796326794896619231321691639742726335L),
2953 TEST_c_c (cacosh, 0x1p-106L, -0x1.000000000000000000000000008p0L, 8.813735870195430252326093249798097405561e-1L, -1.570796326794896619231321691639742726335L),
2954 TEST_c_c (cacosh, -0x1p-106L, 0x1.000000000000000000000000008p0L, 8.813735870195430252326093249798097405561e-1L, 1.570796326794896619231321691639760157863L),
2955 TEST_c_c (cacosh, -0x1p-106L, -0x1.000000000000000000000000008p0L, 8.813735870195430252326093249798097405561e-1L, -1.570796326794896619231321691639760157863L),
2956 TEST_c_c (cacosh, 0x1.000000000000000000000000008p0L, 0x1p-106L, 2.285028863093221674154232933662774454211e-16L, 5.394221422390606848017034778914096659726e-17L),
2957 TEST_c_c (cacosh, -0x1.000000000000000000000000008p0L, 0x1p-106L, 2.285028863093221674154232933662774454211e-16L, 3.141592653589793184520429159373434404027L),
2958 TEST_c_c (cacosh, 0x1.000000000000000000000000008p0L, -0x1p-106L, 2.285028863093221674154232933662774454211e-16L, -5.394221422390606848017034778914096659726e-17L),
2959 TEST_c_c (cacosh, -0x1.000000000000000000000000008p0L, -0x1p-106L, 2.285028863093221674154232933662774454211e-16L, -3.141592653589793184520429159373434404027L),
2960 TEST_c_c (cacosh, 0x1.fp-1025L, 0x1.000000000000000000000000008p0L, 8.813735870195430252326093249798097405561e-1L, 1.570796326794896619231321691639751442099L),
2961 TEST_c_c (cacosh, 0x1.fp-1025L, -0x1.000000000000000000000000008p0L, 8.813735870195430252326093249798097405561e-1L, -1.570796326794896619231321691639751442099L),
2962 TEST_c_c (cacosh, -0x1.fp-1025L, 0x1.000000000000000000000000008p0L, 8.813735870195430252326093249798097405561e-1L, 1.570796326794896619231321691639751442099L),
2963 TEST_c_c (cacosh, -0x1.fp-1025L, -0x1.000000000000000000000000008p0L, 8.813735870195430252326093249798097405561e-1L, -1.570796326794896619231321691639751442099L),
2964 TEST_c_c (cacosh, 0x1.000000000000000000000000008p0L, 0x1.fp-1025L, 2.220446049250313080847263336181636063482e-16L, 2.426922623448365473354662093431821897807e-293L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
2965 TEST_c_c (cacosh, -0x1.000000000000000000000000008p0L, 0x1.fp-1025L, 2.220446049250313080847263336181636063482e-16L, 3.141592653589793238462643383279502884197L),
2966 TEST_c_c (cacosh, 0x1.000000000000000000000000008p0L, -0x1.fp-1025L, 2.220446049250313080847263336181636063482e-16L, -2.426922623448365473354662093431821897807e-293L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
2967 TEST_c_c (cacosh, -0x1.000000000000000000000000008p0L, -0x1.fp-1025L, 2.220446049250313080847263336181636063482e-16L, -3.141592653589793238462643383279502884197L),
2968 TEST_c_c (cacosh, 0.0L, 0x1.000000000000000000000000008p0L, 8.813735870195430252326093249798097405561e-1L, 1.570796326794896619231321691639751442099L),
2969 TEST_c_c (cacosh, 0.0L, -0x1.000000000000000000000000008p0L, 8.813735870195430252326093249798097405561e-1L, -1.570796326794896619231321691639751442099L),
2970 TEST_c_c (cacosh, -0.0L, 0x1.000000000000000000000000008p0L, 8.813735870195430252326093249798097405561e-1L, 1.570796326794896619231321691639751442099L),
2971 TEST_c_c (cacosh, -0.0L, -0x1.000000000000000000000000008p0L, 8.813735870195430252326093249798097405561e-1L, -1.570796326794896619231321691639751442099L),
2972 TEST_c_c (cacosh, 0x1.000000000000000000000000008p0L, 0.0L, 2.220446049250313080847263336181636063482e-16L, 0.0L),
2973 TEST_c_c (cacosh, -0x1.000000000000000000000000008p0L, 0.0L, 2.220446049250313080847263336181636063482e-16L, 3.141592653589793238462643383279502884197L),
2974 TEST_c_c (cacosh, 0x1.000000000000000000000000008p0L, -0.0L, 2.220446049250313080847263336181636063482e-16L, -0.0L),
2975 TEST_c_c (cacosh, -0x1.000000000000000000000000008p0L, -0.0L, 2.220446049250313080847263336181636063482e-16L, -3.141592653589793238462643383279502884197L),
2976 #endif
2977 #if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 113
2978 TEST_c_c (cacosh, 0x1p-113L, 0x1.0000000000000000000000000001p0L, 8.813735870195430252326093249797924452120e-1L, 1.570796326794896619231321691639751374007L),
2979 TEST_c_c (cacosh, 0x1p-113L, -0x1.0000000000000000000000000001p0L, 8.813735870195430252326093249797924452120e-1L, -1.570796326794896619231321691639751374007L),
2980 TEST_c_c (cacosh, -0x1p-113L, 0x1.0000000000000000000000000001p0L, 8.813735870195430252326093249797924452120e-1L, 1.570796326794896619231321691639751510190L),
2981 TEST_c_c (cacosh, -0x1p-113L, -0x1.0000000000000000000000000001p0L, 8.813735870195430252326093249797924452120e-1L, -1.570796326794896619231321691639751510190L),
2982 TEST_c_c (cacosh, 0x1.0000000000000000000000000001p0L, 0x1p-113L, 2.019699255375255198156433710951064632386e-17L, 4.767863183742677481693563511435642755521e-18L),
2983 TEST_c_c (cacosh, -0x1.0000000000000000000000000001p0L, 0x1p-113L, 2.019699255375255198156433710951064632386e-17L, 3.141592653589793233694780199536825402504L),
2984 TEST_c_c (cacosh, 0x1.0000000000000000000000000001p0L, -0x1p-113L, 2.019699255375255198156433710951064632386e-17L, -4.767863183742677481693563511435642755521e-18L),
2985 TEST_c_c (cacosh, -0x1.0000000000000000000000000001p0L, -0x1p-113L, 2.019699255375255198156433710951064632386e-17L, -3.141592653589793233694780199536825402504L),
2986 TEST_c_c (cacosh, 0x1.fp-16385L, 0x1.0000000000000000000000000001p0L, 8.813735870195430252326093249797924452120e-1L, 1.570796326794896619231321691639751442099L),
2987 TEST_c_c (cacosh, 0x1.fp-16385L, -0x1.0000000000000000000000000001p0L, 8.813735870195430252326093249797924452120e-1L, -1.570796326794896619231321691639751442099L),
2988 TEST_c_c (cacosh, -0x1.fp-16385L, 0x1.0000000000000000000000000001p0L, 8.813735870195430252326093249797924452120e-1L, 1.570796326794896619231321691639751442099L),
2989 TEST_c_c (cacosh, -0x1.fp-16385L, -0x1.0000000000000000000000000001p0L, 8.813735870195430252326093249797924452120e-1L, -1.570796326794896619231321691639751442099L),
2990 TEST_c_c (cacosh, 0x1.0000000000000000000000000001p0L, 0x1.fp-16385L, 1.962615573354718824241727964954454332780e-17L, 4.148847925325683229178506116378864361396e-4916L),
2991 TEST_c_c (cacosh, -0x1.0000000000000000000000000001p0L, 0x1.fp-16385L, 1.962615573354718824241727964954454332780e-17L, 3.141592653589793238462643383279502884197L),
2992 TEST_c_c (cacosh, 0x1.0000000000000000000000000001p0L, -0x1.fp-16385L, 1.962615573354718824241727964954454332780e-17L, -4.148847925325683229178506116378864361396e-4916L),
2993 TEST_c_c (cacosh, -0x1.0000000000000000000000000001p0L, -0x1.fp-16385L, 1.962615573354718824241727964954454332780e-17L, -3.141592653589793238462643383279502884197L),
2994 TEST_c_c (cacosh, 0.0L, 0x1.0000000000000000000000000001p0L, 8.813735870195430252326093249797924452120e-1L, 1.570796326794896619231321691639751442099L),
2995 TEST_c_c (cacosh, 0.0L, -0x1.0000000000000000000000000001p0L, 8.813735870195430252326093249797924452120e-1L, -1.570796326794896619231321691639751442099L),
2996 TEST_c_c (cacosh, -0.0L, 0x1.0000000000000000000000000001p0L, 8.813735870195430252326093249797924452120e-1L, 1.570796326794896619231321691639751442099L),
2997 TEST_c_c (cacosh, -0.0L, -0x1.0000000000000000000000000001p0L, 8.813735870195430252326093249797924452120e-1L, -1.570796326794896619231321691639751442099L),
2998 TEST_c_c (cacosh, 0x1.0000000000000000000000000001p0L, 0.0L, 1.962615573354718824241727964954454332780e-17L, 0.0L),
2999 TEST_c_c (cacosh, -0x1.0000000000000000000000000001p0L, 0.0L, 1.962615573354718824241727964954454332780e-17L, 3.141592653589793238462643383279502884197L),
3000 TEST_c_c (cacosh, 0x1.0000000000000000000000000001p0L, -0.0L, 1.962615573354718824241727964954454332780e-17L, -0.0L),
3001 TEST_c_c (cacosh, -0x1.0000000000000000000000000001p0L, -0.0L, 1.962615573354718824241727964954454332780e-17L, -3.141592653589793238462643383279502884197L),
3002 #endif
3003 TEST_c_c (cacosh, 0x1p-23L, 0x0.ffffffp0L, 8.813735448726963984495965873956465777250e-1L, 1.570796242501197085295336701632142060969L),
3004 TEST_c_c (cacosh, 0x1p-23L, -0x0.ffffffp0L, 8.813735448726963984495965873956465777250e-1L, -1.570796242501197085295336701632142060969L),
3005 TEST_c_c (cacosh, -0x1p-23L, 0x0.ffffffp0L, 8.813735448726963984495965873956465777250e-1L, 1.570796411088596153167306681647360823228L),
3006 TEST_c_c (cacosh, -0x1p-23L, -0x0.ffffffp0L, 8.813735448726963984495965873956465777250e-1L, -1.570796411088596153167306681647360823228L),
3007 TEST_c_c (cacosh, 0x0.ffffffp0L, 0x1p-23L, 2.714321200917194650737217746780928423385e-4L, 4.391863861910487109445187743978204002614e-4L),
3008 TEST_c_c (cacosh, -0x0.ffffffp0L, 0x1p-23L, 2.714321200917194650737217746780928423385e-4L, 3.141153467203602189751698864505105063797L),
3009 TEST_c_c (cacosh, 0x0.ffffffp0L, -0x1p-23L, 2.714321200917194650737217746780928423385e-4L, -4.391863861910487109445187743978204002614e-4L),
3010 TEST_c_c (cacosh, -0x0.ffffffp0L, -0x1p-23L, 2.714321200917194650737217746780928423385e-4L, -3.141153467203602189751698864505105063797L),
3011 TEST_c_c (cacosh, 0x1.fp-129L, 0x0.ffffffp0L, 8.813735448726938863015878255140556727969e-1L, 1.570796326794896619231321691639751442097L),
3012 TEST_c_c (cacosh, 0x1.fp-129L, -0x0.ffffffp0L, 8.813735448726938863015878255140556727969e-1L, -1.570796326794896619231321691639751442097L),
3013 TEST_c_c (cacosh, -0x1.fp-129L, 0x0.ffffffp0L, 8.813735448726938863015878255140556727969e-1L, 1.570796326794896619231321691639751442101L),
3014 TEST_c_c (cacosh, -0x1.fp-129L, -0x0.ffffffp0L, 8.813735448726938863015878255140556727969e-1L, -1.570796326794896619231321691639751442101L),
3015 TEST_c_c (cacosh, 0x0.ffffffp0L, 0x1.fp-129L, 8.245504387859737323891843603996428534945e-36L, 3.452669847162035876032494826387364972849e-4L),
3016 TEST_c_c (cacosh, -0x0.ffffffp0L, 0x1.fp-129L, 8.245504387859737323891843603996428534945e-36L, 3.141247386605077034875040133796864147700L),
3017 TEST_c_c (cacosh, 0x0.ffffffp0L, -0x1.fp-129L, 8.245504387859737323891843603996428534945e-36L, -3.452669847162035876032494826387364972849e-4L),
3018 TEST_c_c (cacosh, -0x0.ffffffp0L, -0x1.fp-129L, 8.245504387859737323891843603996428534945e-36L, -3.141247386605077034875040133796864147700L),
3019 TEST_c_c (cacosh, 0.0L, 0x0.ffffffp0L, 8.813735448726938863015878255140556727969e-1L, 1.570796326794896619231321691639751442099L),
3020 TEST_c_c (cacosh, 0.0L, -0x0.ffffffp0L, 8.813735448726938863015878255140556727969e-1L, -1.570796326794896619231321691639751442099L),
3021 TEST_c_c (cacosh, -0.0L, 0x0.ffffffp0L, 8.813735448726938863015878255140556727969e-1L, 1.570796326794896619231321691639751442099L),
3022 TEST_c_c (cacosh, -0.0L, -0x0.ffffffp0L, 8.813735448726938863015878255140556727969e-1L, -1.570796326794896619231321691639751442099L),
3023 TEST_c_c (cacosh, 0x0.ffffffp0L, 0.0L, 0.0L, 3.452669847162035876032494826387364972849e-4L),
3024 TEST_c_c (cacosh, -0x0.ffffffp0L, 0.0L, 0.0L, 3.141247386605077034875040133796864147700L),
3025 TEST_c_c (cacosh, 0x0.ffffffp0L, -0.0L, 0.0L, -3.452669847162035876032494826387364972849e-4L),
3026 TEST_c_c (cacosh, -0x0.ffffffp0L, -0.0L, 0.0L, -3.141247386605077034875040133796864147700L),
3027 TEST_c_c (cacosh, 0x1p-23L, 0.5L, 4.812118250596059896127318386463676808798e-1L, 1.570796220170866625230343643673321150378L),
3028 TEST_c_c (cacosh, 0x1p-23L, -0.5L, 4.812118250596059896127318386463676808798e-1L, -1.570796220170866625230343643673321150378L),
3029 TEST_c_c (cacosh, -0x1p-23L, 0.5L, 4.812118250596059896127318386463676808798e-1L, 1.570796433418926613232299739606181733819L),
3030 TEST_c_c (cacosh, -0x1p-23L, -0.5L, 4.812118250596059896127318386463676808798e-1L, -1.570796433418926613232299739606181733819L),
3031 TEST_c_c (cacosh, 0.5L, 0x1p-23L, 1.376510308240943236356088341381173571841e-7L, 1.047197551196603215914744618665204532273L),
3032 TEST_c_c (cacosh, -0.5L, 0x1p-23L, 1.376510308240943236356088341381173571841e-7L, 2.094395102393190022547898764614298351924L),
3033 TEST_c_c (cacosh, 0.5L, -0x1p-23L, 1.376510308240943236356088341381173571841e-7L, -1.047197551196603215914744618665204532273L),
3034 TEST_c_c (cacosh, -0.5L, -0x1p-23L, 1.376510308240943236356088341381173571841e-7L, -2.094395102393190022547898764614298351924L),
3035 TEST_c_c (cacosh, 0x1.fp-129L, 0.5L, 4.812118250596034474977589134243684231352e-1L, 1.570796326794896619231321691639751442096L),
3036 TEST_c_c (cacosh, 0x1.fp-129L, -0.5L, 4.812118250596034474977589134243684231352e-1L, -1.570796326794896619231321691639751442096L),
3037 TEST_c_c (cacosh, -0x1.fp-129L, 0.5L, 4.812118250596034474977589134243684231352e-1L, 1.570796326794896619231321691639751442101L),
3038 TEST_c_c (cacosh, -0x1.fp-129L, -0.5L, 4.812118250596034474977589134243684231352e-1L, -1.570796326794896619231321691639751442101L),
3039 TEST_c_c (cacosh, 0.5L, 0x1.fp-129L, 3.287317402534702257036015056278368274737e-39L, 1.047197551196597746154214461093167628066L, UNDERFLOW_EXCEPTION_FLOAT),
3040 TEST_c_c (cacosh, -0.5L, 0x1.fp-129L, 3.287317402534702257036015056278368274737e-39L, 2.094395102393195492308428922186335256131L, UNDERFLOW_EXCEPTION_FLOAT),
3041 TEST_c_c (cacosh, 0.5L, -0x1.fp-129L, 3.287317402534702257036015056278368274737e-39L, -1.047197551196597746154214461093167628066L, UNDERFLOW_EXCEPTION_FLOAT),
3042 TEST_c_c (cacosh, -0.5L, -0x1.fp-129L, 3.287317402534702257036015056278368274737e-39L, -2.094395102393195492308428922186335256131L, UNDERFLOW_EXCEPTION_FLOAT),
3043 TEST_c_c (cacosh, 0x1p-23L, 0x1p-23L, 1.192092895507818146886315028596704749235e-7L, 1.570796207585607068450636380271254316214L),
3044 TEST_c_c (cacosh, 0x1p-23L, -0x1p-23L, 1.192092895507818146886315028596704749235e-7L, -1.570796207585607068450636380271254316214L),
3045 TEST_c_c (cacosh, -0x1p-23L, 0x1p-23L, 1.192092895507818146886315028596704749235e-7L, 1.570796446004186170012007003008248567984L),
3046 TEST_c_c (cacosh, -0x1p-23L, -0x1p-23L, 1.192092895507818146886315028596704749235e-7L, -1.570796446004186170012007003008248567984L),
3047 TEST_c_c (cacosh, 0x1.fp-129L, 0x1p-23L, 1.192092895507809676556842485683592032154e-7L, 1.570796326794896619231321691639751442096L),
3048 TEST_c_c (cacosh, 0x1.fp-129L, -0x1p-23L, 1.192092895507809676556842485683592032154e-7L, -1.570796326794896619231321691639751442096L),
3049 TEST_c_c (cacosh, -0x1.fp-129L, 0x1p-23L, 1.192092895507809676556842485683592032154e-7L, 1.570796326794896619231321691639751442101L),
3050 TEST_c_c (cacosh, -0x1.fp-129L, -0x1p-23L, 1.192092895507809676556842485683592032154e-7L, -1.570796326794896619231321691639751442101L),
3051 TEST_c_c (cacosh, 0x1p-23L, 0x1.fp-129L, 2.846900380897747786805634596726756660388e-39L, 1.570796207585607068449789347324000006847L, UNDERFLOW_EXCEPTION_FLOAT),
3052 TEST_c_c (cacosh, -0x1p-23L, 0x1.fp-129L, 2.846900380897747786805634596726756660388e-39L, 1.570796446004186170012854035955502877351L, UNDERFLOW_EXCEPTION_FLOAT),
3053 TEST_c_c (cacosh, 0x1p-23L, -0x1.fp-129L, 2.846900380897747786805634596726756660388e-39L, -1.570796207585607068449789347324000006847L, UNDERFLOW_EXCEPTION_FLOAT),
3054 TEST_c_c (cacosh, -0x1p-23L, -0x1.fp-129L, 2.846900380897747786805634596726756660388e-39L, -1.570796446004186170012854035955502877351L, UNDERFLOW_EXCEPTION_FLOAT),
3055 TEST_c_c (cacosh, 0.0L, 0x1p-23L, 1.192092895507809676556842485683592032154e-7L, 1.570796326794896619231321691639751442099L),
3056 TEST_c_c (cacosh, 0.0L, -0x1p-23L, 1.192092895507809676556842485683592032154e-7L, -1.570796326794896619231321691639751442099L),
3057 TEST_c_c (cacosh, -0.0L, 0x1p-23L, 1.192092895507809676556842485683592032154e-7L, 1.570796326794896619231321691639751442099L),
3058 TEST_c_c (cacosh, -0.0L, -0x1p-23L, 1.192092895507809676556842485683592032154e-7L, -1.570796326794896619231321691639751442099L),
3059 TEST_c_c (cacosh, 0x1p-23L, 0.0L, 0.0L, 1.570796207585607068449789347324000006847L),
3060 TEST_c_c (cacosh, -0x1p-23L, 0.0L, 0.0L, 1.570796446004186170012854035955502877351L),
3061 TEST_c_c (cacosh, 0x1p-23L, -0.0L, 0.0L, -1.570796207585607068449789347324000006847L),
3062 TEST_c_c (cacosh, -0x1p-23L, -0.0L, 0.0L, -1.570796446004186170012854035955502877351L),
3063 TEST_c_c (cacosh, 0x1.fp-129L, 0x1.fp-129L, 2.846900380897727558361783801085126250967e-39L, 1.570796326794896619231321691639751442096L, UNDERFLOW_EXCEPTION_FLOAT),
3064 TEST_c_c (cacosh, 0x1.fp-129L, -0x1.fp-129L, 2.846900380897727558361783801085126250967e-39L, -1.570796326794896619231321691639751442096L, UNDERFLOW_EXCEPTION_FLOAT),
3065 TEST_c_c (cacosh, -0x1.fp-129L, 0x1.fp-129L, 2.846900380897727558361783801085126250967e-39L, 1.570796326794896619231321691639751442101L, UNDERFLOW_EXCEPTION_FLOAT),
3066 TEST_c_c (cacosh, -0x1.fp-129L, -0x1.fp-129L, 2.846900380897727558361783801085126250967e-39L, -1.570796326794896619231321691639751442101L, UNDERFLOW_EXCEPTION_FLOAT),
3067 #ifndef TEST_FLOAT
3068 TEST_c_c (cacosh, 0x1p-52L, 0x0.fffffffffffff8p0L, 8.813735870195429467279863907910458761820e-1L, 1.570796326794896462222075823262236786996L),
3069 TEST_c_c (cacosh, 0x1p-52L, -0x0.fffffffffffff8p0L, 8.813735870195429467279863907910458761820e-1L, -1.570796326794896462222075823262236786996L),
3070 TEST_c_c (cacosh, -0x1p-52L, 0x0.fffffffffffff8p0L, 8.813735870195429467279863907910458761820e-1L, 1.570796326794896776240567560017266097201L),
3071 TEST_c_c (cacosh, -0x1p-52L, -0x0.fffffffffffff8p0L, 8.813735870195429467279863907910458761820e-1L, -1.570796326794896776240567560017266097201L),
3072 TEST_c_c (cacosh, 0x0.fffffffffffff8p0L, 0x1p-52L, 1.171456840272878582596796205397918831268e-8L, 1.895456983915074112227925127005564372844e-8L),
3073 TEST_c_c (cacosh, -0x0.fffffffffffff8p0L, 0x1p-52L, 1.171456840272878582596796205397918831268e-8L, 3.141592634635223399311902261000251614142L),
3074 TEST_c_c (cacosh, 0x0.fffffffffffff8p0L, -0x1p-52L, 1.171456840272878582596796205397918831268e-8L, -1.895456983915074112227925127005564372844e-8L),
3075 TEST_c_c (cacosh, -0x0.fffffffffffff8p0L, -0x1p-52L, 1.171456840272878582596796205397918831268e-8L, -3.141592634635223399311902261000251614142L),
3076 TEST_c_c (cacosh, 0x1.fp-1025L, 0x0.fffffffffffff8p0L, 8.813735870195429467279863907910371604180e-1L, 1.570796326794896619231321691639751442099L),
3077 TEST_c_c (cacosh, 0x1.fp-1025L, -0x0.fffffffffffff8p0L, 8.813735870195429467279863907910371604180e-1L, -1.570796326794896619231321691639751442099L),
3078 TEST_c_c (cacosh, -0x1.fp-1025L, 0x0.fffffffffffff8p0L, 8.813735870195429467279863907910371604180e-1L, 1.570796326794896619231321691639751442099L),
3079 TEST_c_c (cacosh, -0x1.fp-1025L, -0x0.fffffffffffff8p0L, 8.813735870195429467279863907910371604180e-1L, -1.570796326794896619231321691639751442099L),
3080 TEST_c_c (cacosh, 0x0.fffffffffffff8p0L, 0x1.fp-1025L, 3.616396521699973256461764099945789620604e-301L, 1.490116119384765638786343542550461592240e-8L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
3081 TEST_c_c (cacosh, -0x0.fffffffffffff8p0L, 0x1.fp-1025L, 3.616396521699973256461764099945789620604e-301L, 3.141592638688632044614986995416067458693L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
3082 TEST_c_c (cacosh, 0x0.fffffffffffff8p0L, -0x1.fp-1025L, 3.616396521699973256461764099945789620604e-301L, -1.490116119384765638786343542550461592240e-8L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
3083 TEST_c_c (cacosh, -0x0.fffffffffffff8p0L, -0x1.fp-1025L, 3.616396521699973256461764099945789620604e-301L, -3.141592638688632044614986995416067458693L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
3084 TEST_c_c (cacosh, 0.0L, 0x0.fffffffffffff8p0L, 8.813735870195429467279863907910371604180e-1L, 1.570796326794896619231321691639751442099L),
3085 TEST_c_c (cacosh, 0.0L, -0x0.fffffffffffff8p0L, 8.813735870195429467279863907910371604180e-1L, -1.570796326794896619231321691639751442099L),
3086 TEST_c_c (cacosh, -0.0L, 0x0.fffffffffffff8p0L, 8.813735870195429467279863907910371604180e-1L, 1.570796326794896619231321691639751442099L),
3087 TEST_c_c (cacosh, -0.0L, -0x0.fffffffffffff8p0L, 8.813735870195429467279863907910371604180e-1L, -1.570796326794896619231321691639751442099L),
3088 TEST_c_c (cacosh, 0x0.fffffffffffff8p0L, 0.0L, 0.0L, 1.490116119384765638786343542550461592240e-8L),
3089 TEST_c_c (cacosh, -0x0.fffffffffffff8p0L, 0.0L, 0.0L, 3.141592638688632044614986995416067458693L),
3090 TEST_c_c (cacosh, 0x0.fffffffffffff8p0L, -0.0L, 0.0L, -1.490116119384765638786343542550461592240e-8L),
3091 TEST_c_c (cacosh, -0x0.fffffffffffff8p0L, -0.0L, 0.0L, -3.141592638688632044614986995416067458693L),
3092 #endif
3093 TEST_c_c (cacosh, 0x1p-52L, 0.5L, 4.812118250596034474977589134243772428682e-1L, 1.570796326794896420628589431857911675917L),
3094 TEST_c_c (cacosh, 0x1p-52L, -0.5L, 4.812118250596034474977589134243772428682e-1L, -1.570796326794896420628589431857911675917L),
3095 TEST_c_c (cacosh, -0x1p-52L, 0.5L, 4.812118250596034474977589134243772428682e-1L, 1.570796326794896817834053951421591208280L),
3096 TEST_c_c (cacosh, -0x1p-52L, -0.5L, 4.812118250596034474977589134243772428682e-1L, -1.570796326794896817834053951421591208280L),
3097 TEST_c_c (cacosh, 0.5L, 0x1p-52L, 2.563950248511418570403591756798643804971e-16L, 1.047197551196597746154214461093186605110L),
3098 TEST_c_c (cacosh, -0.5L, 0x1p-52L, 2.563950248511418570403591756798643804971e-16L, 2.094395102393195492308428922186316279087L),
3099 TEST_c_c (cacosh, 0.5L, -0x1p-52L, 2.563950248511418570403591756798643804971e-16L, -1.047197551196597746154214461093186605110L),
3100 TEST_c_c (cacosh, -0.5L, -0x1p-52L, 2.563950248511418570403591756798643804971e-16L, -2.094395102393195492308428922186316279087L),
3101 #ifndef TEST_FLOAT
3102 TEST_c_c (cacosh, 0x1.fp-1025L, 0.5L, 4.812118250596034474977589134243684231352e-1L, 1.570796326794896619231321691639751442099L),
3103 TEST_c_c (cacosh, 0x1.fp-1025L, -0.5L, 4.812118250596034474977589134243684231352e-1L, -1.570796326794896619231321691639751442099L),
3104 TEST_c_c (cacosh, -0x1.fp-1025L, 0.5L, 4.812118250596034474977589134243684231352e-1L, 1.570796326794896619231321691639751442099L),
3105 TEST_c_c (cacosh, -0x1.fp-1025L, -0.5L, 4.812118250596034474977589134243684231352e-1L, -1.570796326794896619231321691639751442099L),
3106 TEST_c_c (cacosh, 0.5L, 0x1.fp-1025L, 6.222508863508420569166420770843207333493e-309L, 1.047197551196597746154214461093167628066L, UNDERFLOW_EXCEPTION_DOUBLE),
3107 TEST_c_c (cacosh, -0.5L, 0x1.fp-1025L, 6.222508863508420569166420770843207333493e-309L, 2.094395102393195492308428922186335256131L, UNDERFLOW_EXCEPTION_DOUBLE),
3108 TEST_c_c (cacosh, 0.5L, -0x1.fp-1025L, 6.222508863508420569166420770843207333493e-309L, -1.047197551196597746154214461093167628066L, UNDERFLOW_EXCEPTION_DOUBLE),
3109 TEST_c_c (cacosh, -0.5L, -0x1.fp-1025L, 6.222508863508420569166420770843207333493e-309L, -2.094395102393195492308428922186335256131L, UNDERFLOW_EXCEPTION_DOUBLE),
3110 #endif
3111 TEST_c_c (cacosh, 0x1p-52L, 0x1p-52L, 2.220446049250313080847263336181677117148e-16L, 1.570796326794896397186716766608443357372L),
3112 TEST_c_c (cacosh, 0x1p-52L, -0x1p-52L, 2.220446049250313080847263336181677117148e-16L, -1.570796326794896397186716766608443357372L),
3113 TEST_c_c (cacosh, -0x1p-52L, 0x1p-52L, 2.220446049250313080847263336181677117148e-16L, 1.570796326794896841275926616671059526825L),
3114 TEST_c_c (cacosh, -0x1p-52L, -0x1p-52L, 2.220446049250313080847263336181677117148e-16L, -1.570796326794896841275926616671059526825L),
3115 #ifndef TEST_FLOAT
3116 TEST_c_c (cacosh, 0x1.fp-1025L, 0x1p-52L, 2.220446049250313080847263336181622378926e-16L, 1.570796326794896619231321691639751442099L),
3117 TEST_c_c (cacosh, 0x1.fp-1025L, -0x1p-52L, 2.220446049250313080847263336181622378926e-16L, -1.570796326794896619231321691639751442099L),
3118 TEST_c_c (cacosh, -0x1.fp-1025L, 0x1p-52L, 2.220446049250313080847263336181622378926e-16L, 1.570796326794896619231321691639751442099L),
3119 TEST_c_c (cacosh, -0x1.fp-1025L, -0x1p-52L, 2.220446049250313080847263336181622378926e-16L, -1.570796326794896619231321691639751442099L),
3120 TEST_c_c (cacosh, 0x1p-52L, 0x1.fp-1025L, 5.388850751072128349671657362289548938458e-309L, 1.570796326794896397186716766608443357372L, UNDERFLOW_EXCEPTION_DOUBLE),
3121 TEST_c_c (cacosh, -0x1p-52L, 0x1.fp-1025L, 5.388850751072128349671657362289548938458e-309L, 1.570796326794896841275926616671059526825L, UNDERFLOW_EXCEPTION_DOUBLE),
3122 TEST_c_c (cacosh, 0x1p-52L, -0x1.fp-1025L, 5.388850751072128349671657362289548938458e-309L, -1.570796326794896397186716766608443357372L, UNDERFLOW_EXCEPTION_DOUBLE),
3123 TEST_c_c (cacosh, -0x1p-52L, -0x1.fp-1025L, 5.388850751072128349671657362289548938458e-309L, -1.570796326794896841275926616671059526825L, UNDERFLOW_EXCEPTION_DOUBLE),
3124 #endif
3125 TEST_c_c (cacosh, 0.0L, 0x1p-52L, 2.220446049250313080847263336181622378926e-16L, 1.570796326794896619231321691639751442099L),
3126 TEST_c_c (cacosh, 0.0L, -0x1p-52L, 2.220446049250313080847263336181622378926e-16L, -1.570796326794896619231321691639751442099L),
3127 TEST_c_c (cacosh, -0.0L, 0x1p-52L, 2.220446049250313080847263336181622378926e-16L, 1.570796326794896619231321691639751442099L),
3128 TEST_c_c (cacosh, -0.0L, -0x1p-52L, 2.220446049250313080847263336181622378926e-16L, -1.570796326794896619231321691639751442099L),
3129 TEST_c_c (cacosh, 0x1p-52L, 0.0L, 0.0L, 1.570796326794896397186716766608443357372L),
3130 TEST_c_c (cacosh, -0x1p-52L, 0.0L, 0.0L, 1.570796326794896841275926616671059526825L),
3131 TEST_c_c (cacosh, 0x1p-52L, -0.0L, 0.0L, -1.570796326794896397186716766608443357372L),
3132 TEST_c_c (cacosh, -0x1p-52L, -0.0L, 0.0L, -1.570796326794896841275926616671059526825L),
3133 #ifndef TEST_FLOAT
3134 TEST_c_c (cacosh, 0x1.fp-1025L, 0x1.fp-1025L, 5.388850751072128349671657362289416093031e-309L, 1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION_DOUBLE),
3135 TEST_c_c (cacosh, 0x1.fp-1025L, -0x1.fp-1025L, 5.388850751072128349671657362289416093031e-309L, -1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION_DOUBLE),
3136 TEST_c_c (cacosh, -0x1.fp-1025L, 0x1.fp-1025L, 5.388850751072128349671657362289416093031e-309L, 1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION_DOUBLE),
3137 TEST_c_c (cacosh, -0x1.fp-1025L, -0x1.fp-1025L, 5.388850751072128349671657362289416093031e-309L, -1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION_DOUBLE),
3138 #endif
3139 #if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 64
3140 TEST_c_c (cacosh, 0x1p-63L, 0x0.ffffffffffffffffp0L, 8.813735870195430251942769895627079569937e-1L, 1.570796326794896619154657020805582738025L),
3141 TEST_c_c (cacosh, 0x1p-63L, -0x0.ffffffffffffffffp0L, 8.813735870195430251942769895627079569937e-1L, -1.570796326794896619154657020805582738025L),
3142 TEST_c_c (cacosh, -0x1p-63L, 0x0.ffffffffffffffffp0L, 8.813735870195430251942769895627079569937e-1L, 1.570796326794896619307986362473920146173L),
3143 TEST_c_c (cacosh, -0x1p-63L, -0x0.ffffffffffffffffp0L, 8.813735870195430251942769895627079569937e-1L, -1.570796326794896619307986362473920146173L),
3144 TEST_c_c (cacosh, 0x0.ffffffffffffffffp0L, 0x1p-63L, 2.588578361325995866221775673638805081337e-10L, 4.188407771167967636741951941902992986043e-10L),
3145 TEST_c_c (cacosh, -0x0.ffffffffffffffffp0L, 0x1p-63L, 2.588578361325995866221775673638805081337e-10L, 3.141592653170952461345846619605307690007L),
3146 TEST_c_c (cacosh, 0x0.ffffffffffffffffp0L, -0x1p-63L, 2.588578361325995866221775673638805081337e-10L, -4.188407771167967636741951941902992986043e-10L),
3147 TEST_c_c (cacosh, -0x0.ffffffffffffffffp0L, -0x1p-63L, 2.588578361325995866221775673638805081337e-10L, -3.141592653170952461345846619605307690007L),
3148 # if LDBL_MIN_EXP <= -16381
3149 TEST_c_c (cacosh, 0x1.fp-16385L, 0x0.ffffffffffffffffp0L, 8.813735870195430251942769895627079569917e-1L, 1.570796326794896619231321691639751442099L),
3150 TEST_c_c (cacosh, 0x1.fp-16385L, -0x0.ffffffffffffffffp0L, 8.813735870195430251942769895627079569917e-1L, -1.570796326794896619231321691639751442099L),
3151 TEST_c_c (cacosh, -0x1.fp-16385L, 0x0.ffffffffffffffffp0L, 8.813735870195430251942769895627079569917e-1L, 1.570796326794896619231321691639751442099L),
3152 TEST_c_c (cacosh, -0x1.fp-16385L, -0x0.ffffffffffffffffp0L, 8.813735870195430251942769895627079569917e-1L, -1.570796326794896619231321691639751442099L),
3153 TEST_c_c (cacosh, 0x0.ffffffffffffffffp0L, 0x1.fp-16385L, 2.472906068161537187835415298076415423459e-4923L, 3.292722539913596233371825532007990724506e-10L),
3154 TEST_c_c (cacosh, -0x0.ffffffffffffffffp0L, 0x1.fp-16385L, 2.472906068161537187835415298076415423459e-4923L, 3.141592653260520984471283759942320330996L),
3155 TEST_c_c (cacosh, 0x0.ffffffffffffffffp0L, -0x1.fp-16385L, 2.472906068161537187835415298076415423459e-4923L, -3.292722539913596233371825532007990724506e-10L),
3156 TEST_c_c (cacosh, -0x0.ffffffffffffffffp0L, -0x1.fp-16385L, 2.472906068161537187835415298076415423459e-4923L, -3.141592653260520984471283759942320330996L),
3157 # endif
3158 TEST_c_c (cacosh, 0.0L, 0x0.ffffffffffffffffp0L, 8.813735870195430251942769895627079569917e-1L, 1.570796326794896619231321691639751442099L),
3159 TEST_c_c (cacosh, 0.0L, -0x0.ffffffffffffffffp0L, 8.813735870195430251942769895627079569917e-1L, -1.570796326794896619231321691639751442099L),
3160 TEST_c_c (cacosh, -0.0L, 0x0.ffffffffffffffffp0L, 8.813735870195430251942769895627079569917e-1L, 1.570796326794896619231321691639751442099L),
3161 TEST_c_c (cacosh, -0.0L, -0x0.ffffffffffffffffp0L, 8.813735870195430251942769895627079569917e-1L, -1.570796326794896619231321691639751442099L),
3162 TEST_c_c (cacosh, 0x0.ffffffffffffffffp0L, 0.0L, 0.0L, 3.292722539913596233371825532007990724506e-10L),
3163 TEST_c_c (cacosh, -0x0.ffffffffffffffffp0L, 0.0L, 0.0L, 3.141592653260520984471283759942320330996L),
3164 TEST_c_c (cacosh, 0x0.ffffffffffffffffp0L, -0.0L, 0.0L, -3.292722539913596233371825532007990724506e-10L),
3165 TEST_c_c (cacosh, -0x0.ffffffffffffffffp0L, -0.0L, 0.0L, -3.141592653260520984471283759942320330996L),
3166 #endif
3167 TEST_c_c (cacosh, 0x1p-63L, 0.5L, 4.812118250596034474977589134243684231373e-1L, 1.570796326794896619134347701278529840650L),
3168 TEST_c_c (cacosh, 0x1p-63L, -0.5L, 4.812118250596034474977589134243684231373e-1L, -1.570796326794896619134347701278529840650L),
3169 TEST_c_c (cacosh, -0x1p-63L, 0.5L, 4.812118250596034474977589134243684231373e-1L, 1.570796326794896619328295682000973043547L),
3170 TEST_c_c (cacosh, -0x1p-63L, -0.5L, 4.812118250596034474977589134243684231373e-1L, -1.570796326794896619328295682000973043547L),
3171 TEST_c_c (cacosh, 0.5L, 0x1p-63L, 1.251928832280966098829878787499365228659e-19L, 1.047197551196597746154214461093167628070L),
3172 TEST_c_c (cacosh, -0.5L, 0x1p-63L, 1.251928832280966098829878787499365228659e-19L, 2.094395102393195492308428922186335256127L),
3173 TEST_c_c (cacosh, 0.5L, -0x1p-63L, 1.251928832280966098829878787499365228659e-19L, -1.047197551196597746154214461093167628070L),
3174 TEST_c_c (cacosh, -0.5L, -0x1p-63L, 1.251928832280966098829878787499365228659e-19L, -2.094395102393195492308428922186335256127L),
3175 #if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
3176 TEST_c_c (cacosh, 0x1.fp-16385L, 0.5L, 4.812118250596034474977589134243684231352e-1L, 1.570796326794896619231321691639751442099L),
3177 TEST_c_c (cacosh, 0x1.fp-16385L, -0.5L, 4.812118250596034474977589134243684231352e-1L, -1.570796326794896619231321691639751442099L),
3178 TEST_c_c (cacosh, -0x1.fp-16385L, 0.5L, 4.812118250596034474977589134243684231352e-1L, 1.570796326794896619231321691639751442099L),
3179 TEST_c_c (cacosh, -0x1.fp-16385L, -0.5L, 4.812118250596034474977589134243684231352e-1L, -1.570796326794896619231321691639751442099L),
3180 TEST_c_c (cacosh, 0.5L, 0x1.fp-16385L, 9.402257155670418112159334875199821342890e-4933L, 1.047197551196597746154214461093167628066L, UNDERFLOW_EXCEPTION),
3181 TEST_c_c (cacosh, -0.5L, 0x1.fp-16385L, 9.402257155670418112159334875199821342890e-4933L, 2.094395102393195492308428922186335256131L, UNDERFLOW_EXCEPTION),
3182 TEST_c_c (cacosh, 0.5L, -0x1.fp-16385L, 9.402257155670418112159334875199821342890e-4933L, -1.047197551196597746154214461093167628066L, UNDERFLOW_EXCEPTION),
3183 TEST_c_c (cacosh, -0.5L, -0x1.fp-16385L, 9.402257155670418112159334875199821342890e-4933L, -2.094395102393195492308428922186335256131L, UNDERFLOW_EXCEPTION),
3184 #endif
3185 TEST_c_c (cacosh, 0x1p-63L, 0x1p-63L, 1.084202172485504434007452800869941711430e-19L, 1.570796326794896619122901474391200998698L),
3186 TEST_c_c (cacosh, 0x1p-63L, -0x1p-63L, 1.084202172485504434007452800869941711430e-19L, -1.570796326794896619122901474391200998698L),
3187 TEST_c_c (cacosh, -0x1p-63L, 0x1p-63L, 1.084202172485504434007452800869941711430e-19L, 1.570796326794896619339741908888301885499L),
3188 TEST_c_c (cacosh, -0x1p-63L, -0x1p-63L, 1.084202172485504434007452800869941711430e-19L, -1.570796326794896619339741908888301885499L),
3189 #if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
3190 TEST_c_c (cacosh, 0x1.fp-16385L, 0x1p-63L, 1.084202172485504434007452800869941711424e-19L, 1.570796326794896619231321691639751442099L),
3191 TEST_c_c (cacosh, 0x1.fp-16385L, -0x1p-63L, 1.084202172485504434007452800869941711424e-19L, -1.570796326794896619231321691639751442099L),
3192 TEST_c_c (cacosh, -0x1.fp-16385L, 0x1p-63L, 1.084202172485504434007452800869941711424e-19L, 1.570796326794896619231321691639751442099L),
3193 TEST_c_c (cacosh, -0x1.fp-16385L, -0x1p-63L, 1.084202172485504434007452800869941711424e-19L, -1.570796326794896619231321691639751442099L),
3194 TEST_c_c (cacosh, 0x1p-63L, 0x1.fp-16385L, 8.142593549724601460479922838826119584465e-4933L, 1.570796326794896619122901474391200998698L, UNDERFLOW_EXCEPTION),
3195 TEST_c_c (cacosh, -0x1p-63L, 0x1.fp-16385L, 8.142593549724601460479922838826119584465e-4933L, 1.570796326794896619339741908888301885499L, UNDERFLOW_EXCEPTION),
3196 TEST_c_c (cacosh, 0x1p-63L, -0x1.fp-16385L, 8.142593549724601460479922838826119584465e-4933L, -1.570796326794896619122901474391200998698L, UNDERFLOW_EXCEPTION),
3197 TEST_c_c (cacosh, -0x1p-63L, -0x1.fp-16385L, 8.142593549724601460479922838826119584465e-4933L, -1.570796326794896619339741908888301885499L, UNDERFLOW_EXCEPTION),
3198 #endif
3199 TEST_c_c (cacosh, 0.0L, 0x1p-63L, 1.084202172485504434007452800869941711424e-19L, 1.570796326794896619231321691639751442099L),
3200 TEST_c_c (cacosh, 0.0L, -0x1p-63L, 1.084202172485504434007452800869941711424e-19L, -1.570796326794896619231321691639751442099L),
3201 TEST_c_c (cacosh, -0.0L, 0x1p-63L, 1.084202172485504434007452800869941711424e-19L, 1.570796326794896619231321691639751442099L),
3202 TEST_c_c (cacosh, -0.0L, -0x1p-63L, 1.084202172485504434007452800869941711424e-19L, -1.570796326794896619231321691639751442099L),
3203 TEST_c_c (cacosh, 0x1p-63L, 0.0L, 0.0L, 1.570796326794896619122901474391200998698L),
3204 TEST_c_c (cacosh, -0x1p-63L, 0.0L, 0.0L, 1.570796326794896619339741908888301885499L),
3205 TEST_c_c (cacosh, 0x1p-63L, -0.0L, 0.0L, -1.570796326794896619122901474391200998698L),
3206 TEST_c_c (cacosh, -0x1p-63L, -0.0L, 0.0L, -1.570796326794896619339741908888301885499L),
3207 #if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
3208 TEST_c_c (cacosh, 0x1.fp-16385L, 0x1.fp-16385L, 8.142593549724601460479922838826119584417e-4933L, 1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION),
3209 TEST_c_c (cacosh, 0x1.fp-16385L, -0x1.fp-16385L, 8.142593549724601460479922838826119584417e-4933L, -1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION),
3210 TEST_c_c (cacosh, -0x1.fp-16385L, 0x1.fp-16385L, 8.142593549724601460479922838826119584417e-4933L, 1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION),
3211 TEST_c_c (cacosh, -0x1.fp-16385L, -0x1.fp-16385L, 8.142593549724601460479922838826119584417e-4933L, -1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION),
3212 #endif
3213 #if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 106
3214 TEST_c_c (cacosh, 0x1p-105L, 0x0.ffffffffffffffffffffffffffcp0L, 8.813735870195430252326093249797835932642e-1L, 1.570796326794896619231321691639734010571L),
3215 TEST_c_c (cacosh, 0x1p-105L, -0x0.ffffffffffffffffffffffffffcp0L, 8.813735870195430252326093249797835932642e-1L, -1.570796326794896619231321691639734010571L),
3216 TEST_c_c (cacosh, -0x1p-105L, 0x0.ffffffffffffffffffffffffffcp0L, 8.813735870195430252326093249797835932642e-1L, 1.570796326794896619231321691639768873627L),
3217 TEST_c_c (cacosh, -0x1p-105L, -0x0.ffffffffffffffffffffffffffcp0L, 8.813735870195430252326093249797835932642e-1L, -1.570796326794896619231321691639768873627L),
3218 TEST_c_c (cacosh, 0x0.ffffffffffffffffffffffffffcp0L, 0x1p-105L, 1.234330349600789959989661887846005659983e-16L, 1.997188458999618357060632049675702684031e-16L),
3219 TEST_c_c (cacosh, -0x0.ffffffffffffffffffffffffffcp0L, 0x1p-105L, 1.234330349600789959989661887846005659983e-16L, 3.141592653589793038743797483317667178134L),
3220 TEST_c_c (cacosh, 0x0.ffffffffffffffffffffffffffcp0L, -0x1p-105L, 1.234330349600789959989661887846005659983e-16L, -1.997188458999618357060632049675702684031e-16L),
3221 TEST_c_c (cacosh, -0x0.ffffffffffffffffffffffffffcp0L, -0x1p-105L, 1.234330349600789959989661887846005659983e-16L, -3.141592653589793038743797483317667178134L),
3222 TEST_c_c (cacosh, 0x1.fp-1025L, 0x0.ffffffffffffffffffffffffffcp0L, 8.813735870195430252326093249797835932642e-1L, 1.570796326794896619231321691639751442099L),
3223 TEST_c_c (cacosh, 0x1.fp-1025L, -0x0.ffffffffffffffffffffffffffcp0L, 8.813735870195430252326093249797835932642e-1L, -1.570796326794896619231321691639751442099L),
3224 TEST_c_c (cacosh, -0x1.fp-1025L, 0x0.ffffffffffffffffffffffffffcp0L, 8.813735870195430252326093249797835932642e-1L, 1.570796326794896619231321691639751442099L),
3225 TEST_c_c (cacosh, -0x1.fp-1025L, -0x0.ffffffffffffffffffffffffffcp0L, 8.813735870195430252326093249797835932642e-1L, -1.570796326794896619231321691639751442099L),
3226 TEST_c_c (cacosh, 0x0.ffffffffffffffffffffffffffcp0L, 0x1.fp-1025L, 3.432186888910770473784103112009399360940e-293L, 1.570092458683775059393382371963565104164e-16L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
3227 TEST_c_c (cacosh, -0x0.ffffffffffffffffffffffffffcp0L, 0x1.fp-1025L, 3.432186888910770473784103112009399360940e-293L, 3.141592653589793081453397514901996944859L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
3228 TEST_c_c (cacosh, 0x0.ffffffffffffffffffffffffffcp0L, -0x1.fp-1025L, 3.432186888910770473784103112009399360940e-293L, -1.570092458683775059393382371963565104164e-16L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
3229 TEST_c_c (cacosh, -0x0.ffffffffffffffffffffffffffcp0L, -0x1.fp-1025L, 3.432186888910770473784103112009399360940e-293L, -3.141592653589793081453397514901996944859L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
3230 TEST_c_c (cacosh, 0.0L, 0x0.ffffffffffffffffffffffffffcp0L, 8.813735870195430252326093249797835932642e-1L, 1.570796326794896619231321691639751442099L),
3231 TEST_c_c (cacosh, 0.0L, -0x0.ffffffffffffffffffffffffffcp0L, 8.813735870195430252326093249797835932642e-1L, -1.570796326794896619231321691639751442099L),
3232 TEST_c_c (cacosh, -0.0L, 0x0.ffffffffffffffffffffffffffcp0L, 8.813735870195430252326093249797835932642e-1L, 1.570796326794896619231321691639751442099L),
3233 TEST_c_c (cacosh, -0.0L, -0x0.ffffffffffffffffffffffffffcp0L, 8.813735870195430252326093249797835932642e-1L, -1.570796326794896619231321691639751442099L),
3234 TEST_c_c (cacosh, 0x0.ffffffffffffffffffffffffffcp0L, 0.0L, 0.0L, 1.570092458683775059393382371963565104164e-16L),
3235 TEST_c_c (cacosh, -0x0.ffffffffffffffffffffffffffcp0L, 0.0L, 0.0L, 3.141592653589793081453397514901996944859L),
3236 TEST_c_c (cacosh, 0x0.ffffffffffffffffffffffffffcp0L, -0.0L, 0.0L, -1.570092458683775059393382371963565104164e-16L),
3237 TEST_c_c (cacosh, -0x0.ffffffffffffffffffffffffffcp0L, -0.0L, 0.0L, -3.141592653589793081453397514901996944859L),
3238 #endif
3239 TEST_c_c (cacosh, 0x1p-105L, 0.5L, 4.812118250596034474977589134243684231352e-1L, 1.570796326794896619231321691639729392766L),
3240 TEST_c_c (cacosh, 0x1p-105L, -0.5L, 4.812118250596034474977589134243684231352e-1L, -1.570796326794896619231321691639729392766L),
3241 TEST_c_c (cacosh, -0x1p-105L, 0.5L, 4.812118250596034474977589134243684231352e-1L, 1.570796326794896619231321691639773491431L),
3242 TEST_c_c (cacosh, -0x1p-105L, -0.5L, 4.812118250596034474977589134243684231352e-1L, -1.570796326794896619231321691639773491431L),
3243 TEST_c_c (cacosh, 0.5L, 0x1p-105L, 2.846556599890768890940941645338546615370e-32L, 1.047197551196597746154214461093167628066L),
3244 TEST_c_c (cacosh, -0.5L, 0x1p-105L, 2.846556599890768890940941645338546615370e-32L, 2.094395102393195492308428922186335256131L),
3245 TEST_c_c (cacosh, 0.5L, -0x1p-105L, 2.846556599890768890940941645338546615370e-32L, -1.047197551196597746154214461093167628066L),
3246 TEST_c_c (cacosh, -0.5L, -0x1p-105L, 2.846556599890768890940941645338546615370e-32L, -2.094395102393195492308428922186335256131L),
3247 TEST_c_c (cacosh, 0x1p-105L, 0x1p-105L, 2.465190328815661891911651766508706967729e-32L, 1.570796326794896619231321691639726790195L),
3248 TEST_c_c (cacosh, 0x1p-105L, -0x1p-105L, 2.465190328815661891911651766508706967729e-32L, -1.570796326794896619231321691639726790195L),
3249 TEST_c_c (cacosh, -0x1p-105L, 0x1p-105L, 2.465190328815661891911651766508706967729e-32L, 1.570796326794896619231321691639776094002L),
3250 TEST_c_c (cacosh, -0x1p-105L, -0x1p-105L, 2.465190328815661891911651766508706967729e-32L, -1.570796326794896619231321691639776094002L),
3251 #ifndef TEST_FLOAT
3252 TEST_c_c (cacosh, 0x1.fp-1025L, 0x1p-105L, 2.465190328815661891911651766508706967729e-32L, 1.570796326794896619231321691639751442099L),
3253 TEST_c_c (cacosh, 0x1.fp-1025L, -0x1p-105L, 2.465190328815661891911651766508706967729e-32L, -1.570796326794896619231321691639751442099L),
3254 TEST_c_c (cacosh, -0x1.fp-1025L, 0x1p-105L, 2.465190328815661891911651766508706967729e-32L, 1.570796326794896619231321691639751442099L),
3255 TEST_c_c (cacosh, -0x1.fp-1025L, -0x1p-105L, 2.465190328815661891911651766508706967729e-32L, -1.570796326794896619231321691639751442099L),
3256 TEST_c_c (cacosh, 0x1p-105L, 0x1.fp-1025L, 5.388850751072128349671657362289416093031e-309L, 1.570796326794896619231321691639726790195L, UNDERFLOW_EXCEPTION_DOUBLE),
3257 TEST_c_c (cacosh, -0x1p-105L, 0x1.fp-1025L, 5.388850751072128349671657362289416093031e-309L, 1.570796326794896619231321691639776094002L, UNDERFLOW_EXCEPTION_DOUBLE),
3258 TEST_c_c (cacosh, 0x1p-105L, -0x1.fp-1025L, 5.388850751072128349671657362289416093031e-309L, -1.570796326794896619231321691639726790195L, UNDERFLOW_EXCEPTION_DOUBLE),
3259 TEST_c_c (cacosh, -0x1p-105L, -0x1.fp-1025L, 5.388850751072128349671657362289416093031e-309L, -1.570796326794896619231321691639776094002L, UNDERFLOW_EXCEPTION_DOUBLE),
3260 #endif
3261 TEST_c_c (cacosh, 0.0L, 0x1p-105L, 2.465190328815661891911651766508706967729e-32L, 1.570796326794896619231321691639751442099L),
3262 TEST_c_c (cacosh, 0.0L, -0x1p-105L, 2.465190328815661891911651766508706967729e-32L, -1.570796326794896619231321691639751442099L),
3263 TEST_c_c (cacosh, -0.0L, 0x1p-105L, 2.465190328815661891911651766508706967729e-32L, 1.570796326794896619231321691639751442099L),
3264 TEST_c_c (cacosh, -0.0L, -0x1p-105L, 2.465190328815661891911651766508706967729e-32L, -1.570796326794896619231321691639751442099L),
3265 TEST_c_c (cacosh, 0x1p-105L, 0.0L, 0.0L, 1.570796326794896619231321691639726790195L),
3266 TEST_c_c (cacosh, -0x1p-105L, 0.0L, 0.0L, 1.570796326794896619231321691639776094002L),
3267 TEST_c_c (cacosh, 0x1p-105L, -0.0L, 0.0L, -1.570796326794896619231321691639726790195L),
3268 TEST_c_c (cacosh, -0x1p-105L, -0.0L, 0.0L, -1.570796326794896619231321691639776094002L),
3269 #if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 113
3270 TEST_c_c (cacosh, 0x1p-112L, 0x0.ffffffffffffffffffffffffffff8p0L, 8.813735870195430252326093249797922409363e-1L, 1.570796326794896619231321691639751305915L),
3271 TEST_c_c (cacosh, 0x1p-112L, -0x0.ffffffffffffffffffffffffffff8p0L, 8.813735870195430252326093249797922409363e-1L, -1.570796326794896619231321691639751305915L),
3272 TEST_c_c (cacosh, -0x1p-112L, 0x0.ffffffffffffffffffffffffffff8p0L, 8.813735870195430252326093249797922409363e-1L, 1.570796326794896619231321691639751578282L),
3273 TEST_c_c (cacosh, -0x1p-112L, -0x0.ffffffffffffffffffffffffffff8p0L, 8.813735870195430252326093249797922409363e-1L, -1.570796326794896619231321691639751578282L),
3274 TEST_c_c (cacosh, 0x0.ffffffffffffffffffffffffffff8p0L, 0x1p-112L, 1.091004200533850618345330909857103457781e-17L, 1.765281878332676474347460257221369818872e-17L),
3275 TEST_c_c (cacosh, -0x0.ffffffffffffffffffffffffffff8p0L, 0x1p-112L, 1.091004200533850618345330909857103457781e-17L, 3.141592653589793220809824599952738140723L),
3276 TEST_c_c (cacosh, 0x0.ffffffffffffffffffffffffffff8p0L, -0x1p-112L, 1.091004200533850618345330909857103457781e-17L, -1.765281878332676474347460257221369818872e-17L),
3277 TEST_c_c (cacosh, -0x0.ffffffffffffffffffffffffffff8p0L, -0x1p-112L, 1.091004200533850618345330909857103457781e-17L, -3.141592653589793220809824599952738140723L),
3278 TEST_c_c (cacosh, 0x1.fp-16385L, 0x0.ffffffffffffffffffffffffffff8p0L, 8.813735870195430252326093249797922409363e-1L, 1.570796326794896619231321691639751442099L),
3279 TEST_c_c (cacosh, 0x1.fp-16385L, -0x0.ffffffffffffffffffffffffffff8p0L, 8.813735870195430252326093249797922409363e-1L, -1.570796326794896619231321691639751442099L),
3280 TEST_c_c (cacosh, -0x1.fp-16385L, 0x0.ffffffffffffffffffffffffffff8p0L, 8.813735870195430252326093249797922409363e-1L, 1.570796326794896619231321691639751442099L),
3281 TEST_c_c (cacosh, -0x1.fp-16385L, -0x0.ffffffffffffffffffffffffffff8p0L, 8.813735870195430252326093249797922409363e-1L, -1.570796326794896619231321691639751442099L),
3282 TEST_c_c (cacosh, 0x0.ffffffffffffffffffffffffffff8p0L, 0x1.fp-16385L, 5.867357004219059108790368268900490184505e-4916L, 1.387778780781445675529539585113525401762e-17L),
3283 TEST_c_c (cacosh, -0x0.ffffffffffffffffffffffffffff8p0L, 0x1.fp-16385L, 5.867357004219059108790368268900490184505e-4916L, 3.141592653589793224584855575465046128902L),
3284 TEST_c_c (cacosh, 0x0.ffffffffffffffffffffffffffff8p0L, -0x1.fp-16385L, 5.867357004219059108790368268900490184505e-4916L, -1.387778780781445675529539585113525401762e-17L),
3285 TEST_c_c (cacosh, -0x0.ffffffffffffffffffffffffffff8p0L, -0x1.fp-16385L, 5.867357004219059108790368268900490184505e-4916L, -3.141592653589793224584855575465046128902L),
3286 TEST_c_c (cacosh, 0.0L, 0x0.ffffffffffffffffffffffffffff8p0L, 8.813735870195430252326093249797922409363e-1L, 1.570796326794896619231321691639751442099L),
3287 TEST_c_c (cacosh, 0.0L, -0x0.ffffffffffffffffffffffffffff8p0L, 8.813735870195430252326093249797922409363e-1L, -1.570796326794896619231321691639751442099L),
3288 TEST_c_c (cacosh, -0.0L, 0x0.ffffffffffffffffffffffffffff8p0L, 8.813735870195430252326093249797922409363e-1L, 1.570796326794896619231321691639751442099L),
3289 TEST_c_c (cacosh, -0.0L, -0x0.ffffffffffffffffffffffffffff8p0L, 8.813735870195430252326093249797922409363e-1L, -1.570796326794896619231321691639751442099L),
3290 TEST_c_c (cacosh, 0x0.ffffffffffffffffffffffffffff8p0L, 0.0L, 0.0L, 1.387778780781445675529539585113525401762e-17L),
3291 TEST_c_c (cacosh, -0x0.ffffffffffffffffffffffffffff8p0L, 0.0L, 0.0L, 3.141592653589793224584855575465046128902L),
3292 TEST_c_c (cacosh, 0x0.ffffffffffffffffffffffffffff8p0L, -0.0L, 0.0L, -1.387778780781445675529539585113525401762e-17L),
3293 TEST_c_c (cacosh, -0x0.ffffffffffffffffffffffffffff8p0L, -0.0L, 0.0L, -3.141592653589793224584855575465046128902L),
3294 #endif
3295 TEST_c_c (cacosh, 0x1p-112L, 0.5L, 4.812118250596034474977589134243684231352e-1L, 1.570796326794896619231321691639751269838L),
3296 TEST_c_c (cacosh, 0x1p-112L, -0.5L, 4.812118250596034474977589134243684231352e-1L, -1.570796326794896619231321691639751269838L),
3297 TEST_c_c (cacosh, -0x1p-112L, 0.5L, 4.812118250596034474977589134243684231352e-1L, 1.570796326794896619231321691639751614359L),
3298 TEST_c_c (cacosh, -0x1p-112L, -0.5L, 4.812118250596034474977589134243684231352e-1L, -1.570796326794896619231321691639751614359L),
3299 TEST_c_c (cacosh, 0.5L, 0x1p-112L, 2.223872343664663196047610660420739543258e-34L, 1.047197551196597746154214461093167628066L),
3300 TEST_c_c (cacosh, -0.5L, 0x1p-112L, 2.223872343664663196047610660420739543258e-34L, 2.094395102393195492308428922186335256131L),
3301 TEST_c_c (cacosh, 0.5L, -0x1p-112L, 2.223872343664663196047610660420739543258e-34L, -1.047197551196597746154214461093167628066L),
3302 TEST_c_c (cacosh, -0.5L, -0x1p-112L, 2.223872343664663196047610660420739543258e-34L, -2.094395102393195492308428922186335256131L),
3303 TEST_c_c (cacosh, 0x1p-112L, 0x1p-112L, 1.925929944387235853055977942584927318538e-34L, 1.570796326794896619231321691639751249506L),
3304 TEST_c_c (cacosh, 0x1p-112L, -0x1p-112L, 1.925929944387235853055977942584927318538e-34L, -1.570796326794896619231321691639751249506L),
3305 TEST_c_c (cacosh, -0x1p-112L, 0x1p-112L, 1.925929944387235853055977942584927318538e-34L, 1.570796326794896619231321691639751634692L),
3306 TEST_c_c (cacosh, -0x1p-112L, -0x1p-112L, 1.925929944387235853055977942584927318538e-34L, -1.570796326794896619231321691639751634692L),
3307 #if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
3308 TEST_c_c (cacosh, 0x1.fp-16385L, 0x1p-112L, 1.925929944387235853055977942584927318538e-34L, 1.570796326794896619231321691639751442099L),
3309 TEST_c_c (cacosh, 0x1.fp-16385L, -0x1p-112L, 1.925929944387235853055977942584927318538e-34L, -1.570796326794896619231321691639751442099L),
3310 TEST_c_c (cacosh, -0x1.fp-16385L, 0x1p-112L, 1.925929944387235853055977942584927318538e-34L, 1.570796326794896619231321691639751442099L),
3311 TEST_c_c (cacosh, -0x1.fp-16385L, -0x1p-112L, 1.925929944387235853055977942584927318538e-34L, -1.570796326794896619231321691639751442099L),
3312 TEST_c_c (cacosh, 0x1p-112L, 0x1.fp-16385L, 8.142593549724601460479922838826119584417e-4933L, 1.570796326794896619231321691639751249506L, UNDERFLOW_EXCEPTION),
3313 TEST_c_c (cacosh, -0x1p-112L, 0x1.fp-16385L, 8.142593549724601460479922838826119584417e-4933L, 1.570796326794896619231321691639751634692L, UNDERFLOW_EXCEPTION),
3314 TEST_c_c (cacosh, 0x1p-112L, -0x1.fp-16385L, 8.142593549724601460479922838826119584417e-4933L, -1.570796326794896619231321691639751249506L, UNDERFLOW_EXCEPTION),
3315 TEST_c_c (cacosh, -0x1p-112L, -0x1.fp-16385L, 8.142593549724601460479922838826119584417e-4933L, -1.570796326794896619231321691639751634692L, UNDERFLOW_EXCEPTION),
3316 #endif
3317 TEST_c_c (cacosh, 0.0L, 0x1p-112L, 1.925929944387235853055977942584927318538e-34L, 1.570796326794896619231321691639751442099L),
3318 TEST_c_c (cacosh, 0.0L, -0x1p-112L, 1.925929944387235853055977942584927318538e-34L, -1.570796326794896619231321691639751442099L),
3319 TEST_c_c (cacosh, -0.0L, 0x1p-112L, 1.925929944387235853055977942584927318538e-34L, 1.570796326794896619231321691639751442099L),
3320 TEST_c_c (cacosh, -0.0L, -0x1p-112L, 1.925929944387235853055977942584927318538e-34L, -1.570796326794896619231321691639751442099L),
3321 TEST_c_c (cacosh, 0x1p-112L, 0.0L, 0.0L, 1.570796326794896619231321691639751249506L),
3322 TEST_c_c (cacosh, -0x1p-112L, 0.0L, 0.0L, 1.570796326794896619231321691639751634692L),
3323 TEST_c_c (cacosh, 0x1p-112L, -0.0L, 0.0L, -1.570796326794896619231321691639751249506L),
3324 TEST_c_c (cacosh, -0x1p-112L, -0.0L, 0.0L, -1.570796326794896619231321691639751634692L),
3325
3326 TEST_c_c (cacosh, 0.75L, 1.25L, 1.13239363160530819522266333696834467L, 1.11752014915610270578240049553777969L),
3327 TEST_c_c (cacosh, -2, -3, 1.9833870299165354323470769028940395L, -2.1414491111159960199416055713254211L),
3328 END_DATA (cacosh)
3329 };
3330
3331 static void
3332 cacosh_test (void)
3333 {
3334 errno = 0;
3335 FUNC(cacosh) (BUILD_COMPLEX (0.7L, 1.2L));
3336 if (errno == ENOSYS)
3337 /* Function not implemented. */
3338 return;
3339
3340 START (cacosh);
3341 RUN_TEST_LOOP_c_c (cacosh, cacosh_test_data, );
3342 END (cacosh, complex);
3343 }
3344
3345
3346 static const struct test_c_f_data carg_test_data[] =
3347 {
3348 START_DATA (carg);
3349 /* carg (x + iy) is specified as atan2 (y, x) */
3350
3351 /* carg (x + i 0) == 0 for x > 0. */
3352 TEST_c_f (carg, 2.0, 0, 0),
3353 /* carg (x - i 0) == -0 for x > 0. */
3354 TEST_c_f (carg, 2.0, minus_zero, minus_zero),
3355
3356 TEST_c_f (carg, 0, 0, 0),
3357 TEST_c_f (carg, 0, minus_zero, minus_zero),
3358
3359 /* carg (x + i 0) == +pi for x < 0. */
3360 TEST_c_f (carg, -2.0, 0, M_PIl),
3361
3362 /* carg (x - i 0) == -pi for x < 0. */
3363 TEST_c_f (carg, -2.0, minus_zero, -M_PIl),
3364
3365 TEST_c_f (carg, minus_zero, 0, M_PIl),
3366 TEST_c_f (carg, minus_zero, minus_zero, -M_PIl),
3367
3368 /* carg (+0 + i y) == pi/2 for y > 0. */
3369 TEST_c_f (carg, 0, 2.0, M_PI_2l),
3370
3371 /* carg (-0 + i y) == pi/2 for y > 0. */
3372 TEST_c_f (carg, minus_zero, 2.0, M_PI_2l),
3373
3374 /* carg (+0 + i y) == -pi/2 for y < 0. */
3375 TEST_c_f (carg, 0, -2.0, -M_PI_2l),
3376
3377 /* carg (-0 + i y) == -pi/2 for y < 0. */
3378 TEST_c_f (carg, minus_zero, -2.0, -M_PI_2l),
3379
3380 /* carg (inf + i y) == +0 for finite y > 0. */
3381 TEST_c_f (carg, plus_infty, 2.0, 0),
3382
3383 /* carg (inf + i y) == -0 for finite y < 0. */
3384 TEST_c_f (carg, plus_infty, -2.0, minus_zero),
3385
3386 /* carg(x + i inf) == pi/2 for finite x. */
3387 TEST_c_f (carg, 10.0, plus_infty, M_PI_2l),
3388
3389 /* carg(x - i inf) == -pi/2 for finite x. */
3390 TEST_c_f (carg, 10.0, minus_infty, -M_PI_2l),
3391
3392 /* carg (-inf + i y) == +pi for finite y > 0. */
3393 TEST_c_f (carg, minus_infty, 10.0, M_PIl),
3394
3395 /* carg (-inf + i y) == -pi for finite y < 0. */
3396 TEST_c_f (carg, minus_infty, -10.0, -M_PIl),
3397
3398 TEST_c_f (carg, plus_infty, plus_infty, M_PI_4l),
3399
3400 TEST_c_f (carg, plus_infty, minus_infty, -M_PI_4l),
3401
3402 TEST_c_f (carg, minus_infty, plus_infty, M_PI_34l),
3403
3404 TEST_c_f (carg, minus_infty, minus_infty, -M_PI_34l),
3405
3406 TEST_c_f (carg, qnan_value, qnan_value, qnan_value),
3407 END_DATA (carg);
3408 };
3409
3410 static void
3411 carg_test (void)
3412 {
3413 START (carg);
3414 RUN_TEST_LOOP_c_f (carg, carg_test_data, );
3415 END (carg);
3416 }
3417
3418 static const struct test_c_c_data casin_test_data[] =
3419 {
3420 START_DATA (casin),
3421 TEST_c_c (casin, 0, 0, 0.0, 0.0),
3422 TEST_c_c (casin, minus_zero, 0, minus_zero, 0.0),
3423 TEST_c_c (casin, 0, minus_zero, 0.0, minus_zero),
3424 TEST_c_c (casin, minus_zero, minus_zero, minus_zero, minus_zero),
3425
3426 TEST_c_c (casin, plus_infty, plus_infty, M_PI_4l, plus_infty),
3427 TEST_c_c (casin, plus_infty, minus_infty, M_PI_4l, minus_infty),
3428 TEST_c_c (casin, minus_infty, plus_infty, -M_PI_4l, plus_infty),
3429 TEST_c_c (casin, minus_infty, minus_infty, -M_PI_4l, minus_infty),
3430
3431 TEST_c_c (casin, -10.0, plus_infty, minus_zero, plus_infty),
3432 TEST_c_c (casin, -10.0, minus_infty, minus_zero, minus_infty),
3433 TEST_c_c (casin, 0, plus_infty, 0.0, plus_infty),
3434 TEST_c_c (casin, 0, minus_infty, 0.0, minus_infty),
3435 TEST_c_c (casin, minus_zero, plus_infty, minus_zero, plus_infty),
3436 TEST_c_c (casin, minus_zero, minus_infty, minus_zero, minus_infty),
3437 TEST_c_c (casin, 0.1L, plus_infty, 0.0, plus_infty),
3438 TEST_c_c (casin, 0.1L, minus_infty, 0.0, minus_infty),
3439
3440 TEST_c_c (casin, minus_infty, 0, -M_PI_2l, plus_infty),
3441 TEST_c_c (casin, minus_infty, minus_zero, -M_PI_2l, minus_infty),
3442 TEST_c_c (casin, minus_infty, 100, -M_PI_2l, plus_infty),
3443 TEST_c_c (casin, minus_infty, -100, -M_PI_2l, minus_infty),
3444
3445 TEST_c_c (casin, plus_infty, 0, M_PI_2l, plus_infty),
3446 TEST_c_c (casin, plus_infty, minus_zero, M_PI_2l, minus_infty),
3447 TEST_c_c (casin, plus_infty, 0.5, M_PI_2l, plus_infty),
3448 TEST_c_c (casin, plus_infty, -0.5, M_PI_2l, minus_infty),
3449
3450 TEST_c_c (casin, qnan_value, plus_infty, qnan_value, plus_infty),
3451 TEST_c_c (casin, qnan_value, minus_infty, qnan_value, minus_infty),
3452
3453 TEST_c_c (casin, 0.0, qnan_value, 0.0, qnan_value),
3454 TEST_c_c (casin, minus_zero, qnan_value, minus_zero, qnan_value),
3455
3456 TEST_c_c (casin, plus_infty, qnan_value, qnan_value, plus_infty, IGNORE_ZERO_INF_SIGN),
3457 TEST_c_c (casin, minus_infty, qnan_value, qnan_value, plus_infty, IGNORE_ZERO_INF_SIGN),
3458
3459 TEST_c_c (casin, qnan_value, 10.5, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
3460 TEST_c_c (casin, qnan_value, -10.5, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
3461
3462 TEST_c_c (casin, 0.75, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
3463 TEST_c_c (casin, -0.75, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
3464
3465 TEST_c_c (casin, qnan_value, qnan_value, qnan_value, qnan_value),
3466
3467 TEST_c_c (casin, plus_zero, -1.5L, plus_zero, -1.194763217287109304111930828519090523536L),
3468 TEST_c_c (casin, minus_zero, -1.5L, minus_zero, -1.194763217287109304111930828519090523536L),
3469 TEST_c_c (casin, plus_zero, -1.0L, plus_zero, -0.8813735870195430252326093249797923090282L),
3470 TEST_c_c (casin, minus_zero, -1.0L, minus_zero, -0.8813735870195430252326093249797923090282L),
3471 TEST_c_c (casin, plus_zero, -0.5L, plus_zero, -0.4812118250596034474977589134243684231352L),
3472 TEST_c_c (casin, minus_zero, -0.5L, minus_zero, -0.4812118250596034474977589134243684231352L),
3473 TEST_c_c (casin, plus_zero, 0.5L, plus_zero, 0.4812118250596034474977589134243684231352L),
3474 TEST_c_c (casin, minus_zero, 0.5L, minus_zero, 0.4812118250596034474977589134243684231352L),
3475 TEST_c_c (casin, plus_zero, 1.0L, plus_zero, 0.8813735870195430252326093249797923090282L),
3476 TEST_c_c (casin, minus_zero, 1.0L, minus_zero, 0.8813735870195430252326093249797923090282L),
3477 TEST_c_c (casin, plus_zero, 1.5L, plus_zero, 1.194763217287109304111930828519090523536L),
3478 TEST_c_c (casin, minus_zero, 1.5L, minus_zero, 1.194763217287109304111930828519090523536L),
3479
3480 TEST_c_c (casin, -1.5L, plus_zero, -M_PI_2l, 0.9624236501192068949955178268487368462704L),
3481 TEST_c_c (casin, -1.5L, minus_zero, -M_PI_2l, -0.9624236501192068949955178268487368462704L),
3482 TEST_c_c (casin, -1.0L, plus_zero, -M_PI_2l, plus_zero),
3483 TEST_c_c (casin, -1.0L, minus_zero, -M_PI_2l, minus_zero),
3484 TEST_c_c (casin, -0.5L, plus_zero, -0.5235987755982988730771072305465838140329L, plus_zero),
3485 TEST_c_c (casin, -0.5L, minus_zero, -0.5235987755982988730771072305465838140329L, minus_zero),
3486 TEST_c_c (casin, 0.5L, plus_zero, 0.5235987755982988730771072305465838140329L, plus_zero),
3487 TEST_c_c (casin, 0.5L, minus_zero, 0.5235987755982988730771072305465838140329L, minus_zero),
3488 TEST_c_c (casin, 1.0L, plus_zero, M_PI_2l, plus_zero),
3489 TEST_c_c (casin, 1.0L, minus_zero, M_PI_2l, minus_zero),
3490 TEST_c_c (casin, 1.5L, plus_zero, M_PI_2l, 0.9624236501192068949955178268487368462704L),
3491 TEST_c_c (casin, 1.5L, minus_zero, M_PI_2l, -0.9624236501192068949955178268487368462704L),
3492
3493 TEST_c_c (casin, 0x1p50L, 1.0L, 1.570796326794895731052901991514519103193L, 3.535050620855721078027883819436720218708e1L),
3494 TEST_c_c (casin, 0x1p50L, -1.0L, 1.570796326794895731052901991514519103193L, -3.535050620855721078027883819436720218708e1L),
3495 TEST_c_c (casin, -0x1p50L, 1.0L, -1.570796326794895731052901991514519103193L, 3.535050620855721078027883819436720218708e1L),
3496 TEST_c_c (casin, -0x1p50L, -1.0L, -1.570796326794895731052901991514519103193L, -3.535050620855721078027883819436720218708e1L),
3497 TEST_c_c (casin, 1.0L, 0x1p50L, 8.881784197001252323389053344720723756399e-16L, 3.535050620855721078027883819436759661753e1L),
3498 TEST_c_c (casin, -1.0L, 0x1p50L, -8.881784197001252323389053344720723756399e-16L, 3.535050620855721078027883819436759661753e1L),
3499 TEST_c_c (casin, 1.0L, -0x1p50L, 8.881784197001252323389053344720723756399e-16L, -3.535050620855721078027883819436759661753e1L),
3500 TEST_c_c (casin, -1.0L, -0x1p50L, -8.881784197001252323389053344720723756399e-16L, -3.535050620855721078027883819436759661753e1L),
3501 #ifndef TEST_FLOAT
3502 TEST_c_c (casin, 0x1p500L, 1.0L, 1.570796326794896619231321691639751442099L, 3.472667374605326000180332928505464606058e2L),
3503 TEST_c_c (casin, 0x1p500L, -1.0L, 1.570796326794896619231321691639751442099L, -3.472667374605326000180332928505464606058e2L),
3504 TEST_c_c (casin, -0x1p500L, 1.0L, -1.570796326794896619231321691639751442099L, 3.472667374605326000180332928505464606058e2L),
3505 TEST_c_c (casin, -0x1p500L, -1.0L, -1.570796326794896619231321691639751442099L, -3.472667374605326000180332928505464606058e2L),
3506 TEST_c_c (casin, 1.0L, 0x1p500L, 3.054936363499604682051979393213617699789e-151L, 3.472667374605326000180332928505464606058e2L),
3507 TEST_c_c (casin, -1.0L, 0x1p500L, -3.054936363499604682051979393213617699789e-151L, 3.472667374605326000180332928505464606058e2L),
3508 TEST_c_c (casin, 1.0L, -0x1p500L, 3.054936363499604682051979393213617699789e-151L, -3.472667374605326000180332928505464606058e2L),
3509 TEST_c_c (casin, -1.0L, -0x1p500L, -3.054936363499604682051979393213617699789e-151L, -3.472667374605326000180332928505464606058e2L),
3510 #endif
3511 #if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
3512 TEST_c_c (casin, 0x1p5000L, 1.0L, 1.570796326794896619231321691639751442099L, 3.466429049980286492395577839412341016946e3L),
3513 TEST_c_c (casin, 0x1p5000L, -1.0L, 1.570796326794896619231321691639751442099L, -3.466429049980286492395577839412341016946e3L),
3514 TEST_c_c (casin, -0x1p5000L, 1.0L, -1.570796326794896619231321691639751442099L, 3.466429049980286492395577839412341016946e3L),
3515 TEST_c_c (casin, -0x1p5000L, -1.0L, -1.570796326794896619231321691639751442099L, -3.466429049980286492395577839412341016946e3L),
3516 TEST_c_c (casin, 1.0L, 0x1p5000L, 7.079811261048172892385615158694057552948e-1506L, 3.466429049980286492395577839412341016946e3L),
3517 TEST_c_c (casin, -1.0L, 0x1p5000L, -7.079811261048172892385615158694057552948e-1506L, 3.466429049980286492395577839412341016946e3L),
3518 TEST_c_c (casin, 1.0L, -0x1p5000L, 7.079811261048172892385615158694057552948e-1506L, -3.466429049980286492395577839412341016946e3L),
3519 TEST_c_c (casin, -1.0L, -0x1p5000L, -7.079811261048172892385615158694057552948e-1506L, -3.466429049980286492395577839412341016946e3L),
3520 #endif
3521
3522 TEST_c_c (casin, 0x1.fp127L, 0x1.fp127L, 7.853981633974483096156608458198757210493e-1L, 8.973081118419833726837456344608533993585e1L),
3523 #ifndef TEST_FLOAT
3524 TEST_c_c (casin, 0x1.fp1023L, 0x1.fp1023L, 7.853981633974483096156608458198757210493e-1L, 7.107906849659093345062145442726115449315e2L),
3525 #endif
3526 #if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
3527 TEST_c_c (casin, 0x1.fp16383L, 0x1.fp16383L, 7.853981633974483096156608458198757210493e-1L, 1.135753137836666928715489992987020363057e4L),
3528 #endif
3529
3530 TEST_c_c (casin, 0x1.fp-129L, 1.5L, 1.579176199917649005841160751101628985741e-39L, 1.194763217287109304111930828519090523536L, UNDERFLOW_EXCEPTION_FLOAT),
3531 TEST_c_c (casin, 0x1.fp-129L, -1.5L, 1.579176199917649005841160751101628985741e-39L, -1.194763217287109304111930828519090523536L, UNDERFLOW_EXCEPTION_FLOAT),
3532 TEST_c_c (casin, -0x1.fp-129L, 1.5L, -1.579176199917649005841160751101628985741e-39L, 1.194763217287109304111930828519090523536L, UNDERFLOW_EXCEPTION_FLOAT),
3533 TEST_c_c (casin, -0x1.fp-129L, -1.5L, -1.579176199917649005841160751101628985741e-39L, -1.194763217287109304111930828519090523536L, UNDERFLOW_EXCEPTION_FLOAT),
3534 TEST_c_c (casin, 1.5L, 0x1.fp-129L, 1.570796326794896619231321691639751442096L, 9.624236501192068949955178268487368462704e-1L),
3535 TEST_c_c (casin, -1.5L, 0x1.fp-129L, -1.570796326794896619231321691639751442096L, 9.624236501192068949955178268487368462704e-1L),
3536 TEST_c_c (casin, 1.5L, -0x1.fp-129L, 1.570796326794896619231321691639751442096L, -9.624236501192068949955178268487368462704e-1L),
3537 TEST_c_c (casin, -1.5L, -0x1.fp-129L, -1.570796326794896619231321691639751442096L, -9.624236501192068949955178268487368462704e-1L),
3538 #ifndef TEST_FLOAT
3539 TEST_c_c (casin, 0x1.fp-1025L, 1.5L, 2.989196569048182929051881765490354365918e-309L, 1.194763217287109304111930828519090523536L, UNDERFLOW_EXCEPTION_DOUBLE),
3540 TEST_c_c (casin, 0x1.fp-1025L, -1.5L, 2.989196569048182929051881765490354365918e-309L, -1.194763217287109304111930828519090523536L, UNDERFLOW_EXCEPTION_DOUBLE),
3541 TEST_c_c (casin, -0x1.fp-1025L, 1.5L, -2.989196569048182929051881765490354365918e-309L, 1.194763217287109304111930828519090523536L, UNDERFLOW_EXCEPTION_DOUBLE),
3542 TEST_c_c (casin, -0x1.fp-1025L, -1.5L, -2.989196569048182929051881765490354365918e-309L, -1.194763217287109304111930828519090523536L, UNDERFLOW_EXCEPTION_DOUBLE),
3543 TEST_c_c (casin, 1.5L, 0x1.fp-1025L, 1.570796326794896619231321691639751442099L, 9.624236501192068949955178268487368462704e-1L),
3544 TEST_c_c (casin, -1.5L, 0x1.fp-1025L, -1.570796326794896619231321691639751442099L, 9.624236501192068949955178268487368462704e-1L),
3545 TEST_c_c (casin, 1.5L, -0x1.fp-1025L, 1.570796326794896619231321691639751442099L, -9.624236501192068949955178268487368462704e-1L),
3546 TEST_c_c (casin, -1.5L, -0x1.fp-1025L, -1.570796326794896619231321691639751442099L, -9.624236501192068949955178268487368462704e-1L),
3547 #endif
3548 #if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
3549 TEST_c_c (casin, 0x1.fp-16385L, 1.5L, 4.516698239814521372306784062043266700598e-4933L, 1.194763217287109304111930828519090523536L, UNDERFLOW_EXCEPTION),
3550 TEST_c_c (casin, 0x1.fp-16385L, -1.5L, 4.516698239814521372306784062043266700598e-4933L, -1.194763217287109304111930828519090523536L, UNDERFLOW_EXCEPTION),
3551 TEST_c_c (casin, -0x1.fp-16385L, 1.5L, -4.516698239814521372306784062043266700598e-4933L, 1.194763217287109304111930828519090523536L, UNDERFLOW_EXCEPTION),
3552 TEST_c_c (casin, -0x1.fp-16385L, -1.5L, -4.516698239814521372306784062043266700598e-4933L, -1.194763217287109304111930828519090523536L, UNDERFLOW_EXCEPTION),
3553 TEST_c_c (casin, 1.5L, 0x1.fp-16385L, 1.570796326794896619231321691639751442099L, 9.624236501192068949955178268487368462704e-1L),
3554 TEST_c_c (casin, -1.5L, 0x1.fp-16385L, -1.570796326794896619231321691639751442099L, 9.624236501192068949955178268487368462704e-1L),
3555 TEST_c_c (casin, 1.5L, -0x1.fp-16385L, 1.570796326794896619231321691639751442099L, -9.624236501192068949955178268487368462704e-1L),
3556 TEST_c_c (casin, -1.5L, -0x1.fp-16385L, -1.570796326794896619231321691639751442099L, -9.624236501192068949955178268487368462704e-1L),
3557 #endif
3558
3559 TEST_c_c (casin, 0.5L, 1.0L, 3.494390628572132936274118260753699527325e-1L, 9.261330313501824245501244453057873152694e-1L),
3560 TEST_c_c (casin, 0.5L, -1.0L, 3.494390628572132936274118260753699527325e-1L, -9.261330313501824245501244453057873152694e-1L),
3561 TEST_c_c (casin, -0.5L, 1.0L, -3.494390628572132936274118260753699527325e-1L, 9.261330313501824245501244453057873152694e-1L),
3562 TEST_c_c (casin, -0.5L, -1.0L, -3.494390628572132936274118260753699527325e-1L, -9.261330313501824245501244453057873152694e-1L),
3563 TEST_c_c (casin, 1.0L, 0.5L, 8.959074812088902390666567243275770102229e-1L, 7.328576759736452608886724437653071523305e-1L),
3564 TEST_c_c (casin, -1.0L, 0.5L, -8.959074812088902390666567243275770102229e-1L, 7.328576759736452608886724437653071523305e-1L),
3565 TEST_c_c (casin, 1.0L, -0.5L, 8.959074812088902390666567243275770102229e-1L, -7.328576759736452608886724437653071523305e-1L),
3566 TEST_c_c (casin, -1.0L, -0.5L, -8.959074812088902390666567243275770102229e-1L, -7.328576759736452608886724437653071523305e-1L),
3567 TEST_c_c (casin, 0.25L, 1.0L, 1.763024327769669304186785666360901026468e-1L, 8.924633639033482359562124741744951972772e-1L),
3568 TEST_c_c (casin, 0.25L, -1.0L, 1.763024327769669304186785666360901026468e-1L, -8.924633639033482359562124741744951972772e-1L),
3569 TEST_c_c (casin, -0.25L, 1.0L, -1.763024327769669304186785666360901026468e-1L, 8.924633639033482359562124741744951972772e-1L),
3570 TEST_c_c (casin, -0.25L, -1.0L, -1.763024327769669304186785666360901026468e-1L, -8.924633639033482359562124741744951972772e-1L),
3571 TEST_c_c (casin, 1.0L, 0.25L, 1.081751996523816326311037318425097434186L, 5.097911466811016354623559941115413499164e-1L),
3572 TEST_c_c (casin, -1.0L, 0.25L, -1.081751996523816326311037318425097434186L, 5.097911466811016354623559941115413499164e-1L),
3573 TEST_c_c (casin, 1.0L, -0.25L, 1.081751996523816326311037318425097434186L, -5.097911466811016354623559941115413499164e-1L),
3574 TEST_c_c (casin, -1.0L, -0.25L, -1.081751996523816326311037318425097434186L, -5.097911466811016354623559941115413499164e-1L),
3575 TEST_c_c (casin, 0x1.fp-10L, 1.0L, 1.337909359557740912558349531052239112857e-3L, 8.813742198809567991336704287826445879025e-1L),
3576 TEST_c_c (casin, 0x1.fp-10L, -1.0L, 1.337909359557740912558349531052239112857e-3L, -8.813742198809567991336704287826445879025e-1L),
3577 TEST_c_c (casin, -0x1.fp-10L, 1.0L, -1.337909359557740912558349531052239112857e-3L, 8.813742198809567991336704287826445879025e-1L),
3578 TEST_c_c (casin, -0x1.fp-10L, -1.0L, -1.337909359557740912558349531052239112857e-3L, -8.813742198809567991336704287826445879025e-1L),
3579 TEST_c_c (casin, 1.0L, 0x1.fp-10L, 1.527305029163877791518741192097931722508L, 4.350501469856803800217957402220976497152e-2L),
3580 TEST_c_c (casin, -1.0L, 0x1.fp-10L, -1.527305029163877791518741192097931722508L, 4.350501469856803800217957402220976497152e-2L),
3581 TEST_c_c (casin, 1.0L, -0x1.fp-10L, 1.527305029163877791518741192097931722508L, -4.350501469856803800217957402220976497152e-2L),
3582 TEST_c_c (casin, -1.0L, -0x1.fp-10L, -1.527305029163877791518741192097931722508L, -4.350501469856803800217957402220976497152e-2L),
3583 TEST_c_c (casin, 0x1.fp-30L, 1.0L, 1.275929984216518540252717485007112529021e-9L, 8.813735870195430258081932989769495326854e-1L),
3584 TEST_c_c (casin, 0x1.fp-30L, -1.0L, 1.275929984216518540252717485007112529021e-9L, -8.813735870195430258081932989769495326854e-1L),
3585 TEST_c_c (casin, -0x1.fp-30L, 1.0L, -1.275929984216518540252717485007112529021e-9L, 8.813735870195430258081932989769495326854e-1L),
3586 TEST_c_c (casin, -0x1.fp-30L, -1.0L, -1.275929984216518540252717485007112529021e-9L, -8.813735870195430258081932989769495326854e-1L),
3587 TEST_c_c (casin, 1.0L, 0x1.fp-30L, 1.570753848123921942730162693731872690232L, 4.247867098745151888768727039216644758847e-5L),
3588 TEST_c_c (casin, -1.0L, 0x1.fp-30L, -1.570753848123921942730162693731872690232L, 4.247867098745151888768727039216644758847e-5L),
3589 TEST_c_c (casin, 1.0L, -0x1.fp-30L, 1.570753848123921942730162693731872690232L, -4.247867098745151888768727039216644758847e-5L),
3590 TEST_c_c (casin, -1.0L, -0x1.fp-30L, -1.570753848123921942730162693731872690232L, -4.247867098745151888768727039216644758847e-5L),
3591 TEST_c_c (casin, 0x1.fp-100L, 1.0L, 1.080754735021050612990719608916167354321e-30L, 8.813735870195430252326093249797923090282e-1L),
3592 TEST_c_c (casin, 0x1.fp-100L, -1.0L, 1.080754735021050612990719608916167354321e-30L, -8.813735870195430252326093249797923090282e-1L),
3593 TEST_c_c (casin, -0x1.fp-100L, 1.0L, -1.080754735021050612990719608916167354321e-30L, 8.813735870195430252326093249797923090282e-1L),
3594 TEST_c_c (casin, -0x1.fp-100L, -1.0L, -1.080754735021050612990719608916167354321e-30L, -8.813735870195430252326093249797923090282e-1L),
3595 TEST_c_c (casin, 1.0L, 0x1.fp-100L, 1.570796326794895382939283431378862777584L, 1.236292038260260888664514866457202186027e-15L),
3596 TEST_c_c (casin, -1.0L, 0x1.fp-100L, -1.570796326794895382939283431378862777584L, 1.236292038260260888664514866457202186027e-15L),
3597 TEST_c_c (casin, 1.0L, -0x1.fp-100L, 1.570796326794895382939283431378862777584L, -1.236292038260260888664514866457202186027e-15L),
3598 TEST_c_c (casin, -1.0L, -0x1.fp-100L, -1.570796326794895382939283431378862777584L, -1.236292038260260888664514866457202186027e-15L),
3599 TEST_c_c (casin, 0x1.fp-129L, 1.0L, 2.013062564695348242280482517399205554874e-39L, 8.813735870195430252326093249797923090282e-1L, UNDERFLOW_EXCEPTION_FLOAT),
3600 TEST_c_c (casin, 0x1.fp-129L, -1.0L, 2.013062564695348242280482517399205554874e-39L, -8.813735870195430252326093249797923090282e-1L, UNDERFLOW_EXCEPTION_FLOAT),
3601 TEST_c_c (casin, -0x1.fp-129L, 1.0L, -2.013062564695348242280482517399205554874e-39L, 8.813735870195430252326093249797923090282e-1L, UNDERFLOW_EXCEPTION_FLOAT),
3602 TEST_c_c (casin, -0x1.fp-129L, -1.0L, -2.013062564695348242280482517399205554874e-39L, -8.813735870195430252326093249797923090282e-1L, UNDERFLOW_EXCEPTION_FLOAT),
3603 TEST_c_c (casin, 1.0L, 0x1.fp-129L, 1.570796326794896619177965338869929107115L, 5.335635276982233498398987585285818977933e-20L),
3604 TEST_c_c (casin, -1.0L, 0x1.fp-129L, -1.570796326794896619177965338869929107115L, 5.335635276982233498398987585285818977933e-20L),
3605 TEST_c_c (casin, 1.0L, -0x1.fp-129L, 1.570796326794896619177965338869929107115L, -5.335635276982233498398987585285818977933e-20L),
3606 TEST_c_c (casin, -1.0L, -0x1.fp-129L, -1.570796326794896619177965338869929107115L, -5.335635276982233498398987585285818977933e-20L),
3607 #ifndef TEST_FLOAT
3608 TEST_c_c (casin, 0x1.fp-1000L, 1.0L, 1.278589251976747242280879285935084814093e-301L, 8.813735870195430252326093249797923090282e-1L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
3609 TEST_c_c (casin, 0x1.fp-1000L, -1.0L, 1.278589251976747242280879285935084814093e-301L, -8.813735870195430252326093249797923090282e-1L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
3610 TEST_c_c (casin, -0x1.fp-1000L, 1.0L, -1.278589251976747242280879285935084814093e-301L, 8.813735870195430252326093249797923090282e-1L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
3611 TEST_c_c (casin, -0x1.fp-1000L, -1.0L, -1.278589251976747242280879285935084814093e-301L, -8.813735870195430252326093249797923090282e-1L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
3612 TEST_c_c (casin, 1.0L, 0x1.fp-1000L, 1.570796326794896619231321691639751442099L, 4.252291453851660175550490409247739011867e-151L),
3613 TEST_c_c (casin, -1.0L, 0x1.fp-1000L, -1.570796326794896619231321691639751442099L, 4.252291453851660175550490409247739011867e-151L),
3614 TEST_c_c (casin, 1.0L, -0x1.fp-1000L, 1.570796326794896619231321691639751442099L, -4.252291453851660175550490409247739011867e-151L),
3615 TEST_c_c (casin, -1.0L, -0x1.fp-1000L, -1.570796326794896619231321691639751442099L, -4.252291453851660175550490409247739011867e-151L),
3616 TEST_c_c (casin, 0x1.fp-1025L, 1.0L, 3.810492908885321743133304375216617626230e-309L, 8.813735870195430252326093249797923090282e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
3617 TEST_c_c (casin, 0x1.fp-1025L, -1.0L, 3.810492908885321743133304375216617626230e-309L, -8.813735870195430252326093249797923090282e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
3618 TEST_c_c (casin, -0x1.fp-1025L, 1.0L, -3.810492908885321743133304375216617626230e-309L, 8.813735870195430252326093249797923090282e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
3619 TEST_c_c (casin, -0x1.fp-1025L, -1.0L, -3.810492908885321743133304375216617626230e-309L, -8.813735870195430252326093249797923090282e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
3620 TEST_c_c (casin, 1.0L, 0x1.fp-1025L, 1.570796326794896619231321691639751442099L, 7.340879205566679497036857179189356754017e-155L),
3621 TEST_c_c (casin, -1.0L, 0x1.fp-1025L, -1.570796326794896619231321691639751442099L, 7.340879205566679497036857179189356754017e-155L),
3622 TEST_c_c (casin, 1.0L, -0x1.fp-1025L, 1.570796326794896619231321691639751442099L, -7.340879205566679497036857179189356754017e-155L),
3623 TEST_c_c (casin, -1.0L, -0x1.fp-1025L, -1.570796326794896619231321691639751442099L, -7.340879205566679497036857179189356754017e-155L),
3624 #endif
3625 #if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
3626 TEST_c_c (casin, 0x1.fp-10000L, 1.0L, 6.867047849047171855399183659351043150871e-3011L, 8.813735870195430252326093249797923090282e-1L),
3627 TEST_c_c (casin, 0x1.fp-10000L, -1.0L, 6.867047849047171855399183659351043150871e-3011L, -8.813735870195430252326093249797923090282e-1L),
3628 TEST_c_c (casin, -0x1.fp-10000L, 1.0L, -6.867047849047171855399183659351043150871e-3011L, 8.813735870195430252326093249797923090282e-1L),
3629 TEST_c_c (casin, -0x1.fp-10000L, -1.0L, -6.867047849047171855399183659351043150871e-3011L, -8.813735870195430252326093249797923090282e-1L),
3630 TEST_c_c (casin, 1.0L, 0x1.fp-10000L, 1.570796326794896619231321691639751442099L, 9.854680208706673586644342922051388714633e-1506L),
3631 TEST_c_c (casin, -1.0L, 0x1.fp-10000L, -1.570796326794896619231321691639751442099L, 9.854680208706673586644342922051388714633e-1506L),
3632 TEST_c_c (casin, 1.0L, -0x1.fp-10000L, 1.570796326794896619231321691639751442099L, -9.854680208706673586644342922051388714633e-1506L),
3633 TEST_c_c (casin, -1.0L, -0x1.fp-10000L, -1.570796326794896619231321691639751442099L, -9.854680208706673586644342922051388714633e-1506L),
3634 TEST_c_c (casin, 0x1.fp-16385L, 1.0L, 5.757683115456107044131264955348448954458e-4933L, 8.813735870195430252326093249797923090282e-1L, UNDERFLOW_EXCEPTION),
3635 TEST_c_c (casin, 0x1.fp-16385L, -1.0L, 5.757683115456107044131264955348448954458e-4933L, -8.813735870195430252326093249797923090282e-1L, UNDERFLOW_EXCEPTION),
3636 TEST_c_c (casin, -0x1.fp-16385L, 1.0L, -5.757683115456107044131264955348448954458e-4933L, 8.813735870195430252326093249797923090282e-1L, UNDERFLOW_EXCEPTION),
3637 TEST_c_c (casin, -0x1.fp-16385L, -1.0L, -5.757683115456107044131264955348448954458e-4933L, -8.813735870195430252326093249797923090282e-1L, UNDERFLOW_EXCEPTION),
3638 TEST_c_c (casin, 1.0L, 0x1.fp-16385L, 1.570796326794896619231321691639751442099L, 9.023632056840860275214893047597614177639e-2467L),
3639 TEST_c_c (casin, -1.0L, 0x1.fp-16385L, -1.570796326794896619231321691639751442099L, 9.023632056840860275214893047597614177639e-2467L),
3640 TEST_c_c (casin, 1.0L, -0x1.fp-16385L, 1.570796326794896619231321691639751442099L, -9.023632056840860275214893047597614177639e-2467L),
3641 TEST_c_c (casin, -1.0L, -0x1.fp-16385L, -1.570796326794896619231321691639751442099L, -9.023632056840860275214893047597614177639e-2467L),
3642 #endif
3643
3644 TEST_c_c (casin, 0x1p-23L, 0x1.000002p0L, 8.429369199749229560964789467980644296420e-8L, 8.813736713132400470205730751186547909968e-1L),
3645 TEST_c_c (casin, 0x1p-23L, -0x1.000002p0L, 8.429369199749229560964789467980644296420e-8L, -8.813736713132400470205730751186547909968e-1L),
3646 TEST_c_c (casin, -0x1p-23L, 0x1.000002p0L, -8.429369199749229560964789467980644296420e-8L, 8.813736713132400470205730751186547909968e-1L),
3647 TEST_c_c (casin, -0x1p-23L, -0x1.000002p0L, -8.429369199749229560964789467980644296420e-8L, -8.813736713132400470205730751186547909968e-1L),
3648 TEST_c_c (casin, 0x1.000002p0L, 0x1p-23L, 1.570574114956455764594481054234834678422L, 5.364668491573609633134147164031476452679e-4L),
3649 TEST_c_c (casin, -0x1.000002p0L, 0x1p-23L, -1.570574114956455764594481054234834678422L, 5.364668491573609633134147164031476452679e-4L),
3650 TEST_c_c (casin, 0x1.000002p0L, -0x1p-23L, 1.570574114956455764594481054234834678422L, -5.364668491573609633134147164031476452679e-4L),
3651 TEST_c_c (casin, -0x1.000002p0L, -0x1p-23L, -1.570574114956455764594481054234834678422L, -5.364668491573609633134147164031476452679e-4L),
3652 TEST_c_c (casin, 0x1.fp-129L, 0x1.000002p0L, 2.013062444707472738895109955455676357057e-39L, 8.813736713132375348727889167749389235161e-1L, UNDERFLOW_EXCEPTION_FLOAT),
3653 TEST_c_c (casin, 0x1.fp-129L, -0x1.000002p0L, 2.013062444707472738895109955455676357057e-39L, -8.813736713132375348727889167749389235161e-1L, UNDERFLOW_EXCEPTION_FLOAT),
3654 TEST_c_c (casin, -0x1.fp-129L, 0x1.000002p0L, -2.013062444707472738895109955455676357057e-39L, 8.813736713132375348727889167749389235161e-1L, UNDERFLOW_EXCEPTION_FLOAT),
3655 TEST_c_c (casin, -0x1.fp-129L, -0x1.000002p0L, -2.013062444707472738895109955455676357057e-39L, -8.813736713132375348727889167749389235161e-1L, UNDERFLOW_EXCEPTION_FLOAT),
3656 TEST_c_c (casin, 0x1.000002p0L, 0x1.fp-129L, 1.570796326794896619231321691639751436268L, 4.882812451493617206486388134172712975070e-4L),
3657 TEST_c_c (casin, -0x1.000002p0L, 0x1.fp-129L, -1.570796326794896619231321691639751436268L, 4.882812451493617206486388134172712975070e-4L),
3658 TEST_c_c (casin, 0x1.000002p0L, -0x1.fp-129L, 1.570796326794896619231321691639751436268L, -4.882812451493617206486388134172712975070e-4L),
3659 TEST_c_c (casin, -0x1.000002p0L, -0x1.fp-129L, -1.570796326794896619231321691639751436268L, -4.882812451493617206486388134172712975070e-4L),
3660 TEST_c_c (casin, 0.0L, 0x1.000002p0L, 0.0L, 8.813736713132375348727889167749389235161e-1L),
3661 TEST_c_c (casin, 0.0L, -0x1.000002p0L, 0.0L, -8.813736713132375348727889167749389235161e-1L),
3662 TEST_c_c (casin, -0.0L, 0x1.000002p0L, -0.0L, 8.813736713132375348727889167749389235161e-1L),
3663 TEST_c_c (casin, -0.0L, -0x1.000002p0L, -0.0L, -8.813736713132375348727889167749389235161e-1L),
3664 TEST_c_c (casin, 0x1.000002p0L, 0.0L, 1.570796326794896619231321691639751442099L, 4.882812451493617206486388134172712975070e-4L),
3665 TEST_c_c (casin, -0x1.000002p0L, 0.0L, -1.570796326794896619231321691639751442099L, 4.882812451493617206486388134172712975070e-4L),
3666 TEST_c_c (casin, 0x1.000002p0L, -0.0L, 1.570796326794896619231321691639751442099L, -4.882812451493617206486388134172712975070e-4L),
3667 TEST_c_c (casin, -0x1.000002p0L, -0.0L, -1.570796326794896619231321691639751442099L, -4.882812451493617206486388134172712975070e-4L),
3668 #ifndef TEST_FLOAT
3669 TEST_c_c (casin, 0x1p-52L, 0x1.0000000000001p0L, 1.570092458683774885078102529858632363236e-16L, 8.813735870195431822418551933572982483664e-1L),
3670 TEST_c_c (casin, 0x1p-52L, -0x1.0000000000001p0L, 1.570092458683774885078102529858632363236e-16L, -8.813735870195431822418551933572982483664e-1L),
3671 TEST_c_c (casin, -0x1p-52L, 0x1.0000000000001p0L, -1.570092458683774885078102529858632363236e-16L, 8.813735870195431822418551933572982483664e-1L),
3672 TEST_c_c (casin, -0x1p-52L, -0x1.0000000000001p0L, -1.570092458683774885078102529858632363236e-16L, -8.813735870195431822418551933572982483664e-1L),
3673 TEST_c_c (casin, 0x1.0000000000001p0L, 0x1p-52L, 1.570796317204594913251280305810847349436L, 2.315303644582684770975188768022139415020e-8L),
3674 TEST_c_c (casin, -0x1.0000000000001p0L, 0x1p-52L, -1.570796317204594913251280305810847349436L, 2.315303644582684770975188768022139415020e-8L),
3675 TEST_c_c (casin, 0x1.0000000000001p0L, -0x1p-52L, 1.570796317204594913251280305810847349436L, -2.315303644582684770975188768022139415020e-8L),
3676 TEST_c_c (casin, -0x1.0000000000001p0L, -0x1p-52L, -1.570796317204594913251280305810847349436L, -2.315303644582684770975188768022139415020e-8L),
3677 TEST_c_c (casin, 0x1.fp-1025L, 0x1.0000000000001p0L, 3.810492908885321320083608113679347200012e-309L, 8.813735870195431822418551933572895326024e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
3678 TEST_c_c (casin, 0x1.fp-1025L, -0x1.0000000000001p0L, 3.810492908885321320083608113679347200012e-309L, -8.813735870195431822418551933572895326024e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
3679 TEST_c_c (casin, -0x1.fp-1025L, 0x1.0000000000001p0L, -3.810492908885321320083608113679347200012e-309L, 8.813735870195431822418551933572895326024e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
3680 TEST_c_c (casin, -0x1.fp-1025L, -0x1.0000000000001p0L, -3.810492908885321320083608113679347200012e-309L, -8.813735870195431822418551933572895326024e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
3681 TEST_c_c (casin, 0x1.0000000000001p0L, 0x1.fp-1025L, 1.570796326794896619231321691639751442099L, 2.107342425544701550354780375182800088393e-8L),
3682 TEST_c_c (casin, -0x1.0000000000001p0L, 0x1.fp-1025L, -1.570796326794896619231321691639751442099L, 2.107342425544701550354780375182800088393e-8L),
3683 TEST_c_c (casin, 0x1.0000000000001p0L, -0x1.fp-1025L, 1.570796326794896619231321691639751442099L, -2.107342425544701550354780375182800088393e-8L),
3684 TEST_c_c (casin, -0x1.0000000000001p0L, -0x1.fp-1025L, -1.570796326794896619231321691639751442099L, -2.107342425544701550354780375182800088393e-8L),
3685 TEST_c_c (casin, 0.0L, 0x1.0000000000001p0L, 0.0L, 8.813735870195431822418551933572895326024e-1L),
3686 TEST_c_c (casin, 0.0L, -0x1.0000000000001p0L, 0.0L, -8.813735870195431822418551933572895326024e-1L),
3687 TEST_c_c (casin, -0.0L, 0x1.0000000000001p0L, -0.0L, 8.813735870195431822418551933572895326024e-1L),
3688 TEST_c_c (casin, -0.0L, -0x1.0000000000001p0L, -0.0L, -8.813735870195431822418551933572895326024e-1L),
3689 TEST_c_c (casin, 0x1.0000000000001p0L, 0.0L, 1.570796326794896619231321691639751442099L, 2.107342425544701550354780375182800088393e-8L),
3690 TEST_c_c (casin, -0x1.0000000000001p0L, 0.0L, -1.570796326794896619231321691639751442099L, 2.107342425544701550354780375182800088393e-8L),
3691 TEST_c_c (casin, 0x1.0000000000001p0L, -0.0L, 1.570796326794896619231321691639751442099L, -2.107342425544701550354780375182800088393e-8L),
3692 TEST_c_c (casin, -0x1.0000000000001p0L, -0.0L, -1.570796326794896619231321691639751442099L, -2.107342425544701550354780375182800088393e-8L),
3693 #endif
3694 #if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 64
3695 TEST_c_c (casin, 0x1p-63L, 0x1.0000000000000002p0L, 7.666467083416870406778649849746878368519e-20L, 8.813735870195430253092739958139610131001e-1L),
3696 TEST_c_c (casin, 0x1p-63L, -0x1.0000000000000002p0L, 7.666467083416870406778649849746878368519e-20L, -8.813735870195430253092739958139610131001e-1L),
3697 TEST_c_c (casin, -0x1p-63L, 0x1.0000000000000002p0L, -7.666467083416870406778649849746878368519e-20L, 8.813735870195430253092739958139610131001e-1L),
3698 TEST_c_c (casin, -0x1p-63L, -0x1.0000000000000002p0L, -7.666467083416870406778649849746878368519e-20L, -8.813735870195430253092739958139610131001e-1L),
3699 TEST_c_c (casin, 0x1.0000000000000002p0L, 0x1p-63L, 1.570796326582978888921215348380499122131L, 5.116146586219826555037807251857670783420e-10L),
3700 TEST_c_c (casin, -0x1.0000000000000002p0L, 0x1p-63L, -1.570796326582978888921215348380499122131L, 5.116146586219826555037807251857670783420e-10L),
3701 TEST_c_c (casin, 0x1.0000000000000002p0L, -0x1p-63L, 1.570796326582978888921215348380499122131L, -5.116146586219826555037807251857670783420e-10L),
3702 TEST_c_c (casin, -0x1.0000000000000002p0L, -0x1p-63L, -1.570796326582978888921215348380499122131L, -5.116146586219826555037807251857670783420e-10L),
3703 # if LDBL_MIN_EXP <= -16381
3704 TEST_c_c (casin, 0x1.fp-16385L, 0x1.0000000000000002p0L, 5.757683115456107043819140328235418018963e-4933L, 8.813735870195430253092739958139610130980e-1L, UNDERFLOW_EXCEPTION),
3705 TEST_c_c (casin, 0x1.fp-16385L, -0x1.0000000000000002p0L, 5.757683115456107043819140328235418018963e-4933L, -8.813735870195430253092739958139610130980e-1L, UNDERFLOW_EXCEPTION),
3706 TEST_c_c (casin, -0x1.fp-16385L, 0x1.0000000000000002p0L, -5.757683115456107043819140328235418018963e-4933L, 8.813735870195430253092739958139610130980e-1L, UNDERFLOW_EXCEPTION),
3707 TEST_c_c (casin, -0x1.fp-16385L, -0x1.0000000000000002p0L, -5.757683115456107043819140328235418018963e-4933L, -8.813735870195430253092739958139610130980e-1L, UNDERFLOW_EXCEPTION),
3708 TEST_c_c (casin, 0x1.0000000000000002p0L, 0x1.fp-16385L, 1.570796326794896619231321691639751442099L, 4.656612873077392578082927418388212703712e-10L),
3709 TEST_c_c (casin, -0x1.0000000000000002p0L, 0x1.fp-16385L, -1.570796326794896619231321691639751442099L, 4.656612873077392578082927418388212703712e-10L),
3710 TEST_c_c (casin, 0x1.0000000000000002p0L, -0x1.fp-16385L, 1.570796326794896619231321691639751442099L, -4.656612873077392578082927418388212703712e-10L),
3711 TEST_c_c (casin, -0x1.0000000000000002p0L, -0x1.fp-16385L, -1.570796326794896619231321691639751442099L, -4.656612873077392578082927418388212703712e-10L),
3712 # endif
3713 TEST_c_c (casin, 0.0L, 0x1.0000000000000002p0L, 0.0L, 8.813735870195430253092739958139610130980e-1L),
3714 TEST_c_c (casin, 0.0L, -0x1.0000000000000002p0L, 0.0L, -8.813735870195430253092739958139610130980e-1L),
3715 TEST_c_c (casin, -0.0L, 0x1.0000000000000002p0L, -0.0L, 8.813735870195430253092739958139610130980e-1L),
3716 TEST_c_c (casin, -0.0L, -0x1.0000000000000002p0L, -0.0L, -8.813735870195430253092739958139610130980e-1L),
3717 TEST_c_c (casin, 0x1.0000000000000002p0L, 0.0L, 1.570796326794896619231321691639751442099L, 4.656612873077392578082927418388212703712e-10L),
3718 TEST_c_c (casin, -0x1.0000000000000002p0L, 0.0L, -1.570796326794896619231321691639751442099L, 4.656612873077392578082927418388212703712e-10L),
3719 TEST_c_c (casin, 0x1.0000000000000002p0L, -0.0L, 1.570796326794896619231321691639751442099L, -4.656612873077392578082927418388212703712e-10L),
3720 TEST_c_c (casin, -0x1.0000000000000002p0L, -0.0L, -1.570796326794896619231321691639751442099L, -4.656612873077392578082927418388212703712e-10L),
3721 #endif
3722 #if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 106
3723 TEST_c_c (casin, 0x1p-106L, 0x1.000000000000000000000000008p0L, 8.715763992105246878957416200936726072500e-33L, 8.813735870195430252326093249798097405561e-1L),
3724 TEST_c_c (casin, 0x1p-106L, -0x1.000000000000000000000000008p0L, 8.715763992105246878957416200936726072500e-33L, -8.813735870195430252326093249798097405561e-1L),
3725 TEST_c_c (casin, -0x1p-106L, 0x1.000000000000000000000000008p0L, -8.715763992105246878957416200936726072500e-33L, 8.813735870195430252326093249798097405561e-1L),
3726 TEST_c_c (casin, -0x1p-106L, -0x1.000000000000000000000000008p0L, -8.715763992105246878957416200936726072500e-33L, -8.813735870195430252326093249798097405561e-1L),
3727 TEST_c_c (casin, 0x1.000000000000000000000000008p0L, 0x1p-106L, 1.570796326794896565289107467733682961928L, 2.285028863093221674154232933662774454211e-16L),
3728 TEST_c_c (casin, -0x1.000000000000000000000000008p0L, 0x1p-106L, -1.570796326794896565289107467733682961928L, 2.285028863093221674154232933662774454211e-16L),
3729 TEST_c_c (casin, 0x1.000000000000000000000000008p0L, -0x1p-106L, 1.570796326794896565289107467733682961928L, -2.285028863093221674154232933662774454211e-16L),
3730 TEST_c_c (casin, -0x1.000000000000000000000000008p0L, -0x1p-106L, -1.570796326794896565289107467733682961928L, -2.285028863093221674154232933662774454211e-16L),
3731 TEST_c_c (casin, 0x1.fp-1025L, 0x1.000000000000000000000000008p0L, 3.810492908885321743133304375216570658278e-309L, 8.813735870195430252326093249798097405561e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
3732 TEST_c_c (casin, 0x1.fp-1025L, -0x1.000000000000000000000000008p0L, 3.810492908885321743133304375216570658278e-309L, -8.813735870195430252326093249798097405561e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
3733 TEST_c_c (casin, -0x1.fp-1025L, 0x1.000000000000000000000000008p0L, -3.810492908885321743133304375216570658278e-309L, 8.813735870195430252326093249798097405561e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
3734 TEST_c_c (casin, -0x1.fp-1025L, -0x1.000000000000000000000000008p0L, -3.810492908885321743133304375216570658278e-309L, -8.813735870195430252326093249798097405561e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
3735 TEST_c_c (casin, 0x1.000000000000000000000000008p0L, 0x1.fp-1025L, 1.570796326794896619231321691639751442099L, 2.220446049250313080847263336181636063482e-16L),
3736 TEST_c_c (casin, -0x1.000000000000000000000000008p0L, 0x1.fp-1025L, -1.570796326794896619231321691639751442099L, 2.220446049250313080847263336181636063482e-16L),
3737 TEST_c_c (casin, 0x1.000000000000000000000000008p0L, -0x1.fp-1025L, 1.570796326794896619231321691639751442099L, -2.220446049250313080847263336181636063482e-16L),
3738 TEST_c_c (casin, -0x1.000000000000000000000000008p0L, -0x1.fp-1025L, -1.570796326794896619231321691639751442099L, -2.220446049250313080847263336181636063482e-16L),
3739 TEST_c_c (casin, 0.0L, 0x1.000000000000000000000000008p0L, 0.0L, 8.813735870195430252326093249798097405561e-1L),
3740 TEST_c_c (casin, 0.0L, -0x1.000000000000000000000000008p0L, 0.0L, -8.813735870195430252326093249798097405561e-1L),
3741 TEST_c_c (casin, -0.0L, 0x1.000000000000000000000000008p0L, -0.0L, 8.813735870195430252326093249798097405561e-1L),
3742 TEST_c_c (casin, -0.0L, -0x1.000000000000000000000000008p0L, -0.0L, -8.813735870195430252326093249798097405561e-1L),
3743 TEST_c_c (casin, 0x1.000000000000000000000000008p0L, 0.0L, 1.570796326794896619231321691639751442099L, 2.220446049250313080847263336181636063482e-16L),
3744 TEST_c_c (casin, -0x1.000000000000000000000000008p0L, 0.0L, -1.570796326794896619231321691639751442099L, 2.220446049250313080847263336181636063482e-16L),
3745 TEST_c_c (casin, 0x1.000000000000000000000000008p0L, -0.0L, 1.570796326794896619231321691639751442099L, -2.220446049250313080847263336181636063482e-16L),
3746 TEST_c_c (casin, -0x1.000000000000000000000000008p0L, -0.0L, -1.570796326794896619231321691639751442099L, -2.220446049250313080847263336181636063482e-16L),
3747 #endif
3748 #if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 113
3749 TEST_c_c (casin, 0x1p-113L, 0x1.0000000000000000000000000001p0L, 6.809190618832224124185481406981900518193e-35L, 8.813735870195430252326093249797924452120e-1L),
3750 TEST_c_c (casin, 0x1p-113L, -0x1.0000000000000000000000000001p0L, 6.809190618832224124185481406981900518193e-35L, -8.813735870195430252326093249797924452120e-1L),
3751 TEST_c_c (casin, -0x1p-113L, 0x1.0000000000000000000000000001p0L, -6.809190618832224124185481406981900518193e-35L, 8.813735870195430252326093249797924452120e-1L),
3752 TEST_c_c (casin, -0x1p-113L, -0x1.0000000000000000000000000001p0L, -6.809190618832224124185481406981900518193e-35L, -8.813735870195430252326093249797924452120e-1L),
3753 TEST_c_c (casin, 0x1.0000000000000000000000000001p0L, 0x1p-113L, 1.570796326794896614463458507897073960405L, 2.019699255375255198156433710951064632386e-17L),
3754 TEST_c_c (casin, -0x1.0000000000000000000000000001p0L, 0x1p-113L, -1.570796326794896614463458507897073960405L, 2.019699255375255198156433710951064632386e-17L),
3755 TEST_c_c (casin, 0x1.0000000000000000000000000001p0L, -0x1p-113L, 1.570796326794896614463458507897073960405L, -2.019699255375255198156433710951064632386e-17L),
3756 TEST_c_c (casin, -0x1.0000000000000000000000000001p0L, -0x1p-113L, -1.570796326794896614463458507897073960405L, -2.019699255375255198156433710951064632386e-17L),
3757 TEST_c_c (casin, 0x1.fp-16385L, 0x1.0000000000000000000000000001p0L, 5.757683115456107044131264955348448400014e-4933L, 8.813735870195430252326093249797924452120e-1L, UNDERFLOW_EXCEPTION),
3758 TEST_c_c (casin, 0x1.fp-16385L, -0x1.0000000000000000000000000001p0L, 5.757683115456107044131264955348448400014e-4933L, -8.813735870195430252326093249797924452120e-1L, UNDERFLOW_EXCEPTION),
3759 TEST_c_c (casin, -0x1.fp-16385L, 0x1.0000000000000000000000000001p0L, -5.757683115456107044131264955348448400014e-4933L, 8.813735870195430252326093249797924452120e-1L, UNDERFLOW_EXCEPTION),
3760 TEST_c_c (casin, -0x1.fp-16385L, -0x1.0000000000000000000000000001p0L, -5.757683115456107044131264955348448400014e-4933L, -8.813735870195430252326093249797924452120e-1L, UNDERFLOW_EXCEPTION),
3761 TEST_c_c (casin, 0x1.0000000000000000000000000001p0L, 0x1.fp-16385L, 1.570796326794896619231321691639751442099L, 1.962615573354718824241727964954454332780e-17L),
3762 TEST_c_c (casin, -0x1.0000000000000000000000000001p0L, 0x1.fp-16385L, -1.570796326794896619231321691639751442099L, 1.962615573354718824241727964954454332780e-17L),
3763 TEST_c_c (casin, 0x1.0000000000000000000000000001p0L, -0x1.fp-16385L, 1.570796326794896619231321691639751442099L, -1.962615573354718824241727964954454332780e-17L),
3764 TEST_c_c (casin, -0x1.0000000000000000000000000001p0L, -0x1.fp-16385L, -1.570796326794896619231321691639751442099L, -1.962615573354718824241727964954454332780e-17L),
3765 TEST_c_c (casin, 0.0L, 0x1.0000000000000000000000000001p0L, 0.0L, 8.813735870195430252326093249797924452120e-1L),
3766 TEST_c_c (casin, 0.0L, -0x1.0000000000000000000000000001p0L, 0.0L, -8.813735870195430252326093249797924452120e-1L),
3767 TEST_c_c (casin, -0.0L, 0x1.0000000000000000000000000001p0L, -0.0L, 8.813735870195430252326093249797924452120e-1L),
3768 TEST_c_c (casin, -0.0L, -0x1.0000000000000000000000000001p0L, -0.0L, -8.813735870195430252326093249797924452120e-1L),
3769 TEST_c_c (casin, 0x1.0000000000000000000000000001p0L, 0.0L, 1.570796326794896619231321691639751442099L, 1.962615573354718824241727964954454332780e-17L),
3770 TEST_c_c (casin, -0x1.0000000000000000000000000001p0L, 0.0L, -1.570796326794896619231321691639751442099L, 1.962615573354718824241727964954454332780e-17L),
3771 TEST_c_c (casin, 0x1.0000000000000000000000000001p0L, -0.0L, 1.570796326794896619231321691639751442099L, -1.962615573354718824241727964954454332780e-17L),
3772 TEST_c_c (casin, -0x1.0000000000000000000000000001p0L, -0.0L, -1.570796326794896619231321691639751442099L, -1.962615573354718824241727964954454332780e-17L),
3773 #endif
3774
3775 TEST_c_c (casin, 0x1p-23L, 0x0.ffffffp0L, 8.429369953393598499000760938112968755257e-8L, 8.813735448726963984495965873956465777250e-1L),
3776 TEST_c_c (casin, 0x1p-23L, -0x0.ffffffp0L, 8.429369953393598499000760938112968755257e-8L, -8.813735448726963984495965873956465777250e-1L),
3777 TEST_c_c (casin, -0x1p-23L, 0x0.ffffffp0L, -8.429369953393598499000760938112968755257e-8L, 8.813735448726963984495965873956465777250e-1L),
3778 TEST_c_c (casin, -0x1p-23L, -0x0.ffffffp0L, -8.429369953393598499000760938112968755257e-8L, -8.813735448726963984495965873956465777250e-1L),
3779 TEST_c_c (casin, 0x0.ffffffp0L, 0x1p-23L, 1.570357140408705570520377172865353621698L, 2.714321200917194650737217746780928423385e-4L),
3780 TEST_c_c (casin, -0x0.ffffffp0L, 0x1p-23L, -1.570357140408705570520377172865353621698L, 2.714321200917194650737217746780928423385e-4L),
3781 TEST_c_c (casin, 0x0.ffffffp0L, -0x1p-23L, 1.570357140408705570520377172865353621698L, -2.714321200917194650737217746780928423385e-4L),
3782 TEST_c_c (casin, -0x0.ffffffp0L, -0x1p-23L, -1.570357140408705570520377172865353621698L, -2.714321200917194650737217746780928423385e-4L),
3783 TEST_c_c (casin, 0x1.fp-129L, 0x0.ffffffp0L, 2.013062624689288675911339929224634593425e-39L, 8.813735448726938863015878255140556727969e-1L, UNDERFLOW_EXCEPTION_FLOAT),
3784 TEST_c_c (casin, 0x1.fp-129L, -0x0.ffffffp0L, 2.013062624689288675911339929224634593425e-39L, -8.813735448726938863015878255140556727969e-1L, UNDERFLOW_EXCEPTION_FLOAT),
3785 TEST_c_c (casin, -0x1.fp-129L, 0x0.ffffffp0L, -2.013062624689288675911339929224634593425e-39L, 8.813735448726938863015878255140556727969e-1L, UNDERFLOW_EXCEPTION_FLOAT),
3786 TEST_c_c (casin, -0x1.fp-129L, -0x0.ffffffp0L, -2.013062624689288675911339929224634593425e-39L, -8.813735448726938863015878255140556727969e-1L, UNDERFLOW_EXCEPTION_FLOAT),
3787 TEST_c_c (casin, 0x0.ffffffp0L, 0x1.fp-129L, 1.570451059810180415643718442157112705601L, 8.245504387859737323891843603996428534945e-36L),
3788 TEST_c_c (casin, -0x0.ffffffp0L, 0x1.fp-129L, -1.570451059810180415643718442157112705601L, 8.245504387859737323891843603996428534945e-36L),
3789 TEST_c_c (casin, 0x0.ffffffp0L, -0x1.fp-129L, 1.570451059810180415643718442157112705601L, -8.245504387859737323891843603996428534945e-36L),
3790 TEST_c_c (casin, -0x0.ffffffp0L, -0x1.fp-129L, -1.570451059810180415643718442157112705601L, -8.245504387859737323891843603996428534945e-36L),
3791 TEST_c_c (casin, 0.0L, 0x0.ffffffp0L, 0.0L, 8.813735448726938863015878255140556727969e-1L),
3792 TEST_c_c (casin, 0.0L, -0x0.ffffffp0L, 0.0L, -8.813735448726938863015878255140556727969e-1L),
3793 TEST_c_c (casin, -0.0L, 0x0.ffffffp0L, -0.0L, 8.813735448726938863015878255140556727969e-1L),
3794 TEST_c_c (casin, -0.0L, -0x0.ffffffp0L, -0.0L, -8.813735448726938863015878255140556727969e-1L),
3795 TEST_c_c (casin, 0x0.ffffffp0L, 0.0L, 1.570451059810180415643718442157112705601L, 0.0L),
3796 TEST_c_c (casin, -0x0.ffffffp0L, 0.0L, -1.570451059810180415643718442157112705601L, 0.0L),
3797 TEST_c_c (casin, 0x0.ffffffp0L, -0.0L, 1.570451059810180415643718442157112705601L, -0.0L),
3798 TEST_c_c (casin, -0x0.ffffffp0L, -0.0L, -1.570451059810180415643718442157112705601L, -0.0L),
3799 TEST_c_c (casin, 0x1p-23L, 0.5L, 1.066240299940009780479664302917201696886e-7L, 4.812118250596059896127318386463676808798e-1L),
3800 TEST_c_c (casin, 0x1p-23L, -0.5L, 1.066240299940009780479664302917201696886e-7L, -4.812118250596059896127318386463676808798e-1L),
3801 TEST_c_c (casin, -0x1p-23L, 0.5L, -1.066240299940009780479664302917201696886e-7L, 4.812118250596059896127318386463676808798e-1L),
3802 TEST_c_c (casin, -0x1p-23L, -0.5L, -1.066240299940009780479664302917201696886e-7L, -4.812118250596059896127318386463676808798e-1L),
3803 TEST_c_c (casin, 0.5L, 0x1p-23L, 5.235987755982934033165770729745469098254e-1L, 1.376510308240943236356088341381173571841e-7L),
3804 TEST_c_c (casin, -0.5L, 0x1p-23L, -5.235987755982934033165770729745469098254e-1L, 1.376510308240943236356088341381173571841e-7L),
3805 TEST_c_c (casin, 0.5L, -0x1p-23L, 5.235987755982934033165770729745469098254e-1L, -1.376510308240943236356088341381173571841e-7L),
3806 TEST_c_c (casin, -0.5L, -0x1p-23L, -5.235987755982934033165770729745469098254e-1L, -1.376510308240943236356088341381173571841e-7L),
3807 TEST_c_c (casin, 0x1.fp-129L, 0.5L, 2.546345110742945032959687790021055102355e-39L, 4.812118250596034474977589134243684231352e-1L, UNDERFLOW_EXCEPTION_FLOAT),
3808 TEST_c_c (casin, 0x1.fp-129L, -0.5L, 2.546345110742945032959687790021055102355e-39L, -4.812118250596034474977589134243684231352e-1L, UNDERFLOW_EXCEPTION_FLOAT),
3809 TEST_c_c (casin, -0x1.fp-129L, 0.5L, -2.546345110742945032959687790021055102355e-39L, 4.812118250596034474977589134243684231352e-1L, UNDERFLOW_EXCEPTION_FLOAT),
3810 TEST_c_c (casin, -0x1.fp-129L, -0.5L, -2.546345110742945032959687790021055102355e-39L, -4.812118250596034474977589134243684231352e-1L, UNDERFLOW_EXCEPTION_FLOAT),
3811 TEST_c_c (casin, 0.5L, 0x1.fp-129L, 5.235987755982988730771072305465838140329e-1L, 3.287317402534702257036015056278368274737e-39L, UNDERFLOW_EXCEPTION_FLOAT),
3812 TEST_c_c (casin, -0.5L, 0x1.fp-129L, -5.235987755982988730771072305465838140329e-1L, 3.287317402534702257036015056278368274737e-39L, UNDERFLOW_EXCEPTION_FLOAT),
3813 TEST_c_c (casin, 0.5L, -0x1.fp-129L, 5.235987755982988730771072305465838140329e-1L, -3.287317402534702257036015056278368274737e-39L, UNDERFLOW_EXCEPTION_FLOAT),
3814 TEST_c_c (casin, -0.5L, -0x1.fp-129L, -5.235987755982988730771072305465838140329e-1L, -3.287317402534702257036015056278368274737e-39L, UNDERFLOW_EXCEPTION_FLOAT),
3815 TEST_c_c (casin, 0x1p-23L, 0x1p-23L, 1.192092895507806853113684971258850504935e-7L, 1.192092895507818146886315028596704749235e-7L),
3816 TEST_c_c (casin, 0x1p-23L, -0x1p-23L, 1.192092895507806853113684971258850504935e-7L, -1.192092895507818146886315028596704749235e-7L),
3817 TEST_c_c (casin, -0x1p-23L, 0x1p-23L, -1.192092895507806853113684971258850504935e-7L, 1.192092895507818146886315028596704749235e-7L),
3818 TEST_c_c (casin, -0x1p-23L, -0x1p-23L, -1.192092895507806853113684971258850504935e-7L, -1.192092895507818146886315028596704749235e-7L),
3819 /* Bug 15319: underflow exception may be missing. */
3820 TEST_c_c (casin, 0x1.fp-129L, 0x1p-23L, 2.846900380897707329917933005874691056564e-39L, 1.192092895507809676556842485683592032154e-7L, UNDERFLOW_EXCEPTION_OK_FLOAT),
3821 TEST_c_c (casin, 0x1.fp-129L, -0x1p-23L, 2.846900380897707329917933005874691056564e-39L, -1.192092895507809676556842485683592032154e-7L, UNDERFLOW_EXCEPTION_OK_FLOAT),
3822 TEST_c_c (casin, -0x1.fp-129L, 0x1p-23L, -2.846900380897707329917933005874691056564e-39L, 1.192092895507809676556842485683592032154e-7L, UNDERFLOW_EXCEPTION_OK_FLOAT),
3823 TEST_c_c (casin, -0x1.fp-129L, -0x1p-23L, -2.846900380897707329917933005874691056564e-39L, -1.192092895507809676556842485683592032154e-7L, UNDERFLOW_EXCEPTION_OK_FLOAT),
3824 TEST_c_c (casin, 0x1p-23L, 0x1.fp-129L, 1.192092895507815323443157514352519154304e-7L, 2.846900380897747786805634596726756660388e-39L, UNDERFLOW_EXCEPTION_FLOAT),
3825 TEST_c_c (casin, -0x1p-23L, 0x1.fp-129L, -1.192092895507815323443157514352519154304e-7L, 2.846900380897747786805634596726756660388e-39L, UNDERFLOW_EXCEPTION_FLOAT),
3826 TEST_c_c (casin, 0x1p-23L, -0x1.fp-129L, 1.192092895507815323443157514352519154304e-7L, -2.846900380897747786805634596726756660388e-39L, UNDERFLOW_EXCEPTION_FLOAT),
3827 TEST_c_c (casin, -0x1p-23L, -0x1.fp-129L, -1.192092895507815323443157514352519154304e-7L, -2.846900380897747786805634596726756660388e-39L, UNDERFLOW_EXCEPTION_FLOAT),
3828 TEST_c_c (casin, 0.0L, 0x1p-23L, 0.0L, 1.192092895507809676556842485683592032154e-7L),
3829 TEST_c_c (casin, 0.0L, -0x1p-23L, 0.0L, -1.192092895507809676556842485683592032154e-7L),
3830 TEST_c_c (casin, -0.0L, 0x1p-23L, -0.0L, 1.192092895507809676556842485683592032154e-7L),
3831 TEST_c_c (casin, -0.0L, -0x1p-23L, -0.0L, -1.192092895507809676556842485683592032154e-7L),
3832 TEST_c_c (casin, 0x1p-23L, 0.0L, 1.192092895507815323443157514352519154304e-7L, 0.0L),
3833 TEST_c_c (casin, -0x1p-23L, 0.0L, -1.192092895507815323443157514352519154304e-7L, 0.0L),
3834 TEST_c_c (casin, 0x1p-23L, -0.0L, 1.192092895507815323443157514352519154304e-7L, -0.0L),
3835 TEST_c_c (casin, -0x1p-23L, -0.0L, -1.192092895507815323443157514352519154304e-7L, -0.0L),
3836 TEST_c_c (casin, 0x1.fp-129L, 0x1.fp-129L, 2.846900380897727558361783801085126250967e-39L, 2.846900380897727558361783801085126250967e-39L, UNDERFLOW_EXCEPTION_FLOAT),
3837 TEST_c_c (casin, 0x1.fp-129L, -0x1.fp-129L, 2.846900380897727558361783801085126250967e-39L, -2.846900380897727558361783801085126250967e-39L, UNDERFLOW_EXCEPTION_FLOAT),
3838 TEST_c_c (casin, -0x1.fp-129L, 0x1.fp-129L, -2.846900380897727558361783801085126250967e-39L, 2.846900380897727558361783801085126250967e-39L, UNDERFLOW_EXCEPTION_FLOAT),
3839 TEST_c_c (casin, -0x1.fp-129L, -0x1.fp-129L, -2.846900380897727558361783801085126250967e-39L, -2.846900380897727558361783801085126250967e-39L, UNDERFLOW_EXCEPTION_FLOAT),
3840 #ifndef TEST_FLOAT
3841 TEST_c_c (casin, 0x1p-52L, 0x0.fffffffffffff8p0L, 1.570092458683775146551022293016031474627e-16L, 8.813735870195429467279863907910458761820e-1L),
3842 TEST_c_c (casin, 0x1p-52L, -0x0.fffffffffffff8p0L, 1.570092458683775146551022293016031474627e-16L, -8.813735870195429467279863907910458761820e-1L),
3843 TEST_c_c (casin, -0x1p-52L, 0x0.fffffffffffff8p0L, -1.570092458683775146551022293016031474627e-16L, 8.813735870195429467279863907910458761820e-1L),
3844 TEST_c_c (casin, -0x1p-52L, -0x0.fffffffffffff8p0L, -1.570092458683775146551022293016031474627e-16L, -8.813735870195429467279863907910458761820e-1L),
3845 TEST_c_c (casin, 0x0.fffffffffffff8p0L, 0x1p-52L, 1.570796307840326780080580569360500172043L, 1.171456840272878582596796205397918831268e-8L),
3846 TEST_c_c (casin, -0x0.fffffffffffff8p0L, 0x1p-52L, -1.570796307840326780080580569360500172043L, 1.171456840272878582596796205397918831268e-8L),
3847 TEST_c_c (casin, 0x0.fffffffffffff8p0L, -0x1p-52L, 1.570796307840326780080580569360500172043L, -1.171456840272878582596796205397918831268e-8L),
3848 TEST_c_c (casin, -0x0.fffffffffffff8p0L, -0x1p-52L, -1.570796307840326780080580569360500172043L, -1.171456840272878582596796205397918831268e-8L),
3849 TEST_c_c (casin, 0x1.fp-1025L, 0x0.fffffffffffff8p0L, 3.810492908885321954658152505985270452320e-309L, 8.813735870195429467279863907910371604180e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
3850 TEST_c_c (casin, 0x1.fp-1025L, -0x0.fffffffffffff8p0L, 3.810492908885321954658152505985270452320e-309L, -8.813735870195429467279863907910371604180e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
3851 TEST_c_c (casin, -0x1.fp-1025L, 0x0.fffffffffffff8p0L, -3.810492908885321954658152505985270452320e-309L, 8.813735870195429467279863907910371604180e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
3852 TEST_c_c (casin, -0x1.fp-1025L, -0x0.fffffffffffff8p0L, -3.810492908885321954658152505985270452320e-309L, -8.813735870195429467279863907910371604180e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
3853 TEST_c_c (casin, 0x0.fffffffffffff8p0L, 0x1.fp-1025L, 1.570796311893735425383665303776316016594L, 3.616396521699973256461764099945789620604e-301L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
3854 TEST_c_c (casin, -0x0.fffffffffffff8p0L, 0x1.fp-1025L, -1.570796311893735425383665303776316016594L, 3.616396521699973256461764099945789620604e-301L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
3855 TEST_c_c (casin, 0x0.fffffffffffff8p0L, -0x1.fp-1025L, 1.570796311893735425383665303776316016594L, -3.616396521699973256461764099945789620604e-301L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
3856 TEST_c_c (casin, -0x0.fffffffffffff8p0L, -0x1.fp-1025L, -1.570796311893735425383665303776316016594L, -3.616396521699973256461764099945789620604e-301L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
3857 TEST_c_c (casin, 0.0L, 0x0.fffffffffffff8p0L, 0.0L, 8.813735870195429467279863907910371604180e-1L),
3858 TEST_c_c (casin, 0.0L, -0x0.fffffffffffff8p0L, 0.0L, -8.813735870195429467279863907910371604180e-1L),
3859 TEST_c_c (casin, -0.0L, 0x0.fffffffffffff8p0L, -0.0L, 8.813735870195429467279863907910371604180e-1L),
3860 TEST_c_c (casin, -0.0L, -0x0.fffffffffffff8p0L, -0.0L, -8.813735870195429467279863907910371604180e-1L),
3861 TEST_c_c (casin, 0x0.fffffffffffff8p0L, 0.0L, 1.570796311893735425383665303776316016594L, 0.0L),
3862 TEST_c_c (casin, -0x0.fffffffffffff8p0L, 0.0L, -1.570796311893735425383665303776316016594L, 0.0L),
3863 TEST_c_c (casin, 0x0.fffffffffffff8p0L, -0.0L, 1.570796311893735425383665303776316016594L, -0.0L),
3864 TEST_c_c (casin, -0x0.fffffffffffff8p0L, -0.0L, -1.570796311893735425383665303776316016594L, -0.0L),
3865 #endif
3866 TEST_c_c (casin, 0x1p-52L, 0.5L, 1.986027322597818397661816253158024383707e-16L, 4.812118250596034474977589134243772428682e-1L),
3867 TEST_c_c (casin, 0x1p-52L, -0.5L, 1.986027322597818397661816253158024383707e-16L, -4.812118250596034474977589134243772428682e-1L),
3868 TEST_c_c (casin, -0x1p-52L, 0.5L, -1.986027322597818397661816253158024383707e-16L, 4.812118250596034474977589134243772428682e-1L),
3869 TEST_c_c (casin, -0x1p-52L, -0.5L, -1.986027322597818397661816253158024383707e-16L, -4.812118250596034474977589134243772428682e-1L),
3870 TEST_c_c (casin, 0.5L, 0x1p-52L, 5.235987755982988730771072305465648369889e-1L, 2.563950248511418570403591756798643804971e-16L),
3871 TEST_c_c (casin, -0.5L, 0x1p-52L, -5.235987755982988730771072305465648369889e-1L, 2.563950248511418570403591756798643804971e-16L),
3872 TEST_c_c (casin, 0.5L, -0x1p-52L, 5.235987755982988730771072305465648369889e-1L, -2.563950248511418570403591756798643804971e-16L),
3873 TEST_c_c (casin, -0.5L, -0x1p-52L, -5.235987755982988730771072305465648369889e-1L, -2.563950248511418570403591756798643804971e-16L),
3874 #ifndef TEST_FLOAT
3875 TEST_c_c (casin, 0x1.fp-1025L, 0.5L, 4.819934639999230680322935210539402497827e-309L, 4.812118250596034474977589134243684231352e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
3876 TEST_c_c (casin, 0x1.fp-1025L, -0.5L, 4.819934639999230680322935210539402497827e-309L, -4.812118250596034474977589134243684231352e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
3877 TEST_c_c (casin, -0x1.fp-1025L, 0.5L, -4.819934639999230680322935210539402497827e-309L, 4.812118250596034474977589134243684231352e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
3878 TEST_c_c (casin, -0x1.fp-1025L, -0.5L, -4.819934639999230680322935210539402497827e-309L, -4.812118250596034474977589134243684231352e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
3879 TEST_c_c (casin, 0.5L, 0x1.fp-1025L, 5.235987755982988730771072305465838140329e-1L, 6.222508863508420569166420770843207333493e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
3880 TEST_c_c (casin, -0.5L, 0x1.fp-1025L, -5.235987755982988730771072305465838140329e-1L, 6.222508863508420569166420770843207333493e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
3881 TEST_c_c (casin, 0.5L, -0x1.fp-1025L, 5.235987755982988730771072305465838140329e-1L, -6.222508863508420569166420770843207333493e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
3882 TEST_c_c (casin, -0.5L, -0x1.fp-1025L, -5.235987755982988730771072305465838140329e-1L, -6.222508863508420569166420770843207333493e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
3883 #endif
3884 TEST_c_c (casin, 0x1p-52L, 0x1p-52L, 2.220446049250313080847263336181604132852e-16L, 2.220446049250313080847263336181677117148e-16L),
3885 TEST_c_c (casin, 0x1p-52L, -0x1p-52L, 2.220446049250313080847263336181604132852e-16L, -2.220446049250313080847263336181677117148e-16L),
3886 TEST_c_c (casin, -0x1p-52L, 0x1p-52L, -2.220446049250313080847263336181604132852e-16L, 2.220446049250313080847263336181677117148e-16L),
3887 TEST_c_c (casin, -0x1p-52L, -0x1p-52L, -2.220446049250313080847263336181604132852e-16L, -2.220446049250313080847263336181677117148e-16L),
3888 #ifndef TEST_FLOAT
3889 /* Bug 15319: underflow exception may be missing. */
3890 TEST_c_c (casin, 0x1.fp-1025L, 0x1p-52L, 5.388850751072128349671657362289283247603e-309L, 2.220446049250313080847263336181622378926e-16L, UNDERFLOW_EXCEPTION_OK_DOUBLE),
3891 TEST_c_c (casin, 0x1.fp-1025L, -0x1p-52L, 5.388850751072128349671657362289283247603e-309L, -2.220446049250313080847263336181622378926e-16L, UNDERFLOW_EXCEPTION_OK_DOUBLE),
3892 TEST_c_c (casin, -0x1.fp-1025L, 0x1p-52L, -5.388850751072128349671657362289283247603e-309L, 2.220446049250313080847263336181622378926e-16L, UNDERFLOW_EXCEPTION_OK_DOUBLE),
3893 TEST_c_c (casin, -0x1.fp-1025L, -0x1p-52L, -5.388850751072128349671657362289283247603e-309L, -2.220446049250313080847263336181622378926e-16L, UNDERFLOW_EXCEPTION_OK_DOUBLE),
3894 TEST_c_c (casin, 0x1p-52L, 0x1.fp-1025L, 2.220446049250313080847263336181658871074e-16L, 5.388850751072128349671657362289548938458e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
3895 TEST_c_c (casin, -0x1p-52L, 0x1.fp-1025L, -2.220446049250313080847263336181658871074e-16L, 5.388850751072128349671657362289548938458e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
3896 TEST_c_c (casin, 0x1p-52L, -0x1.fp-1025L, 2.220446049250313080847263336181658871074e-16L, -5.388850751072128349671657362289548938458e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
3897 TEST_c_c (casin, -0x1p-52L, -0x1.fp-1025L, -2.220446049250313080847263336181658871074e-16L, -5.388850751072128349671657362289548938458e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
3898 #endif
3899 TEST_c_c (casin, 0.0L, 0x1p-52L, 0.0L, 2.220446049250313080847263336181622378926e-16L),
3900 TEST_c_c (casin, 0.0L, -0x1p-52L, 0.0L, -2.220446049250313080847263336181622378926e-16L),
3901 TEST_c_c (casin, -0.0L, 0x1p-52L, -0.0L, 2.220446049250313080847263336181622378926e-16L),
3902 TEST_c_c (casin, -0.0L, -0x1p-52L, -0.0L, -2.220446049250313080847263336181622378926e-16L),
3903 TEST_c_c (casin, 0x1p-52L, 0.0L, 2.220446049250313080847263336181658871074e-16L, 0.0L),
3904 TEST_c_c (casin, -0x1p-52L, 0.0L, -2.220446049250313080847263336181658871074e-16L, 0.0L),
3905 TEST_c_c (casin, 0x1p-52L, -0.0L, 2.220446049250313080847263336181658871074e-16L, -0.0L),
3906 TEST_c_c (casin, -0x1p-52L, -0.0L, -2.220446049250313080847263336181658871074e-16L, -0.0L),
3907 #ifndef TEST_FLOAT
3908 TEST_c_c (casin, 0x1.fp-1025L, 0x1.fp-1025L, 5.388850751072128349671657362289416093031e-309L, 5.388850751072128349671657362289416093031e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
3909 TEST_c_c (casin, 0x1.fp-1025L, -0x1.fp-1025L, 5.388850751072128349671657362289416093031e-309L, -5.388850751072128349671657362289416093031e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
3910 TEST_c_c (casin, -0x1.fp-1025L, 0x1.fp-1025L, -5.388850751072128349671657362289416093031e-309L, 5.388850751072128349671657362289416093031e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
3911 TEST_c_c (casin, -0x1.fp-1025L, -0x1.fp-1025L, -5.388850751072128349671657362289416093031e-309L, -5.388850751072128349671657362289416093031e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
3912 #endif
3913 #if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 64
3914 TEST_c_c (casin, 0x1p-63L, 0x0.ffffffffffffffffp0L, 7.666467083416870407402049869781566856442e-20L, 8.813735870195430251942769895627079569937e-1L),
3915 TEST_c_c (casin, 0x1p-63L, -0x0.ffffffffffffffffp0L, 7.666467083416870407402049869781566856442e-20L, -8.813735870195430251942769895627079569937e-1L),
3916 TEST_c_c (casin, -0x1p-63L, 0x0.ffffffffffffffffp0L, -7.666467083416870407402049869781566856442e-20L, 8.813735870195430251942769895627079569937e-1L),
3917 TEST_c_c (casin, -0x1p-63L, -0x0.ffffffffffffffffp0L, -7.666467083416870407402049869781566856442e-20L, -8.813735870195430251942769895627079569937e-1L),
3918 TEST_c_c (casin, 0x0.ffffffffffffffffp0L, 0x1p-63L, 1.570796326376055842114524927965556247908L, 2.588578361325995866221775673638805081337e-10L),
3919 TEST_c_c (casin, -0x0.ffffffffffffffffp0L, 0x1p-63L, -1.570796326376055842114524927965556247908L, 2.588578361325995866221775673638805081337e-10L),
3920 TEST_c_c (casin, 0x0.ffffffffffffffffp0L, -0x1p-63L, 1.570796326376055842114524927965556247908L, -2.588578361325995866221775673638805081337e-10L),
3921 TEST_c_c (casin, -0x0.ffffffffffffffffp0L, -0x1p-63L, -1.570796326376055842114524927965556247908L, -2.588578361325995866221775673638805081337e-10L),
3922 # if LDBL_MIN_EXP <= -16381
3923 TEST_c_c (casin, 0x1.fp-16385L, 0x0.ffffffffffffffffp0L, 5.757683115456107044287327268904964422212e-4933L, 8.813735870195430251942769895627079569917e-1L, UNDERFLOW_EXCEPTION),
3924 TEST_c_c (casin, 0x1.fp-16385L, -0x0.ffffffffffffffffp0L, 5.757683115456107044287327268904964422212e-4933L, -8.813735870195430251942769895627079569917e-1L, UNDERFLOW_EXCEPTION),
3925 TEST_c_c (casin, -0x1.fp-16385L, 0x0.ffffffffffffffffp0L, -5.757683115456107044287327268904964422212e-4933L, 8.813735870195430251942769895627079569917e-1L, UNDERFLOW_EXCEPTION),
3926 TEST_c_c (casin, -0x1.fp-16385L, -0x0.ffffffffffffffffp0L, -5.757683115456107044287327268904964422212e-4933L, -8.813735870195430251942769895627079569917e-1L, UNDERFLOW_EXCEPTION),
3927 TEST_c_c (casin, 0x0.ffffffffffffffffp0L, 0x1.fp-16385L, 1.570796326465624365239962068302568888898L, 2.472906068161537187835415298076415423459e-4923L),
3928 TEST_c_c (casin, -0x0.ffffffffffffffffp0L, 0x1.fp-16385L, -1.570796326465624365239962068302568888898L, 2.472906068161537187835415298076415423459e-4923L),
3929 TEST_c_c (casin, 0x0.ffffffffffffffffp0L, -0x1.fp-16385L, 1.570796326465624365239962068302568888898L, -2.472906068161537187835415298076415423459e-4923L),
3930 TEST_c_c (casin, -0x0.ffffffffffffffffp0L, -0x1.fp-16385L, -1.570796326465624365239962068302568888898L, -2.472906068161537187835415298076415423459e-4923L),
3931 # endif
3932 TEST_c_c (casin, 0.0L, 0x0.ffffffffffffffffp0L, 0.0L, 8.813735870195430251942769895627079569917e-1L),
3933 TEST_c_c (casin, 0.0L, -0x0.ffffffffffffffffp0L, 0.0L, -8.813735870195430251942769895627079569917e-1L),
3934 TEST_c_c (casin, -0.0L, 0x0.ffffffffffffffffp0L, -0.0L, 8.813735870195430251942769895627079569917e-1L),
3935 TEST_c_c (casin, -0.0L, -0x0.ffffffffffffffffp0L, -0.0L, -8.813735870195430251942769895627079569917e-1L),
3936 TEST_c_c (casin, 0x0.ffffffffffffffffp0L, 0.0L, 1.570796326465624365239962068302568888898L, 0.0L),
3937 TEST_c_c (casin, -0x0.ffffffffffffffffp0L, 0.0L, -1.570796326465624365239962068302568888898L, 0.0L),
3938 TEST_c_c (casin, 0x0.ffffffffffffffffp0L, -0.0L, 1.570796326465624365239962068302568888898L, -0.0L),
3939 TEST_c_c (casin, -0x0.ffffffffffffffffp0L, -0.0L, -1.570796326465624365239962068302568888898L, -0.0L),
3940 #endif
3941 TEST_c_c (casin, 0x1p-63L, 0.5L, 9.697399036122160144833087173623140436413e-20L, 4.812118250596034474977589134243684231373e-1L),
3942 TEST_c_c (casin, 0x1p-63L, -0.5L, 9.697399036122160144833087173623140436413e-20L, -4.812118250596034474977589134243684231373e-1L),
3943 TEST_c_c (casin, -0x1p-63L, 0.5L, -9.697399036122160144833087173623140436413e-20L, 4.812118250596034474977589134243684231373e-1L),
3944 TEST_c_c (casin, -0x1p-63L, -0.5L, -9.697399036122160144833087173623140436413e-20L, -4.812118250596034474977589134243684231373e-1L),
3945 TEST_c_c (casin, 0.5L, 0x1p-63L, 5.235987755982988730771072305465838140283e-1L, 1.251928832280966098829878787499365228659e-19L),
3946 TEST_c_c (casin, -0.5L, 0x1p-63L, -5.235987755982988730771072305465838140283e-1L, 1.251928832280966098829878787499365228659e-19L),
3947 TEST_c_c (casin, 0.5L, -0x1p-63L, 5.235987755982988730771072305465838140283e-1L, -1.251928832280966098829878787499365228659e-19L),
3948 TEST_c_c (casin, -0.5L, -0x1p-63L, -5.235987755982988730771072305465838140283e-1L, -1.251928832280966098829878787499365228659e-19L),
3949 #if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
3950 TEST_c_c (casin, 0x1.fp-16385L, 0.5L, 7.282957076134209141226696333885150260319e-4933L, 4.812118250596034474977589134243684231352e-1L, UNDERFLOW_EXCEPTION),
3951 TEST_c_c (casin, 0x1.fp-16385L, -0.5L, 7.282957076134209141226696333885150260319e-4933L, -4.812118250596034474977589134243684231352e-1L, UNDERFLOW_EXCEPTION),
3952 TEST_c_c (casin, -0x1.fp-16385L, 0.5L, -7.282957076134209141226696333885150260319e-4933L, 4.812118250596034474977589134243684231352e-1L, UNDERFLOW_EXCEPTION),
3953 TEST_c_c (casin, -0x1.fp-16385L, -0.5L, -7.282957076134209141226696333885150260319e-4933L, -4.812118250596034474977589134243684231352e-1L, UNDERFLOW_EXCEPTION),
3954 TEST_c_c (casin, 0.5L, 0x1.fp-16385L, 5.235987755982988730771072305465838140329e-1L, 9.402257155670418112159334875199821342890e-4933L, UNDERFLOW_EXCEPTION),
3955 TEST_c_c (casin, -0.5L, 0x1.fp-16385L, -5.235987755982988730771072305465838140329e-1L, 9.402257155670418112159334875199821342890e-4933L, UNDERFLOW_EXCEPTION),
3956 TEST_c_c (casin, 0.5L, -0x1.fp-16385L, 5.235987755982988730771072305465838140329e-1L, -9.402257155670418112159334875199821342890e-4933L, UNDERFLOW_EXCEPTION),
3957 TEST_c_c (casin, -0.5L, -0x1.fp-16385L, -5.235987755982988730771072305465838140329e-1L, -9.402257155670418112159334875199821342890e-4933L, UNDERFLOW_EXCEPTION),
3958 #endif
3959 TEST_c_c (casin, 0x1p-63L, 0x1p-63L, 1.084202172485504434007452800869941711422e-19L, 1.084202172485504434007452800869941711430e-19L),
3960 TEST_c_c (casin, 0x1p-63L, -0x1p-63L, 1.084202172485504434007452800869941711422e-19L, -1.084202172485504434007452800869941711430e-19L),
3961 TEST_c_c (casin, -0x1p-63L, 0x1p-63L, -1.084202172485504434007452800869941711422e-19L, 1.084202172485504434007452800869941711430e-19L),
3962 TEST_c_c (casin, -0x1p-63L, -0x1p-63L, -1.084202172485504434007452800869941711422e-19L, -1.084202172485504434007452800869941711430e-19L),
3963 #if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
3964 TEST_c_c (casin, 0x1.fp-16385L, 0x1p-63L, 8.142593549724601460479922838826119584369e-4933L, 1.084202172485504434007452800869941711424e-19L, UNDERFLOW_EXCEPTION),
3965 TEST_c_c (casin, 0x1.fp-16385L, -0x1p-63L, 8.142593549724601460479922838826119584369e-4933L, -1.084202172485504434007452800869941711424e-19L, UNDERFLOW_EXCEPTION),
3966 TEST_c_c (casin, -0x1.fp-16385L, 0x1p-63L, -8.142593549724601460479922838826119584369e-4933L, 1.084202172485504434007452800869941711424e-19L, UNDERFLOW_EXCEPTION),
3967 TEST_c_c (casin, -0x1.fp-16385L, -0x1p-63L, -8.142593549724601460479922838826119584369e-4933L, -1.084202172485504434007452800869941711424e-19L, UNDERFLOW_EXCEPTION),
3968 TEST_c_c (casin, 0x1p-63L, 0x1.fp-16385L, 1.084202172485504434007452800869941711428e-19L, 8.142593549724601460479922838826119584465e-4933L, UNDERFLOW_EXCEPTION),
3969 TEST_c_c (casin, -0x1p-63L, 0x1.fp-16385L, -1.084202172485504434007452800869941711428e-19L, 8.142593549724601460479922838826119584465e-4933L, UNDERFLOW_EXCEPTION),
3970 TEST_c_c (casin, 0x1p-63L, -0x1.fp-16385L, 1.084202172485504434007452800869941711428e-19L, -8.142593549724601460479922838826119584465e-4933L, UNDERFLOW_EXCEPTION),
3971 TEST_c_c (casin, -0x1p-63L, -0x1.fp-16385L, -1.084202172485504434007452800869941711428e-19L, -8.142593549724601460479922838826119584465e-4933L, UNDERFLOW_EXCEPTION),
3972 #endif
3973 TEST_c_c (casin, 0.0L, 0x1p-63L, 0.0L, 1.084202172485504434007452800869941711424e-19L),
3974 TEST_c_c (casin, 0.0L, -0x1p-63L, 0.0L, -1.084202172485504434007452800869941711424e-19L),
3975 TEST_c_c (casin, -0.0L, 0x1p-63L, -0.0L, 1.084202172485504434007452800869941711424e-19L),
3976 TEST_c_c (casin, -0.0L, -0x1p-63L, -0.0L, -1.084202172485504434007452800869941711424e-19L),
3977 TEST_c_c (casin, 0x1p-63L, 0.0L, 1.084202172485504434007452800869941711428e-19L, 0.0L),
3978 TEST_c_c (casin, -0x1p-63L, 0.0L, -1.084202172485504434007452800869941711428e-19L, 0.0L),
3979 TEST_c_c (casin, 0x1p-63L, -0.0L, 1.084202172485504434007452800869941711428e-19L, -0.0L),
3980 TEST_c_c (casin, -0x1p-63L, -0.0L, -1.084202172485504434007452800869941711428e-19L, -0.0L),
3981 #if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
3982 TEST_c_c (casin, 0x1.fp-16385L, 0x1.fp-16385L, 8.142593549724601460479922838826119584417e-4933L, 8.142593549724601460479922838826119584417e-4933L, UNDERFLOW_EXCEPTION),
3983 TEST_c_c (casin, 0x1.fp-16385L, -0x1.fp-16385L, 8.142593549724601460479922838826119584417e-4933L, -8.142593549724601460479922838826119584417e-4933L, UNDERFLOW_EXCEPTION),
3984 TEST_c_c (casin, -0x1.fp-16385L, 0x1.fp-16385L, -8.142593549724601460479922838826119584417e-4933L, 8.142593549724601460479922838826119584417e-4933L, UNDERFLOW_EXCEPTION),
3985 TEST_c_c (casin, -0x1.fp-16385L, -0x1.fp-16385L, -8.142593549724601460479922838826119584417e-4933L, -8.142593549724601460479922838826119584417e-4933L, UNDERFLOW_EXCEPTION),
3986 #endif
3987 #if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 106
3988 TEST_c_c (casin, 0x1p-105L, 0x0.ffffffffffffffffffffffffffcp0L, 1.743152798421049375791483240187377443526e-32L, 8.813735870195430252326093249797835932642e-1L),
3989 TEST_c_c (casin, 0x1p-105L, -0x0.ffffffffffffffffffffffffffcp0L, 1.743152798421049375791483240187377443526e-32L, -8.813735870195430252326093249797835932642e-1L),
3990 TEST_c_c (casin, -0x1p-105L, 0x0.ffffffffffffffffffffffffffcp0L, -1.743152798421049375791483240187377443526e-32L, 8.813735870195430252326093249797835932642e-1L),
3991 TEST_c_c (casin, -0x1p-105L, -0x0.ffffffffffffffffffffffffffcp0L, -1.743152798421049375791483240187377443526e-32L, -8.813735870195430252326093249797835932642e-1L),
3992 TEST_c_c (casin, 0x0.ffffffffffffffffffffffffffcp0L, 0x1p-105L, 1.570796326794896419512475791677915736035L, 1.234330349600789959989661887846005659983e-16L),
3993 TEST_c_c (casin, -0x0.ffffffffffffffffffffffffffcp0L, 0x1p-105L, -1.570796326794896419512475791677915736035L, 1.234330349600789959989661887846005659983e-16L),
3994 TEST_c_c (casin, 0x0.ffffffffffffffffffffffffffcp0L, -0x1p-105L, 1.570796326794896419512475791677915736035L, -1.234330349600789959989661887846005659983e-16L),
3995 TEST_c_c (casin, -0x0.ffffffffffffffffffffffffffcp0L, -0x1p-105L, -1.570796326794896419512475791677915736035L, -1.234330349600789959989661887846005659983e-16L),
3996 TEST_c_c (casin, 0x1.fp-1025L, 0x0.ffffffffffffffffffffffffffcp0L, 3.810492908885321743133304375216641110205e-309L, 8.813735870195430252326093249797835932642e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
3997 TEST_c_c (casin, 0x1.fp-1025L, -0x0.ffffffffffffffffffffffffffcp0L, 3.810492908885321743133304375216641110205e-309L, -8.813735870195430252326093249797835932642e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
3998 TEST_c_c (casin, -0x1.fp-1025L, 0x0.ffffffffffffffffffffffffffcp0L, -3.810492908885321743133304375216641110205e-309L, 8.813735870195430252326093249797835932642e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
3999 TEST_c_c (casin, -0x1.fp-1025L, -0x0.ffffffffffffffffffffffffffcp0L, -3.810492908885321743133304375216641110205e-309L, -8.813735870195430252326093249797835932642e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
4000 TEST_c_c (casin, 0x0.ffffffffffffffffffffffffffcp0L, 0x1.fp-1025L, 1.570796326794896462222075823262245502760L, 3.432186888910770473784103112009399360940e-293L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
4001 TEST_c_c (casin, -0x0.ffffffffffffffffffffffffffcp0L, 0x1.fp-1025L, -1.570796326794896462222075823262245502760L, 3.432186888910770473784103112009399360940e-293L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
4002 TEST_c_c (casin, 0x0.ffffffffffffffffffffffffffcp0L, -0x1.fp-1025L, 1.570796326794896462222075823262245502760L, -3.432186888910770473784103112009399360940e-293L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
4003 TEST_c_c (casin, -0x0.ffffffffffffffffffffffffffcp0L, -0x1.fp-1025L, -1.570796326794896462222075823262245502760L, -3.432186888910770473784103112009399360940e-293L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
4004 TEST_c_c (casin, 0.0L, 0x0.ffffffffffffffffffffffffffcp0L, 0.0L, 8.813735870195430252326093249797835932642e-1L),
4005 TEST_c_c (casin, 0.0L, -0x0.ffffffffffffffffffffffffffcp0L, 0.0L, -8.813735870195430252326093249797835932642e-1L),
4006 TEST_c_c (casin, -0.0L, 0x0.ffffffffffffffffffffffffffcp0L, -0.0L, 8.813735870195430252326093249797835932642e-1L),
4007 TEST_c_c (casin, -0.0L, -0x0.ffffffffffffffffffffffffffcp0L, -0.0L, -8.813735870195430252326093249797835932642e-1L),
4008 TEST_c_c (casin, 0x0.ffffffffffffffffffffffffffcp0L, 0.0L, 1.570796326794896462222075823262245502760L, 0.0L),
4009 TEST_c_c (casin, -0x0.ffffffffffffffffffffffffffcp0L, 0.0L, -1.570796326794896462222075823262245502760L, 0.0L),
4010 TEST_c_c (casin, 0x0.ffffffffffffffffffffffffffcp0L, -0.0L, 1.570796326794896462222075823262245502760L, -0.0L),
4011 TEST_c_c (casin, -0x0.ffffffffffffffffffffffffffcp0L, -0.0L, -1.570796326794896462222075823262245502760L, -0.0L),
4012 #endif
4013 TEST_c_c (casin, 0x1p-105L, 0.5L, 2.204933261082751447436996198490110245167e-32L, 4.812118250596034474977589134243684231352e-1L),
4014 TEST_c_c (casin, 0x1p-105L, -0.5L, 2.204933261082751447436996198490110245167e-32L, -4.812118250596034474977589134243684231352e-1L),
4015 TEST_c_c (casin, -0x1p-105L, 0.5L, -2.204933261082751447436996198490110245167e-32L, 4.812118250596034474977589134243684231352e-1L),
4016 TEST_c_c (casin, -0x1p-105L, -0.5L, -2.204933261082751447436996198490110245167e-32L, -4.812118250596034474977589134243684231352e-1L),
4017 TEST_c_c (casin, 0.5L, 0x1p-105L, 5.235987755982988730771072305465838140329e-1L, 2.846556599890768890940941645338546615370e-32L),
4018 TEST_c_c (casin, -0.5L, 0x1p-105L, -5.235987755982988730771072305465838140329e-1L, 2.846556599890768890940941645338546615370e-32L),
4019 TEST_c_c (casin, 0.5L, -0x1p-105L, 5.235987755982988730771072305465838140329e-1L, -2.846556599890768890940941645338546615370e-32L),
4020 TEST_c_c (casin, -0.5L, -0x1p-105L, -5.235987755982988730771072305465838140329e-1L, -2.846556599890768890940941645338546615370e-32L),
4021 TEST_c_c (casin, 0x1p-105L, 0x1p-105L, 2.465190328815661891911651766508706967729e-32L, 2.465190328815661891911651766508706967729e-32L),
4022 TEST_c_c (casin, 0x1p-105L, -0x1p-105L, 2.465190328815661891911651766508706967729e-32L, -2.465190328815661891911651766508706967729e-32L),
4023 TEST_c_c (casin, -0x1p-105L, 0x1p-105L, -2.465190328815661891911651766508706967729e-32L, 2.465190328815661891911651766508706967729e-32L),
4024 TEST_c_c (casin, -0x1p-105L, -0x1p-105L, -2.465190328815661891911651766508706967729e-32L, -2.465190328815661891911651766508706967729e-32L),
4025 #ifndef TEST_FLOAT
4026 /* Bug 15319: underflow exception may be missing. */
4027 TEST_c_c (casin, 0x1.fp-1025L, 0x1p-105L, 5.388850751072128349671657362289416093031e-309L, 2.465190328815661891911651766508706967729e-32L, UNDERFLOW_EXCEPTION_OK_DOUBLE),
4028 TEST_c_c (casin, 0x1.fp-1025L, -0x1p-105L, 5.388850751072128349671657362289416093031e-309L, -2.465190328815661891911651766508706967729e-32L, UNDERFLOW_EXCEPTION_OK_DOUBLE),
4029 TEST_c_c (casin, -0x1.fp-1025L, 0x1p-105L, -5.388850751072128349671657362289416093031e-309L, 2.465190328815661891911651766508706967729e-32L, UNDERFLOW_EXCEPTION_OK_DOUBLE),
4030 TEST_c_c (casin, -0x1.fp-1025L, -0x1p-105L, -5.388850751072128349671657362289416093031e-309L, -2.465190328815661891911651766508706967729e-32L, UNDERFLOW_EXCEPTION_OK_DOUBLE),
4031 TEST_c_c (casin, 0x1p-105L, 0x1.fp-1025L, 2.465190328815661891911651766508706967729e-32L, 5.388850751072128349671657362289416093031e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
4032 TEST_c_c (casin, -0x1p-105L, 0x1.fp-1025L, -2.465190328815661891911651766508706967729e-32L, 5.388850751072128349671657362289416093031e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
4033 TEST_c_c (casin, 0x1p-105L, -0x1.fp-1025L, 2.465190328815661891911651766508706967729e-32L, -5.388850751072128349671657362289416093031e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
4034 TEST_c_c (casin, -0x1p-105L, -0x1.fp-1025L, -2.465190328815661891911651766508706967729e-32L, -5.388850751072128349671657362289416093031e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
4035 #endif
4036 TEST_c_c (casin, 0.0L, 0x1p-105L, 0.0L, 2.465190328815661891911651766508706967729e-32L),
4037 TEST_c_c (casin, 0.0L, -0x1p-105L, 0.0L, -2.465190328815661891911651766508706967729e-32L),
4038 TEST_c_c (casin, -0.0L, 0x1p-105L, -0.0L, 2.465190328815661891911651766508706967729e-32L),
4039 TEST_c_c (casin, -0.0L, -0x1p-105L, -0.0L, -2.465190328815661891911651766508706967729e-32L),
4040 TEST_c_c (casin, 0x1p-105L, 0.0L, 2.465190328815661891911651766508706967729e-32L, 0.0L),
4041 TEST_c_c (casin, -0x1p-105L, 0.0L, -2.465190328815661891911651766508706967729e-32L, 0.0L),
4042 TEST_c_c (casin, 0x1p-105L, -0.0L, 2.465190328815661891911651766508706967729e-32L, -0.0L),
4043 TEST_c_c (casin, -0x1p-105L, -0.0L, -2.465190328815661891911651766508706967729e-32L, -0.0L),
4044 #if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 113
4045 TEST_c_c (casin, 0x1p-112L, 0x0.ffffffffffffffffffffffffffff8p0L, 1.361838123766444824837096281396380300349e-34L, 8.813735870195430252326093249797922409363e-1L),
4046 TEST_c_c (casin, 0x1p-112L, -0x0.ffffffffffffffffffffffffffff8p0L, 1.361838123766444824837096281396380300349e-34L, -8.813735870195430252326093249797922409363e-1L),
4047 TEST_c_c (casin, -0x1p-112L, 0x0.ffffffffffffffffffffffffffff8p0L, -1.361838123766444824837096281396380300349e-34L, 8.813735870195430252326093249797922409363e-1L),
4048 TEST_c_c (casin, -0x1p-112L, -0x0.ffffffffffffffffffffffffffff8p0L, -1.361838123766444824837096281396380300349e-34L, -8.813735870195430252326093249797922409363e-1L),
4049 TEST_c_c (casin, 0x0.ffffffffffffffffffffffffffff8p0L, 0x1p-112L, 1.570796326794896601578502908312986698624L, 1.091004200533850618345330909857103457781e-17L),
4050 TEST_c_c (casin, -0x0.ffffffffffffffffffffffffffff8p0L, 0x1p-112L, -1.570796326794896601578502908312986698624L, 1.091004200533850618345330909857103457781e-17L),
4051 TEST_c_c (casin, 0x0.ffffffffffffffffffffffffffff8p0L, -0x1p-112L, 1.570796326794896601578502908312986698624L, -1.091004200533850618345330909857103457781e-17L),
4052 TEST_c_c (casin, -0x0.ffffffffffffffffffffffffffff8p0L, -0x1p-112L, -1.570796326794896601578502908312986698624L, -1.091004200533850618345330909857103457781e-17L),
4053 TEST_c_c (casin, 0x1.fp-16385L, 0x0.ffffffffffffffffffffffffffff8p0L, 5.757683115456107044131264955348449231681e-4933L, 8.813735870195430252326093249797922409363e-1L, UNDERFLOW_EXCEPTION),
4054 TEST_c_c (casin, 0x1.fp-16385L, -0x0.ffffffffffffffffffffffffffff8p0L, 5.757683115456107044131264955348449231681e-4933L, -8.813735870195430252326093249797922409363e-1L, UNDERFLOW_EXCEPTION),
4055 TEST_c_c (casin, -0x1.fp-16385L, 0x0.ffffffffffffffffffffffffffff8p0L, -5.757683115456107044131264955348449231681e-4933L, 8.813735870195430252326093249797922409363e-1L, UNDERFLOW_EXCEPTION),
4056 TEST_c_c (casin, -0x1.fp-16385L, -0x0.ffffffffffffffffffffffffffff8p0L, -5.757683115456107044131264955348449231681e-4933L, -8.813735870195430252326093249797922409363e-1L, UNDERFLOW_EXCEPTION),
4057 TEST_c_c (casin, 0x0.ffffffffffffffffffffffffffff8p0L, 0x1.fp-16385L, 1.570796326794896605353533883825294686803L, 5.867357004219059108790368268900490184505e-4916L),
4058 TEST_c_c (casin, -0x0.ffffffffffffffffffffffffffff8p0L, 0x1.fp-16385L, -1.570796326794896605353533883825294686803L, 5.867357004219059108790368268900490184505e-4916L),
4059 TEST_c_c (casin, 0x0.ffffffffffffffffffffffffffff8p0L, -0x1.fp-16385L, 1.570796326794896605353533883825294686803L, -5.867357004219059108790368268900490184505e-4916L),
4060 TEST_c_c (casin, -0x0.ffffffffffffffffffffffffffff8p0L, -0x1.fp-16385L, -1.570796326794896605353533883825294686803L, -5.867357004219059108790368268900490184505e-4916L),
4061 TEST_c_c (casin, 0.0L, 0x0.ffffffffffffffffffffffffffff8p0L, 0.0L, 8.813735870195430252326093249797922409363e-1L),
4062 TEST_c_c (casin, 0.0L, -0x0.ffffffffffffffffffffffffffff8p0L, 0.0L, -8.813735870195430252326093249797922409363e-1L),
4063 TEST_c_c (casin, -0.0L, 0x0.ffffffffffffffffffffffffffff8p0L, -0.0L, 8.813735870195430252326093249797922409363e-1L),
4064 TEST_c_c (casin, -0.0L, -0x0.ffffffffffffffffffffffffffff8p0L, -0.0L, -8.813735870195430252326093249797922409363e-1L),
4065 TEST_c_c (casin, 0x0.ffffffffffffffffffffffffffff8p0L, 0.0L, 1.570796326794896605353533883825294686803L, 0.0L),
4066 TEST_c_c (casin, -0x0.ffffffffffffffffffffffffffff8p0L, 0.0L, -1.570796326794896605353533883825294686803L, 0.0L),
4067 TEST_c_c (casin, 0x0.ffffffffffffffffffffffffffff8p0L, -0.0L, 1.570796326794896605353533883825294686803L, -0.0L),
4068 TEST_c_c (casin, -0x0.ffffffffffffffffffffffffffff8p0L, -0.0L, -1.570796326794896605353533883825294686803L, -0.0L),
4069 #endif
4070 TEST_c_c (casin, 0x1p-112L, 0.5L, 1.722604110220899568310153280070398629037e-34L, 4.812118250596034474977589134243684231352e-1L),
4071 TEST_c_c (casin, 0x1p-112L, -0.5L, 1.722604110220899568310153280070398629037e-34L, -4.812118250596034474977589134243684231352e-1L),
4072 TEST_c_c (casin, -0x1p-112L, 0.5L, -1.722604110220899568310153280070398629037e-34L, 4.812118250596034474977589134243684231352e-1L),
4073 TEST_c_c (casin, -0x1p-112L, -0.5L, -1.722604110220899568310153280070398629037e-34L, -4.812118250596034474977589134243684231352e-1L),
4074 TEST_c_c (casin, 0.5L, 0x1p-112L, 5.235987755982988730771072305465838140329e-1L, 2.223872343664663196047610660420739543258e-34L),
4075 TEST_c_c (casin, -0.5L, 0x1p-112L, -5.235987755982988730771072305465838140329e-1L, 2.223872343664663196047610660420739543258e-34L),
4076 TEST_c_c (casin, 0.5L, -0x1p-112L, 5.235987755982988730771072305465838140329e-1L, -2.223872343664663196047610660420739543258e-34L),
4077 TEST_c_c (casin, -0.5L, -0x1p-112L, -5.235987755982988730771072305465838140329e-1L, -2.223872343664663196047610660420739543258e-34L),
4078 TEST_c_c (casin, 0x1p-112L, 0x1p-112L, 1.925929944387235853055977942584927318538e-34L, 1.925929944387235853055977942584927318538e-34L),
4079 TEST_c_c (casin, 0x1p-112L, -0x1p-112L, 1.925929944387235853055977942584927318538e-34L, -1.925929944387235853055977942584927318538e-34L),
4080 TEST_c_c (casin, -0x1p-112L, 0x1p-112L, -1.925929944387235853055977942584927318538e-34L, 1.925929944387235853055977942584927318538e-34L),
4081 TEST_c_c (casin, -0x1p-112L, -0x1p-112L, -1.925929944387235853055977942584927318538e-34L, -1.925929944387235853055977942584927318538e-34L),
4082 #if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
4083 TEST_c_c (casin, 0x1.fp-16385L, 0x1p-112L, 8.142593549724601460479922838826119584417e-4933L, 1.925929944387235853055977942584927318538e-34L, UNDERFLOW_EXCEPTION),
4084 TEST_c_c (casin, 0x1.fp-16385L, -0x1p-112L, 8.142593549724601460479922838826119584417e-4933L, -1.925929944387235853055977942584927318538e-34L, UNDERFLOW_EXCEPTION),
4085 TEST_c_c (casin, -0x1.fp-16385L, 0x1p-112L, -8.142593549724601460479922838826119584417e-4933L, 1.925929944387235853055977942584927318538e-34L, UNDERFLOW_EXCEPTION),
4086 TEST_c_c (casin, -0x1.fp-16385L, -0x1p-112L, -8.142593549724601460479922838826119584417e-4933L, -1.925929944387235853055977942584927318538e-34L, UNDERFLOW_EXCEPTION),
4087 TEST_c_c (casin, 0x1p-112L, 0x1.fp-16385L, 1.925929944387235853055977942584927318538e-34L, 8.142593549724601460479922838826119584417e-4933L, UNDERFLOW_EXCEPTION),
4088 TEST_c_c (casin, -0x1p-112L, 0x1.fp-16385L, -1.925929944387235853055977942584927318538e-34L, 8.142593549724601460479922838826119584417e-4933L, UNDERFLOW_EXCEPTION),
4089 TEST_c_c (casin, 0x1p-112L, -0x1.fp-16385L, 1.925929944387235853055977942584927318538e-34L, -8.142593549724601460479922838826119584417e-4933L, UNDERFLOW_EXCEPTION),
4090 TEST_c_c (casin, -0x1p-112L, -0x1.fp-16385L, -1.925929944387235853055977942584927318538e-34L, -8.142593549724601460479922838826119584417e-4933L, UNDERFLOW_EXCEPTION),
4091 #endif
4092 TEST_c_c (casin, 0.0L, 0x1p-112L, 0.0L, 1.925929944387235853055977942584927318538e-34L),
4093 TEST_c_c (casin, 0.0L, -0x1p-112L, 0.0L, -1.925929944387235853055977942584927318538e-34L),
4094 TEST_c_c (casin, -0.0L, 0x1p-112L, -0.0L, 1.925929944387235853055977942584927318538e-34L),
4095 TEST_c_c (casin, -0.0L, -0x1p-112L, -0.0L, -1.925929944387235853055977942584927318538e-34L),
4096 TEST_c_c (casin, 0x1p-112L, 0.0L, 1.925929944387235853055977942584927318538e-34L, 0.0L),
4097 TEST_c_c (casin, -0x1p-112L, 0.0L, -1.925929944387235853055977942584927318538e-34L, 0.0L),
4098 TEST_c_c (casin, 0x1p-112L, -0.0L, 1.925929944387235853055977942584927318538e-34L, -0.0L),
4099 TEST_c_c (casin, -0x1p-112L, -0.0L, -1.925929944387235853055977942584927318538e-34L, -0.0L),
4100
4101 TEST_c_c (casin, 0.75L, 1.25L, 0.453276177638793913448921196101971749L, 1.13239363160530819522266333696834467L),
4102 TEST_c_c (casin, -2, -3, -0.57065278432109940071028387968566963L, -1.9833870299165354323470769028940395L),
4103 END_DATA (casin)
4104 };
4105
4106 static void
4107 casin_test (void)
4108 {
4109 errno = 0;
4110 FUNC(casin) (BUILD_COMPLEX (0.7L, 1.2L));
4111 if (errno == ENOSYS)
4112 /* Function not implemented. */
4113 return;
4114
4115 START (casin);
4116 RUN_TEST_LOOP_c_c (casin, casin_test_data, );
4117 END (casin, complex);
4118 }
4119
4120
4121 static const struct test_c_c_data casinh_test_data[] =
4122 {
4123 START_DATA (casinh),
4124 TEST_c_c (casinh, 0, 0, 0.0, 0.0),
4125 TEST_c_c (casinh, minus_zero, 0, minus_zero, 0),
4126 TEST_c_c (casinh, 0, minus_zero, 0.0, minus_zero),
4127 TEST_c_c (casinh, minus_zero, minus_zero, minus_zero, minus_zero),
4128
4129 TEST_c_c (casinh, plus_infty, plus_infty, plus_infty, M_PI_4l),
4130 TEST_c_c (casinh, plus_infty, minus_infty, plus_infty, -M_PI_4l),
4131 TEST_c_c (casinh, minus_infty, plus_infty, minus_infty, M_PI_4l),
4132 TEST_c_c (casinh, minus_infty, minus_infty, minus_infty, -M_PI_4l),
4133
4134 TEST_c_c (casinh, -10.0, plus_infty, minus_infty, M_PI_2l),
4135 TEST_c_c (casinh, -10.0, minus_infty, minus_infty, -M_PI_2l),
4136 TEST_c_c (casinh, 0, plus_infty, plus_infty, M_PI_2l),
4137 TEST_c_c (casinh, 0, minus_infty, plus_infty, -M_PI_2l),
4138 TEST_c_c (casinh, minus_zero, plus_infty, minus_infty, M_PI_2l),
4139 TEST_c_c (casinh, minus_zero, minus_infty, minus_infty, -M_PI_2l),
4140 TEST_c_c (casinh, 0.1L, plus_infty, plus_infty, M_PI_2l),
4141 TEST_c_c (casinh, 0.1L, minus_infty, plus_infty, -M_PI_2l),
4142
4143 TEST_c_c (casinh, minus_infty, 0, minus_infty, 0.0),
4144 TEST_c_c (casinh, minus_infty, minus_zero, minus_infty, minus_zero),
4145 TEST_c_c (casinh, minus_infty, 100, minus_infty, 0.0),
4146 TEST_c_c (casinh, minus_infty, -100, minus_infty, minus_zero),
4147
4148 TEST_c_c (casinh, plus_infty, 0, plus_infty, 0.0),
4149 TEST_c_c (casinh, plus_infty, minus_zero, plus_infty, minus_zero),
4150 TEST_c_c (casinh, plus_infty, 0.5, plus_infty, 0.0),
4151 TEST_c_c (casinh, plus_infty, -0.5, plus_infty, minus_zero),
4152
4153 TEST_c_c (casinh, plus_infty, qnan_value, plus_infty, qnan_value),
4154 TEST_c_c (casinh, minus_infty, qnan_value, minus_infty, qnan_value),
4155
4156 TEST_c_c (casinh, qnan_value, 0, qnan_value, 0.0),
4157 TEST_c_c (casinh, qnan_value, minus_zero, qnan_value, minus_zero),
4158
4159 TEST_c_c (casinh, qnan_value, plus_infty, plus_infty, qnan_value, IGNORE_ZERO_INF_SIGN),
4160 TEST_c_c (casinh, qnan_value, minus_infty, plus_infty, qnan_value, IGNORE_ZERO_INF_SIGN),
4161
4162 TEST_c_c (casinh, 10.5, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
4163 TEST_c_c (casinh, -10.5, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
4164
4165 TEST_c_c (casinh, qnan_value, 0.75, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
4166 TEST_c_c (casinh, -0.75, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
4167
4168 TEST_c_c (casinh, qnan_value, qnan_value, qnan_value, qnan_value),
4169
4170 TEST_c_c (casinh, plus_zero, -1.5L, 0.9624236501192068949955178268487368462704L, -M_PI_2l),
4171 TEST_c_c (casinh, minus_zero, -1.5L, -0.9624236501192068949955178268487368462704L, -M_PI_2l),
4172 TEST_c_c (casinh, plus_zero, -1.0L, plus_zero, -M_PI_2l),
4173 TEST_c_c (casinh, minus_zero, -1.0L, minus_zero, -M_PI_2l),
4174 TEST_c_c (casinh, plus_zero, -0.5L, plus_zero, -0.5235987755982988730771072305465838140329L),
4175 TEST_c_c (casinh, minus_zero, -0.5L, minus_zero, -0.5235987755982988730771072305465838140329L),
4176 TEST_c_c (casinh, plus_zero, 0.5L, plus_zero, 0.5235987755982988730771072305465838140329L),
4177 TEST_c_c (casinh, minus_zero, 0.5L, minus_zero, 0.5235987755982988730771072305465838140329L),
4178 TEST_c_c (casinh, plus_zero, 1.0L, plus_zero, M_PI_2l),
4179 TEST_c_c (casinh, minus_zero, 1.0L, minus_zero, M_PI_2l),
4180 TEST_c_c (casinh, plus_zero, 1.5L, 0.9624236501192068949955178268487368462704L, M_PI_2l),
4181 TEST_c_c (casinh, minus_zero, 1.5L, -0.9624236501192068949955178268487368462704L, M_PI_2l),
4182
4183 TEST_c_c (casinh, -1.5L, plus_zero, -1.194763217287109304111930828519090523536L, plus_zero),
4184 TEST_c_c (casinh, -1.5L, minus_zero, -1.194763217287109304111930828519090523536L, minus_zero),
4185 TEST_c_c (casinh, -1.0L, plus_zero, -0.8813735870195430252326093249797923090282L, plus_zero),
4186 TEST_c_c (casinh, -1.0L, minus_zero, -0.8813735870195430252326093249797923090282L, minus_zero),
4187 TEST_c_c (casinh, -0.5L, plus_zero, -0.4812118250596034474977589134243684231352L, plus_zero),
4188 TEST_c_c (casinh, -0.5L, minus_zero, -0.4812118250596034474977589134243684231352L, minus_zero),
4189 TEST_c_c (casinh, 0.5L, plus_zero, 0.4812118250596034474977589134243684231352L, plus_zero),
4190 TEST_c_c (casinh, 0.5L, minus_zero, 0.4812118250596034474977589134243684231352L, minus_zero),
4191 TEST_c_c (casinh, 1.0L, plus_zero, 0.8813735870195430252326093249797923090282L, plus_zero),
4192 TEST_c_c (casinh, 1.0L, minus_zero, 0.8813735870195430252326093249797923090282L, minus_zero),
4193 TEST_c_c (casinh, 1.5L, plus_zero, 1.194763217287109304111930828519090523536L, plus_zero),
4194 TEST_c_c (casinh, 1.5L, minus_zero, 1.194763217287109304111930828519090523536L, minus_zero),
4195
4196 TEST_c_c (casinh, 0x1p50L, 1.0L, 3.535050620855721078027883819436759661753e1L, 8.881784197001252323389053344720723756399e-16L),
4197 TEST_c_c (casinh, 0x1p50L, -1.0L, 3.535050620855721078027883819436759661753e1L, -8.881784197001252323389053344720723756399e-16L),
4198 TEST_c_c (casinh, -0x1p50L, 1.0L, -3.535050620855721078027883819436759661753e1L, 8.881784197001252323389053344720723756399e-16L),
4199 TEST_c_c (casinh, -0x1p50L, -1.0L, -3.535050620855721078027883819436759661753e1L, -8.881784197001252323389053344720723756399e-16L),
4200 TEST_c_c (casinh, 1.0L, 0x1p50L, 3.535050620855721078027883819436720218708e1L, 1.570796326794895731052901991514519103193L),
4201 TEST_c_c (casinh, -1.0L, 0x1p50L, -3.535050620855721078027883819436720218708e1L, 1.570796326794895731052901991514519103193L),
4202 TEST_c_c (casinh, 1.0L, -0x1p50L, 3.535050620855721078027883819436720218708e1L, -1.570796326794895731052901991514519103193L),
4203 TEST_c_c (casinh, -1.0L, -0x1p50L, -3.535050620855721078027883819436720218708e1L, -1.570796326794895731052901991514519103193L),
4204 #ifndef TEST_FLOAT
4205 TEST_c_c (casinh, 0x1p500L, 1.0L, 3.472667374605326000180332928505464606058e2L, 3.054936363499604682051979393213617699789e-151L),
4206 TEST_c_c (casinh, 0x1p500L, -1.0L, 3.472667374605326000180332928505464606058e2L, -3.054936363499604682051979393213617699789e-151L),
4207 TEST_c_c (casinh, -0x1p500L, 1.0L, -3.472667374605326000180332928505464606058e2L, 3.054936363499604682051979393213617699789e-151L),
4208 TEST_c_c (casinh, -0x1p500L, -1.0L, -3.472667374605326000180332928505464606058e2L, -3.054936363499604682051979393213617699789e-151L),
4209 TEST_c_c (casinh, 1.0L, 0x1p500L, 3.472667374605326000180332928505464606058e2L, 1.570796326794896619231321691639751442099L),
4210 TEST_c_c (casinh, -1.0L, 0x1p500L, -3.472667374605326000180332928505464606058e2L, 1.570796326794896619231321691639751442099L),
4211 TEST_c_c (casinh, 1.0L, -0x1p500L, 3.472667374605326000180332928505464606058e2L, -1.570796326794896619231321691639751442099L),
4212 TEST_c_c (casinh, -1.0L, -0x1p500L, -3.472667374605326000180332928505464606058e2L, -1.570796326794896619231321691639751442099L),
4213 #endif
4214 #if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
4215 TEST_c_c (casinh, 0x1p5000L, 1.0L, 3.466429049980286492395577839412341016946e3L, 7.079811261048172892385615158694057552948e-1506L),
4216 TEST_c_c (casinh, 0x1p5000L, -1.0L, 3.466429049980286492395577839412341016946e3L, -7.079811261048172892385615158694057552948e-1506L),
4217 TEST_c_c (casinh, -0x1p5000L, 1.0L, -3.466429049980286492395577839412341016946e3L, 7.079811261048172892385615158694057552948e-1506L),
4218 TEST_c_c (casinh, -0x1p5000L, -1.0L, -3.466429049980286492395577839412341016946e3L, -7.079811261048172892385615158694057552948e-1506L),
4219 TEST_c_c (casinh, 1.0L, 0x1p5000L, 3.466429049980286492395577839412341016946e3L, 1.570796326794896619231321691639751442099L),
4220 TEST_c_c (casinh, -1.0L, 0x1p5000L, -3.466429049980286492395577839412341016946e3L, 1.570796326794896619231321691639751442099L),
4221 TEST_c_c (casinh, 1.0L, -0x1p5000L, 3.466429049980286492395577839412341016946e3L, -1.570796326794896619231321691639751442099L),
4222 TEST_c_c (casinh, -1.0L, -0x1p5000L, -3.466429049980286492395577839412341016946e3L, -1.570796326794896619231321691639751442099L),
4223 #endif
4224
4225 TEST_c_c (casinh, 0x1.fp127L, 0x1.fp127L, 8.973081118419833726837456344608533993585e1L, 7.853981633974483096156608458198757210493e-1L),
4226 #ifndef TEST_FLOAT
4227 TEST_c_c (casinh, 0x1.fp1023L, 0x1.fp1023L, 7.107906849659093345062145442726115449315e2L, 7.853981633974483096156608458198757210493e-1L),
4228 #endif
4229 #if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
4230 TEST_c_c (casinh, 0x1.fp16383L, 0x1.fp16383L, 1.135753137836666928715489992987020363057e4L, 7.853981633974483096156608458198757210493e-1L),
4231 #endif
4232
4233 TEST_c_c (casinh, 0x1.fp-129L, 1.5L, 9.624236501192068949955178268487368462704e-1L, 1.570796326794896619231321691639751442096L),
4234 TEST_c_c (casinh, 0x1.fp-129L, -1.5L, 9.624236501192068949955178268487368462704e-1L, -1.570796326794896619231321691639751442096L),
4235 TEST_c_c (casinh, -0x1.fp-129L, 1.5L, -9.624236501192068949955178268487368462704e-1L, 1.570796326794896619231321691639751442096L),
4236 TEST_c_c (casinh, -0x1.fp-129L, -1.5L, -9.624236501192068949955178268487368462704e-1L, -1.570796326794896619231321691639751442096L),
4237 TEST_c_c (casinh, 1.5L, 0x1.fp-129L, 1.194763217287109304111930828519090523536L, 1.579176199917649005841160751101628985741e-39L, UNDERFLOW_EXCEPTION_FLOAT),
4238 TEST_c_c (casinh, -1.5L, 0x1.fp-129L, -1.194763217287109304111930828519090523536L, 1.579176199917649005841160751101628985741e-39L, UNDERFLOW_EXCEPTION_FLOAT),
4239 TEST_c_c (casinh, 1.5L, -0x1.fp-129L, 1.194763217287109304111930828519090523536L, -1.579176199917649005841160751101628985741e-39L, UNDERFLOW_EXCEPTION_FLOAT),
4240 TEST_c_c (casinh, -1.5L, -0x1.fp-129L, -1.194763217287109304111930828519090523536L, -1.579176199917649005841160751101628985741e-39L, UNDERFLOW_EXCEPTION_FLOAT),
4241 #ifndef TEST_FLOAT
4242 TEST_c_c (casinh, 0x1.fp-1025L, 1.5L, 9.624236501192068949955178268487368462704e-1L, 1.570796326794896619231321691639751442099L),
4243 TEST_c_c (casinh, 0x1.fp-1025L, -1.5L, 9.624236501192068949955178268487368462704e-1L, -1.570796326794896619231321691639751442099L),
4244 TEST_c_c (casinh, -0x1.fp-1025L, 1.5L, -9.624236501192068949955178268487368462704e-1L, 1.570796326794896619231321691639751442099L),
4245 TEST_c_c (casinh, -0x1.fp-1025L, -1.5L, -9.624236501192068949955178268487368462704e-1L, -1.570796326794896619231321691639751442099L),
4246 TEST_c_c (casinh, 1.5L, 0x1.fp-1025L, 1.194763217287109304111930828519090523536L, 2.989196569048182929051881765490354365918e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
4247 TEST_c_c (casinh, -1.5L, 0x1.fp-1025L, -1.194763217287109304111930828519090523536L, 2.989196569048182929051881765490354365918e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
4248 TEST_c_c (casinh, 1.5L, -0x1.fp-1025L, 1.194763217287109304111930828519090523536L, -2.989196569048182929051881765490354365918e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
4249 TEST_c_c (casinh, -1.5L, -0x1.fp-1025L, -1.194763217287109304111930828519090523536L, -2.989196569048182929051881765490354365918e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
4250 #endif
4251 #if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
4252 TEST_c_c (casinh, 0x1.fp-16385L, 1.5L, 9.624236501192068949955178268487368462704e-1L, 1.570796326794896619231321691639751442099L),
4253 TEST_c_c (casinh, 0x1.fp-16385L, -1.5L, 9.624236501192068949955178268487368462704e-1L, -1.570796326794896619231321691639751442099L),
4254 TEST_c_c (casinh, -0x1.fp-16385L, 1.5L, -9.624236501192068949955178268487368462704e-1L, 1.570796326794896619231321691639751442099L),
4255 TEST_c_c (casinh, -0x1.fp-16385L, -1.5L, -9.624236501192068949955178268487368462704e-1L, -1.570796326794896619231321691639751442099L),
4256 TEST_c_c (casinh, 1.5L, 0x1.fp-16385L, 1.194763217287109304111930828519090523536L, 4.516698239814521372306784062043266700598e-4933L, UNDERFLOW_EXCEPTION),
4257 TEST_c_c (casinh, -1.5L, 0x1.fp-16385L, -1.194763217287109304111930828519090523536L, 4.516698239814521372306784062043266700598e-4933L, UNDERFLOW_EXCEPTION),
4258 TEST_c_c (casinh, 1.5L, -0x1.fp-16385L, 1.194763217287109304111930828519090523536L, -4.516698239814521372306784062043266700598e-4933L, UNDERFLOW_EXCEPTION),
4259 TEST_c_c (casinh, -1.5L, -0x1.fp-16385L, -1.194763217287109304111930828519090523536L, -4.516698239814521372306784062043266700598e-4933L, UNDERFLOW_EXCEPTION),
4260 #endif
4261
4262 TEST_c_c (casinh, 0.5L, 1.0L, 7.328576759736452608886724437653071523305e-1L, 8.959074812088902390666567243275770102229e-1L),
4263 TEST_c_c (casinh, 0.5L, -1.0L, 7.328576759736452608886724437653071523305e-1L, -8.959074812088902390666567243275770102229e-1L),
4264 TEST_c_c (casinh, -0.5L, 1.0L, -7.328576759736452608886724437653071523305e-1L, 8.959074812088902390666567243275770102229e-1L),
4265 TEST_c_c (casinh, -0.5L, -1.0L, -7.328576759736452608886724437653071523305e-1L, -8.959074812088902390666567243275770102229e-1L),
4266 TEST_c_c (casinh, 1.0L, 0.5L, 9.261330313501824245501244453057873152694e-1L, 3.494390628572132936274118260753699527325e-1L),
4267 TEST_c_c (casinh, -1.0L, 0.5L, -9.261330313501824245501244453057873152694e-1L, 3.494390628572132936274118260753699527325e-1L),
4268 TEST_c_c (casinh, 1.0L, -0.5L, 9.261330313501824245501244453057873152694e-1L, -3.494390628572132936274118260753699527325e-1L),
4269 TEST_c_c (casinh, -1.0L, -0.5L, -9.261330313501824245501244453057873152694e-1L, -3.494390628572132936274118260753699527325e-1L),
4270 TEST_c_c (casinh, 0.25L, 1.0L, 5.097911466811016354623559941115413499164e-1L, 1.081751996523816326311037318425097434186L),
4271 TEST_c_c (casinh, 0.25L, -1.0L, 5.097911466811016354623559941115413499164e-1L, -1.081751996523816326311037318425097434186L),
4272 TEST_c_c (casinh, -0.25L, 1.0L, -5.097911466811016354623559941115413499164e-1L, 1.081751996523816326311037318425097434186L),
4273 TEST_c_c (casinh, -0.25L, -1.0L, -5.097911466811016354623559941115413499164e-1L, -1.081751996523816326311037318425097434186L),
4274 TEST_c_c (casinh, 1.0L, 0.25L, 8.924633639033482359562124741744951972772e-1L, 1.763024327769669304186785666360901026468e-1L),
4275 TEST_c_c (casinh, -1.0L, 0.25L, -8.924633639033482359562124741744951972772e-1L, 1.763024327769669304186785666360901026468e-1L),
4276 TEST_c_c (casinh, 1.0L, -0.25L, 8.924633639033482359562124741744951972772e-1L, -1.763024327769669304186785666360901026468e-1L),
4277 TEST_c_c (casinh, -1.0L, -0.25L, -8.924633639033482359562124741744951972772e-1L, -1.763024327769669304186785666360901026468e-1L),
4278 TEST_c_c (casinh, 0x1.fp-10L, 1.0L, 4.350501469856803800217957402220976497152e-2L, 1.527305029163877791518741192097931722508L),
4279 TEST_c_c (casinh, 0x1.fp-10L, -1.0L, 4.350501469856803800217957402220976497152e-2L, -1.527305029163877791518741192097931722508L),
4280 TEST_c_c (casinh, -0x1.fp-10L, 1.0L, -4.350501469856803800217957402220976497152e-2L, 1.527305029163877791518741192097931722508L),
4281 TEST_c_c (casinh, -0x1.fp-10L, -1.0L, -4.350501469856803800217957402220976497152e-2L, -1.527305029163877791518741192097931722508L),
4282 TEST_c_c (casinh, 1.0L, 0x1.fp-10L, 8.813742198809567991336704287826445879025e-1L, 1.337909359557740912558349531052239112857e-3L),
4283 TEST_c_c (casinh, -1.0L, 0x1.fp-10L, -8.813742198809567991336704287826445879025e-1L, 1.337909359557740912558349531052239112857e-3L),
4284 TEST_c_c (casinh, 1.0L, -0x1.fp-10L, 8.813742198809567991336704287826445879025e-1L, -1.337909359557740912558349531052239112857e-3L),
4285 TEST_c_c (casinh, -1.0L, -0x1.fp-10L, -8.813742198809567991336704287826445879025e-1L, -1.337909359557740912558349531052239112857e-3L),
4286 TEST_c_c (casinh, 0x1.fp-30L, 1.0L, 4.247867098745151888768727039216644758847e-5L, 1.570753848123921942730162693731872690232L),
4287 TEST_c_c (casinh, 0x1.fp-30L, -1.0L, 4.247867098745151888768727039216644758847e-5L, -1.570753848123921942730162693731872690232L),
4288 TEST_c_c (casinh, -0x1.fp-30L, 1.0L, -4.247867098745151888768727039216644758847e-5L, 1.570753848123921942730162693731872690232L),
4289 TEST_c_c (casinh, -0x1.fp-30L, -1.0L, -4.247867098745151888768727039216644758847e-5L, -1.570753848123921942730162693731872690232L),
4290 TEST_c_c (casinh, 1.0L, 0x1.fp-30L, 8.813735870195430258081932989769495326854e-1L, 1.275929984216518540252717485007112529021e-9L),
4291 TEST_c_c (casinh, -1.0L, 0x1.fp-30L, -8.813735870195430258081932989769495326854e-1L, 1.275929984216518540252717485007112529021e-9L),
4292 TEST_c_c (casinh, 1.0L, -0x1.fp-30L, 8.813735870195430258081932989769495326854e-1L, -1.275929984216518540252717485007112529021e-9L),
4293 TEST_c_c (casinh, -1.0L, -0x1.fp-30L, -8.813735870195430258081932989769495326854e-1L, -1.275929984216518540252717485007112529021e-9L),
4294 TEST_c_c (casinh, 0x1.fp-100L, 1.0L, 1.236292038260260888664514866457202186027e-15L, 1.570796326794895382939283431378862777584L),
4295 TEST_c_c (casinh, 0x1.fp-100L, -1.0L, 1.236292038260260888664514866457202186027e-15L, -1.570796326794895382939283431378862777584L),
4296 TEST_c_c (casinh, -0x1.fp-100L, 1.0L, -1.236292038260260888664514866457202186027e-15L, 1.570796326794895382939283431378862777584L),
4297 TEST_c_c (casinh, -0x1.fp-100L, -1.0L, -1.236292038260260888664514866457202186027e-15L, -1.570796326794895382939283431378862777584L),
4298 TEST_c_c (casinh, 1.0L, 0x1.fp-100L, 8.813735870195430252326093249797923090282e-1L, 1.080754735021050612990719608916167354321e-30L),
4299 TEST_c_c (casinh, -1.0L, 0x1.fp-100L, -8.813735870195430252326093249797923090282e-1L, 1.080754735021050612990719608916167354321e-30L),
4300 TEST_c_c (casinh, 1.0L, -0x1.fp-100L, 8.813735870195430252326093249797923090282e-1L, -1.080754735021050612990719608916167354321e-30L),
4301 TEST_c_c (casinh, -1.0L, -0x1.fp-100L, -8.813735870195430252326093249797923090282e-1L, -1.080754735021050612990719608916167354321e-30L),
4302 TEST_c_c (casinh, 0x1.fp-129L, 1.0L, 5.335635276982233498398987585285818977933e-20L, 1.570796326794896619177965338869929107115L),
4303 TEST_c_c (casinh, 0x1.fp-129L, -1.0L, 5.335635276982233498398987585285818977933e-20L, -1.570796326794896619177965338869929107115L),
4304 TEST_c_c (casinh, -0x1.fp-129L, 1.0L, -5.335635276982233498398987585285818977933e-20L, 1.570796326794896619177965338869929107115L),
4305 TEST_c_c (casinh, -0x1.fp-129L, -1.0L, -5.335635276982233498398987585285818977933e-20L, -1.570796326794896619177965338869929107115L),
4306 TEST_c_c (casinh, 1.0L, 0x1.fp-129L, 8.813735870195430252326093249797923090282e-1L, 2.013062564695348242280482517399205554874e-39L, UNDERFLOW_EXCEPTION_FLOAT),
4307 TEST_c_c (casinh, -1.0L, 0x1.fp-129L, -8.813735870195430252326093249797923090282e-1L, 2.013062564695348242280482517399205554874e-39L, UNDERFLOW_EXCEPTION_FLOAT),
4308 TEST_c_c (casinh, 1.0L, -0x1.fp-129L, 8.813735870195430252326093249797923090282e-1L, -2.013062564695348242280482517399205554874e-39L, UNDERFLOW_EXCEPTION_FLOAT),
4309 TEST_c_c (casinh, -1.0L, -0x1.fp-129L, -8.813735870195430252326093249797923090282e-1L, -2.013062564695348242280482517399205554874e-39L, UNDERFLOW_EXCEPTION_FLOAT),
4310 #ifndef TEST_FLOAT
4311 TEST_c_c (casinh, 0x1.fp-1000L, 1.0L, 4.252291453851660175550490409247739011867e-151L, 1.570796326794896619231321691639751442099L),
4312 TEST_c_c (casinh, 0x1.fp-1000L, -1.0L, 4.252291453851660175550490409247739011867e-151L, -1.570796326794896619231321691639751442099L),
4313 TEST_c_c (casinh, -0x1.fp-1000L, 1.0L, -4.252291453851660175550490409247739011867e-151L, 1.570796326794896619231321691639751442099L),
4314 TEST_c_c (casinh, -0x1.fp-1000L, -1.0L, -4.252291453851660175550490409247739011867e-151L, -1.570796326794896619231321691639751442099L),
4315 TEST_c_c (casinh, 1.0L, 0x1.fp-1000L, 8.813735870195430252326093249797923090282e-1L, 1.278589251976747242280879285935084814093e-301L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
4316 TEST_c_c (casinh, -1.0L, 0x1.fp-1000L, -8.813735870195430252326093249797923090282e-1L, 1.278589251976747242280879285935084814093e-301L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
4317 TEST_c_c (casinh, 1.0L, -0x1.fp-1000L, 8.813735870195430252326093249797923090282e-1L, -1.278589251976747242280879285935084814093e-301L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
4318 TEST_c_c (casinh, -1.0L, -0x1.fp-1000L, -8.813735870195430252326093249797923090282e-1L, -1.278589251976747242280879285935084814093e-301L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
4319 TEST_c_c (casinh, 0x1.fp-1025L, 1.0L, 7.340879205566679497036857179189356754017e-155L, 1.570796326794896619231321691639751442099L),
4320 TEST_c_c (casinh, 0x1.fp-1025L, -1.0L, 7.340879205566679497036857179189356754017e-155L, -1.570796326794896619231321691639751442099L),
4321 TEST_c_c (casinh, -0x1.fp-1025L, 1.0L, -7.340879205566679497036857179189356754017e-155L, 1.570796326794896619231321691639751442099L),
4322 TEST_c_c (casinh, -0x1.fp-1025L, -1.0L, -7.340879205566679497036857179189356754017e-155L, -1.570796326794896619231321691639751442099L),
4323 TEST_c_c (casinh, 1.0L, 0x1.fp-1025L, 8.813735870195430252326093249797923090282e-1L, 3.810492908885321743133304375216617626230e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
4324 TEST_c_c (casinh, -1.0L, 0x1.fp-1025L, -8.813735870195430252326093249797923090282e-1L, 3.810492908885321743133304375216617626230e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
4325 TEST_c_c (casinh, 1.0L, -0x1.fp-1025L, 8.813735870195430252326093249797923090282e-1L, -3.810492908885321743133304375216617626230e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
4326 TEST_c_c (casinh, -1.0L, -0x1.fp-1025L, -8.813735870195430252326093249797923090282e-1L, -3.810492908885321743133304375216617626230e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
4327 #endif
4328 #if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
4329 TEST_c_c (casinh, 0x1.fp-10000L, 1.0L, 9.854680208706673586644342922051388714633e-1506L, 1.570796326794896619231321691639751442099L),
4330 TEST_c_c (casinh, 0x1.fp-10000L, -1.0L, 9.854680208706673586644342922051388714633e-1506L, -1.570796326794896619231321691639751442099L),
4331 TEST_c_c (casinh, -0x1.fp-10000L, 1.0L, -9.854680208706673586644342922051388714633e-1506L, 1.570796326794896619231321691639751442099L),
4332 TEST_c_c (casinh, -0x1.fp-10000L, -1.0L, -9.854680208706673586644342922051388714633e-1506L, -1.570796326794896619231321691639751442099L),
4333 TEST_c_c (casinh, 1.0L, 0x1.fp-10000L, 8.813735870195430252326093249797923090282e-1L, 6.867047849047171855399183659351043150871e-3011L),
4334 TEST_c_c (casinh, -1.0L, 0x1.fp-10000L, -8.813735870195430252326093249797923090282e-1L, 6.867047849047171855399183659351043150871e-3011L),
4335 TEST_c_c (casinh, 1.0L, -0x1.fp-10000L, 8.813735870195430252326093249797923090282e-1L, -6.867047849047171855399183659351043150871e-3011L),
4336 TEST_c_c (casinh, -1.0L, -0x1.fp-10000L, -8.813735870195430252326093249797923090282e-1L, -6.867047849047171855399183659351043150871e-3011L),
4337 TEST_c_c (casinh, 0x1.fp-16385L, 1.0L, 9.023632056840860275214893047597614177639e-2467L, 1.570796326794896619231321691639751442099L),
4338 TEST_c_c (casinh, 0x1.fp-16385L, -1.0L, 9.023632056840860275214893047597614177639e-2467L, -1.570796326794896619231321691639751442099L),
4339 TEST_c_c (casinh, -0x1.fp-16385L, 1.0L, -9.023632056840860275214893047597614177639e-2467L, 1.570796326794896619231321691639751442099L),
4340 TEST_c_c (casinh, -0x1.fp-16385L, -1.0L, -9.023632056840860275214893047597614177639e-2467L, -1.570796326794896619231321691639751442099L),
4341 TEST_c_c (casinh, 1.0L, 0x1.fp-16385L, 8.813735870195430252326093249797923090282e-1L, 5.757683115456107044131264955348448954458e-4933L, UNDERFLOW_EXCEPTION),
4342 TEST_c_c (casinh, -1.0L, 0x1.fp-16385L, -8.813735870195430252326093249797923090282e-1L, 5.757683115456107044131264955348448954458e-4933L, UNDERFLOW_EXCEPTION),
4343 TEST_c_c (casinh, 1.0L, -0x1.fp-16385L, 8.813735870195430252326093249797923090282e-1L, -5.757683115456107044131264955348448954458e-4933L, UNDERFLOW_EXCEPTION),
4344 TEST_c_c (casinh, -1.0L, -0x1.fp-16385L, -8.813735870195430252326093249797923090282e-1L, -5.757683115456107044131264955348448954458e-4933L, UNDERFLOW_EXCEPTION),
4345 #endif
4346
4347 TEST_c_c (casinh, 0x1p-23L, 0x1.000002p0L, 5.364668491573609633134147164031476452679e-4L, 1.570574114956455764594481054234834678422L),
4348 TEST_c_c (casinh, 0x1p-23L, -0x1.000002p0L, 5.364668491573609633134147164031476452679e-4L, -1.570574114956455764594481054234834678422L),
4349 TEST_c_c (casinh, -0x1p-23L, 0x1.000002p0L, -5.364668491573609633134147164031476452679e-4L, 1.570574114956455764594481054234834678422L),
4350 TEST_c_c (casinh, -0x1p-23L, -0x1.000002p0L, -5.364668491573609633134147164031476452679e-4L, -1.570574114956455764594481054234834678422L),
4351 TEST_c_c (casinh, 0x1.000002p0L, 0x1p-23L, 8.813736713132400470205730751186547909968e-1L, 8.429369199749229560964789467980644296420e-8L),
4352 TEST_c_c (casinh, -0x1.000002p0L, 0x1p-23L, -8.813736713132400470205730751186547909968e-1L, 8.429369199749229560964789467980644296420e-8L),
4353 TEST_c_c (casinh, 0x1.000002p0L, -0x1p-23L, 8.813736713132400470205730751186547909968e-1L, -8.429369199749229560964789467980644296420e-8L),
4354 TEST_c_c (casinh, -0x1.000002p0L, -0x1p-23L, -8.813736713132400470205730751186547909968e-1L, -8.429369199749229560964789467980644296420e-8L),
4355 TEST_c_c (casinh, 0x1.fp-129L, 0x1.000002p0L, 4.882812451493617206486388134172712975070e-4L, 1.570796326794896619231321691639751436268L),
4356 TEST_c_c (casinh, 0x1.fp-129L, -0x1.000002p0L, 4.882812451493617206486388134172712975070e-4L, -1.570796326794896619231321691639751436268L),
4357 TEST_c_c (casinh, -0x1.fp-129L, 0x1.000002p0L, -4.882812451493617206486388134172712975070e-4L, 1.570796326794896619231321691639751436268L),
4358 TEST_c_c (casinh, -0x1.fp-129L, -0x1.000002p0L, -4.882812451493617206486388134172712975070e-4L, -1.570796326794896619231321691639751436268L),
4359 TEST_c_c (casinh, 0x1.000002p0L, 0x1.fp-129L, 8.813736713132375348727889167749389235161e-1L, 2.013062444707472738895109955455676357057e-39L, UNDERFLOW_EXCEPTION_FLOAT),
4360 TEST_c_c (casinh, -0x1.000002p0L, 0x1.fp-129L, -8.813736713132375348727889167749389235161e-1L, 2.013062444707472738895109955455676357057e-39L, UNDERFLOW_EXCEPTION_FLOAT),
4361 TEST_c_c (casinh, 0x1.000002p0L, -0x1.fp-129L, 8.813736713132375348727889167749389235161e-1L, -2.013062444707472738895109955455676357057e-39L, UNDERFLOW_EXCEPTION_FLOAT),
4362 TEST_c_c (casinh, -0x1.000002p0L, -0x1.fp-129L, -8.813736713132375348727889167749389235161e-1L, -2.013062444707472738895109955455676357057e-39L, UNDERFLOW_EXCEPTION_FLOAT),
4363 TEST_c_c (casinh, 0.0L, 0x1.000002p0L, 4.882812451493617206486388134172712975070e-4L, 1.570796326794896619231321691639751442099L),
4364 TEST_c_c (casinh, 0.0L, -0x1.000002p0L, 4.882812451493617206486388134172712975070e-4L, -1.570796326794896619231321691639751442099L),
4365 TEST_c_c (casinh, -0.0L, 0x1.000002p0L, -4.882812451493617206486388134172712975070e-4L, 1.570796326794896619231321691639751442099L),
4366 TEST_c_c (casinh, -0.0L, -0x1.000002p0L, -4.882812451493617206486388134172712975070e-4L, -1.570796326794896619231321691639751442099L),
4367 TEST_c_c (casinh, 0x1.000002p0L, 0.0L, 8.813736713132375348727889167749389235161e-1L, 0.0L),
4368 TEST_c_c (casinh, -0x1.000002p0L, 0.0L, -8.813736713132375348727889167749389235161e-1L, 0.0L),
4369 TEST_c_c (casinh, 0x1.000002p0L, -0.0L, 8.813736713132375348727889167749389235161e-1L, -0.0L),
4370 TEST_c_c (casinh, -0x1.000002p0L, -0.0L, -8.813736713132375348727889167749389235161e-1L, -0.0L),
4371 #ifndef TEST_FLOAT
4372 TEST_c_c (casinh, 0x1p-52L, 0x1.0000000000001p0L, 2.315303644582684770975188768022139415020e-8L, 1.570796317204594913251280305810847349436L),
4373 TEST_c_c (casinh, 0x1p-52L, -0x1.0000000000001p0L, 2.315303644582684770975188768022139415020e-8L, -1.570796317204594913251280305810847349436L),
4374 TEST_c_c (casinh, -0x1p-52L, 0x1.0000000000001p0L, -2.315303644582684770975188768022139415020e-8L, 1.570796317204594913251280305810847349436L),
4375 TEST_c_c (casinh, -0x1p-52L, -0x1.0000000000001p0L, -2.315303644582684770975188768022139415020e-8L, -1.570796317204594913251280305810847349436L),
4376 TEST_c_c (casinh, 0x1.0000000000001p0L, 0x1p-52L, 8.813735870195431822418551933572982483664e-1L, 1.570092458683774885078102529858632363236e-16L),
4377 TEST_c_c (casinh, -0x1.0000000000001p0L, 0x1p-52L, -8.813735870195431822418551933572982483664e-1L, 1.570092458683774885078102529858632363236e-16L),
4378 TEST_c_c (casinh, 0x1.0000000000001p0L, -0x1p-52L, 8.813735870195431822418551933572982483664e-1L, -1.570092458683774885078102529858632363236e-16L),
4379 TEST_c_c (casinh, -0x1.0000000000001p0L, -0x1p-52L, -8.813735870195431822418551933572982483664e-1L, -1.570092458683774885078102529858632363236e-16L),
4380 TEST_c_c (casinh, 0x1.fp-1025L, 0x1.0000000000001p0L, 2.107342425544701550354780375182800088393e-8L, 1.570796326794896619231321691639751442099L),
4381 TEST_c_c (casinh, 0x1.fp-1025L, -0x1.0000000000001p0L, 2.107342425544701550354780375182800088393e-8L, -1.570796326794896619231321691639751442099L),
4382 TEST_c_c (casinh, -0x1.fp-1025L, 0x1.0000000000001p0L, -2.107342425544701550354780375182800088393e-8L, 1.570796326794896619231321691639751442099L),
4383 TEST_c_c (casinh, -0x1.fp-1025L, -0x1.0000000000001p0L, -2.107342425544701550354780375182800088393e-8L, -1.570796326794896619231321691639751442099L),
4384 TEST_c_c (casinh, 0x1.0000000000001p0L, 0x1.fp-1025L, 8.813735870195431822418551933572895326024e-1L, 3.810492908885321320083608113679347200012e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
4385 TEST_c_c (casinh, -0x1.0000000000001p0L, 0x1.fp-1025L, -8.813735870195431822418551933572895326024e-1L, 3.810492908885321320083608113679347200012e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
4386 TEST_c_c (casinh, 0x1.0000000000001p0L, -0x1.fp-1025L, 8.813735870195431822418551933572895326024e-1L, -3.810492908885321320083608113679347200012e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
4387 TEST_c_c (casinh, -0x1.0000000000001p0L, -0x1.fp-1025L, -8.813735870195431822418551933572895326024e-1L, -3.810492908885321320083608113679347200012e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
4388 TEST_c_c (casinh, 0.0L, 0x1.0000000000001p0L, 2.107342425544701550354780375182800088393e-8L, 1.570796326794896619231321691639751442099L),
4389 TEST_c_c (casinh, 0.0L, -0x1.0000000000001p0L, 2.107342425544701550354780375182800088393e-8L, -1.570796326794896619231321691639751442099L),
4390 TEST_c_c (casinh, -0.0L, 0x1.0000000000001p0L, -2.107342425544701550354780375182800088393e-8L, 1.570796326794896619231321691639751442099L),
4391 TEST_c_c (casinh, -0.0L, -0x1.0000000000001p0L, -2.107342425544701550354780375182800088393e-8L, -1.570796326794896619231321691639751442099L),
4392 TEST_c_c (casinh, 0x1.0000000000001p0L, 0.0L, 8.813735870195431822418551933572895326024e-1L, 0.0L),
4393 TEST_c_c (casinh, -0x1.0000000000001p0L, 0.0L, -8.813735870195431822418551933572895326024e-1L, 0.0L),
4394 TEST_c_c (casinh, 0x1.0000000000001p0L, -0.0L, 8.813735870195431822418551933572895326024e-1L, -0.0L),
4395 TEST_c_c (casinh, -0x1.0000000000001p0L, -0.0L, -8.813735870195431822418551933572895326024e-1L, -0.0L),
4396 #endif
4397 #if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 64
4398 TEST_c_c (casinh, 0x1p-63L, 0x1.0000000000000002p0L, 5.116146586219826555037807251857670783420e-10L, 1.570796326582978888921215348380499122131L),
4399 TEST_c_c (casinh, 0x1p-63L, -0x1.0000000000000002p0L, 5.116146586219826555037807251857670783420e-10L, -1.570796326582978888921215348380499122131L),
4400 TEST_c_c (casinh, -0x1p-63L, 0x1.0000000000000002p0L, -5.116146586219826555037807251857670783420e-10L, 1.570796326582978888921215348380499122131L),
4401 TEST_c_c (casinh, -0x1p-63L, -0x1.0000000000000002p0L, -5.116146586219826555037807251857670783420e-10L, -1.570796326582978888921215348380499122131L),
4402 TEST_c_c (casinh, 0x1.0000000000000002p0L, 0x1p-63L, 8.813735870195430253092739958139610131001e-1L, 7.666467083416870406778649849746878368519e-20L),
4403 TEST_c_c (casinh, -0x1.0000000000000002p0L, 0x1p-63L, -8.813735870195430253092739958139610131001e-1L, 7.666467083416870406778649849746878368519e-20L),
4404 TEST_c_c (casinh, 0x1.0000000000000002p0L, -0x1p-63L, 8.813735870195430253092739958139610131001e-1L, -7.666467083416870406778649849746878368519e-20L),
4405 TEST_c_c (casinh, -0x1.0000000000000002p0L, -0x1p-63L, -8.813735870195430253092739958139610131001e-1L, -7.666467083416870406778649849746878368519e-20L),
4406 # if LDBL_MIN_EXP <= -16381
4407 TEST_c_c (casinh, 0x1.fp-16385L, 0x1.0000000000000002p0L, 4.656612873077392578082927418388212703712e-10L, 1.570796326794896619231321691639751442099L),
4408 TEST_c_c (casinh, 0x1.fp-16385L, -0x1.0000000000000002p0L, 4.656612873077392578082927418388212703712e-10L, -1.570796326794896619231321691639751442099L),
4409 TEST_c_c (casinh, -0x1.fp-16385L, 0x1.0000000000000002p0L, -4.656612873077392578082927418388212703712e-10L, 1.570796326794896619231321691639751442099L),
4410 TEST_c_c (casinh, -0x1.fp-16385L, -0x1.0000000000000002p0L, -4.656612873077392578082927418388212703712e-10L, -1.570796326794896619231321691639751442099L),
4411 TEST_c_c (casinh, 0x1.0000000000000002p0L, 0x1.fp-16385L, 8.813735870195430253092739958139610130980e-1L, 5.757683115456107043819140328235418018963e-4933L, UNDERFLOW_EXCEPTION),
4412 TEST_c_c (casinh, -0x1.0000000000000002p0L, 0x1.fp-16385L, -8.813735870195430253092739958139610130980e-1L, 5.757683115456107043819140328235418018963e-4933L, UNDERFLOW_EXCEPTION),
4413 TEST_c_c (casinh, 0x1.0000000000000002p0L, -0x1.fp-16385L, 8.813735870195430253092739958139610130980e-1L, -5.757683115456107043819140328235418018963e-4933L, UNDERFLOW_EXCEPTION),
4414 TEST_c_c (casinh, -0x1.0000000000000002p0L, -0x1.fp-16385L, -8.813735870195430253092739958139610130980e-1L, -5.757683115456107043819140328235418018963e-4933L, UNDERFLOW_EXCEPTION),
4415 # endif
4416 TEST_c_c (casinh, 0.0L, 0x1.0000000000000002p0L, 4.656612873077392578082927418388212703712e-10L, 1.570796326794896619231321691639751442099L),
4417 TEST_c_c (casinh, 0.0L, -0x1.0000000000000002p0L, 4.656612873077392578082927418388212703712e-10L, -1.570796326794896619231321691639751442099L),
4418 TEST_c_c (casinh, -0.0L, 0x1.0000000000000002p0L, -4.656612873077392578082927418388212703712e-10L, 1.570796326794896619231321691639751442099L),
4419 TEST_c_c (casinh, -0.0L, -0x1.0000000000000002p0L, -4.656612873077392578082927418388212703712e-10L, -1.570796326794896619231321691639751442099L),
4420 TEST_c_c (casinh, 0x1.0000000000000002p0L, 0.0L, 8.813735870195430253092739958139610130980e-1L, 0.0L),
4421 TEST_c_c (casinh, -0x1.0000000000000002p0L, 0.0L, -8.813735870195430253092739958139610130980e-1L, 0.0L),
4422 TEST_c_c (casinh, 0x1.0000000000000002p0L, -0.0L, 8.813735870195430253092739958139610130980e-1L, -0.0L),
4423 TEST_c_c (casinh, -0x1.0000000000000002p0L, -0.0L, -8.813735870195430253092739958139610130980e-1L, -0.0L),
4424 #endif
4425 #if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 106
4426 TEST_c_c (casinh, 0x1p-106L, 0x1.000000000000000000000000008p0L, 2.285028863093221674154232933662774454211e-16L, 1.570796326794896565289107467733682961928L),
4427 TEST_c_c (casinh, 0x1p-106L, -0x1.000000000000000000000000008p0L, 2.285028863093221674154232933662774454211e-16L, -1.570796326794896565289107467733682961928L),
4428 TEST_c_c (casinh, -0x1p-106L, 0x1.000000000000000000000000008p0L, -2.285028863093221674154232933662774454211e-16L, 1.570796326794896565289107467733682961928L),
4429 TEST_c_c (casinh, -0x1p-106L, -0x1.000000000000000000000000008p0L, -2.285028863093221674154232933662774454211e-16L, -1.570796326794896565289107467733682961928L),
4430 TEST_c_c (casinh, 0x1.000000000000000000000000008p0L, 0x1p-106L, 8.813735870195430252326093249798097405561e-1L, 8.715763992105246878957416200936726072500e-33L),
4431 TEST_c_c (casinh, -0x1.000000000000000000000000008p0L, 0x1p-106L, -8.813735870195430252326093249798097405561e-1L, 8.715763992105246878957416200936726072500e-33L),
4432 TEST_c_c (casinh, 0x1.000000000000000000000000008p0L, -0x1p-106L, 8.813735870195430252326093249798097405561e-1L, -8.715763992105246878957416200936726072500e-33L),
4433 TEST_c_c (casinh, -0x1.000000000000000000000000008p0L, -0x1p-106L, -8.813735870195430252326093249798097405561e-1L, -8.715763992105246878957416200936726072500e-33L),
4434 TEST_c_c (casinh, 0x1.fp-1025L, 0x1.000000000000000000000000008p0L, 2.220446049250313080847263336181636063482e-16L, 1.570796326794896619231321691639751442099L),
4435 TEST_c_c (casinh, 0x1.fp-1025L, -0x1.000000000000000000000000008p0L, 2.220446049250313080847263336181636063482e-16L, -1.570796326794896619231321691639751442099L),
4436 TEST_c_c (casinh, -0x1.fp-1025L, 0x1.000000000000000000000000008p0L, -2.220446049250313080847263336181636063482e-16L, 1.570796326794896619231321691639751442099L),
4437 TEST_c_c (casinh, -0x1.fp-1025L, -0x1.000000000000000000000000008p0L, -2.220446049250313080847263336181636063482e-16L, -1.570796326794896619231321691639751442099L),
4438 TEST_c_c (casinh, 0x1.000000000000000000000000008p0L, 0x1.fp-1025L, 8.813735870195430252326093249798097405561e-1L, 3.810492908885321743133304375216570658278e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
4439 TEST_c_c (casinh, -0x1.000000000000000000000000008p0L, 0x1.fp-1025L, -8.813735870195430252326093249798097405561e-1L, 3.810492908885321743133304375216570658278e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
4440 TEST_c_c (casinh, 0x1.000000000000000000000000008p0L, -0x1.fp-1025L, 8.813735870195430252326093249798097405561e-1L, -3.810492908885321743133304375216570658278e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
4441 TEST_c_c (casinh, -0x1.000000000000000000000000008p0L, -0x1.fp-1025L, -8.813735870195430252326093249798097405561e-1L, -3.810492908885321743133304375216570658278e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
4442 TEST_c_c (casinh, 0.0L, 0x1.000000000000000000000000008p0L, 2.220446049250313080847263336181636063482e-16L, 1.570796326794896619231321691639751442099L),
4443 TEST_c_c (casinh, 0.0L, -0x1.000000000000000000000000008p0L, 2.220446049250313080847263336181636063482e-16L, -1.570796326794896619231321691639751442099L),
4444 TEST_c_c (casinh, -0.0L, 0x1.000000000000000000000000008p0L, -2.220446049250313080847263336181636063482e-16L, 1.570796326794896619231321691639751442099L),
4445 TEST_c_c (casinh, -0.0L, -0x1.000000000000000000000000008p0L, -2.220446049250313080847263336181636063482e-16L, -1.570796326794896619231321691639751442099L),
4446 TEST_c_c (casinh, 0x1.000000000000000000000000008p0L, 0.0L, 8.813735870195430252326093249798097405561e-1L, 0.0L),
4447 TEST_c_c (casinh, -0x1.000000000000000000000000008p0L, 0.0L, -8.813735870195430252326093249798097405561e-1L, 0.0L),
4448 TEST_c_c (casinh, 0x1.000000000000000000000000008p0L, -0.0L, 8.813735870195430252326093249798097405561e-1L, -0.0L),
4449 TEST_c_c (casinh, -0x1.000000000000000000000000008p0L, -0.0L, -8.813735870195430252326093249798097405561e-1L, -0.0L),
4450 #endif
4451 #if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 113
4452 TEST_c_c (casinh, 0x1p-113L, 0x1.0000000000000000000000000001p0L, 2.019699255375255198156433710951064632386e-17L, 1.570796326794896614463458507897073960405L),
4453 TEST_c_c (casinh, 0x1p-113L, -0x1.0000000000000000000000000001p0L, 2.019699255375255198156433710951064632386e-17L, -1.570796326794896614463458507897073960405L),
4454 TEST_c_c (casinh, -0x1p-113L, 0x1.0000000000000000000000000001p0L, -2.019699255375255198156433710951064632386e-17L, 1.570796326794896614463458507897073960405L),
4455 TEST_c_c (casinh, -0x1p-113L, -0x1.0000000000000000000000000001p0L, -2.019699255375255198156433710951064632386e-17L, -1.570796326794896614463458507897073960405L),
4456 TEST_c_c (casinh, 0x1.0000000000000000000000000001p0L, 0x1p-113L, 8.813735870195430252326093249797924452120e-1L, 6.809190618832224124185481406981900518193e-35L),
4457 TEST_c_c (casinh, -0x1.0000000000000000000000000001p0L, 0x1p-113L, -8.813735870195430252326093249797924452120e-1L, 6.809190618832224124185481406981900518193e-35L),
4458 TEST_c_c (casinh, 0x1.0000000000000000000000000001p0L, -0x1p-113L, 8.813735870195430252326093249797924452120e-1L, -6.809190618832224124185481406981900518193e-35L),
4459 TEST_c_c (casinh, -0x1.0000000000000000000000000001p0L, -0x1p-113L, -8.813735870195430252326093249797924452120e-1L, -6.809190618832224124185481406981900518193e-35L),
4460 TEST_c_c (casinh, 0x1.fp-16385L, 0x1.0000000000000000000000000001p0L, 1.962615573354718824241727964954454332780e-17L, 1.570796326794896619231321691639751442099L),
4461 TEST_c_c (casinh, 0x1.fp-16385L, -0x1.0000000000000000000000000001p0L, 1.962615573354718824241727964954454332780e-17L, -1.570796326794896619231321691639751442099L),
4462 TEST_c_c (casinh, -0x1.fp-16385L, 0x1.0000000000000000000000000001p0L, -1.962615573354718824241727964954454332780e-17L, 1.570796326794896619231321691639751442099L),
4463 TEST_c_c (casinh, -0x1.fp-16385L, -0x1.0000000000000000000000000001p0L, -1.962615573354718824241727964954454332780e-17L, -1.570796326794896619231321691639751442099L),
4464 TEST_c_c (casinh, 0x1.0000000000000000000000000001p0L, 0x1.fp-16385L, 8.813735870195430252326093249797924452120e-1L, 5.757683115456107044131264955348448400014e-4933L, UNDERFLOW_EXCEPTION),
4465 TEST_c_c (casinh, -0x1.0000000000000000000000000001p0L, 0x1.fp-16385L, -8.813735870195430252326093249797924452120e-1L, 5.757683115456107044131264955348448400014e-4933L, UNDERFLOW_EXCEPTION),
4466 TEST_c_c (casinh, 0x1.0000000000000000000000000001p0L, -0x1.fp-16385L, 8.813735870195430252326093249797924452120e-1L, -5.757683115456107044131264955348448400014e-4933L, UNDERFLOW_EXCEPTION),
4467 TEST_c_c (casinh, -0x1.0000000000000000000000000001p0L, -0x1.fp-16385L, -8.813735870195430252326093249797924452120e-1L, -5.757683115456107044131264955348448400014e-4933L, UNDERFLOW_EXCEPTION),
4468 TEST_c_c (casinh, 0.0L, 0x1.0000000000000000000000000001p0L, 1.962615573354718824241727964954454332780e-17L, 1.570796326794896619231321691639751442099L),
4469 TEST_c_c (casinh, 0.0L, -0x1.0000000000000000000000000001p0L, 1.962615573354718824241727964954454332780e-17L, -1.570796326794896619231321691639751442099L),
4470 TEST_c_c (casinh, -0.0L, 0x1.0000000000000000000000000001p0L, -1.962615573354718824241727964954454332780e-17L, 1.570796326794896619231321691639751442099L),
4471 TEST_c_c (casinh, -0.0L, -0x1.0000000000000000000000000001p0L, -1.962615573354718824241727964954454332780e-17L, -1.570796326794896619231321691639751442099L),
4472 TEST_c_c (casinh, 0x1.0000000000000000000000000001p0L, 0.0L, 8.813735870195430252326093249797924452120e-1L, 0.0L),
4473 TEST_c_c (casinh, -0x1.0000000000000000000000000001p0L, 0.0L, -8.813735870195430252326093249797924452120e-1L, 0.0L),
4474 TEST_c_c (casinh, 0x1.0000000000000000000000000001p0L, -0.0L, 8.813735870195430252326093249797924452120e-1L, -0.0L),
4475 TEST_c_c (casinh, -0x1.0000000000000000000000000001p0L, -0.0L, -8.813735870195430252326093249797924452120e-1L, -0.0L),
4476 #endif
4477
4478 TEST_c_c (casinh, 0x1p-23L, 0x0.ffffffp0L, 2.714321200917194650737217746780928423385e-4L, 1.570357140408705570520377172865353621698L),
4479 TEST_c_c (casinh, 0x1p-23L, -0x0.ffffffp0L, 2.714321200917194650737217746780928423385e-4L, -1.570357140408705570520377172865353621698L),
4480 TEST_c_c (casinh, -0x1p-23L, 0x0.ffffffp0L, -2.714321200917194650737217746780928423385e-4L, 1.570357140408705570520377172865353621698L),
4481 TEST_c_c (casinh, -0x1p-23L, -0x0.ffffffp0L, -2.714321200917194650737217746780928423385e-4L, -1.570357140408705570520377172865353621698L),
4482 TEST_c_c (casinh, 0x0.ffffffp0L, 0x1p-23L, 8.813735448726963984495965873956465777250e-1L, 8.429369953393598499000760938112968755257e-8L),
4483 TEST_c_c (casinh, -0x0.ffffffp0L, 0x1p-23L, -8.813735448726963984495965873956465777250e-1L, 8.429369953393598499000760938112968755257e-8L),
4484 TEST_c_c (casinh, 0x0.ffffffp0L, -0x1p-23L, 8.813735448726963984495965873956465777250e-1L, -8.429369953393598499000760938112968755257e-8L),
4485 TEST_c_c (casinh, -0x0.ffffffp0L, -0x1p-23L, -8.813735448726963984495965873956465777250e-1L, -8.429369953393598499000760938112968755257e-8L),
4486 TEST_c_c (casinh, 0x1.fp-129L, 0x0.ffffffp0L, 8.245504387859737323891843603996428534945e-36L, 1.570451059810180415643718442157112705601L),
4487 TEST_c_c (casinh, 0x1.fp-129L, -0x0.ffffffp0L, 8.245504387859737323891843603996428534945e-36L, -1.570451059810180415643718442157112705601L),
4488 TEST_c_c (casinh, -0x1.fp-129L, 0x0.ffffffp0L, -8.245504387859737323891843603996428534945e-36L, 1.570451059810180415643718442157112705601L),
4489 TEST_c_c (casinh, -0x1.fp-129L, -0x0.ffffffp0L, -8.245504387859737323891843603996428534945e-36L, -1.570451059810180415643718442157112705601L),
4490 TEST_c_c (casinh, 0x0.ffffffp0L, 0x1.fp-129L, 8.813735448726938863015878255140556727969e-1L, 2.013062624689288675911339929224634593425e-39L, UNDERFLOW_EXCEPTION_FLOAT),
4491 TEST_c_c (casinh, -0x0.ffffffp0L, 0x1.fp-129L, -8.813735448726938863015878255140556727969e-1L, 2.013062624689288675911339929224634593425e-39L, UNDERFLOW_EXCEPTION_FLOAT),
4492 TEST_c_c (casinh, 0x0.ffffffp0L, -0x1.fp-129L, 8.813735448726938863015878255140556727969e-1L, -2.013062624689288675911339929224634593425e-39L, UNDERFLOW_EXCEPTION_FLOAT),
4493 TEST_c_c (casinh, -0x0.ffffffp0L, -0x1.fp-129L, -8.813735448726938863015878255140556727969e-1L, -2.013062624689288675911339929224634593425e-39L, UNDERFLOW_EXCEPTION_FLOAT),
4494 TEST_c_c (casinh, 0.0L, 0x0.ffffffp0L, 0.0L, 1.570451059810180415643718442157112705601L),
4495 TEST_c_c (casinh, 0.0L, -0x0.ffffffp0L, 0.0L, -1.570451059810180415643718442157112705601L),
4496 TEST_c_c (casinh, -0.0L, 0x0.ffffffp0L, -0.0L, 1.570451059810180415643718442157112705601L),
4497 TEST_c_c (casinh, -0.0L, -0x0.ffffffp0L, -0.0L, -1.570451059810180415643718442157112705601L),
4498 TEST_c_c (casinh, 0x0.ffffffp0L, 0.0L, 8.813735448726938863015878255140556727969e-1L, 0.0L),
4499 TEST_c_c (casinh, -0x0.ffffffp0L, 0.0L, -8.813735448726938863015878255140556727969e-1L, 0.0L),
4500 TEST_c_c (casinh, 0x0.ffffffp0L, -0.0L, 8.813735448726938863015878255140556727969e-1L, -0.0L),
4501 TEST_c_c (casinh, -0x0.ffffffp0L, -0.0L, -8.813735448726938863015878255140556727969e-1L, -0.0L),
4502 TEST_c_c (casinh, 0x1p-23L, 0.5L, 1.376510308240943236356088341381173571841e-7L, 5.235987755982934033165770729745469098254e-1L),
4503 TEST_c_c (casinh, 0x1p-23L, -0.5L, 1.376510308240943236356088341381173571841e-7L, -5.235987755982934033165770729745469098254e-1L),
4504 TEST_c_c (casinh, -0x1p-23L, 0.5L, -1.376510308240943236356088341381173571841e-7L, 5.235987755982934033165770729745469098254e-1L),
4505 TEST_c_c (casinh, -0x1p-23L, -0.5L, -1.376510308240943236356088341381173571841e-7L, -5.235987755982934033165770729745469098254e-1L),
4506 TEST_c_c (casinh, 0.5L, 0x1p-23L, 4.812118250596059896127318386463676808798e-1L, 1.066240299940009780479664302917201696886e-7L),
4507 TEST_c_c (casinh, -0.5L, 0x1p-23L, -4.812118250596059896127318386463676808798e-1L, 1.066240299940009780479664302917201696886e-7L),
4508 TEST_c_c (casinh, 0.5L, -0x1p-23L, 4.812118250596059896127318386463676808798e-1L, -1.066240299940009780479664302917201696886e-7L),
4509 TEST_c_c (casinh, -0.5L, -0x1p-23L, -4.812118250596059896127318386463676808798e-1L, -1.066240299940009780479664302917201696886e-7L),
4510 TEST_c_c (casinh, 0x1.fp-129L, 0.5L, 3.287317402534702257036015056278368274737e-39L, 5.235987755982988730771072305465838140329e-1L, UNDERFLOW_EXCEPTION_FLOAT),
4511 TEST_c_c (casinh, 0x1.fp-129L, -0.5L, 3.287317402534702257036015056278368274737e-39L, -5.235987755982988730771072305465838140329e-1L, UNDERFLOW_EXCEPTION_FLOAT),
4512 TEST_c_c (casinh, -0x1.fp-129L, 0.5L, -3.287317402534702257036015056278368274737e-39L, 5.235987755982988730771072305465838140329e-1L, UNDERFLOW_EXCEPTION_FLOAT),
4513 TEST_c_c (casinh, -0x1.fp-129L, -0.5L, -3.287317402534702257036015056278368274737e-39L, -5.235987755982988730771072305465838140329e-1L, UNDERFLOW_EXCEPTION_FLOAT),
4514 TEST_c_c (casinh, 0.5L, 0x1.fp-129L, 4.812118250596034474977589134243684231352e-1L, 2.546345110742945032959687790021055102355e-39L, UNDERFLOW_EXCEPTION_FLOAT),
4515 TEST_c_c (casinh, -0.5L, 0x1.fp-129L, -4.812118250596034474977589134243684231352e-1L, 2.546345110742945032959687790021055102355e-39L, UNDERFLOW_EXCEPTION_FLOAT),
4516 TEST_c_c (casinh, 0.5L, -0x1.fp-129L, 4.812118250596034474977589134243684231352e-1L, -2.546345110742945032959687790021055102355e-39L, UNDERFLOW_EXCEPTION_FLOAT),
4517 TEST_c_c (casinh, -0.5L, -0x1.fp-129L, -4.812118250596034474977589134243684231352e-1L, -2.546345110742945032959687790021055102355e-39L, UNDERFLOW_EXCEPTION_FLOAT),
4518 TEST_c_c (casinh, 0x1p-23L, 0x1p-23L, 1.192092895507818146886315028596704749235e-7L, 1.192092895507806853113684971258850504935e-7L),
4519 TEST_c_c (casinh, 0x1p-23L, -0x1p-23L, 1.192092895507818146886315028596704749235e-7L, -1.192092895507806853113684971258850504935e-7L),
4520 TEST_c_c (casinh, -0x1p-23L, 0x1p-23L, -1.192092895507818146886315028596704749235e-7L, 1.192092895507806853113684971258850504935e-7L),
4521 TEST_c_c (casinh, -0x1p-23L, -0x1p-23L, -1.192092895507818146886315028596704749235e-7L, -1.192092895507806853113684971258850504935e-7L),
4522 TEST_c_c (casinh, 0x1.fp-129L, 0x1p-23L, 2.846900380897747786805634596726756660388e-39L, 1.192092895507815323443157514352519154304e-7L, UNDERFLOW_EXCEPTION_FLOAT),
4523 TEST_c_c (casinh, 0x1.fp-129L, -0x1p-23L, 2.846900380897747786805634596726756660388e-39L, -1.192092895507815323443157514352519154304e-7L, UNDERFLOW_EXCEPTION_FLOAT),
4524 TEST_c_c (casinh, -0x1.fp-129L, 0x1p-23L, -2.846900380897747786805634596726756660388e-39L, 1.192092895507815323443157514352519154304e-7L, UNDERFLOW_EXCEPTION_FLOAT),
4525 TEST_c_c (casinh, -0x1.fp-129L, -0x1p-23L, -2.846900380897747786805634596726756660388e-39L, -1.192092895507815323443157514352519154304e-7L, UNDERFLOW_EXCEPTION_FLOAT),
4526 /* Bug 15319: underflow exception may be missing. */
4527 TEST_c_c (casinh, 0x1p-23L, 0x1.fp-129L, 1.192092895507809676556842485683592032154e-7L, 2.846900380897707329917933005874691056564e-39L, UNDERFLOW_EXCEPTION_OK_FLOAT),
4528 TEST_c_c (casinh, -0x1p-23L, 0x1.fp-129L, -1.192092895507809676556842485683592032154e-7L, 2.846900380897707329917933005874691056564e-39L, UNDERFLOW_EXCEPTION_OK_FLOAT),
4529 TEST_c_c (casinh, 0x1p-23L, -0x1.fp-129L, 1.192092895507809676556842485683592032154e-7L, -2.846900380897707329917933005874691056564e-39L, UNDERFLOW_EXCEPTION_OK_FLOAT),
4530 TEST_c_c (casinh, -0x1p-23L, -0x1.fp-129L, -1.192092895507809676556842485683592032154e-7L, -2.846900380897707329917933005874691056564e-39L, UNDERFLOW_EXCEPTION_OK_FLOAT),
4531 TEST_c_c (casinh, 0.0L, 0x1p-23L, 0.0L, 1.192092895507815323443157514352519154304e-7L),
4532 TEST_c_c (casinh, 0.0L, -0x1p-23L, 0.0L, -1.192092895507815323443157514352519154304e-7L),
4533 TEST_c_c (casinh, -0.0L, 0x1p-23L, -0.0L, 1.192092895507815323443157514352519154304e-7L),
4534 TEST_c_c (casinh, -0.0L, -0x1p-23L, -0.0L, -1.192092895507815323443157514352519154304e-7L),
4535 TEST_c_c (casinh, 0x1p-23L, 0.0L, 1.192092895507809676556842485683592032154e-7L, 0.0L),
4536 TEST_c_c (casinh, -0x1p-23L, 0.0L, -1.192092895507809676556842485683592032154e-7L, 0.0L),
4537 TEST_c_c (casinh, 0x1p-23L, -0.0L, 1.192092895507809676556842485683592032154e-7L, -0.0L),
4538 TEST_c_c (casinh, -0x1p-23L, -0.0L, -1.192092895507809676556842485683592032154e-7L, -0.0L),
4539 TEST_c_c (casinh, 0x1.fp-129L, 0x1.fp-129L, 2.846900380897727558361783801085126250967e-39L, 2.846900380897727558361783801085126250967e-39L, UNDERFLOW_EXCEPTION_FLOAT),
4540 TEST_c_c (casinh, 0x1.fp-129L, -0x1.fp-129L, 2.846900380897727558361783801085126250967e-39L, -2.846900380897727558361783801085126250967e-39L, UNDERFLOW_EXCEPTION_FLOAT),
4541 TEST_c_c (casinh, -0x1.fp-129L, 0x1.fp-129L, -2.846900380897727558361783801085126250967e-39L, 2.846900380897727558361783801085126250967e-39L, UNDERFLOW_EXCEPTION_FLOAT),
4542 TEST_c_c (casinh, -0x1.fp-129L, -0x1.fp-129L, -2.846900380897727558361783801085126250967e-39L, -2.846900380897727558361783801085126250967e-39L, UNDERFLOW_EXCEPTION_FLOAT),
4543 #ifndef TEST_FLOAT
4544 TEST_c_c (casinh, 0x1p-52L, 0x0.fffffffffffff8p0L, 1.171456840272878582596796205397918831268e-8L, 1.570796307840326780080580569360500172043L),
4545 TEST_c_c (casinh, 0x1p-52L, -0x0.fffffffffffff8p0L, 1.171456840272878582596796205397918831268e-8L, -1.570796307840326780080580569360500172043L),
4546 TEST_c_c (casinh, -0x1p-52L, 0x0.fffffffffffff8p0L, -1.171456840272878582596796205397918831268e-8L, 1.570796307840326780080580569360500172043L),
4547 TEST_c_c (casinh, -0x1p-52L, -0x0.fffffffffffff8p0L, -1.171456840272878582596796205397918831268e-8L, -1.570796307840326780080580569360500172043L),
4548 TEST_c_c (casinh, 0x0.fffffffffffff8p0L, 0x1p-52L, 8.813735870195429467279863907910458761820e-1L, 1.570092458683775146551022293016031474627e-16L),
4549 TEST_c_c (casinh, -0x0.fffffffffffff8p0L, 0x1p-52L, -8.813735870195429467279863907910458761820e-1L, 1.570092458683775146551022293016031474627e-16L),
4550 TEST_c_c (casinh, 0x0.fffffffffffff8p0L, -0x1p-52L, 8.813735870195429467279863907910458761820e-1L, -1.570092458683775146551022293016031474627e-16L),
4551 TEST_c_c (casinh, -0x0.fffffffffffff8p0L, -0x1p-52L, -8.813735870195429467279863907910458761820e-1L, -1.570092458683775146551022293016031474627e-16L),
4552 TEST_c_c (casinh, 0x1.fp-1025L, 0x0.fffffffffffff8p0L, 3.616396521699973256461764099945789620604e-301L, 1.570796311893735425383665303776316016594L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
4553 TEST_c_c (casinh, 0x1.fp-1025L, -0x0.fffffffffffff8p0L, 3.616396521699973256461764099945789620604e-301L, -1.570796311893735425383665303776316016594L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
4554 TEST_c_c (casinh, -0x1.fp-1025L, 0x0.fffffffffffff8p0L, -3.616396521699973256461764099945789620604e-301L, 1.570796311893735425383665303776316016594L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
4555 TEST_c_c (casinh, -0x1.fp-1025L, -0x0.fffffffffffff8p0L, -3.616396521699973256461764099945789620604e-301L, -1.570796311893735425383665303776316016594L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
4556 TEST_c_c (casinh, 0x0.fffffffffffff8p0L, 0x1.fp-1025L, 8.813735870195429467279863907910371604180e-1L, 3.810492908885321954658152505985270452320e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
4557 TEST_c_c (casinh, -0x0.fffffffffffff8p0L, 0x1.fp-1025L, -8.813735870195429467279863907910371604180e-1L, 3.810492908885321954658152505985270452320e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
4558 TEST_c_c (casinh, 0x0.fffffffffffff8p0L, -0x1.fp-1025L, 8.813735870195429467279863907910371604180e-1L, -3.810492908885321954658152505985270452320e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
4559 TEST_c_c (casinh, -0x0.fffffffffffff8p0L, -0x1.fp-1025L, -8.813735870195429467279863907910371604180e-1L, -3.810492908885321954658152505985270452320e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
4560 TEST_c_c (casinh, 0.0L, 0x0.fffffffffffff8p0L, 0.0L, 1.570796311893735425383665303776316016594L),
4561 TEST_c_c (casinh, 0.0L, -0x0.fffffffffffff8p0L, 0.0L, -1.570796311893735425383665303776316016594L),
4562 TEST_c_c (casinh, -0.0L, 0x0.fffffffffffff8p0L, -0.0L, 1.570796311893735425383665303776316016594L),
4563 TEST_c_c (casinh, -0.0L, -0x0.fffffffffffff8p0L, -0.0L, -1.570796311893735425383665303776316016594L),
4564 TEST_c_c (casinh, 0x0.fffffffffffff8p0L, 0.0L, 8.813735870195429467279863907910371604180e-1L, 0.0L),
4565 TEST_c_c (casinh, -0x0.fffffffffffff8p0L, 0.0L, -8.813735870195429467279863907910371604180e-1L, 0.0L),
4566 TEST_c_c (casinh, 0x0.fffffffffffff8p0L, -0.0L, 8.813735870195429467279863907910371604180e-1L, -0.0L),
4567 TEST_c_c (casinh, -0x0.fffffffffffff8p0L, -0.0L, -8.813735870195429467279863907910371604180e-1L, -0.0L),
4568 #endif
4569 TEST_c_c (casinh, 0x1p-52L, 0.5L, 2.563950248511418570403591756798643804971e-16L, 5.235987755982988730771072305465648369889e-1L),
4570 TEST_c_c (casinh, 0x1p-52L, -0.5L, 2.563950248511418570403591756798643804971e-16L, -5.235987755982988730771072305465648369889e-1L),
4571 TEST_c_c (casinh, -0x1p-52L, 0.5L, -2.563950248511418570403591756798643804971e-16L, 5.235987755982988730771072305465648369889e-1L),
4572 TEST_c_c (casinh, -0x1p-52L, -0.5L, -2.563950248511418570403591756798643804971e-16L, -5.235987755982988730771072305465648369889e-1L),
4573 TEST_c_c (casinh, 0.5L, 0x1p-52L, 4.812118250596034474977589134243772428682e-1L, 1.986027322597818397661816253158024383707e-16L),
4574 TEST_c_c (casinh, -0.5L, 0x1p-52L, -4.812118250596034474977589134243772428682e-1L, 1.986027322597818397661816253158024383707e-16L),
4575 TEST_c_c (casinh, 0.5L, -0x1p-52L, 4.812118250596034474977589134243772428682e-1L, -1.986027322597818397661816253158024383707e-16L),
4576 TEST_c_c (casinh, -0.5L, -0x1p-52L, -4.812118250596034474977589134243772428682e-1L, -1.986027322597818397661816253158024383707e-16L),
4577 #ifndef TEST_FLOAT
4578 TEST_c_c (casinh, 0x1.fp-1025L, 0.5L, 6.222508863508420569166420770843207333493e-309L, 5.235987755982988730771072305465838140329e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
4579 TEST_c_c (casinh, 0x1.fp-1025L, -0.5L, 6.222508863508420569166420770843207333493e-309L, -5.235987755982988730771072305465838140329e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
4580 TEST_c_c (casinh, -0x1.fp-1025L, 0.5L, -6.222508863508420569166420770843207333493e-309L, 5.235987755982988730771072305465838140329e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
4581 TEST_c_c (casinh, -0x1.fp-1025L, -0.5L, -6.222508863508420569166420770843207333493e-309L, -5.235987755982988730771072305465838140329e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
4582 TEST_c_c (casinh, 0.5L, 0x1.fp-1025L, 4.812118250596034474977589134243684231352e-1L, 4.819934639999230680322935210539402497827e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
4583 TEST_c_c (casinh, -0.5L, 0x1.fp-1025L, -4.812118250596034474977589134243684231352e-1L, 4.819934639999230680322935210539402497827e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
4584 TEST_c_c (casinh, 0.5L, -0x1.fp-1025L, 4.812118250596034474977589134243684231352e-1L, -4.819934639999230680322935210539402497827e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
4585 TEST_c_c (casinh, -0.5L, -0x1.fp-1025L, -4.812118250596034474977589134243684231352e-1L, -4.819934639999230680322935210539402497827e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
4586 #endif
4587 TEST_c_c (casinh, 0x1p-52L, 0x1p-52L, 2.220446049250313080847263336181677117148e-16L, 2.220446049250313080847263336181604132852e-16L),
4588 TEST_c_c (casinh, 0x1p-52L, -0x1p-52L, 2.220446049250313080847263336181677117148e-16L, -2.220446049250313080847263336181604132852e-16L),
4589 TEST_c_c (casinh, -0x1p-52L, 0x1p-52L, -2.220446049250313080847263336181677117148e-16L, 2.220446049250313080847263336181604132852e-16L),
4590 TEST_c_c (casinh, -0x1p-52L, -0x1p-52L, -2.220446049250313080847263336181677117148e-16L, -2.220446049250313080847263336181604132852e-16L),
4591 #ifndef TEST_FLOAT
4592 TEST_c_c (casinh, 0x1.fp-1025L, 0x1p-52L, 5.388850751072128349671657362289548938458e-309L, 2.220446049250313080847263336181658871074e-16L, UNDERFLOW_EXCEPTION_DOUBLE),
4593 TEST_c_c (casinh, 0x1.fp-1025L, -0x1p-52L, 5.388850751072128349671657362289548938458e-309L, -2.220446049250313080847263336181658871074e-16L, UNDERFLOW_EXCEPTION_DOUBLE),
4594 TEST_c_c (casinh, -0x1.fp-1025L, 0x1p-52L, -5.388850751072128349671657362289548938458e-309L, 2.220446049250313080847263336181658871074e-16L, UNDERFLOW_EXCEPTION_DOUBLE),
4595 TEST_c_c (casinh, -0x1.fp-1025L, -0x1p-52L, -5.388850751072128349671657362289548938458e-309L, -2.220446049250313080847263336181658871074e-16L, UNDERFLOW_EXCEPTION_DOUBLE),
4596 /* Bug 15319: underflow exception may be missing. */
4597 TEST_c_c (casinh, 0x1p-52L, 0x1.fp-1025L, 2.220446049250313080847263336181622378926e-16L, 5.388850751072128349671657362289283247603e-309L, UNDERFLOW_EXCEPTION_OK_DOUBLE),
4598 TEST_c_c (casinh, -0x1p-52L, 0x1.fp-1025L, -2.220446049250313080847263336181622378926e-16L, 5.388850751072128349671657362289283247603e-309L, UNDERFLOW_EXCEPTION_OK_DOUBLE),
4599 TEST_c_c (casinh, 0x1p-52L, -0x1.fp-1025L, 2.220446049250313080847263336181622378926e-16L, -5.388850751072128349671657362289283247603e-309L, UNDERFLOW_EXCEPTION_OK_DOUBLE),
4600 TEST_c_c (casinh, -0x1p-52L, -0x1.fp-1025L, -2.220446049250313080847263336181622378926e-16L, -5.388850751072128349671657362289283247603e-309L, UNDERFLOW_EXCEPTION_OK_DOUBLE),
4601 #endif
4602 TEST_c_c (casinh, 0.0L, 0x1p-52L, 0.0L, 2.220446049250313080847263336181658871074e-16L),
4603 TEST_c_c (casinh, 0.0L, -0x1p-52L, 0.0L, -2.220446049250313080847263336181658871074e-16L),
4604 TEST_c_c (casinh, -0.0L, 0x1p-52L, -0.0L, 2.220446049250313080847263336181658871074e-16L),
4605 TEST_c_c (casinh, -0.0L, -0x1p-52L, -0.0L, -2.220446049250313080847263336181658871074e-16L),
4606 TEST_c_c (casinh, 0x1p-52L, 0.0L, 2.220446049250313080847263336181622378926e-16L, 0.0L),
4607 TEST_c_c (casinh, -0x1p-52L, 0.0L, -2.220446049250313080847263336181622378926e-16L, 0.0L),
4608 TEST_c_c (casinh, 0x1p-52L, -0.0L, 2.220446049250313080847263336181622378926e-16L, -0.0L),
4609 TEST_c_c (casinh, -0x1p-52L, -0.0L, -2.220446049250313080847263336181622378926e-16L, -0.0L),
4610 #ifndef TEST_FLOAT
4611 TEST_c_c (casinh, 0x1.fp-1025L, 0x1.fp-1025L, 5.388850751072128349671657362289416093031e-309L, 5.388850751072128349671657362289416093031e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
4612 TEST_c_c (casinh, 0x1.fp-1025L, -0x1.fp-1025L, 5.388850751072128349671657362289416093031e-309L, -5.388850751072128349671657362289416093031e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
4613 TEST_c_c (casinh, -0x1.fp-1025L, 0x1.fp-1025L, -5.388850751072128349671657362289416093031e-309L, 5.388850751072128349671657362289416093031e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
4614 TEST_c_c (casinh, -0x1.fp-1025L, -0x1.fp-1025L, -5.388850751072128349671657362289416093031e-309L, -5.388850751072128349671657362289416093031e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
4615 #endif
4616 #if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 64
4617 TEST_c_c (casinh, 0x1p-63L, 0x0.ffffffffffffffffp0L, 2.588578361325995866221775673638805081337e-10L, 1.570796326376055842114524927965556247908L),
4618 TEST_c_c (casinh, 0x1p-63L, -0x0.ffffffffffffffffp0L, 2.588578361325995866221775673638805081337e-10L, -1.570796326376055842114524927965556247908L),
4619 TEST_c_c (casinh, -0x1p-63L, 0x0.ffffffffffffffffp0L, -2.588578361325995866221775673638805081337e-10L, 1.570796326376055842114524927965556247908L),
4620 TEST_c_c (casinh, -0x1p-63L, -0x0.ffffffffffffffffp0L, -2.588578361325995866221775673638805081337e-10L, -1.570796326376055842114524927965556247908L),
4621 TEST_c_c (casinh, 0x0.ffffffffffffffffp0L, 0x1p-63L, 8.813735870195430251942769895627079569937e-1L, 7.666467083416870407402049869781566856442e-20L),
4622 TEST_c_c (casinh, -0x0.ffffffffffffffffp0L, 0x1p-63L, -8.813735870195430251942769895627079569937e-1L, 7.666467083416870407402049869781566856442e-20L),
4623 TEST_c_c (casinh, 0x0.ffffffffffffffffp0L, -0x1p-63L, 8.813735870195430251942769895627079569937e-1L, -7.666467083416870407402049869781566856442e-20L),
4624 TEST_c_c (casinh, -0x0.ffffffffffffffffp0L, -0x1p-63L, -8.813735870195430251942769895627079569937e-1L, -7.666467083416870407402049869781566856442e-20L),
4625 # if LDBL_MIN_EXP <= -16381
4626 TEST_c_c (casinh, 0x1.fp-16385L, 0x0.ffffffffffffffffp0L, 2.472906068161537187835415298076415423459e-4923L, 1.570796326465624365239962068302568888898L),
4627 TEST_c_c (casinh, 0x1.fp-16385L, -0x0.ffffffffffffffffp0L, 2.472906068161537187835415298076415423459e-4923L, -1.570796326465624365239962068302568888898L),
4628 TEST_c_c (casinh, -0x1.fp-16385L, 0x0.ffffffffffffffffp0L, -2.472906068161537187835415298076415423459e-4923L, 1.570796326465624365239962068302568888898L),
4629 TEST_c_c (casinh, -0x1.fp-16385L, -0x0.ffffffffffffffffp0L, -2.472906068161537187835415298076415423459e-4923L, -1.570796326465624365239962068302568888898L),
4630 TEST_c_c (casinh, 0x0.ffffffffffffffffp0L, 0x1.fp-16385L, 8.813735870195430251942769895627079569917e-1L, 5.757683115456107044287327268904964422212e-4933L, UNDERFLOW_EXCEPTION),
4631 TEST_c_c (casinh, -0x0.ffffffffffffffffp0L, 0x1.fp-16385L, -8.813735870195430251942769895627079569917e-1L, 5.757683115456107044287327268904964422212e-4933L, UNDERFLOW_EXCEPTION),
4632 TEST_c_c (casinh, 0x0.ffffffffffffffffp0L, -0x1.fp-16385L, 8.813735870195430251942769895627079569917e-1L, -5.757683115456107044287327268904964422212e-4933L, UNDERFLOW_EXCEPTION),
4633 TEST_c_c (casinh, -0x0.ffffffffffffffffp0L, -0x1.fp-16385L, -8.813735870195430251942769895627079569917e-1L, -5.757683115456107044287327268904964422212e-4933L, UNDERFLOW_EXCEPTION),
4634 # endif
4635 TEST_c_c (casinh, 0.0L, 0x0.ffffffffffffffffp0L, 0.0L, 1.570796326465624365239962068302568888898L),
4636 TEST_c_c (casinh, 0.0L, -0x0.ffffffffffffffffp0L, 0.0L, -1.570796326465624365239962068302568888898L),
4637 TEST_c_c (casinh, -0.0L, 0x0.ffffffffffffffffp0L, -0.0L, 1.570796326465624365239962068302568888898L),
4638 TEST_c_c (casinh, -0.0L, -0x0.ffffffffffffffffp0L, -0.0L, -1.570796326465624365239962068302568888898L),
4639 TEST_c_c (casinh, 0x0.ffffffffffffffffp0L, 0.0L, 8.813735870195430251942769895627079569917e-1L, 0.0L),
4640 TEST_c_c (casinh, -0x0.ffffffffffffffffp0L, 0.0L, -8.813735870195430251942769895627079569917e-1L, 0.0L),
4641 TEST_c_c (casinh, 0x0.ffffffffffffffffp0L, -0.0L, 8.813735870195430251942769895627079569917e-1L, -0.0L),
4642 TEST_c_c (casinh, -0x0.ffffffffffffffffp0L, -0.0L, -8.813735870195430251942769895627079569917e-1L, -0.0L),
4643 #endif
4644 TEST_c_c (casinh, 0x1p-63L, 0.5L, 1.251928832280966098829878787499365228659e-19L, 5.235987755982988730771072305465838140283e-1L),
4645 TEST_c_c (casinh, 0x1p-63L, -0.5L, 1.251928832280966098829878787499365228659e-19L, -5.235987755982988730771072305465838140283e-1L),
4646 TEST_c_c (casinh, -0x1p-63L, 0.5L, -1.251928832280966098829878787499365228659e-19L, 5.235987755982988730771072305465838140283e-1L),
4647 TEST_c_c (casinh, -0x1p-63L, -0.5L, -1.251928832280966098829878787499365228659e-19L, -5.235987755982988730771072305465838140283e-1L),
4648 TEST_c_c (casinh, 0.5L, 0x1p-63L, 4.812118250596034474977589134243684231373e-1L, 9.697399036122160144833087173623140436413e-20L),
4649 TEST_c_c (casinh, -0.5L, 0x1p-63L, -4.812118250596034474977589134243684231373e-1L, 9.697399036122160144833087173623140436413e-20L),
4650 TEST_c_c (casinh, 0.5L, -0x1p-63L, 4.812118250596034474977589134243684231373e-1L, -9.697399036122160144833087173623140436413e-20L),
4651 TEST_c_c (casinh, -0.5L, -0x1p-63L, -4.812118250596034474977589134243684231373e-1L, -9.697399036122160144833087173623140436413e-20L),
4652 #if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
4653 TEST_c_c (casinh, 0x1.fp-16385L, 0.5L, 9.402257155670418112159334875199821342890e-4933L, 5.235987755982988730771072305465838140329e-1L, UNDERFLOW_EXCEPTION),
4654 TEST_c_c (casinh, 0x1.fp-16385L, -0.5L, 9.402257155670418112159334875199821342890e-4933L, -5.235987755982988730771072305465838140329e-1L, UNDERFLOW_EXCEPTION),
4655 TEST_c_c (casinh, -0x1.fp-16385L, 0.5L, -9.402257155670418112159334875199821342890e-4933L, 5.235987755982988730771072305465838140329e-1L, UNDERFLOW_EXCEPTION),
4656 TEST_c_c (casinh, -0x1.fp-16385L, -0.5L, -9.402257155670418112159334875199821342890e-4933L, -5.235987755982988730771072305465838140329e-1L, UNDERFLOW_EXCEPTION),
4657 TEST_c_c (casinh, 0.5L, 0x1.fp-16385L, 4.812118250596034474977589134243684231352e-1L, 7.282957076134209141226696333885150260319e-4933L, UNDERFLOW_EXCEPTION),
4658 TEST_c_c (casinh, -0.5L, 0x1.fp-16385L, -4.812118250596034474977589134243684231352e-1L, 7.282957076134209141226696333885150260319e-4933L, UNDERFLOW_EXCEPTION),
4659 TEST_c_c (casinh, 0.5L, -0x1.fp-16385L, 4.812118250596034474977589134243684231352e-1L, -7.282957076134209141226696333885150260319e-4933L, UNDERFLOW_EXCEPTION),
4660 TEST_c_c (casinh, -0.5L, -0x1.fp-16385L, -4.812118250596034474977589134243684231352e-1L, -7.282957076134209141226696333885150260319e-4933L, UNDERFLOW_EXCEPTION),
4661 #endif
4662 TEST_c_c (casinh, 0x1p-63L, 0x1p-63L, 1.084202172485504434007452800869941711430e-19L, 1.084202172485504434007452800869941711422e-19L),
4663 TEST_c_c (casinh, 0x1p-63L, -0x1p-63L, 1.084202172485504434007452800869941711430e-19L, -1.084202172485504434007452800869941711422e-19L),
4664 TEST_c_c (casinh, -0x1p-63L, 0x1p-63L, -1.084202172485504434007452800869941711430e-19L, 1.084202172485504434007452800869941711422e-19L),
4665 TEST_c_c (casinh, -0x1p-63L, -0x1p-63L, -1.084202172485504434007452800869941711430e-19L, -1.084202172485504434007452800869941711422e-19L),
4666 #if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
4667 TEST_c_c (casinh, 0x1.fp-16385L, 0x1p-63L, 8.142593549724601460479922838826119584465e-4933L, 1.084202172485504434007452800869941711428e-19L, UNDERFLOW_EXCEPTION),
4668 TEST_c_c (casinh, 0x1.fp-16385L, -0x1p-63L, 8.142593549724601460479922838826119584465e-4933L, -1.084202172485504434007452800869941711428e-19L, UNDERFLOW_EXCEPTION),
4669 TEST_c_c (casinh, -0x1.fp-16385L, 0x1p-63L, -8.142593549724601460479922838826119584465e-4933L, 1.084202172485504434007452800869941711428e-19L, UNDERFLOW_EXCEPTION),
4670 TEST_c_c (casinh, -0x1.fp-16385L, -0x1p-63L, -8.142593549724601460479922838826119584465e-4933L, -1.084202172485504434007452800869941711428e-19L, UNDERFLOW_EXCEPTION),
4671 TEST_c_c (casinh, 0x1p-63L, 0x1.fp-16385L, 1.084202172485504434007452800869941711424e-19L, 8.142593549724601460479922838826119584369e-4933L, UNDERFLOW_EXCEPTION),
4672 TEST_c_c (casinh, -0x1p-63L, 0x1.fp-16385L, -1.084202172485504434007452800869941711424e-19L, 8.142593549724601460479922838826119584369e-4933L, UNDERFLOW_EXCEPTION),
4673 TEST_c_c (casinh, 0x1p-63L, -0x1.fp-16385L, 1.084202172485504434007452800869941711424e-19L, -8.142593549724601460479922838826119584369e-4933L, UNDERFLOW_EXCEPTION),
4674 TEST_c_c (casinh, -0x1p-63L, -0x1.fp-16385L, -1.084202172485504434007452800869941711424e-19L, -8.142593549724601460479922838826119584369e-4933L, UNDERFLOW_EXCEPTION),
4675 #endif
4676 TEST_c_c (casinh, 0.0L, 0x1p-63L, 0.0L, 1.084202172485504434007452800869941711428e-19L),
4677 TEST_c_c (casinh, 0.0L, -0x1p-63L, 0.0L, -1.084202172485504434007452800869941711428e-19L),
4678 TEST_c_c (casinh, -0.0L, 0x1p-63L, -0.0L, 1.084202172485504434007452800869941711428e-19L),
4679 TEST_c_c (casinh, -0.0L, -0x1p-63L, -0.0L, -1.084202172485504434007452800869941711428e-19L),
4680 TEST_c_c (casinh, 0x1p-63L, 0.0L, 1.084202172485504434007452800869941711424e-19L, 0.0L),
4681 TEST_c_c (casinh, -0x1p-63L, 0.0L, -1.084202172485504434007452800869941711424e-19L, 0.0L),
4682 TEST_c_c (casinh, 0x1p-63L, -0.0L, 1.084202172485504434007452800869941711424e-19L, -0.0L),
4683 TEST_c_c (casinh, -0x1p-63L, -0.0L, -1.084202172485504434007452800869941711424e-19L, -0.0L),
4684 #if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
4685 TEST_c_c (casinh, 0x1.fp-16385L, 0x1.fp-16385L, 8.142593549724601460479922838826119584417e-4933L, 8.142593549724601460479922838826119584417e-4933L, UNDERFLOW_EXCEPTION),
4686 TEST_c_c (casinh, 0x1.fp-16385L, -0x1.fp-16385L, 8.142593549724601460479922838826119584417e-4933L, -8.142593549724601460479922838826119584417e-4933L, UNDERFLOW_EXCEPTION),
4687 TEST_c_c (casinh, -0x1.fp-16385L, 0x1.fp-16385L, -8.142593549724601460479922838826119584417e-4933L, 8.142593549724601460479922838826119584417e-4933L, UNDERFLOW_EXCEPTION),
4688 TEST_c_c (casinh, -0x1.fp-16385L, -0x1.fp-16385L, -8.142593549724601460479922838826119584417e-4933L, -8.142593549724601460479922838826119584417e-4933L, UNDERFLOW_EXCEPTION),
4689 #endif
4690 #if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 106
4691 TEST_c_c (casinh, 0x1p-105L, 0x0.ffffffffffffffffffffffffffcp0L, 1.234330349600789959989661887846005659983e-16L, 1.570796326794896419512475791677915736035L),
4692 TEST_c_c (casinh, 0x1p-105L, -0x0.ffffffffffffffffffffffffffcp0L, 1.234330349600789959989661887846005659983e-16L, -1.570796326794896419512475791677915736035L),
4693 TEST_c_c (casinh, -0x1p-105L, 0x0.ffffffffffffffffffffffffffcp0L, -1.234330349600789959989661887846005659983e-16L, 1.570796326794896419512475791677915736035L),
4694 TEST_c_c (casinh, -0x1p-105L, -0x0.ffffffffffffffffffffffffffcp0L, -1.234330349600789959989661887846005659983e-16L, -1.570796326794896419512475791677915736035L),
4695 TEST_c_c (casinh, 0x0.ffffffffffffffffffffffffffcp0L, 0x1p-105L, 8.813735870195430252326093249797835932642e-1L, 1.743152798421049375791483240187377443526e-32L),
4696 TEST_c_c (casinh, -0x0.ffffffffffffffffffffffffffcp0L, 0x1p-105L, -8.813735870195430252326093249797835932642e-1L, 1.743152798421049375791483240187377443526e-32L),
4697 TEST_c_c (casinh, 0x0.ffffffffffffffffffffffffffcp0L, -0x1p-105L, 8.813735870195430252326093249797835932642e-1L, -1.743152798421049375791483240187377443526e-32L),
4698 TEST_c_c (casinh, -0x0.ffffffffffffffffffffffffffcp0L, -0x1p-105L, -8.813735870195430252326093249797835932642e-1L, -1.743152798421049375791483240187377443526e-32L),
4699 TEST_c_c (casinh, 0x1.fp-1025L, 0x0.ffffffffffffffffffffffffffcp0L, 3.432186888910770473784103112009399360940e-293L, 1.570796326794896462222075823262245502760L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
4700 TEST_c_c (casinh, 0x1.fp-1025L, -0x0.ffffffffffffffffffffffffffcp0L, 3.432186888910770473784103112009399360940e-293L, -1.570796326794896462222075823262245502760L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
4701 TEST_c_c (casinh, -0x1.fp-1025L, 0x0.ffffffffffffffffffffffffffcp0L, -3.432186888910770473784103112009399360940e-293L, 1.570796326794896462222075823262245502760L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
4702 TEST_c_c (casinh, -0x1.fp-1025L, -0x0.ffffffffffffffffffffffffffcp0L, -3.432186888910770473784103112009399360940e-293L, -1.570796326794896462222075823262245502760L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
4703 TEST_c_c (casinh, 0x0.ffffffffffffffffffffffffffcp0L, 0x1.fp-1025L, 8.813735870195430252326093249797835932642e-1L, 3.810492908885321743133304375216641110205e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
4704 TEST_c_c (casinh, -0x0.ffffffffffffffffffffffffffcp0L, 0x1.fp-1025L, -8.813735870195430252326093249797835932642e-1L, 3.810492908885321743133304375216641110205e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
4705 TEST_c_c (casinh, 0x0.ffffffffffffffffffffffffffcp0L, -0x1.fp-1025L, 8.813735870195430252326093249797835932642e-1L, -3.810492908885321743133304375216641110205e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
4706 TEST_c_c (casinh, -0x0.ffffffffffffffffffffffffffcp0L, -0x1.fp-1025L, -8.813735870195430252326093249797835932642e-1L, -3.810492908885321743133304375216641110205e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
4707 TEST_c_c (casinh, 0.0L, 0x0.ffffffffffffffffffffffffffcp0L, 0.0L, 1.570796326794896462222075823262245502760L),
4708 TEST_c_c (casinh, 0.0L, -0x0.ffffffffffffffffffffffffffcp0L, 0.0L, -1.570796326794896462222075823262245502760L),
4709 TEST_c_c (casinh, -0.0L, 0x0.ffffffffffffffffffffffffffcp0L, -0.0L, 1.570796326794896462222075823262245502760L),
4710 TEST_c_c (casinh, -0.0L, -0x0.ffffffffffffffffffffffffffcp0L, -0.0L, -1.570796326794896462222075823262245502760L),
4711 TEST_c_c (casinh, 0x0.ffffffffffffffffffffffffffcp0L, 0.0L, 8.813735870195430252326093249797835932642e-1L, 0.0L),
4712 TEST_c_c (casinh, -0x0.ffffffffffffffffffffffffffcp0L, 0.0L, -8.813735870195430252326093249797835932642e-1L, 0.0L),
4713 TEST_c_c (casinh, 0x0.ffffffffffffffffffffffffffcp0L, -0.0L, 8.813735870195430252326093249797835932642e-1L, -0.0L),
4714 TEST_c_c (casinh, -0x0.ffffffffffffffffffffffffffcp0L, -0.0L, -8.813735870195430252326093249797835932642e-1L, -0.0L),
4715 #endif
4716 TEST_c_c (casinh, 0x1p-105L, 0.5L, 2.846556599890768890940941645338546615370e-32L, 5.235987755982988730771072305465838140329e-1L),
4717 TEST_c_c (casinh, 0x1p-105L, -0.5L, 2.846556599890768890940941645338546615370e-32L, -5.235987755982988730771072305465838140329e-1L),
4718 TEST_c_c (casinh, -0x1p-105L, 0.5L, -2.846556599890768890940941645338546615370e-32L, 5.235987755982988730771072305465838140329e-1L),
4719 TEST_c_c (casinh, -0x1p-105L, -0.5L, -2.846556599890768890940941645338546615370e-32L, -5.235987755982988730771072305465838140329e-1L),
4720 TEST_c_c (casinh, 0.5L, 0x1p-105L, 4.812118250596034474977589134243684231352e-1L, 2.204933261082751447436996198490110245167e-32L),
4721 TEST_c_c (casinh, -0.5L, 0x1p-105L, -4.812118250596034474977589134243684231352e-1L, 2.204933261082751447436996198490110245167e-32L),
4722 TEST_c_c (casinh, 0.5L, -0x1p-105L, 4.812118250596034474977589134243684231352e-1L, -2.204933261082751447436996198490110245167e-32L),
4723 TEST_c_c (casinh, -0.5L, -0x1p-105L, -4.812118250596034474977589134243684231352e-1L, -2.204933261082751447436996198490110245167e-32L),
4724 TEST_c_c (casinh, 0x1p-105L, 0x1p-105L, 2.465190328815661891911651766508706967729e-32L, 2.465190328815661891911651766508706967729e-32L),
4725 TEST_c_c (casinh, 0x1p-105L, -0x1p-105L, 2.465190328815661891911651766508706967729e-32L, -2.465190328815661891911651766508706967729e-32L),
4726 TEST_c_c (casinh, -0x1p-105L, 0x1p-105L, -2.465190328815661891911651766508706967729e-32L, 2.465190328815661891911651766508706967729e-32L),
4727 TEST_c_c (casinh, -0x1p-105L, -0x1p-105L, -2.465190328815661891911651766508706967729e-32L, -2.465190328815661891911651766508706967729e-32L),
4728 #ifndef TEST_FLOAT
4729 TEST_c_c (casinh, 0x1.fp-1025L, 0x1p-105L, 5.388850751072128349671657362289416093031e-309L, 2.465190328815661891911651766508706967729e-32L, UNDERFLOW_EXCEPTION_DOUBLE),
4730 TEST_c_c (casinh, 0x1.fp-1025L, -0x1p-105L, 5.388850751072128349671657362289416093031e-309L, -2.465190328815661891911651766508706967729e-32L, UNDERFLOW_EXCEPTION_DOUBLE),
4731 TEST_c_c (casinh, -0x1.fp-1025L, 0x1p-105L, -5.388850751072128349671657362289416093031e-309L, 2.465190328815661891911651766508706967729e-32L, UNDERFLOW_EXCEPTION_DOUBLE),
4732 TEST_c_c (casinh, -0x1.fp-1025L, -0x1p-105L, -5.388850751072128349671657362289416093031e-309L, -2.465190328815661891911651766508706967729e-32L, UNDERFLOW_EXCEPTION_DOUBLE),
4733 /* Bug 15319: underflow exception may be missing. */
4734 TEST_c_c (casinh, 0x1p-105L, 0x1.fp-1025L, 2.465190328815661891911651766508706967729e-32L, 5.388850751072128349671657362289416093031e-309L, UNDERFLOW_EXCEPTION_OK_DOUBLE),
4735 TEST_c_c (casinh, -0x1p-105L, 0x1.fp-1025L, -2.465190328815661891911651766508706967729e-32L, 5.388850751072128349671657362289416093031e-309L, UNDERFLOW_EXCEPTION_OK_DOUBLE),
4736 TEST_c_c (casinh, 0x1p-105L, -0x1.fp-1025L, 2.465190328815661891911651766508706967729e-32L, -5.388850751072128349671657362289416093031e-309L, UNDERFLOW_EXCEPTION_OK_DOUBLE),
4737 TEST_c_c (casinh, -0x1p-105L, -0x1.fp-1025L, -2.465190328815661891911651766508706967729e-32L, -5.388850751072128349671657362289416093031e-309L, UNDERFLOW_EXCEPTION_OK_DOUBLE),
4738 #endif
4739 TEST_c_c (casinh, 0.0L, 0x1p-105L, 0.0L, 2.465190328815661891911651766508706967729e-32L),
4740 TEST_c_c (casinh, 0.0L, -0x1p-105L, 0.0L, -2.465190328815661891911651766508706967729e-32L),
4741 TEST_c_c (casinh, -0.0L, 0x1p-105L, -0.0L, 2.465190328815661891911651766508706967729e-32L),
4742 TEST_c_c (casinh, -0.0L, -0x1p-105L, -0.0L, -2.465190328815661891911651766508706967729e-32L),
4743 TEST_c_c (casinh, 0x1p-105L, 0.0L, 2.465190328815661891911651766508706967729e-32L, 0.0L),
4744 TEST_c_c (casinh, -0x1p-105L, 0.0L, -2.465190328815661891911651766508706967729e-32L, 0.0L),
4745 TEST_c_c (casinh, 0x1p-105L, -0.0L, 2.465190328815661891911651766508706967729e-32L, -0.0L),
4746 TEST_c_c (casinh, -0x1p-105L, -0.0L, -2.465190328815661891911651766508706967729e-32L, -0.0L),
4747 #if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 113
4748 TEST_c_c (casinh, 0x1p-112L, 0x0.ffffffffffffffffffffffffffff8p0L, 1.091004200533850618345330909857103457781e-17L, 1.570796326794896601578502908312986698624L),
4749 TEST_c_c (casinh, 0x1p-112L, -0x0.ffffffffffffffffffffffffffff8p0L, 1.091004200533850618345330909857103457781e-17L, -1.570796326794896601578502908312986698624L),
4750 TEST_c_c (casinh, -0x1p-112L, 0x0.ffffffffffffffffffffffffffff8p0L, -1.091004200533850618345330909857103457781e-17L, 1.570796326794896601578502908312986698624L),
4751 TEST_c_c (casinh, -0x1p-112L, -0x0.ffffffffffffffffffffffffffff8p0L, -1.091004200533850618345330909857103457781e-17L, -1.570796326794896601578502908312986698624L),
4752 TEST_c_c (casinh, 0x0.ffffffffffffffffffffffffffff8p0L, 0x1p-112L, 8.813735870195430252326093249797922409363e-1L, 1.361838123766444824837096281396380300349e-34L),
4753 TEST_c_c (casinh, -0x0.ffffffffffffffffffffffffffff8p0L, 0x1p-112L, -8.813735870195430252326093249797922409363e-1L, 1.361838123766444824837096281396380300349e-34L),
4754 TEST_c_c (casinh, 0x0.ffffffffffffffffffffffffffff8p0L, -0x1p-112L, 8.813735870195430252326093249797922409363e-1L, -1.361838123766444824837096281396380300349e-34L),
4755 TEST_c_c (casinh, -0x0.ffffffffffffffffffffffffffff8p0L, -0x1p-112L, -8.813735870195430252326093249797922409363e-1L, -1.361838123766444824837096281396380300349e-34L),
4756 TEST_c_c (casinh, 0x1.fp-16385L, 0x0.ffffffffffffffffffffffffffff8p0L, 5.867357004219059108790368268900490184505e-4916L, 1.570796326794896605353533883825294686803L),
4757 TEST_c_c (casinh, 0x1.fp-16385L, -0x0.ffffffffffffffffffffffffffff8p0L, 5.867357004219059108790368268900490184505e-4916L, -1.570796326794896605353533883825294686803L),
4758 TEST_c_c (casinh, -0x1.fp-16385L, 0x0.ffffffffffffffffffffffffffff8p0L, -5.867357004219059108790368268900490184505e-4916L, 1.570796326794896605353533883825294686803L),
4759 TEST_c_c (casinh, -0x1.fp-16385L, -0x0.ffffffffffffffffffffffffffff8p0L, -5.867357004219059108790368268900490184505e-4916L, -1.570796326794896605353533883825294686803L),
4760 TEST_c_c (casinh, 0x0.ffffffffffffffffffffffffffff8p0L, 0x1.fp-16385L, 8.813735870195430252326093249797922409363e-1L, 5.757683115456107044131264955348449231681e-4933L, UNDERFLOW_EXCEPTION),
4761 TEST_c_c (casinh, -0x0.ffffffffffffffffffffffffffff8p0L, 0x1.fp-16385L, -8.813735870195430252326093249797922409363e-1L, 5.757683115456107044131264955348449231681e-4933L, UNDERFLOW_EXCEPTION),
4762 TEST_c_c (casinh, 0x0.ffffffffffffffffffffffffffff8p0L, -0x1.fp-16385L, 8.813735870195430252326093249797922409363e-1L, -5.757683115456107044131264955348449231681e-4933L, UNDERFLOW_EXCEPTION),
4763 TEST_c_c (casinh, -0x0.ffffffffffffffffffffffffffff8p0L, -0x1.fp-16385L, -8.813735870195430252326093249797922409363e-1L, -5.757683115456107044131264955348449231681e-4933L, UNDERFLOW_EXCEPTION),
4764 TEST_c_c (casinh, 0.0L, 0x0.ffffffffffffffffffffffffffff8p0L, 0.0L, 1.570796326794896605353533883825294686803L),
4765 TEST_c_c (casinh, 0.0L, -0x0.ffffffffffffffffffffffffffff8p0L, 0.0L, -1.570796326794896605353533883825294686803L),
4766 TEST_c_c (casinh, -0.0L, 0x0.ffffffffffffffffffffffffffff8p0L, -0.0L, 1.570796326794896605353533883825294686803L),
4767 TEST_c_c (casinh, -0.0L, -0x0.ffffffffffffffffffffffffffff8p0L, -0.0L, -1.570796326794896605353533883825294686803L),
4768 TEST_c_c (casinh, 0x0.ffffffffffffffffffffffffffff8p0L, 0.0L, 8.813735870195430252326093249797922409363e-1L, 0.0L),
4769 TEST_c_c (casinh, -0x0.ffffffffffffffffffffffffffff8p0L, 0.0L, -8.813735870195430252326093249797922409363e-1L, 0.0L),
4770 TEST_c_c (casinh, 0x0.ffffffffffffffffffffffffffff8p0L, -0.0L, 8.813735870195430252326093249797922409363e-1L, -0.0L),
4771 TEST_c_c (casinh, -0x0.ffffffffffffffffffffffffffff8p0L, -0.0L, -8.813735870195430252326093249797922409363e-1L, -0.0L),
4772 #endif
4773 TEST_c_c (casinh, 0x1p-112L, 0.5L, 2.223872343664663196047610660420739543258e-34L, 5.235987755982988730771072305465838140329e-1L),
4774 TEST_c_c (casinh, 0x1p-112L, -0.5L, 2.223872343664663196047610660420739543258e-34L, -5.235987755982988730771072305465838140329e-1L),
4775 TEST_c_c (casinh, -0x1p-112L, 0.5L, -2.223872343664663196047610660420739543258e-34L, 5.235987755982988730771072305465838140329e-1L),
4776 TEST_c_c (casinh, -0x1p-112L, -0.5L, -2.223872343664663196047610660420739543258e-34L, -5.235987755982988730771072305465838140329e-1L),
4777 TEST_c_c (casinh, 0.5L, 0x1p-112L, 4.812118250596034474977589134243684231352e-1L, 1.722604110220899568310153280070398629037e-34L),
4778 TEST_c_c (casinh, -0.5L, 0x1p-112L, -4.812118250596034474977589134243684231352e-1L, 1.722604110220899568310153280070398629037e-34L),
4779 TEST_c_c (casinh, 0.5L, -0x1p-112L, 4.812118250596034474977589134243684231352e-1L, -1.722604110220899568310153280070398629037e-34L),
4780 TEST_c_c (casinh, -0.5L, -0x1p-112L, -4.812118250596034474977589134243684231352e-1L, -1.722604110220899568310153280070398629037e-34L),
4781 TEST_c_c (casinh, 0x1p-112L, 0x1p-112L, 1.925929944387235853055977942584927318538e-34L, 1.925929944387235853055977942584927318538e-34L),
4782 TEST_c_c (casinh, 0x1p-112L, -0x1p-112L, 1.925929944387235853055977942584927318538e-34L, -1.925929944387235853055977942584927318538e-34L),
4783 TEST_c_c (casinh, -0x1p-112L, 0x1p-112L, -1.925929944387235853055977942584927318538e-34L, 1.925929944387235853055977942584927318538e-34L),
4784 TEST_c_c (casinh, -0x1p-112L, -0x1p-112L, -1.925929944387235853055977942584927318538e-34L, -1.925929944387235853055977942584927318538e-34L),
4785 #if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
4786 TEST_c_c (casinh, 0x1.fp-16385L, 0x1p-112L, 8.142593549724601460479922838826119584417e-4933L, 1.925929944387235853055977942584927318538e-34L, UNDERFLOW_EXCEPTION),
4787 TEST_c_c (casinh, 0x1.fp-16385L, -0x1p-112L, 8.142593549724601460479922838826119584417e-4933L, -1.925929944387235853055977942584927318538e-34L, UNDERFLOW_EXCEPTION),
4788 TEST_c_c (casinh, -0x1.fp-16385L, 0x1p-112L, -8.142593549724601460479922838826119584417e-4933L, 1.925929944387235853055977942584927318538e-34L, UNDERFLOW_EXCEPTION),
4789 TEST_c_c (casinh, -0x1.fp-16385L, -0x1p-112L, -8.142593549724601460479922838826119584417e-4933L, -1.925929944387235853055977942584927318538e-34L, UNDERFLOW_EXCEPTION),
4790 TEST_c_c (casinh, 0x1p-112L, 0x1.fp-16385L, 1.925929944387235853055977942584927318538e-34L, 8.142593549724601460479922838826119584417e-4933L, UNDERFLOW_EXCEPTION),
4791 TEST_c_c (casinh, -0x1p-112L, 0x1.fp-16385L, -1.925929944387235853055977942584927318538e-34L, 8.142593549724601460479922838826119584417e-4933L, UNDERFLOW_EXCEPTION),
4792 TEST_c_c (casinh, 0x1p-112L, -0x1.fp-16385L, 1.925929944387235853055977942584927318538e-34L, -8.142593549724601460479922838826119584417e-4933L, UNDERFLOW_EXCEPTION),
4793 TEST_c_c (casinh, -0x1p-112L, -0x1.fp-16385L, -1.925929944387235853055977942584927318538e-34L, -8.142593549724601460479922838826119584417e-4933L, UNDERFLOW_EXCEPTION),
4794 #endif
4795 TEST_c_c (casinh, 0.0L, 0x1p-112L, 0.0L, 1.925929944387235853055977942584927318538e-34L),
4796 TEST_c_c (casinh, 0.0L, -0x1p-112L, 0.0L, -1.925929944387235853055977942584927318538e-34L),
4797 TEST_c_c (casinh, -0.0L, 0x1p-112L, -0.0L, 1.925929944387235853055977942584927318538e-34L),
4798 TEST_c_c (casinh, -0.0L, -0x1p-112L, -0.0L, -1.925929944387235853055977942584927318538e-34L),
4799 TEST_c_c (casinh, 0x1p-112L, 0.0L, 1.925929944387235853055977942584927318538e-34L, 0.0L),
4800 TEST_c_c (casinh, -0x1p-112L, 0.0L, -1.925929944387235853055977942584927318538e-34L, 0.0L),
4801 TEST_c_c (casinh, 0x1p-112L, -0.0L, 1.925929944387235853055977942584927318538e-34L, -0.0L),
4802 TEST_c_c (casinh, -0x1p-112L, -0.0L, -1.925929944387235853055977942584927318538e-34L, -0.0L),
4803
4804 TEST_c_c (casinh, 0.75L, 1.25L, 1.03171853444778027336364058631006594L, 0.911738290968487636358489564316731207L),
4805 TEST_c_c (casinh, -2, -3, -1.9686379257930962917886650952454982L, -0.96465850440760279204541105949953237L),
4806 END_DATA (casinh)
4807 };
4808
4809 static void
4810 casinh_test (void)
4811 {
4812 errno = 0;
4813 FUNC(casinh) (BUILD_COMPLEX (0.7L, 1.2L));
4814 if (errno == ENOSYS)
4815 /* Function not implemented. */
4816 return;
4817
4818 START (casinh);
4819 RUN_TEST_LOOP_c_c (casinh, casinh_test_data, );
4820 END (casinh, complex);
4821 }
4822
4823
4824 static const struct test_c_c_data catan_test_data[] =
4825 {
4826 START_DATA (catan),
4827 TEST_c_c (catan, 0, 0, 0, 0),
4828 TEST_c_c (catan, minus_zero, 0, minus_zero, 0),
4829 TEST_c_c (catan, 0, minus_zero, 0, minus_zero),
4830 TEST_c_c (catan, minus_zero, minus_zero, minus_zero, minus_zero),
4831
4832 TEST_c_c (catan, 1.0L, plus_zero, M_PI_4l, plus_zero),
4833 TEST_c_c (catan, 1.0L, minus_zero, M_PI_4l, minus_zero),
4834 TEST_c_c (catan, -1.0L, plus_zero, -M_PI_4l, plus_zero),
4835 TEST_c_c (catan, -1.0L, minus_zero, -M_PI_4l, minus_zero),
4836 TEST_c_c (catan, plus_zero, 1.0L, plus_zero, plus_infty, DIVIDE_BY_ZERO_EXCEPTION),
4837 TEST_c_c (catan, minus_zero, 1.0L, minus_zero, plus_infty, DIVIDE_BY_ZERO_EXCEPTION),
4838 TEST_c_c (catan, plus_zero, -1.0L, plus_zero, minus_infty, DIVIDE_BY_ZERO_EXCEPTION),
4839 TEST_c_c (catan, minus_zero, -1.0L, minus_zero, minus_infty, DIVIDE_BY_ZERO_EXCEPTION),
4840
4841 TEST_c_c (catan, plus_infty, plus_infty, M_PI_2l, 0),
4842 TEST_c_c (catan, plus_infty, minus_infty, M_PI_2l, minus_zero),
4843 TEST_c_c (catan, minus_infty, plus_infty, -M_PI_2l, 0),
4844 TEST_c_c (catan, minus_infty, minus_infty, -M_PI_2l, minus_zero),
4845
4846
4847 TEST_c_c (catan, plus_infty, -10.0, M_PI_2l, minus_zero),
4848 TEST_c_c (catan, minus_infty, -10.0, -M_PI_2l, minus_zero),
4849 TEST_c_c (catan, plus_infty, minus_zero, M_PI_2l, minus_zero),
4850 TEST_c_c (catan, minus_infty, minus_zero, -M_PI_2l, minus_zero),
4851 TEST_c_c (catan, plus_infty, 0.0, M_PI_2l, 0),
4852 TEST_c_c (catan, minus_infty, 0.0, -M_PI_2l, 0),
4853 TEST_c_c (catan, plus_infty, 0.1L, M_PI_2l, 0),
4854 TEST_c_c (catan, minus_infty, 0.1L, -M_PI_2l, 0),
4855
4856 TEST_c_c (catan, 0.0, minus_infty, M_PI_2l, minus_zero),
4857 TEST_c_c (catan, minus_zero, minus_infty, -M_PI_2l, minus_zero),
4858 TEST_c_c (catan, 100.0, minus_infty, M_PI_2l, minus_zero),
4859 TEST_c_c (catan, -100.0, minus_infty, -M_PI_2l, minus_zero),
4860
4861 TEST_c_c (catan, 0.0, plus_infty, M_PI_2l, 0),
4862 TEST_c_c (catan, minus_zero, plus_infty, -M_PI_2l, 0),
4863 TEST_c_c (catan, 0.5, plus_infty, M_PI_2l, 0),
4864 TEST_c_c (catan, -0.5, plus_infty, -M_PI_2l, 0),
4865
4866 TEST_c_c (catan, qnan_value, 0.0, qnan_value, 0),
4867 TEST_c_c (catan, qnan_value, minus_zero, qnan_value, minus_zero),
4868
4869 TEST_c_c (catan, qnan_value, plus_infty, qnan_value, 0),
4870 TEST_c_c (catan, qnan_value, minus_infty, qnan_value, minus_zero),
4871
4872 TEST_c_c (catan, 0.0, qnan_value, qnan_value, qnan_value),
4873 TEST_c_c (catan, minus_zero, qnan_value, qnan_value, qnan_value),
4874
4875 TEST_c_c (catan, plus_infty, qnan_value, M_PI_2l, 0, IGNORE_ZERO_INF_SIGN),
4876 TEST_c_c (catan, minus_infty, qnan_value, -M_PI_2l, 0, IGNORE_ZERO_INF_SIGN),
4877
4878 TEST_c_c (catan, qnan_value, 10.5, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
4879 TEST_c_c (catan, qnan_value, -10.5, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
4880
4881 TEST_c_c (catan, 0.75, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
4882 TEST_c_c (catan, -0.75, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
4883
4884 TEST_c_c (catan, qnan_value, qnan_value, qnan_value, qnan_value),
4885
4886 TEST_c_c (catan, 0x1p50L, 0.0L, 1.570796326794895731052901991514519103193L, 0.0L),
4887 TEST_c_c (catan, 0x1p50L, -0.0L, 1.570796326794895731052901991514519103193L, -0.0L),
4888 TEST_c_c (catan, -0x1p50L, 0.0L, -1.570796326794895731052901991514519103193L, 0.0L),
4889 TEST_c_c (catan, -0x1p50L, -0.0L, -1.570796326794895731052901991514519103193L, -0.0L),
4890 TEST_c_c (catan, 0.0L, 0x1p50L, 1.570796326794896619231321691639751442099L, 8.881784197001252323389053344728897997441e-16L),
4891 TEST_c_c (catan, -0.0L, 0x1p50L, -1.570796326794896619231321691639751442099L, 8.881784197001252323389053344728897997441e-16L),
4892 TEST_c_c (catan, 0.0L, -0x1p50L, 1.570796326794896619231321691639751442099L, -8.881784197001252323389053344728897997441e-16L),
4893 TEST_c_c (catan, -0.0L, -0x1p50L, -1.570796326794896619231321691639751442099L, -8.881784197001252323389053344728897997441e-16L),
4894 #ifndef TEST_FLOAT
4895 TEST_c_c (catan, 0x1p500L, 0.0L, 1.570796326794896619231321691639751442099L, 0.0L),
4896 TEST_c_c (catan, 0x1p500L, -0.0L, 1.570796326794896619231321691639751442099L, -0.0L),
4897 TEST_c_c (catan, -0x1p500L, 0.0L, -1.570796326794896619231321691639751442099L, 0.0L),
4898 TEST_c_c (catan, -0x1p500L, -0.0L, -1.570796326794896619231321691639751442099L, -0.0L),
4899 TEST_c_c (catan, 0.0L, 0x1p500L, 1.570796326794896619231321691639751442099L, 3.054936363499604682051979393213617699789e-151L),
4900 TEST_c_c (catan, -0.0L, 0x1p500L, -1.570796326794896619231321691639751442099L, 3.054936363499604682051979393213617699789e-151L),
4901 TEST_c_c (catan, 0.0L, -0x1p500L, 1.570796326794896619231321691639751442099L, -3.054936363499604682051979393213617699789e-151L),
4902 TEST_c_c (catan, -0.0L, -0x1p500L, -1.570796326794896619231321691639751442099L, -3.054936363499604682051979393213617699789e-151L),
4903 #endif
4904 #if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
4905 TEST_c_c (catan, 0x1p5000L, 0.0L, 1.570796326794896619231321691639751442099L, 0.0L),
4906 TEST_c_c (catan, 0x1p5000L, -0.0L, 1.570796326794896619231321691639751442099L, -0.0L),
4907 TEST_c_c (catan, -0x1p5000L, 0.0L, -1.570796326794896619231321691639751442099L, 0.0L),
4908 TEST_c_c (catan, -0x1p5000L, -0.0L, -1.570796326794896619231321691639751442099L, -0.0L),
4909 TEST_c_c (catan, 0.0L, 0x1p5000L, 1.570796326794896619231321691639751442099L, 7.079811261048172892385615158694057552948e-1506L),
4910 TEST_c_c (catan, -0.0L, 0x1p5000L, -1.570796326794896619231321691639751442099L, 7.079811261048172892385615158694057552948e-1506L),
4911 TEST_c_c (catan, 0.0L, -0x1p5000L, 1.570796326794896619231321691639751442099L, -7.079811261048172892385615158694057552948e-1506L),
4912 TEST_c_c (catan, -0.0L, -0x1p5000L, -1.570796326794896619231321691639751442099L, -7.079811261048172892385615158694057552948e-1506L),
4913 #endif
4914 TEST_c_c (catan, 0x1p63L, 0.5L, 1.570796326794896619122901474391200998698L, 5.877471754111437539843682686111228389007e-39L, UNDERFLOW_EXCEPTION_FLOAT),
4915 TEST_c_c (catan, 0x1p63L, -0.5L, 1.570796326794896619122901474391200998698L, -5.877471754111437539843682686111228389007e-39L, UNDERFLOW_EXCEPTION_FLOAT),
4916 TEST_c_c (catan, -0x1p63L, 0.5L, -1.570796326794896619122901474391200998698L, 5.877471754111437539843682686111228389007e-39L, UNDERFLOW_EXCEPTION_FLOAT),
4917 TEST_c_c (catan, -0x1p63L, -0.5L, -1.570796326794896619122901474391200998698L, -5.877471754111437539843682686111228389007e-39L, UNDERFLOW_EXCEPTION_FLOAT),
4918 TEST_c_c (catan, 0.5L, 0x1p63L, 1.570796326794896619231321691639751442093L, 1.084202172485504434007452800869941711427e-19L),
4919 TEST_c_c (catan, -0.5L, 0x1p63L, -1.570796326794896619231321691639751442093L, 1.084202172485504434007452800869941711427e-19L),
4920 TEST_c_c (catan, 0.5L, -0x1p63L, 1.570796326794896619231321691639751442093L, -1.084202172485504434007452800869941711427e-19L),
4921 TEST_c_c (catan, -0.5L, -0x1p63L, -1.570796326794896619231321691639751442093L, -1.084202172485504434007452800869941711427e-19L),
4922 #ifndef TEST_FLOAT
4923 TEST_c_c (catan, 0x1p511L, 0.5L, 1.570796326794896619231321691639751442099L, 1.112536929253600691545116358666202032110e-308L, UNDERFLOW_EXCEPTION_DOUBLE),
4924 TEST_c_c (catan, 0x1p511L, -0.5L, 1.570796326794896619231321691639751442099L, -1.112536929253600691545116358666202032110e-308L, UNDERFLOW_EXCEPTION_DOUBLE),
4925 TEST_c_c (catan, -0x1p511L, 0.5L, -1.570796326794896619231321691639751442099L, 1.112536929253600691545116358666202032110e-308L, UNDERFLOW_EXCEPTION_DOUBLE),
4926 TEST_c_c (catan, -0x1p511L, -0.5L, -1.570796326794896619231321691639751442099L, -1.112536929253600691545116358666202032110e-308L, UNDERFLOW_EXCEPTION_DOUBLE),
4927 TEST_c_c (catan, 0.5L, 0x1p511L, 1.570796326794896619231321691639751442099L, 1.491668146240041348658193063092586767475e-154L),
4928 TEST_c_c (catan, -0.5L, 0x1p511L, -1.570796326794896619231321691639751442099L, 1.491668146240041348658193063092586767475e-154L),
4929 TEST_c_c (catan, 0.5L, -0x1p511L, 1.570796326794896619231321691639751442099L, -1.491668146240041348658193063092586767475e-154L),
4930 TEST_c_c (catan, -0.5L, -0x1p511L, -1.570796326794896619231321691639751442099L, -1.491668146240041348658193063092586767475e-154L),
4931 #endif
4932 #if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
4933 TEST_c_c (catan, 0x1p8191L, 0.5L, 1.570796326794896619231321691639751442099L, 1.681051571556046753131338908660876301299e-4932L, UNDERFLOW_EXCEPTION),
4934 TEST_c_c (catan, 0x1p8191L, -0.5L, 1.570796326794896619231321691639751442099L, -1.681051571556046753131338908660876301299e-4932L, UNDERFLOW_EXCEPTION),
4935 TEST_c_c (catan, -0x1p8191L, 0.5L, -1.570796326794896619231321691639751442099L, 1.681051571556046753131338908660876301299e-4932L, UNDERFLOW_EXCEPTION),
4936 TEST_c_c (catan, -0x1p8191L, -0.5L, -1.570796326794896619231321691639751442099L, -1.681051571556046753131338908660876301299e-4932L, UNDERFLOW_EXCEPTION),
4937 TEST_c_c (catan, 0.5L, 0x1p8191L, 1.570796326794896619231321691639751442099L, 1.833603867554847165621412392048483165956e-2466L),
4938 TEST_c_c (catan, -0.5L, 0x1p8191L, -1.570796326794896619231321691639751442099L, 1.833603867554847165621412392048483165956e-2466L),
4939 TEST_c_c (catan, 0.5L, -0x1p8191L, 1.570796326794896619231321691639751442099L, -1.833603867554847165621412392048483165956e-2466L),
4940 TEST_c_c (catan, -0.5L, -0x1p8191L, -1.570796326794896619231321691639751442099L, -1.833603867554847165621412392048483165956e-2466L),
4941 #endif
4942 TEST_c_c (catan, 0x1p100L, 0.0L, 1.570796326794896619231321691638962581193L, 0.0L),
4943 TEST_c_c (catan, 0x1p100L, -0.0L, 1.570796326794896619231321691638962581193L, -0.0L),
4944 TEST_c_c (catan, -0x1p100L, 0.0L, -1.570796326794896619231321691638962581193L, 0.0L),
4945 TEST_c_c (catan, -0x1p100L, -0.0L, -1.570796326794896619231321691638962581193L, -0.0L),
4946 TEST_c_c (catan, 0.0L, 0x1p100L, 1.570796326794896619231321691639751442099L, 7.888609052210118054117285652827862296732e-31L),
4947 TEST_c_c (catan, -0.0L, 0x1p100L, -1.570796326794896619231321691639751442099L, 7.888609052210118054117285652827862296732e-31L),
4948 TEST_c_c (catan, 0.0L, -0x1p100L, 1.570796326794896619231321691639751442099L, -7.888609052210118054117285652827862296732e-31L),
4949 TEST_c_c (catan, -0.0L, -0x1p100L, -1.570796326794896619231321691639751442099L, -7.888609052210118054117285652827862296732e-31L),
4950 TEST_c_c (catan, 0x1.fp127L, 0.0L, 1.570796326794896619231321691639751442096L, 0.0L),
4951 TEST_c_c (catan, 0x1.fp127L, -0.0L, 1.570796326794896619231321691639751442096L, -0.0L),
4952 TEST_c_c (catan, -0x1.fp127L, 0.0L, -1.570796326794896619231321691639751442096L, 0.0L),
4953 TEST_c_c (catan, -0x1.fp127L, -0.0L, -1.570796326794896619231321691639751442096L, -0.0L),
4954 TEST_c_c (catan, 0.0L, 0x1.fp127L, 1.570796326794896619231321691639751442099L, 3.033533808573645181854803967025150136306e-39L, UNDERFLOW_EXCEPTION_FLOAT),
4955 TEST_c_c (catan, -0.0L, 0x1.fp127L, -1.570796326794896619231321691639751442099L, 3.033533808573645181854803967025150136306e-39L, UNDERFLOW_EXCEPTION_FLOAT),
4956 TEST_c_c (catan, 0.0L, -0x1.fp127L, 1.570796326794896619231321691639751442099L, -3.033533808573645181854803967025150136306e-39L, UNDERFLOW_EXCEPTION_FLOAT),
4957 TEST_c_c (catan, -0.0L, -0x1.fp127L, -1.570796326794896619231321691639751442099L, -3.033533808573645181854803967025150136306e-39L, UNDERFLOW_EXCEPTION_FLOAT),
4958 TEST_c_c (catan, 0x1.fp127L, 0x1.fp127L, 1.570796326794896619231321691639751442097L, 1.516766904286822590927401983512575068153e-39L, UNDERFLOW_EXCEPTION_FLOAT),
4959 TEST_c_c (catan, 0x1.fp127L, -0x1.fp127L, 1.570796326794896619231321691639751442097L, -1.516766904286822590927401983512575068153e-39L, UNDERFLOW_EXCEPTION_FLOAT),
4960 TEST_c_c (catan, -0x1.fp127L, 0x1.fp127L, -1.570796326794896619231321691639751442097L, 1.516766904286822590927401983512575068153e-39L, UNDERFLOW_EXCEPTION_FLOAT),
4961 TEST_c_c (catan, -0x1.fp127L, -0x1.fp127L, -1.570796326794896619231321691639751442097L, -1.516766904286822590927401983512575068153e-39L, UNDERFLOW_EXCEPTION_FLOAT),
4962 #ifndef TEST_FLOAT
4963 TEST_c_c (catan, 0x1p900L, 0.0L, 1.570796326794896619231321691639751442099L, 0.0L),
4964 TEST_c_c (catan, 0x1p900L, -0.0L, 1.570796326794896619231321691639751442099L, -0.0L),
4965 TEST_c_c (catan, -0x1p900L, 0.0L, -1.570796326794896619231321691639751442099L, 0.0L),
4966 TEST_c_c (catan, -0x1p900L, -0.0L, -1.570796326794896619231321691639751442099L, -0.0L),
4967 TEST_c_c (catan, 0.0L, 0x1p900L, 1.570796326794896619231321691639751442099L, 1.183052186166774710972751597518026531652e-271L),
4968 TEST_c_c (catan, -0.0L, 0x1p900L, -1.570796326794896619231321691639751442099L, 1.183052186166774710972751597518026531652e-271L),
4969 TEST_c_c (catan, 0.0L, -0x1p900L, 1.570796326794896619231321691639751442099L, -1.183052186166774710972751597518026531652e-271L),
4970 TEST_c_c (catan, -0.0L, -0x1p900L, -1.570796326794896619231321691639751442099L, -1.183052186166774710972751597518026531652e-271L),
4971 TEST_c_c (catan, 0x1.fp1023L, 0.0L, 1.570796326794896619231321691639751442099L, 0.0L),
4972 TEST_c_c (catan, 0x1.fp1023L, -0.0L, 1.570796326794896619231321691639751442099L, -0.0L),
4973 TEST_c_c (catan, -0x1.fp1023L, 0.0L, -1.570796326794896619231321691639751442099L, 0.0L),
4974 TEST_c_c (catan, -0x1.fp1023L, -0.0L, -1.570796326794896619231321691639751442099L, -0.0L),
4975 TEST_c_c (catan, 0.0L, 0x1.fp1023L, 1.570796326794896619231321691639751442099L, 5.742126086470197117652213464083623391533e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
4976 TEST_c_c (catan, -0.0L, 0x1.fp1023L, -1.570796326794896619231321691639751442099L, 5.742126086470197117652213464083623391533e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
4977 TEST_c_c (catan, 0.0L, -0x1.fp1023L, 1.570796326794896619231321691639751442099L, -5.742126086470197117652213464083623391533e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
4978 TEST_c_c (catan, -0.0L, -0x1.fp1023L, -1.570796326794896619231321691639751442099L, -5.742126086470197117652213464083623391533e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
4979 TEST_c_c (catan, 0x1.fp1023L, 0x1.fp1023L, 1.570796326794896619231321691639751442099L, 2.871063043235098558826106732041811695767e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
4980 TEST_c_c (catan, 0x1.fp1023L, -0x1.fp1023L, 1.570796326794896619231321691639751442099L, -2.871063043235098558826106732041811695767e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
4981 TEST_c_c (catan, -0x1.fp1023L, 0x1.fp1023L, -1.570796326794896619231321691639751442099L, 2.871063043235098558826106732041811695767e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
4982 TEST_c_c (catan, -0x1.fp1023L, -0x1.fp1023L, -1.570796326794896619231321691639751442099L, -2.871063043235098558826106732041811695767e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
4983 #endif
4984 #if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
4985 TEST_c_c (catan, 0x1p10000L, 0.0L, 1.570796326794896619231321691639751442099L, 0.0L),
4986 TEST_c_c (catan, 0x1p10000L, -0.0L, 1.570796326794896619231321691639751442099L, -0.0L),
4987 TEST_c_c (catan, -0x1p10000L, 0.0L, -1.570796326794896619231321691639751442099L, 0.0L),
4988 TEST_c_c (catan, -0x1p10000L, -0.0L, -1.570796326794896619231321691639751442099L, -0.0L),
4989 TEST_c_c (catan, 0.0L, 0x1p10000L, 1.570796326794896619231321691639751442099L, 5.012372749206452009297555933742977749322e-3011L),
4990 TEST_c_c (catan, -0.0L, 0x1p10000L, -1.570796326794896619231321691639751442099L, 5.012372749206452009297555933742977749322e-3011L),
4991 TEST_c_c (catan, 0.0L, -0x1p10000L, 1.570796326794896619231321691639751442099L, -5.012372749206452009297555933742977749322e-3011L),
4992 TEST_c_c (catan, -0.0L, -0x1p10000L, -1.570796326794896619231321691639751442099L, -5.012372749206452009297555933742977749322e-3011L),
4993 TEST_c_c (catan, 0x1.fp16383L, 0.0L, 1.570796326794896619231321691639751442099L, 0.0L),
4994 TEST_c_c (catan, 0x1.fp16383L, -0.0L, 1.570796326794896619231321691639751442099L, -0.0L),
4995 TEST_c_c (catan, -0x1.fp16383L, 0.0L, -1.570796326794896619231321691639751442099L, 0.0L),
4996 TEST_c_c (catan, -0x1.fp16383L, -0.0L, -1.570796326794896619231321691639751442099L, -0.0L),
4997 TEST_c_c (catan, 0.0L, 0x1.fp16383L, 1.570796326794896619231321691639751442099L, 8.676395208031209048419813722120651877672e-4933L, UNDERFLOW_EXCEPTION),
4998 TEST_c_c (catan, -0.0L, 0x1.fp16383L, -1.570796326794896619231321691639751442099L, 8.676395208031209048419813722120651877672e-4933L, UNDERFLOW_EXCEPTION),
4999 TEST_c_c (catan, 0.0L, -0x1.fp16383L, 1.570796326794896619231321691639751442099L, -8.676395208031209048419813722120651877672e-4933L, UNDERFLOW_EXCEPTION),
5000 TEST_c_c (catan, -0.0L, -0x1.fp16383L, -1.570796326794896619231321691639751442099L, -8.676395208031209048419813722120651877672e-4933L, UNDERFLOW_EXCEPTION),
5001 TEST_c_c (catan, 0x1.fp16383L, 0x1.fp16383L, 1.570796326794896619231321691639751442099L, 4.338197604015604524209906861060325938836e-4933L, UNDERFLOW_EXCEPTION),
5002 TEST_c_c (catan, 0x1.fp16383L, -0x1.fp16383L, 1.570796326794896619231321691639751442099L, -4.338197604015604524209906861060325938836e-4933L, UNDERFLOW_EXCEPTION),
5003 TEST_c_c (catan, -0x1.fp16383L, 0x1.fp16383L, -1.570796326794896619231321691639751442099L, 4.338197604015604524209906861060325938836e-4933L, UNDERFLOW_EXCEPTION),
5004 TEST_c_c (catan, -0x1.fp16383L, -0x1.fp16383L, -1.570796326794896619231321691639751442099L, -4.338197604015604524209906861060325938836e-4933L, UNDERFLOW_EXCEPTION),
5005 #endif
5006 TEST_c_c (catan, 0x1p-13L, 1.0L, 7.854286809755354140031716771044626356262e-1L, 4.852030264850939738801379894163661227127L),
5007 TEST_c_c (catan, 0x1p-13L, -1.0L, 7.854286809755354140031716771044626356262e-1L, -4.852030264850939738801379894163661227127L),
5008 TEST_c_c (catan, -0x1p-13L, 1.0L, -7.854286809755354140031716771044626356262e-1L, 4.852030264850939738801379894163661227127L),
5009 TEST_c_c (catan, -0x1p-13L, -1.0L, -7.854286809755354140031716771044626356262e-1L, -4.852030264850939738801379894163661227127L),
5010 TEST_c_c (catan, 1.0L, 0x1p-13L, 7.853981671227386080775748393881580082970e-1L, 6.103515609841754902688560615027452023669e-5L),
5011 TEST_c_c (catan, -1.0L, 0x1p-13L, -7.853981671227386080775748393881580082970e-1L, 6.103515609841754902688560615027452023669e-5L),
5012 TEST_c_c (catan, 1.0L, -0x1p-13L, 7.853981671227386080775748393881580082970e-1L, -6.103515609841754902688560615027452023669e-5L),
5013 TEST_c_c (catan, -1.0L, -0x1p-13L, -7.853981671227386080775748393881580082970e-1L, -6.103515609841754902688560615027452023669e-5L),
5014 TEST_c_c (catan, 0x1p-27L, 1.0L, 7.853981652600934588466178684534110069553e-1L, 9.704060527839234335310696652368086117807L),
5015 TEST_c_c (catan, 0x1p-27L, -1.0L, 7.853981652600934588466178684534110069553e-1L, -9.704060527839234335310696652368086117807L),
5016 TEST_c_c (catan, -0x1p-27L, 1.0L, -7.853981652600934588466178684534110069553e-1L, 9.704060527839234335310696652368086117807L),
5017 TEST_c_c (catan, -0x1p-27L, -1.0L, -7.853981652600934588466178684534110069553e-1L, -9.704060527839234335310696652368086117807L),
5018 TEST_c_c (catan, 1.0L, 0x1p-27L, 7.853981633974483234934486536343324763447e-1L, 3.725290298461914028034141143623846306386e-9L),
5019 TEST_c_c (catan, -1.0L, 0x1p-27L, -7.853981633974483234934486536343324763447e-1L, 3.725290298461914028034141143623846306386e-9L),
5020 TEST_c_c (catan, 1.0L, -0x1p-27L, 7.853981633974483234934486536343324763447e-1L, -3.725290298461914028034141143623846306386e-9L),
5021 TEST_c_c (catan, -1.0L, -0x1p-27L, -7.853981633974483234934486536343324763447e-1L, -3.725290298461914028034141143623846306386e-9L),
5022 TEST_c_c (catan, 0x1p-33L, 1.0L, 7.853981634265521400723945494331241018449e-1L, 1.178350206951907026009379309773625595762e1L),
5023 TEST_c_c (catan, 0x1p-33L, -1.0L, 7.853981634265521400723945494331241018449e-1L, -1.178350206951907026009379309773625595762e1L),
5024 TEST_c_c (catan, -0x1p-33L, 1.0L, -7.853981634265521400723945494331241018449e-1L, 1.178350206951907026009379309773625595762e1L),
5025 TEST_c_c (catan, -0x1p-33L, -1.0L, -7.853981634265521400723945494331241018449e-1L, -1.178350206951907026009379309773625595762e1L),
5026 TEST_c_c (catan, 1.0L, 0x1p-33L, 7.853981633974483096190489776088929224056e-1L, 5.820766091346740722643102318246316469910e-11L),
5027 TEST_c_c (catan, -1.0L, 0x1p-33L, -7.853981633974483096190489776088929224056e-1L, 5.820766091346740722643102318246316469910e-11L),
5028 TEST_c_c (catan, 1.0L, -0x1p-33L, 7.853981633974483096190489776088929224056e-1L, -5.820766091346740722643102318246316469910e-11L),
5029 TEST_c_c (catan, -1.0L, -0x1p-33L, -7.853981633974483096190489776088929224056e-1L, -5.820766091346740722643102318246316469910e-11L),
5030 TEST_c_c (catan, 0x1p-54L, 1.0L, 7.853981633974483234934486536343324763447e-1L, 1.906154746539849600897388334009985581467e1L),
5031 TEST_c_c (catan, 0x1p-54L, -1.0L, 7.853981633974483234934486536343324763447e-1L, -1.906154746539849600897388334009985581467e1L),
5032 TEST_c_c (catan, -0x1p-54L, 1.0L, -7.853981633974483234934486536343324763447e-1L, 1.906154746539849600897388334009985581467e1L),
5033 TEST_c_c (catan, -0x1p-54L, -1.0L, -7.853981633974483234934486536343324763447e-1L, -1.906154746539849600897388334009985581467e1L),
5034 TEST_c_c (catan, 1.0L, 0x1p-54L, 7.853981633974483096156608458198764914213e-1L, 2.775557561562891351059079170227049355775e-17L),
5035 TEST_c_c (catan, -1.0L, 0x1p-54L, -7.853981633974483096156608458198764914213e-1L, 2.775557561562891351059079170227049355775e-17L),
5036 TEST_c_c (catan, 1.0L, -0x1p-54L, 7.853981633974483096156608458198764914213e-1L, -2.775557561562891351059079170227049355775e-17L),
5037 TEST_c_c (catan, -1.0L, -0x1p-54L, -7.853981633974483096156608458198764914213e-1L, -2.775557561562891351059079170227049355775e-17L),
5038 TEST_c_c (catan, 0x1p-57L, 1.0L, 7.853981633974483113503843217966828154612e-1L, 2.010126823623841397309973152228712047720e1L),
5039 TEST_c_c (catan, 0x1p-57L, -1.0L, 7.853981633974483113503843217966828154612e-1L, -2.010126823623841397309973152228712047720e1L),
5040 TEST_c_c (catan, -0x1p-57L, 1.0L, -7.853981633974483113503843217966828154612e-1L, 2.010126823623841397309973152228712047720e1L),
5041 TEST_c_c (catan, -0x1p-57L, -1.0L, -7.853981633974483113503843217966828154612e-1L, -2.010126823623841397309973152228712047720e1L),
5042 TEST_c_c (catan, 1.0L, 0x1p-57L, 7.853981633974483096156608458198757330864e-1L, 3.469446951953614188823848962783813448721e-18L),
5043 TEST_c_c (catan, -1.0L, 0x1p-57L, -7.853981633974483096156608458198757330864e-1L, 3.469446951953614188823848962783813448721e-18L),
5044 TEST_c_c (catan, 1.0L, -0x1p-57L, 7.853981633974483096156608458198757330864e-1L, -3.469446951953614188823848962783813448721e-18L),
5045 TEST_c_c (catan, -1.0L, -0x1p-57L, -7.853981633974483096156608458198757330864e-1L, -3.469446951953614188823848962783813448721e-18L),
5046 TEST_c_c (catan, 0x1p-13L, 0x1.000002p0L, 7.859169620684960844300240092596908675974e-1L, 4.852030056234795712498957387213592193975L),
5047 TEST_c_c (catan, 0x1p-13L, -0x1.000002p0L, 7.859169620684960844300240092596908675974e-1L, -4.852030056234795712498957387213592193975L),
5048 TEST_c_c (catan, -0x1p-13L, 0x1.000002p0L, -7.859169620684960844300240092596908675974e-1L, 4.852030056234795712498957387213592193975L),
5049 TEST_c_c (catan, -0x1p-13L, -0x1.000002p0L, -7.859169620684960844300240092596908675974e-1L, -4.852030056234795712498957387213592193975L),
5050 TEST_c_c (catan, 0x1.000002p0L, 0x1p-13L, 7.853982267273793866654490522673596014524e-1L, 6.103514882246036852433556327261700380577e-5L),
5051 TEST_c_c (catan, -0x1.000002p0L, 0x1p-13L, -7.853982267273793866654490522673596014524e-1L, 6.103514882246036852433556327261700380577e-5L),
5052 TEST_c_c (catan, 0x1.000002p0L, -0x1p-13L, 7.853982267273793866654490522673596014524e-1L, -6.103514882246036852433556327261700380577e-5L),
5053 TEST_c_c (catan, -0x1.000002p0L, -0x1p-13L, -7.853982267273793866654490522673596014524e-1L, -6.103514882246036852433556327261700380577e-5L),
5054 TEST_c_c (catan, 0x1p-13L, 0x0.ffffffp0L, 7.851845403708474595909269086711426246675e-1L, 4.852030190345140708455871037447717761868L),
5055 TEST_c_c (catan, 0x1p-13L, -0x0.ffffffp0L, 7.851845403708474595909269086711426246675e-1L, -4.852030190345140708455871037447717761868L),
5056 TEST_c_c (catan, -0x1p-13L, 0x0.ffffffp0L, -7.851845403708474595909269086711426246675e-1L, 4.852030190345140708455871037447717761868L),
5057 TEST_c_c (catan, -0x1p-13L, -0x0.ffffffp0L, -7.851845403708474595909269086711426246675e-1L, -4.852030190345140708455871037447717761868L),
5058 TEST_c_c (catan, 0x0.ffffffp0L, 0x1p-13L, 7.853981373204155542484315721351697277336e-1L, 6.103515973639646453881721999956617260502e-5L),
5059 TEST_c_c (catan, -0x0.ffffffp0L, 0x1p-13L, -7.853981373204155542484315721351697277336e-1L, 6.103515973639646453881721999956617260502e-5L),
5060 TEST_c_c (catan, 0x0.ffffffp0L, -0x1p-13L, 7.853981373204155542484315721351697277336e-1L, -6.103515973639646453881721999956617260502e-5L),
5061 TEST_c_c (catan, -0x0.ffffffp0L, -0x1p-13L, -7.853981373204155542484315721351697277336e-1L, -6.103515973639646453881721999956617260502e-5L),
5062 #ifndef TEST_FLOAT
5063 TEST_c_c (catan, 0x1p-27L, 0x1.0000000000001p0L, 7.853981801612546526942695000283242525531e-1L, 9.704060527839234168777242958594699810015L),
5064 TEST_c_c (catan, 0x1p-27L, -0x1.0000000000001p0L, 7.853981801612546526942695000283242525531e-1L, -9.704060527839234168777242958594699810015L),
5065 TEST_c_c (catan, -0x1p-27L, 0x1.0000000000001p0L, -7.853981801612546526942695000283242525531e-1L, 9.704060527839234168777242958594699810015L),
5066 TEST_c_c (catan, -0x1p-27L, -0x1.0000000000001p0L, -7.853981801612546526942695000283242525531e-1L, -9.704060527839234168777242958594699810015L),
5067 TEST_c_c (catan, 0x1.0000000000001p0L, 0x1p-27L, 7.853981633974484345157511161499711112683e-1L, 3.725290298461913200853528590596263270474e-9L),
5068 TEST_c_c (catan, -0x1.0000000000001p0L, 0x1p-27L, -7.853981633974484345157511161499711112683e-1L, 3.725290298461913200853528590596263270474e-9L),
5069 TEST_c_c (catan, 0x1.0000000000001p0L, -0x1p-27L, 7.853981633974484345157511161499711112683e-1L, -3.725290298461913200853528590596263270474e-9L),
5070 TEST_c_c (catan, -0x1.0000000000001p0L, -0x1p-27L, -7.853981633974484345157511161499711112683e-1L, -3.725290298461913200853528590596263270474e-9L),
5071 TEST_c_c (catan, 0x1p-27L, 0x0.fffffffffffff8p0L, 7.853981578095128619227903983047292781021e-1L, 9.704060527839234252043969805481351363824L),
5072 TEST_c_c (catan, 0x1p-27L, -0x0.fffffffffffff8p0L, 7.853981578095128619227903983047292781021e-1L, -9.704060527839234252043969805481351363824L),
5073 TEST_c_c (catan, -0x1p-27L, 0x0.fffffffffffff8p0L, -7.853981578095128619227903983047292781021e-1L, 9.704060527839234252043969805481351363824L),
5074 TEST_c_c (catan, -0x1p-27L, -0x0.fffffffffffff8p0L, -7.853981578095128619227903983047292781021e-1L, -9.704060527839234252043969805481351363824L),
5075 TEST_c_c (catan, 0x0.fffffffffffff8p0L, 0x1p-27L, 7.853981633974482679822974223765039144191e-1L, 3.725290298461914441624447420137706700965e-9L),
5076 TEST_c_c (catan, -0x0.fffffffffffff8p0L, 0x1p-27L, -7.853981633974482679822974223765039144191e-1L, 3.725290298461914441624447420137706700965e-9L),
5077 TEST_c_c (catan, 0x0.fffffffffffff8p0L, -0x1p-27L, 7.853981633974482679822974223765039144191e-1L, -3.725290298461914441624447420137706700965e-9L),
5078 TEST_c_c (catan, -0x0.fffffffffffff8p0L, -0x1p-27L, -7.853981633974482679822974223765039144191e-1L, -3.725290298461914441624447420137706700965e-9L),
5079 #endif
5080 #if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 64
5081 TEST_c_c (catan, 0x1p-33L, 0x1.0000000000000002p0L, 7.853981638922134273801338071094141188767e-1L, 1.178350206951907025990405771755129268176e1L),
5082 TEST_c_c (catan, 0x1p-33L, -0x1.0000000000000002p0L, 7.853981638922134273801338071094141188767e-1L, -1.178350206951907025990405771755129268176e1L),
5083 TEST_c_c (catan, -0x1p-33L, 0x1.0000000000000002p0L, -7.853981638922134273801338071094141188767e-1L, 1.178350206951907025990405771755129268176e1L),
5084 TEST_c_c (catan, -0x1p-33L, -0x1.0000000000000002p0L, -7.853981638922134273801338071094141188767e-1L, -1.178350206951907025990405771755129268176e1L),
5085 TEST_c_c (catan, 0x1.0000000000000002p0L, 0x1p-33L, 7.853981633974483096732590862331681441026e-1L, 5.820766091346740722012013594069507025615e-11L),
5086 TEST_c_c (catan, -0x1.0000000000000002p0L, 0x1p-33L, -7.853981633974483096732590862331681441026e-1L, 5.820766091346740722012013594069507025615e-11L),
5087 TEST_c_c (catan, 0x1.0000000000000002p0L, -0x1p-33L, 7.853981633974483096732590862331681441026e-1L, -5.820766091346740722012013594069507025615e-11L),
5088 TEST_c_c (catan, -0x1.0000000000000002p0L, -0x1p-33L, -7.853981633974483096732590862331681441026e-1L, -5.820766091346740722012013594069507025615e-11L),
5089 TEST_c_c (catan, 0x1p-33L, 0x0.ffffffffffffffffp0L, 7.853981631937214964185249205444919953948e-1L, 1.178350206951907026002603046195591193050e1L),
5090 TEST_c_c (catan, 0x1p-33L, -0x0.ffffffffffffffffp0L, 7.853981631937214964185249205444919953948e-1L, -1.178350206951907026002603046195591193050e1L),
5091 TEST_c_c (catan, -0x1p-33L, 0x0.ffffffffffffffffp0L, -7.853981631937214964185249205444919953948e-1L, 1.178350206951907026002603046195591193050e1L),
5092 TEST_c_c (catan, -0x1p-33L, -0x0.ffffffffffffffffp0L, -7.853981631937214964185249205444919953948e-1L, -1.178350206951907026002603046195591193050e1L),
5093 TEST_c_c (catan, 0x0.ffffffffffffffffp0L, 0x1p-33L, 7.853981633974483095919439232967553115548e-1L, 5.820766091346740722958646680334721192083e-11L),
5094 TEST_c_c (catan, -0x0.ffffffffffffffffp0L, 0x1p-33L, -7.853981633974483095919439232967553115548e-1L, 5.820766091346740722958646680334721192083e-11L),
5095 TEST_c_c (catan, 0x0.ffffffffffffffffp0L, -0x1p-33L, 7.853981633974483095919439232967553115548e-1L, -5.820766091346740722958646680334721192083e-11L),
5096 TEST_c_c (catan, -0x0.ffffffffffffffffp0L, -0x1p-33L, -7.853981633974483095919439232967553115548e-1L, -5.820766091346740722958646680334721192083e-11L),
5097 #endif
5098 #if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 106
5099 TEST_c_c (catan, 0x1p-54L, 0x1.000000000000000000000000008p0L, 7.853981633974485455380535786656405610710e-1L, 1.906154746539849600897388334009981267384e1L),
5100 TEST_c_c (catan, 0x1p-54L, -0x1.000000000000000000000000008p0L, 7.853981633974485455380535786656405610710e-1L, -1.906154746539849600897388334009981267384e1L),
5101 TEST_c_c (catan, -0x1p-54L, 0x1.000000000000000000000000008p0L, -7.853981633974485455380535786656405610710e-1L, 1.906154746539849600897388334009981267384e1L),
5102 TEST_c_c (catan, -0x1p-54L, -0x1.000000000000000000000000008p0L, -7.853981633974485455380535786656405610710e-1L, -1.906154746539849600897388334009981267384e1L),
5103 TEST_c_c (catan, 0x1.000000000000000000000000008p0L, 0x1p-54L, 7.853981633974483096156608458198888173729e-1L, 2.775557561562891351059079170226980932999e-17L),
5104 TEST_c_c (catan, -0x1.000000000000000000000000008p0L, 0x1p-54L, -7.853981633974483096156608458198888173729e-1L, 2.775557561562891351059079170226980932999e-17L),
5105 TEST_c_c (catan, 0x1.000000000000000000000000008p0L, -0x1p-54L, 7.853981633974483096156608458198888173729e-1L, -2.775557561562891351059079170226980932999e-17L),
5106 TEST_c_c (catan, -0x1.000000000000000000000000008p0L, -0x1p-54L, -7.853981633974483096156608458198888173729e-1L, -2.775557561562891351059079170226980932999e-17L),
5107 TEST_c_c (catan, 0x1p-54L, 0x0.ffffffffffffffffffffffffffcp0L, 7.853981633974482124711461911186784339815e-1L, 1.906154746539849600897388334009984040723e1L),
5108 TEST_c_c (catan, 0x1p-54L, -0x0.ffffffffffffffffffffffffffcp0L, 7.853981633974482124711461911186784339815e-1L, -1.906154746539849600897388334009984040723e1L),
5109 TEST_c_c (catan, -0x1p-54L, 0x0.ffffffffffffffffffffffffffcp0L, -7.853981633974482124711461911186784339815e-1L, 1.906154746539849600897388334009984040723e1L),
5110 TEST_c_c (catan, -0x1p-54L, -0x0.ffffffffffffffffffffffffffcp0L, -7.853981633974482124711461911186784339815e-1L, -1.906154746539849600897388334009984040723e1L),
5111 TEST_c_c (catan, 0x0.ffffffffffffffffffffffffffcp0L, 0x1p-54L, 7.853981633974483096156608458198703284454e-1L, 2.775557561562891351059079170227083567164e-17L),
5112 TEST_c_c (catan, -0x0.ffffffffffffffffffffffffffcp0L, 0x1p-54L, -7.853981633974483096156608458198703284454e-1L, 2.775557561562891351059079170227083567164e-17L),
5113 TEST_c_c (catan, 0x0.ffffffffffffffffffffffffffcp0L, -0x1p-54L, 7.853981633974483096156608458198703284454e-1L, -2.775557561562891351059079170227083567164e-17L),
5114 TEST_c_c (catan, -0x0.ffffffffffffffffffffffffffcp0L, -0x1p-54L, -7.853981633974483096156608458198703284454e-1L, -2.775557561562891351059079170227083567164e-17L),
5115 #endif
5116 #if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 113
5117 TEST_c_c (catan, 0x1p-57L, 0x1.0000000000000000000000000001p0L, 7.853981633974483252281721296111395707566e-1L, 2.010126823623841397309973152228712033275e1L),
5118 TEST_c_c (catan, 0x1p-57L, -0x1.0000000000000000000000000001p0L, 7.853981633974483252281721296111395707566e-1L, -2.010126823623841397309973152228712033275e1L),
5119 TEST_c_c (catan, -0x1p-57L, 0x1.0000000000000000000000000001p0L, -7.853981633974483252281721296111395707566e-1L, 2.010126823623841397309973152228712033275e1L),
5120 TEST_c_c (catan, -0x1p-57L, -0x1.0000000000000000000000000001p0L, -7.853981633974483252281721296111395707566e-1L, -2.010126823623841397309973152228712033275e1L),
5121 TEST_c_c (catan, 0x1.0000000000000000000000000001p0L, 0x1p-57L, 7.853981633974483096156608458198758293829e-1L, 3.469446951953614188823848962783812780530e-18L),
5122 TEST_c_c (catan, -0x1.0000000000000000000000000001p0L, 0x1p-57L, -7.853981633974483096156608458198758293829e-1L, 3.469446951953614188823848962783812780530e-18L),
5123 TEST_c_c (catan, 0x1.0000000000000000000000000001p0L, -0x1p-57L, 7.853981633974483096156608458198758293829e-1L, -3.469446951953614188823848962783812780530e-18L),
5124 TEST_c_c (catan, -0x1.0000000000000000000000000001p0L, -0x1p-57L, -7.853981633974483096156608458198758293829e-1L, -3.469446951953614188823848962783812780530e-18L),
5125 TEST_c_c (catan, 0x1p-57L, 0x0.ffffffffffffffffffffffffffff8p0L, 7.853981633974483044114904178894544378135e-1L, 2.010126823623841397309973152228712040498e1L),
5126 TEST_c_c (catan, 0x1p-57L, -0x0.ffffffffffffffffffffffffffff8p0L, 7.853981633974483044114904178894544378135e-1L, -2.010126823623841397309973152228712040498e1L),
5127 TEST_c_c (catan, -0x1p-57L, 0x0.ffffffffffffffffffffffffffff8p0L, -7.853981633974483044114904178894544378135e-1L, 2.010126823623841397309973152228712040498e1L),
5128 TEST_c_c (catan, -0x1p-57L, -0x0.ffffffffffffffffffffffffffff8p0L, -7.853981633974483044114904178894544378135e-1L, -2.010126823623841397309973152228712040498e1L),
5129 TEST_c_c (catan, 0x0.ffffffffffffffffffffffffffff8p0L, 0x1p-57L, 7.853981633974483096156608458198756849381e-1L, 3.469446951953614188823848962783813782817e-18L),
5130 TEST_c_c (catan, -0x0.ffffffffffffffffffffffffffff8p0L, 0x1p-57L, -7.853981633974483096156608458198756849381e-1L, 3.469446951953614188823848962783813782817e-18L),
5131 TEST_c_c (catan, 0x0.ffffffffffffffffffffffffffff8p0L, -0x1p-57L, 7.853981633974483096156608458198756849381e-1L, -3.469446951953614188823848962783813782817e-18L),
5132 TEST_c_c (catan, -0x0.ffffffffffffffffffffffffffff8p0L, -0x1p-57L, -7.853981633974483096156608458198756849381e-1L, -3.469446951953614188823848962783813782817e-18L),
5133 #endif
5134 TEST_c_c (catan, 1.0L, 0x1p-64L, 7.853981633974483096156608458198757210500e-1L, 2.710505431213761085018632002174854278563e-20L),
5135 TEST_c_c (catan, 1.0L, -0x1p-64L, 7.853981633974483096156608458198757210500e-1L, -2.710505431213761085018632002174854278563e-20L),
5136 TEST_c_c (catan, -1.0L, 0x1p-64L, -7.853981633974483096156608458198757210500e-1L, 2.710505431213761085018632002174854278563e-20L),
5137 TEST_c_c (catan, -1.0L, -0x1p-64L, -7.853981633974483096156608458198757210500e-1L, -2.710505431213761085018632002174854278563e-20L),
5138 TEST_c_c (catan, 0x1p-64L, 1.0L, 7.853981633974483096292133729759445264744e-1L, 2.252728336819822255606004394739073846245e1L),
5139 TEST_c_c (catan, -0x1p-64L, 1.0L, -7.853981633974483096292133729759445264744e-1L, 2.252728336819822255606004394739073846245e1L),
5140 TEST_c_c (catan, 0x1p-64L, -1.0L, 7.853981633974483096292133729759445264744e-1L, -2.252728336819822255606004394739073846245e1L),
5141 TEST_c_c (catan, -0x1p-64L, -1.0L, -7.853981633974483096292133729759445264744e-1L, -2.252728336819822255606004394739073846245e1L),
5142 TEST_c_c (catan, 1.0L, 0x1.3p-73L, 7.853981633974483096156608458198757210493e-1L, 6.286572655403010329022706059731717687100e-23L),
5143 TEST_c_c (catan, 1.0L, -0x1.3p-73L, 7.853981633974483096156608458198757210493e-1L, -6.286572655403010329022706059731717687100e-23L),
5144 TEST_c_c (catan, -1.0L, 0x1.3p-73L, -7.853981633974483096156608458198757210493e-1L, 6.286572655403010329022706059731717687100e-23L),
5145 TEST_c_c (catan, -1.0L, -0x1.3p-73L, -7.853981633974483096156608458198757210493e-1L, -6.286572655403010329022706059731717687100e-23L),
5146 TEST_c_c (catan, 0x1.3p-73L, 1.0L, 7.853981633974483096156922786831527361009e-1L, 2.556052055225464683726753902092495938633e1L),
5147 TEST_c_c (catan, -0x1.3p-73L, 1.0L, -7.853981633974483096156922786831527361009e-1L, 2.556052055225464683726753902092495938633e1L),
5148 TEST_c_c (catan, 0x1.3p-73L, -1.0L, 7.853981633974483096156922786831527361009e-1L, -2.556052055225464683726753902092495938633e1L),
5149 TEST_c_c (catan, -0x1.3p-73L, -1.0L, -7.853981633974483096156922786831527361009e-1L, -2.556052055225464683726753902092495938633e1L),
5150 TEST_c_c (catan, 1.0L, 0x1p-124L, 7.853981633974483096156608458198757210493e-1L, 2.350988701644575015937473074444491355637e-38L),
5151 TEST_c_c (catan, 1.0L, -0x1p-124L, 7.853981633974483096156608458198757210493e-1L, -2.350988701644575015937473074444491355637e-38L),
5152 TEST_c_c (catan, -1.0L, 0x1p-124L, -7.853981633974483096156608458198757210493e-1L, 2.350988701644575015937473074444491355637e-38L),
5153 TEST_c_c (catan, -1.0L, -0x1p-124L, -7.853981633974483096156608458198757210493e-1L, -2.350988701644575015937473074444491355637e-38L),
5154 TEST_c_c (catan, 0x1p-124L, 1.0L, 7.853981633974483096156608458198757210610e-1L, 4.332169878499658183857700759113603550472e1L),
5155 TEST_c_c (catan, -0x1p-124L, 1.0L, -7.853981633974483096156608458198757210610e-1L, 4.332169878499658183857700759113603550472e1L),
5156 TEST_c_c (catan, 0x1p-124L, -1.0L, 7.853981633974483096156608458198757210610e-1L, -4.332169878499658183857700759113603550472e1L),
5157 TEST_c_c (catan, -0x1p-124L, -1.0L, -7.853981633974483096156608458198757210610e-1L, -4.332169878499658183857700759113603550472e1L),
5158 TEST_c_c (catan, 0x1.000002p0L, 0x1p-126L, 7.853982230020895322927482174768220815493e-1L, 5.877471053462247139383742414506671233336e-39L, UNDERFLOW_EXCEPTION_FLOAT),
5159 TEST_c_c (catan, 0x1.000002p0L, -0x1p-126L, 7.853982230020895322927482174768220815493e-1L, -5.877471053462247139383742414506671233336e-39L, UNDERFLOW_EXCEPTION_FLOAT),
5160 TEST_c_c (catan, -0x1.000002p0L, 0x1p-126L, -7.853982230020895322927482174768220815493e-1L, 5.877471053462247139383742414506671233336e-39L, UNDERFLOW_EXCEPTION_FLOAT),
5161 TEST_c_c (catan, -0x1.000002p0L, -0x1p-126L, -7.853982230020895322927482174768220815493e-1L, -5.877471053462247139383742414506671233336e-39L, UNDERFLOW_EXCEPTION_FLOAT),
5162 TEST_c_c (catan, 0x1p-126L, 0x1.000002p0L, 1.570796326794896619231321691639702138295L, 8.317766196521665212523713550410777685446L),
5163 TEST_c_c (catan, -0x1p-126L, 0x1.000002p0L, -1.570796326794896619231321691639702138295L, 8.317766196521665212523713550410777685446L),
5164 TEST_c_c (catan, 0x1p-126L, -0x1.000002p0L, 1.570796326794896619231321691639702138295L, -8.317766196521665212523713550410777685446L),
5165 TEST_c_c (catan, -0x1p-126L, -0x1.000002p0L, -1.570796326794896619231321691639702138295L, -8.317766196521665212523713550410777685446L),
5166 TEST_c_c (catan, 0x0.ffffffp0L, 0x1p-126L, 7.853981335951250337419109991749089175724e-1L, 5.877472104436064061535099214664320916184e-39L, UNDERFLOW_EXCEPTION_FLOAT),
5167 TEST_c_c (catan, 0x0.ffffffp0L, -0x1p-126L, 7.853981335951250337419109991749089175724e-1L, -5.877472104436064061535099214664320916184e-39L, UNDERFLOW_EXCEPTION_FLOAT),
5168 TEST_c_c (catan, -0x0.ffffffp0L, 0x1p-126L, -7.853981335951250337419109991749089175724e-1L, 5.877472104436064061535099214664320916184e-39L, UNDERFLOW_EXCEPTION_FLOAT),
5169 TEST_c_c (catan, -0x0.ffffffp0L, -0x1p-126L, -7.853981335951250337419109991749089175724e-1L, -5.877472104436064061535099214664320916184e-39L, UNDERFLOW_EXCEPTION_FLOAT),
5170 TEST_c_c (catan, 0x1p-126L, 0x0.ffffffp0L, 9.860761609136244031334147100512154160097e-32L, 8.664339742098154951823135931565866792454L),
5171 TEST_c_c (catan, -0x1p-126L, 0x0.ffffffp0L, -9.860761609136244031334147100512154160097e-32L, 8.664339742098154951823135931565866792454L),
5172 TEST_c_c (catan, 0x1p-126L, -0x0.ffffffp0L, 9.860761609136244031334147100512154160097e-32L, -8.664339742098154951823135931565866792454L),
5173 TEST_c_c (catan, -0x1p-126L, -0x0.ffffffp0L, -9.860761609136244031334147100512154160097e-32L, -8.664339742098154951823135931565866792454L),
5174 #ifndef TEST_FLOAT
5175 TEST_c_c (catan, 1.0L, 0x1p-512L, 7.853981633974483096156608458198757210493e-1L, 3.729170365600103371645482657731466918688e-155L),
5176 TEST_c_c (catan, 1.0L, -0x1p-512L, 7.853981633974483096156608458198757210493e-1L, -3.729170365600103371645482657731466918688e-155L),
5177 TEST_c_c (catan, -1.0L, 0x1p-512L, -7.853981633974483096156608458198757210493e-1L, 3.729170365600103371645482657731466918688e-155L),
5178 TEST_c_c (catan, -1.0L, -0x1p-512L, -7.853981633974483096156608458198757210493e-1L, -3.729170365600103371645482657731466918688e-155L),
5179 TEST_c_c (catan, 0x1p-512L, 1.0L, 7.853981633974483096156608458198757210493e-1L, 1.777922518136259718655200391540222897114e2L),
5180 TEST_c_c (catan, -0x1p-512L, 1.0L, -7.853981633974483096156608458198757210493e-1L, 1.777922518136259718655200391540222897114e2L),
5181 TEST_c_c (catan, 0x1p-512L, -1.0L, 7.853981633974483096156608458198757210493e-1L, -1.777922518136259718655200391540222897114e2L),
5182 TEST_c_c (catan, -0x1p-512L, -1.0L, -7.853981633974483096156608458198757210493e-1L, -1.777922518136259718655200391540222897114e2L),
5183 TEST_c_c (catan, 1.0L, 0x1.3p-536L, 7.853981633974483096156608458198757210493e-1L, 2.639526015013529511588222179446290115084e-162L),
5184 TEST_c_c (catan, 1.0L, -0x1.3p-536L, 7.853981633974483096156608458198757210493e-1L, -2.639526015013529511588222179446290115084e-162L),
5185 TEST_c_c (catan, -1.0L, 0x1.3p-536L, -7.853981633974483096156608458198757210493e-1L, 2.639526015013529511588222179446290115084e-162L),
5186 TEST_c_c (catan, -1.0L, -0x1.3p-536L, -7.853981633974483096156608458198757210493e-1L, -2.639526015013529511588222179446290115084e-162L),
5187 TEST_c_c (catan, 0x1.3p-536L, 1.0L, 7.853981633974483096156608458198757210493e-1L, 1.860240928518819859673567751384928348958e2L),
5188 TEST_c_c (catan, -0x1.3p-536L, 1.0L, -7.853981633974483096156608458198757210493e-1L, 1.860240928518819859673567751384928348958e2L),
5189 TEST_c_c (catan, 0x1.3p-536L, -1.0L, 7.853981633974483096156608458198757210493e-1L, -1.860240928518819859673567751384928348958e2L),
5190 TEST_c_c (catan, -0x1.3p-536L, -1.0L, -7.853981633974483096156608458198757210493e-1L, -1.860240928518819859673567751384928348958e2L),
5191 TEST_c_c (catan, 1.0L, 0x1p-1020L, 7.853981633974483096156608458198757210493e-1L, 4.450147717014402766180465434664808128438e-308L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
5192 TEST_c_c (catan, 1.0L, -0x1p-1020L, 7.853981633974483096156608458198757210493e-1L, -4.450147717014402766180465434664808128438e-308L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
5193 TEST_c_c (catan, -1.0L, 0x1p-1020L, -7.853981633974483096156608458198757210493e-1L, 4.450147717014402766180465434664808128438e-308L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
5194 TEST_c_c (catan, -1.0L, -0x1p-1020L, -7.853981633974483096156608458198757210493e-1L, -4.450147717014402766180465434664808128438e-308L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
5195 TEST_c_c (catan, 0x1p-1020L, 1.0L, 7.853981633974483096156608458198757210493e-1L, 3.538516356758520804574969980043991380025e2L),
5196 TEST_c_c (catan, -0x1p-1020L, 1.0L, -7.853981633974483096156608458198757210493e-1L, 3.538516356758520804574969980043991380025e2L),
5197 TEST_c_c (catan, 0x1p-1020L, -1.0L, 7.853981633974483096156608458198757210493e-1L, -3.538516356758520804574969980043991380025e2L),
5198 TEST_c_c (catan, -0x1p-1020L, -1.0L, -7.853981633974483096156608458198757210493e-1L, -3.538516356758520804574969980043991380025e2L),
5199 TEST_c_c (catan, 0x1.0000000000001p0L, 0x1p-1022L, 7.853981633974484206379633083355174374608e-1L, 1.112536929253600444512293438042957369978e-308L, UNDERFLOW_EXCEPTION_DOUBLE),
5200 TEST_c_c (catan, 0x1.0000000000001p0L, -0x1p-1022L, 7.853981633974484206379633083355174374608e-1L, -1.112536929253600444512293438042957369978e-308L, UNDERFLOW_EXCEPTION_DOUBLE),
5201 TEST_c_c (catan, -0x1.0000000000001p0L, 0x1p-1022L, -7.853981633974484206379633083355174374608e-1L, 1.112536929253600444512293438042957369978e-308L, UNDERFLOW_EXCEPTION_DOUBLE),
5202 TEST_c_c (catan, -0x1.0000000000001p0L, -0x1p-1022L, -7.853981633974484206379633083355174374608e-1L, -1.112536929253600444512293438042957369978e-308L, UNDERFLOW_EXCEPTION_DOUBLE),
5203 TEST_c_c (catan, 0x1p-1022L, 0x1.0000000000001p0L, 1.570796326794896619231321691639751442099L, 1.836840028483855075506780244989950299369e1L),
5204 TEST_c_c (catan, -0x1p-1022L, 0x1.0000000000001p0L, -1.570796326794896619231321691639751442099L, 1.836840028483855075506780244989950299369e1L),
5205 TEST_c_c (catan, 0x1p-1022L, -0x1.0000000000001p0L, 1.570796326794896619231321691639751442099L, -1.836840028483855075506780244989950299369e1L),
5206 TEST_c_c (catan, -0x1p-1022L, -0x1.0000000000001p0L, -1.570796326794896619231321691639751442099L, -1.836840028483855075506780244989950299369e1L),
5207 TEST_c_c (catan, 0x0.fffffffffffff8p0L, 0x1p-1022L, 7.853981633974482541045096145620456183798e-1L, 1.112536929253600815061527818977844932790e-308L, UNDERFLOW_EXCEPTION_DOUBLE),
5208 TEST_c_c (catan, 0x0.fffffffffffff8p0L, -0x1p-1022L, 7.853981633974482541045096145620456183798e-1L, -1.112536929253600815061527818977844932790e-308L, UNDERFLOW_EXCEPTION_DOUBLE),
5209 TEST_c_c (catan, -0x0.fffffffffffff8p0L, 0x1p-1022L, -7.853981633974482541045096145620456183798e-1L, 1.112536929253600815061527818977844932790e-308L, UNDERFLOW_EXCEPTION_DOUBLE),
5210 TEST_c_c (catan, -0x0.fffffffffffff8p0L, -0x1p-1022L, -7.853981633974482541045096145620456183798e-1L, -1.112536929253600815061527818977844932790e-308L, UNDERFLOW_EXCEPTION_DOUBLE),
5211 TEST_c_c (catan, 0x1p-1022L, 0x0.fffffffffffff8p0L, 1.002084180004486444624900488355118689113e-292L, 1.871497387511852332650969166374185305708e1L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
5212 TEST_c_c (catan, -0x1p-1022L, 0x0.fffffffffffff8p0L, -1.002084180004486444624900488355118689113e-292L, 1.871497387511852332650969166374185305708e1L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
5213 TEST_c_c (catan, 0x1p-1022L, -0x0.fffffffffffff8p0L, 1.002084180004486444624900488355118689113e-292L, -1.871497387511852332650969166374185305708e1L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
5214 TEST_c_c (catan, -0x1p-1022L, -0x0.fffffffffffff8p0L, -1.002084180004486444624900488355118689113e-292L, -1.871497387511852332650969166374185305708e1L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
5215 #endif
5216 #if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 64
5217 TEST_c_c (catan, 0x1.0000000000000002p0L, 0x1p-1022L, 7.853981633974483096698709544441509427467e-1L, 1.112536929253600691424494863099491450042e-308L, UNDERFLOW_EXCEPTION_DOUBLE),
5218 TEST_c_c (catan, 0x1.0000000000000002p0L, -0x1p-1022L, 7.853981633974483096698709544441509427467e-1L, -1.112536929253600691424494863099491450042e-308L, UNDERFLOW_EXCEPTION_DOUBLE),
5219 TEST_c_c (catan, -0x1.0000000000000002p0L, 0x1p-1022L, -7.853981633974483096698709544441509427467e-1L, 1.112536929253600691424494863099491450042e-308L, UNDERFLOW_EXCEPTION_DOUBLE),
5220 TEST_c_c (catan, -0x1.0000000000000002p0L, -0x1p-1022L, -7.853981633974483096698709544441509427467e-1L, -1.112536929253600691424494863099491450042e-308L, UNDERFLOW_EXCEPTION_DOUBLE),
5221 TEST_c_c (catan, 0x1p-1022L, 0x1.0000000000000002p0L, 1.570796326794896619231321691639751442099L, 2.218070977791824990137853294097378778927e1L),
5222 TEST_c_c (catan, -0x1p-1022L, 0x1.0000000000000002p0L, -1.570796326794896619231321691639751442099L, 2.218070977791824990137853294097378778927e1L),
5223 TEST_c_c (catan, 0x1p-1022L, -0x1.0000000000000002p0L, 1.570796326794896619231321691639751442099L, -2.218070977791824990137853294097378778927e1L),
5224 TEST_c_c (catan, -0x1p-1022L, -0x1.0000000000000002p0L, -1.570796326794896619231321691639751442099L, -2.218070977791824990137853294097378778927e1L),
5225 TEST_c_c (catan, 0x0.ffffffffffffffffp0L, 0x1p-1022L, 7.853981633974483095885557915077381101984e-1L, 1.112536929253600691605427106449557323148e-308L, UNDERFLOW_EXCEPTION_DOUBLE),
5226 TEST_c_c (catan, 0x0.ffffffffffffffffp0L, -0x1p-1022L, 7.853981633974483095885557915077381101984e-1L, -1.112536929253600691605427106449557323148e-308L, UNDERFLOW_EXCEPTION_DOUBLE),
5227 TEST_c_c (catan, -0x0.ffffffffffffffffp0L, 0x1p-1022L, -7.853981633974483095885557915077381101984e-1L, 1.112536929253600691605427106449557323148e-308L, UNDERFLOW_EXCEPTION_DOUBLE),
5228 TEST_c_c (catan, -0x0.ffffffffffffffffp0L, -0x1p-1022L, -7.853981633974483095885557915077381101984e-1L, -1.112536929253600691605427106449557323148e-308L, UNDERFLOW_EXCEPTION_DOUBLE),
5229 TEST_c_c (catan, 0x1p-1022L, 0x0.ffffffffffffffffp0L, 2.052268400649188124723641491045245971623e-289L, 2.252728336819822255604649142023466965703e1L),
5230 TEST_c_c (catan, -0x1p-1022L, 0x0.ffffffffffffffffp0L, -2.052268400649188124723641491045245971623e-289L, 2.252728336819822255604649142023466965703e1L),
5231 TEST_c_c (catan, 0x1p-1022L, -0x0.ffffffffffffffffp0L, 2.052268400649188124723641491045245971623e-289L, -2.252728336819822255604649142023466965703e1L),
5232 TEST_c_c (catan, -0x1p-1022L, -0x0.ffffffffffffffffp0L, -2.052268400649188124723641491045245971623e-289L, -2.252728336819822255604649142023466965703e1L),
5233 #endif
5234 #if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 106
5235 TEST_c_c (catan, 0x1.000000000000000000000000008p0L, 0x1p-1022L, 7.853981633974483096156608458198880470009e-1L, 1.112536929253600691545116358666174605957e-308L, UNDERFLOW_EXCEPTION_DOUBLE),
5236 TEST_c_c (catan, 0x1.000000000000000000000000008p0L, -0x1p-1022L, 7.853981633974483096156608458198880470009e-1L, -1.112536929253600691545116358666174605957e-308L, UNDERFLOW_EXCEPTION_DOUBLE),
5237 TEST_c_c (catan, -0x1.000000000000000000000000008p0L, 0x1p-1022L, -7.853981633974483096156608458198880470009e-1L, 1.112536929253600691545116358666174605957e-308L, UNDERFLOW_EXCEPTION_DOUBLE),
5238 TEST_c_c (catan, -0x1.000000000000000000000000008p0L, -0x1p-1022L, -7.853981633974483096156608458198880470009e-1L, -1.112536929253600691545116358666174605957e-308L, UNDERFLOW_EXCEPTION_DOUBLE),
5239 TEST_c_c (catan, 0x1p-1022L, 0x1.000000000000000000000000008p0L, 1.570796326794896619231321691639751442099L, 3.673680056967710139911330243728336427098e1L),
5240 TEST_c_c (catan, -0x1p-1022L, 0x1.000000000000000000000000008p0L, -1.570796326794896619231321691639751442099L, 3.673680056967710139911330243728336427098e1L),
5241 TEST_c_c (catan, 0x1p-1022L, -0x1.000000000000000000000000008p0L, 1.570796326794896619231321691639751442099L, -3.673680056967710139911330243728336427098e1L),
5242 TEST_c_c (catan, -0x1p-1022L, -0x1.000000000000000000000000008p0L, -1.570796326794896619231321691639751442099L, -3.673680056967710139911330243728336427098e1L),
5243 TEST_c_c (catan, 0x0.ffffffffffffffffffffffffffcp0L, 0x1p-1022L, 7.853981633974483096156608458198695580735e-1L, 1.112536929253600691545116358666215745186e-308L, UNDERFLOW_EXCEPTION_DOUBLE),
5244 TEST_c_c (catan, 0x0.ffffffffffffffffffffffffffcp0L, -0x1p-1022L, 7.853981633974483096156608458198695580735e-1L, -1.112536929253600691545116358666215745186e-308L, UNDERFLOW_EXCEPTION_DOUBLE),
5245 TEST_c_c (catan, -0x0.ffffffffffffffffffffffffffcp0L, 0x1p-1022L, -7.853981633974483096156608458198695580735e-1L, 1.112536929253600691545116358666215745186e-308L, UNDERFLOW_EXCEPTION_DOUBLE),
5246 TEST_c_c (catan, -0x0.ffffffffffffffffffffffffffcp0L, -0x1p-1022L, -7.853981633974483096156608458198695580735e-1L, -1.112536929253600691545116358666215745186e-308L, UNDERFLOW_EXCEPTION_DOUBLE),
5247 TEST_c_c (catan, 0x1p-1022L, 0x0.ffffffffffffffffffffffffffcp0L, 9.025971879324147880346310405868788320726e-277L, 3.708337415995707405382191849801244331055e1L),
5248 TEST_c_c (catan, -0x1p-1022L, 0x0.ffffffffffffffffffffffffffcp0L, -9.025971879324147880346310405868788320726e-277L, 3.708337415995707405382191849801244331055e1L),
5249 TEST_c_c (catan, 0x1p-1022L, -0x0.ffffffffffffffffffffffffffcp0L, 9.025971879324147880346310405868788320726e-277L, -3.708337415995707405382191849801244331055e1L),
5250 TEST_c_c (catan, -0x1p-1022L, -0x0.ffffffffffffffffffffffffffcp0L, -9.025971879324147880346310405868788320726e-277L, -3.708337415995707405382191849801244331055e1L),
5251 #endif
5252 #if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
5253 TEST_c_c (catan, 1.0L, 0x1p-8192L, 7.853981633974483096156608458198757210493e-1L, 4.584009668887117914053530980121207914891e-2467L),
5254 TEST_c_c (catan, 1.0L, -0x1p-8192L, 7.853981633974483096156608458198757210493e-1L, -4.584009668887117914053530980121207914891e-2467L),
5255 TEST_c_c (catan, -1.0L, 0x1p-8192L, -7.853981633974483096156608458198757210493e-1L, 4.584009668887117914053530980121207914891e-2467L),
5256 TEST_c_c (catan, -1.0L, -0x1p-8192L, -7.853981633974483096156608458198757210493e-1L, -4.584009668887117914053530980121207914891e-2467L),
5257 TEST_c_c (catan, 0x1p-8192L, 1.0L, 7.853981633974483096156608458198757210493e-1L, 2.839477425163815960027691385553420311121e3L),
5258 TEST_c_c (catan, -0x1p-8192L, 1.0L, -7.853981633974483096156608458198757210493e-1L, 2.839477425163815960027691385553420311121e3L),
5259 TEST_c_c (catan, 0x1p-8192L, -1.0L, 7.853981633974483096156608458198757210493e-1L, -2.839477425163815960027691385553420311121e3L),
5260 TEST_c_c (catan, -0x1p-8192L, -1.0L, -7.853981633974483096156608458198757210493e-1L, -2.839477425163815960027691385553420311121e3L),
5261 TEST_c_c (catan, 1.0L, 0x1.3p-8221L, 7.853981633974483096156608458198757210493e-1L, 1.013933025636421986471594877335044443409e-2475L),
5262 TEST_c_c (catan, 1.0L, -0x1.3p-8221L, 7.853981633974483096156608458198757210493e-1L, -1.013933025636421986471594877335044443409e-2475L),
5263 TEST_c_c (catan, -1.0L, 0x1.3p-8221L, -7.853981633974483096156608458198757210493e-1L, 1.013933025636421986471594877335044443409e-2475L),
5264 TEST_c_c (catan, -1.0L, -0x1.3p-8221L, -7.853981633974483096156608458198757210493e-1L, -1.013933025636421986471594877335044443409e-2475L),
5265 TEST_c_c (catan, 0x1.3p-8221L, 1.0L, 7.853981633974483096156608458198757210493e-1L, 2.849442134153471837403071201841536297726e3L),
5266 TEST_c_c (catan, -0x1.3p-8221L, 1.0L, -7.853981633974483096156608458198757210493e-1L, 2.849442134153471837403071201841536297726e3L),
5267 TEST_c_c (catan, 0x1.3p-8221L, -1.0L, 7.853981633974483096156608458198757210493e-1L, -2.849442134153471837403071201841536297726e3L),
5268 TEST_c_c (catan, -0x1.3p-8221L, -1.0L, -7.853981633974483096156608458198757210493e-1L, -2.849442134153471837403071201841536297726e3L),
5269 TEST_c_c (catan, 1.0L, 0x1.3p-8246L, 7.853981633974483096156608458198757210493e-1L, 3.021755890954798419688924781486524472858e-2483L),
5270 TEST_c_c (catan, 1.0L, -0x1.3p-8246L, 7.853981633974483096156608458198757210493e-1L, -3.021755890954798419688924781486524472858e-2483L),
5271 TEST_c_c (catan, -1.0L, 0x1.3p-8246L, -7.853981633974483096156608458198757210493e-1L, 3.021755890954798419688924781486524472858e-2483L),
5272 TEST_c_c (catan, -1.0L, -0x1.3p-8246L, -7.853981633974483096156608458198757210493e-1L, -3.021755890954798419688924781486524472858e-2483L),
5273 TEST_c_c (catan, 0x1.3p-8246L, 1.0L, 7.853981633974483096156608458198757210493e-1L, 2.858106473910471153770786603359763504827e3L),
5274 TEST_c_c (catan, -0x1.3p-8246L, 1.0L, -7.853981633974483096156608458198757210493e-1L, 2.858106473910471153770786603359763504827e3L),
5275 TEST_c_c (catan, 0x1.3p-8246L, -1.0L, 7.853981633974483096156608458198757210493e-1L, -2.858106473910471153770786603359763504827e3L),
5276 TEST_c_c (catan, -0x1.3p-8246L, -1.0L, -7.853981633974483096156608458198757210493e-1L, -2.858106473910471153770786603359763504827e3L),
5277 TEST_c_c (catan, 1.0L, 0x1p-16380L, 7.853981633974483096156608458198757210493e-1L, 6.724206286224187012525355634643505205196e-4932L),
5278 TEST_c_c (catan, 1.0L, -0x1p-16380L, 7.853981633974483096156608458198757210493e-1L, -6.724206286224187012525355634643505205196e-4932L),
5279 TEST_c_c (catan, -1.0L, 0x1p-16380L, -7.853981633974483096156608458198757210493e-1L, 6.724206286224187012525355634643505205196e-4932L),
5280 TEST_c_c (catan, -1.0L, -0x1p-16380L, -7.853981633974483096156608458198757210493e-1L, -6.724206286224187012525355634643505205196e-4932L),
5281 TEST_c_c (catan, 0x1p-16380L, 1.0L, 7.853981633974483096156608458198757210493e-1L, 5.677221982376232056781839690803195180822e3L),
5282 TEST_c_c (catan, -0x1p-16380L, 1.0L, -7.853981633974483096156608458198757210493e-1L, 5.677221982376232056781839690803195180822e3L),
5283 TEST_c_c (catan, 0x1p-16380L, -1.0L, 7.853981633974483096156608458198757210493e-1L, -5.677221982376232056781839690803195180822e3L),
5284 TEST_c_c (catan, -0x1p-16380L, -1.0L, -7.853981633974483096156608458198757210493e-1L, -5.677221982376232056781839690803195180822e3L),
5285 TEST_c_c (catan, 0x1.0000000000000002p0L, 0x1p-16382L, 7.853981633974483096698709544441509427467e-1L, 1.681051571556046752949078932066752571182e-4932L, UNDERFLOW_EXCEPTION),
5286 TEST_c_c (catan, 0x1.0000000000000002p0L, -0x1p-16382L, 7.853981633974483096698709544441509427467e-1L, -1.681051571556046752949078932066752571182e-4932L, UNDERFLOW_EXCEPTION),
5287 TEST_c_c (catan, -0x1.0000000000000002p0L, 0x1p-16382L, -7.853981633974483096698709544441509427467e-1L, 1.681051571556046752949078932066752571182e-4932L, UNDERFLOW_EXCEPTION),
5288 TEST_c_c (catan, -0x1.0000000000000002p0L, -0x1p-16382L, -7.853981633974483096698709544441509427467e-1L, -1.681051571556046752949078932066752571182e-4932L, UNDERFLOW_EXCEPTION),
5289 TEST_c_c (catan, 0x1p-16382L, 0x1.0000000000000002p0L, 1.570796326794896619231321691639751442099L, 2.218070977791824990137853294097378778927e1L),
5290 TEST_c_c (catan, -0x1p-16382L, 0x1.0000000000000002p0L, -1.570796326794896619231321691639751442099L, 2.218070977791824990137853294097378778927e1L),
5291 TEST_c_c (catan, 0x1p-16382L, -0x1.0000000000000002p0L, 1.570796326794896619231321691639751442099L, -2.218070977791824990137853294097378778927e1L),
5292 TEST_c_c (catan, -0x1p-16382L, -0x1.0000000000000002p0L, -1.570796326794896619231321691639751442099L, -2.218070977791824990137853294097378778927e1L),
5293 TEST_c_c (catan, 0x0.ffffffffffffffffp0L, 0x1p-16382L, 7.853981633974483095885557915077381101984e-1L, 1.681051571556046753222468896957938166365e-4932L, UNDERFLOW_EXCEPTION),
5294 TEST_c_c (catan, 0x0.ffffffffffffffffp0L, -0x1p-16382L, 7.853981633974483095885557915077381101984e-1L, -1.681051571556046753222468896957938166365e-4932L, UNDERFLOW_EXCEPTION),
5295 TEST_c_c (catan, -0x0.ffffffffffffffffp0L, 0x1p-16382L, -7.853981633974483095885557915077381101984e-1L, 1.681051571556046753222468896957938166365e-4932L, UNDERFLOW_EXCEPTION),
5296 TEST_c_c (catan, -0x0.ffffffffffffffffp0L, -0x1p-16382L, -7.853981633974483095885557915077381101984e-1L, -1.681051571556046753222468896957938166365e-4932L, UNDERFLOW_EXCEPTION),
5297 TEST_c_c (catan, 0x1p-16382L, 0x0.ffffffffffffffffp0L, 3.100992811520163369065387859792822623745e-4913L, 2.252728336819822255604649142023466965703e1L),
5298 TEST_c_c (catan, -0x1p-16382L, 0x0.ffffffffffffffffp0L, -3.100992811520163369065387859792822623745e-4913L, 2.252728336819822255604649142023466965703e1L),
5299 TEST_c_c (catan, 0x1p-16382L, -0x0.ffffffffffffffffp0L, 3.100992811520163369065387859792822623745e-4913L, -2.252728336819822255604649142023466965703e1L),
5300 TEST_c_c (catan, -0x1p-16382L, -0x0.ffffffffffffffffp0L, -3.100992811520163369065387859792822623745e-4913L, -2.252728336819822255604649142023466965703e1L),
5301 # if LDBL_MANT_DIG >= 113
5302 TEST_c_c (catan, 0x1.0000000000000000000000000001p0L, 0x1p-16382L, 7.853981633974483096156608458198758173458e-1L, 1.681051571556046753131338908660875977540e-4932L, UNDERFLOW_EXCEPTION),
5303 TEST_c_c (catan, 0x1.0000000000000000000000000001p0L, -0x1p-16382L, 7.853981633974483096156608458198758173458e-1L, -1.681051571556046753131338908660875977540e-4932L, UNDERFLOW_EXCEPTION),
5304 TEST_c_c (catan, -0x1.0000000000000000000000000001p0L, 0x1p-16382L, -7.853981633974483096156608458198758173458e-1L, 1.681051571556046753131338908660875977540e-4932L, UNDERFLOW_EXCEPTION),
5305 TEST_c_c (catan, -0x1.0000000000000000000000000001p0L, -0x1p-16382L, -7.853981633974483096156608458198758173458e-1L, -1.681051571556046753131338908660875977540e-4932L, UNDERFLOW_EXCEPTION),
5306 TEST_c_c (catan, 0x1p-16382L, 0x1.0000000000000000000000000001p0L, 1.570796326794896619231321691639751442099L, 3.916281570163690998207361486238697614441e1L),
5307 TEST_c_c (catan, -0x1p-16382L, 0x1.0000000000000000000000000001p0L, -1.570796326794896619231321691639751442099L, 3.916281570163690998207361486238697614441e1L),
5308 TEST_c_c (catan, 0x1p-16382L, -0x1.0000000000000000000000000001p0L, 1.570796326794896619231321691639751442099L, -3.916281570163690998207361486238697614441e1L),
5309 TEST_c_c (catan, -0x1p-16382L, -0x1.0000000000000000000000000001p0L, -1.570796326794896619231321691639751442099L, -3.916281570163690998207361486238697614441e1L),
5310 TEST_c_c (catan, 0x0.ffffffffffffffffffffffffffff8p0L, 0x1p-16382L, 7.853981633974483096156608458198756729010e-1L, 1.681051571556046753131338908660876463178e-4932L, UNDERFLOW_EXCEPTION),
5311 TEST_c_c (catan, 0x0.ffffffffffffffffffffffffffff8p0L, -0x1p-16382L, 7.853981633974483096156608458198756729010e-1L, -1.681051571556046753131338908660876463178e-4932L, UNDERFLOW_EXCEPTION),
5312 TEST_c_c (catan, -0x0.ffffffffffffffffffffffffffff8p0L, 0x1p-16382L, -7.853981633974483096156608458198756729010e-1L, 1.681051571556046753131338908660876463178e-4932L, UNDERFLOW_EXCEPTION),
5313 TEST_c_c (catan, -0x0.ffffffffffffffffffffffffffff8p0L, -0x1p-16382L, -7.853981633974483096156608458198756729010e-1L, -1.681051571556046753131338908660876463178e-4932L, UNDERFLOW_EXCEPTION),
5314 TEST_c_c (catan, 0x1p-16382L, 0x0.ffffffffffffffffffffffffffff8p0L, 1.745703758805099310527547423749501866998e-4898L, 3.950938929191688263678223092311606435623e1L),
5315 TEST_c_c (catan, -0x1p-16382L, 0x0.ffffffffffffffffffffffffffff8p0L, -1.745703758805099310527547423749501866998e-4898L, 3.950938929191688263678223092311606435623e1L),
5316 TEST_c_c (catan, 0x1p-16382L, -0x0.ffffffffffffffffffffffffffff8p0L, 1.745703758805099310527547423749501866998e-4898L, -3.950938929191688263678223092311606435623e1L),
5317 TEST_c_c (catan, -0x1p-16382L, -0x0.ffffffffffffffffffffffffffff8p0L, -1.745703758805099310527547423749501866998e-4898L, -3.950938929191688263678223092311606435623e1L),
5318 # endif
5319 #endif
5320
5321 TEST_c_c (catan, 0.75L, 1.25L, 1.10714871779409050301706546017853704L, 0.549306144334054845697622618461262852L),
5322 TEST_c_c (catan, -2, -3, -1.4099210495965755225306193844604208L, -0.22907268296853876629588180294200276L),
5323 END_DATA (catan)
5324 };
5325
5326 static void
5327 catan_test (void)
5328 {
5329 errno = 0;
5330 FUNC(catan) (BUILD_COMPLEX (0.7L, 1.2L));
5331 if (errno == ENOSYS)
5332 /* Function not implemented. */
5333 return;
5334
5335 START (catan);
5336 RUN_TEST_LOOP_c_c (catan, catan_test_data, );
5337 END (catan, complex);
5338 }
5339
5340 static const struct test_c_c_data catanh_test_data[] =
5341 {
5342 START_DATA (catanh),
5343 TEST_c_c (catanh, 0, 0, 0.0, 0.0),
5344 TEST_c_c (catanh, minus_zero, 0, minus_zero, 0.0),
5345 TEST_c_c (catanh, 0, minus_zero, 0.0, minus_zero),
5346 TEST_c_c (catanh, minus_zero, minus_zero, minus_zero, minus_zero),
5347
5348 TEST_c_c (catanh, 1.0L, plus_zero, plus_infty, plus_zero, DIVIDE_BY_ZERO_EXCEPTION),
5349 TEST_c_c (catanh, 1.0L, minus_zero, plus_infty, minus_zero, DIVIDE_BY_ZERO_EXCEPTION),
5350 TEST_c_c (catanh, -1.0L, plus_zero, minus_infty, plus_zero, DIVIDE_BY_ZERO_EXCEPTION),
5351 TEST_c_c (catanh, -1.0L, minus_zero, minus_infty, minus_zero, DIVIDE_BY_ZERO_EXCEPTION),
5352 TEST_c_c (catanh, plus_zero, 1.0L, plus_zero, M_PI_4l),
5353 TEST_c_c (catanh, minus_zero, 1.0L, minus_zero, M_PI_4l),
5354 TEST_c_c (catanh, plus_zero, -1.0L, plus_zero, -M_PI_4l),
5355 TEST_c_c (catanh, minus_zero, -1.0L, minus_zero, -M_PI_4l),
5356
5357 TEST_c_c (catanh, plus_infty, plus_infty, 0.0, M_PI_2l),
5358 TEST_c_c (catanh, plus_infty, minus_infty, 0.0, -M_PI_2l),
5359 TEST_c_c (catanh, minus_infty, plus_infty, minus_zero, M_PI_2l),
5360 TEST_c_c (catanh, minus_infty, minus_infty, minus_zero, -M_PI_2l),
5361
5362 TEST_c_c (catanh, -10.0, plus_infty, minus_zero, M_PI_2l),
5363 TEST_c_c (catanh, -10.0, minus_infty, minus_zero, -M_PI_2l),
5364 TEST_c_c (catanh, minus_zero, plus_infty, minus_zero, M_PI_2l),
5365 TEST_c_c (catanh, minus_zero, minus_infty, minus_zero, -M_PI_2l),
5366 TEST_c_c (catanh, 0, plus_infty, 0.0, M_PI_2l),
5367 TEST_c_c (catanh, 0, minus_infty, 0.0, -M_PI_2l),
5368 TEST_c_c (catanh, 0.1L, plus_infty, 0.0, M_PI_2l),
5369 TEST_c_c (catanh, 0.1L, minus_infty, 0.0, -M_PI_2l),
5370
5371 TEST_c_c (catanh, minus_infty, 0, minus_zero, M_PI_2l),
5372 TEST_c_c (catanh, minus_infty, minus_zero, minus_zero, -M_PI_2l),
5373 TEST_c_c (catanh, minus_infty, 100, minus_zero, M_PI_2l),
5374 TEST_c_c (catanh, minus_infty, -100, minus_zero, -M_PI_2l),
5375
5376 TEST_c_c (catanh, plus_infty, 0, 0.0, M_PI_2l),
5377 TEST_c_c (catanh, plus_infty, minus_zero, 0.0, -M_PI_2l),
5378 TEST_c_c (catanh, plus_infty, 0.5, 0.0, M_PI_2l),
5379 TEST_c_c (catanh, plus_infty, -0.5, 0.0, -M_PI_2l),
5380
5381 TEST_c_c (catanh, 0, qnan_value, 0.0, qnan_value),
5382 TEST_c_c (catanh, minus_zero, qnan_value, minus_zero, qnan_value),
5383
5384 TEST_c_c (catanh, plus_infty, qnan_value, 0.0, qnan_value),
5385 TEST_c_c (catanh, minus_infty, qnan_value, minus_zero, qnan_value),
5386
5387 TEST_c_c (catanh, qnan_value, 0, qnan_value, qnan_value),
5388 TEST_c_c (catanh, qnan_value, minus_zero, qnan_value, qnan_value),
5389
5390 TEST_c_c (catanh, qnan_value, plus_infty, 0.0, M_PI_2l, IGNORE_ZERO_INF_SIGN),
5391 TEST_c_c (catanh, qnan_value, minus_infty, 0.0, -M_PI_2l, IGNORE_ZERO_INF_SIGN),
5392
5393 TEST_c_c (catanh, 10.5, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
5394 TEST_c_c (catanh, -10.5, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
5395
5396 TEST_c_c (catanh, qnan_value, 0.75, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
5397 TEST_c_c (catanh, qnan_value, -0.75, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
5398
5399 TEST_c_c (catanh, qnan_value, qnan_value, qnan_value, qnan_value),
5400
5401 TEST_c_c (catanh, 0x1p50L, 0.0L, 8.881784197001252323389053344728897997441e-16L, 1.570796326794896619231321691639751442099L),
5402 TEST_c_c (catanh, 0x1p50L, -0.0L, 8.881784197001252323389053344728897997441e-16L, -1.570796326794896619231321691639751442099L),
5403 TEST_c_c (catanh, -0x1p50L, 0.0L, -8.881784197001252323389053344728897997441e-16L, 1.570796326794896619231321691639751442099L),
5404 TEST_c_c (catanh, -0x1p50L, -0.0L, -8.881784197001252323389053344728897997441e-16L, -1.570796326794896619231321691639751442099L),
5405 TEST_c_c (catanh, 0.0L, 0x1p50L, 0.0L, 1.570796326794895731052901991514519103193L),
5406 TEST_c_c (catanh, -0.0L, 0x1p50L, -0.0L, 1.570796326794895731052901991514519103193L),
5407 TEST_c_c (catanh, 0.0L, -0x1p50L, 0.0L, -1.570796326794895731052901991514519103193L),
5408 TEST_c_c (catanh, -0.0L, -0x1p50L, -0.0L, -1.570796326794895731052901991514519103193L),
5409 #ifndef TEST_FLOAT
5410 TEST_c_c (catanh, 0x1p500L, 0.0L, 3.054936363499604682051979393213617699789e-151L, 1.570796326794896619231321691639751442099L),
5411 TEST_c_c (catanh, 0x1p500L, -0.0L, 3.054936363499604682051979393213617699789e-151L, -1.570796326794896619231321691639751442099L),
5412 TEST_c_c (catanh, -0x1p500L, 0.0L, -3.054936363499604682051979393213617699789e-151L, 1.570796326794896619231321691639751442099L),
5413 TEST_c_c (catanh, -0x1p500L, -0.0L, -3.054936363499604682051979393213617699789e-151L, -1.570796326794896619231321691639751442099L),
5414 TEST_c_c (catanh, 0.0L, 0x1p500L, 0.0L, 1.570796326794896619231321691639751442099L),
5415 TEST_c_c (catanh, -0.0L, 0x1p500L, -0.0L, 1.570796326794896619231321691639751442099L),
5416 TEST_c_c (catanh, 0.0L, -0x1p500L, 0.0L, -1.570796326794896619231321691639751442099L),
5417 TEST_c_c (catanh, -0.0L, -0x1p500L, -0.0L, -1.570796326794896619231321691639751442099L),
5418 #endif
5419 #if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
5420 TEST_c_c (catanh, 0x1p5000L, 0.0L, 7.079811261048172892385615158694057552948e-1506L, 1.570796326794896619231321691639751442099L),
5421 TEST_c_c (catanh, 0x1p5000L, -0.0L, 7.079811261048172892385615158694057552948e-1506L, -1.570796326794896619231321691639751442099L),
5422 TEST_c_c (catanh, -0x1p5000L, 0.0L, -7.079811261048172892385615158694057552948e-1506L, 1.570796326794896619231321691639751442099L),
5423 TEST_c_c (catanh, -0x1p5000L, -0.0L, -7.079811261048172892385615158694057552948e-1506L, -1.570796326794896619231321691639751442099L),
5424 TEST_c_c (catanh, 0.0L, 0x1p5000L, 0.0L, 1.570796326794896619231321691639751442099L),
5425 TEST_c_c (catanh, -0.0L, 0x1p5000L, -0.0L, 1.570796326794896619231321691639751442099L),
5426 TEST_c_c (catanh, 0.0L, -0x1p5000L, 0.0L, -1.570796326794896619231321691639751442099L),
5427 TEST_c_c (catanh, -0.0L, -0x1p5000L, -0.0L, -1.570796326794896619231321691639751442099L),
5428 #endif
5429 TEST_c_c (catanh, 0x1p63L, 0.5L, 1.084202172485504434007452800869941711427e-19L, 1.570796326794896619231321691639751442093L),
5430 TEST_c_c (catanh, 0x1p63L, -0.5L, 1.084202172485504434007452800869941711427e-19L, -1.570796326794896619231321691639751442093L),
5431 TEST_c_c (catanh, -0x1p63L, 0.5L, -1.084202172485504434007452800869941711427e-19L, 1.570796326794896619231321691639751442093L),
5432 TEST_c_c (catanh, -0x1p63L, -0.5L, -1.084202172485504434007452800869941711427e-19L, -1.570796326794896619231321691639751442093L),
5433 TEST_c_c (catanh, 0.5L, 0x1p63L, 5.877471754111437539843682686111228389007e-39L, 1.570796326794896619122901474391200998698L, UNDERFLOW_EXCEPTION_FLOAT),
5434 TEST_c_c (catanh, -0.5L, 0x1p63L, -5.877471754111437539843682686111228389007e-39L, 1.570796326794896619122901474391200998698L, UNDERFLOW_EXCEPTION_FLOAT),
5435 TEST_c_c (catanh, 0.5L, -0x1p63L, 5.877471754111437539843682686111228389007e-39L, -1.570796326794896619122901474391200998698L, UNDERFLOW_EXCEPTION_FLOAT),
5436 TEST_c_c (catanh, -0.5L, -0x1p63L, -5.877471754111437539843682686111228389007e-39L, -1.570796326794896619122901474391200998698L, UNDERFLOW_EXCEPTION_FLOAT),
5437 #ifndef TEST_FLOAT
5438 TEST_c_c (catanh, 0x1p511L, 0.5L, 1.491668146240041348658193063092586767475e-154L, 1.570796326794896619231321691639751442099L),
5439 TEST_c_c (catanh, 0x1p511L, -0.5L, 1.491668146240041348658193063092586767475e-154L, -1.570796326794896619231321691639751442099L),
5440 TEST_c_c (catanh, -0x1p511L, 0.5L, -1.491668146240041348658193063092586767475e-154L, 1.570796326794896619231321691639751442099L),
5441 TEST_c_c (catanh, -0x1p511L, -0.5L, -1.491668146240041348658193063092586767475e-154L, -1.570796326794896619231321691639751442099L),
5442 TEST_c_c (catanh, 0.5L, 0x1p511L, 1.112536929253600691545116358666202032110e-308L, 1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION_DOUBLE),
5443 TEST_c_c (catanh, -0.5L, 0x1p511L, -1.112536929253600691545116358666202032110e-308L, 1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION_DOUBLE),
5444 TEST_c_c (catanh, 0.5L, -0x1p511L, 1.112536929253600691545116358666202032110e-308L, -1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION_DOUBLE),
5445 TEST_c_c (catanh, -0.5L, -0x1p511L, -1.112536929253600691545116358666202032110e-308L, -1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION_DOUBLE),
5446 #endif
5447 #if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
5448 TEST_c_c (catanh, 0x1p8191L, 0.5L, 1.833603867554847165621412392048483165956e-2466L, 1.570796326794896619231321691639751442099L),
5449 TEST_c_c (catanh, 0x1p8191L, -0.5L, 1.833603867554847165621412392048483165956e-2466L, -1.570796326794896619231321691639751442099L),
5450 TEST_c_c (catanh, -0x1p8191L, 0.5L, -1.833603867554847165621412392048483165956e-2466L, 1.570796326794896619231321691639751442099L),
5451 TEST_c_c (catanh, -0x1p8191L, -0.5L, -1.833603867554847165621412392048483165956e-2466L, -1.570796326794896619231321691639751442099L),
5452 TEST_c_c (catanh, 0.5L, 0x1p8191L, 1.681051571556046753131338908660876301299e-4932L, 1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION),
5453 TEST_c_c (catanh, -0.5L, 0x1p8191L, -1.681051571556046753131338908660876301299e-4932L, 1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION),
5454 TEST_c_c (catanh, 0.5L, -0x1p8191L, 1.681051571556046753131338908660876301299e-4932L, -1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION),
5455 TEST_c_c (catanh, -0.5L, -0x1p8191L, -1.681051571556046753131338908660876301299e-4932L, -1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION),
5456 #endif
5457 TEST_c_c (catanh, 0x1p100L, 0.0L, 7.888609052210118054117285652827862296732e-31L, 1.570796326794896619231321691639751442099L),
5458 TEST_c_c (catanh, 0x1p100L, -0.0L, 7.888609052210118054117285652827862296732e-31L, -1.570796326794896619231321691639751442099L),
5459 TEST_c_c (catanh, -0x1p100L, 0.0L, -7.888609052210118054117285652827862296732e-31L, 1.570796326794896619231321691639751442099L),
5460 TEST_c_c (catanh, -0x1p100L, -0.0L, -7.888609052210118054117285652827862296732e-31L, -1.570796326794896619231321691639751442099L),
5461 TEST_c_c (catanh, 0.0L, 0x1p100L, 0.0L, 1.570796326794896619231321691638962581193L),
5462 TEST_c_c (catanh, -0.0L, 0x1p100L, -0.0L, 1.570796326794896619231321691638962581193L),
5463 TEST_c_c (catanh, 0.0L, -0x1p100L, 0.0L, -1.570796326794896619231321691638962581193L),
5464 TEST_c_c (catanh, -0.0L, -0x1p100L, -0.0L, -1.570796326794896619231321691638962581193L),
5465 TEST_c_c (catanh, 0x1.fp127L, 0.0L, 3.033533808573645181854803967025150136306e-39L, 1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION_FLOAT),
5466 TEST_c_c (catanh, 0x1.fp127L, -0.0L, 3.033533808573645181854803967025150136306e-39L, -1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION_FLOAT),
5467 TEST_c_c (catanh, -0x1.fp127L, 0.0L, -3.033533808573645181854803967025150136306e-39L, 1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION_FLOAT),
5468 TEST_c_c (catanh, -0x1.fp127L, -0.0L, -3.033533808573645181854803967025150136306e-39L, -1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION_FLOAT),
5469 TEST_c_c (catanh, 0.0L, 0x1.fp127L, 0.0L, 1.570796326794896619231321691639751442096L),
5470 TEST_c_c (catanh, -0.0L, 0x1.fp127L, -0.0L, 1.570796326794896619231321691639751442096L),
5471 TEST_c_c (catanh, 0.0L, -0x1.fp127L, 0.0L, -1.570796326794896619231321691639751442096L),
5472 TEST_c_c (catanh, -0.0L, -0x1.fp127L, -0.0L, -1.570796326794896619231321691639751442096L),
5473 TEST_c_c (catanh, 0x1.fp127L, 0x1.fp127L, 1.516766904286822590927401983512575068153e-39L, 1.570796326794896619231321691639751442097L, UNDERFLOW_EXCEPTION_FLOAT),
5474 TEST_c_c (catanh, 0x1.fp127L, -0x1.fp127L, 1.516766904286822590927401983512575068153e-39L, -1.570796326794896619231321691639751442097L, UNDERFLOW_EXCEPTION_FLOAT),
5475 TEST_c_c (catanh, -0x1.fp127L, 0x1.fp127L, -1.516766904286822590927401983512575068153e-39L, 1.570796326794896619231321691639751442097L, UNDERFLOW_EXCEPTION_FLOAT),
5476 TEST_c_c (catanh, -0x1.fp127L, -0x1.fp127L, -1.516766904286822590927401983512575068153e-39L, -1.570796326794896619231321691639751442097L, UNDERFLOW_EXCEPTION_FLOAT),
5477 #ifndef TEST_FLOAT
5478 TEST_c_c (catanh, 0x1p900L, 0.0L, 1.183052186166774710972751597518026531652e-271L, 1.570796326794896619231321691639751442099L),
5479 TEST_c_c (catanh, 0x1p900L, -0.0L, 1.183052186166774710972751597518026531652e-271L, -1.570796326794896619231321691639751442099L),
5480 TEST_c_c (catanh, -0x1p900L, 0.0L, -1.183052186166774710972751597518026531652e-271L, 1.570796326794896619231321691639751442099L),
5481 TEST_c_c (catanh, -0x1p900L, -0.0L, -1.183052186166774710972751597518026531652e-271L, -1.570796326794896619231321691639751442099L),
5482 TEST_c_c (catanh, 0.0L, 0x1p900L, 0.0L, 1.570796326794896619231321691639751442099L),
5483 TEST_c_c (catanh, -0.0L, 0x1p900L, -0.0L, 1.570796326794896619231321691639751442099L),
5484 TEST_c_c (catanh, 0.0L, -0x1p900L, 0.0L, -1.570796326794896619231321691639751442099L),
5485 TEST_c_c (catanh, -0.0L, -0x1p900L, -0.0L, -1.570796326794896619231321691639751442099L),
5486 TEST_c_c (catanh, 0x1.fp1023L, 0.0L, 5.742126086470197117652213464083623391533e-309L, 1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION_DOUBLE),
5487 TEST_c_c (catanh, 0x1.fp1023L, -0.0L, 5.742126086470197117652213464083623391533e-309L, -1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION_DOUBLE),
5488 TEST_c_c (catanh, -0x1.fp1023L, 0.0L, -5.742126086470197117652213464083623391533e-309L, 1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION_DOUBLE),
5489 TEST_c_c (catanh, -0x1.fp1023L, -0.0L, -5.742126086470197117652213464083623391533e-309L, -1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION_DOUBLE),
5490 TEST_c_c (catanh, 0.0L, 0x1.fp1023L, 0.0L, 1.570796326794896619231321691639751442099L),
5491 TEST_c_c (catanh, -0.0L, 0x1.fp1023L, -0.0L, 1.570796326794896619231321691639751442099L),
5492 TEST_c_c (catanh, 0.0L, -0x1.fp1023L, 0.0L, -1.570796326794896619231321691639751442099L),
5493 TEST_c_c (catanh, -0.0L, -0x1.fp1023L, -0.0L, -1.570796326794896619231321691639751442099L),
5494 TEST_c_c (catanh, 0x1.fp1023L, 0x1.fp1023L, 2.871063043235098558826106732041811695767e-309L, 1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION_DOUBLE),
5495 TEST_c_c (catanh, 0x1.fp1023L, -0x1.fp1023L, 2.871063043235098558826106732041811695767e-309L, -1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION_DOUBLE),
5496 TEST_c_c (catanh, -0x1.fp1023L, 0x1.fp1023L, -2.871063043235098558826106732041811695767e-309L, 1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION_DOUBLE),
5497 TEST_c_c (catanh, -0x1.fp1023L, -0x1.fp1023L, -2.871063043235098558826106732041811695767e-309L, -1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION_DOUBLE),
5498 #endif
5499 #if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
5500 TEST_c_c (catanh, 0x1p10000L, 0.0L, 5.012372749206452009297555933742977749322e-3011L, 1.570796326794896619231321691639751442099L),
5501 TEST_c_c (catanh, 0x1p10000L, -0.0L, 5.012372749206452009297555933742977749322e-3011L, -1.570796326794896619231321691639751442099L),
5502 TEST_c_c (catanh, -0x1p10000L, 0.0L, -5.012372749206452009297555933742977749322e-3011L, 1.570796326794896619231321691639751442099L),
5503 TEST_c_c (catanh, -0x1p10000L, -0.0L, -5.012372749206452009297555933742977749322e-3011L, -1.570796326794896619231321691639751442099L),
5504 TEST_c_c (catanh, 0.0L, 0x1p10000L, 0.0L, 1.570796326794896619231321691639751442099L),
5505 TEST_c_c (catanh, -0.0L, 0x1p10000L, -0.0L, 1.570796326794896619231321691639751442099L),
5506 TEST_c_c (catanh, 0.0L, -0x1p10000L, 0.0L, -1.570796326794896619231321691639751442099L),
5507 TEST_c_c (catanh, -0.0L, -0x1p10000L, -0.0L, -1.570796326794896619231321691639751442099L),
5508 TEST_c_c (catanh, 0x1.fp16383L, 0.0L, 8.676395208031209048419813722120651877672e-4933L, 1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION),
5509 TEST_c_c (catanh, 0x1.fp16383L, -0.0L, 8.676395208031209048419813722120651877672e-4933L, -1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION),
5510 TEST_c_c (catanh, -0x1.fp16383L, 0.0L, -8.676395208031209048419813722120651877672e-4933L, 1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION),
5511 TEST_c_c (catanh, -0x1.fp16383L, -0.0L, -8.676395208031209048419813722120651877672e-4933L, -1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION),
5512 TEST_c_c (catanh, 0.0L, 0x1.fp16383L, 0.0L, 1.570796326794896619231321691639751442099L),
5513 TEST_c_c (catanh, -0.0L, 0x1.fp16383L, -0.0L, 1.570796326794896619231321691639751442099L),
5514 TEST_c_c (catanh, 0.0L, -0x1.fp16383L, 0.0L, -1.570796326794896619231321691639751442099L),
5515 TEST_c_c (catanh, -0.0L, -0x1.fp16383L, -0.0L, -1.570796326794896619231321691639751442099L),
5516 TEST_c_c (catanh, 0x1.fp16383L, 0x1.fp16383L, 4.338197604015604524209906861060325938836e-4933L, 1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION),
5517 TEST_c_c (catanh, 0x1.fp16383L, -0x1.fp16383L, 4.338197604015604524209906861060325938836e-4933L, -1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION),
5518 TEST_c_c (catanh, -0x1.fp16383L, 0x1.fp16383L, -4.338197604015604524209906861060325938836e-4933L, 1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION),
5519 TEST_c_c (catanh, -0x1.fp16383L, -0x1.fp16383L, -4.338197604015604524209906861060325938836e-4933L, -1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION),
5520 #endif
5521 TEST_c_c (catanh, 0x1p-13L, 1.0L, 6.103515609841754902688560615027452023669e-5L, 7.853981671227386080775748393881580082970e-1L),
5522 TEST_c_c (catanh, 0x1p-13L, -1.0L, 6.103515609841754902688560615027452023669e-5L, -7.853981671227386080775748393881580082970e-1L),
5523 TEST_c_c (catanh, -0x1p-13L, 1.0L, -6.103515609841754902688560615027452023669e-5L, 7.853981671227386080775748393881580082970e-1L),
5524 TEST_c_c (catanh, -0x1p-13L, -1.0L, -6.103515609841754902688560615027452023669e-5L, -7.853981671227386080775748393881580082970e-1L),
5525 TEST_c_c (catanh, 1.0L, 0x1p-13L, 4.852030264850939738801379894163661227127L, 7.854286809755354140031716771044626356262e-1L),
5526 TEST_c_c (catanh, -1.0L, 0x1p-13L, -4.852030264850939738801379894163661227127L, 7.854286809755354140031716771044626356262e-1L),
5527 TEST_c_c (catanh, 1.0L, -0x1p-13L, 4.852030264850939738801379894163661227127L, -7.854286809755354140031716771044626356262e-1L),
5528 TEST_c_c (catanh, -1.0L, -0x1p-13L, -4.852030264850939738801379894163661227127L, -7.854286809755354140031716771044626356262e-1L),
5529 TEST_c_c (catanh, 0x1p-27L, 1.0L, 3.725290298461914028034141143623846306386e-9L, 7.853981633974483234934486536343324763447e-1L),
5530 TEST_c_c (catanh, 0x1p-27L, -1.0L, 3.725290298461914028034141143623846306386e-9L, -7.853981633974483234934486536343324763447e-1L),
5531 TEST_c_c (catanh, -0x1p-27L, 1.0L, -3.725290298461914028034141143623846306386e-9L, 7.853981633974483234934486536343324763447e-1L),
5532 TEST_c_c (catanh, -0x1p-27L, -1.0L, -3.725290298461914028034141143623846306386e-9L, -7.853981633974483234934486536343324763447e-1L),
5533 TEST_c_c (catanh, 1.0L, 0x1p-27L, 9.704060527839234335310696652368086117807L, 7.853981652600934588466178684534110069553e-1L),
5534 TEST_c_c (catanh, -1.0L, 0x1p-27L, -9.704060527839234335310696652368086117807L, 7.853981652600934588466178684534110069553e-1L),
5535 TEST_c_c (catanh, 1.0L, -0x1p-27L, 9.704060527839234335310696652368086117807L, -7.853981652600934588466178684534110069553e-1L),
5536 TEST_c_c (catanh, -1.0L, -0x1p-27L, -9.704060527839234335310696652368086117807L, -7.853981652600934588466178684534110069553e-1L),
5537 TEST_c_c (catanh, 0x1p-33L, 1.0L, 5.820766091346740722643102318246316469910e-11L, 7.853981633974483096190489776088929224056e-1L),
5538 TEST_c_c (catanh, 0x1p-33L, -1.0L, 5.820766091346740722643102318246316469910e-11L, -7.853981633974483096190489776088929224056e-1L),
5539 TEST_c_c (catanh, -0x1p-33L, 1.0L, -5.820766091346740722643102318246316469910e-11L, 7.853981633974483096190489776088929224056e-1L),
5540 TEST_c_c (catanh, -0x1p-33L, -1.0L, -5.820766091346740722643102318246316469910e-11L, -7.853981633974483096190489776088929224056e-1L),
5541 TEST_c_c (catanh, 1.0L, 0x1p-33L, 1.178350206951907026009379309773625595762e1L, 7.853981634265521400723945494331241018449e-1L),
5542 TEST_c_c (catanh, -1.0L, 0x1p-33L, -1.178350206951907026009379309773625595762e1L, 7.853981634265521400723945494331241018449e-1L),
5543 TEST_c_c (catanh, 1.0L, -0x1p-33L, 1.178350206951907026009379309773625595762e1L, -7.853981634265521400723945494331241018449e-1L),
5544 TEST_c_c (catanh, -1.0L, -0x1p-33L, -1.178350206951907026009379309773625595762e1L, -7.853981634265521400723945494331241018449e-1L),
5545 TEST_c_c (catanh, 0x1p-54L, 1.0L, 2.775557561562891351059079170227049355775e-17L, 7.853981633974483096156608458198764914213e-1L),
5546 TEST_c_c (catanh, 0x1p-54L, -1.0L, 2.775557561562891351059079170227049355775e-17L, -7.853981633974483096156608458198764914213e-1L),
5547 TEST_c_c (catanh, -0x1p-54L, 1.0L, -2.775557561562891351059079170227049355775e-17L, 7.853981633974483096156608458198764914213e-1L),
5548 TEST_c_c (catanh, -0x1p-54L, -1.0L, -2.775557561562891351059079170227049355775e-17L, -7.853981633974483096156608458198764914213e-1L),
5549 TEST_c_c (catanh, 1.0L, 0x1p-54L, 1.906154746539849600897388334009985581467e1L, 7.853981633974483234934486536343324763447e-1L),
5550 TEST_c_c (catanh, -1.0L, 0x1p-54L, -1.906154746539849600897388334009985581467e1L, 7.853981633974483234934486536343324763447e-1L),
5551 TEST_c_c (catanh, 1.0L, -0x1p-54L, 1.906154746539849600897388334009985581467e1L, -7.853981633974483234934486536343324763447e-1L),
5552 TEST_c_c (catanh, -1.0L, -0x1p-54L, -1.906154746539849600897388334009985581467e1L, -7.853981633974483234934486536343324763447e-1L),
5553 TEST_c_c (catanh, 0x1p-57L, 1.0L, 3.469446951953614188823848962783813448721e-18L, 7.853981633974483096156608458198757330864e-1L),
5554 TEST_c_c (catanh, 0x1p-57L, -1.0L, 3.469446951953614188823848962783813448721e-18L, -7.853981633974483096156608458198757330864e-1L),
5555 TEST_c_c (catanh, -0x1p-57L, 1.0L, -3.469446951953614188823848962783813448721e-18L, 7.853981633974483096156608458198757330864e-1L),
5556 TEST_c_c (catanh, -0x1p-57L, -1.0L, -3.469446951953614188823848962783813448721e-18L, -7.853981633974483096156608458198757330864e-1L),
5557 TEST_c_c (catanh, 1.0L, 0x1p-57L, 2.010126823623841397309973152228712047720e1L, 7.853981633974483113503843217966828154612e-1L),
5558 TEST_c_c (catanh, -1.0L, 0x1p-57L, -2.010126823623841397309973152228712047720e1L, 7.853981633974483113503843217966828154612e-1L),
5559 TEST_c_c (catanh, 1.0L, -0x1p-57L, 2.010126823623841397309973152228712047720e1L, -7.853981633974483113503843217966828154612e-1L),
5560 TEST_c_c (catanh, -1.0L, -0x1p-57L, -2.010126823623841397309973152228712047720e1L, -7.853981633974483113503843217966828154612e-1L),
5561 TEST_c_c (catanh, 0x1p-13L, 0x1.000002p0L, 6.103514882246036852433556327261700380577e-5L, 7.853982267273793866654490522673596014524e-1L),
5562 TEST_c_c (catanh, 0x1p-13L, -0x1.000002p0L, 6.103514882246036852433556327261700380577e-5L, -7.853982267273793866654490522673596014524e-1L),
5563 TEST_c_c (catanh, -0x1p-13L, 0x1.000002p0L, -6.103514882246036852433556327261700380577e-5L, 7.853982267273793866654490522673596014524e-1L),
5564 TEST_c_c (catanh, -0x1p-13L, -0x1.000002p0L, -6.103514882246036852433556327261700380577e-5L, -7.853982267273793866654490522673596014524e-1L),
5565 TEST_c_c (catanh, 0x1.000002p0L, 0x1p-13L, 4.852030056234795712498957387213592193975L, 7.859169620684960844300240092596908675974e-1L),
5566 TEST_c_c (catanh, -0x1.000002p0L, 0x1p-13L, -4.852030056234795712498957387213592193975L, 7.859169620684960844300240092596908675974e-1L),
5567 TEST_c_c (catanh, 0x1.000002p0L, -0x1p-13L, 4.852030056234795712498957387213592193975L, -7.859169620684960844300240092596908675974e-1L),
5568 TEST_c_c (catanh, -0x1.000002p0L, -0x1p-13L, -4.852030056234795712498957387213592193975L, -7.859169620684960844300240092596908675974e-1L),
5569 TEST_c_c (catanh, 0x1p-13L, 0x0.ffffffp0L, 6.103515973639646453881721999956617260502e-5L, 7.853981373204155542484315721351697277336e-1L),
5570 TEST_c_c (catanh, 0x1p-13L, -0x0.ffffffp0L, 6.103515973639646453881721999956617260502e-5L, -7.853981373204155542484315721351697277336e-1L),
5571 TEST_c_c (catanh, -0x1p-13L, 0x0.ffffffp0L, -6.103515973639646453881721999956617260502e-5L, 7.853981373204155542484315721351697277336e-1L),
5572 TEST_c_c (catanh, -0x1p-13L, -0x0.ffffffp0L, -6.103515973639646453881721999956617260502e-5L, -7.853981373204155542484315721351697277336e-1L),
5573 TEST_c_c (catanh, 0x0.ffffffp0L, 0x1p-13L, 4.852030190345140708455871037447717761868L, 7.851845403708474595909269086711426246675e-1L),
5574 TEST_c_c (catanh, -0x0.ffffffp0L, 0x1p-13L, -4.852030190345140708455871037447717761868L, 7.851845403708474595909269086711426246675e-1L),
5575 TEST_c_c (catanh, 0x0.ffffffp0L, -0x1p-13L, 4.852030190345140708455871037447717761868L, -7.851845403708474595909269086711426246675e-1L),
5576 TEST_c_c (catanh, -0x0.ffffffp0L, -0x1p-13L, -4.852030190345140708455871037447717761868L, -7.851845403708474595909269086711426246675e-1L),
5577 #ifndef TEST_FLOAT
5578 TEST_c_c (catanh, 0x1p-27L, 0x1.0000000000001p0L, 3.725290298461913200853528590596263270474e-9L, 7.853981633974484345157511161499711112683e-1L),
5579 TEST_c_c (catanh, 0x1p-27L, -0x1.0000000000001p0L, 3.725290298461913200853528590596263270474e-9L, -7.853981633974484345157511161499711112683e-1L),
5580 TEST_c_c (catanh, -0x1p-27L, 0x1.0000000000001p0L, -3.725290298461913200853528590596263270474e-9L, 7.853981633974484345157511161499711112683e-1L),
5581 TEST_c_c (catanh, -0x1p-27L, -0x1.0000000000001p0L, -3.725290298461913200853528590596263270474e-9L, -7.853981633974484345157511161499711112683e-1L),
5582 TEST_c_c (catanh, 0x1.0000000000001p0L, 0x1p-27L, 9.704060527839234168777242958594699810015L, 7.853981801612546526942695000283242525531e-1L),
5583 TEST_c_c (catanh, -0x1.0000000000001p0L, 0x1p-27L, -9.704060527839234168777242958594699810015L, 7.853981801612546526942695000283242525531e-1L),
5584 TEST_c_c (catanh, 0x1.0000000000001p0L, -0x1p-27L, 9.704060527839234168777242958594699810015L, -7.853981801612546526942695000283242525531e-1L),
5585 TEST_c_c (catanh, -0x1.0000000000001p0L, -0x1p-27L, -9.704060527839234168777242958594699810015L, -7.853981801612546526942695000283242525531e-1L),
5586 TEST_c_c (catanh, 0x1p-27L, 0x0.fffffffffffff8p0L, 3.725290298461914441624447420137706700965e-9L, 7.853981633974482679822974223765039144191e-1L),
5587 TEST_c_c (catanh, 0x1p-27L, -0x0.fffffffffffff8p0L, 3.725290298461914441624447420137706700965e-9L, -7.853981633974482679822974223765039144191e-1L),
5588 TEST_c_c (catanh, -0x1p-27L, 0x0.fffffffffffff8p0L, -3.725290298461914441624447420137706700965e-9L, 7.853981633974482679822974223765039144191e-1L),
5589 TEST_c_c (catanh, -0x1p-27L, -0x0.fffffffffffff8p0L, -3.725290298461914441624447420137706700965e-9L, -7.853981633974482679822974223765039144191e-1L),
5590 TEST_c_c (catanh, 0x0.fffffffffffff8p0L, 0x1p-27L, 9.704060527839234252043969805481351363824L, 7.853981578095128619227903983047292781021e-1L),
5591 TEST_c_c (catanh, -0x0.fffffffffffff8p0L, 0x1p-27L, -9.704060527839234252043969805481351363824L, 7.853981578095128619227903983047292781021e-1L),
5592 TEST_c_c (catanh, 0x0.fffffffffffff8p0L, -0x1p-27L, 9.704060527839234252043969805481351363824L, -7.853981578095128619227903983047292781021e-1L),
5593 TEST_c_c (catanh, -0x0.fffffffffffff8p0L, -0x1p-27L, -9.704060527839234252043969805481351363824L, -7.853981578095128619227903983047292781021e-1L),
5594 #endif
5595 #if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 64
5596 TEST_c_c (catanh, 0x1p-33L, 0x1.0000000000000002p0L, 5.820766091346740722012013594069507025615e-11L, 7.853981633974483096732590862331681441026e-1L),
5597 TEST_c_c (catanh, 0x1p-33L, -0x1.0000000000000002p0L, 5.820766091346740722012013594069507025615e-11L, -7.853981633974483096732590862331681441026e-1L),
5598 TEST_c_c (catanh, -0x1p-33L, 0x1.0000000000000002p0L, -5.820766091346740722012013594069507025615e-11L, 7.853981633974483096732590862331681441026e-1L),
5599 TEST_c_c (catanh, -0x1p-33L, -0x1.0000000000000002p0L, -5.820766091346740722012013594069507025615e-11L, -7.853981633974483096732590862331681441026e-1L),
5600 TEST_c_c (catanh, 0x1.0000000000000002p0L, 0x1p-33L, 1.178350206951907025990405771755129268176e1L, 7.853981638922134273801338071094141188767e-1L),
5601 TEST_c_c (catanh, -0x1.0000000000000002p0L, 0x1p-33L, -1.178350206951907025990405771755129268176e1L, 7.853981638922134273801338071094141188767e-1L),
5602 TEST_c_c (catanh, 0x1.0000000000000002p0L, -0x1p-33L, 1.178350206951907025990405771755129268176e1L, -7.853981638922134273801338071094141188767e-1L),
5603 TEST_c_c (catanh, -0x1.0000000000000002p0L, -0x1p-33L, -1.178350206951907025990405771755129268176e1L, -7.853981638922134273801338071094141188767e-1L),
5604 TEST_c_c (catanh, 0x1p-33L, 0x0.ffffffffffffffffp0L, 5.820766091346740722958646680334721192083e-11L, 7.853981633974483095919439232967553115548e-1L),
5605 TEST_c_c (catanh, 0x1p-33L, -0x0.ffffffffffffffffp0L, 5.820766091346740722958646680334721192083e-11L, -7.853981633974483095919439232967553115548e-1L),
5606 TEST_c_c (catanh, -0x1p-33L, 0x0.ffffffffffffffffp0L, -5.820766091346740722958646680334721192083e-11L, 7.853981633974483095919439232967553115548e-1L),
5607 TEST_c_c (catanh, -0x1p-33L, -0x0.ffffffffffffffffp0L, -5.820766091346740722958646680334721192083e-11L, -7.853981633974483095919439232967553115548e-1L),
5608 TEST_c_c (catanh, 0x0.ffffffffffffffffp0L, 0x1p-33L, 1.178350206951907026002603046195591193050e1L, 7.853981631937214964185249205444919953948e-1L),
5609 TEST_c_c (catanh, -0x0.ffffffffffffffffp0L, 0x1p-33L, -1.178350206951907026002603046195591193050e1L, 7.853981631937214964185249205444919953948e-1L),
5610 TEST_c_c (catanh, 0x0.ffffffffffffffffp0L, -0x1p-33L, 1.178350206951907026002603046195591193050e1L, -7.853981631937214964185249205444919953948e-1L),
5611 TEST_c_c (catanh, -0x0.ffffffffffffffffp0L, -0x1p-33L, -1.178350206951907026002603046195591193050e1L, -7.853981631937214964185249205444919953948e-1L),
5612 #endif
5613 #if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 106
5614 TEST_c_c (catanh, 0x1p-54L, 0x1.000000000000000000000000008p0L, 2.775557561562891351059079170226980932999e-17L, 7.853981633974483096156608458198888173729e-1L),
5615 TEST_c_c (catanh, 0x1p-54L, -0x1.000000000000000000000000008p0L, 2.775557561562891351059079170226980932999e-17L, -7.853981633974483096156608458198888173729e-1L),
5616 TEST_c_c (catanh, -0x1p-54L, 0x1.000000000000000000000000008p0L, -2.775557561562891351059079170226980932999e-17L, 7.853981633974483096156608458198888173729e-1L),
5617 TEST_c_c (catanh, -0x1p-54L, -0x1.000000000000000000000000008p0L, -2.775557561562891351059079170226980932999e-17L, -7.853981633974483096156608458198888173729e-1L),
5618 TEST_c_c (catanh, 0x1.000000000000000000000000008p0L, 0x1p-54L, 1.906154746539849600897388334009981267384e1L, 7.853981633974485455380535786656405610710e-1L),
5619 TEST_c_c (catanh, -0x1.000000000000000000000000008p0L, 0x1p-54L, -1.906154746539849600897388334009981267384e1L, 7.853981633974485455380535786656405610710e-1L),
5620 TEST_c_c (catanh, 0x1.000000000000000000000000008p0L, -0x1p-54L, 1.906154746539849600897388334009981267384e1L, -7.853981633974485455380535786656405610710e-1L),
5621 TEST_c_c (catanh, -0x1.000000000000000000000000008p0L, -0x1p-54L, -1.906154746539849600897388334009981267384e1L, -7.853981633974485455380535786656405610710e-1L),
5622 TEST_c_c (catanh, 0x1p-54L, 0x0.ffffffffffffffffffffffffffcp0L, 2.775557561562891351059079170227083567164e-17L, 7.853981633974483096156608458198703284454e-1L),
5623 TEST_c_c (catanh, 0x1p-54L, -0x0.ffffffffffffffffffffffffffcp0L, 2.775557561562891351059079170227083567164e-17L, -7.853981633974483096156608458198703284454e-1L),
5624 TEST_c_c (catanh, -0x1p-54L, 0x0.ffffffffffffffffffffffffffcp0L, -2.775557561562891351059079170227083567164e-17L, 7.853981633974483096156608458198703284454e-1L),
5625 TEST_c_c (catanh, -0x1p-54L, -0x0.ffffffffffffffffffffffffffcp0L, -2.775557561562891351059079170227083567164e-17L, -7.853981633974483096156608458198703284454e-1L),
5626 TEST_c_c (catanh, 0x0.ffffffffffffffffffffffffffcp0L, 0x1p-54L, 1.906154746539849600897388334009984040723e1L, 7.853981633974482124711461911186784339815e-1L),
5627 TEST_c_c (catanh, -0x0.ffffffffffffffffffffffffffcp0L, 0x1p-54L, -1.906154746539849600897388334009984040723e1L, 7.853981633974482124711461911186784339815e-1L),
5628 TEST_c_c (catanh, 0x0.ffffffffffffffffffffffffffcp0L, -0x1p-54L, 1.906154746539849600897388334009984040723e1L, -7.853981633974482124711461911186784339815e-1L),
5629 TEST_c_c (catanh, -0x0.ffffffffffffffffffffffffffcp0L, -0x1p-54L, -1.906154746539849600897388334009984040723e1L, -7.853981633974482124711461911186784339815e-1L),
5630 #endif
5631 #if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 113
5632 TEST_c_c (catanh, 0x1p-57L, 0x1.0000000000000000000000000001p0L, 3.469446951953614188823848962783812780530e-18L, 7.853981633974483096156608458198758293829e-1L),
5633 TEST_c_c (catanh, 0x1p-57L, -0x1.0000000000000000000000000001p0L, 3.469446951953614188823848962783812780530e-18L, -7.853981633974483096156608458198758293829e-1L),
5634 TEST_c_c (catanh, -0x1p-57L, 0x1.0000000000000000000000000001p0L, -3.469446951953614188823848962783812780530e-18L, 7.853981633974483096156608458198758293829e-1L),
5635 TEST_c_c (catanh, -0x1p-57L, -0x1.0000000000000000000000000001p0L, -3.469446951953614188823848962783812780530e-18L, -7.853981633974483096156608458198758293829e-1L),
5636 TEST_c_c (catanh, 0x1.0000000000000000000000000001p0L, 0x1p-57L, 2.010126823623841397309973152228712033275e1L, 7.853981633974483252281721296111395707566e-1L),
5637 TEST_c_c (catanh, -0x1.0000000000000000000000000001p0L, 0x1p-57L, -2.010126823623841397309973152228712033275e1L, 7.853981633974483252281721296111395707566e-1L),
5638 TEST_c_c (catanh, 0x1.0000000000000000000000000001p0L, -0x1p-57L, 2.010126823623841397309973152228712033275e1L, -7.853981633974483252281721296111395707566e-1L),
5639 TEST_c_c (catanh, -0x1.0000000000000000000000000001p0L, -0x1p-57L, -2.010126823623841397309973152228712033275e1L, -7.853981633974483252281721296111395707566e-1L),
5640 TEST_c_c (catanh, 0x1p-57L, 0x0.ffffffffffffffffffffffffffff8p0L, 3.469446951953614188823848962783813782817e-18L, 7.853981633974483096156608458198756849381e-1L),
5641 TEST_c_c (catanh, 0x1p-57L, -0x0.ffffffffffffffffffffffffffff8p0L, 3.469446951953614188823848962783813782817e-18L, -7.853981633974483096156608458198756849381e-1L),
5642 TEST_c_c (catanh, -0x1p-57L, 0x0.ffffffffffffffffffffffffffff8p0L, -3.469446951953614188823848962783813782817e-18L, 7.853981633974483096156608458198756849381e-1L),
5643 TEST_c_c (catanh, -0x1p-57L, -0x0.ffffffffffffffffffffffffffff8p0L, -3.469446951953614188823848962783813782817e-18L, -7.853981633974483096156608458198756849381e-1L),
5644 TEST_c_c (catanh, 0x0.ffffffffffffffffffffffffffff8p0L, 0x1p-57L, 2.010126823623841397309973152228712040498e1L, 7.853981633974483044114904178894544378135e-1L),
5645 TEST_c_c (catanh, -0x0.ffffffffffffffffffffffffffff8p0L, 0x1p-57L, -2.010126823623841397309973152228712040498e1L, 7.853981633974483044114904178894544378135e-1L),
5646 TEST_c_c (catanh, 0x0.ffffffffffffffffffffffffffff8p0L, -0x1p-57L, 2.010126823623841397309973152228712040498e1L, -7.853981633974483044114904178894544378135e-1L),
5647 TEST_c_c (catanh, -0x0.ffffffffffffffffffffffffffff8p0L, -0x1p-57L, -2.010126823623841397309973152228712040498e1L, -7.853981633974483044114904178894544378135e-1L),
5648 #endif
5649 TEST_c_c (catanh, 1.0L, 0x1p-64L, 2.252728336819822255606004394739073846245e1L, 7.853981633974483096292133729759445264744e-1L),
5650 TEST_c_c (catanh, 1.0L, -0x1p-64L, 2.252728336819822255606004394739073846245e1L, -7.853981633974483096292133729759445264744e-1L),
5651 TEST_c_c (catanh, -1.0L, 0x1p-64L, -2.252728336819822255606004394739073846245e1L, 7.853981633974483096292133729759445264744e-1L),
5652 TEST_c_c (catanh, -1.0L, -0x1p-64L, -2.252728336819822255606004394739073846245e1L, -7.853981633974483096292133729759445264744e-1L),
5653 TEST_c_c (catanh, 0x1p-64L, 1.0L, 2.710505431213761085018632002174854278563e-20L, 7.853981633974483096156608458198757210500e-1L),
5654 TEST_c_c (catanh, -0x1p-64L, 1.0L, -2.710505431213761085018632002174854278563e-20L, 7.853981633974483096156608458198757210500e-1L),
5655 TEST_c_c (catanh, 0x1p-64L, -1.0L, 2.710505431213761085018632002174854278563e-20L, -7.853981633974483096156608458198757210500e-1L),
5656 TEST_c_c (catanh, -0x1p-64L, -1.0L, -2.710505431213761085018632002174854278563e-20L, -7.853981633974483096156608458198757210500e-1L),
5657 TEST_c_c (catanh, 1.0L, 0x1.3p-73L, 2.556052055225464683726753902092495938633e1L, 7.853981633974483096156922786831527361009e-1L),
5658 TEST_c_c (catanh, 1.0L, -0x1.3p-73L, 2.556052055225464683726753902092495938633e1L, -7.853981633974483096156922786831527361009e-1L),
5659 TEST_c_c (catanh, -1.0L, 0x1.3p-73L, -2.556052055225464683726753902092495938633e1L, 7.853981633974483096156922786831527361009e-1L),
5660 TEST_c_c (catanh, -1.0L, -0x1.3p-73L, -2.556052055225464683726753902092495938633e1L, -7.853981633974483096156922786831527361009e-1L),
5661 TEST_c_c (catanh, 0x1.3p-73L, 1.0L, 6.286572655403010329022706059731717687100e-23L, 7.853981633974483096156608458198757210493e-1L),
5662 TEST_c_c (catanh, -0x1.3p-73L, 1.0L, -6.286572655403010329022706059731717687100e-23L, 7.853981633974483096156608458198757210493e-1L),
5663 TEST_c_c (catanh, 0x1.3p-73L, -1.0L, 6.286572655403010329022706059731717687100e-23L, -7.853981633974483096156608458198757210493e-1L),
5664 TEST_c_c (catanh, -0x1.3p-73L, -1.0L, -6.286572655403010329022706059731717687100e-23L, -7.853981633974483096156608458198757210493e-1L),
5665 TEST_c_c (catanh, 1.0L, 0x1p-124L, 4.332169878499658183857700759113603550472e1L, 7.853981633974483096156608458198757210610e-1L),
5666 TEST_c_c (catanh, 1.0L, -0x1p-124L, 4.332169878499658183857700759113603550472e1L, -7.853981633974483096156608458198757210610e-1L),
5667 TEST_c_c (catanh, -1.0L, 0x1p-124L, -4.332169878499658183857700759113603550472e1L, 7.853981633974483096156608458198757210610e-1L),
5668 TEST_c_c (catanh, -1.0L, -0x1p-124L, -4.332169878499658183857700759113603550472e1L, -7.853981633974483096156608458198757210610e-1L),
5669 TEST_c_c (catanh, 0x1p-124L, 1.0L, 2.350988701644575015937473074444491355637e-38L, 7.853981633974483096156608458198757210493e-1L),
5670 TEST_c_c (catanh, -0x1p-124L, 1.0L, -2.350988701644575015937473074444491355637e-38L, 7.853981633974483096156608458198757210493e-1L),
5671 TEST_c_c (catanh, 0x1p-124L, -1.0L, 2.350988701644575015937473074444491355637e-38L, -7.853981633974483096156608458198757210493e-1L),
5672 TEST_c_c (catanh, -0x1p-124L, -1.0L, -2.350988701644575015937473074444491355637e-38L, -7.853981633974483096156608458198757210493e-1L),
5673 TEST_c_c (catanh, 0x1.000002p0L, 0x1p-126L, 8.317766196521665212523713550410777685446L, 1.570796326794896619231321691639702138295L),
5674 TEST_c_c (catanh, 0x1.000002p0L, -0x1p-126L, 8.317766196521665212523713550410777685446L, -1.570796326794896619231321691639702138295L),
5675 TEST_c_c (catanh, -0x1.000002p0L, 0x1p-126L, -8.317766196521665212523713550410777685446L, 1.570796326794896619231321691639702138295L),
5676 TEST_c_c (catanh, -0x1.000002p0L, -0x1p-126L, -8.317766196521665212523713550410777685446L, -1.570796326794896619231321691639702138295L),
5677 TEST_c_c (catanh, 0x1p-126L, 0x1.000002p0L, 5.877471053462247139383742414506671233336e-39L, 7.853982230020895322927482174768220815493e-1L, UNDERFLOW_EXCEPTION_FLOAT),
5678 TEST_c_c (catanh, -0x1p-126L, 0x1.000002p0L, -5.877471053462247139383742414506671233336e-39L, 7.853982230020895322927482174768220815493e-1L, UNDERFLOW_EXCEPTION_FLOAT),
5679 TEST_c_c (catanh, 0x1p-126L, -0x1.000002p0L, 5.877471053462247139383742414506671233336e-39L, -7.853982230020895322927482174768220815493e-1L, UNDERFLOW_EXCEPTION_FLOAT),
5680 TEST_c_c (catanh, -0x1p-126L, -0x1.000002p0L, -5.877471053462247139383742414506671233336e-39L, -7.853982230020895322927482174768220815493e-1L, UNDERFLOW_EXCEPTION_FLOAT),
5681 TEST_c_c (catanh, 0x0.ffffffp0L, 0x1p-126L, 8.664339742098154951823135931565866792454L, 9.860761609136244031334147100512154160097e-32L),
5682 TEST_c_c (catanh, 0x0.ffffffp0L, -0x1p-126L, 8.664339742098154951823135931565866792454L, -9.860761609136244031334147100512154160097e-32L),
5683 TEST_c_c (catanh, -0x0.ffffffp0L, 0x1p-126L, -8.664339742098154951823135931565866792454L, 9.860761609136244031334147100512154160097e-32L),
5684 TEST_c_c (catanh, -0x0.ffffffp0L, -0x1p-126L, -8.664339742098154951823135931565866792454L, -9.860761609136244031334147100512154160097e-32L),
5685 TEST_c_c (catanh, 0x1p-126L, 0x0.ffffffp0L, 5.877472104436064061535099214664320916184e-39L, 7.853981335951250337419109991749089175724e-1L, UNDERFLOW_EXCEPTION_FLOAT),
5686 TEST_c_c (catanh, -0x1p-126L, 0x0.ffffffp0L, -5.877472104436064061535099214664320916184e-39L, 7.853981335951250337419109991749089175724e-1L, UNDERFLOW_EXCEPTION_FLOAT),
5687 TEST_c_c (catanh, 0x1p-126L, -0x0.ffffffp0L, 5.877472104436064061535099214664320916184e-39L, -7.853981335951250337419109991749089175724e-1L, UNDERFLOW_EXCEPTION_FLOAT),
5688 TEST_c_c (catanh, -0x1p-126L, -0x0.ffffffp0L, -5.877472104436064061535099214664320916184e-39L, -7.853981335951250337419109991749089175724e-1L, UNDERFLOW_EXCEPTION_FLOAT),
5689 #ifndef TEST_FLOAT
5690 TEST_c_c (catanh, 1.0L, 0x1p-512L, 1.777922518136259718655200391540222897114e2L, 7.853981633974483096156608458198757210493e-1L),
5691 TEST_c_c (catanh, 1.0L, -0x1p-512L, 1.777922518136259718655200391540222897114e2L, -7.853981633974483096156608458198757210493e-1L),
5692 TEST_c_c (catanh, -1.0L, 0x1p-512L, -1.777922518136259718655200391540222897114e2L, 7.853981633974483096156608458198757210493e-1L),
5693 TEST_c_c (catanh, -1.0L, -0x1p-512L, -1.777922518136259718655200391540222897114e2L, -7.853981633974483096156608458198757210493e-1L),
5694 TEST_c_c (catanh, 0x1p-512L, 1.0L, 3.729170365600103371645482657731466918688e-155L, 7.853981633974483096156608458198757210493e-1L),
5695 TEST_c_c (catanh, -0x1p-512L, 1.0L, -3.729170365600103371645482657731466918688e-155L, 7.853981633974483096156608458198757210493e-1L),
5696 TEST_c_c (catanh, 0x1p-512L, -1.0L, 3.729170365600103371645482657731466918688e-155L, -7.853981633974483096156608458198757210493e-1L),
5697 TEST_c_c (catanh, -0x1p-512L, -1.0L, -3.729170365600103371645482657731466918688e-155L, -7.853981633974483096156608458198757210493e-1L),
5698 TEST_c_c (catanh, 1.0L, 0x1.3p-536L, 1.860240928518819859673567751384928348958e2L, 7.853981633974483096156608458198757210493e-1L),
5699 TEST_c_c (catanh, 1.0L, -0x1.3p-536L, 1.860240928518819859673567751384928348958e2L, -7.853981633974483096156608458198757210493e-1L),
5700 TEST_c_c (catanh, -1.0L, 0x1.3p-536L, -1.860240928518819859673567751384928348958e2L, 7.853981633974483096156608458198757210493e-1L),
5701 TEST_c_c (catanh, -1.0L, -0x1.3p-536L, -1.860240928518819859673567751384928348958e2L, -7.853981633974483096156608458198757210493e-1L),
5702 TEST_c_c (catanh, 0x1.3p-536L, 1.0L, 2.639526015013529511588222179446290115084e-162L, 7.853981633974483096156608458198757210493e-1L),
5703 TEST_c_c (catanh, -0x1.3p-536L, 1.0L, -2.639526015013529511588222179446290115084e-162L, 7.853981633974483096156608458198757210493e-1L),
5704 TEST_c_c (catanh, 0x1.3p-536L, -1.0L, 2.639526015013529511588222179446290115084e-162L, -7.853981633974483096156608458198757210493e-1L),
5705 TEST_c_c (catanh, -0x1.3p-536L, -1.0L, -2.639526015013529511588222179446290115084e-162L, -7.853981633974483096156608458198757210493e-1L),
5706 TEST_c_c (catanh, 1.0L, 0x1p-1020L, 3.538516356758520804574969980043991380025e2L, 7.853981633974483096156608458198757210493e-1L),
5707 TEST_c_c (catanh, 1.0L, -0x1p-1020L, 3.538516356758520804574969980043991380025e2L, -7.853981633974483096156608458198757210493e-1L),
5708 TEST_c_c (catanh, -1.0L, 0x1p-1020L, -3.538516356758520804574969980043991380025e2L, 7.853981633974483096156608458198757210493e-1L),
5709 TEST_c_c (catanh, -1.0L, -0x1p-1020L, -3.538516356758520804574969980043991380025e2L, -7.853981633974483096156608458198757210493e-1L),
5710 TEST_c_c (catanh, 0x1p-1020L, 1.0L, 4.450147717014402766180465434664808128438e-308L, 7.853981633974483096156608458198757210493e-1L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
5711 TEST_c_c (catanh, -0x1p-1020L, 1.0L, -4.450147717014402766180465434664808128438e-308L, 7.853981633974483096156608458198757210493e-1L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
5712 TEST_c_c (catanh, 0x1p-1020L, -1.0L, 4.450147717014402766180465434664808128438e-308L, -7.853981633974483096156608458198757210493e-1L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
5713 TEST_c_c (catanh, -0x1p-1020L, -1.0L, -4.450147717014402766180465434664808128438e-308L, -7.853981633974483096156608458198757210493e-1L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
5714 TEST_c_c (catanh, 0x1.0000000000001p0L, 0x1p-1022L, 1.836840028483855075506780244989950299369e1L, 1.570796326794896619231321691639751442099L),
5715 TEST_c_c (catanh, 0x1.0000000000001p0L, -0x1p-1022L, 1.836840028483855075506780244989950299369e1L, -1.570796326794896619231321691639751442099L),
5716 TEST_c_c (catanh, -0x1.0000000000001p0L, 0x1p-1022L, -1.836840028483855075506780244989950299369e1L, 1.570796326794896619231321691639751442099L),
5717 TEST_c_c (catanh, -0x1.0000000000001p0L, -0x1p-1022L, -1.836840028483855075506780244989950299369e1L, -1.570796326794896619231321691639751442099L),
5718 TEST_c_c (catanh, 0x1p-1022L, 0x1.0000000000001p0L, 1.112536929253600444512293438042957369978e-308L, 7.853981633974484206379633083355174374608e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
5719 TEST_c_c (catanh, -0x1p-1022L, 0x1.0000000000001p0L, -1.112536929253600444512293438042957369978e-308L, 7.853981633974484206379633083355174374608e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
5720 TEST_c_c (catanh, 0x1p-1022L, -0x1.0000000000001p0L, 1.112536929253600444512293438042957369978e-308L, -7.853981633974484206379633083355174374608e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
5721 TEST_c_c (catanh, -0x1p-1022L, -0x1.0000000000001p0L, -1.112536929253600444512293438042957369978e-308L, -7.853981633974484206379633083355174374608e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
5722 TEST_c_c (catanh, 0x0.fffffffffffff8p0L, 0x1p-1022L, 1.871497387511852332650969166374185305708e1L, 1.002084180004486444624900488355118689113e-292L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
5723 TEST_c_c (catanh, 0x0.fffffffffffff8p0L, -0x1p-1022L, 1.871497387511852332650969166374185305708e1L, -1.002084180004486444624900488355118689113e-292L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
5724 TEST_c_c (catanh, -0x0.fffffffffffff8p0L, 0x1p-1022L, -1.871497387511852332650969166374185305708e1L, 1.002084180004486444624900488355118689113e-292L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
5725 TEST_c_c (catanh, -0x0.fffffffffffff8p0L, -0x1p-1022L, -1.871497387511852332650969166374185305708e1L, -1.002084180004486444624900488355118689113e-292L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
5726 TEST_c_c (catanh, 0x1p-1022L, 0x0.fffffffffffff8p0L, 1.112536929253600815061527818977844932790e-308L, 7.853981633974482541045096145620456183798e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
5727 TEST_c_c (catanh, -0x1p-1022L, 0x0.fffffffffffff8p0L, -1.112536929253600815061527818977844932790e-308L, 7.853981633974482541045096145620456183798e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
5728 TEST_c_c (catanh, 0x1p-1022L, -0x0.fffffffffffff8p0L, 1.112536929253600815061527818977844932790e-308L, -7.853981633974482541045096145620456183798e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
5729 TEST_c_c (catanh, -0x1p-1022L, -0x0.fffffffffffff8p0L, -1.112536929253600815061527818977844932790e-308L, -7.853981633974482541045096145620456183798e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
5730 #endif
5731 #if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 64
5732 TEST_c_c (catanh, 0x1.0000000000000002p0L, 0x1p-1022L, 2.218070977791824990137853294097378778927e1L, 1.570796326794896619231321691639751442099L),
5733 TEST_c_c (catanh, 0x1.0000000000000002p0L, -0x1p-1022L, 2.218070977791824990137853294097378778927e1L, -1.570796326794896619231321691639751442099L),
5734 TEST_c_c (catanh, -0x1.0000000000000002p0L, 0x1p-1022L, -2.218070977791824990137853294097378778927e1L, 1.570796326794896619231321691639751442099L),
5735 TEST_c_c (catanh, -0x1.0000000000000002p0L, -0x1p-1022L, -2.218070977791824990137853294097378778927e1L, -1.570796326794896619231321691639751442099L),
5736 TEST_c_c (catanh, 0x1p-1022L, 0x1.0000000000000002p0L, 1.112536929253600691424494863099491450042e-308L, 7.853981633974483096698709544441509427467e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
5737 TEST_c_c (catanh, -0x1p-1022L, 0x1.0000000000000002p0L, -1.112536929253600691424494863099491450042e-308L, 7.853981633974483096698709544441509427467e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
5738 TEST_c_c (catanh, 0x1p-1022L, -0x1.0000000000000002p0L, 1.112536929253600691424494863099491450042e-308L, -7.853981633974483096698709544441509427467e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
5739 TEST_c_c (catanh, -0x1p-1022L, -0x1.0000000000000002p0L, -1.112536929253600691424494863099491450042e-308L, -7.853981633974483096698709544441509427467e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
5740 TEST_c_c (catanh, 0x0.ffffffffffffffffp0L, 0x1p-1022L, 2.252728336819822255604649142023466965703e1L, 2.052268400649188124723641491045245971623e-289L),
5741 TEST_c_c (catanh, 0x0.ffffffffffffffffp0L, -0x1p-1022L, 2.252728336819822255604649142023466965703e1L, -2.052268400649188124723641491045245971623e-289L),
5742 TEST_c_c (catanh, -0x0.ffffffffffffffffp0L, 0x1p-1022L, -2.252728336819822255604649142023466965703e1L, 2.052268400649188124723641491045245971623e-289L),
5743 TEST_c_c (catanh, -0x0.ffffffffffffffffp0L, -0x1p-1022L, -2.252728336819822255604649142023466965703e1L, -2.052268400649188124723641491045245971623e-289L),
5744 TEST_c_c (catanh, 0x1p-1022L, 0x0.ffffffffffffffffp0L, 1.112536929253600691605427106449557323148e-308L, 7.853981633974483095885557915077381101984e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
5745 TEST_c_c (catanh, -0x1p-1022L, 0x0.ffffffffffffffffp0L, -1.112536929253600691605427106449557323148e-308L, 7.853981633974483095885557915077381101984e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
5746 TEST_c_c (catanh, 0x1p-1022L, -0x0.ffffffffffffffffp0L, 1.112536929253600691605427106449557323148e-308L, -7.853981633974483095885557915077381101984e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
5747 TEST_c_c (catanh, -0x1p-1022L, -0x0.ffffffffffffffffp0L, -1.112536929253600691605427106449557323148e-308L, -7.853981633974483095885557915077381101984e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
5748 #endif
5749 #if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 106
5750 TEST_c_c (catanh, 0x1.000000000000000000000000008p0L, 0x1p-1022L, 3.673680056967710139911330243728336427098e1L, 1.570796326794896619231321691639751442099L),
5751 TEST_c_c (catanh, 0x1.000000000000000000000000008p0L, -0x1p-1022L, 3.673680056967710139911330243728336427098e1L, -1.570796326794896619231321691639751442099L),
5752 TEST_c_c (catanh, -0x1.000000000000000000000000008p0L, 0x1p-1022L, -3.673680056967710139911330243728336427098e1L, 1.570796326794896619231321691639751442099L),
5753 TEST_c_c (catanh, -0x1.000000000000000000000000008p0L, -0x1p-1022L, -3.673680056967710139911330243728336427098e1L, -1.570796326794896619231321691639751442099L),
5754 TEST_c_c (catanh, 0x1p-1022L, 0x1.000000000000000000000000008p0L, 1.112536929253600691545116358666174605957e-308L, 7.853981633974483096156608458198880470009e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
5755 TEST_c_c (catanh, -0x1p-1022L, 0x1.000000000000000000000000008p0L, -1.112536929253600691545116358666174605957e-308L, 7.853981633974483096156608458198880470009e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
5756 TEST_c_c (catanh, 0x1p-1022L, -0x1.000000000000000000000000008p0L, 1.112536929253600691545116358666174605957e-308L, -7.853981633974483096156608458198880470009e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
5757 TEST_c_c (catanh, -0x1p-1022L, -0x1.000000000000000000000000008p0L, -1.112536929253600691545116358666174605957e-308L, -7.853981633974483096156608458198880470009e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
5758 TEST_c_c (catanh, 0x0.ffffffffffffffffffffffffffcp0L, 0x1p-1022L, 3.708337415995707405382191849801244331055e1L, 9.025971879324147880346310405868788320726e-277L),
5759 TEST_c_c (catanh, 0x0.ffffffffffffffffffffffffffcp0L, -0x1p-1022L, 3.708337415995707405382191849801244331055e1L, -9.025971879324147880346310405868788320726e-277L),
5760 TEST_c_c (catanh, -0x0.ffffffffffffffffffffffffffcp0L, 0x1p-1022L, -3.708337415995707405382191849801244331055e1L, 9.025971879324147880346310405868788320726e-277L),
5761 TEST_c_c (catanh, -0x0.ffffffffffffffffffffffffffcp0L, -0x1p-1022L, -3.708337415995707405382191849801244331055e1L, -9.025971879324147880346310405868788320726e-277L),
5762 TEST_c_c (catanh, 0x1p-1022L, 0x0.ffffffffffffffffffffffffffcp0L, 1.112536929253600691545116358666215745186e-308L, 7.853981633974483096156608458198695580735e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
5763 TEST_c_c (catanh, -0x1p-1022L, 0x0.ffffffffffffffffffffffffffcp0L, -1.112536929253600691545116358666215745186e-308L, 7.853981633974483096156608458198695580735e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
5764 TEST_c_c (catanh, 0x1p-1022L, -0x0.ffffffffffffffffffffffffffcp0L, 1.112536929253600691545116358666215745186e-308L, -7.853981633974483096156608458198695580735e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
5765 TEST_c_c (catanh, -0x1p-1022L, -0x0.ffffffffffffffffffffffffffcp0L, -1.112536929253600691545116358666215745186e-308L, -7.853981633974483096156608458198695580735e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
5766 #endif
5767 #if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
5768 TEST_c_c (catanh, 1.0L, 0x1p-8192L, 2.839477425163815960027691385553420311121e3L, 7.853981633974483096156608458198757210493e-1L),
5769 TEST_c_c (catanh, 1.0L, -0x1p-8192L, 2.839477425163815960027691385553420311121e3L, -7.853981633974483096156608458198757210493e-1L),
5770 TEST_c_c (catanh, -1.0L, 0x1p-8192L, -2.839477425163815960027691385553420311121e3L, 7.853981633974483096156608458198757210493e-1L),
5771 TEST_c_c (catanh, -1.0L, -0x1p-8192L, -2.839477425163815960027691385553420311121e3L, -7.853981633974483096156608458198757210493e-1L),
5772 TEST_c_c (catanh, 0x1p-8192L, 1.0L, 4.584009668887117914053530980121207914891e-2467L, 7.853981633974483096156608458198757210493e-1L),
5773 TEST_c_c (catanh, -0x1p-8192L, 1.0L, -4.584009668887117914053530980121207914891e-2467L, 7.853981633974483096156608458198757210493e-1L),
5774 TEST_c_c (catanh, 0x1p-8192L, -1.0L, 4.584009668887117914053530980121207914891e-2467L, -7.853981633974483096156608458198757210493e-1L),
5775 TEST_c_c (catanh, -0x1p-8192L, -1.0L, -4.584009668887117914053530980121207914891e-2467L, -7.853981633974483096156608458198757210493e-1L),
5776 TEST_c_c (catanh, 1.0L, 0x1.3p-8221L, 2.849442134153471837403071201841536297726e3L, 7.853981633974483096156608458198757210493e-1L),
5777 TEST_c_c (catanh, 1.0L, -0x1.3p-8221L, 2.849442134153471837403071201841536297726e3L, -7.853981633974483096156608458198757210493e-1L),
5778 TEST_c_c (catanh, -1.0L, 0x1.3p-8221L, -2.849442134153471837403071201841536297726e3L, 7.853981633974483096156608458198757210493e-1L),
5779 TEST_c_c (catanh, -1.0L, -0x1.3p-8221L, -2.849442134153471837403071201841536297726e3L, -7.853981633974483096156608458198757210493e-1L),
5780 TEST_c_c (catanh, 0x1.3p-8221L, 1.0L, 1.013933025636421986471594877335044443409e-2475L, 7.853981633974483096156608458198757210493e-1L),
5781 TEST_c_c (catanh, -0x1.3p-8221L, 1.0L, -1.013933025636421986471594877335044443409e-2475L, 7.853981633974483096156608458198757210493e-1L),
5782 TEST_c_c (catanh, 0x1.3p-8221L, -1.0L, 1.013933025636421986471594877335044443409e-2475L, -7.853981633974483096156608458198757210493e-1L),
5783 TEST_c_c (catanh, -0x1.3p-8221L, -1.0L, -1.013933025636421986471594877335044443409e-2475L, -7.853981633974483096156608458198757210493e-1L),
5784 TEST_c_c (catanh, 1.0L, 0x1.3p-8246L, 2.858106473910471153770786603359763504827e3L, 7.853981633974483096156608458198757210493e-1L),
5785 TEST_c_c (catanh, 1.0L, -0x1.3p-8246L, 2.858106473910471153770786603359763504827e3L, -7.853981633974483096156608458198757210493e-1L),
5786 TEST_c_c (catanh, -1.0L, 0x1.3p-8246L, -2.858106473910471153770786603359763504827e3L, 7.853981633974483096156608458198757210493e-1L),
5787 TEST_c_c (catanh, -1.0L, -0x1.3p-8246L, -2.858106473910471153770786603359763504827e3L, -7.853981633974483096156608458198757210493e-1L),
5788 TEST_c_c (catanh, 0x1.3p-8246L, 1.0L, 3.021755890954798419688924781486524472858e-2483L, 7.853981633974483096156608458198757210493e-1L),
5789 TEST_c_c (catanh, -0x1.3p-8246L, 1.0L, -3.021755890954798419688924781486524472858e-2483L, 7.853981633974483096156608458198757210493e-1L),
5790 TEST_c_c (catanh, 0x1.3p-8246L, -1.0L, 3.021755890954798419688924781486524472858e-2483L, -7.853981633974483096156608458198757210493e-1L),
5791 TEST_c_c (catanh, -0x1.3p-8246L, -1.0L, -3.021755890954798419688924781486524472858e-2483L, -7.853981633974483096156608458198757210493e-1L),
5792 TEST_c_c (catanh, 1.0L, 0x1p-16380L, 5.677221982376232056781839690803195180822e3L, 7.853981633974483096156608458198757210493e-1L),
5793 TEST_c_c (catanh, 1.0L, -0x1p-16380L, 5.677221982376232056781839690803195180822e3L, -7.853981633974483096156608458198757210493e-1L),
5794 TEST_c_c (catanh, -1.0L, 0x1p-16380L, -5.677221982376232056781839690803195180822e3L, 7.853981633974483096156608458198757210493e-1L),
5795 TEST_c_c (catanh, -1.0L, -0x1p-16380L, -5.677221982376232056781839690803195180822e3L, -7.853981633974483096156608458198757210493e-1L),
5796 TEST_c_c (catanh, 0x1p-16380L, 1.0L, 6.724206286224187012525355634643505205196e-4932L, 7.853981633974483096156608458198757210493e-1L),
5797 TEST_c_c (catanh, -0x1p-16380L, 1.0L, -6.724206286224187012525355634643505205196e-4932L, 7.853981633974483096156608458198757210493e-1L),
5798 TEST_c_c (catanh, 0x1p-16380L, -1.0L, 6.724206286224187012525355634643505205196e-4932L, -7.853981633974483096156608458198757210493e-1L),
5799 TEST_c_c (catanh, -0x1p-16380L, -1.0L, -6.724206286224187012525355634643505205196e-4932L, -7.853981633974483096156608458198757210493e-1L),
5800 TEST_c_c (catanh, 0x1.0000000000000002p0L, 0x1p-16382L, 2.218070977791824990137853294097378778927e1L, 1.570796326794896619231321691639751442099L),
5801 TEST_c_c (catanh, 0x1.0000000000000002p0L, -0x1p-16382L, 2.218070977791824990137853294097378778927e1L, -1.570796326794896619231321691639751442099L),
5802 TEST_c_c (catanh, -0x1.0000000000000002p0L, 0x1p-16382L, -2.218070977791824990137853294097378778927e1L, 1.570796326794896619231321691639751442099L),
5803 TEST_c_c (catanh, -0x1.0000000000000002p0L, -0x1p-16382L, -2.218070977791824990137853294097378778927e1L, -1.570796326794896619231321691639751442099L),
5804 TEST_c_c (catanh, 0x1p-16382L, 0x1.0000000000000002p0L, 1.681051571556046752949078932066752571182e-4932L, 7.853981633974483096698709544441509427467e-1L, UNDERFLOW_EXCEPTION),
5805 TEST_c_c (catanh, -0x1p-16382L, 0x1.0000000000000002p0L, -1.681051571556046752949078932066752571182e-4932L, 7.853981633974483096698709544441509427467e-1L, UNDERFLOW_EXCEPTION),
5806 TEST_c_c (catanh, 0x1p-16382L, -0x1.0000000000000002p0L, 1.681051571556046752949078932066752571182e-4932L, -7.853981633974483096698709544441509427467e-1L, UNDERFLOW_EXCEPTION),
5807 TEST_c_c (catanh, -0x1p-16382L, -0x1.0000000000000002p0L, -1.681051571556046752949078932066752571182e-4932L, -7.853981633974483096698709544441509427467e-1L, UNDERFLOW_EXCEPTION),
5808 TEST_c_c (catanh, 0x0.ffffffffffffffffp0L, 0x1p-16382L, 2.252728336819822255604649142023466965703e1L, 3.100992811520163369065387859792822623745e-4913L),
5809 TEST_c_c (catanh, 0x0.ffffffffffffffffp0L, -0x1p-16382L, 2.252728336819822255604649142023466965703e1L, -3.100992811520163369065387859792822623745e-4913L),
5810 TEST_c_c (catanh, -0x0.ffffffffffffffffp0L, 0x1p-16382L, -2.252728336819822255604649142023466965703e1L, 3.100992811520163369065387859792822623745e-4913L),
5811 TEST_c_c (catanh, -0x0.ffffffffffffffffp0L, -0x1p-16382L, -2.252728336819822255604649142023466965703e1L, -3.100992811520163369065387859792822623745e-4913L),
5812 TEST_c_c (catanh, 0x1p-16382L, 0x0.ffffffffffffffffp0L, 1.681051571556046753222468896957938166365e-4932L, 7.853981633974483095885557915077381101984e-1L, UNDERFLOW_EXCEPTION),
5813 TEST_c_c (catanh, -0x1p-16382L, 0x0.ffffffffffffffffp0L, -1.681051571556046753222468896957938166365e-4932L, 7.853981633974483095885557915077381101984e-1L, UNDERFLOW_EXCEPTION),
5814 TEST_c_c (catanh, 0x1p-16382L, -0x0.ffffffffffffffffp0L, 1.681051571556046753222468896957938166365e-4932L, -7.853981633974483095885557915077381101984e-1L, UNDERFLOW_EXCEPTION),
5815 TEST_c_c (catanh, -0x1p-16382L, -0x0.ffffffffffffffffp0L, -1.681051571556046753222468896957938166365e-4932L, -7.853981633974483095885557915077381101984e-1L, UNDERFLOW_EXCEPTION),
5816 # if LDBL_MANT_DIG >= 113
5817 TEST_c_c (catanh, 0x1.0000000000000000000000000001p0L, 0x1p-16382L, 3.916281570163690998207361486238697614441e1L, 1.570796326794896619231321691639751442099L),
5818 TEST_c_c (catanh, 0x1.0000000000000000000000000001p0L, -0x1p-16382L, 3.916281570163690998207361486238697614441e1L, -1.570796326794896619231321691639751442099L),
5819 TEST_c_c (catanh, -0x1.0000000000000000000000000001p0L, 0x1p-16382L, -3.916281570163690998207361486238697614441e1L, 1.570796326794896619231321691639751442099L),
5820 TEST_c_c (catanh, -0x1.0000000000000000000000000001p0L, -0x1p-16382L, -3.916281570163690998207361486238697614441e1L, -1.570796326794896619231321691639751442099L),
5821 TEST_c_c (catanh, 0x1p-16382L, 0x1.0000000000000000000000000001p0L, 1.681051571556046753131338908660875977540e-4932L, 7.853981633974483096156608458198758173458e-1L, UNDERFLOW_EXCEPTION),
5822 TEST_c_c (catanh, -0x1p-16382L, 0x1.0000000000000000000000000001p0L, -1.681051571556046753131338908660875977540e-4932L, 7.853981633974483096156608458198758173458e-1L, UNDERFLOW_EXCEPTION),
5823 TEST_c_c (catanh, 0x1p-16382L, -0x1.0000000000000000000000000001p0L, 1.681051571556046753131338908660875977540e-4932L, -7.853981633974483096156608458198758173458e-1L, UNDERFLOW_EXCEPTION),
5824 TEST_c_c (catanh, -0x1p-16382L, -0x1.0000000000000000000000000001p0L, -1.681051571556046753131338908660875977540e-4932L, -7.853981633974483096156608458198758173458e-1L, UNDERFLOW_EXCEPTION),
5825 TEST_c_c (catanh, 0x0.ffffffffffffffffffffffffffff8p0L, 0x1p-16382L, 3.950938929191688263678223092311606435623e1L, 1.745703758805099310527547423749501866998e-4898L),
5826 TEST_c_c (catanh, 0x0.ffffffffffffffffffffffffffff8p0L, -0x1p-16382L, 3.950938929191688263678223092311606435623e1L, -1.745703758805099310527547423749501866998e-4898L),
5827 TEST_c_c (catanh, -0x0.ffffffffffffffffffffffffffff8p0L, 0x1p-16382L, -3.950938929191688263678223092311606435623e1L, 1.745703758805099310527547423749501866998e-4898L),
5828 TEST_c_c (catanh, -0x0.ffffffffffffffffffffffffffff8p0L, -0x1p-16382L, -3.950938929191688263678223092311606435623e1L, -1.745703758805099310527547423749501866998e-4898L),
5829 TEST_c_c (catanh, 0x1p-16382L, 0x0.ffffffffffffffffffffffffffff8p0L, 1.681051571556046753131338908660876463178e-4932L, 7.853981633974483096156608458198756729010e-1L, UNDERFLOW_EXCEPTION),
5830 TEST_c_c (catanh, -0x1p-16382L, 0x0.ffffffffffffffffffffffffffff8p0L, -1.681051571556046753131338908660876463178e-4932L, 7.853981633974483096156608458198756729010e-1L, UNDERFLOW_EXCEPTION),
5831 TEST_c_c (catanh, 0x1p-16382L, -0x0.ffffffffffffffffffffffffffff8p0L, 1.681051571556046753131338908660876463178e-4932L, -7.853981633974483096156608458198756729010e-1L, UNDERFLOW_EXCEPTION),
5832 TEST_c_c (catanh, -0x1p-16382L, -0x0.ffffffffffffffffffffffffffff8p0L, -1.681051571556046753131338908660876463178e-4932L, -7.853981633974483096156608458198756729010e-1L, UNDERFLOW_EXCEPTION),
5833 # endif
5834 #endif
5835
5836 TEST_c_c (catanh, 0.75L, 1.25L, 0.261492138795671927078652057366532140L, 0.996825126463918666098902241310446708L),
5837 TEST_c_c (catanh, -2, -3, -0.14694666622552975204743278515471595L, -1.3389725222944935611241935759091443L),
5838 END_DATA (catanh)
5839 };
5840
5841 static void
5842 catanh_test (void)
5843 {
5844 errno = 0;
5845 FUNC(catanh) (BUILD_COMPLEX (0.7L, 1.2L));
5846 if (errno == ENOSYS)
5847 /* Function not implemented. */
5848 return;
5849
5850 START (catanh);
5851 RUN_TEST_LOOP_c_c (catanh, catanh_test_data, );
5852 END (catanh, complex);
5853 }
5854
5855 static const struct test_f_f_data cbrt_test_data[] =
5856 {
5857 START_DATA (cbrt),
5858 TEST_f_f (cbrt, 0.0, 0.0),
5859 TEST_f_f (cbrt, minus_zero, minus_zero),
5860
5861 TEST_f_f (cbrt, plus_infty, plus_infty),
5862 TEST_f_f (cbrt, minus_infty, minus_infty),
5863 TEST_f_f (cbrt, qnan_value, qnan_value),
5864
5865 TEST_f_f (cbrt, -0.001L, -0.1L),
5866 TEST_f_f (cbrt, 8, 2),
5867 TEST_f_f (cbrt, -27.0, -3.0),
5868 TEST_f_f (cbrt, 0.9921875L, 0.997389022060725270579075195353955217L),
5869 TEST_f_f (cbrt, 0.75L, 0.908560296416069829445605878163630251L),
5870 END_DATA (cbrt)
5871 };
5872
5873 static void
5874 cbrt_test (void)
5875 {
5876 errno = 0;
5877 FUNC(cbrt) (8);
5878 if (errno == ENOSYS)
5879 /* Function not implemented. */
5880 return;
5881
5882 START (cbrt);
5883 RUN_TEST_LOOP_f_f (cbrt, cbrt_test_data, );
5884 END (cbrt);
5885 }
5886
5887
5888 static const struct test_c_c_data ccos_test_data[] =
5889 {
5890 START_DATA (ccos),
5891 TEST_c_c (ccos, 0.0, 0.0, 1.0, minus_zero),
5892 TEST_c_c (ccos, minus_zero, 0.0, 1.0, 0.0),
5893 TEST_c_c (ccos, 0.0, minus_zero, 1.0, 0.0),
5894 TEST_c_c (ccos, minus_zero, minus_zero, 1.0, minus_zero),
5895
5896 TEST_c_c (ccos, plus_infty, 0.0, qnan_value, 0.0, INVALID_EXCEPTION|IGNORE_ZERO_INF_SIGN),
5897 TEST_c_c (ccos, plus_infty, minus_zero, qnan_value, 0.0, INVALID_EXCEPTION|IGNORE_ZERO_INF_SIGN),
5898 TEST_c_c (ccos, minus_infty, 0.0, qnan_value, 0.0, INVALID_EXCEPTION|IGNORE_ZERO_INF_SIGN),
5899 TEST_c_c (ccos, minus_infty, minus_zero, qnan_value, 0.0, INVALID_EXCEPTION|IGNORE_ZERO_INF_SIGN),
5900
5901 TEST_c_c (ccos, 0.0, plus_infty, plus_infty, minus_zero),
5902 TEST_c_c (ccos, 0.0, minus_infty, plus_infty, 0.0),
5903 TEST_c_c (ccos, minus_zero, plus_infty, plus_infty, 0.0),
5904 TEST_c_c (ccos, minus_zero, minus_infty, plus_infty, minus_zero),
5905
5906 TEST_c_c (ccos, plus_infty, plus_infty, plus_infty, qnan_value, INVALID_EXCEPTION),
5907 TEST_c_c (ccos, minus_infty, plus_infty, plus_infty, qnan_value, INVALID_EXCEPTION),
5908 TEST_c_c (ccos, plus_infty, minus_infty, plus_infty, qnan_value, INVALID_EXCEPTION),
5909 TEST_c_c (ccos, minus_infty, minus_infty, plus_infty, qnan_value, INVALID_EXCEPTION),
5910
5911 TEST_c_c (ccos, 4.625, plus_infty, minus_infty, plus_infty),
5912 TEST_c_c (ccos, 4.625, minus_infty, minus_infty, minus_infty),
5913 TEST_c_c (ccos, -4.625, plus_infty, minus_infty, minus_infty),
5914 TEST_c_c (ccos, -4.625, minus_infty, minus_infty, plus_infty),
5915
5916 TEST_c_c (ccos, plus_infty, 6.75, qnan_value, qnan_value, INVALID_EXCEPTION),
5917 TEST_c_c (ccos, plus_infty, -6.75, qnan_value, qnan_value, INVALID_EXCEPTION),
5918 TEST_c_c (ccos, minus_infty, 6.75, qnan_value, qnan_value, INVALID_EXCEPTION),
5919 TEST_c_c (ccos, minus_infty, -6.75, qnan_value, qnan_value, INVALID_EXCEPTION),
5920
5921 TEST_c_c (ccos, qnan_value, 0.0, qnan_value, 0.0, IGNORE_ZERO_INF_SIGN),
5922 TEST_c_c (ccos, qnan_value, minus_zero, qnan_value, 0.0, IGNORE_ZERO_INF_SIGN),
5923
5924 TEST_c_c (ccos, qnan_value, plus_infty, plus_infty, qnan_value),
5925 TEST_c_c (ccos, qnan_value, minus_infty, plus_infty, qnan_value),
5926
5927 TEST_c_c (ccos, qnan_value, 9.0, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
5928 TEST_c_c (ccos, qnan_value, -9.0, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
5929
5930 TEST_c_c (ccos, 0.0, qnan_value, qnan_value, 0.0, IGNORE_ZERO_INF_SIGN),
5931 TEST_c_c (ccos, minus_zero, qnan_value, qnan_value, 0.0, IGNORE_ZERO_INF_SIGN),
5932
5933 TEST_c_c (ccos, 10.0, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
5934 TEST_c_c (ccos, -10.0, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
5935
5936 TEST_c_c (ccos, plus_infty, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
5937 TEST_c_c (ccos, minus_infty, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
5938
5939 TEST_c_c (ccos, qnan_value, qnan_value, qnan_value, qnan_value),
5940
5941 TEST_c_c (ccos, 0.75L, 1.25L, 1.38173873063425888530729933139078645L, -1.09193013555397466170919531722024128L),
5942 TEST_c_c (ccos, -2, -3, -4.18962569096880723013255501961597373L, -9.10922789375533659797919726277886212L),
5943
5944 TEST_c_c (ccos, 0.75, 89.5, 2.708024460708609732016532185663087200560e38L, -2.522786001038096774676288412995370563339e38L),
5945 TEST_c_c (ccos, 0.75, -89.5, 2.708024460708609732016532185663087200560e38L, 2.522786001038096774676288412995370563339e38L),
5946 TEST_c_c (ccos, -0.75, 89.5, 2.708024460708609732016532185663087200560e38L, 2.522786001038096774676288412995370563339e38L),
5947 TEST_c_c (ccos, -0.75, -89.5, 2.708024460708609732016532185663087200560e38L, -2.522786001038096774676288412995370563339e38L),
5948
5949 #ifndef TEST_FLOAT
5950 TEST_c_c (ccos, 0.75, 710.5, 1.347490911916428129246890157395342279438e308L, -1.255317763348154410745082950806112487736e308L),
5951 TEST_c_c (ccos, 0.75, -710.5, 1.347490911916428129246890157395342279438e308L, 1.255317763348154410745082950806112487736e308L),
5952 TEST_c_c (ccos, -0.75, 710.5, 1.347490911916428129246890157395342279438e308L, 1.255317763348154410745082950806112487736e308L),
5953 TEST_c_c (ccos, -0.75, -710.5, 1.347490911916428129246890157395342279438e308L, -1.255317763348154410745082950806112487736e308L),
5954 #endif
5955
5956 #if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
5957 TEST_c_c (ccos, 0.75, 11357.25, 9.001213196851067077465606717616495588201e4931L, -8.385498349388321535962327491346664141020e4931L),
5958 TEST_c_c (ccos, 0.75, -11357.25, 9.001213196851067077465606717616495588201e4931L, 8.385498349388321535962327491346664141020e4931L),
5959 TEST_c_c (ccos, -0.75, 11357.25, 9.001213196851067077465606717616495588201e4931L, 8.385498349388321535962327491346664141020e4931L),
5960 TEST_c_c (ccos, -0.75, -11357.25, 9.001213196851067077465606717616495588201e4931L, -8.385498349388321535962327491346664141020e4931L),
5961 #endif
5962
5963 #ifdef TEST_FLOAT
5964 TEST_c_c (ccos, 0x1p-149, 180, plus_infty, -1.043535896672617552965983803453927655332e33L, OVERFLOW_EXCEPTION),
5965 #endif
5966
5967 #if defined TEST_DOUBLE || (defined TEST_LDOUBLE && LDBL_MAX_EXP == 1024)
5968 TEST_c_c (ccos, 0x1p-1074, 1440, plus_infty, -5.981479269486130556466515778180916082415e301L, OVERFLOW_EXCEPTION),
5969 #endif
5970
5971 #if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
5972 TEST_c_c (ccos, 0x1p-16434L, 22730, plus_infty, -1.217853148905605987081057582351152052687e4924L, OVERFLOW_EXCEPTION),
5973 #endif
5974
5975 TEST_c_c (ccos, min_subnorm_value * 0x1p120, 0x1p-120, 1.0, -min_subnorm_value, UNDERFLOW_EXCEPTION),
5976 TEST_c_c (ccos, 0x1p-120, min_subnorm_value * 0x1p120, 1.0, -min_subnorm_value, UNDERFLOW_EXCEPTION),
5977 END_DATA (ccos)
5978 };
5979
5980 static void
5981 ccos_test (void)
5982 {
5983 errno = 0;
5984 FUNC(ccos) (BUILD_COMPLEX (0, 0));
5985 if (errno == ENOSYS)
5986 /* Function not implemented. */
5987 return;
5988
5989 START (ccos);
5990 RUN_TEST_LOOP_c_c (ccos, ccos_test_data, );
5991 END (ccos, complex);
5992 }
5993
5994
5995 static const struct test_c_c_data ccosh_test_data[] =
5996 {
5997 START_DATA (ccosh),
5998 TEST_c_c (ccosh, 0.0, 0.0, 1.0, 0.0),
5999 TEST_c_c (ccosh, minus_zero, 0.0, 1.0, minus_zero),
6000 TEST_c_c (ccosh, 0.0, minus_zero, 1.0, minus_zero),
6001 TEST_c_c (ccosh, minus_zero, minus_zero, 1.0, 0.0),
6002
6003 TEST_c_c (ccosh, 0.0, plus_infty, qnan_value, 0.0, INVALID_EXCEPTION|IGNORE_ZERO_INF_SIGN),
6004 TEST_c_c (ccosh, minus_zero, plus_infty, qnan_value, 0.0, INVALID_EXCEPTION|IGNORE_ZERO_INF_SIGN),
6005 TEST_c_c (ccosh, 0.0, minus_infty, qnan_value, 0.0, INVALID_EXCEPTION|IGNORE_ZERO_INF_SIGN),
6006 TEST_c_c (ccosh, minus_zero, minus_infty, qnan_value, 0.0, INVALID_EXCEPTION|IGNORE_ZERO_INF_SIGN),
6007
6008 TEST_c_c (ccosh, plus_infty, 0.0, plus_infty, 0.0),
6009 TEST_c_c (ccosh, minus_infty, 0.0, plus_infty, minus_zero),
6010 TEST_c_c (ccosh, plus_infty, minus_zero, plus_infty, minus_zero),
6011 TEST_c_c (ccosh, minus_infty, minus_zero, plus_infty, 0.0),
6012
6013 TEST_c_c (ccosh, plus_infty, plus_infty, plus_infty, qnan_value, INVALID_EXCEPTION),
6014 TEST_c_c (ccosh, minus_infty, plus_infty, plus_infty, qnan_value, INVALID_EXCEPTION),
6015 TEST_c_c (ccosh, plus_infty, minus_infty, plus_infty, qnan_value, INVALID_EXCEPTION),
6016 TEST_c_c (ccosh, minus_infty, minus_infty, plus_infty, qnan_value, INVALID_EXCEPTION),
6017
6018 TEST_c_c (ccosh, plus_infty, 4.625, minus_infty, minus_infty),
6019 TEST_c_c (ccosh, minus_infty, 4.625, minus_infty, plus_infty),
6020 TEST_c_c (ccosh, plus_infty, -4.625, minus_infty, plus_infty),
6021 TEST_c_c (ccosh, minus_infty, -4.625, minus_infty, minus_infty),
6022
6023 TEST_c_c (ccosh, 6.75, plus_infty, qnan_value, qnan_value, INVALID_EXCEPTION),
6024 TEST_c_c (ccosh, -6.75, plus_infty, qnan_value, qnan_value, INVALID_EXCEPTION),
6025 TEST_c_c (ccosh, 6.75, minus_infty, qnan_value, qnan_value, INVALID_EXCEPTION),
6026 TEST_c_c (ccosh, -6.75, minus_infty, qnan_value, qnan_value, INVALID_EXCEPTION),
6027
6028 TEST_c_c (ccosh, 0.0, qnan_value, qnan_value, 0.0, IGNORE_ZERO_INF_SIGN),
6029 TEST_c_c (ccosh, minus_zero, qnan_value, qnan_value, 0.0, IGNORE_ZERO_INF_SIGN),
6030
6031 TEST_c_c (ccosh, plus_infty, qnan_value, plus_infty, qnan_value),
6032 TEST_c_c (ccosh, minus_infty, qnan_value, plus_infty, qnan_value),
6033
6034 TEST_c_c (ccosh, 9.0, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
6035 TEST_c_c (ccosh, -9.0, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
6036
6037 TEST_c_c (ccosh, qnan_value, 0.0, qnan_value, 0.0, IGNORE_ZERO_INF_SIGN),
6038 TEST_c_c (ccosh, qnan_value, minus_zero, qnan_value, 0.0, IGNORE_ZERO_INF_SIGN),
6039
6040 TEST_c_c (ccosh, qnan_value, 10.0, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
6041 TEST_c_c (ccosh, qnan_value, -10.0, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
6042
6043 TEST_c_c (ccosh, qnan_value, plus_infty, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
6044 TEST_c_c (ccosh, qnan_value, minus_infty, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
6045
6046 TEST_c_c (ccosh, qnan_value, qnan_value, qnan_value, qnan_value),
6047
6048 TEST_c_c (ccosh, 0.75L, 1.25L, 0.408242591877968807788852146397499084L, 0.780365930845853240391326216300863152L),
6049
6050 TEST_c_c (ccosh, -2, -3, -3.72454550491532256547397070325597253L, 0.511822569987384608834463849801875634L),
6051
6052 TEST_c_c (ccosh, 89.5, 0.75, 2.708024460708609732016532185663087200560e38L, 2.522786001038096774676288412995370563339e38L),
6053 TEST_c_c (ccosh, -89.5, 0.75, 2.708024460708609732016532185663087200560e38L, -2.522786001038096774676288412995370563339e38L),
6054 TEST_c_c (ccosh, 89.5, -0.75, 2.708024460708609732016532185663087200560e38L, -2.522786001038096774676288412995370563339e38L),
6055 TEST_c_c (ccosh, -89.5, -0.75, 2.708024460708609732016532185663087200560e38L, 2.522786001038096774676288412995370563339e38L),
6056
6057 #ifndef TEST_FLOAT
6058 TEST_c_c (ccosh, 710.5, 0.75, 1.347490911916428129246890157395342279438e308L, 1.255317763348154410745082950806112487736e308L),
6059 TEST_c_c (ccosh, -710.5, 0.75, 1.347490911916428129246890157395342279438e308L, -1.255317763348154410745082950806112487736e308L),
6060 TEST_c_c (ccosh, 710.5, -0.75, 1.347490911916428129246890157395342279438e308L, -1.255317763348154410745082950806112487736e308L),
6061 TEST_c_c (ccosh, -710.5, -0.75, 1.347490911916428129246890157395342279438e308L, 1.255317763348154410745082950806112487736e308L),
6062 #endif
6063
6064 #if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
6065 TEST_c_c (ccosh, 11357.25, 0.75, 9.001213196851067077465606717616495588201e4931L, 8.385498349388321535962327491346664141020e4931L),
6066 TEST_c_c (ccosh, -11357.25, 0.75, 9.001213196851067077465606717616495588201e4931L, -8.385498349388321535962327491346664141020e4931L),
6067 TEST_c_c (ccosh, 11357.25, -0.75, 9.001213196851067077465606717616495588201e4931L, -8.385498349388321535962327491346664141020e4931L),
6068 TEST_c_c (ccosh, -11357.25, -0.75, 9.001213196851067077465606717616495588201e4931L, 8.385498349388321535962327491346664141020e4931L),
6069 #endif
6070
6071 #ifdef TEST_FLOAT
6072 TEST_c_c (ccosh, 180, 0x1p-149, plus_infty, 1.043535896672617552965983803453927655332e33L, OVERFLOW_EXCEPTION),
6073 #endif
6074
6075 #if defined TEST_DOUBLE || (defined TEST_LDOUBLE && LDBL_MAX_EXP == 1024)
6076 TEST_c_c (ccosh, 1440, 0x1p-1074, plus_infty, 5.981479269486130556466515778180916082415e301L, OVERFLOW_EXCEPTION),
6077 #endif
6078
6079 #if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
6080 TEST_c_c (ccosh, 22730, 0x1p-16434L, plus_infty, 1.217853148905605987081057582351152052687e4924L, OVERFLOW_EXCEPTION),
6081 #endif
6082
6083 TEST_c_c (ccosh, min_subnorm_value * 0x1p120, 0x1p-120, 1.0, min_subnorm_value, UNDERFLOW_EXCEPTION),
6084 TEST_c_c (ccosh, 0x1p-120, min_subnorm_value * 0x1p120, 1.0, min_subnorm_value, UNDERFLOW_EXCEPTION),
6085 END_DATA (ccosh)
6086 };
6087
6088 static void
6089 ccosh_test (void)
6090 {
6091 errno = 0;
6092 FUNC(ccosh) (BUILD_COMPLEX (0.7L, 1.2L));
6093 if (errno == ENOSYS)
6094 /* Function not implemented. */
6095 return;
6096
6097 START (ccosh);
6098 RUN_TEST_LOOP_c_c (ccosh, ccosh_test_data, );
6099 END (ccosh, complex);
6100 }
6101
6102
6103 static const struct test_f_f_data ceil_test_data[] =
6104 {
6105 START_DATA (ceil),
6106 TEST_f_f (ceil, 0.0, 0.0),
6107 TEST_f_f (ceil, minus_zero, minus_zero),
6108 TEST_f_f (ceil, plus_infty, plus_infty),
6109 TEST_f_f (ceil, minus_infty, minus_infty),
6110 TEST_f_f (ceil, qnan_value, qnan_value),
6111
6112 TEST_f_f (ceil, M_PIl, 4.0),
6113 TEST_f_f (ceil, -M_PIl, -3.0),
6114 TEST_f_f (ceil, 0.1, 1.0),
6115 TEST_f_f (ceil, 0.25, 1.0),
6116 TEST_f_f (ceil, 0.625, 1.0),
6117 TEST_f_f (ceil, -0.1, minus_zero),
6118 TEST_f_f (ceil, -0.25, minus_zero),
6119 TEST_f_f (ceil, -0.625, minus_zero),
6120
6121 #ifdef TEST_LDOUBLE
6122 /* The result can only be represented in long double. */
6123 TEST_f_f (ceil, 4503599627370495.5L, 4503599627370496.0L),
6124 TEST_f_f (ceil, 4503599627370496.25L, 4503599627370497.0L),
6125 TEST_f_f (ceil, 4503599627370496.5L, 4503599627370497.0L),
6126 TEST_f_f (ceil, 4503599627370496.75L, 4503599627370497.0L),
6127 TEST_f_f (ceil, 4503599627370497.5L, 4503599627370498.0L),
6128
6129 TEST_f_f (ceil, -4503599627370495.5L, -4503599627370495.0L),
6130 TEST_f_f (ceil, -4503599627370496.25L, -4503599627370496.0L),
6131 TEST_f_f (ceil, -4503599627370496.5L, -4503599627370496.0L),
6132 TEST_f_f (ceil, -4503599627370496.75L, -4503599627370496.0L),
6133 TEST_f_f (ceil, -4503599627370497.5L, -4503599627370497.0L),
6134
6135 # if LDBL_MANT_DIG > 100
6136 TEST_f_f (ceil, 4503599627370494.5000000000001L, 4503599627370495.0L),
6137 TEST_f_f (ceil, 4503599627370495.5000000000001L, 4503599627370496.0L),
6138 TEST_f_f (ceil, 4503599627370496.5000000000001L, 4503599627370497.0L),
6139 TEST_f_f (ceil, -4503599627370494.5000000000001L, -4503599627370494.0L),
6140 TEST_f_f (ceil, -4503599627370495.5000000000001L, -4503599627370495.0L),
6141 TEST_f_f (ceil, -4503599627370496.5000000000001L, -4503599627370496.0L),
6142 # endif
6143
6144 TEST_f_f (ceil, 9007199254740991.5L, 9007199254740992.0L),
6145 TEST_f_f (ceil, 9007199254740992.25L, 9007199254740993.0L),
6146 TEST_f_f (ceil, 9007199254740992.5L, 9007199254740993.0L),
6147 TEST_f_f (ceil, 9007199254740992.75L, 9007199254740993.0L),
6148 TEST_f_f (ceil, 9007199254740993.5L, 9007199254740994.0L),
6149
6150 TEST_f_f (ceil, -9007199254740991.5L, -9007199254740991.0L),
6151 TEST_f_f (ceil, -9007199254740992.25L, -9007199254740992.0L),
6152 TEST_f_f (ceil, -9007199254740992.5L, -9007199254740992.0L),
6153 TEST_f_f (ceil, -9007199254740992.75L, -9007199254740992.0L),
6154 TEST_f_f (ceil, -9007199254740993.5L, -9007199254740993.0L),
6155
6156 # if LDBL_MANT_DIG > 100
6157 TEST_f_f (ceil, 9007199254740991.0000000000001L, 9007199254740992.0L),
6158 TEST_f_f (ceil, 9007199254740992.0000000000001L, 9007199254740993.0L),
6159 TEST_f_f (ceil, 9007199254740993.0000000000001L, 9007199254740994.0L),
6160 TEST_f_f (ceil, 9007199254740991.5000000000001L, 9007199254740992.0L),
6161 TEST_f_f (ceil, 9007199254740992.5000000000001L, 9007199254740993.0L),
6162 TEST_f_f (ceil, 9007199254740993.5000000000001L, 9007199254740994.0L),
6163
6164 TEST_f_f (ceil, -9007199254740991.0000000000001L, -9007199254740991.0L),
6165 TEST_f_f (ceil, -9007199254740992.0000000000001L, -9007199254740992.0L),
6166 TEST_f_f (ceil, -9007199254740993.0000000000001L, -9007199254740993.0L),
6167 TEST_f_f (ceil, -9007199254740991.5000000000001L, -9007199254740991.0L),
6168 TEST_f_f (ceil, -9007199254740992.5000000000001L, -9007199254740992.0L),
6169 TEST_f_f (ceil, -9007199254740993.5000000000001L, -9007199254740993.0L),
6170 # endif
6171
6172 TEST_f_f (ceil, 72057594037927935.5L, 72057594037927936.0L),
6173 TEST_f_f (ceil, 72057594037927936.25L, 72057594037927937.0L),
6174 TEST_f_f (ceil, 72057594037927936.5L, 72057594037927937.0L),
6175 TEST_f_f (ceil, 72057594037927936.75L, 72057594037927937.0L),
6176 TEST_f_f (ceil, 72057594037927937.5L, 72057594037927938.0L),
6177
6178 TEST_f_f (ceil, -72057594037927935.5L, -72057594037927935.0L),
6179 TEST_f_f (ceil, -72057594037927936.25L, -72057594037927936.0L),
6180 TEST_f_f (ceil, -72057594037927936.5L, -72057594037927936.0L),
6181 TEST_f_f (ceil, -72057594037927936.75L, -72057594037927936.0L),
6182 TEST_f_f (ceil, -72057594037927937.5L, -72057594037927937.0L),
6183
6184 TEST_f_f (ceil, 10141204801825835211973625643007.5L, 10141204801825835211973625643008.0L),
6185 TEST_f_f (ceil, 10141204801825835211973625643008.25L, 10141204801825835211973625643009.0L),
6186 TEST_f_f (ceil, 10141204801825835211973625643008.5L, 10141204801825835211973625643009.0L),
6187 TEST_f_f (ceil, 10141204801825835211973625643008.75L, 10141204801825835211973625643009.0L),
6188 TEST_f_f (ceil, 10141204801825835211973625643009.5L, 10141204801825835211973625643010.0L),
6189 #endif
6190 END_DATA (ceil)
6191 };
6192
6193 static void
6194 ceil_test (void)
6195 {
6196 START (ceil);
6197 RUN_TEST_LOOP_f_f (ceil, ceil_test_data, );
6198 END (ceil);
6199 }
6200
6201
6202 static const struct test_c_c_data cexp_test_data[] =
6203 {
6204 START_DATA (cexp),
6205 TEST_c_c (cexp, plus_zero, plus_zero, 1, 0.0),
6206 TEST_c_c (cexp, minus_zero, plus_zero, 1, 0.0),
6207 TEST_c_c (cexp, plus_zero, minus_zero, 1, minus_zero),
6208 TEST_c_c (cexp, minus_zero, minus_zero, 1, minus_zero),
6209
6210 TEST_c_c (cexp, plus_infty, plus_zero, plus_infty, 0.0),
6211 TEST_c_c (cexp, plus_infty, minus_zero, plus_infty, minus_zero),
6212
6213 TEST_c_c (cexp, minus_infty, plus_zero, 0.0, 0.0),
6214 TEST_c_c (cexp, minus_infty, minus_zero, 0.0, minus_zero),
6215
6216 TEST_c_c (cexp, 0.0, plus_infty, qnan_value, qnan_value, INVALID_EXCEPTION),
6217 TEST_c_c (cexp, minus_zero, plus_infty, qnan_value, qnan_value, INVALID_EXCEPTION),
6218
6219 TEST_c_c (cexp, 0.0, minus_infty, qnan_value, qnan_value, INVALID_EXCEPTION),
6220 TEST_c_c (cexp, minus_zero, minus_infty, qnan_value, qnan_value, INVALID_EXCEPTION),
6221
6222 TEST_c_c (cexp, 100.0, plus_infty, qnan_value, qnan_value, INVALID_EXCEPTION),
6223 TEST_c_c (cexp, -100.0, plus_infty, qnan_value, qnan_value, INVALID_EXCEPTION),
6224
6225 TEST_c_c (cexp, 100.0, minus_infty, qnan_value, qnan_value, INVALID_EXCEPTION),
6226 TEST_c_c (cexp, -100.0, minus_infty, qnan_value, qnan_value, INVALID_EXCEPTION),
6227
6228 TEST_c_c (cexp, minus_infty, 2.0, minus_zero, 0.0),
6229 TEST_c_c (cexp, minus_infty, 4.0, minus_zero, minus_zero),
6230 TEST_c_c (cexp, plus_infty, 2.0, minus_infty, plus_infty),
6231 TEST_c_c (cexp, plus_infty, 4.0, minus_infty, minus_infty),
6232
6233 TEST_c_c (cexp, plus_infty, plus_infty, plus_infty, qnan_value, INVALID_EXCEPTION|IGNORE_ZERO_INF_SIGN),
6234 TEST_c_c (cexp, plus_infty, minus_infty, plus_infty, qnan_value, INVALID_EXCEPTION|IGNORE_ZERO_INF_SIGN),
6235
6236 TEST_c_c (cexp, minus_infty, plus_infty, 0.0, 0.0, IGNORE_ZERO_INF_SIGN),
6237 TEST_c_c (cexp, minus_infty, minus_infty, 0.0, minus_zero, IGNORE_ZERO_INF_SIGN),
6238
6239 TEST_c_c (cexp, minus_infty, qnan_value, 0, 0, IGNORE_ZERO_INF_SIGN),
6240
6241 TEST_c_c (cexp, plus_infty, qnan_value, plus_infty, qnan_value),
6242
6243 TEST_c_c (cexp, qnan_value, 0.0, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
6244 TEST_c_c (cexp, qnan_value, 1.0, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
6245
6246 TEST_c_c (cexp, qnan_value, plus_infty, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
6247 TEST_c_c (cexp, 0, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
6248 TEST_c_c (cexp, 1, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
6249 TEST_c_c (cexp, qnan_value, qnan_value, qnan_value, qnan_value),
6250
6251 TEST_c_c (cexp, 0.75L, 1.25L, 0.667537446429131586942201977015932112L, 2.00900045494094876258347228145863909L),
6252 TEST_c_c (cexp, -2.0, -3.0, -0.13398091492954261346140525546115575L, -0.019098516261135196432576240858800925L),
6253
6254 TEST_c_c (cexp, 0, 0x1p65, 0.99888622066058013610642172179340364209972L, -0.047183876212354673805106149805700013943218L),
6255 TEST_c_c (cexp, 0, -0x1p65, 0.99888622066058013610642172179340364209972L, 0.047183876212354673805106149805700013943218L),
6256 TEST_c_c (cexp, 50, 0x1p127, 4.053997150228616856622417636046265337193e21L, 3.232070315463388524466674772633810238819e21L),
6257
6258 #ifndef TEST_FLOAT
6259 TEST_c_c (cexp, 0, 1e22, 0.5232147853951389454975944733847094921409L, -0.8522008497671888017727058937530293682618L),
6260 TEST_c_c (cexp, 0, 0x1p1023, -0.826369834614147994500785680811743734805L, 0.5631277798508840134529434079444683477104L),
6261 TEST_c_c (cexp, 500, 0x1p1023, -1.159886268932754433233243794561351783426e217L, 7.904017694554466595359379965081774849708e216L),
6262 #endif
6263
6264 #if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
6265 TEST_c_c (cexp, 0, 0x1p16383L, 0.9210843909921906206874509522505756251609L, 0.3893629985894208126948115852610595405563L),
6266 TEST_c_c (cexp, -10000, 0x1p16383L, 1.045876464564882298442774542991176546722e-4343L, 4.421154026488516836023811173959413420548e-4344L),
6267 #endif
6268
6269 TEST_c_c (cexp, 88.75, 0.75, 2.558360358486542817001900410314204322891e38L, 2.383359453227311447654736314679677655100e38L),
6270 TEST_c_c (cexp, -95, 0.75, 4.039714446238306526889476684000081624047e-42L, 3.763383677300535390271646960780570275931e-42L, UNDERFLOW_EXCEPTION_FLOAT),
6271
6272 #ifndef TEST_FLOAT
6273 TEST_c_c (cexp, 709.8125, 0.75, 1.355121963080879535248452862759108365762e308L, 1.262426823598609432507811340856186873507e308L),
6274 TEST_c_c (cexp, -720, 0.75, 1.486960657116368433685753325516638551722e-313L, 1.385247284245720590980701226843815229385e-313L, UNDERFLOW_EXCEPTION_DOUBLE),
6275 #endif
6276
6277 #if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
6278 TEST_c_c (cexp, 11356.5625, 0.75, 9.052188470850960144814815984311663764287e4931L, 8.432986734191301036267148978260970230200e4931L),
6279 TEST_c_c (cexp, -11370, 0.75, 8.631121063182211587489310508568170739592e-4939L, 8.040721827809267291427062346918413482824e-4939L, UNDERFLOW_EXCEPTION),
6280 #endif
6281
6282 #ifdef TEST_FLOAT
6283 TEST_c_c (cexp, 180, 0x1p-149, plus_infty, 2.087071793345235105931967606907855310664e33L, OVERFLOW_EXCEPTION),
6284 #endif
6285
6286 #if defined TEST_DOUBLE || (defined TEST_LDOUBLE && LDBL_MAX_EXP == 1024)
6287 TEST_c_c (cexp, 1440, 0x1p-1074, plus_infty, 1.196295853897226111293303155636183216483e302L, OVERFLOW_EXCEPTION),
6288 #endif
6289
6290 #if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
6291 TEST_c_c (cexp, 22730, 0x1p-16434L, plus_infty, 2.435706297811211974162115164702304105374e4924L, OVERFLOW_EXCEPTION),
6292 #endif
6293
6294 TEST_c_c (cexp, 1e6, 0, plus_infty, 0, OVERFLOW_EXCEPTION),
6295 TEST_c_c (cexp, 1e6, min_value, plus_infty, plus_infty, OVERFLOW_EXCEPTION),
6296 TEST_c_c (cexp, 1e6, -min_value, plus_infty, minus_infty, OVERFLOW_EXCEPTION),
6297
6298 TEST_c_c (cexp, min_value, min_subnorm_value, 1.0, min_subnorm_value, UNDERFLOW_EXCEPTION),
6299 TEST_c_c (cexp, min_value, -min_subnorm_value, 1.0, -min_subnorm_value, UNDERFLOW_EXCEPTION),
6300 END_DATA (cexp)
6301 };
6302
6303 static void
6304 cexp_test (void)
6305 {
6306 errno = 0;
6307 FUNC(cexp) (BUILD_COMPLEX (0, 0));
6308 if (errno == ENOSYS)
6309 /* Function not implemented. */
6310 return;
6311
6312 START (cexp);
6313 RUN_TEST_LOOP_c_c (cexp, cexp_test_data, );
6314 END (cexp, complex);
6315 }
6316
6317
6318 static const struct test_c_f_data cimag_test_data[] =
6319 {
6320 START_DATA (cimag);
6321 TEST_c_f (cimag, 1.0, 0.0, 0.0),
6322 TEST_c_f (cimag, 1.0, minus_zero, minus_zero),
6323 TEST_c_f (cimag, 1.0, qnan_value, qnan_value),
6324 TEST_c_f (cimag, qnan_value, qnan_value, qnan_value),
6325 TEST_c_f (cimag, 1.0, plus_infty, plus_infty),
6326 TEST_c_f (cimag, 1.0, minus_infty, minus_infty),
6327 TEST_c_f (cimag, 2.0, 3.0, 3.0),
6328 END_DATA (cimag);
6329 };
6330
6331 static void
6332 cimag_test (void)
6333 {
6334 START (cimag);
6335 RUN_TEST_LOOP_c_f (cimag, cimag_test_data, );
6336 END (cimag);
6337 }
6338
6339 static const struct test_c_c_data clog_test_data[] =
6340 {
6341 START_DATA (clog),
6342 TEST_c_c (clog, minus_zero, 0, minus_infty, M_PIl, DIVIDE_BY_ZERO_EXCEPTION),
6343 TEST_c_c (clog, minus_zero, minus_zero, minus_infty, -M_PIl, DIVIDE_BY_ZERO_EXCEPTION),
6344
6345 TEST_c_c (clog, 0, 0, minus_infty, 0.0, DIVIDE_BY_ZERO_EXCEPTION),
6346 TEST_c_c (clog, 0, minus_zero, minus_infty, minus_zero, DIVIDE_BY_ZERO_EXCEPTION),
6347
6348 TEST_c_c (clog, minus_infty, plus_infty, plus_infty, M_PI_34l),
6349 TEST_c_c (clog, minus_infty, minus_infty, plus_infty, -M_PI_34l),
6350
6351 TEST_c_c (clog, plus_infty, plus_infty, plus_infty, M_PI_4l),
6352 TEST_c_c (clog, plus_infty, minus_infty, plus_infty, -M_PI_4l),
6353
6354 TEST_c_c (clog, 0, plus_infty, plus_infty, M_PI_2l),
6355 TEST_c_c (clog, 3, plus_infty, plus_infty, M_PI_2l),
6356 TEST_c_c (clog, minus_zero, plus_infty, plus_infty, M_PI_2l),
6357 TEST_c_c (clog, -3, plus_infty, plus_infty, M_PI_2l),
6358 TEST_c_c (clog, 0, minus_infty, plus_infty, -M_PI_2l),
6359 TEST_c_c (clog, 3, minus_infty, plus_infty, -M_PI_2l),
6360 TEST_c_c (clog, minus_zero, minus_infty, plus_infty, -M_PI_2l),
6361 TEST_c_c (clog, -3, minus_infty, plus_infty, -M_PI_2l),
6362
6363 TEST_c_c (clog, minus_infty, 0, plus_infty, M_PIl),
6364 TEST_c_c (clog, minus_infty, 1, plus_infty, M_PIl),
6365 TEST_c_c (clog, minus_infty, minus_zero, plus_infty, -M_PIl),
6366 TEST_c_c (clog, minus_infty, -1, plus_infty, -M_PIl),
6367
6368 TEST_c_c (clog, plus_infty, 0, plus_infty, 0.0),
6369 TEST_c_c (clog, plus_infty, 1, plus_infty, 0.0),
6370 TEST_c_c (clog, plus_infty, minus_zero, plus_infty, minus_zero),
6371 TEST_c_c (clog, plus_infty, -1, plus_infty, minus_zero),
6372
6373 TEST_c_c (clog, plus_infty, qnan_value, plus_infty, qnan_value),
6374 TEST_c_c (clog, minus_infty, qnan_value, plus_infty, qnan_value),
6375
6376 TEST_c_c (clog, qnan_value, plus_infty, plus_infty, qnan_value),
6377 TEST_c_c (clog, qnan_value, minus_infty, plus_infty, qnan_value),
6378
6379 TEST_c_c (clog, 0, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
6380 TEST_c_c (clog, 3, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
6381 TEST_c_c (clog, minus_zero, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
6382 TEST_c_c (clog, -3, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
6383
6384 TEST_c_c (clog, qnan_value, 0, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
6385 TEST_c_c (clog, qnan_value, 5, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
6386 TEST_c_c (clog, qnan_value, minus_zero, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
6387 TEST_c_c (clog, qnan_value, -5, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
6388
6389 TEST_c_c (clog, qnan_value, qnan_value, qnan_value, qnan_value),
6390
6391 TEST_c_c (clog, 0.75L, 1.25L, 0.376885901188190075998919126749298416L, 1.03037682652431246378774332703115153L),
6392 TEST_c_c (clog, -2, -3, 1.2824746787307683680267437207826593L, -2.1587989303424641704769327722648368L),
6393
6394 TEST_c_c (clog, 0x1.fffffep+127L, 0x1.fffffep+127L, 89.06941264234832570836679262104313101776L, M_PI_4l),
6395 TEST_c_c (clog, 0x1.fffffep+127L, 1.0L, 88.72283905206835305365817656031404273372L, 2.938736052218037251011746307725933020145e-39L, UNDERFLOW_EXCEPTION_FLOAT),
6396 TEST_c_c (clog, 0x1p-149L, 0x1p-149L, -102.9323563131518784484589700365392203592L, M_PI_4l),
6397 TEST_c_c (clog, 0x1p-147L, 0x1p-147L, -101.5460619520319878296245057936228672231L, M_PI_4l),
6398
6399 #ifndef TEST_FLOAT
6400 TEST_c_c (clog, 0x1.fffffffffffffp+1023L, 0x1.fffffffffffffp+1023L, 710.1292864836639693869320059713862337880L, M_PI_4l),
6401 TEST_c_c (clog, 0x1.fffffffffffffp+1023L, 0x1p+1023L, 709.8942846690411016323109979483151967689L, 0.4636476090008061606231772164674799632783L),
6402 TEST_c_c (clog, 0x1p-1074L, 0x1p-1074L, -744.0934983311012896593986823853525458290L, M_PI_4l),
6403 TEST_c_c (clog, 0x1p-1073L, 0x1p-1073L, -743.4003511505413443499814502638943692610L, M_PI_4l),
6404 #endif
6405
6406 #if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
6407 TEST_c_c (clog, 0x1.fp+16383L, 0x1.fp+16383L, 11356.83823118610934184548269774874545400L, M_PI_4l),
6408 TEST_c_c (clog, 0x1.fp+16383L, 0x1p+16383L, 11356.60974243783798653123798337822335902L, 0.4764674194737066993385333770295162295856L),
6409 TEST_c_c (clog, 0x1p-16440L, 0x1p-16441L, -11395.22807662984378194141292922726786191L, 0.4636476090008061162142562314612144020285L),
6410 #endif
6411
6412 TEST_c_c (clog, 0x1p-149L, 0x1.fp+127L, 88.69109041335841930424871526389807508374L, M_PI_2l),
6413 TEST_c_c (clog, -0x1p-149L, 0x1.fp+127L, 88.69109041335841930424871526389807508374L, M_PI_2l),
6414 TEST_c_c (clog, 0x1p-149L, -0x1.fp+127L, 88.69109041335841930424871526389807508374L, -M_PI_2l),
6415 TEST_c_c (clog, -0x1p-149L, -0x1.fp+127L, 88.69109041335841930424871526389807508374L, -M_PI_2l),
6416 TEST_c_c (clog, -0x1.fp+127L, 0x1p-149L, 88.69109041335841930424871526389807508374L, M_PIl),
6417 TEST_c_c (clog, -0x1.fp+127L, -0x1p-149L, 88.69109041335841930424871526389807508374L, -M_PIl),
6418 #ifdef TEST_FLOAT
6419 TEST_c_c (clog, 0x1.fp+127L, 0x1p-149L, 88.69109041335841930424871526389807508374L, plus_zero, UNDERFLOW_EXCEPTION),
6420 TEST_c_c (clog, 0x1.fp+127L, -0x1p-149L, 88.69109041335841930424871526389807508374L, minus_zero, UNDERFLOW_EXCEPTION),
6421 #endif
6422
6423 #ifndef TEST_FLOAT
6424 TEST_c_c (clog, 0x1p-1074L, 0x1.fp+1023L, 709.7509641950694165420886960904242800794L, M_PI_2l),
6425 TEST_c_c (clog, -0x1p-1074L, 0x1.fp+1023L, 709.7509641950694165420886960904242800794L, M_PI_2l),
6426 TEST_c_c (clog, 0x1p-1074L, -0x1.fp+1023L, 709.7509641950694165420886960904242800794L, -M_PI_2l),
6427 TEST_c_c (clog, -0x1p-1074L, -0x1.fp+1023L, 709.7509641950694165420886960904242800794L, -M_PI_2l),
6428 TEST_c_c (clog, -0x1.fp+1023L, 0x1p-1074L, 709.7509641950694165420886960904242800794L, M_PIl),
6429 TEST_c_c (clog, -0x1.fp+1023L, -0x1p-1074L, 709.7509641950694165420886960904242800794L, -M_PIl),
6430 #endif
6431 #if defined TEST_DOUBLE || (defined TEST_LDOUBLE && LDBL_MAX_EXP == 1024)
6432 TEST_c_c (clog, 0x1.fp+1023L, 0x1p-1074L, 709.7509641950694165420886960904242800794L, plus_zero, UNDERFLOW_EXCEPTION),
6433 TEST_c_c (clog, 0x1.fp+1023L, -0x1p-1074L, 709.7509641950694165420886960904242800794L, minus_zero, UNDERFLOW_EXCEPTION),
6434 #endif
6435
6436 #if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
6437 TEST_c_c (clog, 0x1p-16445L, 0x1.fp+16383L, 11356.49165759582936919077408168801636572L, M_PI_2l),
6438 TEST_c_c (clog, -0x1p-16445L, 0x1.fp+16383L, 11356.49165759582936919077408168801636572L, M_PI_2l),
6439 TEST_c_c (clog, 0x1p-16445L, -0x1.fp+16383L, 11356.49165759582936919077408168801636572L, -M_PI_2l),
6440 TEST_c_c (clog, -0x1p-16445L, -0x1.fp+16383L, 11356.49165759582936919077408168801636572L, -M_PI_2l),
6441 TEST_c_c (clog, -0x1.fp+16383L, 0x1p-16445L, 11356.49165759582936919077408168801636572L, M_PIl),
6442 TEST_c_c (clog, -0x1.fp+16383L, -0x1p-16445L, 11356.49165759582936919077408168801636572L, -M_PIl),
6443 TEST_c_c (clog, 0x1.fp+16383L, 0x1p-16445L, 11356.49165759582936919077408168801636572L, plus_zero, UNDERFLOW_EXCEPTION),
6444 TEST_c_c (clog, 0x1.fp+16383L, -0x1p-16445L, 11356.49165759582936919077408168801636572L, minus_zero, UNDERFLOW_EXCEPTION),
6445 # if LDBL_MANT_DIG >= 113
6446 TEST_c_c (clog, 0x1p-16494L, 0x1.fp+16383L, 11356.49165759582936919077408168801636572L, M_PI_2l),
6447 TEST_c_c (clog, -0x1p-16494L, 0x1.fp+16383L, 11356.49165759582936919077408168801636572L, M_PI_2l),
6448 TEST_c_c (clog, 0x1p-16494L, -0x1.fp+16383L, 11356.49165759582936919077408168801636572L, -M_PI_2l),
6449 TEST_c_c (clog, -0x1p-16494L, -0x1.fp+16383L, 11356.49165759582936919077408168801636572L, -M_PI_2l),
6450 TEST_c_c (clog, -0x1.fp+16383L, 0x1p-16494L, 11356.49165759582936919077408168801636572L, M_PIl),
6451 TEST_c_c (clog, -0x1.fp+16383L, -0x1p-16494L, 11356.49165759582936919077408168801636572L, -M_PIl),
6452 TEST_c_c (clog, 0x1.fp+16383L, 0x1p-16494L, 11356.49165759582936919077408168801636572L, plus_zero, UNDERFLOW_EXCEPTION),
6453 TEST_c_c (clog, 0x1.fp+16383L, -0x1p-16494L, 11356.49165759582936919077408168801636572L, minus_zero, UNDERFLOW_EXCEPTION),
6454 # endif
6455 #endif
6456
6457 TEST_c_c (clog, 1.0L, 0x1.234566p-10L, 6.172834701221959432440126967147726538097e-7L, 1.111110564353742042376451655136933182201e-3L),
6458 TEST_c_c (clog, -1.0L, 0x1.234566p-20L, 5.886877547844618300918562490463748605537e-13L, 3.141591568520436206990380699322226378452L),
6459 TEST_c_c (clog, 0x1.234566p-30L, 1.0L, 5.614163921211322622623353961365728040115e-19L, 1.570796325735258575254858696548386439740L),
6460 TEST_c_c (clog, -0x1.234566p-40L, -1.0L, 5.354083939753840089583620652120903838944e-25L, -1.570796326795931422008642456283782656359L),
6461 TEST_c_c (clog, 0x1.234566p-50L, 1.0L, 5.106052341226425256332038420428899201070e-31L, 1.570796326794895608681734464330528755366L),
6462 TEST_c_c (clog, 0x1.234566p-60L, 1.0L, 4.869510976053643471080816669875627875933e-37L, 1.570796326794896618244456860363082279319L),
6463 TEST_c_c (clog, 0x1p-62L, 1.0L, 2.350988701644575015937473074444491355582e-38L, 1.570796326794896619014481257142650555297L),
6464 TEST_c_c (clog, 0x1p-63L, 1.0L, 5.877471754111437539843682686111228389059e-39L, 1.570796326794896619122901474391200998698L, UNDERFLOW_EXCEPTION_FLOAT),
6465 TEST_c_c (clog, 0x1p-64L, 1.0L, 1.469367938527859384960920671527807097271e-39L, 1.570796326794896619177111583015476220398L, UNDERFLOW_EXCEPTION_FLOAT),
6466 #ifndef TEST_FLOAT
6467 TEST_c_c (clog, 0x1p-510L, 1.0L, 4.450147717014402766180465434664808128438e-308L, 1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
6468 TEST_c_c (clog, 0x1p-511L, 1.0L, 1.112536929253600691545116358666202032110e-308L, 1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION_DOUBLE),
6469 TEST_c_c (clog, 0x1p-512L, 1.0L, 2.781342323134001728862790896665505080274e-309L, 1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION_DOUBLE),
6470 #endif
6471 #if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
6472 TEST_c_c (clog, 0x1p-8190L, 1.0L, 6.724206286224187012525355634643505205196e-4932L, 1.570796326794896619231321691639751442099L),
6473 TEST_c_c (clog, 0x1p-8191L, 1.0L, 1.681051571556046753131338908660876301299e-4932L, 1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION),
6474 TEST_c_c (clog, 0x1p-8192L, 1.0L, 4.202628928890116882828347271652190753248e-4933L, 1.570796326794896619231321691639751442099L, UNDERFLOW_EXCEPTION),
6475 #endif
6476
6477 TEST_c_c (clog, 0x1.000566p0L, 0x1.234p-10L, 8.298731898331237038231468223024422855654e-5L, 1.110938609507128729312743251313024793990e-3L),
6478 TEST_c_c (clog, 0x1.000566p0L, 0x1.234p-100L, 8.237022655933121125560939513260027133767e-5L, 8.974094312218060110948251664314290484113e-31L),
6479 #ifndef TEST_FLOAT
6480 TEST_c_c (clog, -0x1.0000000123456p0L, 0x1.2345678p-30L, 2.649094282537168795982991778475646793277e-10L, 3.141592652530155111500161671113150737892L),
6481 TEST_c_c (clog, -0x1.0000000123456p0L, 0x1.2345678p-1000L, 2.649094276923003995420209214900915462737e-10L, 3.141592653589793238462643383279502884197L),
6482 #endif
6483 #if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 106
6484 TEST_c_c (clog, 0x1.00000000000000123456789abcp0L, 0x1.23456789p-60L, 9.868649107778739757272772275265050767867e-19L, 9.868649106423871142816660980898339912137e-19L),
6485 TEST_c_c (clog, 0x1.00000000000000123456789abcp0L, 0x1.23456789p-1000L, 9.868649107778739752403260515979017248596e-19L, 1.061846605795612822522063052130030717368e-301L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
6486 #endif
6487
6488 TEST_c_c (clog, 0x0.ffffffp0L, 0x0.ffffffp-100L, -5.960464655174753498633255797994360530379e-8L, 7.888609052210118054117285652827862296732e-31L),
6489 #ifndef TEST_FLOAT
6490 TEST_c_c (clog, 0x0.fffffffffffff8p0L, 0x0.fffffffffffff8p-1000L, -1.110223024625156602053389888482372171810e-16L, 9.332636185032188789900895447238171696171e-302L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
6491 #endif
6492 #if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
6493 TEST_c_c (clog, 0x0.ffffffffffffffffp0L, 0x0.ffffffffffffffffp-15000L, -5.421010862427522170184200798202494495630e-20L, 3.548665303440282824232502561095699343814e-4516L),
6494 #endif
6495
6496 TEST_c_c (clog, 0x1a6p-10L, 0x3a5p-10L, -1.4305135209763571252847059962654228661815e-06L, 1.1460277178115757370775644871674016684074L),
6497 TEST_c_c (clog, 0xf2p-10L, 0x3e3p-10L, 6.1988446308070710970664736815277450078106e-06L, 1.3322126499153926210226335249558203898460L),
6498 TEST_c_c (clog, 0x4d4ep-15L, 0x6605p-15L, -1.6298145321400412054744424587143483169412e-08L, 0.9223574537155056772124552172295398141249L),
6499 TEST_c_c (clog, 0x2818p-15L, 0x798fp-15L, 1.5366822245016167178749091974664853785194e-08L, 1.2522014929038946066987318471922169174157L),
6500 TEST_c_c (clog, 0x9b57bp-20L, 0xcb7b4p-20L, -3.9563019528687610863490232935890272740908e-11L, 0.9187593477446338910857133065497364950682L),
6501 TEST_c_c (clog, 0x2731p-20L, 0xfffd0p-20L, 4.4110493034041283943115971658295280288115e-11L, 1.5612279663766352262688735061954290528838L),
6502 TEST_c_c (clog, 0x2ede88p-23L, 0x771c3fp-23L, -4.4764192352906350039050902870893173560494e-13L, 1.1959106857549200806818600493552847793381L),
6503 TEST_c_c (clog, 0x11682p-23L, 0x7ffed1p-23L, 1.1723955140027907954461000991619077811832e-12L, 1.5622968405332756349813737986164832897108L),
6504 TEST_c_c (clog, 0xa1f2c1p-24L, 0xc643aep-24L, -1.0480505352462576151523512837107080269981e-13L, 0.8858771987699967480545613322309315260313L),
6505 TEST_c_c (clog, 0x659feap-24L, 0xeaf6f9p-24L, 3.7303493627403868207597214252239749960738e-14L, 1.1625816408046866464773042283673653469061L),
6506 #ifndef TEST_FLOAT
6507 TEST_c_c (clog, 0x4447d7175p-35L, 0x6c445e00ap-35L, -1.4823076576950255933915367361099865652625e-20L, 1.0081311552703893116404606212158840190615L),
6508 TEST_c_c (clog, 0x2dd46725bp-35L, 0x7783a1284p-35L, 4.4469229730850767799109418892826021157328e-20L, 1.2046235979300843056806465045930070146351L),
6509 TEST_c_c (clog, 0x164c74eea876p-45L, 0x16f393482f77p-45L, -3.0292258760486853327810377824479932031744e-26L, 0.7998237934177411746093524982030330293980L),
6510 TEST_c_c (clog, 0xfe961079616p-45L, 0x1bc37e09e6d1p-45L, 5.3718272201930019901317065495843842735179e-26L, 1.0503831592447830576186444373011142397404L),
6511 TEST_c_c (clog, 0xa4722f19346cp-51L, 0x7f9631c5e7f07p-51L, -6.2122796286154679676173624516405339768606e-30L, 1.4904138780720095276446375492434049214172L),
6512 TEST_c_c (clog, 0x10673dd0f2481p-51L, 0x7ef1d17cefbd2p-51L, 3.2047474274603604594851472963586149973093e-29L, 1.4422922682185099608731642353544207976604L),
6513 TEST_c_c (clog, 0x8ecbf810c4ae6p-52L, 0xd479468b09a37p-52L, -9.7375017988218644730510244778042114638107e-30L, 0.9790637929494922564724108399524154766631L),
6514 TEST_c_c (clog, 0x5b06b680ea2ccp-52L, 0xef452b965da9fp-52L, 8.3076914081087805757422664530653247447136e-30L, 1.2072712126771536614482822173033535043206L),
6515 TEST_c_c (clog, 0x659b70ab7971bp-53L, 0x1f5d111e08abecp-53L, -2.5083311595699359750201056724289010648701e-30L, 1.3710185432462268491534742969536240564640L),
6516 TEST_c_c (clog, 0x15cfbd1990d1ffp-53L, 0x176a3973e09a9ap-53L, 1.0168910106364605304135563536838075568606e-30L, 0.8208373755522359859870890246475340086663L),
6517 TEST_c_c (clog, 0x1367a310575591p-54L, 0x3cfcc0a0541f60p-54L, 5.0844550531823026520677817684239496041087e-32L, 1.2627468605458094918919206628466016525397L),
6518 TEST_c_c (clog, 0x55cb6d0c83af5p-55L, 0x7fe33c0c7c4e90p-55L, -5.2000108498455368032511404449795741611813e-32L, 1.5288921536982513453421343495466824420259L),
6519 #endif
6520 #if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 64
6521 TEST_c_c (clog, 0x298c62cb546588a7p-63L, 0x7911b1dfcc4ecdaep-63L, -1.1931267660846218205882675852805793644095e-36L, 1.2402109774337032400594953899784058127412L),
6522 TEST_c_c (clog, 0x4d9c37e2b5cb4533p-63L, 0x65c98be2385a042ep-63L, 6.4064442119814669184296141278612389400075e-37L, 0.9193591364645830864185131402313014890145L),
6523 TEST_c_c (clog, 0x602fd5037c4792efp-64L, 0xed3e2086dcca80b8p-64L, -2.3362950222592964220878638677292132852104e-37L, 1.1856121127236268105413184264288408265852L),
6524 TEST_c_c (clog, 0x6b10b4f3520217b6p-64L, 0xe8893cbb449253a1p-64L, 2.4244570985709679851855191080208817099132e-37L, 1.1393074519572050614551047548718495655972L),
6525 TEST_c_c (clog, 0x81b7efa81fc35ad1p-65L, 0x1ef4b835f1c79d812p-65L, -9.9182335850630508484862145328126979066934e-39L, 1.3146479888794807046338799047003947008804L),
6526 #endif
6527 #if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 106
6528 TEST_c_c (clog, 0x3f96469050f650869c2p-75L, 0x6f16b2c9c8b05988335p-75L, -1.0509738482436128031927971874674370984602e-45L, 1.0509191467640012308402149909370784281448L),
6529 TEST_c_c (clog, 0x3157fc1d73233e580c8p-75L, 0x761b52ccd435d7c7f5fp-75L, 1.3487497719126364307640897239165442763573e-43L, 1.1750493008528425228929764149024375035382L),
6530 TEST_c_c (clog, 0x155f8afc4c48685bf63610p-85L, 0x17d0cf2652cdbeb1294e19p-85L, -4.7775669192897997174762089350332738583822e-50L, 0.8393953487996880419413728440067635213372L),
6531 TEST_c_c (clog, 0x13836d58a13448d750b4b9p-85L, 0x195ca7bc3ab4f9161edbe6p-85L, 2.8398125044729578740243199963484494962411e-50L, 0.9149964976334130461795060758257083099706L),
6532 TEST_c_c (clog, 0x1df515eb171a808b9e400266p-95L, 0x7c71eb0cd4688dfe98581c77p-95L, -3.5048022044913950094635368750889659723004e-57L, 1.3345633256521815205858155673950177421079L),
6533 TEST_c_c (clog, 0xe33f66c9542ca25cc43c867p-95L, 0x7f35a68ebd3704a43c465864p-95L, 4.1101771307217268747345114262406964584250e-56L, 1.4596065864518742494094402406719567059585L),
6534 TEST_c_c (clog, 0x6771f22c64ed551b857c128b4cp-105L, 0x1f570e7a13cc3cf2f44fd793ea1p-105L, -1.4281333889622737316199756373421183559948e-62L, 1.3673546561165378090903506783353927980633L),
6535 TEST_c_c (clog, 0x15d8ab6ed05ca514086ac3a1e84p-105L, 0x1761e480aa094c0b10b34b09ce9p-105L, 1.0027319539522347477331743836657426754857e-62L, 0.8193464073721167323313606647411269414759L),
6536 TEST_c_c (clog, 0x187190c1a334497bdbde5a95f48p-106L, 0x3b25f08062d0a095c4cfbbc338dp-106L, -1.7471844652198029695350765775994001163767e-63L, 1.1789110097072986038243729592318526094314L),
6537 TEST_c_c (clog, 0x6241ef0da53f539f02fad67dabp-106L, 0x3fb46641182f7efd9caa769dac0p-106L, 4.3299788920664682288477984749202524623248e-63L, 1.4746938237585656250866370987773473745867L),
6538 #endif
6539 #if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 113
6540 TEST_c_c (clog, 0x3e1d0a105ac4ebeacd9c6952d34cp-112L, 0xf859b3d1b06d005dcbb5516d5479p-112L, -1.1683999374665377365054966073875064467108e-66L, 1.3257197596350832748781065387304444940172L),
6541 TEST_c_c (clog, 0x47017a2e36807acb1e5214b209dep-112L, 0xf5f4a550c9d75e3bb1839d865f0dp-112L, 1.5077923002544367932999503838191154621839e-65L, 1.2897445708311412721399861948957141824914L),
6542 TEST_c_c (clog, 0x148f818cb7a9258fca942ade2a0cap-113L, 0x18854a34780b8333ec53310ad7001p-113L, -7.1865869169568789348552370692485515571497e-67L, 0.8730167479365994646287897223471819363668L),
6543 TEST_c_c (clog, 0xfd95243681c055c2632286921092p-113L, 0x1bccabcd29ca2152860ec29e34ef7p-113L, 6.6255694866654064502633121109394710807528e-66L, 1.0526409614996288387567810726095850312049L),
6544 TEST_c_c (clog, 0xdb85c467ee2aadd5f425fe0f4b8dp-114L, 0x3e83162a0f95f1dcbf97dddf410eap-114L, 4.6017338806965821566734340588575402712716e-67L, 1.3547418904611758959096647942223384691728L),
6545 TEST_c_c (clog, 0x1415bcaf2105940d49a636e98ae59p-115L, 0x7e6a150adfcd1b0921d44b31f40f4p-115L, 2.5993421227864195179698176012564317527271e-67L, 1.4132318089683022770487383611430906982461L),
6546 #endif
6547 END_DATA (clog)
6548 };
6549
6550 static void
6551 clog_test (void)
6552 {
6553 errno = 0;
6554 FUNC(clog) (BUILD_COMPLEX (-2, -3));
6555 if (errno == ENOSYS)
6556 /* Function not implemented. */
6557 return;
6558
6559 START (clog);
6560 RUN_TEST_LOOP_c_c (clog, clog_test_data, );
6561 END (clog, complex);
6562 }
6563
6564
6565 static const struct test_c_c_data clog10_test_data[] =
6566 {
6567 START_DATA (clog10),
6568 TEST_c_c (clog10, minus_zero, 0, minus_infty, M_PIl, DIVIDE_BY_ZERO_EXCEPTION),
6569 TEST_c_c (clog10, minus_zero, minus_zero, minus_infty, -M_PIl, DIVIDE_BY_ZERO_EXCEPTION),
6570
6571 TEST_c_c (clog10, 0, 0, minus_infty, 0.0, DIVIDE_BY_ZERO_EXCEPTION),
6572 TEST_c_c (clog10, 0, minus_zero, minus_infty, minus_zero, DIVIDE_BY_ZERO_EXCEPTION),
6573
6574 TEST_c_c (clog10, minus_infty, plus_infty, plus_infty, M_PI_34_LOG10El),
6575
6576 TEST_c_c (clog10, plus_infty, plus_infty, plus_infty, M_PI4_LOG10El),
6577 TEST_c_c (clog10, plus_infty, minus_infty, plus_infty, -M_PI4_LOG10El),
6578
6579 TEST_c_c (clog10, 0, plus_infty, plus_infty, M_PI2_LOG10El),
6580 TEST_c_c (clog10, 3, plus_infty, plus_infty, M_PI2_LOG10El),
6581 TEST_c_c (clog10, minus_zero, plus_infty, plus_infty, M_PI2_LOG10El),
6582 TEST_c_c (clog10, -3, plus_infty, plus_infty, M_PI2_LOG10El),
6583 TEST_c_c (clog10, 0, minus_infty, plus_infty, -M_PI2_LOG10El),
6584 TEST_c_c (clog10, 3, minus_infty, plus_infty, -M_PI2_LOG10El),
6585 TEST_c_c (clog10, minus_zero, minus_infty, plus_infty, -M_PI2_LOG10El),
6586 TEST_c_c (clog10, -3, minus_infty, plus_infty, -M_PI2_LOG10El),
6587
6588 TEST_c_c (clog10, minus_infty, 0, plus_infty, M_PI_LOG10El),
6589 TEST_c_c (clog10, minus_infty, 1, plus_infty, M_PI_LOG10El),
6590 TEST_c_c (clog10, minus_infty, minus_zero, plus_infty, -M_PI_LOG10El),
6591 TEST_c_c (clog10, minus_infty, -1, plus_infty, -M_PI_LOG10El),
6592
6593 TEST_c_c (clog10, plus_infty, 0, plus_infty, 0.0),
6594 TEST_c_c (clog10, plus_infty, 1, plus_infty, 0.0),
6595 TEST_c_c (clog10, plus_infty, minus_zero, plus_infty, minus_zero),
6596 TEST_c_c (clog10, plus_infty, -1, plus_infty, minus_zero),
6597
6598 TEST_c_c (clog10, plus_infty, qnan_value, plus_infty, qnan_value),
6599 TEST_c_c (clog10, minus_infty, qnan_value, plus_infty, qnan_value),
6600
6601 TEST_c_c (clog10, qnan_value, plus_infty, plus_infty, qnan_value),
6602 TEST_c_c (clog10, qnan_value, minus_infty, plus_infty, qnan_value),
6603
6604 TEST_c_c (clog10, 0, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
6605 TEST_c_c (clog10, 3, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
6606 TEST_c_c (clog10, minus_zero, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
6607 TEST_c_c (clog10, -3, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
6608
6609 TEST_c_c (clog10, qnan_value, 0, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
6610 TEST_c_c (clog10, qnan_value, 5, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
6611 TEST_c_c (clog10, qnan_value, minus_zero, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
6612 TEST_c_c (clog10, qnan_value, -5, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
6613
6614 TEST_c_c (clog10, qnan_value, qnan_value, qnan_value, qnan_value),
6615
6616 TEST_c_c (clog10, 0.75L, 1.25L, 0.163679467193165171449476605077428975L, 0.447486970040493067069984724340855636L),
6617 TEST_c_c (clog10, -2, -3, 0.556971676153418384603252578971164214L, -0.937554462986374708541507952140189646L),
6618
6619 TEST_c_c (clog10, 0x1.fffffep+127L, 0x1.fffffep+127L, 38.68235441693561449174780668781319348761L, M_PI4_LOG10El),
6620 TEST_c_c (clog10, 0x1.fffffep+127L, 1.0L, 38.53183941910362389414093724045094697423L, 1.276276851248440096917018665609900318458e-39L, UNDERFLOW_EXCEPTION_FLOAT),
6621 TEST_c_c (clog10, 0x1p-149L, 0x1p-149L, -44.70295435610120748924022586658721447508L, M_PI4_LOG10El),
6622 TEST_c_c (clog10, 0x1p-147L, 0x1p-147L, -44.10089436477324509881274807713822842154L, M_PI4_LOG10El),
6623
6624 #ifndef TEST_FLOAT
6625 TEST_c_c (clog10, 0x1.fffffffffffffp+1023L, 0x1.fffffffffffffp+1023L, 308.4052305577487344482591243175787477115L, M_PI4_LOG10El),
6626 TEST_c_c (clog10, 0x1.fffffffffffffp+1023L, 0x1p+1023L, 308.3031705664207720674749211936626341569L, 0.2013595981366865903254995612594728746470L),
6627 TEST_c_c (clog10, 0x1p-1074L, 0x1p-1074L, -323.1557003452838130619487034867432642357L, M_PI4_LOG10El),
6628 TEST_c_c (clog10, 0x1p-1073L, 0x1p-1073L, -322.8546703496198318667349645920187712089L, M_PI4_LOG10El),
6629 #endif
6630
6631 #if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
6632 TEST_c_c (clog10, 0x1.fp+16383L, 0x1.fp+16383L, 4932.212175672014259683102930239951947672L, M_PI4_LOG10El),
6633 TEST_c_c (clog10, 0x1.fp+16383L, 0x1p+16383L, 4932.112944269463028900262609694408579449L, 0.2069271710841128115912940666587802677383L),
6634 TEST_c_c (clog10, 0x1p-16440L, 0x1p-16441L, -4948.884673709346821106688037612752099609L, 0.2013595981366865710389502301937289472543L),
6635 #endif
6636
6637 TEST_c_c (clog10, 0x1p-149L, 0x1.fp+127L, 38.51805116050395969095658815123105801479L, 0.6821881769209206737428918127156778851051L),
6638 TEST_c_c (clog10, -0x1p-149L, 0x1.fp+127L, 38.51805116050395969095658815123105801479L, 0.6821881769209206737428918127156778851051L),
6639 TEST_c_c (clog10, 0x1p-149L, -0x1.fp+127L, 38.51805116050395969095658815123105801479L, -0.6821881769209206737428918127156778851051L),
6640 TEST_c_c (clog10, -0x1p-149L, -0x1.fp+127L, 38.51805116050395969095658815123105801479L, -0.6821881769209206737428918127156778851051L),
6641 TEST_c_c (clog10, -0x1.fp+127L, 0x1p-149L, 38.51805116050395969095658815123105801479L, 1.364376353841841347485783625431355770210L),
6642 TEST_c_c (clog10, -0x1.fp+127L, -0x1p-149L, 38.51805116050395969095658815123105801479L, -1.364376353841841347485783625431355770210L),
6643 #ifdef TEST_FLOAT
6644 TEST_c_c (clog10, 0x1.fp+127L, 0x1p-149L, 38.51805116050395969095658815123105801479L, plus_zero, UNDERFLOW_EXCEPTION),
6645 TEST_c_c (clog10, 0x1.fp+127L, -0x1p-149L, 38.51805116050395969095658815123105801479L, minus_zero, UNDERFLOW_EXCEPTION),
6646 #endif
6647
6648 #ifndef TEST_FLOAT
6649 TEST_c_c (clog10, 0x1p-1074L, 0x1.fp+1023L, 308.2409272754311106024666378243768099991L, 0.6821881769209206737428918127156778851051L),
6650 TEST_c_c (clog10, -0x1p-1074L, 0x1.fp+1023L, 308.2409272754311106024666378243768099991L, 0.6821881769209206737428918127156778851051L),
6651 TEST_c_c (clog10, 0x1p-1074L, -0x1.fp+1023L, 308.2409272754311106024666378243768099991L, -0.6821881769209206737428918127156778851051L),
6652 TEST_c_c (clog10, -0x1p-1074L, -0x1.fp+1023L, 308.2409272754311106024666378243768099991L, -0.6821881769209206737428918127156778851051L),
6653 TEST_c_c (clog10, -0x1.fp+1023L, 0x1p-1074L, 308.2409272754311106024666378243768099991L, 1.364376353841841347485783625431355770210L),
6654 TEST_c_c (clog10, -0x1.fp+1023L, -0x1p-1074L, 308.2409272754311106024666378243768099991L, -1.364376353841841347485783625431355770210L),
6655 #endif
6656 #if defined TEST_DOUBLE || (defined TEST_LDOUBLE && LDBL_MAX_EXP == 1024)
6657 TEST_c_c (clog10, 0x1.fp+1023L, 0x1p-1074L, 308.2409272754311106024666378243768099991L, plus_zero, UNDERFLOW_EXCEPTION),
6658 TEST_c_c (clog10, 0x1.fp+1023L, -0x1p-1074L, 308.2409272754311106024666378243768099991L, minus_zero, UNDERFLOW_EXCEPTION),
6659 #endif
6660
6661 #if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
6662 TEST_c_c (clog10, 0x1p-16445L, 0x1.fp+16383L, 4932.061660674182269085496060792589701158L, 0.6821881769209206737428918127156778851051L),
6663 TEST_c_c (clog10, -0x1p-16445L, 0x1.fp+16383L, 4932.061660674182269085496060792589701158L, 0.6821881769209206737428918127156778851051L),
6664 TEST_c_c (clog10, 0x1p-16445L, -0x1.fp+16383L, 4932.061660674182269085496060792589701158L, -0.6821881769209206737428918127156778851051L),
6665 TEST_c_c (clog10, -0x1p-16445L, -0x1.fp+16383L, 4932.061660674182269085496060792589701158L, -0.6821881769209206737428918127156778851051L),
6666 TEST_c_c (clog10, -0x1.fp+16383L, 0x1p-16445L, 4932.061660674182269085496060792589701158L, 1.364376353841841347485783625431355770210L),
6667 TEST_c_c (clog10, -0x1.fp+16383L, -0x1p-16445L, 4932.061660674182269085496060792589701158L, -1.364376353841841347485783625431355770210L),
6668 TEST_c_c (clog10, 0x1.fp+16383L, 0x1p-16445L, 4932.061660674182269085496060792589701158L, plus_zero, UNDERFLOW_EXCEPTION),
6669 TEST_c_c (clog10, 0x1.fp+16383L, -0x1p-16445L, 4932.061660674182269085496060792589701158L, minus_zero, UNDERFLOW_EXCEPTION),
6670 # if LDBL_MANT_DIG >= 113
6671 TEST_c_c (clog10, 0x1p-16494L, 0x1.fp+16383L, 4932.061660674182269085496060792589701158L, 0.6821881769209206737428918127156778851051L),
6672 TEST_c_c (clog10, -0x1p-16494L, 0x1.fp+16383L, 4932.061660674182269085496060792589701158L, 0.6821881769209206737428918127156778851051L),
6673 TEST_c_c (clog10, 0x1p-16494L, -0x1.fp+16383L, 4932.061660674182269085496060792589701158L, -0.6821881769209206737428918127156778851051L),
6674 TEST_c_c (clog10, -0x1p-16494L, -0x1.fp+16383L, 4932.061660674182269085496060792589701158L, -0.6821881769209206737428918127156778851051L),
6675 TEST_c_c (clog10, -0x1.fp+16383L, 0x1p-16494L, 4932.061660674182269085496060792589701158L, 1.364376353841841347485783625431355770210L),
6676 TEST_c_c (clog10, -0x1.fp+16383L, -0x1p-16494L, 4932.061660674182269085496060792589701158L, -1.364376353841841347485783625431355770210L),
6677 TEST_c_c (clog10, 0x1.fp+16383L, 0x1p-16494L, 4932.061660674182269085496060792589701158L, plus_zero, UNDERFLOW_EXCEPTION),
6678 TEST_c_c (clog10, 0x1.fp+16383L, -0x1p-16494L, 4932.061660674182269085496060792589701158L, minus_zero, UNDERFLOW_EXCEPTION),
6679 # endif
6680 #endif
6681
6682 TEST_c_c (clog10, 1.0L, 0x1.234566p-10L, 2.680828048441605163181684680300513080769e-7L, 4.825491868832381486767558728169977751564e-4L),
6683 TEST_c_c (clog10, -1.0L, 0x1.234566p-20L, 2.556638434669064077889576526006849923281e-13L, 1.364375882602207106407956770293808181427L),
6684 TEST_c_c (clog10, 0x1.234566p-30L, 1.0L, 2.438200411482400072282924063740535840474e-19L, 6.821881764607257184291586401763604544928e-1L),
6685 TEST_c_c (clog10, -0x1.234566p-40L, -1.0L, 2.325249110681915353442924915876654139373e-25L, -6.821881769213700828789403802671540158935e-1L),
6686 TEST_c_c (clog10, 0x1.234566p-50L, 1.0L, 2.217530356103816369479108963807448194409e-31L, 6.821881769209202348667823902864283966959e-1L),
6687 TEST_c_c (clog10, 0x1.234566p-60L, 1.0L, 2.114801746467415208319767917450504756866e-37L, 6.821881769209206733143018621078368211515e-1L),
6688 TEST_c_c (clog10, 0x1p-61L, 1.0L, 4.084085680564517578238994467153626207224e-38L, 6.821881769209206735545466044044889962925e-1L),
6689 TEST_c_c (clog10, 0x1p-62L, 1.0L, 1.021021420141129394559748616788406551878e-38L, 6.821881769209206736487192085600834406988e-1L, UNDERFLOW_EXCEPTION_FLOAT),
6690 TEST_c_c (clog10, 0x1p-63L, 1.0L, 2.552553550352823486399371541971016379740e-39L, 6.821881769209206736958055106378806629019e-1L, UNDERFLOW_EXCEPTION_FLOAT),
6691 #ifndef TEST_FLOAT
6692 TEST_c_c (clog10, 0x1p-509L, 1.0L, 7.730698388614835910296270976605350994446e-308L, 6.821881769209206737428918127156778851051e-1L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
6693 TEST_c_c (clog10, 0x1p-510L, 1.0L, 1.932674597153708977574067744151337748612e-308L, 6.821881769209206737428918127156778851051e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
6694 TEST_c_c (clog10, 0x1p-511L, 1.0L, 4.831686492884272443935169360378344371529e-309L, 6.821881769209206737428918127156778851051e-1L, UNDERFLOW_EXCEPTION_DOUBLE),
6695 #endif
6696 #if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
6697 TEST_c_c (clog10, 0x1p-8189L, 1.0L, 1.168114274114528946314738738025008370069e-4931L, 6.821881769209206737428918127156778851051e-1L),
6698 TEST_c_c (clog10, 0x1p-8190L, 1.0L, 2.920285685286322365786846845062520925172e-4932L, 6.821881769209206737428918127156778851051e-1L, UNDERFLOW_EXCEPTION),
6699 TEST_c_c (clog10, 0x1p-8191L, 1.0L, 7.300714213215805914467117112656302312931e-4933L, 6.821881769209206737428918127156778851051e-1L, UNDERFLOW_EXCEPTION),
6700 #endif
6701
6702 TEST_c_c (clog10, 0x1.000566p0L, 0x1.234p-10L, 3.604093470239754109961125085078190708674e-5L, 4.824745078422174667425851670822596859720e-4L),
6703 TEST_c_c (clog10, 0x1.000566p0L, 0x1.234p-100L, 3.577293486783822178310971763308187385546e-5L, 3.897399639875661463735636919790792140598e-31L),
6704 #ifndef TEST_FLOAT
6705 TEST_c_c (clog10, -0x1.0000000123456p0L, 0x1.2345678p-30L, 1.150487028947346337782682105935961875822e-10L, 1.364376353381646356131680448946397884147L),
6706 TEST_c_c (clog10, -0x1.0000000123456p0L, 0x1.2345678p-1000L, 1.150487026509145544402795327729455391948e-10L, 1.364376353841841347485783625431355770210L),
6707 #endif
6708 #if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 106
6709 TEST_c_c (clog10, 0x1.00000000000000123456789abcp0L, 0x1.23456789p-60L, 4.285899851347756188767674032946882584784e-19L, 4.285899850759344225805480528847018395861e-19L),
6710 TEST_c_c (clog10, 0x1.00000000000000123456789abcp0L, 0x1.23456789p-1000L, 4.285899851347756186652871946325962330640e-19L, 4.611541215247321502041995872887317363241e-302L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
6711 #endif
6712
6713 TEST_c_c (clog10, 0x0.ffffffp0L, 0x0.ffffffp-100L, -2.588596909321764128428416045209904492216e-8L, 3.425979381266895667295625489912064603415e-31L),
6714 #ifndef TEST_FLOAT
6715 TEST_c_c (clog10, 0x0.fffffffffffff8p0L, 0x0.fffffffffffff8p-1000L, -4.821637332766435821255375046554377090472e-17L, 4.053112396770095089737411317782466262176e-302L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
6716 #endif
6717 #if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
6718 TEST_c_c (clog10, 0x0.ffffffffffffffffp0L, 0x0.ffffffffffffffffp-15000L, -2.354315103889861110220423157644627849164e-20L, 1.541165759405643564697852372112893034397e-4516L),
6719 #endif
6720
6721 TEST_c_c (clog10, 0x1a6p-10L, 0x3a5p-10L, -6.2126412844802358329771948751248003038444e-07L, 0.4977135139537443711784513409096950995985L),
6722 TEST_c_c (clog10, 0xf2p-10L, 0x3e3p-10L, 2.6921240173351112953324592659528481616879e-06L, 0.5785726025799636431142862788413361783862L),
6723 TEST_c_c (clog10, 0x4d4ep-15L, 0x6605p-15L, -7.0781945783414996953799915941870192015212e-09L, 0.4005747524909781155537088181659175147564L),
6724 TEST_c_c (clog10, 0x2818p-15L, 0x798fp-15L, 6.6737261053986614395049481326819059203910e-09L, 0.5438241985991753781478398141908629586460L),
6725 TEST_c_c (clog10, 0x9b57bp-20L, 0xcb7b4p-20L, -1.7182001068739620267773842120965071561416e-11L, 0.3990121149225253562859800593935899629087L),
6726 TEST_c_c (clog10, 0x2731p-20L, 0xfffd0p-20L, 1.9156943718715958194239364991329064049438e-11L, 0.6780326907904082601285090019969008967595L),
6727 TEST_c_c (clog10, 0x2ede88p-23L, 0x771c3fp-23L, -1.9440841725722970687903291200493082253766e-13L, 0.5193774116724956222518530053006822210323L),
6728 TEST_c_c (clog10, 0x11682p-23L, 0x7ffed1p-23L, 5.0916490233953865181284669870035717560498e-13L, 0.6784968969384861816694467029319146542069L),
6729 TEST_c_c (clog10, 0xa1f2c1p-24L, 0xc643aep-24L, -4.5516256421319921959681423447271490869664e-14L, 0.3847315790697197749315054516562206543710L),
6730 TEST_c_c (clog10, 0x659feap-24L, 0xeaf6f9p-24L, 1.6200701438094619117335617123525612051457e-14L, 0.5049027913635038013499728086604870749732L),
6731 #ifndef TEST_FLOAT
6732 TEST_c_c (clog10, 0x4447d7175p-35L, 0x6c445e00ap-35L, -6.4375803621988389731799033530075237868110e-21L, 0.4378257977686804492768642780897650927167L),
6733 TEST_c_c (clog10, 0x2dd46725bp-35L, 0x7783a1284p-35L, 1.9312741086596516918394613098872836703188e-20L, 0.5231613813514771042838490538484014771862L),
6734 TEST_c_c (clog10, 0x164c74eea876p-45L, 0x16f393482f77p-45L, -1.3155760824064879362415202279780039150764e-26L, 0.3473590599762514228227328130640352044313L),
6735 TEST_c_c (clog10, 0xfe961079616p-45L, 0x1bc37e09e6d1p-45L, 2.3329549194675052736016290082882121135546e-26L, 0.4561756099441139182878993697611751382976L),
6736 TEST_c_c (clog10, 0xa4722f19346cp-51L, 0x7f9631c5e7f07p-51L, -2.6979587627476803379953050733225113494503e-30L, 0.6472785229986997177606324374555347813105L),
6737 TEST_c_c (clog10, 0x10673dd0f2481p-51L, 0x7ef1d17cefbd2p-51L, 1.3918041236396763648388478552321724382899e-29L, 0.6263795733790237053262025311642907438291L),
6738 TEST_c_c (clog10, 0x8ecbf810c4ae6p-52L, 0xd479468b09a37p-52L, -4.2289432987513243393180377141513840878196e-30L, 0.4252020027092323591068799049905597805296L),
6739 TEST_c_c (clog10, 0x5b06b680ea2ccp-52L, 0xef452b965da9fp-52L, 3.6079845358966994996207055940336690133424e-30L, 0.5243112258263349992771652393178033846555L),
6740 TEST_c_c (clog10, 0x659b70ab7971bp-53L, 0x1f5d111e08abecp-53L, -1.0893543813872082317104059174982092534059e-30L, 0.5954257879188711495921161433751775633232L),
6741 TEST_c_c (clog10, 0x15cfbd1990d1ffp-53L, 0x176a3973e09a9ap-53L, 4.4163015461643576961232672330852798804976e-31L, 0.3564851427422832755956993418877523303529L),
6742 TEST_c_c (clog10, 0x1367a310575591p-54L, 0x3cfcc0a0541f60p-54L, 2.2081507730821788480616336165447731164865e-32L, 0.5484039935757001196548030312819898864760L),
6743 TEST_c_c (clog10, 0x55cb6d0c83af5p-55L, 0x7fe33c0c7c4e90p-55L, -2.2583360179249556400630343805573865814771e-32L, 0.6639894257763289307423302343317622430835L),
6744 #endif
6745 #if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 64
6746 TEST_c_c (clog10, 0x298c62cb546588a7p-63L, 0x7911b1dfcc4ecdaep-63L, -5.1816837072162316773907242302011632570857e-37L, 0.5386167838952956925896424154370364458140L),
6747 TEST_c_c (clog10, 0x4d9c37e2b5cb4533p-63L, 0x65c98be2385a042ep-63L, 2.7822833698845776001753149807484078521508e-37L, 0.3992725998539071066769046272515417679815L),
6748 TEST_c_c (clog10, 0x602fd5037c4792efp-64L, 0xed3e2086dcca80b8p-64L, -1.0146400362652473358437501879334790111898e-37L, 0.5149047982335273098246594109614460842099L),
6749 TEST_c_c (clog10, 0x6b10b4f3520217b6p-64L, 0xe8893cbb449253a1p-64L, 1.0529283395205396881397407610630442563938e-37L, 0.4947949395762683446121140513971996916447L),
6750 TEST_c_c (clog10, 0x81b7efa81fc35ad1p-65L, 0x1ef4b835f1c79d812p-65L, -4.3074341162203896332989394770760901408798e-39L, 0.5709443672155660428417571212549720987784L),
6751 #endif
6752 #if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 106
6753 TEST_c_c (clog10, 0x3f96469050f650869c2p-75L, 0x6f16b2c9c8b05988335p-75L, -4.5643214291682663316715446865040356750881e-46L, 0.4564083863660793840592614609053162690362L),
6754 TEST_c_c (clog10, 0x3157fc1d73233e580c8p-75L, 0x761b52ccd435d7c7f5fp-75L, 5.8575458340992751256451490143468457830297e-44L, 0.5103174273246635294300470585396890237265L),
6755 TEST_c_c (clog10, 0x155f8afc4c48685bf63610p-85L, 0x17d0cf2652cdbeb1294e19p-85L, -2.0748709499710785084693619097712106753591e-50L, 0.3645447681189598740620098186365764884771L),
6756 TEST_c_c (clog10, 0x13836d58a13448d750b4b9p-85L, 0x195ca7bc3ab4f9161edbe6p-85L, 1.2333149003324592532859843519619084433953e-50L, 0.3973779298829931059309198145608711073016L),
6757 TEST_c_c (clog10, 0x1df515eb171a808b9e400266p-95L, 0x7c71eb0cd4688dfe98581c77p-95L, -1.5221162575729652613635150540947625639689e-57L, 0.5795934880811949230121092882659698986043L),
6758 TEST_c_c (clog10, 0xe33f66c9542ca25cc43c867p-95L, 0x7f35a68ebd3704a43c465864p-95L, 1.7850272475173865337808494725293124613817e-56L, 0.6338990862456906754888183278564382516852L),
6759 TEST_c_c (clog10, 0x6771f22c64ed551b857c128b4cp-105L, 0x1f570e7a13cc3cf2f44fd793ea1p-105L, -6.2023045024810589256360494043570293518879e-63L, 0.5938345819561308555003145899438513900776L),
6760 TEST_c_c (clog10, 0x15d8ab6ed05ca514086ac3a1e84p-105L, 0x1761e480aa094c0b10b34b09ce9p-105L, 4.3548095442952115860848857519953610343042e-63L, 0.3558376234889641500775150477035448866763L),
6761 TEST_c_c (clog10, 0x187190c1a334497bdbde5a95f48p-106L, 0x3b25f08062d0a095c4cfbbc338dp-106L, -7.5879257211204444302994221436282805900756e-64L, 0.5119945461708707332160859198685423099187L),
6762 TEST_c_c (clog10, 0x6241ef0da53f539f02fad67dabp-106L, 0x3fb46641182f7efd9caa769dac0p-106L, 1.8804859395820231849002915747252695375405e-63L, 0.6404513901551516189871978418046651877394L),
6763 #endif
6764 #if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 113
6765 TEST_c_c (clog10, 0x3e1d0a105ac4ebeacd9c6952d34cp-112L, 0xf859b3d1b06d005dcbb5516d5479p-112L, -5.0742964549782184008668435276046798273476e-67L, 0.5757527761596220360985719127090110408283L),
6766 TEST_c_c (clog10, 0x47017a2e36807acb1e5214b209dep-112L, 0xf5f4a550c9d75e3bb1839d865f0dp-112L, 6.5482587585671294601662599808612773010057e-66L, 0.5601289501766423782280643144987875760229L),
6767 TEST_c_c (clog10, 0x148f818cb7a9258fca942ade2a0cap-113L, 0x18854a34780b8333ec53310ad7001p-113L, -3.1210950417524756037077807411854181477733e-67L, 0.3791463562379872585396164879981280044658L),
6768 TEST_c_c (clog10, 0xfd95243681c055c2632286921092p-113L, 0x1bccabcd29ca2152860ec29e34ef7p-113L, 2.8774482675253468630312378575186855052697e-66L, 0.4571561610046221605554903008571429975493L),
6769 TEST_c_c (clog10, 0xdb85c467ee2aadd5f425fe0f4b8dp-114L, 0x3e83162a0f95f1dcbf97dddf410eap-114L, 1.9985076315737626043096596036300177494613e-67L, 0.5883569274304683249184005177865521205198L),
6770 TEST_c_c (clog10, 0x1415bcaf2105940d49a636e98ae59p-115L, 0x7e6a150adfcd1b0921d44b31f40f4p-115L, 1.1288799405048268615023706955013387413519e-67L, 0.6137587762850841972073301550420510507903L),
6771 #endif
6772 END_DATA (clog10)
6773 };
6774
6775 static void
6776 clog10_test (void)
6777 {
6778 errno = 0;
6779 FUNC(clog10) (BUILD_COMPLEX (0.7L, 1.2L));
6780 if (errno == ENOSYS)
6781 /* Function not implemented. */
6782 return;
6783
6784 START (clog10);
6785 RUN_TEST_LOOP_c_c (clog10, clog10_test_data, );
6786 END (clog10, complex);
6787 }
6788
6789
6790 static const struct test_c_c_data conj_test_data[] =
6791 {
6792 START_DATA (conj),
6793 TEST_c_c (conj, 0.0, 0.0, 0.0, minus_zero),
6794 TEST_c_c (conj, 0.0, minus_zero, 0.0, 0.0),
6795 TEST_c_c (conj, qnan_value, qnan_value, qnan_value, qnan_value),
6796 TEST_c_c (conj, plus_infty, minus_infty, plus_infty, plus_infty),
6797 TEST_c_c (conj, plus_infty, plus_infty, plus_infty, minus_infty),
6798 TEST_c_c (conj, 1.0, 2.0, 1.0, -2.0),
6799 TEST_c_c (conj, 3.0, -4.0, 3.0, 4.0),
6800 END_DATA (conj)
6801 };
6802
6803 static void
6804 conj_test (void)
6805 {
6806 START (conj);
6807 RUN_TEST_LOOP_c_c (conj, conj_test_data, );
6808 END (conj, complex);
6809 }
6810
6811
6812 static const struct test_ff_f_data copysign_test_data[] =
6813 {
6814 START_DATA (copysign),
6815 TEST_ff_f (copysign, 0, 4, 0),
6816 TEST_ff_f (copysign, 0, -4, minus_zero),
6817 TEST_ff_f (copysign, minus_zero, 4, 0),
6818 TEST_ff_f (copysign, minus_zero, -4, minus_zero),
6819
6820 TEST_ff_f (copysign, plus_infty, 0, plus_infty),
6821 TEST_ff_f (copysign, plus_infty, minus_zero, minus_infty),
6822 TEST_ff_f (copysign, minus_infty, 0, plus_infty),
6823 TEST_ff_f (copysign, minus_infty, minus_zero, minus_infty),
6824
6825 TEST_ff_f (copysign, 0, plus_infty, 0),
6826 TEST_ff_f (copysign, 0, minus_zero, minus_zero),
6827 TEST_ff_f (copysign, minus_zero, plus_infty, 0),
6828 TEST_ff_f (copysign, minus_zero, minus_zero, minus_zero),
6829
6830 /* XXX More correctly we would have to check the sign of the NaN. */
6831 TEST_ff_f (copysign, qnan_value, 0, qnan_value),
6832 TEST_ff_f (copysign, qnan_value, minus_zero, qnan_value),
6833 TEST_ff_f (copysign, -qnan_value, 0, qnan_value),
6834 TEST_ff_f (copysign, -qnan_value, minus_zero, qnan_value),
6835 END_DATA (copysign)
6836 };
6837
6838 static void
6839 copysign_test (void)
6840 {
6841 START (copysign);
6842 RUN_TEST_LOOP_ff_f (copysign, copysign_test_data, );
6843 END (copysign);
6844 }
6845
6846
6847 static const struct test_f_f_data cos_test_data[] =
6848 {
6849 START_DATA (cos),
6850 TEST_f_f (cos, 0, 1),
6851 TEST_f_f (cos, minus_zero, 1),
6852 TEST_f_f (cos, plus_infty, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
6853 TEST_f_f (cos, minus_infty, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
6854 TEST_f_f (cos, qnan_value, qnan_value, ERRNO_UNCHANGED),
6855
6856 TEST_f_f (cos, M_PI_6l * 2.0, 0.5),
6857 TEST_f_f (cos, M_PI_6l * 4.0, -0.5),
6858
6859 /* The value of M_PI_2l is never exactly PI/2, and therefore the
6860 answer is never exactly zero. The answer is equal to the error
6861 in rounding PI/2 for the type used. Thus the answer is unique
6862 to each type. */
6863 #ifdef TEST_FLOAT
6864 /* 32-bit float. */
6865 TEST_f_f (cos, M_PI_2l, -0x1.777a5cp-25L),
6866 #endif
6867 #if defined TEST_DOUBLE || (defined TEST_LDOUBLE && LDBL_MANT_DIG == 53)
6868 /* 64-bit double or 64-bit long double. */
6869 TEST_f_f (cos, M_PI_2l, 0x1.1a62633145c07p-54L),
6870 #endif
6871 #if defined TEST_LDOUBLE && LDBL_MANT_DIG == 64
6872 /* 96-bit long double. */
6873 TEST_f_f (cos, M_PI_2l, -0xe.ce675d1fc8f8cbbp-69L),
6874 #endif
6875 #if defined TEST_LDOUBLE && LDBL_MANT_DIG == 106
6876 /* 128-bit IBM long double. */
6877 TEST_f_f (cos, M_PI_2l, 0x1.c1cd129024e088a67cc74020bcp-107L),
6878 #endif
6879 #if defined TEST_LDOUBLE && LDBL_MANT_DIG == 113
6880 /* 128-bit long double. */
6881 TEST_f_f (cos, M_PI_2l, 0x1.cd129024e088a67cc74020bbea64p-115L),
6882 #endif
6883
6884 TEST_f_f (cos, 0.75L, 0.731688868873820886311838753000084544L),
6885
6886 TEST_f_f (cos, 0x1p65, 0.99888622066058013610642172179340364209972L),
6887 TEST_f_f (cos, -0x1p65, 0.99888622066058013610642172179340364209972L),
6888
6889 #ifdef TEST_DOUBLE
6890 TEST_f_f (cos, 0.80190127184058835, 0.69534156199418473),
6891 #endif
6892
6893 TEST_f_f (cos, 0x1.442f74p+15, 2.4407839902314016628485779006274989801517e-06L),
6894
6895 #ifndef TEST_FLOAT
6896 TEST_f_f (cos, 1e22, 0.5232147853951389454975944733847094921409L),
6897 TEST_f_f (cos, 0x1p1023, -0.826369834614147994500785680811743734805L),
6898 #endif
6899
6900 #if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
6901 TEST_f_f (cos, 0x1p16383L, 0.9210843909921906206874509522505756251609L),
6902 #endif
6903
6904 TEST_f_f (cos, 0x1p+120, -9.25879022854837867303861764107414946730833e-01L),
6905 TEST_f_f (cos, 0x1p+127, 7.81914638714960072263910298466369236613162e-01L),
6906 TEST_f_f (cos, 0x1.fffff8p+127, 9.98819362551949040703862043664101081064641e-01L),
6907 TEST_f_f (cos, 0x1.fffffep+127, 8.53021039830304158051791467692161107353094e-01L),
6908 TEST_f_f (cos, 0x1p+50, 8.68095904660550604334592502063501320395739e-01L),
6909 TEST_f_f (cos, 0x1p+28, -1.65568979490578758865468278195361551113358e-01L),
6910 END_DATA (cos)
6911 };
6912
6913 static void
6914 cos_test (void)
6915 {
6916 errno = 0;
6917 FUNC(cos) (0);
6918 if (errno == ENOSYS)
6919 /* Function not implemented. */
6920 return;
6921
6922 START (cos);
6923 RUN_TEST_LOOP_f_f (cos, cos_test_data, );
6924 END (cos);
6925 }
6926
6927
6928 static const struct test_f_f_data cos_tonearest_test_data[] =
6929 {
6930 START_DATA (cos_tonearest),
6931 TEST_f_f (cos, 1, 0.5403023058681397174009366074429766037323L),
6932 TEST_f_f (cos, 2, -0.4161468365471423869975682295007621897660L),
6933 TEST_f_f (cos, 3, -0.9899924966004454572715727947312613023937L),
6934 TEST_f_f (cos, 4, -0.6536436208636119146391681830977503814241L),
6935 TEST_f_f (cos, 5, 0.2836621854632262644666391715135573083344L),
6936 TEST_f_f (cos, 6, 0.9601702866503660205456522979229244054519L),
6937 TEST_f_f (cos, 7, 0.7539022543433046381411975217191820122183L),
6938 TEST_f_f (cos, 8, -0.1455000338086135258688413818311946826093L),
6939 TEST_f_f (cos, 9, -0.9111302618846769883682947111811653112463L),
6940 TEST_f_f (cos, 10, -0.8390715290764524522588639478240648345199L),
6941 END_DATA (cos_tonearest)
6942 };
6943
6944 static void
6945 cos_test_tonearest (void)
6946 {
6947 errno = 0;
6948 FUNC(cos) (0);
6949 if (errno == ENOSYS)
6950 /* Function not implemented. */
6951 return;
6952
6953 START (cos_tonearest);
6954 RUN_TEST_LOOP_f_f (cos, cos_tonearest_test_data, FE_TONEAREST);
6955 END (cos_tonearest);
6956 }
6957
6958
6959 static const struct test_f_f_data cos_towardzero_test_data[] =
6960 {
6961 START_DATA (cos_towardzero),
6962 TEST_f_f (cos, 1, 0.5403023058681397174009366074429766037323L),
6963 TEST_f_f (cos, 2, -0.4161468365471423869975682295007621897660L),
6964 TEST_f_f (cos, 3, -0.9899924966004454572715727947312613023937L),
6965 TEST_f_f (cos, 4, -0.6536436208636119146391681830977503814241L),
6966 TEST_f_f (cos, 5, 0.2836621854632262644666391715135573083344L),
6967 TEST_f_f (cos, 6, 0.9601702866503660205456522979229244054519L),
6968 TEST_f_f (cos, 7, 0.7539022543433046381411975217191820122183L),
6969 TEST_f_f (cos, 8, -0.1455000338086135258688413818311946826093L),
6970 TEST_f_f (cos, 9, -0.9111302618846769883682947111811653112463L),
6971 TEST_f_f (cos, 10, -0.8390715290764524522588639478240648345199L),
6972 END_DATA (cos_towardzero)
6973 };
6974
6975 static void
6976 cos_test_towardzero (void)
6977 {
6978 errno = 0;
6979 FUNC(cos) (0);
6980 if (errno == ENOSYS)
6981 /* Function not implemented. */
6982 return;
6983
6984 START (cos_towardzero);
6985 RUN_TEST_LOOP_f_f (cos, cos_towardzero_test_data, FE_TOWARDZERO);
6986 END (cos_towardzero);
6987 }
6988
6989
6990 static const struct test_f_f_data cos_downward_test_data[] =
6991 {
6992 START_DATA (cos_downward),
6993 TEST_f_f (cos, 1, 0.5403023058681397174009366074429766037323L),
6994 TEST_f_f (cos, 2, -0.4161468365471423869975682295007621897660L),
6995 TEST_f_f (cos, 3, -0.9899924966004454572715727947312613023937L),
6996 TEST_f_f (cos, 4, -0.6536436208636119146391681830977503814241L),
6997 TEST_f_f (cos, 5, 0.2836621854632262644666391715135573083344L),
6998 TEST_f_f (cos, 6, 0.9601702866503660205456522979229244054519L),
6999 TEST_f_f (cos, 7, 0.7539022543433046381411975217191820122183L),
7000 TEST_f_f (cos, 8, -0.1455000338086135258688413818311946826093L),
7001 TEST_f_f (cos, 9, -0.9111302618846769883682947111811653112463L),
7002 TEST_f_f (cos, 10, -0.8390715290764524522588639478240648345199L),
7003 END_DATA (cos_downward)
7004 };
7005
7006 static void
7007 cos_test_downward (void)
7008 {
7009 errno = 0;
7010 FUNC(cos) (0);
7011 if (errno == ENOSYS)
7012 /* Function not implemented. */
7013 return;
7014
7015 START (cos_downward);
7016 RUN_TEST_LOOP_f_f (cos, cos_downward_test_data, FE_DOWNWARD);
7017 END (cos_downward);
7018 }
7019
7020
7021 static const struct test_f_f_data cos_upward_test_data[] =
7022 {
7023 START_DATA (cos_upward),
7024 TEST_f_f (cos, 1, 0.5403023058681397174009366074429766037323L),
7025 TEST_f_f (cos, 2, -0.4161468365471423869975682295007621897660L),
7026 TEST_f_f (cos, 3, -0.9899924966004454572715727947312613023937L),
7027 TEST_f_f (cos, 4, -0.6536436208636119146391681830977503814241L),
7028 TEST_f_f (cos, 5, 0.2836621854632262644666391715135573083344L),
7029 TEST_f_f (cos, 6, 0.9601702866503660205456522979229244054519L),
7030 TEST_f_f (cos, 7, 0.7539022543433046381411975217191820122183L),
7031 TEST_f_f (cos, 8, -0.1455000338086135258688413818311946826093L),
7032 TEST_f_f (cos, 9, -0.9111302618846769883682947111811653112463L),
7033 TEST_f_f (cos, 10, -0.8390715290764524522588639478240648345199L),
7034 END_DATA (cos_upward)
7035 };
7036
7037 static void
7038 cos_test_upward (void)
7039 {
7040 errno = 0;
7041 FUNC(cos) (0);
7042 if (errno == ENOSYS)
7043 /* Function not implemented. */
7044 return;
7045
7046 START (cos_upward);
7047 RUN_TEST_LOOP_f_f (cos, cos_upward_test_data, FE_UPWARD);
7048 END (cos_upward);
7049 }
7050
7051
7052 static const struct test_f_f_data cosh_test_data[] =
7053 {
7054 START_DATA (cosh),
7055 TEST_f_f (cosh, 0, 1),
7056 TEST_f_f (cosh, minus_zero, 1),
7057
7058 #ifndef TEST_INLINE
7059 TEST_f_f (cosh, plus_infty, plus_infty),
7060 TEST_f_f (cosh, minus_infty, plus_infty),
7061 #endif
7062 TEST_f_f (cosh, qnan_value, qnan_value),
7063
7064 TEST_f_f (cosh, 0.75L, 1.29468328467684468784170818539018176L),
7065
7066 #ifndef TEST_FLOAT
7067 TEST_f_f (cosh, 709.8893558127259666434838436543941497802734375L, 9.9999998999995070652573675944761818416035e+307L),
7068 TEST_f_f (cosh, -709.8893558127259666434838436543941497802734375L, 9.9999998999995070652573675944761818416035e+307L),
7069 #endif
7070 END_DATA (cosh)
7071 };
7072
7073 static void
7074 cosh_test (void)
7075 {
7076 errno = 0;
7077 FUNC(cosh) (0.7L);
7078 if (errno == ENOSYS)
7079 /* Function not implemented. */
7080 return;
7081
7082 START (cosh);
7083 RUN_TEST_LOOP_f_f (cosh, cosh_test_data, );
7084 END (cosh);
7085 }
7086
7087
7088 static const struct test_f_f_data cosh_tonearest_test_data[] =
7089 {
7090 START_DATA (cosh_tonearest),
7091 TEST_f_f (cosh, 22, 1792456423.065795780980053377632656584997L),
7092 TEST_f_f (cosh, 23, 4872401723.124451300068625740569997090344L),
7093 TEST_f_f (cosh, 24, 13244561064.92173614708845674912733665919L),
7094 END_DATA (cosh_tonearest)
7095 };
7096
7097 static void
7098 cosh_test_tonearest (void)
7099 {
7100 errno = 0;
7101 FUNC(cosh) (0);
7102 if (errno == ENOSYS)
7103 /* Function not implemented. */
7104 return;
7105
7106 START (cosh_tonearest);
7107 RUN_TEST_LOOP_f_f (cosh, cosh_tonearest_test_data, FE_TONEAREST);
7108 END (cosh_tonearest);
7109 }
7110
7111
7112 static const struct test_f_f_data cosh_towardzero_test_data[] =
7113 {
7114 START_DATA (cosh_towardzero),
7115 TEST_f_f (cosh, 22, 1792456423.065795780980053377632656584997L),
7116 TEST_f_f (cosh, 23, 4872401723.124451300068625740569997090344L),
7117 TEST_f_f (cosh, 24, 13244561064.92173614708845674912733665919L),
7118 END_DATA (cosh_towardzero)
7119 };
7120
7121 static void
7122 cosh_test_towardzero (void)
7123 {
7124 errno = 0;
7125 FUNC(cosh) (0);
7126 if (errno == ENOSYS)
7127 /* Function not implemented. */
7128 return;
7129
7130 START (cosh_towardzero);
7131 RUN_TEST_LOOP_f_f (cosh, cosh_towardzero_test_data, FE_TOWARDZERO);
7132 END (cosh_towardzero);
7133 }
7134
7135
7136 static const struct test_f_f_data cosh_downward_test_data[] =
7137 {
7138 START_DATA (cosh_downward),
7139 TEST_f_f (cosh, 22, 1792456423.065795780980053377632656584997L),
7140 TEST_f_f (cosh, 23, 4872401723.124451300068625740569997090344L),
7141 TEST_f_f (cosh, 24, 13244561064.92173614708845674912733665919L),
7142 END_DATA (cosh_downward)
7143 };
7144
7145 static void
7146 cosh_test_downward (void)
7147 {
7148 errno = 0;
7149 FUNC(cosh) (0);
7150 if (errno == ENOSYS)
7151 /* Function not implemented. */
7152 return;
7153
7154 START (cosh_downward);
7155 RUN_TEST_LOOP_f_f (cosh, cosh_downward_test_data, FE_DOWNWARD);
7156 END (cosh_downward);
7157 }
7158
7159
7160 static const struct test_f_f_data cosh_upward_test_data[] =
7161 {
7162 START_DATA (cosh_upward),
7163 TEST_f_f (cosh, 22, 1792456423.065795780980053377632656584997L),
7164 TEST_f_f (cosh, 23, 4872401723.124451300068625740569997090344L),
7165 TEST_f_f (cosh, 24, 13244561064.92173614708845674912733665919L),
7166 END_DATA (cosh_upward)
7167 };
7168
7169 static void
7170 cosh_test_upward (void)
7171 {
7172 errno = 0;
7173 FUNC(cosh) (0);
7174 if (errno == ENOSYS)
7175 /* Function not implemented. */
7176 return;
7177
7178 START (cosh_upward);
7179 RUN_TEST_LOOP_f_f (cosh, cosh_upward_test_data, FE_UPWARD);
7180 END (cosh_upward);
7181 }
7182
7183
7184 static const struct test_cc_c_data cpow_test_data[] =
7185 {
7186 START_DATA (cpow),
7187 TEST_cc_c (cpow, 1, 0, 0, 0, 1.0, 0.0),
7188 TEST_cc_c (cpow, 2, 0, 10, 0, 1024.0, 0.0),
7189
7190 TEST_cc_c (cpow, M_El, 0, 0, 2 * M_PIl, 1.0, 0.0),
7191 TEST_cc_c (cpow, 2, 3, 4, 0, -119.0, -120.0),
7192
7193 TEST_cc_c (cpow, qnan_value, qnan_value, qnan_value, qnan_value, qnan_value, qnan_value),
7194
7195 TEST_cc_c (cpow, 0.75L, 1.25L, 0.75L, 1.25L, 0.117506293914473555420279832210420483L, 0.346552747708338676483025352060418001L),
7196 TEST_cc_c (cpow, 0.75L, 1.25L, 1.0L, 1.0L, 0.0846958290317209430433805274189191353L, 0.513285749182902449043287190519090481L),
7197 TEST_cc_c (cpow, 0.75L, 1.25L, 1.0L, 0.0L, 0.75L, 1.25L),
7198 TEST_cc_c (cpow, 0.75L, 1.25L, 0.0L, 1.0L, 0.331825439177608832276067945276730566L, 0.131338600281188544930936345230903032L),
7199 END_DATA (cpow)
7200 };
7201
7202 static void
7203 cpow_test (void)
7204 {
7205 errno = 0;
7206 FUNC(cpow) (BUILD_COMPLEX (1, 0), BUILD_COMPLEX (0, 0));
7207 if (errno == ENOSYS)
7208 /* Function not implemented. */
7209 return;
7210
7211 START (cpow);
7212 RUN_TEST_LOOP_cc_c (cpow, cpow_test_data, );
7213 END (cpow, complex);
7214 }
7215
7216
7217 static const struct test_c_c_data cproj_test_data[] =
7218 {
7219 START_DATA (cproj),
7220 TEST_c_c (cproj, 0.0, 0.0, 0.0, 0.0),
7221 TEST_c_c (cproj, minus_zero, minus_zero, minus_zero, minus_zero),
7222 TEST_c_c (cproj, 0.0, minus_zero, 0.0, minus_zero),
7223 TEST_c_c (cproj, minus_zero, 0.0, minus_zero, 0.0),
7224
7225 TEST_c_c (cproj, qnan_value, qnan_value, qnan_value, qnan_value),
7226
7227 TEST_c_c (cproj, plus_infty, plus_infty, plus_infty, 0.0),
7228 TEST_c_c (cproj, plus_infty, minus_infty, plus_infty, minus_zero),
7229 TEST_c_c (cproj, minus_infty, plus_infty, plus_infty, 0.0),
7230 TEST_c_c (cproj, minus_infty, minus_infty, plus_infty, minus_zero),
7231
7232 TEST_c_c (cproj, 1.0, 0.0, 1.0, 0.0),
7233 TEST_c_c (cproj, 2.0, 3.0, 2.0, 3.0),
7234 END_DATA (cproj)
7235 };
7236
7237 static void
7238 cproj_test (void)
7239 {
7240 START (cproj);
7241 RUN_TEST_LOOP_c_c (cproj, cproj_test_data, );
7242 END (cproj, complex);
7243 }
7244
7245
7246 static const struct test_c_f_data creal_test_data[] =
7247 {
7248 START_DATA (creal);
7249 TEST_c_f (creal, 0.0, 1.0, 0.0),
7250 TEST_c_f (creal, minus_zero, 1.0, minus_zero),
7251 TEST_c_f (creal, qnan_value, 1.0, qnan_value),
7252 TEST_c_f (creal, qnan_value, qnan_value, qnan_value),
7253 TEST_c_f (creal, plus_infty, 1.0, plus_infty),
7254 TEST_c_f (creal, minus_infty, 1.0, minus_infty),
7255 TEST_c_f (creal, 2.0, 3.0, 2.0),
7256 END_DATA (creal);
7257 };
7258
7259 static void
7260 creal_test (void)
7261 {
7262 START (creal);
7263 RUN_TEST_LOOP_c_f (creal, creal_test_data, );
7264 END (creal);
7265 }
7266
7267 static const struct test_c_c_data csin_test_data[] =
7268 {
7269 START_DATA (csin),
7270 TEST_c_c (csin, 0.0, 0.0, 0.0, 0.0),
7271 TEST_c_c (csin, minus_zero, 0.0, minus_zero, 0.0),
7272 TEST_c_c (csin, 0.0, minus_zero, 0, minus_zero),
7273 TEST_c_c (csin, minus_zero, minus_zero, minus_zero, minus_zero),
7274
7275 TEST_c_c (csin, 0.0, plus_infty, 0.0, plus_infty),
7276 TEST_c_c (csin, minus_zero, plus_infty, minus_zero, plus_infty),
7277 TEST_c_c (csin, 0.0, minus_infty, 0.0, minus_infty),
7278 TEST_c_c (csin, minus_zero, minus_infty, minus_zero, minus_infty),
7279
7280 TEST_c_c (csin, plus_infty, 0.0, qnan_value, 0.0, INVALID_EXCEPTION|IGNORE_ZERO_INF_SIGN),
7281 TEST_c_c (csin, minus_infty, 0.0, qnan_value, 0.0, INVALID_EXCEPTION|IGNORE_ZERO_INF_SIGN),
7282 TEST_c_c (csin, plus_infty, minus_zero, qnan_value, 0.0, INVALID_EXCEPTION|IGNORE_ZERO_INF_SIGN),
7283 TEST_c_c (csin, minus_infty, minus_zero, qnan_value, 0.0, INVALID_EXCEPTION|IGNORE_ZERO_INF_SIGN),
7284
7285 TEST_c_c (csin, plus_infty, plus_infty, qnan_value, plus_infty, INVALID_EXCEPTION|IGNORE_ZERO_INF_SIGN),
7286 TEST_c_c (csin, minus_infty, plus_infty, qnan_value, plus_infty, INVALID_EXCEPTION|IGNORE_ZERO_INF_SIGN),
7287 TEST_c_c (csin, plus_infty, minus_infty, qnan_value, plus_infty, INVALID_EXCEPTION|IGNORE_ZERO_INF_SIGN),
7288 TEST_c_c (csin, minus_infty, minus_infty, qnan_value, plus_infty, INVALID_EXCEPTION|IGNORE_ZERO_INF_SIGN),
7289
7290 TEST_c_c (csin, plus_infty, 6.75, qnan_value, qnan_value, INVALID_EXCEPTION),
7291 TEST_c_c (csin, plus_infty, -6.75, qnan_value, qnan_value, INVALID_EXCEPTION),
7292 TEST_c_c (csin, minus_infty, 6.75, qnan_value, qnan_value, INVALID_EXCEPTION),
7293 TEST_c_c (csin, minus_infty, -6.75, qnan_value, qnan_value, INVALID_EXCEPTION),
7294
7295 TEST_c_c (csin, 4.625, plus_infty, minus_infty, minus_infty),
7296 TEST_c_c (csin, 4.625, minus_infty, minus_infty, plus_infty),
7297 TEST_c_c (csin, -4.625, plus_infty, plus_infty, minus_infty),
7298 TEST_c_c (csin, -4.625, minus_infty, plus_infty, plus_infty),
7299
7300 TEST_c_c (csin, qnan_value, 0.0, qnan_value, 0.0, IGNORE_ZERO_INF_SIGN),
7301 TEST_c_c (csin, qnan_value, minus_zero, qnan_value, 0.0, IGNORE_ZERO_INF_SIGN),
7302
7303 TEST_c_c (csin, qnan_value, plus_infty, qnan_value, plus_infty, IGNORE_ZERO_INF_SIGN),
7304 TEST_c_c (csin, qnan_value, minus_infty, qnan_value, plus_infty, IGNORE_ZERO_INF_SIGN),
7305
7306 TEST_c_c (csin, qnan_value, 9.0, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
7307 TEST_c_c (csin, qnan_value, -9.0, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
7308
7309 TEST_c_c (csin, 0.0, qnan_value, 0.0, qnan_value),
7310 TEST_c_c (csin, minus_zero, qnan_value, minus_zero, qnan_value),
7311
7312 TEST_c_c (csin, 10.0, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
7313 TEST_c_c (csin, qnan_value, -10.0, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
7314
7315 TEST_c_c (csin, plus_infty, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
7316 TEST_c_c (csin, minus_infty, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
7317
7318 TEST_c_c (csin, qnan_value, qnan_value, qnan_value, qnan_value),
7319
7320 TEST_c_c (csin, 0.75L, 1.25L, 1.28722291002649188575873510790565441L, 1.17210635989270256101081285116138863L),
7321 TEST_c_c (csin, -2, -3, -9.15449914691142957346729954460983256L, 4.16890695996656435075481305885375484L),
7322
7323 TEST_c_c (csin, 0.75, 89.5, 2.522786001038096774676288412995370563339e38L, 2.708024460708609732016532185663087200560e38L),
7324 TEST_c_c (csin, 0.75, -89.5, 2.522786001038096774676288412995370563339e38L, -2.708024460708609732016532185663087200560e38L),
7325 TEST_c_c (csin, -0.75, 89.5, -2.522786001038096774676288412995370563339e38L, 2.708024460708609732016532185663087200560e38L),
7326 TEST_c_c (csin, -0.75, -89.5, -2.522786001038096774676288412995370563339e38L, -2.708024460708609732016532185663087200560e38L),
7327
7328 #ifndef TEST_FLOAT
7329 TEST_c_c (csin, 0.75, 710.5, 1.255317763348154410745082950806112487736e308L, 1.347490911916428129246890157395342279438e308L),
7330 TEST_c_c (csin, 0.75, -710.5, 1.255317763348154410745082950806112487736e308L, -1.347490911916428129246890157395342279438e308L),
7331 TEST_c_c (csin, -0.75, 710.5, -1.255317763348154410745082950806112487736e308L, 1.347490911916428129246890157395342279438e308L),
7332 TEST_c_c (csin, -0.75, -710.5, -1.255317763348154410745082950806112487736e308L, -1.347490911916428129246890157395342279438e308L),
7333 #endif
7334
7335 #if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
7336 TEST_c_c (csin, 0.75, 11357.25, 8.385498349388321535962327491346664141020e4931L, 9.001213196851067077465606717616495588201e4931L),
7337 TEST_c_c (csin, 0.75, -11357.25, 8.385498349388321535962327491346664141020e4931L, -9.001213196851067077465606717616495588201e4931L),
7338 TEST_c_c (csin, -0.75, 11357.25, -8.385498349388321535962327491346664141020e4931L, 9.001213196851067077465606717616495588201e4931L),
7339 TEST_c_c (csin, -0.75, -11357.25, -8.385498349388321535962327491346664141020e4931L, -9.001213196851067077465606717616495588201e4931L),
7340 #endif
7341
7342 #ifdef TEST_FLOAT
7343 TEST_c_c (csin, 0x1p-149, 180, 1.043535896672617552965983803453927655332e33L, plus_infty, OVERFLOW_EXCEPTION),
7344 #endif
7345
7346 #if defined TEST_DOUBLE || (defined TEST_LDOUBLE && LDBL_MAX_EXP == 1024)
7347 TEST_c_c (csin, 0x1p-1074, 1440, 5.981479269486130556466515778180916082415e301L, plus_infty, OVERFLOW_EXCEPTION),
7348 #endif
7349
7350 #if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
7351 TEST_c_c (csin, 0x1p-16434L, 22730, 1.217853148905605987081057582351152052687e4924L, plus_infty, OVERFLOW_EXCEPTION),
7352 #endif
7353
7354 TEST_c_c (csin, min_subnorm_value, min_value, min_subnorm_value, min_value, UNDERFLOW_EXCEPTION),
7355 TEST_c_c (csin, min_value, min_subnorm_value, min_value, min_subnorm_value, UNDERFLOW_EXCEPTION),
7356 END_DATA (csin)
7357 };
7358
7359 static void
7360 csin_test (void)
7361 {
7362 errno = 0;
7363 FUNC(csin) (BUILD_COMPLEX (0.7L, 1.2L));
7364 if (errno == ENOSYS)
7365 /* Function not implemented. */
7366 return;
7367
7368 START (csin);
7369 RUN_TEST_LOOP_c_c (csin, csin_test_data, );
7370 END (csin, complex);
7371 }
7372
7373
7374 static const struct test_c_c_data csinh_test_data[] =
7375 {
7376 START_DATA (csinh),
7377 TEST_c_c (csinh, 0.0, 0.0, 0.0, 0.0),
7378 TEST_c_c (csinh, minus_zero, 0.0, minus_zero, 0.0),
7379 TEST_c_c (csinh, 0.0, minus_zero, 0.0, minus_zero),
7380 TEST_c_c (csinh, minus_zero, minus_zero, minus_zero, minus_zero),
7381
7382 TEST_c_c (csinh, 0.0, plus_infty, 0.0, qnan_value, INVALID_EXCEPTION|IGNORE_ZERO_INF_SIGN),
7383 TEST_c_c (csinh, minus_zero, plus_infty, 0.0, qnan_value, INVALID_EXCEPTION|IGNORE_ZERO_INF_SIGN),
7384 TEST_c_c (csinh, 0.0, minus_infty, 0.0, qnan_value, INVALID_EXCEPTION|IGNORE_ZERO_INF_SIGN),
7385 TEST_c_c (csinh, minus_zero, minus_infty, 0.0, qnan_value, INVALID_EXCEPTION|IGNORE_ZERO_INF_SIGN),
7386
7387 TEST_c_c (csinh, plus_infty, 0.0, plus_infty, 0.0),
7388 TEST_c_c (csinh, minus_infty, 0.0, minus_infty, 0.0),
7389 TEST_c_c (csinh, plus_infty, minus_zero, plus_infty, minus_zero),
7390 TEST_c_c (csinh, minus_infty, minus_zero, minus_infty, minus_zero),
7391
7392 TEST_c_c (csinh, plus_infty, plus_infty, plus_infty, qnan_value, INVALID_EXCEPTION|IGNORE_ZERO_INF_SIGN),
7393 TEST_c_c (csinh, minus_infty, plus_infty, plus_infty, qnan_value, INVALID_EXCEPTION|IGNORE_ZERO_INF_SIGN),
7394 TEST_c_c (csinh, plus_infty, minus_infty, plus_infty, qnan_value, INVALID_EXCEPTION|IGNORE_ZERO_INF_SIGN),
7395 TEST_c_c (csinh, minus_infty, minus_infty, plus_infty, qnan_value, INVALID_EXCEPTION|IGNORE_ZERO_INF_SIGN),
7396
7397 TEST_c_c (csinh, plus_infty, 4.625, minus_infty, minus_infty),
7398 TEST_c_c (csinh, minus_infty, 4.625, plus_infty, minus_infty),
7399 TEST_c_c (csinh, plus_infty, -4.625, minus_infty, plus_infty),
7400 TEST_c_c (csinh, minus_infty, -4.625, plus_infty, plus_infty),
7401
7402 TEST_c_c (csinh, 6.75, plus_infty, qnan_value, qnan_value, INVALID_EXCEPTION),
7403 TEST_c_c (csinh, -6.75, plus_infty, qnan_value, qnan_value, INVALID_EXCEPTION),
7404 TEST_c_c (csinh, 6.75, minus_infty, qnan_value, qnan_value, INVALID_EXCEPTION),
7405 TEST_c_c (csinh, -6.75, minus_infty, qnan_value, qnan_value, INVALID_EXCEPTION),
7406
7407 TEST_c_c (csinh, 0.0, qnan_value, 0.0, qnan_value, IGNORE_ZERO_INF_SIGN),
7408 TEST_c_c (csinh, minus_zero, qnan_value, 0.0, qnan_value, IGNORE_ZERO_INF_SIGN),
7409
7410 TEST_c_c (csinh, plus_infty, qnan_value, plus_infty, qnan_value, IGNORE_ZERO_INF_SIGN),
7411 TEST_c_c (csinh, minus_infty, qnan_value, plus_infty, qnan_value, IGNORE_ZERO_INF_SIGN),
7412
7413 TEST_c_c (csinh, 9.0, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
7414 TEST_c_c (csinh, -9.0, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
7415
7416 TEST_c_c (csinh, qnan_value, 0.0, qnan_value, 0.0),
7417 TEST_c_c (csinh, qnan_value, minus_zero, qnan_value, minus_zero),
7418
7419 TEST_c_c (csinh, qnan_value, 10.0, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
7420 TEST_c_c (csinh, qnan_value, -10.0, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
7421
7422 TEST_c_c (csinh, qnan_value, plus_infty, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
7423 TEST_c_c (csinh, qnan_value, minus_infty, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
7424
7425 TEST_c_c (csinh, qnan_value, qnan_value, qnan_value, qnan_value),
7426
7427 TEST_c_c (csinh, 0.75L, 1.25L, 0.259294854551162779153349830618433028L, 1.22863452409509552219214606515777594L),
7428 TEST_c_c (csinh, -2, -3, 3.59056458998577995201256544779481679L, -0.530921086248519805267040090660676560L),
7429
7430 TEST_c_c (csinh, 89.5, 0.75, 2.708024460708609732016532185663087200560e38L, 2.522786001038096774676288412995370563339e38L),
7431 TEST_c_c (csinh, -89.5, 0.75, -2.708024460708609732016532185663087200560e38L, 2.522786001038096774676288412995370563339e38L),
7432 TEST_c_c (csinh, 89.5, -0.75, 2.708024460708609732016532185663087200560e38L, -2.522786001038096774676288412995370563339e38L),
7433 TEST_c_c (csinh, -89.5, -0.75, -2.708024460708609732016532185663087200560e38L, -2.522786001038096774676288412995370563339e38L),
7434
7435 #ifndef TEST_FLOAT
7436 TEST_c_c (csinh, 710.5, 0.75, 1.347490911916428129246890157395342279438e308L, 1.255317763348154410745082950806112487736e308L),
7437 TEST_c_c (csinh, -710.5, 0.75, -1.347490911916428129246890157395342279438e308L, 1.255317763348154410745082950806112487736e308L),
7438 TEST_c_c (csinh, 710.5, -0.75, 1.347490911916428129246890157395342279438e308L, -1.255317763348154410745082950806112487736e308L),
7439 TEST_c_c (csinh, -710.5, -0.75, -1.347490911916428129246890157395342279438e308L, -1.255317763348154410745082950806112487736e308L),
7440 #endif
7441
7442 #if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
7443 TEST_c_c (csinh, 11357.25, 0.75, 9.001213196851067077465606717616495588201e4931L, 8.385498349388321535962327491346664141020e4931L),
7444 TEST_c_c (csinh, -11357.25, 0.75, -9.001213196851067077465606717616495588201e4931L, 8.385498349388321535962327491346664141020e4931L),
7445 TEST_c_c (csinh, 11357.25, -0.75, 9.001213196851067077465606717616495588201e4931L, -8.385498349388321535962327491346664141020e4931L),
7446 TEST_c_c (csinh, -11357.25, -0.75, -9.001213196851067077465606717616495588201e4931L, -8.385498349388321535962327491346664141020e4931L),
7447 #endif
7448
7449 #ifdef TEST_FLOAT
7450 TEST_c_c (csinh, 180, 0x1p-149, plus_infty, 1.043535896672617552965983803453927655332e33L, OVERFLOW_EXCEPTION),
7451 #endif
7452
7453 #if defined TEST_DOUBLE || (defined TEST_LDOUBLE && LDBL_MAX_EXP == 1024)
7454 TEST_c_c (csinh, 1440, 0x1p-1074, plus_infty, 5.981479269486130556466515778180916082415e301L, OVERFLOW_EXCEPTION),
7455 #endif
7456
7457 #if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
7458 TEST_c_c (csinh, 22730, 0x1p-16434L, plus_infty, 1.217853148905605987081057582351152052687e4924L, OVERFLOW_EXCEPTION),
7459 #endif
7460
7461 TEST_c_c (csinh, min_subnorm_value, min_value, min_subnorm_value, min_value, UNDERFLOW_EXCEPTION),
7462 TEST_c_c (csinh, min_value, min_subnorm_value, min_value, min_subnorm_value, UNDERFLOW_EXCEPTION),
7463 END_DATA (csinh)
7464 };
7465
7466 static void
7467 csinh_test (void)
7468 {
7469 errno = 0;
7470 FUNC(csinh) (BUILD_COMPLEX (0.7L, 1.2L));
7471 if (errno == ENOSYS)
7472 /* Function not implemented. */
7473 return;
7474
7475 START (csinh);
7476 RUN_TEST_LOOP_c_c (csinh, csinh_test_data, );
7477 END (csinh, complex);
7478 }
7479
7480
7481 static const struct test_c_c_data csqrt_test_data[] =
7482 {
7483 START_DATA (csqrt),
7484 TEST_c_c (csqrt, 0, 0, 0.0, 0.0),
7485 TEST_c_c (csqrt, 0, minus_zero, 0, minus_zero),
7486 TEST_c_c (csqrt, minus_zero, 0, 0.0, 0.0),
7487 TEST_c_c (csqrt, minus_zero, minus_zero, 0.0, minus_zero),
7488
7489 TEST_c_c (csqrt, minus_infty, 0, 0.0, plus_infty),
7490 TEST_c_c (csqrt, minus_infty, 6, 0.0, plus_infty),
7491 TEST_c_c (csqrt, minus_infty, minus_zero, 0.0, minus_infty),
7492 TEST_c_c (csqrt, minus_infty, -6, 0.0, minus_infty),
7493
7494 TEST_c_c (csqrt, plus_infty, 0, plus_infty, 0.0),
7495 TEST_c_c (csqrt, plus_infty, 6, plus_infty, 0.0),
7496 TEST_c_c (csqrt, plus_infty, minus_zero, plus_infty, minus_zero),
7497 TEST_c_c (csqrt, plus_infty, -6, plus_infty, minus_zero),
7498
7499 TEST_c_c (csqrt, 0, plus_infty, plus_infty, plus_infty),
7500 TEST_c_c (csqrt, 4, plus_infty, plus_infty, plus_infty),
7501 TEST_c_c (csqrt, plus_infty, plus_infty, plus_infty, plus_infty),
7502 TEST_c_c (csqrt, minus_zero, plus_infty, plus_infty, plus_infty),
7503 TEST_c_c (csqrt, -4, plus_infty, plus_infty, plus_infty),
7504 TEST_c_c (csqrt, minus_infty, plus_infty, plus_infty, plus_infty),
7505 TEST_c_c (csqrt, 0, minus_infty, plus_infty, minus_infty),
7506 TEST_c_c (csqrt, 4, minus_infty, plus_infty, minus_infty),
7507 TEST_c_c (csqrt, plus_infty, minus_infty, plus_infty, minus_infty),
7508 TEST_c_c (csqrt, minus_zero, minus_infty, plus_infty, minus_infty),
7509 TEST_c_c (csqrt, -4, minus_infty, plus_infty, minus_infty),
7510 TEST_c_c (csqrt, minus_infty, minus_infty, plus_infty, minus_infty),
7511
7512 TEST_c_c (csqrt, minus_infty, qnan_value, qnan_value, plus_infty, IGNORE_ZERO_INF_SIGN),
7513
7514 TEST_c_c (csqrt, plus_infty, qnan_value, plus_infty, qnan_value),
7515
7516 TEST_c_c (csqrt, 0, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
7517 TEST_c_c (csqrt, 1, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
7518 TEST_c_c (csqrt, minus_zero, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
7519 TEST_c_c (csqrt, -1, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
7520
7521 TEST_c_c (csqrt, qnan_value, 0, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
7522 TEST_c_c (csqrt, qnan_value, 8, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
7523 TEST_c_c (csqrt, qnan_value, minus_zero, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
7524 TEST_c_c (csqrt, qnan_value, -8, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
7525
7526 TEST_c_c (csqrt, qnan_value, qnan_value, qnan_value, qnan_value),
7527
7528 TEST_c_c (csqrt, 16.0, -30.0, 5.0, -3.0),
7529 TEST_c_c (csqrt, -1, 0, 0.0, 1.0),
7530 TEST_c_c (csqrt, 0, 2, 1.0, 1.0),
7531 TEST_c_c (csqrt, 119, 120, 12.0, 5.0),
7532 TEST_c_c (csqrt, 0.75L, 1.25L, 1.05065169626078392338656675760808326L, 0.594868882070379067881984030639932657L),
7533 TEST_c_c (csqrt, -2, -3, 0.89597747612983812471573375529004348L, -1.6741492280355400404480393008490519L),
7534 TEST_c_c (csqrt, -2, 3, 0.89597747612983812471573375529004348L, 1.6741492280355400404480393008490519L),
7535 /* Principal square root should be returned (i.e., non-negative real
7536 part). */
7537 TEST_c_c (csqrt, 0, -1, M_SQRT1_2l, -M_SQRT1_2l),
7538
7539 TEST_c_c (csqrt, 0x1.fffffep+127L, 0x1.fffffep+127L, 2.026714405498316804978751017492482558075e+19L, 8.394925938143272988211878516208015586281e+18L),
7540 TEST_c_c (csqrt, 0x1.fffffep+127L, 1.0L, 1.844674352395372953599975585936590505260e+19L, 2.710505511993121390769065968615872097053e-20L),
7541 TEST_c_c (csqrt, 0x1p-149L, 0x1p-149L, 4.112805464342778798097003462770175200803e-23L, 1.703579802732953750368659735601389709551e-23L),
7542 TEST_c_c (csqrt, 0x1p-147L, 0x1p-147L, 8.225610928685557596194006925540350401606e-23L, 3.407159605465907500737319471202779419102e-23L),
7543
7544 TEST_c_c (csqrt, plus_zero, 0x1p-149L, 2.646977960169688559588507814623881131411e-23L, 2.646977960169688559588507814623881131411e-23L),
7545 TEST_c_c (csqrt, 0x1p-50L, 0x1p-149L, 2.980232238769531250000000000000000000000e-8L, 2.350988701644575015937473074444491355637e-38L),
7546 #ifdef TEST_FLOAT
7547 TEST_c_c (csqrt, 0x1p+127L, 0x1p-149L, 1.304381782533278221234957180625250836888e19L, plus_zero, UNDERFLOW_EXCEPTION),
7548 #endif
7549 TEST_c_c (csqrt, 0x1p-149L, 0x1p+127L, 9.223372036854775808000000000000000000000e18L, 9.223372036854775808000000000000000000000e18L),
7550 TEST_c_c (csqrt, 0x1.000002p-126L, 0x1.000002p-126L, 1.191195773697904627170323731331667740087e-19L, 4.934094449071842328766868579214125217132e-20L),
7551 TEST_c_c (csqrt, -0x1.000002p-126L, -0x1.000002p-126L, 4.934094449071842328766868579214125217132e-20L, -1.191195773697904627170323731331667740087e-19L),
7552
7553 #ifndef TEST_FLOAT
7554 TEST_c_c (csqrt, 0x1.fffffffffffffp+1023L, 0x1.fffffffffffffp+1023L, 1.473094556905565378990473658199034571917e+154L, 6.101757441282702188537080005372547713595e+153L),
7555 TEST_c_c (csqrt, 0x1.fffffffffffffp+1023L, 0x1p+1023L, 1.379778091031440685006200821918878702861e+154L, 3.257214233483129514781233066898042490248e+153L),
7556 TEST_c_c (csqrt, 0x1p-1074L, 0x1p-1074L, 2.442109726130830256743814843868934877597e-162L, 1.011554969366634726113090867589031782487e-162L),
7557 TEST_c_c (csqrt, 0x1p-1073L, 0x1p-1073L, 3.453664695497464982856905711457966660085e-162L, 1.430554756764195530630723976279903095110e-162L),
7558
7559 TEST_c_c (csqrt, plus_zero, 0x1p-1074L, 1.571727784702628688909515672805082228285e-162L, 1.571727784702628688909515672805082228285e-162L),
7560 TEST_c_c (csqrt, 0x1p-500L, 0x1p-1074L, 5.527147875260444560247265192192255725514e-76L, 4.469444793151709302716387622440056066334e-249L),
7561 #if defined TEST_DOUBLE || (defined TEST_LDOUBLE && LDBL_MAX_EXP == 1024)
7562 TEST_c_c (csqrt, 0x1p+1023L, 0x1p-1074L, 9.480751908109176726832526455652159260085e153L, plus_zero, UNDERFLOW_EXCEPTION),
7563 #endif
7564 TEST_c_c (csqrt, 0x1p-1074L, 0x1p+1023L, 6.703903964971298549787012499102923063740e153L, 6.703903964971298549787012499102923063740e153L),
7565 TEST_c_c (csqrt, 0x1.0000000000001p-1022L, 0x1.0000000000001p-1022L, 1.638872094839911521020410942677082920935e-154L, 6.788430486774966350907249113759995429568e-155L),
7566 TEST_c_c (csqrt, -0x1.0000000000001p-1022L, -0x1.0000000000001p-1022L, 6.788430486774966350907249113759995429568e-155L, -1.638872094839911521020410942677082920935e-154L),
7567 #endif
7568
7569 #if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
7570 TEST_c_c (csqrt, 0x1.fp+16383L, 0x1.fp+16383L, 1.179514222452201722651836720466795901016e+2466L, 4.885707879516577666702435054303191575148e+2465L),
7571 TEST_c_c (csqrt, 0x1.fp+16383L, 0x1p+16383L, 1.106698967236475180613254276996359485630e+2466L, 2.687568007603946993388538156299100955642e+2465L),
7572 TEST_c_c (csqrt, 0x1p-16440L, 0x1p-16441L, 3.514690655930285351254618340783294558136e-2475L, 8.297059146828716918029689466551384219370e-2476L),
7573
7574 TEST_c_c (csqrt, plus_zero, 0x1p-16445L, 4.269191686890197837775136325621239761720e-2476L, 4.269191686890197837775136325621239761720e-2476L),
7575 TEST_c_c (csqrt, 0x1p-5000L, 0x1p-16445L, 2.660791472672778409283210520357607795518e-753L, 6.849840675828785164910701384823702064234e-4199L),
7576 TEST_c_c (csqrt, 0x1p+16383L, 0x1p-16445L, 7.712754032630730034273323365543179095045e2465L, plus_zero, UNDERFLOW_EXCEPTION),
7577 TEST_c_c (csqrt, 0x1p-16445L, 0x1p+16383L, 5.453740678097079647314921223668914312241e2465L, 5.453740678097079647314921223668914312241e2465L),
7578 TEST_c_c (csqrt, 0x1.0000000000000002p-16382L, 0x1.0000000000000002p-16382L, 2.014551439675644900131815801350165472778e-2466L, 8.344545284118961664300307045791497724440e-2467L),
7579 TEST_c_c (csqrt, -0x1.0000000000000002p-16382L, -0x1.0000000000000002p-16382L, 8.344545284118961664300307045791497724440e-2467L, -2.014551439675644900131815801350165472778e-2466L),
7580
7581 # if LDBL_MANT_DIG >= 113
7582 TEST_c_c (csqrt, plus_zero, 0x1p-16494L, 1.799329752913293143453817328207572571442e-2483L, 1.799329752913293143453817328207572571442e-2483L),
7583 TEST_c_c (csqrt, 0x1p-5000L, 0x1p-16494L, 2.660791472672778409283210520357607795518e-753L, 1.216776133331049643422030716668249905907e-4213L),
7584 TEST_c_c (csqrt, 0x1p+16383L, 0x1p-16494L, 7.712754032630730034273323365543179095045e2465L, plus_zero, UNDERFLOW_EXCEPTION),
7585 TEST_c_c (csqrt, 0x1p-16494L, 0x1p+16383L, 5.453740678097079647314921223668914312241e2465L, 5.453740678097079647314921223668914312241e2465L),
7586 TEST_c_c (csqrt, 0x1.0000000000000000000000000001p-16382L, 0x1.0000000000000000000000000001p-16382L, 2.014551439675644900022606748976158925145e-2466L, 8.344545284118961663847948339519226074126e-2467L),
7587 TEST_c_c (csqrt, -0x1.0000000000000000000000000001p-16382L, -0x1.0000000000000000000000000001p-16382L, 8.344545284118961663847948339519226074126e-2467L, -2.014551439675644900022606748976158925145e-2466L),
7588 # endif
7589 #endif
7590 END_DATA (csqrt)
7591 };
7592
7593 static void
7594 csqrt_test (void)
7595 {
7596 errno = 0;
7597 FUNC(csqrt) (BUILD_COMPLEX (-1, 0));
7598 if (errno == ENOSYS)
7599 /* Function not implemented. */
7600 return;
7601
7602 START (csqrt);
7603 RUN_TEST_LOOP_c_c (csqrt, csqrt_test_data, );
7604 END (csqrt, complex);
7605 }
7606
7607 static const struct test_c_c_data ctan_test_data[] =
7608 {
7609 START_DATA (ctan),
7610 TEST_c_c (ctan, 0, 0, 0.0, 0.0),
7611 TEST_c_c (ctan, 0, minus_zero, 0.0, minus_zero),
7612 TEST_c_c (ctan, minus_zero, 0, minus_zero, 0.0),
7613 TEST_c_c (ctan, minus_zero, minus_zero, minus_zero, minus_zero),
7614
7615 TEST_c_c (ctan, 0, plus_infty, 0.0, 1.0),
7616 TEST_c_c (ctan, 1, plus_infty, 0.0, 1.0),
7617 TEST_c_c (ctan, minus_zero, plus_infty, minus_zero, 1.0),
7618 TEST_c_c (ctan, -1, plus_infty, minus_zero, 1.0),
7619
7620 TEST_c_c (ctan, 0, minus_infty, 0.0, -1.0),
7621 TEST_c_c (ctan, 1, minus_infty, 0.0, -1.0),
7622 TEST_c_c (ctan, minus_zero, minus_infty, minus_zero, -1.0),
7623 TEST_c_c (ctan, -1, minus_infty, minus_zero, -1.0),
7624
7625 TEST_c_c (ctan, plus_infty, 0, qnan_value, qnan_value, INVALID_EXCEPTION),
7626 TEST_c_c (ctan, plus_infty, 2, qnan_value, qnan_value, INVALID_EXCEPTION),
7627 TEST_c_c (ctan, minus_infty, 0, qnan_value, qnan_value, INVALID_EXCEPTION),
7628 TEST_c_c (ctan, minus_infty, 2, qnan_value, qnan_value, INVALID_EXCEPTION),
7629 TEST_c_c (ctan, plus_infty, minus_zero, qnan_value, qnan_value, INVALID_EXCEPTION),
7630 TEST_c_c (ctan, plus_infty, -2, qnan_value, qnan_value, INVALID_EXCEPTION),
7631 TEST_c_c (ctan, minus_infty, minus_zero, qnan_value, qnan_value, INVALID_EXCEPTION),
7632 TEST_c_c (ctan, minus_infty, -2, qnan_value, qnan_value, INVALID_EXCEPTION),
7633
7634 TEST_c_c (ctan, qnan_value, plus_infty, 0.0, 1.0, IGNORE_ZERO_INF_SIGN),
7635 TEST_c_c (ctan, qnan_value, minus_infty, 0.0, -1.0, IGNORE_ZERO_INF_SIGN),
7636
7637 TEST_c_c (ctan, 0, qnan_value, 0.0, qnan_value),
7638 TEST_c_c (ctan, minus_zero, qnan_value, minus_zero, qnan_value),
7639
7640 TEST_c_c (ctan, 0.5, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
7641 TEST_c_c (ctan, -4.5, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
7642
7643 TEST_c_c (ctan, qnan_value, 0, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
7644 TEST_c_c (ctan, qnan_value, 5, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
7645 TEST_c_c (ctan, qnan_value, minus_zero, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
7646 TEST_c_c (ctan, qnan_value, -0.25, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
7647
7648 TEST_c_c (ctan, qnan_value, qnan_value, qnan_value, qnan_value),
7649
7650 TEST_c_c (ctan, 0.75L, 1.25L, 0.160807785916206426725166058173438663L, 0.975363285031235646193581759755216379L),
7651 TEST_c_c (ctan, -2, -3, 0.376402564150424829275122113032269084e-2L, -1.00323862735360980144635859782192726L),
7652
7653 TEST_c_c (ctan, 1, 45, 1.490158918874345552942703234806348520895e-39L, 1.000000000000000000000000000000000000001L, UNDERFLOW_EXCEPTION_FLOAT),
7654 TEST_c_c (ctan, 1, 47, 2.729321264492904590777293425576722354636e-41L, 1.0, UNDERFLOW_EXCEPTION_FLOAT),
7655
7656 #ifndef TEST_FLOAT
7657 TEST_c_c (ctan, 1, 355, 8.140551093483276762350406321792653551513e-309L, 1.0, UNDERFLOW_EXCEPTION_DOUBLE),
7658 TEST_c_c (ctan, 1, 365, 1.677892637497921890115075995898773550884e-317L, 1.0, UNDERFLOW_EXCEPTION_DOUBLE),
7659 #endif
7660
7661 #if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
7662 TEST_c_c (ctan, 1, 5680, 4.725214596136812019616700920476949798307e-4934L, 1.0, UNDERFLOW_EXCEPTION),
7663 TEST_c_c (ctan, 1, 5690, 9.739393181626937151720816611272607059057e-4943L, 1.0, UNDERFLOW_EXCEPTION),
7664 #endif
7665
7666 TEST_c_c (ctan, 0x3.243f6cp-1, 0, -2.287733242885645987394874673945769518150e7L, 0.0),
7667
7668 TEST_c_c (ctan, 0x1p127, 1, 0.2446359391192790896381501310437708987204L, 0.9101334047676183761532873794426475906201L),
7669
7670 #ifndef TEST_FLOAT
7671 TEST_c_c (ctan, 0x1p1023, 1, -0.2254627924997545057926782581695274244229L, 0.8786063118883068695462540226219865087189L),
7672 #endif
7673
7674 #if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
7675 TEST_c_c (ctan, 0x1p16383L, 1, 0.1608598776370396607204448234354670036772L, 0.8133818522051542536316746743877629761488L),
7676 #endif
7677
7678 TEST_c_c (ctan, 50000, 50000, plus_zero, 1.0, UNDERFLOW_EXCEPTION),
7679 TEST_c_c (ctan, 50000, -50000, plus_zero, -1.0, UNDERFLOW_EXCEPTION),
7680 TEST_c_c (ctan, -50000, 50000, minus_zero, 1.0, UNDERFLOW_EXCEPTION),
7681 TEST_c_c (ctan, -50000, -50000, minus_zero, -1.0, UNDERFLOW_EXCEPTION),
7682 END_DATA (ctan)
7683 };
7684
7685 static void
7686 ctan_test (void)
7687 {
7688 errno = 0;
7689 FUNC(ctan) (BUILD_COMPLEX (0.7L, 1.2L));
7690 if (errno == ENOSYS)
7691 /* Function not implemented. */
7692 return;
7693
7694 START (ctan);
7695 RUN_TEST_LOOP_c_c (ctan, ctan_test_data, );
7696 END (ctan, complex);
7697 }
7698
7699
7700 static const struct test_c_c_data ctan_tonearest_test_data[] =
7701 {
7702 START_DATA (ctan_tonearest),
7703 TEST_c_c (ctan, 0x1.921fb6p+0, 0x1p-149, -2.287733242885645987394874673945769518150e7L, 7.334008549954377778731880988481078535821e-31L),
7704
7705 #ifndef TEST_FLOAT
7706 TEST_c_c (ctan, 0x1.921fb54442d18p+0, 0x1p-1074, 1.633123935319536975596773704152891653086e16L, 1.317719414943508315995636961402669067843e-291L),
7707 #endif
7708
7709 #if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
7710 TEST_c_c (ctan, 0x1.921fb54442d1846ap+0L, 0x1p-16445L, -3.986797629811710706723242948653362815645e19L, 5.793882568875674066286163141055208625180e-4912L),
7711 #endif
7712 END_DATA (ctan_tonearest)
7713 };
7714
7715 static void
7716 ctan_test_tonearest (void)
7717 {
7718 errno = 0;
7719 FUNC(ctan) (BUILD_COMPLEX (0.7L, 1.2L));
7720 if (errno == ENOSYS)
7721 /* Function not implemented. */
7722 return;
7723
7724 START (ctan_tonearest);
7725 RUN_TEST_LOOP_c_c (ctan, ctan_tonearest_test_data, FE_TONEAREST);
7726 END (ctan_tonearest, complex);
7727 }
7728
7729
7730 static const struct test_c_c_data ctan_towardzero_test_data[] =
7731 {
7732 START_DATA (ctan_towardzero),
7733 TEST_c_c (ctan, 0x1.921fb6p+0, 0x1p-149, -2.287733242885645987394874673945769518150e7L, 7.334008549954377778731880988481078535821e-31L),
7734
7735 #ifndef TEST_FLOAT
7736 TEST_c_c (ctan, 0x1.921fb54442d18p+0, 0x1p-1074, 1.633123935319536975596773704152891653086e16L, 1.317719414943508315995636961402669067843e-291L),
7737 #endif
7738
7739 #if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
7740 TEST_c_c (ctan, 0x1.921fb54442d1846ap+0L, 0x1p-16445L, -3.986797629811710706723242948653362815645e19L, 5.793882568875674066286163141055208625180e-4912L),
7741 #endif
7742 END_DATA (ctan_towardzero)
7743 };
7744
7745 static void
7746 ctan_test_towardzero (void)
7747 {
7748 errno = 0;
7749 FUNC(ctan) (BUILD_COMPLEX (0.7L, 1.2L));
7750 if (errno == ENOSYS)
7751 /* Function not implemented. */
7752 return;
7753
7754 START (ctan_towardzero);
7755 RUN_TEST_LOOP_c_c (ctan, ctan_towardzero_test_data, FE_TOWARDZERO);
7756 END (ctan_towardzero, complex);
7757 }
7758
7759
7760 static const struct test_c_c_data ctan_downward_test_data[] =
7761 {
7762 START_DATA (ctan_downward),
7763 TEST_c_c (ctan, 0x1.921fb6p+0, 0x1p-149, -2.287733242885645987394874673945769518150e7L, 7.334008549954377778731880988481078535821e-31L),
7764
7765 #ifndef TEST_FLOAT
7766 TEST_c_c (ctan, 0x1.921fb54442d18p+0, 0x1p-1074, 1.633123935319536975596773704152891653086e16L, 1.317719414943508315995636961402669067843e-291L),
7767 #endif
7768
7769 #if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
7770 TEST_c_c (ctan, 0x1.921fb54442d1846ap+0L, 0x1p-16445L, -3.986797629811710706723242948653362815645e19L, 5.793882568875674066286163141055208625180e-4912L),
7771 #endif
7772 END_DATA (ctan_downward)
7773 };
7774
7775 static void
7776 ctan_test_downward (void)
7777 {
7778 errno = 0;
7779 FUNC(ctan) (BUILD_COMPLEX (0.7L, 1.2L));
7780 if (errno == ENOSYS)
7781 /* Function not implemented. */
7782 return;
7783
7784 START (ctan_downward);
7785 RUN_TEST_LOOP_c_c (ctan, ctan_downward_test_data, FE_DOWNWARD);
7786 END (ctan_downward, complex);
7787 }
7788
7789
7790 static const struct test_c_c_data ctan_upward_test_data[] =
7791 {
7792 START_DATA (ctan_upward),
7793 TEST_c_c (ctan, 0x1.921fb6p+0, 0x1p-149, -2.287733242885645987394874673945769518150e7L, 7.334008549954377778731880988481078535821e-31L),
7794
7795 #ifndef TEST_FLOAT
7796 TEST_c_c (ctan, 0x1.921fb54442d18p+0, 0x1p-1074, 1.633123935319536975596773704152891653086e16L, 1.317719414943508315995636961402669067843e-291L),
7797 #endif
7798
7799 #if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
7800 TEST_c_c (ctan, 0x1.921fb54442d1846ap+0L, 0x1p-16445L, -3.986797629811710706723242948653362815645e19L, 5.793882568875674066286163141055208625180e-4912L),
7801 #endif
7802 END_DATA (ctan_upward)
7803 };
7804
7805 static void
7806 ctan_test_upward (void)
7807 {
7808 errno = 0;
7809 FUNC(ctan) (BUILD_COMPLEX (0.7L, 1.2L));
7810 if (errno == ENOSYS)
7811 /* Function not implemented. */
7812 return;
7813
7814 START (ctan_upward);
7815 RUN_TEST_LOOP_c_c (ctan, ctan_upward_test_data, FE_UPWARD);
7816 END (ctan_upward, complex);
7817 }
7818
7819
7820 static const struct test_c_c_data ctanh_test_data[] =
7821 {
7822 START_DATA (ctanh),
7823 TEST_c_c (ctanh, 0, 0, 0.0, 0.0),
7824 TEST_c_c (ctanh, 0, minus_zero, 0.0, minus_zero),
7825 TEST_c_c (ctanh, minus_zero, 0, minus_zero, 0.0),
7826 TEST_c_c (ctanh, minus_zero, minus_zero, minus_zero, minus_zero),
7827
7828 TEST_c_c (ctanh, plus_infty, 0, 1.0, 0.0),
7829 TEST_c_c (ctanh, plus_infty, 1, 1.0, 0.0),
7830 TEST_c_c (ctanh, plus_infty, minus_zero, 1.0, minus_zero),
7831 TEST_c_c (ctanh, plus_infty, -1, 1.0, minus_zero),
7832 TEST_c_c (ctanh, minus_infty, 0, -1.0, 0.0),
7833 TEST_c_c (ctanh, minus_infty, 1, -1.0, 0.0),
7834 TEST_c_c (ctanh, minus_infty, minus_zero, -1.0, minus_zero),
7835 TEST_c_c (ctanh, minus_infty, -1, -1.0, minus_zero),
7836
7837 TEST_c_c (ctanh, 0, plus_infty, qnan_value, qnan_value, INVALID_EXCEPTION),
7838 TEST_c_c (ctanh, 2, plus_infty, qnan_value, qnan_value, INVALID_EXCEPTION),
7839 TEST_c_c (ctanh, 0, minus_infty, qnan_value, qnan_value, INVALID_EXCEPTION),
7840 TEST_c_c (ctanh, 2, minus_infty, qnan_value, qnan_value, INVALID_EXCEPTION),
7841 TEST_c_c (ctanh, minus_zero, plus_infty, qnan_value, qnan_value, INVALID_EXCEPTION),
7842 TEST_c_c (ctanh, -2, plus_infty, qnan_value, qnan_value, INVALID_EXCEPTION),
7843 TEST_c_c (ctanh, minus_zero, minus_infty, qnan_value, qnan_value, INVALID_EXCEPTION),
7844 TEST_c_c (ctanh, -2, minus_infty, qnan_value, qnan_value, INVALID_EXCEPTION),
7845
7846 TEST_c_c (ctanh, plus_infty, qnan_value, 1.0, 0.0, IGNORE_ZERO_INF_SIGN),
7847 TEST_c_c (ctanh, minus_infty, qnan_value, -1.0, 0.0, IGNORE_ZERO_INF_SIGN),
7848
7849 TEST_c_c (ctanh, qnan_value, 0, qnan_value, 0.0),
7850 TEST_c_c (ctanh, qnan_value, minus_zero, qnan_value, minus_zero),
7851
7852 TEST_c_c (ctanh, qnan_value, 0.5, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
7853 TEST_c_c (ctanh, qnan_value, -4.5, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
7854
7855 TEST_c_c (ctanh, 0, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
7856 TEST_c_c (ctanh, 5, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
7857 TEST_c_c (ctanh, minus_zero, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
7858 TEST_c_c (ctanh, -0.25, qnan_value, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
7859
7860 TEST_c_c (ctanh, qnan_value, qnan_value, qnan_value, qnan_value),
7861
7862 TEST_c_c (ctanh, 0, M_PI_4l, 0.0, 1.0),
7863
7864 TEST_c_c (ctanh, 0.75L, 1.25L, 1.37260757053378320258048606571226857L, 0.385795952609750664177596760720790220L),
7865 TEST_c_c (ctanh, -2, -3, -0.965385879022133124278480269394560686L, 0.988437503832249372031403430350121098e-2L),
7866
7867 TEST_c_c (ctanh, 45, 1, 1.000000000000000000000000000000000000001L, 1.490158918874345552942703234806348520895e-39L, UNDERFLOW_EXCEPTION_FLOAT),
7868 TEST_c_c (ctanh, 47, 1, 1.0, 2.729321264492904590777293425576722354636e-41L, UNDERFLOW_EXCEPTION_FLOAT),
7869
7870 #ifndef TEST_FLOAT
7871 TEST_c_c (ctanh, 355, 1, 1.0, 8.140551093483276762350406321792653551513e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
7872 TEST_c_c (ctanh, 365, 1, 1.0, 1.677892637497921890115075995898773550884e-317L, UNDERFLOW_EXCEPTION_DOUBLE),
7873 #endif
7874
7875 #if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
7876 TEST_c_c (ctanh, 5680, 1, 1.0, 4.725214596136812019616700920476949798307e-4934L, UNDERFLOW_EXCEPTION),
7877 TEST_c_c (ctanh, 5690, 1, 1.0, 9.739393181626937151720816611272607059057e-4943L, UNDERFLOW_EXCEPTION),
7878 #endif
7879
7880 TEST_c_c (ctanh, 0, 0x3.243f6cp-1, 0.0, -2.287733242885645987394874673945769518150e7L),
7881
7882 TEST_c_c (ctanh, 1, 0x1p127, 0.9101334047676183761532873794426475906201L, 0.2446359391192790896381501310437708987204L),
7883
7884 #ifndef TEST_FLOAT
7885 TEST_c_c (ctanh, 1, 0x1p1023, 0.8786063118883068695462540226219865087189L, -0.2254627924997545057926782581695274244229L),
7886 #endif
7887
7888 #if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
7889 TEST_c_c (ctanh, 1, 0x1p16383L, 0.8133818522051542536316746743877629761488L, 0.1608598776370396607204448234354670036772L),
7890 #endif
7891
7892 TEST_c_c (ctanh, 50000, 50000, 1.0, plus_zero, UNDERFLOW_EXCEPTION),
7893 TEST_c_c (ctanh, 50000, -50000, 1.0, minus_zero, UNDERFLOW_EXCEPTION),
7894 TEST_c_c (ctanh, -50000, 50000, -1.0, plus_zero, UNDERFLOW_EXCEPTION),
7895 TEST_c_c (ctanh, -50000, -50000, -1.0, minus_zero, UNDERFLOW_EXCEPTION),
7896 END_DATA (ctanh)
7897 };
7898
7899 static void
7900 ctanh_test (void)
7901 {
7902 errno = 0;
7903 FUNC(ctanh) (BUILD_COMPLEX (0, 0));
7904 if (errno == ENOSYS)
7905 /* Function not implemented. */
7906 return;
7907
7908 START (ctanh);
7909 RUN_TEST_LOOP_c_c (ctanh, ctanh_test_data, );
7910 END (ctanh, complex);
7911 }
7912
7913
7914 static const struct test_c_c_data ctanh_tonearest_test_data[] =
7915 {
7916 START_DATA (ctanh_tonearest),
7917 TEST_c_c (ctanh, 0x1p-149, 0x1.921fb6p+0, 7.334008549954377778731880988481078535821e-31L, -2.287733242885645987394874673945769518150e7L),
7918
7919 #ifndef TEST_FLOAT
7920 TEST_c_c (ctanh, 0x1p-1074, 0x1.921fb54442d18p+0, 1.317719414943508315995636961402669067843e-291L, 1.633123935319536975596773704152891653086e16L),
7921 #endif
7922
7923 #if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
7924 TEST_c_c (ctanh, 0x1p-16445L, 0x1.921fb54442d1846ap+0L, 5.793882568875674066286163141055208625180e-4912L, -3.986797629811710706723242948653362815645e19L),
7925 #endif
7926 END_DATA (ctanh_tonearest)
7927 };
7928
7929 static void
7930 ctanh_test_tonearest (void)
7931 {
7932 errno = 0;
7933 FUNC(ctanh) (BUILD_COMPLEX (0.7L, 1.2L));
7934 if (errno == ENOSYS)
7935 /* Function not implemented. */
7936 return;
7937
7938 START (ctanh_tonearest);
7939 RUN_TEST_LOOP_c_c (ctanh, ctanh_tonearest_test_data, FE_TONEAREST);
7940 END (ctanh_tonearest, complex);
7941 }
7942
7943
7944 static const struct test_c_c_data ctanh_towardzero_test_data[] =
7945 {
7946 START_DATA (ctanh_towardzero),
7947 TEST_c_c (ctanh, 0x1p-149, 0x1.921fb6p+0, 7.334008549954377778731880988481078535821e-31L, -2.287733242885645987394874673945769518150e7L),
7948
7949 #ifndef TEST_FLOAT
7950 TEST_c_c (ctanh, 0x1p-1074, 0x1.921fb54442d18p+0, 1.317719414943508315995636961402669067843e-291L, 1.633123935319536975596773704152891653086e16L),
7951 #endif
7952
7953 #if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
7954 TEST_c_c (ctanh, 0x1p-16445L, 0x1.921fb54442d1846ap+0L, 5.793882568875674066286163141055208625180e-4912L, -3.986797629811710706723242948653362815645e19L),
7955 #endif
7956 END_DATA (ctanh_towardzero)
7957 };
7958
7959 static void
7960 ctanh_test_towardzero (void)
7961 {
7962 errno = 0;
7963 FUNC(ctanh) (BUILD_COMPLEX (0.7L, 1.2L));
7964 if (errno == ENOSYS)
7965 /* Function not implemented. */
7966 return;
7967
7968 START (ctanh_towardzero);
7969 RUN_TEST_LOOP_c_c (ctanh, ctanh_towardzero_test_data, FE_TOWARDZERO);
7970 END (ctanh_towardzero, complex);
7971 }
7972
7973
7974 static const struct test_c_c_data ctanh_downward_test_data[] =
7975 {
7976 START_DATA (ctanh_downward),
7977 TEST_c_c (ctanh, 0x1p-149, 0x1.921fb6p+0, 7.334008549954377778731880988481078535821e-31L, -2.287733242885645987394874673945769518150e7L),
7978
7979 #ifndef TEST_FLOAT
7980 TEST_c_c (ctanh, 0x1p-1074, 0x1.921fb54442d18p+0, 1.317719414943508315995636961402669067843e-291L, 1.633123935319536975596773704152891653086e16L),
7981 #endif
7982
7983 #if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
7984 TEST_c_c (ctanh, 0x1p-16445L, 0x1.921fb54442d1846ap+0L, 5.793882568875674066286163141055208625180e-4912L, -3.986797629811710706723242948653362815645e19L),
7985 #endif
7986 END_DATA (ctanh_downward)
7987 };
7988
7989 static void
7990 ctanh_test_downward (void)
7991 {
7992 errno = 0;
7993 FUNC(ctanh) (BUILD_COMPLEX (0.7L, 1.2L));
7994 if (errno == ENOSYS)
7995 /* Function not implemented. */
7996 return;
7997
7998 START (ctanh_downward);
7999 RUN_TEST_LOOP_c_c (ctanh, ctanh_downward_test_data, FE_DOWNWARD);
8000 END (ctanh_downward, complex);
8001 }
8002
8003
8004 static const struct test_c_c_data ctanh_upward_test_data[] =
8005 {
8006 START_DATA (ctanh_upward),
8007 TEST_c_c (ctanh, 0x1p-149, 0x1.921fb6p+0, 7.334008549954377778731880988481078535821e-31L, -2.287733242885645987394874673945769518150e7L),
8008
8009 #ifndef TEST_FLOAT
8010 TEST_c_c (ctanh, 0x1p-1074, 0x1.921fb54442d18p+0, 1.317719414943508315995636961402669067843e-291L, 1.633123935319536975596773704152891653086e16L),
8011 #endif
8012
8013 #if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
8014 TEST_c_c (ctanh, 0x1p-16445L, 0x1.921fb54442d1846ap+0L, 5.793882568875674066286163141055208625180e-4912L, -3.986797629811710706723242948653362815645e19L),
8015 #endif
8016 END_DATA (ctanh_upward)
8017 };
8018
8019 static void
8020 ctanh_test_upward (void)
8021 {
8022 errno = 0;
8023 FUNC(ctanh) (BUILD_COMPLEX (0.7L, 1.2L));
8024 if (errno == ENOSYS)
8025 /* Function not implemented. */
8026 return;
8027
8028 START (ctanh_upward);
8029 RUN_TEST_LOOP_c_c (ctanh, ctanh_upward_test_data, FE_UPWARD);
8030 END (ctanh_upward, complex);
8031 }
8032
8033
8034 static const struct test_f_f_data erf_test_data[] =
8035 {
8036 START_DATA (erf),
8037 TEST_f_f (erf, 0, 0),
8038 TEST_f_f (erf, minus_zero, minus_zero),
8039 TEST_f_f (erf, plus_infty, 1),
8040 TEST_f_f (erf, minus_infty, -1),
8041 TEST_f_f (erf, qnan_value, qnan_value),
8042
8043 TEST_f_f (erf, 0.125L, 0.140316204801333817393029446521623398L),
8044 TEST_f_f (erf, 0.75L, 0.711155633653515131598937834591410777L),
8045 TEST_f_f (erf, 1.25L, 0.922900128256458230136523481197281140L),
8046 TEST_f_f (erf, 2.0L, 0.995322265018952734162069256367252929L),
8047 TEST_f_f (erf, 4.125L, 0.999999994576599200434933994687765914L),
8048 TEST_f_f (erf, 27.0L, 1.0L),
8049 END_DATA (erf)
8050 };
8051
8052 static void
8053 erf_test (void)
8054 {
8055 errno = 0;
8056 FUNC(erf) (0);
8057 if (errno == ENOSYS)
8058 /* Function not implemented. */
8059 return;
8060
8061 START (erf);
8062 RUN_TEST_LOOP_f_f (erf, erf_test_data, );
8063 END (erf);
8064 }
8065
8066
8067 static const struct test_f_f_data erfc_test_data[] =
8068 {
8069 START_DATA (erfc),
8070 TEST_f_f (erfc, plus_infty, 0.0),
8071 TEST_f_f (erfc, minus_infty, 2.0),
8072 TEST_f_f (erfc, 0.0, 1.0),
8073 TEST_f_f (erfc, minus_zero, 1.0),
8074 TEST_f_f (erfc, qnan_value, qnan_value),
8075
8076 TEST_f_f (erfc, 0.125L, 0.859683795198666182606970553478376602L),
8077 TEST_f_f (erfc, 0.75L, 0.288844366346484868401062165408589223L),
8078 TEST_f_f (erfc, 1.25L, 0.0770998717435417698634765188027188596L),
8079 TEST_f_f (erfc, 2.0L, 0.00467773498104726583793074363274707139L),
8080 TEST_f_f (erfc, 0x1.f7303cp+1L, 2.705500297238986897105236321218861842255e-8L),
8081 TEST_f_f (erfc, 4.125L, 0.542340079956506600531223408575531062e-8L),
8082 TEST_f_f (erfc, 0x1.ffa002p+2L, 1.233585992097580296336099501489175967033e-29L),
8083 TEST_f_f (erfc, 0x1.ffffc8p+2L, 1.122671365033056305522366683719541099329e-29L),
8084 #ifdef TEST_LDOUBLE
8085 /* The result can only be represented in long double. */
8086 # if LDBL_MIN_10_EXP < -319
8087 TEST_f_f (erfc, 27.0L, 0.523704892378925568501606768284954709e-318L),
8088 # endif
8089 # if LDBL_MANT_DIG >= 106
8090 TEST_f_f (erfc, 0x1.ffff56789abcdef0123456789a8p+2L, 1.123161416304655390092138725253789378459e-29L),
8091 # endif
8092 #endif
8093 END_DATA (erfc)
8094 };
8095
8096 static void
8097 erfc_test (void)
8098 {
8099 errno = 0;
8100 FUNC(erfc) (0);
8101 if (errno == ENOSYS)
8102 /* Function not implemented. */
8103 return;
8104
8105 START (erfc);
8106 RUN_TEST_LOOP_f_f (erfc, erfc_test_data, );
8107 END (erfc);
8108 }
8109
8110
8111 static const struct test_f_f_data exp_test_data[] =
8112 {
8113 START_DATA (exp),
8114 TEST_f_f (exp, 0, 1),
8115 TEST_f_f (exp, minus_zero, 1),
8116
8117 #ifndef TEST_INLINE
8118 TEST_f_f (exp, plus_infty, plus_infty),
8119 TEST_f_f (exp, minus_infty, 0),
8120 #endif
8121 TEST_f_f (exp, qnan_value, qnan_value),
8122 TEST_f_f (exp, 1, M_El),
8123
8124 TEST_f_f (exp, 2, M_E2l),
8125 TEST_f_f (exp, 3, M_E3l),
8126 TEST_f_f (exp, 0.75L, 2.11700001661267466854536981983709561L),
8127 TEST_f_f (exp, 50.0L, 5184705528587072464087.45332293348538L),
8128 TEST_f_f (exp, 88.72269439697265625L, 3.40233126623160774937554134772290447915e38L),
8129 #ifndef TEST_FLOAT
8130 TEST_f_f (exp, 709.75L, 1.739836873264160557698252711673830393864768e+308L),
8131 #endif
8132 #if defined TEST_LDOUBLE && __LDBL_MAX_EXP__ > 1024
8133 /* The result can only be represented in sane long double. */
8134 TEST_f_f (exp, 1000.0L, 0.197007111401704699388887935224332313e435L),
8135 #endif
8136
8137 #if !(defined TEST_LDOUBLE && LDBL_MAX_EXP > 1024)
8138 TEST_f_f (exp, 710, plus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
8139 TEST_f_f (exp, -1234, plus_zero, UNDERFLOW_EXCEPTION),
8140 #endif
8141 TEST_f_f (exp, 1e5, plus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
8142 TEST_f_f (exp, max_value, plus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
8143 TEST_f_f (exp, -max_value, 0, UNDERFLOW_EXCEPTION),
8144 END_DATA (exp)
8145 };
8146
8147 static void
8148 exp_test (void)
8149 {
8150 errno = 0;
8151 FUNC(exp) (0);
8152 if (errno == ENOSYS)
8153 /* Function not implemented. */
8154 return;
8155
8156 START (exp);
8157 RUN_TEST_LOOP_f_f (exp, exp_test_data, );
8158 END (exp);
8159 }
8160
8161
8162 static const struct test_f_f_data exp_tonearest_test_data[] =
8163 {
8164 START_DATA (exp_tonearest),
8165 TEST_f_f (exp, 1, M_El),
8166 TEST_f_f (exp, 2, M_E2l),
8167 TEST_f_f (exp, 3, M_E3l),
8168 END_DATA (exp_tonearest)
8169 };
8170
8171 static void
8172 exp_test_tonearest (void)
8173 {
8174 errno = 0;
8175 FUNC(exp) (0);
8176 if (errno == ENOSYS)
8177 /* Function not implemented. */
8178 return;
8179
8180 START (exp_tonearest);
8181 RUN_TEST_LOOP_f_f (exp, exp_tonearest_test_data, FE_TONEAREST);
8182 END (exp_tonearest);
8183 }
8184
8185
8186 static const struct test_f_f_data exp_towardzero_test_data[] =
8187 {
8188 START_DATA (exp_towardzero),
8189 TEST_f_f (exp, 1, M_El),
8190 TEST_f_f (exp, 2, M_E2l),
8191 TEST_f_f (exp, 3, M_E3l),
8192 END_DATA (exp_towardzero)
8193 };
8194
8195 static void
8196 exp_test_towardzero (void)
8197 {
8198 errno = 0;
8199 FUNC(exp) (0);
8200 if (errno == ENOSYS)
8201 /* Function not implemented. */
8202 return;
8203
8204 START (exp_towardzero);
8205 RUN_TEST_LOOP_f_f (exp, exp_towardzero_test_data, FE_TOWARDZERO);
8206 END (exp_towardzero);
8207 }
8208
8209
8210 static const struct test_f_f_data exp_downward_test_data[] =
8211 {
8212 START_DATA (exp_downward),
8213 TEST_f_f (exp, 1, M_El),
8214 TEST_f_f (exp, 2, M_E2l),
8215 TEST_f_f (exp, 3, M_E3l),
8216 END_DATA (exp_downward)
8217 };
8218
8219 static void
8220 exp_test_downward (void)
8221 {
8222 errno = 0;
8223 FUNC(exp) (0);
8224 if (errno == ENOSYS)
8225 /* Function not implemented. */
8226 return;
8227
8228 START (exp_downward);
8229 RUN_TEST_LOOP_f_f (exp, exp_downward_test_data, FE_DOWNWARD);
8230 END (exp_downward);
8231 }
8232
8233
8234 static const struct test_f_f_data exp_upward_test_data[] =
8235 {
8236 START_DATA (exp_upward),
8237 TEST_f_f (exp, 1, M_El),
8238 TEST_f_f (exp, 2, M_E2l),
8239 TEST_f_f (exp, 3, M_E3l),
8240 END_DATA (exp_upward)
8241 };
8242
8243 static void
8244 exp_test_upward (void)
8245 {
8246 errno = 0;
8247 FUNC(exp) (0);
8248 if (errno == ENOSYS)
8249 /* Function not implemented. */
8250 return;
8251
8252 START (exp_upward);
8253 RUN_TEST_LOOP_f_f (exp, exp_upward_test_data, FE_UPWARD);
8254 END (exp_upward);
8255 }
8256
8257
8258 static const struct test_f_f_data exp10_test_data[] =
8259 {
8260 START_DATA (exp10),
8261 TEST_f_f (exp10, 0, 1),
8262 TEST_f_f (exp10, minus_zero, 1),
8263
8264 TEST_f_f (exp10, plus_infty, plus_infty),
8265 TEST_f_f (exp10, minus_infty, 0),
8266 TEST_f_f (exp10, qnan_value, qnan_value),
8267 TEST_f_f (exp10, 3, 1000),
8268 TEST_f_f (exp10, -1, 0.1L),
8269 TEST_f_f (exp10, 36, 1.0e36L),
8270 TEST_f_f (exp10, -36, 1.0e-36L),
8271 #ifndef TEST_FLOAT
8272 TEST_f_f (exp10, 305, 1.0e305L),
8273 TEST_f_f (exp10, -305, 1.0e-305L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
8274 #endif
8275 #if defined TEST_LDOUBLE && LDBL_MAX_10_EXP >= 4932
8276 TEST_f_f (exp10, 4932, 1.0e4932L),
8277 TEST_f_f (exp10, -4932, 1.0e-4932L, UNDERFLOW_EXCEPTION),
8278 #endif
8279 TEST_f_f (exp10, 1e6, plus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
8280 TEST_f_f (exp10, -1e6, 0, UNDERFLOW_EXCEPTION),
8281 TEST_f_f (exp10, max_value, plus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
8282 TEST_f_f (exp10, -max_value, 0, UNDERFLOW_EXCEPTION),
8283 TEST_f_f (exp10, 0.75L, 5.62341325190349080394951039776481231L),
8284 END_DATA (exp10)
8285 };
8286
8287 static void
8288 exp10_test (void)
8289 {
8290 errno = 0;
8291 FUNC(exp10) (0);
8292 if (errno == ENOSYS)
8293 /* Function not implemented. */
8294 return;
8295
8296 START (exp10);
8297 RUN_TEST_LOOP_f_f (exp10, exp10_test_data, );
8298 END (exp10);
8299 }
8300
8301
8302 static const struct test_f_f_data exp2_test_data[] =
8303 {
8304 START_DATA (exp2),
8305 TEST_f_f (exp2, 0, 1),
8306 TEST_f_f (exp2, minus_zero, 1),
8307 TEST_f_f (exp2, plus_infty, plus_infty),
8308 TEST_f_f (exp2, minus_infty, 0),
8309 TEST_f_f (exp2, qnan_value, qnan_value),
8310
8311 TEST_f_f (exp2, 10, 1024),
8312 TEST_f_f (exp2, -1, 0.5),
8313 TEST_f_f (exp2, 1e6, plus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
8314 TEST_f_f (exp2, -1e6, 0, UNDERFLOW_EXCEPTION),
8315 TEST_f_f (exp2, max_value, plus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
8316 TEST_f_f (exp2, -max_value, 0, UNDERFLOW_EXCEPTION),
8317 TEST_f_f (exp2, 0.75L, 1.68179283050742908606225095246642979L),
8318
8319 TEST_f_f (exp2, 100.5, 1.792728671193156477399422023278661496394e+30L),
8320 TEST_f_f (exp2, 127, 0x1p127),
8321 TEST_f_f (exp2, -149, 0x1p-149),
8322
8323 #ifndef TEST_FLOAT
8324 TEST_f_f (exp2, 1000.25, 1.274245659452564874772384918171765416737e+301L),
8325 TEST_f_f (exp2, 1023, 0x1p1023),
8326 TEST_f_f (exp2, -1074, 0x1p-1074),
8327 #endif
8328
8329 #if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
8330 TEST_f_f (exp2, 16383, 0x1p16383L),
8331 TEST_f_f (exp2, -16400, 0x1p-16400L),
8332 #endif
8333 END_DATA (exp2)
8334 };
8335
8336 static void
8337 exp2_test (void)
8338 {
8339 errno = 0;
8340 FUNC(exp2) (0);
8341 if (errno == ENOSYS)
8342 /* Function not implemented. */
8343 return;
8344
8345 START (exp2);
8346 RUN_TEST_LOOP_f_f (exp2, exp2_test_data, );
8347 END (exp2);
8348 }
8349
8350
8351 static const struct test_f_f_data expm1_test_data[] =
8352 {
8353 START_DATA (expm1),
8354 TEST_f_f (expm1, 0, 0),
8355 TEST_f_f (expm1, minus_zero, minus_zero),
8356
8357 #ifndef TEST_INLINE
8358 TEST_f_f (expm1, plus_infty, plus_infty),
8359 TEST_f_f (expm1, minus_infty, -1),
8360 #endif
8361 TEST_f_f (expm1, qnan_value, qnan_value),
8362
8363 TEST_f_f (expm1, 1, M_El - 1.0),
8364 TEST_f_f (expm1, 0.75L, 1.11700001661267466854536981983709561L),
8365
8366 TEST_f_f (expm1, 50.0L, 5.1847055285870724640864533229334853848275e+21L),
8367
8368 #ifndef TEST_FLOAT
8369 TEST_f_f (expm1, 127.0L, 1.4302079958348104463583671072905261080748e+55L),
8370 TEST_f_f (expm1, 500.0L, 1.4035922178528374107397703328409120821806e+217L),
8371 #endif
8372
8373 #if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
8374 TEST_f_f (expm1, 11356.25L, 9.05128237311923300051376115753226014206e+4931L),
8375 #endif
8376
8377 TEST_f_f (expm1, -10.0, -0.9999546000702375151484644084844394493898L),
8378 TEST_f_f (expm1, -16.0, -0.9999998874648252807408854862248209398728L),
8379 TEST_f_f (expm1, -17.0, -0.9999999586006228121483334034897228104472L),
8380 TEST_f_f (expm1, -18.0, -0.9999999847700202552873715638633707664826L),
8381 TEST_f_f (expm1, -36.0, -0.9999999999999997680477169756430611687736L),
8382 TEST_f_f (expm1, -37.0, -0.9999999999999999146695237425593420572195L),
8383 TEST_f_f (expm1, -38.0, -0.9999999999999999686086720795197037129104L),
8384 TEST_f_f (expm1, -44.0, -0.9999999999999999999221886775886620348429L),
8385 TEST_f_f (expm1, -45.0, -0.9999999999999999999713748141945060635553L),
8386 TEST_f_f (expm1, -46.0, -0.9999999999999999999894693826424461876212L),
8387 TEST_f_f (expm1, -73.0, -0.9999999999999999999999999999999802074012L),
8388 TEST_f_f (expm1, -74.0, -0.9999999999999999999999999999999927187098L),
8389 TEST_f_f (expm1, -75.0, -0.9999999999999999999999999999999973213630L),
8390 TEST_f_f (expm1, -78.0, -0.9999999999999999999999999999999998666385L),
8391 TEST_f_f (expm1, -79.0, -0.9999999999999999999999999999999999509391L),
8392 TEST_f_f (expm1, -80.0, -0.9999999999999999999999999999999999819515L),
8393 TEST_f_f (expm1, -100.0, -1.0),
8394 TEST_f_f (expm1, -1000.0, -1.0),
8395 TEST_f_f (expm1, -10000.0, -1.0),
8396 TEST_f_f (expm1, -100000.0, -1.0),
8397
8398 TEST_f_f (expm1, 100000.0, plus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
8399 TEST_f_f (expm1, max_value, plus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
8400 TEST_f_f (expm1, -max_value, -1),
8401 END_DATA (expm1)
8402 };
8403
8404 static void
8405 expm1_test (void)
8406 {
8407 errno = 0;
8408 FUNC(expm1) (0);
8409 if (errno == ENOSYS)
8410 /* Function not implemented. */
8411 return;
8412
8413 START (expm1);
8414 RUN_TEST_LOOP_f_f (expm1, expm1_test_data, );
8415 END (expm1);
8416 }
8417
8418
8419 static const struct test_f_f_data fabs_test_data[] =
8420 {
8421 START_DATA (fabs),
8422 TEST_f_f (fabs, 0, 0),
8423 TEST_f_f (fabs, minus_zero, 0),
8424
8425 TEST_f_f (fabs, plus_infty, plus_infty),
8426 TEST_f_f (fabs, minus_infty, plus_infty),
8427 TEST_f_f (fabs, qnan_value, qnan_value),
8428
8429 TEST_f_f (fabs, 38.0, 38.0),
8430 TEST_f_f (fabs, -M_El, M_El),
8431 END_DATA (fabs)
8432 };
8433
8434 static void
8435 fabs_test (void)
8436 {
8437 START (fabs);
8438 RUN_TEST_LOOP_f_f (fabs, fabs_test_data, );
8439 END (fabs);
8440 }
8441
8442
8443 static const struct test_ff_f_data fdim_test_data[] =
8444 {
8445 START_DATA (fdim),
8446 TEST_ff_f (fdim, 0, 0, 0),
8447 TEST_ff_f (fdim, 9, 0, 9),
8448 TEST_ff_f (fdim, 0, 9, 0),
8449 TEST_ff_f (fdim, -9, 0, 0),
8450 TEST_ff_f (fdim, 0, -9, 9),
8451
8452 TEST_ff_f (fdim, plus_infty, 9, plus_infty),
8453 TEST_ff_f (fdim, plus_infty, -9, plus_infty),
8454 TEST_ff_f (fdim, minus_infty, 9, 0),
8455 TEST_ff_f (fdim, minus_infty, -9, 0),
8456 TEST_ff_f (fdim, 9, minus_infty, plus_infty),
8457 TEST_ff_f (fdim, -9, minus_infty, plus_infty),
8458 TEST_ff_f (fdim, 9, plus_infty, 0),
8459 TEST_ff_f (fdim, -9, plus_infty, 0),
8460
8461 TEST_ff_f (fdim, 0, qnan_value, qnan_value),
8462 TEST_ff_f (fdim, 9, qnan_value, qnan_value),
8463 TEST_ff_f (fdim, -9, qnan_value, qnan_value),
8464 TEST_ff_f (fdim, qnan_value, 9, qnan_value),
8465 TEST_ff_f (fdim, qnan_value, -9, qnan_value),
8466 TEST_ff_f (fdim, plus_infty, qnan_value, qnan_value),
8467 TEST_ff_f (fdim, minus_infty, qnan_value, qnan_value),
8468 TEST_ff_f (fdim, qnan_value, plus_infty, qnan_value),
8469 TEST_ff_f (fdim, qnan_value, minus_infty, qnan_value),
8470 TEST_ff_f (fdim, qnan_value, qnan_value, qnan_value),
8471
8472 TEST_ff_f (fdim, plus_infty, plus_infty, 0),
8473 END_DATA (fdim)
8474 };
8475
8476 static void
8477 fdim_test (void)
8478 {
8479 START (fdim);
8480 RUN_TEST_LOOP_ff_f (fdim, fdim_test_data, );
8481 END (fdim);
8482 }
8483
8484
8485 static const struct test_f_i_data finite_test_data[] =
8486 {
8487 START_DATA (finite),
8488 TEST_f_b (finite, 0, 1),
8489 TEST_f_b (finite, minus_zero, 1),
8490 TEST_f_b (finite, 10, 1),
8491 TEST_f_b (finite, min_subnorm_value, 1),
8492 TEST_f_b (finite, plus_infty, 0),
8493 TEST_f_b (finite, minus_infty, 0),
8494 TEST_f_b (finite, qnan_value, 0),
8495 END_DATA (finite)
8496 };
8497
8498 static void
8499 finite_test (void)
8500 {
8501 START (finite);
8502 RUN_TEST_LOOP_f_b (finite, finite_test_data, );
8503 END (finite);
8504 }
8505
8506
8507 static const struct test_f_f_data floor_test_data[] =
8508 {
8509 START_DATA (floor),
8510 TEST_f_f (floor, 0.0, 0.0),
8511 TEST_f_f (floor, minus_zero, minus_zero),
8512 TEST_f_f (floor, plus_infty, plus_infty),
8513 TEST_f_f (floor, minus_infty, minus_infty),
8514 TEST_f_f (floor, qnan_value, qnan_value),
8515
8516 TEST_f_f (floor, M_PIl, 3.0),
8517 TEST_f_f (floor, -M_PIl, -4.0),
8518
8519 TEST_f_f (floor, 0.1, 0.0),
8520 TEST_f_f (floor, 0.25, 0.0),
8521 TEST_f_f (floor, 0.625, 0.0),
8522 TEST_f_f (floor, -0.1, -1.0),
8523 TEST_f_f (floor, -0.25, -1.0),
8524 TEST_f_f (floor, -0.625, -1.0),
8525
8526 #ifdef TEST_LDOUBLE
8527 /* The result can only be represented in long double. */
8528 TEST_f_f (floor, 4503599627370495.5L, 4503599627370495.0L),
8529 TEST_f_f (floor, 4503599627370496.25L, 4503599627370496.0L),
8530 TEST_f_f (floor, 4503599627370496.5L, 4503599627370496.0L),
8531 TEST_f_f (floor, 4503599627370496.75L, 4503599627370496.0L),
8532 TEST_f_f (floor, 4503599627370497.5L, 4503599627370497.0L),
8533 # if LDBL_MANT_DIG > 100
8534 TEST_f_f (floor, 4503599627370494.5000000000001L, 4503599627370494.0L),
8535 TEST_f_f (floor, 4503599627370495.5000000000001L, 4503599627370495.0L),
8536 TEST_f_f (floor, 4503599627370496.5000000000001L, 4503599627370496.0L),
8537 # endif
8538
8539 TEST_f_f (floor, -4503599627370495.5L, -4503599627370496.0L),
8540 TEST_f_f (floor, -4503599627370496.25L, -4503599627370497.0L),
8541 TEST_f_f (floor, -4503599627370496.5L, -4503599627370497.0L),
8542 TEST_f_f (floor, -4503599627370496.75L, -4503599627370497.0L),
8543 TEST_f_f (floor, -4503599627370497.5L, -4503599627370498.0L),
8544 # if LDBL_MANT_DIG > 100
8545 TEST_f_f (floor, -4503599627370494.5000000000001L, -4503599627370495.0L),
8546 TEST_f_f (floor, -4503599627370495.5000000000001L, -4503599627370496.0L),
8547 TEST_f_f (floor, -4503599627370496.5000000000001L, -4503599627370497.0L),
8548 # endif
8549
8550 TEST_f_f (floor, 9007199254740991.5L, 9007199254740991.0L),
8551 TEST_f_f (floor, 9007199254740992.25L, 9007199254740992.0L),
8552 TEST_f_f (floor, 9007199254740992.5L, 9007199254740992.0L),
8553 TEST_f_f (floor, 9007199254740992.75L, 9007199254740992.0L),
8554 TEST_f_f (floor, 9007199254740993.5L, 9007199254740993.0L),
8555
8556 # if LDBL_MANT_DIG > 100
8557 TEST_f_f (floor, 9007199254740991.0000000000001L, 9007199254740991.0L),
8558 TEST_f_f (floor, 9007199254740992.0000000000001L, 9007199254740992.0L),
8559 TEST_f_f (floor, 9007199254740993.0000000000001L, 9007199254740993.0L),
8560 TEST_f_f (floor, 9007199254740991.5000000000001L, 9007199254740991.0L),
8561 TEST_f_f (floor, 9007199254740992.5000000000001L, 9007199254740992.0L),
8562 TEST_f_f (floor, 9007199254740993.5000000000001L, 9007199254740993.0L),
8563 # endif
8564
8565 TEST_f_f (floor, -9007199254740991.5L, -9007199254740992.0L),
8566 TEST_f_f (floor, -9007199254740992.25L, -9007199254740993.0L),
8567 TEST_f_f (floor, -9007199254740992.5L, -9007199254740993.0L),
8568 TEST_f_f (floor, -9007199254740992.75L, -9007199254740993.0L),
8569 TEST_f_f (floor, -9007199254740993.5L, -9007199254740994.0L),
8570
8571 # if LDBL_MANT_DIG > 100
8572 TEST_f_f (floor, -9007199254740991.0000000000001L, -9007199254740992.0L),
8573 TEST_f_f (floor, -9007199254740992.0000000000001L, -9007199254740993.0L),
8574 TEST_f_f (floor, -9007199254740993.0000000000001L, -9007199254740994.0L),
8575 TEST_f_f (floor, -9007199254740991.5000000000001L, -9007199254740992.0L),
8576 TEST_f_f (floor, -9007199254740992.5000000000001L, -9007199254740993.0L),
8577 TEST_f_f (floor, -9007199254740993.5000000000001L, -9007199254740994.0L),
8578 # endif
8579
8580 TEST_f_f (floor, 72057594037927935.5L, 72057594037927935.0L),
8581 TEST_f_f (floor, 72057594037927936.25L, 72057594037927936.0L),
8582 TEST_f_f (floor, 72057594037927936.5L, 72057594037927936.0L),
8583 TEST_f_f (floor, 72057594037927936.75L, 72057594037927936.0L),
8584 TEST_f_f (floor, 72057594037927937.5L, 72057594037927937.0L),
8585
8586 TEST_f_f (floor, -72057594037927935.5L, -72057594037927936.0L),
8587 TEST_f_f (floor, -72057594037927936.25L, -72057594037927937.0L),
8588 TEST_f_f (floor, -72057594037927936.5L, -72057594037927937.0L),
8589 TEST_f_f (floor, -72057594037927936.75L, -72057594037927937.0L),
8590 TEST_f_f (floor, -72057594037927937.5L, -72057594037927938.0L),
8591
8592 TEST_f_f (floor, 10141204801825835211973625643007.5L, 10141204801825835211973625643007.0L),
8593 TEST_f_f (floor, 10141204801825835211973625643008.25L, 10141204801825835211973625643008.0L),
8594 TEST_f_f (floor, 10141204801825835211973625643008.5L, 10141204801825835211973625643008.0L),
8595 TEST_f_f (floor, 10141204801825835211973625643008.75L, 10141204801825835211973625643008.0L),
8596 TEST_f_f (floor, 10141204801825835211973625643009.5L, 10141204801825835211973625643009.0L),
8597
8598 TEST_f_f (floor, 0xf.ffffffffffffff8p+47L, 0xf.fffffffffffep+47L),
8599 TEST_f_f (floor, -0x8.000000000000004p+48L, -0x8.000000000001p+48L),
8600 #endif
8601 END_DATA (floor)
8602 };
8603
8604 static void
8605 floor_test (void)
8606 {
8607 START (floor);
8608 RUN_TEST_LOOP_f_f (floor, floor_test_data, );
8609 END (floor);
8610 }
8611
8612
8613 static const struct test_fff_f_data fma_test_data[] =
8614 {
8615 START_DATA (fma),
8616 TEST_fff_f (fma, 1.0, 2.0, 3.0, 5.0),
8617 TEST_fff_f (fma, qnan_value, 2.0, 3.0, qnan_value),
8618 TEST_fff_f (fma, 1.0, qnan_value, 3.0, qnan_value),
8619 TEST_fff_f (fma, 1.0, 2.0, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
8620 TEST_fff_f (fma, plus_infty, 0.0, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
8621 TEST_fff_f (fma, minus_infty, 0.0, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
8622 TEST_fff_f (fma, 0.0, plus_infty, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
8623 TEST_fff_f (fma, 0.0, minus_infty, qnan_value, qnan_value, INVALID_EXCEPTION_OK),
8624 TEST_fff_f (fma, plus_infty, 0.0, 1.0, qnan_value, INVALID_EXCEPTION),
8625 TEST_fff_f (fma, minus_infty, 0.0, 1.0, qnan_value, INVALID_EXCEPTION),
8626 TEST_fff_f (fma, 0.0, plus_infty, 1.0, qnan_value, INVALID_EXCEPTION),
8627 TEST_fff_f (fma, 0.0, minus_infty, 1.0, qnan_value, INVALID_EXCEPTION),
8628
8629 TEST_fff_f (fma, plus_infty, plus_infty, minus_infty, qnan_value, INVALID_EXCEPTION),
8630 TEST_fff_f (fma, minus_infty, plus_infty, plus_infty, qnan_value, INVALID_EXCEPTION),
8631 TEST_fff_f (fma, plus_infty, minus_infty, plus_infty, qnan_value, INVALID_EXCEPTION),
8632 TEST_fff_f (fma, minus_infty, minus_infty, minus_infty, qnan_value, INVALID_EXCEPTION),
8633 TEST_fff_f (fma, plus_infty, 3.5L, minus_infty, qnan_value, INVALID_EXCEPTION),
8634 TEST_fff_f (fma, minus_infty, -7.5L, minus_infty, qnan_value, INVALID_EXCEPTION),
8635 TEST_fff_f (fma, -13.5L, plus_infty, plus_infty, qnan_value, INVALID_EXCEPTION),
8636 TEST_fff_f (fma, minus_infty, 7.5L, plus_infty, qnan_value, INVALID_EXCEPTION),
8637
8638 TEST_fff_f (fma, 1.25L, 0.75L, 0.0625L, 1.0L),
8639
8640 TEST_fff_f (fma, -max_value, -max_value, minus_infty, minus_infty),
8641 TEST_fff_f (fma, max_value / 2, max_value / 2, minus_infty, minus_infty),
8642 TEST_fff_f (fma, -max_value, max_value, plus_infty, plus_infty),
8643 TEST_fff_f (fma, max_value / 2, -max_value / 4, plus_infty, plus_infty),
8644 TEST_fff_f (fma, plus_infty, 4, plus_infty, plus_infty),
8645 TEST_fff_f (fma, 2, minus_infty, minus_infty, minus_infty),
8646 TEST_fff_f (fma, minus_infty, minus_infty, plus_infty, plus_infty),
8647 TEST_fff_f (fma, plus_infty, minus_infty, minus_infty, minus_infty),
8648
8649 TEST_fff_f (fma, plus_zero, plus_zero, plus_zero, plus_zero),
8650 TEST_fff_f (fma, plus_zero, plus_zero, minus_zero, plus_zero),
8651 TEST_fff_f (fma, plus_zero, minus_zero, plus_zero, plus_zero),
8652 TEST_fff_f (fma, plus_zero, minus_zero, minus_zero, minus_zero),
8653 TEST_fff_f (fma, minus_zero, plus_zero, plus_zero, plus_zero),
8654 TEST_fff_f (fma, minus_zero, plus_zero, minus_zero, minus_zero),
8655 TEST_fff_f (fma, minus_zero, minus_zero, plus_zero, plus_zero),
8656 TEST_fff_f (fma, minus_zero, minus_zero, minus_zero, plus_zero),
8657 TEST_fff_f (fma, 1.0, plus_zero, plus_zero, plus_zero),
8658 TEST_fff_f (fma, 1.0, plus_zero, minus_zero, plus_zero),
8659 TEST_fff_f (fma, 1.0, minus_zero, plus_zero, plus_zero),
8660 TEST_fff_f (fma, 1.0, minus_zero, minus_zero, minus_zero),
8661 TEST_fff_f (fma, -1.0, plus_zero, plus_zero, plus_zero),
8662 TEST_fff_f (fma, -1.0, plus_zero, minus_zero, minus_zero),
8663 TEST_fff_f (fma, -1.0, minus_zero, plus_zero, plus_zero),
8664 TEST_fff_f (fma, -1.0, minus_zero, minus_zero, plus_zero),
8665 TEST_fff_f (fma, plus_zero, 1.0, plus_zero, plus_zero),
8666 TEST_fff_f (fma, plus_zero, 1.0, minus_zero, plus_zero),
8667 TEST_fff_f (fma, plus_zero, -1.0, plus_zero, plus_zero),
8668 TEST_fff_f (fma, plus_zero, -1.0, minus_zero, minus_zero),
8669 TEST_fff_f (fma, minus_zero, 1.0, plus_zero, plus_zero),
8670 TEST_fff_f (fma, minus_zero, 1.0, minus_zero, minus_zero),
8671 TEST_fff_f (fma, minus_zero, -1.0, plus_zero, plus_zero),
8672 TEST_fff_f (fma, minus_zero, -1.0, minus_zero, plus_zero),
8673
8674 TEST_fff_f (fma, 1.0, 1.0, -1.0, plus_zero),
8675 TEST_fff_f (fma, 1.0, -1.0, 1.0, plus_zero),
8676 TEST_fff_f (fma, -1.0, 1.0, 1.0, plus_zero),
8677 TEST_fff_f (fma, -1.0, -1.0, -1.0, plus_zero),
8678
8679 TEST_fff_f (fma, min_value, min_value, plus_zero, plus_zero, UNDERFLOW_EXCEPTION),
8680 TEST_fff_f (fma, min_value, min_value, minus_zero, plus_zero, UNDERFLOW_EXCEPTION),
8681 TEST_fff_f (fma, min_value, -min_value, plus_zero, minus_zero, UNDERFLOW_EXCEPTION),
8682 TEST_fff_f (fma, min_value, -min_value, minus_zero, minus_zero, UNDERFLOW_EXCEPTION),
8683 TEST_fff_f (fma, -min_value, min_value, plus_zero, minus_zero, UNDERFLOW_EXCEPTION),
8684 TEST_fff_f (fma, -min_value, min_value, minus_zero, minus_zero, UNDERFLOW_EXCEPTION),
8685 TEST_fff_f (fma, -min_value, -min_value, plus_zero, plus_zero, UNDERFLOW_EXCEPTION),
8686 TEST_fff_f (fma, -min_value, -min_value, minus_zero, plus_zero, UNDERFLOW_EXCEPTION),
8687
8688 TEST_fff_f (fma, max_value, max_value, min_value, plus_infty, OVERFLOW_EXCEPTION),
8689 TEST_fff_f (fma, max_value, max_value, -min_value, plus_infty, OVERFLOW_EXCEPTION),
8690 TEST_fff_f (fma, max_value, -max_value, min_value, minus_infty, OVERFLOW_EXCEPTION),
8691 TEST_fff_f (fma, max_value, -max_value, -min_value, minus_infty, OVERFLOW_EXCEPTION),
8692 TEST_fff_f (fma, -max_value, max_value, min_value, minus_infty, OVERFLOW_EXCEPTION),
8693 TEST_fff_f (fma, -max_value, max_value, -min_value, minus_infty, OVERFLOW_EXCEPTION),
8694 TEST_fff_f (fma, -max_value, -max_value, min_value, plus_infty, OVERFLOW_EXCEPTION),
8695 TEST_fff_f (fma, -max_value, -max_value, -min_value, plus_infty, OVERFLOW_EXCEPTION),
8696
8697 #if defined (TEST_FLOAT) && FLT_MANT_DIG == 24
8698 TEST_fff_f (fma, 0x1.7ff8p+13, 0x1.000002p+0, 0x1.ffffp-24, 0x1.7ff802p+13),
8699 TEST_fff_f (fma, 0x1.fffp+0, 0x1.00001p+0, -0x1.fffp+0, 0x1.fffp-20),
8700 TEST_fff_f (fma, 0x1.9abcdep+127, 0x0.9abcdep-126, -0x1.f08948p+0, 0x1.bb421p-25),
8701 TEST_fff_f (fma, 0x1.9abcdep+100, 0x0.9abcdep-126, -0x1.f08948p-27, 0x1.bb421p-52),
8702 TEST_fff_f (fma, 0x1.fffffep+127, 0x1.001p+0, -0x1.fffffep+127, 0x1.fffffep+115),
8703 TEST_fff_f (fma, -0x1.fffffep+127, 0x1.fffffep+0, 0x1.fffffep+127, -0x1.fffffap+127),
8704 TEST_fff_f (fma, 0x1.fffffep+127, 2.0, -0x1.fffffep+127, 0x1.fffffep+127),
8705 TEST_fff_f (fma, 0x1.4p-126, 0x1.000004p-1, 0x1p-128, 0x1.c00004p-127, UNDERFLOW_EXCEPTION),
8706 TEST_fff_f (fma, -0x1.4p-126, 0x1.000004p-1, -0x1p-128, -0x1.c00004p-127, UNDERFLOW_EXCEPTION),
8707 TEST_fff_f (fma, 0x1.fffff8p-126, 0x1.000002p-1, 0x1p-149, 0x1p-126, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING),
8708 TEST_fff_f (fma, -0x1.fffff8p-126, 0x1.000002p-1, -0x1p-149, -0x1p-126, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING),
8709 TEST_fff_f (fma, 0x1p-149, 0x1p-1, 0x0.fffffep-126, 0x1p-126, UNDERFLOW_EXCEPTION),
8710 TEST_fff_f (fma, -0x1p-149, 0x1p-1, -0x0.fffffep-126, -0x1p-126, UNDERFLOW_EXCEPTION),
8711 TEST_fff_f (fma, 0x1p-149, 0x1.1p-1, 0x0.fffffep-126, 0x1p-126, UNDERFLOW_EXCEPTION),
8712 TEST_fff_f (fma, -0x1p-149, 0x1.1p-1, -0x0.fffffep-126, -0x1p-126, UNDERFLOW_EXCEPTION),
8713 TEST_fff_f (fma, 0x1p-149, 0x1p-149, 0x1p127, 0x1p127),
8714 TEST_fff_f (fma, 0x1p-149, -0x1p-149, 0x1p127, 0x1p127),
8715 TEST_fff_f (fma, 0x1p-149, 0x1p-149, -0x1p127, -0x1p127),
8716 TEST_fff_f (fma, 0x1p-149, -0x1p-149, -0x1p127, -0x1p127),
8717 TEST_fff_f (fma, 0x1p-149, 0x1p-149, 0x1p-126, 0x1p-126),
8718 TEST_fff_f (fma, 0x1p-149, -0x1p-149, 0x1p-126, 0x1p-126, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING),
8719 TEST_fff_f (fma, 0x1p-149, 0x1p-149, -0x1p-126, -0x1p-126, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING),
8720 TEST_fff_f (fma, 0x1p-149, -0x1p-149, -0x1p-126, -0x1p-126),
8721 TEST_fff_f (fma, 0x1p-149, 0x1p-149, 0x0.fffffep-126, 0x0.fffffep-126, UNDERFLOW_EXCEPTION),
8722 TEST_fff_f (fma, 0x1p-149, -0x1p-149, 0x0.fffffep-126, 0x0.fffffep-126, UNDERFLOW_EXCEPTION),
8723 TEST_fff_f (fma, 0x1p-149, 0x1p-149, -0x0.fffffep-126, -0x0.fffffep-126, UNDERFLOW_EXCEPTION),
8724 TEST_fff_f (fma, 0x1p-149, -0x1p-149, -0x0.fffffep-126, -0x0.fffffep-126, UNDERFLOW_EXCEPTION),
8725 TEST_fff_f (fma, 0x1p-149, 0x1p-149, 0x1p-149, 0x1p-149, UNDERFLOW_EXCEPTION),
8726 TEST_fff_f (fma, 0x1p-149, -0x1p-149, 0x1p-149, 0x1p-149, UNDERFLOW_EXCEPTION),
8727 TEST_fff_f (fma, 0x1p-149, 0x1p-149, -0x1p-149, -0x1p-149, UNDERFLOW_EXCEPTION),
8728 TEST_fff_f (fma, 0x1p-149, -0x1p-149, -0x1p-149, -0x1p-149, UNDERFLOW_EXCEPTION),
8729 TEST_fff_f (fma, 0x0.fffp0, 0x0.fffp0, -0x0.ffep0, 0x1p-24),
8730 TEST_fff_f (fma, 0x0.fffp0, -0x0.fffp0, 0x0.ffep0, -0x1p-24),
8731 TEST_fff_f (fma, -0x0.fffp0, 0x0.fffp0, 0x0.ffep0, -0x1p-24),
8732 TEST_fff_f (fma, -0x0.fffp0, -0x0.fffp0, -0x0.ffep0, 0x1p-24),
8733 TEST_fff_f (fma, 0x1.000002p-126, 0x1.000002p-26, 0x1p127, 0x1p127),
8734 TEST_fff_f (fma, 0x1.000002p-126, -0x1.000002p-26, 0x1p127, 0x1p127),
8735 TEST_fff_f (fma, 0x1.000002p-126, 0x1.000002p-26, -0x1p127, -0x1p127),
8736 TEST_fff_f (fma, 0x1.000002p-126, -0x1.000002p-26, -0x1p127, -0x1p127),
8737 TEST_fff_f (fma, 0x1.000002p-126, 0x1.000002p-26, 0x1p103, 0x1p103),
8738 TEST_fff_f (fma, 0x1.000002p-126, -0x1.000002p-26, 0x1p103, 0x1p103),
8739 TEST_fff_f (fma, 0x1.000002p-126, 0x1.000002p-26, -0x1p103, -0x1p103),
8740 TEST_fff_f (fma, 0x1.000002p-126, -0x1.000002p-26, -0x1p103, -0x1p103),
8741 #endif
8742 #if defined (TEST_DOUBLE) && DBL_MANT_DIG == 53
8743 TEST_fff_f (fma, 0x1.7fp+13, 0x1.0000000000001p+0, 0x1.ffep-48, 0x1.7f00000000001p+13),
8744 TEST_fff_f (fma, 0x1.fffp+0, 0x1.0000000000001p+0, -0x1.fffp+0, 0x1.fffp-52),
8745 TEST_fff_f (fma, 0x1.0000002p+0, 0x1.ffffffcp-1, 0x1p-300, 1.0),
8746 TEST_fff_f (fma, 0x1.0000002p+0, 0x1.ffffffcp-1, -0x1p-300, 0x1.fffffffffffffp-1),
8747 TEST_fff_f (fma, 0x1.deadbeef2feedp+1023, 0x0.deadbeef2feedp-1022, -0x1.a05f8c01a4bfbp+1, 0x1.0989687bc9da4p-53),
8748 TEST_fff_f (fma, 0x1.deadbeef2feedp+900, 0x0.deadbeef2feedp-1022, -0x1.a05f8c01a4bfbp-122, 0x1.0989687bc9da4p-176),
8749 TEST_fff_f (fma, 0x1.fffffffffffffp+1023, 0x1.001p+0, -0x1.fffffffffffffp+1023, 0x1.fffffffffffffp+1011),
8750 TEST_fff_f (fma, -0x1.fffffffffffffp+1023, 0x1.fffffffffffffp+0, 0x1.fffffffffffffp+1023, -0x1.ffffffffffffdp+1023),
8751 TEST_fff_f (fma, 0x1.fffffffffffffp+1023, 2.0, -0x1.fffffffffffffp+1023, 0x1.fffffffffffffp+1023),
8752 TEST_fff_f (fma, 0x1.6a09e667f3bccp-538, 0x1.6a09e667f3bccp-538, 0.0, 0.0, UNDERFLOW_EXCEPTION),
8753 TEST_fff_f (fma, 0x1.deadbeef2feedp-495, 0x1.deadbeef2feedp-495, -0x1.bf86a5786a574p-989, 0x0.0000042625a1fp-1022, UNDERFLOW_EXCEPTION),
8754 TEST_fff_f (fma, 0x1.deadbeef2feedp-503, 0x1.deadbeef2feedp-503, -0x1.bf86a5786a574p-1005, 0x0.0000000004262p-1022, UNDERFLOW_EXCEPTION),
8755 TEST_fff_f (fma, 0x1p-537, 0x1p-538, 0x1p-1074, 0x0.0000000000002p-1022, UNDERFLOW_EXCEPTION),
8756 TEST_fff_f (fma, 0x1.7fffff8p-968, 0x1p-106, 0x0.000001p-1022, 0x0.0000010000001p-1022, UNDERFLOW_EXCEPTION),
8757 TEST_fff_f (fma, 0x1.4000004p-967, 0x1p-106, 0x0.000001p-1022, 0x0.0000010000003p-1022, UNDERFLOW_EXCEPTION),
8758 TEST_fff_f (fma, 0x1.4p-967, -0x1p-106, -0x0.000001p-1022, -0x0.0000010000002p-1022, UNDERFLOW_EXCEPTION),
8759 TEST_fff_f (fma, -0x1.19cab66d73e17p-959, 0x1.c7108a8c5ff51p-107, -0x0.80b0ad65d9b64p-1022, -0x0.80b0ad65d9d59p-1022, UNDERFLOW_EXCEPTION),
8760 TEST_fff_f (fma, -0x1.d2eaed6e8e9d3p-979, -0x1.4e066c62ac9ddp-63, -0x0.9245e6b003454p-1022, -0x0.9245c09c5fb5dp-1022, UNDERFLOW_EXCEPTION),
8761 TEST_fff_f (fma, 0x1.153d650bb9f06p-907, 0x1.2d01230d48407p-125, -0x0.b278d5acfc3cp-1022, -0x0.b22757123bbe9p-1022, UNDERFLOW_EXCEPTION),
8762 TEST_fff_f (fma, -0x1.fffffffffffffp-711, 0x1.fffffffffffffp-275, 0x1.fffffe00007ffp-983, 0x1.7ffffe00007ffp-983),
8763 TEST_fff_f (fma, 0x1.4p-1022, 0x1.0000000000002p-1, 0x1p-1024, 0x1.c000000000002p-1023, UNDERFLOW_EXCEPTION),
8764 TEST_fff_f (fma, -0x1.4p-1022, 0x1.0000000000002p-1, -0x1p-1024, -0x1.c000000000002p-1023, UNDERFLOW_EXCEPTION),
8765 TEST_fff_f (fma, 0x1.ffffffffffffcp-1022, 0x1.0000000000001p-1, 0x1p-1074, 0x1p-1022, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING),
8766 TEST_fff_f (fma, -0x1.ffffffffffffcp-1022, 0x1.0000000000001p-1, -0x1p-1074, -0x1p-1022, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING),
8767 TEST_fff_f (fma, 0x1p-1074, 0x1p-1, 0x0.fffffffffffffp-1022, 0x1p-1022, UNDERFLOW_EXCEPTION),
8768 TEST_fff_f (fma, -0x1p-1074, 0x1p-1, -0x0.fffffffffffffp-1022, -0x1p-1022, UNDERFLOW_EXCEPTION),
8769 TEST_fff_f (fma, 0x1p-1074, 0x1.1p-1, 0x0.fffffffffffffp-1022, 0x1p-1022, UNDERFLOW_EXCEPTION),
8770 TEST_fff_f (fma, -0x1p-1074, 0x1.1p-1, -0x0.fffffffffffffp-1022, -0x1p-1022, UNDERFLOW_EXCEPTION),
8771 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, 0x1p1023, 0x1p1023),
8772 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, 0x1p1023, 0x1p1023),
8773 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, -0x1p1023, -0x1p1023),
8774 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, -0x1p1023, -0x1p1023),
8775 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, 0x1p-1022, 0x1p-1022),
8776 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, 0x1p-1022, 0x1p-1022, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING),
8777 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, -0x1p-1022, -0x1p-1022, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING),
8778 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, -0x1p-1022, -0x1p-1022),
8779 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, 0x0.fffffffffffffp-1022, 0x0.fffffffffffffp-1022, UNDERFLOW_EXCEPTION),
8780 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, 0x0.fffffffffffffp-1022, 0x0.fffffffffffffp-1022, UNDERFLOW_EXCEPTION),
8781 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, -0x0.fffffffffffffp-1022, -0x0.fffffffffffffp-1022, UNDERFLOW_EXCEPTION),
8782 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, -0x0.fffffffffffffp-1022, -0x0.fffffffffffffp-1022, UNDERFLOW_EXCEPTION),
8783 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, 0x1p-1074, 0x1p-1074, UNDERFLOW_EXCEPTION),
8784 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, 0x1p-1074, 0x1p-1074, UNDERFLOW_EXCEPTION),
8785 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, -0x1p-1074, -0x1p-1074, UNDERFLOW_EXCEPTION),
8786 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, -0x1p-1074, -0x1p-1074, UNDERFLOW_EXCEPTION),
8787 TEST_fff_f (fma, 0x0.fffffffffffff8p0, 0x0.fffffffffffff8p0, -0x0.fffffffffffffp0, 0x1p-106),
8788 TEST_fff_f (fma, 0x0.fffffffffffff8p0, -0x0.fffffffffffff8p0, 0x0.fffffffffffffp0, -0x1p-106),
8789 TEST_fff_f (fma, -0x0.fffffffffffff8p0, 0x0.fffffffffffff8p0, 0x0.fffffffffffffp0, -0x1p-106),
8790 TEST_fff_f (fma, -0x0.fffffffffffff8p0, -0x0.fffffffffffff8p0, -0x0.fffffffffffffp0, 0x1p-106),
8791 TEST_fff_f (fma, 0x1.0000000000001p-1022, 0x1.0000000000001p-55, 0x1p1023, 0x1p1023),
8792 TEST_fff_f (fma, 0x1.0000000000001p-1022, -0x1.0000000000001p-55, 0x1p1023, 0x1p1023),
8793 TEST_fff_f (fma, 0x1.0000000000001p-1022, 0x1.0000000000001p-55, -0x1p1023, -0x1p1023),
8794 TEST_fff_f (fma, 0x1.0000000000001p-1022, -0x1.0000000000001p-55, -0x1p1023, -0x1p1023),
8795 TEST_fff_f (fma, 0x1.0000000000001p-1022, 0x1.0000000000001p-55, 0x1p970, 0x1p970),
8796 TEST_fff_f (fma, 0x1.0000000000001p-1022, -0x1.0000000000001p-55, 0x1p970, 0x1p970),
8797 TEST_fff_f (fma, 0x1.0000000000001p-1022, 0x1.0000000000001p-55, -0x1p970, -0x1p970),
8798 TEST_fff_f (fma, 0x1.0000000000001p-1022, -0x1.0000000000001p-55, -0x1p970, -0x1p970),
8799 #endif
8800 #if defined (TEST_LDOUBLE) && LDBL_MANT_DIG == 64
8801 TEST_fff_f (fma, -0x8.03fcp+3696L, 0xf.fffffffffffffffp-6140L, 0x8.3ffffffffffffffp-2450L, -0x8.01ecp-2440L),
8802 TEST_fff_f (fma, 0x9.fcp+2033L, -0x8.000e1f000ff800fp-3613L, -0xf.fffffffffffc0ffp-1579L, -0xd.fc119fb093ed092p-1577L),
8803 TEST_fff_f (fma, 0xc.7fc000003ffffffp-1194L, 0x8.1e0003fffffffffp+15327L, -0x8.fffep+14072L, 0xc.ae9f164020effffp+14136L),
8804 TEST_fff_f (fma, -0x8.0001fc000000003p+1798L, 0xcp-2230L, 0x8.f7e000000000007p-468L, -0xc.0002f9ffee10404p-429L),
8805 TEST_fff_f (fma, 0xc.0000000000007ffp+10130L, -0x8.000000000000001p+4430L, 0xc.07000000001ffffp+14513L, -0xb.fffffffffffd7e4p+14563L),
8806 TEST_fff_f (fma, 0xb.ffffp-4777L, 0x8.000000fffffffffp-11612L, -0x0.3800fff8p-16385L, 0x5.c7fe80c7ffeffffp-16385L, UNDERFLOW_EXCEPTION),
8807 TEST_fff_f (fma, 0x1.4p-16382L, 0x1.0000000000000004p-1L, 0x1p-16384L, 0x1.c000000000000004p-16383L, UNDERFLOW_EXCEPTION),
8808 TEST_fff_f (fma, -0x1.4p-16382L, 0x1.0000000000000004p-1L, -0x1p-16384L, -0x1.c000000000000004p-16383L, UNDERFLOW_EXCEPTION),
8809 TEST_fff_f (fma, 0x1.fffffffffffffff8p-16382L, 0x1.0000000000000002p-1L, 0x1p-16445L, 0x1p-16382L, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING),
8810 TEST_fff_f (fma, -0x1.fffffffffffffff8p-16382L, 0x1.0000000000000002p-1L, -0x1p-16445L, -0x1p-16382L, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING),
8811 TEST_fff_f (fma, 0x1p-16445L, 0x1p-1L, 0x0.fffffffffffffffep-16382L, 0x1p-16382L, UNDERFLOW_EXCEPTION),
8812 TEST_fff_f (fma, -0x1p-16445L, 0x1p-1L, -0x0.fffffffffffffffep-16382L, -0x1p-16382L, UNDERFLOW_EXCEPTION),
8813 TEST_fff_f (fma, 0x1p-16445L, 0x1.1p-1L, 0x0.fffffffffffffffep-16382L, 0x1p-16382L, UNDERFLOW_EXCEPTION),
8814 TEST_fff_f (fma, -0x1p-16445L, 0x1.1p-1L, -0x0.fffffffffffffffep-16382L, -0x1p-16382L, UNDERFLOW_EXCEPTION),
8815 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, 0x1p16383L, 0x1p16383L),
8816 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, 0x1p16383L, 0x1p16383L),
8817 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, -0x1p16383L, -0x1p16383L),
8818 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, -0x1p16383L, -0x1p16383L),
8819 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, 0x1p-16382L, 0x1p-16382L),
8820 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, 0x1p-16382L, 0x1p-16382L, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING),
8821 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, -0x1p-16382L, -0x1p-16382L, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING),
8822 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, -0x1p-16382L, -0x1p-16382L),
8823 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, 0x0.fffffffffffffffep-16382L, 0x0.fffffffffffffffep-16382L, UNDERFLOW_EXCEPTION),
8824 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, 0x0.fffffffffffffffep-16382L, 0x0.fffffffffffffffep-16382L, UNDERFLOW_EXCEPTION),
8825 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, -0x0.fffffffffffffffep-16382L, -0x0.fffffffffffffffep-16382L, UNDERFLOW_EXCEPTION),
8826 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, -0x0.fffffffffffffffep-16382L, -0x0.fffffffffffffffep-16382L, UNDERFLOW_EXCEPTION),
8827 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, 0x1p-16445L, 0x1p-16445L, UNDERFLOW_EXCEPTION),
8828 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, 0x1p-16445L, 0x1p-16445L, UNDERFLOW_EXCEPTION),
8829 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, -0x1p-16445L, -0x1p-16445L, UNDERFLOW_EXCEPTION),
8830 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, -0x1p-16445L, -0x1p-16445L, UNDERFLOW_EXCEPTION),
8831 TEST_fff_f (fma, 0x0.ffffffffffffffffp0L, 0x0.ffffffffffffffffp0L, -0x0.fffffffffffffffep0L, 0x1p-128L),
8832 TEST_fff_f (fma, 0x0.ffffffffffffffffp0L, -0x0.ffffffffffffffffp0L, 0x0.fffffffffffffffep0L, -0x1p-128L),
8833 TEST_fff_f (fma, -0x0.ffffffffffffffffp0L, 0x0.ffffffffffffffffp0L, 0x0.fffffffffffffffep0L, -0x1p-128L),
8834 TEST_fff_f (fma, -0x0.ffffffffffffffffp0L, -0x0.ffffffffffffffffp0L, -0x0.fffffffffffffffep0L, 0x1p-128L),
8835 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, 0x1.0000000000000002p-66L, 0x1p16383L, 0x1p16383L),
8836 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, -0x1.0000000000000002p-66L, 0x1p16383L, 0x1p16383L),
8837 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, 0x1.0000000000000002p-66L, -0x1p16383L, -0x1p16383L),
8838 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, -0x1.0000000000000002p-66L, -0x1p16383L, -0x1p16383L),
8839 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, 0x1.0000000000000002p-66L, 0x1p16319L, 0x1p16319L),
8840 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, -0x1.0000000000000002p-66L, 0x1p16319L, 0x1p16319L),
8841 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, 0x1.0000000000000002p-66L, -0x1p16319L, -0x1p16319L),
8842 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, -0x1.0000000000000002p-66L, -0x1p16319L, -0x1p16319L),
8843 #endif
8844 #if defined (TEST_LDOUBLE) && LDBL_MANT_DIG == 113
8845 TEST_fff_f (fma, 0x1.bb2de33e02ccbbfa6e245a7c1f71p-2584L, -0x1.6b500daf0580d987f1bc0cadfcddp-13777L, 0x1.613cd91d9fed34b33820e5ab9d8dp-16378L, -0x1.3a79fb50eb9ce887cffa0f09bd9fp-16360L),
8846 TEST_fff_f (fma, -0x1.f949b880cacb0f0c61540105321dp-5954L, -0x1.3876cec84b4140f3bd6198731b7ep-10525L, -0x0.a5dc1c6cfbc498c54fb0b504bf19p-16382L, -0x0.a5dc1c6cfbc498c54fb0b5038abbp-16382L, UNDERFLOW_EXCEPTION),
8847 TEST_fff_f (fma, -0x1.0000fffffffffp-16221L, 0x1.0000001fffff8007fep-239L, 0x0.ff87ffffffffffffe000003fffffp-16382L, 0x0.ff87ffffffffffffdffc003bff7fp-16382L, UNDERFLOW_EXCEPTION),
8848 TEST_fff_f (fma, -0x1.ac79c9376ef447f3827c9e9de008p-2228L, -0x1.5ba830022b6139e21fbe7270cad8p-6314L, 0x1.e8282b6a26bb6a9daf5c8e73e9f9p-8616L, 0x1.22f14a0253878a730cd1aee373adp-8541L),
8849 TEST_fff_f (fma, -0x1.c69749ec574caaa2ab8e97ddb9f3p+2652L, 0x1.f34235ff9d095449c29b4831b62dp+3311L, 0x1.fbe4302df23354dbd0c4d3cfe606p+5879L, -0x1.bb473bfdfb7a6e18886ce6e57eafp+5964L),
8850 TEST_fff_f (fma, -0x1.ca8835fc6ecfb5398625fc891be5p-1686L, 0x1.621e1972bbe2180e5be9dd7d8df5p-7671L, -0x1.7d2d21b73b52cf20dec2a83902a4p-9395L, -0x1.3d2322191c9c88bc68a62ab8042cp-9356L),
8851 TEST_fff_f (fma, -0x1.55cff679ec49c2541fab41fc843ep-11819L, 0x1.e60e9f464f9e8df0509647c7c971p+12325L, 0x1.eaa2a7649d765c2f564f7a5beca7p+454L, -0x1.447e29fa7e406a285f4e350fcf86p+507L),
8852 TEST_fff_f (fma, 0x1.f0e7b1454908576f2537d863cf9bp+11432L, 0x1.cdce52f09d4ca76e68706f34b5d5p-1417L, -0x1.2e986187c70f146235ea2066e486p+9979L, 0x1.c030dad3cc5643f3dd0f5619f661p+10016L),
8853 TEST_fff_f (fma, 0x1.f102f7da4a57a3a4aab620e29452p-3098L, -0x1.cc06a4ff40248f9e2dcc4b6afd84p-11727L, 0x1.d512a11126b5ac8ed8973b8580c8p-14849L, -0x1.be8f1cf737ab4d1c31c54f5ec23bp-14824L),
8854 TEST_fff_f (fma, -0x1.fc47ac7434b993cd8dcb2b431f25p-3816L, 0x1.fbc9750da8468852d84558e1db6dp-5773L, -0x1.00a98abf783f75c40fe5b7a37d86p-9607L, -0x1.f81917b166f45e763cfcc057e2adp-9588L),
8855 TEST_fff_f (fma, 0x1.00000000000007ffffffffffffffp-9045L, -0x1.ffffffffffff80000001ffffffffp+4773L, -0x1.f8p-4316L, -0x1.00000000000f88000000fffffdffp-4271L),
8856 TEST_fff_f (fma, 0x1.4e922764c90701d4a2f21d01893dp-8683L, -0x1.955a12e2d7c9447c27fa022fc865p+212L, -0x1.e9634462eaef96528b90b6944578p-8521L, -0x1.08e1783184a371943d3598e10865p-8470L),
8857 TEST_fff_f (fma, 0x1.801181509c03bdbef10d6165588cp-15131L, 0x1.ad86f8e57d3d40bfa8007780af63p-368L, -0x1.6e9df0dab1c9f1d7a6043c390741p-15507L, 0x1.417c9b2b15e2ad57dc9e0e920844p-15498L),
8858 TEST_fff_f (fma, 0x1.4p-16382L, 0x1.0000000000000000000000000002p-1L, 0x1p-16384L, 0x1.c000000000000000000000000002p-16383L, UNDERFLOW_EXCEPTION),
8859 TEST_fff_f (fma, -0x1.4p-16382L, 0x1.0000000000000000000000000002p-1L, -0x1p-16384L, -0x1.c000000000000000000000000002p-16383L, UNDERFLOW_EXCEPTION),
8860 TEST_fff_f (fma, 0x1.fffffffffffffffffffffffffffcp-16382L, 0x1.0000000000000000000000000001p-1L, 0x1p-16494L, 0x1p-16382L, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING),
8861 TEST_fff_f (fma, -0x1.fffffffffffffffffffffffffffcp-16382L, 0x1.0000000000000000000000000001p-1L, -0x1p-16494L, -0x1p-16382L, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING),
8862 TEST_fff_f (fma, 0x1p-16494L, 0x1p-1L, 0x0.ffffffffffffffffffffffffffffp-16382L, 0x1p-16382L, UNDERFLOW_EXCEPTION),
8863 TEST_fff_f (fma, -0x1p-16494L, 0x1p-1L, -0x0.ffffffffffffffffffffffffffffp-16382L, -0x1p-16382L, UNDERFLOW_EXCEPTION),
8864 TEST_fff_f (fma, 0x1p-16494L, 0x1.1p-1L, 0x0.ffffffffffffffffffffffffffffp-16382L, 0x1p-16382L, UNDERFLOW_EXCEPTION),
8865 TEST_fff_f (fma, -0x1p-16494L, 0x1.1p-1L, -0x0.ffffffffffffffffffffffffffffp-16382L, -0x1p-16382L, UNDERFLOW_EXCEPTION),
8866 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, 0x1p16383L, 0x1p16383L),
8867 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, 0x1p16383L, 0x1p16383L),
8868 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, -0x1p16383L, -0x1p16383L),
8869 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, -0x1p16383L, -0x1p16383L),
8870 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, 0x1p-16382L, 0x1p-16382L),
8871 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, 0x1p-16382L, 0x1p-16382L, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING),
8872 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, -0x1p-16382L, -0x1p-16382L, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING),
8873 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, -0x1p-16382L, -0x1p-16382L),
8874 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, 0x0.ffffffffffffffffffffffffffffp-16382L, 0x0.ffffffffffffffffffffffffffffp-16382L, UNDERFLOW_EXCEPTION),
8875 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, 0x0.ffffffffffffffffffffffffffffp-16382L, 0x0.ffffffffffffffffffffffffffffp-16382L, UNDERFLOW_EXCEPTION),
8876 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, -0x0.ffffffffffffffffffffffffffffp-16382L, -0x0.ffffffffffffffffffffffffffffp-16382L, UNDERFLOW_EXCEPTION),
8877 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, -0x0.ffffffffffffffffffffffffffffp-16382L, -0x0.ffffffffffffffffffffffffffffp-16382L, UNDERFLOW_EXCEPTION),
8878 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, 0x1p-16494L, 0x1p-16494L, UNDERFLOW_EXCEPTION),
8879 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, 0x1p-16494L, 0x1p-16494L, UNDERFLOW_EXCEPTION),
8880 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, -0x1p-16494L, -0x1p-16494L, UNDERFLOW_EXCEPTION),
8881 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, -0x1p-16494L, -0x1p-16494L, UNDERFLOW_EXCEPTION),
8882 TEST_fff_f (fma, 0x0.ffffffffffffffffffffffffffff8p0L, 0x0.ffffffffffffffffffffffffffff8p0L, -0x0.ffffffffffffffffffffffffffffp0L, 0x1p-226L),
8883 TEST_fff_f (fma, 0x0.ffffffffffffffffffffffffffff8p0L, -0x0.ffffffffffffffffffffffffffff8p0L, 0x0.ffffffffffffffffffffffffffffp0L, -0x1p-226L),
8884 TEST_fff_f (fma, -0x0.ffffffffffffffffffffffffffff8p0L, 0x0.ffffffffffffffffffffffffffff8p0L, 0x0.ffffffffffffffffffffffffffffp0L, -0x1p-226L),
8885 TEST_fff_f (fma, -0x0.ffffffffffffffffffffffffffff8p0L, -0x0.ffffffffffffffffffffffffffff8p0L, -0x0.ffffffffffffffffffffffffffffp0L, 0x1p-226L),
8886 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, 0x1.0000000000000000000000000001p-66L, 0x1p16383L, 0x1p16383L),
8887 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, -0x1.0000000000000000000000000001p-66L, 0x1p16383L, 0x1p16383L),
8888 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, 0x1.0000000000000000000000000001p-66L, -0x1p16383L, -0x1p16383L),
8889 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, -0x1.0000000000000000000000000001p-66L, -0x1p16383L, -0x1p16383L),
8890 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, 0x1.0000000000000000000000000001p-66L, 0x1p16319L, 0x1p16319L),
8891 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, -0x1.0000000000000000000000000001p-66L, 0x1p16319L, 0x1p16319L),
8892 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, 0x1.0000000000000000000000000001p-66L, -0x1p16319L, -0x1p16319L),
8893 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, -0x1.0000000000000000000000000001p-66L, -0x1p16319L, -0x1p16319L),
8894 #endif
8895 END_DATA (fma)
8896 };
8897
8898 static void
8899 fma_test (void)
8900 {
8901 START (fma);
8902 RUN_TEST_LOOP_fff_f (fma, fma_test_data, );
8903 END (fma);
8904 }
8905
8906
8907 static const struct test_fff_f_data fma_towardzero_test_data[] =
8908 {
8909 START_DATA (fma_towardzero),
8910 TEST_fff_f (fma, plus_zero, plus_zero, plus_zero, plus_zero),
8911 TEST_fff_f (fma, plus_zero, plus_zero, minus_zero, plus_zero),
8912 TEST_fff_f (fma, plus_zero, minus_zero, plus_zero, plus_zero),
8913 TEST_fff_f (fma, plus_zero, minus_zero, minus_zero, minus_zero),
8914 TEST_fff_f (fma, minus_zero, plus_zero, plus_zero, plus_zero),
8915 TEST_fff_f (fma, minus_zero, plus_zero, minus_zero, minus_zero),
8916 TEST_fff_f (fma, minus_zero, minus_zero, plus_zero, plus_zero),
8917 TEST_fff_f (fma, minus_zero, minus_zero, minus_zero, plus_zero),
8918 TEST_fff_f (fma, 1.0, plus_zero, plus_zero, plus_zero),
8919 TEST_fff_f (fma, 1.0, plus_zero, minus_zero, plus_zero),
8920 TEST_fff_f (fma, 1.0, minus_zero, plus_zero, plus_zero),
8921 TEST_fff_f (fma, 1.0, minus_zero, minus_zero, minus_zero),
8922 TEST_fff_f (fma, -1.0, plus_zero, plus_zero, plus_zero),
8923 TEST_fff_f (fma, -1.0, plus_zero, minus_zero, minus_zero),
8924 TEST_fff_f (fma, -1.0, minus_zero, plus_zero, plus_zero),
8925 TEST_fff_f (fma, -1.0, minus_zero, minus_zero, plus_zero),
8926 TEST_fff_f (fma, plus_zero, 1.0, plus_zero, plus_zero),
8927 TEST_fff_f (fma, plus_zero, 1.0, minus_zero, plus_zero),
8928 TEST_fff_f (fma, plus_zero, -1.0, plus_zero, plus_zero),
8929 TEST_fff_f (fma, plus_zero, -1.0, minus_zero, minus_zero),
8930 TEST_fff_f (fma, minus_zero, 1.0, plus_zero, plus_zero),
8931 TEST_fff_f (fma, minus_zero, 1.0, minus_zero, minus_zero),
8932 TEST_fff_f (fma, minus_zero, -1.0, plus_zero, plus_zero),
8933 TEST_fff_f (fma, minus_zero, -1.0, minus_zero, plus_zero),
8934
8935 TEST_fff_f (fma, 1.0, 1.0, -1.0, plus_zero),
8936 TEST_fff_f (fma, 1.0, -1.0, 1.0, plus_zero),
8937 TEST_fff_f (fma, -1.0, 1.0, 1.0, plus_zero),
8938 TEST_fff_f (fma, -1.0, -1.0, -1.0, plus_zero),
8939
8940 TEST_fff_f (fma, min_value, min_value, plus_zero, plus_zero, UNDERFLOW_EXCEPTION),
8941 TEST_fff_f (fma, min_value, min_value, minus_zero, plus_zero, UNDERFLOW_EXCEPTION),
8942 TEST_fff_f (fma, min_value, -min_value, plus_zero, minus_zero, UNDERFLOW_EXCEPTION),
8943 TEST_fff_f (fma, min_value, -min_value, minus_zero, minus_zero, UNDERFLOW_EXCEPTION),
8944 TEST_fff_f (fma, -min_value, min_value, plus_zero, minus_zero, UNDERFLOW_EXCEPTION),
8945 TEST_fff_f (fma, -min_value, min_value, minus_zero, minus_zero, UNDERFLOW_EXCEPTION),
8946 TEST_fff_f (fma, -min_value, -min_value, plus_zero, plus_zero, UNDERFLOW_EXCEPTION),
8947 TEST_fff_f (fma, -min_value, -min_value, minus_zero, plus_zero, UNDERFLOW_EXCEPTION),
8948
8949 #if !(defined TEST_LDOUBLE && LDBL_MANT_DIG == 106) /* Bug 13304. */
8950 TEST_fff_f (fma, max_value, max_value, min_value, max_value, OVERFLOW_EXCEPTION),
8951 TEST_fff_f (fma, max_value, max_value, -min_value, max_value, OVERFLOW_EXCEPTION),
8952 TEST_fff_f (fma, max_value, -max_value, min_value, -max_value, OVERFLOW_EXCEPTION),
8953 TEST_fff_f (fma, max_value, -max_value, -min_value, -max_value, OVERFLOW_EXCEPTION),
8954 TEST_fff_f (fma, -max_value, max_value, min_value, -max_value, OVERFLOW_EXCEPTION),
8955 TEST_fff_f (fma, -max_value, max_value, -min_value, -max_value, OVERFLOW_EXCEPTION),
8956 TEST_fff_f (fma, -max_value, -max_value, min_value, max_value, OVERFLOW_EXCEPTION),
8957 TEST_fff_f (fma, -max_value, -max_value, -min_value, max_value, OVERFLOW_EXCEPTION),
8958 #endif
8959
8960 #if defined (TEST_FLOAT) && FLT_MANT_DIG == 24
8961 TEST_fff_f (fma, 0x1.4p-126, 0x1.000004p-1, 0x1p-128, 0x1.c00004p-127, UNDERFLOW_EXCEPTION),
8962 TEST_fff_f (fma, -0x1.4p-126, 0x1.000004p-1, -0x1p-128, -0x1.c00004p-127, UNDERFLOW_EXCEPTION),
8963 TEST_fff_f (fma, 0x1.fffff8p-126, 0x1.000002p-1, 0x1p-149, 0x0.fffffep-126, UNDERFLOW_EXCEPTION),
8964 TEST_fff_f (fma, -0x1.fffff8p-126, 0x1.000002p-1, -0x1p-149, -0x0.fffffep-126, UNDERFLOW_EXCEPTION),
8965 TEST_fff_f (fma, 0x1p-149, 0x1p-1, 0x0.fffffep-126, 0x0.fffffep-126, UNDERFLOW_EXCEPTION),
8966 TEST_fff_f (fma, -0x1p-149, 0x1p-1, -0x0.fffffep-126, -0x0.fffffep-126, UNDERFLOW_EXCEPTION),
8967 TEST_fff_f (fma, 0x1p-149, 0x1.1p-1, 0x0.fffffep-126, 0x0.fffffep-126, UNDERFLOW_EXCEPTION),
8968 TEST_fff_f (fma, -0x1p-149, 0x1.1p-1, -0x0.fffffep-126, -0x0.fffffep-126, UNDERFLOW_EXCEPTION),
8969 TEST_fff_f (fma, 0x1p-149, 0x1p-149, 0x1p127, 0x1p127),
8970 TEST_fff_f (fma, 0x1p-149, -0x1p-149, 0x1p127, 0x0.ffffffp127),
8971 TEST_fff_f (fma, 0x1p-149, 0x1p-149, -0x1p127, -0x0.ffffffp127),
8972 TEST_fff_f (fma, 0x1p-149, -0x1p-149, -0x1p127, -0x1p127),
8973 TEST_fff_f (fma, 0x1p-149, 0x1p-149, 0x1p-126, 0x1p-126),
8974 TEST_fff_f (fma, 0x1p-149, -0x1p-149, 0x1p-126, 0x0.fffffep-126, UNDERFLOW_EXCEPTION),
8975 TEST_fff_f (fma, 0x1p-149, 0x1p-149, -0x1p-126, -0x0.fffffep-126, UNDERFLOW_EXCEPTION),
8976 TEST_fff_f (fma, 0x1p-149, -0x1p-149, -0x1p-126, -0x1p-126),
8977 TEST_fff_f (fma, 0x1p-149, 0x1p-149, 0x0.fffffep-126, 0x0.fffffep-126, UNDERFLOW_EXCEPTION),
8978 TEST_fff_f (fma, 0x1p-149, -0x1p-149, 0x0.fffffep-126, 0x0.fffffcp-126, UNDERFLOW_EXCEPTION),
8979 TEST_fff_f (fma, 0x1p-149, 0x1p-149, -0x0.fffffep-126, -0x0.fffffcp-126, UNDERFLOW_EXCEPTION),
8980 TEST_fff_f (fma, 0x1p-149, -0x1p-149, -0x0.fffffep-126, -0x0.fffffep-126, UNDERFLOW_EXCEPTION),
8981 TEST_fff_f (fma, 0x1p-149, 0x1p-149, 0x1p-149, 0x1p-149, UNDERFLOW_EXCEPTION),
8982 TEST_fff_f (fma, 0x1p-149, -0x1p-149, 0x1p-149, plus_zero, UNDERFLOW_EXCEPTION),
8983 TEST_fff_f (fma, 0x1p-149, 0x1p-149, -0x1p-149, minus_zero, UNDERFLOW_EXCEPTION),
8984 TEST_fff_f (fma, 0x1p-149, -0x1p-149, -0x1p-149, -0x1p-149, UNDERFLOW_EXCEPTION),
8985 TEST_fff_f (fma, 0x0.fffp0, 0x0.fffp0, -0x0.ffep0, 0x1p-24),
8986 TEST_fff_f (fma, 0x0.fffp0, -0x0.fffp0, 0x0.ffep0, -0x1p-24),
8987 TEST_fff_f (fma, -0x0.fffp0, 0x0.fffp0, 0x0.ffep0, -0x1p-24),
8988 TEST_fff_f (fma, -0x0.fffp0, -0x0.fffp0, -0x0.ffep0, 0x1p-24),
8989 TEST_fff_f (fma, 0x1.000002p-126, 0x1.000002p-26, 0x1p127, 0x1p127),
8990 TEST_fff_f (fma, 0x1.000002p-126, -0x1.000002p-26, 0x1p127, 0x0.ffffffp127),
8991 TEST_fff_f (fma, 0x1.000002p-126, 0x1.000002p-26, -0x1p127, -0x0.ffffffp127),
8992 TEST_fff_f (fma, 0x1.000002p-126, -0x1.000002p-26, -0x1p127, -0x1p127),
8993 TEST_fff_f (fma, 0x1.000002p-126, 0x1.000002p-26, 0x1p103, 0x1p103),
8994 TEST_fff_f (fma, 0x1.000002p-126, -0x1.000002p-26, 0x1p103, 0x0.ffffffp103),
8995 TEST_fff_f (fma, 0x1.000002p-126, 0x1.000002p-26, -0x1p103, -0x0.ffffffp103),
8996 TEST_fff_f (fma, 0x1.000002p-126, -0x1.000002p-26, -0x1p103, -0x1p103),
8997 #endif
8998 #if defined (TEST_DOUBLE) && DBL_MANT_DIG == 53
8999 TEST_fff_f (fma, 0x1.4p-1022, 0x1.0000000000002p-1, 0x1p-1024, 0x1.c000000000002p-1023, UNDERFLOW_EXCEPTION),
9000 TEST_fff_f (fma, -0x1.4p-1022, 0x1.0000000000002p-1, -0x1p-1024, -0x1.c000000000002p-1023, UNDERFLOW_EXCEPTION),
9001 TEST_fff_f (fma, 0x1.ffffffffffffcp-1022, 0x1.0000000000001p-1, 0x1p-1074, 0x0.fffffffffffffp-1022, UNDERFLOW_EXCEPTION),
9002 TEST_fff_f (fma, -0x1.ffffffffffffcp-1022, 0x1.0000000000001p-1, -0x1p-1074, -0x0.fffffffffffffp-1022, UNDERFLOW_EXCEPTION),
9003 TEST_fff_f (fma, 0x1p-1074, 0x1p-1, 0x0.fffffffffffffp-1022, 0x0.fffffffffffffp-1022, UNDERFLOW_EXCEPTION),
9004 TEST_fff_f (fma, -0x1p-1074, 0x1p-1, -0x0.fffffffffffffp-1022, -0x0.fffffffffffffp-1022, UNDERFLOW_EXCEPTION),
9005 TEST_fff_f (fma, 0x1p-1074, 0x1.1p-1, 0x0.fffffffffffffp-1022, 0x0.fffffffffffffp-1022, UNDERFLOW_EXCEPTION),
9006 TEST_fff_f (fma, -0x1p-1074, 0x1.1p-1, -0x0.fffffffffffffp-1022, -0x0.fffffffffffffp-1022, UNDERFLOW_EXCEPTION),
9007 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, 0x1p1023, 0x1p1023),
9008 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, 0x1p1023, 0x0.fffffffffffff8p1023),
9009 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, -0x1p1023, -0x0.fffffffffffff8p1023),
9010 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, -0x1p1023, -0x1p1023),
9011 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, 0x1p-1022, 0x1p-1022),
9012 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, 0x1p-1022, 0x0.fffffffffffffp-1022, UNDERFLOW_EXCEPTION),
9013 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, -0x1p-1022, -0x0.fffffffffffffp-1022, UNDERFLOW_EXCEPTION),
9014 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, -0x1p-1022, -0x1p-1022),
9015 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, 0x0.fffffffffffffp-1022, 0x0.fffffffffffffp-1022, UNDERFLOW_EXCEPTION),
9016 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, 0x0.fffffffffffffp-1022, 0x0.ffffffffffffep-1022, UNDERFLOW_EXCEPTION),
9017 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, -0x0.fffffffffffffp-1022, -0x0.ffffffffffffep-1022, UNDERFLOW_EXCEPTION),
9018 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, -0x0.fffffffffffffp-1022, -0x0.fffffffffffffp-1022, UNDERFLOW_EXCEPTION),
9019 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, 0x1p-1074, 0x1p-1074, UNDERFLOW_EXCEPTION),
9020 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, 0x1p-1074, plus_zero, UNDERFLOW_EXCEPTION),
9021 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, -0x1p-1074, minus_zero, UNDERFLOW_EXCEPTION),
9022 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, -0x1p-1074, -0x1p-1074, UNDERFLOW_EXCEPTION),
9023 TEST_fff_f (fma, 0x0.fffffffffffff8p0, 0x0.fffffffffffff8p0, -0x0.fffffffffffffp0, 0x1p-106),
9024 TEST_fff_f (fma, 0x0.fffffffffffff8p0, -0x0.fffffffffffff8p0, 0x0.fffffffffffffp0, -0x1p-106),
9025 TEST_fff_f (fma, -0x0.fffffffffffff8p0, 0x0.fffffffffffff8p0, 0x0.fffffffffffffp0, -0x1p-106),
9026 TEST_fff_f (fma, -0x0.fffffffffffff8p0, -0x0.fffffffffffff8p0, -0x0.fffffffffffffp0, 0x1p-106),
9027 TEST_fff_f (fma, 0x1.0000000000001p-1022, 0x1.0000000000001p-55, 0x1p1023, 0x1p1023),
9028 TEST_fff_f (fma, 0x1.0000000000001p-1022, -0x1.0000000000001p-55, 0x1p1023, 0x0.fffffffffffff8p1023),
9029 TEST_fff_f (fma, 0x1.0000000000001p-1022, 0x1.0000000000001p-55, -0x1p1023, -0x0.fffffffffffff8p1023),
9030 TEST_fff_f (fma, 0x1.0000000000001p-1022, -0x1.0000000000001p-55, -0x1p1023, -0x1p1023),
9031 TEST_fff_f (fma, 0x1.0000000000001p-1022, 0x1.0000000000001p-55, 0x1p970, 0x1p970),
9032 TEST_fff_f (fma, 0x1.0000000000001p-1022, -0x1.0000000000001p-55, 0x1p970, 0x0.fffffffffffff8p970),
9033 TEST_fff_f (fma, 0x1.0000000000001p-1022, 0x1.0000000000001p-55, -0x1p970, -0x0.fffffffffffff8p970),
9034 TEST_fff_f (fma, 0x1.0000000000001p-1022, -0x1.0000000000001p-55, -0x1p970, -0x1p970),
9035 #endif
9036 #if defined (TEST_LDOUBLE) && LDBL_MANT_DIG == 64
9037 TEST_fff_f (fma, 0x1.4p-16382L, 0x1.0000000000000004p-1L, 0x1p-16384L, 0x1.c000000000000004p-16383L, UNDERFLOW_EXCEPTION),
9038 TEST_fff_f (fma, -0x1.4p-16382L, 0x1.0000000000000004p-1L, -0x1p-16384L, -0x1.c000000000000004p-16383L, UNDERFLOW_EXCEPTION),
9039 TEST_fff_f (fma, 0x1.fffffffffffffff8p-16382L, 0x1.0000000000000002p-1L, 0x1p-16445L, 0x0.fffffffffffffffep-16382L, UNDERFLOW_EXCEPTION),
9040 TEST_fff_f (fma, -0x1.fffffffffffffff8p-16382L, 0x1.0000000000000002p-1L, -0x1p-16445L, -0x0.fffffffffffffffep-16382L, UNDERFLOW_EXCEPTION),
9041 TEST_fff_f (fma, 0x1p-16445L, 0x1p-1L, 0x0.fffffffffffffffep-16382L, 0x0.fffffffffffffffep-16382L, UNDERFLOW_EXCEPTION),
9042 TEST_fff_f (fma, -0x1p-16445L, 0x1p-1L, -0x0.fffffffffffffffep-16382L, -0x0.fffffffffffffffep-16382L, UNDERFLOW_EXCEPTION),
9043 TEST_fff_f (fma, 0x1p-16445L, 0x1.1p-1L, 0x0.fffffffffffffffep-16382L, 0x0.fffffffffffffffep-16382L, UNDERFLOW_EXCEPTION),
9044 TEST_fff_f (fma, -0x1p-16445L, 0x1.1p-1L, -0x0.fffffffffffffffep-16382L, -0x0.fffffffffffffffep-16382L, UNDERFLOW_EXCEPTION),
9045 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, 0x1p16383L, 0x1p16383L),
9046 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, 0x1p16383L, 0x0.ffffffffffffffffp16383L),
9047 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, -0x1p16383L, -0x0.ffffffffffffffffp16383L),
9048 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, -0x1p16383L, -0x1p16383L),
9049 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, 0x1p-16382L, 0x1p-16382L),
9050 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, 0x1p-16382L, 0x0.fffffffffffffffep-16382L, UNDERFLOW_EXCEPTION),
9051 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, -0x1p-16382L, -0x0.fffffffffffffffep-16382L, UNDERFLOW_EXCEPTION),
9052 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, -0x1p-16382L, -0x1p-16382L),
9053 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, 0x0.fffffffffffffffep-16382L, 0x0.fffffffffffffffep-16382L, UNDERFLOW_EXCEPTION),
9054 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, 0x0.fffffffffffffffep-16382L, 0x0.fffffffffffffffcp-16382L, UNDERFLOW_EXCEPTION),
9055 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, -0x0.fffffffffffffffep-16382L, -0x0.fffffffffffffffcp-16382L, UNDERFLOW_EXCEPTION),
9056 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, -0x0.fffffffffffffffep-16382L, -0x0.fffffffffffffffep-16382L, UNDERFLOW_EXCEPTION),
9057 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, 0x1p-16445L, 0x1p-16445L, UNDERFLOW_EXCEPTION),
9058 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, 0x1p-16445L, plus_zero, UNDERFLOW_EXCEPTION),
9059 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, -0x1p-16445L, minus_zero, UNDERFLOW_EXCEPTION),
9060 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, -0x1p-16445L, -0x1p-16445L, UNDERFLOW_EXCEPTION),
9061 TEST_fff_f (fma, 0x0.ffffffffffffffffp0L, 0x0.ffffffffffffffffp0L, -0x0.fffffffffffffffep0L, 0x1p-128L),
9062 TEST_fff_f (fma, 0x0.ffffffffffffffffp0L, -0x0.ffffffffffffffffp0L, 0x0.fffffffffffffffep0L, -0x1p-128L),
9063 TEST_fff_f (fma, -0x0.ffffffffffffffffp0L, 0x0.ffffffffffffffffp0L, 0x0.fffffffffffffffep0L, -0x1p-128L),
9064 TEST_fff_f (fma, -0x0.ffffffffffffffffp0L, -0x0.ffffffffffffffffp0L, -0x0.fffffffffffffffep0L, 0x1p-128L),
9065 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, 0x1.0000000000000002p-66L, 0x1p16383L, 0x1p16383L),
9066 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, -0x1.0000000000000002p-66L, 0x1p16383L, 0x0.ffffffffffffffffp16383L),
9067 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, 0x1.0000000000000002p-66L, -0x1p16383L, -0x0.ffffffffffffffffp16383L),
9068 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, -0x1.0000000000000002p-66L, -0x1p16383L, -0x1p16383L),
9069 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, 0x1.0000000000000002p-66L, 0x1p16319L, 0x1p16319L),
9070 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, -0x1.0000000000000002p-66L, 0x1p16319L, 0x0.ffffffffffffffffp16319L),
9071 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, 0x1.0000000000000002p-66L, -0x1p16319L, -0x0.ffffffffffffffffp16319L),
9072 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, -0x1.0000000000000002p-66L, -0x1p16319L, -0x1p16319L),
9073 #endif
9074 #if defined (TEST_LDOUBLE) && LDBL_MANT_DIG == 113
9075 TEST_fff_f (fma, 0x1.4p-16382L, 0x1.0000000000000000000000000002p-1L, 0x1p-16384L, 0x1.c000000000000000000000000002p-16383L, UNDERFLOW_EXCEPTION),
9076 TEST_fff_f (fma, -0x1.4p-16382L, 0x1.0000000000000000000000000002p-1L, -0x1p-16384L, -0x1.c000000000000000000000000002p-16383L, UNDERFLOW_EXCEPTION),
9077 TEST_fff_f (fma, 0x1.fffffffffffffffffffffffffffcp-16382L, 0x1.0000000000000000000000000001p-1L, 0x1p-16494L, 0x0.ffffffffffffffffffffffffffffp-16382L, UNDERFLOW_EXCEPTION),
9078 TEST_fff_f (fma, -0x1.fffffffffffffffffffffffffffcp-16382L, 0x1.0000000000000000000000000001p-1L, -0x1p-16494L, -0x0.ffffffffffffffffffffffffffffp-16382L, UNDERFLOW_EXCEPTION),
9079 TEST_fff_f (fma, 0x1p-16494L, 0x1p-1L, 0x0.ffffffffffffffffffffffffffffp-16382L, 0x0.ffffffffffffffffffffffffffffp-16382L, UNDERFLOW_EXCEPTION),
9080 TEST_fff_f (fma, -0x1p-16494L, 0x1p-1L, -0x0.ffffffffffffffffffffffffffffp-16382L, -0x0.ffffffffffffffffffffffffffffp-16382L, UNDERFLOW_EXCEPTION),
9081 TEST_fff_f (fma, 0x1p-16494L, 0x1.1p-1L, 0x0.ffffffffffffffffffffffffffffp-16382L, 0x0.ffffffffffffffffffffffffffffp-16382L, UNDERFLOW_EXCEPTION),
9082 TEST_fff_f (fma, -0x1p-16494L, 0x1.1p-1L, -0x0.ffffffffffffffffffffffffffffp-16382L, -0x0.ffffffffffffffffffffffffffffp-16382L, UNDERFLOW_EXCEPTION),
9083 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, 0x1p16383L, 0x1p16383L),
9084 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, 0x1p16383L, 0x0.ffffffffffffffffffffffffffff8p16383L),
9085 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, -0x1p16383L, -0x0.ffffffffffffffffffffffffffff8p16383L),
9086 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, -0x1p16383L, -0x1p16383L),
9087 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, 0x1p-16382L, 0x1p-16382L),
9088 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, 0x1p-16382L, 0x0.ffffffffffffffffffffffffffffp-16382L, UNDERFLOW_EXCEPTION),
9089 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, -0x1p-16382L, -0x0.ffffffffffffffffffffffffffffp-16382L, UNDERFLOW_EXCEPTION),
9090 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, -0x1p-16382L, -0x1p-16382L),
9091 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, 0x0.ffffffffffffffffffffffffffffp-16382L, 0x0.ffffffffffffffffffffffffffffp-16382L, UNDERFLOW_EXCEPTION),
9092 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, 0x0.ffffffffffffffffffffffffffffp-16382L, 0x0.fffffffffffffffffffffffffffep-16382L, UNDERFLOW_EXCEPTION),
9093 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, -0x0.ffffffffffffffffffffffffffffp-16382L, -0x0.fffffffffffffffffffffffffffep-16382L, UNDERFLOW_EXCEPTION),
9094 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, -0x0.ffffffffffffffffffffffffffffp-16382L, -0x0.ffffffffffffffffffffffffffffp-16382L, UNDERFLOW_EXCEPTION),
9095 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, 0x1p-16494L, 0x1p-16494L, UNDERFLOW_EXCEPTION),
9096 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, 0x1p-16494L, plus_zero, UNDERFLOW_EXCEPTION),
9097 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, -0x1p-16494L, minus_zero, UNDERFLOW_EXCEPTION),
9098 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, -0x1p-16494L, -0x1p-16494L, UNDERFLOW_EXCEPTION),
9099 TEST_fff_f (fma, 0x0.ffffffffffffffffffffffffffff8p0L, 0x0.ffffffffffffffffffffffffffff8p0L, -0x0.ffffffffffffffffffffffffffffp0L, 0x1p-226L),
9100 TEST_fff_f (fma, 0x0.ffffffffffffffffffffffffffff8p0L, -0x0.ffffffffffffffffffffffffffff8p0L, 0x0.ffffffffffffffffffffffffffffp0L, -0x1p-226L),
9101 TEST_fff_f (fma, -0x0.ffffffffffffffffffffffffffff8p0L, 0x0.ffffffffffffffffffffffffffff8p0L, 0x0.ffffffffffffffffffffffffffffp0L, -0x1p-226L),
9102 TEST_fff_f (fma, -0x0.ffffffffffffffffffffffffffff8p0L, -0x0.ffffffffffffffffffffffffffff8p0L, -0x0.ffffffffffffffffffffffffffffp0L, 0x1p-226L),
9103 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, 0x1.0000000000000000000000000001p-66L, 0x1p16383L, 0x1p16383L),
9104 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, -0x1.0000000000000000000000000001p-66L, 0x1p16383L, 0x0.ffffffffffffffffffffffffffff8p16383L),
9105 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, 0x1.0000000000000000000000000001p-66L, -0x1p16383L, -0x0.ffffffffffffffffffffffffffff8p16383L),
9106 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, -0x1.0000000000000000000000000001p-66L, -0x1p16383L, -0x1p16383L),
9107 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, 0x1.0000000000000000000000000001p-66L, 0x1p16319L, 0x1p16319L),
9108 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, -0x1.0000000000000000000000000001p-66L, 0x1p16319L, 0x0.ffffffffffffffffffffffffffff8p16319L),
9109 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, 0x1.0000000000000000000000000001p-66L, -0x1p16319L, -0x0.ffffffffffffffffffffffffffff8p16319L),
9110 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, -0x1.0000000000000000000000000001p-66L, -0x1p16319L, -0x1p16319L),
9111 #endif
9112 END_DATA (fma_towardzero)
9113 };
9114
9115 static void
9116 fma_test_towardzero (void)
9117 {
9118 START (fma_towardzero);
9119 RUN_TEST_LOOP_fff_f (fma, fma_towardzero_test_data, FE_TOWARDZERO);
9120 END (fma_towardzero);
9121 }
9122
9123
9124 static const struct test_fff_f_data fma_downward_test_data[] =
9125 {
9126 START_DATA (fma_downward),
9127 TEST_fff_f (fma, plus_zero, plus_zero, plus_zero, plus_zero),
9128 TEST_fff_f (fma, plus_zero, plus_zero, minus_zero, minus_zero),
9129 TEST_fff_f (fma, plus_zero, minus_zero, plus_zero, minus_zero),
9130 TEST_fff_f (fma, plus_zero, minus_zero, minus_zero, minus_zero),
9131 TEST_fff_f (fma, minus_zero, plus_zero, plus_zero, minus_zero),
9132 TEST_fff_f (fma, minus_zero, plus_zero, minus_zero, minus_zero),
9133 TEST_fff_f (fma, minus_zero, minus_zero, plus_zero, plus_zero),
9134 TEST_fff_f (fma, minus_zero, minus_zero, minus_zero, minus_zero),
9135 TEST_fff_f (fma, 1.0, plus_zero, plus_zero, plus_zero),
9136 TEST_fff_f (fma, 1.0, plus_zero, minus_zero, minus_zero),
9137 TEST_fff_f (fma, 1.0, minus_zero, plus_zero, minus_zero),
9138 TEST_fff_f (fma, 1.0, minus_zero, minus_zero, minus_zero),
9139 TEST_fff_f (fma, -1.0, plus_zero, plus_zero, minus_zero),
9140 TEST_fff_f (fma, -1.0, plus_zero, minus_zero, minus_zero),
9141 TEST_fff_f (fma, -1.0, minus_zero, plus_zero, plus_zero),
9142 TEST_fff_f (fma, -1.0, minus_zero, minus_zero, minus_zero),
9143 TEST_fff_f (fma, plus_zero, 1.0, plus_zero, plus_zero),
9144 TEST_fff_f (fma, plus_zero, 1.0, minus_zero, minus_zero),
9145 TEST_fff_f (fma, plus_zero, -1.0, plus_zero, minus_zero),
9146 TEST_fff_f (fma, plus_zero, -1.0, minus_zero, minus_zero),
9147 TEST_fff_f (fma, minus_zero, 1.0, plus_zero, minus_zero),
9148 TEST_fff_f (fma, minus_zero, 1.0, minus_zero, minus_zero),
9149 TEST_fff_f (fma, minus_zero, -1.0, plus_zero, plus_zero),
9150 TEST_fff_f (fma, minus_zero, -1.0, minus_zero, minus_zero),
9151
9152 TEST_fff_f (fma, 1.0, 1.0, -1.0, minus_zero),
9153 TEST_fff_f (fma, 1.0, -1.0, 1.0, minus_zero),
9154 TEST_fff_f (fma, -1.0, 1.0, 1.0, minus_zero),
9155 TEST_fff_f (fma, -1.0, -1.0, -1.0, minus_zero),
9156
9157 TEST_fff_f (fma, min_value, min_value, plus_zero, plus_zero, UNDERFLOW_EXCEPTION),
9158 TEST_fff_f (fma, min_value, min_value, minus_zero, plus_zero, UNDERFLOW_EXCEPTION),
9159 TEST_fff_f (fma, min_value, -min_value, plus_zero, -min_subnorm_value, UNDERFLOW_EXCEPTION),
9160 TEST_fff_f (fma, min_value, -min_value, minus_zero, -min_subnorm_value, UNDERFLOW_EXCEPTION),
9161 TEST_fff_f (fma, -min_value, min_value, plus_zero, -min_subnorm_value, UNDERFLOW_EXCEPTION),
9162 TEST_fff_f (fma, -min_value, min_value, minus_zero, -min_subnorm_value, UNDERFLOW_EXCEPTION),
9163 TEST_fff_f (fma, -min_value, -min_value, plus_zero, plus_zero, UNDERFLOW_EXCEPTION),
9164 TEST_fff_f (fma, -min_value, -min_value, minus_zero, plus_zero, UNDERFLOW_EXCEPTION),
9165
9166 #if !(defined TEST_LDOUBLE && LDBL_MANT_DIG == 106) /* Bug 13304. */
9167 TEST_fff_f (fma, max_value, max_value, min_value, max_value, OVERFLOW_EXCEPTION),
9168 TEST_fff_f (fma, max_value, max_value, -min_value, max_value, OVERFLOW_EXCEPTION),
9169 TEST_fff_f (fma, max_value, -max_value, min_value, minus_infty, OVERFLOW_EXCEPTION),
9170 TEST_fff_f (fma, max_value, -max_value, -min_value, minus_infty, OVERFLOW_EXCEPTION),
9171 TEST_fff_f (fma, -max_value, max_value, min_value, minus_infty, OVERFLOW_EXCEPTION),
9172 TEST_fff_f (fma, -max_value, max_value, -min_value, minus_infty, OVERFLOW_EXCEPTION),
9173 TEST_fff_f (fma, -max_value, -max_value, min_value, max_value, OVERFLOW_EXCEPTION),
9174 TEST_fff_f (fma, -max_value, -max_value, -min_value, max_value, OVERFLOW_EXCEPTION),
9175 #endif
9176
9177 #if defined (TEST_FLOAT) && FLT_MANT_DIG == 24
9178 TEST_fff_f (fma, 0x1.4p-126, 0x1.000004p-1, 0x1p-128, 0x1.c00004p-127, UNDERFLOW_EXCEPTION),
9179 TEST_fff_f (fma, -0x1.4p-126, 0x1.000004p-1, -0x1p-128, -0x1.c00008p-127, UNDERFLOW_EXCEPTION),
9180 TEST_fff_f (fma, 0x1.fffff8p-126, 0x1.000002p-1, 0x1p-149, 0x0.fffffep-126, UNDERFLOW_EXCEPTION),
9181 TEST_fff_f (fma, -0x1.fffff8p-126, 0x1.000002p-1, -0x1p-149, -0x1p-126, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING),
9182 TEST_fff_f (fma, 0x1p-149, 0x1p-1, 0x0.fffffep-126, 0x0.fffffep-126, UNDERFLOW_EXCEPTION),
9183 TEST_fff_f (fma, -0x1p-149, 0x1p-1, -0x0.fffffep-126, -0x1p-126, UNDERFLOW_EXCEPTION),
9184 TEST_fff_f (fma, 0x1p-149, 0x1.1p-1, 0x0.fffffep-126, 0x0.fffffep-126, UNDERFLOW_EXCEPTION),
9185 TEST_fff_f (fma, -0x1p-149, 0x1.1p-1, -0x0.fffffep-126, -0x1p-126, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING),
9186 TEST_fff_f (fma, 0x1p-149, 0x1p-149, 0x1p127, 0x1p127),
9187 TEST_fff_f (fma, 0x1p-149, -0x1p-149, 0x1p127, 0x0.ffffffp127),
9188 TEST_fff_f (fma, 0x1p-149, 0x1p-149, -0x1p127, -0x1p127),
9189 TEST_fff_f (fma, 0x1p-149, -0x1p-149, -0x1p127, -0x1.000002p127),
9190 TEST_fff_f (fma, 0x1p-149, 0x1p-149, 0x1p-126, 0x1p-126),
9191 TEST_fff_f (fma, 0x1p-149, -0x1p-149, 0x1p-126, 0x0.fffffep-126, UNDERFLOW_EXCEPTION),
9192 TEST_fff_f (fma, 0x1p-149, 0x1p-149, -0x1p-126, -0x1p-126, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING),
9193 TEST_fff_f (fma, 0x1p-149, -0x1p-149, -0x1p-126, -0x1.000002p-126),
9194 TEST_fff_f (fma, 0x1p-149, 0x1p-149, 0x0.fffffep-126, 0x0.fffffep-126, UNDERFLOW_EXCEPTION),
9195 TEST_fff_f (fma, 0x1p-149, -0x1p-149, 0x0.fffffep-126, 0x0.fffffcp-126, UNDERFLOW_EXCEPTION),
9196 TEST_fff_f (fma, 0x1p-149, 0x1p-149, -0x0.fffffep-126, -0x0.fffffep-126, UNDERFLOW_EXCEPTION),
9197 TEST_fff_f (fma, 0x1p-149, -0x1p-149, -0x0.fffffep-126, -0x1p-126, UNDERFLOW_EXCEPTION),
9198 TEST_fff_f (fma, 0x1p-149, 0x1p-149, 0x1p-149, 0x1p-149, UNDERFLOW_EXCEPTION),
9199 TEST_fff_f (fma, 0x1p-149, -0x1p-149, 0x1p-149, plus_zero, UNDERFLOW_EXCEPTION),
9200 TEST_fff_f (fma, 0x1p-149, 0x1p-149, -0x1p-149, -0x1p-149, UNDERFLOW_EXCEPTION),
9201 TEST_fff_f (fma, 0x1p-149, -0x1p-149, -0x1p-149, -0x1p-148, UNDERFLOW_EXCEPTION),
9202 TEST_fff_f (fma, 0x0.fffp0, 0x0.fffp0, -0x0.ffep0, 0x1p-24),
9203 TEST_fff_f (fma, 0x0.fffp0, -0x0.fffp0, 0x0.ffep0, -0x1p-24),
9204 TEST_fff_f (fma, -0x0.fffp0, 0x0.fffp0, 0x0.ffep0, -0x1p-24),
9205 TEST_fff_f (fma, -0x0.fffp0, -0x0.fffp0, -0x0.ffep0, 0x1p-24),
9206 TEST_fff_f (fma, 0x1.000002p-126, 0x1.000002p-26, 0x1p127, 0x1p127),
9207 TEST_fff_f (fma, 0x1.000002p-126, -0x1.000002p-26, 0x1p127, 0x0.ffffffp127),
9208 TEST_fff_f (fma, 0x1.000002p-126, 0x1.000002p-26, -0x1p127, -0x1p127),
9209 TEST_fff_f (fma, 0x1.000002p-126, -0x1.000002p-26, -0x1p127, -0x1.000002p127),
9210 TEST_fff_f (fma, 0x1.000002p-126, 0x1.000002p-26, 0x1p103, 0x1p103),
9211 TEST_fff_f (fma, 0x1.000002p-126, -0x1.000002p-26, 0x1p103, 0x0.ffffffp103),
9212 TEST_fff_f (fma, 0x1.000002p-126, 0x1.000002p-26, -0x1p103, -0x1p103),
9213 TEST_fff_f (fma, 0x1.000002p-126, -0x1.000002p-26, -0x1p103, -0x1.000002p103),
9214 #endif
9215 #if defined (TEST_DOUBLE) && DBL_MANT_DIG == 53
9216 TEST_fff_f (fma, 0x1.4p-1022, 0x1.0000000000002p-1, 0x1p-1024, 0x1.c000000000002p-1023, UNDERFLOW_EXCEPTION),
9217 TEST_fff_f (fma, -0x1.4p-1022, 0x1.0000000000002p-1, -0x1p-1024, -0x1.c000000000004p-1023, UNDERFLOW_EXCEPTION),
9218 TEST_fff_f (fma, 0x1.ffffffffffffcp-1022, 0x1.0000000000001p-1, 0x1p-1074, 0x0.fffffffffffffp-1022, UNDERFLOW_EXCEPTION),
9219 TEST_fff_f (fma, -0x1.ffffffffffffcp-1022, 0x1.0000000000001p-1, -0x1p-1074, -0x1p-1022, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING),
9220 TEST_fff_f (fma, 0x1p-1074, 0x1p-1, 0x0.fffffffffffffp-1022, 0x0.fffffffffffffp-1022, UNDERFLOW_EXCEPTION),
9221 TEST_fff_f (fma, -0x1p-1074, 0x1p-1, -0x0.fffffffffffffp-1022, -0x1p-1022, UNDERFLOW_EXCEPTION),
9222 TEST_fff_f (fma, 0x1p-1074, 0x1.1p-1, 0x0.fffffffffffffp-1022, 0x0.fffffffffffffp-1022, UNDERFLOW_EXCEPTION),
9223 TEST_fff_f (fma, -0x1p-1074, 0x1.1p-1, -0x0.fffffffffffffp-1022, -0x1p-1022, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING),
9224 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, 0x1p1023, 0x1p1023),
9225 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, 0x1p1023, 0x0.fffffffffffff8p1023),
9226 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, -0x1p1023, -0x1p1023),
9227 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, -0x1p1023, -0x1.0000000000001p1023),
9228 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, 0x1p-1022, 0x1p-1022),
9229 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, 0x1p-1022, 0x0.fffffffffffffp-1022, UNDERFLOW_EXCEPTION),
9230 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, -0x1p-1022, -0x1p-1022, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING),
9231 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, -0x1p-1022, -0x1.0000000000001p-1022),
9232 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, 0x0.fffffffffffffp-1022, 0x0.fffffffffffffp-1022, UNDERFLOW_EXCEPTION),
9233 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, 0x0.fffffffffffffp-1022, 0x0.ffffffffffffep-1022, UNDERFLOW_EXCEPTION),
9234 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, -0x0.fffffffffffffp-1022, -0x0.fffffffffffffp-1022, UNDERFLOW_EXCEPTION),
9235 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, -0x0.fffffffffffffp-1022, -0x1p-1022, UNDERFLOW_EXCEPTION),
9236 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, 0x1p-1074, 0x1p-1074, UNDERFLOW_EXCEPTION),
9237 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, 0x1p-1074, plus_zero, UNDERFLOW_EXCEPTION),
9238 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, -0x1p-1074, -0x1p-1074, UNDERFLOW_EXCEPTION),
9239 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, -0x1p-1074, -0x1p-1073, UNDERFLOW_EXCEPTION),
9240 TEST_fff_f (fma, 0x0.fffffffffffff8p0, 0x0.fffffffffffff8p0, -0x0.fffffffffffffp0, 0x1p-106),
9241 TEST_fff_f (fma, 0x0.fffffffffffff8p0, -0x0.fffffffffffff8p0, 0x0.fffffffffffffp0, -0x1p-106),
9242 TEST_fff_f (fma, -0x0.fffffffffffff8p0, 0x0.fffffffffffff8p0, 0x0.fffffffffffffp0, -0x1p-106),
9243 TEST_fff_f (fma, -0x0.fffffffffffff8p0, -0x0.fffffffffffff8p0, -0x0.fffffffffffffp0, 0x1p-106),
9244 TEST_fff_f (fma, 0x1.0000000000001p-1022, 0x1.0000000000001p-55, 0x1p1023, 0x1p1023),
9245 TEST_fff_f (fma, 0x1.0000000000001p-1022, -0x1.0000000000001p-55, 0x1p1023, 0x0.fffffffffffff8p1023),
9246 TEST_fff_f (fma, 0x1.0000000000001p-1022, 0x1.0000000000001p-55, -0x1p1023, -0x1p1023),
9247 TEST_fff_f (fma, 0x1.0000000000001p-1022, -0x1.0000000000001p-55, -0x1p1023, -0x1.0000000000001p1023),
9248 TEST_fff_f (fma, 0x1.0000000000001p-1022, 0x1.0000000000001p-55, 0x1p970, 0x1p970),
9249 TEST_fff_f (fma, 0x1.0000000000001p-1022, -0x1.0000000000001p-55, 0x1p970, 0x0.fffffffffffff8p970),
9250 TEST_fff_f (fma, 0x1.0000000000001p-1022, 0x1.0000000000001p-55, -0x1p970, -0x1p970),
9251 TEST_fff_f (fma, 0x1.0000000000001p-1022, -0x1.0000000000001p-55, -0x1p970, -0x1.0000000000001p970),
9252 #endif
9253 #if defined (TEST_LDOUBLE) && LDBL_MANT_DIG == 64
9254 TEST_fff_f (fma, 0x1.4p-16382L, 0x1.0000000000000004p-1L, 0x1p-16384L, 0x1.c000000000000004p-16383L, UNDERFLOW_EXCEPTION),
9255 TEST_fff_f (fma, -0x1.4p-16382L, 0x1.0000000000000004p-1L, -0x1p-16384L, -0x1.c000000000000008p-16383L, UNDERFLOW_EXCEPTION),
9256 TEST_fff_f (fma, 0x1.fffffffffffffff8p-16382L, 0x1.0000000000000002p-1L, 0x1p-16445L, 0x0.fffffffffffffffep-16382L, UNDERFLOW_EXCEPTION),
9257 TEST_fff_f (fma, -0x1.fffffffffffffff8p-16382L, 0x1.0000000000000002p-1L, -0x1p-16445L, -0x1p-16382L, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING),
9258 TEST_fff_f (fma, 0x1p-16445L, 0x1p-1L, 0x0.fffffffffffffffep-16382L, 0x0.fffffffffffffffep-16382L, UNDERFLOW_EXCEPTION),
9259 TEST_fff_f (fma, -0x1p-16445L, 0x1p-1L, -0x0.fffffffffffffffep-16382L, -0x1p-16382L, UNDERFLOW_EXCEPTION),
9260 TEST_fff_f (fma, 0x1p-16445L, 0x1.1p-1L, 0x0.fffffffffffffffep-16382L, 0x0.fffffffffffffffep-16382L, UNDERFLOW_EXCEPTION),
9261 TEST_fff_f (fma, -0x1p-16445L, 0x1.1p-1L, -0x0.fffffffffffffffep-16382L, -0x1p-16382L, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING),
9262 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, 0x1p16383L, 0x1p16383L),
9263 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, 0x1p16383L, 0x0.ffffffffffffffffp16383L),
9264 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, -0x1p16383L, -0x1p16383L),
9265 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, -0x1p16383L, -0x1.0000000000000002p16383L),
9266 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, 0x1p-16382L, 0x1p-16382L),
9267 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, 0x1p-16382L, 0x0.fffffffffffffffep-16382L, UNDERFLOW_EXCEPTION),
9268 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, -0x1p-16382L, -0x1p-16382L, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING),
9269 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, -0x1p-16382L, -0x1.0000000000000002p-16382L),
9270 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, 0x0.fffffffffffffffep-16382L, 0x0.fffffffffffffffep-16382L, UNDERFLOW_EXCEPTION),
9271 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, 0x0.fffffffffffffffep-16382L, 0x0.fffffffffffffffcp-16382L, UNDERFLOW_EXCEPTION),
9272 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, -0x0.fffffffffffffffep-16382L, -0x0.fffffffffffffffep-16382L, UNDERFLOW_EXCEPTION),
9273 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, -0x0.fffffffffffffffep-16382L, -0x1p-16382L, UNDERFLOW_EXCEPTION),
9274 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, 0x1p-16445L, 0x1p-16445L, UNDERFLOW_EXCEPTION),
9275 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, 0x1p-16445L, plus_zero, UNDERFLOW_EXCEPTION),
9276 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, -0x1p-16445L, -0x1p-16445L, UNDERFLOW_EXCEPTION),
9277 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, -0x1p-16445L, -0x1p-16444L, UNDERFLOW_EXCEPTION),
9278 TEST_fff_f (fma, 0x0.ffffffffffffffffp0L, 0x0.ffffffffffffffffp0L, -0x0.fffffffffffffffep0L, 0x1p-128L),
9279 TEST_fff_f (fma, 0x0.ffffffffffffffffp0L, -0x0.ffffffffffffffffp0L, 0x0.fffffffffffffffep0L, -0x1p-128L),
9280 TEST_fff_f (fma, -0x0.ffffffffffffffffp0L, 0x0.ffffffffffffffffp0L, 0x0.fffffffffffffffep0L, -0x1p-128L),
9281 TEST_fff_f (fma, -0x0.ffffffffffffffffp0L, -0x0.ffffffffffffffffp0L, -0x0.fffffffffffffffep0L, 0x1p-128L),
9282 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, 0x1.0000000000000002p-66L, 0x1p16383L, 0x1p16383L),
9283 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, -0x1.0000000000000002p-66L, 0x1p16383L, 0x0.ffffffffffffffffp16383L),
9284 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, 0x1.0000000000000002p-66L, -0x1p16383L, -0x1p16383L),
9285 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, -0x1.0000000000000002p-66L, -0x1p16383L, -0x1.0000000000000002p16383L),
9286 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, 0x1.0000000000000002p-66L, 0x1p16319L, 0x1p16319L),
9287 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, -0x1.0000000000000002p-66L, 0x1p16319L, 0x0.ffffffffffffffffp16319L),
9288 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, 0x1.0000000000000002p-66L, -0x1p16319L, -0x1p16319L),
9289 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, -0x1.0000000000000002p-66L, -0x1p16319L, -0x1.0000000000000002p16319L),
9290 #endif
9291 #if defined (TEST_LDOUBLE) && LDBL_MANT_DIG == 113
9292 TEST_fff_f (fma, 0x1.4p-16382L, 0x1.0000000000000000000000000002p-1L, 0x1p-16384L, 0x1.c000000000000000000000000002p-16383L, UNDERFLOW_EXCEPTION),
9293 TEST_fff_f (fma, -0x1.4p-16382L, 0x1.0000000000000000000000000002p-1L, -0x1p-16384L, -0x1.c000000000000000000000000004p-16383L, UNDERFLOW_EXCEPTION),
9294 TEST_fff_f (fma, 0x1.fffffffffffffffffffffffffffcp-16382L, 0x1.0000000000000000000000000001p-1L, 0x1p-16494L, 0x0.ffffffffffffffffffffffffffffp-16382L, UNDERFLOW_EXCEPTION),
9295 TEST_fff_f (fma, -0x1.fffffffffffffffffffffffffffcp-16382L, 0x1.0000000000000000000000000001p-1L, -0x1p-16494L, -0x1p-16382L, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING),
9296 TEST_fff_f (fma, 0x1p-16494L, 0x1p-1L, 0x0.ffffffffffffffffffffffffffffp-16382L, 0x0.ffffffffffffffffffffffffffffp-16382L, UNDERFLOW_EXCEPTION),
9297 TEST_fff_f (fma, -0x1p-16494L, 0x1p-1L, -0x0.ffffffffffffffffffffffffffffp-16382L, -0x1p-16382L, UNDERFLOW_EXCEPTION),
9298 TEST_fff_f (fma, 0x1p-16494L, 0x1.1p-1L, 0x0.ffffffffffffffffffffffffffffp-16382L, 0x0.ffffffffffffffffffffffffffffp-16382L, UNDERFLOW_EXCEPTION),
9299 TEST_fff_f (fma, -0x1p-16494L, 0x1.1p-1L, -0x0.ffffffffffffffffffffffffffffp-16382L, -0x1p-16382L, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING),
9300 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, 0x1p16383L, 0x1p16383L),
9301 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, 0x1p16383L, 0x0.ffffffffffffffffffffffffffff8p16383L),
9302 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, -0x1p16383L, -0x1p16383L),
9303 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, -0x1p16383L, -0x1.0000000000000000000000000001p16383L),
9304 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, 0x1p-16382L, 0x1p-16382L),
9305 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, 0x1p-16382L, 0x0.ffffffffffffffffffffffffffffp-16382L, UNDERFLOW_EXCEPTION),
9306 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, -0x1p-16382L, -0x1p-16382L, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING),
9307 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, -0x1p-16382L, -0x1.0000000000000000000000000001p-16382L),
9308 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, 0x0.ffffffffffffffffffffffffffffp-16382L, 0x0.ffffffffffffffffffffffffffffp-16382L, UNDERFLOW_EXCEPTION),
9309 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, 0x0.ffffffffffffffffffffffffffffp-16382L, 0x0.fffffffffffffffffffffffffffep-16382L, UNDERFLOW_EXCEPTION),
9310 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, -0x0.ffffffffffffffffffffffffffffp-16382L, -0x0.ffffffffffffffffffffffffffffp-16382L, UNDERFLOW_EXCEPTION),
9311 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, -0x0.ffffffffffffffffffffffffffffp-16382L, -0x1p-16382L, UNDERFLOW_EXCEPTION),
9312 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, 0x1p-16494L, 0x1p-16494L, UNDERFLOW_EXCEPTION),
9313 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, 0x1p-16494L, plus_zero, UNDERFLOW_EXCEPTION),
9314 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, -0x1p-16494L, -0x1p-16494L, UNDERFLOW_EXCEPTION),
9315 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, -0x1p-16494L, -0x1p-16493L, UNDERFLOW_EXCEPTION),
9316 TEST_fff_f (fma, 0x0.ffffffffffffffffffffffffffff8p0L, 0x0.ffffffffffffffffffffffffffff8p0L, -0x0.ffffffffffffffffffffffffffffp0L, 0x1p-226L),
9317 TEST_fff_f (fma, 0x0.ffffffffffffffffffffffffffff8p0L, -0x0.ffffffffffffffffffffffffffff8p0L, 0x0.ffffffffffffffffffffffffffffp0L, -0x1p-226L),
9318 TEST_fff_f (fma, -0x0.ffffffffffffffffffffffffffff8p0L, 0x0.ffffffffffffffffffffffffffff8p0L, 0x0.ffffffffffffffffffffffffffffp0L, -0x1p-226L),
9319 TEST_fff_f (fma, -0x0.ffffffffffffffffffffffffffff8p0L, -0x0.ffffffffffffffffffffffffffff8p0L, -0x0.ffffffffffffffffffffffffffffp0L, 0x1p-226L),
9320 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, 0x1.0000000000000000000000000001p-66L, 0x1p16383L, 0x1p16383L),
9321 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, -0x1.0000000000000000000000000001p-66L, 0x1p16383L, 0x0.ffffffffffffffffffffffffffff8p16383L),
9322 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, 0x1.0000000000000000000000000001p-66L, -0x1p16383L, -0x1p16383L),
9323 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, -0x1.0000000000000000000000000001p-66L, -0x1p16383L, -0x1.0000000000000000000000000001p16383L),
9324 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, 0x1.0000000000000000000000000001p-66L, 0x1p16319L, 0x1p16319L),
9325 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, -0x1.0000000000000000000000000001p-66L, 0x1p16319L, 0x0.ffffffffffffffffffffffffffff8p16319L),
9326 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, 0x1.0000000000000000000000000001p-66L, -0x1p16319L, -0x1p16319L),
9327 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, -0x1.0000000000000000000000000001p-66L, -0x1p16319L, -0x1.0000000000000000000000000001p16319L),
9328 #endif
9329 END_DATA (fma_downward)
9330 };
9331
9332 static void
9333 fma_test_downward (void)
9334 {
9335 START (fma_downward);
9336 RUN_TEST_LOOP_fff_f (fma, fma_downward_test_data, FE_DOWNWARD);
9337 END (fma_downward);
9338 }
9339
9340
9341 static const struct test_fff_f_data fma_upward_test_data[] =
9342 {
9343 START_DATA (fma_upward),
9344 TEST_fff_f (fma, plus_zero, plus_zero, plus_zero, plus_zero),
9345 TEST_fff_f (fma, plus_zero, plus_zero, minus_zero, plus_zero),
9346 TEST_fff_f (fma, plus_zero, minus_zero, plus_zero, plus_zero),
9347 TEST_fff_f (fma, plus_zero, minus_zero, minus_zero, minus_zero),
9348 TEST_fff_f (fma, minus_zero, plus_zero, plus_zero, plus_zero),
9349 TEST_fff_f (fma, minus_zero, plus_zero, minus_zero, minus_zero),
9350 TEST_fff_f (fma, minus_zero, minus_zero, plus_zero, plus_zero),
9351 TEST_fff_f (fma, minus_zero, minus_zero, minus_zero, plus_zero),
9352 TEST_fff_f (fma, 1.0, plus_zero, plus_zero, plus_zero),
9353 TEST_fff_f (fma, 1.0, plus_zero, minus_zero, plus_zero),
9354 TEST_fff_f (fma, 1.0, minus_zero, plus_zero, plus_zero),
9355 TEST_fff_f (fma, 1.0, minus_zero, minus_zero, minus_zero),
9356 TEST_fff_f (fma, -1.0, plus_zero, plus_zero, plus_zero),
9357 TEST_fff_f (fma, -1.0, plus_zero, minus_zero, minus_zero),
9358 TEST_fff_f (fma, -1.0, minus_zero, plus_zero, plus_zero),
9359 TEST_fff_f (fma, -1.0, minus_zero, minus_zero, plus_zero),
9360 TEST_fff_f (fma, plus_zero, 1.0, plus_zero, plus_zero),
9361 TEST_fff_f (fma, plus_zero, 1.0, minus_zero, plus_zero),
9362 TEST_fff_f (fma, plus_zero, -1.0, plus_zero, plus_zero),
9363 TEST_fff_f (fma, plus_zero, -1.0, minus_zero, minus_zero),
9364 TEST_fff_f (fma, minus_zero, 1.0, plus_zero, plus_zero),
9365 TEST_fff_f (fma, minus_zero, 1.0, minus_zero, minus_zero),
9366 TEST_fff_f (fma, minus_zero, -1.0, plus_zero, plus_zero),
9367 TEST_fff_f (fma, minus_zero, -1.0, minus_zero, plus_zero),
9368
9369 TEST_fff_f (fma, 1.0, 1.0, -1.0, plus_zero),
9370 TEST_fff_f (fma, 1.0, -1.0, 1.0, plus_zero),
9371 TEST_fff_f (fma, -1.0, 1.0, 1.0, plus_zero),
9372 TEST_fff_f (fma, -1.0, -1.0, -1.0, plus_zero),
9373
9374 TEST_fff_f (fma, min_value, min_value, plus_zero, min_subnorm_value, UNDERFLOW_EXCEPTION),
9375 TEST_fff_f (fma, min_value, min_value, minus_zero, min_subnorm_value, UNDERFLOW_EXCEPTION),
9376 TEST_fff_f (fma, min_value, -min_value, plus_zero, minus_zero, UNDERFLOW_EXCEPTION),
9377 TEST_fff_f (fma, min_value, -min_value, minus_zero, minus_zero, UNDERFLOW_EXCEPTION),
9378 TEST_fff_f (fma, -min_value, min_value, plus_zero, minus_zero, UNDERFLOW_EXCEPTION),
9379 TEST_fff_f (fma, -min_value, min_value, minus_zero, minus_zero, UNDERFLOW_EXCEPTION),
9380 TEST_fff_f (fma, -min_value, -min_value, plus_zero, min_subnorm_value, UNDERFLOW_EXCEPTION),
9381 TEST_fff_f (fma, -min_value, -min_value, minus_zero, min_subnorm_value, UNDERFLOW_EXCEPTION),
9382
9383 #if !(defined TEST_LDOUBLE && LDBL_MANT_DIG == 106) /* Bug 13304. */
9384 TEST_fff_f (fma, max_value, max_value, min_value, plus_infty, OVERFLOW_EXCEPTION),
9385 TEST_fff_f (fma, max_value, max_value, -min_value, plus_infty, OVERFLOW_EXCEPTION),
9386 TEST_fff_f (fma, max_value, -max_value, min_value, -max_value, OVERFLOW_EXCEPTION),
9387 TEST_fff_f (fma, max_value, -max_value, -min_value, -max_value, OVERFLOW_EXCEPTION),
9388 TEST_fff_f (fma, -max_value, max_value, min_value, -max_value, OVERFLOW_EXCEPTION),
9389 TEST_fff_f (fma, -max_value, max_value, -min_value, -max_value, OVERFLOW_EXCEPTION),
9390 TEST_fff_f (fma, -max_value, -max_value, min_value, plus_infty, OVERFLOW_EXCEPTION),
9391 TEST_fff_f (fma, -max_value, -max_value, -min_value, plus_infty, OVERFLOW_EXCEPTION),
9392 #endif
9393
9394 #if defined (TEST_FLOAT) && FLT_MANT_DIG == 24
9395 TEST_fff_f (fma, 0x1.4p-126, 0x1.000004p-1, 0x1p-128, 0x1.c00008p-127, UNDERFLOW_EXCEPTION),
9396 TEST_fff_f (fma, -0x1.4p-126, 0x1.000004p-1, -0x1p-128, -0x1.c00004p-127, UNDERFLOW_EXCEPTION),
9397 TEST_fff_f (fma, 0x1.fffff8p-126, 0x1.000002p-1, 0x1p-149, 0x1p-126, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING),
9398 TEST_fff_f (fma, -0x1.fffff8p-126, 0x1.000002p-1, -0x1p-149, -0x0.fffffep-126, UNDERFLOW_EXCEPTION),
9399 TEST_fff_f (fma, 0x1p-149, 0x1p-1, 0x0.fffffep-126, 0x1p-126, UNDERFLOW_EXCEPTION),
9400 TEST_fff_f (fma, -0x1p-149, 0x1p-1, -0x0.fffffep-126, -0x0.fffffep-126, UNDERFLOW_EXCEPTION),
9401 TEST_fff_f (fma, 0x1p-149, 0x1.1p-1, 0x0.fffffep-126, 0x1p-126, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING),
9402 TEST_fff_f (fma, -0x1p-149, 0x1.1p-1, -0x0.fffffep-126, -0x0.fffffep-126, UNDERFLOW_EXCEPTION),
9403 TEST_fff_f (fma, 0x1p-149, 0x1p-149, 0x1p127, 0x1.000002p127),
9404 TEST_fff_f (fma, 0x1p-149, -0x1p-149, 0x1p127, 0x1p127),
9405 TEST_fff_f (fma, 0x1p-149, 0x1p-149, -0x1p127, -0x0.ffffffp127),
9406 TEST_fff_f (fma, 0x1p-149, -0x1p-149, -0x1p127, -0x1p127),
9407 TEST_fff_f (fma, 0x1p-149, 0x1p-149, 0x1p-126, 0x1.000002p-126),
9408 TEST_fff_f (fma, 0x1p-149, -0x1p-149, 0x1p-126, 0x1p-126, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING),
9409 TEST_fff_f (fma, 0x1p-149, 0x1p-149, -0x1p-126, -0x0.fffffep-126, UNDERFLOW_EXCEPTION),
9410 TEST_fff_f (fma, 0x1p-149, -0x1p-149, -0x1p-126, -0x1p-126),
9411 TEST_fff_f (fma, 0x1p-149, 0x1p-149, 0x0.fffffep-126, 0x1p-126, UNDERFLOW_EXCEPTION),
9412 TEST_fff_f (fma, 0x1p-149, -0x1p-149, 0x0.fffffep-126, 0x0.fffffep-126, UNDERFLOW_EXCEPTION),
9413 TEST_fff_f (fma, 0x1p-149, 0x1p-149, -0x0.fffffep-126, -0x0.fffffcp-126, UNDERFLOW_EXCEPTION),
9414 TEST_fff_f (fma, 0x1p-149, -0x1p-149, -0x0.fffffep-126, -0x0.fffffep-126, UNDERFLOW_EXCEPTION),
9415 TEST_fff_f (fma, 0x1p-149, 0x1p-149, 0x1p-149, 0x1p-148, UNDERFLOW_EXCEPTION),
9416 TEST_fff_f (fma, 0x1p-149, -0x1p-149, 0x1p-149, 0x1p-149, UNDERFLOW_EXCEPTION),
9417 TEST_fff_f (fma, 0x1p-149, 0x1p-149, -0x1p-149, minus_zero, UNDERFLOW_EXCEPTION),
9418 TEST_fff_f (fma, 0x1p-149, -0x1p-149, -0x1p-149, -0x1p-149, UNDERFLOW_EXCEPTION),
9419 TEST_fff_f (fma, 0x0.fffp0, 0x0.fffp0, -0x0.ffep0, 0x1p-24),
9420 TEST_fff_f (fma, 0x0.fffp0, -0x0.fffp0, 0x0.ffep0, -0x1p-24),
9421 TEST_fff_f (fma, -0x0.fffp0, 0x0.fffp0, 0x0.ffep0, -0x1p-24),
9422 TEST_fff_f (fma, -0x0.fffp0, -0x0.fffp0, -0x0.ffep0, 0x1p-24),
9423 TEST_fff_f (fma, 0x1.000002p-126, 0x1.000002p-26, 0x1p127, 0x1.000002p127),
9424 TEST_fff_f (fma, 0x1.000002p-126, -0x1.000002p-26, 0x1p127, 0x1p127),
9425 TEST_fff_f (fma, 0x1.000002p-126, 0x1.000002p-26, -0x1p127, -0x0.ffffffp127),
9426 TEST_fff_f (fma, 0x1.000002p-126, -0x1.000002p-26, -0x1p127, -0x1p127),
9427 TEST_fff_f (fma, 0x1.000002p-126, 0x1.000002p-26, 0x1p103, 0x1.000002p103),
9428 TEST_fff_f (fma, 0x1.000002p-126, -0x1.000002p-26, 0x1p103, 0x1p103),
9429 TEST_fff_f (fma, 0x1.000002p-126, 0x1.000002p-26, -0x1p103, -0x0.ffffffp103),
9430 TEST_fff_f (fma, 0x1.000002p-126, -0x1.000002p-26, -0x1p103, -0x1p103),
9431 #endif
9432 #if defined (TEST_DOUBLE) && DBL_MANT_DIG == 53
9433 TEST_fff_f (fma, 0x1.4p-1022, 0x1.0000000000002p-1, 0x1p-1024, 0x1.c000000000004p-1023, UNDERFLOW_EXCEPTION),
9434 TEST_fff_f (fma, -0x1.4p-1022, 0x1.0000000000002p-1, -0x1p-1024, -0x1.c000000000002p-1023, UNDERFLOW_EXCEPTION),
9435 TEST_fff_f (fma, 0x1.ffffffffffffcp-1022, 0x1.0000000000001p-1, 0x1p-1074, 0x1p-1022, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING),
9436 TEST_fff_f (fma, -0x1.ffffffffffffcp-1022, 0x1.0000000000001p-1, -0x1p-1074, -0x0.fffffffffffffp-1022, UNDERFLOW_EXCEPTION),
9437 TEST_fff_f (fma, 0x1p-1074, 0x1p-1, 0x0.fffffffffffffp-1022, 0x1p-1022, UNDERFLOW_EXCEPTION),
9438 TEST_fff_f (fma, -0x1p-1074, 0x1p-1, -0x0.fffffffffffffp-1022, -0x0.fffffffffffffp-1022, UNDERFLOW_EXCEPTION),
9439 TEST_fff_f (fma, 0x1p-1074, 0x1.1p-1, 0x0.fffffffffffffp-1022, 0x1p-1022, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING),
9440 TEST_fff_f (fma, -0x1p-1074, 0x1.1p-1, -0x0.fffffffffffffp-1022, -0x0.fffffffffffffp-1022, UNDERFLOW_EXCEPTION),
9441 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, 0x1p1023, 0x1.0000000000001p1023),
9442 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, 0x1p1023, 0x1p1023),
9443 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, -0x1p1023, -0x0.fffffffffffff8p1023),
9444 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, -0x1p1023, -0x1p1023),
9445 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, 0x1p-1022, 0x1.0000000000001p-1022),
9446 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, 0x1p-1022, 0x1p-1022, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING),
9447 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, -0x1p-1022, -0x0.fffffffffffffp-1022, UNDERFLOW_EXCEPTION),
9448 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, -0x1p-1022, -0x1p-1022),
9449 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, 0x0.fffffffffffffp-1022, 0x1p-1022, UNDERFLOW_EXCEPTION),
9450 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, 0x0.fffffffffffffp-1022, 0x0.fffffffffffffp-1022, UNDERFLOW_EXCEPTION),
9451 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, -0x0.fffffffffffffp-1022, -0x0.ffffffffffffep-1022, UNDERFLOW_EXCEPTION),
9452 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, -0x0.fffffffffffffp-1022, -0x0.fffffffffffffp-1022, UNDERFLOW_EXCEPTION),
9453 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, 0x1p-1074, 0x1p-1073, UNDERFLOW_EXCEPTION),
9454 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, 0x1p-1074, 0x1p-1074, UNDERFLOW_EXCEPTION),
9455 TEST_fff_f (fma, 0x1p-1074, 0x1p-1074, -0x1p-1074, minus_zero, UNDERFLOW_EXCEPTION),
9456 TEST_fff_f (fma, 0x1p-1074, -0x1p-1074, -0x1p-1074, -0x1p-1074, UNDERFLOW_EXCEPTION),
9457 TEST_fff_f (fma, 0x0.fffffffffffff8p0, 0x0.fffffffffffff8p0, -0x0.fffffffffffffp0, 0x1p-106),
9458 TEST_fff_f (fma, 0x0.fffffffffffff8p0, -0x0.fffffffffffff8p0, 0x0.fffffffffffffp0, -0x1p-106),
9459 TEST_fff_f (fma, -0x0.fffffffffffff8p0, 0x0.fffffffffffff8p0, 0x0.fffffffffffffp0, -0x1p-106),
9460 TEST_fff_f (fma, -0x0.fffffffffffff8p0, -0x0.fffffffffffff8p0, -0x0.fffffffffffffp0, 0x1p-106),
9461 TEST_fff_f (fma, 0x1.0000000000001p-1022, 0x1.0000000000001p-55, 0x1p1023, 0x1.0000000000001p1023),
9462 TEST_fff_f (fma, 0x1.0000000000001p-1022, -0x1.0000000000001p-55, 0x1p1023, 0x1p1023),
9463 TEST_fff_f (fma, 0x1.0000000000001p-1022, 0x1.0000000000001p-55, -0x1p1023, -0x0.fffffffffffff8p1023),
9464 TEST_fff_f (fma, 0x1.0000000000001p-1022, -0x1.0000000000001p-55, -0x1p1023, -0x1p1023),
9465 TEST_fff_f (fma, 0x1.0000000000001p-1022, 0x1.0000000000001p-55, 0x1p970, 0x1.0000000000001p970),
9466 TEST_fff_f (fma, 0x1.0000000000001p-1022, -0x1.0000000000001p-55, 0x1p970, 0x1p970),
9467 TEST_fff_f (fma, 0x1.0000000000001p-1022, 0x1.0000000000001p-55, -0x1p970, -0x0.fffffffffffff8p970),
9468 TEST_fff_f (fma, 0x1.0000000000001p-1022, -0x1.0000000000001p-55, -0x1p970, -0x1p970),
9469 #endif
9470 #if defined (TEST_LDOUBLE) && LDBL_MANT_DIG == 64
9471 TEST_fff_f (fma, 0x1.4p-16382L, 0x1.0000000000000004p-1L, 0x1p-16384L, 0x1.c000000000000008p-16383L, UNDERFLOW_EXCEPTION),
9472 TEST_fff_f (fma, -0x1.4p-16382L, 0x1.0000000000000004p-1L, -0x1p-16384L, -0x1.c000000000000004p-16383L, UNDERFLOW_EXCEPTION),
9473 TEST_fff_f (fma, 0x1.fffffffffffffff8p-16382L, 0x1.0000000000000002p-1L, 0x1p-16445L, 0x1p-16382L, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING),
9474 TEST_fff_f (fma, -0x1.fffffffffffffff8p-16382L, 0x1.0000000000000002p-1L, -0x1p-16445L, -0x0.fffffffffffffffep-16382L, UNDERFLOW_EXCEPTION),
9475 TEST_fff_f (fma, 0x1p-16445L, 0x1p-1L, 0x0.fffffffffffffffep-16382L, 0x1p-16382L, UNDERFLOW_EXCEPTION),
9476 TEST_fff_f (fma, -0x1p-16445L, 0x1p-1L, -0x0.fffffffffffffffep-16382L, -0x0.fffffffffffffffep-16382L, UNDERFLOW_EXCEPTION),
9477 TEST_fff_f (fma, 0x1p-16445L, 0x1.1p-1L, 0x0.fffffffffffffffep-16382L, 0x1p-16382L, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING),
9478 TEST_fff_f (fma, -0x1p-16445L, 0x1.1p-1L, -0x0.fffffffffffffffep-16382L, -0x0.fffffffffffffffep-16382L, UNDERFLOW_EXCEPTION),
9479 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, 0x1p16383L, 0x1.0000000000000002p16383L),
9480 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, 0x1p16383L, 0x1p16383L),
9481 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, -0x1p16383L, -0x0.ffffffffffffffffp16383L),
9482 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, -0x1p16383L, -0x1p16383L),
9483 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, 0x1p-16382L, 0x1.0000000000000002p-16382L),
9484 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, 0x1p-16382L, 0x1p-16382L, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING),
9485 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, -0x1p-16382L, -0x0.fffffffffffffffep-16382L, UNDERFLOW_EXCEPTION),
9486 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, -0x1p-16382L, -0x1p-16382L),
9487 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, 0x0.fffffffffffffffep-16382L, 0x1p-16382L, UNDERFLOW_EXCEPTION),
9488 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, 0x0.fffffffffffffffep-16382L, 0x0.fffffffffffffffep-16382L, UNDERFLOW_EXCEPTION),
9489 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, -0x0.fffffffffffffffep-16382L, -0x0.fffffffffffffffcp-16382L, UNDERFLOW_EXCEPTION),
9490 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, -0x0.fffffffffffffffep-16382L, -0x0.fffffffffffffffep-16382L, UNDERFLOW_EXCEPTION),
9491 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, 0x1p-16445L, 0x1p-16444L, UNDERFLOW_EXCEPTION),
9492 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, 0x1p-16445L, 0x1p-16445L, UNDERFLOW_EXCEPTION),
9493 TEST_fff_f (fma, 0x1p-16445L, 0x1p-16445L, -0x1p-16445L, minus_zero, UNDERFLOW_EXCEPTION),
9494 TEST_fff_f (fma, 0x1p-16445L, -0x1p-16445L, -0x1p-16445L, -0x1p-16445L, UNDERFLOW_EXCEPTION),
9495 TEST_fff_f (fma, 0x0.ffffffffffffffffp0L, 0x0.ffffffffffffffffp0L, -0x0.fffffffffffffffep0L, 0x1p-128L),
9496 TEST_fff_f (fma, 0x0.ffffffffffffffffp0L, -0x0.ffffffffffffffffp0L, 0x0.fffffffffffffffep0L, -0x1p-128L),
9497 TEST_fff_f (fma, -0x0.ffffffffffffffffp0L, 0x0.ffffffffffffffffp0L, 0x0.fffffffffffffffep0L, -0x1p-128L),
9498 TEST_fff_f (fma, -0x0.ffffffffffffffffp0L, -0x0.ffffffffffffffffp0L, -0x0.fffffffffffffffep0L, 0x1p-128L),
9499 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, 0x1.0000000000000002p-66L, 0x1p16383L, 0x1.0000000000000002p16383L),
9500 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, -0x1.0000000000000002p-66L, 0x1p16383L, 0x1p16383L),
9501 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, 0x1.0000000000000002p-66L, -0x1p16383L, -0x0.ffffffffffffffffp16383L),
9502 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, -0x1.0000000000000002p-66L, -0x1p16383L, -0x1p16383L),
9503 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, 0x1.0000000000000002p-66L, 0x1p16319L, 0x1.0000000000000002p16319L),
9504 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, -0x1.0000000000000002p-66L, 0x1p16319L, 0x1p16319L),
9505 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, 0x1.0000000000000002p-66L, -0x1p16319L, -0x0.ffffffffffffffffp16319L),
9506 TEST_fff_f (fma, 0x1.0000000000000002p-16382L, -0x1.0000000000000002p-66L, -0x1p16319L, -0x1p16319L),
9507 #endif
9508 #if defined (TEST_LDOUBLE) && LDBL_MANT_DIG == 113
9509 TEST_fff_f (fma, 0x1.4p-16382L, 0x1.0000000000000000000000000002p-1L, 0x1p-16384L, 0x1.c000000000000000000000000004p-16383L, UNDERFLOW_EXCEPTION),
9510 TEST_fff_f (fma, -0x1.4p-16382L, 0x1.0000000000000000000000000002p-1L, -0x1p-16384L, -0x1.c000000000000000000000000002p-16383L, UNDERFLOW_EXCEPTION),
9511 TEST_fff_f (fma, 0x1.fffffffffffffffffffffffffffcp-16382L, 0x1.0000000000000000000000000001p-1L, 0x1p-16494L, 0x1p-16382L, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING),
9512 TEST_fff_f (fma, -0x1.fffffffffffffffffffffffffffcp-16382L, 0x1.0000000000000000000000000001p-1L, -0x1p-16494L, -0x0.ffffffffffffffffffffffffffffp-16382L, UNDERFLOW_EXCEPTION),
9513 TEST_fff_f (fma, 0x1p-16494L, 0x1p-1L, 0x0.ffffffffffffffffffffffffffffp-16382L, 0x1p-16382L, UNDERFLOW_EXCEPTION),
9514 TEST_fff_f (fma, -0x1p-16494L, 0x1p-1L, -0x0.ffffffffffffffffffffffffffffp-16382L, -0x0.ffffffffffffffffffffffffffffp-16382L, UNDERFLOW_EXCEPTION),
9515 TEST_fff_f (fma, 0x1p-16494L, 0x1.1p-1L, 0x0.ffffffffffffffffffffffffffffp-16382L, 0x1p-16382L, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING),
9516 TEST_fff_f (fma, -0x1p-16494L, 0x1.1p-1L, -0x0.ffffffffffffffffffffffffffffp-16382L, -0x0.ffffffffffffffffffffffffffffp-16382L, UNDERFLOW_EXCEPTION),
9517 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, 0x1p16383L, 0x1.0000000000000000000000000001p16383L),
9518 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, 0x1p16383L, 0x1p16383L),
9519 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, -0x1p16383L, -0x0.ffffffffffffffffffffffffffff8p16383L),
9520 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, -0x1p16383L, -0x1p16383L),
9521 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, 0x1p-16382L, 0x1.0000000000000000000000000001p-16382L),
9522 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, 0x1p-16382L, 0x1p-16382L, UNDERFLOW_EXCEPTION_BEFORE_ROUNDING),
9523 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, -0x1p-16382L, -0x0.ffffffffffffffffffffffffffffp-16382L, UNDERFLOW_EXCEPTION),
9524 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, -0x1p-16382L, -0x1p-16382L),
9525 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, 0x0.ffffffffffffffffffffffffffffp-16382L, 0x1p-16382L, UNDERFLOW_EXCEPTION),
9526 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, 0x0.ffffffffffffffffffffffffffffp-16382L, 0x0.ffffffffffffffffffffffffffffp-16382L, UNDERFLOW_EXCEPTION),
9527 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, -0x0.ffffffffffffffffffffffffffffp-16382L, -0x0.fffffffffffffffffffffffffffep-16382L, UNDERFLOW_EXCEPTION),
9528 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, -0x0.ffffffffffffffffffffffffffffp-16382L, -0x0.ffffffffffffffffffffffffffffp-16382L, UNDERFLOW_EXCEPTION),
9529 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, 0x1p-16494L, 0x1p-16493L, UNDERFLOW_EXCEPTION),
9530 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, 0x1p-16494L, 0x1p-16494L, UNDERFLOW_EXCEPTION),
9531 TEST_fff_f (fma, 0x1p-16494L, 0x1p-16494L, -0x1p-16494L, minus_zero, UNDERFLOW_EXCEPTION),
9532 TEST_fff_f (fma, 0x1p-16494L, -0x1p-16494L, -0x1p-16494L, -0x1p-16494L, UNDERFLOW_EXCEPTION),
9533 TEST_fff_f (fma, 0x0.ffffffffffffffffffffffffffff8p0L, 0x0.ffffffffffffffffffffffffffff8p0L, -0x0.ffffffffffffffffffffffffffffp0L, 0x1p-226L),
9534 TEST_fff_f (fma, 0x0.ffffffffffffffffffffffffffff8p0L, -0x0.ffffffffffffffffffffffffffff8p0L, 0x0.ffffffffffffffffffffffffffffp0L, -0x1p-226L),
9535 TEST_fff_f (fma, -0x0.ffffffffffffffffffffffffffff8p0L, 0x0.ffffffffffffffffffffffffffff8p0L, 0x0.ffffffffffffffffffffffffffffp0L, -0x1p-226L),
9536 TEST_fff_f (fma, -0x0.ffffffffffffffffffffffffffff8p0L, -0x0.ffffffffffffffffffffffffffff8p0L, -0x0.ffffffffffffffffffffffffffffp0L, 0x1p-226L),
9537 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, 0x1.0000000000000000000000000001p-66L, 0x1p16383L, 0x1.0000000000000000000000000001p16383L),
9538 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, -0x1.0000000000000000000000000001p-66L, 0x1p16383L, 0x1p16383L),
9539 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, 0x1.0000000000000000000000000001p-66L, -0x1p16383L, -0x0.ffffffffffffffffffffffffffff8p16383L),
9540 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, -0x1.0000000000000000000000000001p-66L, -0x1p16383L, -0x1p16383L),
9541 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, 0x1.0000000000000000000000000001p-66L, 0x1p16319L, 0x1.0000000000000000000000000001p16319L),
9542 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, -0x1.0000000000000000000000000001p-66L, 0x1p16319L, 0x1p16319L),
9543 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, 0x1.0000000000000000000000000001p-66L, -0x1p16319L, -0x0.ffffffffffffffffffffffffffff8p16319L),
9544 TEST_fff_f (fma, 0x1.0000000000000000000000000001p-16382L, -0x1.0000000000000000000000000001p-66L, -0x1p16319L, -0x1p16319L),
9545 #endif
9546 END_DATA (fma_upward)
9547 };
9548
9549 static void
9550 fma_test_upward (void)
9551 {
9552 START (fma_upward);
9553 RUN_TEST_LOOP_fff_f (fma, fma_upward_test_data, FE_UPWARD);
9554 END (fma_upward);
9555 }
9556
9557
9558 static const struct test_ff_f_data fmax_test_data[] =
9559 {
9560 START_DATA (fmax),
9561 TEST_ff_f (fmax, 0, 0, 0),
9562 TEST_ff_f (fmax, minus_zero, minus_zero, minus_zero),
9563 TEST_ff_f (fmax, 9, 0, 9),
9564 TEST_ff_f (fmax, 0, 9, 9),
9565 TEST_ff_f (fmax, -9, 0, 0),
9566 TEST_ff_f (fmax, 0, -9, 0),
9567
9568 TEST_ff_f (fmax, plus_infty, 9, plus_infty),
9569 TEST_ff_f (fmax, 0, plus_infty, plus_infty),
9570 TEST_ff_f (fmax, -9, plus_infty, plus_infty),
9571 TEST_ff_f (fmax, plus_infty, -9, plus_infty),
9572
9573 TEST_ff_f (fmax, minus_infty, 9, 9),
9574 TEST_ff_f (fmax, minus_infty, -9, -9),
9575 TEST_ff_f (fmax, 9, minus_infty, 9),
9576 TEST_ff_f (fmax, -9, minus_infty, -9),
9577
9578 TEST_ff_f (fmax, 0, qnan_value, 0),
9579 TEST_ff_f (fmax, 9, qnan_value, 9),
9580 TEST_ff_f (fmax, -9, qnan_value, -9),
9581 TEST_ff_f (fmax, qnan_value, 0, 0),
9582 TEST_ff_f (fmax, qnan_value, 9, 9),
9583 TEST_ff_f (fmax, qnan_value, -9, -9),
9584 TEST_ff_f (fmax, plus_infty, qnan_value, plus_infty),
9585 TEST_ff_f (fmax, minus_infty, qnan_value, minus_infty),
9586 TEST_ff_f (fmax, qnan_value, plus_infty, plus_infty),
9587 TEST_ff_f (fmax, qnan_value, minus_infty, minus_infty),
9588 TEST_ff_f (fmax, qnan_value, qnan_value, qnan_value),
9589 END_DATA (fmax)
9590 };
9591
9592 static void
9593 fmax_test (void)
9594 {
9595 START (fmax);
9596 RUN_TEST_LOOP_ff_f (fmax, fmax_test_data, );
9597 END (fmax);
9598 }
9599
9600
9601 static const struct test_ff_f_data fmin_test_data[] =
9602 {
9603 START_DATA (fmin),
9604 TEST_ff_f (fmin, 0, 0, 0),
9605 TEST_ff_f (fmin, minus_zero, minus_zero, minus_zero),
9606 TEST_ff_f (fmin, 9, 0, 0),
9607 TEST_ff_f (fmin, 0, 9, 0),
9608 TEST_ff_f (fmin, -9, 0, -9),
9609 TEST_ff_f (fmin, 0, -9, -9),
9610
9611 TEST_ff_f (fmin, plus_infty, 9, 9),
9612 TEST_ff_f (fmin, 9, plus_infty, 9),
9613 TEST_ff_f (fmin, plus_infty, -9, -9),
9614 TEST_ff_f (fmin, -9, plus_infty, -9),
9615 TEST_ff_f (fmin, minus_infty, 9, minus_infty),
9616 TEST_ff_f (fmin, minus_infty, -9, minus_infty),
9617 TEST_ff_f (fmin, 9, minus_infty, minus_infty),
9618 TEST_ff_f (fmin, -9, minus_infty, minus_infty),
9619
9620 TEST_ff_f (fmin, 0, qnan_value, 0),
9621 TEST_ff_f (fmin, 9, qnan_value, 9),
9622 TEST_ff_f (fmin, -9, qnan_value, -9),
9623 TEST_ff_f (fmin, qnan_value, 0, 0),
9624 TEST_ff_f (fmin, qnan_value, 9, 9),
9625 TEST_ff_f (fmin, qnan_value, -9, -9),
9626 TEST_ff_f (fmin, plus_infty, qnan_value, plus_infty),
9627 TEST_ff_f (fmin, minus_infty, qnan_value, minus_infty),
9628 TEST_ff_f (fmin, qnan_value, plus_infty, plus_infty),
9629 TEST_ff_f (fmin, qnan_value, minus_infty, minus_infty),
9630 TEST_ff_f (fmin, qnan_value, qnan_value, qnan_value),
9631 END_DATA (fmin)
9632 };
9633
9634 static void
9635 fmin_test (void)
9636 {
9637 START (fmin);
9638 RUN_TEST_LOOP_ff_f (fmin, fmin_test_data, );
9639 END (fmin);
9640 }
9641
9642
9643 static const struct test_ff_f_data fmod_test_data[] =
9644 {
9645 START_DATA (fmod),
9646 /* fmod (+0, y) == +0 for y != 0. */
9647 TEST_ff_f (fmod, 0, 3, 0),
9648
9649 /* fmod (-0, y) == -0 for y != 0. */
9650 TEST_ff_f (fmod, minus_zero, 3, minus_zero),
9651
9652 /* fmod (+inf, y) == qNaN plus invalid exception. */
9653 TEST_ff_f (fmod, plus_infty, 3, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
9654 /* fmod (-inf, y) == qNaN plus invalid exception. */
9655 TEST_ff_f (fmod, minus_infty, 3, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
9656 /* fmod (x, +0) == qNaN plus invalid exception. */
9657 TEST_ff_f (fmod, 3, 0, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
9658 /* fmod (x, -0) == qNaN plus invalid exception. */
9659 TEST_ff_f (fmod, 3, minus_zero, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
9660
9661 /* fmod (x, +inf) == x for x not infinite. */
9662 TEST_ff_f (fmod, 3.0, plus_infty, 3.0),
9663 /* fmod (x, -inf) == x for x not infinite. */
9664 TEST_ff_f (fmod, 3.0, minus_infty, 3.0),
9665
9666 TEST_ff_f (fmod, qnan_value, qnan_value, qnan_value),
9667
9668 TEST_ff_f (fmod, 6.5, 2.25L, 2.0L),
9669 TEST_ff_f (fmod, -6.5, 2.25L, -2.0L),
9670 TEST_ff_f (fmod, 6.5, -2.25L, 2.0L),
9671 TEST_ff_f (fmod, -6.5, -2.25L, -2.0L),
9672
9673 TEST_ff_f (fmod, 0x0.fffffep-126L, 0x1p-149L, plus_zero),
9674 #ifndef TEST_FLOAT
9675 TEST_ff_f (fmod, 0x0.fffffffffffffp-1022L, 0x1p-1074L, plus_zero),
9676 #endif
9677 #if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
9678 TEST_ff_f (fmod, 0x0.fffffffffffffffep-16382L, 0x1p-16445L, plus_zero),
9679 #endif
9680 END_DATA (fmod)
9681 };
9682
9683 static void
9684 fmod_test (void)
9685 {
9686 errno = 0;
9687 FUNC(fmod) (6.5, 2.3L);
9688 if (errno == ENOSYS)
9689 /* Function not implemented. */
9690 return;
9691
9692 START (fmod);
9693 RUN_TEST_LOOP_ff_f (fmod, fmod_test_data, );
9694 END (fmod);
9695 }
9696
9697
9698 static const struct test_f_i_data fpclassify_test_data[] =
9699 {
9700 START_DATA (fpclassify),
9701 TEST_f_i (fpclassify, qnan_value, FP_NAN),
9702 TEST_f_i (fpclassify, plus_infty, FP_INFINITE),
9703 TEST_f_i (fpclassify, minus_infty, FP_INFINITE),
9704 TEST_f_i (fpclassify, plus_zero, FP_ZERO),
9705 TEST_f_i (fpclassify, minus_zero, FP_ZERO),
9706 TEST_f_i (fpclassify, 1000, FP_NORMAL),
9707 TEST_f_i (fpclassify, min_subnorm_value, FP_SUBNORMAL),
9708 END_DATA (fpclassify)
9709 };
9710
9711 static void
9712 fpclassify_test (void)
9713 {
9714 START (fpclassify);
9715 RUN_TEST_LOOP_f_i_tg (fpclassify, fpclassify_test_data, );
9716 END (fpclassify);
9717 }
9718
9719
9720 static const struct test_f_f1_data frexp_test_data[] =
9721 {
9722 START_DATA (frexp),
9723 TEST_fI_f1 (frexp, plus_infty, plus_infty, IGNORE),
9724 TEST_fI_f1 (frexp, minus_infty, minus_infty, IGNORE),
9725 TEST_fI_f1 (frexp, qnan_value, qnan_value, IGNORE),
9726
9727 TEST_fI_f1 (frexp, 0.0, 0.0, 0.0),
9728 TEST_fI_f1 (frexp, minus_zero, minus_zero, 0.0),
9729
9730 TEST_fI_f1 (frexp, 12.8L, 0.8L, 4),
9731 TEST_fI_f1 (frexp, -27.34L, -0.854375L, 5),
9732 END_DATA (frexp)
9733 };
9734
9735 static void
9736 frexp_test (void)
9737 {
9738 int x;
9739
9740 START (frexp);
9741 RUN_TEST_LOOP_fI_f1 (frexp, frexp_test_data, , x);
9742 END (frexp);
9743 }
9744
9745
9746 static const struct test_f_f1_data gamma_test_data[] =
9747 {
9748 START_DATA (gamma),
9749 TEST_f_f1 (gamma, plus_infty, plus_infty, 1),
9750 TEST_f_f1 (gamma, 0, plus_infty, 1, DIVIDE_BY_ZERO_EXCEPTION),
9751 TEST_f_f1 (gamma, -3, plus_infty, IGNORE, DIVIDE_BY_ZERO_EXCEPTION),
9752 TEST_f_f1 (gamma, minus_infty, plus_infty, IGNORE),
9753 TEST_f_f1 (gamma, qnan_value, qnan_value, IGNORE),
9754
9755 TEST_f_f1 (gamma, 1, 0, 1),
9756 TEST_f_f1 (gamma, 3, M_LN2l, 1),
9757
9758 TEST_f_f1 (gamma, 0.5, M_LOG_SQRT_PIl, 1),
9759 TEST_f_f1 (gamma, -0.5, M_LOG_2_SQRT_PIl, -1),
9760 END_DATA (gamma)
9761 };
9762
9763 static void
9764 gamma_test (void)
9765 {
9766 errno = 0;
9767 FUNC(gamma) (1);
9768
9769 if (errno == ENOSYS)
9770 /* Function not implemented. */
9771 return;
9772
9773 START (gamma);
9774 RUN_TEST_LOOP_f_f1 (gamma, gamma_test_data, , signgam);
9775 END (gamma);
9776 }
9777
9778 static const struct test_ff_f_data hypot_test_data[] =
9779 {
9780 START_DATA (hypot),
9781 TEST_ff_f (hypot, plus_infty, 1, plus_infty),
9782 TEST_ff_f (hypot, minus_infty, 1, plus_infty),
9783
9784 #ifndef TEST_INLINE
9785 TEST_ff_f (hypot, plus_infty, qnan_value, plus_infty),
9786 TEST_ff_f (hypot, minus_infty, qnan_value, plus_infty),
9787 TEST_ff_f (hypot, qnan_value, plus_infty, plus_infty),
9788 TEST_ff_f (hypot, qnan_value, minus_infty, plus_infty),
9789 #endif
9790
9791 TEST_ff_f (hypot, qnan_value, qnan_value, qnan_value),
9792
9793 /* hypot (x,y) == hypot (+-x, +-y) */
9794 TEST_ff_f (hypot, 0.7L, 12.4L, 12.419742348374220601176836866763271L),
9795 TEST_ff_f (hypot, -0.7L, 12.4L, 12.419742348374220601176836866763271L),
9796 TEST_ff_f (hypot, 0.7L, -12.4L, 12.419742348374220601176836866763271L),
9797 TEST_ff_f (hypot, -0.7L, -12.4L, 12.419742348374220601176836866763271L),
9798 TEST_ff_f (hypot, 12.4L, 0.7L, 12.419742348374220601176836866763271L),
9799 TEST_ff_f (hypot, -12.4L, 0.7L, 12.419742348374220601176836866763271L),
9800 TEST_ff_f (hypot, 12.4L, -0.7L, 12.419742348374220601176836866763271L),
9801 TEST_ff_f (hypot, -12.4L, -0.7L, 12.419742348374220601176836866763271L),
9802
9803 /* hypot (x,0) == fabs (x) */
9804 TEST_ff_f (hypot, 0.75L, 0, 0.75L),
9805 TEST_ff_f (hypot, -0.75L, 0, 0.75L),
9806 TEST_ff_f (hypot, -5.7e7, 0, 5.7e7L),
9807
9808 TEST_ff_f (hypot, 0.75L, 1.25L, 1.45773797371132511771853821938639577L),
9809
9810 TEST_ff_f (hypot, 1.0L, 0x1p-61L, 1.0L),
9811 TEST_ff_f (hypot, 0x1p+0L, 0x1.fp-129L, 0x1p+0L),
9812 #if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 106
9813 TEST_ff_f (hypot, 0x1.23456789abcdef0123456789ab8p-500L, 0x1.23456789abcdef0123456789ab8p-500L, 4.9155782399407039128612180934736799735113e-151L),
9814 #endif
9815
9816 #if !(defined TEST_FLOAT && defined TEST_INLINE)
9817 TEST_ff_f (hypot, 0x3p125L, 0x4p125L, 0x5p125L),
9818 TEST_ff_f (hypot, 0x1.234566p-126L, 0x1.234566p-126L, 1.891441686191081936598531534017449451173e-38L),
9819 #endif
9820
9821 #if !defined TEST_FLOAT && !(defined TEST_DOUBLE && defined TEST_INLINE)
9822 TEST_ff_f (hypot, 0x3p1021L, 0x4p1021L, 0x5p1021L),
9823 TEST_ff_f (hypot, 0x1p+0L, 0x0.3ep-1022L, 0x1p+0L),
9824 #endif
9825
9826 #if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384 && !defined TEST_INLINE
9827 TEST_ff_f (hypot, 0x3p16381L, 0x4p16381L, 0x5p16381L),
9828 #endif
9829 END_DATA (hypot)
9830 };
9831
9832 static void
9833 hypot_test (void)
9834 {
9835 errno = 0;
9836 FUNC(hypot) (0.7L, 12.4L);
9837 if (errno == ENOSYS)
9838 /* Function not implemented. */
9839 return;
9840
9841 START (hypot);
9842 RUN_TEST_LOOP_ff_f (hypot, hypot_test_data, );
9843 END (hypot);
9844 }
9845
9846
9847 static const struct test_f_i_data ilogb_test_data[] =
9848 {
9849 START_DATA (ilogb),
9850 TEST_f_i (ilogb, 1, 0),
9851 TEST_f_i (ilogb, M_El, 1),
9852 TEST_f_i (ilogb, 1024, 10),
9853 TEST_f_i (ilogb, -2000, 10),
9854
9855 /* ilogb (0.0) == FP_ILOGB0 plus invalid exception */
9856 TEST_f_i (ilogb, 0.0, FP_ILOGB0, INVALID_EXCEPTION|ERRNO_EDOM),
9857 /* ilogb (qNaN) == FP_ILOGBNAN plus invalid exception */
9858 TEST_f_i (ilogb, qnan_value, FP_ILOGBNAN, INVALID_EXCEPTION|ERRNO_EDOM),
9859 /* ilogb (inf) == INT_MAX plus invalid exception */
9860 TEST_f_i (ilogb, plus_infty, INT_MAX, INVALID_EXCEPTION|ERRNO_EDOM),
9861 /* ilogb (-inf) == INT_MAX plus invalid exception */
9862 TEST_f_i (ilogb, minus_infty, INT_MAX, INVALID_EXCEPTION|ERRNO_EDOM),
9863 END_DATA (ilogb)
9864 };
9865
9866 static void
9867 ilogb_test (void)
9868 {
9869 START (ilogb);
9870 RUN_TEST_LOOP_f_i (ilogb, ilogb_test_data, );
9871 END (ilogb);
9872 }
9873
9874 static const struct test_f_i_data isfinite_test_data[] =
9875 {
9876 START_DATA (isfinite),
9877 TEST_f_b (isfinite, 0, 1),
9878 TEST_f_b (isfinite, minus_zero, 1),
9879 TEST_f_b (isfinite, 10, 1),
9880 TEST_f_b (isfinite, min_subnorm_value, 1),
9881 TEST_f_b (isfinite, plus_infty, 0),
9882 TEST_f_b (isfinite, minus_infty, 0),
9883 TEST_f_b (isfinite, qnan_value, 0),
9884 END_DATA (isfinite)
9885 };
9886
9887 static void
9888 isfinite_test (void)
9889 {
9890 START (isfinite);
9891 RUN_TEST_LOOP_f_b_tg (isfinite, isfinite_test_data, );
9892 END (isfinite);
9893 }
9894
9895 static const struct test_ff_i_data isgreater_test_data[] =
9896 {
9897 START_DATA (isgreater),
9898 TEST_ff_i (isgreater, minus_zero, minus_zero, 0),
9899 TEST_ff_i (isgreater, minus_zero, plus_zero, 0),
9900 TEST_ff_i (isgreater, minus_zero, (FLOAT) 1, 0),
9901 TEST_ff_i (isgreater, minus_zero, qnan_value, 0),
9902 TEST_ff_i (isgreater, plus_zero, minus_zero, 0),
9903 TEST_ff_i (isgreater, plus_zero, plus_zero, 0),
9904 TEST_ff_i (isgreater, plus_zero, (FLOAT) 1, 0),
9905 TEST_ff_i (isgreater, plus_zero, qnan_value, 0),
9906 TEST_ff_i (isgreater, (FLOAT) 1, minus_zero, 1),
9907 TEST_ff_i (isgreater, (FLOAT) 1, plus_zero, 1),
9908 TEST_ff_i (isgreater, (FLOAT) 1, (FLOAT) 1, 0),
9909 TEST_ff_i (isgreater, (FLOAT) 1, qnan_value, 0),
9910 TEST_ff_i (isgreater, qnan_value, minus_zero, 0),
9911 TEST_ff_i (isgreater, qnan_value, plus_zero, 0),
9912 TEST_ff_i (isgreater, qnan_value, (FLOAT) 1, 0),
9913 TEST_ff_i (isgreater, qnan_value, qnan_value, 0),
9914 END_DATA (isgreater)
9915 };
9916
9917 static void
9918 isgreater_test (void)
9919 {
9920 START (isgreater);
9921 RUN_TEST_LOOP_ff_i_tg (isgreater, isgreater_test_data, );
9922 END (isgreater);
9923 }
9924
9925 static const struct test_ff_i_data isgreaterequal_test_data[] =
9926 {
9927 START_DATA (isgreaterequal),
9928 TEST_ff_i (isgreaterequal, minus_zero, minus_zero, 1),
9929 TEST_ff_i (isgreaterequal, minus_zero, plus_zero, 1),
9930 TEST_ff_i (isgreaterequal, minus_zero, (FLOAT) 1, 0),
9931 TEST_ff_i (isgreaterequal, minus_zero, qnan_value, 0),
9932 TEST_ff_i (isgreaterequal, plus_zero, minus_zero, 1),
9933 TEST_ff_i (isgreaterequal, plus_zero, plus_zero, 1),
9934 TEST_ff_i (isgreaterequal, plus_zero, (FLOAT) 1, 0),
9935 TEST_ff_i (isgreaterequal, plus_zero, qnan_value, 0),
9936 TEST_ff_i (isgreaterequal, (FLOAT) 1, minus_zero, 1),
9937 TEST_ff_i (isgreaterequal, (FLOAT) 1, plus_zero, 1),
9938 TEST_ff_i (isgreaterequal, (FLOAT) 1, (FLOAT) 1, 1),
9939 TEST_ff_i (isgreaterequal, (FLOAT) 1, qnan_value, 0),
9940 TEST_ff_i (isgreaterequal, qnan_value, minus_zero, 0),
9941 TEST_ff_i (isgreaterequal, qnan_value, plus_zero, 0),
9942 TEST_ff_i (isgreaterequal, qnan_value, (FLOAT) 1, 0),
9943 TEST_ff_i (isgreaterequal, qnan_value, qnan_value, 0),
9944 END_DATA (isgreaterequal)
9945 };
9946
9947 static void
9948 isgreaterequal_test (void)
9949 {
9950 START (isgreaterequal);
9951 RUN_TEST_LOOP_ff_i_tg (isgreaterequal, isgreaterequal_test_data, );
9952 END (isgreaterequal);
9953 }
9954
9955 static const struct test_f_i_data isinf_test_data[] =
9956 {
9957 START_DATA (isinf),
9958 TEST_f_b (isinf, 0, 0),
9959 TEST_f_b (isinf, minus_zero, 0),
9960 TEST_f_b (isinf, 10, 0),
9961 TEST_f_b (isinf, min_subnorm_value, 0),
9962 TEST_f_b (isinf, plus_infty, 1),
9963 TEST_f_b (isinf, minus_infty, 1),
9964 TEST_f_b (isinf, qnan_value, 0),
9965 END_DATA (isinf)
9966 };
9967
9968 static void
9969 isinf_test (void)
9970 {
9971 START (isinf);
9972 RUN_TEST_LOOP_f_b_tg (isinf, isinf_test_data, );
9973 END (isinf);
9974 }
9975
9976 static const struct test_ff_i_data isless_test_data[] =
9977 {
9978 START_DATA (isless),
9979 TEST_ff_i (isless, minus_zero, minus_zero, 0),
9980 TEST_ff_i (isless, minus_zero, plus_zero, 0),
9981 TEST_ff_i (isless, minus_zero, (FLOAT) 1, 1),
9982 TEST_ff_i (isless, minus_zero, qnan_value, 0),
9983 TEST_ff_i (isless, plus_zero, minus_zero, 0),
9984 TEST_ff_i (isless, plus_zero, plus_zero, 0),
9985 TEST_ff_i (isless, plus_zero, (FLOAT) 1, 1),
9986 TEST_ff_i (isless, plus_zero, qnan_value, 0),
9987 TEST_ff_i (isless, (FLOAT) 1, minus_zero, 0),
9988 TEST_ff_i (isless, (FLOAT) 1, plus_zero, 0),
9989 TEST_ff_i (isless, (FLOAT) 1, (FLOAT) 1, 0),
9990 TEST_ff_i (isless, (FLOAT) 1, qnan_value, 0),
9991 TEST_ff_i (isless, qnan_value, minus_zero, 0),
9992 TEST_ff_i (isless, qnan_value, plus_zero, 0),
9993 TEST_ff_i (isless, qnan_value, (FLOAT) 1, 0),
9994 TEST_ff_i (isless, qnan_value, qnan_value, 0),
9995 END_DATA (isless)
9996 };
9997
9998 static void
9999 isless_test (void)
10000 {
10001 START (isless);
10002 RUN_TEST_LOOP_ff_i_tg (isless, isless_test_data, );
10003 END (isless);
10004 }
10005
10006 static const struct test_ff_i_data islessequal_test_data[] =
10007 {
10008 START_DATA (islessequal),
10009 TEST_ff_i (islessequal, minus_zero, minus_zero, 1),
10010 TEST_ff_i (islessequal, minus_zero, plus_zero, 1),
10011 TEST_ff_i (islessequal, minus_zero, (FLOAT) 1, 1),
10012 TEST_ff_i (islessequal, minus_zero, qnan_value, 0),
10013 TEST_ff_i (islessequal, plus_zero, minus_zero, 1),
10014 TEST_ff_i (islessequal, plus_zero, plus_zero, 1),
10015 TEST_ff_i (islessequal, plus_zero, (FLOAT) 1, 1),
10016 TEST_ff_i (islessequal, plus_zero, qnan_value, 0),
10017 TEST_ff_i (islessequal, (FLOAT) 1, minus_zero, 0),
10018 TEST_ff_i (islessequal, (FLOAT) 1, plus_zero, 0),
10019 TEST_ff_i (islessequal, (FLOAT) 1, (FLOAT) 1, 1),
10020 TEST_ff_i (islessequal, (FLOAT) 1, qnan_value, 0),
10021 TEST_ff_i (islessequal, qnan_value, minus_zero, 0),
10022 TEST_ff_i (islessequal, qnan_value, plus_zero, 0),
10023 TEST_ff_i (islessequal, qnan_value, (FLOAT) 1, 0),
10024 TEST_ff_i (islessequal, qnan_value, qnan_value, 0),
10025 END_DATA (islessequal)
10026 };
10027
10028 static void
10029 islessequal_test (void)
10030 {
10031 START (islessequal);
10032 RUN_TEST_LOOP_ff_i_tg (islessequal, islessequal_test_data, );
10033 END (islessequal);
10034 }
10035
10036 static const struct test_ff_i_data islessgreater_test_data[] =
10037 {
10038 START_DATA (islessgreater),
10039 TEST_ff_i (islessgreater, minus_zero, minus_zero, 0),
10040 TEST_ff_i (islessgreater, minus_zero, plus_zero, 0),
10041 TEST_ff_i (islessgreater, minus_zero, (FLOAT) 1, 1),
10042 TEST_ff_i (islessgreater, minus_zero, qnan_value, 0),
10043 TEST_ff_i (islessgreater, plus_zero, minus_zero, 0),
10044 TEST_ff_i (islessgreater, plus_zero, plus_zero, 0),
10045 TEST_ff_i (islessgreater, plus_zero, (FLOAT) 1, 1),
10046 TEST_ff_i (islessgreater, plus_zero, qnan_value, 0),
10047 TEST_ff_i (islessgreater, (FLOAT) 1, minus_zero, 1),
10048 TEST_ff_i (islessgreater, (FLOAT) 1, plus_zero, 1),
10049 TEST_ff_i (islessgreater, (FLOAT) 1, (FLOAT) 1, 0),
10050 TEST_ff_i (islessgreater, (FLOAT) 1, qnan_value, 0),
10051 TEST_ff_i (islessgreater, qnan_value, minus_zero, 0),
10052 TEST_ff_i (islessgreater, qnan_value, plus_zero, 0),
10053 TEST_ff_i (islessgreater, qnan_value, (FLOAT) 1, 0),
10054 TEST_ff_i (islessgreater, qnan_value, qnan_value, 0),
10055 END_DATA (islessgreater)
10056 };
10057
10058 static void
10059 islessgreater_test (void)
10060 {
10061 START (islessgreater);
10062 RUN_TEST_LOOP_ff_i_tg (islessgreater, islessgreater_test_data, );
10063 END (islessgreater);
10064 }
10065
10066 static const struct test_f_i_data isnan_test_data[] =
10067 {
10068 START_DATA (isnan),
10069 TEST_f_b (isnan, 0, 0),
10070 TEST_f_b (isnan, minus_zero, 0),
10071 TEST_f_b (isnan, 10, 0),
10072 TEST_f_b (isnan, min_subnorm_value, 0),
10073 TEST_f_b (isnan, plus_infty, 0),
10074 TEST_f_b (isnan, minus_infty, 0),
10075 TEST_f_b (isnan, qnan_value, 1),
10076 END_DATA (isnan)
10077 };
10078
10079 static void
10080 isnan_test (void)
10081 {
10082 START (isnan);
10083 RUN_TEST_LOOP_f_b_tg (isnan, isnan_test_data, );
10084 END (isnan);
10085 }
10086
10087 static const struct test_f_i_data isnormal_test_data[] =
10088 {
10089 START_DATA (isnormal),
10090 TEST_f_b (isnormal, 0, 0),
10091 TEST_f_b (isnormal, minus_zero, 0),
10092 TEST_f_b (isnormal, 10, 1),
10093 TEST_f_b (isnormal, min_subnorm_value, 0),
10094 TEST_f_b (isnormal, plus_infty, 0),
10095 TEST_f_b (isnormal, minus_infty, 0),
10096 TEST_f_b (isnormal, qnan_value, 0),
10097 END_DATA (isnormal)
10098 };
10099
10100 static void
10101 isnormal_test (void)
10102 {
10103 START (isnormal);
10104 RUN_TEST_LOOP_f_b_tg (isnormal, isnormal_test_data, );
10105 END (isnormal);
10106 }
10107
10108 static const struct test_f_i_data issignaling_test_data[] =
10109 {
10110 START_DATA (issignaling),
10111 TEST_f_b (issignaling, 0, 0),
10112 TEST_f_b (issignaling, minus_zero, 0),
10113 TEST_f_b (issignaling, 10, 0),
10114 TEST_f_b (issignaling, min_subnorm_value, 0),
10115 TEST_f_b (issignaling, plus_infty, 0),
10116 TEST_f_b (issignaling, minus_infty, 0),
10117 TEST_f_b (issignaling, qnan_value, 0),
10118 END_DATA (issignaling)
10119 };
10120
10121 static void
10122 issignaling_test (void)
10123 {
10124 START (issignaling);
10125 RUN_TEST_LOOP_f_b_tg (issignaling, issignaling_test_data, );
10126 END (issignaling);
10127 }
10128
10129 static const struct test_ff_i_data isunordered_test_data[] =
10130 {
10131 START_DATA (isunordered),
10132 TEST_ff_i (isunordered, minus_zero, minus_zero, 0),
10133 TEST_ff_i (isunordered, minus_zero, plus_zero, 0),
10134 TEST_ff_i (isunordered, minus_zero, (FLOAT) 1, 0),
10135 TEST_ff_i (isunordered, minus_zero, qnan_value, 1),
10136 TEST_ff_i (isunordered, plus_zero, minus_zero, 0),
10137 TEST_ff_i (isunordered, plus_zero, plus_zero, 0),
10138 TEST_ff_i (isunordered, plus_zero, (FLOAT) 1, 0),
10139 TEST_ff_i (isunordered, plus_zero, qnan_value, 1),
10140 TEST_ff_i (isunordered, (FLOAT) 1, minus_zero, 0),
10141 TEST_ff_i (isunordered, (FLOAT) 1, plus_zero, 0),
10142 TEST_ff_i (isunordered, (FLOAT) 1, (FLOAT) 1, 0),
10143 TEST_ff_i (isunordered, (FLOAT) 1, qnan_value, 1),
10144 TEST_ff_i (isunordered, qnan_value, minus_zero, 1),
10145 TEST_ff_i (isunordered, qnan_value, plus_zero, 1),
10146 TEST_ff_i (isunordered, qnan_value, (FLOAT) 1, 1),
10147 TEST_ff_i (isunordered, qnan_value, qnan_value, 1),
10148 END_DATA (isunordered)
10149 };
10150
10151 static void
10152 isunordered_test (void)
10153 {
10154 START (isunordered);
10155 RUN_TEST_LOOP_ff_i_tg (isunordered, isunordered_test_data, );
10156 END (isunordered);
10157 }
10158
10159 static const struct test_f_f_data j0_test_data[] =
10160 {
10161 START_DATA (j0),
10162 /* j0 is the Bessel function of the first kind of order 0 */
10163 TEST_f_f (j0, qnan_value, qnan_value),
10164 TEST_f_f (j0, plus_infty, 0),
10165 TEST_f_f (j0, -1.0, 0.765197686557966551449717526102663221L),
10166 TEST_f_f (j0, 0.0, 1.0),
10167 TEST_f_f (j0, 0.125L, 0.996097563041985204620768999453174712L),
10168 TEST_f_f (j0, 0.75L, 0.864242275166648623555731103820923211L),
10169 TEST_f_f (j0, 1.0, 0.765197686557966551449717526102663221L),
10170 TEST_f_f (j0, 1.5, 0.511827671735918128749051744283411720L),
10171 TEST_f_f (j0, 2.0, 0.223890779141235668051827454649948626L),
10172 TEST_f_f (j0, 8.0, 0.171650807137553906090869407851972001L),
10173 TEST_f_f (j0, 10.0, -0.245935764451348335197760862485328754L),
10174 TEST_f_f (j0, 4.0, -3.9714980986384737228659076845169804197562E-1L),
10175 TEST_f_f (j0, -4.0, -3.9714980986384737228659076845169804197562E-1L),
10176
10177 TEST_f_f (j0, 0x1.d7ce3ap+107L, 2.775523647291230802651040996274861694514e-17L),
10178
10179 #ifndef TEST_FLOAT
10180 TEST_f_f (j0, -0x1.001000001p+593L, -3.927269966354206207832593635798954916263e-90L),
10181 TEST_f_f (j0, 0x1p1023L, -1.5665258060609012834424478437196679802783e-155L),
10182 #endif
10183
10184 #if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
10185 TEST_f_f (j0, 0x1p16382L, -1.2193782500509000574176799046642541129387e-2466L),
10186 TEST_f_f (j0, 0x1p16383L, 9.5859502826270374691362975419147645151233e-2467L),
10187 #endif
10188 END_DATA (j0)
10189 };
10190
10191 static void
10192 j0_test (void)
10193 {
10194 FLOAT s, c;
10195 errno = 0;
10196 FUNC (sincos) (0, &s, &c);
10197 if (errno == ENOSYS)
10198 /* Required function not implemented. */
10199 return;
10200 FUNC(j0) (0);
10201 if (errno == ENOSYS)
10202 /* Function not implemented. */
10203 return;
10204
10205 START (j0);
10206 RUN_TEST_LOOP_f_f (j0, j0_test_data, );
10207 END (j0);
10208 }
10209
10210
10211 static const struct test_f_f_data j1_test_data[] =
10212 {
10213 START_DATA (j1),
10214 /* j1 is the Bessel function of the first kind of order 1 */
10215 TEST_f_f (j1, qnan_value, qnan_value),
10216 TEST_f_f (j1, plus_infty, 0),
10217
10218 TEST_f_f (j1, -1.0, -0.440050585744933515959682203718914913L),
10219 TEST_f_f (j1, 0.0, 0.0),
10220 TEST_f_f (j1, 0.125L, 0.0623780091344946810942311355879361177L),
10221 TEST_f_f (j1, 0.75L, 0.349243602174862192523281016426251335L),
10222 TEST_f_f (j1, 1.0, 0.440050585744933515959682203718914913L),
10223 TEST_f_f (j1, 1.5, 0.557936507910099641990121213156089400L),
10224 TEST_f_f (j1, 2.0, 0.576724807756873387202448242269137087L),
10225 TEST_f_f (j1, 8.0, 0.234636346853914624381276651590454612L),
10226 TEST_f_f (j1, 10.0, 0.0434727461688614366697487680258592883L),
10227
10228 TEST_f_f (j1, 0x1.3ffp+74L, 1.818984347516051243459364437186082741567e-12L),
10229
10230 #ifndef TEST_FLOAT
10231 TEST_f_f (j1, 0x1.ff00000000002p+840L, 1.846591691699331493194965158699937660696e-127L),
10232 TEST_f_f (j1, 0x1p1023L, 8.2687542933709649327986678723012001545638e-155L),
10233 #endif
10234
10235 #if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
10236 TEST_f_f (j1, 0x1p16382L, 8.0839224448726336195866026476176740513439e-2467L),
10237 TEST_f_f (j1, 0x1p16383L, -3.8895531955766020648617743624167352352217e-2467L),
10238 #endif
10239 END_DATA (j1)
10240 };
10241
10242 static void
10243 j1_test (void)
10244 {
10245 FLOAT s, c;
10246 errno = 0;
10247 FUNC (sincos) (0, &s, &c);
10248 if (errno == ENOSYS)
10249 /* Required function not implemented. */
10250 return;
10251 FUNC(j1) (0);
10252 if (errno == ENOSYS)
10253 /* Function not implemented. */
10254 return;
10255
10256 START (j1);
10257 RUN_TEST_LOOP_f_f (j1, j1_test_data, );
10258 END (j1);
10259 }
10260
10261 static const struct test_if_f_data jn_test_data[] =
10262 {
10263 START_DATA (jn),
10264 /* jn is the Bessel function of the first kind of order n. */
10265 /* jn (0, x) == j0 (x) */
10266 TEST_if_f (jn, 0, qnan_value, qnan_value),
10267 TEST_if_f (jn, 0, plus_infty, 0),
10268 TEST_if_f (jn, 0, -1.0, 0.765197686557966551449717526102663221L),
10269 TEST_if_f (jn, 0, 0.0, 1.0),
10270 TEST_if_f (jn, 0, 0.125L, 0.996097563041985204620768999453174712L),
10271 TEST_if_f (jn, 0, 0.75L, 0.864242275166648623555731103820923211L),
10272 TEST_if_f (jn, 0, 1.0, 0.765197686557966551449717526102663221L),
10273 TEST_if_f (jn, 0, 1.5, 0.511827671735918128749051744283411720L),
10274 TEST_if_f (jn, 0, 2.0, 0.223890779141235668051827454649948626L),
10275 TEST_if_f (jn, 0, 8.0, 0.171650807137553906090869407851972001L),
10276 TEST_if_f (jn, 0, 10.0, -0.245935764451348335197760862485328754L),
10277 TEST_if_f (jn, 0, 4.0, -3.9714980986384737228659076845169804197562E-1L),
10278 TEST_if_f (jn, 0, -4.0, -3.9714980986384737228659076845169804197562E-1L),
10279
10280 /* jn (1, x) == j1 (x) */
10281 TEST_if_f (jn, 1, qnan_value, qnan_value),
10282 TEST_if_f (jn, 1, plus_infty, 0),
10283 TEST_if_f (jn, 1, -1.0, -0.440050585744933515959682203718914913L),
10284 TEST_if_f (jn, 1, 0.0, 0.0),
10285 TEST_if_f (jn, 1, 0.125L, 0.0623780091344946810942311355879361177L),
10286 TEST_if_f (jn, 1, 0.75L, 0.349243602174862192523281016426251335L),
10287 TEST_if_f (jn, 1, 1.0, 0.440050585744933515959682203718914913L),
10288 TEST_if_f (jn, 1, 1.5, 0.557936507910099641990121213156089400L),
10289 TEST_if_f (jn, 1, 2.0, 0.576724807756873387202448242269137087L),
10290 TEST_if_f (jn, 1, 8.0, 0.234636346853914624381276651590454612L),
10291 TEST_if_f (jn, 1, 10.0, 0.0434727461688614366697487680258592883L),
10292
10293 /* jn (3, x) */
10294 TEST_if_f (jn, 3, qnan_value, qnan_value),
10295 TEST_if_f (jn, 3, plus_infty, 0),
10296
10297 TEST_if_f (jn, 3, -1.0, -0.0195633539826684059189053216217515083L),
10298 TEST_if_f (jn, 3, 0.0, 0.0),
10299 TEST_if_f (jn, 3, 0.125L, 0.406503832554912875023029337653442868e-4L),
10300 TEST_if_f (jn, 3, 0.75L, 0.848438342327410884392755236884386804e-2L),
10301 TEST_if_f (jn, 3, 1.0, 0.0195633539826684059189053216217515083L),
10302 TEST_if_f (jn, 3, 2.0, 0.128943249474402051098793332969239835L),
10303 TEST_if_f (jn, 3, 10.0, 0.0583793793051868123429354784103409563L),
10304
10305 /* jn (10, x) */
10306 TEST_if_f (jn, 10, qnan_value, qnan_value),
10307 TEST_if_f (jn, 10, plus_infty, 0),
10308
10309 TEST_if_f (jn, 10, -1.0, 0.263061512368745320699785368779050294e-9L),
10310 TEST_if_f (jn, 10, 0.0, 0.0),
10311 TEST_if_f (jn, 10, 0.125L, 0.250543369809369890173993791865771547e-18L),
10312 TEST_if_f (jn, 10, 0.75L, 0.149621713117596814698712483621682835e-10L),
10313 TEST_if_f (jn, 10, 1.0, 0.263061512368745320699785368779050294e-9L),
10314 TEST_if_f (jn, 10, 2.0, 0.251538628271673670963516093751820639e-6L),
10315 TEST_if_f (jn, 10, 10.0, 0.207486106633358857697278723518753428L),
10316
10317 /* BZ #11589 .*/
10318 TEST_if_f (jn, 2, 2.4048255576957729L, 0.43175480701968038399746111312430703L),
10319 TEST_if_f (jn, 3, 2.4048255576957729L, 0.19899990535769083404042146764530813L),
10320 TEST_if_f (jn, 4, 2.4048255576957729L, 0.647466661641779720084932282551219891E-1L),
10321 TEST_if_f (jn, 5, 2.4048255576957729L, 0.163892432048058525099230549946147698E-1L),
10322 TEST_if_f (jn, 6, 2.4048255576957729L, 0.34048184720278336646673682895929161E-2L),
10323 TEST_if_f (jn, 7, 2.4048255576957729L, 0.60068836573295394221291569249883076E-3L),
10324 TEST_if_f (jn, 8, 2.4048255576957729L, 0.92165786705344923232879022467054148E-4L),
10325 TEST_if_f (jn, 9, 2.4048255576957729L, 0.12517270977961513005428966643852564E-4L),
10326
10327 /* Bug 14155: spurious exception may occur. */
10328 TEST_if_f (jn, 2, 0x1.ffff62p+99L, -4.43860668048170034334926693188979974489e-16L, UNDERFLOW_EXCEPTION_OK),
10329 END_DATA (jn)
10330 };
10331
10332 static void
10333 jn_test (void)
10334 {
10335 FLOAT s, c;
10336 errno = 0;
10337 FUNC (sincos) (0, &s, &c);
10338 if (errno == ENOSYS)
10339 /* Required function not implemented. */
10340 return;
10341 FUNC(jn) (1, 1);
10342 if (errno == ENOSYS)
10343 /* Function not implemented. */
10344 return;
10345
10346 START (jn);
10347 RUN_TEST_LOOP_if_f (jn, jn_test_data, );
10348 END (jn);
10349 }
10350
10351
10352 static const struct test_fi_f_data ldexp_test_data[] =
10353 {
10354 START_DATA (ldexp),
10355 TEST_fi_f (ldexp, 0, 0, 0),
10356 TEST_fi_f (ldexp, minus_zero, 0, minus_zero),
10357
10358 TEST_fi_f (ldexp, plus_infty, 1, plus_infty),
10359 TEST_fi_f (ldexp, minus_infty, 1, minus_infty),
10360 TEST_fi_f (ldexp, qnan_value, 1, qnan_value),
10361
10362 TEST_fi_f (ldexp, 0.8L, 4, 12.8L),
10363 TEST_fi_f (ldexp, -0.854375L, 5, -27.34L),
10364
10365 /* ldexp (x, 0) == x. */
10366 TEST_fi_f (ldexp, 1.0L, 0L, 1.0L),
10367 END_DATA (ldexp)
10368 };
10369
10370 static void
10371 ldexp_test (void)
10372 {
10373 START (ldexp);
10374 RUN_TEST_LOOP_fi_f (ldexp, ldexp_test_data, );
10375 END (ldexp);
10376 }
10377
10378
10379 static const struct test_f_f1_data lgamma_test_data[] =
10380 {
10381 START_DATA (lgamma),
10382 TEST_f_f1 (lgamma, plus_infty, plus_infty, 1),
10383 TEST_f_f1 (lgamma, 0, plus_infty, 1, DIVIDE_BY_ZERO_EXCEPTION),
10384 TEST_f_f1 (lgamma, minus_zero, plus_infty, -1, DIVIDE_BY_ZERO_EXCEPTION),
10385 TEST_f_f1 (lgamma, qnan_value, qnan_value, IGNORE),
10386
10387 /* lgamma (x) == +inf plus divide by zero exception for integer x <= 0. */
10388 TEST_f_f1 (lgamma, -3, plus_infty, IGNORE, DIVIDE_BY_ZERO_EXCEPTION|ERRNO_ERANGE),
10389 TEST_f_f1 (lgamma, minus_infty, plus_infty, IGNORE),
10390 TEST_f_f1 (lgamma, -max_value, plus_infty, IGNORE, DIVIDE_BY_ZERO_EXCEPTION),
10391 TEST_f_f1 (lgamma, max_value, plus_infty, 1, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
10392
10393 TEST_f_f1 (lgamma, 1, 0, 1),
10394
10395 TEST_f_f1 (lgamma, 3, M_LN2l, 1),
10396
10397 TEST_f_f1 (lgamma, 0.5, M_LOG_SQRT_PIl, 1),
10398 TEST_f_f1 (lgamma, -0.5, M_LOG_2_SQRT_PIl, -1),
10399 TEST_f_f1 (lgamma, 0.7L, 0.260867246531666514385732417016759578L, 1),
10400 TEST_f_f1 (lgamma, 1.2L, -0.853740900033158497197028392998854470e-1L, 1),
10401 END_DATA (lgamma)
10402 };
10403
10404 static void
10405 lgamma_test (void)
10406 {
10407 errno = 0;
10408 FUNC(lgamma) (0);
10409 if (errno == ENOSYS)
10410 /* Function not implemented. */
10411 return;
10412
10413 START (lgamma);
10414 RUN_TEST_LOOP_f_f1 (lgamma, lgamma_test_data, , signgam);
10415 END (lgamma);
10416 }
10417
10418
10419 static const struct test_f_l_data lrint_test_data[] =
10420 {
10421 START_DATA (lrint),
10422 /* XXX this test is incomplete. We need to have a way to specifiy
10423 the rounding method and test the critical cases. So far, only
10424 unproblematic numbers are tested. */
10425 /* TODO: missing +/-Inf as well as qNaN tests. */
10426 TEST_f_l (lrint, 0.0, 0),
10427 TEST_f_l (lrint, minus_zero, 0),
10428 TEST_f_l (lrint, 0.2L, 0),
10429 TEST_f_l (lrint, -0.2L, 0),
10430
10431 TEST_f_l (lrint, 1.4L, 1),
10432 TEST_f_l (lrint, -1.4L, -1),
10433
10434 TEST_f_l (lrint, 8388600.3L, 8388600),
10435 TEST_f_l (lrint, -8388600.3L, -8388600),
10436
10437 TEST_f_l (lrint, 1071930.0008, 1071930),
10438 #ifndef TEST_FLOAT
10439 TEST_f_l (lrint, 1073741824.01, 1073741824),
10440 # if LONG_MAX > 281474976710656
10441 TEST_f_l (lrint, 281474976710656.025, 281474976710656),
10442 # endif
10443 #endif
10444 END_DATA (lrint)
10445 };
10446
10447 static void
10448 lrint_test (void)
10449 {
10450 START (lrint);
10451 RUN_TEST_LOOP_f_l (lrint, lrint_test_data, );
10452 END (lrint);
10453 }
10454
10455
10456 static const struct test_f_l_data lrint_tonearest_test_data[] =
10457 {
10458 START_DATA (lrint_tonearest),
10459 TEST_f_l (lrint, 0.0, 0),
10460 TEST_f_l (lrint, minus_zero, 0),
10461 TEST_f_l (lrint, 0.2L, 0),
10462 TEST_f_l (lrint, -0.2L, 0),
10463 TEST_f_l (lrint, 0.5L, 0),
10464 TEST_f_l (lrint, -0.5L, 0),
10465 TEST_f_l (lrint, 0.8L, 1),
10466 TEST_f_l (lrint, -0.8L, -1),
10467
10468 TEST_f_l (lrint, 1.4L, 1),
10469 TEST_f_l (lrint, -1.4L, -1),
10470
10471 TEST_f_l (lrint, 8388600.3L, 8388600),
10472 TEST_f_l (lrint, -8388600.3L, -8388600),
10473
10474 TEST_f_l (lrint, 1071930.0008, 1071930),
10475 #ifndef TEST_FLOAT
10476 TEST_f_l (lrint, 1073741824.01, 1073741824),
10477 # if LONG_MAX > 281474976710656
10478 TEST_f_l (lrint, 281474976710656.025, 281474976710656),
10479 # endif
10480 #endif
10481 END_DATA (lrint_tonearest)
10482 };
10483
10484 static void
10485 lrint_test_tonearest (void)
10486 {
10487 START (lrint_tonearest);
10488 RUN_TEST_LOOP_f_l (lrint, lrint_tonearest_test_data, FE_TONEAREST);
10489 END (lrint_tonearest);
10490 }
10491
10492
10493 static const struct test_f_l_data lrint_towardzero_test_data[] =
10494 {
10495 START_DATA (lrint_towardzero),
10496 TEST_f_l (lrint, 0.0, 0),
10497 TEST_f_l (lrint, minus_zero, 0),
10498 TEST_f_l (lrint, 0.2L, 0),
10499 TEST_f_l (lrint, -0.2L, 0),
10500 TEST_f_l (lrint, 0.5L, 0),
10501 TEST_f_l (lrint, -0.5L, 0),
10502 TEST_f_l (lrint, 0.8L, 0),
10503 TEST_f_l (lrint, -0.8L, 0),
10504
10505 TEST_f_l (lrint, 1.4L, 1),
10506 TEST_f_l (lrint, -1.4L, -1),
10507
10508 TEST_f_l (lrint, 8388600.3L, 8388600),
10509 TEST_f_l (lrint, -8388600.3L, -8388600),
10510
10511 TEST_f_l (lrint, 1071930.0008, 1071930),
10512 #ifndef TEST_FLOAT
10513 TEST_f_l (lrint, 1073741824.01, 1073741824),
10514 # if LONG_MAX > 281474976710656
10515 TEST_f_l (lrint, 281474976710656.025, 281474976710656),
10516 # endif
10517 #endif
10518 END_DATA (lrint_towardzero)
10519 };
10520
10521 static void
10522 lrint_test_towardzero (void)
10523 {
10524 START (lrint_towardzero);
10525 RUN_TEST_LOOP_f_l (lrint, lrint_towardzero_test_data, FE_TOWARDZERO);
10526 END (lrint_towardzero);
10527 }
10528
10529
10530 static const struct test_f_l_data lrint_downward_test_data[] =
10531 {
10532 START_DATA (lrint_downward),
10533 TEST_f_l (lrint, 0.0, 0),
10534 TEST_f_l (lrint, minus_zero, 0),
10535 TEST_f_l (lrint, 0.2L, 0),
10536 TEST_f_l (lrint, -0.2L, -1),
10537 TEST_f_l (lrint, 0.5L, 0),
10538 TEST_f_l (lrint, -0.5L, -1),
10539 TEST_f_l (lrint, 0.8L, 0),
10540 TEST_f_l (lrint, -0.8L, -1),
10541
10542 TEST_f_l (lrint, 1.4L, 1),
10543 TEST_f_l (lrint, -1.4L, -2),
10544
10545 TEST_f_l (lrint, 8388600.3L, 8388600),
10546 TEST_f_l (lrint, -8388600.3L, -8388601),
10547
10548 TEST_f_l (lrint, 1071930.0008, 1071930),
10549 #ifndef TEST_FLOAT
10550 TEST_f_l (lrint, 1073741824.01, 1073741824),
10551 # if LONG_MAX > 281474976710656
10552 TEST_f_l (lrint, 281474976710656.025, 281474976710656),
10553 # endif
10554 #endif
10555 END_DATA (lrint_downward)
10556 };
10557
10558 static void
10559 lrint_test_downward (void)
10560 {
10561 START (lrint_downward);
10562 RUN_TEST_LOOP_f_l (lrint, lrint_downward_test_data, FE_DOWNWARD);
10563 END (lrint_downward);
10564 }
10565
10566
10567 static const struct test_f_l_data lrint_upward_test_data[] =
10568 {
10569 START_DATA (lrint_upward),
10570 TEST_f_l (lrint, 0.0, 0),
10571 TEST_f_l (lrint, minus_zero, 0),
10572 TEST_f_l (lrint, 0.2L, 1),
10573 TEST_f_l (lrint, -0.2L, 0),
10574 TEST_f_l (lrint, 0.5L, 1),
10575 TEST_f_l (lrint, -0.5L, 0),
10576 TEST_f_l (lrint, 0.8L, 1),
10577 TEST_f_l (lrint, -0.8L, 0),
10578
10579 TEST_f_l (lrint, 1.4L, 2),
10580 TEST_f_l (lrint, -1.4L, -1),
10581
10582 TEST_f_l (lrint, 8388600.3L, 8388601),
10583 TEST_f_l (lrint, -8388600.3L, -8388600),
10584
10585 #ifndef TEST_FLOAT
10586 TEST_f_l (lrint, 1071930.0008, 1071931),
10587 TEST_f_l (lrint, 1073741824.01, 1073741825),
10588 # if LONG_MAX > 281474976710656 && defined (TEST_LDOUBLE)
10589 TEST_f_l (lrint, 281474976710656.025, 281474976710656),
10590 # endif
10591 #endif
10592 END_DATA (lrint_upward)
10593 };
10594
10595 static void
10596 lrint_test_upward (void)
10597 {
10598 START (lrint_upward);
10599 RUN_TEST_LOOP_f_l (lrint, lrint_upward_test_data, FE_UPWARD);
10600 END (lrint_upward);
10601 }
10602
10603
10604 static const struct test_f_L_data llrint_test_data[] =
10605 {
10606 START_DATA (llrint),
10607 /* XXX this test is incomplete. We need to have a way to specifiy
10608 the rounding method and test the critical cases. So far, only
10609 unproblematic numbers are tested. */
10610 /* TODO: missing +/-Inf as well as qNaN tests. */
10611 TEST_f_L (llrint, 0.0, 0),
10612 TEST_f_L (llrint, minus_zero, 0),
10613 TEST_f_L (llrint, 0.2L, 0),
10614 TEST_f_L (llrint, -0.2L, 0),
10615
10616 TEST_f_L (llrint, 1.4L, 1),
10617 TEST_f_L (llrint, -1.4L, -1),
10618
10619 TEST_f_L (llrint, 8388600.3L, 8388600),
10620 TEST_f_L (llrint, -8388600.3L, -8388600),
10621
10622 TEST_f_L (llrint, 1071930.0008, 1071930),
10623
10624 /* Test boundary conditions. */
10625 /* 0x1FFFFF */
10626 TEST_f_L (llrint, 2097151.0,2097151LL),
10627 /* 0x800000 */
10628 TEST_f_L (llrint, 8388608.0, 8388608LL),
10629 /* 0x1000000 */
10630 TEST_f_L (llrint, 16777216.0, 16777216LL),
10631 /* 0x20000000000 */
10632 TEST_f_L (llrint, 2199023255552.0, 2199023255552LL),
10633 /* 0x40000000000 */
10634 TEST_f_L (llrint, 4398046511104.0, 4398046511104LL),
10635 /* 0x1000000000000 */
10636 TEST_f_L (llrint, 281474976710656.0, 281474976710656LL),
10637 /* 0x10000000000000 */
10638 TEST_f_L (llrint, 4503599627370496.0, 4503599627370496LL),
10639 /* 0x10000080000000 */
10640 TEST_f_L (llrint, 4503601774854144.0, 4503601774854144LL),
10641 /* 0x20000000000000 */
10642 TEST_f_L (llrint, 9007199254740992.0, 9007199254740992LL),
10643 /* 0x80000000000000 */
10644 TEST_f_L (llrint, 36028797018963968.0, 36028797018963968LL),
10645 /* 0x100000000000000 */
10646 TEST_f_L (llrint, 72057594037927936.0, 72057594037927936LL),
10647 #ifdef TEST_LDOUBLE
10648 /* The input can only be represented in long double. */
10649 TEST_f_L (llrint, 4503599627370495.5L, 4503599627370496LL),
10650 TEST_f_L (llrint, 4503599627370496.25L, 4503599627370496LL),
10651 TEST_f_L (llrint, 4503599627370496.5L, 4503599627370496LL),
10652 TEST_f_L (llrint, 4503599627370496.75L, 4503599627370497LL),
10653 TEST_f_L (llrint, 4503599627370497.5L, 4503599627370498LL),
10654
10655 TEST_f_L (llrint, -4503599627370495.5L, -4503599627370496LL),
10656 TEST_f_L (llrint, -4503599627370496.25L, -4503599627370496LL),
10657 TEST_f_L (llrint, -4503599627370496.5L, -4503599627370496LL),
10658 TEST_f_L (llrint, -4503599627370496.75L, -4503599627370497LL),
10659 TEST_f_L (llrint, -4503599627370497.5L, -4503599627370498LL),
10660
10661 # if LDBL_MANT_DIG > 100
10662 TEST_f_L (llrint, 4503599627370495.4999999999999L, 4503599627370495LL),
10663 TEST_f_L (llrint, 4503599627370496.4999999999999L, 4503599627370496LL),
10664 TEST_f_L (llrint, 4503599627370497.4999999999999L, 4503599627370497LL),
10665 TEST_f_L (llrint, 4503599627370494.5000000000001L, 4503599627370495LL),
10666 TEST_f_L (llrint, 4503599627370495.5000000000001L, 4503599627370496LL),
10667 TEST_f_L (llrint, 4503599627370496.5000000000001L, 4503599627370497LL),
10668
10669 TEST_f_L (llrint, -4503599627370495.4999999999999L, -4503599627370495LL),
10670 TEST_f_L (llrint, -4503599627370496.4999999999999L, -4503599627370496LL),
10671 TEST_f_L (llrint, -4503599627370497.4999999999999L, -4503599627370497LL),
10672 TEST_f_L (llrint, -4503599627370494.5000000000001L, -4503599627370495LL),
10673 TEST_f_L (llrint, -4503599627370495.5000000000001L, -4503599627370496LL),
10674 TEST_f_L (llrint, -4503599627370496.5000000000001L, -4503599627370497LL),
10675 #endif
10676
10677 TEST_f_L (llrint, 9007199254740991.5L, 9007199254740992LL),
10678 TEST_f_L (llrint, 9007199254740992.25L, 9007199254740992LL),
10679 TEST_f_L (llrint, 9007199254740992.5L, 9007199254740992LL),
10680 TEST_f_L (llrint, 9007199254740992.75L, 9007199254740993LL),
10681 TEST_f_L (llrint, 9007199254740993.5L, 9007199254740994LL),
10682
10683 TEST_f_L (llrint, -9007199254740991.5L, -9007199254740992LL),
10684 TEST_f_L (llrint, -9007199254740992.25L, -9007199254740992LL),
10685 TEST_f_L (llrint, -9007199254740992.5L, -9007199254740992LL),
10686 TEST_f_L (llrint, -9007199254740992.75L, -9007199254740993LL),
10687 TEST_f_L (llrint, -9007199254740993.5L, -9007199254740994LL),
10688
10689 # if LDBL_MANT_DIG > 100
10690 TEST_f_L (llrint, 9007199254740991.4999999999999L, 9007199254740991LL),
10691 TEST_f_L (llrint, 9007199254740992.4999999999999L, 9007199254740992LL),
10692 TEST_f_L (llrint, 9007199254740993.4999999999999L, 9007199254740993LL),
10693 TEST_f_L (llrint, 9007199254740991.5000000000001L, 9007199254740992LL),
10694 TEST_f_L (llrint, 9007199254740992.5000000000001L, 9007199254740993LL),
10695 TEST_f_L (llrint, 9007199254740993.5000000000001L, 9007199254740994LL),
10696
10697 TEST_f_L (llrint, -9007199254740991.4999999999999L, -9007199254740991LL),
10698 TEST_f_L (llrint, -9007199254740992.4999999999999L, -9007199254740992LL),
10699 TEST_f_L (llrint, -9007199254740993.4999999999999L, -9007199254740993LL),
10700 TEST_f_L (llrint, -9007199254740991.5000000000001L, -9007199254740992LL),
10701 TEST_f_L (llrint, -9007199254740992.5000000000001L, -9007199254740993LL),
10702 TEST_f_L (llrint, -9007199254740993.5000000000001L, -9007199254740994LL),
10703 #endif
10704
10705 TEST_f_L (llrint, 72057594037927935.5L, 72057594037927936LL),
10706 TEST_f_L (llrint, 72057594037927936.25L, 72057594037927936LL),
10707 TEST_f_L (llrint, 72057594037927936.5L, 72057594037927936LL),
10708 TEST_f_L (llrint, 72057594037927936.75L, 72057594037927937LL),
10709 TEST_f_L (llrint, 72057594037927937.5L, 72057594037927938LL),
10710
10711 TEST_f_L (llrint, -72057594037927935.5L, -72057594037927936LL),
10712 TEST_f_L (llrint, -72057594037927936.25L, -72057594037927936LL),
10713 TEST_f_L (llrint, -72057594037927936.5L, -72057594037927936LL),
10714 TEST_f_L (llrint, -72057594037927936.75L, -72057594037927937LL),
10715 TEST_f_L (llrint, -72057594037927937.5L, -72057594037927938LL),
10716
10717 # if LDBL_MANT_DIG > 100
10718 TEST_f_L (llrint, 9223372036854775805.5L, 9223372036854775806LL),
10719 TEST_f_L (llrint, -9223372036854775805.5L, -9223372036854775806LL),
10720 TEST_f_L (llrint, 9223372036854775806.0L, 9223372036854775806LL),
10721 TEST_f_L (llrint, -9223372036854775806.0L, -9223372036854775806LL),
10722 TEST_f_L (llrint, 9223372036854775806.25L, 9223372036854775806LL),
10723 TEST_f_L (llrint, -9223372036854775806.25L, -9223372036854775806LL),
10724 TEST_f_L (llrint, 9223372036854775806.5L, 9223372036854775806L),
10725 TEST_f_L (llrint, -9223372036854775806.5L, -9223372036854775806LL),
10726 TEST_f_L (llrint, 9223372036854775806.75L, 9223372036854775807LL),
10727 TEST_f_L (llrint, -9223372036854775806.75L, -9223372036854775807LL),
10728 TEST_f_L (llrint, 9223372036854775807.0L, 9223372036854775807LL),
10729 TEST_f_L (llrint, -9223372036854775807.0L, -9223372036854775807LL),
10730 # endif
10731 #endif
10732 END_DATA (llrint)
10733 };
10734
10735 static void
10736 llrint_test (void)
10737 {
10738 START (llrint);
10739 RUN_TEST_LOOP_f_L (llrint, llrint_test_data, );
10740 END (llrint);
10741 }
10742
10743 static const struct test_f_L_data llrint_tonearest_test_data[] =
10744 {
10745 START_DATA (llrint_tonearest),
10746 TEST_f_L (llrint, 0.0, 0),
10747 TEST_f_L (llrint, minus_zero, 0),
10748 TEST_f_L (llrint, 0.2L, 0),
10749 TEST_f_L (llrint, -0.2L, 0),
10750
10751 TEST_f_L (llrint, 1.4L, 1),
10752 TEST_f_L (llrint, -1.4L, -1),
10753
10754 TEST_f_L (llrint, 8388600.3L, 8388600),
10755 TEST_f_L (llrint, -8388600.3L, -8388600),
10756
10757 TEST_f_L (llrint, 1071930.0008, 1071930),
10758
10759 /* Test boundary conditions. */
10760 /* 0x1FFFFF */
10761 TEST_f_L (llrint, 2097151.0,2097151LL),
10762 /* 0x800000 */
10763 TEST_f_L (llrint, 8388608.0, 8388608LL),
10764 /* 0x1000000 */
10765 TEST_f_L (llrint, 16777216.0, 16777216LL),
10766 /* 0x20000000000 */
10767 TEST_f_L (llrint, 2199023255552.0, 2199023255552LL),
10768 /* 0x40000000000 */
10769 TEST_f_L (llrint, 4398046511104.0, 4398046511104LL),
10770 /* 0x1000000000000 */
10771 TEST_f_L (llrint, 281474976710656.0, 281474976710656LL),
10772 /* 0x10000000000000 */
10773 TEST_f_L (llrint, 4503599627370496.0, 4503599627370496LL),
10774 /* 0x10000080000000 */
10775 TEST_f_L (llrint, 4503601774854144.0, 4503601774854144LL),
10776 /* 0x20000000000000 */
10777 TEST_f_L (llrint, 9007199254740992.0, 9007199254740992LL),
10778 /* 0x80000000000000 */
10779 TEST_f_L (llrint, 36028797018963968.0, 36028797018963968LL),
10780 /* 0x100000000000000 */
10781 TEST_f_L (llrint, 72057594037927936.0, 72057594037927936LL),
10782 #ifdef TEST_LDOUBLE
10783 /* The input can only be represented in long double. */
10784 TEST_f_L (llrint, 4503599627370495.5L, 4503599627370496LL),
10785 TEST_f_L (llrint, 4503599627370496.25L, 4503599627370496LL),
10786 TEST_f_L (llrint, 4503599627370496.5L, 4503599627370496LL),
10787 TEST_f_L (llrint, 4503599627370496.75L, 4503599627370497LL),
10788 TEST_f_L (llrint, 4503599627370497.5L, 4503599627370498LL),
10789
10790 TEST_f_L (llrint, -4503599627370495.5L, -4503599627370496LL),
10791 TEST_f_L (llrint, -4503599627370496.25L, -4503599627370496LL),
10792 TEST_f_L (llrint, -4503599627370496.5L, -4503599627370496LL),
10793 TEST_f_L (llrint, -4503599627370496.75L, -4503599627370497LL),
10794 TEST_f_L (llrint, -4503599627370497.5L, -4503599627370498LL),
10795
10796 # if LDBL_MANT_DIG > 100
10797 TEST_f_L (llrint, 4503599627370495.4999999999999L, 4503599627370495LL),
10798 TEST_f_L (llrint, 4503599627370496.4999999999999L, 4503599627370496LL),
10799 TEST_f_L (llrint, 4503599627370497.4999999999999L, 4503599627370497LL),
10800 TEST_f_L (llrint, 4503599627370494.5000000000001L, 4503599627370495LL),
10801 TEST_f_L (llrint, 4503599627370495.5000000000001L, 4503599627370496LL),
10802 TEST_f_L (llrint, 4503599627370496.5000000000001L, 4503599627370497LL),
10803
10804 TEST_f_L (llrint, -4503599627370495.4999999999999L, -4503599627370495LL),
10805 TEST_f_L (llrint, -4503599627370496.4999999999999L, -4503599627370496LL),
10806 TEST_f_L (llrint, -4503599627370497.4999999999999L, -4503599627370497LL),
10807 TEST_f_L (llrint, -4503599627370494.5000000000001L, -4503599627370495LL),
10808 TEST_f_L (llrint, -4503599627370495.5000000000001L, -4503599627370496LL),
10809 TEST_f_L (llrint, -4503599627370496.5000000000001L, -4503599627370497LL),
10810 #endif
10811
10812 TEST_f_L (llrint, 9007199254740991.5L, 9007199254740992LL),
10813 TEST_f_L (llrint, 9007199254740992.25L, 9007199254740992LL),
10814 TEST_f_L (llrint, 9007199254740992.5L, 9007199254740992LL),
10815 TEST_f_L (llrint, 9007199254740992.75L, 9007199254740993LL),
10816 TEST_f_L (llrint, 9007199254740993.5L, 9007199254740994LL),
10817
10818 TEST_f_L (llrint, -9007199254740991.5L, -9007199254740992LL),
10819 TEST_f_L (llrint, -9007199254740992.25L, -9007199254740992LL),
10820 TEST_f_L (llrint, -9007199254740992.5L, -9007199254740992LL),
10821 TEST_f_L (llrint, -9007199254740992.75L, -9007199254740993LL),
10822 TEST_f_L (llrint, -9007199254740993.5L, -9007199254740994LL),
10823
10824 # if LDBL_MANT_DIG > 100
10825 TEST_f_L (llrint, 9007199254740991.4999999999999L, 9007199254740991LL),
10826 TEST_f_L (llrint, 9007199254740992.4999999999999L, 9007199254740992LL),
10827 TEST_f_L (llrint, 9007199254740993.4999999999999L, 9007199254740993LL),
10828 TEST_f_L (llrint, 9007199254740991.5000000000001L, 9007199254740992LL),
10829 TEST_f_L (llrint, 9007199254740992.5000000000001L, 9007199254740993LL),
10830 TEST_f_L (llrint, 9007199254740993.5000000000001L, 9007199254740994LL),
10831
10832 TEST_f_L (llrint, -9007199254740991.4999999999999L, -9007199254740991LL),
10833 TEST_f_L (llrint, -9007199254740992.4999999999999L, -9007199254740992LL),
10834 TEST_f_L (llrint, -9007199254740993.4999999999999L, -9007199254740993LL),
10835 TEST_f_L (llrint, -9007199254740991.5000000000001L, -9007199254740992LL),
10836 TEST_f_L (llrint, -9007199254740992.5000000000001L, -9007199254740993LL),
10837 TEST_f_L (llrint, -9007199254740993.5000000000001L, -9007199254740994LL),
10838 #endif
10839
10840 TEST_f_L (llrint, 72057594037927935.5L, 72057594037927936LL),
10841 TEST_f_L (llrint, 72057594037927936.25L, 72057594037927936LL),
10842 TEST_f_L (llrint, 72057594037927936.5L, 72057594037927936LL),
10843 TEST_f_L (llrint, 72057594037927936.75L, 72057594037927937LL),
10844 TEST_f_L (llrint, 72057594037927937.5L, 72057594037927938LL),
10845
10846 TEST_f_L (llrint, -72057594037927935.5L, -72057594037927936LL),
10847 TEST_f_L (llrint, -72057594037927936.25L, -72057594037927936LL),
10848 TEST_f_L (llrint, -72057594037927936.5L, -72057594037927936LL),
10849 TEST_f_L (llrint, -72057594037927936.75L, -72057594037927937LL),
10850 TEST_f_L (llrint, -72057594037927937.5L, -72057594037927938LL),
10851
10852 # if LDBL_MANT_DIG > 100
10853 TEST_f_L (llrint, 9223372036854775805.5L, 9223372036854775806LL),
10854 TEST_f_L (llrint, -9223372036854775805.5L, -9223372036854775806LL),
10855 TEST_f_L (llrint, 9223372036854775806.0L, 9223372036854775806LL),
10856 TEST_f_L (llrint, -9223372036854775806.0L, -9223372036854775806LL),
10857 TEST_f_L (llrint, 9223372036854775806.25L, 9223372036854775806LL),
10858 TEST_f_L (llrint, -9223372036854775806.25L, -9223372036854775806LL),
10859 TEST_f_L (llrint, 9223372036854775806.5L, 9223372036854775806L),
10860 TEST_f_L (llrint, -9223372036854775806.5L, -9223372036854775806LL),
10861 TEST_f_L (llrint, 9223372036854775806.75L, 9223372036854775807LL),
10862 TEST_f_L (llrint, -9223372036854775806.75L, -9223372036854775807LL),
10863 TEST_f_L (llrint, 9223372036854775807.0L, 9223372036854775807LL),
10864 TEST_f_L (llrint, -9223372036854775807.0L, -9223372036854775807LL),
10865 # endif
10866 #endif
10867 END_DATA (llrint_tonearest)
10868 };
10869
10870 static void
10871 llrint_test_tonearest (void)
10872 {
10873 START (llrint_tonearest);
10874 RUN_TEST_LOOP_f_L (llrint, llrint_tonearest_test_data, FE_TONEAREST);
10875 END (llrint_tonearest);
10876 }
10877
10878 static const struct test_f_L_data llrint_towardzero_test_data[] =
10879 {
10880 START_DATA (llrint_towardzero),
10881 TEST_f_L (llrint, 0.0, 0),
10882 TEST_f_L (llrint, minus_zero, 0),
10883 TEST_f_L (llrint, 0.2L, 0),
10884 TEST_f_L (llrint, -0.2L, 0),
10885
10886 TEST_f_L (llrint, 1.4L, 1),
10887 TEST_f_L (llrint, -1.4L, -1),
10888
10889 TEST_f_L (llrint, 8388600.3L, 8388600),
10890 TEST_f_L (llrint, -8388600.3L, -8388600),
10891
10892 TEST_f_L (llrint, 1071930.0008, 1071930),
10893
10894 /* Test boundary conditions. */
10895 /* 0x1FFFFF */
10896 TEST_f_L (llrint, 2097151.0,2097151LL),
10897 /* 0x800000 */
10898 TEST_f_L (llrint, 8388608.0, 8388608LL),
10899 /* 0x1000000 */
10900 TEST_f_L (llrint, 16777216.0, 16777216LL),
10901 /* 0x20000000000 */
10902 TEST_f_L (llrint, 2199023255552.0, 2199023255552LL),
10903 /* 0x40000000000 */
10904 TEST_f_L (llrint, 4398046511104.0, 4398046511104LL),
10905 /* 0x1000000000000 */
10906 TEST_f_L (llrint, 281474976710656.0, 281474976710656LL),
10907 /* 0x10000000000000 */
10908 TEST_f_L (llrint, 4503599627370496.0, 4503599627370496LL),
10909 /* 0x10000080000000 */
10910 TEST_f_L (llrint, 4503601774854144.0, 4503601774854144LL),
10911 /* 0x20000000000000 */
10912 TEST_f_L (llrint, 9007199254740992.0, 9007199254740992LL),
10913 /* 0x80000000000000 */
10914 TEST_f_L (llrint, 36028797018963968.0, 36028797018963968LL),
10915 /* 0x100000000000000 */
10916 TEST_f_L (llrint, 72057594037927936.0, 72057594037927936LL),
10917 #ifdef TEST_LDOUBLE
10918 /* The input can only be represented in long double. */
10919 TEST_f_L (llrint, 4503599627370495.5L, 4503599627370495LL),
10920 TEST_f_L (llrint, 4503599627370496.25L, 4503599627370496LL),
10921 TEST_f_L (llrint, 4503599627370496.5L, 4503599627370496LL),
10922 TEST_f_L (llrint, 4503599627370496.75L, 4503599627370496LL),
10923 TEST_f_L (llrint, 4503599627370497.5L, 4503599627370497LL),
10924
10925 TEST_f_L (llrint, -4503599627370495.5L, -4503599627370495LL),
10926 TEST_f_L (llrint, -4503599627370496.25L, -4503599627370496LL),
10927 TEST_f_L (llrint, -4503599627370496.5L, -4503599627370496LL),
10928 TEST_f_L (llrint, -4503599627370496.75L, -4503599627370496LL),
10929 TEST_f_L (llrint, -4503599627370497.5L, -4503599627370497LL),
10930
10931 # if LDBL_MANT_DIG > 100
10932 TEST_f_L (llrint, 4503599627370495.4999999999999L, 4503599627370495LL),
10933 TEST_f_L (llrint, 4503599627370496.4999999999999L, 4503599627370496LL),
10934 TEST_f_L (llrint, 4503599627370497.4999999999999L, 4503599627370497LL),
10935 TEST_f_L (llrint, 4503599627370494.5000000000001L, 4503599627370494LL),
10936 TEST_f_L (llrint, 4503599627370495.5000000000001L, 4503599627370495LL),
10937 TEST_f_L (llrint, 4503599627370496.5000000000001L, 4503599627370496LL),
10938
10939 TEST_f_L (llrint, -4503599627370495.4999999999999L, -4503599627370495LL),
10940 TEST_f_L (llrint, -4503599627370496.4999999999999L, -4503599627370496LL),
10941 TEST_f_L (llrint, -4503599627370497.4999999999999L, -4503599627370497LL),
10942 TEST_f_L (llrint, -4503599627370494.5000000000001L, -4503599627370494LL),
10943 TEST_f_L (llrint, -4503599627370495.5000000000001L, -4503599627370495LL),
10944 TEST_f_L (llrint, -4503599627370496.5000000000001L, -4503599627370496LL),
10945 #endif
10946
10947 TEST_f_L (llrint, 9007199254740991.5L, 9007199254740991LL),
10948 TEST_f_L (llrint, 9007199254740992.25L, 9007199254740992LL),
10949 TEST_f_L (llrint, 9007199254740992.5L, 9007199254740992LL),
10950 TEST_f_L (llrint, 9007199254740992.75L, 9007199254740992LL),
10951 TEST_f_L (llrint, 9007199254740993.5L, 9007199254740993LL),
10952
10953 TEST_f_L (llrint, -9007199254740991.5L, -9007199254740991LL),
10954 TEST_f_L (llrint, -9007199254740992.25L, -9007199254740992LL),
10955 TEST_f_L (llrint, -9007199254740992.5L, -9007199254740992LL),
10956 TEST_f_L (llrint, -9007199254740992.75L, -9007199254740992LL),
10957 TEST_f_L (llrint, -9007199254740993.5L, -9007199254740993LL),
10958
10959 # if LDBL_MANT_DIG > 100
10960 TEST_f_L (llrint, 9007199254740991.4999999999999L, 9007199254740991LL),
10961 TEST_f_L (llrint, 9007199254740992.4999999999999L, 9007199254740992LL),
10962 TEST_f_L (llrint, 9007199254740993.4999999999999L, 9007199254740993LL),
10963 TEST_f_L (llrint, 9007199254740991.5000000000001L, 9007199254740991LL),
10964 TEST_f_L (llrint, 9007199254740992.5000000000001L, 9007199254740992LL),
10965 TEST_f_L (llrint, 9007199254740993.5000000000001L, 9007199254740993LL),
10966
10967 TEST_f_L (llrint, -9007199254740991.4999999999999L, -9007199254740991LL),
10968 TEST_f_L (llrint, -9007199254740992.4999999999999L, -9007199254740992LL),
10969 TEST_f_L (llrint, -9007199254740993.4999999999999L, -9007199254740993LL),
10970 TEST_f_L (llrint, -9007199254740991.5000000000001L, -9007199254740991LL),
10971 TEST_f_L (llrint, -9007199254740992.5000000000001L, -9007199254740992LL),
10972 TEST_f_L (llrint, -9007199254740993.5000000000001L, -9007199254740993LL),
10973 #endif
10974
10975 TEST_f_L (llrint, 72057594037927935.5L, 72057594037927935LL),
10976 TEST_f_L (llrint, 72057594037927936.25L, 72057594037927936LL),
10977 TEST_f_L (llrint, 72057594037927936.5L, 72057594037927936LL),
10978 TEST_f_L (llrint, 72057594037927936.75L, 72057594037927936LL),
10979 TEST_f_L (llrint, 72057594037927937.5L, 72057594037927937LL),
10980
10981 TEST_f_L (llrint, -72057594037927935.5L, -72057594037927935LL),
10982 TEST_f_L (llrint, -72057594037927936.25L, -72057594037927936LL),
10983 TEST_f_L (llrint, -72057594037927936.5L, -72057594037927936LL),
10984 TEST_f_L (llrint, -72057594037927936.75L, -72057594037927936LL),
10985 TEST_f_L (llrint, -72057594037927937.5L, -72057594037927937LL),
10986
10987 # if LDBL_MANT_DIG > 100
10988 TEST_f_L (llrint, 9223372036854775805.5L, 9223372036854775805LL),
10989 TEST_f_L (llrint, -9223372036854775805.5L, -9223372036854775805LL),
10990 TEST_f_L (llrint, 9223372036854775806.0L, 9223372036854775806LL),
10991 TEST_f_L (llrint, -9223372036854775806.0L, -9223372036854775806LL),
10992 TEST_f_L (llrint, 9223372036854775806.25L, 9223372036854775806LL),
10993 TEST_f_L (llrint, -9223372036854775806.25L, -9223372036854775806LL),
10994 TEST_f_L (llrint, 9223372036854775806.5L, 9223372036854775806L),
10995 TEST_f_L (llrint, -9223372036854775806.5L, -9223372036854775806LL),
10996 TEST_f_L (llrint, 9223372036854775806.75L, 9223372036854775806LL),
10997 TEST_f_L (llrint, -9223372036854775806.75L, -9223372036854775806LL),
10998 TEST_f_L (llrint, 9223372036854775807.0L, 9223372036854775807LL),
10999 TEST_f_L (llrint, -9223372036854775807.0L, -9223372036854775807LL),
11000 # endif
11001 #endif
11002 END_DATA (llrint_towardzero)
11003 };
11004
11005 static void
11006 llrint_test_towardzero (void)
11007 {
11008 START (llrint_towardzero);
11009 RUN_TEST_LOOP_f_L (llrint, llrint_towardzero_test_data, FE_TOWARDZERO);
11010 END (llrint_towardzero);
11011 }
11012
11013 static const struct test_f_L_data llrint_downward_test_data[] =
11014 {
11015 START_DATA (llrint_downward),
11016 TEST_f_L (llrint, 0.0, 0),
11017 TEST_f_L (llrint, minus_zero, 0),
11018 TEST_f_L (llrint, 0.2L, 0),
11019 TEST_f_L (llrint, -0.2L, -1),
11020
11021 TEST_f_L (llrint, 1.4L, 1),
11022 TEST_f_L (llrint, -1.4L, -2),
11023
11024 TEST_f_L (llrint, 8388600.3L, 8388600),
11025 TEST_f_L (llrint, -8388600.3L, -8388601),
11026
11027 TEST_f_L (llrint, 1071930.0008, 1071930),
11028
11029 /* Test boundary conditions. */
11030 /* 0x1FFFFF */
11031 TEST_f_L (llrint, 2097151.0,2097151LL),
11032 /* 0x800000 */
11033 TEST_f_L (llrint, 8388608.0, 8388608LL),
11034 /* 0x1000000 */
11035 TEST_f_L (llrint, 16777216.0, 16777216LL),
11036 /* 0x20000000000 */
11037 TEST_f_L (llrint, 2199023255552.0, 2199023255552LL),
11038 /* 0x40000000000 */
11039 TEST_f_L (llrint, 4398046511104.0, 4398046511104LL),
11040 /* 0x1000000000000 */
11041 TEST_f_L (llrint, 281474976710656.0, 281474976710656LL),
11042 /* 0x10000000000000 */
11043 TEST_f_L (llrint, 4503599627370496.0, 4503599627370496LL),
11044 /* 0x10000080000000 */
11045 TEST_f_L (llrint, 4503601774854144.0, 4503601774854144LL),
11046 /* 0x20000000000000 */
11047 TEST_f_L (llrint, 9007199254740992.0, 9007199254740992LL),
11048 /* 0x80000000000000 */
11049 TEST_f_L (llrint, 36028797018963968.0, 36028797018963968LL),
11050 /* 0x100000000000000 */
11051 TEST_f_L (llrint, 72057594037927936.0, 72057594037927936LL),
11052 #ifdef TEST_LDOUBLE
11053 /* The input can only be represented in long double. */
11054 TEST_f_L (llrint, 4503599627370495.5L, 4503599627370495LL),
11055 TEST_f_L (llrint, 4503599627370496.25L, 4503599627370496LL),
11056 TEST_f_L (llrint, 4503599627370496.5L, 4503599627370496LL),
11057 TEST_f_L (llrint, 4503599627370496.75L, 4503599627370496LL),
11058 TEST_f_L (llrint, 4503599627370497.5L, 4503599627370497LL),
11059
11060 TEST_f_L (llrint, 4503599627370495.4999999999999L, 4503599627370495LL),
11061 TEST_f_L (llrint, 4503599627370496.4999999999999L, 4503599627370496LL),
11062 TEST_f_L (llrint, 4503599627370497.4999999999999L, 4503599627370497LL),
11063 TEST_f_L (llrint, 4503599627370494.5000000000001L, 4503599627370494LL),
11064 TEST_f_L (llrint, 4503599627370495.5000000000001L, 4503599627370495LL),
11065 TEST_f_L (llrint, 4503599627370496.5000000000001L, 4503599627370496LL),
11066
11067 TEST_f_L (llrint, -4503599627370495.5L, -4503599627370496LL),
11068 TEST_f_L (llrint, -4503599627370496.25L, -4503599627370497LL),
11069 TEST_f_L (llrint, -4503599627370496.5L, -4503599627370497LL),
11070 TEST_f_L (llrint, -4503599627370496.75L, -4503599627370497LL),
11071 TEST_f_L (llrint, -4503599627370497.5L, -4503599627370498LL),
11072
11073 TEST_f_L (llrint, -4503599627370495.4999999999999L, -4503599627370496LL),
11074 TEST_f_L (llrint, -4503599627370496.4999999999999L, -4503599627370497LL),
11075 TEST_f_L (llrint, -4503599627370497.4999999999999L, -4503599627370498LL),
11076 TEST_f_L (llrint, -4503599627370494.5000000000001L, -4503599627370495LL),
11077 TEST_f_L (llrint, -4503599627370495.5000000000001L, -4503599627370496LL),
11078 TEST_f_L (llrint, -4503599627370496.5000000000001L, -4503599627370497LL),
11079
11080 TEST_f_L (llrint, 9007199254740991.5L, 9007199254740991LL),
11081 TEST_f_L (llrint, 9007199254740992.25L, 9007199254740992LL),
11082 TEST_f_L (llrint, 9007199254740992.5L, 9007199254740992LL),
11083 TEST_f_L (llrint, 9007199254740992.75L, 9007199254740992LL),
11084 TEST_f_L (llrint, 9007199254740993.5L, 9007199254740993LL),
11085
11086 TEST_f_L (llrint, 9007199254740991.4999999999999L, 9007199254740991LL),
11087 TEST_f_L (llrint, 9007199254740992.4999999999999L, 9007199254740992LL),
11088 TEST_f_L (llrint, 9007199254740993.4999999999999L, 9007199254740993LL),
11089 TEST_f_L (llrint, 9007199254740991.5000000000001L, 9007199254740991LL),
11090 TEST_f_L (llrint, 9007199254740992.5000000000001L, 9007199254740992LL),
11091 TEST_f_L (llrint, 9007199254740993.5000000000001L, 9007199254740993LL),
11092
11093 TEST_f_L (llrint, -9007199254740991.5L, -9007199254740992LL),
11094 TEST_f_L (llrint, -9007199254740992.25L, -9007199254740993LL),
11095 TEST_f_L (llrint, -9007199254740992.5L, -9007199254740993LL),
11096 TEST_f_L (llrint, -9007199254740992.75L, -9007199254740993LL),
11097 TEST_f_L (llrint, -9007199254740993.5L, -9007199254740994LL),
11098
11099 TEST_f_L (llrint, -9007199254740991.4999999999999L, -9007199254740992LL),
11100 TEST_f_L (llrint, -9007199254740992.4999999999999L, -9007199254740993LL),
11101 TEST_f_L (llrint, -9007199254740993.4999999999999L, -9007199254740994LL),
11102 TEST_f_L (llrint, -9007199254740991.5000000000001L, -9007199254740992LL),
11103 TEST_f_L (llrint, -9007199254740992.5000000000001L, -9007199254740993LL),
11104 TEST_f_L (llrint, -9007199254740993.5000000000001L, -9007199254740994LL),
11105
11106 TEST_f_L (llrint, 72057594037927935.5L, 72057594037927935LL),
11107 TEST_f_L (llrint, 72057594037927936.25L, 72057594037927936LL),
11108 TEST_f_L (llrint, 72057594037927936.5L, 72057594037927936LL),
11109 TEST_f_L (llrint, 72057594037927936.75L, 72057594037927936LL),
11110 TEST_f_L (llrint, 72057594037927937.5L, 72057594037927937LL),
11111
11112 TEST_f_L (llrint, -72057594037927935.5L, -72057594037927936LL),
11113 TEST_f_L (llrint, -72057594037927936.25L, -72057594037927937LL),
11114 TEST_f_L (llrint, -72057594037927936.5L, -72057594037927937LL),
11115 TEST_f_L (llrint, -72057594037927936.75L, -72057594037927937LL),
11116 TEST_f_L (llrint, -72057594037927937.5L, -72057594037927938LL),
11117
11118 # if LDBL_MANT_DIG > 100
11119 TEST_f_L (llrint, 9223372036854775805.5L, 9223372036854775805LL),
11120 TEST_f_L (llrint, -9223372036854775805.5L, -9223372036854775806LL),
11121 TEST_f_L (llrint, 9223372036854775806.0L, 9223372036854775806LL),
11122 TEST_f_L (llrint, -9223372036854775806.0L, -9223372036854775806LL),
11123 TEST_f_L (llrint, 9223372036854775806.25L, 9223372036854775806LL),
11124 TEST_f_L (llrint, -9223372036854775806.25L, -9223372036854775807LL),
11125 TEST_f_L (llrint, 9223372036854775806.5L, 9223372036854775806L),
11126 TEST_f_L (llrint, -9223372036854775806.5L, -9223372036854775807LL),
11127 TEST_f_L (llrint, 9223372036854775806.75L, 9223372036854775806LL),
11128 TEST_f_L (llrint, -9223372036854775806.75L, -9223372036854775807LL),
11129 TEST_f_L (llrint, 9223372036854775807.0L, 9223372036854775807LL),
11130 TEST_f_L (llrint, -9223372036854775807.0L, -9223372036854775807LL),
11131 # endif
11132 #endif
11133 END_DATA (llrint_downward)
11134 };
11135
11136 static void
11137 llrint_test_downward (void)
11138 {
11139 START (llrint_downward);
11140 RUN_TEST_LOOP_f_L (llrint, llrint_downward_test_data, FE_DOWNWARD);
11141 END (llrint_downward);
11142 }
11143
11144 static const struct test_f_L_data llrint_upward_test_data[] =
11145 {
11146 START_DATA (llrint_upward),
11147 TEST_f_L (llrint, 0.0, 0),
11148 TEST_f_L (llrint, minus_zero, 0),
11149 TEST_f_L (llrint, 0.2L, 1),
11150 TEST_f_L (llrint, -0.2L, 0),
11151
11152 TEST_f_L (llrint, 1.4L, 2),
11153 TEST_f_L (llrint, -1.4L, -1),
11154
11155 TEST_f_L (llrint, 8388600.3L, 8388601),
11156 TEST_f_L (llrint, -8388600.3L, -8388600),
11157 #ifndef TEST_FLOAT
11158 TEST_f_L (llrint, 1071930.0008, 1071931),
11159 #endif
11160 /* Test boundary conditions. */
11161 /* 0x1FFFFF */
11162 TEST_f_L (llrint, 2097151.0,2097151LL),
11163 /* 0x800000 */
11164 TEST_f_L (llrint, 8388608.0, 8388608LL),
11165 /* 0x1000000 */
11166 TEST_f_L (llrint, 16777216.0, 16777216LL),
11167 /* 0x20000000000 */
11168 TEST_f_L (llrint, 2199023255552.0, 2199023255552LL),
11169 /* 0x40000000000 */
11170 TEST_f_L (llrint, 4398046511104.0, 4398046511104LL),
11171 /* 0x1000000000000 */
11172 TEST_f_L (llrint, 281474976710656.0, 281474976710656LL),
11173 /* 0x10000000000000 */
11174 TEST_f_L (llrint, 4503599627370496.0, 4503599627370496LL),
11175 /* 0x10000080000000 */
11176 TEST_f_L (llrint, 4503601774854144.0, 4503601774854144LL),
11177 /* 0x20000000000000 */
11178 TEST_f_L (llrint, 9007199254740992.0, 9007199254740992LL),
11179 /* 0x80000000000000 */
11180 TEST_f_L (llrint, 36028797018963968.0, 36028797018963968LL),
11181 /* 0x100000000000000 */
11182 TEST_f_L (llrint, 72057594037927936.0, 72057594037927936LL),
11183 #ifdef TEST_LDOUBLE
11184 /* The input can only be represented in long double. */
11185 TEST_f_L (llrint, 4503599627370495.5L, 4503599627370496LL),
11186 TEST_f_L (llrint, 4503599627370496.25L, 4503599627370497LL),
11187 TEST_f_L (llrint, 4503599627370496.5L, 4503599627370497LL),
11188 TEST_f_L (llrint, 4503599627370496.75L, 4503599627370497LL),
11189 TEST_f_L (llrint, 4503599627370497.5L, 4503599627370498LL),
11190
11191 TEST_f_L (llrint, 4503599627370495.4999999999999L, 4503599627370496LL),
11192 TEST_f_L (llrint, 4503599627370496.4999999999999L, 4503599627370497LL),
11193 TEST_f_L (llrint, 4503599627370497.4999999999999L, 4503599627370498LL),
11194 TEST_f_L (llrint, 4503599627370494.5000000000001L, 4503599627370495LL),
11195 TEST_f_L (llrint, 4503599627370495.5000000000001L, 4503599627370496LL),
11196 TEST_f_L (llrint, 4503599627370496.5000000000001L, 4503599627370497LL),
11197
11198 TEST_f_L (llrint, -4503599627370495.5L, -4503599627370495LL),
11199 TEST_f_L (llrint, -4503599627370496.25L, -4503599627370496LL),
11200 TEST_f_L (llrint, -4503599627370496.5L, -4503599627370496LL),
11201 TEST_f_L (llrint, -4503599627370496.75L, -4503599627370496LL),
11202 TEST_f_L (llrint, -4503599627370497.5L, -4503599627370497LL),
11203
11204 TEST_f_L (llrint, -4503599627370495.4999999999999L, -4503599627370495LL),
11205 TEST_f_L (llrint, -4503599627370496.4999999999999L, -4503599627370496LL),
11206 TEST_f_L (llrint, -4503599627370497.4999999999999L, -4503599627370497LL),
11207 TEST_f_L (llrint, -4503599627370494.5000000000001L, -4503599627370494LL),
11208 TEST_f_L (llrint, -4503599627370495.5000000000001L, -4503599627370495LL),
11209 TEST_f_L (llrint, -4503599627370496.5000000000001L, -4503599627370496LL),
11210
11211 TEST_f_L (llrint, 9007199254740991.5L, 9007199254740992LL),
11212 TEST_f_L (llrint, 9007199254740992.25L, 9007199254740993LL),
11213 TEST_f_L (llrint, 9007199254740992.5L, 9007199254740993LL),
11214 TEST_f_L (llrint, 9007199254740992.75L, 9007199254740993LL),
11215 TEST_f_L (llrint, 9007199254740993.5L, 9007199254740994LL),
11216
11217 TEST_f_L (llrint, 9007199254740991.4999999999999L, 9007199254740992LL),
11218 TEST_f_L (llrint, 9007199254740992.4999999999999L, 9007199254740993LL),
11219 TEST_f_L (llrint, 9007199254740993.4999999999999L, 9007199254740994LL),
11220 TEST_f_L (llrint, 9007199254740991.5000000000001L, 9007199254740992LL),
11221 TEST_f_L (llrint, 9007199254740992.5000000000001L, 9007199254740993LL),
11222 TEST_f_L (llrint, 9007199254740993.5000000000001L, 9007199254740994LL),
11223
11224 TEST_f_L (llrint, -9007199254740991.5L, -9007199254740991LL),
11225 TEST_f_L (llrint, -9007199254740992.25L, -9007199254740992LL),
11226 TEST_f_L (llrint, -9007199254740992.5L, -9007199254740992LL),
11227 TEST_f_L (llrint, -9007199254740992.75L, -9007199254740992LL),
11228 TEST_f_L (llrint, -9007199254740993.5L, -9007199254740993LL),
11229
11230 TEST_f_L (llrint, -9007199254740991.4999999999999L, -9007199254740991LL),
11231 TEST_f_L (llrint, -9007199254740992.4999999999999L, -9007199254740992LL),
11232 TEST_f_L (llrint, -9007199254740993.4999999999999L, -9007199254740993LL),
11233 TEST_f_L (llrint, -9007199254740991.5000000000001L, -9007199254740991LL),
11234 TEST_f_L (llrint, -9007199254740992.5000000000001L, -9007199254740992LL),
11235 TEST_f_L (llrint, -9007199254740993.5000000000001L, -9007199254740993LL),
11236
11237 TEST_f_L (llrint, 72057594037927935.5L, 72057594037927936LL),
11238 TEST_f_L (llrint, 72057594037927936.25L, 72057594037927937LL),
11239 TEST_f_L (llrint, 72057594037927936.5L, 72057594037927937LL),
11240 TEST_f_L (llrint, 72057594037927936.75L, 72057594037927937LL),
11241 TEST_f_L (llrint, 72057594037927937.5L, 72057594037927938LL),
11242
11243 TEST_f_L (llrint, -72057594037927935.5L, -72057594037927935LL),
11244 TEST_f_L (llrint, -72057594037927936.25L, -72057594037927936LL),
11245 TEST_f_L (llrint, -72057594037927936.5L, -72057594037927936LL),
11246 TEST_f_L (llrint, -72057594037927936.75L, -72057594037927936LL),
11247 TEST_f_L (llrint, -72057594037927937.5L, -72057594037927937LL),
11248
11249 # if LDBL_MANT_DIG > 100
11250 TEST_f_L (llrint, 9223372036854775805.5L, 9223372036854775806LL),
11251 TEST_f_L (llrint, -9223372036854775805.5L, -9223372036854775805LL),
11252 TEST_f_L (llrint, 9223372036854775806.0L, 9223372036854775806LL),
11253 TEST_f_L (llrint, -9223372036854775806.0L, -9223372036854775806LL),
11254 TEST_f_L (llrint, 9223372036854775806.25L, 9223372036854775807LL),
11255 TEST_f_L (llrint, -9223372036854775806.25L, -9223372036854775806LL),
11256 TEST_f_L (llrint, 9223372036854775806.5L, 9223372036854775807L),
11257 TEST_f_L (llrint, -9223372036854775806.5L, -9223372036854775806LL),
11258 TEST_f_L (llrint, 9223372036854775806.75L, 9223372036854775807LL),
11259 TEST_f_L (llrint, -9223372036854775806.75L, -9223372036854775806LL),
11260 TEST_f_L (llrint, 9223372036854775807.0L, 9223372036854775807LL),
11261 TEST_f_L (llrint, -9223372036854775807.0L, -9223372036854775807LL),
11262 # endif
11263 #endif
11264 END_DATA (llrint_upward)
11265 };
11266
11267 static void
11268 llrint_test_upward (void)
11269 {
11270 START (llrint_upward);
11271 RUN_TEST_LOOP_f_L (llrint, llrint_upward_test_data, FE_UPWARD);
11272 END (llrint_upward);
11273 }
11274
11275
11276 static const struct test_f_f_data log_test_data[] =
11277 {
11278 START_DATA (log),
11279 TEST_f_f (log, 0, minus_infty, DIVIDE_BY_ZERO_EXCEPTION),
11280 TEST_f_f (log, minus_zero, minus_infty, DIVIDE_BY_ZERO_EXCEPTION),
11281
11282 TEST_f_f (log, 1, 0),
11283
11284 TEST_f_f (log, -1, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
11285 TEST_f_f (log, -max_value, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
11286 TEST_f_f (log, minus_infty, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
11287 TEST_f_f (log, plus_infty, plus_infty),
11288 TEST_f_f (log, qnan_value, qnan_value),
11289
11290 TEST_f_f (log, M_El, 1),
11291 TEST_f_f (log, M_1_DIV_El, -1),
11292 TEST_f_f (log, 2, M_LN2l),
11293 TEST_f_f (log, 10, M_LN10l),
11294 TEST_f_f (log, 0.75L, -0.287682072451780927439219005993827432L),
11295 END_DATA (log)
11296 };
11297
11298 static void
11299 log_test (void)
11300 {
11301 errno = 0;
11302 FUNC(log) (1);
11303 if (errno == ENOSYS)
11304 /* Function not implemented. */
11305 return;
11306 START (log);
11307 RUN_TEST_LOOP_f_f (log, log_test_data, );
11308 END (log);
11309 }
11310
11311
11312 static const struct test_f_f_data log10_test_data[] =
11313 {
11314 START_DATA (log10),
11315 TEST_f_f (log10, 0, minus_infty, DIVIDE_BY_ZERO_EXCEPTION),
11316 TEST_f_f (log10, minus_zero, minus_infty, DIVIDE_BY_ZERO_EXCEPTION),
11317
11318 TEST_f_f (log10, 1, 0),
11319
11320 /* log10 (x) == qNaN plus invalid exception if x < 0. */
11321 TEST_f_f (log10, -1, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
11322 TEST_f_f (log10, -max_value, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
11323 TEST_f_f (log10, minus_infty, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
11324
11325 TEST_f_f (log10, plus_infty, plus_infty),
11326 TEST_f_f (log10, qnan_value, qnan_value),
11327
11328 TEST_f_f (log10, 0.1L, -1),
11329 TEST_f_f (log10, 10.0, 1),
11330 TEST_f_f (log10, 100.0, 2),
11331 TEST_f_f (log10, 10000.0, 4),
11332 TEST_f_f (log10, M_El, M_LOG10El),
11333 TEST_f_f (log10, 0.75L, -0.124938736608299953132449886193870744L),
11334 END_DATA (log10)
11335 };
11336
11337 static void
11338 log10_test (void)
11339 {
11340 errno = 0;
11341 FUNC(log10) (1);
11342 if (errno == ENOSYS)
11343 /* Function not implemented. */
11344 return;
11345
11346 START (log10);
11347 RUN_TEST_LOOP_f_f (log10, log10_test_data, );
11348 END (log10);
11349 }
11350
11351
11352 static const struct test_f_f_data log1p_test_data[] =
11353 {
11354 START_DATA (log1p),
11355 TEST_f_f (log1p, 0, 0),
11356 TEST_f_f (log1p, minus_zero, minus_zero),
11357
11358 TEST_f_f (log1p, -1, minus_infty, DIVIDE_BY_ZERO_EXCEPTION),
11359 TEST_f_f (log1p, -2, qnan_value, INVALID_EXCEPTION),
11360 TEST_f_f (log1p, -max_value, qnan_value, INVALID_EXCEPTION),
11361 TEST_f_f (log1p, minus_infty, qnan_value, INVALID_EXCEPTION),
11362
11363 TEST_f_f (log1p, plus_infty, plus_infty),
11364 TEST_f_f (log1p, qnan_value, qnan_value),
11365
11366 TEST_f_f (log1p, M_El - 1.0, 1),
11367
11368 TEST_f_f (log1p, -0.25L, -0.287682072451780927439219005993827432L),
11369 TEST_f_f (log1p, -0.875, -2.07944154167983592825169636437452970L),
11370 END_DATA (log1p)
11371 };
11372
11373 static void
11374 log1p_test (void)
11375 {
11376 errno = 0;
11377 FUNC(log1p) (0);
11378 if (errno == ENOSYS)
11379 /* Function not implemented. */
11380 return;
11381
11382 START (log1p);
11383 RUN_TEST_LOOP_f_f (log1p, log1p_test_data, );
11384 END (log1p);
11385 }
11386
11387
11388 static const struct test_f_f_data log2_test_data[] =
11389 {
11390 START_DATA (log2),
11391 TEST_f_f (log2, 0, minus_infty, DIVIDE_BY_ZERO_EXCEPTION),
11392 TEST_f_f (log2, minus_zero, minus_infty, DIVIDE_BY_ZERO_EXCEPTION),
11393
11394 TEST_f_f (log2, 1, 0),
11395
11396 TEST_f_f (log2, -1, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
11397 TEST_f_f (log2, -max_value, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
11398 TEST_f_f (log2, minus_infty, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
11399
11400 TEST_f_f (log2, plus_infty, plus_infty),
11401 TEST_f_f (log2, qnan_value, qnan_value),
11402
11403 TEST_f_f (log2, M_El, M_LOG2El),
11404 TEST_f_f (log2, 2.0, 1),
11405 TEST_f_f (log2, 16.0, 4),
11406 TEST_f_f (log2, 256.0, 8),
11407 TEST_f_f (log2, 0.75L, -.415037499278843818546261056052183492L),
11408 END_DATA (log2)
11409 };
11410
11411 static void
11412 log2_test (void)
11413 {
11414 errno = 0;
11415 FUNC(log2) (1);
11416 if (errno == ENOSYS)
11417 /* Function not implemented. */
11418 return;
11419
11420 START (log2);
11421 RUN_TEST_LOOP_f_f (log2, log2_test_data, );
11422 END (log2);
11423 }
11424
11425
11426 static const struct test_f_f_data logb_test_data[] =
11427 {
11428 START_DATA (logb),
11429 TEST_f_f (logb, plus_infty, plus_infty),
11430 TEST_f_f (logb, minus_infty, plus_infty),
11431
11432 TEST_f_f (logb, 0, minus_infty, DIVIDE_BY_ZERO_EXCEPTION),
11433
11434 TEST_f_f (logb, minus_zero, minus_infty, DIVIDE_BY_ZERO_EXCEPTION),
11435 TEST_f_f (logb, qnan_value, qnan_value),
11436
11437 TEST_f_f (logb, 1, 0),
11438 TEST_f_f (logb, M_El, 1),
11439 TEST_f_f (logb, 1024, 10),
11440 TEST_f_f (logb, -2000, 10),
11441
11442 TEST_f_f (logb, 0x0.1p-127, -131),
11443 TEST_f_f (logb, 0x0.01p-127, -135),
11444 TEST_f_f (logb, 0x0.011p-127, -135),
11445 #ifndef TEST_FLOAT
11446 TEST_f_f (logb, 0x0.8p-1022, -1023),
11447 TEST_f_f (logb, 0x0.1p-1022, -1026),
11448 TEST_f_f (logb, 0x0.00111p-1022, -1034),
11449 TEST_f_f (logb, 0x0.00001p-1022, -1042),
11450 TEST_f_f (logb, 0x0.000011p-1022, -1042),
11451 TEST_f_f (logb, 0x0.0000000000001p-1022, -1074),
11452 #endif
11453 #if defined TEST_LDOUBLE && LDBL_MIN_EXP - LDBL_MANT_DIG <= -16400
11454 TEST_f_f (logb, 0x1p-16400L, -16400),
11455 TEST_f_f (logb, 0x.00000000001p-16382L, -16426),
11456 #endif
11457 END_DATA (logb)
11458 };
11459
11460 static void
11461 logb_test (void)
11462 {
11463 START (logb);
11464 RUN_TEST_LOOP_f_f (logb, logb_test_data, );
11465 END (logb);
11466 }
11467
11468 static const struct test_f_f_data logb_downward_test_data[] =
11469 {
11470 START_DATA (logb_downward),
11471 /* IEEE 754-2008 says (section 5.3.3) that "logB(1) is +0.". Libm
11472 should not return -0 from logb in any rounding mode. PowerPC32 has
11473 failed with this test for power4 logb (and logbl on all PowerPC
11474 platforms) in the past due to instruction selection. GCC PR 52775
11475 provides the availability of the fcfid insn in 32-bit mode which
11476 eliminates the use of fsub in this instance and prevents the negative
11477 signed 0.0. */
11478
11479 /* BZ #887 */
11480 TEST_f_f (logb, 1.000e+0, plus_zero),
11481 END_DATA (logb_downward)
11482 };
11483
11484 static void
11485 logb_test_downward (void)
11486 {
11487 errno = 0;
11488
11489 FUNC(logb) (0);
11490 if (errno == ENOSYS)
11491 /* Function not implemented. */
11492 return;
11493
11494 START (logb_downward);
11495 RUN_TEST_LOOP_f_f (logb, logb_downward_test_data, FE_DOWNWARD);
11496 END (logb_downward);
11497 }
11498
11499 static const struct test_f_l_data lround_test_data[] =
11500 {
11501 START_DATA (lround),
11502 /* TODO: missing +/-Inf as well as qNaN tests. */
11503 TEST_f_l (lround, 0, 0),
11504 TEST_f_l (lround, minus_zero, 0),
11505 TEST_f_l (lround, 0.2L, 0.0),
11506 TEST_f_l (lround, -0.2L, 0),
11507 TEST_f_l (lround, 0.5, 1),
11508 TEST_f_l (lround, -0.5, -1),
11509 TEST_f_l (lround, 0.8L, 1),
11510 TEST_f_l (lround, -0.8L, -1),
11511 TEST_f_l (lround, 1.5, 2),
11512 TEST_f_l (lround, -1.5, -2),
11513 TEST_f_l (lround, 22514.5, 22515),
11514 TEST_f_l (lround, -22514.5, -22515),
11515 TEST_f_l (lround, 1071930.0008, 1071930),
11516 #ifndef TEST_FLOAT
11517 TEST_f_l (lround, 1073741824.01, 1073741824),
11518 # if LONG_MAX > 281474976710656
11519 TEST_f_l (lround, 281474976710656.025, 281474976710656),
11520 TEST_f_l (lround, 18014398509481974, 18014398509481974),
11521 # endif
11522 TEST_f_l (lround, 2097152.5, 2097153),
11523 TEST_f_l (lround, -2097152.5, -2097153),
11524 /* nextafter(0.5,-1) */
11525 TEST_f_l (lround, 0x1.fffffffffffffp-2, 0),
11526 /* nextafter(-0.5,1) */
11527 TEST_f_l (lround, -0x1.fffffffffffffp-2, 0),
11528 #else
11529 /* nextafter(0.5,-1) */
11530 TEST_f_l (lround, 0x1.fffffp-2, 0),
11531 /* nextafter(-0.5,1) */
11532 TEST_f_l (lround, -0x1.fffffp-2, 0),
11533 TEST_f_l (lround, 0x1.fffffep+23, 16777215),
11534 TEST_f_l (lround, -0x1.fffffep+23, -16777215),
11535 #endif
11536 END_DATA (lround)
11537 };
11538
11539 static void
11540 lround_test (void)
11541 {
11542 START (lround);
11543 RUN_TEST_LOOP_f_l (lround, lround_test_data, );
11544 END (lround);
11545 }
11546
11547
11548 static const struct test_f_L_data llround_test_data[] =
11549 {
11550 START_DATA (llround),
11551 /* TODO: missing +/-Inf as well as qNaN tests. */
11552 TEST_f_L (llround, 0, 0),
11553 TEST_f_L (llround, minus_zero, 0),
11554 TEST_f_L (llround, 0.2L, 0.0),
11555 TEST_f_L (llround, -0.2L, 0),
11556 TEST_f_L (llround, 0.5, 1),
11557 TEST_f_L (llround, -0.5, -1),
11558 TEST_f_L (llround, 0.8L, 1),
11559 TEST_f_L (llround, -0.8L, -1),
11560 TEST_f_L (llround, 1.5, 2),
11561 TEST_f_L (llround, -1.5, -2),
11562 TEST_f_L (llround, 22514.5, 22515),
11563 TEST_f_L (llround, -22514.5, -22515),
11564 TEST_f_L (llround, 1071930.0008, 1071930),
11565 #ifndef TEST_FLOAT
11566 TEST_f_L (llround, 2097152.5, 2097153),
11567 TEST_f_L (llround, -2097152.5, -2097153),
11568 TEST_f_L (llround, 34359738368.5, 34359738369ll),
11569 TEST_f_L (llround, -34359738368.5, -34359738369ll),
11570 TEST_f_L (llround, -3.65309740835E17, -365309740835000000LL),
11571 #endif
11572
11573 /* Test boundary conditions. */
11574 /* 0x1FFFFF */
11575 TEST_f_L (llround, 2097151.0, 2097151LL),
11576 /* 0x800000 */
11577 TEST_f_L (llround, 8388608.0, 8388608LL),
11578 /* 0x1000000 */
11579 TEST_f_L (llround, 16777216.0, 16777216LL),
11580 /* 0x20000000000 */
11581 TEST_f_L (llround, 2199023255552.0, 2199023255552LL),
11582 /* 0x40000000000 */
11583 TEST_f_L (llround, 4398046511104.0, 4398046511104LL),
11584 /* 0x1000000000000 */
11585 TEST_f_L (llround, 281474976710656.0, 281474976710656LL),
11586 /* 0x10000000000000 */
11587 TEST_f_L (llround, 4503599627370496.0, 4503599627370496LL),
11588 /* 0x10000080000000 */
11589 TEST_f_L (llround, 4503601774854144.0, 4503601774854144LL),
11590 /* 0x20000000000000 */
11591 TEST_f_L (llround, 9007199254740992.0, 9007199254740992LL),
11592 /* 0x80000000000000 */
11593 TEST_f_L (llround, 36028797018963968.0, 36028797018963968LL),
11594 /* 0x100000000000000 */
11595 TEST_f_L (llround, 72057594037927936.0, 72057594037927936LL),
11596
11597 #ifndef TEST_FLOAT
11598 /* 0x100000000 */
11599 TEST_f_L (llround, 4294967295.5, 4294967296LL),
11600 /* 0x200000000 */
11601 TEST_f_L (llround, 8589934591.5, 8589934592LL),
11602
11603 /* nextafter(0.5,-1) */
11604 TEST_f_L (llround, 0x1.fffffffffffffp-2, 0),
11605 /* nextafter(-0.5,1) */
11606 TEST_f_L (llround, -0x1.fffffffffffffp-2, 0),
11607 /* On PowerPC an exponent of '52' is the largest incrementally
11608 * representable sequence of whole-numbers in the 'double' range. We test
11609 * lround to make sure that a guard bit set during the lround operation
11610 * hasn't forced an erroneous shift giving us an incorrect result. The odd
11611 * numbers between +-(2^52+1 and 2^53-1) are affected since they have the
11612 * rightmost bit set. */
11613 /* +-(2^52+1) */
11614 TEST_f_L (llround, 0x1.0000000000001p+52,4503599627370497LL),
11615 TEST_f_L (llround, -0x1.0000000000001p+52,-4503599627370497LL),
11616 /* +-(2^53-1): Input is the last (positive and negative) incrementally
11617 * representable whole-number in the 'double' range that might round
11618 * erroneously. */
11619 TEST_f_L (llround, 0x1.fffffffffffffp+52, 9007199254740991LL),
11620 TEST_f_L (llround, -0x1.fffffffffffffp+52, -9007199254740991LL),
11621 #else
11622 /* nextafter(0.5,-1) */
11623 TEST_f_L (llround, 0x1.fffffep-2, 0),
11624 /* nextafter(-0.5,1) */
11625 TEST_f_L (llround, -0x1.fffffep-2, 0),
11626 /* As above, on PowerPC an exponent of '23' is the largest incrementally
11627 * representable sequence of whole-numbers in the 'float' range.
11628 * Likewise, numbers between +-(2^23+1 and 2^24-1) are affected. */
11629 TEST_f_L (llround, 0x1.000002p+23,8388609),
11630 TEST_f_L (llround, -0x1.000002p+23,-8388609),
11631 TEST_f_L (llround, 0x1.fffffep+23, 16777215),
11632 TEST_f_L (llround, -0x1.fffffep+23, -16777215),
11633 #endif
11634
11635
11636 #ifdef TEST_LDOUBLE
11637 /* The input can only be represented in long double. */
11638 TEST_f_L (llround, 4503599627370495.5L, 4503599627370496LL),
11639 TEST_f_L (llround, 4503599627370496.25L, 4503599627370496LL),
11640 TEST_f_L (llround, 4503599627370496.5L, 4503599627370497LL),
11641 TEST_f_L (llround, 4503599627370496.75L, 4503599627370497LL),
11642 TEST_f_L (llround, 4503599627370497.5L, 4503599627370498LL),
11643
11644 # if LDBL_MANT_DIG > 100
11645 TEST_f_L (llround, 4503599627370495.4999999999999L, 4503599627370495LL),
11646 TEST_f_L (llround, 4503599627370496.4999999999999L, 4503599627370496LL),
11647 TEST_f_L (llround, 4503599627370497.4999999999999L, 4503599627370497LL),
11648 TEST_f_L (llround, 4503599627370494.5000000000001L, 4503599627370495LL),
11649 TEST_f_L (llround, 4503599627370495.5000000000001L, 4503599627370496LL),
11650 TEST_f_L (llround, 4503599627370496.5000000000001L, 4503599627370497LL),
11651
11652 TEST_f_L (llround, -4503599627370495.4999999999999L, -4503599627370495LL),
11653 TEST_f_L (llround, -4503599627370496.4999999999999L, -4503599627370496LL),
11654 TEST_f_L (llround, -4503599627370497.4999999999999L, -4503599627370497LL),
11655 TEST_f_L (llround, -4503599627370494.5000000000001L, -4503599627370495LL),
11656 TEST_f_L (llround, -4503599627370495.5000000000001L, -4503599627370496LL),
11657 TEST_f_L (llround, -4503599627370496.5000000000001L, -4503599627370497LL),
11658 # endif
11659
11660 TEST_f_L (llround, -4503599627370495.5L, -4503599627370496LL),
11661 TEST_f_L (llround, -4503599627370496.25L, -4503599627370496LL),
11662 TEST_f_L (llround, -4503599627370496.5L, -4503599627370497LL),
11663 TEST_f_L (llround, -4503599627370496.75L, -4503599627370497LL),
11664 TEST_f_L (llround, -4503599627370497.5L, -4503599627370498LL),
11665
11666 TEST_f_L (llround, 9007199254740991.5L, 9007199254740992LL),
11667 TEST_f_L (llround, 9007199254740992.25L, 9007199254740992LL),
11668 TEST_f_L (llround, 9007199254740992.5L, 9007199254740993LL),
11669 TEST_f_L (llround, 9007199254740992.75L, 9007199254740993LL),
11670 TEST_f_L (llround, 9007199254740993.5L, 9007199254740994LL),
11671
11672 # if LDBL_MANT_DIG > 100
11673 TEST_f_L (llround, 9007199254740991.4999999999999L, 9007199254740991LL),
11674 TEST_f_L (llround, 9007199254740992.4999999999999L, 9007199254740992LL),
11675 TEST_f_L (llround, 9007199254740993.4999999999999L, 9007199254740993LL),
11676 TEST_f_L (llround, 9007199254740991.5000000000001L, 9007199254740992LL),
11677 TEST_f_L (llround, 9007199254740992.5000000000001L, 9007199254740993LL),
11678 TEST_f_L (llround, 9007199254740993.5000000000001L, 9007199254740994LL),
11679
11680 TEST_f_L (llround, -9007199254740991.4999999999999L, -9007199254740991LL),
11681 TEST_f_L (llround, -9007199254740992.4999999999999L, -9007199254740992LL),
11682 TEST_f_L (llround, -9007199254740993.4999999999999L, -9007199254740993LL),
11683 TEST_f_L (llround, -9007199254740991.5000000000001L, -9007199254740992LL),
11684 TEST_f_L (llround, -9007199254740992.5000000000001L, -9007199254740993LL),
11685 TEST_f_L (llround, -9007199254740993.5000000000001L, -9007199254740994LL),
11686 # endif
11687
11688 TEST_f_L (llround, -9007199254740991.5L, -9007199254740992LL),
11689 TEST_f_L (llround, -9007199254740992.25L, -9007199254740992LL),
11690 TEST_f_L (llround, -9007199254740992.5L, -9007199254740993LL),
11691 TEST_f_L (llround, -9007199254740992.75L, -9007199254740993LL),
11692 TEST_f_L (llround, -9007199254740993.5L, -9007199254740994LL),
11693
11694 TEST_f_L (llround, 72057594037927935.5L, 72057594037927936LL),
11695 TEST_f_L (llround, 72057594037927936.25L, 72057594037927936LL),
11696 TEST_f_L (llround, 72057594037927936.5L, 72057594037927937LL),
11697 TEST_f_L (llround, 72057594037927936.75L, 72057594037927937LL),
11698 TEST_f_L (llround, 72057594037927937.5L, 72057594037927938LL),
11699
11700 TEST_f_L (llround, -72057594037927935.5L, -72057594037927936LL),
11701 TEST_f_L (llround, -72057594037927936.25L, -72057594037927936LL),
11702 TEST_f_L (llround, -72057594037927936.5L, -72057594037927937LL),
11703 TEST_f_L (llround, -72057594037927936.75L, -72057594037927937LL),
11704 TEST_f_L (llround, -72057594037927937.5L, -72057594037927938LL),
11705
11706 TEST_f_L (llround, 9223372036854775806.25L, 9223372036854775806LL),
11707 TEST_f_L (llround, -9223372036854775806.25L, -9223372036854775806LL),
11708 TEST_f_L (llround, 9223372036854775806.5L, 9223372036854775807LL),
11709 TEST_f_L (llround, -9223372036854775806.5L, -9223372036854775807LL),
11710 TEST_f_L (llround, 9223372036854775807.0L, 9223372036854775807LL),
11711 TEST_f_L (llround, -9223372036854775807.0L, -9223372036854775807LL),
11712 #endif
11713 END_DATA (llround)
11714 };
11715
11716 static void
11717 llround_test (void)
11718 {
11719 START (llround);
11720 RUN_TEST_LOOP_f_L (llround, llround_test_data, );
11721 END (llround);
11722 }
11723
11724 static const struct test_fF_f1_data modf_test_data[] =
11725 {
11726 START_DATA (modf),
11727 TEST_fF_f1 (modf, plus_infty, 0, plus_infty),
11728 TEST_fF_f1 (modf, minus_infty, minus_zero, minus_infty),
11729 TEST_fF_f1 (modf, qnan_value, qnan_value, qnan_value),
11730 TEST_fF_f1 (modf, 0, 0, 0),
11731 TEST_fF_f1 (modf, 1.5, 0.5, 1),
11732 TEST_fF_f1 (modf, 2.5, 0.5, 2),
11733 TEST_fF_f1 (modf, -2.5, -0.5, -2),
11734 TEST_fF_f1 (modf, 20, 0, 20),
11735 TEST_fF_f1 (modf, 21, 0, 21),
11736 TEST_fF_f1 (modf, 89.5, 0.5, 89),
11737 END_DATA (modf)
11738 };
11739
11740 static void
11741 modf_test (void)
11742 {
11743 FLOAT x;
11744
11745 START (modf);
11746 RUN_TEST_LOOP_fF_f1 (modf, modf_test_data, , x);
11747 END (modf);
11748 }
11749
11750
11751 static const struct test_f_f_data nearbyint_test_data[] =
11752 {
11753 START_DATA (nearbyint),
11754
11755 TEST_f_f (nearbyint, 0.0, 0.0, NO_INEXACT_EXCEPTION),
11756 TEST_f_f (nearbyint, minus_zero, minus_zero, NO_INEXACT_EXCEPTION),
11757 TEST_f_f (nearbyint, plus_infty, plus_infty, NO_INEXACT_EXCEPTION),
11758 TEST_f_f (nearbyint, minus_infty, minus_infty, NO_INEXACT_EXCEPTION),
11759 TEST_f_f (nearbyint, qnan_value, qnan_value, NO_INEXACT_EXCEPTION),
11760
11761 /* Subnormal values */
11762 TEST_f_f (nearbyint, -8.98847e+307, -8.98847e+307, NO_INEXACT_EXCEPTION),
11763 TEST_f_f (nearbyint, -4.45015e-308, minus_zero, NO_INEXACT_EXCEPTION),
11764
11765 /* Default rounding mode is round to nearest. */
11766 TEST_f_f (nearbyint, 0.5, 0.0, NO_INEXACT_EXCEPTION),
11767 TEST_f_f (nearbyint, 1.5, 2.0, NO_INEXACT_EXCEPTION),
11768 TEST_f_f (nearbyint, -0.5, minus_zero, NO_INEXACT_EXCEPTION),
11769 TEST_f_f (nearbyint, -1.5, -2.0, NO_INEXACT_EXCEPTION),
11770
11771 TEST_f_f (nearbyint, 262144.75, 262145.0, NO_INEXACT_EXCEPTION),
11772 TEST_f_f (nearbyint, 262142.75, 262143.0, NO_INEXACT_EXCEPTION),
11773 TEST_f_f (nearbyint, 524286.75, 524287.0, NO_INEXACT_EXCEPTION),
11774 TEST_f_f (nearbyint, 524288.75, 524289.0, NO_INEXACT_EXCEPTION),
11775
11776 TEST_f_f (nearbyint, 1048576.75, 1048577.0, NO_INEXACT_EXCEPTION),
11777 TEST_f_f (nearbyint, 2097152.75, 2097153.0, NO_INEXACT_EXCEPTION),
11778 TEST_f_f (nearbyint, 2492472.75, 2492473.0, NO_INEXACT_EXCEPTION),
11779 TEST_f_f (nearbyint, 2886220.75, 2886221.0, NO_INEXACT_EXCEPTION),
11780 TEST_f_f (nearbyint, 3058792.75, 3058793.0, NO_INEXACT_EXCEPTION),
11781 TEST_f_f (nearbyint, -1048576.75, -1048577.0, NO_INEXACT_EXCEPTION),
11782 TEST_f_f (nearbyint, -2097152.75, -2097153.0, NO_INEXACT_EXCEPTION),
11783 TEST_f_f (nearbyint, -2492472.75, -2492473.0, NO_INEXACT_EXCEPTION),
11784 TEST_f_f (nearbyint, -2886220.75, -2886221.0, NO_INEXACT_EXCEPTION),
11785 TEST_f_f (nearbyint, -3058792.75, -3058793.0, NO_INEXACT_EXCEPTION),
11786 #ifndef TEST_FLOAT
11787 TEST_f_f (nearbyint, 70368744177664.75, 70368744177665.0, NO_INEXACT_EXCEPTION),
11788 TEST_f_f (nearbyint, 140737488355328.75, 140737488355329.0, NO_INEXACT_EXCEPTION),
11789 TEST_f_f (nearbyint, 281474976710656.75, 281474976710657.0, NO_INEXACT_EXCEPTION),
11790 TEST_f_f (nearbyint, 562949953421312.75, 562949953421313.0, NO_INEXACT_EXCEPTION),
11791 TEST_f_f (nearbyint, 1125899906842624.75, 1125899906842625.0, NO_INEXACT_EXCEPTION),
11792 TEST_f_f (nearbyint, -70368744177664.75, -70368744177665.0, NO_INEXACT_EXCEPTION),
11793 TEST_f_f (nearbyint, -140737488355328.75, -140737488355329.0, NO_INEXACT_EXCEPTION),
11794 TEST_f_f (nearbyint, -281474976710656.75, -281474976710657.0, NO_INEXACT_EXCEPTION),
11795 TEST_f_f (nearbyint, -562949953421312.75, -562949953421313.0, NO_INEXACT_EXCEPTION),
11796 TEST_f_f (nearbyint, -1125899906842624.75, -1125899906842625.0, NO_INEXACT_EXCEPTION),
11797 #endif
11798
11799 END_DATA (nearbyint)
11800 };
11801
11802 static void
11803 nearbyint_test (void)
11804 {
11805 START (nearbyint);
11806 RUN_TEST_LOOP_f_f (nearbyint, nearbyint_test_data, );
11807 END (nearbyint);
11808 }
11809
11810 static const struct test_ff_f_data nextafter_test_data[] =
11811 {
11812 START_DATA (nextafter),
11813
11814 TEST_ff_f (nextafter, 0, 0, 0),
11815 TEST_ff_f (nextafter, minus_zero, 0, 0),
11816 TEST_ff_f (nextafter, 0, minus_zero, minus_zero),
11817 TEST_ff_f (nextafter, minus_zero, minus_zero, minus_zero),
11818
11819 TEST_ff_f (nextafter, 9, 9, 9),
11820 TEST_ff_f (nextafter, -9, -9, -9),
11821 TEST_ff_f (nextafter, plus_infty, plus_infty, plus_infty),
11822 TEST_ff_f (nextafter, minus_infty, minus_infty, minus_infty),
11823
11824 TEST_ff_f (nextafter, qnan_value, 1.1L, qnan_value),
11825 TEST_ff_f (nextafter, 1.1L, qnan_value, qnan_value),
11826 TEST_ff_f (nextafter, qnan_value, qnan_value, qnan_value),
11827
11828 TEST_ff_f (nextafter, max_value, plus_infty, plus_infty, OVERFLOW_EXCEPTION),
11829 TEST_ff_f (nextafter, -max_value, minus_infty, minus_infty, OVERFLOW_EXCEPTION),
11830
11831 #ifdef TEST_LDOUBLE
11832 // XXX Enable once gcc is fixed.
11833 //TEST_ff_f (nextafter, 0x0.00000040000000000000p-16385L, -0.1L, 0x0.0000003ffffffff00000p-16385L),
11834 #endif
11835
11836 /* XXX We need the hexadecimal FP number representation here for further
11837 tests. */
11838 END_DATA (nextafter)
11839 };
11840
11841 static void
11842 nextafter_test (void)
11843 {
11844
11845 START (nextafter);
11846 RUN_TEST_LOOP_ff_f (nextafter, nextafter_test_data, );
11847 END (nextafter);
11848 }
11849
11850
11851 static const struct test_ff_f_data_nexttoward nexttoward_test_data[] =
11852 {
11853 START_DATA (nexttoward),
11854 TEST_ff_f (nexttoward, 0, 0, 0),
11855 TEST_ff_f (nexttoward, minus_zero, 0, 0),
11856 TEST_ff_f (nexttoward, 0, minus_zero, minus_zero),
11857 TEST_ff_f (nexttoward, minus_zero, minus_zero, minus_zero),
11858
11859 TEST_ff_f (nexttoward, 9, 9, 9),
11860 TEST_ff_f (nexttoward, -9, -9, -9),
11861 TEST_ff_f (nexttoward, plus_infty, plus_infty, plus_infty),
11862 TEST_ff_f (nexttoward, minus_infty, minus_infty, minus_infty),
11863
11864 TEST_ff_f (nexttoward, qnan_value, 1.1L, qnan_value),
11865 TEST_ff_f (nexttoward, 1.1L, qnan_value, qnan_value),
11866 TEST_ff_f (nexttoward, qnan_value, qnan_value, qnan_value),
11867
11868 #ifdef TEST_FLOAT
11869 TEST_ff_f (nexttoward, 1.0, 1.1L, 0x1.000002p0),
11870 TEST_ff_f (nexttoward, 1.0, LDBL_MAX, 0x1.000002p0),
11871 TEST_ff_f (nexttoward, 1.0, 0x1.0000000000001p0, 0x1.000002p0),
11872 TEST_ff_f (nexttoward, 1.0, 0.9L, 0x0.ffffffp0),
11873 TEST_ff_f (nexttoward, 1.0, -LDBL_MAX, 0x0.ffffffp0),
11874 TEST_ff_f (nexttoward, 1.0, 0x0.fffffffffffff8p0, 0x0.ffffffp0),
11875 TEST_ff_f (nexttoward, -1.0, -1.1L, -0x1.000002p0),
11876 TEST_ff_f (nexttoward, -1.0, -LDBL_MAX, -0x1.000002p0),
11877 TEST_ff_f (nexttoward, -1.0, -0x1.0000000000001p0, -0x1.000002p0),
11878 TEST_ff_f (nexttoward, -1.0, -0.9L, -0x0.ffffffp0),
11879 TEST_ff_f (nexttoward, -1.0, LDBL_MAX, -0x0.ffffffp0),
11880 TEST_ff_f (nexttoward, -1.0, -0x0.fffffffffffff8p0, -0x0.ffffffp0),
11881 TEST_ff_f (nexttoward, -0x1.3p-145, -0xap-148L, -0x1.4p-145, UNDERFLOW_EXCEPTION),
11882 # if LDBL_MANT_DIG >= 64
11883 TEST_ff_f (nexttoward, 1.0, 0x1.000000000000002p0L, 0x1.000002p0),
11884 TEST_ff_f (nexttoward, 1.0, 0x0.ffffffffffffffffp0L, 0x0.ffffffp0),
11885 TEST_ff_f (nexttoward, -1.0, -0x1.000000000000002p0L, -0x1.000002p0),
11886 TEST_ff_f (nexttoward, -1.0, -0x0.ffffffffffffffffp0L, -0x0.ffffffp0),
11887 # endif
11888 # if LDBL_MANT_DIG >= 106
11889 TEST_ff_f (nexttoward, 1.0, 0x1.000000000000000000000000008p0L, 0x1.000002p0),
11890 TEST_ff_f (nexttoward, 1.0, 0x0.ffffffffffffffffffffffffffcp0L, 0x0.ffffffp0),
11891 TEST_ff_f (nexttoward, -1.0, -0x1.000000000000000000000000008p0L, -0x1.000002p0),
11892 TEST_ff_f (nexttoward, -1.0, -0x0.ffffffffffffffffffffffffffcp0L, -0x0.ffffffp0),
11893 # endif
11894 # if LDBL_MANT_DIG >= 113
11895 TEST_ff_f (nexttoward, 1.0, 0x1.0000000000000000000000000001p0L, 0x1.000002p0),
11896 TEST_ff_f (nexttoward, 1.0, 0x0.ffffffffffffffffffffffffffff8p0L, 0x0.ffffffp0),
11897 TEST_ff_f (nexttoward, -1.0, -0x1.0000000000000000000000000001p0L, -0x1.000002p0),
11898 TEST_ff_f (nexttoward, -1.0, -0x0.ffffffffffffffffffffffffffff8p0L, -0x0.ffffffp0),
11899 # endif
11900 #endif
11901 #ifdef TEST_DOUBLE
11902 TEST_ff_f (nexttoward, 1.0, 1.1L, 0x1.0000000000001p0),
11903 TEST_ff_f (nexttoward, 1.0, LDBL_MAX, 0x1.0000000000001p0),
11904 TEST_ff_f (nexttoward, 1.0, 0x1.0000000000001p0, 0x1.0000000000001p0),
11905 TEST_ff_f (nexttoward, 1.0, 0.9L, 0x0.fffffffffffff8p0),
11906 TEST_ff_f (nexttoward, 1.0, -LDBL_MAX, 0x0.fffffffffffff8p0),
11907 TEST_ff_f (nexttoward, 1.0, 0x0.fffffffffffff8p0, 0x0.fffffffffffff8p0),
11908 TEST_ff_f (nexttoward, -1.0, -1.1L, -0x1.0000000000001p0),
11909 TEST_ff_f (nexttoward, -1.0, -LDBL_MAX, -0x1.0000000000001p0),
11910 TEST_ff_f (nexttoward, -1.0, -0x1.0000000000001p0, -0x1.0000000000001p0),
11911 TEST_ff_f (nexttoward, -1.0, -0.9L, -0x0.fffffffffffff8p0),
11912 TEST_ff_f (nexttoward, -1.0, LDBL_MAX, -0x0.fffffffffffff8p0),
11913 TEST_ff_f (nexttoward, -1.0, -0x0.fffffffffffff8p0, -0x0.fffffffffffff8p0),
11914 TEST_ff_f (nexttoward, -1.0, -0x8.00346dc5d6388p-3L, -0x1.0000000000001p0),
11915 TEST_ff_f (nexttoward, 0x1p-1074, 0x1p-1073L, 0x1p-1073, UNDERFLOW_EXCEPTION),
11916 # if LDBL_MANT_DIG >= 64
11917 TEST_ff_f (nexttoward, 1.0, 0x1.000000000000002p0L, 0x1.0000000000001p0),
11918 TEST_ff_f (nexttoward, 1.0, 0x0.ffffffffffffffffp0L, 0x0.fffffffffffff8p0),
11919 TEST_ff_f (nexttoward, -1.0, -0x1.000000000000002p0L, -0x1.0000000000001p0),
11920 TEST_ff_f (nexttoward, -1.0, -0x0.ffffffffffffffffp0L, -0x0.fffffffffffff8p0),
11921 # endif
11922 # if LDBL_MANT_DIG >= 106
11923 TEST_ff_f (nexttoward, 1.0, 0x1.000000000000000000000000008p0L, 0x1.0000000000001p0),
11924 TEST_ff_f (nexttoward, 1.0, 0x0.ffffffffffffffffffffffffffcp0L, 0x0.fffffffffffff8p0),
11925 TEST_ff_f (nexttoward, -1.0, -0x1.000000000000000000000000008p0L, -0x1.0000000000001p0),
11926 TEST_ff_f (nexttoward, -1.0, -0x0.ffffffffffffffffffffffffffcp0L, -0x0.fffffffffffff8p0),
11927 # endif
11928 # if LDBL_MANT_DIG >= 113
11929 TEST_ff_f (nexttoward, 1.0, 0x1.0000000000000000000000000001p0L, 0x1.0000000000001p0),
11930 TEST_ff_f (nexttoward, 1.0, 0x0.ffffffffffffffffffffffffffff8p0L, 0x0.fffffffffffff8p0),
11931 TEST_ff_f (nexttoward, -1.0, -0x1.0000000000000000000000000001p0L, -0x1.0000000000001p0),
11932 TEST_ff_f (nexttoward, -1.0, -0x0.ffffffffffffffffffffffffffff8p0L, -0x0.fffffffffffff8p0),
11933 # endif
11934 #endif
11935 END_DATA (nexttoward)
11936 };
11937
11938 static void
11939 nexttoward_test (void)
11940 {
11941 START (nexttoward);
11942 RUN_TEST_LOOP_ff_f (nexttoward, nexttoward_test_data, );
11943 END (nexttoward);
11944 }
11945
11946
11947 static const struct test_ff_f_data pow_test_data[] =
11948 {
11949 START_DATA (pow),
11950 TEST_ff_f (pow, 0, 0, 1),
11951 TEST_ff_f (pow, 0, minus_zero, 1),
11952 TEST_ff_f (pow, minus_zero, 0, 1),
11953 TEST_ff_f (pow, minus_zero, minus_zero, 1),
11954
11955 TEST_ff_f (pow, 10, 0, 1),
11956 TEST_ff_f (pow, 10, minus_zero, 1),
11957 TEST_ff_f (pow, -10, 0, 1),
11958 TEST_ff_f (pow, -10, minus_zero, 1),
11959
11960 TEST_ff_f (pow, qnan_value, 0, 1),
11961 TEST_ff_f (pow, qnan_value, minus_zero, 1),
11962
11963 #ifndef TEST_INLINE
11964 TEST_ff_f (pow, 1.1L, plus_infty, plus_infty),
11965 TEST_ff_f (pow, plus_infty, plus_infty, plus_infty),
11966 TEST_ff_f (pow, -1.1L, plus_infty, plus_infty),
11967 TEST_ff_f (pow, minus_infty, plus_infty, plus_infty),
11968
11969 TEST_ff_f (pow, 0.9L, plus_infty, 0),
11970 TEST_ff_f (pow, 1e-7L, plus_infty, 0),
11971 TEST_ff_f (pow, -0.9L, plus_infty, 0),
11972 TEST_ff_f (pow, -1e-7L, plus_infty, 0),
11973
11974 TEST_ff_f (pow, 1.1L, minus_infty, 0),
11975 TEST_ff_f (pow, plus_infty, minus_infty, 0),
11976 TEST_ff_f (pow, -1.1L, minus_infty, 0),
11977 TEST_ff_f (pow, minus_infty, minus_infty, 0),
11978
11979 TEST_ff_f (pow, 0.9L, minus_infty, plus_infty),
11980 TEST_ff_f (pow, 1e-7L, minus_infty, plus_infty),
11981 TEST_ff_f (pow, -0.9L, minus_infty, plus_infty),
11982 TEST_ff_f (pow, -1e-7L, minus_infty, plus_infty),
11983
11984 TEST_ff_f (pow, plus_infty, 1e-7L, plus_infty),
11985 TEST_ff_f (pow, plus_infty, 1, plus_infty),
11986 TEST_ff_f (pow, plus_infty, 1e7L, plus_infty),
11987 TEST_ff_f (pow, plus_infty, min_subnorm_value, plus_infty),
11988
11989 TEST_ff_f (pow, plus_infty, -1e-7L, 0),
11990 TEST_ff_f (pow, plus_infty, -1, 0),
11991 TEST_ff_f (pow, plus_infty, -1e7L, 0),
11992 TEST_ff_f (pow, plus_infty, -min_subnorm_value, 0),
11993
11994 TEST_ff_f (pow, minus_infty, 1, minus_infty),
11995 TEST_ff_f (pow, minus_infty, 11, minus_infty),
11996 TEST_ff_f (pow, minus_infty, 1001, minus_infty),
11997
11998 TEST_ff_f (pow, minus_infty, 2, plus_infty),
11999 TEST_ff_f (pow, minus_infty, 12, plus_infty),
12000 TEST_ff_f (pow, minus_infty, 1002, plus_infty),
12001 TEST_ff_f (pow, minus_infty, 0.1L, plus_infty),
12002 TEST_ff_f (pow, minus_infty, 1.1L, plus_infty),
12003 TEST_ff_f (pow, minus_infty, 11.1L, plus_infty),
12004 TEST_ff_f (pow, minus_infty, 1001.1L, plus_infty),
12005 TEST_ff_f (pow, minus_infty, min_subnorm_value, plus_infty),
12006
12007 TEST_ff_f (pow, minus_infty, -1, minus_zero),
12008 TEST_ff_f (pow, minus_infty, -11, minus_zero),
12009 TEST_ff_f (pow, minus_infty, -1001, minus_zero),
12010
12011 TEST_ff_f (pow, minus_infty, -2, 0),
12012 TEST_ff_f (pow, minus_infty, -12, 0),
12013 TEST_ff_f (pow, minus_infty, -1002, 0),
12014 TEST_ff_f (pow, minus_infty, -0.1L, 0),
12015 TEST_ff_f (pow, minus_infty, -1.1L, 0),
12016 TEST_ff_f (pow, minus_infty, -11.1L, 0),
12017 TEST_ff_f (pow, minus_infty, -1001.1L, 0),
12018 TEST_ff_f (pow, minus_infty, -min_subnorm_value, 0),
12019 #endif
12020
12021 TEST_ff_f (pow, qnan_value, qnan_value, qnan_value),
12022 TEST_ff_f (pow, 0, qnan_value, qnan_value),
12023 TEST_ff_f (pow, 1, qnan_value, 1),
12024 TEST_ff_f (pow, -1, qnan_value, qnan_value),
12025 TEST_ff_f (pow, qnan_value, 1, qnan_value),
12026 TEST_ff_f (pow, qnan_value, -1, qnan_value),
12027
12028 /* pow (x, qNaN) == qNaN. */
12029 TEST_ff_f (pow, 3.0, qnan_value, qnan_value),
12030 TEST_ff_f (pow, minus_zero, qnan_value, qnan_value),
12031 TEST_ff_f (pow, plus_infty, qnan_value, qnan_value),
12032 TEST_ff_f (pow, -3.0, qnan_value, qnan_value),
12033 TEST_ff_f (pow, minus_infty, qnan_value, qnan_value),
12034
12035 TEST_ff_f (pow, qnan_value, 3.0, qnan_value),
12036 TEST_ff_f (pow, qnan_value, -3.0, qnan_value),
12037 TEST_ff_f (pow, qnan_value, plus_infty, qnan_value),
12038 TEST_ff_f (pow, qnan_value, minus_infty, qnan_value),
12039 TEST_ff_f (pow, qnan_value, 2.5, qnan_value),
12040 TEST_ff_f (pow, qnan_value, -2.5, qnan_value),
12041 TEST_ff_f (pow, qnan_value, min_subnorm_value, qnan_value),
12042 TEST_ff_f (pow, qnan_value, -min_subnorm_value, qnan_value),
12043
12044 TEST_ff_f (pow, 1, plus_infty, 1),
12045 TEST_ff_f (pow, -1, plus_infty, 1),
12046 TEST_ff_f (pow, 1, minus_infty, 1),
12047 TEST_ff_f (pow, -1, minus_infty, 1),
12048 TEST_ff_f (pow, 1, 1, 1),
12049 TEST_ff_f (pow, 1, -1, 1),
12050 TEST_ff_f (pow, 1, 1.25, 1),
12051 TEST_ff_f (pow, 1, -1.25, 1),
12052 TEST_ff_f (pow, 1, 0x1p62L, 1),
12053 TEST_ff_f (pow, 1, 0x1p63L, 1),
12054 TEST_ff_f (pow, 1, 0x1p64L, 1),
12055 TEST_ff_f (pow, 1, 0x1p72L, 1),
12056 TEST_ff_f (pow, 1, min_subnorm_value, 1),
12057 TEST_ff_f (pow, 1, -min_subnorm_value, 1),
12058
12059 /* pow (x, +-0) == 1. */
12060 TEST_ff_f (pow, plus_infty, 0, 1),
12061 TEST_ff_f (pow, plus_infty, minus_zero, 1),
12062 TEST_ff_f (pow, minus_infty, 0, 1),
12063 TEST_ff_f (pow, minus_infty, minus_zero, 1),
12064 TEST_ff_f (pow, 32.75L, 0, 1),
12065 TEST_ff_f (pow, 32.75L, minus_zero, 1),
12066 TEST_ff_f (pow, -32.75L, 0, 1),
12067 TEST_ff_f (pow, -32.75L, minus_zero, 1),
12068 TEST_ff_f (pow, 0x1p72L, 0, 1),
12069 TEST_ff_f (pow, 0x1p72L, minus_zero, 1),
12070 TEST_ff_f (pow, 0x1p-72L, 0, 1),
12071 TEST_ff_f (pow, 0x1p-72L, minus_zero, 1),
12072
12073 TEST_ff_f (pow, -0.1L, 1.1L, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
12074 TEST_ff_f (pow, -0.1L, -1.1L, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
12075 TEST_ff_f (pow, -10.1L, 1.1L, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
12076 TEST_ff_f (pow, -10.1L, -1.1L, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
12077 TEST_ff_f (pow, -1.01L, min_subnorm_value, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
12078 TEST_ff_f (pow, -1.01L, -min_subnorm_value, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
12079 TEST_ff_f (pow, -1.0L, min_subnorm_value, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
12080 TEST_ff_f (pow, -1.0L, -min_subnorm_value, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
12081
12082 TEST_ff_f (pow, 0, -1, plus_infty, DIVIDE_BY_ZERO_EXCEPTION|ERRNO_ERANGE),
12083 TEST_ff_f (pow, 0, -11, plus_infty, DIVIDE_BY_ZERO_EXCEPTION|ERRNO_ERANGE),
12084 TEST_ff_f (pow, 0, -0xffffff, plus_infty, DIVIDE_BY_ZERO_EXCEPTION|ERRNO_ERANGE),
12085 #ifndef TEST_FLOAT
12086 TEST_ff_f (pow, 0, -0x1.fffffffffffffp+52L, plus_infty, DIVIDE_BY_ZERO_EXCEPTION|ERRNO_ERANGE),
12087 #endif
12088 #ifdef TEST_LDOUBLE
12089 # if LDBL_MANT_DIG >= 64
12090 TEST_ff_f (pow, 0, -0x1.fffffffffffffffep+63L, plus_infty, DIVIDE_BY_ZERO_EXCEPTION|ERRNO_ERANGE),
12091 # endif
12092 # if LDBL_MANT_DIG >= 106
12093 TEST_ff_f (pow, 0, -0x1.ffffffffffffffffffffffffff8p+105L, plus_infty, DIVIDE_BY_ZERO_EXCEPTION|ERRNO_ERANGE),
12094 # endif
12095 # if LDBL_MANT_DIG >= 113
12096 TEST_ff_f (pow, 0, -0x1.ffffffffffffffffffffffffffffp+112L, plus_infty, DIVIDE_BY_ZERO_EXCEPTION|ERRNO_ERANGE),
12097 # endif
12098 #endif
12099 TEST_ff_f (pow, minus_zero, -1, minus_infty, DIVIDE_BY_ZERO_EXCEPTION|ERRNO_ERANGE),
12100 TEST_ff_f (pow, minus_zero, -11L, minus_infty, DIVIDE_BY_ZERO_EXCEPTION|ERRNO_ERANGE),
12101 TEST_ff_f (pow, minus_zero, -0xffffff, minus_infty, DIVIDE_BY_ZERO_EXCEPTION|ERRNO_ERANGE),
12102 TEST_ff_f (pow, minus_zero, -0x1fffffe, plus_infty, DIVIDE_BY_ZERO_EXCEPTION|ERRNO_ERANGE),
12103 #ifndef TEST_FLOAT
12104 TEST_ff_f (pow, minus_zero, -0x1.fffffffffffffp+52L, minus_infty, DIVIDE_BY_ZERO_EXCEPTION|ERRNO_ERANGE),
12105 TEST_ff_f (pow, minus_zero, -0x1.fffffffffffffp+53L, plus_infty, DIVIDE_BY_ZERO_EXCEPTION|ERRNO_ERANGE),
12106 #endif
12107 #ifdef TEST_LDOUBLE
12108 # if LDBL_MANT_DIG >= 64
12109 TEST_ff_f (pow, minus_zero, -0x1.fffffffffffffffep+63L, minus_infty, DIVIDE_BY_ZERO_EXCEPTION|ERRNO_ERANGE),
12110 TEST_ff_f (pow, minus_zero, -0x1.fffffffffffffffep+64L, plus_infty, DIVIDE_BY_ZERO_EXCEPTION|ERRNO_ERANGE),
12111 # endif
12112 # if LDBL_MANT_DIG >= 106
12113 TEST_ff_f (pow, minus_zero, -0x1.ffffffffffffffffffffffffff8p+105L, minus_infty, DIVIDE_BY_ZERO_EXCEPTION|ERRNO_ERANGE),
12114 TEST_ff_f (pow, minus_zero, -0x1.ffffffffffffffffffffffffff8p+106L, plus_infty, DIVIDE_BY_ZERO_EXCEPTION|ERRNO_ERANGE),
12115 # endif
12116 # if LDBL_MANT_DIG >= 113
12117 TEST_ff_f (pow, minus_zero, -0x1.ffffffffffffffffffffffffffffp+112L, minus_infty, DIVIDE_BY_ZERO_EXCEPTION|ERRNO_ERANGE),
12118 TEST_ff_f (pow, minus_zero, -0x1.ffffffffffffffffffffffffffffp+113L, plus_infty, DIVIDE_BY_ZERO_EXCEPTION|ERRNO_ERANGE),
12119 # endif
12120 #endif
12121
12122 TEST_ff_f (pow, 0, -2, plus_infty, DIVIDE_BY_ZERO_EXCEPTION|ERRNO_ERANGE),
12123 TEST_ff_f (pow, 0, -11.1L, plus_infty, DIVIDE_BY_ZERO_EXCEPTION|ERRNO_ERANGE),
12124 TEST_ff_f (pow, 0, -min_subnorm_value, plus_infty, DIVIDE_BY_ZERO_EXCEPTION|ERRNO_ERANGE),
12125 TEST_ff_f (pow, 0, -0x1p24, plus_infty, DIVIDE_BY_ZERO_EXCEPTION|ERRNO_ERANGE),
12126 TEST_ff_f (pow, 0, -0x1p127, plus_infty, DIVIDE_BY_ZERO_EXCEPTION|ERRNO_ERANGE),
12127 TEST_ff_f (pow, 0, -max_value, plus_infty, DIVIDE_BY_ZERO_EXCEPTION|ERRNO_ERANGE),
12128 TEST_ff_f (pow, minus_zero, -2, plus_infty, DIVIDE_BY_ZERO_EXCEPTION|ERRNO_ERANGE),
12129 TEST_ff_f (pow, minus_zero, -11.1L, plus_infty, DIVIDE_BY_ZERO_EXCEPTION|ERRNO_ERANGE),
12130 TEST_ff_f (pow, minus_zero, -min_subnorm_value, plus_infty, DIVIDE_BY_ZERO_EXCEPTION|ERRNO_ERANGE),
12131 TEST_ff_f (pow, minus_zero, -0x1p24, plus_infty, DIVIDE_BY_ZERO_EXCEPTION|ERRNO_ERANGE),
12132 TEST_ff_f (pow, minus_zero, -0x1p127, plus_infty, DIVIDE_BY_ZERO_EXCEPTION|ERRNO_ERANGE),
12133 TEST_ff_f (pow, minus_zero, -max_value, plus_infty, DIVIDE_BY_ZERO_EXCEPTION|ERRNO_ERANGE),
12134
12135 TEST_ff_f (pow, 0x1p72L, 0x1p72L, plus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
12136 TEST_ff_f (pow, 10, -0x1p72L, 0, UNDERFLOW_EXCEPTION),
12137 TEST_ff_f (pow, max_value, max_value, plus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
12138 TEST_ff_f (pow, 10, -max_value, 0, UNDERFLOW_EXCEPTION),
12139
12140 TEST_ff_f (pow, 0, 1, 0),
12141 TEST_ff_f (pow, 0, 11, 0),
12142
12143 TEST_ff_f (pow, minus_zero, 1, minus_zero),
12144 TEST_ff_f (pow, minus_zero, 11, minus_zero),
12145
12146 TEST_ff_f (pow, 0, 2, 0),
12147 TEST_ff_f (pow, 0, 11.1L, 0),
12148
12149 TEST_ff_f (pow, minus_zero, 2, 0),
12150 TEST_ff_f (pow, minus_zero, 11.1L, 0),
12151 TEST_ff_f (pow, 0, plus_infty, 0),
12152 TEST_ff_f (pow, minus_zero, plus_infty, 0),
12153 TEST_ff_f (pow, 0, minus_infty, plus_infty, DIVIDE_BY_ZERO_EXCEPTION_OK),
12154 TEST_ff_f (pow, minus_zero, minus_infty, plus_infty, DIVIDE_BY_ZERO_EXCEPTION_OK),
12155
12156 #ifndef TEST_INLINE
12157 /* pow (x, +inf) == +inf for |x| > 1. */
12158 TEST_ff_f (pow, 1.5, plus_infty, plus_infty),
12159
12160 /* pow (x, +inf) == +0 for |x| < 1. */
12161 TEST_ff_f (pow, 0.5, plus_infty, 0.0),
12162
12163 /* pow (x, -inf) == +0 for |x| > 1. */
12164 TEST_ff_f (pow, 1.5, minus_infty, 0.0),
12165
12166 /* pow (x, -inf) == +inf for |x| < 1. */
12167 TEST_ff_f (pow, 0.5, minus_infty, plus_infty),
12168 #endif
12169
12170 /* pow (+inf, y) == +inf for y > 0. */
12171 TEST_ff_f (pow, plus_infty, 2, plus_infty),
12172 TEST_ff_f (pow, plus_infty, 0xffffff, plus_infty),
12173 #ifndef TEST_FLOAT
12174 TEST_ff_f (pow, plus_infty, 0x1.fffffffffffffp+52L, plus_infty),
12175 #endif
12176 #ifdef TEST_LDOUBLE
12177 # if LDBL_MANT_DIG >= 64
12178 TEST_ff_f (pow, plus_infty, 0x1.fffffffffffffffep+63L, plus_infty),
12179 # endif
12180 # if LDBL_MANT_DIG >= 106
12181 TEST_ff_f (pow, plus_infty, 0x1.ffffffffffffffffffffffffff8p+105L, plus_infty),
12182 # endif
12183 # if LDBL_MANT_DIG >= 113
12184 TEST_ff_f (pow, plus_infty, 0x1.ffffffffffffffffffffffffffffp+112L, plus_infty),
12185 # endif
12186 #endif
12187 TEST_ff_f (pow, plus_infty, 0x1p24, plus_infty),
12188 TEST_ff_f (pow, plus_infty, 0x1p127, plus_infty),
12189 TEST_ff_f (pow, plus_infty, max_value, plus_infty),
12190
12191 /* pow (+inf, y) == +0 for y < 0. */
12192 TEST_ff_f (pow, plus_infty, -1, 0.0),
12193 TEST_ff_f (pow, plus_infty, -0xffffff, 0.0),
12194 #ifndef TEST_FLOAT
12195 TEST_ff_f (pow, plus_infty, -0x1.fffffffffffffp+52L, 0.0),
12196 #endif
12197 #ifdef TEST_LDOUBLE
12198 # if LDBL_MANT_DIG >= 64
12199 TEST_ff_f (pow, plus_infty, -0x1.fffffffffffffffep+63L, 0.0),
12200 # endif
12201 # if LDBL_MANT_DIG >= 106
12202 TEST_ff_f (pow, plus_infty, -0x1.ffffffffffffffffffffffffff8p+105L, 0.0),
12203 # endif
12204 # if LDBL_MANT_DIG >= 113
12205 TEST_ff_f (pow, plus_infty, -0x1.ffffffffffffffffffffffffffffp+112L, 0.0),
12206 # endif
12207 #endif
12208 TEST_ff_f (pow, plus_infty, -0x1p24, 0.0),
12209 TEST_ff_f (pow, plus_infty, -0x1p127, 0.0),
12210 TEST_ff_f (pow, plus_infty, -max_value, 0.0),
12211
12212 /* pow (-inf, y) == -inf for y an odd integer > 0. */
12213 TEST_ff_f (pow, minus_infty, 27, minus_infty),
12214 TEST_ff_f (pow, minus_infty, 0xffffff, minus_infty),
12215 TEST_ff_f (pow, minus_infty, 0x1fffffe, plus_infty),
12216 #ifndef TEST_FLOAT
12217 TEST_ff_f (pow, minus_infty, 0x1.fffffffffffffp+52L, minus_infty),
12218 TEST_ff_f (pow, minus_infty, 0x1.fffffffffffffp+53L, plus_infty),
12219 #endif
12220 #ifdef TEST_LDOUBLE
12221 # if LDBL_MANT_DIG >= 64
12222 TEST_ff_f (pow, minus_infty, 0x1.fffffffffffffffep+63L, minus_infty),
12223 TEST_ff_f (pow, minus_infty, 0x1.fffffffffffffffep+64L, plus_infty),
12224 # endif
12225 # if LDBL_MANT_DIG >= 106
12226 TEST_ff_f (pow, minus_infty, 0x1.ffffffffffffffffffffffffff8p+105L, minus_infty),
12227 TEST_ff_f (pow, minus_infty, 0x1.ffffffffffffffffffffffffff8p+106L, plus_infty),
12228 # endif
12229 # if LDBL_MANT_DIG >= 113
12230 TEST_ff_f (pow, minus_infty, 0x1.ffffffffffffffffffffffffffffp+112L, minus_infty),
12231 TEST_ff_f (pow, minus_infty, 0x1.ffffffffffffffffffffffffffffp+113L, plus_infty),
12232 # endif
12233 #endif
12234
12235 /* pow (-inf, y) == +inf for y > 0 and not an odd integer. */
12236 TEST_ff_f (pow, minus_infty, 28, plus_infty),
12237 TEST_ff_f (pow, minus_infty, 0x1p24, plus_infty),
12238 TEST_ff_f (pow, minus_infty, 0x1p127, plus_infty),
12239 TEST_ff_f (pow, minus_infty, max_value, plus_infty),
12240
12241 /* pow (-inf, y) == -0 for y an odd integer < 0. */
12242 TEST_ff_f (pow, minus_infty, -3, minus_zero),
12243 TEST_ff_f (pow, minus_infty, -0xffffff, minus_zero),
12244 TEST_ff_f (pow, minus_infty, -0x1fffffe, plus_zero),
12245 #ifndef TEST_FLOAT
12246 TEST_ff_f (pow, minus_infty, -0x1.fffffffffffffp+52L, minus_zero),
12247 TEST_ff_f (pow, minus_infty, -0x1.fffffffffffffp+53L, plus_zero),
12248 #endif
12249 #ifdef TEST_LDOUBLE
12250 # if LDBL_MANT_DIG >= 64
12251 TEST_ff_f (pow, minus_infty, -0x1.fffffffffffffffep+63L, minus_zero),
12252 TEST_ff_f (pow, minus_infty, -0x1.fffffffffffffffep+64L, plus_zero),
12253 # endif
12254 # if LDBL_MANT_DIG >= 106
12255 TEST_ff_f (pow, minus_infty, -0x1.ffffffffffffffffffffffffff8p+105L, minus_zero),
12256 TEST_ff_f (pow, minus_infty, -0x1.ffffffffffffffffffffffffff8p+106L, plus_zero),
12257 # endif
12258 # if LDBL_MANT_DIG >= 113
12259 TEST_ff_f (pow, minus_infty, -0x1.ffffffffffffffffffffffffffffp+112L, minus_zero),
12260 TEST_ff_f (pow, minus_infty, -0x1.ffffffffffffffffffffffffffffp+113L, plus_zero),
12261 # endif
12262 #endif
12263 /* pow (-inf, y) == +0 for y < 0 and not an odd integer. */
12264 TEST_ff_f (pow, minus_infty, -2.0, 0.0),
12265 TEST_ff_f (pow, minus_infty, -0x1p24, 0.0),
12266 TEST_ff_f (pow, minus_infty, -0x1p127, 0.0),
12267 TEST_ff_f (pow, minus_infty, -max_value, 0.0),
12268
12269 /* pow (+0, y) == +0 for y an odd integer > 0. */
12270 TEST_ff_f (pow, 0.0, 27, 0.0),
12271 TEST_ff_f (pow, 0.0, 0xffffff, 0.0),
12272 #ifndef TEST_FLOAT
12273 TEST_ff_f (pow, 0.0, 0x1.fffffffffffffp+52L, 0.0),
12274 #endif
12275 #ifdef TEST_LDOUBLE
12276 # if LDBL_MANT_DIG >= 64
12277 TEST_ff_f (pow, 0.0, 0x1.fffffffffffffffep+63L, 0.0),
12278 # endif
12279 # if LDBL_MANT_DIG >= 106
12280 TEST_ff_f (pow, 0.0, 0x1.ffffffffffffffffffffffffff8p+105L, 0.0),
12281 # endif
12282 # if LDBL_MANT_DIG >= 113
12283 TEST_ff_f (pow, 0.0, 0x1.ffffffffffffffffffffffffffffp+112L, 0.0),
12284 # endif
12285 #endif
12286
12287 /* pow (-0, y) == -0 for y an odd integer > 0. */
12288 TEST_ff_f (pow, minus_zero, 27, minus_zero),
12289 TEST_ff_f (pow, minus_zero, 0xffffff, minus_zero),
12290 TEST_ff_f (pow, minus_zero, 0x1fffffe, plus_zero),
12291 #ifndef TEST_FLOAT
12292 TEST_ff_f (pow, minus_zero, 0x1.fffffffffffffp+52L, minus_zero),
12293 TEST_ff_f (pow, minus_zero, 0x1.fffffffffffffp+53L, plus_zero),
12294 #endif
12295 #ifdef TEST_LDOUBLE
12296 # if LDBL_MANT_DIG >= 64
12297 TEST_ff_f (pow, minus_zero, 0x1.fffffffffffffffep+63L, minus_zero),
12298 TEST_ff_f (pow, minus_zero, 0x1.fffffffffffffffep+64L, plus_zero),
12299 # endif
12300 # if LDBL_MANT_DIG >= 106
12301 TEST_ff_f (pow, minus_zero, 0x1.ffffffffffffffffffffffffff8p+105L, minus_zero),
12302 TEST_ff_f (pow, minus_zero, 0x1.ffffffffffffffffffffffffff8p+106L, plus_zero),
12303 # endif
12304 # if LDBL_MANT_DIG >= 113
12305 TEST_ff_f (pow, minus_zero, 0x1.ffffffffffffffffffffffffffffp+112L, minus_zero),
12306 TEST_ff_f (pow, minus_zero, 0x1.ffffffffffffffffffffffffffffp+113L, plus_zero),
12307 # endif
12308 #endif
12309
12310 /* pow (+0, y) == +0 for y > 0 and not an odd integer. */
12311 TEST_ff_f (pow, 0.0, 4, 0.0),
12312 TEST_ff_f (pow, 0.0, 0x1p24, 0.0),
12313 TEST_ff_f (pow, 0.0, 0x1p127, 0.0),
12314 TEST_ff_f (pow, 0.0, max_value, 0.0),
12315 TEST_ff_f (pow, 0.0, min_subnorm_value, 0.0),
12316
12317 /* pow (-0, y) == +0 for y > 0 and not an odd integer. */
12318 TEST_ff_f (pow, minus_zero, 4, 0.0),
12319 TEST_ff_f (pow, minus_zero, 0x1p24, 0.0),
12320 TEST_ff_f (pow, minus_zero, 0x1p127, 0.0),
12321 TEST_ff_f (pow, minus_zero, max_value, 0.0),
12322 TEST_ff_f (pow, minus_zero, min_subnorm_value, 0.0),
12323
12324 TEST_ff_f (pow, 16, 0.25L, 2),
12325 TEST_ff_f (pow, 0x1p64L, 0.125L, 256),
12326 TEST_ff_f (pow, 2, 4, 16),
12327 TEST_ff_f (pow, 256, 8, 0x1p64L),
12328
12329 TEST_ff_f (pow, 0.75L, 1.25L, 0.697953644326574699205914060237425566L),
12330
12331 #if defined TEST_DOUBLE || defined TEST_LDOUBLE
12332 TEST_ff_f (pow, -7.49321e+133, -9.80818e+16, 0, UNDERFLOW_EXCEPTION),
12333 #endif
12334
12335 TEST_ff_f (pow, -1.0, -0xffffff, -1.0),
12336 TEST_ff_f (pow, -1.0, -0x1fffffe, 1.0),
12337 #ifndef TEST_FLOAT
12338 TEST_ff_f (pow, -1.0, -0x1.fffffffffffffp+52L, -1.0),
12339 TEST_ff_f (pow, -1.0, -0x1.fffffffffffffp+53L, 1.0),
12340 #endif
12341 #ifdef TEST_LDOUBLE
12342 # if LDBL_MANT_DIG >= 64
12343 TEST_ff_f (pow, -1.0, -0x1.fffffffffffffffep+63L, -1.0),
12344 TEST_ff_f (pow, -1.0, -0x1.fffffffffffffffep+64L, 1.0),
12345 # endif
12346 # if LDBL_MANT_DIG >= 106
12347 TEST_ff_f (pow, -1.0, -0x1.ffffffffffffffffffffffffff8p+105L, -1.0),
12348 TEST_ff_f (pow, -1.0, -0x1.ffffffffffffffffffffffffff8p+106L, 1.0),
12349 # endif
12350 # if LDBL_MANT_DIG >= 113
12351 TEST_ff_f (pow, -1.0, -0x1.ffffffffffffffffffffffffffffp+112L, -1.0),
12352 TEST_ff_f (pow, -1.0, -0x1.ffffffffffffffffffffffffffffp+113L, 1.0),
12353 # endif
12354 #endif
12355 TEST_ff_f (pow, -1.0, -max_value, 1.0),
12356
12357 TEST_ff_f (pow, -1.0, 0xffffff, -1.0),
12358 TEST_ff_f (pow, -1.0, 0x1fffffe, 1.0),
12359 #ifndef TEST_FLOAT
12360 TEST_ff_f (pow, -1.0, 0x1.fffffffffffffp+52L, -1.0),
12361 TEST_ff_f (pow, -1.0, 0x1.fffffffffffffp+53L, 1.0),
12362 #endif
12363 #ifdef TEST_LDOUBLE
12364 # if LDBL_MANT_DIG >= 64
12365 TEST_ff_f (pow, -1.0, 0x1.fffffffffffffffep+63L, -1.0),
12366 TEST_ff_f (pow, -1.0, 0x1.fffffffffffffffep+64L, 1.0),
12367 # endif
12368 # if LDBL_MANT_DIG >= 106
12369 TEST_ff_f (pow, -1.0, 0x1.ffffffffffffffffffffffffff8p+105L, -1.0),
12370 TEST_ff_f (pow, -1.0, 0x1.ffffffffffffffffffffffffff8p+106L, 1.0),
12371 # endif
12372 # if LDBL_MANT_DIG >= 113
12373 TEST_ff_f (pow, -1.0, 0x1.ffffffffffffffffffffffffffffp+112L, -1.0),
12374 TEST_ff_f (pow, -1.0, 0x1.ffffffffffffffffffffffffffffp+113L, 1.0),
12375 # endif
12376 #endif
12377 TEST_ff_f (pow, -1.0, max_value, 1.0),
12378
12379 TEST_ff_f (pow, -2.0, 126, 0x1p126),
12380 TEST_ff_f (pow, -2.0, 127, -0x1p127),
12381 /* Allow inexact results for float to be considered to underflow. */
12382 TEST_ff_f (pow, -2.0, -126, 0x1p-126, UNDERFLOW_EXCEPTION_OK_FLOAT),
12383 TEST_ff_f (pow, -2.0, -127, -0x1p-127, UNDERFLOW_EXCEPTION_OK_FLOAT),
12384
12385 TEST_ff_f (pow, -2.0, -0xffffff, minus_zero, UNDERFLOW_EXCEPTION),
12386 TEST_ff_f (pow, -2.0, -0x1fffffe, plus_zero, UNDERFLOW_EXCEPTION),
12387 #ifndef TEST_FLOAT
12388 TEST_ff_f (pow, -2.0, -0x1.fffffffffffffp+52L, minus_zero, UNDERFLOW_EXCEPTION),
12389 TEST_ff_f (pow, -2.0, -0x1.fffffffffffffp+53L, plus_zero, UNDERFLOW_EXCEPTION),
12390 #endif
12391 #ifdef TEST_LDOUBLE
12392 # if LDBL_MANT_DIG >= 64
12393 TEST_ff_f (pow, -2.0, -0x1.fffffffffffffffep+63L, minus_zero, UNDERFLOW_EXCEPTION),
12394 TEST_ff_f (pow, -2.0, -0x1.fffffffffffffffep+64L, plus_zero, UNDERFLOW_EXCEPTION),
12395 # endif
12396 # if LDBL_MANT_DIG >= 106
12397 TEST_ff_f (pow, -2.0, -0x1.ffffffffffffffffffffffffff8p+105L, minus_zero, UNDERFLOW_EXCEPTION),
12398 TEST_ff_f (pow, -2.0, -0x1.ffffffffffffffffffffffffff8p+106L, plus_zero, UNDERFLOW_EXCEPTION),
12399 # endif
12400 # if LDBL_MANT_DIG >= 113
12401 TEST_ff_f (pow, -2.0, -0x1.ffffffffffffffffffffffffffffp+112L, minus_zero, UNDERFLOW_EXCEPTION),
12402 TEST_ff_f (pow, -2.0, -0x1.ffffffffffffffffffffffffffffp+113L, plus_zero, UNDERFLOW_EXCEPTION),
12403 # endif
12404 #endif
12405 TEST_ff_f (pow, -2.0, -max_value, plus_zero, UNDERFLOW_EXCEPTION),
12406
12407 TEST_ff_f (pow, -2.0, 0xffffff, minus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
12408 TEST_ff_f (pow, -2.0, 0x1fffffe, plus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
12409 #ifndef TEST_FLOAT
12410 TEST_ff_f (pow, -2.0, 0x1.fffffffffffffp+52L, minus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
12411 TEST_ff_f (pow, -2.0, 0x1.fffffffffffffp+53L, plus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
12412 #endif
12413 #ifdef TEST_LDOUBLE
12414 # if LDBL_MANT_DIG >= 64
12415 TEST_ff_f (pow, -2.0, 0x1.fffffffffffffffep+63L, minus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
12416 TEST_ff_f (pow, -2.0, 0x1.fffffffffffffffep+64L, plus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
12417 # endif
12418 # if LDBL_MANT_DIG >= 106
12419 TEST_ff_f (pow, -2.0, 0x1.ffffffffffffffffffffffffff8p+105L, minus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
12420 TEST_ff_f (pow, -2.0, 0x1.ffffffffffffffffffffffffff8p+106L, plus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
12421 # endif
12422 # if LDBL_MANT_DIG >= 113
12423 TEST_ff_f (pow, -2.0, 0x1.ffffffffffffffffffffffffffffp+112L, minus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
12424 TEST_ff_f (pow, -2.0, 0x1.ffffffffffffffffffffffffffffp+113L, plus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
12425 # endif
12426 #endif
12427 TEST_ff_f (pow, -2.0, max_value, plus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
12428
12429 TEST_ff_f (pow, -max_value, 0.5, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
12430 TEST_ff_f (pow, -max_value, 1.5, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
12431 TEST_ff_f (pow, -max_value, 1000.5, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
12432 TEST_ff_f (pow, -max_value, -2, plus_zero, UNDERFLOW_EXCEPTION),
12433 TEST_ff_f (pow, -max_value, -3, minus_zero, UNDERFLOW_EXCEPTION),
12434 TEST_ff_f (pow, -max_value, 2, plus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
12435 TEST_ff_f (pow, -max_value, 3, minus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
12436
12437 TEST_ff_f (pow, -max_value, -0xffffff, minus_zero, UNDERFLOW_EXCEPTION),
12438 TEST_ff_f (pow, -max_value, -0x1fffffe, plus_zero, UNDERFLOW_EXCEPTION),
12439 #ifndef TEST_FLOAT
12440 TEST_ff_f (pow, -max_value, -0x1.fffffffffffffp+52L, minus_zero, UNDERFLOW_EXCEPTION),
12441 TEST_ff_f (pow, -max_value, -0x1.fffffffffffffp+53L, plus_zero, UNDERFLOW_EXCEPTION),
12442 #endif
12443 #ifdef TEST_LDOUBLE
12444 # if LDBL_MANT_DIG >= 64
12445 TEST_ff_f (pow, -max_value, -0x1.fffffffffffffffep+63L, minus_zero, UNDERFLOW_EXCEPTION),
12446 TEST_ff_f (pow, -max_value, -0x1.fffffffffffffffep+64L, plus_zero, UNDERFLOW_EXCEPTION),
12447 # endif
12448 # if LDBL_MANT_DIG >= 106
12449 TEST_ff_f (pow, -max_value, -0x1.ffffffffffffffffffffffffff8p+105L, minus_zero, UNDERFLOW_EXCEPTION),
12450 TEST_ff_f (pow, -max_value, -0x1.ffffffffffffffffffffffffff8p+106L, plus_zero, UNDERFLOW_EXCEPTION),
12451 # endif
12452 # if LDBL_MANT_DIG >= 113
12453 TEST_ff_f (pow, -max_value, -0x1.ffffffffffffffffffffffffffffp+112L, minus_zero, UNDERFLOW_EXCEPTION),
12454 TEST_ff_f (pow, -max_value, -0x1.ffffffffffffffffffffffffffffp+113L, plus_zero, UNDERFLOW_EXCEPTION),
12455 # endif
12456 #endif
12457 TEST_ff_f (pow, -max_value, -max_value, plus_zero, UNDERFLOW_EXCEPTION),
12458
12459 TEST_ff_f (pow, -max_value, 0xffffff, minus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
12460 TEST_ff_f (pow, -max_value, 0x1fffffe, plus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
12461 #ifndef TEST_FLOAT
12462 TEST_ff_f (pow, -max_value, 0x1.fffffffffffffp+52L, minus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
12463 TEST_ff_f (pow, -max_value, 0x1.fffffffffffffp+53L, plus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
12464 #endif
12465 #ifdef TEST_LDOUBLE
12466 # if LDBL_MANT_DIG >= 64
12467 TEST_ff_f (pow, -max_value, 0x1.fffffffffffffffep+63L, minus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
12468 TEST_ff_f (pow, -max_value, 0x1.fffffffffffffffep+64L, plus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
12469 # endif
12470 # if LDBL_MANT_DIG >= 106
12471 TEST_ff_f (pow, -max_value, 0x1.ffffffffffffffffffffffffff8p+105L, minus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
12472 TEST_ff_f (pow, -max_value, 0x1.ffffffffffffffffffffffffff8p+106L, plus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
12473 # endif
12474 # if LDBL_MANT_DIG >= 113
12475 TEST_ff_f (pow, -max_value, 0x1.ffffffffffffffffffffffffffffp+112L, minus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
12476 TEST_ff_f (pow, -max_value, 0x1.ffffffffffffffffffffffffffffp+113L, plus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
12477 # endif
12478 #endif
12479 TEST_ff_f (pow, -max_value, max_value, plus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
12480
12481 TEST_ff_f (pow, -0.5, 126, 0x1p-126),
12482 TEST_ff_f (pow, -0.5, 127, -0x1p-127),
12483 TEST_ff_f (pow, -0.5, -126, 0x1p126),
12484 TEST_ff_f (pow, -0.5, -127, -0x1p127),
12485
12486 TEST_ff_f (pow, -0.5, -0xffffff, minus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
12487 TEST_ff_f (pow, -0.5, -0x1fffffe, plus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
12488 #ifndef TEST_FLOAT
12489 TEST_ff_f (pow, -0.5, -0x1.fffffffffffffp+52L, minus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
12490 TEST_ff_f (pow, -0.5, -0x1.fffffffffffffp+53L, plus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
12491 #endif
12492 #ifdef TEST_LDOUBLE
12493 # if LDBL_MANT_DIG >= 64
12494 TEST_ff_f (pow, -0.5, -0x1.fffffffffffffffep+63L, minus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
12495 TEST_ff_f (pow, -0.5, -0x1.fffffffffffffffep+64L, plus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
12496 # endif
12497 # if LDBL_MANT_DIG >= 106
12498 TEST_ff_f (pow, -0.5, -0x1.ffffffffffffffffffffffffff8p+105L, minus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
12499 TEST_ff_f (pow, -0.5, -0x1.ffffffffffffffffffffffffff8p+106L, plus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
12500 # endif
12501 # if LDBL_MANT_DIG >= 113
12502 TEST_ff_f (pow, -0.5, -0x1.ffffffffffffffffffffffffffffp+112L, minus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
12503 TEST_ff_f (pow, -0.5, -0x1.ffffffffffffffffffffffffffffp+113L, plus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
12504 # endif
12505 #endif
12506 TEST_ff_f (pow, -0.5, -max_value, plus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
12507
12508 TEST_ff_f (pow, -0.5, 0xffffff, minus_zero, UNDERFLOW_EXCEPTION),
12509 TEST_ff_f (pow, -0.5, 0x1fffffe, plus_zero, UNDERFLOW_EXCEPTION),
12510 #ifndef TEST_FLOAT
12511 TEST_ff_f (pow, -0.5, 0x1.fffffffffffffp+52L, minus_zero, UNDERFLOW_EXCEPTION),
12512 TEST_ff_f (pow, -0.5, 0x1.fffffffffffffp+53L, plus_zero, UNDERFLOW_EXCEPTION),
12513 #endif
12514 #ifdef TEST_LDOUBLE
12515 # if LDBL_MANT_DIG >= 64
12516 TEST_ff_f (pow, -0.5, 0x1.fffffffffffffffep+63L, minus_zero, UNDERFLOW_EXCEPTION),
12517 TEST_ff_f (pow, -0.5, 0x1.fffffffffffffffep+64L, plus_zero, UNDERFLOW_EXCEPTION),
12518 # endif
12519 # if LDBL_MANT_DIG >= 106
12520 TEST_ff_f (pow, -0.5, 0x1.ffffffffffffffffffffffffff8p+105L, minus_zero, UNDERFLOW_EXCEPTION),
12521 TEST_ff_f (pow, -0.5, 0x1.ffffffffffffffffffffffffff8p+106L, plus_zero, UNDERFLOW_EXCEPTION),
12522 # endif
12523 # if LDBL_MANT_DIG >= 113
12524 TEST_ff_f (pow, -0.5, 0x1.ffffffffffffffffffffffffffffp+112L, minus_zero, UNDERFLOW_EXCEPTION),
12525 TEST_ff_f (pow, -0.5, 0x1.ffffffffffffffffffffffffffffp+113L, plus_zero, UNDERFLOW_EXCEPTION),
12526 # endif
12527 #endif
12528 TEST_ff_f (pow, -0.5, max_value, plus_zero, UNDERFLOW_EXCEPTION),
12529
12530 TEST_ff_f (pow, -min_value, 0.5, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
12531 TEST_ff_f (pow, -min_value, 1.5, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
12532 TEST_ff_f (pow, -min_value, 1000.5, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
12533 TEST_ff_f (pow, -min_value, -2, plus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
12534 TEST_ff_f (pow, -min_value, -3, minus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
12535 /* Allow inexact results to be considered to underflow. */
12536 TEST_ff_f (pow, -min_value, 1, -min_value, UNDERFLOW_EXCEPTION_OK),
12537 TEST_ff_f (pow, -min_value, 2, plus_zero, UNDERFLOW_EXCEPTION),
12538 TEST_ff_f (pow, -min_value, 3, minus_zero, UNDERFLOW_EXCEPTION),
12539
12540 TEST_ff_f (pow, -min_value, -0xffffff, minus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
12541 TEST_ff_f (pow, -min_value, -0x1fffffe, plus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
12542 #ifndef TEST_FLOAT
12543 TEST_ff_f (pow, -min_value, -0x1.fffffffffffffp+52L, minus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
12544 TEST_ff_f (pow, -min_value, -0x1.fffffffffffffp+53L, plus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
12545 #endif
12546 #ifdef TEST_LDOUBLE
12547 # if LDBL_MANT_DIG >= 64
12548 TEST_ff_f (pow, -min_value, -0x1.fffffffffffffffep+63L, minus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
12549 TEST_ff_f (pow, -min_value, -0x1.fffffffffffffffep+64L, plus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
12550 # endif
12551 # if LDBL_MANT_DIG >= 106
12552 TEST_ff_f (pow, -min_value, -0x1.ffffffffffffffffffffffffff8p+105L, minus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
12553 TEST_ff_f (pow, -min_value, -0x1.ffffffffffffffffffffffffff8p+106L, plus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
12554 # endif
12555 # if LDBL_MANT_DIG >= 113
12556 TEST_ff_f (pow, -min_value, -0x1.ffffffffffffffffffffffffffffp+112L, minus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
12557 TEST_ff_f (pow, -min_value, -0x1.ffffffffffffffffffffffffffffp+113L, plus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
12558 # endif
12559 #endif
12560 TEST_ff_f (pow, -min_value, -max_value, plus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
12561
12562 TEST_ff_f (pow, -min_value, 0xffffff, minus_zero, UNDERFLOW_EXCEPTION),
12563 TEST_ff_f (pow, -min_value, 0x1fffffe, plus_zero, UNDERFLOW_EXCEPTION),
12564 #ifndef TEST_FLOAT
12565 TEST_ff_f (pow, -min_value, 0x1.fffffffffffffp+52L, minus_zero, UNDERFLOW_EXCEPTION),
12566 TEST_ff_f (pow, -min_value, 0x1.fffffffffffffp+53L, plus_zero, UNDERFLOW_EXCEPTION),
12567 #endif
12568 #ifdef TEST_LDOUBLE
12569 # if LDBL_MANT_DIG >= 64
12570 TEST_ff_f (pow, -min_value, 0x1.fffffffffffffffep+63L, minus_zero, UNDERFLOW_EXCEPTION),
12571 TEST_ff_f (pow, -min_value, 0x1.fffffffffffffffep+64L, plus_zero, UNDERFLOW_EXCEPTION),
12572 # endif
12573 # if LDBL_MANT_DIG >= 106
12574 TEST_ff_f (pow, -min_value, 0x1.ffffffffffffffffffffffffff8p+105L, minus_zero, UNDERFLOW_EXCEPTION),
12575 TEST_ff_f (pow, -min_value, 0x1.ffffffffffffffffffffffffff8p+106L, plus_zero, UNDERFLOW_EXCEPTION),
12576 # endif
12577 # if LDBL_MANT_DIG >= 113
12578 TEST_ff_f (pow, -min_value, 0x1.ffffffffffffffffffffffffffffp+112L, minus_zero, UNDERFLOW_EXCEPTION),
12579 TEST_ff_f (pow, -min_value, 0x1.ffffffffffffffffffffffffffffp+113L, plus_zero, UNDERFLOW_EXCEPTION),
12580 # endif
12581 #endif
12582 TEST_ff_f (pow, -min_value, max_value, plus_zero, UNDERFLOW_EXCEPTION),
12583
12584 TEST_ff_f (pow, 0x0.ffffffp0, 10, 0.999999403953712118183885036774764444747L),
12585 TEST_ff_f (pow, 0x0.ffffffp0, 100, 0.999994039553108359406305079606228341585L),
12586 TEST_ff_f (pow, 0x0.ffffffp0, 1000, 0.9999403971297699052276650144650733772182L),
12587 TEST_ff_f (pow, 0x0.ffffffp0, 0x1p24, 0.3678794302077803437135155590023422899744L),
12588 TEST_ff_f (pow, 0x0.ffffffp0, 0x1p30, 1.603807831524924233828134753069728224044e-28L),
12589 TEST_ff_f (pow, 0x0.ffffffp0, 0x1.234566p30, 2.374884712135295099971443365381007297732e-32L),
12590 TEST_ff_f (pow, 0x0.ffffffp0, -10, 1.000000596046643153205170848674671339688L),
12591 TEST_ff_f (pow, 0x0.ffffffp0, -100, 1.000005960482418779499387594989252621451L),
12592 TEST_ff_f (pow, 0x0.ffffffp0, -1000, 1.000059606422943986382898964231519867906L),
12593 TEST_ff_f (pow, 0x0.ffffffp0, -0x1p24, 2.7182819094701610539628664526874952929416L),
12594 TEST_ff_f (pow, 0x0.ffffffp0, -0x1p30, 6.2351609734265057988914412331288163636075e+27L),
12595 TEST_ff_f (pow, 0x0.ffffffp0, -0x1.234566p30, 4.2107307141696353498921307077142537353515e+31L),
12596 TEST_ff_f (pow, 0x1.000002p0, 0x1p24, 7.3890552180866447284268641248075832310141L),
12597 TEST_ff_f (pow, 0x1.000002p0, 0x1.234566p29, 4.2107033006507495188536371520637025716256e+31L),
12598 TEST_ff_f (pow, 0x1.000002p0, -0x1.234566p29, 2.3749001736727769098946062325205705312166e-32L),
12599
12600 #if !defined TEST_FLOAT
12601 TEST_ff_f (pow, 0x0.fffffffffffff8p0L, 0x1.23456789abcdfp62L, 1.0118762747827252817436395051178295138220e-253L),
12602 TEST_ff_f (pow, 0x0.fffffffffffff8p0L, -0x1.23456789abcdfp62L, 9.8826311568054561811190162420900667121992e+252L),
12603 TEST_ff_f (pow, 0x1.0000000000001p0L, 0x1.23456789abcdfp61L, 9.8826311568044974397135026217687399395481e+252L),
12604 TEST_ff_f (pow, 0x1.0000000000001p0L, -0x1.23456789abcdfp61L, 1.0118762747828234466621210689458255908670e-253L),
12605 #endif
12606
12607 #if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 64 && LDBL_MAX_EXP >= 16384
12608 TEST_ff_f (pow, 0x0.ffffffffffffffffp0L, 0x1.23456789abcdef0ep77L, 1.2079212226420368189981778807634890018840e-4048L),
12609 TEST_ff_f (pow, 0x0.ffffffffffffffffp0L, -0x1.23456789abcdef0ep77L, 8.2786855736563746280496724205839522148001e+4047L),
12610 TEST_ff_f (pow, 0x1.0000000000000002p0L, 0x1.23456789abcdef0ep76L, 8.2786855736563683535324500168799315131570e+4047L),
12611 TEST_ff_f (pow, 0x1.0000000000000002p0L, -0x1.23456789abcdef0ep76L, 1.2079212226420377344964713407722652880280e-4048L),
12612 #endif
12613
12614 #if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 113
12615 TEST_ff_f (pow, 0x0.ffffffffffffffffffffffffffff8p0L, 0x1.23456789abcdef0123456789abcdp126L, 1.2079212226420440237790185999151440179953e-4048L),
12616 TEST_ff_f (pow, 0x0.ffffffffffffffffffffffffffff8p0L, -0x1.23456789abcdef0123456789abcdp126L, 8.2786855736563252489063231915535105363602e+4047L),
12617 TEST_ff_f (pow, 0x1.0000000000000000000000000001p0L, 0x1.23456789abcdef0123456789abcdp125L, 8.2786855736563252489063231915423647547782e+4047L),
12618 TEST_ff_f (pow, 0x1.0000000000000000000000000001p0L, -0x1.23456789abcdef0123456789abcdp125L, 1.2079212226420440237790185999167702696503e-4048L),
12619 #endif
12620
12621 #if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
12622 TEST_ff_f (pow, 1e4932L, 0.75L, 1e3699L),
12623 TEST_ff_f (pow, 1e4928L, 0.75L, 1e3696L),
12624 TEST_ff_f (pow, 1e4924L, 0.75L, 1e3693L),
12625 TEST_ff_f (pow, 1e4920L, 0.75L, 1e3690L),
12626 TEST_ff_f (pow, 10.0L, 4932.0L, 1e4932L),
12627 TEST_ff_f (pow, 10.0L, 4931.0L, 1e4931L),
12628 TEST_ff_f (pow, 10.0L, 4930.0L, 1e4930L),
12629 TEST_ff_f (pow, 10.0L, 4929.0L, 1e4929L),
12630 TEST_ff_f (pow, 10.0L, -4931.0L, 1e-4931L),
12631 TEST_ff_f (pow, 10.0L, -4930.0L, 1e-4930L),
12632 TEST_ff_f (pow, 10.0L, -4929.0L, 1e-4929L),
12633 TEST_ff_f (pow, 1e27L, 182.0L, 1e4914L),
12634 TEST_ff_f (pow, 1e27L, -182.0L, 1e-4914L),
12635 #endif
12636
12637 TEST_ff_f (pow, min_subnorm_value, min_subnorm_value, 1.0L),
12638 TEST_ff_f (pow, min_subnorm_value, -min_subnorm_value, 1.0L),
12639 TEST_ff_f (pow, max_value, min_subnorm_value, 1.0L),
12640 TEST_ff_f (pow, max_value, -min_subnorm_value, 1.0L),
12641 TEST_ff_f (pow, 0.99L, min_subnorm_value, 1.0L),
12642 TEST_ff_f (pow, 0.99L, -min_subnorm_value, 1.0L),
12643 TEST_ff_f (pow, 1.01L, min_subnorm_value, 1.0L),
12644 TEST_ff_f (pow, 1.01L, -min_subnorm_value, 1.0L),
12645
12646 TEST_ff_f (pow, 2.0L, -100000.0L, plus_zero, UNDERFLOW_EXCEPTION),
12647 END_DATA (pow)
12648 };
12649
12650 static void
12651 pow_test (void)
12652 {
12653
12654 errno = 0;
12655 FUNC(pow) (0, 0);
12656 if (errno == ENOSYS)
12657 /* Function not implemented. */
12658 return;
12659
12660 START (pow);
12661 RUN_TEST_LOOP_ff_f (pow, pow_test_data, );
12662 END (pow);
12663 }
12664
12665
12666 static const struct test_ff_f_data pow_tonearest_test_data[] =
12667 {
12668 START_DATA (pow_tonearest),
12669 TEST_ff_f (pow, 1.0625L, 1.125L, 1.070582293028761362162622578677070098674L),
12670 TEST_ff_f (pow, 1.5L, 1.03125L, 1.519127098714743184071644334163037684948L),
12671 END_DATA (pow_tonearest)
12672 };
12673
12674 static void
12675 pow_test_tonearest (void)
12676 {
12677 errno = 0;
12678 FUNC(pow) (0, 0);
12679 if (errno == ENOSYS)
12680 /* Function not implemented. */
12681 return;
12682
12683 START (pow_tonearest);
12684 RUN_TEST_LOOP_ff_f (pow, pow_tonearest_test_data, FE_TONEAREST);
12685 END (pow_tonearest);
12686 }
12687
12688
12689 static const struct test_ff_f_data pow_towardzero_test_data[] =
12690 {
12691 START_DATA (pow_towardzero),
12692 TEST_ff_f (pow, 1.0625L, 1.125L, 1.070582293028761362162622578677070098674L),
12693 TEST_ff_f (pow, 1.5L, 1.03125L, 1.519127098714743184071644334163037684948L),
12694 END_DATA (pow_towardzero)
12695 };
12696
12697 static void
12698 pow_test_towardzero (void)
12699 {
12700 errno = 0;
12701 FUNC(pow) (0, 0);
12702 if (errno == ENOSYS)
12703 /* Function not implemented. */
12704 return;
12705
12706 START (pow_towardzero);
12707 RUN_TEST_LOOP_ff_f (pow, pow_towardzero_test_data, FE_TOWARDZERO);
12708 END (pow_towardzero);
12709 }
12710
12711
12712 static const struct test_ff_f_data pow_downward_test_data[] =
12713 {
12714 START_DATA (pow_downward),
12715 TEST_ff_f (pow, 1.0625L, 1.125L, 1.070582293028761362162622578677070098674L),
12716 TEST_ff_f (pow, 1.5L, 1.03125L, 1.519127098714743184071644334163037684948L),
12717 END_DATA (pow_downward)
12718 };
12719
12720 static void
12721 pow_test_downward (void)
12722 {
12723 errno = 0;
12724 FUNC(pow) (0, 0);
12725 if (errno == ENOSYS)
12726 /* Function not implemented. */
12727 return;
12728
12729 START (pow_downward);
12730 RUN_TEST_LOOP_ff_f (pow, pow_downward_test_data, FE_DOWNWARD);
12731 END (pow_downward);
12732 }
12733
12734
12735 static const struct test_ff_f_data pow_upward_test_data[] =
12736 {
12737 START_DATA (pow_upward),
12738 TEST_ff_f (pow, 1.0625L, 1.125L, 1.070582293028761362162622578677070098674L),
12739 TEST_ff_f (pow, 1.5L, 1.03125L, 1.519127098714743184071644334163037684948L),
12740 END_DATA (pow_upward)
12741 };
12742
12743 static void
12744 pow_test_upward (void)
12745 {
12746 errno = 0;
12747 FUNC(pow) (0, 0);
12748 if (errno == ENOSYS)
12749 /* Function not implemented. */
12750 return;
12751
12752 START (pow_upward);
12753 RUN_TEST_LOOP_ff_f (pow, pow_upward_test_data, FE_UPWARD);
12754 END (pow_upward);
12755 }
12756
12757
12758 static const struct test_ff_f_data remainder_test_data[] =
12759 {
12760 START_DATA (remainder),
12761 TEST_ff_f (remainder, 1, 0, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
12762 TEST_ff_f (remainder, 1, minus_zero, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
12763 TEST_ff_f (remainder, plus_infty, minus_zero, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
12764 TEST_ff_f (remainder, plus_infty, 0, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
12765 TEST_ff_f (remainder, plus_infty, 1, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
12766 TEST_ff_f (remainder, plus_infty, 2, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
12767 TEST_ff_f (remainder, minus_infty, minus_zero, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
12768 TEST_ff_f (remainder, minus_infty, 0, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
12769 TEST_ff_f (remainder, minus_infty, 1, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
12770 TEST_ff_f (remainder, minus_infty, 2, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
12771 TEST_ff_f (remainder, qnan_value, qnan_value, qnan_value, ERRNO_UNCHANGED),
12772 TEST_ff_f (remainder, 0, qnan_value, qnan_value, ERRNO_UNCHANGED),
12773 TEST_ff_f (remainder, qnan_value, 0, qnan_value, ERRNO_UNCHANGED),
12774
12775 TEST_ff_f (remainder, 7.0, plus_infty, 7.0, ERRNO_UNCHANGED),
12776 TEST_ff_f (remainder, 7.0, minus_infty, 7.0, ERRNO_UNCHANGED),
12777
12778 TEST_ff_f (remainder, 1.625, 1.0, -0.375),
12779 TEST_ff_f (remainder, -1.625, 1.0, 0.375),
12780 TEST_ff_f (remainder, 1.625, -1.0, -0.375),
12781 TEST_ff_f (remainder, -1.625, -1.0, 0.375),
12782 TEST_ff_f (remainder, 5.0, 2.0, 1.0),
12783 TEST_ff_f (remainder, 3.0, 2.0, -1.0),
12784 END_DATA (remainder)
12785 };
12786
12787 static void
12788 remainder_test (void)
12789 {
12790 errno = 0;
12791 FUNC(remainder) (1.625, 1.0);
12792 if (errno == ENOSYS)
12793 /* Function not implemented. */
12794 return;
12795
12796 START (remainder);
12797 RUN_TEST_LOOP_ff_f (remainder, remainder_test_data, );
12798 END (remainder);
12799 }
12800
12801 static const struct test_ffI_f1_data remquo_test_data[] =
12802 {
12803 START_DATA (remquo),
12804 TEST_ffI_f1 (remquo, 1, 0, qnan_value, IGNORE, INVALID_EXCEPTION),
12805 TEST_ffI_f1 (remquo, 1, minus_zero, qnan_value, IGNORE, INVALID_EXCEPTION),
12806 TEST_ffI_f1 (remquo, plus_infty, 1, qnan_value, IGNORE, INVALID_EXCEPTION),
12807 TEST_ffI_f1 (remquo, minus_infty, 1, qnan_value, IGNORE, INVALID_EXCEPTION),
12808 TEST_ffI_f1 (remquo, qnan_value, qnan_value, qnan_value, IGNORE),
12809
12810 TEST_ffI_f1 (remquo, 1.625, 1.0, -0.375, 2),
12811 TEST_ffI_f1 (remquo, -1.625, 1.0, 0.375, -2),
12812 TEST_ffI_f1 (remquo, 1.625, -1.0, -0.375, -2),
12813 TEST_ffI_f1 (remquo, -1.625, -1.0, 0.375, 2),
12814
12815 TEST_ffI_f1 (remquo, 5, 2, 1, 2),
12816 TEST_ffI_f1 (remquo, 3, 2, -1, 2),
12817 END_DATA (remquo)
12818 };
12819
12820 static void
12821 remquo_test (void)
12822 {
12823 /* x is needed. */
12824 int x;
12825
12826 errno = 0;
12827 FUNC(remquo) (1.625, 1.0, &x);
12828 if (errno == ENOSYS)
12829 /* Function not implemented. */
12830 return;
12831
12832 START (remquo);
12833 RUN_TEST_LOOP_ffI_f1 (remquo, remquo_test_data, , x);
12834 END (remquo);
12835 }
12836
12837 static const struct test_f_f_data rint_test_data[] =
12838 {
12839 START_DATA (rint),
12840 /* TODO: missing qNaN tests. */
12841
12842 TEST_f_f (rint, 0.0, 0.0, NO_INEXACT_EXCEPTION),
12843 TEST_f_f (rint, minus_zero, minus_zero, NO_INEXACT_EXCEPTION),
12844 TEST_f_f (rint, plus_infty, plus_infty, NO_INEXACT_EXCEPTION),
12845 TEST_f_f (rint, minus_infty, minus_infty, NO_INEXACT_EXCEPTION),
12846
12847 /* Default rounding mode is round to even. */
12848 TEST_f_f (rint, 0.5, 0.0, INEXACT_EXCEPTION),
12849 TEST_f_f (rint, 1.5, 2.0, INEXACT_EXCEPTION),
12850 TEST_f_f (rint, 2.5, 2.0, INEXACT_EXCEPTION),
12851 TEST_f_f (rint, 3.5, 4.0, INEXACT_EXCEPTION),
12852 TEST_f_f (rint, 4.5, 4.0, INEXACT_EXCEPTION),
12853 TEST_f_f (rint, -0.5, -0.0, INEXACT_EXCEPTION),
12854 TEST_f_f (rint, -1.5, -2.0, INEXACT_EXCEPTION),
12855 TEST_f_f (rint, -2.5, -2.0, INEXACT_EXCEPTION),
12856 TEST_f_f (rint, -3.5, -4.0, INEXACT_EXCEPTION),
12857 TEST_f_f (rint, -4.5, -4.0, INEXACT_EXCEPTION),
12858 TEST_f_f (rint, 0.1, 0.0, INEXACT_EXCEPTION),
12859 TEST_f_f (rint, 0.25, 0.0, INEXACT_EXCEPTION),
12860 TEST_f_f (rint, 0.625, 1.0, INEXACT_EXCEPTION),
12861 TEST_f_f (rint, -0.1, -0.0, INEXACT_EXCEPTION),
12862 TEST_f_f (rint, -0.25, -0.0, INEXACT_EXCEPTION),
12863 TEST_f_f (rint, -0.625, -1.0, INEXACT_EXCEPTION),
12864 TEST_f_f (rint, 262144.75, 262145.0, INEXACT_EXCEPTION),
12865 TEST_f_f (rint, 262142.75, 262143.0, INEXACT_EXCEPTION),
12866 TEST_f_f (rint, 524286.75, 524287.0, INEXACT_EXCEPTION),
12867 TEST_f_f (rint, 524288.75, 524289.0, INEXACT_EXCEPTION),
12868 TEST_f_f (rint, 1048576.75, 1048577.0, INEXACT_EXCEPTION),
12869 TEST_f_f (rint, 2097152.75, 2097153.0, INEXACT_EXCEPTION),
12870 TEST_f_f (rint, -1048576.75, -1048577.0, INEXACT_EXCEPTION),
12871 TEST_f_f (rint, -2097152.75, -2097153.0, INEXACT_EXCEPTION),
12872 #ifndef TEST_FLOAT
12873 TEST_f_f (rint, 70368744177664.75, 70368744177665.0, INEXACT_EXCEPTION),
12874 TEST_f_f (rint, 140737488355328.75, 140737488355329.0, INEXACT_EXCEPTION),
12875 TEST_f_f (rint, 281474976710656.75, 281474976710657.0, INEXACT_EXCEPTION),
12876 TEST_f_f (rint, 562949953421312.75, 562949953421313.0, INEXACT_EXCEPTION),
12877 TEST_f_f (rint, 1125899906842624.75, 1125899906842625.0, INEXACT_EXCEPTION),
12878 TEST_f_f (rint, -70368744177664.75, -70368744177665.0, INEXACT_EXCEPTION),
12879 TEST_f_f (rint, -140737488355328.75, -140737488355329.0, INEXACT_EXCEPTION),
12880 TEST_f_f (rint, -281474976710656.75, -281474976710657.0, INEXACT_EXCEPTION),
12881 TEST_f_f (rint, -562949953421312.75, -562949953421313.0, INEXACT_EXCEPTION),
12882 TEST_f_f (rint, -1125899906842624.75, -1125899906842625.0, INEXACT_EXCEPTION),
12883 #endif
12884 #ifdef TEST_LDOUBLE
12885 /* The result can only be represented in long double. */
12886 TEST_f_f (rint, 4503599627370495.5L, 4503599627370496.0L, INEXACT_EXCEPTION),
12887 TEST_f_f (rint, 4503599627370496.25L, 4503599627370496.0L, INEXACT_EXCEPTION),
12888 TEST_f_f (rint, 4503599627370496.5L, 4503599627370496.0L, INEXACT_EXCEPTION),
12889 TEST_f_f (rint, 4503599627370496.75L, 4503599627370497.0L, INEXACT_EXCEPTION),
12890 TEST_f_f (rint, 4503599627370497.5L, 4503599627370498.0L, INEXACT_EXCEPTION),
12891
12892 # if LDBL_MANT_DIG > 100
12893 TEST_f_f (rint, 4503599627370494.5000000000001L, 4503599627370495.0L, INEXACT_EXCEPTION),
12894 TEST_f_f (rint, 4503599627370495.5000000000001L, 4503599627370496.0L, INEXACT_EXCEPTION),
12895 TEST_f_f (rint, 4503599627370496.5000000000001L, 4503599627370497.0L, INEXACT_EXCEPTION),
12896 # endif
12897
12898 TEST_f_f (rint, -4503599627370495.5L, -4503599627370496.0L, INEXACT_EXCEPTION),
12899 TEST_f_f (rint, -4503599627370496.25L, -4503599627370496.0L, INEXACT_EXCEPTION),
12900 TEST_f_f (rint, -4503599627370496.5L, -4503599627370496.0L, INEXACT_EXCEPTION),
12901 TEST_f_f (rint, -4503599627370496.75L, -4503599627370497.0L, INEXACT_EXCEPTION),
12902 TEST_f_f (rint, -4503599627370497.5L, -4503599627370498.0L, INEXACT_EXCEPTION),
12903
12904 # if LDBL_MANT_DIG > 100
12905 TEST_f_f (rint, -4503599627370494.5000000000001L, -4503599627370495.0L, INEXACT_EXCEPTION),
12906 TEST_f_f (rint, -4503599627370495.5000000000001L, -4503599627370496.0L, INEXACT_EXCEPTION),
12907 TEST_f_f (rint, -4503599627370496.5000000000001L, -4503599627370497.0L, INEXACT_EXCEPTION),
12908
12909 TEST_f_f (rint, 9007199254740991.0000000000001L, 9007199254740991.0L, INEXACT_EXCEPTION),
12910 TEST_f_f (rint, 9007199254740992.0000000000001L, 9007199254740992.0L, INEXACT_EXCEPTION),
12911 TEST_f_f (rint, 9007199254740993.0000000000001L, 9007199254740993.0L, INEXACT_EXCEPTION),
12912 TEST_f_f (rint, 9007199254740991.5000000000001L, 9007199254740992.0L, INEXACT_EXCEPTION),
12913 TEST_f_f (rint, 9007199254740992.5000000000001L, 9007199254740993.0L, INEXACT_EXCEPTION),
12914 TEST_f_f (rint, 9007199254740993.5000000000001L, 9007199254740994.0L, INEXACT_EXCEPTION),
12915
12916 TEST_f_f (rint, -9007199254740991.0000000000001L, -9007199254740991.0L, INEXACT_EXCEPTION),
12917 TEST_f_f (rint, -9007199254740992.0000000000001L, -9007199254740992.0L, INEXACT_EXCEPTION),
12918 TEST_f_f (rint, -9007199254740993.0000000000001L, -9007199254740993.0L, INEXACT_EXCEPTION),
12919 TEST_f_f (rint, -9007199254740991.5000000000001L, -9007199254740992.0L, INEXACT_EXCEPTION),
12920 TEST_f_f (rint, -9007199254740992.5000000000001L, -9007199254740993.0L, INEXACT_EXCEPTION),
12921 TEST_f_f (rint, -9007199254740993.5000000000001L, -9007199254740994.0L, INEXACT_EXCEPTION),
12922 # endif
12923
12924 TEST_f_f (rint, 9007199254740991.5L, 9007199254740992.0L, INEXACT_EXCEPTION),
12925 TEST_f_f (rint, 9007199254740992.25L, 9007199254740992.0L, INEXACT_EXCEPTION),
12926 TEST_f_f (rint, 9007199254740992.5L, 9007199254740992.0L, INEXACT_EXCEPTION),
12927 TEST_f_f (rint, 9007199254740992.75L, 9007199254740993.0L, INEXACT_EXCEPTION),
12928 TEST_f_f (rint, 9007199254740993.5L, 9007199254740994.0L, INEXACT_EXCEPTION),
12929
12930 TEST_f_f (rint, -9007199254740991.5L, -9007199254740992.0L, INEXACT_EXCEPTION),
12931 TEST_f_f (rint, -9007199254740992.25L, -9007199254740992.0L, INEXACT_EXCEPTION),
12932 TEST_f_f (rint, -9007199254740992.5L, -9007199254740992.0L, INEXACT_EXCEPTION),
12933 TEST_f_f (rint, -9007199254740992.75L, -9007199254740993.0L, INEXACT_EXCEPTION),
12934 TEST_f_f (rint, -9007199254740993.5L, -9007199254740994.0L, INEXACT_EXCEPTION),
12935
12936 TEST_f_f (rint, 72057594037927935.5L, 72057594037927936.0L, INEXACT_EXCEPTION),
12937 TEST_f_f (rint, 72057594037927936.25L, 72057594037927936.0L, INEXACT_EXCEPTION),
12938 TEST_f_f (rint, 72057594037927936.5L, 72057594037927936.0L, INEXACT_EXCEPTION),
12939 TEST_f_f (rint, 72057594037927936.75L, 72057594037927937.0L, INEXACT_EXCEPTION),
12940 TEST_f_f (rint, 72057594037927937.5L, 72057594037927938.0L, INEXACT_EXCEPTION),
12941
12942 TEST_f_f (rint, -72057594037927935.5L, -72057594037927936.0L, INEXACT_EXCEPTION),
12943 TEST_f_f (rint, -72057594037927936.25L, -72057594037927936.0L, INEXACT_EXCEPTION),
12944 TEST_f_f (rint, -72057594037927936.5L, -72057594037927936.0L, INEXACT_EXCEPTION),
12945 TEST_f_f (rint, -72057594037927936.75L, -72057594037927937.0L, INEXACT_EXCEPTION),
12946 TEST_f_f (rint, -72057594037927937.5L, -72057594037927938.0L, INEXACT_EXCEPTION),
12947
12948 # if LDBL_MANT_DIG > 100
12949 TEST_f_f (rint, 10141204801825835211973625643007.5L, 10141204801825835211973625643008.0L, INEXACT_EXCEPTION),
12950 TEST_f_f (rint, 10141204801825835211973625643008.25L, 10141204801825835211973625643008.0L, INEXACT_EXCEPTION),
12951 TEST_f_f (rint, 10141204801825835211973625643008.5L, 10141204801825835211973625643008.0L, INEXACT_EXCEPTION),
12952 TEST_f_f (rint, 10141204801825835211973625643008.75L, 10141204801825835211973625643009.0L, INEXACT_EXCEPTION),
12953 TEST_f_f (rint, 10141204801825835211973625643009.5L, 10141204801825835211973625643010.0L, INEXACT_EXCEPTION),
12954 # endif
12955 #endif
12956 END_DATA (rint)
12957 };
12958
12959 static void
12960 rint_test (void)
12961 {
12962 START (rint);
12963 RUN_TEST_LOOP_f_f (rint, rint_test_data, );
12964 END (rint);
12965 }
12966
12967 static const struct test_f_f_data rint_tonearest_test_data[] =
12968 {
12969 START_DATA (rint_tonearest),
12970 TEST_f_f (rint, 2.0, 2.0, NO_INEXACT_EXCEPTION),
12971 TEST_f_f (rint, 1.5, 2.0, INEXACT_EXCEPTION),
12972 TEST_f_f (rint, 1.0, 1.0, NO_INEXACT_EXCEPTION),
12973 TEST_f_f (rint, 0.5, 0.0, INEXACT_EXCEPTION),
12974 TEST_f_f (rint, 0.0, 0.0, NO_INEXACT_EXCEPTION),
12975 TEST_f_f (rint, minus_zero, minus_zero, NO_INEXACT_EXCEPTION),
12976 TEST_f_f (rint, -0.5, -0.0, INEXACT_EXCEPTION),
12977 TEST_f_f (rint, -1.0, -1.0, NO_INEXACT_EXCEPTION),
12978 TEST_f_f (rint, -1.5, -2.0, INEXACT_EXCEPTION),
12979 TEST_f_f (rint, -2.0, -2.0, NO_INEXACT_EXCEPTION),
12980 TEST_f_f (rint, 0.1, 0.0, INEXACT_EXCEPTION),
12981 TEST_f_f (rint, 0.25, 0.0, INEXACT_EXCEPTION),
12982 TEST_f_f (rint, 0.625, 1.0, INEXACT_EXCEPTION),
12983 TEST_f_f (rint, -0.1, -0.0, INEXACT_EXCEPTION),
12984 TEST_f_f (rint, -0.25, -0.0, INEXACT_EXCEPTION),
12985 TEST_f_f (rint, -0.625, -1.0, INEXACT_EXCEPTION),
12986 TEST_f_f (rint, 1048576.75, 1048577.0, INEXACT_EXCEPTION),
12987 TEST_f_f (rint, 2097152.75, 2097153.0, INEXACT_EXCEPTION),
12988 TEST_f_f (rint, -1048576.75, -1048577.0, INEXACT_EXCEPTION),
12989 TEST_f_f (rint, -2097152.75, -2097153.0, INEXACT_EXCEPTION),
12990 #ifndef TEST_FLOAT
12991 TEST_f_f (rint, 70368744177664.75, 70368744177665.0, INEXACT_EXCEPTION),
12992 TEST_f_f (rint, 140737488355328.75, 140737488355329.0, INEXACT_EXCEPTION),
12993 TEST_f_f (rint, 281474976710656.75, 281474976710657.0, INEXACT_EXCEPTION),
12994 TEST_f_f (rint, 562949953421312.75, 562949953421313.0, INEXACT_EXCEPTION),
12995 TEST_f_f (rint, 1125899906842624.75, 1125899906842625.0, INEXACT_EXCEPTION),
12996 TEST_f_f (rint, -70368744177664.75, -70368744177665.0, INEXACT_EXCEPTION),
12997 TEST_f_f (rint, -140737488355328.75, -140737488355329.0, INEXACT_EXCEPTION),
12998 TEST_f_f (rint, -281474976710656.75, -281474976710657.0, INEXACT_EXCEPTION),
12999 TEST_f_f (rint, -562949953421312.75, -562949953421313.0, INEXACT_EXCEPTION),
13000 TEST_f_f (rint, -1125899906842624.75, -1125899906842625.0, INEXACT_EXCEPTION),
13001 #endif
13002 #ifdef TEST_LDOUBLE
13003 /* The result can only be represented in long double. */
13004 TEST_f_f (rint, 4503599627370495.5L, 4503599627370496.0L, INEXACT_EXCEPTION),
13005 TEST_f_f (rint, 4503599627370496.25L, 4503599627370496.0L, INEXACT_EXCEPTION),
13006 TEST_f_f (rint, 4503599627370496.5L, 4503599627370496.0L, INEXACT_EXCEPTION),
13007 TEST_f_f (rint, 4503599627370496.75L, 4503599627370497.0L, INEXACT_EXCEPTION),
13008 TEST_f_f (rint, 4503599627370497.5L, 4503599627370498.0L, INEXACT_EXCEPTION),
13009 # if LDBL_MANT_DIG > 100
13010 TEST_f_f (rint, 4503599627370494.5000000000001L, 4503599627370495.0L, INEXACT_EXCEPTION),
13011 TEST_f_f (rint, 4503599627370495.5000000000001L, 4503599627370496.0L, INEXACT_EXCEPTION),
13012 TEST_f_f (rint, 4503599627370496.5000000000001L, 4503599627370497.0L, INEXACT_EXCEPTION),
13013 # endif
13014 TEST_f_f (rint, -4503599627370495.5L, -4503599627370496.0L, INEXACT_EXCEPTION),
13015 TEST_f_f (rint, -4503599627370496.25L, -4503599627370496.0L, INEXACT_EXCEPTION),
13016 TEST_f_f (rint, -4503599627370496.5L, -4503599627370496.0L, INEXACT_EXCEPTION),
13017 TEST_f_f (rint, -4503599627370496.75L, -4503599627370497.0L, INEXACT_EXCEPTION),
13018 TEST_f_f (rint, -4503599627370497.5L, -4503599627370498.0L, INEXACT_EXCEPTION),
13019 # if LDBL_MANT_DIG > 100
13020 TEST_f_f (rint, -4503599627370494.5000000000001L, -4503599627370495.0L, INEXACT_EXCEPTION),
13021 TEST_f_f (rint, -4503599627370495.5000000000001L, -4503599627370496.0L, INEXACT_EXCEPTION),
13022 TEST_f_f (rint, -4503599627370496.5000000000001L, -4503599627370497.0L, INEXACT_EXCEPTION),
13023
13024 TEST_f_f (rint, 9007199254740991.0000000000001L, 9007199254740991.0L, INEXACT_EXCEPTION),
13025 TEST_f_f (rint, 9007199254740992.0000000000001L, 9007199254740992.0L, INEXACT_EXCEPTION),
13026 TEST_f_f (rint, 9007199254740993.0000000000001L, 9007199254740993.0L, INEXACT_EXCEPTION),
13027 TEST_f_f (rint, 9007199254740991.5000000000001L, 9007199254740992.0L, INEXACT_EXCEPTION),
13028 TEST_f_f (rint, 9007199254740992.5000000000001L, 9007199254740993.0L, INEXACT_EXCEPTION),
13029 TEST_f_f (rint, 9007199254740993.5000000000001L, 9007199254740994.0L, INEXACT_EXCEPTION),
13030
13031 TEST_f_f (rint, -9007199254740991.0000000000001L, -9007199254740991.0L, INEXACT_EXCEPTION),
13032 TEST_f_f (rint, -9007199254740992.0000000000001L, -9007199254740992.0L, INEXACT_EXCEPTION),
13033 TEST_f_f (rint, -9007199254740993.0000000000001L, -9007199254740993.0L, INEXACT_EXCEPTION),
13034 TEST_f_f (rint, -9007199254740991.5000000000001L, -9007199254740992.0L, INEXACT_EXCEPTION),
13035 TEST_f_f (rint, -9007199254740992.5000000000001L, -9007199254740993.0L, INEXACT_EXCEPTION),
13036 TEST_f_f (rint, -9007199254740993.5000000000001L, -9007199254740994.0L, INEXACT_EXCEPTION),
13037 # endif
13038 #endif
13039 END_DATA (rint_tonearest)
13040 };
13041
13042 static void
13043 rint_test_tonearest (void)
13044 {
13045 START (rint_tonearest);
13046 RUN_TEST_LOOP_f_f (rint, rint_tonearest_test_data, FE_TONEAREST);
13047 END (rint_tonearest);
13048 }
13049
13050 static const struct test_f_f_data rint_towardzero_test_data[] =
13051 {
13052 START_DATA (rint_towardzero),
13053 TEST_f_f (rint, 2.0, 2.0, NO_INEXACT_EXCEPTION),
13054 TEST_f_f (rint, 1.5, 1.0, INEXACT_EXCEPTION),
13055 TEST_f_f (rint, 1.0, 1.0, NO_INEXACT_EXCEPTION),
13056 TEST_f_f (rint, 0.5, 0.0, INEXACT_EXCEPTION),
13057 TEST_f_f (rint, 0.0, 0.0, NO_INEXACT_EXCEPTION),
13058 TEST_f_f (rint, minus_zero, minus_zero, NO_INEXACT_EXCEPTION),
13059 TEST_f_f (rint, -0.5, -0.0, INEXACT_EXCEPTION),
13060 TEST_f_f (rint, -1.0, -1.0, NO_INEXACT_EXCEPTION),
13061 TEST_f_f (rint, -1.5, -1.0, INEXACT_EXCEPTION),
13062 TEST_f_f (rint, -2.0, -2.0, NO_INEXACT_EXCEPTION),
13063 TEST_f_f (rint, 0.1, 0.0, INEXACT_EXCEPTION),
13064 TEST_f_f (rint, 0.25, 0.0, INEXACT_EXCEPTION),
13065 TEST_f_f (rint, 0.625, 0.0, INEXACT_EXCEPTION),
13066 TEST_f_f (rint, -0.1, -0.0, INEXACT_EXCEPTION),
13067 TEST_f_f (rint, -0.25, -0.0, INEXACT_EXCEPTION),
13068 TEST_f_f (rint, -0.625, -0.0, INEXACT_EXCEPTION),
13069 TEST_f_f (rint, 1048576.75, 1048576.0, INEXACT_EXCEPTION),
13070 TEST_f_f (rint, 2097152.75, 2097152.0, INEXACT_EXCEPTION),
13071 TEST_f_f (rint, -1048576.75, -1048576.0, INEXACT_EXCEPTION),
13072 TEST_f_f (rint, -2097152.75, -2097152.0, INEXACT_EXCEPTION),
13073 #ifndef TEST_FLOAT
13074 TEST_f_f (rint, 70368744177664.75, 70368744177664.0, INEXACT_EXCEPTION),
13075 TEST_f_f (rint, 140737488355328.75, 140737488355328.0, INEXACT_EXCEPTION),
13076 TEST_f_f (rint, 281474976710656.75, 281474976710656.0, INEXACT_EXCEPTION),
13077 TEST_f_f (rint, 562949953421312.75, 562949953421312.0, INEXACT_EXCEPTION),
13078 TEST_f_f (rint, 1125899906842624.75, 1125899906842624.0, INEXACT_EXCEPTION),
13079 TEST_f_f (rint, -70368744177664.75, -70368744177664.0, INEXACT_EXCEPTION),
13080 TEST_f_f (rint, -140737488355328.75, -140737488355328.0, INEXACT_EXCEPTION),
13081 TEST_f_f (rint, -281474976710656.75, -281474976710656.0, INEXACT_EXCEPTION),
13082 TEST_f_f (rint, -562949953421312.75, -562949953421312.0, INEXACT_EXCEPTION),
13083 TEST_f_f (rint, -1125899906842624.75, -1125899906842624.0, INEXACT_EXCEPTION),
13084 #endif
13085 #ifdef TEST_LDOUBLE
13086 /* The result can only be represented in long double. */
13087 TEST_f_f (rint, 4503599627370495.5L, 4503599627370495.0L, INEXACT_EXCEPTION),
13088 TEST_f_f (rint, 4503599627370496.25L, 4503599627370496.0L, INEXACT_EXCEPTION),
13089 TEST_f_f (rint, 4503599627370496.5L, 4503599627370496.0L, INEXACT_EXCEPTION),
13090 TEST_f_f (rint, 4503599627370496.75L, 4503599627370496.0L, INEXACT_EXCEPTION),
13091 TEST_f_f (rint, 4503599627370497.5L, 4503599627370497.0L, INEXACT_EXCEPTION),
13092 # if LDBL_MANT_DIG > 100
13093 TEST_f_f (rint, 4503599627370494.5000000000001L, 4503599627370494.0L, INEXACT_EXCEPTION),
13094 TEST_f_f (rint, 4503599627370495.5000000000001L, 4503599627370495.0L, INEXACT_EXCEPTION),
13095 TEST_f_f (rint, 4503599627370496.5000000000001L, 4503599627370496.0L, INEXACT_EXCEPTION),
13096 # endif
13097 TEST_f_f (rint, -4503599627370495.5L, -4503599627370495.0L, INEXACT_EXCEPTION),
13098 TEST_f_f (rint, -4503599627370496.25L, -4503599627370496.0L, INEXACT_EXCEPTION),
13099 TEST_f_f (rint, -4503599627370496.5L, -4503599627370496.0L, INEXACT_EXCEPTION),
13100 TEST_f_f (rint, -4503599627370496.75L, -4503599627370496.0L, INEXACT_EXCEPTION),
13101 TEST_f_f (rint, -4503599627370497.5L, -4503599627370497.0L, INEXACT_EXCEPTION),
13102 # if LDBL_MANT_DIG > 100
13103 TEST_f_f (rint, -4503599627370494.5000000000001L, -4503599627370494.0L, INEXACT_EXCEPTION),
13104 TEST_f_f (rint, -4503599627370495.5000000000001L, -4503599627370495.0L, INEXACT_EXCEPTION),
13105 TEST_f_f (rint, -4503599627370496.5000000000001L, -4503599627370496.0L, INEXACT_EXCEPTION),
13106
13107 TEST_f_f (rint, 9007199254740991.0000000000001L, 9007199254740991.0L, INEXACT_EXCEPTION),
13108 TEST_f_f (rint, 9007199254740992.0000000000001L, 9007199254740992.0L, INEXACT_EXCEPTION),
13109 TEST_f_f (rint, 9007199254740993.0000000000001L, 9007199254740993.0L, INEXACT_EXCEPTION),
13110 TEST_f_f (rint, 9007199254740991.5000000000001L, 9007199254740991.0L, INEXACT_EXCEPTION),
13111 TEST_f_f (rint, 9007199254740992.5000000000001L, 9007199254740992.0L, INEXACT_EXCEPTION),
13112 TEST_f_f (rint, 9007199254740993.5000000000001L, 9007199254740993.0L, INEXACT_EXCEPTION),
13113
13114 TEST_f_f (rint, -9007199254740991.0000000000001L, -9007199254740991.0L, INEXACT_EXCEPTION),
13115 TEST_f_f (rint, -9007199254740992.0000000000001L, -9007199254740992.0L, INEXACT_EXCEPTION),
13116 TEST_f_f (rint, -9007199254740993.0000000000001L, -9007199254740993.0L, INEXACT_EXCEPTION),
13117 TEST_f_f (rint, -9007199254740991.5000000000001L, -9007199254740991.0L, INEXACT_EXCEPTION),
13118 TEST_f_f (rint, -9007199254740992.5000000000001L, -9007199254740992.0L, INEXACT_EXCEPTION),
13119 TEST_f_f (rint, -9007199254740993.5000000000001L, -9007199254740993.0L, INEXACT_EXCEPTION),
13120 # endif
13121 #endif
13122 END_DATA (rint_towardzero)
13123 };
13124
13125 static void
13126 rint_test_towardzero (void)
13127 {
13128 START (rint_towardzero);
13129 RUN_TEST_LOOP_f_f (rint, rint_towardzero_test_data, FE_TOWARDZERO);
13130 END (rint_towardzero);
13131 }
13132
13133 static const struct test_f_f_data rint_downward_test_data[] =
13134 {
13135 START_DATA (rint_downward),
13136 TEST_f_f (rint, 2.0, 2.0, NO_INEXACT_EXCEPTION),
13137 TEST_f_f (rint, 1.5, 1.0, INEXACT_EXCEPTION),
13138 TEST_f_f (rint, 1.0, 1.0, NO_INEXACT_EXCEPTION),
13139 TEST_f_f (rint, 0.5, 0.0, INEXACT_EXCEPTION),
13140 TEST_f_f (rint, 0.0, 0.0, NO_INEXACT_EXCEPTION),
13141 TEST_f_f (rint, minus_zero, minus_zero, NO_INEXACT_EXCEPTION),
13142 TEST_f_f (rint, -0.5, -1.0, INEXACT_EXCEPTION),
13143 TEST_f_f (rint, -1.0, -1.0, NO_INEXACT_EXCEPTION),
13144 TEST_f_f (rint, -1.5, -2.0, INEXACT_EXCEPTION),
13145 TEST_f_f (rint, -2.0, -2.0, NO_INEXACT_EXCEPTION),
13146 TEST_f_f (rint, 0.1, 0.0, INEXACT_EXCEPTION),
13147 TEST_f_f (rint, 0.25, 0.0, INEXACT_EXCEPTION),
13148 TEST_f_f (rint, 0.625, 0.0, INEXACT_EXCEPTION),
13149 TEST_f_f (rint, -0.1, -1.0, INEXACT_EXCEPTION),
13150 TEST_f_f (rint, -0.25, -1.0, INEXACT_EXCEPTION),
13151 TEST_f_f (rint, -0.625, -1.0, INEXACT_EXCEPTION),
13152 TEST_f_f (rint, 1048576.75, 1048576.0, INEXACT_EXCEPTION),
13153 TEST_f_f (rint, 2097152.75, 2097152.0, INEXACT_EXCEPTION),
13154 TEST_f_f (rint, -1048576.75, -1048577.0, INEXACT_EXCEPTION),
13155 TEST_f_f (rint, -2097152.75, -2097153.0, INEXACT_EXCEPTION),
13156 #ifndef TEST_FLOAT
13157 TEST_f_f (rint, 70368744177664.75, 70368744177664.0, INEXACT_EXCEPTION),
13158 TEST_f_f (rint, 140737488355328.75, 140737488355328.0, INEXACT_EXCEPTION),
13159 TEST_f_f (rint, 281474976710656.75, 281474976710656.0, INEXACT_EXCEPTION),
13160 TEST_f_f (rint, 562949953421312.75, 562949953421312.0, INEXACT_EXCEPTION),
13161 TEST_f_f (rint, 1125899906842624.75, 1125899906842624.0, INEXACT_EXCEPTION),
13162 TEST_f_f (rint, -70368744177664.75, -70368744177665.0, INEXACT_EXCEPTION),
13163 TEST_f_f (rint, -140737488355328.75, -140737488355329.0, INEXACT_EXCEPTION),
13164 TEST_f_f (rint, -281474976710656.75, -281474976710657.0, INEXACT_EXCEPTION),
13165 TEST_f_f (rint, -562949953421312.75, -562949953421313.0, INEXACT_EXCEPTION),
13166 TEST_f_f (rint, -1125899906842624.75, -1125899906842625.0, INEXACT_EXCEPTION),
13167 #endif
13168 #ifdef TEST_LDOUBLE
13169 /* The result can only be represented in long double. */
13170 TEST_f_f (rint, 4503599627370495.5L, 4503599627370495.0L, INEXACT_EXCEPTION),
13171 TEST_f_f (rint, 4503599627370496.25L, 4503599627370496.0L, INEXACT_EXCEPTION),
13172 TEST_f_f (rint, 4503599627370496.5L, 4503599627370496.0L, INEXACT_EXCEPTION),
13173 TEST_f_f (rint, 4503599627370496.75L, 4503599627370496.0L, INEXACT_EXCEPTION),
13174 TEST_f_f (rint, 4503599627370497.5L, 4503599627370497.0L, INEXACT_EXCEPTION),
13175 # if LDBL_MANT_DIG > 100
13176 TEST_f_f (rint, 4503599627370494.5000000000001L, 4503599627370494.0L, INEXACT_EXCEPTION),
13177 TEST_f_f (rint, 4503599627370495.5000000000001L, 4503599627370495.0L, INEXACT_EXCEPTION),
13178 TEST_f_f (rint, 4503599627370496.5000000000001L, 4503599627370496.0L, INEXACT_EXCEPTION),
13179 # endif
13180 TEST_f_f (rint, -4503599627370495.5L, -4503599627370496.0L, INEXACT_EXCEPTION),
13181 TEST_f_f (rint, -4503599627370496.25L, -4503599627370497.0L, INEXACT_EXCEPTION),
13182 TEST_f_f (rint, -4503599627370496.5L, -4503599627370497.0L, INEXACT_EXCEPTION),
13183 TEST_f_f (rint, -4503599627370496.75L, -4503599627370497.0L, INEXACT_EXCEPTION),
13184 TEST_f_f (rint, -4503599627370497.5L, -4503599627370498.0L, INEXACT_EXCEPTION),
13185 # if LDBL_MANT_DIG > 100
13186 TEST_f_f (rint, -4503599627370494.5000000000001L, -4503599627370495.0L, INEXACT_EXCEPTION),
13187 TEST_f_f (rint, -4503599627370495.5000000000001L, -4503599627370496.0L, INEXACT_EXCEPTION),
13188 TEST_f_f (rint, -4503599627370496.5000000000001L, -4503599627370497.0L, INEXACT_EXCEPTION),
13189
13190 TEST_f_f (rint, 9007199254740991.0000000000001L, 9007199254740991.0L, INEXACT_EXCEPTION),
13191 TEST_f_f (rint, 9007199254740992.0000000000001L, 9007199254740992.0L, INEXACT_EXCEPTION),
13192 TEST_f_f (rint, 9007199254740993.0000000000001L, 9007199254740993.0L, INEXACT_EXCEPTION),
13193 TEST_f_f (rint, 9007199254740991.5000000000001L, 9007199254740991.0L, INEXACT_EXCEPTION),
13194 TEST_f_f (rint, 9007199254740992.5000000000001L, 9007199254740992.0L, INEXACT_EXCEPTION),
13195 TEST_f_f (rint, 9007199254740993.5000000000001L, 9007199254740993.0L, INEXACT_EXCEPTION),
13196
13197 TEST_f_f (rint, -9007199254740991.0000000000001L, -9007199254740992.0L, INEXACT_EXCEPTION),
13198 TEST_f_f (rint, -9007199254740992.0000000000001L, -9007199254740993.0L, INEXACT_EXCEPTION),
13199 TEST_f_f (rint, -9007199254740993.0000000000001L, -9007199254740994.0L, INEXACT_EXCEPTION),
13200 TEST_f_f (rint, -9007199254740991.5000000000001L, -9007199254740992.0L, INEXACT_EXCEPTION),
13201 TEST_f_f (rint, -9007199254740992.5000000000001L, -9007199254740993.0L, INEXACT_EXCEPTION),
13202 TEST_f_f (rint, -9007199254740993.5000000000001L, -9007199254740994.0L, INEXACT_EXCEPTION),
13203 # endif
13204 #endif
13205 END_DATA (rint_downward)
13206 };
13207
13208 static void
13209 rint_test_downward (void)
13210 {
13211 START (rint_downward);
13212 RUN_TEST_LOOP_f_f (rint, rint_downward_test_data, FE_DOWNWARD);
13213 END (rint_downward);
13214 }
13215
13216 static const struct test_f_f_data rint_upward_test_data[] =
13217 {
13218 START_DATA (rint_upward),
13219 TEST_f_f (rint, 2.0, 2.0, NO_INEXACT_EXCEPTION),
13220 TEST_f_f (rint, 1.5, 2.0, INEXACT_EXCEPTION),
13221 TEST_f_f (rint, 1.0, 1.0, NO_INEXACT_EXCEPTION),
13222 TEST_f_f (rint, 0.5, 1.0, INEXACT_EXCEPTION),
13223 TEST_f_f (rint, 0.0, 0.0, NO_INEXACT_EXCEPTION),
13224 TEST_f_f (rint, minus_zero, minus_zero, NO_INEXACT_EXCEPTION),
13225 TEST_f_f (rint, -0.5, -0.0, INEXACT_EXCEPTION),
13226 TEST_f_f (rint, -1.0, -1.0, NO_INEXACT_EXCEPTION),
13227 TEST_f_f (rint, -1.5, -1.0, INEXACT_EXCEPTION),
13228 TEST_f_f (rint, -2.0, -2.0, NO_INEXACT_EXCEPTION),
13229 TEST_f_f (rint, 0.1, 1.0, INEXACT_EXCEPTION),
13230 TEST_f_f (rint, 0.25, 1.0, INEXACT_EXCEPTION),
13231 TEST_f_f (rint, 0.625, 1.0, INEXACT_EXCEPTION),
13232 TEST_f_f (rint, -0.1, -0.0, INEXACT_EXCEPTION),
13233 TEST_f_f (rint, -0.25, -0.0, INEXACT_EXCEPTION),
13234 TEST_f_f (rint, -0.625, -0.0, INEXACT_EXCEPTION),
13235 TEST_f_f (rint, 1048576.75, 1048577.0, INEXACT_EXCEPTION),
13236 TEST_f_f (rint, 2097152.75, 2097153.0, INEXACT_EXCEPTION),
13237 TEST_f_f (rint, -1048576.75, -1048576.0, INEXACT_EXCEPTION),
13238 TEST_f_f (rint, -2097152.75, -2097152.0, INEXACT_EXCEPTION),
13239 #ifndef TEST_FLOAT
13240 TEST_f_f (rint, 70368744177664.75, 70368744177665.0, INEXACT_EXCEPTION),
13241 TEST_f_f (rint, 140737488355328.75, 140737488355329.0, INEXACT_EXCEPTION),
13242 TEST_f_f (rint, 281474976710656.75, 281474976710657.0, INEXACT_EXCEPTION),
13243 TEST_f_f (rint, 562949953421312.75, 562949953421313.0, INEXACT_EXCEPTION),
13244 TEST_f_f (rint, 1125899906842624.75, 1125899906842625.0, INEXACT_EXCEPTION),
13245 TEST_f_f (rint, -70368744177664.75, -70368744177664.0, INEXACT_EXCEPTION),
13246 TEST_f_f (rint, -140737488355328.75, -140737488355328.0, INEXACT_EXCEPTION),
13247 TEST_f_f (rint, -281474976710656.75, -281474976710656.0, INEXACT_EXCEPTION),
13248 TEST_f_f (rint, -562949953421312.75, -562949953421312.0, INEXACT_EXCEPTION),
13249 TEST_f_f (rint, -1125899906842624.75, -1125899906842624.0, INEXACT_EXCEPTION),
13250 #endif
13251 #ifdef TEST_LDOUBLE
13252 /* The result can only be represented in long double. */
13253 TEST_f_f (rint, 4503599627370495.5L, 4503599627370496.0L, INEXACT_EXCEPTION),
13254 TEST_f_f (rint, 4503599627370496.25L, 4503599627370497.0L, INEXACT_EXCEPTION),
13255 TEST_f_f (rint, 4503599627370496.5L, 4503599627370497.0L, INEXACT_EXCEPTION),
13256 TEST_f_f (rint, 4503599627370496.75L, 4503599627370497.0L, INEXACT_EXCEPTION),
13257 TEST_f_f (rint, 4503599627370497.5L, 4503599627370498.0L, INEXACT_EXCEPTION),
13258 # if LDBL_MANT_DIG > 100
13259 TEST_f_f (rint, 4503599627370494.5000000000001L, 4503599627370495.0L, INEXACT_EXCEPTION),
13260 TEST_f_f (rint, 4503599627370495.5000000000001L, 4503599627370496.0L, INEXACT_EXCEPTION),
13261 TEST_f_f (rint, 4503599627370496.5000000000001L, 4503599627370497.0L, INEXACT_EXCEPTION),
13262 # endif
13263 TEST_f_f (rint, -4503599627370495.5L, -4503599627370495.0L, INEXACT_EXCEPTION),
13264 TEST_f_f (rint, -4503599627370496.25L, -4503599627370496.0L, INEXACT_EXCEPTION),
13265 TEST_f_f (rint, -4503599627370496.5L, -4503599627370496.0L, INEXACT_EXCEPTION),
13266 TEST_f_f (rint, -4503599627370496.75L, -4503599627370496.0L, INEXACT_EXCEPTION),
13267 TEST_f_f (rint, -4503599627370497.5L, -4503599627370497.0L, INEXACT_EXCEPTION),
13268 # if LDBL_MANT_DIG > 100
13269 TEST_f_f (rint, -4503599627370494.5000000000001L, -4503599627370494.0L, INEXACT_EXCEPTION),
13270 TEST_f_f (rint, -4503599627370495.5000000000001L, -4503599627370495.0L, INEXACT_EXCEPTION),
13271 TEST_f_f (rint, -4503599627370496.5000000000001L, -4503599627370496.0L, INEXACT_EXCEPTION),
13272
13273 TEST_f_f (rint, 9007199254740991.0000000000001L, 9007199254740992.0L, INEXACT_EXCEPTION),
13274 TEST_f_f (rint, 9007199254740992.0000000000001L, 9007199254740993.0L, INEXACT_EXCEPTION),
13275 TEST_f_f (rint, 9007199254740993.0000000000001L, 9007199254740994.0L, INEXACT_EXCEPTION),
13276 TEST_f_f (rint, 9007199254740991.5000000000001L, 9007199254740992.0L, INEXACT_EXCEPTION),
13277 TEST_f_f (rint, 9007199254740992.5000000000001L, 9007199254740993.0L, INEXACT_EXCEPTION),
13278 TEST_f_f (rint, 9007199254740993.5000000000001L, 9007199254740994.0L, INEXACT_EXCEPTION),
13279
13280 TEST_f_f (rint, -9007199254740991.0000000000001L, -9007199254740991.0L, INEXACT_EXCEPTION),
13281 TEST_f_f (rint, -9007199254740992.0000000000001L, -9007199254740992.0L, INEXACT_EXCEPTION),
13282 TEST_f_f (rint, -9007199254740993.0000000000001L, -9007199254740993.0L, INEXACT_EXCEPTION),
13283 TEST_f_f (rint, -9007199254740991.5000000000001L, -9007199254740991.0L, INEXACT_EXCEPTION),
13284 TEST_f_f (rint, -9007199254740992.5000000000001L, -9007199254740992.0L, INEXACT_EXCEPTION),
13285 TEST_f_f (rint, -9007199254740993.5000000000001L, -9007199254740993.0L, INEXACT_EXCEPTION),
13286 # endif
13287 #endif
13288 END_DATA (rint_upward)
13289 };
13290
13291 static void
13292 rint_test_upward (void)
13293 {
13294 START (rint_upward);
13295 RUN_TEST_LOOP_f_f (rint, rint_upward_test_data, FE_UPWARD);
13296 END (rint_upward);
13297 }
13298
13299 static const struct test_f_f_data round_test_data[] =
13300 {
13301 START_DATA (round),
13302 /* TODO: missing +/-Inf as well as qNaN tests. */
13303
13304 TEST_f_f (round, 0, 0),
13305 TEST_f_f (round, minus_zero, minus_zero),
13306 TEST_f_f (round, 0.2L, 0.0),
13307 TEST_f_f (round, -0.2L, minus_zero),
13308 TEST_f_f (round, 0.5, 1.0),
13309 TEST_f_f (round, -0.5, -1.0),
13310 TEST_f_f (round, 0.8L, 1.0),
13311 TEST_f_f (round, -0.8L, -1.0),
13312 TEST_f_f (round, 1.5, 2.0),
13313 TEST_f_f (round, -1.5, -2.0),
13314 TEST_f_f (round, 0.1, 0.0),
13315 TEST_f_f (round, 0.25, 0.0),
13316 TEST_f_f (round, 0.625, 1.0),
13317 TEST_f_f (round, -0.1, -0.0),
13318 TEST_f_f (round, -0.25, -0.0),
13319 TEST_f_f (round, -0.625, -1.0),
13320 TEST_f_f (round, 2097152.5, 2097153),
13321 TEST_f_f (round, -2097152.5, -2097153),
13322
13323 #ifdef TEST_LDOUBLE
13324 /* The result can only be represented in long double. */
13325 TEST_f_f (round, 4503599627370495.5L, 4503599627370496.0L),
13326 TEST_f_f (round, 4503599627370496.25L, 4503599627370496.0L),
13327 TEST_f_f (round, 4503599627370496.5L, 4503599627370497.0L),
13328 TEST_f_f (round, 4503599627370496.75L, 4503599627370497.0L),
13329 TEST_f_f (round, 4503599627370497.5L, 4503599627370498.0L),
13330 # if LDBL_MANT_DIG > 100
13331 TEST_f_f (round, 4503599627370494.5000000000001L, 4503599627370495.0L),
13332 TEST_f_f (round, 4503599627370495.5000000000001L, 4503599627370496.0L),
13333 TEST_f_f (round, 4503599627370496.5000000000001L, 4503599627370497.0L),
13334 # endif
13335
13336 TEST_f_f (round, -4503599627370495.5L, -4503599627370496.0L),
13337 TEST_f_f (round, -4503599627370496.25L, -4503599627370496.0L),
13338 TEST_f_f (round, -4503599627370496.5L, -4503599627370497.0L),
13339 TEST_f_f (round, -4503599627370496.75L, -4503599627370497.0L),
13340 TEST_f_f (round, -4503599627370497.5L, -4503599627370498.0L),
13341 # if LDBL_MANT_DIG > 100
13342 TEST_f_f (round, -4503599627370494.5000000000001L, -4503599627370495.0L),
13343 TEST_f_f (round, -4503599627370495.5000000000001L, -4503599627370496.0L),
13344 TEST_f_f (round, -4503599627370496.5000000000001L, -4503599627370497.0L),
13345 # endif
13346
13347 TEST_f_f (round, 9007199254740991.5L, 9007199254740992.0L),
13348 TEST_f_f (round, 9007199254740992.25L, 9007199254740992.0L),
13349 TEST_f_f (round, 9007199254740992.5L, 9007199254740993.0L),
13350 TEST_f_f (round, 9007199254740992.75L, 9007199254740993.0L),
13351 TEST_f_f (round, 9007199254740993.5L, 9007199254740994.0L),
13352
13353 TEST_f_f (round, -9007199254740991.5L, -9007199254740992.0L),
13354 TEST_f_f (round, -9007199254740992.25L, -9007199254740992.0L),
13355 TEST_f_f (round, -9007199254740992.5L, -9007199254740993.0L),
13356 TEST_f_f (round, -9007199254740992.75L, -9007199254740993.0L),
13357 TEST_f_f (round, -9007199254740993.5L, -9007199254740994.0L),
13358
13359 # if LDBL_MANT_DIG > 100
13360 TEST_f_f (round, 9007199254740991.0000000000001L, 9007199254740991.0L),
13361 TEST_f_f (round, 9007199254740992.0000000000001L, 9007199254740992.0L),
13362 TEST_f_f (round, 9007199254740993.0000000000001L, 9007199254740993.0L),
13363 TEST_f_f (round, 9007199254740991.5000000000001L, 9007199254740992.0L),
13364 TEST_f_f (round, 9007199254740992.5000000000001L, 9007199254740993.0L),
13365 TEST_f_f (round, 9007199254740993.5000000000001L, 9007199254740994.0L),
13366
13367 TEST_f_f (round, -9007199254740991.0000000000001L, -9007199254740991.0L),
13368 TEST_f_f (round, -9007199254740992.0000000000001L, -9007199254740992.0L),
13369 TEST_f_f (round, -9007199254740993.0000000000001L, -9007199254740993.0L),
13370 TEST_f_f (round, -9007199254740991.5000000000001L, -9007199254740992.0L),
13371 TEST_f_f (round, -9007199254740992.5000000000001L, -9007199254740993.0L),
13372 TEST_f_f (round, -9007199254740993.5000000000001L, -9007199254740994.0L),
13373 # endif
13374
13375 TEST_f_f (round, 72057594037927935.5L, 72057594037927936.0L),
13376 TEST_f_f (round, 72057594037927936.25L, 72057594037927936.0L),
13377 TEST_f_f (round, 72057594037927936.5L, 72057594037927937.0L),
13378 TEST_f_f (round, 72057594037927936.75L, 72057594037927937.0L),
13379 TEST_f_f (round, 72057594037927937.5L, 72057594037927938.0L),
13380
13381 TEST_f_f (round, -72057594037927935.5L, -72057594037927936.0L),
13382 TEST_f_f (round, -72057594037927936.25L, -72057594037927936.0L),
13383 TEST_f_f (round, -72057594037927936.5L, -72057594037927937.0L),
13384 TEST_f_f (round, -72057594037927936.75L, -72057594037927937.0L),
13385 TEST_f_f (round, -72057594037927937.5L, -72057594037927938.0L),
13386
13387 TEST_f_f (round, 10141204801825835211973625643007.5L, 10141204801825835211973625643008.0L),
13388 TEST_f_f (round, 10141204801825835211973625643008.25L, 10141204801825835211973625643008.0L),
13389 TEST_f_f (round, 10141204801825835211973625643008.5L, 10141204801825835211973625643009.0L),
13390 TEST_f_f (round, 10141204801825835211973625643008.75L, 10141204801825835211973625643009.0L),
13391 TEST_f_f (round, 10141204801825835211973625643009.5L, 10141204801825835211973625643010.0L),
13392 #endif
13393 END_DATA (round)
13394 };
13395
13396 static void
13397 round_test (void)
13398 {
13399 START (round);
13400 RUN_TEST_LOOP_f_f (round, round_test_data, );
13401 END (round);
13402 }
13403
13404
13405 static const struct test_ff_f_data scalb_test_data[] =
13406 {
13407 START_DATA (scalb),
13408 TEST_ff_f (scalb, 2.0, 0.5, qnan_value, INVALID_EXCEPTION),
13409 TEST_ff_f (scalb, 3.0, -2.5, qnan_value, INVALID_EXCEPTION),
13410
13411 TEST_ff_f (scalb, 0, qnan_value, qnan_value),
13412 TEST_ff_f (scalb, 1, qnan_value, qnan_value),
13413
13414 TEST_ff_f (scalb, 1, 0, 1),
13415 TEST_ff_f (scalb, -1, 0, -1),
13416
13417 TEST_ff_f (scalb, 0, plus_infty, qnan_value, INVALID_EXCEPTION),
13418 TEST_ff_f (scalb, minus_zero, plus_infty, qnan_value, INVALID_EXCEPTION),
13419
13420 TEST_ff_f (scalb, 0, 2, 0),
13421 TEST_ff_f (scalb, minus_zero, -4, minus_zero),
13422 TEST_ff_f (scalb, 0, 0, 0),
13423 TEST_ff_f (scalb, minus_zero, 0, minus_zero),
13424 TEST_ff_f (scalb, 0, -1, 0),
13425 TEST_ff_f (scalb, minus_zero, -10, minus_zero),
13426 TEST_ff_f (scalb, 0, minus_infty, 0),
13427 TEST_ff_f (scalb, minus_zero, minus_infty, minus_zero),
13428
13429 TEST_ff_f (scalb, plus_infty, -1, plus_infty),
13430 TEST_ff_f (scalb, minus_infty, -10, minus_infty),
13431 TEST_ff_f (scalb, plus_infty, 0, plus_infty),
13432 TEST_ff_f (scalb, minus_infty, 0, minus_infty),
13433 TEST_ff_f (scalb, plus_infty, 2, plus_infty),
13434 TEST_ff_f (scalb, minus_infty, 100, minus_infty),
13435
13436 TEST_ff_f (scalb, 0.1L, minus_infty, 0.0),
13437 TEST_ff_f (scalb, -0.1L, minus_infty, minus_zero),
13438
13439 TEST_ff_f (scalb, 1, plus_infty, plus_infty),
13440 TEST_ff_f (scalb, -1, plus_infty, minus_infty),
13441 TEST_ff_f (scalb, plus_infty, plus_infty, plus_infty),
13442 TEST_ff_f (scalb, minus_infty, plus_infty, minus_infty),
13443
13444 TEST_ff_f (scalb, plus_infty, minus_infty, qnan_value, INVALID_EXCEPTION),
13445 TEST_ff_f (scalb, minus_infty, minus_infty, qnan_value, INVALID_EXCEPTION),
13446
13447 TEST_ff_f (scalb, qnan_value, 1, qnan_value),
13448 TEST_ff_f (scalb, 1, qnan_value, qnan_value),
13449 TEST_ff_f (scalb, qnan_value, 0, qnan_value),
13450 TEST_ff_f (scalb, 0, qnan_value, qnan_value),
13451 TEST_ff_f (scalb, qnan_value, plus_infty, qnan_value),
13452 TEST_ff_f (scalb, plus_infty, qnan_value, qnan_value),
13453 TEST_ff_f (scalb, qnan_value, qnan_value, qnan_value),
13454
13455 TEST_ff_f (scalb, 0.8L, 4, 12.8L),
13456 TEST_ff_f (scalb, -0.854375L, 5, -27.34L),
13457 END_DATA (scalb)
13458 };
13459
13460 static void
13461 scalb_test (void)
13462 {
13463
13464 START (scalb);
13465 RUN_TEST_LOOP_ff_f (scalb, scalb_test_data, );
13466 END (scalb);
13467 }
13468
13469
13470 static const struct test_fi_f_data scalbn_test_data[] =
13471 {
13472 START_DATA (scalbn),
13473 TEST_fi_f (scalbn, 0, 0, 0),
13474 TEST_fi_f (scalbn, minus_zero, 0, minus_zero),
13475
13476 TEST_fi_f (scalbn, plus_infty, 1, plus_infty),
13477 TEST_fi_f (scalbn, minus_infty, 1, minus_infty),
13478 TEST_fi_f (scalbn, qnan_value, 1, qnan_value),
13479
13480 TEST_fi_f (scalbn, 0.8L, 4, 12.8L),
13481 TEST_fi_f (scalbn, -0.854375L, 5, -27.34L),
13482
13483 TEST_fi_f (scalbn, 1, 0L, 1),
13484
13485 TEST_fi_f (scalbn, 1, INT_MAX, plus_infty, OVERFLOW_EXCEPTION),
13486 TEST_fi_f (scalbn, 1, INT_MIN, plus_zero, UNDERFLOW_EXCEPTION),
13487 TEST_fi_f (scalbn, max_value, INT_MAX, plus_infty, OVERFLOW_EXCEPTION),
13488 TEST_fi_f (scalbn, max_value, INT_MIN, plus_zero, UNDERFLOW_EXCEPTION),
13489 TEST_fi_f (scalbn, min_value, INT_MAX, plus_infty, OVERFLOW_EXCEPTION),
13490 TEST_fi_f (scalbn, min_value, INT_MIN, plus_zero, UNDERFLOW_EXCEPTION),
13491 TEST_fi_f (scalbn, min_value / 4, INT_MAX, plus_infty, OVERFLOW_EXCEPTION),
13492 TEST_fi_f (scalbn, min_value / 4, INT_MIN, plus_zero, UNDERFLOW_EXCEPTION),
13493 END_DATA (scalbn)
13494 };
13495
13496 static void
13497 scalbn_test (void)
13498 {
13499
13500 START (scalbn);
13501 RUN_TEST_LOOP_fi_f (scalbn, scalbn_test_data, );
13502 END (scalbn);
13503 }
13504
13505
13506 static const struct test_fl_f_data scalbln_test_data[] =
13507 {
13508 START_DATA (scalbln),
13509 TEST_fl_f (scalbln, 0, 0, 0),
13510 TEST_fl_f (scalbln, minus_zero, 0, minus_zero),
13511
13512 TEST_fl_f (scalbln, plus_infty, 1, plus_infty),
13513 TEST_fl_f (scalbln, minus_infty, 1, minus_infty),
13514 TEST_fl_f (scalbln, qnan_value, 1, qnan_value),
13515
13516 TEST_fl_f (scalbln, 0.8L, 4, 12.8L),
13517 TEST_fl_f (scalbln, -0.854375L, 5, -27.34L),
13518
13519 TEST_fl_f (scalbln, 1, 0L, 1),
13520
13521 TEST_fl_f (scalbln, 1, INT_MAX, plus_infty, OVERFLOW_EXCEPTION),
13522 TEST_fl_f (scalbln, 1, INT_MIN, plus_zero, UNDERFLOW_EXCEPTION),
13523 TEST_fl_f (scalbln, max_value, INT_MAX, plus_infty, OVERFLOW_EXCEPTION),
13524 TEST_fl_f (scalbln, max_value, INT_MIN, plus_zero, UNDERFLOW_EXCEPTION),
13525 TEST_fl_f (scalbln, min_value, INT_MAX, plus_infty, OVERFLOW_EXCEPTION),
13526 TEST_fl_f (scalbln, min_value, INT_MIN, plus_zero, UNDERFLOW_EXCEPTION),
13527 TEST_fl_f (scalbln, min_value / 4, INT_MAX, plus_infty, OVERFLOW_EXCEPTION),
13528 TEST_fl_f (scalbln, min_value / 4, INT_MIN, plus_zero, UNDERFLOW_EXCEPTION),
13529
13530 TEST_fl_f (scalbln, 1, LONG_MAX, plus_infty, OVERFLOW_EXCEPTION),
13531 TEST_fl_f (scalbln, 1, LONG_MIN, plus_zero, UNDERFLOW_EXCEPTION),
13532 TEST_fl_f (scalbln, max_value, LONG_MAX, plus_infty, OVERFLOW_EXCEPTION),
13533 TEST_fl_f (scalbln, max_value, LONG_MIN, plus_zero, UNDERFLOW_EXCEPTION),
13534 TEST_fl_f (scalbln, min_value, LONG_MAX, plus_infty, OVERFLOW_EXCEPTION),
13535 TEST_fl_f (scalbln, min_value, LONG_MIN, plus_zero, UNDERFLOW_EXCEPTION),
13536 TEST_fl_f (scalbln, min_value / 4, LONG_MAX, plus_infty, OVERFLOW_EXCEPTION),
13537 TEST_fl_f (scalbln, min_value / 4, LONG_MIN, plus_zero, UNDERFLOW_EXCEPTION),
13538
13539 #if LONG_MAX >= 0x100000000
13540 TEST_fl_f (scalbln, 1, 0x88000000L, plus_infty, OVERFLOW_EXCEPTION),
13541 TEST_fl_f (scalbln, 1, -0x88000000L, plus_zero, UNDERFLOW_EXCEPTION),
13542 TEST_fl_f (scalbln, max_value, 0x88000000L, plus_infty, OVERFLOW_EXCEPTION),
13543 TEST_fl_f (scalbln, max_value, -0x88000000L, plus_zero, UNDERFLOW_EXCEPTION),
13544 TEST_fl_f (scalbln, min_value, 0x88000000L, plus_infty, OVERFLOW_EXCEPTION),
13545 TEST_fl_f (scalbln, min_value, -0x88000000L, plus_zero, UNDERFLOW_EXCEPTION),
13546 TEST_fl_f (scalbln, min_value / 4, 0x88000000L, plus_infty, OVERFLOW_EXCEPTION),
13547 TEST_fl_f (scalbln, min_value / 4, -0x88000000L, plus_zero, UNDERFLOW_EXCEPTION),
13548 #endif
13549 END_DATA (scalbln)
13550 };
13551
13552 static void
13553 scalbln_test (void)
13554 {
13555
13556 START (scalbln);
13557 RUN_TEST_LOOP_fl_f (scalbln, scalbln_test_data, );
13558 END (scalbln);
13559 }
13560
13561
13562 static const struct test_f_i_data signbit_test_data[] =
13563 {
13564 START_DATA (signbit),
13565 /* TODO: missing qNaN tests. */
13566 TEST_f_b (signbit, 0, 0),
13567 TEST_f_b (signbit, minus_zero, 1),
13568 TEST_f_b (signbit, plus_infty, 0),
13569 TEST_f_b (signbit, minus_infty, 1),
13570
13571 /* signbit (x) != 0 for x < 0. */
13572 TEST_f_b (signbit, -1, 1),
13573 /* signbit (x) == 0 for x >= 0. */
13574 TEST_f_b (signbit, 1, 0),
13575 END_DATA (signbit)
13576 };
13577
13578 static void
13579 signbit_test (void)
13580 {
13581 START (signbit);
13582 RUN_TEST_LOOP_f_b_tg (signbit, signbit_test_data, );
13583 END (signbit);
13584 }
13585
13586
13587 static const struct test_f_f_data sin_test_data[] =
13588 {
13589 START_DATA (sin),
13590 TEST_f_f (sin, 0, 0),
13591 TEST_f_f (sin, minus_zero, minus_zero),
13592 TEST_f_f (sin, plus_infty, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
13593 TEST_f_f (sin, minus_infty, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
13594 TEST_f_f (sin, qnan_value, qnan_value, ERRNO_UNCHANGED),
13595
13596 TEST_f_f (sin, M_PI_6l, 0.5),
13597 TEST_f_f (sin, -M_PI_6l, -0.5),
13598 TEST_f_f (sin, M_PI_2l, 1),
13599 TEST_f_f (sin, -M_PI_2l, -1),
13600 TEST_f_f (sin, 0.75L, 0.681638760023334166733241952779893935L),
13601
13602 TEST_f_f (sin, 0x1p65, -0.047183876212354673805106149805700013943218L),
13603 TEST_f_f (sin, -0x1p65, 0.047183876212354673805106149805700013943218L),
13604
13605 TEST_f_f (sin, 0x1.7f4134p+103, -6.6703229329788657073304190650534846045235e-08L),
13606
13607 #ifdef TEST_DOUBLE
13608 TEST_f_f (sin, 0.80190127184058835, 0.71867942238767868),
13609 TEST_f_f (sin, 2.522464e-1, 2.4957989804940911e-1),
13610 #endif
13611
13612 #ifndef TEST_FLOAT
13613 TEST_f_f (sin, 1e22, -0.8522008497671888017727058937530293682618L),
13614 TEST_f_f (sin, 0x1p1023, 0.5631277798508840134529434079444683477104L),
13615 #endif
13616
13617 #if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
13618 TEST_f_f (sin, 0x1p16383L, 0.3893629985894208126948115852610595405563L),
13619 #endif
13620
13621 TEST_f_f (sin, 0x1p+120, 3.77820109360752022655548470056922991960587e-01L),
13622 TEST_f_f (sin, 0x1p+127, 6.23385512955870240370428801097126489001833e-01L),
13623 TEST_f_f (sin, 0x1.fffff8p+127, 4.85786063130487339701113680434728152037092e-02L),
13624 TEST_f_f (sin, 0x1.fffffep+127, -5.21876523333658540551505357019806722935726e-01L),
13625 TEST_f_f (sin, 0x1p+50, 4.96396515208940840876821859865411368093356e-01L),
13626 TEST_f_f (sin, 0x1p+28, -9.86198211836975655703110310527108292055548e-01L),
13627 END_DATA (sin)
13628 };
13629
13630 static void
13631 sin_test (void)
13632 {
13633 errno = 0;
13634 FUNC(sin) (0);
13635 if (errno == ENOSYS)
13636 /* Function not implemented. */
13637 return;
13638
13639 START (sin);
13640 RUN_TEST_LOOP_f_f (sin, sin_test_data, );
13641 END (sin);
13642 }
13643
13644
13645 static const struct test_f_f_data sin_tonearest_test_data[] =
13646 {
13647 START_DATA (sin_tonearest),
13648 TEST_f_f (sin, 1, 0.8414709848078965066525023216302989996226L),
13649 TEST_f_f (sin, 2, 0.9092974268256816953960198659117448427023L),
13650 TEST_f_f (sin, 3, 0.1411200080598672221007448028081102798469L),
13651 TEST_f_f (sin, 4, -0.7568024953079282513726390945118290941359L),
13652 TEST_f_f (sin, 5, -0.9589242746631384688931544061559939733525L),
13653 TEST_f_f (sin, 6, -0.2794154981989258728115554466118947596280L),
13654 TEST_f_f (sin, 7, 0.6569865987187890903969990915936351779369L),
13655 TEST_f_f (sin, 8, 0.9893582466233817778081235982452886721164L),
13656 TEST_f_f (sin, 9, 0.4121184852417565697562725663524351793439L),
13657 TEST_f_f (sin, 10, -0.5440211108893698134047476618513772816836L),
13658 END_DATA (sin_tonearest)
13659 };
13660
13661 static void
13662 sin_test_tonearest (void)
13663 {
13664 errno = 0;
13665 FUNC(sin) (0);
13666 if (errno == ENOSYS)
13667 /* Function not implemented. */
13668 return;
13669
13670 START (sin_tonearest);
13671 RUN_TEST_LOOP_f_f (sin, sin_tonearest_test_data, FE_TONEAREST);
13672 END (sin_tonearest);
13673 }
13674
13675
13676 static const struct test_f_f_data sin_towardzero_test_data[] =
13677 {
13678 START_DATA (sin_towardzero),
13679 TEST_f_f (sin, 1, 0.8414709848078965066525023216302989996226L),
13680 TEST_f_f (sin, 2, 0.9092974268256816953960198659117448427023L),
13681 TEST_f_f (sin, 3, 0.1411200080598672221007448028081102798469L),
13682 TEST_f_f (sin, 4, -0.7568024953079282513726390945118290941359L),
13683 TEST_f_f (sin, 5, -0.9589242746631384688931544061559939733525L),
13684 TEST_f_f (sin, 6, -0.2794154981989258728115554466118947596280L),
13685 TEST_f_f (sin, 7, 0.6569865987187890903969990915936351779369L),
13686 TEST_f_f (sin, 8, 0.9893582466233817778081235982452886721164L),
13687 TEST_f_f (sin, 9, 0.4121184852417565697562725663524351793439L),
13688 TEST_f_f (sin, 10, -0.5440211108893698134047476618513772816836L),
13689 END_DATA (sin_towardzero)
13690 };
13691
13692 static void
13693 sin_test_towardzero (void)
13694 {
13695 errno = 0;
13696 FUNC(sin) (0);
13697 if (errno == ENOSYS)
13698 /* Function not implemented. */
13699 return;
13700
13701 START (sin_towardzero);
13702 RUN_TEST_LOOP_f_f (sin, sin_towardzero_test_data, FE_TOWARDZERO);
13703 END (sin_towardzero);
13704 }
13705
13706
13707 static const struct test_f_f_data sin_downward_test_data[] =
13708 {
13709 START_DATA (sin_downward),
13710 TEST_f_f (sin, 1, 0.8414709848078965066525023216302989996226L),
13711 TEST_f_f (sin, 2, 0.9092974268256816953960198659117448427023L),
13712 TEST_f_f (sin, 3, 0.1411200080598672221007448028081102798469L),
13713 TEST_f_f (sin, 4, -0.7568024953079282513726390945118290941359L),
13714 TEST_f_f (sin, 5, -0.9589242746631384688931544061559939733525L),
13715 TEST_f_f (sin, 6, -0.2794154981989258728115554466118947596280L),
13716 TEST_f_f (sin, 7, 0.6569865987187890903969990915936351779369L),
13717 TEST_f_f (sin, 8, 0.9893582466233817778081235982452886721164L),
13718 TEST_f_f (sin, 9, 0.4121184852417565697562725663524351793439L),
13719 TEST_f_f (sin, 10, -0.5440211108893698134047476618513772816836L),
13720 END_DATA (sin_downward)
13721 };
13722
13723 static void
13724 sin_test_downward (void)
13725 {
13726 errno = 0;
13727 FUNC(sin) (0);
13728 if (errno == ENOSYS)
13729 /* Function not implemented. */
13730 return;
13731
13732 START (sin_downward);
13733 RUN_TEST_LOOP_f_f (sin, sin_downward_test_data, FE_DOWNWARD);
13734 END (sin_downward);
13735 }
13736
13737
13738 static const struct test_f_f_data sin_upward_test_data[] =
13739 {
13740 START_DATA (sin_upward),
13741 TEST_f_f (sin, 1, 0.8414709848078965066525023216302989996226L),
13742 TEST_f_f (sin, 2, 0.9092974268256816953960198659117448427023L),
13743 TEST_f_f (sin, 3, 0.1411200080598672221007448028081102798469L),
13744 TEST_f_f (sin, 4, -0.7568024953079282513726390945118290941359L),
13745 TEST_f_f (sin, 5, -0.9589242746631384688931544061559939733525L),
13746 TEST_f_f (sin, 6, -0.2794154981989258728115554466118947596280L),
13747 TEST_f_f (sin, 7, 0.6569865987187890903969990915936351779369L),
13748 TEST_f_f (sin, 8, 0.9893582466233817778081235982452886721164L),
13749 TEST_f_f (sin, 9, 0.4121184852417565697562725663524351793439L),
13750 TEST_f_f (sin, 10, -0.5440211108893698134047476618513772816836L),
13751 END_DATA (sin_upward)
13752 };
13753
13754 static void
13755 sin_test_upward (void)
13756 {
13757 errno = 0;
13758 FUNC(sin) (0);
13759 if (errno == ENOSYS)
13760 /* Function not implemented. */
13761 return;
13762
13763 START (sin_upward);
13764 RUN_TEST_LOOP_f_f (sin, sin_upward_test_data, FE_UPWARD);
13765 END (sin_upward);
13766 }
13767
13768
13769 static const struct test_sincos_data sincos_test_data[] =
13770 {
13771 START_DATA (sincos),
13772 /* sincos is treated differently because it returns void. */
13773 TEST_extra (sincos, 0, 0, 1),
13774
13775 TEST_extra (sincos, minus_zero, minus_zero, 1),
13776 TEST_extra (sincos, plus_infty, qnan_value, qnan_value, INVALID_EXCEPTION),
13777 TEST_extra (sincos, minus_infty, qnan_value, qnan_value, INVALID_EXCEPTION),
13778 TEST_extra (sincos, qnan_value, qnan_value, qnan_value),
13779
13780 /* The value of M_PI_2l is never exactly PI/2, and therefore the
13781 answer is never exactly zero. The answer is equal to the error
13782 in rounding PI/2 for the type used. Thus the answer is unique
13783 to each type. */
13784 #ifdef TEST_FLOAT
13785 /* 32-bit float. */
13786 TEST_extra (sincos, M_PI_2l, 1, -0x1.777a5cp-25L),
13787 #endif
13788 #if defined TEST_DOUBLE || (defined TEST_LDOUBLE && LDBL_MANT_DIG == 53)
13789 /* 64-bit double or 64-bit long double. */
13790 TEST_extra (sincos, M_PI_2l, 1, 0x1.1a62633145c07p-54L),
13791 #endif
13792 #if defined TEST_LDOUBLE && LDBL_MANT_DIG == 64
13793 /* 96-bit long double. */
13794 TEST_extra (sincos, M_PI_2l, 1, -0xe.ce675d1fc8f8cbbp-69L),
13795 #endif
13796 #if defined TEST_LDOUBLE && LDBL_MANT_DIG == 106
13797 /* 128-bit IBM long double. */
13798 TEST_extra (sincos, M_PI_2l, 1, 0x1.c1cd129024e088a67cc74020bcp-107L),
13799 #endif
13800 #if defined TEST_LDOUBLE && LDBL_MANT_DIG == 113
13801 /* 128-bit long double. */
13802 TEST_extra (sincos, M_PI_2l, 1, 0x1.cd129024e088a67cc74020bbea64p-115L),
13803 #endif
13804
13805 TEST_extra (sincos, M_PI_6l, 0.5, 0.86602540378443864676372317075293616L),
13806 TEST_extra (sincos, M_PI_6l*2.0, 0.86602540378443864676372317075293616L, 0.5),
13807 TEST_extra (sincos, 0.75L, 0.681638760023334166733241952779893935L, 0.731688868873820886311838753000084544L),
13808
13809 TEST_extra (sincos, 0x1p65, -0.047183876212354673805106149805700013943218L, 0.99888622066058013610642172179340364209972L),
13810 TEST_extra (sincos, -0x1p65, 0.047183876212354673805106149805700013943218L, 0.99888622066058013610642172179340364209972L),
13811
13812 #ifdef TEST_DOUBLE
13813 TEST_extra (sincos, 0.80190127184058835, 0.71867942238767868, 0.69534156199418473),
13814 #endif
13815
13816 #ifndef TEST_FLOAT
13817 TEST_extra (sincos, 1e22, -0.8522008497671888017727058937530293682618L, 0.5232147853951389454975944733847094921409L),
13818 TEST_extra (sincos, 0x1p1023, 0.5631277798508840134529434079444683477104L, -0.826369834614147994500785680811743734805L),
13819 #endif
13820
13821 #if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
13822 TEST_extra (sincos, 0x1p16383L, 0.3893629985894208126948115852610595405563L, 0.9210843909921906206874509522505756251609L),
13823 #endif
13824
13825 TEST_extra (sincos, 0x1p+120, 3.77820109360752022655548470056922991960587e-01L, -9.25879022854837867303861764107414946730833e-01L),
13826 TEST_extra (sincos, 0x1p+127, 6.23385512955870240370428801097126489001833e-01L, 7.81914638714960072263910298466369236613162e-01L),
13827 TEST_extra (sincos, 0x1.fffff8p+127, 4.85786063130487339701113680434728152037092e-02L, 9.98819362551949040703862043664101081064641e-01L),
13828 TEST_extra (sincos, 0x1.fffffep+127, -5.21876523333658540551505357019806722935726e-01L, 8.53021039830304158051791467692161107353094e-01L),
13829 TEST_extra (sincos, 0x1p+50, 4.96396515208940840876821859865411368093356e-01L, 8.68095904660550604334592502063501320395739e-01L),
13830 TEST_extra (sincos, 0x1p+28, -9.86198211836975655703110310527108292055548e-01L, -1.65568979490578758865468278195361551113358e-01L),
13831 END_DATA (sincos)
13832 };
13833
13834 static void
13835 sincos_test (void)
13836 {
13837 FLOAT sin_res, cos_res;
13838
13839 errno = 0;
13840 FUNC(sincos) (0, &sin_res, &cos_res);
13841 if (errno == ENOSYS)
13842 /* Function not implemented. */
13843 return;
13844
13845 START (sincos);
13846 RUN_TEST_LOOP_sincos (sincos_test_data, , sin_res, cos_res);
13847 END (sincos);
13848 }
13849
13850 static const struct test_f_f_data sinh_test_data[] =
13851 {
13852 START_DATA (sinh),
13853 TEST_f_f (sinh, 0, 0),
13854 TEST_f_f (sinh, minus_zero, minus_zero),
13855
13856 #ifndef TEST_INLINE
13857 TEST_f_f (sinh, plus_infty, plus_infty),
13858 TEST_f_f (sinh, minus_infty, minus_infty),
13859 #endif
13860 TEST_f_f (sinh, qnan_value, qnan_value),
13861
13862 TEST_f_f (sinh, 0.75L, 0.822316731935829980703661634446913849L),
13863 TEST_f_f (sinh, 0x8p-32L, 1.86264514923095703232705808926175479e-9L),
13864 END_DATA (sinh)
13865 };
13866
13867 static void
13868 sinh_test (void)
13869 {
13870 errno = 0;
13871 FUNC(sinh) (0.7L);
13872 if (errno == ENOSYS)
13873 /* Function not implemented. */
13874 return;
13875
13876 START (sinh);
13877 RUN_TEST_LOOP_f_f (sinh, sinh_test_data, );
13878 END (sinh);
13879 }
13880
13881
13882 static const struct test_f_f_data sinh_tonearest_test_data[] =
13883 {
13884 START_DATA (sinh_tonearest),
13885 TEST_f_f (sinh, 22, 1792456423.065795780701106568345764104225L),
13886 TEST_f_f (sinh, 23, 4872401723.124451299966006944252978187305L),
13887 TEST_f_f (sinh, 24, 13244561064.92173614705070540368454568168L),
13888 END_DATA (sinh_tonearest)
13889 };
13890
13891 static void
13892 sinh_test_tonearest (void)
13893 {
13894 errno = 0;
13895 FUNC(sinh) (0);
13896 if (errno == ENOSYS)
13897 /* Function not implemented. */
13898 return;
13899
13900 START (sinh_tonearest);
13901 RUN_TEST_LOOP_f_f (sinh, sinh_tonearest_test_data, FE_TONEAREST);
13902 END (sinh_tonearest);
13903 }
13904
13905
13906 static const struct test_f_f_data sinh_towardzero_test_data[] =
13907 {
13908 START_DATA (sinh_towardzero),
13909 TEST_f_f (sinh, 22, 1792456423.065795780701106568345764104225L),
13910 TEST_f_f (sinh, 23, 4872401723.124451299966006944252978187305L),
13911 TEST_f_f (sinh, 24, 13244561064.92173614705070540368454568168L),
13912 END_DATA (sinh_towardzero)
13913 };
13914
13915 static void
13916 sinh_test_towardzero (void)
13917 {
13918 errno = 0;
13919 FUNC(sinh) (0);
13920 if (errno == ENOSYS)
13921 /* Function not implemented. */
13922 return;
13923
13924 START (sinh_towardzero);
13925 RUN_TEST_LOOP_f_f (sinh, sinh_towardzero_test_data, FE_TOWARDZERO);
13926 END (sinh_towardzero);
13927 }
13928
13929
13930 static const struct test_f_f_data sinh_downward_test_data[] =
13931 {
13932 START_DATA (sinh_downward),
13933 TEST_f_f (sinh, 22, 1792456423.065795780701106568345764104225L),
13934 TEST_f_f (sinh, 23, 4872401723.124451299966006944252978187305L),
13935 TEST_f_f (sinh, 24, 13244561064.92173614705070540368454568168L),
13936 END_DATA (sinh_downward)
13937 };
13938
13939 static void
13940 sinh_test_downward (void)
13941 {
13942 errno = 0;
13943 FUNC(sinh) (0);
13944 if (errno == ENOSYS)
13945 /* Function not implemented. */
13946 return;
13947
13948 START (sinh_downward);
13949 RUN_TEST_LOOP_f_f (sinh, sinh_downward_test_data, FE_DOWNWARD);
13950 END (sinh_downward);
13951 }
13952
13953
13954 static const struct test_f_f_data sinh_upward_test_data[] =
13955 {
13956 START_DATA (sinh_upward),
13957 TEST_f_f (sinh, 22, 1792456423.065795780701106568345764104225L),
13958 TEST_f_f (sinh, 23, 4872401723.124451299966006944252978187305L),
13959 TEST_f_f (sinh, 24, 13244561064.92173614705070540368454568168L),
13960 END_DATA (sinh_upward)
13961 };
13962
13963 static void
13964 sinh_test_upward (void)
13965 {
13966 errno = 0;
13967 FUNC(sinh) (0);
13968 if (errno == ENOSYS)
13969 /* Function not implemented. */
13970 return;
13971
13972 START (sinh_upward);
13973 RUN_TEST_LOOP_f_f (sinh, sinh_upward_test_data, FE_UPWARD);
13974 END (sinh_upward);
13975 }
13976
13977
13978 static const struct test_f_f_data sqrt_test_data[] =
13979 {
13980 START_DATA (sqrt),
13981 TEST_f_f (sqrt, 0, 0),
13982 TEST_f_f (sqrt, qnan_value, qnan_value),
13983 TEST_f_f (sqrt, plus_infty, plus_infty),
13984
13985 TEST_f_f (sqrt, minus_zero, minus_zero),
13986
13987 /* sqrt (x) == qNaN plus invalid exception for x < 0. */
13988 TEST_f_f (sqrt, -1, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
13989 TEST_f_f (sqrt, -max_value, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
13990 TEST_f_f (sqrt, minus_infty, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
13991
13992 TEST_f_f (sqrt, 2209, 47),
13993 TEST_f_f (sqrt, 4, 2),
13994 TEST_f_f (sqrt, 2, M_SQRT2l),
13995 TEST_f_f (sqrt, 0.25, 0.5),
13996 TEST_f_f (sqrt, 6642.25, 81.5),
13997 TEST_f_f (sqrt, 15190.5625L, 123.25L),
13998 TEST_f_f (sqrt, 0.75L, 0.866025403784438646763723170752936183L),
13999 END_DATA (sqrt)
14000 };
14001
14002 static void
14003 sqrt_test (void)
14004 {
14005 errno = 0;
14006 FUNC(sqrt) (1);
14007 if (errno == ENOSYS)
14008 /* Function not implemented. */
14009 return;
14010
14011 START (sqrt);
14012 RUN_TEST_LOOP_f_f (sqrt, sqrt_test_data, );
14013 END (sqrt);
14014 }
14015
14016
14017 static const struct test_f_f_data tan_test_data[] =
14018 {
14019 START_DATA (tan),
14020 TEST_f_f (tan, 0, 0),
14021 TEST_f_f (tan, minus_zero, minus_zero),
14022 TEST_f_f (tan, plus_infty, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
14023 TEST_f_f (tan, minus_infty, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
14024 TEST_f_f (tan, qnan_value, qnan_value, ERRNO_UNCHANGED),
14025
14026 TEST_f_f (tan, M_PI_4l, 1),
14027 TEST_f_f (tan, 0.75L, 0.931596459944072461165202756573936428L),
14028
14029 TEST_f_f (tan, 0x1p65, -0.0472364872359047946798414219288370688827L),
14030 TEST_f_f (tan, -0x1p65, 0.0472364872359047946798414219288370688827L),
14031
14032 TEST_f_f (tan, 0xc.9p-4, 0.9995162902115457818029468900654150261381L),
14033 TEST_f_f (tan, 0xc.908p-4, 0.9997603425502441410973077452249560802034L),
14034 TEST_f_f (tan, 0xc.90cp-4, 0.9998823910588060302788513970802357770031L),
14035 TEST_f_f (tan, 0xc.90ep-4, 0.9999434208994808753305784795924711152508L),
14036 TEST_f_f (tan, 0xc.90fp-4, 0.9999739372166156702433266059635165160515L),
14037 TEST_f_f (tan, 0xc.90f8p-4, 0.9999891957244072765118898375645469865764L),
14038 TEST_f_f (tan, 0xc.90fcp-4, 0.9999968250656122402859679132395522927393L),
14039 TEST_f_f (tan, 0xc.90fdp-4, 0.9999987324100083358016192309006353329444L),
14040 TEST_f_f (tan, 0xc.90fd8p-4, 0.9999996860835706212861509874451585282616L),
14041 TEST_f_f (tan, 0xc.90fdap-4, 0.9999999245021033010474530133665235922808L),
14042 TEST_f_f (tan, 0xc.ap-4, 1.0073556597407272165371804539701396631519L),
14043 TEST_f_f (tan, 0xc.98p-4, 1.0034282930863044654045449407466962736255L),
14044 TEST_f_f (tan, 0xc.94p-4, 1.0014703786820082237342656561856877993328L),
14045 TEST_f_f (tan, 0xc.92p-4, 1.0004928571392300571266638743539017593717L),
14046 TEST_f_f (tan, 0xc.91p-4, 1.0000044544650244953647966900221905361131L),
14047 TEST_f_f (tan, 0xc.90fep-4, 1.0000006397580424009014454926842136804016L),
14048 TEST_f_f (tan, 0xc.90fdcp-4, 1.0000001629206928242190327320047489394217L),
14049 TEST_f_f (tan, 0xc.90fdbp-4, 1.0000000437113909572052640953950483705005L),
14050
14051 TEST_f_f (tan, -0xc.9p-4, -0.9995162902115457818029468900654150261381L),
14052 TEST_f_f (tan, -0xc.908p-4, -0.9997603425502441410973077452249560802034L),
14053 TEST_f_f (tan, -0xc.90cp-4, -0.9998823910588060302788513970802357770031L),
14054 TEST_f_f (tan, -0xc.90ep-4, -0.9999434208994808753305784795924711152508L),
14055 TEST_f_f (tan, -0xc.90fp-4, -0.9999739372166156702433266059635165160515L),
14056 TEST_f_f (tan, -0xc.90f8p-4, -0.9999891957244072765118898375645469865764L),
14057 TEST_f_f (tan, -0xc.90fcp-4, -0.9999968250656122402859679132395522927393L),
14058 TEST_f_f (tan, -0xc.90fdp-4, -0.9999987324100083358016192309006353329444L),
14059 TEST_f_f (tan, -0xc.90fd8p-4, -0.9999996860835706212861509874451585282616L),
14060 TEST_f_f (tan, -0xc.90fdap-4, -0.9999999245021033010474530133665235922808L),
14061 TEST_f_f (tan, -0xc.ap-4, -1.0073556597407272165371804539701396631519L),
14062 TEST_f_f (tan, -0xc.98p-4, -1.0034282930863044654045449407466962736255L),
14063 TEST_f_f (tan, -0xc.94p-4, -1.0014703786820082237342656561856877993328L),
14064 TEST_f_f (tan, -0xc.92p-4, -1.0004928571392300571266638743539017593717L),
14065 TEST_f_f (tan, -0xc.91p-4, -1.0000044544650244953647966900221905361131L),
14066 TEST_f_f (tan, -0xc.90fep-4, -1.0000006397580424009014454926842136804016L),
14067 TEST_f_f (tan, -0xc.90fdcp-4, -1.0000001629206928242190327320047489394217L),
14068 TEST_f_f (tan, -0xc.90fdbp-4, -1.0000000437113909572052640953950483705005L),
14069
14070 #ifndef TEST_FLOAT
14071 TEST_f_f (tan, 1e22, -1.628778225606898878549375936939548513545L),
14072 TEST_f_f (tan, 0x1p1023, -0.6814476476066215012854144040167365190368L),
14073 #endif
14074
14075 #if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
14076 TEST_f_f (tan, 0x1p16383L, 0.422722393732022337800504160054440141575L),
14077 #endif
14078 END_DATA (tan)
14079 };
14080
14081 static void
14082 tan_test (void)
14083 {
14084 errno = 0;
14085 FUNC(tan) (0);
14086 if (errno == ENOSYS)
14087 /* Function not implemented. */
14088 return;
14089
14090 START (tan);
14091 RUN_TEST_LOOP_f_f (tan, tan_test_data, );
14092 END (tan);
14093 }
14094
14095
14096 static const struct test_f_f_data tan_tonearest_test_data[] =
14097 {
14098 START_DATA (tan_tonearest),
14099 TEST_f_f (tan, 1, 1.5574077246549022305069748074583601730873L),
14100 TEST_f_f (tan, 2, -2.1850398632615189916433061023136825434320L),
14101 TEST_f_f (tan, 3, -0.1425465430742778052956354105339134932261L),
14102 TEST_f_f (tan, 4, 1.1578212823495775831373424182673239231198L),
14103 TEST_f_f (tan, 5, -3.3805150062465856369827058794473439087096L),
14104 TEST_f_f (tan, 6, -0.2910061913847491570536995888681755428312L),
14105 TEST_f_f (tan, 7, 0.8714479827243187364564508896003135663222L),
14106 TEST_f_f (tan, 8, -6.7997114552203786999252627596086333648814L),
14107 TEST_f_f (tan, 9, -0.4523156594418098405903708757987855343087L),
14108 TEST_f_f (tan, 10, 0.6483608274590866712591249330098086768169L),
14109 END_DATA (tan_tonearest)
14110 };
14111
14112 static void
14113 tan_test_tonearest (void)
14114 {
14115 errno = 0;
14116 FUNC(tan) (0);
14117 if (errno == ENOSYS)
14118 /* Function not implemented. */
14119 return;
14120
14121 START (tan_tonearest);
14122 RUN_TEST_LOOP_f_f (tan, tan_tonearest_test_data, FE_TONEAREST);
14123 END (tan_tonearest);
14124 }
14125
14126
14127 static const struct test_f_f_data tan_towardzero_test_data[] =
14128 {
14129 START_DATA (tan_towardzero),
14130 TEST_f_f (tan, 1, 1.5574077246549022305069748074583601730873L),
14131 TEST_f_f (tan, 2, -2.1850398632615189916433061023136825434320L),
14132 TEST_f_f (tan, 3, -0.1425465430742778052956354105339134932261L),
14133 TEST_f_f (tan, 4, 1.1578212823495775831373424182673239231198L),
14134 TEST_f_f (tan, 5, -3.3805150062465856369827058794473439087096L),
14135 TEST_f_f (tan, 6, -0.2910061913847491570536995888681755428312L),
14136 TEST_f_f (tan, 7, 0.8714479827243187364564508896003135663222L),
14137 TEST_f_f (tan, 8, -6.7997114552203786999252627596086333648814L),
14138 TEST_f_f (tan, 9, -0.4523156594418098405903708757987855343087L),
14139 TEST_f_f (tan, 10, 0.6483608274590866712591249330098086768169L),
14140 END_DATA (tan_towardzero)
14141 };
14142
14143 static void
14144 tan_test_towardzero (void)
14145 {
14146 errno = 0;
14147 FUNC(tan) (0);
14148 if (errno == ENOSYS)
14149 /* Function not implemented. */
14150 return;
14151
14152 START (tan_towardzero);
14153 RUN_TEST_LOOP_f_f (tan, tan_towardzero_test_data, FE_TOWARDZERO);
14154 END (tan_towardzero);
14155 }
14156
14157
14158 static const struct test_f_f_data tan_downward_test_data[] =
14159 {
14160 START_DATA (tan_downward),
14161 TEST_f_f (tan, 1, 1.5574077246549022305069748074583601730873L),
14162 TEST_f_f (tan, 2, -2.1850398632615189916433061023136825434320L),
14163 TEST_f_f (tan, 3, -0.1425465430742778052956354105339134932261L),
14164 TEST_f_f (tan, 4, 1.1578212823495775831373424182673239231198L),
14165 TEST_f_f (tan, 5, -3.3805150062465856369827058794473439087096L),
14166 TEST_f_f (tan, 6, -0.2910061913847491570536995888681755428312L),
14167 TEST_f_f (tan, 7, 0.8714479827243187364564508896003135663222L),
14168 TEST_f_f (tan, 8, -6.7997114552203786999252627596086333648814L),
14169 TEST_f_f (tan, 9, -0.4523156594418098405903708757987855343087L),
14170 TEST_f_f (tan, 10, 0.6483608274590866712591249330098086768169L),
14171 END_DATA (tan_downward)
14172 };
14173
14174 static void
14175 tan_test_downward (void)
14176 {
14177 errno = 0;
14178 FUNC(tan) (0);
14179 if (errno == ENOSYS)
14180 /* Function not implemented. */
14181 return;
14182
14183 START (tan_downward);
14184 RUN_TEST_LOOP_f_f (tan, tan_downward_test_data, FE_DOWNWARD);
14185 END (tan_downward);
14186 }
14187
14188
14189 static const struct test_f_f_data tan_upward_test_data[] =
14190 {
14191 START_DATA (tan_upward),
14192 TEST_f_f (tan, 1, 1.5574077246549022305069748074583601730873L),
14193 TEST_f_f (tan, 2, -2.1850398632615189916433061023136825434320L),
14194 TEST_f_f (tan, 3, -0.1425465430742778052956354105339134932261L),
14195 TEST_f_f (tan, 4, 1.1578212823495775831373424182673239231198L),
14196 TEST_f_f (tan, 5, -3.3805150062465856369827058794473439087096L),
14197 TEST_f_f (tan, 6, -0.2910061913847491570536995888681755428312L),
14198 TEST_f_f (tan, 7, 0.8714479827243187364564508896003135663222L),
14199 TEST_f_f (tan, 8, -6.7997114552203786999252627596086333648814L),
14200 TEST_f_f (tan, 9, -0.4523156594418098405903708757987855343087L),
14201 TEST_f_f (tan, 10, 0.6483608274590866712591249330098086768169L),
14202 END_DATA (tan_upward)
14203 };
14204
14205 static void
14206 tan_test_upward (void)
14207 {
14208 errno = 0;
14209 FUNC(tan) (0);
14210 if (errno == ENOSYS)
14211 /* Function not implemented. */
14212 return;
14213
14214 START (tan_upward);
14215 RUN_TEST_LOOP_f_f (tan, tan_upward_test_data, FE_UPWARD);
14216 END (tan_upward);
14217 }
14218
14219
14220 static const struct test_f_f_data tanh_test_data[] =
14221 {
14222 START_DATA (tanh),
14223 TEST_f_f (tanh, 0, 0),
14224 TEST_f_f (tanh, minus_zero, minus_zero),
14225
14226 #ifndef TEST_INLINE
14227 TEST_f_f (tanh, plus_infty, 1),
14228 TEST_f_f (tanh, minus_infty, -1),
14229 #endif
14230 TEST_f_f (tanh, qnan_value, qnan_value),
14231
14232 TEST_f_f (tanh, 0.75L, 0.635148952387287319214434357312496495L),
14233 TEST_f_f (tanh, -0.75L, -0.635148952387287319214434357312496495L),
14234
14235 TEST_f_f (tanh, 1.0L, 0.7615941559557648881194582826047935904L),
14236 TEST_f_f (tanh, -1.0L, -0.7615941559557648881194582826047935904L),
14237
14238 /* 2^-57 */
14239 TEST_f_f (tanh, 0x1p-57L, 6.938893903907228377647697925567626953125e-18L),
14240 END_DATA (tanh)
14241 };
14242
14243 static void
14244 tanh_test (void)
14245 {
14246 errno = 0;
14247 FUNC(tanh) (0.7L);
14248 if (errno == ENOSYS)
14249 /* Function not implemented. */
14250 return;
14251
14252 START (tanh);
14253 RUN_TEST_LOOP_f_f (tanh, tanh_test_data, );
14254 END (tanh);
14255 }
14256
14257 static const struct test_f_f_data tgamma_test_data[] =
14258 {
14259 START_DATA (tgamma),
14260 TEST_f_f (tgamma, plus_infty, plus_infty),
14261 TEST_f_f (tgamma, max_value, plus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
14262 TEST_f_f (tgamma, 0, plus_infty, DIVIDE_BY_ZERO_EXCEPTION),
14263 TEST_f_f (tgamma, minus_zero, minus_infty, DIVIDE_BY_ZERO_EXCEPTION),
14264 /* tgamma (x) == qNaN plus invalid exception for integer x <= 0. */
14265 TEST_f_f (tgamma, -2, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
14266 TEST_f_f (tgamma, -max_value, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
14267 TEST_f_f (tgamma, minus_infty, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
14268 TEST_f_f (tgamma, qnan_value, qnan_value),
14269
14270 TEST_f_f (tgamma, 0.5, M_SQRT_PIl),
14271 TEST_f_f (tgamma, -0.5, -M_2_SQRT_PIl),
14272
14273 TEST_f_f (tgamma, 1, 1),
14274 TEST_f_f (tgamma, 2, 1),
14275 TEST_f_f (tgamma, 3, 2),
14276 TEST_f_f (tgamma, 4, 6),
14277 TEST_f_f (tgamma, 5, 24),
14278 TEST_f_f (tgamma, 6, 120),
14279 TEST_f_f (tgamma, 7, 720),
14280 TEST_f_f (tgamma, 8, 5040),
14281 TEST_f_f (tgamma, 9, 40320),
14282 TEST_f_f (tgamma, 10, 362880),
14283
14284 TEST_f_f (tgamma, 0.7L, 1.29805533264755778568117117915281162L),
14285 TEST_f_f (tgamma, 1.2L, 0.918168742399760610640951655185830401L),
14286
14287 TEST_f_f (tgamma, 1.5L, 8.8622692545275801364908374167057259139877e-01L),
14288 TEST_f_f (tgamma, 2.5L, 1.3293403881791370204736256125058588870982e+00L),
14289 TEST_f_f (tgamma, 3.5L, 3.3233509704478425511840640312646472177454e+00L),
14290 TEST_f_f (tgamma, 4.5L, 1.1631728396567448929144224109426265262109e+01L),
14291 TEST_f_f (tgamma, 5.5L, 5.2342777784553520181149008492418193679490e+01L),
14292 TEST_f_f (tgamma, 6.5L, 2.8788527781504436099631954670830006523720e+02L),
14293 TEST_f_f (tgamma, 7.5L, 1.8712543057977883464760770536039504240418e+03L),
14294 TEST_f_f (tgamma, 8.5L, 1.4034407293483412598570577902029628180313e+04L),
14295 TEST_f_f (tgamma, 9.5L, 1.1929246199460900708784991216725183953266e+05L),
14296 TEST_f_f (tgamma, -1.5L, 2.3632718012073547030642233111215269103967e+00L),
14297 TEST_f_f (tgamma, -2.5L, -9.4530872048294188122568932444861076415869e-01L),
14298 TEST_f_f (tgamma, -3.5L, 2.7008820585226910892162552127103164690248e-01L),
14299 TEST_f_f (tgamma, -4.5L, -6.0019601300504246427027893615784810422774e-02L),
14300 TEST_f_f (tgamma, -5.5L, 1.0912654781909862986732344293779056440504e-02L),
14301 TEST_f_f (tgamma, -6.5L, -1.6788699664476712287280529682737009908468e-03L),
14302 TEST_f_f (tgamma, -7.5L, 2.2384932885968949716374039576982679877958e-04L),
14303 TEST_f_f (tgamma, -8.5L, -2.6335215159963470254557693619979623385833e-05L),
14304 TEST_f_f (tgamma, -9.5L, 2.7721279115751021320587045915768024616666e-06L),
14305 TEST_f_f (tgamma, 0x1p-24L, 1.6777215422784394050795179874582764575261e+07L),
14306 TEST_f_f (tgamma, -0x1p-24L, -1.6777216577215723853867349114260580375249e+07L),
14307 TEST_f_f (tgamma, 0x1p-53L, 9.0071992547409914227843350984672492007618e+15L),
14308 TEST_f_f (tgamma, -0x1p-53L, -9.0071992547409925772156649015329704137860e+15L),
14309 TEST_f_f (tgamma, 0x1p-64L, 1.8446744073709551615422784335098467139447e+19L),
14310 TEST_f_f (tgamma, -0x1p-64L, -1.8446744073709551616577215664901532860660e+19L),
14311 TEST_f_f (tgamma, 0x1p-106L, 8.1129638414606681695789005144063422784335e+31L),
14312 TEST_f_f (tgamma, -0x1p-106L, -8.1129638414606681695789005144064577215665e+31L),
14313 TEST_f_f (tgamma, 0x1p-113L, 1.0384593717069655257060992658440191422784e+34L),
14314 TEST_f_f (tgamma, -0x1p-113L, -1.0384593717069655257060992658440192577216e+34L),
14315 TEST_f_f (tgamma, 0x1p-127L, 1.7014118346046923173168730371588410572742e+38L),
14316 TEST_f_f (tgamma, -0x1p-127L, -1.7014118346046923173168730371588410572858e+38L),
14317 #ifdef TEST_FLOAT
14318 TEST_f_f (tgamma, 0x1p-128L, plus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
14319 TEST_f_f (tgamma, -0x1p-128L, minus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
14320 TEST_f_f (tgamma, 0x1p-149L, plus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
14321 TEST_f_f (tgamma, -0x1p-149L, minus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
14322 #else
14323 TEST_f_f (tgamma, 0x1p-128L, 3.4028236692093846346337460743176821145542e+38L),
14324 TEST_f_f (tgamma, -0x1p-128L, -3.4028236692093846346337460743176821145658e+38L),
14325 TEST_f_f (tgamma, 0x1p-149L, 7.1362384635297994052914298472474756819137e+44L),
14326 TEST_f_f (tgamma, -0x1p-149L, -7.1362384635297994052914298472474756819137e+44L),
14327 #endif
14328 #ifndef TEST_FLOAT
14329 TEST_f_f (tgamma, 0x1p-1023L, 8.9884656743115795386465259539451236680899e+307L),
14330 TEST_f_f (tgamma, -0x1p-1023L, -8.9884656743115795386465259539451236680899e+307L),
14331 # if !defined TEST_LDOUBLE || LDBL_MAX_EXP <= 1024
14332 TEST_f_f (tgamma, 0x1p-1024L, plus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
14333 TEST_f_f (tgamma, -0x1p-1024L, minus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
14334 TEST_f_f (tgamma, 0x1p-1074L, plus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
14335 TEST_f_f (tgamma, -0x1p-1074L, minus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
14336 # else
14337 TEST_f_f (tgamma, 0x1p-1024L, 1.7976931348623159077293051907890247336180e+308L),
14338 TEST_f_f (tgamma, -0x1p-1024L, -1.7976931348623159077293051907890247336180e+308L),
14339 TEST_f_f (tgamma, 0x1p-1074L, 2.0240225330731061835249534671891730704956e+323L),
14340 TEST_f_f (tgamma, -0x1p-1074L, -2.0240225330731061835249534671891730704956e+323L),
14341 # endif
14342 #endif
14343 #if defined TEST_LDOUBLE && LDBL_MIN_EXP <= -16381
14344 TEST_f_f (tgamma, 0x1p-16383L, 5.9486574767861588254287966331400356538172e+4931L),
14345 TEST_f_f (tgamma, -0x1p-16383L, -5.9486574767861588254287966331400356538172e+4931L),
14346 TEST_f_f (tgamma, 0x1p-16384L, plus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
14347 TEST_f_f (tgamma, -0x1p-16384L, minus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
14348 TEST_f_f (tgamma, 0x1p-16445L, plus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
14349 TEST_f_f (tgamma, -0x1p-16445L, minus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
14350 # if LDBL_MANT_DIG >= 113
14351 TEST_f_f (tgamma, 0x1p-16494L, plus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
14352 TEST_f_f (tgamma, -0x1p-16494L, minus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
14353 # endif
14354 #endif
14355 TEST_f_f (tgamma, 0x8.00001p0L, 5.0400096882277802019946778420223050233915e+03L),
14356 TEST_f_f (tgamma, 0x7.fffff8p0L, 5.0399951558933225045148935487583089307135e+03L),
14357 TEST_f_f (tgamma, 0x7.000008p0L, 7.2000064296977505705636258629805621178587e+02L),
14358 TEST_f_f (tgamma, 0x6.fffff8p0L, 7.1999935703082425988147448928288557689866e+02L),
14359 TEST_f_f (tgamma, 0x6.000008p0L, 1.2000009762487825358530770343720418162783e+02L),
14360 TEST_f_f (tgamma, 0x5.fffff8p0L, 1.1999990237520611552119807476573441975106e+02L),
14361 TEST_f_f (tgamma, 0x5.000008p0L, 2.4000017236155647574166073485628713443799e+01L),
14362 TEST_f_f (tgamma, 0x4.fffff8p0L, 2.3999982763857938712639837029547357501709e+01L),
14363 TEST_f_f (tgamma, 0x4.000008p0L, 6.0000035937827461765660468073471093546129e+00L),
14364 TEST_f_f (tgamma, 0x3.fffffcp0L, 5.9999982031095793171233994481968816873643e+00L),
14365 TEST_f_f (tgamma, 0x3.000004p0L, 2.0000004400179308360529417942462250547999e+00L),
14366 TEST_f_f (tgamma, 0x2.fffffcp0L, 1.9999995599822108706107786027549565954046e+00L),
14367 TEST_f_f (tgamma, 0x2.000004p0L, 1.0000001007996638509889062631687945799175e+00L),
14368 TEST_f_f (tgamma, 0x1.fffffep0L, 9.9999994960018563231526611134590489120697e-01L),
14369 TEST_f_f (tgamma, 0x1.000002p0L, 9.9999993119054472483596471908942669644327e-01L),
14370 TEST_f_f (tgamma, 0x0.ffffffp0L, 1.0000000344047381790797322460568297132998e+00L),
14371 TEST_f_f (tgamma, -0x0.ffffffp0L, -1.6777216422784419250710305882992376932423e+07L),
14372 TEST_f_f (tgamma, -0x1.000002p0L, 8.3886075772158332060084424806449513922858e+06L),
14373 TEST_f_f (tgamma, -0x1.fffffep0L, 4.1943044613922792026014320172298377770578e+06L),
14374 TEST_f_f (tgamma, -0x2.000004p0L, -2.0971515386080557574407223895988378776747e+06L),
14375 TEST_f_f (tgamma, -0x2.fffffcp0L, -6.9905087601970247876992248591045142913324e+05L),
14376 TEST_f_f (tgamma, -0x3.000004p0L, 6.9905045731381300146131914617735687322025e+05L),
14377 TEST_f_f (tgamma, -0x3.fffffcp0L, 1.7476272942159602684441970627092458855771e+05L),
14378 TEST_f_f (tgamma, -0x4.000008p0L, -8.7381270578483499672965708923121931082305e+04L),
14379 TEST_f_f (tgamma, -0x4.fffff8p0L, -1.7476280884325863043793087474680780379554e+04L),
14380 TEST_f_f (tgamma, -0x5.000008p0L, 1.7476252449031389167286893378510439443844e+04L),
14381 TEST_f_f (tgamma, -0x5.fffff8p0L, 2.9127137122026653716311560165769071985443e+03L),
14382 TEST_f_f (tgamma, -0x6.000008p0L, -2.9127085100239567622341538102130981196910e+03L),
14383 TEST_f_f (tgamma, -0x6.fffff8p0L, -4.1610198723079349791939054365613377035519e+02L),
14384 TEST_f_f (tgamma, -0x7.000008p0L, 4.1610118737306415004517215226199741948733e+02L),
14385 TEST_f_f (tgamma, -0x7.fffff8p0L, 5.2012751504050764429534086402871289946986e+01L),
14386 TEST_f_f (tgamma, -0x8.00001p0L, -2.6006296115134418896533598545925084576702e+01L),
14387 TEST_f_f (tgamma, -0x9.fffffp0L, 2.8896008370721717567612135720915723136310e-01L),
14388 TEST_f_f (tgamma, -0xa.00001p0L, -2.8895878754728051776830454190076999107021e-01L),
14389 TEST_f_f (tgamma, -0x13.ffffep0L, 2.1550026214525536756224040483579183652119e-13L),
14390 TEST_f_f (tgamma, -0x14.00002p0L, -2.1549777908265594916405421768142757507179e-13L),
14391 TEST_f_f (tgamma, -0x1d.ffffep0L, 1.9765721589464867957912772592816027583176e-27L),
14392 TEST_f_f (tgamma, -0x1e.00002p0L, -1.9765463890341964384070157599286498212650e-27L),
14393 TEST_f_f (tgamma, -0x27.ffffcp0L, 3.2129279441390812141195076945616975790225e-43L, UNDERFLOW_EXCEPTION_FLOAT),
14394 TEST_f_f (tgamma, -0x28.00004p0L, -3.2128372159115252365699015758097981155793e-43L, UNDERFLOW_EXCEPTION_FLOAT),
14395 TEST_f_f (tgamma, -0x28.ffffcp0L, -7.8364103489619817539676737414096652170685e-45L, UNDERFLOW_EXCEPTION_FLOAT),
14396 TEST_f_f (tgamma, -0x29.00004p0L, 7.8361876024016854597745353972619195760515e-45L, UNDERFLOW_EXCEPTION_FLOAT),
14397 #ifdef TEST_FLOAT
14398 TEST_f_f (tgamma, -0x29.ffffcp0L, plus_zero, UNDERFLOW_EXCEPTION_FLOAT),
14399 TEST_f_f (tgamma, -0x2a.00004p0L, minus_zero, UNDERFLOW_EXCEPTION_FLOAT),
14400 #else
14401 TEST_f_f (tgamma, -0x29.ffffcp0L, 1.8658121573125798145204120066590953505132e-46L),
14402 TEST_f_f (tgamma, -0x2a.00004p0L, -1.8657587834931410688246126853566488626385e-46L),
14403 #endif
14404 #ifndef TEST_FLOAT
14405 TEST_f_f (tgamma, 0x8.0000000000008p0L, 5.0400000000000180457125667322294144477136e+03L),
14406 TEST_f_f (tgamma, 0x7.ffffffffffffcp0L, 5.0399999999999909771437166339103165198442e+03L),
14407 TEST_f_f (tgamma, 0x7.0000000000004p0L, 7.2000000000000119762397445457359071259652e+02L),
14408 TEST_f_f (tgamma, 0x6.ffffffffffffcp0L, 7.1999999999999880237602554542848858572672e+02L),
14409 TEST_f_f (tgamma, 0x6.0000000000004p0L, 1.2000000000000018184042734842640022086408e+02L),
14410 TEST_f_f (tgamma, 0x5.ffffffffffffcp0L, 1.1999999999999981815957265157389249327533e+02L),
14411 TEST_f_f (tgamma, 0x5.0000000000004p0L, 2.4000000000000032104829055124673225982803e+01L),
14412 TEST_f_f (tgamma, 0x4.ffffffffffffcp0L, 2.3999999999999967895170944875373910918544e+01L),
14413 TEST_f_f (tgamma, 0x4.0000000000004p0L, 6.0000000000000066939396342309789716341613e+00L),
14414 TEST_f_f (tgamma, 0x3.ffffffffffffep0L, 5.9999999999999966530301828845138185025345e+00L),
14415 TEST_f_f (tgamma, 0x3.0000000000002p0L, 2.0000000000000008195971324717875960213536e+00L),
14416 TEST_f_f (tgamma, 0x2.ffffffffffffep0L, 1.9999999999999991804028675282128956223990e+00L),
14417 TEST_f_f (tgamma, 0x2.0000000000002p0L, 1.0000000000000001877539613108624482361963e+00L),
14418 TEST_f_f (tgamma, 0x1.fffffffffffffp0L, 9.9999999999999990612301934456883679778984e-01L),
14419 TEST_f_f (tgamma, 0x1.0000000000001p0L, 9.9999999999999987183237573039992418700531e-01L),
14420 TEST_f_f (tgamma, 0x0.fffffffffffff8p0L, 1.0000000000000000640838121348000744796665e+00L),
14421 TEST_f_f (tgamma, -0x0.fffffffffffff8p0L, -9.0071992547409924227843350984672961392521e+15L),
14422 TEST_f_f (tgamma, -0x1.0000000000001p0L, 4.5035996273704955772156649015331740980405e+15L),
14423 TEST_f_f (tgamma, -0x1.fffffffffffffp0L, 2.2517998136852484613921675492337776673289e+15L),
14424 TEST_f_f (tgamma, -0x2.0000000000002p0L, -1.1258999068426235386078324507668462444260e+15L),
14425 TEST_f_f (tgamma, -0x2.ffffffffffffep0L, -3.7529996894754154268627807196691509198813e+14L),
14426 TEST_f_f (tgamma, -0x3.0000000000002p0L, 3.7529996894754112398038859470009084971438e+14L),
14427 TEST_f_f (tgamma, -0x3.ffffffffffffep0L, 9.3824992236885396088236184658402406857503e+13L),
14428 TEST_f_f (tgamma, -0x4.0000000000004p0L, -4.6912496118442603911763815341745722862351e+13L),
14429 TEST_f_f (tgamma, -0x4.ffffffffffffcp0L, -9.3824992236885475509805702650262155809819e+12L),
14430 TEST_f_f (tgamma, -0x5.0000000000004p0L, 9.3824992236885191156860964016850034672946e+12L),
14431 TEST_f_f (tgamma, -0x5.ffffffffffffcp0L, 1.5637498706147581566449098589862357835505e+12L),
14432 TEST_f_f (tgamma, -0x6.0000000000004p0L, -1.5637498706147529544662012521330708016396e+12L),
14433 TEST_f_f (tgamma, -0x6.ffffffffffffcp0L, -2.2339283865925119357965832452642909859289e+11L),
14434 TEST_f_f (tgamma, -0x7.0000000000004p0L, 2.2339283865925039372192897706214475877342e+11L),
14435 TEST_f_f (tgamma, -0x7.ffffffffffffcp0L, 2.7924104832406402297655703264222230055898e+10L),
14436 TEST_f_f (tgamma, -0x8.0000000000008p0L, -1.3962052416203121511868106259843527348026e+10L),
14437 TEST_f_f (tgamma, -0x9.ffffffffffff8p0L, 1.5513391573559147700413058496716749249803e+08L),
14438 TEST_f_f (tgamma, -0xa.0000000000008p0L, -1.5513391573559018084419393002828541166901e+08L),
14439 TEST_f_f (tgamma, -0x13.ffffffffffffp0L, 1.1569515572952029402736625857313236848570e-04L),
14440 TEST_f_f (tgamma, -0x14.000000000001p0L, -1.1569515572951781096476686854873801225397e-04L),
14441 TEST_f_f (tgamma, -0x1d.ffffffffffffp0L, 1.0611571800204311628217068863959963842891e-18L),
14442 TEST_f_f (tgamma, -0x1e.000000000001p0L, -1.0611571800204053929094168642022073530425e-18L),
14443 TEST_f_f (tgamma, -0x27.fffffffffffep0L, 1.7249032006742266376460389310340465554361e-34L),
14444 TEST_f_f (tgamma, -0x28.000000000002p0L, -1.7249032006741359094184881234822934593822e-34L),
14445 TEST_f_f (tgamma, -0x28.fffffffffffep0L, -4.2070809772542120404320040128839297118648e-36L),
14446 TEST_f_f (tgamma, -0x29.000000000002p0L, 4.2070809772539892938717205103652583609422e-36L),
14447 TEST_f_f (tgamma, -0x29.fffffffffffep0L, 1.0016859469652887505173040814397197718981e-37L),
14448 TEST_f_f (tgamma, -0x2a.000000000002p0L, -1.0016859469652353766978684241048308120274e-37L),
14449 TEST_f_f (tgamma, -0x31.fffffffffffep0L, 4.6273774273632946947805289899230181990085e-51L),
14450 TEST_f_f (tgamma, -0x32.000000000002p0L, -4.6273774273630367887073532197576655720178e-51L),
14451 TEST_f_f (tgamma, -0x63.fffffffffffcp0L, 7.5400833348840965463348754984345825364294e-145L),
14452 TEST_f_f (tgamma, -0x64.000000000004p0L, -7.5400833348831085791638490135462230991587e-145L),
14453 TEST_f_f (tgamma, -0x95.fffffffffff8p0L, 6.1582369322723207086020016423767264008839e-250L),
14454 TEST_f_f (tgamma, -0x96.000000000008p0L, -6.1582369322705655439003240743176243138734e-250L),
14455 TEST_f_f (tgamma, -0xb4.fffffffffff8p0L, -9.6760879059917574597728750098636253931457e-319L, UNDERFLOW_EXCEPTION_DOUBLE),
14456 TEST_f_f (tgamma, -0xb5.000000000008p0L, 9.6760879059888966544677044221698800670218e-319L, UNDERFLOW_EXCEPTION_DOUBLE),
14457 TEST_f_f (tgamma, -0xb5.fffffffffff8p0L, 5.3165318164789884455066481673086605454904e-321L, UNDERFLOW_EXCEPTION_DOUBLE),
14458 TEST_f_f (tgamma, -0xb6.000000000008p0L, -5.3165318164774149139661976747137185876909e-321L, UNDERFLOW_EXCEPTION_DOUBLE),
14459 TEST_f_f (tgamma, -0xb6.fffffffffff8p0L, -2.9052086428846935908287469917922960610289e-323L, UNDERFLOW_EXCEPTION_DOUBLE),
14460 TEST_f_f (tgamma, -0xb7.000000000008p0L, 2.9052086428838328351126988236541632950925e-323L, UNDERFLOW_EXCEPTION_DOUBLE),
14461 # if !defined TEST_LDOUBLE || LDBL_MAX_EXP <= 1024
14462 TEST_f_f (tgamma, -0xb7.fffffffffff8p0L, plus_zero, UNDERFLOW_EXCEPTION_DOUBLE),
14463 TEST_f_f (tgamma, -0xb8.000000000008p0L, minus_zero, UNDERFLOW_EXCEPTION_DOUBLE),
14464 # else
14465 TEST_f_f (tgamma, -0xb7.fffffffffff8p0L, 1.5789177406982032823826953250736039527543e-325L),
14466 TEST_f_f (tgamma, -0xb8.000000000008p0L, -1.5789177406977349925854817486109369828857e-325L),
14467 # endif
14468 #endif
14469 #if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 106
14470 TEST_f_f (tgamma, 0x8.00000000000000000000000004p0L, 5.0400000000000000000000000000020034765587e+03L),
14471 TEST_f_f (tgamma, 0x7.fffffffffffffffffffffffffep0L, 5.0399999999999999999999999999989982617206e+03L),
14472 TEST_f_f (tgamma, 0x7.00000000000000000000000002p0L, 7.2000000000000000000000000000013296297113e+02L),
14473 TEST_f_f (tgamma, 0x6.fffffffffffffffffffffffffep0L, 7.1999999999999999999999999999986703702887e+02L),
14474 TEST_f_f (tgamma, 0x6.00000000000000000000000002p0L, 1.2000000000000000000000000000002018834292e+02L),
14475 TEST_f_f (tgamma, 0x5.fffffffffffffffffffffffffep0L, 1.1999999999999999999999999999997981165708e+02L),
14476 TEST_f_f (tgamma, 0x5.00000000000000000000000002p0L, 2.4000000000000000000000000000003564352042e+01L),
14477 TEST_f_f (tgamma, 0x4.fffffffffffffffffffffffffep0L, 2.3999999999999999999999999999996435647958e+01L),
14478 TEST_f_f (tgamma, 0x4.00000000000000000000000002p0L, 6.0000000000000000000000000000007431765907e+00L),
14479 TEST_f_f (tgamma, 0x3.ffffffffffffffffffffffffffp0L, 5.9999999999999999999999999999996284117046e+00L),
14480 TEST_f_f (tgamma, 0x3.00000000000000000000000001p0L, 2.0000000000000000000000000000000909935607e+00L),
14481 TEST_f_f (tgamma, 0x2.ffffffffffffffffffffffffffp0L, 1.9999999999999999999999999999999090064393e+00L),
14482 TEST_f_f (tgamma, 0x2.00000000000000000000000001p0L, 1.0000000000000000000000000000000208448771e+00L),
14483 TEST_f_f (tgamma, 0x1.ffffffffffffffffffffffffff8p0L, 9.9999999999999999999999999999998957756146e-01L),
14484 TEST_f_f (tgamma, 0x1.000000000000000000000000008p0L, 9.9999999999999999999999999999998577053525e-01L),
14485 TEST_f_f (tgamma, 0x0.ffffffffffffffffffffffffffcp0L, 1.0000000000000000000000000000000071147324e+00L),
14486 TEST_f_f (tgamma, -0x0.ffffffffffffffffffffffffffcp0L, -8.1129638414606681695789005144064422784335e+31L),
14487 TEST_f_f (tgamma, -0x1.000000000000000000000000008p0L, 4.0564819207303340847894502572031577215665e+31L),
14488 TEST_f_f (tgamma, -0x1.ffffffffffffffffffffffffff8p0L, 2.0282409603651670423947251286016461392168e+31L),
14489 TEST_f_f (tgamma, -0x2.00000000000000000000000001p0L, -1.0141204801825835211973625643007538607832e+31L),
14490 TEST_f_f (tgamma, -0x2.ffffffffffffffffffffffffffp0L, -3.3804016006086117373245418810028760196114e+30L),
14491 TEST_f_f (tgamma, -0x3.00000000000000000000000001p0L, 3.3804016006086117373245418810024573137219e+30L),
14492 TEST_f_f (tgamma, -0x3.ffffffffffffffffffffffffffp0L, 8.4510040015215293433113547025072942156952e+29L),
14493 TEST_f_f (tgamma, -0x4.00000000000000000000000002p0L, -4.2255020007607646716556773512527057843048e+29L),
14494 TEST_f_f (tgamma, -0x4.fffffffffffffffffffffffffep0L, -8.4510040015215293433113547025080884313904e+28L),
14495 TEST_f_f (tgamma, -0x5.00000000000000000000000002p0L, 8.4510040015215293433113547025052449019430e+28L),
14496 TEST_f_f (tgamma, -0x5.fffffffffffffffffffffffffep0L, 1.4085006669202548905518924504180378867132e+28L),
14497 TEST_f_f (tgamma, -0x6.00000000000000000000000002p0L, -1.4085006669202548905518924504175176688423e+28L),
14498 TEST_f_f (tgamma, -0x6.fffffffffffffffffffffffffep0L, -2.0121438098860784150741320720257967542615e+27L),
14499 TEST_f_f (tgamma, -0x7.00000000000000000000000002p0L, 2.0121438098860784150741320720249968965322e+27L),
14500 TEST_f_f (tgamma, -0x7.fffffffffffffffffffffffffep0L, 2.5151797623575980188426650900322769448110e+26L),
14501 TEST_f_f (tgamma, -0x8.00000000000000000000000004p0L, -1.2575898811787990094213325450153421028080e+26L),
14502 TEST_f_f (tgamma, -0x9.fffffffffffffffffffffffffcp0L, 1.3973220901986655660237028277960625420495e+24L),
14503 TEST_f_f (tgamma, -0xa.00000000000000000000000004p0L, -1.3973220901986655660237028277947663821128e+24L),
14504 TEST_f_f (tgamma, -0x13.fffffffffffffffffffffffff8p0L, 1.0420893204640670202556853709074896123293e+12L),
14505 TEST_f_f (tgamma, -0x14.00000000000000000000000008p0L, -1.0420893204640670202556853709050065497299e+12L),
14506 TEST_f_f (tgamma, -0x1d.fffffffffffffffffffffffff8p0L, 9.5580541610429641982963434151488827190079e-03L),
14507 TEST_f_f (tgamma, -0x1e.00000000000000000000000008p0L, -9.5580541610429641982963434151231128067179e-03L),
14508 TEST_f_f (tgamma, -0x27.fffffffffffffffffffffffffp0L, 1.5536546823612837336494536911280147806523e-18L),
14509 TEST_f_f (tgamma, -0x28.0000000000000000000000001p0L, -1.5536546823612837336494536911189419578973e-18L),
14510 TEST_f_f (tgamma, -0x28.fffffffffffffffffffffffffp0L, -3.7894016642958139845108626612879138384405e-20L),
14511 TEST_f_f (tgamma, -0x29.0000000000000000000000001p0L, 3.7894016642958139845108626612656391824122e-20L),
14512 TEST_f_f (tgamma, -0x29.fffffffffffffffffffffffffp0L, 9.0223849149900332964544349078285357440663e-22L),
14513 TEST_f_f (tgamma, -0x2a.0000000000000000000000001p0L, -9.0223849149900332964544349077751619246306e-22L),
14514 TEST_f_f (tgamma, -0x31.fffffffffffffffffffffffffp0L, 4.1679710515150795310771069868348482819424e-35L),
14515 TEST_f_f (tgamma, -0x32.0000000000000000000000001p0L, -4.1679710515150795310771069868090576746248e-35L),
14516 TEST_f_f (tgamma, -0x63.ffffffffffffffffffffffffep0L, 6.7915032994648558610510614163560656864280e-129L),
14517 TEST_f_f (tgamma, -0x64.0000000000000000000000002p0L, -6.7915032994648558610510614162572689693253e-129L),
14518 TEST_f_f (tgamma, -0x95.ffffffffffffffffffffffffcp0L, 5.5468467106873795353190582463444660395353e-234L),
14519 TEST_f_f (tgamma, -0x96.0000000000000000000000004p0L, -5.5468467106873795353190582461689495693675e-234L),
14520 TEST_f_f (tgamma, -0xb4.ffffffffffffffffffffffffcp0L, -8.7154451775644399729745472278589884205029e-303L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
14521 TEST_f_f (tgamma, -0xb5.0000000000000000000000004p0L, 8.7154451775644399729745472275729078899858e-303L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
14522 TEST_f_f (tgamma, -0xb5.ffffffffffffffffffffffffcp0L, 4.7887061415189230620739270482742524864974e-305L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
14523 TEST_f_f (tgamma, -0xb6.0000000000000000000000004p0L, -4.7887061415189230620739270481168993324524e-305L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
14524 TEST_f_f (tgamma, -0xb6.ffffffffffffffffffffffffcp0L, -2.6167793123054224382917634143575601407067e-307L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
14525 TEST_f_f (tgamma, -0xb7.0000000000000000000000004p0L, 2.6167793123054224382917634142714845691019e-307L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
14526 TEST_f_f (tgamma, -0xb7.ffffffffffffffffffffffffcp0L, 1.4221626697312078468976975078030462044826e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
14527 TEST_f_f (tgamma, -0xb8.0000000000000000000000004p0L, -1.4221626697312078468976975077562172247612e-309L, UNDERFLOW_EXCEPTION_DOUBLE),
14528 TEST_f_f (tgamma, -0xbb.ffffffffffffffffffffffffcp0L, 1.1756150745511026776007338998283058108448e-318L, UNDERFLOW_EXCEPTION_DOUBLE),
14529 TEST_f_f (tgamma, -0xbc.0000000000000000000000004p0L, -1.1756150745511026776007338997894360215107e-318L, UNDERFLOW_EXCEPTION_DOUBLE),
14530 TEST_f_f (tgamma, -0xbc.ffffffffffffffffffffffffcp0L, -6.2201855796354639026493857133773832713743e-321L, UNDERFLOW_EXCEPTION_DOUBLE),
14531 TEST_f_f (tgamma, -0xbd.0000000000000000000000004p0L, 6.2201855796354639026493857131715153125175e-321L, UNDERFLOW_EXCEPTION_DOUBLE),
14532 TEST_f_f (tgamma, -0xbd.ffffffffffffffffffffffffcp0L, 3.2737818840186652119207293228302560914295e-323L, UNDERFLOW_EXCEPTION_DOUBLE),
14533 TEST_f_f (tgamma, -0xbe.0000000000000000000000004p0L, -3.2737818840186652119207293227217957948294e-323L, UNDERFLOW_EXCEPTION_DOUBLE),
14534 # if LDBL_MAX_EXP <= 1024
14535 TEST_f_f (tgamma, -0xbe.ffffffffffffffffffffffffcp0L, minus_zero, UNDERFLOW_EXCEPTION_DOUBLE),
14536 TEST_f_f (tgamma, -0xbf.0000000000000000000000004p0L, plus_zero, UNDERFLOW_EXCEPTION_DOUBLE),
14537 # else
14538 TEST_f_f (tgamma, -0xbe.ffffffffffffffffffffffffcp0L, -1.7140219288055838805867692789687487834686e-325L),
14539 TEST_f_f (tgamma, -0xbf.0000000000000000000000004p0L, 1.7140219288055838805867692789119066543632e-325L),
14540 # endif
14541 #endif
14542 #if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
14543 TEST_f_f (tgamma, 0x8.000000000000001p0L, 5.0400000000000000088113830892247051102283e+03L),
14544 TEST_f_f (tgamma, 0x7.fffffffffffffff8p0L, 5.0399999999999999955943084553876474508520e+03L),
14545 TEST_f_f (tgamma, 0x7.0000000000000008p0L, 7.2000000000000000058477733127664675369681e+02L),
14546 TEST_f_f (tgamma, 0x6.fffffffffffffff8p0L, 7.1999999999999999941522266872335324679893e+02L),
14547 TEST_f_f (tgamma, 0x6.0000000000000008p0L, 1.2000000000000000008878927116622375680433e+02L),
14548 TEST_f_f (tgamma, 0x5.fffffffffffffff8p0L, 1.1999999999999999991121072883377624326546e+02L),
14549 TEST_f_f (tgamma, 0x5.0000000000000008p0L, 2.4000000000000000015676186062072582846211e+01L),
14550 TEST_f_f (tgamma, 0x4.fffffffffffffff8p0L, 2.3999999999999999984323813937927417165027e+01L),
14551 TEST_f_f (tgamma, 0x4.0000000000000008p0L, 6.0000000000000000032685252120268430507939e+00L),
14552 TEST_f_f (tgamma, 0x3.fffffffffffffffcp0L, 5.9999999999999999983657373939865784753909e+00L),
14553 TEST_f_f (tgamma, 0x3.0000000000000004p0L, 2.0000000000000000004001939123397399171482e+00L),
14554 TEST_f_f (tgamma, 0x2.fffffffffffffffcp0L, 1.9999999999999999995998060876602600829690e+00L),
14555 TEST_f_f (tgamma, 0x2.0000000000000004p0L, 1.0000000000000000000916767389213195151634e+00L),
14556 TEST_f_f (tgamma, 0x1.fffffffffffffffep0L, 9.9999999999999999995416163053934024243282e-01L),
14557 TEST_f_f (tgamma, 0x1.0000000000000002p0L, 9.9999999999999999993741815221210931418291e-01L),
14558 TEST_f_f (tgamma, 0x0.ffffffffffffffffp0L, 1.0000000000000000000312909238939453429173e+00L),
14559 TEST_f_f (tgamma, -0x0.ffffffffffffffffp0L, -1.8446744073709551616422784335098467139470e+19L),
14560 TEST_f_f (tgamma, -0x1.0000000000000002p0L, 9.2233720368547758075772156649015328607596e+18L),
14561 TEST_f_f (tgamma, -0x1.fffffffffffffffep0L, 4.6116860184273879044613921675492335697983e+18L),
14562 TEST_f_f (tgamma, -0x2.0000000000000004p0L, -2.3058430092136939515386078324507664305064e+18L),
14563 TEST_f_f (tgamma, -0x2.fffffffffffffffcp0L, -7.6861433640456465087601961140530007887063e+17L),
14564 TEST_f_f (tgamma, -0x3.0000000000000004p0L, 7.6861433640456465045731372192803325462836e+17L),
14565 TEST_f_f (tgamma, -0x3.fffffffffffffffcp0L, 1.9215358410114116272942156951799168638773e+17L),
14566 TEST_f_f (tgamma, -0x4.0000000000000008p0L, -9.6076792050570581270578430482008313684602e+16L),
14567 TEST_f_f (tgamma, -0x4.fffffffffffffff8p0L, -1.9215358410114116280884313903598337283601e+16L),
14568 TEST_f_f (tgamma, -0x5.0000000000000008p0L, 1.9215358410114116252449019429734996071487e+16L),
14569 TEST_f_f (tgamma, -0x5.fffffffffffffff8p0L, 3.2025597350190193803788671320812043622696e+15L),
14570 TEST_f_f (tgamma, -0x6.0000000000000008p0L, -3.2025597350190193751766884234743511972877e+15L),
14571 TEST_f_f (tgamma, -0x6.fffffffffffffff8p0L, -4.5750853357414562579675426149912896787735e+14L),
14572 TEST_f_f (tgamma, -0x7.0000000000000008p0L, 4.5750853357414562499689653215166468353753e+14L),
14573 TEST_f_f (tgamma, -0x7.fffffffffffffff8p0L, 5.7188566696768203227694481100089533685959e+13L),
14574 TEST_f_f (tgamma, -0x8.000000000000001p0L, -2.8594283348384101534210280804672371201060e+13L),
14575 TEST_f_f (tgamma, -0x9.fffffffffffffffp0L, 3.1771425942649001828476427167843945971988e+11L),
14576 TEST_f_f (tgamma, -0xa.000000000000001p0L, -3.1771425942649001698860433502350057763905e+11L),
14577 TEST_f_f (tgamma, -0x13.ffffffffffffffep0L, 2.3694367893405502075347562184931828448654e-01L),
14578 TEST_f_f (tgamma, -0x14.000000000000002p0L, -2.3694367893405501827041302245929389013031e-01L),
14579 TEST_f_f (tgamma, -0x1d.ffffffffffffffep0L, 2.1732499046818166459536268654187775086902e-15L),
14580 TEST_f_f (tgamma, -0x1e.000000000000002p0L, -2.1732499046818166201837145753965837196590e-15L),
14581 TEST_f_f (tgamma, -0x27.ffffffffffffffcp0L, 3.5326017549807232935581894777156474496719e-31L),
14582 TEST_f_f (tgamma, -0x28.000000000000004p0L, -3.5326017549807232028299619269080956965758e-31L),
14583 TEST_f_f (tgamma, -0x28.ffffffffffffffcp0L, -8.6161018414163982777002940498289948893044e-33L),
14584 TEST_f_f (tgamma, -0x29.000000000000004p0L, 8.6161018414163980549537337663264762179535e-33L),
14585 TEST_f_f (tgamma, -0x29.ffffffffffffffcp0L, 2.0514528193848567329552463626090806737389e-34L),
14586 TEST_f_f (tgamma, -0x2a.000000000000004p0L, -2.0514528193848566795814269269517457847791e-34L),
14587 TEST_f_f (tgamma, -0x31.ffffffffffffffcp0L, 9.4768689712397635680446279661359728835046e-48L),
14588 TEST_f_f (tgamma, -0x32.000000000000004p0L, -9.4768689712397633101385547903658075308777e-48L),
14589 TEST_f_f (tgamma, -0x63.ffffffffffffff8p0L, 1.5442090669841618542494279375256856430049e-141L),
14590 TEST_f_f (tgamma, -0x64.000000000000008p0L, -1.5442090669841617554527108348771968070612e-141L),
14591 TEST_f_f (tgamma, -0x95.ffffffffffffffp0L, 1.2612069237291916400144732227892704713839e-246L),
14592 TEST_f_f (tgamma, -0x96.00000000000001p0L, -1.2612069237291914644980030550324645611752e-246L),
14593 TEST_f_f (tgamma, -0xb4.ffffffffffffffp0L, -1.9816628031468191243385005680879281767694e-315L),
14594 TEST_f_f (tgamma, -0xb5.00000000000001p0L, 1.9816628031468188382579700510291588022368e-315L),
14595 TEST_f_f (tgamma, -0xb5.ffffffffffffffp0L, 1.0888257160147357826865964233809723297472e-317L),
14596 TEST_f_f (tgamma, -0xb6.00000000000001p0L, -1.0888257160147356253334423783317128355514e-317L),
14597 TEST_f_f (tgamma, -0xb6.ffffffffffffffp0L, -5.9498673006269714905418984659220067091260e-320L),
14598 TEST_f_f (tgamma, -0xb7.00000000000001p0L, 5.9498673006269706297861824177538685763601e-320L),
14599 TEST_f_f (tgamma, -0xb7.ffffffffffffffp0L, 3.2336235329494410277123118903958061569834e-322L),
14600 TEST_f_f (tgamma, -0xb8.00000000000001p0L, -3.2336235329494405594225146768193434900135e-322L),
14601 TEST_f_f (tgamma, -0xbb.ffffffffffffffp0L, 2.6730392040715350119087465463119939092815e-331L),
14602 TEST_f_f (tgamma, -0xbc.00000000000001p0L, -2.6730392040715346232108532050343031951651e-331L),
14603 TEST_f_f (tgamma, -0xbc.ffffffffffffffp0L, -1.4143064571807063556111222197839950086445e-333L),
14604 TEST_f_f (tgamma, -0xbd.00000000000001p0L, 1.4143064571807061497431633629389135273431e-333L),
14605 TEST_f_f (tgamma, -0xbd.ffffffffffffffp0L, 7.4437181956879281879706555863416819210399e-336L),
14606 TEST_f_f (tgamma, -0xbe.00000000000001p0L, -7.4437181956879271033676895858841525581153e-336L),
14607 TEST_f_f (tgamma, -0xbe.ffffffffffffffp0L, -3.8972346574282346536709453101948570578636e-338L),
14608 TEST_f_f (tgamma, -0xbf.00000000000001p0L, 3.8972346574282340852496542564155275274974e-338L),
14609 TEST_f_f (tgamma, -0xf9.ffffffffffffffp0L, 2.2289142548411573883553287678043297937797e-476L),
14610 TEST_f_f (tgamma, -0xfa.00000000000001p0L, -2.2289142548411570466476165308364665814265e-476L),
14611 TEST_f_f (tgamma, -0x1f3.fffffffffffffep0L, 2.9528489142763141594943668922610562530068e-1118L),
14612 TEST_f_f (tgamma, -0x1f4.00000000000002p0L, -2.9528489142763131406565394149878256133744e-1118L),
14613 TEST_f_f (tgamma, -0x2ed.fffffffffffffcp0L, 6.9801511765871818502006905472380418430269e-1817L),
14614 TEST_f_f (tgamma, -0x2ee.00000000000004p0L, -6.9801511765871767194421856376592926002995e-1817L),
14615 TEST_f_f (tgamma, -0x3e7.fffffffffffffcp0L, 4.4768809295877296071892611539415773519036e-2552L),
14616 TEST_f_f (tgamma, -0x3e8.00000000000004p0L, -4.4768809295877261735541135972060089530309e-2552L),
14617 TEST_f_f (tgamma, -0x4e1.fffffffffffff8p0L, 5.4651488569236507565341414077911790252381e-3315L),
14618 TEST_f_f (tgamma, -0x4e2.00000000000008p0L, -5.4651488569236421026544487194247355967789e-3315L),
14619 TEST_f_f (tgamma, -0x5db.fffffffffffff8p0L, 1.8718211510339187689122114747834510481993e-4099L),
14620 TEST_f_f (tgamma, -0x5dc.00000000000008p0L, -1.8718211510339157291960718369454861898499e-4099L),
14621 TEST_f_f (tgamma, -0x6d5.fffffffffffff8p0L, 4.2925786447266492555651378780094011518063e-4902L),
14622 TEST_f_f (tgamma, -0x6d6.00000000000008p0L, -4.2925786447266421378134368786479937285900e-4902L),
14623 TEST_f_f (tgamma, -0x6e2.fffffffffffff8p0L, -2.8229173528168668283609231628661510187536e-4944L, UNDERFLOW_EXCEPTION),
14624 TEST_f_f (tgamma, -0x6e3.00000000000008p0L, 2.8229173528168621428945467532322397890424e-4944L, UNDERFLOW_EXCEPTION),
14625 TEST_f_f (tgamma, -0x6e3.fffffffffffff8p0L, 1.6002932839097884515524894602387278842659e-4947L, UNDERFLOW_EXCEPTION),
14626 TEST_f_f (tgamma, -0x6e4.00000000000008p0L, -1.6002932839097857951909742110188634438017e-4947L, UNDERFLOW_EXCEPTION),
14627 TEST_f_f (tgamma, -0x6e4.fffffffffffff8p0L, -9.0668174725767051085164382743343408095146e-4951L, UNDERFLOW_EXCEPTION),
14628 TEST_f_f (tgamma, -0x6e5.00000000000008p0L, 9.0668174725766900571689083050287838090189e-4951L, UNDERFLOW_EXCEPTION),
14629 # if LDBL_MANT_DIG <= 64
14630 TEST_f_f (tgamma, -0x6e5.fffffffffffff8p0L, plus_zero, UNDERFLOW_EXCEPTION),
14631 TEST_f_f (tgamma, -0x6e6.00000000000008p0L, minus_zero, UNDERFLOW_EXCEPTION),
14632 # else
14633 TEST_f_f (tgamma, -0x6e5.fffffffffffff8p0L, 5.1340982290921319983501912122292601780326e-4954L, UNDERFLOW_EXCEPTION),
14634 TEST_f_f (tgamma, -0x6e6.00000000000008p0L, -5.1340982290921234748578193083614111497314e-4954L, UNDERFLOW_EXCEPTION),
14635 # endif
14636 # if LDBL_MANT_DIG >= 113
14637 TEST_f_f (tgamma, 0x8.0000000000000000000000000008p0L, 5.0400000000000000000000000000000156521606e+03L),
14638 TEST_f_f (tgamma, 0x7.fffffffffffffffffffffffffffcp0L, 5.0399999999999999999999999999999921739197e+03L),
14639 TEST_f_f (tgamma, 0x7.0000000000000000000000000004p0L, 7.2000000000000000000000000000000103877321e+02L),
14640 TEST_f_f (tgamma, 0x6.fffffffffffffffffffffffffffcp0L, 7.1999999999999999999999999999999896122679e+02L),
14641 TEST_f_f (tgamma, 0x6.0000000000000000000000000004p0L, 1.2000000000000000000000000000000015772143e+02L),
14642 TEST_f_f (tgamma, 0x5.fffffffffffffffffffffffffffcp0L, 1.1999999999999999999999999999999984227857e+02L),
14643 TEST_f_f (tgamma, 0x5.0000000000000000000000000004p0L, 2.4000000000000000000000000000000027846500e+01L),
14644 TEST_f_f (tgamma, 0x4.fffffffffffffffffffffffffffcp0L, 2.3999999999999999999999999999999972153500e+01L),
14645 TEST_f_f (tgamma, 0x4.0000000000000000000000000004p0L, 6.0000000000000000000000000000000058060671e+00L),
14646 TEST_f_f (tgamma, 0x3.fffffffffffffffffffffffffffep0L, 5.9999999999999999999999999999999970969664e+00L),
14647 TEST_f_f (tgamma, 0x3.0000000000000000000000000002p0L, 2.0000000000000000000000000000000007108872e+00L),
14648 TEST_f_f (tgamma, 0x2.fffffffffffffffffffffffffffep0L, 1.9999999999999999999999999999999992891128e+00L),
14649 TEST_f_f (tgamma, 0x2.0000000000000000000000000002p0L, 1.0000000000000000000000000000000001628506e+00L),
14650 TEST_f_f (tgamma, 0x1.ffffffffffffffffffffffffffffp0L, 9.9999999999999999999999999999999991857470e-01L),
14651 TEST_f_f (tgamma, 0x1.0000000000000000000000000001p0L, 9.9999999999999999999999999999999988883231e-01L),
14652 TEST_f_f (tgamma, 0x0.ffffffffffffffffffffffffffff8p0L, 1.0000000000000000000000000000000000555838e+00L),
14653 TEST_f_f (tgamma, -0x0.ffffffffffffffffffffffffffff8p0L, -1.0384593717069655257060992658440192422784e+34L),
14654 TEST_f_f (tgamma, -0x1.0000000000000000000000000001p0L, 5.1922968585348276285304963292200955772157e+33L),
14655 TEST_f_f (tgamma, -0x1.ffffffffffffffffffffffffffffp0L, 2.5961484292674138142652481646100484613922e+33L),
14656 TEST_f_f (tgamma, -0x2.0000000000000000000000000002p0L, -1.2980742146337069071326240823050235386078e+33L),
14657 TEST_f_f (tgamma, -0x2.fffffffffffffffffffffffffffep0L, -4.3269140487790230237754136076834154268628e+32L),
14658 TEST_f_f (tgamma, -0x3.0000000000000000000000000002p0L, 4.3269140487790230237754136076834112398039e+32L),
14659 TEST_f_f (tgamma, -0x3.fffffffffffffffffffffffffffep0L, 1.0817285121947557559438534019208539608824e+32L),
14660 TEST_f_f (tgamma, -0x4.0000000000000000000000000004p0L, -5.4086425609737787797192670096042603911764e+31L),
14661 TEST_f_f (tgamma, -0x4.fffffffffffffffffffffffffffcp0L, -1.0817285121947557559438534019208547550981e+31L),
14662 TEST_f_f (tgamma, -0x5.0000000000000000000000000004p0L, 1.0817285121947557559438534019208519115686e+31L),
14663 TEST_f_f (tgamma, -0x5.fffffffffffffffffffffffffffcp0L, 1.8028808536579262599064223365347581566449e+30L),
14664 TEST_f_f (tgamma, -0x6.0000000000000000000000000004p0L, -1.8028808536579262599064223365347529544662e+30L),
14665 TEST_f_f (tgamma, -0x6.fffffffffffffffffffffffffffcp0L, -2.5755440766541803712948890521925119357966e+29L),
14666 TEST_f_f (tgamma, -0x7.0000000000000000000000000004p0L, 2.5755440766541803712948890521925039372193e+29L),
14667 TEST_f_f (tgamma, -0x7.fffffffffffffffffffffffffffcp0L, 3.2194300958177254641186113152406402297656e+28L),
14668 TEST_f_f (tgamma, -0x8.0000000000000000000000000008p0L, -1.6097150479088627320593056576203121511868e+28L),
14669 TEST_f_f (tgamma, -0x9.fffffffffffffffffffffffffff8p0L, 1.7885722754542919245103396195781369922635e+26L),
14670 TEST_f_f (tgamma, -0xa.0000000000000000000000000008p0L, -1.7885722754542919245103396195781240306642e+26L),
14671 TEST_f_f (tgamma, -0x13.fffffffffffffffffffffffffffp0L, 1.3338743301940057859272772747600099590309e+14L),
14672 TEST_f_f (tgamma, -0x14.000000000000000000000000001p0L, -1.3338743301940057859272772747599851284049e+14L),
14673 TEST_f_f (tgamma, -0x1d.fffffffffffffffffffffffffffp0L, 1.2234309326134994173819319571374205986026e+00L),
14674 TEST_f_f (tgamma, -0x1e.000000000000000000000000001p0L, -1.2234309326134994173819319571373948286903e+00L),
14675 TEST_f_f (tgamma, -0x27.ffffffffffffffffffffffffffep0L, 1.9886779934224431790713007246380976767855e-16L),
14676 TEST_f_f (tgamma, -0x28.000000000000000000000000002p0L, -1.9886779934224431790713007246380069485580e-16L),
14677 TEST_f_f (tgamma, -0x28.ffffffffffffffffffffffffffep0L, -4.8504341302986419001739042064343853066259e-18L),
14678 TEST_f_f (tgamma, -0x29.000000000000000000000000002p0L, 4.8504341302986419001739042064341625600656e-18L),
14679 TEST_f_f (tgamma, -0x29.ffffffffffffffffffffffffffep0L, 1.1548652691187242619461676681986633377063e-19L),
14680 TEST_f_f (tgamma, -0x2a.000000000000000000000000002p0L, -1.1548652691187242619461676681986099638869e-19L),
14681 TEST_f_f (tgamma, -0x31.ffffffffffffffffffffffffffep0L, 5.3350029459393017997786969431322287652396e-33L),
14682 TEST_f_f (tgamma, -0x32.000000000000000000000000002p0L, -5.3350029459393017997786969431319708591664e-33L),
14683 TEST_f_f (tgamma, -0x63.ffffffffffffffffffffffffffcp0L, 8.6931242233150155021453586128730281632676e-127L),
14684 TEST_f_f (tgamma, -0x64.000000000000000000000000004p0L, -8.6931242233150155021453586128720401960966e-127L),
14685 TEST_f_f (tgamma, -0x95.ffffffffffffffffffffffffff8p0L, 7.0999637896798458052083945552094635720486e-232L),
14686 TEST_f_f (tgamma, -0x96.000000000000000000000000008p0L, -7.0999637896798458052083945552077084073470e-232L),
14687 TEST_f_f (tgamma, -0xb4.ffffffffffffffffffffffffff8p0L, -1.1155769827282483165407420451477844041365e-300L),
14688 TEST_f_f (tgamma, -0xb5.000000000000000000000000008p0L, 1.1155769827282483165407420451474983236060e-300L),
14689 TEST_f_f (tgamma, -0xb5.ffffffffffffffffffffffffff8p0L, 6.1295438611442215194546266216911239298981e-303L),
14690 TEST_f_f (tgamma, -0xb6.000000000000000000000000008p0L, -6.1295438611442215194546266216895503983577e-303L),
14691 TEST_f_f (tgamma, -0xb6.ffffffffffffffffffffffffff8p0L, -3.3494775197509407210134571703230189921356e-305L),
14692 TEST_f_f (tgamma, -0xb7.000000000000000000000000008p0L, 3.3494775197509407210134571703221582364195e-305L),
14693 TEST_f_f (tgamma, -0xb7.ffffffffffffffffffffffffff8p0L, 1.8203682172559460440290528099581627396147e-307L),
14694 TEST_f_f (tgamma, -0xb8.000000000000000000000000008p0L, -1.8203682172559460440290528099576944498174e-307L),
14695 TEST_f_f (tgamma, -0xbb.ffffffffffffffffffffffffff8p0L, 1.5047872954254114273289393917555491216542e-316L),
14696 TEST_f_f (tgamma, -0xbc.000000000000000000000000008p0L, -1.5047872954254114273289393917551604237609e-316L),
14697 TEST_f_f (tgamma, -0xbc.ffffffffffffffffffffffffff8p0L, -7.9618375419333937953912137129923244334851e-319L),
14698 TEST_f_f (tgamma, -0xbd.000000000000000000000000008p0L, 7.9618375419333937953912137129902657538965e-319L),
14699 TEST_f_f (tgamma, -0xbd.ffffffffffffffffffffffffff8p0L, 4.1904408115438914712585335331538555086887e-321L),
14700 TEST_f_f (tgamma, -0xbe.000000000000000000000000008p0L, -4.1904408115438914712585335331527709057227e-321L),
14701 TEST_f_f (tgamma, -0xbe.ffffffffffffffffffffffffff8p0L, -2.1939480688711473671510646770439036908579e-323L),
14702 TEST_f_f (tgamma, -0xbf.000000000000000000000000008p0L, 2.1939480688711473671510646770433352695669e-323L),
14703 TEST_f_f (tgamma, -0xf9.ffffffffffffffffffffffffff8p0L, 1.2547671759429278005937024349858508569625e-461L),
14704 TEST_f_f (tgamma, -0xfa.000000000000000000000000008p0L, -1.2547671759429278005937024349855091492502e-461L),
14705 TEST_f_f (tgamma, -0x1f3.ffffffffffffffffffffffffffp0L, 1.6623061587520224800948170558276526986560e-1103L),
14706 TEST_f_f (tgamma, -0x1f4.00000000000000000000000001p0L, -1.6623061587520224800948170558266338608285e-1103L),
14707 TEST_f_f (tgamma, -0x2ed.fffffffffffffffffffffffffep0L, 3.9294757797334687313030998663853566763041e-1802L),
14708 TEST_f_f (tgamma, -0x2ee.00000000000000000000000002p0L, -3.9294757797334687313030998663802259177992e-1802L),
14709 TEST_f_f (tgamma, -0x3e7.fffffffffffffffffffffffffep0L, 2.5202599107841713834679953735597552855978e-2537L),
14710 TEST_f_f (tgamma, -0x3e8.00000000000000000000000002p0L, -2.5202599107841713834679953735563216504503e-2537L),
14711 TEST_f_f (tgamma, -0x4e1.fffffffffffffffffffffffffcp0L, 3.0766052944457032773369415396747635242705e-3300L),
14712 TEST_f_f (tgamma, -0x4e2.00000000000000000000000004p0L, -3.0766052944457032773369415396661096445778e-3300L),
14713 TEST_f_f (tgamma, -0x5db.fffffffffffffffffffffffffcp0L, 1.0537416297875703295453200836588944487917e-4084L),
14714 TEST_f_f (tgamma, -0x5dc.00000000000000000000000004p0L, -1.0537416297875703295453200836558547326520e-4084L),
14715 TEST_f_f (tgamma, -0x6d5.fffffffffffffffffffffffffcp0L, 2.4165069481061837867659591369998698607387e-4887L),
14716 TEST_f_f (tgamma, -0x6d6.00000000000000000000000004p0L, -2.4165069481061837867659591369927521090377e-4887L),
14717 TEST_f_f (tgamma, -0x6e2.fffffffffffffffffffffffffcp0L, -1.5891611922804672355414813803008070609431e-4929L),
14718 TEST_f_f (tgamma, -0x6e3.00000000000000000000000004p0L, 1.5891611922804672355414813802961215945667e-4929L),
14719 TEST_f_f (tgamma, -0x6e3.fffffffffffffffffffffffffcp0L, 9.0088502963745308137272187091882496519917e-4933L, UNDERFLOW_EXCEPTION),
14720 TEST_f_f (tgamma, -0x6e4.00000000000000000000000004p0L, -9.0088502963745308137272187091616860368392e-4933L, UNDERFLOW_EXCEPTION),
14721 TEST_f_f (tgamma, -0x6e4.fffffffffffffffffffffffffcp0L, -5.1041644738665896961627301468488672286746e-4936L, UNDERFLOW_EXCEPTION),
14722 TEST_f_f (tgamma, -0x6e5.00000000000000000000000004p0L, 5.1041644738665896961627301468338158811446e-4936L, UNDERFLOW_EXCEPTION),
14723 TEST_f_f (tgamma, -0x6e5.fffffffffffffffffffffffffcp0L, 2.8902403589278537350864836618623260468143e-4939L, UNDERFLOW_EXCEPTION),
14724 TEST_f_f (tgamma, -0x6e6.00000000000000000000000004p0L, -2.8902403589278537350864836618538025544424e-4939L, UNDERFLOW_EXCEPTION),
14725 TEST_f_f (tgamma, -0x6eb.fffffffffffffffffffffffffcp0L, 9.4152481960798287090819640211017219042636e-4959L, UNDERFLOW_EXCEPTION),
14726 TEST_f_f (tgamma, -0x6ec.00000000000000000000000004p0L, -9.4152481960798287090819640210739431797168e-4959L, UNDERFLOW_EXCEPTION),
14727 TEST_f_f (tgamma, -0x6ec.fffffffffffffffffffffffffcp0L, -5.3103486723518492437010513373388172315540e-4962L, UNDERFLOW_EXCEPTION),
14728 TEST_f_f (tgamma, -0x6ed.00000000000000000000000004p0L, 5.3103486723518492437010513373231484108489e-4962L, UNDERFLOW_EXCEPTION),
14729 TEST_f_f (tgamma, -0x6ed.fffffffffffffffffffffffffcp0L, 2.9934321715624854812294539669328172615019e-4965L, UNDERFLOW_EXCEPTION),
14730 TEST_f_f (tgamma, -0x6ee.00000000000000000000000004p0L, -2.9934321715624854812294539669239841152754e-4965L, UNDERFLOW_EXCEPTION),
14731 TEST_f_f (tgamma, -0x6ee.fffffffffffffffffffffffffcp0L, minus_zero, UNDERFLOW_EXCEPTION),
14732 TEST_f_f (tgamma, -0x6ef.00000000000000000000000004p0L, plus_zero, UNDERFLOW_EXCEPTION),
14733 # endif
14734 #endif
14735 TEST_f_f (tgamma, -0x1.0a32a2p+5L, 1.8125267978155035272941154746083439329912e-37L),
14736 #ifndef TEST_FLOAT
14737 TEST_f_f (tgamma, -0x1.5800000080001p+7L, -3.1439271448823567326093363350637118195240e-304L, UNDERFLOW_EXCEPTION_LDOUBLE_IBM),
14738 #endif
14739 TEST_f_f (tgamma, 18.5L, 1.4986120533153361177371791123515513270334e+15L),
14740 TEST_f_f (tgamma, 19.5L, 2.7724322986333718178137813578503699550119e+16L),
14741 TEST_f_f (tgamma, 23.5L, 5.3613035875444147334274983856108155717836e+21L),
14742 TEST_f_f (tgamma, 29.5L, 1.6348125198274266444378807806868221866931e+30L),
14743 TEST_f_f (tgamma, 30.5L, 4.8226969334909086010917483030261254507447e+31L),
14744 TEST_f_f (tgamma, 31.5L, 1.4709225647147271233329832324229682624771e+33L),
14745 TEST_f_f (tgamma, 32.5L, 4.6334060788513904384988971821323500268029e+34L),
14746 TEST_f_f (tgamma, 33.5L, 1.5058569756267018925121415841930137587110e+36L),
14747 TEST_f_f (tgamma, 34.5L, 5.0446208683494513399156743070465960916817e+37L),
14748 TEST_f_f (tgamma, 0x2.30a43cp+4L, 3.4027979115654976101247558405326779640190e+38L),
14749 #ifdef TEST_FLOAT
14750 TEST_f_f (tgamma, 0x2.30a44p+4L, plus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
14751 #else
14752 TEST_f_f (tgamma, 0x2.30a44p+4L, 3.4028438913396451054667218138127983367181e+38L),
14753 #endif
14754 #ifndef TEST_FLOAT
14755 TEST_f_f (tgamma, 0xa.b9fd72b0fb238p+4L, 1.7976931348622298700886249281842651388250e+308L),
14756 # if !defined TEST_LDOUBLE || LDBL_MAX_EXP <= 1024
14757 TEST_f_f (tgamma, 0xa.b9fd72b0fb24p+4L, plus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
14758 # else
14759 TEST_f_f (tgamma, 0xa.b9fd72b0fb24p+4L, 1.7976931348624926129589466917917870782484e+308L),
14760 # endif
14761 #endif
14762 #if defined TEST_LDOUBLE && LDBL_MANT_DIG >= 106
14763 TEST_f_f (tgamma, 0xa.b9fd72b0fb23a9ddbf0d3804f4p+4L, 1.7976931348623158079372897140307719334857e+308L),
14764 # if LDBL_MAX_EXP <= 1024
14765 TEST_f_f (tgamma, 0xa.b9fd72b0fb23a9ddbf0d3804f8p+4L, plus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
14766 # else
14767 TEST_f_f (tgamma, 0xa.b9fd72b0fb23a9ddbf0d3804f8p+4L, 1.7976931348623158079372897140599422519044e+308L),
14768 # endif
14769 #endif
14770 #if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
14771 TEST_f_f (tgamma, 0x6.db8c603359a97108p+8L, 1.1897314953572317517071551278058233700012e+4932L),
14772 TEST_f_f (tgamma, 0x6.db8c603359a9711p+8L, plus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
14773 # if LDBL_MANT_DIG >= 113
14774 TEST_f_f (tgamma, 0x6.db8c603359a971081bc4a2e9dfdp+8L, 1.1897314953572317650857593266265995494998e+4932L),
14775 TEST_f_f (tgamma, 0x6.db8c603359a971081bc4a2e9dfd4p+8L, plus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
14776 # endif
14777 #endif
14778 END_DATA (tgamma)
14779 };
14780
14781 static void
14782 tgamma_test (void)
14783 {
14784 errno = 0;
14785 FUNC(tgamma) (1);
14786 if (errno == ENOSYS)
14787 /* Function not implemented. */
14788 return;
14789
14790 START (tgamma);
14791 RUN_TEST_LOOP_f_f (tgamma, tgamma_test_data, );
14792 END (tgamma);
14793 }
14794
14795
14796 static const struct test_f_f_data trunc_test_data[] =
14797 {
14798 START_DATA (trunc),
14799 TEST_f_f (trunc, plus_infty, plus_infty),
14800 TEST_f_f (trunc, minus_infty, minus_infty),
14801 TEST_f_f (trunc, qnan_value, qnan_value),
14802
14803 TEST_f_f (trunc, 0, 0),
14804 TEST_f_f (trunc, minus_zero, minus_zero),
14805 TEST_f_f (trunc, 0.1, 0),
14806 TEST_f_f (trunc, 0.25, 0),
14807 TEST_f_f (trunc, 0.625, 0),
14808 TEST_f_f (trunc, -0.1, minus_zero),
14809 TEST_f_f (trunc, -0.25, minus_zero),
14810 TEST_f_f (trunc, -0.625, minus_zero),
14811 TEST_f_f (trunc, 1, 1),
14812 TEST_f_f (trunc, -1, -1),
14813 TEST_f_f (trunc, 1.625, 1),
14814 TEST_f_f (trunc, -1.625, -1),
14815
14816 TEST_f_f (trunc, 1048580.625L, 1048580L),
14817 TEST_f_f (trunc, -1048580.625L, -1048580L),
14818
14819 TEST_f_f (trunc, 8388610.125L, 8388610.0L),
14820 TEST_f_f (trunc, -8388610.125L, -8388610.0L),
14821
14822 TEST_f_f (trunc, 4294967296.625L, 4294967296.0L),
14823 TEST_f_f (trunc, -4294967296.625L, -4294967296.0L),
14824
14825 #ifdef TEST_LDOUBLE
14826 /* The result can only be represented in long double. */
14827 TEST_f_f (trunc, 4503599627370495.5L, 4503599627370495.0L),
14828 TEST_f_f (trunc, 4503599627370496.25L, 4503599627370496.0L),
14829 TEST_f_f (trunc, 4503599627370496.5L, 4503599627370496.0L),
14830 TEST_f_f (trunc, 4503599627370496.75L, 4503599627370496.0L),
14831 TEST_f_f (trunc, 4503599627370497.5L, 4503599627370497.0L),
14832
14833 # if LDBL_MANT_DIG > 100
14834 TEST_f_f (trunc, 4503599627370494.5000000000001L, 4503599627370494.0L),
14835 TEST_f_f (trunc, 4503599627370495.5000000000001L, 4503599627370495.0L),
14836 TEST_f_f (trunc, 4503599627370496.5000000000001L, 4503599627370496.0L),
14837 # endif
14838
14839 TEST_f_f (trunc, -4503599627370495.5L, -4503599627370495.0L),
14840 TEST_f_f (trunc, -4503599627370496.25L, -4503599627370496.0L),
14841 TEST_f_f (trunc, -4503599627370496.5L, -4503599627370496.0L),
14842 TEST_f_f (trunc, -4503599627370496.75L, -4503599627370496.0L),
14843 TEST_f_f (trunc, -4503599627370497.5L, -4503599627370497.0L),
14844
14845 # if LDBL_MANT_DIG > 100
14846 TEST_f_f (trunc, -4503599627370494.5000000000001L, -4503599627370494.0L),
14847 TEST_f_f (trunc, -4503599627370495.5000000000001L, -4503599627370495.0L),
14848 TEST_f_f (trunc, -4503599627370496.5000000000001L, -4503599627370496.0L),
14849 # endif
14850
14851 TEST_f_f (trunc, 9007199254740991.5L, 9007199254740991.0L),
14852 TEST_f_f (trunc, 9007199254740992.25L, 9007199254740992.0L),
14853 TEST_f_f (trunc, 9007199254740992.5L, 9007199254740992.0L),
14854 TEST_f_f (trunc, 9007199254740992.75L, 9007199254740992.0L),
14855 TEST_f_f (trunc, 9007199254740993.5L, 9007199254740993.0L),
14856
14857 # if LDBL_MANT_DIG > 100
14858 TEST_f_f (trunc, 9007199254740991.0000000000001L, 9007199254740991.0L),
14859 TEST_f_f (trunc, 9007199254740992.0000000000001L, 9007199254740992.0L),
14860 TEST_f_f (trunc, 9007199254740993.0000000000001L, 9007199254740993.0L),
14861 TEST_f_f (trunc, 9007199254740991.5000000000001L, 9007199254740991.0L),
14862 TEST_f_f (trunc, 9007199254740992.5000000000001L, 9007199254740992.0L),
14863 TEST_f_f (trunc, 9007199254740993.5000000000001L, 9007199254740993.0L),
14864 # endif
14865
14866 TEST_f_f (trunc, -9007199254740991.5L, -9007199254740991.0L),
14867 TEST_f_f (trunc, -9007199254740992.25L, -9007199254740992.0L),
14868 TEST_f_f (trunc, -9007199254740992.5L, -9007199254740992.0L),
14869 TEST_f_f (trunc, -9007199254740992.75L, -9007199254740992.0L),
14870 TEST_f_f (trunc, -9007199254740993.5L, -9007199254740993.0L),
14871
14872 # if LDBL_MANT_DIG > 100
14873 TEST_f_f (trunc, -9007199254740991.0000000000001L, -9007199254740991.0L),
14874 TEST_f_f (trunc, -9007199254740992.0000000000001L, -9007199254740992.0L),
14875 TEST_f_f (trunc, -9007199254740993.0000000000001L, -9007199254740993.0L),
14876 TEST_f_f (trunc, -9007199254740991.5000000000001L, -9007199254740991.0L),
14877 TEST_f_f (trunc, -9007199254740992.5000000000001L, -9007199254740992.0L),
14878 TEST_f_f (trunc, -9007199254740993.5000000000001L, -9007199254740993.0L),
14879 # endif
14880
14881 TEST_f_f (trunc, 72057594037927935.5L, 72057594037927935.0L),
14882 TEST_f_f (trunc, 72057594037927936.25L, 72057594037927936.0L),
14883 TEST_f_f (trunc, 72057594037927936.5L, 72057594037927936.0L),
14884 TEST_f_f (trunc, 72057594037927936.75L, 72057594037927936.0L),
14885 TEST_f_f (trunc, 72057594037927937.5L, 72057594037927937.0L),
14886
14887 TEST_f_f (trunc, -72057594037927935.5L, -72057594037927935.0L),
14888 TEST_f_f (trunc, -72057594037927936.25L, -72057594037927936.0L),
14889 TEST_f_f (trunc, -72057594037927936.5L, -72057594037927936.0L),
14890 TEST_f_f (trunc, -72057594037927936.75L, -72057594037927936.0L),
14891 TEST_f_f (trunc, -72057594037927937.5L, -72057594037927937.0L),
14892
14893 TEST_f_f (trunc, 10141204801825835211973625643007.5L, 10141204801825835211973625643007.0L),
14894 TEST_f_f (trunc, 10141204801825835211973625643008.25L, 10141204801825835211973625643008.0L),
14895 TEST_f_f (trunc, 10141204801825835211973625643008.5L, 10141204801825835211973625643008.0L),
14896 TEST_f_f (trunc, 10141204801825835211973625643008.75L, 10141204801825835211973625643008.0L),
14897 TEST_f_f (trunc, 10141204801825835211973625643009.5L, 10141204801825835211973625643009.0L),
14898 #endif
14899 END_DATA (trunc)
14900 };
14901
14902 static void
14903 trunc_test (void)
14904 {
14905 START (trunc);
14906 RUN_TEST_LOOP_f_f (trunc, trunc_test_data, );
14907 END (trunc);
14908 }
14909
14910 static const struct test_f_f_data y0_test_data[] =
14911 {
14912 START_DATA (y0),
14913 /* y0 is the Bessel function of the second kind of order 0 */
14914 TEST_f_f (y0, -1.0, minus_infty, INVALID_EXCEPTION|ERRNO_EDOM),
14915 TEST_f_f (y0, -max_value, minus_infty, INVALID_EXCEPTION|ERRNO_EDOM),
14916 TEST_f_f (y0, 0.0, minus_infty),
14917 TEST_f_f (y0, qnan_value, qnan_value),
14918 TEST_f_f (y0, plus_infty, 0),
14919
14920 TEST_f_f (y0, 0.125L, -1.38968062514384052915582277745018693L),
14921 TEST_f_f (y0, 0.75L, -0.137172769385772397522814379396581855L),
14922 TEST_f_f (y0, 1.0, 0.0882569642156769579829267660235151628L),
14923 TEST_f_f (y0, 1.5, 0.382448923797758843955068554978089862L),
14924 TEST_f_f (y0, 2.0, 0.510375672649745119596606592727157873L),
14925 TEST_f_f (y0, 8.0, 0.223521489387566220527323400498620359L),
14926 TEST_f_f (y0, 10.0, 0.0556711672835993914244598774101900481L),
14927
14928 TEST_f_f (y0, 0x1.3ffp+74L, 1.818984347516051243459467456433028748678e-12L),
14929
14930 #ifndef TEST_FLOAT
14931 TEST_f_f (y0, 0x1.ff00000000002p+840L, 1.846591691699331493194965158699937660696e-127L),
14932 TEST_f_f (y0, 0x1p1023L, 8.2687542933709649327986678723012001545638e-155L),
14933 #endif
14934
14935 #if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
14936 TEST_f_f (y0, 0x1p16382L, 8.0839224448726336195866026476176740513439e-2467L),
14937 TEST_f_f (y0, 0x1p16383L, -3.8895531955766020648617743624167352352217e-2467L),
14938 #endif
14939
14940 TEST_f_f (y0, 0x1p-10L, -4.4865150767109739412411806297168793661098L),
14941 TEST_f_f (y0, 0x1p-20L, -8.8992283012125827603076426611387876938160L),
14942 TEST_f_f (y0, 0x1p-30L, -1.3311940304267782826037118027401817264906e+1L),
14943 TEST_f_f (y0, 0x1p-40L, -1.7724652307320814696990854700366226762563e+1L),
14944 TEST_f_f (y0, 0x1p-50L, -2.2137364310373846564919987139743760738155e+1L),
14945 TEST_f_f (y0, 0x1p-60L, -2.6550076313426878432849115782108205929120e+1L),
14946 TEST_f_f (y0, 0x1p-70L, -3.0962788316479910300778244424468159753887e+1L),
14947 TEST_f_f (y0, 0x1p-80L, -3.5375500319532942168707373066828113573541e+1L),
14948 TEST_f_f (y0, 0x1p-90L, -3.9788212322585974036636501709188067393195e+1L),
14949 TEST_f_f (y0, 0x1p-100L, -4.420092432563900590456563035154802121284e+1L),
14950 TEST_f_f (y0, 0x1p-110L, -4.861363632869203777249475899390797503250e+1L),
14951 END_DATA (y0)
14952 };
14953
14954 static void
14955 y0_test (void)
14956 {
14957 FLOAT s, c;
14958 errno = 0;
14959 FUNC (sincos) (0, &s, &c);
14960 if (errno == ENOSYS)
14961 /* Required function not implemented. */
14962 return;
14963 FUNC(y0) (1);
14964 if (errno == ENOSYS)
14965 /* Function not implemented. */
14966 return;
14967
14968 START (y0);
14969 RUN_TEST_LOOP_f_f (y0, y0_test_data, );
14970 END (y0);
14971 }
14972
14973
14974 static const struct test_f_f_data y1_test_data[] =
14975 {
14976 START_DATA (y1),
14977 /* y1 is the Bessel function of the second kind of order 1 */
14978 TEST_f_f (y1, -1.0, minus_infty, INVALID_EXCEPTION|ERRNO_EDOM),
14979 TEST_f_f (y1, -max_value, minus_infty, INVALID_EXCEPTION|ERRNO_EDOM),
14980 TEST_f_f (y1, 0.0, minus_infty),
14981 TEST_f_f (y1, plus_infty, 0),
14982 TEST_f_f (y1, qnan_value, qnan_value),
14983
14984 TEST_f_f (y1, 0.125L, -5.19993611253477499595928744876579921L),
14985 TEST_f_f (y1, 0.75L, -1.03759455076928541973767132140642198L),
14986 TEST_f_f (y1, 1.0, -0.781212821300288716547150000047964821L),
14987 TEST_f_f (y1, 1.5, -0.412308626973911295952829820633445323L),
14988 TEST_f_f (y1, 2.0, -0.107032431540937546888370772277476637L),
14989 TEST_f_f (y1, 8.0, -0.158060461731247494255555266187483550L),
14990 TEST_f_f (y1, 10.0, 0.249015424206953883923283474663222803L),
14991
14992 TEST_f_f (y1, 0x1.27e204p+99L, -8.881610148467797208469612080785210013461e-16L),
14993
14994 #ifndef TEST_FLOAT
14995 TEST_f_f (y1, 0x1.001000001p+593L, 3.927269966354206207832593635798954916263e-90L),
14996 TEST_f_f (y1, 0x1p1023L, 1.5665258060609012834424478437196679802783e-155L),
14997 #endif
14998
14999 #if defined TEST_LDOUBLE && LDBL_MAX_EXP >= 16384
15000 TEST_f_f (y1, 0x1p16382L, 1.2193782500509000574176799046642541129387e-2466L),
15001 TEST_f_f (y1, 0x1p16383L, -9.5859502826270374691362975419147645151233e-2467L),
15002 #endif
15003
15004 TEST_f_f (y1, 0x1p-10L, -6.5190099301063115047395187618929589514382e+02L),
15005 TEST_f_f (y1, 0x1p-20L, -6.6754421443450423911167962313100637952285e+05L),
15006 TEST_f_f (y1, 0x1p-30L, -6.8356527557643159612937462812258975438856e+08L),
15007 TEST_f_f (y1, 0x1p-40L, -6.9997084219026594793707805777425993547887e+11L),
15008 TEST_f_f (y1, 0x1p-50L, -7.1677014240283233068755952926181262431559e+14L),
15009 TEST_f_f (y1, 0x1p-60L, -7.3397262582050030662406095795388448059822e+17L),
15010 TEST_f_f (y1, 0x1p-70L, -7.5158796884019231398303842094477769620063e+20L),
15011 TEST_f_f (y1, 0x1p-80L, -7.6962608009235692951863134304745236090943e+23L),
15012 TEST_f_f (y1, 0x1p-90L, -7.8809710601457349582707849528059121757126e+26L),
15013 TEST_f_f (y1, 0x1p-100L, -8.0701143655892325972692837916732540679297e+29L),
15014 TEST_f_f (y1, 0x1p-110L, -8.2637971103633741796037466026734121655600e+32L),
15015 END_DATA (y1)
15016 };
15017
15018 static void
15019 y1_test (void)
15020 {
15021 FLOAT s, c;
15022 errno = 0;
15023 FUNC (sincos) (0, &s, &c);
15024 if (errno == ENOSYS)
15025 /* Required function not implemented. */
15026 return;
15027 FUNC(y1) (1);
15028 if (errno == ENOSYS)
15029 /* Function not implemented. */
15030 return;
15031
15032 START (y1);
15033 RUN_TEST_LOOP_f_f (y1, y1_test_data, );
15034 END (y1);
15035 }
15036
15037
15038 static const struct test_if_f_data yn_test_data[] =
15039 {
15040 START_DATA (yn),
15041 /* yn is the Bessel function of the second kind of order n */
15042 /* yn (0, x) == y0 (x) */
15043 TEST_if_f (yn, 0, -1.0, minus_infty, INVALID_EXCEPTION|ERRNO_EDOM),
15044 TEST_if_f (yn, 0, -max_value, minus_infty, INVALID_EXCEPTION|ERRNO_EDOM),
15045 TEST_if_f (yn, 0, 0.0, minus_infty),
15046 TEST_if_f (yn, 0, qnan_value, qnan_value),
15047 TEST_if_f (yn, 0, plus_infty, 0),
15048
15049 TEST_if_f (yn, 0, 0.125L, -1.38968062514384052915582277745018693L),
15050 TEST_if_f (yn, 0, 0.75L, -0.137172769385772397522814379396581855L),
15051 TEST_if_f (yn, 0, 1.0, 0.0882569642156769579829267660235151628L),
15052 TEST_if_f (yn, 0, 1.5, 0.382448923797758843955068554978089862L),
15053 TEST_if_f (yn, 0, 2.0, 0.510375672649745119596606592727157873L),
15054 TEST_if_f (yn, 0, 8.0, 0.223521489387566220527323400498620359L),
15055 TEST_if_f (yn, 0, 10.0, 0.0556711672835993914244598774101900481L),
15056
15057 /* yn (1, x) == y1 (x) */
15058 TEST_if_f (yn, 1, -1.0, minus_infty, INVALID_EXCEPTION|ERRNO_EDOM),
15059 TEST_if_f (yn, 1, 0.0, minus_infty),
15060 TEST_if_f (yn, 1, plus_infty, 0),
15061 TEST_if_f (yn, 1, qnan_value, qnan_value),
15062
15063 TEST_if_f (yn, 1, 0.125L, -5.19993611253477499595928744876579921L),
15064 TEST_if_f (yn, 1, 0.75L, -1.03759455076928541973767132140642198L),
15065 TEST_if_f (yn, 1, 1.0, -0.781212821300288716547150000047964821L),
15066 TEST_if_f (yn, 1, 1.5, -0.412308626973911295952829820633445323L),
15067 TEST_if_f (yn, 1, 2.0, -0.107032431540937546888370772277476637L),
15068 TEST_if_f (yn, 1, 8.0, -0.158060461731247494255555266187483550L),
15069 TEST_if_f (yn, 1, 10.0, 0.249015424206953883923283474663222803L),
15070
15071 /* yn (3, x) */
15072 TEST_if_f (yn, 3, plus_infty, 0),
15073 TEST_if_f (yn, 3, qnan_value, qnan_value),
15074
15075 TEST_if_f (yn, 3, 0.125L, -2612.69757350066712600220955744091741L),
15076 TEST_if_f (yn, 3, 0.75L, -12.9877176234475433186319774484809207L),
15077 TEST_if_f (yn, 3, 1.0, -5.82151760596472884776175706442981440L),
15078 TEST_if_f (yn, 3, 2.0, -1.12778377684042778608158395773179238L),
15079 TEST_if_f (yn, 3, 10.0, -0.251362657183837329779204747654240998L),
15080
15081 /* yn (10, x) */
15082 TEST_if_f (yn, 10, plus_infty, 0),
15083 TEST_if_f (yn, 10, qnan_value, qnan_value),
15084
15085 TEST_if_f (yn, 10, 0.125L, -127057845771019398.252538486899753195L),
15086 TEST_if_f (yn, 10, 0.75L, -2133501638.90573424452445412893839236L),
15087 TEST_if_f (yn, 10, 1.0, -121618014.278689189288130426667971145L),
15088 TEST_if_f (yn, 10, 2.0, -129184.542208039282635913145923304214L),
15089 TEST_if_f (yn, 10, 10.0, -0.359814152183402722051986577343560609L),
15090
15091 /* Check whether yn returns correct value for LDBL_MIN, DBL_MIN,
15092 and FLT_MIN. See Bug 14173. */
15093 TEST_if_f (yn, 10, min_value, minus_infty, OVERFLOW_EXCEPTION|ERRNO_ERANGE),
15094 END_DATA (yn)
15095 };
15096
15097 static void
15098 yn_test (void)
15099 {
15100 FLOAT s, c;
15101 errno = 0;
15102 FUNC (sincos) (0, &s, &c);
15103 if (errno == ENOSYS)
15104 /* Required function not implemented. */
15105 return;
15106 FUNC(yn) (1, 1);
15107 if (errno == ENOSYS)
15108 /* Function not implemented. */
15109 return;
15110
15111 START (yn);
15112 RUN_TEST_LOOP_if_f (yn, yn_test_data, );
15113 END (yn);
15114 }
15115
15116
15117 static const struct test_f_f_data significand_test_data[] =
15118 {
15119 START_DATA (significand),
15120 /* significand returns the mantissa of the exponential representation. */
15121 /* TODO: missing +/-Inf as well as qNaN tests. */
15122 TEST_f_f (significand, 4.0, 1.0),
15123 TEST_f_f (significand, 6.0, 1.5),
15124 TEST_f_f (significand, 8.0, 1.0),
15125 END_DATA (significand)
15126 };
15127
15128 static void
15129 significand_test (void)
15130 {
15131 START (significand);
15132 RUN_TEST_LOOP_f_f (significand, significand_test_data, );
15133 END (significand);
15134 }
15135
15136
15137 static void
15138 initialize (void)
15139 {
15140 fpstack_test ("start *init*");
15141
15142 /* Clear all exceptions. From now on we must not get random exceptions. */
15143 feclearexcept (FE_ALL_EXCEPT);
15144 errno = 0;
15145
15146 /* Test to make sure we start correctly. */
15147 fpstack_test ("end *init*");
15148 }
15149
15150 /* Definitions of arguments for argp functions. */
15151 static const struct argp_option options[] =
15152 {
15153 { "verbose", 'v', "NUMBER", 0, "Level of verbosity (0..3)"},
15154 { "ulps-file", 'u', NULL, 0, "Output ulps to file ULPs"},
15155 { "no-max-error", 'f', NULL, 0,
15156 "Don't output maximal errors of functions"},
15157 { "no-points", 'p', NULL, 0,
15158 "Don't output results of functions invocations"},
15159 { "ignore-max-ulp", 'i', "yes/no", 0,
15160 "Ignore given maximal errors"},
15161 { "output-dir", 'o', "DIR", 0,
15162 "Directory where generated files will be placed"},
15163 { NULL, 0, NULL, 0, NULL }
15164 };
15165
15166 /* Short description of program. */
15167 static const char doc[] = "Math test suite: " TEST_MSG ;
15168
15169 /* Prototype for option handler. */
15170 static error_t parse_opt (int key, char *arg, struct argp_state *state);
15171
15172 /* Data structure to communicate with argp functions. */
15173 static struct argp argp =
15174 {
15175 options, parse_opt, NULL, doc,
15176 };
15177
15178
15179 /* Handle program arguments. */
15180 static error_t
15181 parse_opt (int key, char *arg, struct argp_state *state)
15182 {
15183 switch (key)
15184 {
15185 case 'f':
15186 output_max_error = 0;
15187 break;
15188 case 'i':
15189 if (strcmp (arg, "yes") == 0)
15190 ignore_max_ulp = 1;
15191 else if (strcmp (arg, "no") == 0)
15192 ignore_max_ulp = 0;
15193 break;
15194 case 'o':
15195 output_dir = (char *) malloc (strlen (arg) + 1);
15196 if (output_dir != NULL)
15197 strcpy (output_dir, arg);
15198 else
15199 return errno;
15200 break;
15201 case 'p':
15202 output_points = 0;
15203 break;
15204 case 'u':
15205 output_ulps = 1;
15206 break;
15207 case 'v':
15208 if (optarg)
15209 verbose = (unsigned int) strtoul (optarg, NULL, 0);
15210 else
15211 verbose = 3;
15212 break;
15213 default:
15214 return ARGP_ERR_UNKNOWN;
15215 }
15216 return 0;
15217 }
15218
15219 #if 0
15220 /* function to check our ulp calculation. */
15221 void
15222 check_ulp (void)
15223 {
15224 int i;
15225
15226 FLOAT u, diff, ulp;
15227 /* This gives one ulp. */
15228 u = FUNC(nextafter) (10, 20);
15229 check_equal (10.0, u, 1, &diff, &ulp);
15230 printf ("One ulp: % .4" PRINTF_NEXPR "\n", ulp);
15231
15232 /* This gives one more ulp. */
15233 u = FUNC(nextafter) (u, 20);
15234 check_equal (10.0, u, 2, &diff, &ulp);
15235 printf ("two ulp: % .4" PRINTF_NEXPR "\n", ulp);
15236
15237 /* And now calculate 100 ulp. */
15238 for (i = 2; i < 100; i++)
15239 u = FUNC(nextafter) (u, 20);
15240 check_equal (10.0, u, 100, &diff, &ulp);
15241 printf ("100 ulp: % .4" PRINTF_NEXPR "\n", ulp);
15242 }
15243 #endif
15244
15245 int
15246 main (int argc, char **argv)
15247 {
15248
15249 int remaining;
15250 char *ulps_file_path;
15251 size_t dir_len = 0;
15252
15253 verbose = 1;
15254 output_ulps = 0;
15255 output_max_error = 1;
15256 output_points = 1;
15257 output_dir = NULL;
15258 /* XXX set to 0 for releases. */
15259 ignore_max_ulp = 0;
15260
15261 /* Parse and process arguments. */
15262 argp_parse (&argp, argc, argv, 0, &remaining, NULL);
15263
15264 if (remaining != argc)
15265 {
15266 fprintf (stderr, "wrong number of arguments");
15267 argp_help (&argp, stdout, ARGP_HELP_SEE, program_invocation_short_name);
15268 exit (EXIT_FAILURE);
15269 }
15270
15271 if (output_ulps)
15272 {
15273 if (output_dir != NULL)
15274 dir_len = strlen (output_dir);
15275 ulps_file_path = (char *) malloc (dir_len + strlen (ulps_file_name) + 1);
15276 if (ulps_file_path == NULL)
15277 {
15278 perror ("can't allocate path for `ULPs' file: ");
15279 exit (1);
15280 }
15281 sprintf (ulps_file_path, "%s%s", output_dir == NULL ? "" : output_dir, ulps_file_name);
15282 ulps_file = fopen (ulps_file_path, "a");
15283 if (ulps_file == NULL)
15284 {
15285 perror ("can't open file `ULPs' for writing: ");
15286 exit (1);
15287 }
15288 }
15289
15290
15291 initialize ();
15292 printf (TEST_MSG);
15293
15294 #if 0
15295 check_ulp ();
15296 #endif
15297
15298 /* Keep the tests a wee bit ordered (according to ISO C99). */
15299 /* Classification macros: */
15300 finite_test ();
15301 fpclassify_test ();
15302 isfinite_test ();
15303 isinf_test ();
15304 isnan_test ();
15305 isnormal_test ();
15306 issignaling_test ();
15307 signbit_test ();
15308
15309 /* Trigonometric functions: */
15310 acos_test ();
15311 acos_test_tonearest ();
15312 acos_test_towardzero ();
15313 acos_test_downward ();
15314 acos_test_upward ();
15315 asin_test ();
15316 asin_test_tonearest ();
15317 asin_test_towardzero ();
15318 asin_test_downward ();
15319 asin_test_upward ();
15320 atan_test ();
15321 atan2_test ();
15322 cos_test ();
15323 cos_test_tonearest ();
15324 cos_test_towardzero ();
15325 cos_test_downward ();
15326 cos_test_upward ();
15327 sin_test ();
15328 sin_test_tonearest ();
15329 sin_test_towardzero ();
15330 sin_test_downward ();
15331 sin_test_upward ();
15332 sincos_test ();
15333 tan_test ();
15334 tan_test_tonearest ();
15335 tan_test_towardzero ();
15336 tan_test_downward ();
15337 tan_test_upward ();
15338
15339 /* Hyperbolic functions: */
15340 acosh_test ();
15341 asinh_test ();
15342 atanh_test ();
15343 cosh_test ();
15344 cosh_test_tonearest ();
15345 cosh_test_towardzero ();
15346 cosh_test_downward ();
15347 cosh_test_upward ();
15348 sinh_test ();
15349 sinh_test_tonearest ();
15350 sinh_test_towardzero ();
15351 sinh_test_downward ();
15352 sinh_test_upward ();
15353 tanh_test ();
15354
15355 /* Exponential and logarithmic functions: */
15356 exp_test ();
15357 exp_test_tonearest ();
15358 exp_test_towardzero ();
15359 exp_test_downward ();
15360 exp_test_upward ();
15361 exp10_test ();
15362 exp2_test ();
15363 expm1_test ();
15364 frexp_test ();
15365 ldexp_test ();
15366 log_test ();
15367 log10_test ();
15368 log1p_test ();
15369 log2_test ();
15370 logb_test ();
15371 logb_test_downward ();
15372 modf_test ();
15373 ilogb_test ();
15374 scalb_test ();
15375 scalbn_test ();
15376 scalbln_test ();
15377 significand_test ();
15378
15379 /* Power and absolute value functions: */
15380 cbrt_test ();
15381 fabs_test ();
15382 hypot_test ();
15383 pow_test ();
15384 pow_test_tonearest ();
15385 pow_test_towardzero ();
15386 pow_test_downward ();
15387 pow_test_upward ();
15388 sqrt_test ();
15389
15390 /* Error and gamma functions: */
15391 erf_test ();
15392 erfc_test ();
15393 gamma_test ();
15394 lgamma_test ();
15395 tgamma_test ();
15396
15397 /* Nearest integer functions: */
15398 ceil_test ();
15399 floor_test ();
15400 nearbyint_test ();
15401 rint_test ();
15402 rint_test_tonearest ();
15403 rint_test_towardzero ();
15404 rint_test_downward ();
15405 rint_test_upward ();
15406 lrint_test ();
15407 lrint_test_tonearest ();
15408 lrint_test_towardzero ();
15409 lrint_test_downward ();
15410 lrint_test_upward ();
15411 llrint_test ();
15412 llrint_test_tonearest ();
15413 llrint_test_towardzero ();
15414 llrint_test_downward ();
15415 llrint_test_upward ();
15416 round_test ();
15417 lround_test ();
15418 llround_test ();
15419 trunc_test ();
15420
15421 /* Remainder functions: */
15422 fmod_test ();
15423 remainder_test ();
15424 remquo_test ();
15425
15426 /* Manipulation functions: */
15427 copysign_test ();
15428 nextafter_test ();
15429 nexttoward_test ();
15430
15431 /* maximum, minimum and positive difference functions */
15432 fdim_test ();
15433 fmax_test ();
15434 fmin_test ();
15435
15436 /* Multiply and add: */
15437 fma_test ();
15438 fma_test_towardzero ();
15439 fma_test_downward ();
15440 fma_test_upward ();
15441
15442 /* Comparison macros: */
15443 isgreater_test ();
15444 isgreaterequal_test ();
15445 isless_test ();
15446 islessequal_test ();
15447 islessgreater_test ();
15448 isunordered_test ();
15449
15450 /* Complex functions: */
15451 cabs_test ();
15452 cacos_test ();
15453 cacosh_test ();
15454 carg_test ();
15455 casin_test ();
15456 casinh_test ();
15457 catan_test ();
15458 catanh_test ();
15459 ccos_test ();
15460 ccosh_test ();
15461 cexp_test ();
15462 cimag_test ();
15463 clog10_test ();
15464 clog_test ();
15465 conj_test ();
15466 cpow_test ();
15467 cproj_test ();
15468 creal_test ();
15469 csin_test ();
15470 csinh_test ();
15471 csqrt_test ();
15472 ctan_test ();
15473 ctan_test_tonearest ();
15474 ctan_test_towardzero ();
15475 ctan_test_downward ();
15476 ctan_test_upward ();
15477 ctanh_test ();
15478 ctanh_test_tonearest ();
15479 ctanh_test_towardzero ();
15480 ctanh_test_downward ();
15481 ctanh_test_upward ();
15482
15483 /* Bessel functions: */
15484 j0_test ();
15485 j1_test ();
15486 jn_test ();
15487 y0_test ();
15488 y1_test ();
15489 yn_test ();
15490
15491 if (output_ulps)
15492 fclose (ulps_file);
15493
15494 printf ("\nTest suite completed:\n");
15495 printf (" %d test cases plus %d tests for exception flags and\n"
15496 " %d tests for errno executed.\n",
15497 noTests, noExcTests, noErrnoTests);
15498 if (noErrors)
15499 {
15500 printf (" %d errors occurred.\n", noErrors);
15501 return 1;
15502 }
15503 printf (" All tests passed successfully.\n");
15504
15505 return 0;
15506 }
15507
15508 /*
15509 * Local Variables:
15510 * mode:c
15511 * End:
15512 */