t_casinh.c revision 1.2 1 1.2 christos /* $NetBSD: t_casinh.c,v 1.2 2016/09/20 17:19:28 christos Exp $ */
2 1.1 maya
3 1.1 maya /*
4 1.1 maya * Written by Maya Rashish
5 1.1 maya * Public domain.
6 1.1 maya *
7 1.1 maya * Testing special values of casinh
8 1.1 maya * Values from ISO/IEC 9899:201x G.6.2.2
9 1.1 maya */
10 1.1 maya
11 1.1 maya #include <atf-c.h>
12 1.1 maya #include <complex.h>
13 1.1 maya #include <math.h>
14 1.1 maya
15 1.1 maya #define RE(z) (((double *)(&z))[0])
16 1.1 maya #define IM(z) (((double *)(&z))[1])
17 1.1 maya
18 1.1 maya static const struct {
19 1.1 maya double input_re;
20 1.1 maya double input_im;
21 1.1 maya double result_re;
22 1.1 maya double result_im;
23 1.1 maya } values[] = {
24 1.1 maya { +0, +0, +0, +0},
25 1.1 maya { +5.032E3, +INFINITY, +INFINITY, +M_PI/2},
26 1.1 maya { +INFINITY, +5.023E3, +INFINITY, +0},
27 1.1 maya { +INFINITY, +INFINITY, +INFINITY, +M_PI/4},
28 1.1 maya #ifdef __HAVE_NANF
29 1.1 maya { +INFINITY, +NAN, +INFINITY, +NAN},
30 1.1 maya { +5.032E3, +NAN, +NAN, +NAN}, /* + FE_INVALID optionally raised */
31 1.1 maya { +NAN, +0, +NAN, +0},
32 1.1 maya { +NAN, -5.023E3, +NAN, +NAN}, /* + FE_INVALID optionally raised */
33 1.1 maya { +NAN, +INFINITY, +INFINITY, +NAN}, /* sign of real part of result unspecified */
34 1.1 maya { +NAN, +NAN, +NAN, +NAN},
35 1.1 maya #endif
36 1.1 maya };
37 1.1 maya
38 1.1 maya #ifdef __HAVE_NANF
39 1.1 maya #define both_nan(a,b) (isnan(a) && isnan(b))
40 1.1 maya #else
41 1.1 maya #define both_nan(a,b) 0
42 1.1 maya #endif
43 1.1 maya
44 1.1 maya #define crude_equality(a,b) ((a == b) || both_nan(a,b))
45 1.1 maya
46 1.1 maya #define ATF_COMPLEX_EQUAL(a,b) do { \
47 1.2 christos complex double ci = casinh(a); \
48 1.2 christos ATF_CHECK_MSG(crude_equality(creal(ci),creal(b)) && \
49 1.2 christos crude_equality(cimag(ci), cimag(b)), \
50 1.2 christos "for casinh([%g,%g]) = [%g,%g] != [%g,%g]", \
51 1.2 christos creal(a), cimag(a), creal(ci), cimag(ci), creal(b), cimag(b)); \
52 1.1 maya } while (0/*CONSTCOND*/)
53 1.1 maya
54 1.1 maya
55 1.1 maya ATF_TC(casinh);
56 1.1 maya ATF_TC_HEAD(casinh, tc)
57 1.1 maya {
58 1.1 maya atf_tc_set_md_var(tc, "descr","Check casinh family - special values");
59 1.1 maya }
60 1.1 maya
61 1.1 maya ATF_TC_BODY(casinh, tc)
62 1.1 maya {
63 1.1 maya complex double input;
64 1.1 maya complex double result;
65 1.1 maya unsigned int i;
66 1.1 maya for (i = 0; i < __arraycount(values); i++) {
67 1.1 maya RE(input) = values[i].input_re;
68 1.1 maya IM(input) = values[i].input_im;
69 1.1 maya RE(result) = values[i].result_re;
70 1.1 maya IM(result) = values[i].result_im;
71 1.2 christos ATF_COMPLEX_EQUAL(input, result);
72 1.1 maya }
73 1.1 maya }
74 1.1 maya
75 1.1 maya ATF_TP_ADD_TCS(tp)
76 1.1 maya {
77 1.1 maya
78 1.1 maya ATF_TP_ADD_TC(tp, casinh);
79 1.1 maya
80 1.1 maya return atf_no_error();
81 1.1 maya }
82