1*89c4ff92SAndroid Build Coastguard Worker // 2*89c4ff92SAndroid Build Coastguard Worker // Copyright © 2021-2023 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_ElementwiseUnary") 10*89c4ff92SAndroid Build Coastguard Worker { 11*89c4ff92SAndroid Build Coastguard Worker struct ElementWiseUnaryFixture : public ParserFlatbuffersFixture 12*89c4ff92SAndroid Build Coastguard Worker { ElementWiseUnaryFixtureElementWiseUnaryFixture13*89c4ff92SAndroid Build Coastguard Worker explicit ElementWiseUnaryFixture(const std::string& operatorCode, 14*89c4ff92SAndroid Build Coastguard Worker const std::string& dataType, 15*89c4ff92SAndroid Build Coastguard Worker const std::string& inputShape, 16*89c4ff92SAndroid Build Coastguard Worker const std::string& outputShape) 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": )" + operatorCode + R"( } ], 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": )" + dataType + R"( , 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": [ 0 ], 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.0 ], 45*89c4ff92SAndroid Build Coastguard Worker "zero_point": [ 0 ], 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 "custom_options_format": "FLEXBUFFERS" 57*89c4ff92SAndroid Build Coastguard Worker } 58*89c4ff92SAndroid Build Coastguard Worker ], 59*89c4ff92SAndroid Build Coastguard Worker } ], 60*89c4ff92SAndroid Build Coastguard Worker "buffers" : [ 61*89c4ff92SAndroid Build Coastguard Worker { }, 62*89c4ff92SAndroid Build Coastguard Worker { } 63*89c4ff92SAndroid Build Coastguard Worker ] 64*89c4ff92SAndroid Build Coastguard Worker } 65*89c4ff92SAndroid Build Coastguard Worker )"; 66*89c4ff92SAndroid Build Coastguard Worker Setup(); 67*89c4ff92SAndroid Build Coastguard Worker } 68*89c4ff92SAndroid Build Coastguard Worker }; 69*89c4ff92SAndroid Build Coastguard Worker 70*89c4ff92SAndroid Build Coastguard Worker struct SimpleAbsFixture : public ElementWiseUnaryFixture 71*89c4ff92SAndroid Build Coastguard Worker { SimpleAbsFixtureSimpleAbsFixture72*89c4ff92SAndroid Build Coastguard Worker SimpleAbsFixture() : ElementWiseUnaryFixture("ABS", "FLOAT32", "[ 2, 2 ]", "[ 2, 2 ]") {} 73*89c4ff92SAndroid Build Coastguard Worker }; 74*89c4ff92SAndroid Build Coastguard Worker 75*89c4ff92SAndroid Build Coastguard Worker TEST_CASE_FIXTURE(SimpleAbsFixture, "ParseAbs") 76*89c4ff92SAndroid Build Coastguard Worker { 77*89c4ff92SAndroid Build Coastguard Worker std::vector<float> inputValues 78*89c4ff92SAndroid Build Coastguard Worker { 79*89c4ff92SAndroid Build Coastguard Worker -0.1f, 0.2f, 80*89c4ff92SAndroid Build Coastguard Worker 0.3f, -0.4f 81*89c4ff92SAndroid Build Coastguard Worker }; 82*89c4ff92SAndroid Build Coastguard Worker 83*89c4ff92SAndroid Build Coastguard Worker // Calculate output data 84*89c4ff92SAndroid Build Coastguard Worker std::vector<float> expectedOutputValues(inputValues.size()); 85*89c4ff92SAndroid Build Coastguard Worker for (unsigned int i = 0; i < inputValues.size(); ++i) 86*89c4ff92SAndroid Build Coastguard Worker { 87*89c4ff92SAndroid Build Coastguard Worker expectedOutputValues[i] = std::abs(inputValues[i]); 88*89c4ff92SAndroid Build Coastguard Worker } 89*89c4ff92SAndroid Build Coastguard Worker 90*89c4ff92SAndroid Build Coastguard Worker RunTest<2, armnn::DataType::Float32>(0, {{ "inputTensor", { inputValues } }}, 91*89c4ff92SAndroid Build Coastguard Worker {{ "outputTensor",{ expectedOutputValues } } }); 92*89c4ff92SAndroid Build Coastguard Worker } 93*89c4ff92SAndroid Build Coastguard Worker 94*89c4ff92SAndroid Build Coastguard Worker struct SimpleExpFixture : public ElementWiseUnaryFixture 95*89c4ff92SAndroid Build Coastguard Worker { SimpleExpFixtureSimpleExpFixture96*89c4ff92SAndroid Build Coastguard Worker SimpleExpFixture() : ElementWiseUnaryFixture("EXP", "FLOAT32", "[ 1, 2, 3, 1 ]", "[ 1, 2, 3, 1 ]") {} 97*89c4ff92SAndroid Build Coastguard Worker }; 98*89c4ff92SAndroid Build Coastguard Worker 99*89c4ff92SAndroid Build Coastguard Worker TEST_CASE_FIXTURE(SimpleExpFixture, "ParseExp") 100*89c4ff92SAndroid Build Coastguard Worker { 101*89c4ff92SAndroid Build Coastguard Worker RunTest<4, armnn::DataType::Float32>(0, {{ "inputTensor", { 0.0f, 1.0f, 2.0f, 102*89c4ff92SAndroid Build Coastguard Worker 3.0f, 4.0f, 5.0f} }}, 103*89c4ff92SAndroid Build Coastguard Worker {{ "outputTensor",{ 1.0f, 2.718281f, 7.3890515f, 104*89c4ff92SAndroid Build Coastguard Worker 20.0855185f, 54.5980834f, 148.4129329f} } }); 105*89c4ff92SAndroid Build Coastguard Worker } 106*89c4ff92SAndroid Build Coastguard Worker 107*89c4ff92SAndroid Build Coastguard Worker struct SimpleLogFixture : public ElementWiseUnaryFixture 108*89c4ff92SAndroid Build Coastguard Worker { SimpleLogFixtureSimpleLogFixture109*89c4ff92SAndroid Build Coastguard Worker SimpleLogFixture() : ElementWiseUnaryFixture("LOG", "FLOAT32", "[ 1, 2, 3, 1 ]", "[ 1, 2, 3, 1 ]") {} 110*89c4ff92SAndroid Build Coastguard Worker }; 111*89c4ff92SAndroid Build Coastguard Worker 112*89c4ff92SAndroid Build Coastguard Worker TEST_CASE_FIXTURE(SimpleLogFixture, "ParseLog") 113*89c4ff92SAndroid Build Coastguard Worker { 114*89c4ff92SAndroid Build Coastguard Worker RunTest<4, armnn::DataType::Float32>(0, {{ "inputTensor", { 1.0f, 1.0f, 2.0f, 115*89c4ff92SAndroid Build Coastguard Worker 3.0f, 4.0f, 2.71828f} }}, 116*89c4ff92SAndroid Build Coastguard Worker {{ "outputTensor",{ 0.f, 0.f, 0.69314718056f, 117*89c4ff92SAndroid Build Coastguard Worker 1.09861228867f, 1.38629436112f, 0.99999932734f} } }); 118*89c4ff92SAndroid Build Coastguard Worker } 119*89c4ff92SAndroid Build Coastguard Worker 120*89c4ff92SAndroid Build Coastguard Worker struct SimpleLogicalNotFixture : public ElementWiseUnaryFixture 121*89c4ff92SAndroid Build Coastguard Worker { SimpleLogicalNotFixtureSimpleLogicalNotFixture122*89c4ff92SAndroid Build Coastguard Worker SimpleLogicalNotFixture() : ElementWiseUnaryFixture("LOGICAL_NOT", "BOOL", "[ 1, 1, 1, 4 ]", "[ 1, 1, 1, 4 ]") {} 123*89c4ff92SAndroid Build Coastguard Worker }; 124*89c4ff92SAndroid Build Coastguard Worker 125*89c4ff92SAndroid Build Coastguard Worker TEST_CASE_FIXTURE(SimpleLogicalNotFixture, "ParseLogicalNot") 126*89c4ff92SAndroid Build Coastguard Worker { 127*89c4ff92SAndroid Build Coastguard Worker RunTest<4, armnn::DataType::Boolean>(0, {{ "inputTensor", { 0, 1, 0, 1 } }}, 128*89c4ff92SAndroid Build Coastguard Worker {{ "outputTensor",{ 1, 0, 1, 0 } } }); 129*89c4ff92SAndroid Build Coastguard Worker } 130*89c4ff92SAndroid Build Coastguard Worker 131*89c4ff92SAndroid Build Coastguard Worker struct SimpleNegFixture : public ElementWiseUnaryFixture 132*89c4ff92SAndroid Build Coastguard Worker { SimpleNegFixtureSimpleNegFixture133*89c4ff92SAndroid Build Coastguard Worker SimpleNegFixture() : ElementWiseUnaryFixture("NEG", "FLOAT32", "[ 1, 2, 3, 1 ]", "[ 1, 2, 3, 1 ]") {} 134*89c4ff92SAndroid Build Coastguard Worker }; 135*89c4ff92SAndroid Build Coastguard Worker 136*89c4ff92SAndroid Build Coastguard Worker TEST_CASE_FIXTURE(SimpleNegFixture, "ParseNeg") 137*89c4ff92SAndroid Build Coastguard Worker { 138*89c4ff92SAndroid Build Coastguard Worker RunTest<4, armnn::DataType::Float32>(0, {{ "inputTensor", { 0.0f, 1.0f, -2.0f, 139*89c4ff92SAndroid Build Coastguard Worker 20.0855185f, -54.5980834f, 5.0f} }}, 140*89c4ff92SAndroid Build Coastguard Worker {{ "outputTensor",{ 0.0f, -1.0f, 2.0f, 141*89c4ff92SAndroid Build Coastguard Worker -20.0855185f, 54.5980834f, -5.0f} }}); 142*89c4ff92SAndroid Build Coastguard Worker } 143*89c4ff92SAndroid Build Coastguard Worker 144*89c4ff92SAndroid Build Coastguard Worker struct SimpleRsqrtFixture : public ElementWiseUnaryFixture 145*89c4ff92SAndroid Build Coastguard Worker { SimpleRsqrtFixtureSimpleRsqrtFixture146*89c4ff92SAndroid Build Coastguard Worker SimpleRsqrtFixture() : ElementWiseUnaryFixture("RSQRT", "FLOAT32", "[ 1, 2, 3, 1 ]", "[ 1, 2, 3, 1 ]") {} 147*89c4ff92SAndroid Build Coastguard Worker }; 148*89c4ff92SAndroid Build Coastguard Worker 149*89c4ff92SAndroid Build Coastguard Worker TEST_CASE_FIXTURE(SimpleRsqrtFixture, "ParseRsqrt") 150*89c4ff92SAndroid Build Coastguard Worker { 151*89c4ff92SAndroid Build Coastguard Worker RunTest<4, armnn::DataType::Float32>(0, {{ "inputTensor", { 1.0f, 4.0f, 16.0f, 152*89c4ff92SAndroid Build Coastguard Worker 25.0f, 64.0f, 100.0f } }}, 153*89c4ff92SAndroid Build Coastguard Worker {{ "outputTensor",{ 1.0f, 0.5f, 0.25f, 154*89c4ff92SAndroid Build Coastguard Worker 0.2f, 0.125f, 0.1f} }}); 155*89c4ff92SAndroid Build Coastguard Worker } 156*89c4ff92SAndroid Build Coastguard Worker 157*89c4ff92SAndroid Build Coastguard Worker struct SimpleSqrtFixture : public ElementWiseUnaryFixture 158*89c4ff92SAndroid Build Coastguard Worker { SimpleSqrtFixtureSimpleSqrtFixture159*89c4ff92SAndroid Build Coastguard Worker SimpleSqrtFixture() : ElementWiseUnaryFixture("SQRT", "FLOAT32", "[ 1, 2, 3, 1 ]", "[ 1, 2, 3, 1 ]") {} 160*89c4ff92SAndroid Build Coastguard Worker }; 161*89c4ff92SAndroid Build Coastguard Worker 162*89c4ff92SAndroid Build Coastguard Worker TEST_CASE_FIXTURE(SimpleSqrtFixture, "ParseSqrt") 163*89c4ff92SAndroid Build Coastguard Worker { 164*89c4ff92SAndroid Build Coastguard Worker RunTest<4, armnn::DataType::Float32>(0, {{ "inputTensor", { 9.0f, 4.0f, 16.0f, 165*89c4ff92SAndroid Build Coastguard Worker 25.0f, 36.0f, 49.0f } }}, 166*89c4ff92SAndroid Build Coastguard Worker {{ "outputTensor",{ 3.0f, 2.0f, 4.0f, 167*89c4ff92SAndroid Build Coastguard Worker 5.0f, 6.0f, 7.0f} }}); 168*89c4ff92SAndroid Build Coastguard Worker } 169*89c4ff92SAndroid Build Coastguard Worker 170*89c4ff92SAndroid Build Coastguard Worker struct SimpleSinFixture : public ElementWiseUnaryFixture 171*89c4ff92SAndroid Build Coastguard Worker { SimpleSinFixtureSimpleSinFixture172*89c4ff92SAndroid Build Coastguard Worker SimpleSinFixture() : ElementWiseUnaryFixture("SIN", "FLOAT32", "[ 1, 2, 3, 1 ]", "[ 1, 2, 3, 1 ]") {} 173*89c4ff92SAndroid Build Coastguard Worker }; 174*89c4ff92SAndroid Build Coastguard Worker 175*89c4ff92SAndroid Build Coastguard Worker TEST_CASE_FIXTURE(SimpleSinFixture, "ParseSin") 176*89c4ff92SAndroid Build Coastguard Worker { 177*89c4ff92SAndroid Build Coastguard Worker RunTest<4, armnn::DataType::Float32>(0, {{ "inputTensor", { 0.0f, 1.0f, 16.0f, 178*89c4ff92SAndroid Build Coastguard Worker 0.5f, 36.0f, -1.f } }}, 179*89c4ff92SAndroid Build Coastguard Worker {{ "outputTensor",{ 0.0f, 0.8414709848f, -0.28790331666f, 180*89c4ff92SAndroid Build Coastguard Worker 0.4794255386f, -0.99177885344f, -0.8414709848f} }}); 181*89c4ff92SAndroid Build Coastguard Worker } 182*89c4ff92SAndroid Build Coastguard Worker 183*89c4ff92SAndroid Build Coastguard Worker struct SimpleCeilFixture : public ElementWiseUnaryFixture 184*89c4ff92SAndroid Build Coastguard Worker { SimpleCeilFixtureSimpleCeilFixture185*89c4ff92SAndroid Build Coastguard Worker SimpleCeilFixture() : ElementWiseUnaryFixture("CEIL", "FLOAT32", "[ 1, 2, 3, 1 ]", "[ 1, 2, 3, 1 ]") {} 186*89c4ff92SAndroid Build Coastguard Worker }; 187*89c4ff92SAndroid Build Coastguard Worker 188*89c4ff92SAndroid Build Coastguard Worker TEST_CASE_FIXTURE(SimpleCeilFixture, "ParseCeil") 189*89c4ff92SAndroid Build Coastguard Worker { 190*89c4ff92SAndroid Build Coastguard Worker RunTest<4, armnn::DataType::Float32>(0, {{ "inputTensor", { -50.5f, -25.9999f, -0.5f, 0.0f, 1.5555f, 25.5f } }}, 191*89c4ff92SAndroid Build Coastguard Worker {{ "outputTensor",{ -50.0f, -25.0f, 0.0f, 0.0f, 2.0f, 26.0f} }}); 192*89c4ff92SAndroid Build Coastguard Worker } 193*89c4ff92SAndroid Build Coastguard Worker 194*89c4ff92SAndroid Build Coastguard Worker } 195