我是 numpy 的新手,我正在阅读 numpy,但我无法理解 numpy 中的行专业和列专业,谁能用最简单的方法举例解释?任何答案将不胜感激谢谢
问问题
305 次
1 回答
2
考虑一个这样的数组:
>>> A = np.random.randint(low=1, high=9, size=(3,3))
>>> A
array([[8, 7, 2],
[4, 2, 5],
[8, 6, 7]])
使用row-major意味着这些值将像这样存储在内存中(假设为 64 位整数):
Memory address 0x00 0x08 0x10 0x18 0x20 0x28 0x30 0x38 0x40
Value 8 7 2 4 2 5 8 6 7
而列主要存储看起来像这样:
Memory address 0x00 0x08 0x10 0x18 0x20 0x28 0x30 0x38 0x40
Value 8 4 8 7 2 6 2 5 7
Numpy 默认以行优先顺序存储。
>>> A[0].__array_interface__['data']
(14502656, False)
>>> A[1].__array_interface__['data']
(14502680, False) # 14502680 - 14502656 == 24
您可以看到第二行数据与第一行相距 24 个字节(三个 int64 值)。转置后的数组提供了原始数组数据的视图,而不是副本,它以显示为主要列的方式跨步(内存中的实际数据保持相同的顺序):
>>> A.T[0].__array_interface__['data']
(14502656, False)
>>> A.T[1].__array_interface__['data']
(14502664, False) # 14502664 - 14502656 == 8
于 2019-10-17T16:48:24.707 回答