1 // clang-format off
2 // Generated file (from: reduce_sum.mod.py). Do not edit
CreateModel(Model * model)3 void CreateModel(Model *model) {
4   OperandType type0(Type::TENSOR_FLOAT32, {3, 2});
5   OperandType type1(Type::TENSOR_FLOAT32, {3});
6   OperandType type2(Type::TENSOR_INT32, {1});
7   OperandType type3(Type::BOOL, {});
8   // Phase 1, operands
9   auto input0 = model->addOperand(&type0);
10   auto param = model->addOperand(&type2);
11   auto param1 = model->addOperand(&type3);
12   auto output0 = model->addOperand(&type1);
13   // Phase 2, operations
14   static int32_t param_init[] = {-1};
15   model->setOperandValue(param, param_init, sizeof(int32_t) * 1);
16   static bool8 param1_init[] = {false};
17   model->setOperandValue(param1, param1_init, sizeof(bool8) * 1);
18   model->addOperation(ANEURALNETWORKS_REDUCE_SUM, {input0, param, param1}, {output0});
19   // Phase 3, inputs and outputs
20   model->identifyInputsAndOutputs(
21     {input0},
22     {output0});
23   assert(model->isValid());
24 }
25 
is_ignored(int i)26 inline bool is_ignored(int i) {
27   static std::set<int> ignore = {};
28   return ignore.find(i) != ignore.end();
29 }
30 
CreateModel_relaxed(Model * model)31 void CreateModel_relaxed(Model *model) {
32   OperandType type0(Type::TENSOR_FLOAT32, {3, 2});
33   OperandType type1(Type::TENSOR_FLOAT32, {3});
34   OperandType type2(Type::TENSOR_INT32, {1});
35   OperandType type3(Type::BOOL, {});
36   // Phase 1, operands
37   auto input0 = model->addOperand(&type0);
38   auto param = model->addOperand(&type2);
39   auto param1 = model->addOperand(&type3);
40   auto output0 = model->addOperand(&type1);
41   // Phase 2, operations
42   static int32_t param_init[] = {-1};
43   model->setOperandValue(param, param_init, sizeof(int32_t) * 1);
44   static bool8 param1_init[] = {false};
45   model->setOperandValue(param1, param1_init, sizeof(bool8) * 1);
46   model->addOperation(ANEURALNETWORKS_REDUCE_SUM, {input0, param, param1}, {output0});
47   // Phase 3, inputs and outputs
48   model->identifyInputsAndOutputs(
49     {input0},
50     {output0});
51   // Phase 4: set relaxed execution
52   model->relaxComputationFloat32toFloat16(true);
53   assert(model->isValid());
54 }
55 
is_ignored_relaxed(int i)56 inline bool is_ignored_relaxed(int i) {
57   static std::set<int> ignore = {};
58   return ignore.find(i) != ignore.end();
59 }
60 
CreateModel_float16(Model * model)61 void CreateModel_float16(Model *model) {
62   OperandType type10(Type::TENSOR_FLOAT16, {3, 2});
63   OperandType type11(Type::TENSOR_FLOAT16, {3});
64   OperandType type2(Type::TENSOR_INT32, {1});
65   OperandType type3(Type::BOOL, {});
66   // Phase 1, operands
67   auto input0 = model->addOperand(&type10);
68   auto param = model->addOperand(&type2);
69   auto param1 = model->addOperand(&type3);
70   auto output0 = model->addOperand(&type11);
71   // Phase 2, operations
72   static int32_t param_init[] = {-1};
73   model->setOperandValue(param, param_init, sizeof(int32_t) * 1);
74   static bool8 param1_init[] = {false};
75   model->setOperandValue(param1, param1_init, sizeof(bool8) * 1);
76   model->addOperation(ANEURALNETWORKS_REDUCE_SUM, {input0, param, param1}, {output0});
77   // Phase 3, inputs and outputs
78   model->identifyInputsAndOutputs(
79     {input0},
80     {output0});
81   assert(model->isValid());
82 }
83 
is_ignored_float16(int i)84 inline bool is_ignored_float16(int i) {
85   static std::set<int> ignore = {};
86   return ignore.find(i) != ignore.end();
87 }
88 
CreateModel_dynamic_output_shape(Model * model)89 void CreateModel_dynamic_output_shape(Model *model) {
90   OperandType type0(Type::TENSOR_FLOAT32, {3, 2});
91   OperandType type12(Type::TENSOR_FLOAT32, {0});
92   OperandType type2(Type::TENSOR_INT32, {1});
93   OperandType type3(Type::BOOL, {});
94   // Phase 1, operands
95   auto input0 = model->addOperand(&type0);
96   auto param = model->addOperand(&type2);
97   auto param1 = model->addOperand(&type3);
98   auto output0 = model->addOperand(&type12);
99   // Phase 2, operations
100   static int32_t param_init[] = {-1};
101   model->setOperandValue(param, param_init, sizeof(int32_t) * 1);
102   static bool8 param1_init[] = {false};
103   model->setOperandValue(param1, param1_init, sizeof(bool8) * 1);
104   model->addOperation(ANEURALNETWORKS_REDUCE_SUM, {input0, param, param1}, {output0});
105   // Phase 3, inputs and outputs
106   model->identifyInputsAndOutputs(
107     {input0},
108     {output0});
109   assert(model->isValid());
110 }
111 
is_ignored_dynamic_output_shape(int i)112 inline bool is_ignored_dynamic_output_shape(int i) {
113   static std::set<int> ignore = {};
114   return ignore.find(i) != ignore.end();
115 }
116 
CreateModel_dynamic_output_shape_relaxed(Model * model)117 void CreateModel_dynamic_output_shape_relaxed(Model *model) {
118   OperandType type0(Type::TENSOR_FLOAT32, {3, 2});
119   OperandType type12(Type::TENSOR_FLOAT32, {0});
120   OperandType type2(Type::TENSOR_INT32, {1});
121   OperandType type3(Type::BOOL, {});
122   // Phase 1, operands
123   auto input0 = model->addOperand(&type0);
124   auto param = model->addOperand(&type2);
125   auto param1 = model->addOperand(&type3);
126   auto output0 = model->addOperand(&type12);
127   // Phase 2, operations
128   static int32_t param_init[] = {-1};
129   model->setOperandValue(param, param_init, sizeof(int32_t) * 1);
130   static bool8 param1_init[] = {false};
131   model->setOperandValue(param1, param1_init, sizeof(bool8) * 1);
132   model->addOperation(ANEURALNETWORKS_REDUCE_SUM, {input0, param, param1}, {output0});
133   // Phase 3, inputs and outputs
134   model->identifyInputsAndOutputs(
135     {input0},
136     {output0});
137   // Phase 4: set relaxed execution
138   model->relaxComputationFloat32toFloat16(true);
139   assert(model->isValid());
140 }
141 
is_ignored_dynamic_output_shape_relaxed(int i)142 inline bool is_ignored_dynamic_output_shape_relaxed(int i) {
143   static std::set<int> ignore = {};
144   return ignore.find(i) != ignore.end();
145 }
146 
CreateModel_dynamic_output_shape_float16(Model * model)147 void CreateModel_dynamic_output_shape_float16(Model *model) {
148   OperandType type10(Type::TENSOR_FLOAT16, {3, 2});
149   OperandType type13(Type::TENSOR_FLOAT16, {0});
150   OperandType type2(Type::TENSOR_INT32, {1});
151   OperandType type3(Type::BOOL, {});
152   // Phase 1, operands
153   auto input0 = model->addOperand(&type10);
154   auto param = model->addOperand(&type2);
155   auto param1 = model->addOperand(&type3);
156   auto output0 = model->addOperand(&type13);
157   // Phase 2, operations
158   static int32_t param_init[] = {-1};
159   model->setOperandValue(param, param_init, sizeof(int32_t) * 1);
160   static bool8 param1_init[] = {false};
161   model->setOperandValue(param1, param1_init, sizeof(bool8) * 1);
162   model->addOperation(ANEURALNETWORKS_REDUCE_SUM, {input0, param, param1}, {output0});
163   // Phase 3, inputs and outputs
164   model->identifyInputsAndOutputs(
165     {input0},
166     {output0});
167   assert(model->isValid());
168 }
169 
is_ignored_dynamic_output_shape_float16(int i)170 inline bool is_ignored_dynamic_output_shape_float16(int i) {
171   static std::set<int> ignore = {};
172   return ignore.find(i) != ignore.end();
173 }
174 
CreateModel_2(Model * model)175 void CreateModel_2(Model *model) {
176   OperandType type2(Type::TENSOR_INT32, {1});
177   OperandType type3(Type::BOOL, {});
178   OperandType type4(Type::TENSOR_FLOAT32, {1});
179   // Phase 1, operands
180   auto input01 = model->addOperand(&type4);
181   auto param2 = model->addOperand(&type2);
182   auto param3 = model->addOperand(&type3);
183   auto output01 = model->addOperand(&type4);
184   // Phase 2, operations
185   static int32_t param2_init[] = {0};
186   model->setOperandValue(param2, param2_init, sizeof(int32_t) * 1);
187   static bool8 param3_init[] = {true};
188   model->setOperandValue(param3, param3_init, sizeof(bool8) * 1);
189   model->addOperation(ANEURALNETWORKS_REDUCE_SUM, {input01, param2, param3}, {output01});
190   // Phase 3, inputs and outputs
191   model->identifyInputsAndOutputs(
192     {input01},
193     {output01});
194   assert(model->isValid());
195 }
196 
is_ignored_2(int i)197 inline bool is_ignored_2(int i) {
198   static std::set<int> ignore = {};
199   return ignore.find(i) != ignore.end();
200 }
201 
CreateModel_relaxed_2(Model * model)202 void CreateModel_relaxed_2(Model *model) {
203   OperandType type2(Type::TENSOR_INT32, {1});
204   OperandType type3(Type::BOOL, {});
205   OperandType type4(Type::TENSOR_FLOAT32, {1});
206   // Phase 1, operands
207   auto input01 = model->addOperand(&type4);
208   auto param2 = model->addOperand(&type2);
209   auto param3 = model->addOperand(&type3);
210   auto output01 = model->addOperand(&type4);
211   // Phase 2, operations
212   static int32_t param2_init[] = {0};
213   model->setOperandValue(param2, param2_init, sizeof(int32_t) * 1);
214   static bool8 param3_init[] = {true};
215   model->setOperandValue(param3, param3_init, sizeof(bool8) * 1);
216   model->addOperation(ANEURALNETWORKS_REDUCE_SUM, {input01, param2, param3}, {output01});
217   // Phase 3, inputs and outputs
218   model->identifyInputsAndOutputs(
219     {input01},
220     {output01});
221   // Phase 4: set relaxed execution
222   model->relaxComputationFloat32toFloat16(true);
223   assert(model->isValid());
224 }
225 
is_ignored_relaxed_2(int i)226 inline bool is_ignored_relaxed_2(int i) {
227   static std::set<int> ignore = {};
228   return ignore.find(i) != ignore.end();
229 }
230 
CreateModel_float16_2(Model * model)231 void CreateModel_float16_2(Model *model) {
232   OperandType type14(Type::TENSOR_FLOAT16, {1});
233   OperandType type2(Type::TENSOR_INT32, {1});
234   OperandType type3(Type::BOOL, {});
235   // Phase 1, operands
236   auto input01 = model->addOperand(&type14);
237   auto param2 = model->addOperand(&type2);
238   auto param3 = model->addOperand(&type3);
239   auto output01 = model->addOperand(&type14);
240   // Phase 2, operations
241   static int32_t param2_init[] = {0};
242   model->setOperandValue(param2, param2_init, sizeof(int32_t) * 1);
243   static bool8 param3_init[] = {true};
244   model->setOperandValue(param3, param3_init, sizeof(bool8) * 1);
245   model->addOperation(ANEURALNETWORKS_REDUCE_SUM, {input01, param2, param3}, {output01});
246   // Phase 3, inputs and outputs
247   model->identifyInputsAndOutputs(
248     {input01},
249     {output01});
250   assert(model->isValid());
251 }
252 
is_ignored_float16_2(int i)253 inline bool is_ignored_float16_2(int i) {
254   static std::set<int> ignore = {};
255   return ignore.find(i) != ignore.end();
256 }
257 
CreateModel_dynamic_output_shape_2(Model * model)258 void CreateModel_dynamic_output_shape_2(Model *model) {
259   OperandType type12(Type::TENSOR_FLOAT32, {0});
260   OperandType type2(Type::TENSOR_INT32, {1});
261   OperandType type3(Type::BOOL, {});
262   OperandType type4(Type::TENSOR_FLOAT32, {1});
263   // Phase 1, operands
264   auto input01 = model->addOperand(&type4);
265   auto param2 = model->addOperand(&type2);
266   auto param3 = model->addOperand(&type3);
267   auto output01 = model->addOperand(&type12);
268   // Phase 2, operations
269   static int32_t param2_init[] = {0};
270   model->setOperandValue(param2, param2_init, sizeof(int32_t) * 1);
271   static bool8 param3_init[] = {true};
272   model->setOperandValue(param3, param3_init, sizeof(bool8) * 1);
273   model->addOperation(ANEURALNETWORKS_REDUCE_SUM, {input01, param2, param3}, {output01});
274   // Phase 3, inputs and outputs
275   model->identifyInputsAndOutputs(
276     {input01},
277     {output01});
278   assert(model->isValid());
279 }
280 
is_ignored_dynamic_output_shape_2(int i)281 inline bool is_ignored_dynamic_output_shape_2(int i) {
282   static std::set<int> ignore = {};
283   return ignore.find(i) != ignore.end();
284 }
285 
CreateModel_dynamic_output_shape_relaxed_2(Model * model)286 void CreateModel_dynamic_output_shape_relaxed_2(Model *model) {
287   OperandType type12(Type::TENSOR_FLOAT32, {0});
288   OperandType type2(Type::TENSOR_INT32, {1});
289   OperandType type3(Type::BOOL, {});
290   OperandType type4(Type::TENSOR_FLOAT32, {1});
291   // Phase 1, operands
292   auto input01 = model->addOperand(&type4);
293   auto param2 = model->addOperand(&type2);
294   auto param3 = model->addOperand(&type3);
295   auto output01 = model->addOperand(&type12);
296   // Phase 2, operations
297   static int32_t param2_init[] = {0};
298   model->setOperandValue(param2, param2_init, sizeof(int32_t) * 1);
299   static bool8 param3_init[] = {true};
300   model->setOperandValue(param3, param3_init, sizeof(bool8) * 1);
301   model->addOperation(ANEURALNETWORKS_REDUCE_SUM, {input01, param2, param3}, {output01});
302   // Phase 3, inputs and outputs
303   model->identifyInputsAndOutputs(
304     {input01},
305     {output01});
306   // Phase 4: set relaxed execution
307   model->relaxComputationFloat32toFloat16(true);
308   assert(model->isValid());
309 }
310 
is_ignored_dynamic_output_shape_relaxed_2(int i)311 inline bool is_ignored_dynamic_output_shape_relaxed_2(int i) {
312   static std::set<int> ignore = {};
313   return ignore.find(i) != ignore.end();
314 }
315 
CreateModel_dynamic_output_shape_float16_2(Model * model)316 void CreateModel_dynamic_output_shape_float16_2(Model *model) {
317   OperandType type13(Type::TENSOR_FLOAT16, {0});
318   OperandType type14(Type::TENSOR_FLOAT16, {1});
319   OperandType type2(Type::TENSOR_INT32, {1});
320   OperandType type3(Type::BOOL, {});
321   // Phase 1, operands
322   auto input01 = model->addOperand(&type14);
323   auto param2 = model->addOperand(&type2);
324   auto param3 = model->addOperand(&type3);
325   auto output01 = model->addOperand(&type13);
326   // Phase 2, operations
327   static int32_t param2_init[] = {0};
328   model->setOperandValue(param2, param2_init, sizeof(int32_t) * 1);
329   static bool8 param3_init[] = {true};
330   model->setOperandValue(param3, param3_init, sizeof(bool8) * 1);
331   model->addOperation(ANEURALNETWORKS_REDUCE_SUM, {input01, param2, param3}, {output01});
332   // Phase 3, inputs and outputs
333   model->identifyInputsAndOutputs(
334     {input01},
335     {output01});
336   assert(model->isValid());
337 }
338 
is_ignored_dynamic_output_shape_float16_2(int i)339 inline bool is_ignored_dynamic_output_shape_float16_2(int i) {
340   static std::set<int> ignore = {};
341   return ignore.find(i) != ignore.end();
342 }
343 
CreateModel_3(Model * model)344 void CreateModel_3(Model *model) {
345   OperandType type3(Type::BOOL, {});
346   OperandType type5(Type::TENSOR_FLOAT32, {4, 3, 2});
347   OperandType type6(Type::TENSOR_FLOAT32, {2});
348   OperandType type7(Type::TENSOR_INT32, {4});
349   // Phase 1, operands
350   auto input02 = model->addOperand(&type5);
351   auto param4 = model->addOperand(&type7);
352   auto param5 = model->addOperand(&type3);
353   auto output02 = model->addOperand(&type6);
354   // Phase 2, operations
355   static int32_t param4_init[] = {1, 0, -3, -3};
356   model->setOperandValue(param4, param4_init, sizeof(int32_t) * 4);
357   static bool8 param5_init[] = {false};
358   model->setOperandValue(param5, param5_init, sizeof(bool8) * 1);
359   model->addOperation(ANEURALNETWORKS_REDUCE_SUM, {input02, param4, param5}, {output02});
360   // Phase 3, inputs and outputs
361   model->identifyInputsAndOutputs(
362     {input02},
363     {output02});
364   assert(model->isValid());
365 }
366 
is_ignored_3(int i)367 inline bool is_ignored_3(int i) {
368   static std::set<int> ignore = {};
369   return ignore.find(i) != ignore.end();
370 }
371 
CreateModel_relaxed_3(Model * model)372 void CreateModel_relaxed_3(Model *model) {
373   OperandType type3(Type::BOOL, {});
374   OperandType type5(Type::TENSOR_FLOAT32, {4, 3, 2});
375   OperandType type6(Type::TENSOR_FLOAT32, {2});
376   OperandType type7(Type::TENSOR_INT32, {4});
377   // Phase 1, operands
378   auto input02 = model->addOperand(&type5);
379   auto param4 = model->addOperand(&type7);
380   auto param5 = model->addOperand(&type3);
381   auto output02 = model->addOperand(&type6);
382   // Phase 2, operations
383   static int32_t param4_init[] = {1, 0, -3, -3};
384   model->setOperandValue(param4, param4_init, sizeof(int32_t) * 4);
385   static bool8 param5_init[] = {false};
386   model->setOperandValue(param5, param5_init, sizeof(bool8) * 1);
387   model->addOperation(ANEURALNETWORKS_REDUCE_SUM, {input02, param4, param5}, {output02});
388   // Phase 3, inputs and outputs
389   model->identifyInputsAndOutputs(
390     {input02},
391     {output02});
392   // Phase 4: set relaxed execution
393   model->relaxComputationFloat32toFloat16(true);
394   assert(model->isValid());
395 }
396 
is_ignored_relaxed_3(int i)397 inline bool is_ignored_relaxed_3(int i) {
398   static std::set<int> ignore = {};
399   return ignore.find(i) != ignore.end();
400 }
401 
CreateModel_float16_3(Model * model)402 void CreateModel_float16_3(Model *model) {
403   OperandType type15(Type::TENSOR_FLOAT16, {4, 3, 2});
404   OperandType type16(Type::TENSOR_FLOAT16, {2});
405   OperandType type3(Type::BOOL, {});
406   OperandType type7(Type::TENSOR_INT32, {4});
407   // Phase 1, operands
408   auto input02 = model->addOperand(&type15);
409   auto param4 = model->addOperand(&type7);
410   auto param5 = model->addOperand(&type3);
411   auto output02 = model->addOperand(&type16);
412   // Phase 2, operations
413   static int32_t param4_init[] = {1, 0, -3, -3};
414   model->setOperandValue(param4, param4_init, sizeof(int32_t) * 4);
415   static bool8 param5_init[] = {false};
416   model->setOperandValue(param5, param5_init, sizeof(bool8) * 1);
417   model->addOperation(ANEURALNETWORKS_REDUCE_SUM, {input02, param4, param5}, {output02});
418   // Phase 3, inputs and outputs
419   model->identifyInputsAndOutputs(
420     {input02},
421     {output02});
422   assert(model->isValid());
423 }
424 
is_ignored_float16_3(int i)425 inline bool is_ignored_float16_3(int i) {
426   static std::set<int> ignore = {};
427   return ignore.find(i) != ignore.end();
428 }
429 
CreateModel_dynamic_output_shape_3(Model * model)430 void CreateModel_dynamic_output_shape_3(Model *model) {
431   OperandType type12(Type::TENSOR_FLOAT32, {0});
432   OperandType type3(Type::BOOL, {});
433   OperandType type5(Type::TENSOR_FLOAT32, {4, 3, 2});
434   OperandType type7(Type::TENSOR_INT32, {4});
435   // Phase 1, operands
436   auto input02 = model->addOperand(&type5);
437   auto param4 = model->addOperand(&type7);
438   auto param5 = model->addOperand(&type3);
439   auto output02 = model->addOperand(&type12);
440   // Phase 2, operations
441   static int32_t param4_init[] = {1, 0, -3, -3};
442   model->setOperandValue(param4, param4_init, sizeof(int32_t) * 4);
443   static bool8 param5_init[] = {false};
444   model->setOperandValue(param5, param5_init, sizeof(bool8) * 1);
445   model->addOperation(ANEURALNETWORKS_REDUCE_SUM, {input02, param4, param5}, {output02});
446   // Phase 3, inputs and outputs
447   model->identifyInputsAndOutputs(
448     {input02},
449     {output02});
450   assert(model->isValid());
451 }
452 
is_ignored_dynamic_output_shape_3(int i)453 inline bool is_ignored_dynamic_output_shape_3(int i) {
454   static std::set<int> ignore = {};
455   return ignore.find(i) != ignore.end();
456 }
457 
CreateModel_dynamic_output_shape_relaxed_3(Model * model)458 void CreateModel_dynamic_output_shape_relaxed_3(Model *model) {
459   OperandType type12(Type::TENSOR_FLOAT32, {0});
460   OperandType type3(Type::BOOL, {});
461   OperandType type5(Type::TENSOR_FLOAT32, {4, 3, 2});
462   OperandType type7(Type::TENSOR_INT32, {4});
463   // Phase 1, operands
464   auto input02 = model->addOperand(&type5);
465   auto param4 = model->addOperand(&type7);
466   auto param5 = model->addOperand(&type3);
467   auto output02 = model->addOperand(&type12);
468   // Phase 2, operations
469   static int32_t param4_init[] = {1, 0, -3, -3};
470   model->setOperandValue(param4, param4_init, sizeof(int32_t) * 4);
471   static bool8 param5_init[] = {false};
472   model->setOperandValue(param5, param5_init, sizeof(bool8) * 1);
473   model->addOperation(ANEURALNETWORKS_REDUCE_SUM, {input02, param4, param5}, {output02});
474   // Phase 3, inputs and outputs
475   model->identifyInputsAndOutputs(
476     {input02},
477     {output02});
478   // Phase 4: set relaxed execution
479   model->relaxComputationFloat32toFloat16(true);
480   assert(model->isValid());
481 }
482 
is_ignored_dynamic_output_shape_relaxed_3(int i)483 inline bool is_ignored_dynamic_output_shape_relaxed_3(int i) {
484   static std::set<int> ignore = {};
485   return ignore.find(i) != ignore.end();
486 }
487 
CreateModel_dynamic_output_shape_float16_3(Model * model)488 void CreateModel_dynamic_output_shape_float16_3(Model *model) {
489   OperandType type13(Type::TENSOR_FLOAT16, {0});
490   OperandType type15(Type::TENSOR_FLOAT16, {4, 3, 2});
491   OperandType type3(Type::BOOL, {});
492   OperandType type7(Type::TENSOR_INT32, {4});
493   // Phase 1, operands
494   auto input02 = model->addOperand(&type15);
495   auto param4 = model->addOperand(&type7);
496   auto param5 = model->addOperand(&type3);
497   auto output02 = model->addOperand(&type13);
498   // Phase 2, operations
499   static int32_t param4_init[] = {1, 0, -3, -3};
500   model->setOperandValue(param4, param4_init, sizeof(int32_t) * 4);
501   static bool8 param5_init[] = {false};
502   model->setOperandValue(param5, param5_init, sizeof(bool8) * 1);
503   model->addOperation(ANEURALNETWORKS_REDUCE_SUM, {input02, param4, param5}, {output02});
504   // Phase 3, inputs and outputs
505   model->identifyInputsAndOutputs(
506     {input02},
507     {output02});
508   assert(model->isValid());
509 }
510 
is_ignored_dynamic_output_shape_float16_3(int i)511 inline bool is_ignored_dynamic_output_shape_float16_3(int i) {
512   static std::set<int> ignore = {};
513   return ignore.find(i) != ignore.end();
514 }
515 
CreateModel_4(Model * model)516 void CreateModel_4(Model *model) {
517   OperandType type3(Type::BOOL, {});
518   OperandType type5(Type::TENSOR_FLOAT32, {4, 3, 2});
519   OperandType type8(Type::TENSOR_FLOAT32, {1, 3, 1});
520   OperandType type9(Type::TENSOR_INT32, {2});
521   // Phase 1, operands
522   auto input03 = model->addOperand(&type5);
523   auto param6 = model->addOperand(&type9);
524   auto param7 = model->addOperand(&type3);
525   auto output03 = model->addOperand(&type8);
526   // Phase 2, operations
527   static int32_t param6_init[] = {0, 2};
528   model->setOperandValue(param6, param6_init, sizeof(int32_t) * 2);
529   static bool8 param7_init[] = {true};
530   model->setOperandValue(param7, param7_init, sizeof(bool8) * 1);
531   model->addOperation(ANEURALNETWORKS_REDUCE_SUM, {input03, param6, param7}, {output03});
532   // Phase 3, inputs and outputs
533   model->identifyInputsAndOutputs(
534     {input03},
535     {output03});
536   assert(model->isValid());
537 }
538 
is_ignored_4(int i)539 inline bool is_ignored_4(int i) {
540   static std::set<int> ignore = {};
541   return ignore.find(i) != ignore.end();
542 }
543 
CreateModel_relaxed_4(Model * model)544 void CreateModel_relaxed_4(Model *model) {
545   OperandType type3(Type::BOOL, {});
546   OperandType type5(Type::TENSOR_FLOAT32, {4, 3, 2});
547   OperandType type8(Type::TENSOR_FLOAT32, {1, 3, 1});
548   OperandType type9(Type::TENSOR_INT32, {2});
549   // Phase 1, operands
550   auto input03 = model->addOperand(&type5);
551   auto param6 = model->addOperand(&type9);
552   auto param7 = model->addOperand(&type3);
553   auto output03 = model->addOperand(&type8);
554   // Phase 2, operations
555   static int32_t param6_init[] = {0, 2};
556   model->setOperandValue(param6, param6_init, sizeof(int32_t) * 2);
557   static bool8 param7_init[] = {true};
558   model->setOperandValue(param7, param7_init, sizeof(bool8) * 1);
559   model->addOperation(ANEURALNETWORKS_REDUCE_SUM, {input03, param6, param7}, {output03});
560   // Phase 3, inputs and outputs
561   model->identifyInputsAndOutputs(
562     {input03},
563     {output03});
564   // Phase 4: set relaxed execution
565   model->relaxComputationFloat32toFloat16(true);
566   assert(model->isValid());
567 }
568 
is_ignored_relaxed_4(int i)569 inline bool is_ignored_relaxed_4(int i) {
570   static std::set<int> ignore = {};
571   return ignore.find(i) != ignore.end();
572 }
573 
CreateModel_float16_4(Model * model)574 void CreateModel_float16_4(Model *model) {
575   OperandType type15(Type::TENSOR_FLOAT16, {4, 3, 2});
576   OperandType type17(Type::TENSOR_FLOAT16, {1, 3, 1});
577   OperandType type3(Type::BOOL, {});
578   OperandType type9(Type::TENSOR_INT32, {2});
579   // Phase 1, operands
580   auto input03 = model->addOperand(&type15);
581   auto param6 = model->addOperand(&type9);
582   auto param7 = model->addOperand(&type3);
583   auto output03 = model->addOperand(&type17);
584   // Phase 2, operations
585   static int32_t param6_init[] = {0, 2};
586   model->setOperandValue(param6, param6_init, sizeof(int32_t) * 2);
587   static bool8 param7_init[] = {true};
588   model->setOperandValue(param7, param7_init, sizeof(bool8) * 1);
589   model->addOperation(ANEURALNETWORKS_REDUCE_SUM, {input03, param6, param7}, {output03});
590   // Phase 3, inputs and outputs
591   model->identifyInputsAndOutputs(
592     {input03},
593     {output03});
594   assert(model->isValid());
595 }
596 
is_ignored_float16_4(int i)597 inline bool is_ignored_float16_4(int i) {
598   static std::set<int> ignore = {};
599   return ignore.find(i) != ignore.end();
600 }
601 
CreateModel_dynamic_output_shape_4(Model * model)602 void CreateModel_dynamic_output_shape_4(Model *model) {
603   OperandType type18(Type::TENSOR_FLOAT32, {0, 0, 0});
604   OperandType type3(Type::BOOL, {});
605   OperandType type5(Type::TENSOR_FLOAT32, {4, 3, 2});
606   OperandType type9(Type::TENSOR_INT32, {2});
607   // Phase 1, operands
608   auto input03 = model->addOperand(&type5);
609   auto param6 = model->addOperand(&type9);
610   auto param7 = model->addOperand(&type3);
611   auto output03 = model->addOperand(&type18);
612   // Phase 2, operations
613   static int32_t param6_init[] = {0, 2};
614   model->setOperandValue(param6, param6_init, sizeof(int32_t) * 2);
615   static bool8 param7_init[] = {true};
616   model->setOperandValue(param7, param7_init, sizeof(bool8) * 1);
617   model->addOperation(ANEURALNETWORKS_REDUCE_SUM, {input03, param6, param7}, {output03});
618   // Phase 3, inputs and outputs
619   model->identifyInputsAndOutputs(
620     {input03},
621     {output03});
622   assert(model->isValid());
623 }
624 
is_ignored_dynamic_output_shape_4(int i)625 inline bool is_ignored_dynamic_output_shape_4(int i) {
626   static std::set<int> ignore = {};
627   return ignore.find(i) != ignore.end();
628 }
629 
CreateModel_dynamic_output_shape_relaxed_4(Model * model)630 void CreateModel_dynamic_output_shape_relaxed_4(Model *model) {
631   OperandType type18(Type::TENSOR_FLOAT32, {0, 0, 0});
632   OperandType type3(Type::BOOL, {});
633   OperandType type5(Type::TENSOR_FLOAT32, {4, 3, 2});
634   OperandType type9(Type::TENSOR_INT32, {2});
635   // Phase 1, operands
636   auto input03 = model->addOperand(&type5);
637   auto param6 = model->addOperand(&type9);
638   auto param7 = model->addOperand(&type3);
639   auto output03 = model->addOperand(&type18);
640   // Phase 2, operations
641   static int32_t param6_init[] = {0, 2};
642   model->setOperandValue(param6, param6_init, sizeof(int32_t) * 2);
643   static bool8 param7_init[] = {true};
644   model->setOperandValue(param7, param7_init, sizeof(bool8) * 1);
645   model->addOperation(ANEURALNETWORKS_REDUCE_SUM, {input03, param6, param7}, {output03});
646   // Phase 3, inputs and outputs
647   model->identifyInputsAndOutputs(
648     {input03},
649     {output03});
650   // Phase 4: set relaxed execution
651   model->relaxComputationFloat32toFloat16(true);
652   assert(model->isValid());
653 }
654 
is_ignored_dynamic_output_shape_relaxed_4(int i)655 inline bool is_ignored_dynamic_output_shape_relaxed_4(int i) {
656   static std::set<int> ignore = {};
657   return ignore.find(i) != ignore.end();
658 }
659 
CreateModel_dynamic_output_shape_float16_4(Model * model)660 void CreateModel_dynamic_output_shape_float16_4(Model *model) {
661   OperandType type15(Type::TENSOR_FLOAT16, {4, 3, 2});
662   OperandType type19(Type::TENSOR_FLOAT16, {0, 0, 0});
663   OperandType type3(Type::BOOL, {});
664   OperandType type9(Type::TENSOR_INT32, {2});
665   // Phase 1, operands
666   auto input03 = model->addOperand(&type15);
667   auto param6 = model->addOperand(&type9);
668   auto param7 = model->addOperand(&type3);
669   auto output03 = model->addOperand(&type19);
670   // Phase 2, operations
671   static int32_t param6_init[] = {0, 2};
672   model->setOperandValue(param6, param6_init, sizeof(int32_t) * 2);
673   static bool8 param7_init[] = {true};
674   model->setOperandValue(param7, param7_init, sizeof(bool8) * 1);
675   model->addOperation(ANEURALNETWORKS_REDUCE_SUM, {input03, param6, param7}, {output03});
676   // Phase 3, inputs and outputs
677   model->identifyInputsAndOutputs(
678     {input03},
679     {output03});
680   assert(model->isValid());
681 }
682 
is_ignored_dynamic_output_shape_float16_4(int i)683 inline bool is_ignored_dynamic_output_shape_float16_4(int i) {
684   static std::set<int> ignore = {};
685   return ignore.find(i) != ignore.end();
686 }
687 
688