blob: 171edc6c59462efaa9f41e796f0f212fe0d6c1a3 [file] [log] [blame]
josh minor036f02d2019-11-15 14:53:22 -06001//
2// Copyright © 2019 Arm Ltd. All rights reserved.
3// SPDX-License-Identifier: MIT
4//
5
6#include "NeonSliceWorkload.hpp"
7
8#include "NeonWorkloadUtils.hpp"
9
10#include <aclCommon/ArmComputeTensorUtils.hpp>
11
12#include <neon/NeonTensorHandle.hpp>
13
14#include <arm_compute/core/Error.h>
15
16namespace armnn
17{
18
19arm_compute::Status NeonSliceWorkloadValidate(const TensorInfo& input,
20 const TensorInfo& output,
21 const SliceDescriptor& descriptor)
22{
23 const arm_compute::TensorInfo aclInputInfo = armcomputetensorutils::BuildArmComputeTensorInfo(input);
24 const arm_compute::TensorInfo aclOutputInfo = armcomputetensorutils::BuildArmComputeTensorInfo(output);
25
26 arm_compute::Coordinates starts;
27 arm_compute::Coordinates ends;
28
29 std::tie(starts, ends) = SetNeonSliceData(descriptor.m_Begin, descriptor.m_Size);
30
31 return arm_compute::NESlice::validate(&aclInputInfo, &aclOutputInfo, starts, ends);
32}
33
34NeonSliceWorkload::NeonSliceWorkload(const SliceQueueDescriptor& descriptor,
35 const WorkloadInfo& info)
36 : BaseWorkload<SliceQueueDescriptor>(descriptor, info)
37{
38 m_Data.ValidateInputsOutputs("NeonSliceWorkload", 1, 1);
39
40 arm_compute::ITensor& input = boost::polymorphic_downcast<IAclTensorHandle*>(m_Data.m_Inputs[0])->GetTensor();
41 arm_compute::ITensor& output = boost::polymorphic_downcast<IAclTensorHandle*>(m_Data.m_Outputs[0])->GetTensor();
42
43 arm_compute::Coordinates starts;
44 arm_compute::Coordinates ends;
45
46 std::tie(starts, ends) = SetNeonSliceData(m_Data.m_Parameters.m_Begin, m_Data.m_Parameters.m_Size);
47
48 m_SliceFunction.configure(&input, &output, starts, ends);
49}
50
51void NeonSliceWorkload::Execute() const
52{
53 ARMNN_SCOPED_PROFILING_EVENT_NEON("NeonSliceWorkload_Execute");
54 m_SliceFunction.run();
55}
56
57} // namespace armnn