【发布时间】:2017-10-26 07:04:19
【问题描述】:
我有大量的 numpy 内存错误问题, 我尝试使用切片来处理它,如下所示 How to merge two large numpy arrays if slicing doesn't resolve memory error?
切片适用于 numpy.multiply,但似乎无法通过切片将 numpy int 转换为浮点数。 以下是示例:
images = numpy.array([1,2,3,4,5,6,7,8,9,10])
images[0:5] = images[0:5].astype(numpy.float32)
print type(images[0])
images = images.astype(numpy.float32)
print type(images[0])
<type 'numpy.int32'>
<type 'numpy.float32'>
使用 images.astype(numpy.float32) 后,出现内存错误(dtype 相同)。 目标内存太小,我可能很难使用稀疏矩阵。
感谢您的任何建议...!
【问题讨论】:
-
numpy 声明
numpy.array的每个元素都属于同一类型,因此您不能仅更改数组一部分的类型。你可以创建另一个数组images_5_float = images[0:5].astype(numpy.float32) -
好的...知道了...我猜已经...,只是希望找到另一种方法,谢谢您的回复!
-
但如果您可以逐个部分、逐个切片地执行下一个操作,则可以使用这个新的部分数组
标签: python arrays numpy out-of-memory