blob: 88cc0b38110926a501f92a26b812358ec37d3363 [file] [log] [blame]
Aron Virginas-Tar7a3e2fe2019-06-27 18:54:47 +01001//
Teresa Charlin588cbdf2022-01-19 15:55:37 +00002// Copyright © 2017 Arm Ltd and Contributors. All rights reserved.
Aron Virginas-Tar7a3e2fe2019-06-27 18:54:47 +01003// SPDX-License-Identifier: MIT
4//
5
6#pragma once
7
8#include <armnn/Tensor.hpp>
9#include <armnn/Descriptors.hpp>
10
Teresa Charlin588cbdf2022-01-19 15:55:37 +000011#include "ClBaseWorkload.hpp"
Aron Virginas-Tar7a3e2fe2019-06-27 18:54:47 +010012
13#include <arm_compute/runtime/CL/functions/CLDeconvolutionLayer.h>
14#include <arm_compute/runtime/MemoryManagerOnDemand.h>
15
16#include <memory>
17
18namespace armnn
19{
20
21arm_compute::Status ClTransposeConvolution2dWorkloadValidate(const TensorInfo& input,
22 const TensorInfo& output,
23 const TransposeConvolution2dDescriptor& descriptor,
24 const TensorInfo& weights,
25 const Optional<TensorInfo>& biases);
26
Teresa Charlin588cbdf2022-01-19 15:55:37 +000027class ClTransposeConvolution2dWorkload : public ClBaseWorkload<TransposeConvolution2dQueueDescriptor>
Aron Virginas-Tar7a3e2fe2019-06-27 18:54:47 +010028{
29public:
30 ClTransposeConvolution2dWorkload(const TransposeConvolution2dQueueDescriptor& descriptor,
31 const WorkloadInfo& info,
Sadik Armagane9444752020-12-02 11:28:58 +000032 std::shared_ptr<arm_compute::MemoryManagerOnDemand>& memoryManager,
33 const arm_compute::CLCompileContext& clCompileContext);
Aron Virginas-Tar7a3e2fe2019-06-27 18:54:47 +010034
35 void Execute() const override;
36
37private:
38 mutable arm_compute::CLDeconvolutionLayer m_Layer;
39
40 std::unique_ptr<arm_compute::CLTensor> m_WeightsTensor;
41 std::unique_ptr<arm_compute::CLTensor> m_BiasesTensor;
42
43 void FreeUnusedTensors();
44};
45
46} // namespace armnn
47