blob: 736e821a0995bc43ec17a9247351861dafe0b908 [file] [log] [blame]
Darshan Patel42b3d7d2020-05-25 22:30:07 +05301//
2// Copyright © 2020 Arm Ltd. All rights reserved.
3// SPDX-License-Identifier: MIT
4//
5
Darshan Patel42b3d7d2020-05-25 22:30:07 +05306#include "ParserFlatbuffersFixture.hpp"
7#include "../TfLiteParser.hpp"
8
9#include <string>
10#include <iostream>
11
Sadik Armagan1625efc2021-06-10 18:24:34 +010012TEST_SUITE("TensorflowLiteParser_Div")
13{
Darshan Patel42b3d7d2020-05-25 22:30:07 +053014struct DivFixture : public ParserFlatbuffersFixture
15{
16 explicit DivFixture(const std::string & inputShape1,
17 const std::string & inputShape2,
18 const std::string & outputShape,
19 const std::string & activation="NONE")
20 {
21 m_JsonString = R"(
22 {
23 "version": 3,
24 "operator_codes": [ { "builtin_code": "DIV" } ],
25 "subgraphs": [ {
26 "tensors": [
27 {
28 "shape": )" + inputShape1 + R"(,
29 "type": "FLOAT32",
30 "buffer": 0,
31 "name": "inputTensor1",
32 "quantization": {
33 "min": [ 0.0 ],
34 "max": [ 255.0 ],
35 "scale": [ 1.0 ],
36 "zero_point": [ 0 ],
37 }
38 },
39 {
40 "shape": )" + inputShape2 + R"(,
41 "type": "FLOAT32",
42 "buffer": 1,
43 "name": "inputTensor2",
44 "quantization": {
45 "min": [ 0.0 ],
46 "max": [ 255.0 ],
47 "scale": [ 1.0 ],
48 "zero_point": [ 0 ],
49 }
50 },
51 {
52 "shape": )" + outputShape + R"( ,
53 "type": "FLOAT32",
54 "buffer": 2,
55 "name": "outputTensor",
56 "quantization": {
57 "min": [ 0.0 ],
58 "max": [ 255.0 ],
59 "scale": [ 1.0 ],
60 "zero_point": [ 0 ],
61 }
62 }
63 ],
64 "inputs": [ 0, 1 ],
65 "outputs": [ 2 ],
66 "operators": [
67 {
68 "opcode_index": 0,
69 "inputs": [ 0, 1 ],
70 "outputs": [ 2 ],
71 "builtin_options_type": "DivOptions",
72 "builtin_options": {
73 "fused_activation_function": )" + activation + R"(
74 },
75 "custom_options_format": "FLEXBUFFERS"
76 }
77 ],
78 } ],
79 "buffers" : [
80 { },
81 { }
82 ]
83 }
84 )";
85 Setup();
86 }
87};
88
89struct SimpleDivFixture : public DivFixture
90{
91 SimpleDivFixture() : DivFixture("[ 1, 2, 2, 3 ]", "[ 1, 2, 2, 3 ]", "[ 1, 2, 2, 3 ]") {}
92};
93
Sadik Armagan1625efc2021-06-10 18:24:34 +010094TEST_CASE_FIXTURE(SimpleDivFixture, "ParseDiv")
Darshan Patel42b3d7d2020-05-25 22:30:07 +053095{
96 using armnn::DataType;
97 float Inf = std::numeric_limits<float>::infinity();
98 float NaN = std::numeric_limits<float>::quiet_NaN();
99
100 RunTest<4, DataType::Float32>(0, {{ "inputTensor1", { 0.0f, 1.0f, 2.0f,
101 3.0f, 4.0f, 5.0f,
102 6.0f, 7.0f, 8.0f,
103 9.0f, 10.0f, -11.0f } },
104 { "inputTensor2", { 0.0f, 0.0f, 4.0f,
105 3.0f, 40.0f, 5.0f,
106 6.0f, 7.0f, 8.0f,
107 9.0f, 10.0f, 11.0f} } },
108 {{ "outputTensor", { NaN, Inf, 0.5f,
109 1.0f, 0.1f, 1.0f,
110 1.0f, 1.0f, 1.0f,
111 1.0f, 1.0f, -1.0f } } });
112}
113
Sadik Armagand109a4d2020-07-28 10:42:13 +0100114
115struct DynamicDivFixture : public DivFixture
116{
117 DynamicDivFixture() : DivFixture("[ 1, 2, 2, 3 ]", "[ 1, 2, 2, 3 ]", "[ ]") {}
118};
119
Sadik Armagan1625efc2021-06-10 18:24:34 +0100120TEST_CASE_FIXTURE(DynamicDivFixture, "ParseDynamicDiv")
Sadik Armagand109a4d2020-07-28 10:42:13 +0100121{
122 using armnn::DataType;
123 float Inf = std::numeric_limits<float>::infinity();
124 float NaN = std::numeric_limits<float>::quiet_NaN();
125
126 RunTest<4, DataType::Float32, DataType::Float32>(0, {{ "inputTensor1", { 0.0f, 1.0f, 2.0f,
127 3.0f, 4.0f, 5.0f,
128 6.0f, 7.0f, 8.0f,
129 9.0f, 10.0f, -11.0f } },
130 { "inputTensor2", { 0.0f, 0.0f, 4.0f,
131 3.0f, 40.0f, 5.0f,
132 6.0f, 7.0f, 8.0f,
133 9.0f, 10.0f, 11.0f} } },
134 {{ "outputTensor", { NaN, Inf, 0.5f,
135 1.0f, 0.1f, 1.0f,
136 1.0f, 1.0f, 1.0f,
137 1.0f, 1.0f, -1.0f } } }, true);
138}
139
Sadik Armagan1625efc2021-06-10 18:24:34 +0100140}