1 //===----------------------------------------------------------------------===//
2 //
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6 //
7 //===----------------------------------------------------------------------===//
8 
9 // XFAIL: LIBCXX-AIX-FIXME
10 
11 // <complex>
12 
13 // template<class T>
14 //   complex<T>
15 //   acos(const complex<T>& x);
16 
17 #include <complex>
18 #include <cassert>
19 
20 #include "test_macros.h"
21 #include "../cases.h"
22 
23 template <class T>
24 void
25 test(const std::complex<T>& c, std::complex<T> x)
26 {
27     assert(acos(c) == x);
28 }
29 
30 template <class T>
31 void
32 test()
33 {
34     test(std::complex<T>(INFINITY, 1), std::complex<T>(0, -INFINITY));
35 }
36 
37 void test_edges()
38 {
39     const double pi = std::atan2(+0., -0.);
40     const unsigned N = sizeof(testcases) / sizeof(testcases[0]);
41     for (unsigned i = 0; i < N; ++i)
42     {
43         std::complex<double> r = acos(testcases[i]);
44         if (testcases[i].real() == 0 && testcases[i].imag() == 0)
45         {
46             is_about(r.real(), pi/2);
47             assert(r.imag() == 0);
48             assert(std::signbit(testcases[i].imag()) != std::signbit(r.imag()));
49         }
50         else if (testcases[i].real() == 0 && std::isnan(testcases[i].imag()))
51         {
52             is_about(r.real(), pi/2);
53             assert(std::isnan(r.imag()));
54         }
55         else if (std::isfinite(testcases[i].real()) && std::isinf(testcases[i].imag()))
56         {
57             is_about(r.real(), pi/2);
58             assert(std::isinf(r.imag()));
59             assert(std::signbit(testcases[i].imag()) != std::signbit(r.imag()));
60         }
61         else if (std::isfinite(testcases[i].real()) && testcases[i].real() != 0 && std::isnan(testcases[i].imag()))
62         {
63             assert(std::isnan(r.real()));
64             assert(std::isnan(r.imag()));
65         }
66         else if (std::isinf(testcases[i].real()) && testcases[i].real() < 0 && std::isfinite(testcases[i].imag()))
67         {
68             is_about(r.real(), pi);
69             assert(std::isinf(r.imag()));
70             assert(std::signbit(testcases[i].imag()) != std::signbit(r.imag()));
71         }
72         else if (std::isinf(testcases[i].real()) && testcases[i].real() > 0 && std::isfinite(testcases[i].imag()))
73         {
74             assert(r.real() == 0);
75             assert(!std::signbit(r.real()));
76             assert(std::isinf(r.imag()));
77             assert(std::signbit(testcases[i].imag()) != std::signbit(r.imag()));
78         }
79         else if (std::isinf(testcases[i].real()) && testcases[i].real() < 0 && std::isinf(testcases[i].imag()))
80         {
81             is_about(r.real(), 0.75 * pi);
82             assert(std::isinf(r.imag()));
83             assert(std::signbit(testcases[i].imag()) != std::signbit(r.imag()));
84         }
85         else if (std::isinf(testcases[i].real()) && testcases[i].real() > 0 && std::isinf(testcases[i].imag()))
86         {
87             is_about(r.real(), 0.25 * pi);
88             assert(std::isinf(r.imag()));
89             assert(std::signbit(testcases[i].imag()) != std::signbit(r.imag()));
90         }
91         else if (std::isinf(testcases[i].real()) && std::isnan(testcases[i].imag()))
92         {
93             assert(std::isnan(r.real()));
94             assert(std::isinf(r.imag()));
95         }
96         else if (std::isnan(testcases[i].real()) && std::isfinite(testcases[i].imag()))
97         {
98             assert(std::isnan(r.real()));
99             assert(std::isnan(r.imag()));
100         }
101         else if (std::isnan(testcases[i].real()) && std::isinf(testcases[i].imag()))
102         {
103             assert(std::isnan(r.real()));
104             assert(std::isinf(r.imag()));
105             assert(std::signbit(testcases[i].imag()) != std::signbit(r.imag()));
106         }
107         else if (std::isnan(testcases[i].real()) && std::isnan(testcases[i].imag()))
108         {
109             assert(std::isnan(r.real()));
110             assert(std::isnan(r.imag()));
111         }
112         else if (!std::signbit(testcases[i].real()) && !std::signbit(testcases[i].imag()))
113         {
114             assert(!std::signbit(r.real()));
115             assert( std::signbit(r.imag()));
116         }
117         else if (std::signbit(testcases[i].real()) && !std::signbit(testcases[i].imag()))
118         {
119             assert(!std::signbit(r.real()));
120             assert( std::signbit(r.imag()));
121         }
122         else if (std::signbit(testcases[i].real()) && std::signbit(testcases[i].imag()))
123         {
124             assert(!std::signbit(r.real()));
125             assert(!std::signbit(r.imag()));
126         }
127         else if (!std::signbit(testcases[i].real()) && std::signbit(testcases[i].imag()))
128         {
129             assert(!std::signbit(r.real()));
130             assert(!std::signbit(r.imag()));
131         }
132     }
133 }
134 
135 int main(int, char**)
136 {
137     test<float>();
138     test<double>();
139     test<long double>();
140     test_edges();
141 
142   return 0;
143 }
144