簡體   English   中英

Python-將矩陣a提取到矩陣b

[英]Python - Extract matrix a into matrix b

我想將矩陣A(4,4)提取到矩陣b(7,4)中。

下面的矩陣:

>>> Matrix_A = numpy.array([[[10,1.5,-3.8,8.0],[20,10.2,5.2,6.7],[30,0.5,-6.2,-7.1],[40,-0.7,-0.6,-0.5]]])
>>> Matrix_A
array([[[ 10. ,   1.5,  -3.8,   8. ],
        [ 20. ,  10.2,   5.2,   6.7],
        [ 30. ,   0.5,  -6.2,  -7.1],
        [ 40. ,  -0.7,  -0.6,  -0.5]]])

>>> Matrix_B = numpy.array([[[10,2.7,4.8,-5.8],[15,-1.4,-6.4,8.1],[20,12.4,-7.1,4.9],[25,-1.5,6.2,-4.8],[30,-6.8,0.47,3.8],[35,5.4,-4.8,10.5],[40,16.2,5.7,-8.3]]])
>>> Matrix_B
array([[[ 10.  ,   2.7 ,   4.8 ,  -5.8 ],
        [ 15.  ,  -1.4 ,  -6.4 ,   8.1 ],
        [ 20.  ,  12.4 ,  -7.1 ,   4.9 ],
        [ 25.  ,  -1.5 ,   6.2 ,  -4.8 ],
        [ 30.  ,  -6.8 ,   0.47,   3.8 ],
        [ 35.  ,   5.4 ,  -4.8 ,  10.5 ],
        [ 40.  ,  16.2 ,   5.7 ,  -8.3 ]]])

我想要的結果是:

    >>> Matrix_A_extract_from_Matrix_B
array([[[ 10.  ,   2.7 ,   4.8 ,  -5.8 ],
        [ 20.  ,  12.4 ,  -7.1 ,   4.9 ],
        [ 30.  ,  -6.8 ,   0.47,   3.8 ],
        [ 40.  ,  16.2 ,   5.7 ,  -8.3 ]]])

並且如果可能的話,我想得到一個包含其余部分的矩陣R,如下所示:

    >>> Matrix_R
array([[[ 15. ,  -1.4,  -6.4,   8.1],
        [ 25. ,  -1.5,   6.2,  -4.8],
        [ 35. ,   5.4,  -4.8,  10.5]]])

主要目標是比較Matrix_AMatrix_A_extract_from_Matrix_B

我真正的問題是將矩陣與數千行進行比較,Matrix_A和Matrix B只是簡化問題的一個示例。

非常感謝你的幫助。

首先,由於數組是3d數組,因此應壓縮大小以將其轉換為2d數組,以便於計算。

In [27]: Matrix_A = np.squeeze(Matrix_A)

In [28]: Matrix_B = np.squeeze(Matrix_B)

然后,您可以使用np.in1d查找常見的第一列的索引,並通過簡單的索引提取它們:

In [29]: Matrix_B[np.in1d(Matrix_B[:, 0],Matrix_A[:, 0])]
Out[29]: 
array([[ 10.  ,   2.7 ,   4.8 ,  -5.8 ],
       [ 20.  ,  12.4 ,  -7.1 ,   4.9 ],
       [ 30.  ,  -6.8 ,   0.47,   3.8 ],
       [ 40.  ,  16.2 ,   5.7 ,  -8.3 ]])

In [30]: Matrix_B[np.logical_not(np.in1d(Matrix_B[:, 0],Matrix_A[:, 0]))]
Out[30]: 
array([[ 15. ,  -1.4,  -6.4,   8.1],
       [ 25. ,  -1.5,   6.2,  -4.8],
       [ 35. ,   5.4,  -4.8,  10.5]])

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM