blob: 509c783c7e93f51222aa40bb5d0da18d3d139284 [file] [log] [blame]
Aron Virginas-Tar2f00b742019-09-30 13:28:08 +01001//
Mike Kelly7cbe7812023-07-25 17:37:33 +01002// Copyright © 2019-2023 Arm Ltd and Contributors. All rights reserved.
Aron Virginas-Tar2f00b742019-09-30 13:28:08 +01003// SPDX-License-Identifier: MIT
4//
5
6#include "NeonDepthToSpaceWorkload.hpp"
7
8#include "NeonWorkloadUtils.hpp"
9
10#include <aclCommon/ArmComputeTensorUtils.hpp>
Matthew Sloyan171214c2020-09-09 09:07:37 +010011#include <armnn/utility/NumericCast.hpp>
Jan Eilers3c9e0452020-04-10 13:00:44 +010012#include <armnn/utility/PolymorphicDowncast.hpp>
Aron Virginas-Tar2f00b742019-09-30 13:28:08 +010013
Aron Virginas-Tar2f00b742019-09-30 13:28:08 +010014namespace armnn
15{
16
17using namespace armcomputetensorutils;
18
19arm_compute::Status NeonDepthToSpaceWorkloadValidate(const TensorInfo& input,
20 const TensorInfo& output,
21 const DepthToSpaceDescriptor& descriptor)
22{
23 DataLayout dataLayout = descriptor.m_DataLayout;
24 const arm_compute::TensorInfo aclInput = BuildArmComputeTensorInfo(input, dataLayout);
25 const arm_compute::TensorInfo aclOutput = BuildArmComputeTensorInfo(output, dataLayout);
26
Matthew Sloyan171214c2020-09-09 09:07:37 +010027 int32_t blockSize = armnn::numeric_cast<int32_t>(descriptor.m_BlockSize);
Aron Virginas-Tar2f00b742019-09-30 13:28:08 +010028
29 return arm_compute::NEDepthToSpaceLayer::validate(&aclInput, &aclOutput, blockSize);
30}
31
Keith Davis2d0679f2021-08-05 11:35:00 +010032NeonDepthToSpaceWorkload::NeonDepthToSpaceWorkload(const DepthToSpaceQueueDescriptor& descriptor,
Aron Virginas-Tar2f00b742019-09-30 13:28:08 +010033 const WorkloadInfo& info)
Teresa Charlin588cbdf2022-01-19 15:55:37 +000034 : NeonBaseWorkload<DepthToSpaceQueueDescriptor>(descriptor, info)
Aron Virginas-Tar2f00b742019-09-30 13:28:08 +010035{
Keith Davis2d0679f2021-08-05 11:35:00 +010036 // Report Profiling Details
37 ARMNN_REPORT_PROFILING_WORKLOAD_DESC("NeonDepthToSpaceWorkload_Construct",
38 descriptor.m_Parameters,
39 info,
40 this->GetGuid());
41
Aron Virginas-Tar2f00b742019-09-30 13:28:08 +010042 m_Data.ValidateInputsOutputs("NeonDepthToSpaceWorkload", 1, 1);
43
44 arm_compute::DataLayout aclDataLayout = ConvertDataLayout(m_Data.m_Parameters.m_DataLayout);
45
46 arm_compute::ITensor& input =
Jan Eilers3c9e0452020-04-10 13:00:44 +010047 PolymorphicPointerDowncast<IAclTensorHandle>(m_Data.m_Inputs[0])->GetTensor();
Aron Virginas-Tar2f00b742019-09-30 13:28:08 +010048 input.info()->set_data_layout(aclDataLayout);
49
Keith Davis2d0679f2021-08-05 11:35:00 +010050 int32_t blockSize = armnn::numeric_cast<int32_t>(descriptor.m_Parameters.m_BlockSize);
Aron Virginas-Tar2f00b742019-09-30 13:28:08 +010051
52 arm_compute::ITensor& output =
Jan Eilers3c9e0452020-04-10 13:00:44 +010053 PolymorphicPointerDowncast<IAclTensorHandle>(m_Data.m_Outputs[0])->GetTensor();
Aron Virginas-Tar2f00b742019-09-30 13:28:08 +010054 output.info()->set_data_layout(aclDataLayout);
55
56 m_Layer.configure(&input, &output, blockSize);
57 m_Layer.prepare();
58}
59
60void NeonDepthToSpaceWorkload::Execute() const
61{
Mike Kelly7cbe7812023-07-25 17:37:33 +010062 ARMNN_SCOPED_PROFILING_EVENT_NEON_NAME_GUID("NeonDepthToSpaceWorkload_Execute");
Aron Virginas-Tar2f00b742019-09-30 13:28:08 +010063 m_Layer.run();
64}
65
66} // namespace armnn