ArmNN
 20.05
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  ARMNN_ASSERT(inputDataType == outputDataType);
31  IgnoreUnused(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
CPU Execution: Reference C++ kernels.
const StridedSliceQueueDescriptor m_Data
Definition: Workload.hpp:46
const TensorInfo & GetTensorInfo(const ITensorHandle *tensorHandle)
float32 helpers
Copyright (c) 2020 ARM Limited.
void IgnoreUnused(Ts &&...)
#define ARMNN_SCOPED_PROFILING_EVENT(backendId, name)
Definition: Profiling.hpp:169
DataType
Definition: Types.hpp:32
RefStridedSliceWorkload(const StridedSliceQueueDescriptor &descriptor, const WorkloadInfo &info)
DataType GetDataType() const
Definition: Tensor.hpp:95
#define ARMNN_ASSERT(COND)
Definition: Assert.hpp:14
std::vector< ITensorHandle * > m_Outputs
Contains information about inputs and outputs to a layer.
std::vector< ITensorHandle * > m_Inputs
constexpr unsigned int GetDataTypeSize(DataType dataType)
Definition: TypesUtils.hpp:115