torch_npu.npu.enable_deterministic_with_backward
功能描述
开启“确定性”功能。确定性算法是指在模型的前向传播过程中,每次输入相同,输出也相同。确定性算法可以避免模型在每次前向传播时产生的小随机误差累积,在需要重复测试或比较模型性能时非常有用。
接口原型
1 | torch_npu.npu.enable_deterministic_with_backward(tensor) -> Tensor |
参数说明
tensor:该接口为透明传输接口,不做数据处理,类型支持和数据格式为PyTorch在各芯片上可支持的数据类型和数据格式,无接口级别的约束。
输出说明
一个Tensor类型的输出,代表enable_deterministic_with_backward的计算结果。
约束说明
入参tensor需要是训练网络中可以传递下去和整网的output有关联的tensor变量,否则无法进行反向设置确定性能力。
支持的型号
Atlas A2 训练系列产品/Atlas 800I A2 推理产品 Atlas A3 训练系列产品 Atlas 训练系列产品 Atlas 推理系列产品 Atlas 200/300/500 推理产品 Atlas 200I/500 A2 推理产品
调用示例
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 | import unittest import torch import torch.nn as nn import torch_npu import torchair as tng from torchair.configs.compiler_config import CompilerConfig config = CompilerConfig() npu_backend = tng.get_npu_backend(compiler_config=config) class TorchairSt(unittest.TestCase): def test_enable_to_disable_deterministic_algorithms(self): target_dtype = torch.float16 class DeterministicModel(torch.nn.Module): def __init__(self): super().__init__() def forward(self, x, y): x = x + 1 x = torch_npu.npu.enable_deterministic_with_backward(x) add4 = x + y add1 = sum(add4) add1 = torch_npu.npu.disable_deterministic_with_backward(add1) add6 = add1 + add1 return add6 device = torch.device("npu:0") model = DeterministicModel() npu_mode = model.to(device) ins1 = torch.ones((2, 2), requires_grad=True).to(target_dtype).npu() ins2 = torch.ones((2, 2), requires_grad=True).to(target_dtype).npu() output_data = npu_mode(ins1, ins2) self.assertEqual(False, torch.are_deterministic_algorithms_enabled()) loss_fn = nn.MSELoss() target_data = torch.randn((1, 2), requires_grad=True).to(target_dtype).npu() loss = loss_fn(output_data, target_data) loss.backward() self.assertEqual(False, torch.are_deterministic_algorithms_enabled()) if __name__ == '__main__': unittest.main() |
父主题: torch_npu