快捷方式

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 的全面开发者文档

查看文档

教程

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

查看教程

资源

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

查看资源