python多列填充缺点_python-如何避免多列的numpy-array的精度不那么...

我一直认为numpy uses是一种pairwise-summation,它也确保float32的高精度操作:

import numpy as np

N=17*10**6 # float32-precision no longer enough to hold the whole sum

print(np.ones((N,1),dtype=np.float32).sum(axis=0))

# [17000000.], kind of expected

但是,如果矩阵有多个列,则看起来好像使用了不同的算法:

print(np.ones((N,2),dtype=np.float32).sum(axis=0))

# [16777216. 16777216.] the error is just to big

print(np.ones((2*N,2),dtype=np.float32).sum(axis=0))

# [16777216. 16777216.] error is bigger

大概求和只是天真地将所有值求和.指示是16777216.f 1.0f = 16777216.f,例如:

one = np.array([1.], np.float32)

print(np.array([16777215.], np.float32)+one) # 16777216.

print(np.array([16777216.], np.float32)+one) # 16777216. as well

为什么numpy不对多列使用逐对求和,并且可以强制numpy对多列也使用成对求和?

我的numpy版本是1.14.2,如果有作用的话.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值