24.02.1
ClDirectConvDefaultConfigBifrost.h
Go to the documentation of this file.
1
/*
2
* Copyright (c) 2022 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 SRC_RUNTIME_HEURISTICS_DIRECT_CONV_CLDIRECTCONVDEFAULTCONFIGBIFROST
25
#define SRC_RUNTIME_HEURISTICS_DIRECT_CONV_CLDIRECTCONVDEFAULTCONFIGBIFROST
26
27
#include "
src/runtime/heuristics/direct_conv/IClDirectConvKernelConfig.h
"
28
29
namespace
arm_compute
30
{
31
namespace
cl_direct_conv
32
{
33
/** Bifrost based OpenCL direct convolution configuration */
34
class
ClDirectConvDefaultConfigBifrost
final :
public
IClDirectConvKernelConfig
35
{
36
public
:
37
/** Constructor
38
*
39
* @param[in] gpu GPU target
40
*/
41
ClDirectConvDefaultConfigBifrost
(
GPUTarget
gpu);
42
43
// Inherited overridden method
44
DirectConvComputeKernelInfo
45
configure
(
const
ITensorInfo
*
src
,
const
ITensorInfo
*wei,
const
PadStrideInfo
&
conv_info
)
override
;
46
47
private
:
48
DirectConvComputeKernelInfo
49
configure_G71_f32(
const
ITensorInfo
*
src
,
const
ITensorInfo
*wei,
const
PadStrideInfo
&
conv_info
);
50
DirectConvComputeKernelInfo
51
configure_G71_f16(
const
ITensorInfo
*
src
,
const
ITensorInfo
*wei,
const
PadStrideInfo
&
conv_info
);
52
DirectConvComputeKernelInfo
53
configure_G71_u8(
const
ITensorInfo
*
src
,
const
ITensorInfo
*wei,
const
PadStrideInfo
&
conv_info
);
54
DirectConvComputeKernelInfo
55
configure_default_f32(
const
ITensorInfo
*
src
,
const
ITensorInfo
*wei,
const
PadStrideInfo
&
conv_info
);
56
DirectConvComputeKernelInfo
57
configure_default_f16(
const
ITensorInfo
*
src
,
const
ITensorInfo
*wei,
const
PadStrideInfo
&
conv_info
);
58
};
59
}
// namespace cl_direct_conv
60
}
// namespace arm_compute
61
#endif
/* SRC_RUNTIME_HEURISTICS_DIRECT_CONV_CLDIRECTCONVDEFAULTCONFIGBIFROST */
arm_compute::test::validation::src
SimpleTensor< float > src
Definition:
DFT.cpp:155
arm_compute::cl_direct_conv::ClDirectConvDefaultConfigBifrost::ClDirectConvDefaultConfigBifrost
ClDirectConvDefaultConfigBifrost(GPUTarget gpu)
Constructor.
Definition:
ClDirectConvDefaultConfigBifrost.cpp:41
arm_compute::cl_direct_conv::ClDirectConvDefaultConfigBifrost
Bifrost based OpenCL direct convolution configuration.
Definition:
ClDirectConvDefaultConfigBifrost.h:34
IClDirectConvKernelConfig.h
arm_compute::cl_direct_conv::IClDirectConvKernelConfig
Basic interface for the Direct convolution kernel configuration.
Definition:
IClDirectConvKernelConfig.h:88
arm_compute::cl_direct_conv::ClDirectConvDefaultConfigBifrost::configure
DirectConvComputeKernelInfo configure(const ITensorInfo *src, const ITensorInfo *wei, const PadStrideInfo &conv_info) override
This method returns the DirectConvComputeKernelInfo for the given inputs.
Definition:
ClDirectConvDefaultConfigBifrost.cpp:45
arm_compute::PadStrideInfo
Definition:
CoreTypes.h:139
arm_compute::GPUTarget
GPUTarget
Available GPU Targets.
Definition:
GPUTarget.h:34
arm_compute
Copyright (c) 2017-2024 Arm Limited.
Definition:
introduction.dox:24
arm_compute::test::validation::conv_info
conv_info
Definition:
DirectConvolutionLayer.cpp:547
arm_compute::ITensorInfo
Store the tensor's metadata.
Definition:
ITensorInfo.h:44
arm_compute::DirectConvComputeKernelInfo
Compute descriptor used by the direct convolution kernel.
Definition:
KernelDescriptors.h:124
src
runtime
heuristics
direct_conv
ClDirectConvDefaultConfigBifrost.h
Generated on Mon Mar 18 2024 11:32:04 for Compute Library by
1.8.17