| #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 |