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(1.5, 2.5);
335a83710eSEric Fiselier     std::complex<T> rhs(1.5, 2.5);
345a83710eSEric Fiselier     std::complex<T>   x(-4.0, 7.5);
355a83710eSEric Fiselier     test(lhs, rhs, x);
365a83710eSEric Fiselier }
375a83710eSEric Fiselier 
385a83710eSEric Fiselier // test edges
395a83710eSEric Fiselier 
test_edges()405a83710eSEric Fiselier void test_edges()
415a83710eSEric Fiselier {
42217cf69bSMarshall Clow     const unsigned N = sizeof(testcases) / sizeof(testcases[0]);
435a83710eSEric Fiselier     for (unsigned i = 0; i < N; ++i)
445a83710eSEric Fiselier     {
455a83710eSEric Fiselier         for (unsigned j = 0; j < N; ++j)
465a83710eSEric Fiselier         {
47217cf69bSMarshall Clow             std::complex<double> r = testcases[i] * testcases[j];
48217cf69bSMarshall Clow             switch (classify(testcases[i]))
495a83710eSEric Fiselier             {
505a83710eSEric Fiselier             case zero:
51217cf69bSMarshall Clow                 switch (classify(testcases[j]))
525a83710eSEric Fiselier                 {
535a83710eSEric Fiselier                 case zero:
545a83710eSEric Fiselier                     assert(classify(r) == zero);
555a83710eSEric Fiselier                     break;
565a83710eSEric Fiselier                 case non_zero:
575a83710eSEric Fiselier                     assert(classify(r) == zero);
585a83710eSEric Fiselier                     break;
595a83710eSEric Fiselier                 case inf:
605a83710eSEric Fiselier                     assert(classify(r) == NaN);
615a83710eSEric Fiselier                     break;
625a83710eSEric Fiselier                 case NaN:
635a83710eSEric Fiselier                     assert(classify(r) == NaN);
645a83710eSEric Fiselier                     break;
655a83710eSEric Fiselier                 case non_zero_nan:
665a83710eSEric Fiselier                     assert(classify(r) == NaN);
675a83710eSEric Fiselier                     break;
685a83710eSEric Fiselier                 }
695a83710eSEric Fiselier                 break;
705a83710eSEric Fiselier             case non_zero:
71217cf69bSMarshall Clow                 switch (classify(testcases[j]))
725a83710eSEric Fiselier                 {
735a83710eSEric Fiselier                 case zero:
745a83710eSEric Fiselier                     assert(classify(r) == zero);
755a83710eSEric Fiselier                     break;
765a83710eSEric Fiselier                 case non_zero:
775a83710eSEric Fiselier                     assert(classify(r) == non_zero);
785a83710eSEric Fiselier                     break;
795a83710eSEric Fiselier                 case inf:
805a83710eSEric Fiselier                     assert(classify(r) == inf);
815a83710eSEric Fiselier                     break;
825a83710eSEric Fiselier                 case NaN:
835a83710eSEric Fiselier                     assert(classify(r) == NaN);
845a83710eSEric Fiselier                     break;
855a83710eSEric Fiselier                 case non_zero_nan:
865a83710eSEric Fiselier                     assert(classify(r) == NaN);
875a83710eSEric Fiselier                     break;
885a83710eSEric Fiselier                 }
895a83710eSEric Fiselier                 break;
905a83710eSEric Fiselier             case inf:
91217cf69bSMarshall Clow                 switch (classify(testcases[j]))
925a83710eSEric Fiselier                 {
935a83710eSEric Fiselier                 case zero:
945a83710eSEric Fiselier                     assert(classify(r) == NaN);
955a83710eSEric Fiselier                     break;
965a83710eSEric Fiselier                 case non_zero:
975a83710eSEric Fiselier                     assert(classify(r) == inf);
985a83710eSEric Fiselier                     break;
995a83710eSEric Fiselier                 case inf:
1005a83710eSEric Fiselier                     assert(classify(r) == inf);
1015a83710eSEric Fiselier                     break;
1025a83710eSEric Fiselier                 case NaN:
1035a83710eSEric Fiselier                     assert(classify(r) == NaN);
1045a83710eSEric Fiselier                     break;
1055a83710eSEric Fiselier                 case non_zero_nan:
1065a83710eSEric Fiselier                     assert(classify(r) == inf);
1075a83710eSEric Fiselier                     break;
1085a83710eSEric Fiselier                 }
1095a83710eSEric Fiselier                 break;
1105a83710eSEric Fiselier             case NaN:
111217cf69bSMarshall Clow                 switch (classify(testcases[j]))
1125a83710eSEric Fiselier                 {
1135a83710eSEric Fiselier                 case zero:
1145a83710eSEric Fiselier                     assert(classify(r) == NaN);
1155a83710eSEric Fiselier                     break;
1165a83710eSEric Fiselier                 case non_zero:
1175a83710eSEric Fiselier                     assert(classify(r) == NaN);
1185a83710eSEric Fiselier                     break;
1195a83710eSEric Fiselier                 case inf:
1205a83710eSEric Fiselier                     assert(classify(r) == NaN);
1215a83710eSEric Fiselier                     break;
1225a83710eSEric Fiselier                 case NaN:
1235a83710eSEric Fiselier                     assert(classify(r) == NaN);
1245a83710eSEric Fiselier                     break;
1255a83710eSEric Fiselier                 case non_zero_nan:
1265a83710eSEric Fiselier                     assert(classify(r) == NaN);
1275a83710eSEric Fiselier                     break;
1285a83710eSEric Fiselier                 }
1295a83710eSEric Fiselier                 break;
1305a83710eSEric Fiselier             case non_zero_nan:
131217cf69bSMarshall Clow                 switch (classify(testcases[j]))
1325a83710eSEric Fiselier                 {
1335a83710eSEric Fiselier                 case zero:
1345a83710eSEric Fiselier                     assert(classify(r) == NaN);
1355a83710eSEric Fiselier                     break;
1365a83710eSEric Fiselier                 case non_zero:
1375a83710eSEric Fiselier                     assert(classify(r) == NaN);
1385a83710eSEric Fiselier                     break;
1395a83710eSEric Fiselier                 case inf:
1405a83710eSEric Fiselier                     assert(classify(r) == inf);
1415a83710eSEric Fiselier                     break;
1425a83710eSEric Fiselier                 case NaN:
1435a83710eSEric Fiselier                     assert(classify(r) == NaN);
1445a83710eSEric Fiselier                     break;
1455a83710eSEric Fiselier                 case non_zero_nan:
1465a83710eSEric Fiselier                     assert(classify(r) == NaN);
1475a83710eSEric Fiselier                     break;
1485a83710eSEric Fiselier                 }
1495a83710eSEric Fiselier                 break;
1505a83710eSEric Fiselier             }
1515a83710eSEric Fiselier         }
1525a83710eSEric Fiselier     }
1535a83710eSEric Fiselier }
1545a83710eSEric Fiselier 
main(int,char **)1552df59c50SJF Bastien int main(int, char**)
1565a83710eSEric Fiselier {
1575a83710eSEric Fiselier     test<float>();
1585a83710eSEric Fiselier     test<double>();
1595a83710eSEric Fiselier     test<long double>();
1605a83710eSEric Fiselier     test_edges();
1612df59c50SJF Bastien 
1622df59c50SJF Bastien   return 0;
1635a83710eSEric Fiselier }
164