torch.nan_to_num¶
- torch.nan_to_num(input, nan=0.0, posinf=None, neginf=None, *, out=None) Tensor ¶
将
NaN
、正无穷大和负无穷大值替换为input
中由nan
、posinf
和neginf
指定的值。默认情况下,NaN
将替换为零,正无穷大将替换为input
的 dtype 可表示的最大有限值,而负无穷大将替换为input
的 dtype 可表示的最小有限值。- 参数
input (Tensor) – 输入张量。
nan (数字, 可选) – 用于替换
NaN
的值。默认为零。posinf (数字, 可选) – 如果是数字,则为用于替换正无穷大值的值。如果为 None,则正无穷大值将替换为
input
的 dtype 可表示的最大有限值。默认为 None。neginf (数字, 可选) – 如果是数字,则为用于替换负无穷大值的值。如果为 None,则负无穷大值将替换为
input
的 dtype 可表示的最小有限值。默认为 None。
- 关键字参数
out (Tensor, 可选) – 输出张量。
示例
>>> x = torch.tensor([float('nan'), float('inf'), -float('inf'), 3.14]) >>> torch.nan_to_num(x) tensor([ 0.0000e+00, 3.4028e+38, -3.4028e+38, 3.1400e+00]) >>> torch.nan_to_num(x, nan=2.0) tensor([ 2.0000e+00, 3.4028e+38, -3.4028e+38, 3.1400e+00]) >>> torch.nan_to_num(x, nan=2.0, posinf=1.0) tensor([ 2.0000e+00, 1.0000e+00, -3.4028e+38, 3.1400e+00])