Files
multiprecision/test/mp_number_concept_check.cpp
2012-06-27 18:25:10 +00:00

238 lines
6.8 KiB
C++

// Copyright John Maddock 2011.
// Use, modification and distribution are subject to the
// Boost Software License, Version 1.0. (See accompanying file
// LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
//
// This tests two things: that cpp_dec_float_50 meets our
// conceptual requirements, and that we can instantiate
// all our distributions and special functions on this type.
//
#define BOOST_MATH_ASSERT_UNDEFINED_POLICY false
#define BOOST_MATH_INSTANTIATE_MINIMUM
#ifdef _MSC_VER
# define _SCL_SECURE_NO_WARNINGS
# pragma warning(disable:4800)
# pragma warning(disable:4512)
# pragma warning(disable:4127)
# pragma warning(disable:4512)
# pragma warning(disable:4503) // decorated name length exceeded, name was truncated
#endif
#if !defined(TEST_MPF_50) && !defined(TEST_BACKEND) && !defined(TEST_MPZ) \
&& !defined(TEST_CPP_DEC_FLOAT) && !defined(TEST_MPFR_50)\
&& !defined(TEST_MPFR_6) && !defined(TEST_MPFR_15) && !defined(TEST_MPFR_17) && !defined(TEST_MPFR_30) && !defined(TEST_CPP_DEC_FLOAT_NO_ET)
# define TEST_MPF_50
# define TEST_BACKEND
# define TEST_MPZ
# define TEST_MPFR_50
# define TEST_MPFR_6
# define TEST_MPFR_15
# define TEST_MPFR_17
# define TEST_MPFR_30
# define TEST_CPP_DEC_FLOAT
# define TEST_CPP_DEC_FLOAT_NO_ET
#ifdef _MSC_VER
#pragma message("CAUTION!!: No backend type specified so testing everything.... this will take some time!!")
#endif
#ifdef __GNUC__
#pragma warning "CAUTION!!: No backend type specified so testing everything.... this will take some time!!"
#endif
#endif
#if defined(TEST_MPF_50) || defined(TEST_MPZ)
#include <boost/multiprecision/gmp.hpp>
#endif
#ifdef TEST_BACKEND
#include <boost/multiprecision/concepts/mp_number_archetypes.hpp>
#endif
#if defined(TEST_CPP_DEC_FLOAT) || defined(TEST_CPP_DEC_FLOAT_NO_ET)
#include <boost/multiprecision/cpp_dec_float.hpp>
#endif
#if defined(TEST_MPFR_50) || defined(TEST_MPFR_6) || defined(TEST_MPFR_15) || defined(TEST_MPFR_17) || defined(TEST_MPFR_30)
#include <boost/multiprecision/mpfr.hpp>
#endif
#include <boost/math/concepts/real_type_concept.hpp>
#include "libs/math/test/compile_test/instantiate.hpp"
template <class T>
void test_extra(T)
{
T t = 1;
t = abs(t);
t = abs(t*t);
t = fabs(t);
t = fabs(t*t);
t = sqrt(t);
t = sqrt(t*t);
t = floor(t);
t = floor(t*t);
t = ceil(t);
t = ceil(t*t);
t = trunc(t);
t = trunc(t*t);
t = round(t);
t = round(t*t);
t = exp(t);
t = exp(t*t);
t = log(t);
t = log(t*t);
t = log10(t);
t = log10(t*t);
t = cos(t);
t = cos(t*t);
t = sin(t);
t = sin(t*t);
t = tan(t);
t = tan(t*t);
t = asin(t);
t = asin(t*t);
t = atan(t);
t = atan(t*t);
t = acos(t);
t = acos(t*t);
t = cosh(t);
t = cosh(t*t);
t = sinh(t);
t = sinh(t*t);
t = tanh(t);
t = tanh(t*t);
double dval = 2;
t = pow(t, t);
t = pow(t, t*t);
t = pow(t, dval);
t = pow(t*t, t);
t = pow(t*t, t*t);
t = pow(t*t, dval);
t = pow(dval, t);
t = pow(dval, t*t);
t = atan2(t, t);
t = atan2(t, t*t);
t = atan2(t, dval);
t = atan2(t*t, t);
t = atan2(t*t, t*t);
t = atan2(t*t, dval);
t = atan2(dval, t);
t = atan2(dval, t*t);
t = fmod(t, t);
t = fmod(t, t*t);
t = fmod(t, dval);
t = fmod(t*t, t);
t = fmod(t*t, t*t);
t = fmod(t*t, dval);
t = fmod(dval, t);
t = fmod(dval, t*t);
typedef typename T::backend_type backend_type;
typedef typename backend_type::exponent_type exp_type;
exp_type e = 0;
int i = 0;
t = ldexp(t, i);
t = ldexp(t*t, i);
t = ldexp(t, e);
t = ldexp(t*t, e);
t = frexp(t, &i);
t = frexp(t*t, &i);
t = frexp(t, &e);
t = frexp(t*t, &e);
}
void foo()
{
#ifdef TEST_BACKEND
instantiate(boost::multiprecision::concepts::mp_number_float_architype());
test_extra(boost::multiprecision::concepts::mp_number_float_architype());
#endif
#ifdef TEST_MPF_50
instantiate(boost::multiprecision::mpf_float_50());
test_extra(boost::multiprecision::mpf_float_50());
#endif
#ifdef TEST_MPFR_50
instantiate(boost::multiprecision::mpfr_float_50());
test_extra(boost::multiprecision::mpfr_float_50());
#endif
#ifdef TEST_MPFR_6
instantiate(boost::multiprecision::mp_number<boost::multiprecision::mpfr_float_backend<6> >());
test_extra(boost::multiprecision::mp_number<boost::multiprecision::mpfr_float_backend<6> >());
#endif
#ifdef TEST_MPFR_15
instantiate(boost::multiprecision::mp_number<boost::multiprecision::mpfr_float_backend<15> >());
test_extra(boost::multiprecision::mp_number<boost::multiprecision::mpfr_float_backend<15> >());
#endif
#ifdef TEST_MPFR_17
instantiate(boost::multiprecision::mp_number<boost::multiprecision::mpfr_float_backend<17> >());
test_extra(boost::multiprecision::mp_number<boost::multiprecision::mpfr_float_backend<17> >());
#endif
#ifdef TEST_MPFR_30
instantiate(boost::multiprecision::mp_number<boost::multiprecision::mpfr_float_backend<30> >());
test_extra(boost::multiprecision::mp_number<boost::multiprecision::mpfr_float_backend<30> >());
#endif
#ifdef TEST_CPP_DEC_FLOAT
instantiate(boost::multiprecision::cpp_dec_float_50());
test_extra(boost::multiprecision::cpp_dec_float_50());
#endif
#ifdef TEST_CPP_DEC_FLOAT_NO_ET
instantiate(boost::multiprecision::mp_number<boost::multiprecision::cpp_dec_float<100>, false>());
test_extra(boost::multiprecision::mp_number<boost::multiprecision::cpp_dec_float<100>, false>());
#endif
}
int main()
{
#ifdef TEST_BACKEND
BOOST_CONCEPT_ASSERT((boost::math::concepts::RealTypeConcept<boost::multiprecision::concepts::mp_number_float_architype>));
#endif
#ifdef TEST_MPF_50
BOOST_CONCEPT_ASSERT((boost::math::concepts::RealTypeConcept<boost::multiprecision::mpf_float_50>));
#endif
#ifdef TEST_MPFR_50
BOOST_CONCEPT_ASSERT((boost::math::concepts::RealTypeConcept<boost::multiprecision::mpfr_float_50>));
#endif
#ifdef TEST_MPFR_6
BOOST_CONCEPT_ASSERT((boost::math::concepts::RealTypeConcept<boost::multiprecision::mp_number<boost::multiprecision::mpfr_float_backend<6> > >));
#endif
#ifdef TEST_MPFR_15
BOOST_CONCEPT_ASSERT((boost::math::concepts::RealTypeConcept<boost::multiprecision::mp_number<boost::multiprecision::mpfr_float_backend<15> > >));
#endif
#ifdef TEST_MPFR_17
BOOST_CONCEPT_ASSERT((boost::math::concepts::RealTypeConcept<boost::multiprecision::mp_number<boost::multiprecision::mpfr_float_backend<17> > >));
#endif
#ifdef TEST_MPFR_30
BOOST_CONCEPT_ASSERT((boost::math::concepts::RealTypeConcept<boost::multiprecision::mp_number<boost::multiprecision::mpfr_float_backend<30> > >));
#endif
#ifdef TEST_MPFR_50
BOOST_CONCEPT_ASSERT((boost::math::concepts::RealTypeConcept<boost::multiprecision::mpfr_float_50>));
#endif
#ifdef TEST_CPP_DEC_FLOAT
BOOST_CONCEPT_ASSERT((boost::math::concepts::RealTypeConcept<boost::multiprecision::cpp_dec_float_50>));
#endif
}