pytorch
1from typing import Optional
2import warnings
3
4# NB: Keep this file in sync with enums in aten/src/ATen/core/Reduction.h
5
6
7def get_enum(reduction: str) -> int:
8if reduction == 'none':
9ret = 0
10elif reduction == 'mean':
11ret = 1
12elif reduction == 'elementwise_mean':
13warnings.warn("reduction='elementwise_mean' is deprecated, please use reduction='mean' instead.")
14ret = 1
15elif reduction == 'sum':
16ret = 2
17else:
18ret = -1 # TODO: remove once JIT exceptions support control flow
19raise ValueError(f"{reduction} is not a valid value for reduction")
20return ret
21
22# In order to support previous versions, accept boolean size_average and reduce
23# and convert them into the new constants for now
24
25
26# We use these functions in torch/legacy as well, in which case we'll silence the warning
27def legacy_get_string(size_average: Optional[bool], reduce: Optional[bool], emit_warning: bool = True) -> str:
28warning = "size_average and reduce args will be deprecated, please use reduction='{}' instead."
29
30if size_average is None:
31size_average = True
32if reduce is None:
33reduce = True
34
35if size_average and reduce:
36ret = 'mean'
37elif reduce:
38ret = 'sum'
39else:
40ret = 'none'
41if emit_warning:
42warnings.warn(warning.format(ret))
43return ret
44
45
46def legacy_get_enum(size_average: Optional[bool], reduce: Optional[bool], emit_warning: bool = True) -> int:
47return get_enum(legacy_get_string(size_average, reduce, emit_warning))
48