15a83710eSEric Fiselier //===----------------------------------------------------------------------===//
25a83710eSEric Fiselier //
357b08b09SChandler Carruth // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
457b08b09SChandler Carruth // See https://llvm.org/LICENSE.txt for license information.
557b08b09SChandler Carruth // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
65a83710eSEric Fiselier //
75a83710eSEric Fiselier //===----------------------------------------------------------------------===//
85a83710eSEric Fiselier 
95a83710eSEric Fiselier // <complex>
105a83710eSEric Fiselier 
115a83710eSEric Fiselier // template<class T>
125a83710eSEric Fiselier //   complex<T>
135a83710eSEric Fiselier //   operator/(const complex<T>& lhs, const complex<T>& rhs);
145a83710eSEric Fiselier 
155a83710eSEric Fiselier #include <complex>
165a83710eSEric Fiselier #include <cassert>
175a83710eSEric Fiselier 
18*7fc6a556SMarshall Clow #include "test_macros.h"
195a83710eSEric Fiselier #include "../cases.h"
205a83710eSEric Fiselier 
215a83710eSEric Fiselier template <class T>
225a83710eSEric Fiselier void
test(const std::complex<T> & lhs,const std::complex<T> & rhs,std::complex<T> x)235a83710eSEric Fiselier test(const std::complex<T>& lhs, const std::complex<T>& rhs, std::complex<T> x)
245a83710eSEric Fiselier {
255a83710eSEric Fiselier     assert(lhs / rhs == x);
265a83710eSEric Fiselier }
275a83710eSEric Fiselier 
285a83710eSEric Fiselier template <class T>
295a83710eSEric Fiselier void
test()305a83710eSEric Fiselier test()
315a83710eSEric Fiselier {
325a83710eSEric Fiselier     std::complex<T> lhs(-4.0, 7.5);
335a83710eSEric Fiselier     std::complex<T> rhs(1.5, 2.5);
345a83710eSEric Fiselier     std::complex<T>   x(1.5, 2.5);
355a83710eSEric Fiselier     test(lhs, rhs, x);
365a83710eSEric Fiselier }
375a83710eSEric Fiselier 
test_edges()385a83710eSEric Fiselier void test_edges()
395a83710eSEric Fiselier {
40217cf69bSMarshall Clow     const unsigned N = sizeof(testcases) / sizeof(testcases[0]);
415a83710eSEric Fiselier     for (unsigned i = 0; i < N; ++i)
425a83710eSEric Fiselier     {
435a83710eSEric Fiselier         for (unsigned j = 0; j < N; ++j)
445a83710eSEric Fiselier         {
45217cf69bSMarshall Clow             std::complex<double> r = testcases[i] / testcases[j];
46217cf69bSMarshall Clow             switch (classify(testcases[i]))
475a83710eSEric Fiselier             {
485a83710eSEric Fiselier             case zero:
49217cf69bSMarshall Clow                 switch (classify(testcases[j]))
505a83710eSEric Fiselier                 {
515a83710eSEric Fiselier                 case zero:
525a83710eSEric Fiselier                     assert(classify(r) == NaN);
535a83710eSEric Fiselier                     break;
545a83710eSEric Fiselier                 case non_zero:
555a83710eSEric Fiselier                     assert(classify(r) == zero);
565a83710eSEric Fiselier                     break;
575a83710eSEric Fiselier                 case inf:
585a83710eSEric Fiselier                     assert(classify(r) == zero);
595a83710eSEric Fiselier                     break;
605a83710eSEric Fiselier                 case NaN:
615a83710eSEric Fiselier                     assert(classify(r) == NaN);
625a83710eSEric Fiselier                     break;
635a83710eSEric Fiselier                 case non_zero_nan:
645a83710eSEric Fiselier                     assert(classify(r) == NaN);
655a83710eSEric Fiselier                     break;
665a83710eSEric Fiselier                 }
675a83710eSEric Fiselier                 break;
685a83710eSEric Fiselier             case non_zero:
69217cf69bSMarshall Clow                 switch (classify(testcases[j]))
705a83710eSEric Fiselier                 {
715a83710eSEric Fiselier                 case zero:
725a83710eSEric Fiselier                     assert(classify(r) == inf);
735a83710eSEric Fiselier                     break;
745a83710eSEric Fiselier                 case non_zero:
755a83710eSEric Fiselier                     assert(classify(r) == non_zero);
765a83710eSEric Fiselier                     break;
775a83710eSEric Fiselier                 case inf:
785a83710eSEric Fiselier                     assert(classify(r) == zero);
795a83710eSEric Fiselier                     break;
805a83710eSEric Fiselier                 case NaN:
815a83710eSEric Fiselier                     assert(classify(r) == NaN);
825a83710eSEric Fiselier                     break;
835a83710eSEric Fiselier                 case non_zero_nan:
845a83710eSEric Fiselier                     assert(classify(r) == NaN);
855a83710eSEric Fiselier                     break;
865a83710eSEric Fiselier                 }
875a83710eSEric Fiselier                 break;
885a83710eSEric Fiselier             case inf:
89217cf69bSMarshall Clow                 switch (classify(testcases[j]))
905a83710eSEric Fiselier                 {
915a83710eSEric Fiselier                 case zero:
925a83710eSEric Fiselier                     assert(classify(r) == inf);
935a83710eSEric Fiselier                     break;
945a83710eSEric Fiselier                 case non_zero:
955a83710eSEric Fiselier                     assert(classify(r) == inf);
965a83710eSEric Fiselier                     break;
975a83710eSEric Fiselier                 case inf:
985a83710eSEric Fiselier                     assert(classify(r) == NaN);
995a83710eSEric Fiselier                     break;
1005a83710eSEric Fiselier                 case NaN:
1015a83710eSEric Fiselier                     assert(classify(r) == NaN);
1025a83710eSEric Fiselier                     break;
1035a83710eSEric Fiselier                 case non_zero_nan:
1045a83710eSEric Fiselier                     assert(classify(r) == NaN);
1055a83710eSEric Fiselier                     break;
1065a83710eSEric Fiselier                 }
1075a83710eSEric Fiselier                 break;
1085a83710eSEric Fiselier             case NaN:
109217cf69bSMarshall Clow                 switch (classify(testcases[j]))
1105a83710eSEric Fiselier                 {
1115a83710eSEric Fiselier                 case zero:
1125a83710eSEric Fiselier                     assert(classify(r) == NaN);
1135a83710eSEric Fiselier                     break;
1145a83710eSEric Fiselier                 case non_zero:
1155a83710eSEric Fiselier                     assert(classify(r) == NaN);
1165a83710eSEric Fiselier                     break;
1175a83710eSEric Fiselier                 case inf:
1185a83710eSEric Fiselier                     assert(classify(r) == NaN);
1195a83710eSEric Fiselier                     break;
1205a83710eSEric Fiselier                 case NaN:
1215a83710eSEric Fiselier                     assert(classify(r) == NaN);
1225a83710eSEric Fiselier                     break;
1235a83710eSEric Fiselier                 case non_zero_nan:
1245a83710eSEric Fiselier                     assert(classify(r) == NaN);
1255a83710eSEric Fiselier                     break;
1265a83710eSEric Fiselier                 }
1275a83710eSEric Fiselier                 break;
1285a83710eSEric Fiselier             case non_zero_nan:
129217cf69bSMarshall Clow                 switch (classify(testcases[j]))
1305a83710eSEric Fiselier                 {
1315a83710eSEric Fiselier                 case zero:
1325a83710eSEric Fiselier                     assert(classify(r) == inf);
1335a83710eSEric Fiselier                     break;
1345a83710eSEric Fiselier                 case non_zero:
1355a83710eSEric Fiselier                     assert(classify(r) == NaN);
1365a83710eSEric Fiselier                     break;
1375a83710eSEric Fiselier                 case inf:
1385a83710eSEric Fiselier                     assert(classify(r) == NaN);
1395a83710eSEric Fiselier                     break;
1405a83710eSEric Fiselier                 case NaN:
1415a83710eSEric Fiselier                     assert(classify(r) == NaN);
1425a83710eSEric Fiselier                     break;
1435a83710eSEric Fiselier                 case non_zero_nan:
1445a83710eSEric Fiselier                     assert(classify(r) == NaN);
1455a83710eSEric Fiselier                     break;
1465a83710eSEric Fiselier                 }
1475a83710eSEric Fiselier                 break;
1485a83710eSEric Fiselier             }
1495a83710eSEric Fiselier         }
1505a83710eSEric Fiselier     }
1515a83710eSEric Fiselier }
1525a83710eSEric Fiselier 
main(int,char **)1532df59c50SJF Bastien int main(int, char**)
1545a83710eSEric Fiselier {
1555a83710eSEric Fiselier     test<float>();
1565a83710eSEric Fiselier     test<double>();
1575a83710eSEric Fiselier     test<long double>();
1585a83710eSEric Fiselier     test_edges();
1592df59c50SJF Bastien 
1602df59c50SJF Bastien   return 0;
1615a83710eSEric Fiselier }
162