blob: 7b29cded0f20fa59005188829744e8c713de7945 [file] [log] [blame]
Sadik Armaganf4464322018-12-20 16:19:12 +00001//
2// Copyright © 2017 Arm Ltd. All rights reserved.
3// SPDX-License-Identifier: MIT
4//
5
6#include "ClSpaceToBatchNdWorkload.hpp"
7
8#include "ClWorkloadUtils.hpp"
9
10#include <aclCommon/ArmComputeUtils.hpp>
11#include <aclCommon/ArmComputeTensorUtils.hpp>
Matthew Sloyan171214c2020-09-09 09:07:37 +010012#include <armnn/utility/NumericCast.hpp>
Jan Eilers3c9e0452020-04-10 13:00:44 +010013#include <armnn/utility/PolymorphicDowncast.hpp>
Sadik Armaganf4464322018-12-20 16:19:12 +000014#include <backendsCommon/CpuTensorHandle.hpp>
15#include <cl/ClLayerSupport.hpp>
16#include <cl/ClTensorHandle.hpp>
17#include <cl/ClLayerSupport.hpp>
18
Sadik Armaganf4464322018-12-20 16:19:12 +000019namespace armnn
20{
21using namespace armcomputetensorutils;
22
23arm_compute::Status ClSpaceToBatchNdWorkloadValidate(const TensorInfo& input,
24 const TensorInfo& output,
25 const SpaceToBatchNdDescriptor& descriptor)
26{
27 const arm_compute::TensorInfo aclInputInfo = BuildArmComputeTensorInfo(input, descriptor.m_DataLayout);
28 const arm_compute::TensorInfo aclOutputInfo = BuildArmComputeTensorInfo(output, descriptor.m_DataLayout);
29
30 // ArmNN blockShape is [H, W] Cl asks for W, H
Matthew Sloyan171214c2020-09-09 09:07:37 +010031 int32_t blockHeight = armnn::numeric_cast<int32_t>(descriptor.m_BlockShape[0]);
32 int32_t blockWidth = armnn::numeric_cast<int32_t>(descriptor.m_BlockShape[1]);
Sadik Armaganf4464322018-12-20 16:19:12 +000033
Nattapat Chaimanowong17fa2b42019-02-26 12:26:08 +000034 arm_compute::Size2D paddingLeftTop = BuildArmComputeSize2D(
35 descriptor.m_PadList[1].first, descriptor.m_PadList[0].first);
36 arm_compute::Size2D paddingRightBottom = BuildArmComputeSize2D(
37 descriptor.m_PadList[1].second, descriptor.m_PadList[0].second);
Sadik Armaganf4464322018-12-20 16:19:12 +000038
39 return arm_compute::CLSpaceToBatchLayer::validate(&aclInputInfo,
40 blockWidth,
41 blockHeight,
Nattapat Chaimanowong17fa2b42019-02-26 12:26:08 +000042 paddingLeftTop,
43 paddingRightBottom,
Sadik Armaganf4464322018-12-20 16:19:12 +000044 &aclOutputInfo);
45}
46
47ClSpaceToBatchNdWorkload::ClSpaceToBatchNdWorkload(
Sadik Armagane9444752020-12-02 11:28:58 +000048 const SpaceToBatchNdQueueDescriptor& descriptor,
49 const WorkloadInfo& info,
50 const arm_compute::CLCompileContext& clCompileContext)
Sadik Armaganf4464322018-12-20 16:19:12 +000051 : BaseWorkload<SpaceToBatchNdQueueDescriptor>(descriptor, info)
52{
53 m_Data.ValidateInputsOutputs("ClSpaceToBatchNdWorkload", 1, 1);
54
55 arm_compute::ICLTensor& input =
Jan Eilers3c9e0452020-04-10 13:00:44 +010056 armnn::PolymorphicPointerDowncast<IClTensorHandle>(m_Data.m_Inputs[0])->GetTensor();
Sadik Armaganf4464322018-12-20 16:19:12 +000057 arm_compute::ICLTensor& output =
Jan Eilers3c9e0452020-04-10 13:00:44 +010058 armnn::PolymorphicPointerDowncast<IClTensorHandle>(m_Data.m_Outputs[0])->GetTensor();
Sadik Armaganf4464322018-12-20 16:19:12 +000059
60 // ArmNN blockShape is [H, W] Cl asks for W, H
Matthew Sloyan171214c2020-09-09 09:07:37 +010061 int32_t blockHeight = armnn::numeric_cast<int32_t>(m_Data.m_Parameters.m_BlockShape[0]);
62 int32_t blockWidth = armnn::numeric_cast<int32_t>(m_Data.m_Parameters.m_BlockShape[1]);
Sadik Armaganf4464322018-12-20 16:19:12 +000063
Nattapat Chaimanowong17fa2b42019-02-26 12:26:08 +000064 arm_compute::Size2D paddingLeftTop = BuildArmComputeSize2D(
65 m_Data.m_Parameters.m_PadList[1].first, m_Data.m_Parameters.m_PadList[0].first);
66 arm_compute::Size2D paddingRightBottom = BuildArmComputeSize2D(
67 m_Data.m_Parameters.m_PadList[1].second, m_Data.m_Parameters.m_PadList[0].second);
Sadik Armaganf4464322018-12-20 16:19:12 +000068
69 arm_compute::DataLayout aclDataLayout = ConvertDataLayout(m_Data.m_Parameters.m_DataLayout);
70 input.info()->set_data_layout(aclDataLayout);
71 output.info()->set_data_layout(aclDataLayout);
72
Sadik Armagane9444752020-12-02 11:28:58 +000073 m_SpaceToBatchLayer.configure(clCompileContext,
74 &input,
Sadik Armaganf4464322018-12-20 16:19:12 +000075 blockWidth,
76 blockHeight,
Nattapat Chaimanowong17fa2b42019-02-26 12:26:08 +000077 paddingLeftTop,
78 paddingRightBottom,
Sadik Armaganf4464322018-12-20 16:19:12 +000079 &output);
80}
81
82void ClSpaceToBatchNdWorkload::Execute() const
83{
84 ARMNN_SCOPED_PROFILING_EVENT_CL("ClSpaceToBatchNdWorkload_Execute");
85 RunClFunction(m_SpaceToBatchLayer, CHECK_LOCATION());
86}
87
88} //namespace armnn