1 //===----------------------------------------------------------------------===//
2 //
3 // The LLVM Compiler Infrastructure
4 //
5 // This file is dual licensed under the MIT and the University of Illinois Open
6 // Source Licenses. See LICENSE.TXT for details.
7 //
8 //===----------------------------------------------------------------------===//
9
10 // <complex>
11
12 // template<class T>
13 // complex<T>
14 // operator/(const complex<T>& lhs, const complex<T>& rhs);
15
16 #include <complex>
17 #include <cassert>
18
19 #include "../cases.h"
20
21 template <class T>
22 void
test(const std::complex<T> & lhs,const std::complex<T> & rhs,std::complex<T> x)23 test(const std::complex<T>& lhs, const std::complex<T>& rhs, std::complex<T> x)
24 {
25 assert(lhs / rhs == x);
26 }
27
28 template <class T>
29 void
test()30 test()
31 {
32 std::complex<T> lhs(-4.0, 7.5);
33 std::complex<T> rhs(1.5, 2.5);
34 std::complex<T> x(1.5, 2.5);
35 test(lhs, rhs, x);
36 }
37
test_edges()38 void test_edges()
39 {
40 const unsigned N = sizeof(x) / sizeof(x[0]);
41 for (unsigned i = 0; i < N; ++i)
42 {
43 for (unsigned j = 0; j < N; ++j)
44 {
45 std::complex<double> r = x[i] / x[j];
46 switch (classify(x[i]))
47 {
48 case zero:
49 switch (classify(x[j]))
50 {
51 case zero:
52 assert(classify(r) == NaN);
53 break;
54 case non_zero:
55 assert(classify(r) == zero);
56 break;
57 case inf:
58 assert(classify(r) == zero);
59 break;
60 case NaN:
61 assert(classify(r) == NaN);
62 break;
63 case non_zero_nan:
64 assert(classify(r) == NaN);
65 break;
66 }
67 break;
68 case non_zero:
69 switch (classify(x[j]))
70 {
71 case zero:
72 assert(classify(r) == inf);
73 break;
74 case non_zero:
75 assert(classify(r) == non_zero);
76 break;
77 case inf:
78 assert(classify(r) == zero);
79 break;
80 case NaN:
81 assert(classify(r) == NaN);
82 break;
83 case non_zero_nan:
84 assert(classify(r) == NaN);
85 break;
86 }
87 break;
88 case inf:
89 switch (classify(x[j]))
90 {
91 case zero:
92 assert(classify(r) == inf);
93 break;
94 case non_zero:
95 assert(classify(r) == inf);
96 break;
97 case inf:
98 assert(classify(r) == NaN);
99 break;
100 case NaN:
101 assert(classify(r) == NaN);
102 break;
103 case non_zero_nan:
104 assert(classify(r) == NaN);
105 break;
106 }
107 break;
108 case NaN:
109 switch (classify(x[j]))
110 {
111 case zero:
112 assert(classify(r) == NaN);
113 break;
114 case non_zero:
115 assert(classify(r) == NaN);
116 break;
117 case inf:
118 assert(classify(r) == NaN);
119 break;
120 case NaN:
121 assert(classify(r) == NaN);
122 break;
123 case non_zero_nan:
124 assert(classify(r) == NaN);
125 break;
126 }
127 break;
128 case non_zero_nan:
129 switch (classify(x[j]))
130 {
131 case zero:
132 assert(classify(r) == inf);
133 break;
134 case non_zero:
135 assert(classify(r) == NaN);
136 break;
137 case inf:
138 assert(classify(r) == NaN);
139 break;
140 case NaN:
141 assert(classify(r) == NaN);
142 break;
143 case non_zero_nan:
144 assert(classify(r) == NaN);
145 break;
146 }
147 break;
148 }
149 }
150 }
151 }
152
main()153 int main()
154 {
155 test<float>();
156 test<double>();
157 test<long double>();
158 test_edges();
159 }
160