blob: 48109529f06bea30cbfa2d5a01064a420d31cc37 [file] [log] [blame]
Finn Williams2605b232020-06-10 15:53:46 +01001//
Matthew Sloyan2d213a72022-06-30 17:13:04 +01002// Copyright © 2022 Arm Ltd and Contributors. All rights reserved.
Finn Williams2605b232020-06-10 15:53:46 +01003// SPDX-License-Identifier: MIT
4//
5
6#pragma once
7
Finn Williams73c547d2022-02-15 20:47:34 +00008#include "RefBaseWorkload.hpp"
Colm Donelan0c479742021-12-10 12:43:54 +00009#include <armnn/backends/WorkloadData.hpp>
Finn Williams2605b232020-06-10 15:53:46 +010010
11#include "RefWorkloadUtils.hpp"
12
13namespace armnn
14{
15
Finn Williams73c547d2022-02-15 20:47:34 +000016struct RefRankWorkload : public RefBaseWorkload<RankQueueDescriptor>
Finn Williams2605b232020-06-10 15:53:46 +010017{
18public:
Finn Williams73c547d2022-02-15 20:47:34 +000019 using RefBaseWorkload<RankQueueDescriptor>::RefBaseWorkload;
Finn Williams2605b232020-06-10 15:53:46 +010020 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 }
Matthew Sloyan2d213a72022-06-30 17:13:04 +010025 void ExecuteAsync(ExecutionData& executionData) override
Finn Williamsb8181f72021-04-07 10:23:21 +010026 {
Matthew Sloyan2d213a72022-06-30 17:13:04 +010027 WorkingMemDescriptor* workingMemDescriptor = static_cast<WorkingMemDescriptor*>(executionData.m_Data);
28 Execute(workingMemDescriptor->m_Inputs, workingMemDescriptor->m_Outputs);
Finn Williamsb8181f72021-04-07 10:23:21 +010029 }
30
31private:
32 void Execute(std::vector<ITensorHandle*> inputs, std::vector<ITensorHandle*> outputs) const
33 {
34 const int32_t rank = static_cast<int32_t>(GetTensorInfo(inputs[0]).GetNumDimensions());
Finn Williams2605b232020-06-10 15:53:46 +010035
Finn Williams01097942021-04-26 12:06:34 +010036 std::memcpy(outputs[0]->Map(), &rank, sizeof(int32_t));
Finn Williamsb8181f72021-04-07 10:23:21 +010037 outputs[0]->Unmap();
Finn Williams2605b232020-06-10 15:53:46 +010038 }
39};
40
41} //namespace armnn
42
43
44
45