summaryrefslogtreecommitdiff
path: root/libstdc++-v3/testsuite/tr1/8_c_compatibility/complex/overloads_float.cc
blob: ff90be319eca6d5e6d5e7780cb49c90ff2254e9b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
// { dg-do compile }

// 2006-01-12  Paolo Carlini  <pcarlini@suse.de>
//
// Copyright (C) 2006-2018 Free Software Foundation, Inc.
//
// This file is part of the GNU ISO C++ Library.  This library is free
// software; you can redistribute it and/or modify it under the
// terms of the GNU General Public License as published by the
// Free Software Foundation; either version 3, or (at your option)
// any later version.
//
// This library is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License along
// with this library; see the file COPYING3.  If not see
// <http://www.gnu.org/licenses/>.

// 8.1 Additions to header <complex>

#include <tr1/complex>
#include <testsuite_tr1.h>

void test01()
{
  using __gnu_test::check_ret_type;

  typedef std::complex<float>       cmplx_f_type;
  typedef std::complex<double>      cmplx_d_type;
  typedef std::complex<long double> cmplx_ld_type;

  const float        f1 = 1.0f;
  const double       d1 = 1.0;
  const long double ld1 = 1.0l;

  const cmplx_f_type  c_f1(f1, f1);
  const cmplx_d_type  c_d1(d1, d1);
  const cmplx_ld_type c_ld1(ld1, ld1);

  check_ret_type<float>(std::tr1::arg(f1));
  check_ret_type<double>(std::tr1::arg(d1));
  check_ret_type<long double>(std::tr1::arg(ld1));

  check_ret_type<cmplx_f_type>(std::tr1::conj(f1));
  check_ret_type<cmplx_d_type>(std::tr1::conj(d1));
  check_ret_type<cmplx_ld_type>(std::tr1::conj(ld1));

  check_ret_type<float>(std::tr1::imag(f1));
  check_ret_type<double>(std::tr1::imag(d1));
  check_ret_type<long double>(std::tr1::imag(ld1));

  check_ret_type<float>(std::tr1::norm(f1));
  check_ret_type<double>(std::tr1::norm(d1));
  check_ret_type<long double>(std::tr1::norm(ld1));

  check_ret_type<cmplx_f_type>(std::tr1::polar(f1, f1));
  check_ret_type<cmplx_d_type>(std::tr1::polar(d1, f1));
  check_ret_type<cmplx_d_type>(std::tr1::polar(f1, d1));
  check_ret_type<cmplx_d_type>(std::tr1::polar(d1, d1));
  check_ret_type<cmplx_ld_type>(std::tr1::polar(ld1, d1));
  check_ret_type<cmplx_ld_type>(std::tr1::polar(d1, ld1));
  check_ret_type<cmplx_ld_type>(std::tr1::polar(ld1, f1));
  check_ret_type<cmplx_ld_type>(std::tr1::polar(f1, ld1));
  check_ret_type<cmplx_ld_type>(std::tr1::polar(ld1, ld1));

  check_ret_type<cmplx_f_type>(std::tr1::pow(c_f1, f1));
  check_ret_type<cmplx_d_type>(std::tr1::pow(c_d1, f1));
  check_ret_type<cmplx_d_type>(std::tr1::pow(c_f1, d1));
  check_ret_type<cmplx_d_type>(std::tr1::pow(c_d1, d1));
  check_ret_type<cmplx_ld_type>(std::tr1::pow(c_ld1, d1));
  check_ret_type<cmplx_ld_type>(std::tr1::pow(c_d1, ld1));
  check_ret_type<cmplx_ld_type>(std::tr1::pow(c_ld1, f1));
  check_ret_type<cmplx_ld_type>(std::tr1::pow(c_f1, ld1));
  check_ret_type<cmplx_ld_type>(std::tr1::pow(c_ld1, ld1));

  check_ret_type<cmplx_f_type>(std::tr1::pow(f1, c_f1));
  check_ret_type<cmplx_d_type>(std::tr1::pow(d1, c_f1));
  check_ret_type<cmplx_d_type>(std::tr1::pow(f1, c_d1));
  check_ret_type<cmplx_d_type>(std::tr1::pow(d1, c_d1));
  check_ret_type<cmplx_ld_type>(std::tr1::pow(ld1, c_d1));
  check_ret_type<cmplx_ld_type>(std::tr1::pow(d1, c_ld1));
  check_ret_type<cmplx_ld_type>(std::tr1::pow(ld1, c_f1));
  check_ret_type<cmplx_ld_type>(std::tr1::pow(f1, c_ld1));
  check_ret_type<cmplx_ld_type>(std::tr1::pow(ld1, c_ld1));

  check_ret_type<cmplx_f_type>(std::tr1::pow(c_f1, c_f1));
  check_ret_type<cmplx_d_type>(std::tr1::pow(c_d1, c_f1));
  check_ret_type<cmplx_d_type>(std::tr1::pow(c_f1, c_d1));
  check_ret_type<cmplx_d_type>(std::tr1::pow(c_d1, c_d1));
  check_ret_type<cmplx_ld_type>(std::tr1::pow(c_ld1, c_d1));
  check_ret_type<cmplx_ld_type>(std::tr1::pow(c_d1, c_ld1));
  check_ret_type<cmplx_ld_type>(std::tr1::pow(c_ld1, c_f1));
  check_ret_type<cmplx_ld_type>(std::tr1::pow(c_f1, c_ld1));
  check_ret_type<cmplx_ld_type>(std::tr1::pow(c_ld1, c_ld1));

  check_ret_type<float>(std::tr1::real(f1));
  check_ret_type<double>(std::tr1::real(d1));
  check_ret_type<long double>(std::tr1::real(ld1));
}