• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 //  (C) Copyright John Maddock 2016.
2 //  Use, modification and distribution are subject to the
3 //  Boost Software License, Version 1.0. (See accompanying file
4 //  LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
5 
6 #ifdef _MSC_VER
7 #pragma warning(disable : 4127) // conditional expression is constant
8 #endif
9 
10 #if !defined(TEST_MPF_50) && !defined(TEST_MPF) && !defined(TEST_BACKEND) && !defined(TEST_CPP_DEC_FLOAT) && !defined(TEST_MPFR) && !defined(TEST_MPFR_50) && !defined(TEST_MPFI_50) && !defined(TEST_FLOAT128) && !defined(TEST_CPP_BIN_FLOAT) && !defined(TEST_CPP_DEC_FLOAT_2) && !defined(TEST_CPP_DEC_FLOAT_3) && !defined(TEST_CPP_DEC_FLOAT_4) && !defined(TEST_CPP_DEC_FLOAT_5) && !defined(TEST_CPP_DEC_FLOAT_6) && !defined(TEST_CPP_BIN_FLOAT_2) && !defined(TEST_CPP_BIN_FLOAT_3)
11 #define TEST_MPF_50
12 #define TEST_MPFR_50
13 #define TEST_MPFI_50
14 #define TEST_CPP_DEC_FLOAT
15 #define TEST_CPP_DEC_FLOAT_2
16 #define TEST_CPP_DEC_FLOAT_3
17 #define TEST_CPP_DEC_FLOAT_4
18 #define TEST_CPP_DEC_FLOAT_5
19 #define TEST_CPP_DEC_FLOAT_6
20 #define TEST_FLOAT128
21 #define TEST_CPP_BIN_FLOAT
22 #define TEST_CPP_BIN_FLOAT_2
23 #define TEST_CPP_BIN_FLOAT_3
24 
25 #ifdef _MSC_VER
26 #pragma message("CAUTION!!: No backend type specified so testing everything.... this will take some time!!")
27 #endif
28 #ifdef __GNUC__
29 #pragma warning "CAUTION!!: No backend type specified so testing everything.... this will take some time!!"
30 #endif
31 
32 #endif
33 
34 #if defined(TEST_MPF_50)
35 #include <boost/multiprecision/gmp.hpp>
36 #endif
37 #ifdef TEST_MPFR_50
38 #include <boost/multiprecision/mpfr.hpp>
39 #endif
40 #ifdef TEST_MPFI_50
41 #include <boost/multiprecision/mpfi.hpp>
42 #endif
43 #if defined(TEST_CPP_DEC_FLOAT) || defined(TEST_CPP_DEC_FLOAT_2) || defined(TEST_CPP_DEC_FLOAT_3) || defined(TEST_CPP_DEC_FLOAT_4) || defined(TEST_CPP_DEC_FLOAT_5) || defined(TEST_CPP_DEC_FLOAT_6)
44 #include <boost/multiprecision/cpp_dec_float.hpp>
45 #endif
46 #if defined(TEST_CPP_BIN_FLOAT) || defined(TEST_CPP_BIN_FLOAT_2) || defined(TEST_CPP_BIN_FLOAT_3)
47 #include <boost/multiprecision/cpp_bin_float.hpp>
48 #include <boost/multiprecision/debug_adaptor.hpp>
49 #endif
50 #ifdef TEST_FLOAT128
51 #include <boost/multiprecision/float128.hpp>
52 #endif
53 
54 #include <boost/math/constants/constants.hpp>
55 #include <boost/math/special_functions/gamma.hpp>
56 #include "test.hpp"
57 
58 #ifdef signbit
59 #undef signbit
60 #endif
61 #ifdef sign
62 #undef sign
63 #endif
64 #ifdef changesign
65 #undef changesign
66 #endif
67 #ifdef copysign
68 #undef copysign
69 #endif
70 #ifdef fpclassify
71 #undef fpclassify
72 #endif
73 #ifdef isinf
74 #undef isinf
75 #endif
76 #ifdef isnan
77 #undef isnan
78 #endif
79 #ifdef isnormal
80 #undef isnormal
81 #endif
82 
83 #ifdef MPFR_VERSION_MAJOR
84 #define BOOST_MPFR_VERSION MPFR_VERSION_MAJOR * 10000 + MPFR_VERSION_MINOR * 100 + MPFR_VERSION_PATCHLEVEL
85 #endif
86 
87 template <class T, class U>
test_less(T a,U b)88 void test_less(T a, U b)
89 {
90    BOOST_CHECK(a < b);
91    BOOST_CHECK(a <= b);
92    BOOST_CHECK(!(a > b));
93    BOOST_CHECK(!(a >= b));
94    BOOST_CHECK(!(a == b));
95    BOOST_CHECK((a != b));
96 
97    BOOST_CHECK(b > a);
98    BOOST_CHECK(b >= a);
99    BOOST_CHECK(!(b < a));
100    BOOST_CHECK(!(b <= a));
101    BOOST_CHECK(!(b == a));
102    BOOST_CHECK((b != a));
103 
104    BOOST_CHECK(isless(a, b));
105    BOOST_CHECK(islessequal(a, b));
106    BOOST_CHECK(!isgreater(a, b));
107    BOOST_CHECK(!isgreaterequal(a, b));
108    BOOST_CHECK(islessgreater(a, b));
109 
110    BOOST_CHECK(!isless(b, a));
111    BOOST_CHECK(!islessequal(b, a));
112    BOOST_CHECK(isgreater(b, a));
113    BOOST_CHECK(isgreaterequal(b, a));
114    BOOST_CHECK(islessgreater(b, a));
115 }
116 template <class T, class U>
test_equal(T a,U b)117 void test_equal(T a, U b)
118 {
119    BOOST_CHECK(!(a < b));
120    BOOST_CHECK(a <= b);
121    BOOST_CHECK(!(a > b));
122    BOOST_CHECK((a >= b));
123    BOOST_CHECK((a == b));
124    BOOST_CHECK(!(a != b));
125 
126    BOOST_CHECK(!(b > a));
127    BOOST_CHECK(b >= a);
128    BOOST_CHECK(!(b < a));
129    BOOST_CHECK((b <= a));
130    BOOST_CHECK((b == a));
131    BOOST_CHECK(!(b != a));
132 
133    BOOST_CHECK(!isless(a, b));
134    BOOST_CHECK(islessequal(a, b));
135    BOOST_CHECK(!isgreater(a, b));
136    BOOST_CHECK(isgreaterequal(a, b));
137    BOOST_CHECK(!islessgreater(a, b));
138 
139    BOOST_CHECK(!isless(b, a));
140    BOOST_CHECK(islessequal(b, a));
141    BOOST_CHECK(!isgreater(b, a));
142    BOOST_CHECK(isgreaterequal(b, a));
143    BOOST_CHECK(!islessgreater(b, a));
144 }
145 template <class T, class U>
test_unordered(T a,U b)146 void test_unordered(T a, U b)
147 {
148    BOOST_CHECK(!(a < b));
149    BOOST_CHECK(!(a <= b));
150    BOOST_CHECK(!(a > b));
151    BOOST_CHECK(!(a >= b));
152    BOOST_CHECK(!(a == b));
153    BOOST_CHECK((a != b));
154 
155    BOOST_CHECK(!(b > a));
156    BOOST_CHECK(!(b >= a));
157    BOOST_CHECK(!(b < a));
158    BOOST_CHECK(!(b <= a));
159    BOOST_CHECK(!(b == a));
160    BOOST_CHECK((b != a));
161 
162    BOOST_CHECK(!isless(a, b));
163    BOOST_CHECK(!islessequal(a, b));
164    BOOST_CHECK(!isgreater(a, b));
165    BOOST_CHECK(!isgreaterequal(a, b));
166    BOOST_CHECK(!islessgreater(a, b));
167 
168    BOOST_CHECK(!isless(b, a));
169    BOOST_CHECK(!islessequal(b, a));
170    BOOST_CHECK(!isgreater(b, a));
171    BOOST_CHECK(!isgreaterequal(b, a));
172    BOOST_CHECK(!islessgreater(b, a));
173 }
174 
175 template <class T>
test()176 void test()
177 {
178    //
179    // Basic sanity checks for C99 functions which are just imported versions
180    // from Boost.Math.  These should still be found via ADL so no using declarations here...
181    //
182    T val = 2;
183    BOOST_CHECK(signbit(val) == 0);
184    BOOST_CHECK(signbit(val + 2) == 0);
185    val = -val;
186    BOOST_CHECK(signbit(val));
187    BOOST_CHECK(signbit(val * 2));
188 
189    val = 2;
190    BOOST_CHECK_EQUAL(sign(val), 1);
191    BOOST_CHECK_EQUAL(sign(val + 2), 1);
192    val = -val;
193    BOOST_CHECK_EQUAL(sign(val), -1);
194    BOOST_CHECK_EQUAL(sign(val * 2), -1);
195    val = 0;
196    BOOST_CHECK_EQUAL(sign(val), 0);
197    BOOST_CHECK_EQUAL(sign(val * 2), 0);
198 
199    val = 2;
200    BOOST_CHECK_EQUAL(changesign(val), -2);
201    BOOST_CHECK_EQUAL(changesign(val * 2), -4);
202    val = -2;
203    BOOST_CHECK_EQUAL(changesign(val), 2);
204    BOOST_CHECK_EQUAL(changesign(val * 2), 4);
205    val = 0;
206    BOOST_CHECK_EQUAL(changesign(val), 0);
207    BOOST_CHECK_EQUAL(changesign(val * 2), 0);
208    // Things involving signed zero, need to detect it first:
209    T neg_zero_test = -(std::numeric_limits<T>::min)();
210    neg_zero_test /= (std::numeric_limits<T>::max)();
211    T    one(1);
212    bool test_signed_zero = !boost::multiprecision::is_interval_number<T>::value && std::numeric_limits<T>::has_infinity && (one / neg_zero_test < 0);
213    if (test_signed_zero)
214    {
215       BOOST_CHECK(signbit(changesign(val)));
216       BOOST_CHECK(signbit(changesign(val * 2)));
217    }
218 
219    T s = 2;
220    val = 3;
221    BOOST_CHECK_EQUAL(copysign(val, s), 3);
222    BOOST_CHECK_EQUAL(copysign(val, s * -2), -3);
223    BOOST_CHECK_EQUAL(copysign(-2 * val, s), 6);
224    BOOST_CHECK_EQUAL(copysign(-2 * val, 2 * s), 6);
225    s = -2;
226    BOOST_CHECK_EQUAL(copysign(val, s), -3);
227    BOOST_CHECK_EQUAL(copysign(val, s * -2), 3);
228    BOOST_CHECK_EQUAL(copysign(-2 * val, s), -6);
229    BOOST_CHECK_EQUAL(copysign(-2 * val, 2 * s), -6);
230    val = -3;
231    BOOST_CHECK_EQUAL(copysign(val, s), -3);
232    BOOST_CHECK_EQUAL(copysign(val, s * -2), 3);
233    BOOST_CHECK_EQUAL(copysign(-2 * val, s), -6);
234    BOOST_CHECK_EQUAL(copysign(-2 * val, 2 * s), -6);
235    s = 0;
236    BOOST_CHECK_EQUAL(copysign(val, s), 3);
237    // Things involving signed zero, need to detect it first:
238    if (test_signed_zero)
239    {
240       BOOST_CHECK_EQUAL(copysign(val, s * -2), -3);
241    }
242    BOOST_CHECK_EQUAL(copysign(-2 * val, s), 6);
243    BOOST_CHECK_EQUAL(copysign(-2 * val, 2 * s), 6);
244    // Things involving signed zero, need to detect it first:
245    if (test_signed_zero)
246    {
247       s = changesign(s);
248       if (signbit(s))
249       {
250          BOOST_CHECK_EQUAL(copysign(val, s), -3);
251          BOOST_CHECK_EQUAL(copysign(val, s * -2), 3);
252          BOOST_CHECK_EQUAL(copysign(-2 * val, s), -6);
253          BOOST_CHECK_EQUAL(copysign(-2 * val, 2 * s), -6);
254       }
255    }
256 
257    val = 3;
258    BOOST_CHECK_EQUAL(fpclassify(val), FP_NORMAL);
259    BOOST_CHECK_EQUAL(fpclassify(val * 3), FP_NORMAL);
260    BOOST_CHECK(!isinf(val));
261    BOOST_CHECK(!isinf(val + 2));
262    BOOST_CHECK(!isnan(val));
263    BOOST_CHECK(!isnan(val + 2));
264    BOOST_CHECK(isnormal(val));
265    BOOST_CHECK(isnormal(val + 2));
266    val = -3;
267    BOOST_CHECK_EQUAL(fpclassify(val), FP_NORMAL);
268    BOOST_CHECK_EQUAL(fpclassify(val * 3), FP_NORMAL);
269    BOOST_CHECK(!isinf(val));
270    BOOST_CHECK(!isinf(val + 2));
271    BOOST_CHECK(!isnan(val));
272    BOOST_CHECK(!isnan(val + 2));
273    BOOST_CHECK(isnormal(val));
274    BOOST_CHECK(isnormal(val + 2));
275    val = 0;
276    BOOST_CHECK_EQUAL(fpclassify(val), FP_ZERO);
277    BOOST_CHECK_EQUAL(fpclassify(val * 3), FP_ZERO);
278    BOOST_CHECK(!isinf(val));
279    BOOST_CHECK(!isinf(val + 2));
280    BOOST_CHECK(!isnan(val));
281    BOOST_CHECK(!isnan(val + 2));
282    BOOST_CHECK(!isnormal(val));
283    BOOST_CHECK(!isnormal(val * 2));
284    BOOST_CHECK(!isnormal(val * -2));
285    if (std::numeric_limits<T>::has_infinity)
286    {
287       val = std::numeric_limits<T>::infinity();
288       BOOST_CHECK_EQUAL(fpclassify(val), FP_INFINITE);
289       BOOST_CHECK_EQUAL(fpclassify(val * 3), FP_INFINITE);
290       BOOST_CHECK(isinf(val));
291       BOOST_CHECK(isinf(val + 2));
292       BOOST_CHECK(!isnan(val));
293       BOOST_CHECK(!isnan(val + 2));
294       BOOST_CHECK(!isnormal(val));
295       BOOST_CHECK(!isnormal(val + 2));
296       val = -val;
297       BOOST_CHECK_EQUAL(fpclassify(val), FP_INFINITE);
298       BOOST_CHECK_EQUAL(fpclassify(val * 3), FP_INFINITE);
299       BOOST_CHECK(isinf(val));
300       BOOST_CHECK(isinf(val + 2));
301       BOOST_CHECK(!isnan(val));
302       BOOST_CHECK(!isnan(val + 2));
303       BOOST_CHECK(!isnormal(val));
304       BOOST_CHECK(!isnormal(val + 2));
305    }
306    if (std::numeric_limits<T>::has_quiet_NaN)
307    {
308       val = std::numeric_limits<T>::quiet_NaN();
309       BOOST_CHECK_EQUAL(fpclassify(val), FP_NAN);
310       BOOST_CHECK_EQUAL(fpclassify(val * 3), FP_NAN);
311       BOOST_CHECK(!isinf(val));
312       BOOST_CHECK(!isinf(val + 2));
313       BOOST_CHECK(isnan(val));
314       BOOST_CHECK(isnan(val + 2));
315       BOOST_CHECK(!isnormal(val));
316       BOOST_CHECK(!isnormal(val + 2));
317    }
318    s   = 8 * std::numeric_limits<T>::epsilon();
319    val = 2.5;
320    BOOST_CHECK_CLOSE_FRACTION(asinh(val), T("1.6472311463710957106248586104436196635044144301932365282203100930843983757633104078778420255069424907777006132075516484778755360595913172299093829522950397895699619540523579875476513967578478619028438291006578604823887119907434"), s);
321    BOOST_CHECK_CLOSE_FRACTION(asinh(val + T(0)), T("1.6472311463710957106248586104436196635044144301932365282203100930843983757633104078778420255069424907777006132075516484778755360595913172299093829522950397895699619540523579875476513967578478619028438291006578604823887119907434"), s);
322    BOOST_CHECK_CLOSE_FRACTION(acosh(val), T("1.5667992369724110786640568625804834938620823510926588639329459980122148134693922696279968499622201141051039184050936311066453565386393240356562374302417843319480223211857615778787272615171906055455922537080327062362258846337050"), s);
323    BOOST_CHECK_CLOSE_FRACTION(acosh(val + T(0)), T("1.5667992369724110786640568625804834938620823510926588639329459980122148134693922696279968499622201141051039184050936311066453565386393240356562374302417843319480223211857615778787272615171906055455922537080327062362258846337050"), s);
324    val = 0.5;
325    BOOST_CHECK_CLOSE_FRACTION(atanh(val), T("0.5493061443340548456976226184612628523237452789113747258673471668187471466093044834368078774068660443939850145329789328711840021129652599105264009353836387053015813845916906835896868494221804799518712851583979557605727959588753"), s);
326    BOOST_CHECK_CLOSE_FRACTION(atanh(val + T(0)), T("0.5493061443340548456976226184612628523237452789113747258673471668187471466093044834368078774068660443939850145329789328711840021129652599105264009353836387053015813845916906835896868494221804799518712851583979557605727959588753"), s);
327    val = 55.25;
328    BOOST_CHECK_CLOSE_FRACTION(cbrt(val), T("3.8087058015466360309383876359583281382991983919300128125378938779672144843676192684301168479657279498120767424724024965319869248797423276064015643361426189576415670917818313417529572608229017809069355688606687557031643655896118"), s);
329    BOOST_CHECK_CLOSE_FRACTION(cbrt(val + T(0)), T("3.8087058015466360309383876359583281382991983919300128125378938779672144843676192684301168479657279498120767424724024965319869248797423276064015643361426189576415670917818313417529572608229017809069355688606687557031643655896118"), s);
330    if (!boost::multiprecision::is_interval_number<T>::value)
331    {
332       val = 2.75;
333       BOOST_CHECK_CLOSE_FRACTION(erf(val), T("0.9998993780778803631630956080249130432349352621422640655161095794654526422025908961447328296681056892975214344779300734620255391682713519265048496199034963706976420982849598189071465666866369396765001072187538732800143945532487"), s);
334       BOOST_CHECK_CLOSE_FRACTION(erf(val + T(0)), T("0.9998993780778803631630956080249130432349352621422640655161095794654526422025908961447328296681056892975214344779300734620255391682713519265048496199034963706976420982849598189071465666866369396765001072187538732800143945532487"), s);
335       BOOST_CHECK_CLOSE_FRACTION(erfc(val), T("0.0001006219221196368369043919750869567650647378577359344838904205345473577974091038552671703318943107024785655220699265379744608317286480734951503800965036293023579017150401810928534333133630603234998927812461267199856054467512"), s);
336       BOOST_CHECK_CLOSE_FRACTION(erfc(val + T(0)), T("0.0001006219221196368369043919750869567650647378577359344838904205345473577974091038552671703318943107024785655220699265379744608317286480734951503800965036293023579017150401810928534333133630603234998927812461267199856054467512"), s);
337    }
338    val = 0.125;
339    BOOST_CHECK_CLOSE_FRACTION(expm1(val), T("0.1331484530668263168290072278117938725655031317451816259128200360788235778800483865139399907949417285732315270156473075657048210452584733998785564025916995261162759280700397984729320345630340659469435372721057879969170503978449"), s);
340    BOOST_CHECK_CLOSE_FRACTION(expm1(val + T(0)), T("0.1331484530668263168290072278117938725655031317451816259128200360788235778800483865139399907949417285732315270156473075657048210452584733998785564025916995261162759280700397984729320345630340659469435372721057879969170503978449"), s);
341 
342    val = 20;
343    s   = 2;
344    BOOST_CHECK_EQUAL(fdim(val, s), 18);
345    BOOST_CHECK_EQUAL(fdim(s, val), 0);
346    BOOST_CHECK_EQUAL(fdim(val, s * 2), 16);
347    BOOST_CHECK_EQUAL(fdim(s * 2, val), 0);
348    BOOST_CHECK_EQUAL(fdim(val, 2), 18);
349    BOOST_CHECK_EQUAL(fdim(2, val), 0);
350 
351    BOOST_CHECK_EQUAL(fmax(val, s), val);
352    BOOST_CHECK_EQUAL(fmax(s, val), val);
353    BOOST_CHECK_EQUAL(fmax(val * 2, s), val * 2);
354    BOOST_CHECK_EQUAL(fmax(val, s * 2), val);
355    BOOST_CHECK_EQUAL(fmax(val * 2, s * 2), val * 2);
356    BOOST_CHECK_EQUAL(fmin(val, s), s);
357    BOOST_CHECK_EQUAL(fmin(s, val), s);
358    BOOST_CHECK_EQUAL(fmin(val * 2, s), s);
359    BOOST_CHECK_EQUAL(fmin(val, s * 2), s * 2);
360    BOOST_CHECK_EQUAL(fmin(val * 2, s * 2), s * 2);
361 
362    BOOST_CHECK_EQUAL(fmax(val, 2), val);
363    BOOST_CHECK_EQUAL(fmax(val, 2.0), val);
364    BOOST_CHECK_EQUAL(fmax(20, s), val);
365    BOOST_CHECK_EQUAL(fmax(20.0, s), val);
366    BOOST_CHECK_EQUAL(fmin(val, 2), s);
367    BOOST_CHECK_EQUAL(fmin(val, 2.0), s);
368    BOOST_CHECK_EQUAL(fmin(20, s), s);
369    BOOST_CHECK_EQUAL(fmin(20.0, s), s);
370    if (std::numeric_limits<T>::has_quiet_NaN)
371    {
372       BOOST_CHECK_EQUAL(fmax(val, std::numeric_limits<T>::quiet_NaN()), val);
373       BOOST_CHECK_EQUAL(fmax(std::numeric_limits<T>::quiet_NaN(), val), val);
374       BOOST_CHECK_EQUAL(fmin(val, std::numeric_limits<T>::quiet_NaN()), val);
375       BOOST_CHECK_EQUAL(fmin(std::numeric_limits<T>::quiet_NaN(), val), val);
376    }
377    if (std::numeric_limits<double>::has_quiet_NaN)
378    {
379       BOOST_CHECK_EQUAL(fmax(val, std::numeric_limits<double>::quiet_NaN()), val);
380       BOOST_CHECK_EQUAL(fmax(std::numeric_limits<double>::quiet_NaN(), val), val);
381       BOOST_CHECK_EQUAL(fmin(val, std::numeric_limits<double>::quiet_NaN()), val);
382       BOOST_CHECK_EQUAL(fmin(std::numeric_limits<double>::quiet_NaN(), val), val);
383    }
384 
385    test_less(s, val);
386    test_less(2, val);
387    test_less(s, 20);
388    test_less(s + 0, val);
389    test_less(s, val * 1);
390    test_less(s * 1, val * 1);
391    test_less(s * 1, 20);
392    test_less(s + 2, val * 2);
393 
394    test_equal(val, val);
395    test_equal(20, val);
396    test_equal(val, 20);
397    test_equal(val + 0, val);
398    test_equal(val, val * 1);
399    test_equal(val * 1, val * 1);
400    test_equal(val * 1, 20);
401    test_equal(val * 20, val * 20);
402 
403    if (std::numeric_limits<T>::has_quiet_NaN)
404    {
405       s = std::numeric_limits<T>::quiet_NaN();
406       test_unordered(s, val);
407       test_unordered(s, 20);
408       test_unordered(s + 0, val);
409       test_unordered(s, val * 1);
410       test_unordered(s * 1, val * 1);
411       test_unordered(s * 1, 20);
412       test_unordered(s + 2, val * 2);
413       if (std::numeric_limits<double>::has_quiet_NaN)
414       {
415          double n = std::numeric_limits<double>::quiet_NaN();
416          test_unordered(n, val);
417       }
418    }
419 
420    T tol = 8 * std::numeric_limits<T>::epsilon();
421    s     = 2;
422    BOOST_CHECK_CLOSE_FRACTION(T(hypot(val, s)), T("20.099751242241780540438529825519152373890046940052754581145656594656982463103940762472355384907904704732599006530"), tol);
423    BOOST_CHECK_CLOSE_FRACTION(T(hypot(val, 2)), T("20.099751242241780540438529825519152373890046940052754581145656594656982463103940762472355384907904704732599006530"), tol);
424    BOOST_CHECK_CLOSE_FRACTION(T(hypot(val, 2.0)), T("20.099751242241780540438529825519152373890046940052754581145656594656982463103940762472355384907904704732599006530"), tol);
425    BOOST_CHECK_CLOSE_FRACTION(T(hypot(20, s)), T("20.099751242241780540438529825519152373890046940052754581145656594656982463103940762472355384907904704732599006530"), tol);
426    BOOST_CHECK_CLOSE_FRACTION(T(hypot(20.0, s)), T("20.099751242241780540438529825519152373890046940052754581145656594656982463103940762472355384907904704732599006530"), tol);
427    BOOST_CHECK_CLOSE_FRACTION(T(hypot(val * 1, s)), T("20.099751242241780540438529825519152373890046940052754581145656594656982463103940762472355384907904704732599006530"), tol);
428    BOOST_CHECK_CLOSE_FRACTION(T(hypot(val * 1, s * 1)), T("20.099751242241780540438529825519152373890046940052754581145656594656982463103940762472355384907904704732599006530"), tol);
429    BOOST_CHECK_CLOSE_FRACTION(T(hypot(val * 1, 2)), T("20.099751242241780540438529825519152373890046940052754581145656594656982463103940762472355384907904704732599006530"), tol);
430    BOOST_CHECK_CLOSE_FRACTION(T(hypot(val * 1, 2.0)), T("20.099751242241780540438529825519152373890046940052754581145656594656982463103940762472355384907904704732599006530"), tol);
431    BOOST_CHECK_CLOSE_FRACTION(T(hypot(20, s * 1)), T("20.099751242241780540438529825519152373890046940052754581145656594656982463103940762472355384907904704732599006530"), tol);
432    BOOST_CHECK_CLOSE_FRACTION(T(hypot(20.0, s * 1)), T("20.099751242241780540438529825519152373890046940052754581145656594656982463103940762472355384907904704732599006530"), tol);
433 
434    BOOST_CHECK_CLOSE_FRACTION(lgamma(val), T("39.339884187199494036224652394567381081691457206897853119937969989377572554993874476249340525204204720861169039582"), tol);
435    BOOST_CHECK_CLOSE_FRACTION(lgamma(val + 0), T("39.339884187199494036224652394567381081691457206897853119937969989377572554993874476249340525204204720861169039582"), tol);
436 
437    BOOST_CHECK_EQUAL(lrint(val), 20);
438    BOOST_CHECK_EQUAL(lrint(val * 2), 40);
439    BOOST_CHECK_EQUAL(llrint(val), 20);
440    BOOST_CHECK_EQUAL(llrint(val * 2), 40);
441 
442    val = 0.125;
443    BOOST_CHECK_CLOSE_FRACTION(log1p(val), T("0.117783035656383454538794109470521705068480712564733141107348638794807720528133786929641528638208114949935615070"), tol);
444    BOOST_CHECK_CLOSE_FRACTION(log1p(val + 0), T("0.117783035656383454538794109470521705068480712564733141107348638794807720528133786929641528638208114949935615070"), tol);
445    val = 20;
446    BOOST_CHECK_CLOSE_FRACTION(T(log2(val)), T("4.321928094887362347870319429489390175864831393024580612054756395815934776608625215850139743359370155099657371710"), tol);
447    BOOST_CHECK_CLOSE_FRACTION(T(log2(val + 0)), T("4.321928094887362347870319429489390175864831393024580612054756395815934776608625215850139743359370155099657371710"), tol);
448 
449    BOOST_CHECK_EQUAL(T(nearbyint(val)), 20);
450    BOOST_CHECK_EQUAL(T(nearbyint(val + 0.25)), 20);
451    BOOST_CHECK_EQUAL(T(rint(val)), 20);
452    BOOST_CHECK_EQUAL(T(rint(val + 0.25)), 20);
453 
454    BOOST_CHECK_GT(nextafter(val, T(200)), val);
455    BOOST_CHECK_GT(nextafter(val + 0, T(200)), val);
456    BOOST_CHECK_GT(nextafter(val + 0, T(200) + 1), val);
457    BOOST_CHECK_GT(nextafter(val, T(200) + 1), val);
458 
459    BOOST_CHECK_GT(nexttoward(val, T(200)), val);
460    BOOST_CHECK_GT(nexttoward(val + 0, T(200)), val);
461    BOOST_CHECK_GT(nexttoward(val + 0, T(200) + 1), val);
462    BOOST_CHECK_GT(nexttoward(val, T(200) + 1), val);
463 
464    val = 21;
465    s   = 5;
466    BOOST_CHECK_EQUAL(T(remainder(val, s)), 1);
467    BOOST_CHECK_EQUAL(T(remainder(val, 5)), 1);
468    BOOST_CHECK_EQUAL(T(remainder(21, s)), 1);
469    BOOST_CHECK_EQUAL(T(remainder(val * 1, s)), 1);
470    BOOST_CHECK_EQUAL(T(remainder(val * 1, s * 1)), 1);
471    BOOST_CHECK_EQUAL(T(remainder(val, s * 1)), 1);
472    BOOST_CHECK_EQUAL(T(remainder(val * 1, 5)), 1);
473    BOOST_CHECK_EQUAL(T(remainder(21, s * 1)), 1);
474    int i(0);
475    BOOST_CHECK_EQUAL(T(remquo(val, s, &i)), 1);
476    BOOST_CHECK_EQUAL(i, 4);
477    i = 0;
478    BOOST_CHECK_EQUAL(T(remquo(val, 5, &i)), 1);
479    BOOST_CHECK_EQUAL(i, 4);
480    i = 0;
481    BOOST_CHECK_EQUAL(T(remquo(21, s, &i)), 1);
482    BOOST_CHECK_EQUAL(i, 4);
483    i = 0;
484    BOOST_CHECK_EQUAL(T(remquo(val * 1, s, &i)), 1);
485    BOOST_CHECK_EQUAL(i, 4);
486    i = 0;
487    BOOST_CHECK_EQUAL(T(remquo(val * 1, s * 1, &i)), 1);
488    BOOST_CHECK_EQUAL(i, 4);
489    i = 0;
490    BOOST_CHECK_EQUAL(T(remquo(val, s * 1, &i)), 1);
491    BOOST_CHECK_EQUAL(i, 4);
492    i = 0;
493    BOOST_CHECK_EQUAL(T(remquo(val * 1, 5, &i)), 1);
494    BOOST_CHECK_EQUAL(i, 4);
495    i = 0;
496    BOOST_CHECK_EQUAL(T(remquo(21, s * 1, &i)), 1);
497    BOOST_CHECK_EQUAL(i, 4);
498    i   = 0;
499    val = 5.25;
500    tol = 3000;
501    BOOST_CHECK_CLOSE_FRACTION(tgamma(val), T("35.211611852799685705225257690531248115026311138908448314086859575901217653313145619623624570033258659272301335544"), tol);
502    BOOST_CHECK_CLOSE_FRACTION(tgamma(val + 1), T("184.86096222719834995243260287528905260388813347926935364895601277348139267989401450302402899267460796117958201160"), tol);
503 
504    BOOST_CHECK_CLOSE_FRACTION(T(exp2(val)), T("38.054627680087074134959999057935229289375106958842157216608071191022933383261349115865003025220405558913196632792"), tol);
505    BOOST_CHECK_CLOSE_FRACTION(T(exp2(val + 1)), T("76.109255360174148269919998115870458578750213917684314433216142382045866766522698231730006050440811117826393265585"), tol);
506    val = 15;
507    BOOST_CHECK_CLOSE_FRACTION(T(exp2(val)), T(32768uL), tol);
508    BOOST_CHECK_CLOSE_FRACTION(T(exp2(val + 1)), T(65536uL), tol);
509 
510    i = fpclassify(val) + isgreaterequal(val, s) + islessequal(val, s) + isnan(val) + isunordered(val, s) + isfinite(val) + isinf(val) + islessgreater(val, s) + isnormal(val) + signbit(val) + isgreater(val, s) + isless(val, s);
511 }
512 
513 template <class T>
test_poison()514 void test_poison()
515 {
516    // use these macros as proxies for determining C99 support:
517 #if defined(FP_ILOGB0) && defined(FP_INFINITE)
518    //
519    // These tests verify that our function overloads for Boost.Multiprecision
520    // don't do anything nasty to the std:: overloads for built in types:
521    //
522    using namespace std;
523    using namespace boost::multiprecision;
524    //using namespace boost::math;
525 
526    T   a(2), b(0.3f), c(4), result(0);
527    int i;
528 
529    result += abs(a);
530    result += cosh(a);
531    result += fmod(a, b);
532    result += logb(a);
533    result += remquo(a, b, &i);
534    result += acos(b);
535    result += erf(a);
536    result += frexp(a, &i);
537    result += lrint(a);
538    result += rint(a);
539    result += acosh(b);
540    result += erfc(b);
541    result += hypot(a, b);
542    result += lround(c);
543    result += round(c);
544    result += asin(b);
545    result += exp2(a);
546    result += ilogb(b);
547    result += modf(a, &b);
548    result += scalbln(a, i);
549    result += asinh(b);
550    result += exp(b);
551    result += ldexp(a, i);
552    result += scalbn(a, i);
553    result += atan(b);
554    result += expm1(a);
555    result += lgamma(a);
556    result += sin(b);
557    result += atan2(a, c);
558    result += fabs(a);
559    result += llrint(a);
560    result += sinh(b);
561    result += atanh(b);
562    result += fdim(a, b);
563    result += llround(a);
564    result += nearbyint(a);
565    result += sqrt(b);
566    result += cbrt(a);
567    result += floor(b);
568    result += log(a);
569    result += nextafter(a, b);
570    result += tan(b);
571    result += ceil(b);
572    result += fma(a, b, c);
573    result += log10(a);
574    result += nexttoward(a, b);
575    result += tanh(a);
576    result += copysign(a, b);
577    result += fmax(a, b);
578    result += log1p(a);
579    result += pow(a, b);
580    result += tgamma(a);
581    result += cos(b);
582    result += fmin(a, b);
583    result += log2(a);
584    result += remainder(a, b);
585    result += trunc(b);
586    result += (min)(a, b);
587    result += (max)(a, b);
588 
589 #if !BOOST_WORKAROUND(BOOST_LIBSTDCXX_VERSION, < 60000)
590 
591    i = fpclassify(a) + isgreaterequal(a, b) + islessequal(a, b) + isnan(a) + isunordered(a, b) + isfinite(a) + isinf(a) + islessgreater(a, b) + isnormal(a) + signbit(a) + isgreater(a, b) + isless(a, b);
592 #endif
593 #endif
594 }
595 
596 template <class T>
type_sets_errno(const T &)597 bool type_sets_errno(const T&)
598 {
599    return true;
600 }
601 #ifdef TEST_MPFR_50
602 template <unsigned Digits10, boost::multiprecision::mpfr_allocation_type AllocateType, boost::multiprecision::expression_template_option ExpressionTemplates>
type_sets_errno(const boost::multiprecision::number<boost::multiprecision::mpfr_float_backend<Digits10,AllocateType>,ExpressionTemplates> &)603 bool type_sets_errno(const boost::multiprecision::number<boost::multiprecision::mpfr_float_backend<Digits10, AllocateType>, ExpressionTemplates>&)
604 {
605    return false;
606 }
607 #endif
608 #ifdef TEST_FLOAT128
type_sets_errno(const boost::multiprecision::float128 &)609 bool type_sets_errno(const boost::multiprecision::float128&)
610 {
611    return false;
612 }
613 #endif
614 
615 template <class T>
check_invalid(const T & val)616 typename boost::enable_if_c<std::numeric_limits<T>::is_specialized>::type check_invalid(const T& val)
617 {
618    if (std::numeric_limits<T>::has_quiet_NaN)
619    {
620       BOOST_CHECK(isnan(val));
621    }
622    else
623    {
624       BOOST_CHECK_EQUAL(val, 0);
625    }
626    if (type_sets_errno(val))
627       BOOST_CHECK_EQUAL(errno, EDOM);
628    errno = 0;
629 }
630 
631 template <class T>
check_invalid(const T & val)632 typename boost::disable_if_c<std::numeric_limits<T>::is_specialized>::type check_invalid(const T& val)
633 {
634    check_invalid(static_cast<typename T::result_type>(val));
635 }
636 
637 template <class T>
check_erange(const T & val)638 void check_erange(const T& val)
639 {
640    if (type_sets_errno(val))
641       BOOST_CHECK_EQUAL(errno, ERANGE);
642    errno = 0;
643 }
644 
645 template <class T>
test_c99_appendix_F()646 void test_c99_appendix_F()
647 {
648    //
649    // Tests conformance to non-normative appendix F.9.1 of C99, basically how to handle
650    // special cases, infinities and NaN's.
651    //
652    errno = 0;
653    T tol = std::numeric_limits<T>::epsilon();
654    // F.9.1.1:
655    T arg = 1;
656    T val = acos(arg);
657    BOOST_CHECK_EQUAL(val, 0);
658    BOOST_CHECK(signbit(val) == 0);
659    arg = 2;
660    check_invalid(acos(arg));
661    arg = -2;
662    check_invalid(acos(arg));
663    if (std::numeric_limits<T>::has_infinity)
664    {
665       arg = std::numeric_limits<T>::infinity();
666       check_invalid(acos(arg));
667       arg = -std::numeric_limits<T>::infinity();
668       check_invalid(acos(arg));
669    }
670    if (std::numeric_limits<T>::has_quiet_NaN)
671    {
672       arg = std::numeric_limits<T>::quiet_NaN();
673       check_invalid(acos(arg));
674       arg = -std::numeric_limits<T>::quiet_NaN();
675       check_invalid(acos(arg));
676    }
677    // F.9.1.2:
678    arg = 0;
679    val = asin(arg);
680    BOOST_CHECK_EQUAL(val, 0);
681    BOOST_CHECK(signbit(val) == 0);
682    arg = -arg;
683    if (signbit(arg))
684    {
685       val = asin(arg);
686       BOOST_CHECK_EQUAL(val, 0);
687       BOOST_CHECK(signbit(val));
688    }
689    arg = 2;
690    check_invalid(asin(arg));
691    arg = -2;
692    check_invalid(asin(arg));
693    if (std::numeric_limits<T>::has_infinity)
694    {
695       arg = std::numeric_limits<T>::infinity();
696       check_invalid(asin(arg));
697       arg = -std::numeric_limits<T>::infinity();
698       check_invalid(asin(arg));
699    }
700    if (std::numeric_limits<T>::has_quiet_NaN)
701    {
702       arg = std::numeric_limits<T>::quiet_NaN();
703       check_invalid(asin(arg));
704       arg = -std::numeric_limits<T>::quiet_NaN();
705       check_invalid(asin(arg));
706    }
707    // F.9.1.3:
708    arg = 0;
709    val = atan(arg);
710    BOOST_CHECK_EQUAL(val, 0);
711    BOOST_CHECK(signbit(val) == 0);
712    arg = -arg;
713    if (signbit(arg))
714    {
715       val = atan(arg);
716       BOOST_CHECK_EQUAL(val, 0);
717       BOOST_CHECK(signbit(val));
718    }
719    if (std::numeric_limits<T>::has_infinity)
720    {
721       arg = std::numeric_limits<T>::infinity();
722       val = atan(arg);
723       BOOST_CHECK_EQUAL(val, boost::math::constants::half_pi<T>());
724       arg = -std::numeric_limits<T>::infinity();
725       val = atan(arg);
726       BOOST_CHECK_EQUAL(val, -boost::math::constants::half_pi<T>());
727    }
728    if (std::numeric_limits<T>::has_quiet_NaN)
729    {
730       arg = std::numeric_limits<T>::quiet_NaN();
731       check_invalid(asin(arg));
732       arg = -std::numeric_limits<T>::quiet_NaN();
733       check_invalid(asin(arg));
734    }
735    // F.9.1.4:
736    arg    = 0;
737    T arg2 = 0;
738    val    = atan2(arg, arg2);
739    BOOST_CHECK_EQUAL(val, 0);
740    BOOST_CHECK(signbit(val) == 0);
741    arg = -arg;
742    if (signbit(arg))
743    {
744       val = atan2(arg, arg2);
745       BOOST_CHECK_EQUAL(val, 0);
746       BOOST_CHECK(signbit(val));
747    }
748    arg2 = -arg2;
749    if (signbit(arg2))
750    {
751       arg = 0;
752       val = atan2(arg, arg2);
753       BOOST_CHECK_EQUAL(val, boost::math::constants::pi<T>());
754       BOOST_CHECK(signbit(val) == 0);
755       arg = -arg;
756       val = atan2(arg, arg2);
757       BOOST_CHECK_EQUAL(val, -boost::math::constants::pi<T>());
758       BOOST_CHECK(signbit(val));
759    }
760    arg  = 0;
761    arg2 = -2;
762    val  = atan2(arg, arg2);
763    BOOST_CHECK_EQUAL(val, boost::math::constants::pi<T>());
764    arg = -arg;
765    if (signbit(arg))
766    {
767       val = atan2(arg, arg2);
768       BOOST_CHECK_EQUAL(val, -boost::math::constants::pi<T>());
769    }
770    arg  = 0;
771    arg2 = 2;
772    val  = atan2(arg, arg2);
773    BOOST_CHECK_EQUAL(val, 0);
774    BOOST_CHECK(signbit(val) == 0);
775    arg = -arg;
776    if (signbit(arg))
777    {
778       val = atan2(arg, arg2);
779       BOOST_CHECK_EQUAL(val, 0);
780       BOOST_CHECK(signbit(val));
781    }
782    arg  = -2;
783    arg2 = 0;
784    val  = atan2(arg, arg2);
785    BOOST_CHECK_EQUAL(val, -boost::math::constants::half_pi<T>());
786    arg2 = -arg2;
787    if (signbit(arg2))
788    {
789       val = atan2(arg, arg2);
790       BOOST_CHECK_EQUAL(val, -boost::math::constants::half_pi<T>());
791    }
792    arg  = 2;
793    arg2 = 0;
794    val  = atan2(arg, arg2);
795    BOOST_CHECK_EQUAL(val, boost::math::constants::half_pi<T>());
796    arg2 = -arg2;
797    if (signbit(arg2))
798    {
799       val = atan2(arg, arg2);
800       BOOST_CHECK_EQUAL(val, boost::math::constants::half_pi<T>());
801    }
802    if (std::numeric_limits<T>::has_infinity)
803    {
804       arg  = 2;
805       arg2 = -std::numeric_limits<T>::infinity();
806       val  = atan2(arg, arg2);
807       BOOST_CHECK_EQUAL(val, boost::math::constants::pi<T>());
808       arg = -arg;
809       val = atan2(arg, arg2);
810       BOOST_CHECK_EQUAL(val, -boost::math::constants::pi<T>());
811       arg  = 2;
812       arg2 = std::numeric_limits<T>::infinity();
813       val  = atan2(arg, arg2);
814       BOOST_CHECK_EQUAL(val, 0);
815       BOOST_CHECK(signbit(val) == 0);
816       arg = -arg;
817       if (signbit(-T(0)))
818       {
819          val = atan2(arg, arg2);
820          BOOST_CHECK_EQUAL(val, 0);
821          BOOST_CHECK(signbit(val));
822       }
823       arg  = std::numeric_limits<T>::infinity();
824       arg2 = 2;
825       val  = atan2(arg, arg2);
826       BOOST_CHECK_EQUAL(val, boost::math::constants::half_pi<T>());
827       arg = -arg;
828       val = atan2(arg, arg2);
829       BOOST_CHECK_EQUAL(val, -boost::math::constants::half_pi<T>());
830       arg  = std::numeric_limits<T>::infinity();
831       arg2 = -2;
832       val  = atan2(arg, arg2);
833       BOOST_CHECK_EQUAL(val, boost::math::constants::half_pi<T>());
834       arg = -arg;
835       val = atan2(arg, arg2);
836       BOOST_CHECK_EQUAL(val, -boost::math::constants::half_pi<T>());
837       arg  = std::numeric_limits<T>::infinity();
838       arg2 = -std::numeric_limits<T>::infinity();
839       val  = atan2(arg, arg2);
840       BOOST_CHECK_CLOSE_FRACTION(val, boost::math::constants::three_quarters_pi<T>(), tol);
841       arg = -arg;
842       val = atan2(arg, arg2);
843       BOOST_CHECK_CLOSE_FRACTION(val, -boost::math::constants::three_quarters_pi<T>(), tol);
844       arg  = std::numeric_limits<T>::infinity();
845       arg2 = std::numeric_limits<T>::infinity();
846       val  = atan2(arg, arg2);
847       BOOST_CHECK_CLOSE_FRACTION(val, ldexp(boost::math::constants::pi<T>(), -2), tol);
848       arg = -arg;
849       val = atan2(arg, arg2);
850       BOOST_CHECK_CLOSE_FRACTION(val, -ldexp(boost::math::constants::pi<T>(), -2), tol);
851       if (std::numeric_limits<T>::has_quiet_NaN)
852       {
853          arg  = std::numeric_limits<T>::quiet_NaN();
854          arg2 = 2;
855          check_invalid(atan2(arg, arg2));
856          std::swap(arg, arg2);
857          check_invalid(atan2(arg, arg2));
858          arg = std::numeric_limits<T>::quiet_NaN();
859          check_invalid(atan2(arg, arg2));
860       }
861    }
862    // F.9.1.5:
863    arg = 0;
864    val = cos(arg);
865    BOOST_CHECK_EQUAL(val, 1);
866    arg = -arg;
867    BOOST_CHECK_EQUAL(val, 1);
868    if (std::numeric_limits<T>::has_infinity)
869    {
870       arg = std::numeric_limits<T>::infinity();
871       check_invalid(cos(arg));
872       arg = -std::numeric_limits<T>::infinity();
873       check_invalid(cos(arg));
874    }
875    if (std::numeric_limits<T>::has_quiet_NaN)
876    {
877       arg = std::numeric_limits<T>::quiet_NaN();
878       check_invalid(cos(arg));
879       arg = -std::numeric_limits<T>::quiet_NaN();
880       check_invalid(cos(arg));
881    }
882    // F.9.1.6:
883    arg = 0;
884    val = sin(arg);
885    BOOST_CHECK_EQUAL(val, 0);
886    BOOST_CHECK(signbit(val) == 0);
887    arg = -arg;
888    if (signbit(arg))
889    {
890       val = sin(arg);
891       BOOST_CHECK_EQUAL(val, 0);
892       BOOST_CHECK(signbit(val));
893    }
894    if (std::numeric_limits<T>::has_infinity)
895    {
896       arg = std::numeric_limits<T>::infinity();
897       check_invalid(sin(arg));
898       arg = -std::numeric_limits<T>::infinity();
899       check_invalid(sin(arg));
900    }
901    if (std::numeric_limits<T>::has_quiet_NaN)
902    {
903       arg = std::numeric_limits<T>::quiet_NaN();
904       check_invalid(sin(arg));
905       arg = -std::numeric_limits<T>::quiet_NaN();
906       check_invalid(sin(arg));
907    }
908    // F.9.1.7:
909    arg = 0;
910    val = tan(arg);
911    BOOST_CHECK_EQUAL(val, 0);
912    BOOST_CHECK(signbit(val) == 0);
913    arg = -arg;
914    if (signbit(arg))
915    {
916       val = tan(arg);
917       BOOST_CHECK_EQUAL(val, 0);
918       BOOST_CHECK(signbit(val));
919    }
920    if (std::numeric_limits<T>::has_infinity)
921    {
922       arg = std::numeric_limits<T>::infinity();
923       check_invalid(tan(arg));
924       arg = -std::numeric_limits<T>::infinity();
925       check_invalid(tan(arg));
926    }
927    if (std::numeric_limits<T>::has_quiet_NaN)
928    {
929       arg = std::numeric_limits<T>::quiet_NaN();
930       check_invalid(tan(arg));
931       arg = -std::numeric_limits<T>::quiet_NaN();
932       check_invalid(tan(arg));
933    }
934    // F.9.2.1:
935    arg = 1;
936    val = acosh(arg);
937    BOOST_CHECK_EQUAL(val, 0);
938    BOOST_CHECK(signbit(val) == 0);
939    arg = -arg;
940    check_invalid(acosh(arg));
941    if (std::numeric_limits<T>::has_infinity)
942    {
943       arg = std::numeric_limits<T>::infinity();
944       val = acosh(arg);
945       BOOST_CHECK_EQUAL(val, std::numeric_limits<T>::infinity());
946 
947       arg = -std::numeric_limits<T>::infinity();
948       check_invalid(acosh(arg));
949    }
950    if (std::numeric_limits<T>::has_quiet_NaN)
951    {
952       arg = std::numeric_limits<T>::quiet_NaN();
953       check_invalid(acosh(arg));
954       arg = -std::numeric_limits<T>::quiet_NaN();
955       check_invalid(acosh(arg));
956    }
957    // F.9.2.2:
958    arg = 0;
959    val = asinh(arg);
960    BOOST_CHECK_EQUAL(val, 0);
961    BOOST_CHECK(signbit(val) == 0);
962    arg = -arg;
963    if (signbit(arg))
964    {
965       val = asinh(arg);
966       BOOST_CHECK_EQUAL(val, 0);
967       BOOST_CHECK(signbit(val));
968    }
969    if (std::numeric_limits<T>::has_infinity)
970    {
971       arg = std::numeric_limits<T>::infinity();
972       val = asinh(arg);
973       BOOST_CHECK_EQUAL(val, std::numeric_limits<T>::infinity());
974 
975       arg = -std::numeric_limits<T>::infinity();
976       val = asinh(arg);
977       BOOST_CHECK_EQUAL(val, -std::numeric_limits<T>::infinity());
978    }
979    if (std::numeric_limits<T>::has_quiet_NaN)
980    {
981       arg = std::numeric_limits<T>::quiet_NaN();
982       check_invalid(asinh(arg));
983       arg = -std::numeric_limits<T>::quiet_NaN();
984       check_invalid(asinh(arg));
985    }
986    // F.9.2.3:
987    arg = 0;
988    val = atanh(arg);
989    BOOST_CHECK_EQUAL(val, 0);
990    BOOST_CHECK(signbit(val) == 0);
991    arg = -arg;
992    if (signbit(arg))
993    {
994       val = atanh(arg);
995       BOOST_CHECK_EQUAL(val, 0);
996       BOOST_CHECK(signbit(val));
997    }
998    arg = 2;
999    check_invalid(atanh(arg));
1000    arg = -3;
1001    check_invalid(atanh(arg));
1002 
1003    if (std::numeric_limits<T>::has_infinity)
1004    {
1005       arg = 1;
1006       val = atanh(arg);
1007       BOOST_CHECK_EQUAL(val, std::numeric_limits<T>::infinity());
1008       BOOST_CHECK(signbit(val) == 0);
1009       check_erange(val);
1010       arg = -arg;
1011       val = atanh(arg);
1012       BOOST_CHECK_EQUAL(val, -std::numeric_limits<T>::infinity());
1013       BOOST_CHECK(signbit(val));
1014       check_erange(val);
1015 
1016       arg = std::numeric_limits<T>::infinity();
1017       check_invalid(atanh(arg));
1018       arg = -std::numeric_limits<T>::infinity();
1019       check_invalid(atanh(arg));
1020    }
1021    if (std::numeric_limits<T>::has_quiet_NaN)
1022    {
1023       arg = std::numeric_limits<T>::quiet_NaN();
1024       check_invalid(atanh(arg));
1025       arg = -std::numeric_limits<T>::quiet_NaN();
1026       check_invalid(atanh(arg));
1027    }
1028    // F.9.2.4:
1029    arg = 0;
1030    val = cosh(arg);
1031    BOOST_CHECK_EQUAL(val, 1);
1032    arg = -arg;
1033    if (signbit(arg))
1034    {
1035       val = cosh(arg);
1036       BOOST_CHECK_EQUAL(val, 1);
1037    }
1038    if (std::numeric_limits<T>::has_infinity)
1039    {
1040       arg = (std::numeric_limits<T>::max)();
1041       val = cosh(arg);
1042       BOOST_CHECK_EQUAL(val, std::numeric_limits<T>::infinity());
1043       arg = -arg;
1044       val = cosh(arg);
1045       BOOST_CHECK_EQUAL(val, std::numeric_limits<T>::infinity());
1046       arg = std::numeric_limits<T>::infinity();
1047       val = cosh(arg);
1048       BOOST_CHECK_EQUAL(val, std::numeric_limits<T>::infinity());
1049       arg = -arg;
1050       val = cosh(arg);
1051       BOOST_CHECK_EQUAL(val, std::numeric_limits<T>::infinity());
1052    }
1053    if (std::numeric_limits<T>::has_quiet_NaN)
1054    {
1055       arg = std::numeric_limits<T>::quiet_NaN();
1056       check_invalid(cosh(arg));
1057       arg = -std::numeric_limits<T>::quiet_NaN();
1058       check_invalid(cosh(arg));
1059    }
1060    // F.9.2.5:
1061    arg = 0;
1062    val = sinh(arg);
1063    BOOST_CHECK_EQUAL(val, 0);
1064    BOOST_CHECK(signbit(val) == 0);
1065    arg = -arg;
1066    if (signbit(arg))
1067    {
1068       val = sinh(arg);
1069       BOOST_CHECK_EQUAL(val, 0);
1070       BOOST_CHECK(signbit(val));
1071    }
1072    if (std::numeric_limits<T>::has_infinity)
1073    {
1074       arg = (std::numeric_limits<T>::max)();
1075       val = sinh(arg);
1076       BOOST_CHECK_EQUAL(val, std::numeric_limits<T>::infinity());
1077       arg = -arg;
1078       val = sinh(arg);
1079       BOOST_CHECK_EQUAL(val, -std::numeric_limits<T>::infinity());
1080       arg = std::numeric_limits<T>::infinity();
1081       val = sinh(arg);
1082       BOOST_CHECK_EQUAL(val, std::numeric_limits<T>::infinity());
1083       arg = -arg;
1084       val = sinh(arg);
1085       BOOST_CHECK_EQUAL(val, -std::numeric_limits<T>::infinity());
1086    }
1087    if (std::numeric_limits<T>::has_quiet_NaN)
1088    {
1089       arg = std::numeric_limits<T>::quiet_NaN();
1090       check_invalid(sinh(arg));
1091       arg = -std::numeric_limits<T>::quiet_NaN();
1092       check_invalid(sinh(arg));
1093    }
1094    // F.9.2.6:
1095    arg = 0;
1096    val = tanh(arg);
1097    BOOST_CHECK_EQUAL(val, 0);
1098    BOOST_CHECK(signbit(val) == 0);
1099    arg = -arg;
1100    if (signbit(arg))
1101    {
1102       val = tanh(arg);
1103       BOOST_CHECK_EQUAL(val, 0);
1104       BOOST_CHECK(signbit(val));
1105    }
1106    arg = (std::numeric_limits<T>::max)();
1107    val = tanh(arg);
1108    BOOST_CHECK_EQUAL(val, 1);
1109    arg = -arg;
1110    val = tanh(arg);
1111    BOOST_CHECK_EQUAL(val, -1);
1112    if (std::numeric_limits<T>::has_infinity)
1113    {
1114       arg = std::numeric_limits<T>::infinity();
1115       val = tanh(arg);
1116       BOOST_CHECK_EQUAL(val, 1);
1117       arg = -arg;
1118       val = tanh(arg);
1119       BOOST_CHECK_EQUAL(val, -1);
1120    }
1121    if (std::numeric_limits<T>::has_quiet_NaN)
1122    {
1123       arg = std::numeric_limits<T>::quiet_NaN();
1124       check_invalid(tanh(arg));
1125       arg = -std::numeric_limits<T>::quiet_NaN();
1126       check_invalid(tanh(arg));
1127    }
1128    // F.9.3.1:
1129    arg = 0;
1130    val = exp(arg);
1131    BOOST_CHECK_EQUAL(val, 1);
1132    arg = -arg;
1133    if (signbit(arg))
1134    {
1135       val = exp(arg);
1136       BOOST_CHECK_EQUAL(val, 1);
1137    }
1138    if (std::numeric_limits<T>::has_infinity)
1139    {
1140       arg = std::numeric_limits<T>::infinity();
1141       val = exp(arg);
1142       BOOST_CHECK_EQUAL(val, std::numeric_limits<T>::infinity());
1143       arg = -arg;
1144       val = exp(arg);
1145       BOOST_CHECK_EQUAL(val, 0);
1146       BOOST_CHECK(signbit(val) == 0);
1147       arg = (std::numeric_limits<T>::max)();
1148       val = exp(arg);
1149       BOOST_CHECK_EQUAL(val, std::numeric_limits<T>::infinity());
1150       arg = -arg;
1151       val = exp(arg);
1152       BOOST_CHECK_EQUAL(val, 0);
1153       BOOST_CHECK(signbit(val) == 0);
1154    }
1155    if (std::numeric_limits<T>::has_quiet_NaN)
1156    {
1157       arg = std::numeric_limits<T>::quiet_NaN();
1158       check_invalid(exp(arg));
1159       arg = -std::numeric_limits<T>::quiet_NaN();
1160       check_invalid(exp(arg));
1161    }
1162    // F.9.3.2:
1163    arg = 0;
1164    val = exp2(arg);
1165    BOOST_CHECK_EQUAL(val, 1);
1166    arg = -arg;
1167    if (signbit(arg))
1168    {
1169       val = exp2(arg);
1170       BOOST_CHECK_EQUAL(val, 1);
1171    }
1172    if (std::numeric_limits<T>::has_infinity)
1173    {
1174       arg = std::numeric_limits<T>::infinity();
1175       val = exp2(arg);
1176       BOOST_CHECK_EQUAL(val, std::numeric_limits<T>::infinity());
1177       arg = -arg;
1178       val = exp2(arg);
1179       BOOST_CHECK_EQUAL(val, 0);
1180       BOOST_CHECK(signbit(val) == 0);
1181       arg = (std::numeric_limits<T>::max)();
1182       val = exp2(arg);
1183       BOOST_CHECK_EQUAL(val, std::numeric_limits<T>::infinity());
1184       arg = -arg;
1185       val = exp2(arg);
1186       BOOST_CHECK_EQUAL(val, 0);
1187       BOOST_CHECK(signbit(val) == 0);
1188    }
1189    if (std::numeric_limits<T>::has_quiet_NaN)
1190    {
1191       arg = std::numeric_limits<T>::quiet_NaN();
1192       check_invalid(exp2(arg));
1193       arg = -std::numeric_limits<T>::quiet_NaN();
1194       check_invalid(exp2(arg));
1195    }
1196    // F.9.3.3:
1197    arg = 0;
1198    val = expm1(arg);
1199    BOOST_CHECK_EQUAL(val, 0);
1200    BOOST_CHECK(signbit(val) == 0);
1201    arg = -arg;
1202    if (signbit(arg))
1203    {
1204       val = expm1(arg);
1205       BOOST_CHECK_EQUAL(val, 0);
1206       BOOST_CHECK(signbit(val));
1207    }
1208    if (std::numeric_limits<T>::has_infinity)
1209    {
1210       arg = std::numeric_limits<T>::infinity();
1211       val = expm1(arg);
1212       BOOST_CHECK_EQUAL(val, std::numeric_limits<T>::infinity());
1213       arg = -arg;
1214       val = expm1(arg);
1215       BOOST_CHECK_EQUAL(val, -1);
1216       arg = (std::numeric_limits<T>::max)();
1217       val = expm1(arg);
1218       BOOST_CHECK_EQUAL(val, std::numeric_limits<T>::infinity());
1219       arg = -arg;
1220       val = expm1(arg);
1221       BOOST_CHECK_EQUAL(val, -1);
1222    }
1223    if (std::numeric_limits<T>::has_quiet_NaN)
1224    {
1225       arg = std::numeric_limits<T>::quiet_NaN();
1226       check_invalid(expm1(arg));
1227       arg = -std::numeric_limits<T>::quiet_NaN();
1228       check_invalid(expm1(arg));
1229    }
1230    // F.9.3.4:
1231    arg = 0;
1232    int ival;
1233    val = frexp(arg, &ival);
1234    BOOST_CHECK_EQUAL(val, 0);
1235    BOOST_CHECK_EQUAL(ival, 0);
1236    BOOST_CHECK(signbit(val) == 0);
1237    arg = -arg;
1238    if (signbit(arg))
1239    {
1240       val = frexp(arg, &ival);
1241       BOOST_CHECK_EQUAL(val, 0);
1242       BOOST_CHECK(signbit(val));
1243       BOOST_CHECK(signbit(val));
1244    }
1245    if (std::numeric_limits<T>::has_infinity)
1246    {
1247       arg = std::numeric_limits<T>::infinity();
1248       val = frexp(arg, &ival);
1249       BOOST_CHECK_EQUAL(val, std::numeric_limits<T>::infinity());
1250       arg = -arg;
1251       val = frexp(arg, &ival);
1252       BOOST_CHECK_EQUAL(val, -std::numeric_limits<T>::infinity());
1253    }
1254    if (std::numeric_limits<T>::has_quiet_NaN)
1255    {
1256       arg = std::numeric_limits<T>::quiet_NaN();
1257       val = frexp(arg, &ival);
1258       BOOST_CHECK(isnan(val));
1259    }
1260    // F.9.3.5:
1261    typename T::backend_type::exponent_type eval;
1262    typename T::backend_type::exponent_type fp_ilogb0 = (std::numeric_limits<typename T::backend_type::exponent_type>::min)();
1263    typename T::backend_type::exponent_type fp_ilogbnan =
1264 #ifdef FP_ILOGBNAN
1265        FP_ILOGBNAN < 0 ? (std::numeric_limits<typename T::backend_type::exponent_type>::min)() : (std::numeric_limits<typename T::backend_type::exponent_type>::max)();
1266 #else
1267        INT_MAX;
1268 #endif
1269 
1270    arg  = 0;
1271    eval = ilogb(arg);
1272    BOOST_CHECK_EQUAL(eval, fp_ilogb0);
1273    if (std::numeric_limits<T>::has_infinity)
1274    {
1275       arg  = std::numeric_limits<T>::infinity();
1276       eval = ilogb(arg);
1277       BOOST_CHECK_EQUAL(eval, (std::numeric_limits<typename T::backend_type::exponent_type>::max)());
1278       arg  = -arg;
1279       eval = ilogb(arg);
1280       BOOST_CHECK_EQUAL(eval, (std::numeric_limits<typename T::backend_type::exponent_type>::max)());
1281    }
1282    if (std::numeric_limits<T>::has_quiet_NaN)
1283    {
1284       arg  = std::numeric_limits<T>::quiet_NaN();
1285       eval = ilogb(arg);
1286       BOOST_CHECK_EQUAL(eval, fp_ilogbnan);
1287    }
1288    // F.9.3.7:
1289    arg = 1;
1290    val = log(arg);
1291    BOOST_CHECK_EQUAL(val, 0);
1292    BOOST_CHECK(signbit(val) == 0);
1293    if (std::numeric_limits<T>::has_infinity)
1294    {
1295       arg = 0;
1296       val = log(arg);
1297       BOOST_CHECK_EQUAL(val, -std::numeric_limits<T>::infinity());
1298       check_erange(val);
1299       arg = -arg;
1300       if (signbit(arg))
1301       {
1302          val = log(arg);
1303          BOOST_CHECK_EQUAL(val, -std::numeric_limits<T>::infinity());
1304          check_erange(val);
1305       }
1306       arg = -1;
1307       check_invalid(log(arg));
1308       arg = -std::numeric_limits<T>::infinity();
1309       check_invalid(log(arg));
1310       arg = std::numeric_limits<T>::infinity();
1311       val = log(arg);
1312       BOOST_CHECK_EQUAL(val, std::numeric_limits<T>::infinity());
1313    }
1314    if (std::numeric_limits<T>::has_quiet_NaN)
1315    {
1316       arg = std::numeric_limits<T>::quiet_NaN();
1317       check_invalid(log(arg));
1318       arg = -std::numeric_limits<T>::quiet_NaN();
1319       check_invalid(log(arg));
1320    }
1321    // F.9.3.8:
1322    arg = 1;
1323    val = log10(arg);
1324    BOOST_CHECK_EQUAL(val, 0);
1325    BOOST_CHECK(signbit(val) == 0);
1326    if (std::numeric_limits<T>::has_infinity)
1327    {
1328       arg = 0;
1329       val = log10(arg);
1330       BOOST_CHECK_EQUAL(val, -std::numeric_limits<T>::infinity());
1331       check_erange(val);
1332       arg = -arg;
1333       if (signbit(arg))
1334       {
1335          val = log10(arg);
1336          BOOST_CHECK_EQUAL(val, -std::numeric_limits<T>::infinity());
1337          check_erange(val);
1338       }
1339       arg = -1;
1340       check_invalid(log10(arg));
1341       arg = -std::numeric_limits<T>::infinity();
1342       check_invalid(log10(arg));
1343       arg = std::numeric_limits<T>::infinity();
1344       val = log10(arg);
1345       BOOST_CHECK_EQUAL(val, std::numeric_limits<T>::infinity());
1346    }
1347    if (std::numeric_limits<T>::has_quiet_NaN)
1348    {
1349       arg = std::numeric_limits<T>::quiet_NaN();
1350       check_invalid(log10(arg));
1351       arg = -std::numeric_limits<T>::quiet_NaN();
1352       check_invalid(log10(arg));
1353    }
1354    // F.9.3.9:
1355    arg = 0;
1356    val = log1p(arg);
1357    BOOST_CHECK_EQUAL(val, 0);
1358    BOOST_CHECK(signbit(val) == 0);
1359    arg = -arg;
1360    if (signbit(arg))
1361    {
1362       val = log1p(arg);
1363       BOOST_CHECK_EQUAL(val, 0);
1364       BOOST_CHECK(signbit(val));
1365    }
1366    if (std::numeric_limits<T>::has_infinity)
1367    {
1368       arg = -1;
1369       val = log1p(arg);
1370       BOOST_CHECK_EQUAL(val, -std::numeric_limits<T>::infinity());
1371       check_erange(val);
1372       arg = -2;
1373       check_invalid(log1p(arg));
1374       arg = -std::numeric_limits<T>::infinity();
1375       check_invalid(log1p(arg));
1376       arg = std::numeric_limits<T>::infinity();
1377       val = log1p(arg);
1378       BOOST_CHECK_EQUAL(val, std::numeric_limits<T>::infinity());
1379    }
1380    if (std::numeric_limits<T>::has_quiet_NaN)
1381    {
1382       arg = std::numeric_limits<T>::quiet_NaN();
1383       check_invalid(log1p(arg));
1384       arg = -std::numeric_limits<T>::quiet_NaN();
1385       check_invalid(log1p(arg));
1386    }
1387    // F.9.3.10:
1388    arg = 1;
1389    val = log2(arg);
1390    BOOST_CHECK_EQUAL(val, 0);
1391    BOOST_CHECK(signbit(val) == 0);
1392    if (std::numeric_limits<T>::has_infinity)
1393    {
1394       arg = 0;
1395       val = log2(arg);
1396       BOOST_CHECK_EQUAL(val, -std::numeric_limits<T>::infinity());
1397       check_erange(val);
1398       arg = -arg;
1399       if (signbit(arg))
1400       {
1401          val = log2(arg);
1402          BOOST_CHECK_EQUAL(val, -std::numeric_limits<T>::infinity());
1403          check_erange(val);
1404       }
1405       arg = -1;
1406       check_invalid(log2(arg));
1407       arg = -std::numeric_limits<T>::infinity();
1408       check_invalid(log2(arg));
1409       arg = std::numeric_limits<T>::infinity();
1410       val = log2(arg);
1411       BOOST_CHECK_EQUAL(val, std::numeric_limits<T>::infinity());
1412    }
1413    if (std::numeric_limits<T>::has_quiet_NaN)
1414    {
1415       arg = std::numeric_limits<T>::quiet_NaN();
1416       check_invalid(log2(arg));
1417       arg = -std::numeric_limits<T>::quiet_NaN();
1418       check_invalid(log2(arg));
1419    }
1420    // F.9.3.11:
1421    if (std::numeric_limits<T>::has_infinity)
1422    {
1423       arg = 0;
1424       val = logb(arg);
1425       BOOST_CHECK_EQUAL(val, -std::numeric_limits<T>::infinity());
1426       check_erange(val);
1427       arg = -arg;
1428       if (signbit(arg))
1429       {
1430          val = logb(arg);
1431          BOOST_CHECK_EQUAL(val, -std::numeric_limits<T>::infinity());
1432          check_erange(val);
1433       }
1434       arg = std::numeric_limits<T>::infinity();
1435       val = logb(arg);
1436       BOOST_CHECK_EQUAL(val, std::numeric_limits<T>::infinity());
1437       arg = -std::numeric_limits<T>::infinity();
1438       val = logb(arg);
1439       BOOST_CHECK_EQUAL(val, std::numeric_limits<T>::infinity());
1440    }
1441    if (std::numeric_limits<T>::has_quiet_NaN)
1442    {
1443       arg = std::numeric_limits<T>::quiet_NaN();
1444       check_invalid(logb(arg));
1445       arg = -std::numeric_limits<T>::quiet_NaN();
1446       check_invalid(logb(arg));
1447    }
1448    // F.9.3.13:
1449    arg = 0;
1450    val = scalbn(arg, 2);
1451    BOOST_CHECK_EQUAL(val, 0);
1452    BOOST_CHECK(signbit(val) == 0);
1453    arg = -arg;
1454    if (signbit(arg))
1455    {
1456       val = scalbn(arg, 2);
1457       BOOST_CHECK_EQUAL(val, 0);
1458       BOOST_CHECK(signbit(val));
1459    }
1460    if (std::numeric_limits<T>::has_infinity)
1461    {
1462       arg = std::numeric_limits<T>::infinity();
1463       val = scalbn(arg, -100);
1464       BOOST_CHECK_EQUAL(val, arg);
1465       arg = -arg;
1466       val = scalbn(arg, -100);
1467       BOOST_CHECK_EQUAL(val, arg);
1468    }
1469    // F.9.4.1:
1470    arg = 0;
1471    val = cbrt(arg);
1472    BOOST_CHECK_EQUAL(val, 0);
1473    BOOST_CHECK(signbit(val) == 0);
1474    arg = -arg;
1475    if (signbit(arg))
1476    {
1477       val = cbrt(arg);
1478       BOOST_CHECK_EQUAL(val, 0);
1479       BOOST_CHECK(signbit(val));
1480    }
1481 #if !(defined(TEST_FLOAT128) && defined(BOOST_GCC_VERSION) && (BOOST_GCC_VERSION < 40800))
1482    //
1483    // This test fails with early implementations of libquadmath - not our issue!
1484    //
1485    if (std::numeric_limits<T>::has_infinity)
1486    {
1487       arg = std::numeric_limits<T>::infinity();
1488       val = cbrt(arg);
1489       BOOST_CHECK_EQUAL(val, std::numeric_limits<T>::infinity());
1490       arg = -std::numeric_limits<T>::infinity();
1491       val = cbrt(arg);
1492       BOOST_CHECK_EQUAL(val, -std::numeric_limits<T>::infinity());
1493    }
1494 #endif
1495    if (std::numeric_limits<T>::has_quiet_NaN)
1496    {
1497       arg = std::numeric_limits<T>::quiet_NaN();
1498       check_invalid(cbrt(arg));
1499       arg = -std::numeric_limits<T>::quiet_NaN();
1500       check_invalid(cbrt(arg));
1501    }
1502    // F.9.4.2:
1503    arg = 0;
1504    val = fabs(arg);
1505    BOOST_CHECK_EQUAL(val, 0);
1506    BOOST_CHECK(signbit(val) == 0);
1507    arg = -arg;
1508    if (signbit(arg))
1509    {
1510       val = fabs(arg);
1511       BOOST_CHECK_EQUAL(val, 0);
1512       BOOST_CHECK(signbit(val) == 0);
1513    }
1514    if (std::numeric_limits<T>::has_infinity)
1515    {
1516       arg = std::numeric_limits<T>::infinity();
1517       val = fabs(arg);
1518       BOOST_CHECK_EQUAL(val, std::numeric_limits<T>::infinity());
1519       arg = -std::numeric_limits<T>::infinity();
1520       val = fabs(arg);
1521       BOOST_CHECK_EQUAL(val, std::numeric_limits<T>::infinity());
1522    }
1523    // F.9.4.3:
1524    arg  = 2;
1525    arg2 = 0;
1526    val  = hypot(arg, arg2);
1527    BOOST_CHECK_EQUAL(val, arg);
1528    arg2 = -arg2;
1529    val  = hypot(arg, arg2);
1530    BOOST_CHECK_EQUAL(val, arg);
1531    if (std::numeric_limits<T>::has_infinity)
1532    {
1533       arg  = std::numeric_limits<T>::infinity();
1534       arg2 = 2;
1535       val  = hypot(arg, arg2);
1536       BOOST_CHECK_EQUAL(val, arg);
1537       arg = -arg;
1538       val = hypot(arg, arg2);
1539       BOOST_CHECK_EQUAL(val, -arg);
1540       arg2 = std::numeric_limits<T>::quiet_NaN();
1541       val  = hypot(arg, arg2);
1542       BOOST_CHECK_EQUAL(val, -arg);
1543       arg = -arg;
1544       val = hypot(arg, arg2);
1545       BOOST_CHECK_EQUAL(val, arg);
1546    }
1547    // F.9.4.4:
1548    if (std::numeric_limits<T>::has_infinity)
1549    {
1550       arg  = 0;
1551       arg2 = -3;
1552       val  = pow(arg, arg2);
1553       BOOST_CHECK_EQUAL(val, std::numeric_limits<T>::infinity());
1554       check_erange(val);
1555       arg = -arg;
1556       if (signbit(arg))
1557       {
1558          val = pow(arg, arg2);
1559          BOOST_CHECK_EQUAL(val, -std::numeric_limits<T>::infinity());
1560          check_erange(val);
1561       }
1562       arg  = 0;
1563       arg2 = -2;
1564       val  = pow(arg, arg2);
1565       BOOST_CHECK_EQUAL(val, std::numeric_limits<T>::infinity());
1566       check_erange(val);
1567       arg = -arg;
1568       if (signbit(arg))
1569       {
1570          val = pow(arg, arg2);
1571          BOOST_CHECK_EQUAL(val, std::numeric_limits<T>::infinity());
1572          check_erange(val);
1573       }
1574       arg  = 0;
1575       arg2 = 3;
1576       val  = pow(arg, arg2);
1577       BOOST_CHECK_EQUAL(val, 0);
1578       BOOST_CHECK(signbit(val) == 0);
1579       arg = -arg;
1580       if (signbit(arg))
1581       {
1582          val = pow(arg, arg2);
1583          BOOST_CHECK_EQUAL(val, 0);
1584          BOOST_CHECK(signbit(val));
1585       }
1586       arg  = 0;
1587       arg2 = 2;
1588       val  = pow(arg, arg2);
1589       BOOST_CHECK_EQUAL(val, 0);
1590       BOOST_CHECK(signbit(val) == 0);
1591       arg = -arg;
1592       if (signbit(arg))
1593       {
1594          val = pow(arg, arg2);
1595          BOOST_CHECK_EQUAL(val, 0);
1596          BOOST_CHECK(signbit(val) == 0);
1597       }
1598       arg  = -1;
1599       arg2 = std::numeric_limits<T>::infinity();
1600       val  = pow(arg, arg2);
1601       BOOST_CHECK_EQUAL(val, 1);
1602       arg2 = -std::numeric_limits<T>::infinity();
1603       val  = pow(arg, arg2);
1604       BOOST_CHECK_EQUAL(val, 1);
1605       arg  = 1;
1606       arg2 = 0;
1607       val  = pow(arg, arg2);
1608       BOOST_CHECK_EQUAL(val, 1);
1609       arg2 = std::numeric_limits<T>::infinity();
1610       val  = pow(arg, arg2);
1611       BOOST_CHECK_EQUAL(val, 1);
1612       arg2 = -std::numeric_limits<T>::infinity();
1613       val  = pow(arg, arg2);
1614       BOOST_CHECK_EQUAL(val, 1);
1615       arg2 = std::numeric_limits<T>::quiet_NaN();
1616       val  = pow(arg, arg2);
1617       BOOST_CHECK_EQUAL(val, 1);
1618       arg  = 0;
1619       arg2 = 0;
1620       val  = pow(arg, arg2);
1621       BOOST_CHECK_EQUAL(val, 1);
1622       arg2 = -arg2;
1623       val  = pow(arg, arg2);
1624       BOOST_CHECK_EQUAL(val, 1);
1625       arg = std::numeric_limits<T>::infinity();
1626       val = pow(arg, arg2);
1627       BOOST_CHECK_EQUAL(val, 1);
1628       arg2 = -arg2;
1629       val  = pow(arg, arg2);
1630       BOOST_CHECK_EQUAL(val, 1);
1631       arg = std::numeric_limits<T>::quiet_NaN();
1632       val = pow(arg, arg2);
1633       BOOST_CHECK_EQUAL(val, 1);
1634       arg2 = -arg2;
1635       val  = pow(arg, arg2);
1636       BOOST_CHECK_EQUAL(val, 1);
1637    }
1638    if (std::numeric_limits<T>::has_quiet_NaN)
1639    {
1640       arg  = -2.5;
1641       arg2 = 2.5;
1642       check_invalid(pow(arg, arg2));
1643    }
1644    if (std::numeric_limits<T>::has_infinity)
1645    {
1646       arg  = 0.5;
1647       arg2 = -std::numeric_limits<T>::infinity();
1648       val  = pow(arg, arg2);
1649       BOOST_CHECK_EQUAL(val, std::numeric_limits<T>::infinity());
1650       arg = -0.25;
1651       val = pow(arg, arg2);
1652       BOOST_CHECK_EQUAL(val, std::numeric_limits<T>::infinity());
1653       arg  = 2.5;
1654       arg2 = -std::numeric_limits<T>::infinity();
1655       val  = pow(arg, arg2);
1656       BOOST_CHECK_EQUAL(val, 0);
1657       arg = -arg;
1658       val = pow(arg, arg2);
1659       BOOST_CHECK_EQUAL(val, 0);
1660       arg  = 2.5;
1661       arg2 = std::numeric_limits<T>::infinity();
1662       val  = pow(arg, arg2);
1663       BOOST_CHECK_EQUAL(val, std::numeric_limits<T>::infinity());
1664       arg = -arg;
1665       val = pow(arg, arg2);
1666       BOOST_CHECK_EQUAL(val, std::numeric_limits<T>::infinity());
1667       arg  = -std::numeric_limits<T>::infinity();
1668       arg2 = -3;
1669       val  = pow(arg, arg2);
1670       BOOST_CHECK_EQUAL(val, 0);
1671       if (signbit(-T(0)))
1672          BOOST_CHECK(signbit(val));
1673       arg2 = -2;
1674       val  = pow(arg, arg2);
1675       BOOST_CHECK_EQUAL(val, 0);
1676       BOOST_CHECK(signbit(val) == 0);
1677       arg2 = -2.5;
1678       val  = pow(arg, arg2);
1679       BOOST_CHECK_EQUAL(val, 0);
1680       BOOST_CHECK(signbit(val) == 0);
1681       arg2 = 3;
1682       val  = pow(arg, arg2);
1683       BOOST_CHECK_EQUAL(val, -std::numeric_limits<T>::infinity());
1684       arg2 = 2;
1685       val  = pow(arg, arg2);
1686       BOOST_CHECK_EQUAL(val, std::numeric_limits<T>::infinity());
1687       arg2 = 2.5;
1688       val  = pow(arg, arg2);
1689       BOOST_CHECK_EQUAL(val, std::numeric_limits<T>::infinity());
1690       arg  = -arg; // +INF
1691       arg2 = -2;
1692       val  = pow(arg, arg2);
1693       BOOST_CHECK_EQUAL(val, 0);
1694       BOOST_CHECK(signbit(val) == 0);
1695       arg2 = -3;
1696       val  = pow(arg, arg2);
1697       BOOST_CHECK_EQUAL(val, 0);
1698       BOOST_CHECK(signbit(val) == 0);
1699       arg2 = -3.5;
1700       val  = pow(arg, arg2);
1701       BOOST_CHECK_EQUAL(val, 0);
1702       BOOST_CHECK(signbit(val) == 0);
1703       arg2 = 2;
1704       val  = pow(arg, arg2);
1705       BOOST_CHECK_EQUAL(val, std::numeric_limits<T>::infinity());
1706       arg2 = 3;
1707       val  = pow(arg, arg2);
1708       BOOST_CHECK_EQUAL(val, std::numeric_limits<T>::infinity());
1709       arg2 = 3.5;
1710       val  = pow(arg, arg2);
1711       BOOST_CHECK_EQUAL(val, std::numeric_limits<T>::infinity());
1712    }
1713    // F.9.4.5:
1714    arg = 0;
1715    val = sqrt(arg);
1716    BOOST_CHECK_EQUAL(val, 0);
1717    BOOST_CHECK(signbit(val) == 0);
1718    arg = -arg;
1719    if (signbit(arg))
1720    {
1721       val = sqrt(arg);
1722       BOOST_CHECK_EQUAL(val, 0);
1723       BOOST_CHECK(signbit(val));
1724    }
1725 #if !(defined(TEST_FLOAT128) && defined(BOOST_GCC_VERSION) && (BOOST_GCC_VERSION < 40800))
1726    //
1727    // This test fails with early implementations of libquadmath - not our issue!
1728    //
1729    if (std::numeric_limits<T>::has_infinity)
1730    {
1731       arg = std::numeric_limits<T>::infinity();
1732       val = sqrt(arg);
1733       BOOST_CHECK_EQUAL(val, arg);
1734       arg = -arg;
1735       check_invalid(sqrt(arg));
1736    }
1737 #endif
1738    if (std::numeric_limits<T>::has_quiet_NaN)
1739    {
1740       arg = std::numeric_limits<T>::quiet_NaN();
1741       check_invalid(sqrt(arg));
1742    }
1743    // F.9.5.1:
1744    arg = 0;
1745    val = erf(arg);
1746    BOOST_CHECK_EQUAL(val, 0);
1747    BOOST_CHECK(signbit(val) == 0);
1748    arg = -arg;
1749    if (signbit(arg))
1750    {
1751       val = erf(arg);
1752       BOOST_CHECK_EQUAL(val, 0);
1753       BOOST_CHECK(signbit(val));
1754    }
1755    if (std::numeric_limits<T>::has_infinity)
1756    {
1757       arg = std::numeric_limits<T>::infinity();
1758       val = erf(arg);
1759       BOOST_CHECK_EQUAL(val, 1);
1760       arg = -arg;
1761       val = erf(arg);
1762       BOOST_CHECK_EQUAL(val, -1);
1763    }
1764    if (std::numeric_limits<T>::has_quiet_NaN)
1765    {
1766       arg = std::numeric_limits<T>::quiet_NaN();
1767       check_invalid(erf(arg));
1768    }
1769    // F.9.5.2:
1770    if (std::numeric_limits<T>::has_infinity)
1771    {
1772       arg = std::numeric_limits<T>::infinity();
1773       val = erfc(arg);
1774       BOOST_CHECK_EQUAL(val, 0);
1775       BOOST_CHECK(signbit(val) == 0);
1776       arg = -arg;
1777       val = erfc(arg);
1778       BOOST_CHECK_EQUAL(val, 2);
1779    }
1780    if (std::numeric_limits<T>::has_quiet_NaN)
1781    {
1782       arg = std::numeric_limits<T>::quiet_NaN();
1783       check_invalid(erfc(arg));
1784    }
1785    // F.9.5.3:
1786    arg = 1;
1787    val = lgamma(arg);
1788    BOOST_CHECK_EQUAL(val, 0);
1789    BOOST_CHECK(signbit(val) == 0);
1790    arg = 2;
1791    val = lgamma(arg);
1792    BOOST_CHECK_EQUAL(val, 0);
1793    BOOST_CHECK(signbit(val) == 0);
1794 #if !defined(BOOST_MPFR_VERSION) || (BOOST_MPFR_VERSION > 30103)
1795    arg = 0;
1796    val = lgamma(arg);
1797    BOOST_CHECK_EQUAL(val, std::numeric_limits<T>::infinity());
1798    check_erange(val);
1799    arg = -1;
1800    val = lgamma(arg);
1801    BOOST_CHECK_EQUAL(val, std::numeric_limits<T>::infinity());
1802    check_erange(val);
1803    arg = -2;
1804    val = lgamma(arg);
1805    BOOST_CHECK_EQUAL(val, std::numeric_limits<T>::infinity());
1806    check_erange(val);
1807    arg = -std::numeric_limits<T>::infinity();
1808    val = lgamma(arg);
1809    BOOST_CHECK_EQUAL(val, std::numeric_limits<T>::infinity());
1810 #endif
1811    arg = std::numeric_limits<T>::infinity();
1812    val = lgamma(arg);
1813    BOOST_CHECK_EQUAL(val, std::numeric_limits<T>::infinity());
1814    if (std::numeric_limits<T>::has_quiet_NaN)
1815    {
1816       arg = std::numeric_limits<T>::quiet_NaN();
1817       check_invalid(lgamma(arg));
1818    }
1819    // F.9.5.4:
1820    if (std::numeric_limits<T>::has_infinity)
1821    {
1822       arg = 0;
1823       val = tgamma(arg);
1824       BOOST_CHECK_EQUAL(val, std::numeric_limits<T>::infinity());
1825       check_erange(val);
1826       arg = -arg;
1827       if (signbit(arg))
1828       {
1829          val = tgamma(arg);
1830          BOOST_CHECK_EQUAL(val, -std::numeric_limits<T>::infinity());
1831          check_erange(val);
1832       }
1833       arg = -1;
1834       check_invalid(tgamma(arg));
1835       arg = -std::numeric_limits<T>::infinity();
1836       check_invalid(tgamma(arg));
1837       arg = std::numeric_limits<T>::infinity();
1838       val = tgamma(arg);
1839       BOOST_CHECK_EQUAL(val, std::numeric_limits<T>::infinity());
1840    }
1841    if (std::numeric_limits<T>::has_quiet_NaN)
1842    {
1843       arg = std::numeric_limits<T>::quiet_NaN();
1844       check_invalid(tgamma(arg));
1845    }
1846    // F.9.6.1:
1847    arg = 0;
1848    val = ceil(arg);
1849    BOOST_CHECK_EQUAL(val, 0);
1850    BOOST_CHECK(signbit(val) == 0);
1851    arg = -arg;
1852    if (signbit(arg))
1853    {
1854       val = ceil(arg);
1855       BOOST_CHECK_EQUAL(val, 0);
1856       BOOST_CHECK(signbit(val));
1857    }
1858    if (std::numeric_limits<T>::has_infinity)
1859    {
1860       arg = std::numeric_limits<T>::infinity();
1861       val = ceil(arg);
1862       BOOST_CHECK_EQUAL(val, std::numeric_limits<T>::infinity());
1863       arg = -arg;
1864       val = ceil(arg);
1865       BOOST_CHECK_EQUAL(val, -std::numeric_limits<T>::infinity());
1866    }
1867    if (std::numeric_limits<T>::has_quiet_NaN)
1868    {
1869       arg = std::numeric_limits<T>::quiet_NaN();
1870       check_invalid(ceil(arg));
1871    }
1872    // F.9.6.2:
1873    arg = 0;
1874    val = floor(arg);
1875    BOOST_CHECK_EQUAL(val, 0);
1876    BOOST_CHECK(signbit(val) == 0);
1877    arg = -arg;
1878    if (signbit(arg))
1879    {
1880       val = floor(arg);
1881       BOOST_CHECK_EQUAL(val, 0);
1882       BOOST_CHECK(signbit(val));
1883    }
1884    if (std::numeric_limits<T>::has_infinity)
1885    {
1886       arg = std::numeric_limits<T>::infinity();
1887       val = floor(arg);
1888       BOOST_CHECK_EQUAL(val, std::numeric_limits<T>::infinity());
1889       arg = -arg;
1890       val = floor(arg);
1891       BOOST_CHECK_EQUAL(val, -std::numeric_limits<T>::infinity());
1892    }
1893    if (std::numeric_limits<T>::has_quiet_NaN)
1894    {
1895       arg = std::numeric_limits<T>::quiet_NaN();
1896       check_invalid(floor(arg));
1897    }
1898    // F.9.6.3:
1899    arg = 0;
1900    val = nearbyint(arg);
1901    BOOST_CHECK_EQUAL(val, 0);
1902    BOOST_CHECK(signbit(val) == 0);
1903    arg = -arg;
1904    if (signbit(arg))
1905    {
1906       val = nearbyint(arg);
1907       BOOST_CHECK_EQUAL(val, 0);
1908       BOOST_CHECK(signbit(val));
1909    }
1910    if (std::numeric_limits<T>::has_infinity)
1911    {
1912       arg = std::numeric_limits<T>::infinity();
1913       val = nearbyint(arg);
1914       BOOST_CHECK_EQUAL(val, std::numeric_limits<T>::infinity());
1915       arg = -arg;
1916       val = nearbyint(arg);
1917       BOOST_CHECK_EQUAL(val, -std::numeric_limits<T>::infinity());
1918    }
1919    if (std::numeric_limits<T>::has_quiet_NaN)
1920    {
1921       arg = std::numeric_limits<T>::quiet_NaN();
1922       check_invalid(nearbyint(arg));
1923    }
1924    // F.9.6.4:
1925    arg = 0;
1926    val = rint(arg);
1927    BOOST_CHECK_EQUAL(val, 0);
1928    BOOST_CHECK(signbit(val) == 0);
1929    arg = -arg;
1930    if (signbit(arg))
1931    {
1932       val = rint(arg);
1933       BOOST_CHECK_EQUAL(val, 0);
1934       BOOST_CHECK(signbit(val));
1935    }
1936    if (std::numeric_limits<T>::has_infinity)
1937    {
1938       arg = std::numeric_limits<T>::infinity();
1939       val = rint(arg);
1940       BOOST_CHECK_EQUAL(val, std::numeric_limits<T>::infinity());
1941       arg = -arg;
1942       val = rint(arg);
1943       BOOST_CHECK_EQUAL(val, -std::numeric_limits<T>::infinity());
1944    }
1945    if (std::numeric_limits<T>::has_quiet_NaN)
1946    {
1947       arg = std::numeric_limits<T>::quiet_NaN();
1948       check_invalid(rint(arg));
1949    }
1950    // F.9.6.6:
1951    arg = 0;
1952    val = round(arg);
1953    BOOST_CHECK_EQUAL(val, 0);
1954    BOOST_CHECK(signbit(val) == 0);
1955    arg = -arg;
1956    if (signbit(arg))
1957    {
1958       val = round(arg);
1959       BOOST_CHECK_EQUAL(val, 0);
1960       BOOST_CHECK(signbit(val));
1961    }
1962    if (std::numeric_limits<T>::has_infinity)
1963    {
1964       arg = std::numeric_limits<T>::infinity();
1965       val = round(arg);
1966       BOOST_CHECK_EQUAL(val, std::numeric_limits<T>::infinity());
1967       arg = -arg;
1968       val = round(arg);
1969       BOOST_CHECK_EQUAL(val, -std::numeric_limits<T>::infinity());
1970    }
1971    if (std::numeric_limits<T>::has_quiet_NaN)
1972    {
1973       arg = std::numeric_limits<T>::quiet_NaN();
1974       check_invalid(round(arg));
1975    }
1976    // F.9.6.8:
1977    arg = 0;
1978    val = trunc(arg);
1979    BOOST_CHECK_EQUAL(val, 0);
1980    BOOST_CHECK(signbit(val) == 0);
1981    arg = -arg;
1982    if (signbit(arg))
1983    {
1984       val = trunc(arg);
1985       BOOST_CHECK_EQUAL(val, 0);
1986       BOOST_CHECK(signbit(val));
1987    }
1988    if (std::numeric_limits<T>::has_infinity)
1989    {
1990       arg = std::numeric_limits<T>::infinity();
1991       val = trunc(arg);
1992       BOOST_CHECK_EQUAL(val, std::numeric_limits<T>::infinity());
1993       arg = -arg;
1994       val = trunc(arg);
1995       BOOST_CHECK_EQUAL(val, -std::numeric_limits<T>::infinity());
1996    }
1997    if (std::numeric_limits<T>::has_quiet_NaN)
1998    {
1999       arg = std::numeric_limits<T>::quiet_NaN();
2000       check_invalid(trunc(arg));
2001    }
2002    // F.9.7.1:
2003    arg  = 0;
2004    arg2 = 2;
2005    val  = fmod(arg, arg2);
2006    BOOST_CHECK_EQUAL(val, 0);
2007    BOOST_CHECK(signbit(val) == 0);
2008    arg = -arg;
2009    if (signbit(arg))
2010    {
2011       val = fmod(arg, arg2);
2012       BOOST_CHECK_EQUAL(val, 0);
2013       BOOST_CHECK(signbit(val));
2014    }
2015    if (std::numeric_limits<T>::has_infinity)
2016    {
2017       arg = std::numeric_limits<T>::infinity();
2018       check_invalid(fmod(arg, arg2));
2019       arg = -arg;
2020       check_invalid(fmod(arg, arg2));
2021       arg  = 2;
2022       arg2 = 0;
2023       check_invalid(fmod(arg, arg2));
2024       check_invalid(fmod(arg, -arg2));
2025    }
2026    if (std::numeric_limits<T>::has_quiet_NaN)
2027    {
2028       arg  = std::numeric_limits<T>::quiet_NaN();
2029       arg2 = 2;
2030       check_invalid(fmod(arg, arg2));
2031       swap(arg, arg2);
2032       check_invalid(fmod(arg, arg2));
2033       check_invalid(fmod(arg2, arg2));
2034    }
2035    //
2036    // Bugs:
2037    //
2038    int sign = 0;
2039    boost::math::lgamma(T(0.000001), &sign);
2040    BOOST_CHECK_EQUAL(sign, 1);
2041    sign = 0;
2042    boost::math::lgamma(T(0.5), &sign);
2043    BOOST_CHECK_EQUAL(sign, 1);
2044    sign = 0;
2045    boost::math::lgamma(T(0.9), &sign);
2046    BOOST_CHECK_EQUAL(sign, 1);
2047    sign = 0;
2048    boost::math::lgamma(T(1.1), &sign);
2049    BOOST_CHECK_EQUAL(sign, 1);
2050    sign = 0;
2051    boost::math::lgamma(T(1.9), &sign);
2052    BOOST_CHECK_EQUAL(sign, 1);
2053    sign = 0;
2054    boost::math::lgamma(T(2.1), &sign);
2055    BOOST_CHECK_EQUAL(sign, 1);
2056    sign = 0;
2057    boost::math::lgamma(T(20), &sign);
2058    BOOST_CHECK_EQUAL(sign, 1);
2059    sign = 0;
2060    boost::math::lgamma(T(-0.0000000000001), &sign);
2061    BOOST_CHECK_EQUAL(sign, -1);
2062    sign = 0;
2063    boost::math::lgamma(T(-0.5), &sign);
2064    BOOST_CHECK_EQUAL(sign, -1);
2065    sign = 0;
2066    boost::math::lgamma(T(-1.5), &sign);
2067    BOOST_CHECK_EQUAL(sign, 1);
2068    sign = 0;
2069    boost::math::lgamma(T(-2.5), &sign);
2070    BOOST_CHECK_EQUAL(sign, -1);
2071    sign = 0;
2072    boost::math::lgamma(T(-3.5), &sign);
2073    BOOST_CHECK_EQUAL(sign, 1);
2074 }
2075 
2076 template <class T>
test_c99_appendix_F_tgammaq_addon_for_float128()2077 void test_c99_appendix_F_tgammaq_addon_for_float128()
2078 {
2079 #if defined(TEST_FLOAT128)
2080   // Special tests of tgamma for positive and negative
2081   // real values in the neighborhood of the origin.
2082 
2083    // At Wolfram Alpha: N[Gamma[1/3], 201]
2084    const T tgamma_third
2085    (
2086      "2."
2087      "67893853470774763365569294097467764412868937795730"
2088      "11009504283275904176101677438195409828890411887894"
2089      "19159049200072263335719084569504472259977713367708"
2090      "46976816728982305000321834255032224715694181755545"
2091    );
2092 
2093    // Create a string such as "1e-84", where 84 exemplifies (digits10*5 + 5)/6
2094    // and the exponent varies depending on the value of digits10 for the type.
2095    // Consider, for instance digits10=100. In this case n_exp=(100*5 + 5)/6 = 84.
2096 
2097    const int n_exp =(std::max)(((std::numeric_limits<T>::digits10 * 5) + 5) / 6, 1);
2098 
2099    const T tgamma_tol("1e-" + boost::lexical_cast<std::string>(n_exp));
2100 
2101    // Check tgamma(1/3 - n) for n in 0...24.
2102    for(int n = 0; n < 25; ++n)
2103    {
2104       const T tgamma_val = tgamma(T((T(1) / T(3)) - T(n)));
2105 
2106       T tgamma_control(tgamma_third);
2107 
2108       for(unsigned int k = 0U; k < static_cast<unsigned int>(n); ++k)
2109       {
2110          tgamma_control *= -3;
2111          tgamma_control /= ((3U * (k + 1U)) - 1U);
2112       }
2113 
2114       BOOST_CHECK_CLOSE_FRACTION(tgamma_val, tgamma_control, tgamma_tol);
2115    }
2116 
2117    // Check tgamma(1/3 + n) for n in 0...24.
2118    for(unsigned int n = 0U; n < 25U; ++n)
2119    {
2120       const T tgamma_val = tgamma(T((T(1) / T(3)) + T(n)));
2121 
2122       T tgamma_control(tgamma_third);
2123 
2124       for(unsigned int k = 0U; k < n; ++k)
2125       {
2126          tgamma_control /= 3;
2127          tgamma_control *= ((3U * (k + 1U)) - 2U);
2128       }
2129 
2130       BOOST_CHECK_CLOSE_FRACTION(tgamma_val, tgamma_control, tgamma_tol);
2131    }
2132 #endif
2133 }
2134 
main()2135 int main()
2136 {
2137    test_poison<float>();
2138    test_poison<double>();
2139 #ifdef TEST_MPF_50
2140    test<boost::multiprecision::mpf_float_50>();
2141    test<boost::multiprecision::mpf_float_100>();
2142 #endif
2143 #ifdef TEST_MPFR_50
2144    std::cout << "Testing MPFR: " << MPFR_VERSION_STRING << std::endl;
2145    test<boost::multiprecision::mpfr_float_50>();
2146    test<boost::multiprecision::mpfr_float_100>();
2147    test_c99_appendix_F<boost::multiprecision::mpfr_float_50>();
2148 #endif
2149 #ifdef TEST_MPFI_50
2150    test<boost::multiprecision::mpfi_float_50>();
2151    test<boost::multiprecision::mpfi_float_100>();
2152 #endif
2153 #ifdef TEST_CPP_DEC_FLOAT
2154    test<boost::multiprecision::cpp_dec_float_50>();
2155 #if !(defined(__GNUC__) && defined(_WIN32)) // Object file too large otherwise
2156    test<boost::multiprecision::cpp_dec_float_100>();
2157 #endif
2158    test_c99_appendix_F<boost::multiprecision::cpp_dec_float_50>();
2159 #endif
2160 #ifdef TEST_CPP_DEC_FLOAT_2
2161    // Some "peculiar" digit counts which stress our code:
2162    test<boost::multiprecision::number<boost::multiprecision::cpp_dec_float<65> > >();
2163 #if !(defined(__GNUC__) && defined(_WIN32)) // Object file too large otherwise
2164    test<boost::multiprecision::number<boost::multiprecision::cpp_dec_float<64> > >();
2165 #endif
2166 #endif
2167 #ifdef TEST_CPP_DEC_FLOAT_3
2168    test<boost::multiprecision::number<boost::multiprecision::cpp_dec_float<63> > >();
2169 #if !(defined(__GNUC__) && defined(_WIN32)) // Object file too large otherwise
2170    test<boost::multiprecision::number<boost::multiprecision::cpp_dec_float<62> > >();
2171 #endif
2172 #endif
2173 #ifdef TEST_CPP_DEC_FLOAT_4
2174    test<boost::multiprecision::number<boost::multiprecision::cpp_dec_float<61, long long> > >();
2175 #if !(defined(__GNUC__) && defined(_WIN32)) // Object file too large otherwise
2176    test<boost::multiprecision::number<boost::multiprecision::cpp_dec_float<60, long long> > >();
2177 #endif
2178 #endif
2179 #ifdef TEST_CPP_DEC_FLOAT_5
2180    test<boost::multiprecision::number<boost::multiprecision::cpp_dec_float<59, long long, std::allocator<char> > > >();
2181 #endif
2182 #ifdef TEST_CPP_DEC_FLOAT_6
2183    test<boost::multiprecision::number<boost::multiprecision::cpp_dec_float<58, long long, std::allocator<char> > > >();
2184 #endif
2185 #ifdef TEST_CPP_BIN_FLOAT
2186    test<boost::multiprecision::cpp_bin_float_50>();
2187    test<boost::multiprecision::number<boost::multiprecision::cpp_bin_float<100>, boost::multiprecision::et_on> >();
2188 #endif
2189 #ifdef TEST_CPP_BIN_FLOAT_2
2190    test<boost::multiprecision::number<boost::multiprecision::cpp_bin_float<35, boost::multiprecision::digit_base_10, std::allocator<char>, boost::long_long_type> > >();
2191 #endif
2192 #ifdef TEST_CPP_BIN_FLOAT_3
2193    test_c99_appendix_F<boost::multiprecision::cpp_bin_float_50>();
2194    test_c99_appendix_F<boost::multiprecision::number<boost::multiprecision::cpp_bin_float<100>, boost::multiprecision::et_on> >();
2195 #endif
2196 #ifdef TEST_FLOAT128
2197    test<boost::multiprecision::float128>();
2198    test_c99_appendix_F<boost::multiprecision::float128>();
2199    test_c99_appendix_F_tgammaq_addon_for_float128<boost::multiprecision::float128>();
2200 #endif
2201 
2202    return boost::report_errors();
2203 }
2204