blob: b2b8eebfafe6d590ad8c069d030c729dbdac8339 [file] [log] [blame]
Nikhil Raj91e4c6d2019-07-05 12:22:58 +01001//
Teresa Charlin588cbdf2022-01-19 15:55:37 +00002// Copyright © 2017 Arm Ltd and Contributors. All rights reserved.
Nikhil Raj91e4c6d2019-07-05 12:22:58 +01003// SPDX-License-Identifier: MIT
4//
5
6#include "ClPreluWorkload.hpp"
7#include "ClWorkloadUtils.hpp"
Colm Donelan0c479742021-12-10 12:43:54 +00008#include <armnn/backends/TensorHandle.hpp>
Nikhil Raj91e4c6d2019-07-05 12:22:58 +01009#include <aclCommon/ArmComputeUtils.hpp>
10#include <cl/ClLayerSupport.hpp>
11#include <cl/ClTensorHandle.hpp>
12
13namespace armnn
14{
15
16arm_compute::Status ClPreluWorkloadValidate(const TensorInfo& input,
17 const TensorInfo& alpha,
18 const TensorInfo& output)
19{
20 const arm_compute::TensorInfo aclInput = armcomputetensorutils::BuildArmComputeTensorInfo(input);
21 const arm_compute::TensorInfo aclAlpha = armcomputetensorutils::BuildArmComputeTensorInfo(alpha);
22 const arm_compute::TensorInfo aclOutput = armcomputetensorutils::BuildArmComputeTensorInfo(output);
23
24 return arm_compute::CLPReluLayer::validate(&aclInput,
25 &aclAlpha,
26 &aclOutput);
27}
28
29ClPreluWorkload::ClPreluWorkload(const PreluQueueDescriptor& descriptor,
Sadik Armagane9444752020-12-02 11:28:58 +000030 const WorkloadInfo& info,
31 const arm_compute::CLCompileContext& clCompileContext)
Teresa Charlin588cbdf2022-01-19 15:55:37 +000032 : ClBaseWorkload<PreluQueueDescriptor>(descriptor, info)
Nikhil Raj91e4c6d2019-07-05 12:22:58 +010033{
34 m_Data.ValidateInputsOutputs("ClPreluWorkload", 1, 1);
35
36 arm_compute::ICLTensor& input = static_cast<IClTensorHandle*>(m_Data.m_Inputs[0])->GetTensor();
37 arm_compute::ICLTensor& alpha = static_cast<IClTensorHandle*>(m_Data.m_Inputs[1])->GetTensor();
38 arm_compute::ICLTensor& output = static_cast<IClTensorHandle*>(m_Data.m_Outputs[0])->GetTensor();
39
Kevin May9f6862d2021-10-22 15:42:28 +010040 {
41 ARMNN_SCOPED_PROFILING_EVENT(Compute::Undefined, "ClPreluWorkload_configure");
42 m_PreluLayer.configure(clCompileContext, &input, &alpha, &output);
43 }
Nikhil Raj91e4c6d2019-07-05 12:22:58 +010044}
45
46void ClPreluWorkload::Execute() const
47{
Keith Davisbcd860a2021-08-05 14:20:33 +010048 ARMNN_SCOPED_PROFILING_EVENT_CL_GUID("ClPreluWorkload_Execute", this->GetGuid());
Nikhil Raj91e4c6d2019-07-05 12:22:58 +010049 RunClFunction(m_PreluLayer, CHECK_LOCATION());
50}
51
52} //namespace armnn