5

我有一个 ndarray 子类,它实现将一个或多个记录加载/保存到一个平面二进制文件中。加载记录后,我可以以正常的 NumPy 方式访问它们。

我的问题是当我对结果(或者实际上是任何 NumPy 数组)进行切片时会发生什么。这通常会产生一个“视图”,即。一个数组,它引用与父数组相同的缓冲区。

一旦我有了这个视图,有没有办法确定视图 V 在数组 A 中的位置?更准确地说,我想知道 V 开始的字节偏移量(从 A 的数据缓冲区的开头)。这将允许我将切片以正确的偏移量写回磁盘。

这是一些示例代码来显示这种情况

# Imagine a as consisting of 4 4-byte records...
a = np.arange(16, dtype='B').reshape(4,4)

# I select the first record
v = a[0]

print (v)

# [0 1 2 3]

# I can determine that v is a subarray:

is_subarray = v.base != None

# I can determine which dimension the slice spans..

whichdim = v.base.strides.index (v.strides[-1])

# But not its position along that dimension.
4

1 回答 1

6

信息是通过array.__array_interface__(也许在更好的地方)暴露出来的,但是我认为你可能应该只使用 memmaps 开始而不是搞砸这个。例如检查np.may_share_memory函数(或实际上np.byte_bounds)的 numpy 代码。

于 2012-09-14T11:53:52.353 回答