【问题标题】:Singular matrix issue with NumpyNumpy的奇异矩阵问题
【发布时间】: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

【问题讨论】:

  • 如果您将矩阵提高到负幂也会发生这种情况。

标签: python matrix numpy


【解决方案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来近似初始矩阵。

      【讨论】:

      【解决方案4】:

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

      numpy.linalg.svd numpy.linalg.qr

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 2012-12-25
        • 2018-02-17
        相关资源
        最近更新 更多