You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

dropout.py 1.3 kB

12345678910111213141516171819202122232425262728293031323334
  1. # -*- coding: utf-8 -*-
  2. # MegEngine is Licensed under the Apache License, Version 2.0 (the "License")
  3. #
  4. # Copyright (c) 2014-2021 Megvii Inc. All rights reserved.
  5. #
  6. # Unless required by applicable law or agreed to in writing,
  7. # software distributed under the License is distributed on an
  8. # "AS IS" BASIS, WITHOUT ARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  9. from ..functional import dropout
  10. from .module import Module
  11. class Dropout(Module):
  12. r"""Randomly sets input elements to zeros with the probability :math:`drop\_prob` during training.
  13. Commonly used in large networks to prevent overfitting.
  14. Note that we perform dropout only during training, we also rescale(multiply) the output tensor
  15. by :math:`\frac{1}{1 - drop\_prob}`. During inference :class:`~.Dropout` is equal to :class:`~.module.identity.Identity`.
  16. Args:
  17. drop_prob: The probability to drop (set to zero) each single element
  18. """
  19. def __init__(self, drop_prob=0.0, **kwargs):
  20. super().__init__(**kwargs)
  21. self.drop_prob = drop_prob
  22. def forward(self, inputs):
  23. if self.training:
  24. return dropout(inputs, self.drop_prob, training=True)
  25. else:
  26. return inputs
  27. def _module_info_string(self) -> str:
  28. return "drop_prob={drop_prob}".format(drop_prob=self.drop_prob)