blob: 2d635bf6c2f7c52703f754cf375f24ba8f92a48f [file] [log] [blame]
Nikhil Raj68c2c902019-09-19 11:21:11 +01001//
Mike Kelly1f140f72021-04-06 12:25:55 +01002// Copyright © 2019 Arm Ltd and Contributors. All rights reserved.
Nikhil Raj68c2c902019-09-19 11:21:11 +01003// SPDX-License-Identifier: MIT
4//
5
6#include "RefArgMinMaxWorkload.hpp"
7
8#include "ArgMinMax.hpp"
9#include "RefWorkloadUtils.hpp"
10#include "Decoders.hpp"
11#include "Encoders.hpp"
12#include "Profiling.hpp"
13
14namespace armnn
15{
16RefArgMinMaxWorkload::RefArgMinMaxWorkload(
17 const ArgMinMaxQueueDescriptor& descriptor,
18 const WorkloadInfo& info)
19 : BaseWorkload<ArgMinMaxQueueDescriptor>(descriptor, info) {}
20
Finn Williamsb8181f72021-04-07 10:23:21 +010021
Nikhil Raj68c2c902019-09-19 11:21:11 +010022void RefArgMinMaxWorkload::Execute() const
23{
Finn Williamsb8181f72021-04-07 10:23:21 +010024 Execute(m_Data.m_Inputs, m_Data.m_Outputs);
25}
26
27void RefArgMinMaxWorkload::ExecuteAsync(WorkingMemDescriptor &workingMemDescriptor)
28{
29 Execute(workingMemDescriptor.m_Inputs, workingMemDescriptor.m_Outputs);
30}
31
32void RefArgMinMaxWorkload::Execute(std::vector<ITensorHandle*> inputs, std::vector<ITensorHandle*> outputs) const
33{
Nikhil Raj68c2c902019-09-19 11:21:11 +010034 ARMNN_SCOPED_PROFILING_EVENT(Compute::CpuRef, "RefArgMinMaxWorkload_Execute");
35
Finn Williamsb8181f72021-04-07 10:23:21 +010036 const TensorInfo &inputTensorInfo = GetTensorInfo(inputs[0]);
Nikhil Raj68c2c902019-09-19 11:21:11 +010037
Finn Williamsb8181f72021-04-07 10:23:21 +010038 std::unique_ptr<Decoder<float>> decoderPtr = MakeDecoder<float>(inputTensorInfo, inputs[0]->Map());
Nikhil Raj68c2c902019-09-19 11:21:11 +010039 Decoder<float> &decoder = *decoderPtr;
40
Finn Williamsb8181f72021-04-07 10:23:21 +010041 const TensorInfo &outputTensorInfo = GetTensorInfo(outputs[0]);
Nikhil Raj68c2c902019-09-19 11:21:11 +010042
Mike Kelly1f140f72021-04-06 12:25:55 +010043 if (outputTensorInfo.GetDataType() == armnn::DataType::Signed32) {
Finn Williams01097942021-04-26 12:06:34 +010044 int32_t *output = GetOutputTensorData<int32_t>(outputs[0]);
Inki Daed4619e22020-09-10 15:33:54 +090045 ArgMinMax(decoder, output, inputTensorInfo, outputTensorInfo, m_Data.m_Parameters.m_Function,
46 m_Data.m_Parameters.m_Axis);
47 } else {
Finn Williams01097942021-04-26 12:06:34 +010048 int64_t *output = GetOutputTensorData<int64_t>(outputs[0]);
Inki Daed4619e22020-09-10 15:33:54 +090049 ArgMinMax(decoder, output, inputTensorInfo, outputTensorInfo, m_Data.m_Parameters.m_Function,
50 m_Data.m_Parameters.m_Axis);
51 }
Nikhil Raj68c2c902019-09-19 11:21:11 +010052}
53
54} //namespace armnn