torch.linalg.matrix_rank¶
- torch.linalg.matrix_rank(A, *, atol=None, rtol=None, hermitian=False, out=None) 张量¶
计算矩阵的数值秩。
矩阵的秩计算为大于 阈值的奇异值(或当
hermitian= True 时的绝对值特征值)的数量, 其中 是最大的奇异值(或特征值)。支持输入 float、double、cfloat 和 cdouble 数据类型。 还支持矩阵的批处理,如果
A是矩阵的批处理,则输出具有相同的批处理维度。如果
hermitian= True,则假设A在复数情况下为厄米矩阵,在实数情况下为对称矩阵,但内部不会进行检查。相反,计算中仅使用矩阵的下三角部分。如果未指定
rtol且A是一个维度为 (m, n) 的矩阵, 相对容差将设置为 并且 是A的数据类型(dtype)的 epsilon 值(参见finfo)。 如果未指定rtol且atol被指定为大于零,则rtol将设置为零。如果
atol或rtol是一个torch.Tensor,它的形状必须可以广播到由torch.linalg.svdvals()返回的A的奇异值的形状。注意
此函数具有与NumPy兼容的变体 linalg.matrix_rank(A, tol, hermitian=False)。 然而,使用位置参数
tol已被弃用,取而代之的是atol和rtol。注意
矩阵秩是通过奇异值分解计算的
torch.linalg.svdvals()如果hermitian= False(默认)和特征值 分解torch.linalg.eigvalsh()当hermitian= True。 当输入在CUDA设备上时,此函数会与CPU同步该设备。- Parameters
- Keyword Arguments
示例:
>>> A = torch.eye(10) >>> torch.linalg.matrix_rank(A) tensor(10) >>> B = torch.eye(10) >>> B[0, 0] = 0 >>> torch.linalg.matrix_rank(B) tensor(9) >>> A = torch.randn(4, 3, 2) >>> torch.linalg.matrix_rank(A) tensor([2, 2, 2, 2]) >>> A = torch.randn(2, 4, 2, 3) >>> torch.linalg.matrix_rank(A) tensor([[2, 2, 2, 2], [2, 2, 2, 2]]) >>> A = torch.randn(2, 4, 3, 3, dtype=torch.complex64) >>> torch.linalg.matrix_rank(A) tensor([[3, 3, 3, 3], [3, 3, 3, 3]]) >>> torch.linalg.matrix_rank(A, hermitian=True) tensor([[3, 3, 3, 3], [3, 3, 3, 3]]) >>> torch.linalg.matrix_rank(A, atol=1.0, rtol=0.0) tensor([[3, 2, 2, 2], [1, 2, 1, 2]]) >>> torch.linalg.matrix_rank(A, atol=1.0, rtol=0.0, hermitian=True) tensor([[2, 2, 2, 1], [1, 2, 2, 2]])