21 using namespace armcomputetensorutils;
27 const arm_compute::TensorInfo aclInputInfo = BuildArmComputeTensorInfo(input, descriptor.
m_DataLayout);
28 const arm_compute::TensorInfo aclOutputInfo = BuildArmComputeTensorInfo(output, descriptor.
m_DataLayout);
34 arm_compute::Size2D paddingLeftTop = BuildArmComputeSize2D(
36 arm_compute::Size2D paddingRightBottom = BuildArmComputeSize2D(
39 return arm_compute::CLSpaceToBatchLayer::validate(&aclInputInfo,
50 const arm_compute::CLCompileContext& clCompileContext)
61 arm_compute::ICLTensor& input =
62 armnn::PolymorphicPointerDowncast<IClTensorHandle>(
m_Data.
m_Inputs[0])->GetTensor();
63 arm_compute::ICLTensor& output =
64 armnn::PolymorphicPointerDowncast<IClTensorHandle>(
m_Data.
m_Outputs[0])->GetTensor();
70 arm_compute::Size2D paddingLeftTop = BuildArmComputeSize2D(
72 arm_compute::Size2D paddingRightBottom = BuildArmComputeSize2D(
76 input.info()->set_data_layout(aclDataLayout);
77 output.info()->set_data_layout(aclDataLayout);
81 m_SpaceToBatchLayer.configure(clCompileContext,
#define ARMNN_SCOPED_PROFILING_EVENT_CL_GUID(name, guid)
ClSpaceToBatchNdWorkload(const SpaceToBatchNdQueueDescriptor &descriptor, const WorkloadInfo &info, const arm_compute::CLCompileContext &clCompileContext)
void RunClFunction(arm_compute::IFunction &function, const CheckLocation &location)
arm::pipe::ProfilingGuid GetGuid() const final
void ValidateInputsOutputs(const std::string &descName, unsigned int numExpectedIn, unsigned int numExpectedOut) const
Copyright (c) 2021 ARM Limited and Contributors.
std::vector< std::pair< unsigned int, unsigned int > > m_PadList
Specifies the padding values for the input dimension: heightPad{top, bottom} widthPad{left, right}.
LayerDescriptor m_Parameters
#define ARMNN_SCOPED_PROFILING_EVENT(backendId, name)
DataLayout m_DataLayout
The data layout to be used (NCHW, NHWC).
arm_compute::Status ClSpaceToBatchNdWorkloadValidate(const TensorInfo &input, const TensorInfo &output, const SpaceToBatchNdDescriptor &descriptor)
SpaceToBatchNdQueueDescriptor m_Data
std::vector< unsigned int > m_BlockShape
Block shape value.
A SpaceToBatchNdDescriptor for the SpaceToBatchNdLayer.
std::vector< ITensorHandle * > m_Outputs
void Execute() const override
#define ARMNN_REPORT_PROFILING_WORKLOAD_DESC(name, desc, infos, guid)
std::enable_if_t< std::is_unsigned< Source >::value &&std::is_unsigned< Dest >::value, Dest > numeric_cast(Source source)
Contains information about TensorInfos of a layer.
std::vector< ITensorHandle * > m_Inputs