torch.linalg.pinv¶
- torch.linalg.pinv(A, *, atol=None, rtol=None, hermitian=False, out=None) 张量¶
计算矩阵的伪逆(Moore-Penrose逆)。
伪逆可以通过代数定义,但通过奇异值分解(SVD)来理解它在计算上更为方便。
支持输入 float、double、cfloat 和 cdouble 数据类型。 还支持矩阵的批处理,如果
A是矩阵的批处理,则输出具有相同的批处理维度。如果
hermitian= True,则假设A在复数情况下为厄米矩阵,在实数情况下为对称矩阵,但内部不会进行检查。相反,计算中仅使用矩阵的下三角部分。奇异值(或当
hermitian= True 时的特征值的范数) 低于 阈值的值 在计算中被视为零并被丢弃, 其中 是最大的奇异值(或特征值)。如果未指定
rtol且A是一个维度为 (m, n) 的矩阵, 相对容差将设置为 并且 是A的数据类型(dtype)的 epsilon 值(参见finfo)。 如果未指定rtol且atol被指定为大于零,则rtol将设置为零。如果
atol或rtol是一个torch.Tensor,它的形状必须可以广播到由torch.linalg.svd()返回的A的奇异值的形状。注意
如果
hermitian= False,此函数使用torch.linalg.svd(); 如果hermitian= True,则使用torch.linalg.eigh()。 对于 CUDA 输入,此函数会与 CPU 同步该设备。注意
如果可能的话,考虑使用
torch.linalg.lstsq()来将矩阵左乘伪逆,如下所示:torch.linalg.lstsq(A, B).solution == A.pinv() @ B
在可能的情况下,始终建议使用
lstsq(),因为它更快且在数值上更稳定,而不是显式计算伪逆。注意
此函数具有与NumPy兼容的变体 linalg.pinv(A, rcond, hermitian=False)。 然而,使用位置参数
rcond已被弃用,取而代之的是rtol。警告
此函数内部使用
torch.linalg.svd()(或torch.linalg.eigh()当hermitian= True),因此其导数与这些函数具有相同的问题。有关更多详细信息,请参阅torch.linalg.svd()和torch.linalg.eigh()中的警告。- Parameters
- Keyword Arguments
示例:
>>> A = torch.randn(3, 5) >>> A tensor([[ 0.5495, 0.0979, -1.4092, -0.1128, 0.4132], [-1.1143, -0.3662, 0.3042, 1.6374, -0.9294], [-0.3269, -0.5745, -0.0382, -0.5922, -0.6759]]) >>> torch.linalg.pinv(A) tensor([[ 0.0600, -0.1933, -0.2090], [-0.0903, -0.0817, -0.4752], [-0.7124, -0.1631, -0.2272], [ 0.1356, 0.3933, -0.5023], [-0.0308, -0.1725, -0.5216]]) >>> A = torch.randn(2, 6, 3) >>> Apinv = torch.linalg.pinv(A) >>> torch.dist(Apinv @ A, torch.eye(3)) tensor(8.5633e-07) >>> A = torch.randn(3, 3, dtype=torch.complex64) >>> A = A + A.T.conj() # 创建一个厄米矩阵 >>> Apinv = torch.linalg.pinv(A, hermitian=True) >>> torch.dist(Apinv @ A, torch.eye(3)) tensor(1.0830e-06)