24.04
GpuSub.h
Go to the documentation of this file.
1
/*
2
* Copyright (c) 2023-2024 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
#ifndef ACL_ARM_COMPUTE_DYNAMIC_FUSION_SKETCH_GPU_OPERATORS_GPUSUB_H
25
#define ACL_ARM_COMPUTE_DYNAMIC_FUSION_SKETCH_GPU_OPERATORS_GPUSUB_H
26
27
#include "
arm_compute/core/Error.h
"
28
29
namespace
arm_compute
30
{
31
/** Forward declaration */
32
class
ITensorInfo;
33
34
namespace
experimental
35
{
36
namespace
dynamic_fusion
37
{
38
/** Forward declaration */
39
class
GpuWorkloadContext;
40
class
GpuWorkloadSketch;
41
42
/** Operator interface. */
43
class
GpuSub
final
44
{
45
public
:
46
/** Create an operator and fuse it into the workload sketch.
47
* @note If @ref validate_op() fails, the creation also fails and may throw an error.
48
* @note If @ref validate_op() fails, @p sketch remains unchanged and valid.
49
*
50
* Valid data type configurations:
51
* |lhs |rhs |dst |
52
* |:--------------|:--------------|:-------------|
53
* |F16 |F16 |F16 |
54
* |F32 |F32 |F32 |
55
*
56
* Valid data layouts:
57
* - Any
58
*
59
* @param[in,out] sketch Workload sketch into which the operator will be fused
60
* @param[in] lhs Left hand side tensor info. Data types supported: U8/S16/S32/F16/F32.
61
* @param[in] rhs Right hand side tensor info. Same as @p lhs.
62
*
63
* @return Pointer for the destination tensor info
64
*/
65
static
ITensorInfo
*
create_op
(
GpuWorkloadSketch
&
sketch
,
ITensorInfo
*lhs,
ITensorInfo
*rhs);
66
67
/** Check if the operator configuration is supported, irrespective of fusion
68
*
69
* @param[in] context Workload context within which the operator is running
70
* @param[in] lhs Left hand side tensor info. Data types supported: U8/S16/S32/F16/F32.
71
* @param[in] rhs Right hand side tensor info. Same as @p lhs.
72
*
73
* @return Status
74
*/
75
static
Status
is_supported_op
(
const
GpuWorkloadContext
&
context
,
const
ITensorInfo
*lhs,
const
ITensorInfo
*rhs);
76
77
/** Validate the operator and check if its configuration is supported and if it can be fused into the workload sketch.
78
*
79
* Parameters are similar to @ref GpuSub::create_op()
80
*
81
* @return Status
82
*/
83
static
Status
validate_op
(
const
GpuWorkloadSketch
&
sketch
,
const
ITensorInfo
*rhs,
const
ITensorInfo
*lhs);
84
};
85
}
// namespace dynamic_fusion
86
}
// namespace experimental
87
}
// namespace arm_compute
88
#endif // ACL_ARM_COMPUTE_DYNAMIC_FUSION_SKETCH_GPU_OPERATORS_GPUSUB_H
arm_compute::experimental::dynamic_fusion::GpuSub::is_supported_op
static Status is_supported_op(const GpuWorkloadContext &context, const ITensorInfo *lhs, const ITensorInfo *rhs)
Check if the operator configuration is supported, irrespective of fusion.
Definition:
GpuSub.cpp:48
arm_compute::test::validation::sketch
GpuWorkloadSketch sketch
Definition:
DirectConv2d.cpp:168
Error.h
arm_compute::experimental::dynamic_fusion::GpuWorkloadSketch
A descriptor of a workload of operators.
Definition:
GpuWorkloadSketch.h:42
arm_compute::Status
Status class.
Definition:
Error.h:52
arm_compute::experimental::dynamic_fusion::GpuWorkloadContext
Provide context necessary for the creation and configuration of a workload e.g.
Definition:
GpuWorkloadContext.h:57
arm_compute::experimental::dynamic_fusion::GpuSub::create_op
static ITensorInfo * create_op(GpuWorkloadSketch &sketch, ITensorInfo *lhs, ITensorInfo *rhs)
Create an operator and fuse it into the workload sketch.
Definition:
GpuSub.cpp:60
arm_compute::experimental::dynamic_fusion::GpuSub
Operator interface.
Definition:
GpuSub.h:43
arm_compute::test::validation::context
auto context
Definition:
DirectConv2d.cpp:167
arm_compute
Copyright (c) 2017-2024 Arm Limited.
Definition:
introduction.dox:24
arm_compute::experimental::dynamic_fusion::GpuSub::validate_op
static Status validate_op(const GpuWorkloadSketch &sketch, const ITensorInfo *rhs, const ITensorInfo *lhs)
Validate the operator and check if its configuration is supported and if it can be fused into the wor...
Definition:
GpuSub.cpp:36
arm_compute::ITensorInfo
Store the tensor's metadata.
Definition:
ITensorInfo.h:44
arm_compute
dynamic_fusion
sketch
gpu
operators
GpuSub.h
Generated on Mon Apr 29 2024 10:53:52 for Compute Library by
1.8.17