blob: e35632db5b21509cf0f13fb10882516b10f498e5 [file] [log] [blame]
Laurent Carlier749294b2020-06-01 09:03:17 +01001//
Nattapat Chaimanowong3ea76d52018-11-09 14:10:38 +00002// Copyright © 2017 Arm Ltd. All rights reserved.
3// SPDX-License-Identifier: MIT
4//
5
6#include "RefSpaceToBatchNdWorkload.hpp"
7#include "SpaceToBatchNd.hpp"
8
9#include "RefWorkloadUtils.hpp"
Aron Virginas-Tard4f0fea2019-04-09 14:08:06 +010010#include <ResolveType.hpp>
Nattapat Chaimanowong3ea76d52018-11-09 14:10:38 +000011
12namespace armnn
13{
14
nikraj0122f0f2b2019-05-30 17:29:32 +010015void RefSpaceToBatchNdWorkload::Execute() const
Nattapat Chaimanowong3ea76d52018-11-09 14:10:38 +000016{
Finn Williamsb8181f72021-04-07 10:23:21 +010017 Execute(m_Data.m_Inputs, m_Data.m_Outputs);
18}
19
20void RefSpaceToBatchNdWorkload::ExecuteAsync(WorkingMemDescriptor &workingMemDescriptor)
21{
22 Execute(workingMemDescriptor.m_Inputs, workingMemDescriptor.m_Outputs);
23}
24
25void RefSpaceToBatchNdWorkload::Execute(std::vector<ITensorHandle*> inputs, std::vector<ITensorHandle*> outputs) const
26{
nikraj0122f0f2b2019-05-30 17:29:32 +010027 ARMNN_SCOPED_PROFILING_EVENT(Compute::CpuRef, "RefSpaceToBatchNdWorkload_Execute");
Nattapat Chaimanowong3ea76d52018-11-09 14:10:38 +000028
Finn Williamsb8181f72021-04-07 10:23:21 +010029 const TensorInfo& inputInfo = GetTensorInfo(inputs[0]);
30 std::unique_ptr<Decoder<float>> decoder = MakeDecoder<float>(inputInfo, inputs[0]->Map());
nikraj0122f0f2b2019-05-30 17:29:32 +010031
Finn Williamsb8181f72021-04-07 10:23:21 +010032 const TensorInfo& outputInfo = GetTensorInfo(outputs[0]);
33 std::unique_ptr<Encoder<float>> encoder = MakeEncoder<float>(outputInfo, outputs[0]->Map());
Nattapat Chaimanowong3ea76d52018-11-09 14:10:38 +000034
nikraj0122f0f2b2019-05-30 17:29:32 +010035 SpaceToBatchNd(inputInfo, outputInfo, m_Data.m_Parameters, *decoder, *encoder);
Nattapat Chaimanowong3ea76d52018-11-09 14:10:38 +000036}
37
Nattapat Chaimanowong3ea76d52018-11-09 14:10:38 +000038} //namespace armnn