blob: 288dddd21d7ef3c2a58d2b4210a85653091e054f [file] [log] [blame]
Finn Williams2605b232020-06-10 15:53:46 +01001//
2// Copyright © 2020 Arm Ltd and Contributors. All rights reserved.
3// SPDX-License-Identifier: MIT
4//
5
6#pragma once
7
8#include <backendsCommon/Workload.hpp>
9#include <backendsCommon/WorkloadData.hpp>
10
11#include "RefWorkloadUtils.hpp"
12
13namespace armnn
14{
15
16struct RefRankWorkload : public BaseWorkload<RankQueueDescriptor>
17{
18public:
19 using BaseWorkload<RankQueueDescriptor>::BaseWorkload;
20 virtual void Execute() const override
21 {
Finn Williamsb8181f72021-04-07 10:23:21 +010022 Execute(m_Data.m_Inputs, m_Data.m_Outputs);
23
24 }
25 void ExecuteAsync(WorkingMemDescriptor& workingMemDescriptor) override
26 {
27 Execute(workingMemDescriptor.m_Inputs, workingMemDescriptor.m_Outputs);
28 }
29
30private:
31 void Execute(std::vector<ITensorHandle*> inputs, std::vector<ITensorHandle*> outputs) const
32 {
33 const int32_t rank = static_cast<int32_t>(GetTensorInfo(inputs[0]).GetNumDimensions());
Finn Williams2605b232020-06-10 15:53:46 +010034
Finn Williams01097942021-04-26 12:06:34 +010035 std::memcpy(outputs[0]->Map(), &rank, sizeof(int32_t));
Finn Williamsb8181f72021-04-07 10:23:21 +010036 outputs[0]->Unmap();
Finn Williams2605b232020-06-10 15:53:46 +010037 }
38};
39
40} //namespace armnn
41
42
43
44