xref: /aosp_15_r20/external/ComputeLibrary/src/dynamic_fusion/sketch/gpu/components/cl/ClComponentResize.cpp (revision c217d954acce2dbc11938adb493fc0abd69584f3)
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 
25 #include "ClComponentResize.h"
26 
27 #include "arm_compute/core/Error.h"
28 #include "src/core/CL/CLValidate.h"
29 #include "src/core/utils/ScaleUtils.h"
30 #include "src/dynamic_fusion/sketch/ArgumentPack.h"
31 #include "src/dynamic_fusion/sketch/gpu/template_writer/cl/ClTemplateResize.h"
32 
33 namespace arm_compute
34 {
35 namespace experimental
36 {
37 namespace dynamic_fusion
38 {
validate(const IGpuKernelComponent::Properties & properties,const ArgumentPack<ITensorInfo> & tensors,const ClComponentResize::Attributes & attributes)39 Status ClComponentResize::validate(const IGpuKernelComponent::Properties &properties,
40                                    const ArgumentPack<ITensorInfo>       &tensors,
41                                    const ClComponentResize::Attributes   &attributes)
42 {
43     ARM_COMPUTE_UNUSED(properties);
44 
45     const ITensorInfo *src = tensors.get_const_tensor(TensorType::ACL_SRC_0);
46     const ITensorInfo *dst = tensors.get_const_tensor(TensorType::ACL_DST_0);
47 
48     // Mismatching data types and quantization info
49     ARM_COMPUTE_RETURN_ERROR_ON_MISMATCHING_DATA_TYPES(src, dst);
50     ARM_COMPUTE_RETURN_ERROR_ON_MISMATCHING_QUANTIZATION_INFO(src, dst);
51 
52     // Device requirements met
53     ARM_COMPUTE_RETURN_ERROR_ON_F16_UNSUPPORTED(src);
54 
55     // Align corners and sampling policy conformance
56     ARM_COMPUTE_RETURN_ERROR_ON(attributes.align_corners() && !arm_compute::scale_utils::is_align_corners_allowed_sampling_policy(attributes.sampling_policy()));
57 
58     // All tensor infos are initialized
59     ARM_COMPUTE_RETURN_ERROR_ON(src->tensor_shape().total_size() == 0);
60     ARM_COMPUTE_RETURN_ERROR_ON(dst->tensor_shape().total_size() == 0);
61 
62     return Status();
63 }
64 
ClComponentResize(ComponentId id,const IGpuKernelComponent::Properties & properties,const ArgumentPack<ITensorInfo> & tensors,const ClComponentResize::Attributes & attributes)65 ClComponentResize::ClComponentResize(ComponentId                            id,
66                                      const IGpuKernelComponent::Properties &properties,
67                                      const ArgumentPack<ITensorInfo>       &tensors,
68                                      const ClComponentResize::Attributes   &attributes)
69     : IGpuKernelComponent{ id, properties, tensors },
70       _component_writer{ std::make_unique<ClTemplateResize>(id, tensors, attributes) }
71 {
72 }
73 
~ClComponentResize()74 ClComponentResize::~ClComponentResize()
75 {
76 }
77 
template_writer() const78 const IGpuTemplateComponentWriter *ClComponentResize::template_writer() const
79 {
80     return _component_writer.get();
81 }
82 
83 } // namespace dynamic_fusion
84 } // namespace experimental
85 } // namespace arm_compute
86