diff options
author | Kevin May <kevin.may@arm.com> | 2019-10-09 12:37:34 +0100 |
---|---|---|
committer | Áron Virginás-Tar <aron.virginas-tar@arm.com> | 2019-10-09 16:13:36 +0000 |
commit | 09ca49cdcfbe377da979a19df9bcdb7cbffc7b50 (patch) | |
tree | 62cf0881012c80498ded1963c82654efcb761bf2 /src/backends/reference/workloads/RefInstanceNormalizationWorkload.cpp | |
parent | 0d4863dd3ef0d1cafea0857e70f70b22a841ed71 (diff) | |
download | armnn-09ca49cdcfbe377da979a19df9bcdb7cbffc7b50.tar.gz |
IVGCVSW-3888 Add INSTANCE_NORMALIZATION Reference implementation
Signed-off-by: Kevin May <kevin.may@arm.com>
Change-Id: I725022f86e990c482ea323fc90fd136fe493ed68
Diffstat (limited to 'src/backends/reference/workloads/RefInstanceNormalizationWorkload.cpp')
-rw-r--r-- | src/backends/reference/workloads/RefInstanceNormalizationWorkload.cpp | 33 |
1 files changed, 33 insertions, 0 deletions
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<InstanceNormalizationQueueDescriptor>(descriptor, info) {} + +void RefInstanceNormalizationWorkload::Execute() const +{ + ARMNN_SCOPED_PROFILING_EVENT(Compute::CpuRef, "RefInstanceNormalizationWorkload_Execute"); + + std::unique_ptr<Decoder<float>> inputDecoder = MakeDecoder<float>(GetTensorInfo(m_Data.m_Inputs[0]), + m_Data.m_Inputs[0]->Map()); + std::unique_ptr<Encoder<float>> outputEncoder = MakeEncoder<float>(GetTensorInfo(m_Data.m_Outputs[0]), + m_Data.m_Outputs[0]->Map()); + + InstanceNorm(m_Data, *inputDecoder, *outputEncoder); +} + +} // namespace armnn |