Derek Lamberti | a9cca6a | 2019-03-25 15:41:58 +0000 | [diff] [blame] | 1 | // |
Finn Williams | 87d0bda | 2020-07-03 10:12:03 +0100 | [diff] [blame] | 2 | // Copyright © 2017 Arm Ltd and Contributors. All rights reserved. |
Derek Lamberti | a9cca6a | 2019-03-25 15:41:58 +0000 | [diff] [blame] | 3 | // SPDX-License-Identifier: MIT |
| 4 | // |
| 5 | |
| 6 | #include "QuantizeLayer.hpp" |
| 7 | |
| 8 | #include "LayerCloneBase.hpp" |
| 9 | |
| 10 | #include <armnn/ILayerVisitor.hpp> |
| 11 | |
| 12 | namespace armnn |
| 13 | { |
| 14 | |
| 15 | QuantizeLayer::QuantizeLayer(const char* name) |
| 16 | : Layer(1, 1, LayerType::Quantize, name) |
| 17 | {} |
| 18 | |
Derek Lamberti | 94a88d2 | 2019-12-10 21:12:59 +0000 | [diff] [blame] | 19 | std::unique_ptr<IWorkload> QuantizeLayer::CreateWorkload(const IWorkloadFactory& factory) const |
Derek Lamberti | a9cca6a | 2019-03-25 15:41:58 +0000 | [diff] [blame] | 20 | { |
Derek Lamberti | 5f400d6 | 2019-03-25 15:41:58 +0000 | [diff] [blame] | 21 | QuantizeQueueDescriptor descriptor; |
Keith Davis | df04d23 | 2020-10-23 17:20:05 +0100 | [diff] [blame] | 22 | SetAdditionalInfo(descriptor); |
| 23 | |
Derek Lamberti | 94a88d2 | 2019-12-10 21:12:59 +0000 | [diff] [blame] | 24 | WorkloadInfo info = PrepInfoAndDesc(descriptor); |
Keith Davis | df04d23 | 2020-10-23 17:20:05 +0100 | [diff] [blame] | 25 | |
Derek Lamberti | 5f400d6 | 2019-03-25 15:41:58 +0000 | [diff] [blame] | 26 | return factory.CreateQuantize(descriptor, info); |
Derek Lamberti | a9cca6a | 2019-03-25 15:41:58 +0000 | [diff] [blame] | 27 | } |
| 28 | |
| 29 | Layer* QuantizeLayer::Clone(Graph& graph) const |
| 30 | { |
| 31 | QuantizeLayer* clone = CloneBase<QuantizeLayer>(graph, GetName()); |
| 32 | return clone; |
| 33 | } |
| 34 | |
Finn Williams | f24effa | 2020-07-03 10:12:03 +0100 | [diff] [blame] | 35 | void QuantizeLayer::ValidateTensorShapesFromInputs() |
Derek Lamberti | a9cca6a | 2019-03-25 15:41:58 +0000 | [diff] [blame] | 36 | { |
Derek Lamberti | a9cca6a | 2019-03-25 15:41:58 +0000 | [diff] [blame] | 37 | VerifyLayerConnections(1, CHECK_LOCATION()); |
| 38 | |
Finn Williams | 87d0bda | 2020-07-03 10:12:03 +0100 | [diff] [blame] | 39 | const TensorShape& outputShape = GetOutputSlot(0).GetTensorInfo().GetShape(); |
| 40 | |
Finn Williams | f24effa | 2020-07-03 10:12:03 +0100 | [diff] [blame] | 41 | VerifyShapeInferenceType(outputShape, m_ShapeInferenceMethod); |
Finn Williams | 87d0bda | 2020-07-03 10:12:03 +0100 | [diff] [blame] | 42 | |
Derek Lamberti | a9cca6a | 2019-03-25 15:41:58 +0000 | [diff] [blame] | 43 | auto inferredShapes = InferOutputShapes({ GetInputSlot(0).GetConnection()->GetTensorInfo().GetShape() }); |
| 44 | |
Finn Williams | f24effa | 2020-07-03 10:12:03 +0100 | [diff] [blame] | 45 | ValidateAndCopyShape(outputShape, inferredShapes[0], m_ShapeInferenceMethod, "QuantizeLayer"); |
Derek Lamberti | a9cca6a | 2019-03-25 15:41:58 +0000 | [diff] [blame] | 46 | } |
| 47 | |
Jan Eilers | 1b2654f | 2021-09-24 15:45:46 +0100 | [diff] [blame^] | 48 | ARMNN_NO_DEPRECATE_WARN_BEGIN |
Derek Lamberti | a9cca6a | 2019-03-25 15:41:58 +0000 | [diff] [blame] | 49 | void QuantizeLayer::Accept(ILayerVisitor& visitor) const |
| 50 | { |
| 51 | visitor.VisitQuantizeLayer(this, GetName()); |
| 52 | } |
Jan Eilers | 1b2654f | 2021-09-24 15:45:46 +0100 | [diff] [blame^] | 53 | ARMNN_NO_DEPRECATE_WARN_END |
Derek Lamberti | a9cca6a | 2019-03-25 15:41:58 +0000 | [diff] [blame] | 54 | |
| 55 | } //namespace armnn |