当前位置:  开发笔记 > 编程语言 > 正文

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

如何解决《numpy.sum()在大型数组上给出奇怪的结果》经验,为你挑选了1个好方法。

我似乎找到了一个陷阱,使用.sum()numpy数组,但我无法找到一个解释.从本质上讲,如果我尝试总结大阵,然后我开始变得无厘头的答案,但这种情况发生默默,我不能使输出足够好,谷歌的事业感.

例如,这与预期完全一样:

a = sum(xrange(2000)) 
print('a is {}'.format(a))

b = np.arange(2000).sum()
print('b is {}'.format(b))

为两者提供相同的输出:

a is 1999000
b is 1999000

但是,这不起作用:

c = sum(xrange(200000)) 
print('c is {}'.format(c))

d = np.arange(200000).sum()
print('d is {}'.format(d))

给出以下输出:

c is 19999900000
d is -1474936480

在更大的阵列上,可以获得积极的结果.这更加阴险,因为我可能不会发现一些不寻常的事情正在发生.例如:

e = sum(xrange(100000000))
print('e is {}'.format(e))

f = np.arange(100000000).sum()
print('f is {}'.format(f))

给出这个:

e is 4999999950000000
f is 887459712

这是与数据类型有关,甚至使用python float似乎解决了这个问题:

e = sum(xrange(100000000))
print('e is {}'.format(e))

f = np.arange(100000000, dtype=float).sum()
print('f is {}'.format(f))

赠送:

e is 4999999950000000
f is 4.99999995e+15

我没有Comp的背景.科学.并发现自己卡住了(也许这是一个骗局).我试过的事情:

    numpy数组具有固定的大小.不; 这似乎表明我应该先打一局MemoryError.

    我可能会以某种方式安装32位(可能不相关); 不,我跟着这个并确认我有64位.

    奇怪sum行为的其他例子; nope()我发现了这个,但我看不出它是如何适用的.

有人可以简要解释一下我缺少的东西并告诉我需要阅读的内容吗?此外,除了记住dtype每次定义,有没有办法阻止这种情况发生或发出警告?

可能相关:

Windows 7的

numpy 1.11.3

在Python 2.7.9上耗尽了Enthought Canopy



1> Mike Müller..:

在Windows上(在64位系统上),如果从Python int转换的默认整数NumPy使用的是32位.在Linux和Mac上它是64位.

指定一个64位整数,它将起作用:

d = np.arange(200000, dtype=np.int64).sum()
print('d is {}'.format(d))

输出:

c is 19999900000
d is 19999900000

虽然不是最优雅,但你可以做一些猴子修补,使用functools.partial:

from functools import partial

np.arange = partial(np.arange, dtype=np.int64)

从现在开始np.arange,默认情况下使用64位整数.

推荐阅读
无名有名我无名_593
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有