blob: 619bccccc7d83e72a26f3194cadbacb37df706c0 [file] [log] [blame]
Teresa Charlin50de4fa2021-05-31 18:47:33 +01001//
Mike Kelly7cbe7812023-07-25 17:37:33 +01002// Copyright © 2021-2023 Arm Ltd and Contributors. All rights reserved.
Teresa Charlin50de4fa2021-05-31 18:47:33 +01003// SPDX-License-Identifier: MIT
4//
5
6#include "NeonSinWorkload.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 NeonSinWorkloadValidate(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::NESinLayer::validate(&aclInput, &aclOutput);
23}
24
25NeonSinWorkload::NeonSinWorkload(const ElementwiseUnaryQueueDescriptor& descriptor, const WorkloadInfo& info)
Teresa Charlin588cbdf2022-01-19 15:55:37 +000026 : NeonBaseWorkload<ElementwiseUnaryQueueDescriptor>(descriptor, info)
Teresa Charlin50de4fa2021-05-31 18:47:33 +010027{
28 m_Data.ValidateInputsOutputs("NeonSinWorkload", 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_SinLayer.configure(&input, &output);
34}
35
36void NeonSinWorkload::Execute() const
37{
Mike Kelly7cbe7812023-07-25 17:37:33 +010038 ARMNN_SCOPED_PROFILING_EVENT_NEON_NAME_GUID("NeonSinWorkload_Execute");
Teresa Charlin50de4fa2021-05-31 18:47:33 +010039 m_SinLayer.run();
40}
41
42} // namespace armnn