narpra01 | 4951d84 | 2019-01-18 16:53:53 +0000 | [diff] [blame] | 1 | // |
| 2 | // Copyright © 2017 Arm Ltd. All rights reserved. |
| 3 | // SPDX-License-Identifier: MIT |
| 4 | // |
| 5 | |
| 6 | #include "RefGatherWorkload.hpp" |
| 7 | |
| 8 | #include "Gather.hpp" |
| 9 | #include "Profiling.hpp" |
| 10 | #include "RefWorkloadUtils.hpp" |
Aron Virginas-Tar | d4f0fea | 2019-04-09 14:08:06 +0100 | [diff] [blame] | 11 | #include <ResolveType.hpp> |
narpra01 | 4951d84 | 2019-01-18 16:53:53 +0000 | [diff] [blame] | 12 | |
| 13 | namespace armnn |
| 14 | { |
| 15 | |
| 16 | template <armnn::DataType DataType> |
| 17 | void RefGatherWorkload<DataType>::Execute() const |
| 18 | { |
| 19 | using T = ResolveType<DataType>; |
| 20 | |
| 21 | ARMNN_SCOPED_PROFILING_EVENT(Compute::CpuRef, "RefGatherWorkload_Execute"); |
| 22 | |
| 23 | const TensorInfo& inputInfo0 = GetTensorInfo(m_Data.m_Inputs[0]); |
| 24 | const TensorInfo& inputInfo1 = GetTensorInfo(m_Data.m_Inputs[1]); |
| 25 | const TensorInfo& outputInfo = GetTensorInfo(m_Data.m_Outputs[0]); |
| 26 | |
| 27 | const T* paramsData = GetInputTensorData<T>(0, m_Data); |
| 28 | const int32_t* indicesData = GetInputTensorData<int32_t>(1, m_Data); |
| 29 | T* outputData = GetOutputTensorData<T>(0, m_Data); |
| 30 | |
| 31 | Gather(inputInfo0, inputInfo1, outputInfo, paramsData, indicesData, outputData); |
| 32 | } |
| 33 | |
| 34 | template class RefGatherWorkload<DataType::Float32>; |
| 35 | template class RefGatherWorkload<DataType::QuantisedAsymm8>; |
| 36 | |
| 37 | } //namespace armnn |