ArmNN
 21.08
ActivationSerializationTests.cpp
Go to the documentation of this file.
1 //
2 // Copyright © 2017 Arm Ltd. All rights reserved.
3 // SPDX-License-Identifier: MIT
4 //
5 
6 #include "../Serializer.hpp"
7 
8 #include <armnn/Descriptors.hpp>
9 #include <armnn/INetwork.hpp>
10 #include <armnn/IRuntime.hpp>
13 
14 #include <doctest/doctest.h>
15 
16 #include <sstream>
17 
18 TEST_SUITE("SerializerTests")
19 {
20 class VerifyActivationName : public armnn::IStrategy
21 {
22 public:
23  void ExecuteStrategy(const armnn::IConnectableLayer* layer,
24  const armnn::BaseDescriptor& descriptor,
25  const std::vector<armnn::ConstTensor>& constants,
26  const char* name,
27  const armnn::LayerBindingId id = 0) override
28  {
29  IgnoreUnused(layer, descriptor, constants, id);
30  if (layer->GetType() == armnn::LayerType::Activation)
31  {
32  CHECK(std::string(name) == "activation");
33  }
34  }
35 };
36 
37 TEST_CASE("ActivationSerialization")
38 {
40 
41  armnn::TensorInfo inputInfo(armnn::TensorShape({1, 2, 2, 1}), armnn::DataType::Float32, 1.0f, 0);
42  armnn::TensorInfo outputInfo(armnn::TensorShape({1, 2, 2, 1}), armnn::DataType::Float32, 4.0f, 0);
43 
44  // Construct network
46 
47  armnn::ActivationDescriptor descriptor;
49  descriptor.m_A = 0;
50  descriptor.m_B = 0;
51 
52  armnn::IConnectableLayer* const inputLayer = network->AddInputLayer(0, "input");
53  armnn::IConnectableLayer* const activationLayer = network->AddActivationLayer(descriptor, "activation");
54  armnn::IConnectableLayer* const outputLayer = network->AddOutputLayer(0, "output");
55 
56  inputLayer->GetOutputSlot(0).Connect(activationLayer->GetInputSlot(0));
57  inputLayer->GetOutputSlot(0).SetTensorInfo(inputInfo);
58 
59  activationLayer->GetOutputSlot(0).Connect(outputLayer->GetInputSlot(0));
60  activationLayer->GetOutputSlot(0).SetTensorInfo(outputInfo);
61 
63 
64  serializer->Serialize(*network);
65 
66  std::stringstream stream;
67  serializer->SaveSerializedToStream(stream);
68 
69  std::string const serializerString{stream.str()};
70  std::vector<std::uint8_t> const serializerVector{serializerString.begin(), serializerString.end()};
71 
72  armnn::INetworkPtr deserializedNetwork = parser->CreateNetworkFromBinary(serializerVector);
73 
74  VerifyActivationName visitor;
75  deserializedNetwork->ExecuteStrategy(visitor);
76 
77  armnn::IRuntime::CreationOptions options; // default options
79  auto deserializedOptimized = Optimize(*deserializedNetwork, { armnn::Compute::CpuRef }, run->GetDeviceSpec());
80 
81  armnn::NetworkId networkIdentifier;
82 
83  // Load graph into runtime
84  run->LoadNetwork(networkIdentifier, std::move(deserializedOptimized));
85 
86  std::vector<float> inputData {0.0f, -5.3f, 42.0f, -42.0f};
87  armnn::InputTensors inputTensors
88  {
89  {0, armnn::ConstTensor(run->GetInputTensorInfo(networkIdentifier, 0), inputData.data())}
90  };
91 
92  std::vector<float> expectedOutputData {0.0f, 0.0f, 42.0f, 0.0f};
93 
94  std::vector<float> outputData(4);
95  armnn::OutputTensors outputTensors
96  {
97  {0, armnn::Tensor(run->GetOutputTensorInfo(networkIdentifier, 0), outputData.data())}
98  };
99  run->EnqueueWorkload(networkIdentifier, inputTensors, outputTensors);
100  CHECK(std::equal(outputData.begin(), outputData.end(), expectedOutputData.begin(), expectedOutputData.end()));
101 }
102 
103 }
static IRuntimePtr Create(const CreationOptions &options)
Definition: Runtime.cpp:39
Interface for a layer that is connectable to other layers via InputSlots and OutputSlots.
Definition: INetwork.hpp:61
CPU Execution: Reference C++ kernels.
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)=0
std::unique_ptr< IRuntime, void(*)(IRuntime *runtime)> IRuntimePtr
Definition: IRuntime.hpp:30
static IDeserializerPtr Create()
std::vector< std::pair< LayerBindingId, class ConstTensor > > InputTensors
Definition: Tensor.hpp:360
void IgnoreUnused(Ts &&...)
int LayerBindingId
Type of identifiers for bindable layers (inputs, outputs).
Definition: Types.hpp:244
virtual void SetTensorInfo(const TensorInfo &tensorInfo)=0
Base class for all descriptors.
Definition: Descriptors.hpp:22
A tensor defined by a TensorInfo (shape and data type) and a mutable backing store.
Definition: Tensor.hpp:319
IOptimizedNetworkPtr Optimize(const INetwork &network, const std::vector< BackendId > &backendPreferences, const IDeviceSpec &deviceSpec, const OptimizerOptions &options=OptimizerOptions(), Optional< std::vector< std::string > &> messages=EmptyOptional())
Create an optimized version of the network.
Definition: Network.cpp:1613
int NetworkId
Definition: IRuntime.hpp:24
A tensor defined by a TensorInfo (shape and data type) and an immutable backing store.
Definition: Tensor.hpp:327
std::vector< std::pair< LayerBindingId, class Tensor > > OutputTensors
Definition: Tensor.hpp:361
std::unique_ptr< IDeserializer, void(*)(IDeserializer *parser)> IDeserializerPtr
An ActivationDescriptor for the ActivationLayer.
Definition: Descriptors.hpp:25
virtual LayerType GetType() const =0
Returns the armnn::LayerType of this layer.
float m_A
Alpha upper bound value used by the activation functions. (BoundedReLu, Linear, TanH, Elu).
Definition: Descriptors.hpp:50
std::unique_ptr< ISerializer, void(*)(ISerializer *serializer)> ISerializerPtr
Definition: ISerializer.hpp:15
TEST_SUITE("SerializerTests")
virtual const IInputSlot & GetInputSlot(unsigned int index) const =0
Get a const input slot handle by slot index.
static ISerializerPtr Create()
Definition: Serializer.cpp:35
virtual const IOutputSlot & GetOutputSlot(unsigned int index) const =0
Get the const output slot handle by slot index.
std::unique_ptr< INetwork, void(*)(INetwork *network)> INetworkPtr
Definition: INetwork.hpp:172
virtual int Connect(IInputSlot &destination)=0
static INetworkPtr Create(NetworkOptions networkOptions={})
Definition: Network.cpp:530
float m_B
Beta lower bound value used by the activation functions. (BoundedReLu, Linear, TanH).
Definition: Descriptors.hpp:52
ActivationFunction m_Function
The activation function to use (Sigmoid, TanH, Linear, ReLu, BoundedReLu, SoftReLu, LeakyReLu, Abs, Sqrt, Square, Elu).
Definition: Descriptors.hpp:48