Создание математических констант переменной точности с использованием Boost mpfr_float, например pi или e

Я использую Boost.Multiprecision для оберток вокруг бэкэнда mpfr, и у меня возникли некоторые проблемы с созданием pi (и e или любой другой математической константы) с желаемой точностью. Я чувствую, что то, что я хочу сделать, должно быть возможным из-за использования Boost.Math для констант на странице руководства для Boost.Multiprecision. В учебном пособии они используют числа с фиксированной точностью типов, таких как cpp_dec_float_50 - Я хочу сделать это с variable_precision mpfr_float, Проверьте следующий код:

#include <boost/multiprecision/mpfr.hpp>
#include <boost/math/constants/constants.hpp>
#include <iostream>

...
int main() {
    boost::multiprecision::mpfr_float::default_precision(1000);
    boost::multiprecision::mpfr_float pi = boost::math::constants::pi<boost::multiprecision::mpfr_float>();
    std::cout << std::fixed;
    std::cout.precision(1000);
    std::cout << pi.precision() << " " << pi << std::endl;
}

Результатом является число, pi, который имеет точность 1000, но имеет только ~165 цифр числа Пи, о чем свидетельствует результат выходных операторов, которые подтверждают, что мой pi имеет точность 1000 и печатает около 165 правильных цифр и ~835 нулей. это явно неправильно.

Можно ли сделать boost::multiprecision::mpfr_float с высокой точностью, заполненный константами boost::math::constants?

Обратите внимание, что мне нужно использовать тип переменной точности, и что другие типы с высокой, но фиксированной точностью не подходят. Я должен быть в состоянии изменить точность на лету во время выполнения.

1 ответ

Решение

Константы, встроенные в заголовки Boost, имеют ограниченную точность, и вы достигли этого предела. Если вам нужна более точная версия pi (например), вам нужно будет принести ее самостоятельно.

Например, определение boost::math::constants::pi в заголовках есть:

  BOOST_DEFINE_MATH_CONSTANT(pi, 3.141592653589793238462643383279502884e+00, "3.14159265358979323846264338327950288419716939937510582097494459230781640628620899862803482534211706798214808651e+00")

- https://github.com/boostorg/math/blob/master/include/boost/math/constants/constants.hpp

(Между прочим, это определение дает только 110 цифр после запятой. Любые цифры, которые вы выходите за пределы, могут быть неверными!)

Другие вопросы по тегам