blob: 1c072baf58a0cddba6fd432895204d82bb54b9d6 [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
Nattapat Chaimanowong4e00a3d2018-10-09 17:05:24 +010018ClPadWorkload::ClPadWorkload(const PadQueueDescriptor& descriptor, const WorkloadInfo& info)
19 : BaseWorkload<PadQueueDescriptor>(descriptor, info)
jimfly01e1fa50c2018-09-21 12:09:51 +010020{
21 this->m_Data.ValidateInputsOutputs("ClPadWorkload", 1, 1);
22
23 arm_compute::ICLTensor& input = static_cast<IClTensorHandle*>(this->m_Data.m_Inputs[0])->GetTensor();
24 arm_compute::ICLTensor& output = static_cast<IClTensorHandle*>(this->m_Data.m_Outputs[0])->GetTensor();
Mohamed Nour Abouelseoud7420e552018-10-12 12:26:24 +010025
26 std::vector<std::pair<unsigned int, unsigned int>> reversed_PadList(descriptor.m_Parameters.m_PadList.size());
27
28 std::reverse_copy(std::begin(descriptor.m_Parameters.m_PadList),
29 std::end(descriptor.m_Parameters.m_PadList),
30 std::begin(reversed_PadList));
31
32 arm_compute::PaddingList padList = static_cast<arm_compute::PaddingList>(reversed_PadList);
jimfly01e1fa50c2018-09-21 12:09:51 +010033
FinnWilliamsArmab801622019-07-09 14:46:28 +010034 arm_compute::PixelValue pixelValue = descriptor.m_Parameters.m_PadValue;
35
36 m_Layer.configure(&input, &output, padList, pixelValue);
jimfly01e1fa50c2018-09-21 12:09:51 +010037}
38
Nattapat Chaimanowong4e00a3d2018-10-09 17:05:24 +010039void ClPadWorkload::Execute() const
jimfly01e1fa50c2018-09-21 12:09:51 +010040{
41 ARMNN_SCOPED_PROFILING_EVENT_CL("ClPadWorkload_Execute");
Aron Virginas-Tara8e06ed2018-10-19 16:46:15 +010042 RunClFunction(m_Layer, CHECK_LOCATION());
jimfly01e1fa50c2018-09-21 12:09:51 +010043}
44
arovir01085f0a42018-10-08 14:48:19 +010045arm_compute::Status ClPadValidate(const TensorInfo& input,
46 const TensorInfo& output,
47 const PadDescriptor& descriptor)
jimfly01e1fa50c2018-09-21 12:09:51 +010048{
49 const arm_compute::TensorInfo aclInputInfo = BuildArmComputeTensorInfo(input);
50 const arm_compute::TensorInfo aclOutputInfo = BuildArmComputeTensorInfo(output);
Éanna Ó Catháind0a16082019-01-14 15:50:08 +000051
52 std::vector<std::pair<unsigned int, unsigned int>> reversed_PadList(descriptor.m_PadList.size());
53
54 std::reverse_copy(std::begin(descriptor.m_PadList),
55 std::end(descriptor.m_PadList),
56 std::begin(reversed_PadList));
57
58 arm_compute::PaddingList padList = static_cast<arm_compute::PaddingList>(reversed_PadList);
jimfly01e1fa50c2018-09-21 12:09:51 +010059
60 const arm_compute::Status aclStatus = arm_compute::CLPadLayer::validate(&aclInputInfo,
61 &aclOutputInfo,
62 padList);
63
arovir01085f0a42018-10-08 14:48:19 +010064 return aclStatus;
jimfly01e1fa50c2018-09-21 12:09:51 +010065}
66
67} // namespace armnn