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