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