blob: 2c74955ae4f4d6e8a7c954f615d0c20f2eada37e [file] [log] [blame]
Anthony Barbier6ff3b192017-09-04 18:44:23 +01001/*
Michele Di Giorgiod9eaf612020-07-08 11:12:57 +01002 * Copyright (c) 2016-2020 Arm Limited.
Anthony Barbier6ff3b192017-09-04 18:44:23 +01003 *
4 * SPDX-License-Identifier: MIT
5 *
6 * Permission is hereby granted, free of charge, to any person obtaining a copy
7 * of this software and associated documentation files (the "Software"), to
8 * deal in the Software without restriction, including without limitation the
9 * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
10 * sell copies of the Software, and to permit persons to whom the Software is
11 * furnished to do so, subject to the following conditions:
12 *
13 * The above copyright notice and this permission notice shall be included in all
14 * copies or substantial portions of the Software.
15 *
16 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
19 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
21 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
22 * SOFTWARE.
23 */
Manuel Bottini63bb7ca2020-12-02 13:22:14 +000024#ifndef ARM_COMPUTE_CLBITWISEKERNEL_H
25#define ARM_COMPUTE_CLBITWISEKERNEL_H
Anthony Barbier6ff3b192017-09-04 18:44:23 +010026
Sang-Hoon Parkbef7fa22020-10-21 15:58:54 +010027#include "src/core/CL/ICLKernel.h"
Anthony Barbier6ff3b192017-09-04 18:44:23 +010028
29namespace arm_compute
30{
31class ICLTensor;
32
Manuel Bottini63bb7ca2020-12-02 13:22:14 +000033/** Interface for the bitwise operation kernel.
Anthony Barbier6ff3b192017-09-04 18:44:23 +010034 *
Manuel Bottini63bb7ca2020-12-02 13:22:14 +000035 * Result depends on the \ref BitwiseOperation and is computed by:
36 * AND operation: @f[ output(x,y) = input1(x,y) \land input2(x,y) @f]
37 * NOT operation: @f[ output(x,y) = \lnot input1(x,y) @f]
38 * OR operation: @f[ output(x,y) = input1(x,y) \lor input2(x,y) @f]
39 * XOR operation: @f[ output(x,y) = input1(x,y) \oplus input2(x,y) @f]
Anthony Barbier6ff3b192017-09-04 18:44:23 +010040 */
Manuel Bottini63bb7ca2020-12-02 13:22:14 +000041class CLBitwiseKernel : public ICLKernel
Anthony Barbier6ff3b192017-09-04 18:44:23 +010042{
43public:
44 /** Default constructor. */
Manuel Bottini63bb7ca2020-12-02 13:22:14 +000045 CLBitwiseKernel();
Alex Gildayc357c472018-03-21 13:54:09 +000046 /** Prevent instances of this class from being copied (As this class contains pointers) */
Manuel Bottini63bb7ca2020-12-02 13:22:14 +000047 CLBitwiseKernel(const CLBitwiseKernel &) = delete;
Alex Gildayc357c472018-03-21 13:54:09 +000048 /** Prevent instances of this class from being copied (As this class contains pointers) */
Manuel Bottini63bb7ca2020-12-02 13:22:14 +000049 CLBitwiseKernel &operator=(const CLBitwiseKernel &) = delete;
Anthony Barbier6ff3b192017-09-04 18:44:23 +010050 /** Allow instances of this class to be moved */
Manuel Bottini63bb7ca2020-12-02 13:22:14 +000051 CLBitwiseKernel(CLBitwiseKernel &&) = default;
Anthony Barbier6ff3b192017-09-04 18:44:23 +010052 /** Allow instances of this class to be moved */
Manuel Bottini63bb7ca2020-12-02 13:22:14 +000053 CLBitwiseKernel &operator=(CLBitwiseKernel &&) = default;
54 /** Set the inputs and output tensors
Manuel Bottini4c6bd512020-04-08 10:15:51 +010055 *
56 * @param[in] compile_context The compile context to be used.
57 * @param[in] input1 Source tensor. Data types supported: U8.
58 * @param[in] input2 Source tensor. Data types supported: U8.
59 * @param[out] output Destination tensor. Data types supported: U8.
Manuel Bottini63bb7ca2020-12-02 13:22:14 +000060 * @param[in] op Bitwise operation to perform. Supported: AND, OR, NOT, XOR.
Manuel Bottini4c6bd512020-04-08 10:15:51 +010061 */
Felix Thomasmathibalanafd38f02023-09-27 17:46:17 +010062 void configure(const CLCompileContext &compile_context,
63 const ICLTensor *input1,
64 const ICLTensor *input2,
65 ICLTensor *output,
66 BitwiseOperation op);
Anthony Barbier6ff3b192017-09-04 18:44:23 +010067
68 // Inherited methods overridden:
69 void run(const Window &window, cl::CommandQueue &queue) override;
70
71private:
72 const ICLTensor *_input1; /**< Source tensor 1 */
73 const ICLTensor *_input2; /**< Source tensor 2 */
74 ICLTensor *_output; /**< Destination tensor */
75};
Gian Marco Iodicef670a0a2017-09-18 12:20:45 +010076} // namespace arm_compute
Manuel Bottini63bb7ca2020-12-02 13:22:14 +000077#endif /* ARM_COMPUTE_CLBITWISEKERNEL_H */