]> git.ipfire.org Git - thirdparty/gcc.git/blame - libstdc++-v3/testsuite/tr1/8_c_compatibility/cmath/functions.cc
cmath: Add atan2 and pow bits; add using declarations.
[thirdparty/gcc.git] / libstdc++-v3 / testsuite / tr1 / 8_c_compatibility / cmath / functions.cc
CommitLineData
4f0de5dd
PC
1// { dg-do compile }
2
3// 2006-02-07 Paolo Carlini <pcarlini@suse.de>
4//
5// Copyright (C) 2006 Free Software Foundation, Inc.
6//
7// This file is part of the GNU ISO C++ Library. This library is free
8// software; you can redistribute it and/or modify it under the
9// terms of the GNU General Public License as published by the
10// Free Software Foundation; either version 2, or (at your option)
11// any later version.
12//
13// This library is distributed in the hope that it will be useful,
14// but WITHOUT ANY WARRANTY; without even the implied warranty of
15// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16// GNU General Public License for more details.
17//
18// You should have received a copy of the GNU General Public License along
19// with this library; see the file COPYING. If not, write to the Free
20// Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
21// USA.
22
23// 8.16 Additions to header <cmath>
24
25#include <tr1/cmath>
26
27void test01()
28{
29#if _GLIBCXX_USE_C99_MATH_TR1
30
31 double d0 = 0.0;
32 float f0 = 0.0f;
33 long double ld0 = 0.0l;
34 const char* str = "NAN";
35 int* pquo = 0;
36 long lex = 0l;
37 int ex = 0;
38
39 double ret;
40 float fret;
41 long double ldret;
42 int iret;
43 long lret;
44 long long llret;
45
9a7ab578
PC
46 ret = std::tr1::acosh(d0);
47 fret = std::tr1::acoshf(f0);
48 ldret = std::tr1::acoshl(ld0);
4f0de5dd 49
9a7ab578
PC
50 ret = std::tr1::asinh(d0);
51 fret = std::tr1::asinhf(f0);
52 ldret = std::tr1::asinhl(ld0);
4f0de5dd 53
9a7ab578
PC
54 ret = std::tr1::atanh(d0);
55 fret = std::tr1::atanhf(f0);
56 ldret = std::tr1::atanhl(ld0);
4f0de5dd 57
9a7ab578
PC
58 ret = std::tr1::cbrt(d0);
59 fret = std::tr1::cbrtf(f0);
60 ldret = std::tr1::cbrtl(ld0);
4f0de5dd 61
9a7ab578
PC
62 ret = std::tr1::copysign(d0, d0);
63 fret = std::tr1::copysignf(f0, f0);
64 ldret = std::tr1::copysignl(ld0, ld0);
4f0de5dd 65
9a7ab578
PC
66 ret = std::tr1::erf(d0);
67 fret = std::tr1::erff(f0);
68 ldret = std::tr1::erfl(ld0);
4f0de5dd 69
9a7ab578
PC
70 ret = std::tr1::erfc(d0);
71 fret = std::tr1::erfcf(f0);
72 ldret = std::tr1::erfcl(ld0);
4f0de5dd 73
9a7ab578
PC
74 ret = std::tr1::exp2(d0);
75 fret = std::tr1::exp2f(f0);
76 ldret = std::tr1::exp2l(ld0);
4f0de5dd 77
9a7ab578
PC
78 ret = std::tr1::expm1(d0);
79 fret = std::tr1::expm1f(f0);
80 ldret = std::tr1::expm1l(ld0);
4f0de5dd 81
9a7ab578
PC
82 ret = std::tr1::fdim(d0, d0);
83 fret = std::tr1::fdimf(f0, f0);
84 ldret = std::tr1::fdiml(ld0, ld0);
4f0de5dd 85
9a7ab578
PC
86 ret = std::tr1::fma(d0, d0, d0);
87 fret = std::tr1::fmaf(f0, f0, f0);
88 ldret = std::tr1::fmal(ld0, ld0, ld0);
4f0de5dd 89
9a7ab578
PC
90 ret = std::tr1::fmax(d0, d0);
91 fret = std::tr1::fmaxf(f0, f0);
92 ldret = std::tr1::fmaxl(ld0, ld0);
4f0de5dd 93
9a7ab578
PC
94 ret = std::tr1::fmin(d0, d0);
95 fret = std::tr1::fminf(f0, f0);
96 ldret = std::tr1::fminl(ld0, ld0);
4f0de5dd 97
9a7ab578
PC
98 ret = std::tr1::hypot(d0, d0);
99 fret = std::tr1::hypotf(f0, f0);
100 ldret = std::tr1::hypotl(ld0, ld0);
4f0de5dd 101
9a7ab578
PC
102 iret = std::tr1::ilogb(d0);
103 iret = std::tr1::ilogbf(f0);
104 iret = std::tr1::ilogbl(ld0);
4f0de5dd 105
9a7ab578
PC
106 ret = std::tr1::lgamma(d0);
107 fret = std::tr1::lgammaf(f0);
108 ldret = std::tr1::lgammal(ld0);
4f0de5dd 109
9a7ab578
PC
110 llret = std::tr1::llrint(d0);
111 llret = std::tr1::llrintf(f0);
112 llret = std::tr1::llrintl(ld0);
4f0de5dd 113
9a7ab578
PC
114 llret = std::tr1::llround(d0);
115 llret = std::tr1::llroundf(f0);
116 llret = std::tr1::llroundl(ld0);
4f0de5dd 117
9a7ab578
PC
118 ret = std::tr1::log1p(d0);
119 fret = std::tr1::log1pf(f0);
120 ldret = std::tr1::log1pl(ld0);
4f0de5dd 121
9a7ab578
PC
122 ret = std::tr1::log2(d0);
123 fret = std::tr1::log2f(f0);
124 ldret = std::tr1::log2l(ld0);
4f0de5dd 125
9a7ab578
PC
126 ret = std::tr1::logb(d0);
127 fret = std::tr1::logbf(f0);
128 ldret = std::tr1::logbl(ld0);
4f0de5dd 129
9a7ab578
PC
130 lret = std::tr1::lrint(d0);
131 lret = std::tr1::lrintf(f0);
132 lret = std::tr1::lrintl(ld0);
4f0de5dd 133
9a7ab578
PC
134 lret = std::tr1::lround(d0);
135 lret = std::tr1::lroundf(f0);
136 lret = std::tr1::lroundl(ld0);
4f0de5dd 137
9a7ab578
PC
138 ret = std::tr1::nan(str);
139 fret = std::tr1::nanf(str);
140 ldret = std::tr1::nanl(str);
4f0de5dd 141
9a7ab578
PC
142 ret = std::tr1::nearbyint(d0);
143 fret = std::tr1::nearbyintf(f0);
144 ldret = std::tr1::nearbyintl(ld0);
4f0de5dd 145
9a7ab578
PC
146 ret = std::tr1::nextafter(d0, d0);
147 fret = std::tr1::nextafterf(f0, f0);
148 ldret = std::tr1::nextafterl(ld0, ld0);
4f0de5dd 149
9a7ab578
PC
150 ret = std::tr1::nexttoward(d0, ld0);
151 fret = std::tr1::nexttowardf(f0, ld0);
152 ldret = std::tr1::nexttowardl(ld0, ld0);
4f0de5dd 153
9a7ab578
PC
154 ret = std::tr1::remainder(d0, d0);
155 fret = std::tr1::remainderf(f0, f0);
156 ldret = std::tr1::remainderl(ld0, ld0);
4f0de5dd 157
9a7ab578
PC
158 ret = std::tr1::remquo(d0, d0, pquo);
159 fret = std::tr1::remquo(f0, f0, pquo);
160 ldret = std::tr1::remquo(ld0, ld0, pquo);
4f0de5dd 161
9a7ab578
PC
162 ret = std::tr1::rint(d0);
163 fret = std::tr1::rintf(f0);
164 ldret = std::tr1::rintl(ld0);
4f0de5dd 165
9a7ab578
PC
166 ret = std::tr1::round(d0);
167 fret = std::tr1::roundf(f0);
168 ldret = std::tr1::roundl(ld0);
4f0de5dd 169
9a7ab578
PC
170 ret = std::tr1::scalbln(d0, lex);
171 fret = std::tr1::scalblnf(f0, lex);
172 ldret = std::tr1::scalblnl(ld0, lex);
4f0de5dd 173
9a7ab578
PC
174 ret = std::tr1::scalbn(d0, ex);
175 fret = std::tr1::scalbnf(f0, ex);
176 ldret = std::tr1::scalbnl(ld0, ex);
4f0de5dd 177
9a7ab578
PC
178 ret = std::tr1::tgamma(d0);
179 fret = std::tr1::tgammaf(f0);
180 ldret = std::tr1::tgammal(ld0);
4f0de5dd 181
9a7ab578
PC
182 ret = std::tr1::trunc(d0);
183 fret = std::tr1::truncf(f0);
184 ldret = std::tr1::truncl(ld0);
4f0de5dd
PC
185
186#endif
187}