xref: /aosp_15_r20/external/armnn/src/backends/cl/workloads/ClConvolution3dWorkload.hpp (revision 89c4ff92f2867872bb9e2354d150bf0c8c502810)
1 //
2 // Copyright © 2021 Arm Ltd and Contributors. All rights reserved.
3 // SPDX-License-Identifier: MIT
4 //
5 
6 #pragma once
7 
8 #include "ClBaseWorkload.hpp"
9 
10 #include <arm_compute/runtime/CL/functions/CLConv3D.h>
11 #include <arm_compute/runtime/MemoryManagerOnDemand.h>
12 
13 #include <memory>
14 
15 namespace armnn
16 {
17 
18 arm_compute::Status ClConvolution3dWorkloadValidate(const TensorInfo& input,
19                                                     const TensorInfo& output,
20                                                     const Convolution3dDescriptor& descriptor,
21                                                     const TensorInfo& weights,
22                                                     const Optional<TensorInfo>& biases,
23                                                     bool isFastMathEnabled = false,
24                                                     const ActivationDescriptor* activationDescriptor = nullptr);
25 
26 class ClConvolution3dWorkload : public ClBaseWorkload<Convolution3dQueueDescriptor>
27 {
28 public:
29     ClConvolution3dWorkload(const Convolution3dQueueDescriptor& descriptor,
30                             const WorkloadInfo& info,
31                             std::shared_ptr<arm_compute::MemoryManagerOnDemand>& memoryManager,
32                             const arm_compute::CLCompileContext& clCompileContext,
33                             const bool isFastMathEnabled = false);
34     void Execute() const override;
35 
36 private:
37     mutable arm_compute::CLConv3D m_ConvolutionLayer;
38 };
39 
40 } //namespace armnn
41 
42