blob: a2069a8ffef821d703585005637e3ba14522fb1d [file] [log] [blame]
Laurent Carlier749294b2020-06-01 09:03:17 +01001//
Mike Kelly7cbe7812023-07-25 17:37:33 +01002// Copyright © 2017-2023 Arm Ltd and Contributors. All rights reserved.
David Beckecb56cd2018-09-05 12:52:57 +01003// SPDX-License-Identifier: MIT
telsoa014fcda012018-03-09 14:13:49 +00004//
5
6#include "RefPermuteWorkload.hpp"
7#include "RefWorkloadUtils.hpp"
8
Matteo Martincighe011d202019-11-28 11:35:47 +00009#include <armnnUtils/Permute.hpp>
10
Aron Virginas-Tard4f0fea2019-04-09 14:08:06 +010011#include <ResolveType.hpp>
telsoa014fcda012018-03-09 14:13:49 +000012
13namespace armnn
14{
15
16template <armnn::DataType DataType>
17void RefPermuteWorkload<DataType>::Execute() const
18{
Finn Williamsb8181f72021-04-07 10:23:21 +010019 Execute(m_Data.m_Inputs, m_Data.m_Outputs);
20}
21
22template <armnn::DataType DataType>
Matthew Sloyan2d213a72022-06-30 17:13:04 +010023void RefPermuteWorkload<DataType>::ExecuteAsync(ExecutionData& executionData)
Finn Williamsb8181f72021-04-07 10:23:21 +010024{
Matthew Sloyan2d213a72022-06-30 17:13:04 +010025 WorkingMemDescriptor* workingMemDescriptor = static_cast<WorkingMemDescriptor*>(executionData.m_Data);
26 Execute(workingMemDescriptor->m_Inputs, workingMemDescriptor->m_Outputs);
Finn Williamsb8181f72021-04-07 10:23:21 +010027}
28
29template <armnn::DataType DataType>
30void RefPermuteWorkload<DataType>::Execute(std::vector<ITensorHandle*> inputs,
31 std::vector<ITensorHandle*> outputs) const
32{
telsoa014fcda012018-03-09 14:13:49 +000033 using T = ResolveType<DataType>;
34
Mike Kelly7cbe7812023-07-25 17:37:33 +010035 ARMNN_SCOPED_PROFILING_EVENT_REF_NAME_GUID("RefPermuteWorkload_Execute");
telsoa014fcda012018-03-09 14:13:49 +000036
Finn Williamsb8181f72021-04-07 10:23:21 +010037 const ITensorHandle* src = inputs[0];
38 ITensorHandle* dst = outputs[0];
telsoa014fcda012018-03-09 14:13:49 +000039 const PermutationVector& mappings = m_Data.m_Parameters.m_DimMappings;
40
Matteo Martincighd5b9e642019-01-04 18:01:21 +000041 armnnUtils::Permute(GetTensorInfo(dst).GetShape(), mappings,
Matthew Bentham4cefc412019-06-18 16:14:34 +010042 src->Map(), dst->Map(), sizeof(T));
telsoa014fcda012018-03-09 14:13:49 +000043}
44
Narumol Prangnawarat44179c32020-03-11 14:51:27 +000045template class RefPermuteWorkload<DataType::BFloat16>;
arovir01616e7752018-10-01 17:08:59 +010046template class RefPermuteWorkload<DataType::Float16>;
telsoa014fcda012018-03-09 14:13:49 +000047template class RefPermuteWorkload<DataType::Float32>;
Sadik Armagan303980c2020-04-17 12:45:14 +010048template class RefPermuteWorkload<DataType::QAsymmS8>;
Derek Lambertif90c56d2020-01-10 17:14:08 +000049template class RefPermuteWorkload<DataType::QAsymmU8>;
50template class RefPermuteWorkload<DataType::QSymmS16>;
telsoa014fcda012018-03-09 14:13:49 +000051
52} //namespace armnn