首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >固定精度的重载boost::multiprecision::pow

固定精度的重载boost::multiprecision::pow
EN

Stack Overflow用户
提问于 2020-09-15 15:10:39
回答 2查看 130关注 0票数 0

下面的代码

代码语言:javascript
复制
#include <boost/multiprecision/cpp_dec_float.hpp>
#include <boost/multiprecision/cpp_int.hpp>

typedef boost::multiprecision::number<boost::multiprecision::cpp_dec_float<50>, boost::multiprecision::et_off> float_50; 

int main()
{
    float_50 a = boost::multiprecision::pow((float_50)5, (float_50)10); // works
    double b = boost::multiprecision::pow((double)5, (double)10);       // doesn't work

    //double b = boost::multiprecision::pow<double>((double)5, (double)10); // Why can't be overloaded?
    return 0;
}

无法编译,因为boost::multiprecision::pow不能识别固定精度类型。通常的解决方案是什么?我宁愿有一个单一的pow函数,它同时接受多精度和固定精度类型。例如,我很奇怪boost常量有这样的模板定义

代码语言:javascript
复制
boost::math::constants::pi<double>()
boost::math::constants::pi<float_50>()

工作得很好。boost::multiprecision::pow不也应该被重载吗?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2020-09-15 16:27:43

solution将去掉命名空间。

代码语言:javascript
复制
#include <boost/multiprecision/cpp_dec_float.hpp>
#include <boost/multiprecision/cpp_int.hpp>

typedef boost::multiprecision::number<boost::multiprecision::cpp_dec_float<50>, boost::multiprecision::et_off> float_50; 

int main()
{
    float_50 a = pow((float_50)5, (float_50)10); 
    double b = pow(5., 10.);      
    return 0;
}
票数 0
EN

Stack Overflow用户

发布于 2020-09-15 15:28:27

单个函数无法处理不同类型的参数。对于每个支持的参数集,您都需要一个单独的函数。该函数可能是从模板自动生成的-但pow似乎不是模板实现的候选。

票数 -2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/63896796

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档