blob: 78027f1ed5eb6c81e76d8daa13dd8ab7986dfd2b [file] [log] [blame]
Nikolaj Jensen5ff48022023-06-27 14:13:24 +01001/*
2* Copyright (c) 2023 Arm Limited.
3*
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*/
24
25#ifndef CKW_INCLUDE_CKW_OPERATORS_H
26#define CKW_INCLUDE_CKW_OPERATORS_H
27
28#include <cstdint>
29
30namespace ckw
31{
32
33enum class UnaryOp : int32_t
34{
35 LogicalNot = 0x0000, // !
36};
37
38/* Binary operations
39*/
40enum class BinaryOp : int32_t
41{
42 // Elementwise
43 Add = 0x0000, // +
44 Sub = 0x0001, // -
45 Mul = 0x0002, // *
46 Div = 0x0003, // /
47 Mod = 0x0004, // %
48 // Relational
49 Equal = 0x1000, // ==
50 Less = 0x1001, // <
51 LessEqual = 0x1002, // <=
52 Greater = 0x1003, // >
53 GreaterEqual = 0x1004, // >=
54 // Algebra
55 MatMul_Nt_Nt = 0x2000, // X
56 MatMul_Nt_T = 0x2001, // X
57 MatMul_T_Nt = 0x2002, // X
58 MatMul_T_T = 0x2003, // X
59 Dot = 0x2004, // .
60 // Logical
61 LogicalAnd = 0x3000, // &&
62 LogicalOr = 0x3001, // ||
63};
64
65enum class AssignmentOp : int32_t
66{
67 // Unary
68 Increment = 0x0000, // +=
69 Decrement = 0x0001, // -=
70};
71
72} // namespace ckw
73
74#endif //CKW_INCLUDE_CKW_OPERATORS_H