From fa10524d558770d3ca0485a3dbbc361b0f32014e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?S=C5=82awomir=20Siwek?= Date: Tue, 29 Nov 2022 10:21:08 +0100 Subject: [PATCH] eltwise_div + scale [PHI] (#48484) --- paddle/fluid/operators/ops_extra_info.h | 1 + .../phi/kernels/onednn/elementwise_kernel.cc | 6 ++++ .../test_mkldnn_elt_act_fuse_pass.py | 36 +++++++++++++++++++ 3 files changed, 43 insertions(+) diff --git a/paddle/fluid/operators/ops_extra_info.h b/paddle/fluid/operators/ops_extra_info.h index 77c0aa7a33..94adfaf3b4 100644 --- a/paddle/fluid/operators/ops_extra_info.h +++ b/paddle/fluid/operators/ops_extra_info.h @@ -95,6 +95,7 @@ const std::unordered_map {"fuse_activation_alpha", ExtraAttrProperty::ONEDNN}, {"fuse_activation_beta", ExtraAttrProperty::ONEDNN}, {"fuse_activation_scale", ExtraAttrProperty::ONEDNN}, + {"fused_output_scale", ExtraAttrProperty::ONEDNN}, {"fuse_alpha", ExtraAttrProperty::ONEDNN}, {"fuse_beta", ExtraAttrProperty::ONEDNN}, {"fuse_relu", ExtraAttrProperty::ONEDNN}, diff --git a/paddle/phi/kernels/onednn/elementwise_kernel.cc b/paddle/phi/kernels/onednn/elementwise_kernel.cc index 51be755977..e103f23df0 100644 --- a/paddle/phi/kernels/onednn/elementwise_kernel.cc +++ b/paddle/phi/kernels/onednn/elementwise_kernel.cc @@ -43,6 +43,12 @@ void ElementwiseKernel(const OneDNNContext& dev_ctx, dnnl::post_ops post_operations; funcs::AppendActivation(dev_ctx, post_operations); + if (dev_ctx.HasDnnAttr("fused_output_scale")) { + float scale_alpha = + PADDLE_GET_CONST(float, dev_ctx.GetDnnAttr("fused_output_scale")); + post_operations.append_eltwise( + 1.0, dnnl::algorithm::eltwise_linear, scale_alpha, 0.0f); + } auto* non_const_x = &x; auto* non_const_y = &y; diff --git a/python/paddle/fluid/tests/unittests/ir/inference/test_mkldnn_elt_act_fuse_pass.py b/python/paddle/fluid/tests/unittests/ir/inference/test_mkldnn_elt_act_fuse_pass.py index 068fbe1171..ac635436f6 100644 --- a/python/paddle/fluid/tests/unittests/ir/inference/test_mkldnn_elt_act_fuse_pass.py +++ b/python/paddle/fluid/tests/unittests/ir/inference/test_mkldnn_elt_act_fuse_pass.py @@ -356,6 +356,42 @@ class ElementwiseActivationMkldnnFusePassTest_Mul_Sigmoid( self.act = paddle.nn.functional.sigmoid +class ElementwiseScaleOneDNNFusePassTest_Add( + ElementwiseActivationMkldnnFusePassTest +): + def set_params(self): + self.operand = fluid.layers.elementwise_add + self.act_alpha = 0.6 + self.act = paddle.scale + + +class ElementwiseScaleOneDNNFusePassTest_Sub( + ElementwiseActivationMkldnnFusePassTest +): + def set_params(self): + self.operand = fluid.layers.elementwise_sub + self.act_alpha = 0.6 + self.act = paddle.scale + + +class ElementwiseScaleOneDNNFusePassTest_Mul( + ElementwiseActivationMkldnnFusePassTest +): + def set_params(self): + self.operand = fluid.layers.elementwise_mul + self.act_alpha = 0.6 + self.act = paddle.scale + + +class ElementwiseScaleOneDNNFusePassTest_Div( + ElementwiseActivationMkldnnFusePassTest +): + def set_params(self): + self.operand = fluid.layers.elementwise_div + self.act_alpha = 0.6 + self.act = paddle.scale + + if __name__ == "__main__": paddle.enable_static() unittest.main() -- GitLab