1*89c4ff92SAndroid Build Coastguard Worker // 2*89c4ff92SAndroid Build Coastguard Worker // Copyright © 2019 Arm Ltd and Contributors. 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 "ParserFlatbuffersFixture.hpp" 7*89c4ff92SAndroid Build Coastguard Worker 8*89c4ff92SAndroid Build Coastguard Worker 9*89c4ff92SAndroid Build Coastguard Worker TEST_SUITE("TensorflowLiteParser_Dequantize") 10*89c4ff92SAndroid Build Coastguard Worker { 11*89c4ff92SAndroid Build Coastguard Worker struct DequantizeFixture : public ParserFlatbuffersFixture 12*89c4ff92SAndroid Build Coastguard Worker { DequantizeFixtureDequantizeFixture13*89c4ff92SAndroid Build Coastguard Worker explicit DequantizeFixture(const std::string & inputShape, 14*89c4ff92SAndroid Build Coastguard Worker const std::string & outputShape, 15*89c4ff92SAndroid Build Coastguard Worker const std::string & dataType) 16*89c4ff92SAndroid Build Coastguard Worker { 17*89c4ff92SAndroid Build Coastguard Worker m_JsonString = R"( 18*89c4ff92SAndroid Build Coastguard Worker { 19*89c4ff92SAndroid Build Coastguard Worker "version": 3, 20*89c4ff92SAndroid Build Coastguard Worker "operator_codes": [ { "builtin_code": "DEQUANTIZE" } ], 21*89c4ff92SAndroid Build Coastguard Worker "subgraphs": [ { 22*89c4ff92SAndroid Build Coastguard Worker "tensors": [ 23*89c4ff92SAndroid Build Coastguard Worker { 24*89c4ff92SAndroid Build Coastguard Worker "shape": )" + inputShape + R"(, 25*89c4ff92SAndroid Build Coastguard Worker "type": )" + dataType + R"(, 26*89c4ff92SAndroid Build Coastguard Worker "buffer": 0, 27*89c4ff92SAndroid Build Coastguard Worker "name": "inputTensor", 28*89c4ff92SAndroid Build Coastguard Worker "quantization": { 29*89c4ff92SAndroid Build Coastguard Worker "min": [ 0.0 ], 30*89c4ff92SAndroid Build Coastguard Worker "max": [ 255.0 ], 31*89c4ff92SAndroid Build Coastguard Worker "scale": [ 1.5 ], 32*89c4ff92SAndroid Build Coastguard Worker "zero_point": [ 0 ], 33*89c4ff92SAndroid Build Coastguard Worker } 34*89c4ff92SAndroid Build Coastguard Worker }, 35*89c4ff92SAndroid Build Coastguard Worker { 36*89c4ff92SAndroid Build Coastguard Worker "shape": )" + outputShape + R"( , 37*89c4ff92SAndroid Build Coastguard Worker "type": "FLOAT32", 38*89c4ff92SAndroid Build Coastguard Worker "buffer": 1, 39*89c4ff92SAndroid Build Coastguard Worker "name": "outputTensor", 40*89c4ff92SAndroid Build Coastguard Worker "quantization": { 41*89c4ff92SAndroid Build Coastguard Worker "min": [ 0.0 ], 42*89c4ff92SAndroid Build Coastguard Worker "max": [ 255.0 ], 43*89c4ff92SAndroid Build Coastguard Worker "scale": [ 1.0 ], 44*89c4ff92SAndroid Build Coastguard Worker "zero_point": [ 0 ], 45*89c4ff92SAndroid Build Coastguard Worker } 46*89c4ff92SAndroid Build Coastguard Worker } 47*89c4ff92SAndroid Build Coastguard Worker ], 48*89c4ff92SAndroid Build Coastguard Worker "inputs": [ 0 ], 49*89c4ff92SAndroid Build Coastguard Worker "outputs": [ 1 ], 50*89c4ff92SAndroid Build Coastguard Worker "operators": [ 51*89c4ff92SAndroid Build Coastguard Worker { 52*89c4ff92SAndroid Build Coastguard Worker "opcode_index": 0, 53*89c4ff92SAndroid Build Coastguard Worker "inputs": [ 0 ], 54*89c4ff92SAndroid Build Coastguard Worker "outputs": [ 1 ], 55*89c4ff92SAndroid Build Coastguard Worker "builtin_options_type": "DequantizeOptions", 56*89c4ff92SAndroid Build Coastguard Worker "builtin_options": { 57*89c4ff92SAndroid Build Coastguard Worker }, 58*89c4ff92SAndroid Build Coastguard Worker "custom_options_format": "FLEXBUFFERS" 59*89c4ff92SAndroid Build Coastguard Worker } 60*89c4ff92SAndroid Build Coastguard Worker ], 61*89c4ff92SAndroid Build Coastguard Worker } ], 62*89c4ff92SAndroid Build Coastguard Worker "buffers" : [ 63*89c4ff92SAndroid Build Coastguard Worker { }, 64*89c4ff92SAndroid Build Coastguard Worker { }, 65*89c4ff92SAndroid Build Coastguard Worker ] 66*89c4ff92SAndroid Build Coastguard Worker } 67*89c4ff92SAndroid Build Coastguard Worker )"; 68*89c4ff92SAndroid Build Coastguard Worker SetupSingleInputSingleOutput("inputTensor", "outputTensor"); 69*89c4ff92SAndroid Build Coastguard Worker } 70*89c4ff92SAndroid Build Coastguard Worker }; 71*89c4ff92SAndroid Build Coastguard Worker 72*89c4ff92SAndroid Build Coastguard Worker struct SimpleDequantizeFixtureQAsymm8 : DequantizeFixture 73*89c4ff92SAndroid Build Coastguard Worker { SimpleDequantizeFixtureQAsymm8SimpleDequantizeFixtureQAsymm874*89c4ff92SAndroid Build Coastguard Worker SimpleDequantizeFixtureQAsymm8() : DequantizeFixture("[ 1, 6 ]", 75*89c4ff92SAndroid Build Coastguard Worker "[ 1, 6 ]", 76*89c4ff92SAndroid Build Coastguard Worker "UINT8") {} 77*89c4ff92SAndroid Build Coastguard Worker }; 78*89c4ff92SAndroid Build Coastguard Worker 79*89c4ff92SAndroid Build Coastguard Worker TEST_CASE_FIXTURE(SimpleDequantizeFixtureQAsymm8, "SimpleDequantizeQAsymm8") 80*89c4ff92SAndroid Build Coastguard Worker { 81*89c4ff92SAndroid Build Coastguard Worker RunTest<2, armnn::DataType::QAsymmU8 , armnn::DataType::Float32>( 82*89c4ff92SAndroid Build Coastguard Worker 0, 83*89c4ff92SAndroid Build Coastguard Worker {{"inputTensor", { 0u, 1u, 5u, 100u, 200u, 255u }}}, 84*89c4ff92SAndroid Build Coastguard Worker {{"outputTensor", { 0.0f, 1.5f, 7.5f, 150.0f, 300.0f, 382.5f }}}); 85*89c4ff92SAndroid Build Coastguard Worker } 86*89c4ff92SAndroid Build Coastguard Worker 87*89c4ff92SAndroid Build Coastguard Worker struct SimpleDequantizeFixtureQSymm16 : DequantizeFixture 88*89c4ff92SAndroid Build Coastguard Worker { SimpleDequantizeFixtureQSymm16SimpleDequantizeFixtureQSymm1689*89c4ff92SAndroid Build Coastguard Worker SimpleDequantizeFixtureQSymm16() : DequantizeFixture("[ 1, 6 ]", 90*89c4ff92SAndroid Build Coastguard Worker "[ 1, 6 ]", 91*89c4ff92SAndroid Build Coastguard Worker "INT16") {} 92*89c4ff92SAndroid Build Coastguard Worker }; 93*89c4ff92SAndroid Build Coastguard Worker 94*89c4ff92SAndroid Build Coastguard Worker TEST_CASE_FIXTURE(SimpleDequantizeFixtureQSymm16, "SimpleDequantizeQsymm16") 95*89c4ff92SAndroid Build Coastguard Worker { 96*89c4ff92SAndroid Build Coastguard Worker RunTest<2, armnn::DataType::QSymmS16 , armnn::DataType::Float32>( 97*89c4ff92SAndroid Build Coastguard Worker 0, 98*89c4ff92SAndroid Build Coastguard Worker {{"inputTensor", { 0, 1, 5, 32767, -1, -32768 }}}, 99*89c4ff92SAndroid Build Coastguard Worker {{"outputTensor", { 0.0f, 1.5f, 7.5f, 49150.5f, -1.5f,-49152.0f }}}); 100*89c4ff92SAndroid Build Coastguard Worker } 101*89c4ff92SAndroid Build Coastguard Worker 102*89c4ff92SAndroid Build Coastguard Worker struct SimpleDequantizeFixtureQAsymmS8 : DequantizeFixture 103*89c4ff92SAndroid Build Coastguard Worker { SimpleDequantizeFixtureQAsymmS8SimpleDequantizeFixtureQAsymmS8104*89c4ff92SAndroid Build Coastguard Worker SimpleDequantizeFixtureQAsymmS8() : DequantizeFixture("[ 1, 6 ]", 105*89c4ff92SAndroid Build Coastguard Worker "[ 1, 6 ]", 106*89c4ff92SAndroid Build Coastguard Worker "INT8") {} 107*89c4ff92SAndroid Build Coastguard Worker }; 108*89c4ff92SAndroid Build Coastguard Worker 109*89c4ff92SAndroid Build Coastguard Worker TEST_CASE_FIXTURE(SimpleDequantizeFixtureQAsymmS8, "SimpleDequantizeQAsymmS8") 110*89c4ff92SAndroid Build Coastguard Worker { 111*89c4ff92SAndroid Build Coastguard Worker RunTest<2, armnn::DataType::QAsymmS8 , armnn::DataType::Float32>( 112*89c4ff92SAndroid Build Coastguard Worker 0, 113*89c4ff92SAndroid Build Coastguard Worker {{"inputTensor", { 0, 1, 5, 127, -128, -1 }}}, 114*89c4ff92SAndroid Build Coastguard Worker {{"outputTensor", { 0.0f, 1.5f, 7.5f, 190.5f, -192.0f, -1.5f }}}); 115*89c4ff92SAndroid Build Coastguard Worker } 116*89c4ff92SAndroid Build Coastguard Worker 117*89c4ff92SAndroid Build Coastguard Worker } 118