blob: 8cf97d390927fdde8d74307d20944041cf53e0ae [file] [log] [blame]
telsoa014fcda012018-03-09 14:13:49 +00001//
2// Copyright © 2017 Arm Ltd. All rights reserved.
David Beckecb56cd2018-09-05 12:52:57 +01003// SPDX-License-Identifier: MIT
telsoa014fcda012018-03-09 14:13:49 +00004//
5#pragma once
6
Aron Virginas-Tarc9cc8042018-11-01 16:15:57 +00007#include <backendsCommon/Workload.hpp>
8#include <aclCommon/ArmComputeTensorUtils.hpp>
9#include <neon/NeonTensorHandle.hpp>
10#include <neon/NeonTimer.hpp>
11#include <backendsCommon/CpuTensorHandle.hpp>
telsoa014fcda012018-03-09 14:13:49 +000012
Nattapat Chaimanowong177d8d22018-10-16 13:21:27 +010013#include <Half.hpp>
telsoa014fcda012018-03-09 14:13:49 +000014
Nattapat Chaimanowong177d8d22018-10-16 13:21:27 +010015#define ARMNN_SCOPED_PROFILING_EVENT_NEON(name) \
telsoa01c577f2c2018-08-31 09:22:23 +010016 ARMNN_SCOPED_PROFILING_EVENT_WITH_INSTRUMENTS(armnn::Compute::CpuAcc, \
17 name, \
Nina Drozd69851b52018-09-21 18:42:09 +010018 armnn::NeonTimer(), \
19 armnn::WallClockTimer())
Nattapat Chaimanowong177d8d22018-10-16 13:21:27 +010020
21using namespace armnn::armcomputetensorutils;
22
23namespace armnn
24{
25
26template <typename T>
27void CopyArmComputeTensorData(arm_compute::Tensor& dstTensor, const T* srcData)
28{
29 InitialiseArmComputeTensorEmpty(dstTensor);
30 CopyArmComputeITensorData(srcData, dstTensor);
31}
32
33inline void InitializeArmComputeTensorData(arm_compute::Tensor& tensor,
34 const ConstCpuTensorHandle* handle)
35{
36 BOOST_ASSERT(handle);
37
38 switch(handle->GetTensorInfo().GetDataType())
39 {
40 case DataType::Float16:
41 CopyArmComputeTensorData(tensor, handle->GetConstTensor<armnn::Half>());
42 break;
43 case DataType::Float32:
44 CopyArmComputeTensorData(tensor, handle->GetConstTensor<float>());
45 break;
46 case DataType::QuantisedAsymm8:
47 CopyArmComputeTensorData(tensor, handle->GetConstTensor<uint8_t>());
48 break;
49 case DataType::Signed32:
50 CopyArmComputeTensorData(tensor, handle->GetConstTensor<int32_t>());
51 break;
52 default:
53 BOOST_ASSERT_MSG(false, "Unexpected tensor type.");
54 }
55};
56
FinnWilliamsArm1fa19192019-08-02 17:26:31 +010057inline auto SetNeonStridedSliceData(const std::vector<int>& m_begin,
58 const std::vector<int>& m_end,
59 const std::vector<int>& m_stride)
60{
61 arm_compute::Coordinates starts;
62 arm_compute::Coordinates ends;
63 arm_compute::Coordinates strides;
64
65 unsigned int num_dims = static_cast<unsigned int>(m_begin.size());
66
67 for (unsigned int i = 0; i < num_dims; i++)
68 {
69 unsigned int revertedIndex = num_dims - i - 1;
70
71 starts.set(i, static_cast<int>(m_begin[revertedIndex]));
72 ends.set(i, static_cast<int>(m_end[revertedIndex]));
73 strides.set(i, static_cast<int>(m_stride[revertedIndex]));
74 }
75
76 return std::make_tuple(starts, ends, strides);
77}
78
Nattapat Chaimanowong177d8d22018-10-16 13:21:27 +010079} //namespace armnn