ArmNN
 25.11
Loading...
Searching...
No Matches
RefReduceWorkload.cpp
Go to the documentation of this file.
1//
2// Copyright © 2020 Samsung Electronics Co Ltd and Contributors. All rights reserved.
3// Copyright © 2021-2024 Arm Ltd and Contributors. All rights reserved.
4// SPDX-License-Identifier: MIT
5//
6
8
9#include "Reduce.hpp"
10#include "RefWorkloadUtils.hpp"
11#include "BaseIterator.hpp"
12#include "Profiling.hpp"
13
14namespace armnn
15{
16
21
23{
24 Execute(m_Data.m_Inputs, m_Data.m_Outputs);
25}
26
27void RefReduceWorkload::Execute(std::vector<ITensorHandle*> inputs, std::vector<ITensorHandle*> outputs) const
28{
29 ARMNN_SCOPED_PROFILING_EVENT_REF_NAME_GUID("RefReduceWorkload_Execute");
30
31 const TensorInfo& inputInfo = GetTensorInfo(inputs[0]);
32 const TensorInfo& outputInfo = GetTensorInfo(outputs[0]);
33
34 std::unique_ptr<Decoder<float>> decoderPtr = MakeDecoder<float>(inputInfo, inputs[0]->Map());
35 Decoder<float>& decoder = *decoderPtr;
36
37 std::unique_ptr<Encoder<float>> encoderPtr = MakeEncoder<float>(outputInfo, outputs[0]->Map());
38 Encoder<float>& encoder = *encoderPtr;
39
40 Reduce(inputInfo,
41 outputInfo,
42 decoder,
43 encoder,
46}
47
48} //namespace armnn
#define ARMNN_SCOPED_PROFILING_EVENT_REF_NAME_GUID(label)
Creates a profiling event that uses GetGuid() and GetName() from the calling class.
RefBaseWorkload(const ReduceQueueDescriptor &descriptor, const WorkloadInfo &info)
RefReduceWorkload(const ReduceQueueDescriptor &descriptor, const WorkloadInfo &info)
void Execute() const override
Copyright (c) 2021 ARM Limited and Contributors.
std::unique_ptr< Decoder< T > > MakeDecoder(const TensorInfo &info, const void *data=nullptr)
std::unique_ptr< Encoder< T > > MakeEncoder(const TensorInfo &info, void *data=nullptr)
armnn::TensorInfo GetTensorInfo(unsigned int numberOfBatches, unsigned int numberOfChannels, unsigned int height, unsigned int width, const armnn::DataLayout dataLayout, const armnn::DataType dataType)
std::vector< uint32_t > m_vAxis
The indices of the dimensions to reduce.
ReduceOperation m_ReduceOperation
Specifies the reduction operation to execute.
Contains information about TensorInfos of a layer.