blob: 460f5b3b0950d102adfa8dd8e234a246f2d31d81 [file] [log] [blame]
Teresa Charlin50de4fa2021-05-31 18:47:33 +01001//
2// Copyright © 2021 Arm Ltd and Contributors. All rights reserved.
3// SPDX-License-Identifier: MIT
4//
5
6#include "NeonLogWorkload.hpp"
7
8#include "NeonWorkloadUtils.hpp"
9
10#include <aclCommon/ArmComputeTensorHandle.hpp>
11#include <aclCommon/ArmComputeTensorUtils.hpp>
12#include <armnn/utility/PolymorphicDowncast.hpp>
13
14namespace armnn
15{
16
17arm_compute::Status NeonLogWorkloadValidate(const TensorInfo& input, const TensorInfo& output)
18{
19 const arm_compute::TensorInfo aclInput = armcomputetensorutils::BuildArmComputeTensorInfo(input);
20 const arm_compute::TensorInfo aclOutput = armcomputetensorutils::BuildArmComputeTensorInfo(output);
21
22 return arm_compute::NELogLayer::validate(&aclInput, &aclOutput);
23}
24
25NeonLogWorkload::NeonLogWorkload(const ElementwiseUnaryQueueDescriptor& descriptor, const WorkloadInfo& info)
26 : BaseWorkload<ElementwiseUnaryQueueDescriptor>(descriptor, info)
27{
28 m_Data.ValidateInputsOutputs("NeonLogWorkload", 1, 1);
29
30 arm_compute::ITensor& input = PolymorphicDowncast<IAclTensorHandle*>(m_Data.m_Inputs[0])->GetTensor();
31 arm_compute::ITensor& output = PolymorphicDowncast<IAclTensorHandle*>(m_Data.m_Outputs[0])->GetTensor();
32
33 m_LogLayer.configure(&input, &output);
34}
35
36void NeonLogWorkload::Execute() const
37{
38 ARMNN_SCOPED_PROFILING_EVENT_NEON("NeonLogWorkload_Execute");
39 m_LogLayer.run();
40}
41
42} // namespace armnn