1 // 2 // Copyright © 2017 Arm Ltd and Contributors. All rights reserved. 3 // SPDX-License-Identifier: MIT 4 // 5 6 #pragma once 7 8 #include "NeonBaseWorkload.hpp" 9 10 #include <arm_compute/runtime/IFunction.h> 11 #include <arm_compute/runtime/Tensor.h> 12 13 #include <memory> 14 15 namespace armnn 16 { 17 18 arm_compute::Status NeonDepthwiseConvolutionWorkloadValidate(const TensorInfo& input, 19 const TensorInfo& output, 20 const DepthwiseConvolution2dDescriptor& descriptor, 21 const TensorInfo& weights, 22 const Optional<TensorInfo>& biases, 23 const ActivationDescriptor* activationDescriptor 24 = nullptr); 25 26 class NeonDepthwiseConvolutionWorkload : public NeonBaseWorkload<DepthwiseConvolution2dQueueDescriptor> 27 { 28 public: 29 NeonDepthwiseConvolutionWorkload(const DepthwiseConvolution2dQueueDescriptor& descriptor, 30 const WorkloadInfo& info); 31 32 virtual void Execute() const override; 33 34 private: 35 mutable std::unique_ptr<arm_compute::IFunction> m_pDepthwiseConvolutionLayer; 36 }; 37 38 } // namespace armnn 39