Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

C++: convert "boost::multiprecision::float128" to "double"

I'm using the boost multiprecision library, and more precisely the boost::multiprecision::float128 type. Using ICPC for compiling, I get some errors when trying to to do something like:

double a = functionA();

where functionA() return a boost::multiprecision::float128 variable.

error: no suitable conversion function from "boost::multiprecision::float128" to "double" exists|

How can I solve this?

like image 896
user1403546 Avatar asked Jan 30 '15 17:01

user1403546


1 Answers

From the Boost documentation:

A number can be converted to any built in type, via the convert_to member function:

mpz_int z(2);
double i = z.convert_to<double>(); // sets i to 2

http://www.boost.org/doc/libs/1_57_0/libs/multiprecision/doc/html/boost_multiprecision/tut/conversions.html

like image 109
Richard Critten Avatar answered Oct 11 '22 19:10

Richard Critten