blob: 533855c295fbb0f36f1dac7381f5bcb572af9c59 [file] [log] [blame]
jimfly01e1fa50c2018-09-21 12:09:51 +01001//
2// Copyright © 2017 Arm Ltd. All rights reserved.
3// SPDX-License-Identifier: MIT
4//
5
6#include "ClPadWorkload.hpp"
7
Aron Virginas-Tarc9cc8042018-11-01 16:15:57 +00008#include <cl/ClTensorHandle.hpp>
9#include <aclCommon/ArmComputeTensorUtils.hpp>
jimfly01e1fa50c2018-09-21 12:09:51 +010010#include <arm_compute/core/Types.h>
11
David Beckac42efd2018-09-26 17:41:13 +010012#include "ClWorkloadUtils.hpp"
13
jimfly01e1fa50c2018-09-21 12:09:51 +010014namespace armnn
15{
16using namespace armcomputetensorutils;
17
Sadik Armagane9444752020-12-02 11:28:58 +000018ClPadWorkload::ClPadWorkload(const PadQueueDescriptor& descriptor,
19 const WorkloadInfo& info,
20 const arm_compute::CLCompileContext& clCompileContext)
Nattapat Chaimanowong4e00a3d2018-10-09 17:05:24 +010021 : BaseWorkload<PadQueueDescriptor>(descriptor, info)
jimfly01e1fa50c2018-09-21 12:09:51 +010022{
23 this->m_Data.ValidateInputsOutputs("ClPadWorkload", 1, 1);
24
25 arm_compute::ICLTensor& input = static_cast<IClTensorHandle*>(this->m_Data.m_Inputs[0])->GetTensor();
26 arm_compute::ICLTensor& output = static_cast<IClTensorHandle*>(this->m_Data.m_Outputs[0])->GetTensor();
Mohamed Nour Abouelseoud7420e552018-10-12 12:26:24 +010027
28 std::vector<std::pair<unsigned int, unsigned int>> reversed_PadList(descriptor.m_Parameters.m_PadList.size());
29
30 std::reverse_copy(std::begin(descriptor.m_Parameters.m_PadList),
31 std::end(descriptor.m_Parameters.m_PadList),
32 std::begin(reversed_PadList));
33
34 arm_compute::PaddingList padList = static_cast<arm_compute::PaddingList>(reversed_PadList);
jimfly01e1fa50c2018-09-21 12:09:51 +010035
Mike Kelly0a08ec62019-07-25 08:39:31 +010036 arm_compute::PixelValue pixelValue = GetPixelValue(input, descriptor.m_Parameters.m_PadValue);
FinnWilliamsArmab801622019-07-09 14:46:28 +010037
Sadik Armagane9444752020-12-02 11:28:58 +000038 m_Layer.configure(clCompileContext, &input, &output, padList, pixelValue);
jimfly01e1fa50c2018-09-21 12:09:51 +010039}
40
Nattapat Chaimanowong4e00a3d2018-10-09 17:05:24 +010041void ClPadWorkload::Execute() const
jimfly01e1fa50c2018-09-21 12:09:51 +010042{
43 ARMNN_SCOPED_PROFILING_EVENT_CL("ClPadWorkload_Execute");
Aron Virginas-Tara8e06ed2018-10-19 16:46:15 +010044 RunClFunction(m_Layer, CHECK_LOCATION());
jimfly01e1fa50c2018-09-21 12:09:51 +010045}
46
arovir01085f0a42018-10-08 14:48:19 +010047arm_compute::Status ClPadValidate(const TensorInfo& input,
48 const TensorInfo& output,
49 const PadDescriptor& descriptor)
jimfly01e1fa50c2018-09-21 12:09:51 +010050{
51 const arm_compute::TensorInfo aclInputInfo = BuildArmComputeTensorInfo(input);
52 const arm_compute::TensorInfo aclOutputInfo = BuildArmComputeTensorInfo(output);
Éanna Ó Catháind0a16082019-01-14 15:50:08 +000053
54 std::vector<std::pair<unsigned int, unsigned int>> reversed_PadList(descriptor.m_PadList.size());
55
56 std::reverse_copy(std::begin(descriptor.m_PadList),
57 std::end(descriptor.m_PadList),
58 std::begin(reversed_PadList));
59
60 arm_compute::PaddingList padList = static_cast<arm_compute::PaddingList>(reversed_PadList);
jimfly01e1fa50c2018-09-21 12:09:51 +010061
62 const arm_compute::Status aclStatus = arm_compute::CLPadLayer::validate(&aclInputInfo,
63 &aclOutputInfo,
64 padList);
65
arovir01085f0a42018-10-08 14:48:19 +010066 return aclStatus;
jimfly01e1fa50c2018-09-21 12:09:51 +010067}
68
69} // namespace armnn