blob: 97ebbd80aecd0c511a75539fda30d8e8bac779af [file] [log] [blame]
Laurent Carlier749294b2020-06-01 09:03:17 +01001//
Matthew Sloyan2d213a72022-06-30 17:13:04 +01002// Copyright © 2022 Arm Ltd and Contributors. All rights reserved.
Mike Kellyc9ea45a2020-02-28 18:11:58 +00003// SPDX-License-Identifier: MIT
4//
5
6#pragma once
7
Finn Williams73c547d2022-02-15 20:47:34 +00008#include "RefBaseWorkload.hpp"
Mike Kellyc9ea45a2020-02-28 18:11:58 +00009
10#include <armnn/TypesUtils.hpp>
11
12namespace armnn
13{
14
15template <armnn::DataType DataType>
16class RefTransposeWorkload : public TypedWorkload<TransposeQueueDescriptor, DataType>
17{
18public:
Mike Kellyc9ea45a2020-02-28 18:11:58 +000019 using TypedWorkload<TransposeQueueDescriptor, DataType>::m_Data;
20 using TypedWorkload<TransposeQueueDescriptor, DataType>::TypedWorkload;
21 void Execute() const override;
Matthew Sloyan2d213a72022-06-30 17:13:04 +010022 void ExecuteAsync(ExecutionData& executionData) override;
Finn Williamsb8181f72021-04-07 10:23:21 +010023private:
24 void Execute(std::vector<ITensorHandle*> inputs, std::vector<ITensorHandle*> outputs) const;
Mike Kellyc9ea45a2020-02-28 18:11:58 +000025};
26
Narumol Prangnawarat44179c32020-03-11 14:51:27 +000027using RefTransposeBFloat16Workload = RefTransposeWorkload<DataType::BFloat16>;
Mike Kellyc9ea45a2020-02-28 18:11:58 +000028using RefTransposeFloat16Workload = RefTransposeWorkload<DataType::Float16>;
29using RefTransposeFloat32Workload = RefTransposeWorkload<DataType::Float32>;
Sadik Armagan303980c2020-04-17 12:45:14 +010030using RefTransposeQAsymmS8Workload = RefTransposeWorkload<DataType::QAsymmS8>;
Mike Kellyc9ea45a2020-02-28 18:11:58 +000031using RefTransposeQAsymm8Workload = RefTransposeWorkload<DataType::QAsymmU8>;
32using RefTransposeQSymm16Workload = RefTransposeWorkload<DataType::QSymmS16>;
33
34} //namespace armnn