ArmNN
 23.02
ClBatchMatMulWorkload.hpp
Go to the documentation of this file.
1 //
2 // Copyright © 2022 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/runtime/CL/CLTensor.h>
12 #include <memory>
13 
14 namespace armnn
15 {
16  arm_compute::Status ClBatchMatMulValidate(const TensorInfo& inputX,
17  const TensorInfo& inputY,
18  const TensorInfo& output,
19  const BatchMatMulDescriptor& descriptor);
20 
21  class ClBatchMatMulWorkload : public ClBaseWorkload<BatchMatMulQueueDescriptor>
22  {
23  public:
25  const WorkloadInfo& info,
26  const arm_compute::CLCompileContext& clCompileContext);
27  virtual void Execute() const override;
28 
29  private:
30  // ACL layers required to fully form a Batch Mat Mul layer.
31  std::unique_ptr<arm_compute::IFunction> m_GEMMLayer;
32  std::unique_ptr<arm_compute::IFunction> m_PermuteLayerX;
33  std::unique_ptr<arm_compute::IFunction> m_PermuteLayerY;
34 
35  // Additional CL arm_compute::Tensors.
36  // Required to perform permutations.
37  arm_compute::CLTensor m_PermutedTensorX;
38  arm_compute::CLTensor m_PermutedTensorY;
39 
40  };
41 } //namespace armnn
armnn::ClBatchMatMulValidate
arm_compute::Status ClBatchMatMulValidate(const TensorInfo &inputX, const TensorInfo &inputY, const TensorInfo &output, const BatchMatMulDescriptor &descriptor)
Definition: ClBatchMatMulWorkload.cpp:29
ClBaseWorkload.hpp
armnn::BatchMatMulQueueDescriptor
Definition: WorkloadData.hpp:743
armnn
Copyright (c) 2021 ARM Limited and Contributors.
Definition: 01_00_quick_start.dox:6
armnn::Status
Status
Definition: Types.hpp:42
armnn::ClBaseWorkload
Definition: ClBaseWorkload.hpp:13
armnn::ClBatchMatMulWorkload::ClBatchMatMulWorkload
ClBatchMatMulWorkload(const BatchMatMulQueueDescriptor &descriptor, const WorkloadInfo &info, const arm_compute::CLCompileContext &clCompileContext)
Definition: ClBatchMatMulWorkload.cpp:115
armnn::WorkloadInfo
Contains information about TensorInfos of a layer.
Definition: WorkloadInfo.hpp:16
armnn::ClBatchMatMulWorkload
Definition: ClBatchMatMulWorkload.hpp:21
armnn::ClBatchMatMulWorkload::Execute
virtual void Execute() const override
Definition: ClBatchMatMulWorkload.cpp:207
armnn::BoostLogSeverityMapping::info
@ info