blob: 3cb3459fd2469923d80e35e5cd427104a39c2fa5 [file] [log] [blame]
//
// Copyright © 2020 Arm Ltd and Contributors. All rights reserved.
// SPDX-License-Identifier: MIT
//
#include "ParserFlatbuffersSerializeFixture.hpp"
#include <armnnDeserializer/IDeserializer.hpp>
#include <string>
TEST_SUITE("Deserializer_Rank")
{
struct RankFixture : public ParserFlatbuffersSerializeFixture
{
explicit RankFixture(const std::string &inputShape,
const std::string &dataType)
{
m_JsonString = R"(
{
inputIds: [0],
outputIds: [2],
layers: [
{
layer_type: "InputLayer",
layer: {
base: {
base: {
layerName: "",
layerType: "Input",
inputSlots: [
],
outputSlots: [
{
tensorInfo: {
dimensions: )" + inputShape + R"(,
dataType: )" + dataType + R"(,
quantizationScale: 0.0
}
}
]
}
}
}
},
{
layer_type: "RankLayer",
layer: {
base: {
index: 1,
layerName: "rank",
layerType: "Rank",
inputSlots: [
{
connection: {
sourceLayerIndex: 0,
outputSlotIndex: 0
}
}
],
outputSlots: [
{
tensorInfo: {
dimensions: [ 1 ],
dataType: "Signed32",
quantizationScale: 0.0,
dimensionality: 2
}
}
]
}
}
},
{
layer_type: "OutputLayer",
layer: {
base: {
base: {
index: 2,
layerName: "",
layerType: "Output",
inputSlots: [
{
connection: {
sourceLayerIndex: 1,
outputSlotIndex: 0
}
}
],
outputSlots: []
}
}
}
}
],
}
)";
Setup();
}
};
struct SimpleRankDimSize1Fixture : RankFixture
{
SimpleRankDimSize1Fixture() : RankFixture("[ 8 ]", "QSymmS16") {}
};
struct SimpleRankDimSize2Fixture : RankFixture
{
SimpleRankDimSize2Fixture() : RankFixture("[ 3, 3 ]", "QSymmS8") {}
};
struct SimpleRankDimSize3Fixture : RankFixture
{
SimpleRankDimSize3Fixture() : RankFixture("[ 2, 2, 1 ]", "Signed32") {}
};
struct SimpleRankDimSize4Fixture : RankFixture
{
SimpleRankDimSize4Fixture() : RankFixture("[ 2, 2, 1, 1 ]", "Float32") {}
};
TEST_CASE_FIXTURE(SimpleRankDimSize1Fixture, "RankDimSize1Float16")
{
RunTest<1, armnn::DataType::QSymmS16, armnn::DataType::Signed32>( 0,
{ 1, 2, 3, 4, 5, 6, 7, 8 },
{ 1 });
}
TEST_CASE_FIXTURE(SimpleRankDimSize2Fixture, "RankDimSize2QAsymmU8")
{
RunTest<1, armnn::DataType::QSymmS8, armnn::DataType::Signed32>( 0,
{ 1, 2, 3, 4, 5, 6, 7, 8, 9 },
{ 2 });
}
TEST_CASE_FIXTURE(SimpleRankDimSize3Fixture, "RankDimSize3Signed32")
{
RunTest<1, armnn::DataType::Signed32, armnn::DataType::Signed32>( 0,
{ 111, 85, 226, 3 },
{ 3 });
}
TEST_CASE_FIXTURE(SimpleRankDimSize4Fixture, "RankDimSize4Float32")
{
RunTest<1, armnn::DataType::Float32, armnn::DataType::Signed32>( 0,
{ 111, 85, 226, 3 },
{ 4 });
}
}