gpt4 book ai didi

python - 为什么使用 "colon and comma"进行切片与使用索引集合进行切片不同

转载 作者:行者123 更新时间:2023-12-01 09:23:55 28 4
gpt4 key购买 nike

为什么使用“冒号和逗号”进行切片与使用索引集合进行切片不同?

下面是一个示例,我希望得到相同的结果,但事实并非如此:

import numpy as np

a = np.array([[[1,2,3],[4,5,6]],[[7,8,9],[10,11,12]]])

print(a[[0,1],[0,1]])
# Output
# [[ 1 2 3]
# [10 11 12]]

print(a[:,[0,1]])
# Output
# [[[ 1 2 3]
# [ 4 5 6]]
# [[ 7 8 9]
# [10 11 12]]]

为什么它们不等价?

最佳答案

在第一种情况下,您使用 2 个相同长度的列表对数组 a 进行索引,这相当于使用 2 个相同形状的数组进行索引(请参阅 numpy docs on arrays as indices )。

因此,输出为 a[0,0] (与 a[0,0,:] 相同)和 a[1 ,1],索引数组的元素组合。预计会返回形状为 2,3 的数组。 2 因为它是索引数组的长度,3 因为它是未索引的轴。

在第二种情况下,结果是 a[:,0] (相当于 a[:,0,:])和 a[ :,1]。因此,这里期望的结果是一个数组,其第一维和第三维等于原始数组,第二维等于 2,即索引数组的长度(这里与第二轴的原始大小相同) .

为了清楚地表明这两个操作明显不同,我们可以尝试假设 : 与轴到第三轴的长度相同的范围之间是等价的,这将导致:

print(a[[0,1],[0,1],[0,1,2]])
IndexError Traceback (most recent call last)
<ipython-input-8-110de8f5f6d8> in <module>()
----> 1 print(a[[0,1],[0,1],[0,1,2]])

IndexError: shape mismatch: indexing arrays could not be broadcast together with shapes (2,) (2,) (3,)

这是因为索引数组不可能进行元素组合。与此相反,a[:,:,:] 将返回整个数组,a[[0,1],[0,1],[0,2]] 返回 [ 1 12] ,正如预期的那样,它是一个长度为 2 的一维数组,就像索引数组一样。

关于python - 为什么使用 "colon and comma"进行切片与使用索引集合进行切片不同,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50601068/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com