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