blob: d1e44520a1fbec9f1d57ee1f4b84b2de5e1cfc29 [file] [log] [blame]
Laurent Carlier749294b2020-06-01 09:03:17 +01001//
telsoa014fcda012018-03-09 14:13:49 +00002// Copyright © 2017 Arm Ltd. All rights reserved.
David Beckecb56cd2018-09-05 12:52:57 +01003// SPDX-License-Identifier: MIT
telsoa014fcda012018-03-09 14:13:49 +00004//
5
6#pragma once
7
Finn Williams73c547d2022-02-15 20:47:34 +00008#include "RefBaseWorkload.hpp"
telsoa014fcda012018-03-09 14:13:49 +00009
10#include <armnn/TypesUtils.hpp>
11
12namespace armnn
13{
14
15template <armnn::DataType DataType>
16class RefPermuteWorkload : public TypedWorkload<PermuteQueueDescriptor, DataType>
17{
18public:
19 static const std::string& GetName()
20 {
21 static const std::string name = std::string("RefPermute") + GetDataTypeName(DataType) + "Workload";
22 return name;
23 }
24
25 using TypedWorkload<PermuteQueueDescriptor, DataType>::m_Data;
26 using TypedWorkload<PermuteQueueDescriptor, DataType>::TypedWorkload;
27 void Execute() const override;
Finn Williamsb8181f72021-04-07 10:23:21 +010028 void ExecuteAsync(WorkingMemDescriptor& workingMemDescriptor) override;
29private:
30 void Execute(std::vector<ITensorHandle*> inputs, std::vector<ITensorHandle*> outputs) const;
telsoa014fcda012018-03-09 14:13:49 +000031};
32
Narumol Prangnawarat44179c32020-03-11 14:51:27 +000033using RefPermuteBFloat16Workload = RefPermuteWorkload<DataType::BFloat16>;
Sadik Armagan303980c2020-04-17 12:45:14 +010034using RefPermuteFloat16Workload = RefPermuteWorkload<DataType::Float16>;
35using RefPermuteFloat32Workload = RefPermuteWorkload<DataType::Float32>;
36using RefPermuteQAsymmS8Workload = RefPermuteWorkload<DataType::QAsymmS8>;
37using RefPermuteQAsymm8Workload = RefPermuteWorkload<DataType::QAsymmU8>;
38using RefPermuteQSymm16Workload = RefPermuteWorkload<DataType::QSymmS16>;
telsoa014fcda012018-03-09 14:13:49 +000039
Mohamed Nour Abouelseouddd6acea2018-10-18 12:26:19 +010040} //namespace armnn