xref: /aosp_15_r20/external/armnn/src/armnnDeserializer/test/DeserializeDivision.cpp (revision 89c4ff92f2867872bb9e2354d150bf0c8c502810)
1*89c4ff92SAndroid Build Coastguard Worker //
2*89c4ff92SAndroid Build Coastguard Worker // Copyright © 2017 Arm Ltd. All rights reserved.
3*89c4ff92SAndroid Build Coastguard Worker // SPDX-License-Identifier: MIT
4*89c4ff92SAndroid Build Coastguard Worker //
5*89c4ff92SAndroid Build Coastguard Worker 
6*89c4ff92SAndroid Build Coastguard Worker #include "ParserFlatbuffersSerializeFixture.hpp"
7*89c4ff92SAndroid Build Coastguard Worker #include <armnnDeserializer/IDeserializer.hpp>
8*89c4ff92SAndroid Build Coastguard Worker 
9*89c4ff92SAndroid Build Coastguard Worker #include <string>
10*89c4ff92SAndroid Build Coastguard Worker 
11*89c4ff92SAndroid Build Coastguard Worker TEST_SUITE("Deserializer_Division")
12*89c4ff92SAndroid Build Coastguard Worker {
13*89c4ff92SAndroid Build Coastguard Worker struct DivisionFixture : public ParserFlatbuffersSerializeFixture
14*89c4ff92SAndroid Build Coastguard Worker {
DivisionFixtureDivisionFixture15*89c4ff92SAndroid Build Coastguard Worker     explicit DivisionFixture(const std::string & inputShape1,
16*89c4ff92SAndroid Build Coastguard Worker                         const std::string & inputShape2,
17*89c4ff92SAndroid Build Coastguard Worker                         const std::string & outputShape,
18*89c4ff92SAndroid Build Coastguard Worker                         const std::string & dataType)
19*89c4ff92SAndroid Build Coastguard Worker     {
20*89c4ff92SAndroid Build Coastguard Worker         m_JsonString = R"(
21*89c4ff92SAndroid Build Coastguard Worker         {
22*89c4ff92SAndroid Build Coastguard Worker                 inputIds: [0, 1],
23*89c4ff92SAndroid Build Coastguard Worker                 outputIds: [3],
24*89c4ff92SAndroid Build Coastguard Worker                 layers: [
25*89c4ff92SAndroid Build Coastguard Worker                 {
26*89c4ff92SAndroid Build Coastguard Worker                     layer_type: "InputLayer",
27*89c4ff92SAndroid Build Coastguard Worker                     layer: {
28*89c4ff92SAndroid Build Coastguard Worker                           base: {
29*89c4ff92SAndroid Build Coastguard Worker                                 layerBindingId: 0,
30*89c4ff92SAndroid Build Coastguard Worker                                 base: {
31*89c4ff92SAndroid Build Coastguard Worker                                     index: 0,
32*89c4ff92SAndroid Build Coastguard Worker                                     layerName: "InputLayer1",
33*89c4ff92SAndroid Build Coastguard Worker                                     layerType: "Input",
34*89c4ff92SAndroid Build Coastguard Worker                                     inputSlots: [{
35*89c4ff92SAndroid Build Coastguard Worker                                         index: 0,
36*89c4ff92SAndroid Build Coastguard Worker                                         connection: {sourceLayerIndex:0, outputSlotIndex:0 },
37*89c4ff92SAndroid Build Coastguard Worker                                     }],
38*89c4ff92SAndroid Build Coastguard Worker                                     outputSlots: [ {
39*89c4ff92SAndroid Build Coastguard Worker                                         index: 0,
40*89c4ff92SAndroid Build Coastguard Worker                                         tensorInfo: {
41*89c4ff92SAndroid Build Coastguard Worker                                             dimensions: )" + inputShape1 + R"(,
42*89c4ff92SAndroid Build Coastguard Worker                                             dataType: )" + dataType + R"(
43*89c4ff92SAndroid Build Coastguard Worker                                         },
44*89c4ff92SAndroid Build Coastguard Worker                                     }],
45*89c4ff92SAndroid Build Coastguard Worker                                  },}},
46*89c4ff92SAndroid Build Coastguard Worker                 },
47*89c4ff92SAndroid Build Coastguard Worker                 {
48*89c4ff92SAndroid Build Coastguard Worker                 layer_type: "InputLayer",
49*89c4ff92SAndroid Build Coastguard Worker                 layer: {
50*89c4ff92SAndroid Build Coastguard Worker                        base: {
51*89c4ff92SAndroid Build Coastguard Worker                             layerBindingId: 1,
52*89c4ff92SAndroid Build Coastguard Worker                             base: {
53*89c4ff92SAndroid Build Coastguard Worker                                   index:1,
54*89c4ff92SAndroid Build Coastguard Worker                                   layerName: "InputLayer2",
55*89c4ff92SAndroid Build Coastguard Worker                                   layerType: "Input",
56*89c4ff92SAndroid Build Coastguard Worker                                   inputSlots: [{
57*89c4ff92SAndroid Build Coastguard Worker                                       index: 0,
58*89c4ff92SAndroid Build Coastguard Worker                                       connection: {sourceLayerIndex:0, outputSlotIndex:0 },
59*89c4ff92SAndroid Build Coastguard Worker                                   }],
60*89c4ff92SAndroid Build Coastguard Worker                                   outputSlots: [ {
61*89c4ff92SAndroid Build Coastguard Worker                                       index: 0,
62*89c4ff92SAndroid Build Coastguard Worker                                       tensorInfo: {
63*89c4ff92SAndroid Build Coastguard Worker                                           dimensions: )" + inputShape2 + R"(,
64*89c4ff92SAndroid Build Coastguard Worker                                           dataType: )" + dataType + R"(
65*89c4ff92SAndroid Build Coastguard Worker                                       },
66*89c4ff92SAndroid Build Coastguard Worker                                   }],
67*89c4ff92SAndroid Build Coastguard Worker                                 },}},
68*89c4ff92SAndroid Build Coastguard Worker                 },
69*89c4ff92SAndroid Build Coastguard Worker                 {
70*89c4ff92SAndroid Build Coastguard Worker                 layer_type: "DivisionLayer",
71*89c4ff92SAndroid Build Coastguard Worker                 layer : {
72*89c4ff92SAndroid Build Coastguard Worker                         base: {
73*89c4ff92SAndroid Build Coastguard Worker                              index:2,
74*89c4ff92SAndroid Build Coastguard Worker                              layerName: "DivisionLayer",
75*89c4ff92SAndroid Build Coastguard Worker                              layerType: "Division",
76*89c4ff92SAndroid Build Coastguard Worker                              inputSlots: [
77*89c4ff92SAndroid Build Coastguard Worker                                             {
78*89c4ff92SAndroid Build Coastguard Worker                                              index: 0,
79*89c4ff92SAndroid Build Coastguard Worker                                              connection: {sourceLayerIndex:0, outputSlotIndex:0 },
80*89c4ff92SAndroid Build Coastguard Worker                                             },
81*89c4ff92SAndroid Build Coastguard Worker                                             {
82*89c4ff92SAndroid Build Coastguard Worker                                              index: 1,
83*89c4ff92SAndroid Build Coastguard Worker                                              connection: {sourceLayerIndex:1, outputSlotIndex:0 },
84*89c4ff92SAndroid Build Coastguard Worker                                             }
85*89c4ff92SAndroid Build Coastguard Worker                              ],
86*89c4ff92SAndroid Build Coastguard Worker                              outputSlots: [ {
87*89c4ff92SAndroid Build Coastguard Worker                                  index: 0,
88*89c4ff92SAndroid Build Coastguard Worker                                  tensorInfo: {
89*89c4ff92SAndroid Build Coastguard Worker                                      dimensions: )" + outputShape + R"(,
90*89c4ff92SAndroid Build Coastguard Worker                                      dataType: )" + dataType + R"(
91*89c4ff92SAndroid Build Coastguard Worker                                  },
92*89c4ff92SAndroid Build Coastguard Worker                              }],
93*89c4ff92SAndroid Build Coastguard Worker                             }},
94*89c4ff92SAndroid Build Coastguard Worker                 },
95*89c4ff92SAndroid Build Coastguard Worker                 {
96*89c4ff92SAndroid Build Coastguard Worker                 layer_type: "OutputLayer",
97*89c4ff92SAndroid Build Coastguard Worker                 layer: {
98*89c4ff92SAndroid Build Coastguard Worker                         base:{
99*89c4ff92SAndroid Build Coastguard Worker                               layerBindingId: 0,
100*89c4ff92SAndroid Build Coastguard Worker                               base: {
101*89c4ff92SAndroid Build Coastguard Worker                                     index: 3,
102*89c4ff92SAndroid Build Coastguard Worker                                     layerName: "OutputLayer",
103*89c4ff92SAndroid Build Coastguard Worker                                     layerType: "Output",
104*89c4ff92SAndroid Build Coastguard Worker                                     inputSlots: [{
105*89c4ff92SAndroid Build Coastguard Worker                                         index: 0,
106*89c4ff92SAndroid Build Coastguard Worker                                         connection: {sourceLayerIndex:2, outputSlotIndex:0 },
107*89c4ff92SAndroid Build Coastguard Worker                                     }],
108*89c4ff92SAndroid Build Coastguard Worker                                     outputSlots: [ {
109*89c4ff92SAndroid Build Coastguard Worker                                         index: 0,
110*89c4ff92SAndroid Build Coastguard Worker                                         tensorInfo: {
111*89c4ff92SAndroid Build Coastguard Worker                                             dimensions: )" + outputShape + R"(,
112*89c4ff92SAndroid Build Coastguard Worker                                             dataType: )" + dataType + R"(
113*89c4ff92SAndroid Build Coastguard Worker                                         },
114*89c4ff92SAndroid Build Coastguard Worker                                 }],
115*89c4ff92SAndroid Build Coastguard Worker                             }}},
116*89c4ff92SAndroid Build Coastguard Worker                 }]
117*89c4ff92SAndroid Build Coastguard Worker          }
118*89c4ff92SAndroid Build Coastguard Worker         )";
119*89c4ff92SAndroid Build Coastguard Worker         Setup();
120*89c4ff92SAndroid Build Coastguard Worker     }
121*89c4ff92SAndroid Build Coastguard Worker };
122*89c4ff92SAndroid Build Coastguard Worker 
123*89c4ff92SAndroid Build Coastguard Worker 
124*89c4ff92SAndroid Build Coastguard Worker struct SimpleDivisionFixture : DivisionFixture
125*89c4ff92SAndroid Build Coastguard Worker {
SimpleDivisionFixtureSimpleDivisionFixture126*89c4ff92SAndroid Build Coastguard Worker     SimpleDivisionFixture() : DivisionFixture("[ 2, 2 ]",
127*89c4ff92SAndroid Build Coastguard Worker                                               "[ 2, 2 ]",
128*89c4ff92SAndroid Build Coastguard Worker                                               "[ 2, 2 ]",
129*89c4ff92SAndroid Build Coastguard Worker                                               "QuantisedAsymm8") {}
130*89c4ff92SAndroid Build Coastguard Worker };
131*89c4ff92SAndroid Build Coastguard Worker 
132*89c4ff92SAndroid Build Coastguard Worker struct SimpleDivisionFixture2 : DivisionFixture
133*89c4ff92SAndroid Build Coastguard Worker {
SimpleDivisionFixture2SimpleDivisionFixture2134*89c4ff92SAndroid Build Coastguard Worker     SimpleDivisionFixture2() : DivisionFixture("[ 2, 2, 1, 1 ]",
135*89c4ff92SAndroid Build Coastguard Worker                                                "[ 2, 2, 1, 1 ]",
136*89c4ff92SAndroid Build Coastguard Worker                                                "[ 2, 2, 1, 1 ]",
137*89c4ff92SAndroid Build Coastguard Worker                                                "Float32") {}
138*89c4ff92SAndroid Build Coastguard Worker };
139*89c4ff92SAndroid Build Coastguard Worker 
140*89c4ff92SAndroid Build Coastguard Worker TEST_CASE_FIXTURE(SimpleDivisionFixture, "DivisionQuantisedAsymm8")
141*89c4ff92SAndroid Build Coastguard Worker {
142*89c4ff92SAndroid Build Coastguard Worker     RunTest<2, armnn::DataType::QAsymmU8>(
143*89c4ff92SAndroid Build Coastguard Worker         0,
144*89c4ff92SAndroid Build Coastguard Worker         {{"InputLayer1", { 0, 5, 24, 21 }},
145*89c4ff92SAndroid Build Coastguard Worker          {"InputLayer2", { 4, 1, 6,  7 }}},
146*89c4ff92SAndroid Build Coastguard Worker         {{"OutputLayer", { 0, 5, 3,  3 }}});
147*89c4ff92SAndroid Build Coastguard Worker }
148*89c4ff92SAndroid Build Coastguard Worker 
149*89c4ff92SAndroid Build Coastguard Worker TEST_CASE_FIXTURE(SimpleDivisionFixture2, "DivisionFloat32")
150*89c4ff92SAndroid Build Coastguard Worker {
151*89c4ff92SAndroid Build Coastguard Worker     RunTest<4, armnn::DataType::Float32>(
152*89c4ff92SAndroid Build Coastguard Worker         0,
153*89c4ff92SAndroid Build Coastguard Worker         {{"InputLayer1", { 100, 40, 226, 9 }},
154*89c4ff92SAndroid Build Coastguard Worker          {"InputLayer2", { 5,   8,  1,   3 }}},
155*89c4ff92SAndroid Build Coastguard Worker         {{"OutputLayer", { 20,  5,  226, 3 }}});
156*89c4ff92SAndroid Build Coastguard Worker }
157*89c4ff92SAndroid Build Coastguard Worker 
158*89c4ff92SAndroid Build Coastguard Worker }
159