快捷方式

torch.linalg.ldl_factor_ex

torch.linalg.ldl_factor_ex(A, *, hermitian=False, check_errors=False, out=None)

這是 ldl_factor() 的一個版本,它不執行錯誤檢查,除非設定 check_errors= True。它還返回 LAPACK 的 sytrf 返回的 info 張量。info 儲存來自後端庫的整數錯誤程式碼。一個正整數表示 DD 的對角線元素為零。如果結果用於求解線性方程組,將會發生除以 0 的錯誤。info 中填充零表示分解成功。如果 check_errors=True 並且 info 包含正整數,則會丟擲 RuntimeError

注意

當輸入在 CUDA 裝置上時,此函式僅在 check_errors= True 時進行同步。

警告

此函式是“實驗性”的,在將來的 PyTorch 版本中可能會有所更改。

引數

A (Tensor) – 形狀為 (*, n, n) 的張量,其中 * 表示零個或多個批處理維度,包含對稱矩陣或 Hermitian 矩陣。

關鍵字引數
  • hermitian (bool, 可選) – 是否將輸入視為 Hermitian 矩陣或對稱矩陣。對於實值矩陣,此開關無效。預設值:False

  • check_errors (bool, 可選) – 控制是否檢查 info 的內容,如果非零則丟擲錯誤。預設值:False

  • out (tuple, 可選) – 用於寫入輸出的包含三個張量的元組。如果為 None 則忽略。預設值:None

返回值

一個命名元組 (LD, pivots, info)

示例

>>> A = torch.randn(3, 3)
>>> A = A @ A.mT # make symmetric
>>> A
tensor([[7.2079, 4.2414, 1.9428],
        [4.2414, 3.4554, 0.3264],
        [1.9428, 0.3264, 1.3823]])
>>> LD, pivots, info = torch.linalg.ldl_factor_ex(A)
>>> LD
tensor([[ 7.2079,  0.0000,  0.0000],
        [ 0.5884,  0.9595,  0.0000],
        [ 0.2695, -0.8513,  0.1633]])
>>> pivots
tensor([1, 2, 3], dtype=torch.int32)
>>> info
tensor(0, dtype=torch.int32)

文件

查閱 PyTorch 的全面開發者文件

檢視文件

教程

獲取面向初學者和高階開發者的深度教程

檢視教程

資源

查詢開發資源並獲得問題解答

檢視資源