python – Scipy inv(A)vs A.I

我对
Python很新,我想知道它们之间有什么区别:

inv(A)

A.I

两者都返回包含矩阵A的逆的Numpy数组.

A.我认为它正在访问矩阵类中的变量,该矩阵类存储矩阵的逆矩阵;然而,这意味着每次A改变时,必须重新计算A的倒数(这对我来说似乎不合逻辑).

最佳答案 A.I和numpy.linalg.inv不一样.

A.I是property,拨打matrix.getI

def getI(self):
    M,N = self.shape
    if M == N:
        from numpy.dual import inv as func
    else:
        from numpy.dual import pinv as func
    return asmatrix(func(self))

因此getI要么根据矩阵的形状调用numpy.dual.inv(方形矩阵的乘法逆)或numpy.dual.pinv(Moore-Penrose伪逆).

如果你追踪定义(在dual.py),你会发现
numpy.dual.inv是numpy.linalg.inv,numpy.dual.pinv是numpy.linalg.pinv.

In [69]: s = np.random.random((3,4))

In [70]: t = np.matrix(s)

In [71]: t.I
Out[71]: 
matrix([[ 1.09509751, -0.56685735,  0.51704085],
        [-1.59777153,  0.2777383 ,  1.25579378],
        [ 0.81899054,  0.7594223 , -0.82760378],
        [ 0.02845906,  0.50418885, -0.2091376 ]])

In [72]: np.linalg.inv(t)
...
LinAlgError: Array must be square

此外,np.linalg.inv可以应用于numpy数组(并返回一个numpy数组),也可以应用于numpy矩阵. matrix.I属性特定于numpy矩阵,并返回另一个numpy矩阵.

In [60]: x = np.random.random((3,3))

In [62]: y = np.matrix(x)    

In [64]: type(y.I)
Out[64]: <class 'numpy.matrixlib.defmatrix.matrix'>

In [65]: type(np.linalg.inv(x))
Out[65]: <type 'numpy.ndarray'>

像A.I这样的属性在语法上看起来像一个属性,但它实际上调用了一个函数(在本例中为A.getI).因此,不存储逆的值.每次Python计算A.I时,都会调用函数A.getI(),并返回函数的结果.

有关属性的更多信息,请参见Properties: attributes managed by get/set methods.

点赞