blob: 53b0bbb32f50b54c74560f3ba0fd3a5fa1493360 [file] [log] [blame]
Ellen Norris-Thompson37e68682019-07-15 14:23:30 +01001//
Mike Kelly7cbe7812023-07-25 17:37:33 +01002// Copyright © 2019-2023 Arm Ltd and Contributors. All rights reserved.
Ellen Norris-Thompson37e68682019-07-15 14:23:30 +01003// SPDX-License-Identifier: MIT
4//
5
6#include "NeonResizeWorkload.hpp"
7
8#include "NeonWorkloadUtils.hpp"
9
10#include <aclCommon/ArmComputeUtils.hpp>
11#include <aclCommon/ArmComputeTensorUtils.hpp>
Jan Eilersbb446e52020-04-02 13:56:54 +010012#include <armnn/utility/PolymorphicDowncast.hpp>
Colm Donelan0c479742021-12-10 12:43:54 +000013#include <armnn/backends/TensorHandle.hpp>
Jan Eilersbb446e52020-04-02 13:56:54 +010014
Ellen Norris-Thompson37e68682019-07-15 14:23:30 +010015#include <neon/NeonTensorHandle.hpp>
16
17using namespace armnn::armcomputetensorutils;
18
19namespace armnn
20{
21
22arm_compute::Status NeonResizeWorkloadValidate(const TensorInfo& input,
23 const TensorInfo& output,
24 const ResizeDescriptor& descriptor)
25{
26 arm_compute::TensorInfo aclInputInfo = BuildArmComputeTensorInfo(input);
27 arm_compute::TensorInfo aclOutputInfo = BuildArmComputeTensorInfo(output);
28
29 arm_compute::DataLayout aclDataLayout = ConvertDataLayout(descriptor.m_DataLayout);
30 aclInputInfo.set_data_layout(aclDataLayout);
31 aclOutputInfo.set_data_layout(aclDataLayout);
32
33 arm_compute::InterpolationPolicy aclInterpolationPolicy =
34 ConvertResizeMethodToAclInterpolationPolicy(descriptor.m_Method);
35
David Monahan9b14bfc2020-06-30 15:57:56 +010036 arm_compute::SamplingPolicy samplingPolicy = descriptor.m_HalfPixelCenters ? arm_compute::SamplingPolicy::CENTER :
37 arm_compute::SamplingPolicy::TOP_LEFT;
38
Teresa Charlinef05cdb2020-10-05 09:53:18 +010039 bool usePadding = false;
40
Ellen Norris-Thompson37e68682019-07-15 14:23:30 +010041 return arm_compute::NEScale::validate(&aclInputInfo,
42 &aclOutputInfo,
David Monahan9b14bfc2020-06-30 15:57:56 +010043 arm_compute::ScaleKernelInfo(aclInterpolationPolicy,
44 arm_compute::BorderMode::REPLICATE,
45 arm_compute::PixelValue(0.f),
46 samplingPolicy,
Teresa Charlinef05cdb2020-10-05 09:53:18 +010047 usePadding,
David Monahan9b14bfc2020-06-30 15:57:56 +010048 descriptor.m_AlignCorners));
49
Ellen Norris-Thompson37e68682019-07-15 14:23:30 +010050}
51
52NeonResizeWorkload::NeonResizeWorkload(const ResizeQueueDescriptor& descriptor,
53 const WorkloadInfo& info)
Teresa Charlin588cbdf2022-01-19 15:55:37 +000054 : NeonBaseWorkload<ResizeQueueDescriptor>(descriptor, info)
Ellen Norris-Thompson37e68682019-07-15 14:23:30 +010055{
Keith Davis2d0679f2021-08-05 11:35:00 +010056 // Report Profiling Details
57 ARMNN_REPORT_PROFILING_WORKLOAD_DESC("NeonResizeWorkload_Construct",
58 descriptor.m_Parameters,
59 info,
60 this->GetGuid());
61
Ellen Norris-Thompson37e68682019-07-15 14:23:30 +010062 m_Data.ValidateInputsOutputs("NeonResizeWorkload", 1, 1);
63
Jan Eilersbb446e52020-04-02 13:56:54 +010064 arm_compute::ITensor& input = PolymorphicDowncast<IAclTensorHandle*>(m_Data.m_Inputs[0])->GetTensor();
65 arm_compute::ITensor& output = PolymorphicDowncast<IAclTensorHandle*>(m_Data.m_Outputs[0])->GetTensor();
Ellen Norris-Thompson37e68682019-07-15 14:23:30 +010066
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 arm_compute::InterpolationPolicy aclInterpolationPolicy =
72 ConvertResizeMethodToAclInterpolationPolicy(descriptor.m_Parameters.m_Method);
73
David Monahan9b14bfc2020-06-30 15:57:56 +010074 arm_compute::SamplingPolicy samplingPolicy = descriptor.m_Parameters.m_HalfPixelCenters
75 ? arm_compute::SamplingPolicy::CENTER
76 : arm_compute::SamplingPolicy::TOP_LEFT;
77
Teresa Charlinef05cdb2020-10-05 09:53:18 +010078 bool usePadding = false;
79
Ellen Norris-Thompson37e68682019-07-15 14:23:30 +010080 m_ResizeLayer.configure(&input,
81 &output,
David Monahan9b14bfc2020-06-30 15:57:56 +010082 arm_compute::ScaleKernelInfo(aclInterpolationPolicy,
83 arm_compute::BorderMode::REPLICATE,
84 arm_compute::PixelValue(0.f),
85 samplingPolicy,
Teresa Charlinef05cdb2020-10-05 09:53:18 +010086 usePadding,
David Monahan9b14bfc2020-06-30 15:57:56 +010087 descriptor.m_Parameters.m_AlignCorners));
Ellen Norris-Thompson37e68682019-07-15 14:23:30 +010088};
89
90void NeonResizeWorkload::Execute() const
91{
Mike Kelly7cbe7812023-07-25 17:37:33 +010092 ARMNN_SCOPED_PROFILING_EVENT_NEON_NAME_GUID("NeonResizeWorkload_Execute");
Ellen Norris-Thompson37e68682019-07-15 14:23:30 +010093 m_ResizeLayer.run();
94}
95
96} //namespace armnn