blob: 80fd014d3dff66d995205fbd0abf2c356643e03e [file] [log] [blame]
Sadik Armaganac472102020-03-24 09:54:36 +00001//
Mike Kelly7cbe7812023-07-25 17:37:33 +01002// Copyright © 2020-2023 Arm Ltd and Contributors. All rights reserved.
Sadik Armaganac472102020-03-24 09:54:36 +00003// SPDX-License-Identifier: MIT
4//
5
6#include "NeonNegWorkload.hpp"
7
8#include "NeonWorkloadUtils.hpp"
9
10#include <aclCommon/ArmComputeTensorHandle.hpp>
11#include <aclCommon/ArmComputeTensorUtils.hpp>
Jan Eilersbb446e52020-04-02 13:56:54 +010012#include <armnn/utility/PolymorphicDowncast.hpp>
Sadik Armaganac472102020-03-24 09:54:36 +000013
14namespace armnn
15{
16
17arm_compute::Status NeonNegWorkloadValidate(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::NENegLayer::validate(&aclInput, &aclOutput);
23}
24
25NeonNegWorkload::NeonNegWorkload(const ElementwiseUnaryQueueDescriptor& descriptor, const WorkloadInfo& info)
Teresa Charlin588cbdf2022-01-19 15:55:37 +000026 : NeonBaseWorkload<ElementwiseUnaryQueueDescriptor>(descriptor, info)
Sadik Armaganac472102020-03-24 09:54:36 +000027{
28 m_Data.ValidateInputsOutputs("NeonNegWorkload", 1, 1);
29
Jan Eilersbb446e52020-04-02 13:56:54 +010030 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();
Sadik Armaganac472102020-03-24 09:54:36 +000032
33 m_NegLayer.configure(&input, &output);
34}
35
36void NeonNegWorkload::Execute() const
37{
Mike Kelly7cbe7812023-07-25 17:37:33 +010038 ARMNN_SCOPED_PROFILING_EVENT_NEON_NAME_GUID("NeonNegWorkload_Execute");
Sadik Armaganac472102020-03-24 09:54:36 +000039 m_NegLayer.run();
40}
41
42} // namespace armnn