From 4af0f140ecea3a7b19927f50a17e96161ba3d0c5 Mon Sep 17 00:00:00 2001 From: gouzil <66515297+gouzil@users.noreply.github.com> Date: Tue, 23 May 2023 15:13:36 +0800 Subject: [PATCH] [static op generation] tril_triu (#54033) * [phi] autogen code tril_triu * [phi][api]fix tril_triu_grad args * [fluid] clean cmake; [phi] fix infer_meta --- paddle/fluid/operators/tril_triu_op.cc | 103 ------------------ paddle/fluid/operators/unity_build_rule.cmake | 1 - paddle/phi/api/yaml/op_compat.yaml | 7 ++ paddle/phi/api/yaml/static_backward.yaml | 10 ++ paddle/phi/api/yaml/static_ops.yaml | 9 ++ paddle/phi/ops/compat/tril_triu_sig.cc | 33 ------ 6 files changed, 26 insertions(+), 137 deletions(-) delete mode 100644 paddle/fluid/operators/tril_triu_op.cc delete mode 100644 paddle/phi/ops/compat/tril_triu_sig.cc diff --git a/paddle/fluid/operators/tril_triu_op.cc b/paddle/fluid/operators/tril_triu_op.cc deleted file mode 100644 index 5d2c3c0797a..00000000000 --- a/paddle/fluid/operators/tril_triu_op.cc +++ /dev/null @@ -1,103 +0,0 @@ -/* Copyright (c) 2020 PaddlePaddle Authors. All Rights Reserved. - -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. */ - -#include - -#include "paddle/fluid/framework/infershape_utils.h" -#include "paddle/fluid/framework/op_registry.h" -#include "paddle/phi/core/infermeta_utils.h" -#include "paddle/phi/infermeta/unary.h" - -namespace paddle { -namespace operators { - -class TrilTriuOp : public framework::OperatorWithKernel { - public: - using framework::OperatorWithKernel::OperatorWithKernel; -}; - -class TrilTriuOpMaker : public framework::OpProtoAndCheckerMaker { - public: - void Make() override { - AddInput("X", "Tensor, the input of tril_triu op"); - AddOutput("Out", - "Tensor, the output tensor, with the same shape and data type as " - "input(x)"); - AddAttr("diagonal", "int number, the diagonal to consider.") - .SetDefault(0); - AddAttr("lower", "boolnumber, lower triangular or upper triangular."); - AddComment(R"DOC( -TrilTriu Operator. - -The tril operator returns the lower triangular part of the matrix (2-D tensor) -or batch of matrices $input$. The lower triangular part of the matrix is defined -as the elements on and below the diagonal. -The triu operator returns the upper triangular part of a matrix (2-D tensor) -or batch of matrices $input$. The upper triangular part of the matrix is defined -as the elements on and above the diagonal. -The other elements of the result tensor out are set to 0. - -The argument diagonal controls which diagonal to consider, default value is 0. - -)DOC"); - } -}; - -class TrilTriuGradOp : public framework::OperatorWithKernel { - public: - using framework::OperatorWithKernel::OperatorWithKernel; - - void InferShape(framework::InferShapeContext* ctx) const override { - PADDLE_ENFORCE_EQ(ctx->HasInput(framework::GradVarName("Out")), - true, - platform::errors::NotFound( - "Input(Out@GRAD) of TrilTriuOp should not be null")); - PADDLE_ENFORCE_EQ(ctx->HasOutput(framework::GradVarName("X")), - true, - platform::errors::NotFound( - "Output(X@Grad) of TrilTriuOp should not be null")); - ctx->SetOutputDim(framework::GradVarName("X"), - ctx->GetInputDim(framework::GradVarName("Out"))); - } -}; - -template -class TrilTriuGradOpMaker : public framework::SingleGradOpMaker { - public: - using framework::SingleGradOpMaker::SingleGradOpMaker; - - protected: - void Apply(GradOpPtr op) const override { - op->SetType("tril_triu_grad"); - op->SetInput(framework::GradVarName("Out"), this->OutputGrad("Out")); - op->SetOutput(framework::GradVarName("X"), this->InputGrad("X")); - op->SetAttrMap(this->Attrs()); - } -}; - -} // namespace operators -} // namespace paddle - -namespace ops = paddle::operators; -namespace plat = paddle::platform; -DECLARE_INFER_SHAPE_FUNCTOR(tril_triu, - TrilTriuInferShapeFunctor, - PD_INFER_META(phi::TrilTriuInferMeta)); -REGISTER_OPERATOR(tril_triu, - ops::TrilTriuOp, - ops::TrilTriuOpMaker, - ops::TrilTriuGradOpMaker, - ops::TrilTriuGradOpMaker, - TrilTriuInferShapeFunctor); -REGISTER_OPERATOR(tril_triu_grad, ops::TrilTriuGradOp); diff --git a/paddle/fluid/operators/unity_build_rule.cmake b/paddle/fluid/operators/unity_build_rule.cmake index 6c5f4ccbaa4..10439807a9b 100644 --- a/paddle/fluid/operators/unity_build_rule.cmake +++ b/paddle/fluid/operators/unity_build_rule.cmake @@ -288,7 +288,6 @@ register_unity_group( transpose_op.cc mkldnn/transpose_mkldnn_op.cc tree_conv_op.cc - tril_triu_op.cc unbind_op.cc unfold_op.cc) register_unity_group( diff --git a/paddle/phi/api/yaml/op_compat.yaml b/paddle/phi/api/yaml/op_compat.yaml index c07704bc9a6..0d77b08acba 100755 --- a/paddle/phi/api/yaml/op_compat.yaml +++ b/paddle/phi/api/yaml/op_compat.yaml @@ -2390,6 +2390,13 @@ outputs : out : Out +- op : tril_triu + backward : tril_triu_grad + inputs : + {x: X} + outputs : + {out : Out} + - op : trilinear_interp (trilinear_interp_v2) backward : trilinear_interp_grad (trilinear_interp_v2_grad) inputs : diff --git a/paddle/phi/api/yaml/static_backward.yaml b/paddle/phi/api/yaml/static_backward.yaml index 3ca5260a036..27b2589ce9b 100755 --- a/paddle/phi/api/yaml/static_backward.yaml +++ b/paddle/phi/api/yaml/static_backward.yaml @@ -65,6 +65,16 @@ func : softmax_grad composite : softmax_grad(out, out_grad, axis, x_grad) +- backward_op : tril_triu_grad + forward : tril_triu (Tensor x, int diagonal = 0, bool lower = false) -> Tensor(out) + args : (Tensor out_grad, int diagonal, bool lower) + output : Tensor(x_grad) + infer_meta : + func : UnchangedInferMeta + param : [out_grad] + kernel: + func : tril_triu_grad + - backward_op: unpool_grad forward: unpool (Tensor x, Tensor indices, int[] ksize, str unpooling_type, int[] strides = {1,1}, int[] paddings ={0,0} ,IntArray output_size = {0,0}, str data_format="NCHW") -> Tensor(out) args: (Tensor x, Tensor indices, Tensor out, Tensor out_grad, int[] ksize, int[] strides, int[] paddings, IntArray output_size, str data_format) diff --git a/paddle/phi/api/yaml/static_ops.yaml b/paddle/phi/api/yaml/static_ops.yaml index 4576633c248..095bb89836e 100755 --- a/paddle/phi/api/yaml/static_ops.yaml +++ b/paddle/phi/api/yaml/static_ops.yaml @@ -356,6 +356,15 @@ param : [rows, cols, offset, dtype] data_type : dtype +- op : tril_triu + args : (Tensor x, int diagonal = 0, bool lower = false) + output : Tensor(out) + infer_meta : + func : TrilTriuInferMeta + kernel : + func : tril_triu + backward : tril_triu_grad + - op : triu_indices args : (int row = 0, int col = 0, int offset = 0, DataType dtype = DataType::INT64) output : Tensor(out) diff --git a/paddle/phi/ops/compat/tril_triu_sig.cc b/paddle/phi/ops/compat/tril_triu_sig.cc deleted file mode 100644 index e44684e14ff..00000000000 --- a/paddle/phi/ops/compat/tril_triu_sig.cc +++ /dev/null @@ -1,33 +0,0 @@ -/* Copyright (c) 2022 PaddlePaddle Authors. All Rights Reserved. - -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. */ - -#include "paddle/phi/core/compat/op_utils.h" - -namespace phi { - -KernelSignature TrilTriuOpArgumentMapping( - const ArgumentMappingContext& ctx UNUSED) { - return KernelSignature("tril_triu", {"X"}, {"diagonal", "lower"}, {"Out"}); -} - -KernelSignature TrilTriuGradOpArgumentMapping( - const ArgumentMappingContext& ctx UNUSED) { - return KernelSignature( - "tril_triu_grad", {"Out@GRAD"}, {"diagonal", "lower"}, {"X@GRAD"}); -} - -} // namespace phi - -PD_REGISTER_ARG_MAPPING_FN(tril_triu, phi::TrilTriuOpArgumentMapping); -PD_REGISTER_ARG_MAPPING_FN(tril_triu_grad, phi::TrilTriuGradOpArgumentMapping); -- GitLab