快捷方式

torch.cholesky_inverse

torch.cholesky_inverse(L, upper=False, *, out=None) Tensor

计算给定 Cholesky 分解的复 Hermitian 或实对称正定矩阵的逆矩阵。

AA 为复 Hermitian 或实对称正定矩阵,LL 为其 Cholesky 分解,使得

A=LLHA = LL^{\text{H}}

其中 LHL^{\text{H}} 是当 LL 为复数时的共轭转置,当 LL 为实值时的转置。

计算逆矩阵 A1A^{-1}

支持 float、double、cfloat 和 cdouble dtypes 的输入。也支持矩阵批处理,如果 AA 是矩阵批处理,则输出具有相同的批处理维度。

参数
  • L (Tensor) – 形状为 (*, n, n) 的张量,其中 * 是零个或多个批处理维度,由对称或 Hermitian 正定矩阵的下三角或上三角 Cholesky 分解组成。

  • upper (bool, optional) – 标志,指示 LL 是下三角还是上三角。默认值:False

关键字参数

out (Tensor, optional) – 输出张量。如果为 None 则忽略。默认值:None

示例

>>> A = torch.randn(3, 3)
>>> A = A @ A.T + torch.eye(3) * 1e-3 # Creates a symmetric positive-definite matrix
>>> L = torch.linalg.cholesky(A) # Extract Cholesky decomposition
>>> torch.cholesky_inverse(L)
tensor([[ 1.9314,  1.2251, -0.0889],
        [ 1.2251,  2.4439,  0.2122],
        [-0.0889,  0.2122,  0.1412]])
>>> A.inverse()
tensor([[ 1.9314,  1.2251, -0.0889],
        [ 1.2251,  2.4439,  0.2122],
        [-0.0889,  0.2122,  0.1412]])

>>> A = torch.randn(3, 2, 2, dtype=torch.complex64)
>>> A = A @ A.mH + torch.eye(2) * 1e-3 # Batch of Hermitian positive-definite matrices
>>> L = torch.linalg.cholesky(A)
>>> torch.dist(torch.inverse(A), torch.cholesky_inverse(L))
tensor(5.6358e-7)

文档

访问 PyTorch 的全面开发者文档

查看文档

教程

获取面向初学者和高级开发者的深度教程

查看教程

资源

查找开发资源并获得问题解答

查看资源