|
|
5dffee |
diff -up boost_1_54_0/boost/multiprecision/detail/functions/constants.hpp~ boost_1_54_0/boost/multiprecision/detail/functions/constants.hpp
|
|
|
5dffee |
--- boost_1_54_0/boost/multiprecision/detail/functions/constants.hpp~ 2012-09-20 09:04:02.000000000 -0700
|
|
|
5dffee |
+++ boost_1_54_0/boost/multiprecision/detail/functions/constants.hpp 2013-07-22 03:31:01.145084522 -0700
|
|
|
5dffee |
@@ -81,7 +81,6 @@ template <class T>
|
|
|
5dffee |
void calc_e(T& result, unsigned digits)
|
|
|
5dffee |
{
|
|
|
5dffee |
typedef typename mpl::front<typename T::unsigned_types>::type ui_type;
|
|
|
5dffee |
- typedef typename mpl::front<typename T::float_types>::type real_type;
|
|
|
5dffee |
//
|
|
|
5dffee |
// 1100 digits in string form:
|
|
|
5dffee |
//
|
|
|
5dffee |
diff -up boost_1_54_0/boost/multiprecision/detail/functions/pow.hpp~ boost_1_54_0/boost/multiprecision/detail/functions/pow.hpp
|
|
|
5dffee |
--- boost_1_54_0/boost/multiprecision/detail/functions/pow.hpp~ 2013-03-31 09:34:50.000000000 -0700
|
|
|
5dffee |
+++ boost_1_54_0/boost/multiprecision/detail/functions/pow.hpp 2013-07-22 03:43:12.495489757 -0700
|
|
|
5dffee |
@@ -142,10 +142,6 @@ void hyp1F0(T& H1F0, const T& a, const T
|
|
|
5dffee |
// There are no checks on input range or parameter boundaries.
|
|
|
5dffee |
|
|
|
5dffee |
typedef typename boost::multiprecision::detail::canonical<int, T>::type si_type;
|
|
|
5dffee |
- typedef typename boost::multiprecision::detail::canonical<unsigned, T>::type ui_type;
|
|
|
5dffee |
- typedef typename T::exponent_type exp_type;
|
|
|
5dffee |
- typedef typename boost::multiprecision::detail::canonical<exp_type, T>::type canonical_exp_type;
|
|
|
5dffee |
- typedef typename mpl::front<typename T::float_types>::type fp_type;
|
|
|
5dffee |
|
|
|
5dffee |
BOOST_ASSERT(&H1F0 != &x);
|
|
|
5dffee |
BOOST_ASSERT(&H1F0 != &a);
|
|
|
5dffee |
@@ -200,7 +196,6 @@ void eval_exp(T& result, const T& x)
|
|
|
5dffee |
typedef typename boost::multiprecision::detail::canonical<int, T>::type si_type;
|
|
|
5dffee |
typedef typename T::exponent_type exp_type;
|
|
|
5dffee |
typedef typename boost::multiprecision::detail::canonical<exp_type, T>::type canonical_exp_type;
|
|
|
5dffee |
- typedef typename boost::multiprecision::detail::canonical<float, T>::type float_type;
|
|
|
5dffee |
|
|
|
5dffee |
// Handle special arguments.
|
|
|
5dffee |
int type = eval_fpclassify(x);
|
|
|
5dffee |
@@ -326,7 +321,6 @@ void eval_log(T& result, const T& arg)
|
|
|
5dffee |
// then let y = x - 1 and compute:
|
|
|
5dffee |
// log(x) = log(2) * n + log1p(1 + y)
|
|
|
5dffee |
//
|
|
|
5dffee |
- typedef typename boost::multiprecision::detail::canonical<int, T>::type si_type;
|
|
|
5dffee |
typedef typename boost::multiprecision::detail::canonical<unsigned, T>::type ui_type;
|
|
|
5dffee |
typedef typename T::exponent_type exp_type;
|
|
|
5dffee |
typedef typename boost::multiprecision::detail::canonical<exp_type, T>::type canonical_exp_type;
|
|
|
5dffee |
@@ -409,9 +403,6 @@ inline void eval_pow(T& result, const T&
|
|
|
5dffee |
{
|
|
|
5dffee |
BOOST_STATIC_ASSERT_MSG(number_category<T>::value == number_kind_floating_point, "The pow function is only valid for floating point types.");
|
|
|
5dffee |
typedef typename boost::multiprecision::detail::canonical<int, T>::type si_type;
|
|
|
5dffee |
- typedef typename boost::multiprecision::detail::canonical<unsigned, T>::type ui_type;
|
|
|
5dffee |
- typedef typename T::exponent_type exp_type;
|
|
|
5dffee |
- typedef typename boost::multiprecision::detail::canonical<exp_type, T>::type canonical_exp_type;
|
|
|
5dffee |
typedef typename mpl::front<typename T::float_types>::type fp_type;
|
|
|
5dffee |
|
|
|
5dffee |
if((&result == &x) || (&result == &a))
|
|
|
5dffee |
@@ -595,10 +586,7 @@ namespace detail{
|
|
|
5dffee |
template <class T>
|
|
|
5dffee |
void sinhcosh(const T& x, T* p_sinh, T* p_cosh)
|
|
|
5dffee |
{
|
|
|
5dffee |
- typedef typename boost::multiprecision::detail::canonical<int, T>::type si_type;
|
|
|
5dffee |
typedef typename boost::multiprecision::detail::canonical<unsigned, T>::type ui_type;
|
|
|
5dffee |
- typedef typename T::exponent_type exp_type;
|
|
|
5dffee |
- typedef typename boost::multiprecision::detail::canonical<exp_type, T>::type canonical_exp_type;
|
|
|
5dffee |
typedef typename mpl::front<typename T::float_types>::type fp_type;
|
|
|
5dffee |
|
|
|
5dffee |
switch(eval_fpclassify(x))
|
|
|
5dffee |
diff -up boost_1_54_0/boost/multiprecision/detail/functions/trig.hpp~ boost_1_54_0/boost/multiprecision/detail/functions/trig.hpp
|
|
|
5dffee |
--- boost_1_54_0/boost/multiprecision/detail/functions/trig.hpp~ 2013-03-31 09:34:50.000000000 -0700
|
|
|
5dffee |
+++ boost_1_54_0/boost/multiprecision/detail/functions/trig.hpp 2013-07-22 03:44:30.512963273 -0700
|
|
|
5dffee |
@@ -17,9 +17,6 @@ void hyp0F1(T& result, const T& b, const
|
|
|
5dffee |
{
|
|
|
5dffee |
typedef typename boost::multiprecision::detail::canonical<boost::int32_t, T>::type si_type;
|
|
|
5dffee |
typedef typename boost::multiprecision::detail::canonical<boost::uint32_t, T>::type ui_type;
|
|
|
5dffee |
- typedef typename T::exponent_type exp_type;
|
|
|
5dffee |
- typedef typename boost::multiprecision::detail::canonical<exp_type, T>::type canonical_exp_type;
|
|
|
5dffee |
- typedef typename mpl::front<typename T::float_types>::type fp_type;
|
|
|
5dffee |
|
|
|
5dffee |
// Compute the series representation of Hypergeometric0F1 taken from
|
|
|
5dffee |
// http://functions.wolfram.com/HypergeometricFunctions/Hypergeometric0F1/06/01/01/
|
|
|
5dffee |
@@ -82,8 +79,6 @@ void eval_sin(T& result, const T& x)
|
|
|
5dffee |
|
|
|
5dffee |
typedef typename boost::multiprecision::detail::canonical<boost::int32_t, T>::type si_type;
|
|
|
5dffee |
typedef typename boost::multiprecision::detail::canonical<boost::uint32_t, T>::type ui_type;
|
|
|
5dffee |
- typedef typename T::exponent_type exp_type;
|
|
|
5dffee |
- typedef typename boost::multiprecision::detail::canonical<exp_type, T>::type canonical_exp_type;
|
|
|
5dffee |
typedef typename mpl::front<typename T::float_types>::type fp_type;
|
|
|
5dffee |
|
|
|
5dffee |
switch(eval_fpclassify(x))
|
|
|
5dffee |
@@ -228,8 +223,6 @@ void eval_cos(T& result, const T& x)
|
|
|
5dffee |
|
|
|
5dffee |
typedef typename boost::multiprecision::detail::canonical<boost::int32_t, T>::type si_type;
|
|
|
5dffee |
typedef typename boost::multiprecision::detail::canonical<boost::uint32_t, T>::type ui_type;
|
|
|
5dffee |
- typedef typename T::exponent_type exp_type;
|
|
|
5dffee |
- typedef typename boost::multiprecision::detail::canonical<exp_type, T>::type canonical_exp_type;
|
|
|
5dffee |
typedef typename mpl::front<typename T::float_types>::type fp_type;
|
|
|
5dffee |
|
|
|
5dffee |
switch(eval_fpclassify(x))
|
|
|
5dffee |
@@ -381,11 +374,7 @@ void hyp2F1(T& result, const T& a, const
|
|
|
5dffee |
// Abramowitz and Stegun 15.1.1.
|
|
|
5dffee |
// There are no checks on input range or parameter boundaries.
|
|
|
5dffee |
|
|
|
5dffee |
- typedef typename boost::multiprecision::detail::canonical<boost::int32_t, T>::type si_type;
|
|
|
5dffee |
typedef typename boost::multiprecision::detail::canonical<boost::uint32_t, T>::type ui_type;
|
|
|
5dffee |
- typedef typename T::exponent_type exp_type;
|
|
|
5dffee |
- typedef typename boost::multiprecision::detail::canonical<exp_type, T>::type canonical_exp_type;
|
|
|
5dffee |
- typedef typename mpl::front<typename T::float_types>::type fp_type;
|
|
|
5dffee |
|
|
|
5dffee |
T x_pow_n_div_n_fact(x);
|
|
|
5dffee |
T pochham_a (a);
|
|
|
5dffee |
@@ -443,10 +432,7 @@ template <class T>
|
|
|
5dffee |
void eval_asin(T& result, const T& x)
|
|
|
5dffee |
{
|
|
|
5dffee |
BOOST_STATIC_ASSERT_MSG(number_category<T>::value == number_kind_floating_point, "The asin function is only valid for floating point types.");
|
|
|
5dffee |
- typedef typename boost::multiprecision::detail::canonical<boost::int32_t, T>::type si_type;
|
|
|
5dffee |
typedef typename boost::multiprecision::detail::canonical<boost::uint32_t, T>::type ui_type;
|
|
|
5dffee |
- typedef typename T::exponent_type exp_type;
|
|
|
5dffee |
- typedef typename boost::multiprecision::detail::canonical<exp_type, T>::type canonical_exp_type;
|
|
|
5dffee |
typedef typename mpl::front<typename T::float_types>::type fp_type;
|
|
|
5dffee |
|
|
|
5dffee |
if(&result == &x)
|
|
|
5dffee |
@@ -597,8 +583,6 @@ void eval_atan(T& result, const T& x)
|
|
|
5dffee |
BOOST_STATIC_ASSERT_MSG(number_category<T>::value == number_kind_floating_point, "The atan function is only valid for floating point types.");
|
|
|
5dffee |
typedef typename boost::multiprecision::detail::canonical<boost::int32_t, T>::type si_type;
|
|
|
5dffee |
typedef typename boost::multiprecision::detail::canonical<boost::uint32_t, T>::type ui_type;
|
|
|
5dffee |
- typedef typename T::exponent_type exp_type;
|
|
|
5dffee |
- typedef typename boost::multiprecision::detail::canonical<exp_type, T>::type canonical_exp_type;
|
|
|
5dffee |
typedef typename mpl::front<typename T::float_types>::type fp_type;
|
|
|
5dffee |
|
|
|
5dffee |
switch(eval_fpclassify(x))
|
|
|
5dffee |
@@ -699,11 +683,7 @@ void eval_atan2(T& result, const T& y, c
|
|
|
5dffee |
return;
|
|
|
5dffee |
}
|
|
|
5dffee |
|
|
|
5dffee |
- typedef typename boost::multiprecision::detail::canonical<boost::int32_t, T>::type si_type;
|
|
|
5dffee |
typedef typename boost::multiprecision::detail::canonical<boost::uint32_t, T>::type ui_type;
|
|
|
5dffee |
- typedef typename T::exponent_type exp_type;
|
|
|
5dffee |
- typedef typename boost::multiprecision::detail::canonical<exp_type, T>::type canonical_exp_type;
|
|
|
5dffee |
- typedef typename mpl::front<typename T::float_types>::type fp_type;
|
|
|
5dffee |
|
|
|
5dffee |
switch(eval_fpclassify(y))
|
|
|
5dffee |
{
|
|
|
5dffee |
diff -up boost_1_54_0/boost/multiprecision/detail/generic_interconvert.hpp~ boost_1_54_0/boost/multiprecision/detail/generic_interconvert.hpp
|
|
|
5dffee |
--- boost_1_54_0/boost/multiprecision/detail/generic_interconvert.hpp~ 2012-12-20 09:42:14.000000000 -0800
|
|
|
5dffee |
+++ boost_1_54_0/boost/multiprecision/detail/generic_interconvert.hpp 2013-07-22 03:38:51.614906286 -0700
|
|
|
5dffee |
@@ -191,7 +191,6 @@ void generic_interconvert(To& to, const
|
|
|
5dffee |
template <class To, class From>
|
|
|
5dffee |
void generic_interconvert(To& to, const From& from, const mpl::int_<number_kind_rational>& /*to_type*/, const mpl::int_<number_kind_rational>& /*from_type*/)
|
|
|
5dffee |
{
|
|
|
5dffee |
- typedef typename component_type<number<From> >::type from_component_type;
|
|
|
5dffee |
typedef typename component_type<number<To> >::type to_component_type;
|
|
|
5dffee |
|
|
|
5dffee |
number<From> t(from);
|