From 1ef0de81f2b669a088a777fb5af0a13272a8dbb8 Mon Sep 17 00:00:00 2001 From: zhangyikun02 <48021248+zhangyk0314@users.noreply.github.com> Date: Tue, 23 May 2023 11:17:22 +0800 Subject: [PATCH] [XPU] silu op support to use fast_swish (#53980) --- .../phi/kernels/xpu/activation_grad_kernel.cc | 12 +++++++--- paddle/phi/kernels/xpu/activation_kernel.cc | 12 +++++++--- test/xpu/test_activation_op_xpu.py | 24 +++++++++++++++++++ 3 files changed, 42 insertions(+), 6 deletions(-) diff --git a/paddle/phi/kernels/xpu/activation_grad_kernel.cc b/paddle/phi/kernels/xpu/activation_grad_kernel.cc index 8aae57b1e49..62548434eb2 100644 --- a/paddle/phi/kernels/xpu/activation_grad_kernel.cc +++ b/paddle/phi/kernels/xpu/activation_grad_kernel.cc @@ -378,9 +378,15 @@ struct XPUSiluGradFunctor : public funcs::BaseActivationFunctor { const XPUType* y_grad = reinterpret_cast(dout->data()); XPUType* x_grad = reinterpret_cast(dx->data()); - int r = xpu::swish_grad( - dev_ctx.x_context(), x_data, y_grad, x_grad, dx->numel()); - PADDLE_ENFORCE_XDNN_SUCCESS(r, "swish_grad"); + if (std::getenv("XPU_PADDLE_ACT_LUT") != nullptr) { + int r = xpu::fast_swish_grad( + dev_ctx.x_context(), x_data, y_grad, x_grad, dx->numel()); + PADDLE_ENFORCE_XDNN_SUCCESS(r, "fast_swish_grad"); + } else { + int r = xpu::swish_grad( + dev_ctx.x_context(), x_data, y_grad, x_grad, dx->numel()); + PADDLE_ENFORCE_XDNN_SUCCESS(r, "swish_grad"); + } } }; diff --git a/paddle/phi/kernels/xpu/activation_kernel.cc b/paddle/phi/kernels/xpu/activation_kernel.cc index cc2c76c93a3..1d1f33204bc 100644 --- a/paddle/phi/kernels/xpu/activation_kernel.cc +++ b/paddle/phi/kernels/xpu/activation_kernel.cc @@ -333,9 +333,15 @@ struct XPUSiluFunctor : public funcs::BaseActivationFunctor { XPUType* y_data = reinterpret_cast(out->data()); auto xpu_context = dev_ctx.x_context(); - int r = - xpu::swish(xpu_context, x_data, y_data, x.numel(), nullptr, nullptr); - PADDLE_ENFORCE_XDNN_SUCCESS(r, "swish"); + if (std::getenv("XPU_PADDLE_ACT_LUT") != nullptr) { + int r = xpu::fast_swish( + xpu_context, x_data, y_data, x.numel(), nullptr, nullptr); + PADDLE_ENFORCE_XDNN_SUCCESS(r, "fast_swish"); + } else { + int r = + xpu::swish(xpu_context, x_data, y_data, x.numel(), nullptr, nullptr); + PADDLE_ENFORCE_XDNN_SUCCESS(r, "swish"); + } } }; diff --git a/test/xpu/test_activation_op_xpu.py b/test/xpu/test_activation_op_xpu.py index a877b09bbc9..c0934cdded1 100644 --- a/test/xpu/test_activation_op_xpu.py +++ b/test/xpu/test_activation_op_xpu.py @@ -17,6 +17,8 @@ import unittest sys.path.append('../../python/paddle/fluid/tests/unittests') +import os + import numpy as np from eager_op_test import OpTest from get_test_cover_info import ( @@ -105,16 +107,38 @@ class XPUTestSiluOP(XPUOpTestWrapper): self.outputs = {'Out': out} self.attrs = {'use_xpu': True} + def test_check_output(self): + self.set_env() + self.check_output_with_place(self.place) + self.delete_env() + def test_check_grad(self): + self.set_env() self.check_grad_with_place(self.place, ['X'], 'Out') + self.delete_env() def init_shape(self): self.shape = [11, 17] + def set_env(self): + pass + + def delete_env(self): + pass + class TestSilu_ZeroDim(XPUTestSilu): def init_shape(self): self.shape = [] + class TestSilu_LUT(XPUTestSilu): + def set_env(self): + # set "XPU_PADDLE_ACT_LUT" env to enable lut + os.environ['XPU_PADDLE_ACT_LUT'] = "1" + + def delete_env(self): + if os.getenv('XPU_PADDLE_ACT_LUT'): + del os.environ['XPU_PADDLE_ACT_LUT'] + class TestSiluAPI(unittest.TestCase): # test paddle.nn.Silu, paddle.nn.functional.silu -- GitLab