Numpy的奇异矩阵问题

Posted

技术标签:

【中文标题】Numpy的奇异矩阵问题【英文标题】:Singular matrix issue with Numpy 【发布时间】:2012-05-06 17:58:04 【问题描述】:

我正在尝试将向量(3 乘 1)乘以其转置(1 乘 3)。我得到一个 (3 x 3) 数组,但我无法得到它的倒数。知道为什么吗?

import numpy as np

c=array([1, 8, 50])
np.transpose(c[np.newaxis]) * c
array([[   1,    8,   50],
   [   8,   64,  400],
   [  50,  400, 2500]])
np.linalg.inv(np.transpose(c[np.newaxis]) * c)
Traceback (most recent call last):
  File "<console>", line 1, in <module>
  File "C:\Python26\lib\site-packages\numpy\linalg\linalg.py", line 445, in inv
    return wrap(solve(a, identity(a.shape[0], dtype=a.dtype)))
  File "C:\Python26\lib\site-packages\numpy\linalg\linalg.py", line 328, in solve
    raise LinAlgError, 'Singular matrix'
LinAlgError: Singular matrix

【问题讨论】:

如果您将矩阵提高到负幂也会发生这种情况。 【参考方案1】:

你粘贴的矩阵

[[   1,    8,   50],
 [   8,   64,  400],
 [  50,  400, 2500]]

行列式为零。这是奇异矩阵的定义(不存在逆矩阵)

http://en.wikipedia.org/wiki/Invertible_matrix

【讨论】:

【参考方案2】:

根据定义,通过将一维向量与其转置相乘,您就创建了一个奇异矩阵。

每一行都是第一行的线性组合。

请注意,第二行只是第一行的 8 倍。

同样,第三行是第一行的 50 倍。

你的矩阵中只有一个独立的行。

【讨论】:

【参考方案3】:

正如之前的答案中已经提到的,您的矩阵不能反转,因为它的行列式是 0。 但是如果你仍然想得到逆矩阵,你可以使用np.linalg.pinv,它利用SVD来近似初始矩阵。

【讨论】:

你能详细说明一下吗? SVD 是奇异值分解 (en.wikipedia.org/wiki/Singular_value_decomposition)。而 pinv 是一个伪逆 (en.wikipedia.org/wiki/…, en.wikipedia.org/wiki/Moore%E2%80%93Penrose_inverse)。【参考方案4】:

使用 SVD 或 QR 分解来计算实数或复数域中的精确解:

numpy.linalg.svd numpy.linalg.qr

【讨论】:

以上是关于Numpy的奇异矩阵问题的主要内容,如果未能解决你的问题,请参考以下文章

python numpy svd

Kivy App 在手机上出现“奇异矩阵”错误,但在电脑上却没有

Python加速奇异值分解

小矩阵的 Numpy 点积 MemoryError

numpy数组与矩阵运算

Numpy之线性代数