zoukankan      html  css  js  c++  java
  • boost之multiprecision

    multiprecision

    boost中提供的高精度库,支持高精度整型,浮点型等。并且提供统一的接口模板,只需要指定对应的后端类型即可实现对应类型的高精度计算:

    boost::multiprecision::number<XX_backend>
    

    cpp_int_backend

    提供高精度整型后端类型,需引入头文件#include <boost/multiprecision/cpp_int.hpp>

    template <unsigned MinBits = 0,
              unsigned MaxBits = 0,
              cpp_integer_type SignType = signed_magnitude,
              cpp_int_check_type Checked = unchecked,
              class Allocator = std::allocator<limb_type> >
    class cpp_int_backend;
    
    • MinBits:底层整型占用的最少位宽
    • MaxBits:底层整型占用的最大位宽
    • SignType:有符号整型还是无符号整型(任意精度的整型只能为signed!)
    • Checked:当发生数值溢出,从字符串转换失败,对负数进行位运算是否抛出异常
    • Allocator:内存分配器,当MinBits==MaxBits时,定义为void,表示不需要动态内存分配

    cpp_int中无符号型用二进制补码表示,有符号型用原码表示,并且额外用一位来表示符号;不允许任意精度的无符号整型也是因为二进制补码表示需要基于定长的精度。

    cpp_int使用示例

    有符号数为原码表示,并且额外用一个位表示符号:

    int main() {
        std::cout << "uint128 max: " << std::numeric_limits<boost::multiprecision::uint128_t>::max() << std::endl;
        std::cout << "int128 max: " << std::numeric_limits<boost::multiprecision::int128_t>::max() << std::endl;
        std::cout << "int128 min: " << std::numeric_limits<boost::multiprecision::int128_t>::min() << std::endl;
    
        return 0;
    }
    

    当有符号数转换为无符号数,先是按位截断,再对无符号数的二进制补码求负数:

    int main() {
        auto s = std::numeric_limits<boost::multiprecision::int128_t>::min();
        auto u = (boost::multiprecision::uint128_t)s;
    
        std::cout << "s: " << s << std::endl;
        std::cout << "u: " << u << std::endl;
    
        return 0;
    }
    

  • 相关阅读:
    纹理mag filter不能取GL_XXX_MIPMAP_XXXX
    (转)No architectures to compile for (ONLY_ACTIVE_ARCH=YES, active arch=arm64, VA 解决办法
    轻松制作儿童趣味算术软件
    批处理设置IP地址
    安卓手机文件管理器简单横向评比
    Linux基础和网络管理上机试题
    值得收藏的批处理程序
    王垠:完全用Linux工作
    XINU安装程序.exe一键配置好XINU实验环境
    很全面的WinRAR实用技巧系列
  • 原文地址:https://www.cnblogs.com/HachikoT/p/13728343.html
Copyright © 2011-2022 走看看