blob: 50a61306ec4e0e4517601da98b313950f5075bf4 [file] [log] [blame]
Teresa Charlinec5f7d12021-10-22 17:15:00 +01001//
2// Copyright © 2021 Arm Ltd and Contributors. All rights reserved.
3// SPDX-License-Identifier: MIT
4//
5
6#pragma once
7
Teresa Charlin588cbdf2022-01-19 15:55:37 +00008#include "NeonBaseWorkload.hpp"
Teresa Charlinec5f7d12021-10-22 17:15:00 +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 <memory>
15
16namespace armnn
17{
18
19arm_compute::Status NeonConvolution3dWorkloadValidate(const TensorInfo& input,
20 const TensorInfo& output,
21 const Convolution3dDescriptor& descriptor,
22 const TensorInfo& weights,
23 const Optional<TensorInfo>& biases,
24 bool isFastMathEnabled = false,
25 const ActivationDescriptor* activationDescriptor = nullptr);
26
Teresa Charlin588cbdf2022-01-19 15:55:37 +000027class NeonConvolution3dWorkload : public NeonBaseWorkload<Convolution3dQueueDescriptor>
Teresa Charlinec5f7d12021-10-22 17:15:00 +010028{
29public:
30 using BaseWorkload<Convolution3dQueueDescriptor>::m_Data;
31
32 NeonConvolution3dWorkload(const Convolution3dQueueDescriptor& descriptor,
33 const WorkloadInfo& info,
34 std::shared_ptr<arm_compute::MemoryManagerOnDemand>& memoryManager,
35 const bool isFastMathENabled = false);
36
37 void Execute() const override;
38
39private:
40 std::unique_ptr<arm_compute::IFunction> m_ConvolutionLayer;
41};
42
43} //namespace armnn