diff options
author | Sadik Armagan <sadik.armagan@arm.com> | 2019-04-03 17:48:18 +0100 |
---|---|---|
committer | Sadik Armagan <sadik.armagan@arm.com> | 2019-04-08 15:48:28 +0000 |
commit | 2e6dc3a1c5d47825535db7993ba77eb1596ae99b (patch) | |
tree | 48e73fa1862d17534804d1699bedb76120e88c9f /src/backends/reference/workloads/Broadcast.hpp | |
parent | 0324f48e64edb99a5c8d819394545d97e0c2ae97 (diff) | |
download | armnn-2e6dc3a1c5d47825535db7993ba77eb1596ae99b.tar.gz |
IVGCVSW-2861 Refactor the Reference Elementwise workload
* Refactor Reference Comparison workload
* Removed templating based on the DataType
* Implemented BaseIterator to do decode/encode
Change-Id: I18f299f47ee23772f90152c1146b42f07465e105
Signed-off-by: Sadik Armagan <sadik.armagan@arm.com>
Signed-off-by: Kevin May <kevin.may@arm.com>
Diffstat (limited to 'src/backends/reference/workloads/Broadcast.hpp')
-rw-r--r-- | src/backends/reference/workloads/Broadcast.hpp | 24 |
1 files changed, 19 insertions, 5 deletions
diff --git a/src/backends/reference/workloads/Broadcast.hpp b/src/backends/reference/workloads/Broadcast.hpp index e92ed0598d..5bf6be8939 100644 --- a/src/backends/reference/workloads/Broadcast.hpp +++ b/src/backends/reference/workloads/Broadcast.hpp @@ -3,6 +3,7 @@ // SPDX-License-Identifier: MIT // +#include "BaseIterator.hpp" #include <armnn/Tensor.hpp> #include <functional> @@ -19,19 +20,23 @@ struct BroadcastLoop return static_cast<unsigned int>(m_DimData.size()); } - template <typename T0, typename T1, typename U, typename Func> + template <typename Func, typename DecoderOp, typename EncoderOp> void Unroll(Func operationFunc, unsigned int dimension, - const T0* inData0, - const T1* inData1, - U* outData) + DecoderOp& inData0, + DecoderOp& inData1, + EncoderOp& outData) { if (dimension >= GetNumDimensions()) { - *outData = operationFunc(*inData0, *inData1); + outData.Set(operationFunc(inData0.Get(), inData1.Get())); return; } + unsigned int inData0Movement = 0; + unsigned int inData1Movement = 0; + unsigned int outDataMovement = 0; + for (unsigned int i = 0; i < m_DimData[dimension].m_DimSize; i++) { Unroll(operationFunc, dimension + 1, inData0, inData1, outData); @@ -39,7 +44,16 @@ struct BroadcastLoop inData0 += m_DimData[dimension].m_Stride1; inData1 += m_DimData[dimension].m_Stride2; outData += m_DimData[dimension].m_StrideOut; + + inData0Movement += m_DimData[dimension].m_Stride1; + inData1Movement += m_DimData[dimension].m_Stride2; + outDataMovement += m_DimData[dimension].m_StrideOut; } + + // move iterator back to the start + inData0 -= inData0Movement; + inData1 -= inData1Movement; + outData -= outDataMovement; } private: |