mirror of
https://github.com/zebrajr/pytorch.git
synced 2025-12-07 12:21:27 +01:00
Summary: As GoogleTest `TEST` macro is non-compliant with it as well as `DEFINE_DISPATCH` All changes but the ones to `.clang-tidy` are generated using following script: ``` for i in `find . -type f -iname "*.c*" -or -iname "*.h"|xargs grep cppcoreguidelines-avoid-non-const-global-variables|cut -f1 -d:|sort|uniq`; do sed -i "/\/\/ NOLINTNEXTLINE(cppcoreguidelines-avoid-non-const-global-variables)/d" $i; done ``` Pull Request resolved: https://github.com/pytorch/pytorch/pull/62008 Reviewed By: driazati, r-barnes Differential Revision: D29838584 Pulled By: malfet fbshipit-source-id: 1b2f8602c945bd4ce50a9bfdd204755556e31d13
38 lines
854 B
C++
38 lines
854 B
C++
#include "caffe2/operators/replace_nan_op.h"
|
|
|
|
namespace caffe2 {
|
|
|
|
template <>
|
|
template <typename T>
|
|
void ReplaceNaNOp<CPUContext>::ReplaceNaN(
|
|
const T& value,
|
|
const int64_t size,
|
|
const T* X,
|
|
T* Y) {
|
|
for (int64_t i = 0; i < size; i++) {
|
|
if (std::isnan(X[i])) {
|
|
Y[i] = value;
|
|
} else {
|
|
Y[i] = X[i];
|
|
}
|
|
}
|
|
}
|
|
|
|
REGISTER_CPU_OPERATOR(ReplaceNaN, ReplaceNaNOp<CPUContext>);
|
|
|
|
OPERATOR_SCHEMA(ReplaceNaN)
|
|
.NumInputs(1)
|
|
.NumOutputs(1)
|
|
.AllowInplace({{0, 0}})
|
|
.IdenticalTypeAndShape()
|
|
.SetDoc(R"DOC(
|
|
Replace the NaN (not a number) element in the input tensor with argument `value`
|
|
)DOC")
|
|
.Arg("value (optional)", "the value to replace NaN, the default is 0")
|
|
.Input(0, "input", "Input tensor")
|
|
.Input(1, "output", "Output tensor");
|
|
|
|
SHOULD_NOT_DO_GRADIENT(ReplaceNaN);
|
|
|
|
} // namespace caffe2
|