栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

用Numpy打领带

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

用Numpy打领带

NumPy不对内部舍入模式进行任何控制。这有两种选择:

  1. 使用此答案中
    gmpy2
    概述的内容。这使您可以完全控制舍入模式,但是用于简单的浮点数学运算可能会比NumPy慢。
    gmpy2
  2. 使用

    fesetround
    via
    ctypes
    手动设置舍入模式。这是特定于系统的,因为常量可能因平台而异。检查
    fenv.h
    平台上的常量值。在我的机器上(Mac OS X):

    import numpy as np

    import ctypes
    FE_TonEAREST = 0x0000
    FE_DOWNWARD = 0x0400
    FE_UPWARD = 0x0800
    FE_TOWARDZERO = 0x0c00
    libc = ctypes.CDLL(‘libc.dylib’)

    v = 1. / (1<<23)
    print repr(np.float32(1+v) - np.float32(v/2)) # prints 1.0
    libc.fesetround(FE_UPWARD)
    print repr(np.float32(1+v) - np.float32(v/2)) # prints 1.0000002



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/641569.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号