diff options
author | Finn Williams <Finn.Williams@arm.com> | 2021-02-09 15:56:23 +0000 |
---|---|---|
committer | Finn Williams <Finn.Williams@arm.com> | 2021-02-12 13:10:20 +0000 |
commit | b454c5c65efb238c130b042ace390b2bc7f0bf75 (patch) | |
tree | d6681d0abf416b3cc280bc3bb70e7d55dfd40a0d /src/armnn/DynamicQuantizationStrategy.hpp | |
parent | 8eae955f665f371b0a2c7c1a06e8ba442afa2298 (diff) | |
download | armnn-b454c5c65efb238c130b042ace390b2bc7f0bf75.tar.gz |
IVGCVSW-4893 Refactor ILayerVisitor using unified interface strategy.
Signed-off-by: Jan Eilers <jan.eilers@arm.com>
Signed-off-by: Finn Williams <Finn.Williams@arm.com>
Signed-off-by: Francis Murtagh <francis.murtagh@arm.com>
Change-Id: Id7bc8255a8e3f9e5aac65d510bec8a559bf37246
Diffstat (limited to 'src/armnn/DynamicQuantizationStrategy.hpp')
-rw-r--r-- | src/armnn/DynamicQuantizationStrategy.hpp | 59 |
1 files changed, 59 insertions, 0 deletions
diff --git a/src/armnn/DynamicQuantizationStrategy.hpp b/src/armnn/DynamicQuantizationStrategy.hpp new file mode 100644 index 0000000000..aa77a4b563 --- /dev/null +++ b/src/armnn/DynamicQuantizationStrategy.hpp @@ -0,0 +1,59 @@ +// +// Copyright © 2021 Arm Ltd and Contributors. All rights reserved. +// SPDX-License-Identifier: MIT +// + +#pragma once + +#include "armnn/LayerVisitorBase.hpp" +#include "RangeTracker.hpp" +#include "layers/DebugLayer.hpp" + +#include <armnn/INetwork.hpp> +#include <armnnQuantizer/INetworkQuantizer.hpp> + +namespace armnn +{ + +/// Visitor class implementation to gather the TensorInfo for LayerBindingID for creation of ConstTensor for Refine. +class DynamicQuantizationStrategy : public armnn::IStrategy +{ +public: + + DynamicQuantizationStrategy(RangeTracker& rangeTracker, Graph& graph); + ~DynamicQuantizationStrategy() = default; + + virtual void ExecuteStrategy(const armnn::IConnectableLayer* layer, + const armnn::BaseDescriptor& descriptor, + const std::vector<armnn::ConstTensor>& constants, + const char* name, + const armnn::LayerBindingId id = 0) override; + + const std::vector<armnn::LayerBindingId>& GetOutputLayers(); + void VisitNonCalibratedLayers(); + void FinishStrategy() override; + + +private: + /// Set the range for an output slot on a layer + void SetRange(const IConnectableLayer* layer, unsigned int outputIdx, float min, float max); + + void ForwardParentParameters(const IConnectableLayer* layer); + + /// Mapping from a layer Guid to an array of ranges for outputs + RangeTracker& m_RangeTracker; + + Graph& m_Graph; + + std::vector<const IConnectableLayer*> m_LayersToCalibrate; + std::vector<const IConnectableLayer*> m_LayersNotToCalibrate; + std::vector<DebugLayer*> m_DebugLayers; + + std::vector<armnn::LayerBindingId> m_OutputLayers; + void AddToCalibratedLayers(const IConnectableLayer* layer); + void AddToNonCalibratedLayers(const IConnectableLayer* layer); + void RemoveDebugLayers(); + + +}; +} //namespace armnn |