mirror of
https://github.com/zebrajr/pytorch.git
synced 2025-12-07 12:21:27 +01:00
Summary: Pull Request resolved: https://github.com/pytorch/pytorch/pull/11943 See title Reviewed By: ezyang Differential Revision: D9992645 fbshipit-source-id: e8f80d6ea762971513e5e8072975ceea53e1f11a
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
|