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

numpy.sum()在大型数组上给出奇怪的结果

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

numpy.sum()在大型数组上给出奇怪的结果

显然这是numpy的整数类型,溢出32位。通常,您可以使用以下命令将numpy配置为在这种情况下失败

np.seterr

>>> import numpy as np>>> np.seterr(over='raise'){'divide': 'warn', 'invalid': 'warn', 'over': 'warn', 'under': 'ignore'}>>> np.int8(127) + np.int8(2)FloatingPointError: overflow encountered in byte_scalars

但是,

sum
已明确记录了行为“ 溢出时不会引发错误 ”,因此您在这里可能不走运。为了方便起见,使用numpy通常是性能的折衷!

但是,您可以手动为累加器指定dtype,如下所示:

>>> a = np.ones(129)>>> a.sum(dtype=np.int8)  # will overflow-127>>> a.sum(dtype=np.int64)  # no overflow129

观看票号593,因为这是一个未解决的问题,它可能由numpy开发人员修复。



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

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

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