Shortcuts

torch.linalg.lu_solve

torch.linalg.lu_solve(LU, pivots, B, *, left=True, adjoint=False, out=None) 张量

计算具有唯一解的方阵线性方程组的解,给定LU分解。

K\mathbb{K}R\mathbb{R}C\mathbb{C}, 此函数计算与 AKn×n,BKn×kA \in \mathbb{K}^{n \times n}, B \in \mathbb{K}^{n \times k} 相关的 线性系统 的解 XKn×kX \in \mathbb{K}^{n \times k},其定义为

AX=BAX = B

其中 AA 被分解为 lu_factor() 返回的形式。

如果 left= False,此函数返回矩阵 XKn×kX \in \mathbb{K}^{n \times k} 解决系统

XA=BAKk×k,BKn×k.XA = B\mathrlap{\qquad A \in \mathbb{K}^{k \times k}, B \in \mathbb{K}^{n \times k}.}

如果 adjoint= True(并且 left= True),给定一个 AA 的LU分解,此函数返回 XKn×kX \in \mathbb{K}^{n \times k} 解该系统

AHX=BAKk×k,BKn×k.A^{\text{H}}X = B\mathrlap{\qquad A \in \mathbb{K}^{k \times k}, B \in \mathbb{K}^{n \times k}.}

其中 AHA^{\text{H}} 是当 AA 为复数时的共轭转置,以及当 AA 为实值时的转置。left= False 的情况类似。

支持float、double、cfloat和cdouble数据类型的输入。 还支持矩阵的批处理,如果输入是矩阵的批处理,则输出具有相同的批处理维度。

Parameters
  • LU (张量) – 形状为 (*, n, n)(或 (*, k, k) 如果 left= True)的张量 其中 * 是由 lu_factor() 返回的零个或多个批次维度。

  • pivots (张量) – 形状为 (*, n) 的张量(如果 left= True,则为 (*, k)) 其中 * 是零个或多个批次维度,由 lu_factor() 返回。

  • B (张量) – 形状为 (*, n, k) 的右侧张量。

Keyword Arguments
  • left (bool, 可选) – 是否求解系统 AX=BAX=BXA=BXA = B. 默认值: True.

  • adjoint (bool, 可选) – 是否求解系统 AX=BAX=BAHX=BA^{\text{H}}X = B. 默认值: False.

  • 输出 (张量, 可选) – 输出张量。如果为,则忽略。默认值:

示例:

>>> A = torch.randn(3, 3)
>>> LU, pivots = torch.linalg.lu_factor(A)
>>> B = torch.randn(3, 2)
>>> X = torch.linalg.lu_solve(LU, pivots, B)
>>> torch.allclose(A @ X, B)
True

>>> B = torch.randn(3, 3, 2)   # 广播规则适用:A被广播
>>> X = torch.linalg.lu_solve(LU, pivots, B)
>>> torch.allclose(A @ X, B)
True

>>> B = torch.randn(3, 5, 3)
>>> X = torch.linalg.lu_solve(LU, pivots, B, left=False)
>>> torch.allclose(X @ A, B)
True

>>> B = torch.randn(3, 3, 4)   # 现在求解 A^T
>>> X = torch.linalg.lu_solve(LU, pivots, B, adjoint=True)
>>> torch.allclose(A.mT @ X, B)
True
优云智算