torch.linalg.lu_solve#
- torch.linalg.lu_solve(LU, pivots, B, *, left=True, adjoint=False, out=None) Tensor #
在给定具有唯一解的方阵线性方程组的 LU 分解的情况下,计算该方程组的解。
令 为 或 ,则该函数计算与 关联的**线性系统**的解 ,该系统定义为:
其中 是由
lu_factor()
返回的分解形式。如果
left
= False,则该函数返回求解系统 的矩阵 :如果
adjoint
= True (且left
= True),给定 的 LU 分解,该函数返回求解系统 的矩阵 :其中 是 为复数时的共轭转置,是 为实数时的转置。
left
= False 的情况类似。支持float、double、cfloat和cdouble数据类型的输入。也支持矩阵的批次,如果输入是矩阵的批次,则输出具有相同的批次维度。
- 参数
LU (Tensor) – 形状为 (*, n, n) (如果
left
= True 则为 (*, k, k)) 的张量,其中 * 是零个或多个批次维度,由lu_factor()
返回。pivots (Tensor) – 形状为 (*, n) (如果
left
= True 则为 (*, k)) 的张量,其中 * 是零个或多个批次维度,由lu_factor()
返回。B (Tensor) – 右侧的张量,形状为 (*, n, k)。
- 关键字参数
示例
>>> 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) # Broadcasting rules apply: A is broadcasted >>> 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) # Now solve for A^T >>> X = torch.linalg.lu_solve(LU, pivots, B, adjoint=True) >>> torch.allclose(A.mT @ X, B) True