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