torch.qr¶
- torch.qr(input: Tensor, some: bool = True, *, out: Union[Tensor, Tuple[Tensor, ...], List[Tensor], None])¶
计算矩阵或批量矩阵
input
的 QR 分解,并返回一个命名元组 (Q, R),其中 ,Q 是一个正交矩阵或批量正交矩阵,R 是一个上三角矩阵或批量上三角矩阵。如果
some
为True
,则此函数返回瘦 (reduced) QR 分解。否则,如果some
为False
,此函数返回完全 (complete) QR 分解。警告
torch.qr()
已被弃用,推荐使用torch.linalg.qr()
,并将在未来的 PyTorch 版本中移除。布尔参数some
已被字符串参数mode
替换。Q, R = torch.qr(A)
应替换为Q, R = torch.linalg.qr(A)
Q, R = torch.qr(A, some=False)
应替换为Q, R = torch.linalg.qr(A, mode="complete")
警告
如果您计划通过 QR 进行反向传播,请注意当前的后向实现仅在
input
的前 列线性无关时才良好定义。一旦 QR 支持主元选择,此行为可能会改变。注意
此函数对 CPU 输入使用 LAPACK,对 CUDA 输入使用 MAGMA,并且在不同的设备类型或平台上可能会产生不同的(但有效的)分解结果。
- 参数
- 关键字参数
out (tuple, optional) – 包含 Q 和 R 张量的元组。Q 和 R 的尺寸详情见上文关于
some
的描述。
示例
>>> a = torch.tensor([[12., -51, 4], [6, 167, -68], [-4, 24, -41]]) >>> q, r = torch.qr(a) >>> q tensor([[-0.8571, 0.3943, 0.3314], [-0.4286, -0.9029, -0.0343], [ 0.2857, -0.1714, 0.9429]]) >>> r tensor([[ -14.0000, -21.0000, 14.0000], [ 0.0000, -175.0000, 70.0000], [ 0.0000, 0.0000, -35.0000]]) >>> torch.mm(q, r).round() tensor([[ 12., -51., 4.], [ 6., 167., -68.], [ -4., 24., -41.]]) >>> torch.mm(q.t(), q).round() tensor([[ 1., 0., 0.], [ 0., 1., -0.], [ 0., -0., 1.]]) >>> a = torch.randn(3, 4, 5) >>> q, r = torch.qr(a, some=False) >>> torch.allclose(torch.matmul(q, r), a) True >>> torch.allclose(torch.matmul(q.mT, q), torch.eye(5)) True