From 09ca49cdcfbe377da979a19df9bcdb7cbffc7b50 Mon Sep 17 00:00:00 2001 From: Kevin May Date: Wed, 9 Oct 2019 12:37:34 +0100 Subject: IVGCVSW-3888 Add INSTANCE_NORMALIZATION Reference implementation Signed-off-by: Kevin May Change-Id: I725022f86e990c482ea323fc90fd136fe493ed68 --- .../workloads/RefInstanceNormalizationWorkload.cpp | 33 ++++++++++++++++++++++ 1 file changed, 33 insertions(+) create mode 100644 src/backends/reference/workloads/RefInstanceNormalizationWorkload.cpp (limited to 'src/backends/reference/workloads/RefInstanceNormalizationWorkload.cpp') diff --git a/src/backends/reference/workloads/RefInstanceNormalizationWorkload.cpp b/src/backends/reference/workloads/RefInstanceNormalizationWorkload.cpp new file mode 100644 index 0000000000..875d11a00d --- /dev/null +++ b/src/backends/reference/workloads/RefInstanceNormalizationWorkload.cpp @@ -0,0 +1,33 @@ +// +// Copyright © 2019 Arm Ltd. All rights reserved. +// SPDX-License-Identifier: MIT +// + +#include "RefInstanceNormalizationWorkload.hpp" + +#include "InstanceNorm.hpp" +#include "RefWorkloadUtils.hpp" + +#include "Profiling.hpp" + +namespace armnn +{ + +RefInstanceNormalizationWorkload::RefInstanceNormalizationWorkload( + const InstanceNormalizationQueueDescriptor& descriptor, + const WorkloadInfo& info) + : BaseWorkload(descriptor, info) {} + +void RefInstanceNormalizationWorkload::Execute() const +{ + ARMNN_SCOPED_PROFILING_EVENT(Compute::CpuRef, "RefInstanceNormalizationWorkload_Execute"); + + std::unique_ptr> inputDecoder = MakeDecoder(GetTensorInfo(m_Data.m_Inputs[0]), + m_Data.m_Inputs[0]->Map()); + std::unique_ptr> outputEncoder = MakeEncoder(GetTensorInfo(m_Data.m_Outputs[0]), + m_Data.m_Outputs[0]->Map()); + + InstanceNorm(m_Data, *inputDecoder, *outputEncoder); +} + +} // namespace armnn -- cgit v1.2.1