IVGCVSW-2049 + IVGCVSW-2051 Create the CL Mean Float workload and add
[platform/upstream/armnn.git] / src / backends / cl / workloads / ClMeanWorkload.hpp
1 //
2 // Copyright © 2017 Arm Ltd. All rights reserved.
3 // SPDX-License-Identifier: MIT
4 //
5
6 #pragma once
7
8 #include <backends/Workload.hpp>
9
10 #include <arm_compute/runtime/CL/CLFunctions.h>
11
12 namespace armnn
13 {
14
15 arm_compute::Status ClMeanValidate(const TensorInfo& input,
16                                    const TensorInfo& output,
17                                    const MeanDescriptor& desc);
18
19 class ClMeanWorkload : public BaseWorkload<MeanQueueDescriptor>
20 {
21 public:
22     ClMeanWorkload(const MeanQueueDescriptor& descriptor, const WorkloadInfo& info);
23
24     void Execute() const override;
25
26 private:
27     // Not using CLMeanStdDev, as 4D input tensor support for Mean has been added to a new function called CLReduceMean.
28     mutable arm_compute::CLReduceMean m_Layer;
29 };
30
31 } //namespace armnn