diff --git a/src/ATen/native/xpu/sycl/CumprodKernel.cpp b/src/ATen/native/xpu/sycl/CumprodKernel.cpp index 6c129183d..f35cc7979 100644 --- a/src/ATen/native/xpu/sycl/CumprodKernel.cpp +++ b/src/ATen/native/xpu/sycl/CumprodKernel.cpp @@ -21,4 +21,22 @@ void launch_cumprod_kernel( }); } +static c10::MaybeOwned contiguous_out_arg(const Tensor& tensor) { + if (tensor.is_contiguous()) { + return c10::MaybeOwned::borrowed(tensor); + } + return c10::MaybeOwned::owned( + at::empty(tensor.sizes(), tensor.options())); +} + +void cumprod_kernel(const Tensor& result, const Tensor& self, int64_t dim) { + auto result_ = contiguous_out_arg(result); + + launch_cumprod_kernel(*result_, self, dim); + + if (!result.is_same(*result_)) { + result.copy_(*result_); + } +} + } // namespace at::native::xpu diff --git a/src/ATen/native/xpu/sycl/CumsumKernel.cpp b/src/ATen/native/xpu/sycl/CumsumKernel.cpp index 8a89b2231..c2754869b 100644 --- a/src/ATen/native/xpu/sycl/CumsumKernel.cpp +++ b/src/ATen/native/xpu/sycl/CumsumKernel.cpp @@ -21,4 +21,22 @@ void launch_cumsum_kernel( }); } +static c10::MaybeOwned contiguous_out_arg(const Tensor& tensor) { + if (tensor.is_contiguous()) { + return c10::MaybeOwned::borrowed(tensor); + } + return c10::MaybeOwned::owned( + at::empty(tensor.sizes(), tensor.options())); +} + +void cumsum_kernel(const Tensor& result, const Tensor& self, int64_t dim) { + auto result_ = contiguous_out_arg(result); + + launch_cumsum_kernel(*result_, self, dim); + + if (!result.is_same(*result_)) { + result.copy_(*result_); + } +} + } // namespace at::native::xpu diff --git a/src/ATen/native/xpu/sycl/ScanKernels.cpp b/src/ATen/native/xpu/sycl/ScanKernels.cpp deleted file mode 100644 index ad97dc4b4..000000000 --- a/src/ATen/native/xpu/sycl/ScanKernels.cpp +++ /dev/null @@ -1,49 +0,0 @@ -#define TORCH_ASSERT_ONLY_METHOD_OPERATORS -#include -#include -#include - -#include - -#ifndef AT_PER_OPERATOR_HEADERS -#include -#include -#else -#include -#include -#endif - -#include -#include - -namespace at::native::xpu { - -static c10::MaybeOwned contiguous_out_arg(const Tensor& tensor) { - if (tensor.is_contiguous()) { - return c10::MaybeOwned::borrowed(tensor); - } - return c10::MaybeOwned::owned( - at::empty(tensor.sizes(), tensor.options())); -} - -void cumsum_kernel(const Tensor& result, const Tensor& self, int64_t dim) { - auto result_ = contiguous_out_arg(result); - - launch_cumsum_kernel(*result_, self, dim); - - if (!result.is_same(*result_)) { - result.copy_(*result_); - } -} - -void cumprod_kernel(const Tensor& result, const Tensor& self, int64_t dim) { - auto result_ = contiguous_out_arg(result); - - launch_cumprod_kernel(*result_, self, dim); - - if (!result.is_same(*result_)) { - result.copy_(*result_); - } -} - -} // namespace at::native::xpu