blob: 7941ce2c361aa2b879df35029034c2381100f88c [file] [log] [blame]
James Conroy4d1ff582019-06-10 17:06:39 +01001//
2// Copyright © 2017 Arm Ltd. All rights reserved.
3// SPDX-License-Identifier: MIT
4//
5
6#include "RefMeanWorkload.hpp"
7
Sadik Armagan0c3ea5b2021-02-03 09:29:30 +00008#include "Reduce.hpp"
James Conroy4d1ff582019-06-10 17:06:39 +01009#include "RefWorkloadUtils.hpp"
10
11#include "Profiling.hpp"
12
13#include <vector>
14
15namespace armnn
16{
17
18RefMeanWorkload::RefMeanWorkload(const MeanQueueDescriptor& descriptor, const WorkloadInfo& info)
19 :BaseWorkload<MeanQueueDescriptor>(descriptor, info) {}
20
21void RefMeanWorkload::Execute() const
22{
Finn Williamsb8181f72021-04-07 10:23:21 +010023 Execute(m_Data.m_Inputs, m_Data.m_Outputs);
24}
25
26void RefMeanWorkload::ExecuteAsync(WorkingMemDescriptor &workingMemDescriptor)
27{
28 Execute(workingMemDescriptor.m_Inputs, workingMemDescriptor.m_Outputs);
29}
30
31void RefMeanWorkload::Execute(std::vector<ITensorHandle*> inputs, std::vector<ITensorHandle*> outputs) const
32{
James Conroy4d1ff582019-06-10 17:06:39 +010033 ARMNN_SCOPED_PROFILING_EVENT(Compute::CpuRef, "RefMeanWorkload_Execute");
34
Finn Williamsb8181f72021-04-07 10:23:21 +010035 const TensorInfo& inputInfo = GetTensorInfo(inputs[0]);
36 const TensorInfo& outputInfo = GetTensorInfo(outputs[0]);
James Conroy4d1ff582019-06-10 17:06:39 +010037
Finn Williamsb8181f72021-04-07 10:23:21 +010038 auto inputDecoder = MakeDecoder<float>(inputInfo, inputs[0]->Map());
39 auto outputEncoder = MakeEncoder<float>(outputInfo, outputs[0]->Map());
James Conroy4d1ff582019-06-10 17:06:39 +010040
Sadik Armagan0c3ea5b2021-02-03 09:29:30 +000041 Reduce(inputInfo,
42 outputInfo,
43 *inputDecoder,
44 *outputEncoder,
45 m_Data.m_Parameters.m_Axis,
46 armnn::ReduceOperation::Mean);
James Conroy4d1ff582019-06-10 17:06:39 +010047}
48
49} //namespace armnn