繁体   English   中英

使用较小的N-D阵列按列对N-D numpy数组进行排序

[英]Sort N-D numpy array by column with a smaller N-D array

据我所知,通过使用花式索引对Sort ND numpy数组进行使用花式索引,我可以执行以下c = a[:, :, b]其中b定义了我想按列排序的顺序

>>> a = np.array([[[ 0,  1], [ 2,  3]],
                  [[ 4,  5], [ 6,  7]],
                  [[ 8,  9], [10, 11]]])
>>> b = np.array([1, 0])
>>> c = a[:, :, b]
>>> c
array([[[ 1,  0],
        [ 3,  2]],

       [[ 5,  4],
        [ 7,  6]],

       [[ 9,  8],
        [11, 10]]])

现在我用b2两个输入增加b ,对应于我想要在a对每组2x2进行排序a

>>> b2 = np.array([[1, 0], [0, 1], [1, 0]])
>>> c2 = ?
>>> c2
array([[[ 1,  0],
        [ 3,  2]],

       [[ 4,  5],
        [ 6,  7]],

       [[ 9,  8],
        [11, 10]]])

我有一组更大的输入,我有一个函数返回一个类似'b2'的数组,它为我提供了我应该获得的信息。 因此,我可以知道我应该填写什么c2 = ? 为了得到理想的结果?

这是一种花式索引的方法 -

(a[np.arange(a.shape[0])[:,None],:,b2]).transpose(0,2,1)

样品运行 -

In [191]: a
Out[191]: 
array([[[7, 8, 5, 2, 0],
        [6, 7, 0, 7, 1],
        [7, 6, 5, 4, 0]],

       [[8, 0, 5, 5, 7],
        [4, 3, 4, 0, 1],
        [8, 6, 3, 2, 4]],

       [[3, 2, 7, 3, 7],
        [4, 3, 0, 1, 5],
        [4, 3, 7, 8, 7]]])

In [192]: b2
Out[192]: 
array([[1, 2, 4, 3, 0],
       [4, 2, 0, 1, 3],
       [1, 3, 4, 0, 2]])

In [193]: (a[np.arange(a.shape[0])[:,None],:,b2]).transpose(0,2,1)
Out[193]: 
array([[[8, 5, 0, 2, 7],
        [7, 0, 1, 7, 6],
        [6, 5, 0, 4, 7]],

       [[7, 5, 8, 0, 5],
        [1, 4, 4, 3, 0],
        [4, 3, 8, 6, 2]],

       [[2, 3, 7, 3, 7],
        [3, 1, 5, 4, 0],
        [3, 8, 7, 4, 7]]])

如果没有人找到纯粹的花式索引解决方案,这里就是循环第一个轴的解决方案:

np.asarray([a[n,:,p] for n,p in enumerate(b2)])

array([[[ 1,  3],
    [ 0,  2]],

   [[ 4,  6],
    [ 5,  7]],

   [[ 9, 11],
    [ 8, 10]]])

类似于@Divakar's解决方案,但没有transpose

In [259]: I,J, K = np.ogrid[:3,:2,:2]

In [260]: a[I, J, b[:,None,:]]
Out[260]: 
array([[[ 1,  0],
        [ 3,  2]],

       [[ 4,  5],
        [ 6,  7]],

       [[ 9,  8],
        [11, 10]]])

我使用ogrid (或np.ix_ )作为生成2个3d数组的紧凑方式,用b[:,None,:]广播以产生一组(3,2,2)索引。

完全Nones的等价物是:

a[np.arange(3)[:,None,None], np.arange(2)[None,:,None], b[:,None,:]]

(这更清楚地表明b正沿着第一轴和最后一轴选择项目)

要查看完整的广播索引数组,请打印:

 np.broadcast_arrays(I,J,b[:,None,:])

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM