From e9f0f0fdda42ba17085ba4d86e0c84ab68ed2f5a Mon Sep 17 00:00:00 2001 From: Jan Eilers Date: Fri, 16 Aug 2019 10:28:37 +0100 Subject: IVGCVSW-3617 Add CL TensorHandleFactory * Adds ClTensorHandleFactory * Includes some refactoring of NeonTensorHandleFactory Signed-off-by: Jan Eilers Change-Id: I9f0874b1945050267c5ece970e6d9b200ed8a865 --- src/backends/neon/NeonBackend.cpp | 4 ++-- src/backends/neon/NeonTensorHandleFactory.cpp | 16 +++++++++++----- src/backends/neon/NeonTensorHandleFactory.hpp | 18 +++++++++++------- 3 files changed, 24 insertions(+), 14 deletions(-) (limited to 'src/backends/neon') diff --git a/src/backends/neon/NeonBackend.cpp b/src/backends/neon/NeonBackend.cpp index f86509cbe6..5df231b5e3 100644 --- a/src/backends/neon/NeonBackend.cpp +++ b/src/backends/neon/NeonBackend.cpp @@ -97,7 +97,7 @@ OptimizationViews NeonBackend::OptimizeSubgraphView(const SubgraphView& subgraph std::vector NeonBackend::GetHandleFactoryPreferences() const { - return std::vector() = {"Arm/Neon/TensorHandleFactory"}; + return std::vector() = {NeonTensorHandleFactory::GetIdStatic()}; } void NeonBackend::RegisterTensorHandleFactories(class TensorHandleFactoryRegistry& registry) @@ -106,7 +106,7 @@ void NeonBackend::RegisterTensorHandleFactories(class TensorHandleFactoryRegistr BaseMemoryManager::MemoryAffinity::Offset); registry.RegisterMemoryManager(memoryManager); - registry.RegisterFactory(std::make_unique(memoryManager, "Arm/Neon/TensorHandleFactory")); + registry.RegisterFactory(std::make_unique(memoryManager)); } } // namespace armnn diff --git a/src/backends/neon/NeonTensorHandleFactory.cpp b/src/backends/neon/NeonTensorHandleFactory.cpp index ef342347d3..aff594c9d9 100644 --- a/src/backends/neon/NeonTensorHandleFactory.cpp +++ b/src/backends/neon/NeonTensorHandleFactory.cpp @@ -11,18 +11,18 @@ namespace armnn { -using FactoryId = std::string; +using FactoryId = ITensorHandleFactory::FactoryId; std::unique_ptr NeonTensorHandleFactory::CreateSubTensorHandle(ITensorHandle& parent, - TensorShape const& subTensorShape, - unsigned int const* subTensorOrigin) + const TensorShape& subTensorShape, + const unsigned int* subTensorOrigin) const { const arm_compute::TensorShape shape = armcomputetensorutils::BuildArmComputeTensorShape(subTensorShape); arm_compute::Coordinates coords; coords.set_num_dimensions(subTensorShape.GetNumDimensions()); - for (unsigned int i = 0; i < subTensorShape.GetNumDimensions(); i++) + for (unsigned int i = 0; i < subTensorShape.GetNumDimensions(); ++i) { // Arm compute indexes tensor coords in reverse order. unsigned int revertedIndex = subTensorShape.GetNumDimensions() - i - 1; @@ -56,9 +56,15 @@ std::unique_ptr NeonTensorHandleFactory::CreateTensorHandle(const return tensorHandle; } +const FactoryId& NeonTensorHandleFactory::GetIdStatic() +{ + static const FactoryId s_Id(NeonTensorHandleFactoryId()); + return s_Id; +} + const FactoryId NeonTensorHandleFactory::GetId() const { - return m_Id; + return GetIdStatic(); } bool NeonTensorHandleFactory::SupportsSubTensors() const diff --git a/src/backends/neon/NeonTensorHandleFactory.hpp b/src/backends/neon/NeonTensorHandleFactory.hpp index a2e46e22e9..c401e0ee81 100644 --- a/src/backends/neon/NeonTensorHandleFactory.hpp +++ b/src/backends/neon/NeonTensorHandleFactory.hpp @@ -11,23 +11,28 @@ namespace armnn { +constexpr const char* NeonTensorHandleFactoryId() { return "Arm/Neon/TensorHandleFactory"; } + class NeonTensorHandleFactory : public ITensorHandleFactory { public: - NeonTensorHandleFactory(std::weak_ptr mgr, ITensorHandleFactory::FactoryId id) - : m_Id(id) - , m_MemoryManager(mgr) + NeonTensorHandleFactory(std::weak_ptr mgr) + : m_MemoryManager(mgr), + m_ImportFlags(static_cast(MemorySource::Undefined)), + m_ExportFlags(static_cast(MemorySource::Undefined)) {} std::unique_ptr CreateSubTensorHandle(ITensorHandle& parent, - TensorShape const& subTensorShape, - unsigned int const* subTensorOrigin) const override; + const TensorShape& subTensorShape, + const unsigned int* subTensorOrigin) const override; std::unique_ptr CreateTensorHandle(const TensorInfo& tensorInfo) const override; std::unique_ptr CreateTensorHandle(const TensorInfo& tensorInfo, DataLayout dataLayout) const override; + static const FactoryId& GetIdStatic(); + const FactoryId GetId() const override; bool SupportsSubTensors() const override; @@ -37,10 +42,9 @@ public: MemorySourceFlags GetImportFlags() const override; private: - FactoryId m_Id = "Arm/Neon/TensorHandleFactory"; + mutable std::shared_ptr m_MemoryManager; MemorySourceFlags m_ImportFlags; MemorySourceFlags m_ExportFlags; - mutable std::shared_ptr m_MemoryManager; }; } // namespace armnn -- cgit v1.2.1