blob: 1d6bf70431312a34ffb911dcf5d99b97db435d67 [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 "NeonActivationFloatWorkload.hpp"
David Beck711fa312018-09-24 10:46:38 +01007#include <backends/aclCommon/ArmComputeUtils.hpp>
telsoa014fcda012018-03-09 14:13:49 +00008
9
10namespace armnn
11{
telsoa01c577f2c2018-08-31 09:22:23 +010012
13arm_compute::Status NeonActivationWorkloadValidate(const TensorInfo& input,
14 const TensorInfo& output,
15 const ActivationDescriptor& descriptor)
16{
17 const arm_compute::TensorInfo aclInput = armcomputetensorutils::BuildArmComputeTensorInfo(input);
18 const arm_compute::TensorInfo aclOutput = armcomputetensorutils::BuildArmComputeTensorInfo(output);
19
20 const arm_compute::ActivationLayerInfo activationLayerInfo =
21 ConvertActivationDescriptorToAclActivationLayerInfo(descriptor);
22
23 if (input.GetDataType() == DataType::QuantisedAsymm8 &&
24 activationLayerInfo.activation() == arm_compute::ActivationLayerInfo::ActivationFunction::LOGISTIC)
25 {
26 return arm_compute::Status{arm_compute::ErrorCode::RUNTIME_ERROR,
27 "Neon: Logistic Activations unsupported with QAsymm8 data type."};
28 }
29
30 return arm_compute::NEActivationLayer::validate(&aclInput,
31 &aclOutput,
32 activationLayerInfo);
33}
34
arovir019e53a352018-08-31 15:26:35 +010035NeonActivationFloatWorkload::NeonActivationFloatWorkload(const ActivationQueueDescriptor& descriptor,
36 const WorkloadInfo& info)
telsoa01c577f2c2018-08-31 09:22:23 +010037 : FloatWorkload<ActivationQueueDescriptor>(descriptor, info)
telsoa014fcda012018-03-09 14:13:49 +000038{
arovir019e53a352018-08-31 15:26:35 +010039 m_Data.ValidateInputsOutputs("NeonActivationFloatWorkload", 1, 1);
telsoa014fcda012018-03-09 14:13:49 +000040
41 const arm_compute::ActivationLayerInfo activationLayerInfo =
42 ConvertActivationDescriptorToAclActivationLayerInfo(m_Data.m_Parameters);
43
44 arm_compute::ITensor& input = boost::polymorphic_downcast<INeonTensorHandle*>(m_Data.m_Inputs[0])->GetTensor();
45 arm_compute::ITensor& output = boost::polymorphic_downcast<INeonTensorHandle*>(m_Data.m_Outputs[0])->GetTensor();
46
47 m_ActivationLayer.configure(&input, &output, activationLayerInfo);
48}
49
arovir019e53a352018-08-31 15:26:35 +010050void NeonActivationFloatWorkload::Execute() const
telsoa014fcda012018-03-09 14:13:49 +000051{
arovir019e53a352018-08-31 15:26:35 +010052 ARMNN_SCOPED_PROFILING_EVENT_NEON("NeonActivationFloatWorkload_Execute");
telsoa014fcda012018-03-09 14:13:49 +000053 m_ActivationLayer.run();
54}
55
56} //namespace armnn
57