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