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;
    }
    

  • 相关阅读:
    Flask学习 1创建第一个页面
    Flask教程
    微信服务号认证和不认证的区别
    python保存selenium的cookies写入和读出
    centos 无界面安装selenium+chrome+chromedirver的设置
    win7系统下安装Splash。
    ubuntu mysql5.6二进制安装
    Python socket实现处理多个连接
    Python 简单soket例子
    Python socket网络编程(通信介绍)
  • 原文地址:https://www.cnblogs.com/HachikoT/p/13728343.html
Copyright © 2011-2022 走看看