2 // Copyright © 2017 Arm Ltd. All rights reserved.
3 // See LICENSE file in the project root for full license information.
7 #include "OutputHandler.hpp"
8 #include "ArmComputeTensorUtils.hpp"
10 #include <arm_compute/runtime/MemoryGroup.h>
11 #include <arm_compute/runtime/IMemoryGroup.h>
12 #include <arm_compute/runtime/Tensor.h>
13 #include <arm_compute/runtime/SubTensor.h>
14 #include <arm_compute/core/TensorShape.h>
15 #include <arm_compute/core/Coordinates.h>
17 #include <boost/polymorphic_pointer_cast.hpp>
22 class INeonTensorHandle : public ITensorHandle
25 virtual arm_compute::ITensor& GetTensor() = 0;
26 virtual arm_compute::ITensor const& GetTensor() const = 0;
27 virtual arm_compute::DataType GetDataType() const = 0;
28 virtual void SetMemoryGroup(const std::shared_ptr<arm_compute::IMemoryGroup>& memoryGroup) = 0;
31 class NeonTensorHandle : public INeonTensorHandle
34 NeonTensorHandle(const TensorInfo& tensorInfo)
36 armnn::armcomputetensorutils::BuildArmComputeTensor(m_Tensor, tensorInfo);
39 arm_compute::ITensor& GetTensor() override { return m_Tensor; }
40 arm_compute::ITensor const& GetTensor() const override { return m_Tensor; }
42 virtual void Allocate() override
44 armnn::armcomputetensorutils::InitialiseArmComputeTensorEmpty(m_Tensor);
47 virtual void Manage() override
49 BOOST_ASSERT(m_MemoryGroup != nullptr);
50 m_MemoryGroup->manage(&m_Tensor);
53 virtual ITensorHandle::Type GetType() const override { return ITensorHandle::Neon; }
55 virtual ITensorHandle* GetParent() const override { return nullptr; }
57 virtual arm_compute::DataType GetDataType() const override
59 return m_Tensor.info()->data_type();
62 virtual void SetMemoryGroup(const std::shared_ptr<arm_compute::IMemoryGroup>& memoryGroup) override
64 m_MemoryGroup = boost::polymorphic_pointer_downcast<arm_compute::MemoryGroup>(memoryGroup);
67 virtual const void* Map(bool /* blocking = true */) const override
69 return static_cast<const void*>(m_Tensor.buffer() + m_Tensor.info()->offset_first_element_in_bytes());
71 virtual void Unmap() const override {}
74 TensorShape GetStrides() const override
76 return armcomputetensorutils::GetStrides(m_Tensor.info()->strides_in_bytes());
79 TensorShape GetShape() const override
81 return armcomputetensorutils::GetShape(m_Tensor.info()->tensor_shape());
85 arm_compute::Tensor m_Tensor;
86 std::shared_ptr<arm_compute::MemoryGroup> m_MemoryGroup;
89 class NeonSubTensorHandle : public INeonTensorHandle
92 NeonSubTensorHandle(INeonTensorHandle* parent,
93 const arm_compute::TensorShape& shape,
94 const arm_compute::Coordinates& coords)
95 : m_Tensor(&parent->GetTensor(), shape, coords)
97 parentHandle = parent;
100 arm_compute::ITensor& GetTensor() override { return m_Tensor; }
101 arm_compute::ITensor const& GetTensor() const override { return m_Tensor; }
103 virtual void Allocate() override {}
104 virtual void Manage() override {}
106 virtual ITensorHandle::Type GetType() const override { return ITensorHandle::Neon; }
108 virtual ITensorHandle* GetParent() const override { return parentHandle; }
110 virtual arm_compute::DataType GetDataType() const override
112 return m_Tensor.info()->data_type();
115 virtual void SetMemoryGroup(const std::shared_ptr<arm_compute::IMemoryGroup>&) override {}
117 virtual const void* Map(bool /* blocking = true */) const override
119 return static_cast<const void*>(m_Tensor.buffer() + m_Tensor.info()->offset_first_element_in_bytes());
121 virtual void Unmap() const override {}
123 TensorShape GetStrides() const override
125 return armcomputetensorutils::GetStrides(m_Tensor.info()->strides_in_bytes());
128 TensorShape GetShape() const override
130 return armcomputetensorutils::GetShape(m_Tensor.info()->tensor_shape());
133 arm_compute::SubTensor m_Tensor;
134 ITensorHandle* parentHandle = nullptr;