From 47ea3c0e8d8d10906d04a0e7c537ffee68b0f819 Mon Sep 17 00:00:00 2001 From: Francis Murtagh Date: Thu, 20 Jun 2019 12:07:19 +0100 Subject: IVGCVSW-3248 Refactor reference BatchToSpace workload * Add Decoders and Encoders to workload to make it data type agnostic * Merge float32 and Uint8 into single workload Change-Id: I8adfa1898a63f13889eaaf55a31c26fd1e2d7ee8 Signed-off-by: Francis Murtagh --- .../workloads/RefBatchToSpaceNdWorkload.cpp | 29 ++++++++++++++++++++++ 1 file changed, 29 insertions(+) create mode 100644 src/backends/reference/workloads/RefBatchToSpaceNdWorkload.cpp (limited to 'src/backends/reference/workloads/RefBatchToSpaceNdWorkload.cpp') diff --git a/src/backends/reference/workloads/RefBatchToSpaceNdWorkload.cpp b/src/backends/reference/workloads/RefBatchToSpaceNdWorkload.cpp new file mode 100644 index 0000000000..c293066d26 --- /dev/null +++ b/src/backends/reference/workloads/RefBatchToSpaceNdWorkload.cpp @@ -0,0 +1,29 @@ +// +// Copyright © 2017 Arm Ltd. All rights reserved. +// SPDX-License-Identifier: MIT +// + +#include "BatchToSpaceNd.hpp" +#include "Profiling.hpp" +#include "RefBatchToSpaceNdWorkload.hpp" +#include "RefWorkloadUtils.hpp" + +namespace armnn +{ + +void RefBatchToSpaceNdWorkload::Execute() const +{ + ARMNN_SCOPED_PROFILING_EVENT(Compute::CpuRef, "RefBatchToSpaceNdWorkload_Execute"); + + const TensorInfo& inputInfo = GetTensorInfo(m_Data.m_Inputs[0]); + const TensorInfo& outputInfo = GetTensorInfo(m_Data.m_Outputs[0]); + + std::unique_ptr> inputDecoder = MakeDecoder(inputInfo, m_Data.m_Inputs[0]->Map()); + std::unique_ptr> outputEncoder = MakeEncoder(outputInfo, m_Data.m_Outputs[0]->Map()); + + BatchToSpaceNd(m_Data.m_Parameters.m_DataLayout, inputInfo, outputInfo, m_Data.m_Parameters.m_BlockShape, + m_Data.m_Parameters.m_Crops, *inputDecoder, *outputEncoder); +} + + +} //namespace armnn \ No newline at end of file -- cgit v1.2.1