1 // 2 // Copyright © 2017 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/IFunction.h> 11 #include <arm_compute/core/Error.h> 12 #include <arm_compute/runtime/CL/CLTensor.h> 13 14 namespace armnn 15 { 16 17 arm_compute::Status ClDepthwiseConvolutionWorkloadValidate(const TensorInfo& input, 18 const TensorInfo& output, 19 const DepthwiseConvolution2dDescriptor& descriptor, 20 const TensorInfo& weights, 21 const Optional<TensorInfo>& biases, 22 const ActivationDescriptor* activationDescriptor = nullptr); 23 24 class ClDepthwiseConvolutionWorkload : public ClBaseWorkload<DepthwiseConvolution2dQueueDescriptor> 25 { 26 public: 27 using BaseWorkload<DepthwiseConvolution2dQueueDescriptor>::m_Data; 28 29 ClDepthwiseConvolutionWorkload(const DepthwiseConvolution2dQueueDescriptor& descriptor, 30 const WorkloadInfo& info, 31 const arm_compute::CLCompileContext& clCompileContext); 32 33 void Execute() const override; 34 35 protected: 36 std::unique_ptr<arm_compute::IFunction> m_DepthwiseConvolutionLayer; 37 }; 38 39 } //namespace armnn 40