From b454c5c65efb238c130b042ace390b2bc7f0bf75 Mon Sep 17 00:00:00 2001 From: Finn Williams Date: Tue, 9 Feb 2021 15:56:23 +0000 Subject: IVGCVSW-4893 Refactor ILayerVisitor using unified interface strategy. Signed-off-by: Jan Eilers Signed-off-by: Finn Williams Signed-off-by: Francis Murtagh Change-Id: Id7bc8255a8e3f9e5aac65d510bec8a559bf37246 --- src/armnn/DynamicQuantizationStrategy.hpp | 59 +++++++++++++++++++++++++++++++ 1 file changed, 59 insertions(+) create mode 100644 src/armnn/DynamicQuantizationStrategy.hpp (limited to 'src/armnn/DynamicQuantizationStrategy.hpp') 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 +#include + +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& constants, + const char* name, + const armnn::LayerBindingId id = 0) override; + + const std::vector& 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 m_LayersToCalibrate; + std::vector m_LayersNotToCalibrate; + std::vector m_DebugLayers; + + std::vector m_OutputLayers; + void AddToCalibratedLayers(const IConnectableLayer* layer); + void AddToNonCalibratedLayers(const IConnectableLayer* layer); + void RemoveDebugLayers(); + + +}; +} //namespace armnn -- cgit v1.2.1