diff options
author | Mike Kelly <mike.kelly@arm.com> | 2023-07-07 15:43:06 +0100 |
---|---|---|
committer | Mike Kelly <mike.kelly@arm.com> | 2023-07-14 00:00:53 +0100 |
commit | 4cc341cf8b5a6e6bb0543504cbbfde6fa11a2cdb (patch) | |
tree | 7cac128e9ec6f2fd27f1afdb55f44b870f39e0b3 /src/backends/neon/NeonTensorHandle.cpp | |
parent | 6963b33221c23af4a8eff19ff4a5773230b0befd (diff) | |
download | armnn-4cc341cf8b5a6e6bb0543504cbbfde6fa11a2cdb.tar.gz |
IVGCVSW-7830 Add backend optimizations to remove Reshapes where possible
* Added optimization to remove reshapes for Neon and Ref Backends
by using overridden TensorInfos
* Added ability to delete Subgraphs during Optimization
* Fixed naming error in NeonEndToEndTests and CLEndToEndTests
* Added LayerNameAndTypeCheck for testing.
* Fixed error where layers were not marked as altered when removed in
CLBackend
Signed-off-by: Mike Kelly <mike.kelly@arm.com>
Change-Id: I1ac25cd4ec9821470d961831ae2c8d24882276cc
Diffstat (limited to 'src/backends/neon/NeonTensorHandle.cpp')
-rw-r--r-- | src/backends/neon/NeonTensorHandle.cpp | 47 |
1 files changed, 47 insertions, 0 deletions
diff --git a/src/backends/neon/NeonTensorHandle.cpp b/src/backends/neon/NeonTensorHandle.cpp new file mode 100644 index 0000000000..819805aa59 --- /dev/null +++ b/src/backends/neon/NeonTensorHandle.cpp @@ -0,0 +1,47 @@ +// +// Copyright © 2023 Arm Ltd and Contributors. All rights reserved. +// SPDX-License-Identifier: MIT +// + +#include "NeonTensorHandle.hpp" + +#include <aclCommon/ArmComputeTensorUtils.hpp> + +namespace armnn +{ +std::shared_ptr<ITensorHandle> NeonTensorHandle::DecorateTensorHandle(const TensorInfo &tensorInfo) +{ + auto* parent = const_cast<NeonTensorHandle*>(this); + auto decorated = std::make_shared<NeonTensorHandleDecorator>(parent, tensorInfo); + m_Decorated.emplace_back(decorated); + return decorated; +} + +NeonTensorDecorator::NeonTensorDecorator() + : m_Original(nullptr), m_TensorInfo() +{ +} + +NeonTensorDecorator::NeonTensorDecorator(arm_compute::ITensor *parent, const TensorInfo& tensorInfo) + : m_Original(nullptr), m_TensorInfo() +{ + m_TensorInfo = armcomputetensorutils::BuildArmComputeTensorInfo(tensorInfo); + m_Original = parent; +} + +arm_compute::ITensorInfo *NeonTensorDecorator::info() const +{ + return &m_TensorInfo; +} + +arm_compute::ITensorInfo *NeonTensorDecorator::info() +{ + return &m_TensorInfo; +} + +uint8_t *NeonTensorDecorator::buffer() const +{ + return m_Original->buffer(); +} + +}
\ No newline at end of file |