blob: 443c56b7b58cf19f5e3ce75149e937ca2b86d716 [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(
48 const SpaceToBatchNdQueueDescriptor& descriptor, const WorkloadInfo& info)
49 : BaseWorkload<SpaceToBatchNdQueueDescriptor>(descriptor, info)
50{
51 m_Data.ValidateInputsOutputs("ClSpaceToBatchNdWorkload", 1, 1);
52
53 arm_compute::ICLTensor& input =
Jan Eilers3c9e0452020-04-10 13:00:44 +010054 armnn::PolymorphicPointerDowncast<IClTensorHandle>(m_Data.m_Inputs[0])->GetTensor();
Sadik Armaganf4464322018-12-20 16:19:12 +000055 arm_compute::ICLTensor& output =
Jan Eilers3c9e0452020-04-10 13:00:44 +010056 armnn::PolymorphicPointerDowncast<IClTensorHandle>(m_Data.m_Outputs[0])->GetTensor();
Sadik Armaganf4464322018-12-20 16:19:12 +000057
58 // ArmNN blockShape is [H, W] Cl asks for W, H
Matthew Sloyan171214c2020-09-09 09:07:37 +010059 int32_t blockHeight = armnn::numeric_cast<int32_t>(m_Data.m_Parameters.m_BlockShape[0]);
60 int32_t blockWidth = armnn::numeric_cast<int32_t>(m_Data.m_Parameters.m_BlockShape[1]);
Sadik Armaganf4464322018-12-20 16:19:12 +000061
Nattapat Chaimanowong17fa2b42019-02-26 12:26:08 +000062 arm_compute::Size2D paddingLeftTop = BuildArmComputeSize2D(
63 m_Data.m_Parameters.m_PadList[1].first, m_Data.m_Parameters.m_PadList[0].first);
64 arm_compute::Size2D paddingRightBottom = BuildArmComputeSize2D(
65 m_Data.m_Parameters.m_PadList[1].second, m_Data.m_Parameters.m_PadList[0].second);
Sadik Armaganf4464322018-12-20 16:19:12 +000066
67 arm_compute::DataLayout aclDataLayout = ConvertDataLayout(m_Data.m_Parameters.m_DataLayout);
68 input.info()->set_data_layout(aclDataLayout);
69 output.info()->set_data_layout(aclDataLayout);
70
71 m_SpaceToBatchLayer.configure(&input,
72 blockWidth,
73 blockHeight,
Nattapat Chaimanowong17fa2b42019-02-26 12:26:08 +000074 paddingLeftTop,
75 paddingRightBottom,
Sadik Armaganf4464322018-12-20 16:19:12 +000076 &output);
77}
78
79void ClSpaceToBatchNdWorkload::Execute() const
80{
81 ARMNN_SCOPED_PROFILING_EVENT_CL("ClSpaceToBatchNdWorkload_Execute");
82 RunClFunction(m_SpaceToBatchLayer, CHECK_LOCATION());
83}
84
85} //namespace armnn