xref: /aosp_15_r20/external/armnn/src/armnnDeserializer/test/DeserializeMultiplication.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 <armnn/utility/IgnoreUnused.hpp>
10*89c4ff92SAndroid Build Coastguard Worker 
11*89c4ff92SAndroid Build Coastguard Worker #include <string>
12*89c4ff92SAndroid Build Coastguard Worker 
13*89c4ff92SAndroid Build Coastguard Worker TEST_SUITE("Deserializer_Multiplication")
14*89c4ff92SAndroid Build Coastguard Worker {
15*89c4ff92SAndroid Build Coastguard Worker struct MultiplicationFixture : public ParserFlatbuffersSerializeFixture
16*89c4ff92SAndroid Build Coastguard Worker {
MultiplicationFixtureMultiplicationFixture17*89c4ff92SAndroid Build Coastguard Worker     explicit MultiplicationFixture(const std::string & inputShape1,
18*89c4ff92SAndroid Build Coastguard Worker                                    const std::string & inputShape2,
19*89c4ff92SAndroid Build Coastguard Worker                                    const std::string & outputShape,
20*89c4ff92SAndroid Build Coastguard Worker                                    const std::string & dataType,
21*89c4ff92SAndroid Build Coastguard Worker                                    const std::string & activation="NONE")
22*89c4ff92SAndroid Build Coastguard Worker     {
23*89c4ff92SAndroid Build Coastguard Worker         armnn::IgnoreUnused(activation);
24*89c4ff92SAndroid Build Coastguard Worker         m_JsonString = R"(
25*89c4ff92SAndroid Build Coastguard Worker         {
26*89c4ff92SAndroid Build Coastguard Worker                 inputIds: [0, 1],
27*89c4ff92SAndroid Build Coastguard Worker                 outputIds: [3],
28*89c4ff92SAndroid Build Coastguard Worker                 layers: [
29*89c4ff92SAndroid Build Coastguard Worker                 {
30*89c4ff92SAndroid Build Coastguard Worker                     layer_type: "InputLayer",
31*89c4ff92SAndroid Build Coastguard Worker                     layer: {
32*89c4ff92SAndroid Build Coastguard Worker                           base: {
33*89c4ff92SAndroid Build Coastguard Worker                                 layerBindingId: 0,
34*89c4ff92SAndroid Build Coastguard Worker                                 base: {
35*89c4ff92SAndroid Build Coastguard Worker                                     index: 0,
36*89c4ff92SAndroid Build Coastguard Worker                                     layerName: "InputLayer1",
37*89c4ff92SAndroid Build Coastguard Worker                                     layerType: "Input",
38*89c4ff92SAndroid Build Coastguard Worker                                     inputSlots: [{
39*89c4ff92SAndroid Build Coastguard Worker                                         index: 0,
40*89c4ff92SAndroid Build Coastguard Worker                                         connection: {sourceLayerIndex:0, outputSlotIndex:0 },
41*89c4ff92SAndroid Build Coastguard Worker                                     }],
42*89c4ff92SAndroid Build Coastguard Worker                                     outputSlots: [ {
43*89c4ff92SAndroid Build Coastguard Worker                                         index: 0,
44*89c4ff92SAndroid Build Coastguard Worker                                         tensorInfo: {
45*89c4ff92SAndroid Build Coastguard Worker                                             dimensions: )" + inputShape1 + R"(,
46*89c4ff92SAndroid Build Coastguard Worker                                             dataType: )" + dataType + R"(
47*89c4ff92SAndroid Build Coastguard Worker                                         },
48*89c4ff92SAndroid Build Coastguard Worker                                     }],
49*89c4ff92SAndroid Build Coastguard Worker                                  },}},
50*89c4ff92SAndroid Build Coastguard Worker                 },
51*89c4ff92SAndroid Build Coastguard Worker                 {
52*89c4ff92SAndroid Build Coastguard Worker                 layer_type: "InputLayer",
53*89c4ff92SAndroid Build Coastguard Worker                 layer: {
54*89c4ff92SAndroid Build Coastguard Worker                        base: {
55*89c4ff92SAndroid Build Coastguard Worker                             layerBindingId: 1,
56*89c4ff92SAndroid Build Coastguard Worker                             base: {
57*89c4ff92SAndroid Build Coastguard Worker                                   index:1,
58*89c4ff92SAndroid Build Coastguard Worker                                   layerName: "InputLayer2",
59*89c4ff92SAndroid Build Coastguard Worker                                   layerType: "Input",
60*89c4ff92SAndroid Build Coastguard Worker                                   inputSlots: [{
61*89c4ff92SAndroid Build Coastguard Worker                                       index: 0,
62*89c4ff92SAndroid Build Coastguard Worker                                       connection: {sourceLayerIndex:0, outputSlotIndex:0 },
63*89c4ff92SAndroid Build Coastguard Worker                                   }],
64*89c4ff92SAndroid Build Coastguard Worker                                   outputSlots: [ {
65*89c4ff92SAndroid Build Coastguard Worker                                       index: 0,
66*89c4ff92SAndroid Build Coastguard Worker                                       tensorInfo: {
67*89c4ff92SAndroid Build Coastguard Worker                                           dimensions: )" + inputShape2 + R"(,
68*89c4ff92SAndroid Build Coastguard Worker                                           dataType: )" + dataType + R"(
69*89c4ff92SAndroid Build Coastguard Worker                                       },
70*89c4ff92SAndroid Build Coastguard Worker                                   }],
71*89c4ff92SAndroid Build Coastguard Worker                                 },}},
72*89c4ff92SAndroid Build Coastguard Worker                 },
73*89c4ff92SAndroid Build Coastguard Worker                 {
74*89c4ff92SAndroid Build Coastguard Worker                 layer_type: "MultiplicationLayer",
75*89c4ff92SAndroid Build Coastguard Worker                 layer : {
76*89c4ff92SAndroid Build Coastguard Worker                         base: {
77*89c4ff92SAndroid Build Coastguard Worker                              index:2,
78*89c4ff92SAndroid Build Coastguard Worker                              layerName: "MultiplicationLayer",
79*89c4ff92SAndroid Build Coastguard Worker                              layerType: "Multiplication",
80*89c4ff92SAndroid Build Coastguard Worker                              inputSlots: [
81*89c4ff92SAndroid Build Coastguard Worker                                             {
82*89c4ff92SAndroid Build Coastguard Worker                                              index: 0,
83*89c4ff92SAndroid Build Coastguard Worker                                              connection: {sourceLayerIndex:0, outputSlotIndex:0 },
84*89c4ff92SAndroid Build Coastguard Worker                                             },
85*89c4ff92SAndroid Build Coastguard Worker                                             {
86*89c4ff92SAndroid Build Coastguard Worker                                              index: 1,
87*89c4ff92SAndroid Build Coastguard Worker                                              connection: {sourceLayerIndex:1, outputSlotIndex:0 },
88*89c4ff92SAndroid Build Coastguard Worker                                             }
89*89c4ff92SAndroid Build Coastguard Worker                              ],
90*89c4ff92SAndroid Build Coastguard Worker                              outputSlots: [ {
91*89c4ff92SAndroid Build Coastguard Worker                                  index: 0,
92*89c4ff92SAndroid Build Coastguard Worker                                  tensorInfo: {
93*89c4ff92SAndroid Build Coastguard Worker                                      dimensions: )" + outputShape + R"(,
94*89c4ff92SAndroid Build Coastguard Worker                                      dataType: )" + dataType + R"(
95*89c4ff92SAndroid Build Coastguard Worker                                  },
96*89c4ff92SAndroid Build Coastguard Worker                              }],
97*89c4ff92SAndroid Build Coastguard Worker                             }},
98*89c4ff92SAndroid Build Coastguard Worker                 },
99*89c4ff92SAndroid Build Coastguard Worker                 {
100*89c4ff92SAndroid Build Coastguard Worker                 layer_type: "OutputLayer",
101*89c4ff92SAndroid Build Coastguard Worker                 layer: {
102*89c4ff92SAndroid Build Coastguard Worker                         base:{
103*89c4ff92SAndroid Build Coastguard Worker                               layerBindingId: 0,
104*89c4ff92SAndroid Build Coastguard Worker                               base: {
105*89c4ff92SAndroid Build Coastguard Worker                                     index: 3,
106*89c4ff92SAndroid Build Coastguard Worker                                     layerName: "OutputLayer",
107*89c4ff92SAndroid Build Coastguard Worker                                     layerType: "Output",
108*89c4ff92SAndroid Build Coastguard Worker                                     inputSlots: [{
109*89c4ff92SAndroid Build Coastguard Worker                                         index: 0,
110*89c4ff92SAndroid Build Coastguard Worker                                         connection: {sourceLayerIndex:2, outputSlotIndex:0 },
111*89c4ff92SAndroid Build Coastguard Worker                                     }],
112*89c4ff92SAndroid Build Coastguard Worker                                     outputSlots: [ {
113*89c4ff92SAndroid Build Coastguard Worker                                         index: 0,
114*89c4ff92SAndroid Build Coastguard Worker                                         tensorInfo: {
115*89c4ff92SAndroid Build Coastguard Worker                                             dimensions: )" + outputShape + R"(,
116*89c4ff92SAndroid Build Coastguard Worker                                             dataType: )" + dataType + R"(
117*89c4ff92SAndroid Build Coastguard Worker                                         },
118*89c4ff92SAndroid Build Coastguard Worker                                 }],
119*89c4ff92SAndroid Build Coastguard Worker                             }}},
120*89c4ff92SAndroid Build Coastguard Worker                 }]
121*89c4ff92SAndroid Build Coastguard Worker          }
122*89c4ff92SAndroid Build Coastguard Worker         )";
123*89c4ff92SAndroid Build Coastguard Worker         Setup();
124*89c4ff92SAndroid Build Coastguard Worker     }
125*89c4ff92SAndroid Build Coastguard Worker };
126*89c4ff92SAndroid Build Coastguard Worker 
127*89c4ff92SAndroid Build Coastguard Worker 
128*89c4ff92SAndroid Build Coastguard Worker struct SimpleMultiplicationFixture : MultiplicationFixture
129*89c4ff92SAndroid Build Coastguard Worker {
SimpleMultiplicationFixtureSimpleMultiplicationFixture130*89c4ff92SAndroid Build Coastguard Worker     SimpleMultiplicationFixture() : MultiplicationFixture("[ 2, 2 ]",
131*89c4ff92SAndroid Build Coastguard Worker                                                           "[ 2, 2 ]",
132*89c4ff92SAndroid Build Coastguard Worker                                                           "[ 2, 2 ]",
133*89c4ff92SAndroid Build Coastguard Worker                                                           "QuantisedAsymm8") {}
134*89c4ff92SAndroid Build Coastguard Worker };
135*89c4ff92SAndroid Build Coastguard Worker 
136*89c4ff92SAndroid Build Coastguard Worker struct SimpleMultiplicationFixture2 : MultiplicationFixture
137*89c4ff92SAndroid Build Coastguard Worker {
SimpleMultiplicationFixture2SimpleMultiplicationFixture2138*89c4ff92SAndroid Build Coastguard Worker     SimpleMultiplicationFixture2() : MultiplicationFixture("[ 2, 2, 1, 1 ]",
139*89c4ff92SAndroid Build Coastguard Worker                                                            "[ 2, 2, 1, 1 ]",
140*89c4ff92SAndroid Build Coastguard Worker                                                            "[ 2, 2, 1, 1 ]",
141*89c4ff92SAndroid Build Coastguard Worker                                                            "Float32") {}
142*89c4ff92SAndroid Build Coastguard Worker };
143*89c4ff92SAndroid Build Coastguard Worker 
144*89c4ff92SAndroid Build Coastguard Worker TEST_CASE_FIXTURE(SimpleMultiplicationFixture, "MultiplicationQuantisedAsymm8")
145*89c4ff92SAndroid Build Coastguard Worker {
146*89c4ff92SAndroid Build Coastguard Worker   RunTest<2, armnn::DataType::QAsymmU8>(
147*89c4ff92SAndroid Build Coastguard Worker       0,
148*89c4ff92SAndroid Build Coastguard Worker       {{"InputLayer1", { 0, 1, 2, 3 }},
149*89c4ff92SAndroid Build Coastguard Worker       {"InputLayer2", { 4, 5, 6, 7 }}},
150*89c4ff92SAndroid Build Coastguard Worker       {{"OutputLayer", { 0, 5, 12, 21 }}});
151*89c4ff92SAndroid Build Coastguard Worker }
152*89c4ff92SAndroid Build Coastguard Worker 
153*89c4ff92SAndroid Build Coastguard Worker TEST_CASE_FIXTURE(SimpleMultiplicationFixture2, "MultiplicationFloat32")
154*89c4ff92SAndroid Build Coastguard Worker {
155*89c4ff92SAndroid Build Coastguard Worker     RunTest<4, armnn::DataType::Float32>(
156*89c4ff92SAndroid Build Coastguard Worker     0,
157*89c4ff92SAndroid Build Coastguard Worker     {{"InputLayer1", { 100, 40, 226, 9 }},
158*89c4ff92SAndroid Build Coastguard Worker     {"InputLayer2", {   5,   8,  1, 12 }}},
159*89c4ff92SAndroid Build Coastguard Worker     {{"OutputLayer", { 500, 320, 226, 108 }}});
160*89c4ff92SAndroid Build Coastguard Worker }
161*89c4ff92SAndroid Build Coastguard Worker 
162*89c4ff92SAndroid Build Coastguard Worker }
163