// 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/kernels/logical_kernel.h" #include "paddle/phi/backends/gpu/gpu_context.h" #include "paddle/phi/core/kernel_registry.h" #include "paddle/phi/kernels/funcs/elementwise_base.h" #include "paddle/phi/kernels/funcs/logical_functor.h" #include "paddle/phi/kernels/gpu/elementwise.h" namespace phi { #define DEFINE_LOGICAL_BINARY_KERNEL(type) \ template \ void Logical##type##Kernel(const Context& dev_ctx, \ const DenseTensor& x, \ const DenseTensor& y, \ DenseTensor* out) { \ using InT = typename funcs::Logical##type##Functor::ELEMENT_TYPE; \ using OutT = bool; \ dev_ctx.template Alloc(out); \ funcs::Logical##type##Functor binary_func; \ std::vector ins = {&x, &y}; \ std::vector outs = {out}; \ funcs::BroadcastKernel( \ dev_ctx, ins, &outs, -1, binary_func); \ } DEFINE_LOGICAL_BINARY_KERNEL(And) DEFINE_LOGICAL_BINARY_KERNEL(Or) DEFINE_LOGICAL_BINARY_KERNEL(Xor) #undef DEFINE_LOGICAL_BINARY_KERNEL template void LogicalNotKernel(const Context& dev_ctx, const DenseTensor& x, DenseTensor* out) { using InT = typename funcs::LogicalNotFunctor::ELEMENT_TYPE; using OutT = bool; dev_ctx.template Alloc(out); funcs::LogicalNotFunctor unary_func; std::vector ins = {&x}; std::vector outs = {out}; funcs::BroadcastKernel( dev_ctx, ins, &outs, -1, unary_func); } } // namespace phi #define REGISTER_LOGICAL_CUDA_KERNEL(logical_and, func_type) \ PD_REGISTER_KERNEL(logical_and, \ GPU, \ ALL_LAYOUT, \ phi::Logical##func_type##Kernel, \ float, \ double, \ bool, \ int64_t, \ int, \ int8_t, \ int16_t) {} REGISTER_LOGICAL_CUDA_KERNEL(logical_and, And) REGISTER_LOGICAL_CUDA_KERNEL(logical_or, Or) REGISTER_LOGICAL_CUDA_KERNEL(logical_not, Not) REGISTER_LOGICAL_CUDA_KERNEL(logical_xor, Xor)