blob: dee789af853dd8e3ca4f0b8042b398001f50aac4 [file] [log] [blame]
telsoa014fcda012018-03-09 14:13:49 +00001//
2// Copyright © 2017 Arm Ltd. All rights reserved.
David Beckecb56cd2018-09-05 12:52:57 +01003// SPDX-License-Identifier: MIT
telsoa014fcda012018-03-09 14:13:49 +00004//
5
arovir019e53a352018-08-31 15:26:35 +01006#include "NeonL2NormalizationFloatWorkload.hpp"
David Beck711fa312018-09-24 10:46:38 +01007#include <backends/aclCommon/ArmComputeUtils.hpp>
telsoa014fcda012018-03-09 14:13:49 +00008
telsoa014fcda012018-03-09 14:13:49 +00009namespace armnn
10{
11
telsoa01c577f2c2018-08-31 09:22:23 +010012arm_compute::Status NeonL2NormalizationWorkloadValidate(const TensorInfo& input,
13 const TensorInfo& output)
14{
15 const arm_compute::TensorInfo aclInput = armcomputetensorutils::BuildArmComputeTensorInfo(input);
16 const arm_compute::TensorInfo aclOutput = armcomputetensorutils::BuildArmComputeTensorInfo(output);
17
18 arm_compute::NormalizationLayerInfo normalizationInfo =
19 CreateAclNormalizationLayerInfoForL2Normalization(input);
20
21 return arm_compute::NENormalizationLayer::validate(&aclInput, &aclOutput, normalizationInfo);
22}
23
arovir019e53a352018-08-31 15:26:35 +010024NeonL2NormalizationFloatWorkload::NeonL2NormalizationFloatWorkload(const L2NormalizationQueueDescriptor& descriptor,
surmeh013537c2c2018-05-18 16:31:43 +010025 const WorkloadInfo& info, std::shared_ptr<arm_compute::MemoryManagerOnDemand>& memoryManager)
telsoa01c577f2c2018-08-31 09:22:23 +010026 : FloatWorkload<L2NormalizationQueueDescriptor>(descriptor, info)
surmeh013537c2c2018-05-18 16:31:43 +010027 , m_Layer(memoryManager)
telsoa014fcda012018-03-09 14:13:49 +000028{
arovir019e53a352018-08-31 15:26:35 +010029 m_Data.ValidateInputsOutputs("NeonL2NormalizationFloatWorkload", 1, 1);
telsoa014fcda012018-03-09 14:13:49 +000030
31 arm_compute::ITensor& input = boost::polymorphic_downcast<INeonTensorHandle*>(m_Data.m_Inputs[0])->GetTensor();
32 arm_compute::ITensor& output = boost::polymorphic_downcast<INeonTensorHandle*>(m_Data.m_Outputs[0])->GetTensor();
33 m_Layer.configure(&input, &output, CreateAclNormalizationLayerInfoForL2Normalization(info.m_InputTensorInfos[0]));
34}
35
arovir019e53a352018-08-31 15:26:35 +010036void NeonL2NormalizationFloatWorkload::Execute() const
telsoa014fcda012018-03-09 14:13:49 +000037{
arovir019e53a352018-08-31 15:26:35 +010038 ARMNN_SCOPED_PROFILING_EVENT_NEON("NeonL2NormalizationFloatWorkload_Execute");
telsoa014fcda012018-03-09 14:13:49 +000039 m_Layer.run();
40}
41
42} //namespace armnn