1 回答
![?](http://img1.sycdn.imooc.com/5458692c00014e9b02200220-100-100.jpg)
TA贡献1799条经验 获得超6个赞
Numpy 允许您直接访问数组中的字节。对于简单的情况,您可以直接将 nans 视为整数:
quiet_nan1 = np.uint64(0b0111111111111000000000000000000000000000000000000000000000000000)
x = np.arange(10, dtype=np.float64)
x.view(np.uint64)[5] = quiet_nan1
x.view(np.uint64)
现在您只需比较确切 NaN 的位模式的元素即可。该版本将保留形状,因为元素大小相同。
float128一个更通用的解决方案是使用字节,它可以让您使用在大多数系统上没有相应整数模拟的类型:
quiet_nan1l = np.frombuffer((0b01111111111111111000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000).to_bytes(16, 'big'))
x = np.arange(3 * 4 * 5, dtype=np.float128).reshape3, 4, 5)
x.view(np.uint8).reshape(*x.shape, 16)[2, 2, 3, :] = quiet_nan1l
x.view(np.uint8).reshape(*x.shape, 16)
最终的重塑并不是绝对必要的,但它非常方便,因为它沿着最后一个维度隔离了原始数组元素。
在这两种情况下,修改视图都会修改原始数组。这就是一个观点的观点。
当然,不言而喻(这就是我这么说的原因),这适用于您可能想要分配或测试的任何其他位模式,而不仅仅是 NaN。
添加回答
举报