I need a BSD-like licensed C(++) multiprecision library with complex numbers support so I tried boost.
The following code fails:
#include <boost/multiprecision/cpp_dec_float.hpp>
#include <complex>
using namespace boost::multiprecision;
std::complex<cpp_dec_float_50>(1.0, 2.0) / std::complex<cpp_dec_float_50>(1.0, 2.0)
in Visual Studio 2012 with an error C2440 because the implementation of complex tries to cast to double in internal functions like _Isinf or _Isnan.
Is this an error on my part? How can I fix this? Are there better libraries?