ArmNN  NotReleased
RefStridedSliceWorkload.cpp
Go to the documentation of this file.
1 //
2 // Copyright © 2017 Arm Ltd. All rights reserved.
3 // SPDX-License-Identifier: MIT
4 //
5 
7 #include "RefWorkloadUtils.hpp"
8 #include "StridedSlice.hpp"
9 
10 #include <boost/format.hpp>
11 
12 namespace armnn
13 {
14 
16  const WorkloadInfo& info)
17  : BaseWorkload(descriptor, info)
18 {}
19 
21 {
22  ARMNN_SCOPED_PROFILING_EVENT(Compute::CpuRef, "RefStridedSliceWorkload_Execute");
23 
24  const TensorInfo& inputInfo = GetTensorInfo(m_Data.m_Inputs[0]);
25  const TensorInfo& outputInfo = GetTensorInfo(m_Data.m_Outputs[0]);
26 
27  DataType inputDataType = inputInfo.GetDataType();
28  DataType outputDataType = outputInfo.GetDataType();
29 
30  BOOST_ASSERT(inputDataType == outputDataType);
31  boost::ignore_unused(outputDataType);
32 
33  StridedSlice(inputInfo,
35  m_Data.m_Inputs[0]->Map(),
36  m_Data.m_Outputs[0]->Map(),
37  GetDataTypeSize(inputDataType));
38 }
39 
40 } // namespace armnn
#define ARMNN_SCOPED_PROFILING_EVENT(backendId, name)
Definition: Profiling.hpp:170
constexpr unsigned int GetDataTypeSize(DataType dataType)
Definition: TypesUtils.hpp:113
const StridedSliceQueueDescriptor m_Data
Definition: Workload.hpp:46
CPU Execution: Reference C++ kernels.
DataType
Definition: Types.hpp:32
DataType GetDataType() const
Definition: Tensor.hpp:95
std::vector< ITensorHandle * > m_Outputs
std::vector< ITensorHandle * > m_Inputs
RefStridedSliceWorkload(const StridedSliceQueueDescriptor &descriptor, const WorkloadInfo &info)
const TensorInfo & GetTensorInfo(const ITensorHandle *tensorHandle)
float32 helpers