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