aboutsummaryrefslogtreecommitdiff
path: root/src/armnnDeserializer/test/DeserializeArgMinMax.cpp
blob: 5a792283d8ca38cf2bf722d529624afb95ac0565 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
//
// Copyright © 2021 Arm Ltd and Contributors. All rights reserved.
// SPDX-License-Identifier: MIT
//

#include "ParserFlatbuffersSerializeFixture.hpp"
#include "../Deserializer.hpp"

#include <string>
#include <iostream>

TEST_SUITE("DeserializeParser_ArgMinMax")
{
struct ArgMinMaxFixture : public ParserFlatbuffersSerializeFixture
{
    explicit ArgMinMaxFixture(const std::string& inputShape,
                              const std::string& outputShape,
                              const std::string& axis,
                              const std::string& argMinMaxFunction)
    {
        m_JsonString = R"(
        {
          layers: [
            {
              layer_type: "InputLayer",
              layer: {
                base: {
                  base: {
                    layerName: "InputLayer",
                    layerType: "Input",
                    inputSlots: [

                    ],
                    outputSlots: [
                      {
                        tensorInfo: {
                          dimensions: )" + inputShape + R"(,
                          dataType: "Float32",
                          quantizationScale: 0.0
                        }
                      }
                    ]
                  }
                }
              }
            },
            {
              layer_type: "ArgMinMaxLayer",
              layer: {
                base: {
                  index: 1,
                  layerName: "ArgMinMaxLayer",
                  layerType: "ArgMinMax",
                  inputSlots: [
                    {
                      connection: {
                        sourceLayerIndex: 0,
                        outputSlotIndex: 0
                      }
                    }
                  ],
                  outputSlots: [
                    {
                      tensorInfo: {
                        dimensions: )" + outputShape + R"(,
                        dataType: "Signed64",
                        quantizationScale: 0.0
                      }
                    }
                  ]
                },
                descriptor: {
                  axis: )" + axis + R"(,
                  argMinMaxFunction: )" + argMinMaxFunction + R"(
                }
              }
            },
            {
              layer_type: "OutputLayer",
              layer: {
                base: {
                  base: {
                    index: 2,
                    layerName: "OutputLayer",
                    layerType: "Output",
                    inputSlots: [
                      {
                        connection: {
                          sourceLayerIndex: 1,
                          outputSlotIndex: 0
                        }
                      }
                    ],
                    outputSlots: [

                    ]
                  }
                }
              }
            }
          ],
          inputIds: [
            0
          ],
          outputIds: [
            0
          ],
          featureVersions: {
            bindingIdsScheme: 1
          }
        }
    )";
        Setup();
    }
};

struct SimpleArgMinMaxFixture : public ArgMinMaxFixture
{
    SimpleArgMinMaxFixture() : ArgMinMaxFixture("[ 1, 1, 1, 5 ]",
                                                "[ 1, 1, 1 ]",
                                                "-1",
                                                "Max") {}
};

TEST_CASE_FIXTURE(SimpleArgMinMaxFixture, "ArgMinMax")
{
    RunTest<3, armnn::DataType::Float32, armnn::DataType::Signed64>(
            0,
            {{"InputLayer", { 6.0f, 2.0f, 8.0f, 10.0f, 9.0f}}},
            {{"OutputLayer",{ 3l }}});
}

}