blob: 29db52200bb1f23e35d75fec2f9baf5e6142682c [file] [log] [blame]
Colm Donelanc74b1752021-03-12 15:58:48 +00001//
2// Copyright © 2021 Arm Ltd. All rights reserved.
3// SPDX-License-Identifier: MIT
4//
5
6#include "ClImportTensorHandleFactory.hpp"
David Monahane4a41dc2021-04-14 16:55:36 +01007#include "ClImportTensorHandle.hpp"
Colm Donelanc74b1752021-03-12 15:58:48 +00008
9#include <armnn/utility/NumericCast.hpp>
10#include <armnn/utility/PolymorphicDowncast.hpp>
11
12#include <arm_compute/core/Coordinates.h>
13#include <arm_compute/runtime/CL/CLTensor.h>
14
15namespace armnn
16{
17
18using FactoryId = ITensorHandleFactory::FactoryId;
19
20std::unique_ptr<ITensorHandle> ClImportTensorHandleFactory::CreateSubTensorHandle(
21 ITensorHandle& parent, const TensorShape& subTensorShape, const unsigned int* subTensorOrigin) const
22{
23 arm_compute::Coordinates coords;
24 arm_compute::TensorShape shape = armcomputetensorutils::BuildArmComputeTensorShape(subTensorShape);
25
26 coords.set_num_dimensions(subTensorShape.GetNumDimensions());
27 for (unsigned int i = 0; i < subTensorShape.GetNumDimensions(); ++i)
28 {
29 // Arm compute indexes tensor coords in reverse order.
30 unsigned int revertedIndex = subTensorShape.GetNumDimensions() - i - 1;
31 coords.set(i, armnn::numeric_cast<int>(subTensorOrigin[revertedIndex]));
32 }
33
34 const arm_compute::TensorShape parentShape = armcomputetensorutils::BuildArmComputeTensorShape(parent.GetShape());
35
36 // In order for ACL to support subtensors the concat axis cannot be on x or y and the values of x and y
37 // must match the parent shapes
38 if (coords.x() != 0 || coords.y() != 0)
39 {
40 return nullptr;
41 }
42 if ((parentShape.x() != shape.x()) || (parentShape.y() != shape.y()))
43 {
44 return nullptr;
45 }
46
47 if (!::arm_compute::error_on_invalid_subtensor(__func__, __FILE__, __LINE__, parentShape, coords, shape))
48 {
49 return nullptr;
50 }
51
David Monahane4a41dc2021-04-14 16:55:36 +010052 return std::make_unique<ClImportSubTensorHandle>(
Narumol Prangnawarat9ef36142022-01-25 15:15:34 +000053 PolymorphicDowncast<IClTensorHandle*>(&parent), shape, coords);
Colm Donelanc74b1752021-03-12 15:58:48 +000054}
55
56std::unique_ptr<ITensorHandle> ClImportTensorHandleFactory::CreateTensorHandle(const TensorInfo& tensorInfo) const
57{
David Monahane4a41dc2021-04-14 16:55:36 +010058 std::unique_ptr<ClImportTensorHandle> tensorHandle = std::make_unique<ClImportTensorHandle>(tensorInfo,
59 GetImportFlags());
60 return tensorHandle;
Colm Donelanc74b1752021-03-12 15:58:48 +000061}
62
63std::unique_ptr<ITensorHandle> ClImportTensorHandleFactory::CreateTensorHandle(const TensorInfo& tensorInfo,
64 DataLayout dataLayout) const
65{
David Monahane4a41dc2021-04-14 16:55:36 +010066 std::unique_ptr<ClImportTensorHandle> tensorHandle = std::make_unique<ClImportTensorHandle>(tensorInfo,
67 dataLayout,
68 GetImportFlags());
69 return tensorHandle;
Colm Donelanc74b1752021-03-12 15:58:48 +000070}
71
72std::unique_ptr<ITensorHandle> ClImportTensorHandleFactory::CreateTensorHandle(const TensorInfo& tensorInfo,
73 const bool IsMemoryManaged) const
74{
Colm Donelanc74b1752021-03-12 15:58:48 +000075 if (IsMemoryManaged)
76 {
77 throw InvalidArgumentException("ClImportTensorHandleFactory does not support memory managed tensors.");
78 }
David Monahane4a41dc2021-04-14 16:55:36 +010079 return CreateTensorHandle(tensorInfo);
Colm Donelanc74b1752021-03-12 15:58:48 +000080}
81
82std::unique_ptr<ITensorHandle> ClImportTensorHandleFactory::CreateTensorHandle(const TensorInfo& tensorInfo,
83 DataLayout dataLayout,
84 const bool IsMemoryManaged) const
85{
Colm Donelanc74b1752021-03-12 15:58:48 +000086 if (IsMemoryManaged)
87 {
88 throw InvalidArgumentException("ClImportTensorHandleFactory does not support memory managed tensors.");
89 }
David Monahane4a41dc2021-04-14 16:55:36 +010090 return CreateTensorHandle(tensorInfo, dataLayout);
Colm Donelanc74b1752021-03-12 15:58:48 +000091}
92
93const FactoryId& ClImportTensorHandleFactory::GetIdStatic()
94{
95 static const FactoryId s_Id(ClImportTensorHandleFactoryId());
96 return s_Id;
97}
98
99const FactoryId& ClImportTensorHandleFactory::GetId() const
100{
101 return GetIdStatic();
102}
103
104bool ClImportTensorHandleFactory::SupportsSubTensors() const
105{
106 return true;
107}
108
Narumol Prangnawarate5f0b242021-05-07 17:52:36 +0100109bool ClImportTensorHandleFactory::SupportsMapUnmap() const
110{
111 return false;
112}
113
Colm Donelanc74b1752021-03-12 15:58:48 +0000114MemorySourceFlags ClImportTensorHandleFactory::GetExportFlags() const
115{
116 return m_ExportFlags;
117}
118
119MemorySourceFlags ClImportTensorHandleFactory::GetImportFlags() const
120{
121 return m_ImportFlags;
122}
123
Narumol Prangnawarate5f0b242021-05-07 17:52:36 +0100124std::vector<Capability> ClImportTensorHandleFactory::GetCapabilities(const IConnectableLayer* layer,
125 const IConnectableLayer* connectedLayer,
126 CapabilityClass capabilityClass)
127{
128 IgnoreUnused(layer);
129 IgnoreUnused(connectedLayer);
130 std::vector<Capability> capabilities;
131 if (capabilityClass == CapabilityClass::FallbackImportDisabled)
132 {
133 Capability paddingCapability(CapabilityClass::FallbackImportDisabled, true);
134 capabilities.push_back(paddingCapability);
135 }
136 return capabilities;
137}
138
Colm Donelanc74b1752021-03-12 15:58:48 +0000139} // namespace armnn