aboutsummaryrefslogtreecommitdiff
path: root/src/backends/reference/workloads/RefRsqrtWorkload.cpp
diff options
context:
space:
mode:
authornikraj01 <nikhil.raj@arm.com>2019-06-06 10:31:27 +0100
committerNikhil Raj Arm <nikhil.raj@arm.com>2019-06-06 16:06:10 +0000
commit99a663140294afd2a4ea91ccc61b7266f735b46a (patch)
treebf6984e3734f0d5182a7fa510b80e3600e640e4f /src/backends/reference/workloads/RefRsqrtWorkload.cpp
parent0434df6030eee9bb6842b02a8b28598cfe8f3460 (diff)
downloadarmnn-99a663140294afd2a4ea91ccc61b7266f735b46a.tar.gz
IVGCVSW-3211 Refactor reference Rsqrt workload
Change-Id: Ia413c6b5352dbb3390e7d84e837a542c24ae8813 Signed-off-by: nikraj01 <nikhil.raj@arm.com>
Diffstat (limited to 'src/backends/reference/workloads/RefRsqrtWorkload.cpp')
-rw-r--r--src/backends/reference/workloads/RefRsqrtWorkload.cpp37
1 files changed, 37 insertions, 0 deletions
diff --git a/src/backends/reference/workloads/RefRsqrtWorkload.cpp b/src/backends/reference/workloads/RefRsqrtWorkload.cpp
new file mode 100644
index 0000000000..fd6b9a3549
--- /dev/null
+++ b/src/backends/reference/workloads/RefRsqrtWorkload.cpp
@@ -0,0 +1,37 @@
+//
+// Copyright © 2017 Arm Ltd. All rights reserved.
+// SPDX-License-Identifier: MIT
+//
+
+#include "RefRsqrtWorkload.hpp"
+
+#include "Decoders.hpp"
+#include "Encoders.hpp"
+#include "RefWorkloadUtils.hpp"
+#include "Rsqrt.hpp"
+
+#include <Profiling.hpp>
+
+namespace armnn
+{
+
+void RefRsqrtWorkload::Execute() const
+{
+ ARMNN_SCOPED_PROFILING_EVENT(Compute::CpuRef, "RefRsqrtWorkload_Execute");
+
+ const TensorInfo& inputTensorInfo = GetTensorInfo(m_Data.m_Inputs[0]);
+
+ std::unique_ptr<Decoder<float>> decoderPtr = MakeDecoder<float>(inputTensorInfo, m_Data.m_Inputs[0]->Map());
+ Decoder<float>& decoder = *decoderPtr;
+
+ const TensorInfo& outputTensorInfo = GetTensorInfo(m_Data.m_Outputs[0]);
+
+ std::unique_ptr<Encoder<float>> encoderPtr = MakeEncoder<float>(outputTensorInfo, m_Data.m_Outputs[0]->Map());
+ Encoder<float>& encoder = *encoderPtr;
+
+ Rsqrt(decoder,
+ encoder,
+ GetTensorInfo(m_Data.m_Inputs[0]));
+}
+
+} //namespace armnn