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_Quantize") 10*89c4ff92SAndroid Build Coastguard Worker { 11*89c4ff92SAndroid Build Coastguard Worker struct QuantizeFixture : public ParserFlatbuffersFixture 12*89c4ff92SAndroid Build Coastguard Worker { QuantizeFixtureQuantizeFixture13*89c4ff92SAndroid Build Coastguard Worker explicit QuantizeFixture(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 const std::string& zeroPoint = "[ 0 ]") 17*89c4ff92SAndroid Build Coastguard Worker { 18*89c4ff92SAndroid Build Coastguard Worker m_JsonString = R"( 19*89c4ff92SAndroid Build Coastguard Worker { 20*89c4ff92SAndroid Build Coastguard Worker "version": 3, 21*89c4ff92SAndroid Build Coastguard Worker "operator_codes": [ { "builtin_code": "QUANTIZE" } ], 22*89c4ff92SAndroid Build Coastguard Worker "subgraphs": [ { 23*89c4ff92SAndroid Build Coastguard Worker "tensors": [ 24*89c4ff92SAndroid Build Coastguard Worker { 25*89c4ff92SAndroid Build Coastguard Worker "shape": )" + inputShape + R"(, 26*89c4ff92SAndroid Build Coastguard Worker "type": "FLOAT32", 27*89c4ff92SAndroid Build Coastguard Worker "buffer": 0, 28*89c4ff92SAndroid Build Coastguard Worker "name": "inputTensor", 29*89c4ff92SAndroid Build Coastguard Worker "quantization": { 30*89c4ff92SAndroid Build Coastguard Worker "min": [ 0.0 ], 31*89c4ff92SAndroid Build Coastguard Worker "max": [ 255.0 ], 32*89c4ff92SAndroid Build Coastguard Worker "scale": [ 1.0 ], 33*89c4ff92SAndroid Build Coastguard Worker "zero_point": )" + zeroPoint + R"(, 34*89c4ff92SAndroid Build Coastguard Worker } 35*89c4ff92SAndroid Build Coastguard Worker }, 36*89c4ff92SAndroid Build Coastguard Worker { 37*89c4ff92SAndroid Build Coastguard Worker "shape": )" + outputShape + R"( , 38*89c4ff92SAndroid Build Coastguard Worker "type": )" + dataType + R"(, 39*89c4ff92SAndroid Build Coastguard Worker "buffer": 1, 40*89c4ff92SAndroid Build Coastguard Worker "name": "outputTensor", 41*89c4ff92SAndroid Build Coastguard Worker "quantization": { 42*89c4ff92SAndroid Build Coastguard Worker "min": [ 0.0 ], 43*89c4ff92SAndroid Build Coastguard Worker "max": [ 255.0 ], 44*89c4ff92SAndroid Build Coastguard Worker "scale": [ 1.5 ], 45*89c4ff92SAndroid Build Coastguard Worker "zero_point": )" + zeroPoint + R"(, 46*89c4ff92SAndroid Build Coastguard Worker } 47*89c4ff92SAndroid Build Coastguard Worker } 48*89c4ff92SAndroid Build Coastguard Worker ], 49*89c4ff92SAndroid Build Coastguard Worker "inputs": [ 0 ], 50*89c4ff92SAndroid Build Coastguard Worker "outputs": [ 1 ], 51*89c4ff92SAndroid Build Coastguard Worker "operators": [ 52*89c4ff92SAndroid Build Coastguard Worker { 53*89c4ff92SAndroid Build Coastguard Worker "opcode_index": 0, 54*89c4ff92SAndroid Build Coastguard Worker "inputs": [ 0 ], 55*89c4ff92SAndroid Build Coastguard Worker "outputs": [ 1 ], 56*89c4ff92SAndroid Build Coastguard Worker "builtin_options_type": "QuantizeOptions", 57*89c4ff92SAndroid Build Coastguard Worker "builtin_options": { 58*89c4ff92SAndroid Build Coastguard Worker }, 59*89c4ff92SAndroid Build Coastguard Worker "custom_options_format": "FLEXBUFFERS" 60*89c4ff92SAndroid Build Coastguard Worker } 61*89c4ff92SAndroid Build Coastguard Worker ], 62*89c4ff92SAndroid Build Coastguard Worker } ], 63*89c4ff92SAndroid Build Coastguard Worker "buffers" : [ 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 )"; 69*89c4ff92SAndroid Build Coastguard Worker SetupSingleInputSingleOutput("inputTensor", "outputTensor"); 70*89c4ff92SAndroid Build Coastguard Worker } 71*89c4ff92SAndroid Build Coastguard Worker }; 72*89c4ff92SAndroid Build Coastguard Worker 73*89c4ff92SAndroid Build Coastguard Worker struct SimpleQuantizeFixtureQAsymm8 : QuantizeFixture 74*89c4ff92SAndroid Build Coastguard Worker { SimpleQuantizeFixtureQAsymm8SimpleQuantizeFixtureQAsymm875*89c4ff92SAndroid Build Coastguard Worker SimpleQuantizeFixtureQAsymm8() : QuantizeFixture("[ 1, 6 ]", 76*89c4ff92SAndroid Build Coastguard Worker "[ 1, 6 ]", 77*89c4ff92SAndroid Build Coastguard Worker "UINT8") {} 78*89c4ff92SAndroid Build Coastguard Worker }; 79*89c4ff92SAndroid Build Coastguard Worker 80*89c4ff92SAndroid Build Coastguard Worker TEST_CASE_FIXTURE(SimpleQuantizeFixtureQAsymm8, "SimpleQuantizeFixtureQAsymm8") 81*89c4ff92SAndroid Build Coastguard Worker { 82*89c4ff92SAndroid Build Coastguard Worker RunTest<2, armnn::DataType::Float32, armnn::DataType::QAsymmU8>( 83*89c4ff92SAndroid Build Coastguard Worker 0, 84*89c4ff92SAndroid Build Coastguard Worker {{"inputTensor", { 0.0f, 1.5f, 7.5f, 150.0f, 300.0f, 382.5f }}}, 85*89c4ff92SAndroid Build Coastguard Worker {{"outputTensor", { 0u, 1u, 5u, 100u, 200u, 255u }}}); 86*89c4ff92SAndroid Build Coastguard Worker } 87*89c4ff92SAndroid Build Coastguard Worker 88*89c4ff92SAndroid Build Coastguard Worker struct SimpleQuantizeFixtureQSymm16 : QuantizeFixture 89*89c4ff92SAndroid Build Coastguard Worker { SimpleQuantizeFixtureQSymm16SimpleQuantizeFixtureQSymm1690*89c4ff92SAndroid Build Coastguard Worker SimpleQuantizeFixtureQSymm16() : QuantizeFixture("[ 1, 6 ]", 91*89c4ff92SAndroid Build Coastguard Worker "[ 1, 6 ]", 92*89c4ff92SAndroid Build Coastguard Worker "INT16") {} 93*89c4ff92SAndroid Build Coastguard Worker }; 94*89c4ff92SAndroid Build Coastguard Worker 95*89c4ff92SAndroid Build Coastguard Worker TEST_CASE_FIXTURE(SimpleQuantizeFixtureQSymm16, "SimpleQuantizeQsymm16") 96*89c4ff92SAndroid Build Coastguard Worker { 97*89c4ff92SAndroid Build Coastguard Worker RunTest<2, armnn::DataType::Float32, armnn::DataType::QSymmS16>( 98*89c4ff92SAndroid Build Coastguard Worker 0, 99*89c4ff92SAndroid Build Coastguard Worker {{"inputTensor", { 0.0f, 1.5f, 7.5f, 49150.5f, -1.5f,-49152.0f }}}, 100*89c4ff92SAndroid Build Coastguard Worker {{"outputTensor", { 0, 1, 5, 32767, -1, -32768 }}}); 101*89c4ff92SAndroid Build Coastguard Worker } 102*89c4ff92SAndroid Build Coastguard Worker 103*89c4ff92SAndroid Build Coastguard Worker struct SimpleQuantizeFixtureQSymmS8 : QuantizeFixture 104*89c4ff92SAndroid Build Coastguard Worker { SimpleQuantizeFixtureQSymmS8SimpleQuantizeFixtureQSymmS8105*89c4ff92SAndroid Build Coastguard Worker SimpleQuantizeFixtureQSymmS8() : QuantizeFixture("[ 1, 6 ]", 106*89c4ff92SAndroid Build Coastguard Worker "[ 1, 6 ]", 107*89c4ff92SAndroid Build Coastguard Worker "INT8", 108*89c4ff92SAndroid Build Coastguard Worker "[]") {} 109*89c4ff92SAndroid Build Coastguard Worker }; 110*89c4ff92SAndroid Build Coastguard Worker 111*89c4ff92SAndroid Build Coastguard Worker TEST_CASE_FIXTURE(SimpleQuantizeFixtureQSymmS8, "SimpleQuantizeQSymmS8") 112*89c4ff92SAndroid Build Coastguard Worker { 113*89c4ff92SAndroid Build Coastguard Worker RunTest<2, armnn::DataType::Float32, armnn::DataType::QSymmS8>( 114*89c4ff92SAndroid Build Coastguard Worker 0, 115*89c4ff92SAndroid Build Coastguard Worker {{"inputTensor", { 0.0f, 1.5f, 7.5f, 190.5f, -192.0f, -1.5f }}}, 116*89c4ff92SAndroid Build Coastguard Worker {{"outputTensor", { 0, 1, 5, 127, -128, -1 }}}); 117*89c4ff92SAndroid Build Coastguard Worker } 118*89c4ff92SAndroid Build Coastguard Worker 119*89c4ff92SAndroid Build Coastguard Worker } 120