aboutsummaryrefslogtreecommitdiff
path: root/src/backends/cl/ClTensorHandle.hpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/backends/cl/ClTensorHandle.hpp')
-rw-r--r--src/backends/cl/ClTensorHandle.hpp304
1 files changed, 0 insertions, 304 deletions
diff --git a/src/backends/cl/ClTensorHandle.hpp b/src/backends/cl/ClTensorHandle.hpp
deleted file mode 100644
index 1830d186b6..0000000000
--- a/src/backends/cl/ClTensorHandle.hpp
+++ /dev/null
@@ -1,304 +0,0 @@
-//
-// Copyright © 2017 Arm Ltd. All rights reserved.
-// SPDX-License-Identifier: MIT
-//
-#pragma once
-
-#include <aclCommon/ArmComputeTensorHandle.hpp>
-#include <aclCommon/ArmComputeTensorUtils.hpp>
-
-#include <Half.hpp>
-
-#include <arm_compute/runtime/CL/CLTensor.h>
-#include <arm_compute/runtime/CL/CLSubTensor.h>
-#include <arm_compute/runtime/IMemoryGroup.h>
-#include <arm_compute/runtime/MemoryGroup.h>
-#include <arm_compute/core/TensorShape.h>
-#include <arm_compute/core/Coordinates.h>
-
-#include <boost/polymorphic_pointer_cast.hpp>
-
-namespace armnn
-{
-
-
-class IClTensorHandle : public IAclTensorHandle
-{
-public:
- virtual arm_compute::ICLTensor& GetTensor() = 0;
- virtual arm_compute::ICLTensor const& GetTensor() const = 0;
- virtual arm_compute::DataType GetDataType() const = 0;
- virtual void SetMemoryGroup(const std::shared_ptr<arm_compute::IMemoryGroup>& memoryGroup) = 0;
-};
-
-class ClTensorHandle : public IClTensorHandle
-{
-public:
- ClTensorHandle(const TensorInfo& tensorInfo)
- {
- armnn::armcomputetensorutils::BuildArmComputeTensor(m_Tensor, tensorInfo);
- }
-
- ClTensorHandle(const TensorInfo& tensorInfo, DataLayout dataLayout)
- {
- armnn::armcomputetensorutils::BuildArmComputeTensor(m_Tensor, tensorInfo, dataLayout);
- }
-
- arm_compute::CLTensor& GetTensor() override { return m_Tensor; }
- arm_compute::CLTensor const& GetTensor() const override { return m_Tensor; }
- virtual void Allocate() override {armnn::armcomputetensorutils::InitialiseArmComputeTensorEmpty(m_Tensor);}
-
- virtual void Manage() override
- {
- assert(m_MemoryGroup != nullptr);
- m_MemoryGroup->manage(&m_Tensor);
- }
-
- virtual const void* Map(bool blocking = true) const override
- {
- const_cast<arm_compute::CLTensor*>(&m_Tensor)->map(blocking);
- return static_cast<const void*>(m_Tensor.buffer() + m_Tensor.info()->offset_first_element_in_bytes());
- }
-
- virtual void Unmap() const override { const_cast<arm_compute::CLTensor*>(&m_Tensor)->unmap(); }
-
- virtual ITensorHandle* GetParent() const override { return nullptr; }
-
- virtual arm_compute::DataType GetDataType() const override
- {
- return m_Tensor.info()->data_type();
- }
-
- virtual void SetMemoryGroup(const std::shared_ptr<arm_compute::IMemoryGroup>& memoryGroup) override
- {
- m_MemoryGroup = boost::polymorphic_pointer_downcast<arm_compute::MemoryGroup>(memoryGroup);
- }
-
- TensorShape GetStrides() const override
- {
- return armcomputetensorutils::GetStrides(m_Tensor.info()->strides_in_bytes());
- }
-
- TensorShape GetShape() const override
- {
- return armcomputetensorutils::GetShape(m_Tensor.info()->tensor_shape());
- }
-
-private:
- // Only used for testing
- void CopyOutTo(void* memory) const override
- {
- const_cast<armnn::ClTensorHandle*>(this)->Map(true);
- switch(this->GetDataType())
- {
- case arm_compute::DataType::F32:
- armcomputetensorutils::CopyArmComputeITensorData(this->GetTensor(),
- static_cast<float*>(memory));
- break;
- case arm_compute::DataType::U8:
- case arm_compute::DataType::QASYMM8:
- armcomputetensorutils::CopyArmComputeITensorData(this->GetTensor(),
- static_cast<uint8_t*>(memory));
- break;
- case arm_compute::DataType::QSYMM8_PER_CHANNEL:
- case arm_compute::DataType::QASYMM8_SIGNED:
- armcomputetensorutils::CopyArmComputeITensorData(this->GetTensor(),
- static_cast<int8_t*>(memory));
- break;
- case arm_compute::DataType::F16:
- armcomputetensorutils::CopyArmComputeITensorData(this->GetTensor(),
- static_cast<armnn::Half*>(memory));
- break;
- case arm_compute::DataType::S16:
- case arm_compute::DataType::QSYMM16:
- armcomputetensorutils::CopyArmComputeITensorData(this->GetTensor(),
- static_cast<int16_t*>(memory));
- break;
- case arm_compute::DataType::S32:
- armcomputetensorutils::CopyArmComputeITensorData(this->GetTensor(),
- static_cast<int32_t*>(memory));
- break;
- default:
- {
- throw armnn::UnimplementedException();
- }
- }
- const_cast<armnn::ClTensorHandle*>(this)->Unmap();
- }
-
- // Only used for testing
- void CopyInFrom(const void* memory) override
- {
- this->Map(true);
- switch(this->GetDataType())
- {
- case arm_compute::DataType::F32:
- armcomputetensorutils::CopyArmComputeITensorData(static_cast<const float*>(memory),
- this->GetTensor());
- break;
- case arm_compute::DataType::U8:
- case arm_compute::DataType::QASYMM8:
- armcomputetensorutils::CopyArmComputeITensorData(static_cast<const uint8_t*>(memory),
- this->GetTensor());
- break;
- case arm_compute::DataType::F16:
- armcomputetensorutils::CopyArmComputeITensorData(static_cast<const armnn::Half*>(memory),
- this->GetTensor());
- break;
- case arm_compute::DataType::S16:
- case arm_compute::DataType::QSYMM8_PER_CHANNEL:
- case arm_compute::DataType::QASYMM8_SIGNED:
- armcomputetensorutils::CopyArmComputeITensorData(static_cast<const int8_t*>(memory),
- this->GetTensor());
- break;
- case arm_compute::DataType::QSYMM16:
- armcomputetensorutils::CopyArmComputeITensorData(static_cast<const int16_t*>(memory),
- this->GetTensor());
- break;
- case arm_compute::DataType::S32:
- armcomputetensorutils::CopyArmComputeITensorData(static_cast<const int32_t*>(memory),
- this->GetTensor());
- break;
- default:
- {
- throw armnn::UnimplementedException();
- }
- }
- this->Unmap();
- }
-
- arm_compute::CLTensor m_Tensor;
- std::shared_ptr<arm_compute::MemoryGroup> m_MemoryGroup;
-};
-
-class ClSubTensorHandle : public IClTensorHandle
-{
-public:
- ClSubTensorHandle(IClTensorHandle* parent,
- const arm_compute::TensorShape& shape,
- const arm_compute::Coordinates& coords)
- : m_Tensor(&parent->GetTensor(), shape, coords)
- {
- parentHandle = parent;
- }
-
- arm_compute::CLSubTensor& GetTensor() override { return m_Tensor; }
- arm_compute::CLSubTensor const& GetTensor() const override { return m_Tensor; }
-
- virtual void Allocate() override {}
- virtual void Manage() override {}
-
- virtual const void* Map(bool blocking = true) const override
- {
- const_cast<arm_compute::CLSubTensor*>(&m_Tensor)->map(blocking);
- return static_cast<const void*>(m_Tensor.buffer() + m_Tensor.info()->offset_first_element_in_bytes());
- }
- virtual void Unmap() const override { const_cast<arm_compute::CLSubTensor*>(&m_Tensor)->unmap(); }
-
- virtual ITensorHandle* GetParent() const override { return parentHandle; }
-
- virtual arm_compute::DataType GetDataType() const override
- {
- return m_Tensor.info()->data_type();
- }
-
- virtual void SetMemoryGroup(const std::shared_ptr<arm_compute::IMemoryGroup>&) override {}
-
- TensorShape GetStrides() const override
- {
- return armcomputetensorutils::GetStrides(m_Tensor.info()->strides_in_bytes());
- }
-
- TensorShape GetShape() const override
- {
- return armcomputetensorutils::GetShape(m_Tensor.info()->tensor_shape());
- }
-
-private:
- // Only used for testing
- void CopyOutTo(void* memory) const override
- {
- const_cast<ClSubTensorHandle*>(this)->Map(true);
- switch(this->GetDataType())
- {
- case arm_compute::DataType::F32:
- armcomputetensorutils::CopyArmComputeITensorData(this->GetTensor(),
- static_cast<float*>(memory));
- break;
- case arm_compute::DataType::U8:
- case arm_compute::DataType::QASYMM8:
- armcomputetensorutils::CopyArmComputeITensorData(this->GetTensor(),
- static_cast<uint8_t*>(memory));
- break;
- case arm_compute::DataType::F16:
- armcomputetensorutils::CopyArmComputeITensorData(this->GetTensor(),
- static_cast<armnn::Half*>(memory));
- break;
- case arm_compute::DataType::QSYMM8_PER_CHANNEL:
- case arm_compute::DataType::QASYMM8_SIGNED:
- armcomputetensorutils::CopyArmComputeITensorData(this->GetTensor(),
- static_cast<int8_t*>(memory));
- break;
- case arm_compute::DataType::S16:
- case arm_compute::DataType::QSYMM16:
- armcomputetensorutils::CopyArmComputeITensorData(this->GetTensor(),
- static_cast<int16_t*>(memory));
- break;
- case arm_compute::DataType::S32:
- armcomputetensorutils::CopyArmComputeITensorData(this->GetTensor(),
- static_cast<int32_t*>(memory));
- break;
- default:
- {
- throw armnn::UnimplementedException();
- }
- }
- const_cast<ClSubTensorHandle*>(this)->Unmap();
- }
-
- // Only used for testing
- void CopyInFrom(const void* memory) override
- {
- this->Map(true);
- switch(this->GetDataType())
- {
- case arm_compute::DataType::F32:
- armcomputetensorutils::CopyArmComputeITensorData(static_cast<const float*>(memory),
- this->GetTensor());
- break;
- case arm_compute::DataType::U8:
- case arm_compute::DataType::QASYMM8:
- armcomputetensorutils::CopyArmComputeITensorData(static_cast<const uint8_t*>(memory),
- this->GetTensor());
- break;
- case arm_compute::DataType::F16:
- armcomputetensorutils::CopyArmComputeITensorData(static_cast<const armnn::Half*>(memory),
- this->GetTensor());
- break;
- case arm_compute::DataType::QSYMM8_PER_CHANNEL:
- case arm_compute::DataType::QASYMM8_SIGNED:
- armcomputetensorutils::CopyArmComputeITensorData(static_cast<const int8_t*>(memory),
- this->GetTensor());
- break;
- case arm_compute::DataType::S16:
- case arm_compute::DataType::QSYMM16:
- armcomputetensorutils::CopyArmComputeITensorData(static_cast<const int16_t*>(memory),
- this->GetTensor());
- break;
- case arm_compute::DataType::S32:
- armcomputetensorutils::CopyArmComputeITensorData(static_cast<const int32_t*>(memory),
- this->GetTensor());
- break;
- default:
- {
- throw armnn::UnimplementedException();
- }
- }
- this->Unmap();
- }
-
- mutable arm_compute::CLSubTensor m_Tensor;
- ITensorHandle* parentHandle = nullptr;
-};
-
-} // namespace armnn