blob: 1c6ec26bd1c3a21d953eb39e4f83e6e09a03cead [file] [log] [blame]
Sadik Armagan581742d2019-08-12 14:11:37 +01001//
2// Copyright © 2017 Arm Ltd. All rights reserved.
3// SPDX-License-Identifier: MIT
4//
5
6#pragma once
7
Colm Donelan0c479742021-12-10 12:43:54 +00008#include <armnn/backends/Workload.hpp>
Sadik Armagan581742d2019-08-12 14:11:37 +01009
10#include <arm_compute/runtime/IFunction.h>
11#include <arm_compute/runtime/Tensor.h>
12#include <arm_compute/runtime/MemoryManagerOnDemand.h>
13
14#include <arm_compute/runtime/NEON/functions/NEDeconvolutionLayer.h>
15
16#include <memory>
17
18namespace armnn
19{
20
21arm_compute::Status NeonTransposeConvolution2dWorkloadValidate(const TensorInfo& input,
22 const TensorInfo& output,
23 const TransposeConvolution2dDescriptor& descriptor,
24 const TensorInfo& weights,
25 const Optional<TensorInfo>& biases);
26
27class NeonTransposeConvolution2dWorkload : public BaseWorkload<TransposeConvolution2dQueueDescriptor>
28{
29public:
30 NeonTransposeConvolution2dWorkload(const TransposeConvolution2dQueueDescriptor& descriptor,
31 const WorkloadInfo& info,
32 std::shared_ptr<arm_compute::MemoryManagerOnDemand>& memoryManager);
33
34 void Execute() const override;
35
36private:
37 std::unique_ptr<arm_compute::NEDeconvolutionLayer> m_Layer;
38
39 std::unique_ptr<arm_compute::Tensor> m_KernelTensor;
40 std::unique_ptr<arm_compute::Tensor> m_BiasTensor;
41
42 void FreeUnusedTensors();
43};
44
45} //namespace armnn