fill_zeros_like_op.cc 2.3 KB
Newer Older
1
/* Copyright (c) 2016 PaddlePaddle Authors. All Rights Reserved.
F
fengjiayi 已提交
2 3 4 5 6 7 8 9 10 11 12 13 14

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

    http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License. */

Y
Yi Wang 已提交
15
#include "paddle/fluid/operators/fill_zeros_like_op.h"
F
fengjiayi 已提交
16 17 18 19

namespace paddle {
namespace operators {

20
class FillZerosLikeOp : public framework::OperatorWithKernel {
Y
Yu Yang 已提交
21 22
 public:
  using framework::OperatorWithKernel::OperatorWithKernel;
23

24
  void InferShape(framework::InferShapeContext *ctx) const override {
Q
Qiao Longfei 已提交
25 26
    PADDLE_ENFORCE(ctx->HasInput("X"),
                   "Input(X) of FillZerosLikeOp should not be null.");
F
fengjiayi 已提交
27 28
    PADDLE_ENFORCE(ctx->HasOutput("Out"),
                   "Output(Out) of FillZerosLikeOp should not be null.");
29 30 31 32 33 34

    if (ctx->IsRuntime() &&
        ctx->GetOutputsVarType("Out")[0] ==
            framework::proto::VarType::LOD_TENSOR_ARRAY) {
      return;  // skip runtime infershape when is tensor array;
    }
F
fengjiayi 已提交
35 36 37 38
  }
};

class FillZerosLikeOpMaker : public framework::OpProtoAndCheckerMaker {
39
 public:
Y
Yu Yang 已提交
40
  void Make() override {
41
    AddInput("X", "The input of fill-zeros-like op.");
F
fengjiayi 已提交
42
    AddOutput("Out", "The variable will be filled up with zeros.");
F
fengjiayi 已提交
43
    AddComment(R"DOC(
K
kexinzhao 已提交
44 45
FillZerosLike Operator.

46
Fill up a variable with zeros, supporting both LoDTensor and LoDTensorArray.
K
kexinzhao 已提交
47
The output will have the same size as the input.
F
fengjiayi 已提交
48

49
)DOC");
F
fengjiayi 已提交
50 51 52 53 54
  }
};
}  // namespace operators
}  // namespace paddle

D
dongzhihong 已提交
55
namespace ops = paddle::operators;
F
fengjiayi 已提交
56 57
REGISTER_OP_WITHOUT_GRADIENT(fill_zeros_like, ops::FillZerosLikeOp,
                             ops::FillZerosLikeOpMaker);
58
REGISTER_OP_CPU_KERNEL(
Q
QI JUN 已提交
59 60 61 62 63 64
    fill_zeros_like,
    ops::FillZerosLikeKernel<paddle::platform::CPUDeviceContext, int>,
    ops::FillZerosLikeKernel<paddle::platform::CPUDeviceContext, int64_t>,
    ops::FillZerosLikeKernel<paddle::platform::CPUDeviceContext, float>,
    ops::FillZerosLikeKernel<paddle::platform::CPUDeviceContext, double>,
    ops::FillZerosLikeKernel<paddle::platform::CPUDeviceContext, bool>);