24.02
Main Page
Related Pages
Namespaces
Namespace List
Namespace Members
All
a
b
c
d
e
f
g
h
i
j
l
m
n
o
p
q
r
s
t
u
v
w
Functions
a
b
c
d
e
f
g
h
i
l
m
n
o
p
q
r
s
t
v
w
Variables
Typedefs
a
b
c
d
e
f
g
h
i
l
m
n
o
p
q
r
s
t
u
w
Enumerations
a
b
c
d
e
f
g
j
l
m
n
o
p
q
r
s
t
u
Classes
Class List
Class Index
Class Hierarchy
Class Members
All
a
b
c
d
e
f
g
h
i
j
k
l
m
n
o
p
q
r
s
t
u
v
w
~
Functions
a
b
c
d
e
f
g
h
i
j
l
m
n
o
p
q
r
s
t
u
v
w
~
Variables
c
d
e
f
i
j
l
m
o
p
r
s
v
w
Typedefs
a
b
c
d
e
f
g
h
i
k
l
m
n
o
p
r
s
t
v
w
Enumerations
Enumerator
Related Functions
Files
File List
File Members
All
a
b
c
d
e
f
g
h
i
l
m
o
r
s
t
u
v
x
z
Functions
a
b
c
g
i
m
r
s
t
v
z
Variables
Typedefs
Macros
a
c
d
e
f
h
i
l
o
s
t
u
v
x
Examples
•
All
Classes
Namespaces
Files
Functions
Variables
Typedefs
Enumerations
Enumerator
Friends
Macros
Pages
RefMeanWorkload.cpp
Go to the documentation of this file.
1
//
2
// Copyright © 2019,2021-2023 Arm Ltd and Contributors. All rights reserved.
3
// SPDX-License-Identifier: MIT
4
//
5
6
#include "
RefMeanWorkload.hpp
"
7
8
#include "
Reduce.hpp
"
9
#include "
RefWorkloadUtils.hpp
"
10
11
#include "
Profiling.hpp
"
12
13
#include <vector>
14
15
namespace
armnn
16
{
17
18
RefMeanWorkload::RefMeanWorkload
(
const
MeanQueueDescriptor
& descriptor,
const
WorkloadInfo
& info)
19
:
RefBaseWorkload
<
MeanQueueDescriptor
>(descriptor,
info
) {}
20
21
void
RefMeanWorkload::Execute
()
const
22
{
23
Execute
(
m_Data
.
m_Inputs
,
m_Data
.
m_Outputs
);
24
}
25
26
void
RefMeanWorkload::ExecuteAsync
(
ExecutionData
& executionData)
27
{
28
WorkingMemDescriptor
* workingMemDescriptor =
static_cast<
WorkingMemDescriptor
*
>
(executionData.
m_Data
);
29
Execute
(workingMemDescriptor->
m_Inputs
, workingMemDescriptor->
m_Outputs
);
30
}
31
32
void
RefMeanWorkload::Execute
(std::vector<ITensorHandle*> inputs, std::vector<ITensorHandle*> outputs)
const
33
{
34
ARMNN_SCOPED_PROFILING_EVENT_REF_NAME_GUID
(
"RefMeanWorkload_Execute"
);
35
36
const
TensorInfo
& inputInfo =
GetTensorInfo
(inputs[0]);
37
const
TensorInfo
& outputInfo =
GetTensorInfo
(outputs[0]);
38
39
auto
inputDecoder = MakeDecoder<float>(inputInfo, inputs[0]->
Map
());
40
auto
outputEncoder = MakeEncoder<float>(outputInfo, outputs[0]->
Map
());
41
42
Reduce
(inputInfo,
43
outputInfo,
44
*inputDecoder,
45
*outputEncoder,
46
m_Data
.
m_Parameters
.
m_Axis
,
47
armnn::ReduceOperation::Mean
);
48
}
49
50
}
//namespace armnn
armnn::experimental::ExecutionData::m_Data
void * m_Data
Definition:
ExecutionData.hpp:16
armnn::TensorInfo
Definition:
Tensor.hpp:152
armnn::Reduce
void Reduce(const TensorInfo &inputInfo, const TensorInfo &outputInfo, Decoder< float > &input, Encoder< float > &output, const std::vector< uint32_t > axis, const ReduceOperation reduceOperation)
Definition:
Reduce.cpp:70
Profiling.hpp
ARMNN_SCOPED_PROFILING_EVENT_REF_NAME_GUID
#define ARMNN_SCOPED_PROFILING_EVENT_REF_NAME_GUID(label)
Creates a profiling event that uses GetGuid() and GetName() from the calling class.
Definition:
RefWorkloadUtils.hpp:22
armnn::ReduceOperation::Mean
@ Mean
armnn::QueueDescriptorWithParameters::m_Parameters
LayerDescriptor m_Parameters
Definition:
WorkloadData.hpp:66
armnn::WorkloadInfo
Contains information about TensorInfos of a layer.
Definition:
WorkloadInfo.hpp:16
armnn::RefMeanWorkload::Execute
void Execute() const override
Definition:
RefMeanWorkload.cpp:21
armnn::GetTensorInfo
const TensorInfo & GetTensorInfo(const ITensorHandle *tensorHandle)
float32 helpers
Definition:
RefWorkloadUtils.hpp:33
armnn::BoostLogSeverityMapping::info
@ info
armnn::QueueDescriptor::m_Outputs
std::vector< ITensorHandle * > m_Outputs
Definition:
WorkloadData.hpp:27
RefMeanWorkload.hpp
armnn::RefMeanWorkload::RefMeanWorkload
RefMeanWorkload(const MeanQueueDescriptor &descriptor, const WorkloadInfo &info)
Definition:
RefMeanWorkload.cpp:18
RefWorkloadUtils.hpp
armnn::MeanDescriptor::m_Axis
std::vector< unsigned int > m_Axis
Values for the dimensions to reduce.
Definition:
Descriptors.hpp:1190
armnn::BaseWorkload< MeanQueueDescriptor >::m_Data
MeanQueueDescriptor m_Data
Definition:
Workload.hpp:89
Reduce.hpp
armnn::LayerType::Map
@ Map
armnn::experimental::WorkingMemDescriptor::m_Inputs
std::vector< ITensorHandle * > m_Inputs
Definition:
WorkingMemDescriptor.hpp:20
armnn
Copyright (c) 2021 ARM Limited and Contributors.
Definition:
01_00_quick_start.dox:6
armnn::experimental::WorkingMemDescriptor
Definition:
WorkingMemDescriptor.hpp:18
armnn::MeanQueueDescriptor
Definition:
WorkloadData.hpp:288
armnn::RefBaseWorkload
Definition:
RefBaseWorkload.hpp:13
armnn::experimental::WorkingMemDescriptor::m_Outputs
std::vector< ITensorHandle * > m_Outputs
Definition:
WorkingMemDescriptor.hpp:21
armnn::QueueDescriptor::m_Inputs
std::vector< ITensorHandle * > m_Inputs
Definition:
WorkloadData.hpp:26
armnn::RefMeanWorkload::ExecuteAsync
void ExecuteAsync(ExecutionData &executionData) override
Definition:
RefMeanWorkload.cpp:26
armnn::experimental::ExecutionData
Definition:
ExecutionData.hpp:14
src
backends
reference
workloads
RefMeanWorkload.cpp
Generated on Wed Feb 14 2024 16:36:17 for Arm NN by
1.8.17