xref: /aosp_15_r20/external/XNNPACK/test/qu8-avgpool-minmax.cc (revision 4bdc94577ba0e567308109d787f7fec7b531ce36)
1*4bdc9457SAndroid Build Coastguard Worker // Copyright (c) Facebook, Inc. and its affiliates.
2*4bdc9457SAndroid Build Coastguard Worker // All rights reserved.
3*4bdc9457SAndroid Build Coastguard Worker //
4*4bdc9457SAndroid Build Coastguard Worker // Copyright 2020 Google LLC
5*4bdc9457SAndroid Build Coastguard Worker //
6*4bdc9457SAndroid Build Coastguard Worker // This source code is licensed under the BSD-style license found in the
7*4bdc9457SAndroid Build Coastguard Worker // LICENSE file in the root directory of this source tree.
8*4bdc9457SAndroid Build Coastguard Worker //
9*4bdc9457SAndroid Build Coastguard Worker // Auto-generated file. Do not edit!
10*4bdc9457SAndroid Build Coastguard Worker //   Specification: test/qu8-avgpool-minmax.yaml
11*4bdc9457SAndroid Build Coastguard Worker //   Generator: tools/generate-avgpool-test.py
12*4bdc9457SAndroid Build Coastguard Worker 
13*4bdc9457SAndroid Build Coastguard Worker 
14*4bdc9457SAndroid Build Coastguard Worker #include <gtest/gtest.h>
15*4bdc9457SAndroid Build Coastguard Worker 
16*4bdc9457SAndroid Build Coastguard Worker #include <xnnpack/common.h>
17*4bdc9457SAndroid Build Coastguard Worker #include <xnnpack/isa-checks.h>
18*4bdc9457SAndroid Build Coastguard Worker 
19*4bdc9457SAndroid Build Coastguard Worker #include <xnnpack/avgpool.h>
20*4bdc9457SAndroid Build Coastguard Worker #include <xnnpack/pavgpool.h>
21*4bdc9457SAndroid Build Coastguard Worker #include "avgpool-microkernel-tester.h"
22*4bdc9457SAndroid Build Coastguard Worker 
23*4bdc9457SAndroid Build Coastguard Worker 
24*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_eq_8_twopass_fulltile)25*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_eq_8_twopass_fulltile) {
26*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
27*4bdc9457SAndroid Build Coastguard Worker     AvgPoolMicrokernelTester()
28*4bdc9457SAndroid Build Coastguard Worker       .pooling_elements(17)
29*4bdc9457SAndroid Build Coastguard Worker       .pooling_tile(9, 8)
30*4bdc9457SAndroid Build Coastguard Worker       .channels(8)
31*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
32*4bdc9457SAndroid Build Coastguard Worker   }
33*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_eq_8_twopass_fulltile_with_input_offset)34*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_eq_8_twopass_fulltile_with_input_offset) {
35*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
36*4bdc9457SAndroid Build Coastguard Worker     AvgPoolMicrokernelTester()
37*4bdc9457SAndroid Build Coastguard Worker       .pooling_elements(17)
38*4bdc9457SAndroid Build Coastguard Worker       .pooling_tile(9, 8)
39*4bdc9457SAndroid Build Coastguard Worker       .channels(8)
40*4bdc9457SAndroid Build Coastguard Worker       .input_offset(11)
41*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
42*4bdc9457SAndroid Build Coastguard Worker   }
43*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_eq_8_twopass_fulltile_with_zero)44*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_eq_8_twopass_fulltile_with_zero) {
45*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
46*4bdc9457SAndroid Build Coastguard Worker     for (size_t zero_index = 0; zero_index < 17; zero_index++) {
47*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
48*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(17)
49*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
50*4bdc9457SAndroid Build Coastguard Worker         .channels(8)
51*4bdc9457SAndroid Build Coastguard Worker         .input_offset(11)
52*4bdc9457SAndroid Build Coastguard Worker         .zero_index(zero_index)
53*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
54*4bdc9457SAndroid Build Coastguard Worker     }
55*4bdc9457SAndroid Build Coastguard Worker   }
56*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_eq_8_twopass_fulltile_with_input_scale)57*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_eq_8_twopass_fulltile_with_input_scale) {
58*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
59*4bdc9457SAndroid Build Coastguard Worker     for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
60*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
61*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(17)
62*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
63*4bdc9457SAndroid Build Coastguard Worker         .channels(8)
64*4bdc9457SAndroid Build Coastguard Worker         .input_scale(scale)
65*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
66*4bdc9457SAndroid Build Coastguard Worker     }
67*4bdc9457SAndroid Build Coastguard Worker   }
68*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_eq_8_twopass_fulltile_with_input_zero_point)69*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_eq_8_twopass_fulltile_with_input_zero_point) {
70*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
71*4bdc9457SAndroid Build Coastguard Worker     for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
72*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
73*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(17)
74*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
75*4bdc9457SAndroid Build Coastguard Worker         .channels(8)
76*4bdc9457SAndroid Build Coastguard Worker         .input_zero_point(zero_point)
77*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
78*4bdc9457SAndroid Build Coastguard Worker     }
79*4bdc9457SAndroid Build Coastguard Worker   }
80*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_eq_8_twopass_fulltile_with_output_scale)81*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_eq_8_twopass_fulltile_with_output_scale) {
82*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
83*4bdc9457SAndroid Build Coastguard Worker     for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
84*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
85*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(17)
86*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
87*4bdc9457SAndroid Build Coastguard Worker         .channels(8)
88*4bdc9457SAndroid Build Coastguard Worker         .output_scale(scale)
89*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
90*4bdc9457SAndroid Build Coastguard Worker     }
91*4bdc9457SAndroid Build Coastguard Worker   }
92*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_eq_8_twopass_fulltile_with_output_zero_point)93*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_eq_8_twopass_fulltile_with_output_zero_point) {
94*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
95*4bdc9457SAndroid Build Coastguard Worker     for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
96*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
97*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(17)
98*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
99*4bdc9457SAndroid Build Coastguard Worker         .channels(8)
100*4bdc9457SAndroid Build Coastguard Worker         .output_zero_point(zero_point)
101*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
102*4bdc9457SAndroid Build Coastguard Worker     }
103*4bdc9457SAndroid Build Coastguard Worker   }
104*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_eq_8_twopass_fulltile_with_qmin)105*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_eq_8_twopass_fulltile_with_qmin) {
106*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
107*4bdc9457SAndroid Build Coastguard Worker     AvgPoolMicrokernelTester()
108*4bdc9457SAndroid Build Coastguard Worker       .pooling_elements(17)
109*4bdc9457SAndroid Build Coastguard Worker       .pooling_tile(9, 8)
110*4bdc9457SAndroid Build Coastguard Worker       .channels(8)
111*4bdc9457SAndroid Build Coastguard Worker       .qmin(128)
112*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
113*4bdc9457SAndroid Build Coastguard Worker   }
114*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_eq_8_twopass_fulltile_with_qmax)115*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_eq_8_twopass_fulltile_with_qmax) {
116*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
117*4bdc9457SAndroid Build Coastguard Worker     AvgPoolMicrokernelTester()
118*4bdc9457SAndroid Build Coastguard Worker       .pooling_elements(17)
119*4bdc9457SAndroid Build Coastguard Worker       .pooling_tile(9, 8)
120*4bdc9457SAndroid Build Coastguard Worker       .channels(8)
121*4bdc9457SAndroid Build Coastguard Worker       .qmax(128)
122*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
123*4bdc9457SAndroid Build Coastguard Worker   }
124*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_eq_8_twopass_subtile)125*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_eq_8_twopass_subtile) {
126*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
127*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
128*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
129*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(pooling_elements)
130*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
131*4bdc9457SAndroid Build Coastguard Worker         .channels(8)
132*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
133*4bdc9457SAndroid Build Coastguard Worker     }
134*4bdc9457SAndroid Build Coastguard Worker   }
135*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_eq_8_twopass_subtile_with_input_offset)136*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_eq_8_twopass_subtile_with_input_offset) {
137*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
138*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
139*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
140*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(pooling_elements)
141*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
142*4bdc9457SAndroid Build Coastguard Worker         .channels(8)
143*4bdc9457SAndroid Build Coastguard Worker         .input_offset(11)
144*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
145*4bdc9457SAndroid Build Coastguard Worker     }
146*4bdc9457SAndroid Build Coastguard Worker   }
147*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_eq_8_twopass_subtile_with_zero)148*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_eq_8_twopass_subtile_with_zero) {
149*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
150*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
151*4bdc9457SAndroid Build Coastguard Worker       for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
152*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
153*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
154*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
155*4bdc9457SAndroid Build Coastguard Worker           .channels(8)
156*4bdc9457SAndroid Build Coastguard Worker           .input_offset(11)
157*4bdc9457SAndroid Build Coastguard Worker           .zero_index(zero_index)
158*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
159*4bdc9457SAndroid Build Coastguard Worker       }
160*4bdc9457SAndroid Build Coastguard Worker     }
161*4bdc9457SAndroid Build Coastguard Worker   }
162*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_div_8_twopass_fulltile)163*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_div_8_twopass_fulltile) {
164*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
165*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 16; channels < 64; channels += 8) {
166*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
167*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(17)
168*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
169*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
170*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
171*4bdc9457SAndroid Build Coastguard Worker     }
172*4bdc9457SAndroid Build Coastguard Worker   }
173*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_div_8_twopass_fulltile_with_input_offset)174*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_div_8_twopass_fulltile_with_input_offset) {
175*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
176*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 16; channels < 64; channels += 8) {
177*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
178*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(17)
179*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
180*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
181*4bdc9457SAndroid Build Coastguard Worker         .input_offset(41)
182*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
183*4bdc9457SAndroid Build Coastguard Worker     }
184*4bdc9457SAndroid Build Coastguard Worker   }
185*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_div_8_twopass_fulltile_with_zero)186*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_div_8_twopass_fulltile_with_zero) {
187*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
188*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 16; channels < 64; channels += 8) {
189*4bdc9457SAndroid Build Coastguard Worker       for (size_t zero_index = 0; zero_index < 17; zero_index++) {
190*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
191*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(17)
192*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
193*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
194*4bdc9457SAndroid Build Coastguard Worker           .input_offset(41)
195*4bdc9457SAndroid Build Coastguard Worker           .zero_index(zero_index)
196*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
197*4bdc9457SAndroid Build Coastguard Worker       }
198*4bdc9457SAndroid Build Coastguard Worker     }
199*4bdc9457SAndroid Build Coastguard Worker   }
200*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_div_8_twopass_fulltile_with_input_scale)201*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_div_8_twopass_fulltile_with_input_scale) {
202*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
203*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 16; channels < 64; channels += 8) {
204*4bdc9457SAndroid Build Coastguard Worker       for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
205*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
206*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(17)
207*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
208*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
209*4bdc9457SAndroid Build Coastguard Worker           .input_scale(scale)
210*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
211*4bdc9457SAndroid Build Coastguard Worker       }
212*4bdc9457SAndroid Build Coastguard Worker     }
213*4bdc9457SAndroid Build Coastguard Worker   }
214*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_div_8_twopass_fulltile_with_input_zero_point)215*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_div_8_twopass_fulltile_with_input_zero_point) {
216*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
217*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 16; channels < 64; channels += 8) {
218*4bdc9457SAndroid Build Coastguard Worker       for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
219*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
220*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(17)
221*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
222*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
223*4bdc9457SAndroid Build Coastguard Worker           .input_zero_point(zero_point)
224*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
225*4bdc9457SAndroid Build Coastguard Worker       }
226*4bdc9457SAndroid Build Coastguard Worker     }
227*4bdc9457SAndroid Build Coastguard Worker   }
228*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_div_8_twopass_fulltile_with_output_scale)229*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_div_8_twopass_fulltile_with_output_scale) {
230*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
231*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 16; channels < 64; channels += 8) {
232*4bdc9457SAndroid Build Coastguard Worker       for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
233*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
234*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(17)
235*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
236*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
237*4bdc9457SAndroid Build Coastguard Worker           .output_scale(scale)
238*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
239*4bdc9457SAndroid Build Coastguard Worker       }
240*4bdc9457SAndroid Build Coastguard Worker     }
241*4bdc9457SAndroid Build Coastguard Worker   }
242*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_div_8_twopass_fulltile_with_output_zero_point)243*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_div_8_twopass_fulltile_with_output_zero_point) {
244*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
245*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 16; channels < 64; channels += 8) {
246*4bdc9457SAndroid Build Coastguard Worker       for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
247*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
248*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(17)
249*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
250*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
251*4bdc9457SAndroid Build Coastguard Worker           .output_zero_point(zero_point)
252*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
253*4bdc9457SAndroid Build Coastguard Worker       }
254*4bdc9457SAndroid Build Coastguard Worker     }
255*4bdc9457SAndroid Build Coastguard Worker   }
256*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_div_8_twopass_fulltile_with_qmin)257*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_div_8_twopass_fulltile_with_qmin) {
258*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
259*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 16; channels < 64; channels += 8) {
260*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
261*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(17)
262*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
263*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
264*4bdc9457SAndroid Build Coastguard Worker         .qmin(128)
265*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
266*4bdc9457SAndroid Build Coastguard Worker     }
267*4bdc9457SAndroid Build Coastguard Worker   }
268*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_div_8_twopass_fulltile_with_qmax)269*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_div_8_twopass_fulltile_with_qmax) {
270*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
271*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 16; channels < 64; channels += 8) {
272*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
273*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(17)
274*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
275*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
276*4bdc9457SAndroid Build Coastguard Worker         .qmax(128)
277*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
278*4bdc9457SAndroid Build Coastguard Worker     }
279*4bdc9457SAndroid Build Coastguard Worker   }
280*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_div_8_twopass_subtile)281*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_div_8_twopass_subtile) {
282*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
283*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
284*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 16; channels < 64; channels += 8) {
285*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
286*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
287*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
288*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
289*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
290*4bdc9457SAndroid Build Coastguard Worker       }
291*4bdc9457SAndroid Build Coastguard Worker     }
292*4bdc9457SAndroid Build Coastguard Worker   }
293*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_div_8_twopass_subtile_with_input_offset)294*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_div_8_twopass_subtile_with_input_offset) {
295*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
296*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
297*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 16; channels < 64; channels += 8) {
298*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
299*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
300*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
301*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
302*4bdc9457SAndroid Build Coastguard Worker           .input_offset(67)
303*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
304*4bdc9457SAndroid Build Coastguard Worker       }
305*4bdc9457SAndroid Build Coastguard Worker     }
306*4bdc9457SAndroid Build Coastguard Worker   }
307*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_div_8_twopass_subtile_with_zero)308*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_div_8_twopass_subtile_with_zero) {
309*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
310*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
311*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 16; channels < 64; channels += 8) {
312*4bdc9457SAndroid Build Coastguard Worker         for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
313*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
314*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
315*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 8)
316*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
317*4bdc9457SAndroid Build Coastguard Worker             .input_offset(67)
318*4bdc9457SAndroid Build Coastguard Worker             .zero_index(zero_index)
319*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
320*4bdc9457SAndroid Build Coastguard Worker         }
321*4bdc9457SAndroid Build Coastguard Worker       }
322*4bdc9457SAndroid Build Coastguard Worker     }
323*4bdc9457SAndroid Build Coastguard Worker   }
324*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_lt_8_twopass_fulltile)325*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_lt_8_twopass_fulltile) {
326*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
327*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 1; channels < 8; channels++) {
328*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
329*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(17)
330*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
331*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
332*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
333*4bdc9457SAndroid Build Coastguard Worker     }
334*4bdc9457SAndroid Build Coastguard Worker   }
335*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_lt_8_twopass_fulltile_with_input_offset)336*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_lt_8_twopass_fulltile_with_input_offset) {
337*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
338*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 1; channels < 8; channels++) {
339*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
340*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(17)
341*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
342*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
343*4bdc9457SAndroid Build Coastguard Worker         .input_offset(11)
344*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
345*4bdc9457SAndroid Build Coastguard Worker     }
346*4bdc9457SAndroid Build Coastguard Worker   }
347*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_lt_8_twopass_fulltile_with_zero_index)348*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_lt_8_twopass_fulltile_with_zero_index) {
349*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
350*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 1; channels < 8; channels++) {
351*4bdc9457SAndroid Build Coastguard Worker       for (size_t zero_index = 0; zero_index < 17; zero_index++) {
352*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
353*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(17)
354*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
355*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
356*4bdc9457SAndroid Build Coastguard Worker           .input_offset(11)
357*4bdc9457SAndroid Build Coastguard Worker           .zero_index(zero_index)
358*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
359*4bdc9457SAndroid Build Coastguard Worker       }
360*4bdc9457SAndroid Build Coastguard Worker     }
361*4bdc9457SAndroid Build Coastguard Worker   }
362*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_lt_8_twopass_fulltile_with_input_scale)363*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_lt_8_twopass_fulltile_with_input_scale) {
364*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
365*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 1; channels < 8; channels++) {
366*4bdc9457SAndroid Build Coastguard Worker       for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
367*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
368*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(17)
369*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
370*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
371*4bdc9457SAndroid Build Coastguard Worker           .input_scale(scale)
372*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
373*4bdc9457SAndroid Build Coastguard Worker       }
374*4bdc9457SAndroid Build Coastguard Worker     }
375*4bdc9457SAndroid Build Coastguard Worker   }
376*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_lt_8_twopass_fulltile_with_input_zero_point)377*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_lt_8_twopass_fulltile_with_input_zero_point) {
378*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
379*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 1; channels < 8; channels++) {
380*4bdc9457SAndroid Build Coastguard Worker       for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
381*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
382*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(17)
383*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
384*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
385*4bdc9457SAndroid Build Coastguard Worker           .input_zero_point(zero_point)
386*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
387*4bdc9457SAndroid Build Coastguard Worker       }
388*4bdc9457SAndroid Build Coastguard Worker     }
389*4bdc9457SAndroid Build Coastguard Worker   }
390*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_lt_8_twopass_fulltile_with_output_scale)391*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_lt_8_twopass_fulltile_with_output_scale) {
392*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
393*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 1; channels < 8; channels++) {
394*4bdc9457SAndroid Build Coastguard Worker       for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
395*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
396*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(17)
397*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
398*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
399*4bdc9457SAndroid Build Coastguard Worker           .output_scale(scale)
400*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
401*4bdc9457SAndroid Build Coastguard Worker       }
402*4bdc9457SAndroid Build Coastguard Worker     }
403*4bdc9457SAndroid Build Coastguard Worker   }
404*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_lt_8_twopass_fulltile_with_output_zero_point)405*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_lt_8_twopass_fulltile_with_output_zero_point) {
406*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
407*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 1; channels < 8; channels++) {
408*4bdc9457SAndroid Build Coastguard Worker       for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
409*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
410*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(17)
411*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
412*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
413*4bdc9457SAndroid Build Coastguard Worker           .output_zero_point(zero_point)
414*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
415*4bdc9457SAndroid Build Coastguard Worker       }
416*4bdc9457SAndroid Build Coastguard Worker     }
417*4bdc9457SAndroid Build Coastguard Worker   }
418*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_lt_8_twopass_fulltile_with_qmin)419*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_lt_8_twopass_fulltile_with_qmin) {
420*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
421*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 1; channels < 8; channels++) {
422*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
423*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(17)
424*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
425*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
426*4bdc9457SAndroid Build Coastguard Worker         .qmin(128)
427*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
428*4bdc9457SAndroid Build Coastguard Worker     }
429*4bdc9457SAndroid Build Coastguard Worker   }
430*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_lt_8_twopass_fulltile_with_qmax)431*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_lt_8_twopass_fulltile_with_qmax) {
432*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
433*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 1; channels < 8; channels++) {
434*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
435*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(17)
436*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
437*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
438*4bdc9457SAndroid Build Coastguard Worker         .qmax(128)
439*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
440*4bdc9457SAndroid Build Coastguard Worker     }
441*4bdc9457SAndroid Build Coastguard Worker   }
442*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_lt_8_twopass_subtile)443*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_lt_8_twopass_subtile) {
444*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
445*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
446*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 1; channels < 8; channels++) {
447*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
448*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
449*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
450*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
451*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
452*4bdc9457SAndroid Build Coastguard Worker       }
453*4bdc9457SAndroid Build Coastguard Worker     }
454*4bdc9457SAndroid Build Coastguard Worker   }
455*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_lt_8_twopass_subtile_with_input_offset)456*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_lt_8_twopass_subtile_with_input_offset) {
457*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
458*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
459*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 1; channels < 8; channels++) {
460*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
461*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
462*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
463*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
464*4bdc9457SAndroid Build Coastguard Worker           .input_offset(11)
465*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
466*4bdc9457SAndroid Build Coastguard Worker       }
467*4bdc9457SAndroid Build Coastguard Worker     }
468*4bdc9457SAndroid Build Coastguard Worker   }
469*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_lt_8_twopass_subtile_with_zero)470*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_lt_8_twopass_subtile_with_zero) {
471*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
472*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
473*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 1; channels < 8; channels++) {
474*4bdc9457SAndroid Build Coastguard Worker         for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
475*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
476*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
477*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 8)
478*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
479*4bdc9457SAndroid Build Coastguard Worker             .input_offset(11)
480*4bdc9457SAndroid Build Coastguard Worker             .zero_index(zero_index)
481*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
482*4bdc9457SAndroid Build Coastguard Worker         }
483*4bdc9457SAndroid Build Coastguard Worker       }
484*4bdc9457SAndroid Build Coastguard Worker     }
485*4bdc9457SAndroid Build Coastguard Worker   }
486*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_gt_8_twopass_fulltile)487*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_gt_8_twopass_fulltile) {
488*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
489*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 9; channels < 16; channels++) {
490*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
491*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(17)
492*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
493*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
494*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
495*4bdc9457SAndroid Build Coastguard Worker     }
496*4bdc9457SAndroid Build Coastguard Worker   }
497*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_gt_8_twopass_fulltile_with_input_offset)498*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_gt_8_twopass_fulltile_with_input_offset) {
499*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
500*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 9; channels < 16; channels++) {
501*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
502*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(17)
503*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
504*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
505*4bdc9457SAndroid Build Coastguard Worker         .input_offset(17)
506*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
507*4bdc9457SAndroid Build Coastguard Worker     }
508*4bdc9457SAndroid Build Coastguard Worker   }
509*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_gt_8_twopass_fulltile_with_zero)510*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_gt_8_twopass_fulltile_with_zero) {
511*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
512*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 9; channels < 16; channels++) {
513*4bdc9457SAndroid Build Coastguard Worker       for (size_t zero_index = 0; zero_index < 17; zero_index++) {
514*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
515*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(17)
516*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
517*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
518*4bdc9457SAndroid Build Coastguard Worker           .input_offset(17)
519*4bdc9457SAndroid Build Coastguard Worker           .zero_index(zero_index)
520*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
521*4bdc9457SAndroid Build Coastguard Worker       }
522*4bdc9457SAndroid Build Coastguard Worker     }
523*4bdc9457SAndroid Build Coastguard Worker   }
524*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_gt_8_twopass_fulltile_with_input_scale)525*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_gt_8_twopass_fulltile_with_input_scale) {
526*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
527*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 9; channels < 16; channels++) {
528*4bdc9457SAndroid Build Coastguard Worker       for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
529*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
530*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(17)
531*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
532*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
533*4bdc9457SAndroid Build Coastguard Worker           .input_scale(scale)
534*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
535*4bdc9457SAndroid Build Coastguard Worker       }
536*4bdc9457SAndroid Build Coastguard Worker     }
537*4bdc9457SAndroid Build Coastguard Worker   }
538*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_gt_8_twopass_fulltile_with_input_zero_point)539*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_gt_8_twopass_fulltile_with_input_zero_point) {
540*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
541*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 9; channels < 16; channels++) {
542*4bdc9457SAndroid Build Coastguard Worker       for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
543*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
544*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(17)
545*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
546*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
547*4bdc9457SAndroid Build Coastguard Worker           .input_zero_point(zero_point)
548*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
549*4bdc9457SAndroid Build Coastguard Worker       }
550*4bdc9457SAndroid Build Coastguard Worker     }
551*4bdc9457SAndroid Build Coastguard Worker   }
552*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_gt_8_twopass_fulltile_with_output_scale)553*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_gt_8_twopass_fulltile_with_output_scale) {
554*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
555*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 9; channels < 16; channels++) {
556*4bdc9457SAndroid Build Coastguard Worker       for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
557*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
558*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(17)
559*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
560*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
561*4bdc9457SAndroid Build Coastguard Worker           .output_scale(scale)
562*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
563*4bdc9457SAndroid Build Coastguard Worker       }
564*4bdc9457SAndroid Build Coastguard Worker     }
565*4bdc9457SAndroid Build Coastguard Worker   }
566*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_gt_8_twopass_fulltile_with_output_zero_point)567*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_gt_8_twopass_fulltile_with_output_zero_point) {
568*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
569*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 9; channels < 16; channels++) {
570*4bdc9457SAndroid Build Coastguard Worker       for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
571*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
572*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(17)
573*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
574*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
575*4bdc9457SAndroid Build Coastguard Worker           .output_zero_point(zero_point)
576*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
577*4bdc9457SAndroid Build Coastguard Worker       }
578*4bdc9457SAndroid Build Coastguard Worker     }
579*4bdc9457SAndroid Build Coastguard Worker   }
580*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_gt_8_twopass_fulltile_with_qmin)581*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_gt_8_twopass_fulltile_with_qmin) {
582*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
583*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 9; channels < 16; channels++) {
584*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
585*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(17)
586*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
587*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
588*4bdc9457SAndroid Build Coastguard Worker         .qmin(128)
589*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
590*4bdc9457SAndroid Build Coastguard Worker     }
591*4bdc9457SAndroid Build Coastguard Worker   }
592*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_gt_8_twopass_fulltile_with_qmax)593*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_gt_8_twopass_fulltile_with_qmax) {
594*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
595*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 9; channels < 16; channels++) {
596*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
597*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(17)
598*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
599*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
600*4bdc9457SAndroid Build Coastguard Worker         .qmax(128)
601*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
602*4bdc9457SAndroid Build Coastguard Worker     }
603*4bdc9457SAndroid Build Coastguard Worker   }
604*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_gt_8_twopass_subtile)605*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_gt_8_twopass_subtile) {
606*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
607*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
608*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 9; channels < 16; channels++) {
609*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
610*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
611*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
612*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
613*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
614*4bdc9457SAndroid Build Coastguard Worker       }
615*4bdc9457SAndroid Build Coastguard Worker     }
616*4bdc9457SAndroid Build Coastguard Worker   }
617*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_gt_8_twopass_subtile_with_input_offset)618*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_gt_8_twopass_subtile_with_input_offset) {
619*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
620*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
621*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 9; channels < 16; channels++) {
622*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
623*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
624*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
625*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
626*4bdc9457SAndroid Build Coastguard Worker           .input_offset(17)
627*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
628*4bdc9457SAndroid Build Coastguard Worker       }
629*4bdc9457SAndroid Build Coastguard Worker     }
630*4bdc9457SAndroid Build Coastguard Worker   }
631*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_gt_8_twopass_subtile_with_zero)632*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_gt_8_twopass_subtile_with_zero) {
633*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
634*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
635*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 9; channels < 16; channels++) {
636*4bdc9457SAndroid Build Coastguard Worker         for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
637*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
638*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
639*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 8)
640*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
641*4bdc9457SAndroid Build Coastguard Worker             .input_offset(17)
642*4bdc9457SAndroid Build Coastguard Worker             .zero_index(zero_index)
643*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
644*4bdc9457SAndroid Build Coastguard Worker         }
645*4bdc9457SAndroid Build Coastguard Worker       }
646*4bdc9457SAndroid Build Coastguard Worker     }
647*4bdc9457SAndroid Build Coastguard Worker   }
648*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_eq_8_multipass)649*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_eq_8_multipass) {
650*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
651*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
652*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
653*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(pooling_elements)
654*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
655*4bdc9457SAndroid Build Coastguard Worker         .channels(8)
656*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
657*4bdc9457SAndroid Build Coastguard Worker     }
658*4bdc9457SAndroid Build Coastguard Worker   }
659*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_eq_8_multipass_with_input_offset)660*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_eq_8_multipass_with_input_offset) {
661*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
662*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
663*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
664*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(pooling_elements)
665*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
666*4bdc9457SAndroid Build Coastguard Worker         .channels(8)
667*4bdc9457SAndroid Build Coastguard Worker         .input_offset(11)
668*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
669*4bdc9457SAndroid Build Coastguard Worker     }
670*4bdc9457SAndroid Build Coastguard Worker   }
671*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_eq_8_multipass_with_zero)672*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_eq_8_multipass_with_zero) {
673*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
674*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
675*4bdc9457SAndroid Build Coastguard Worker       for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
676*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
677*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
678*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
679*4bdc9457SAndroid Build Coastguard Worker           .channels(8)
680*4bdc9457SAndroid Build Coastguard Worker           .input_offset(11)
681*4bdc9457SAndroid Build Coastguard Worker           .zero_index(zero_index)
682*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
683*4bdc9457SAndroid Build Coastguard Worker       }
684*4bdc9457SAndroid Build Coastguard Worker     }
685*4bdc9457SAndroid Build Coastguard Worker   }
686*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_eq_8_multipass_with_input_scale)687*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_eq_8_multipass_with_input_scale) {
688*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
689*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
690*4bdc9457SAndroid Build Coastguard Worker       for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
691*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
692*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
693*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
694*4bdc9457SAndroid Build Coastguard Worker           .channels(8)
695*4bdc9457SAndroid Build Coastguard Worker           .input_scale(scale)
696*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
697*4bdc9457SAndroid Build Coastguard Worker       }
698*4bdc9457SAndroid Build Coastguard Worker     }
699*4bdc9457SAndroid Build Coastguard Worker   }
700*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_eq_8_multipass_with_input_zero_point)701*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_eq_8_multipass_with_input_zero_point) {
702*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
703*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
704*4bdc9457SAndroid Build Coastguard Worker       for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
705*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
706*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
707*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
708*4bdc9457SAndroid Build Coastguard Worker           .channels(8)
709*4bdc9457SAndroid Build Coastguard Worker           .input_zero_point(zero_point)
710*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
711*4bdc9457SAndroid Build Coastguard Worker       }
712*4bdc9457SAndroid Build Coastguard Worker     }
713*4bdc9457SAndroid Build Coastguard Worker   }
714*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_eq_8_multipass_with_output_scale)715*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_eq_8_multipass_with_output_scale) {
716*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
717*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
718*4bdc9457SAndroid Build Coastguard Worker       for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
719*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
720*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
721*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
722*4bdc9457SAndroid Build Coastguard Worker           .channels(8)
723*4bdc9457SAndroid Build Coastguard Worker           .output_scale(scale)
724*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
725*4bdc9457SAndroid Build Coastguard Worker       }
726*4bdc9457SAndroid Build Coastguard Worker     }
727*4bdc9457SAndroid Build Coastguard Worker   }
728*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_eq_8_multipass_with_output_zero_point)729*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_eq_8_multipass_with_output_zero_point) {
730*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
731*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
732*4bdc9457SAndroid Build Coastguard Worker       for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
733*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
734*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
735*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
736*4bdc9457SAndroid Build Coastguard Worker           .channels(8)
737*4bdc9457SAndroid Build Coastguard Worker           .output_zero_point(zero_point)
738*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
739*4bdc9457SAndroid Build Coastguard Worker       }
740*4bdc9457SAndroid Build Coastguard Worker     }
741*4bdc9457SAndroid Build Coastguard Worker   }
742*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_eq_8_multipass_with_qmin)743*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_eq_8_multipass_with_qmin) {
744*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
745*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
746*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
747*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(pooling_elements)
748*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
749*4bdc9457SAndroid Build Coastguard Worker         .channels(8)
750*4bdc9457SAndroid Build Coastguard Worker         .qmin(128)
751*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
752*4bdc9457SAndroid Build Coastguard Worker     }
753*4bdc9457SAndroid Build Coastguard Worker   }
754*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_eq_8_multipass_with_qmax)755*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_eq_8_multipass_with_qmax) {
756*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
757*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
758*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
759*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(pooling_elements)
760*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
761*4bdc9457SAndroid Build Coastguard Worker         .channels(8)
762*4bdc9457SAndroid Build Coastguard Worker         .qmax(128)
763*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
764*4bdc9457SAndroid Build Coastguard Worker     }
765*4bdc9457SAndroid Build Coastguard Worker   }
766*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_div_8_multipass)767*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_div_8_multipass) {
768*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
769*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
770*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 16; channels < 64; channels += 8) {
771*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
772*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
773*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
774*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
775*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
776*4bdc9457SAndroid Build Coastguard Worker       }
777*4bdc9457SAndroid Build Coastguard Worker     }
778*4bdc9457SAndroid Build Coastguard Worker   }
779*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_div_8_multipass_with_input_offset)780*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_div_8_multipass_with_input_offset) {
781*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
782*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
783*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 16; channels < 64; channels += 8) {
784*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
785*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
786*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
787*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
788*4bdc9457SAndroid Build Coastguard Worker           .input_offset(67)
789*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
790*4bdc9457SAndroid Build Coastguard Worker       }
791*4bdc9457SAndroid Build Coastguard Worker     }
792*4bdc9457SAndroid Build Coastguard Worker   }
793*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_div_8_multipass_with_zero)794*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_div_8_multipass_with_zero) {
795*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
796*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
797*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 16; channels < 64; channels += 8) {
798*4bdc9457SAndroid Build Coastguard Worker         for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
799*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
800*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
801*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 8)
802*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
803*4bdc9457SAndroid Build Coastguard Worker             .input_offset(67)
804*4bdc9457SAndroid Build Coastguard Worker             .zero_index(zero_index)
805*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
806*4bdc9457SAndroid Build Coastguard Worker         }
807*4bdc9457SAndroid Build Coastguard Worker       }
808*4bdc9457SAndroid Build Coastguard Worker     }
809*4bdc9457SAndroid Build Coastguard Worker   }
810*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_div_8_multipass_with_input_scale)811*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_div_8_multipass_with_input_scale) {
812*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
813*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
814*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 16; channels < 64; channels += 8) {
815*4bdc9457SAndroid Build Coastguard Worker         for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
816*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
817*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
818*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 8)
819*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
820*4bdc9457SAndroid Build Coastguard Worker             .input_scale(scale)
821*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
822*4bdc9457SAndroid Build Coastguard Worker         }
823*4bdc9457SAndroid Build Coastguard Worker       }
824*4bdc9457SAndroid Build Coastguard Worker     }
825*4bdc9457SAndroid Build Coastguard Worker   }
826*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_div_8_multipass_with_input_zero_point)827*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_div_8_multipass_with_input_zero_point) {
828*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
829*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
830*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 16; channels < 64; channels += 8) {
831*4bdc9457SAndroid Build Coastguard Worker         for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
832*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
833*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
834*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 8)
835*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
836*4bdc9457SAndroid Build Coastguard Worker             .input_zero_point(zero_point)
837*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
838*4bdc9457SAndroid Build Coastguard Worker         }
839*4bdc9457SAndroid Build Coastguard Worker       }
840*4bdc9457SAndroid Build Coastguard Worker     }
841*4bdc9457SAndroid Build Coastguard Worker   }
842*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_div_8_multipass_with_output_scale)843*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_div_8_multipass_with_output_scale) {
844*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
845*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
846*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 16; channels < 64; channels += 8) {
847*4bdc9457SAndroid Build Coastguard Worker         for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
848*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
849*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
850*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 8)
851*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
852*4bdc9457SAndroid Build Coastguard Worker             .output_scale(scale)
853*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
854*4bdc9457SAndroid Build Coastguard Worker         }
855*4bdc9457SAndroid Build Coastguard Worker       }
856*4bdc9457SAndroid Build Coastguard Worker     }
857*4bdc9457SAndroid Build Coastguard Worker   }
858*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_div_8_multipass_with_output_zero_point)859*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_div_8_multipass_with_output_zero_point) {
860*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
861*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
862*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 16; channels < 64; channels += 8) {
863*4bdc9457SAndroid Build Coastguard Worker         for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
864*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
865*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
866*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 8)
867*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
868*4bdc9457SAndroid Build Coastguard Worker             .output_zero_point(zero_point)
869*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
870*4bdc9457SAndroid Build Coastguard Worker         }
871*4bdc9457SAndroid Build Coastguard Worker       }
872*4bdc9457SAndroid Build Coastguard Worker     }
873*4bdc9457SAndroid Build Coastguard Worker   }
874*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_div_8_multipass_with_qmin)875*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_div_8_multipass_with_qmin) {
876*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
877*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
878*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 16; channels < 64; channels += 8) {
879*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
880*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
881*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
882*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
883*4bdc9457SAndroid Build Coastguard Worker           .qmin(128)
884*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
885*4bdc9457SAndroid Build Coastguard Worker       }
886*4bdc9457SAndroid Build Coastguard Worker     }
887*4bdc9457SAndroid Build Coastguard Worker   }
888*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_div_8_multipass_with_qmax)889*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_div_8_multipass_with_qmax) {
890*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
891*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
892*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 16; channels < 64; channels += 8) {
893*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
894*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
895*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
896*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
897*4bdc9457SAndroid Build Coastguard Worker           .qmax(128)
898*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
899*4bdc9457SAndroid Build Coastguard Worker       }
900*4bdc9457SAndroid Build Coastguard Worker     }
901*4bdc9457SAndroid Build Coastguard Worker   }
902*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_lt_8_multipass)903*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_lt_8_multipass) {
904*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
905*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
906*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 1; channels < 8; channels++) {
907*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
908*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
909*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
910*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
911*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
912*4bdc9457SAndroid Build Coastguard Worker       }
913*4bdc9457SAndroid Build Coastguard Worker     }
914*4bdc9457SAndroid Build Coastguard Worker   }
915*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_lt_8_multipass_with_input_offset)916*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_lt_8_multipass_with_input_offset) {
917*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
918*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
919*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 1; channels < 8; channels++) {
920*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
921*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
922*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
923*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
924*4bdc9457SAndroid Build Coastguard Worker           .input_offset(8)
925*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
926*4bdc9457SAndroid Build Coastguard Worker       }
927*4bdc9457SAndroid Build Coastguard Worker     }
928*4bdc9457SAndroid Build Coastguard Worker   }
929*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_lt_8_multipass_with_zero)930*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_lt_8_multipass_with_zero) {
931*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
932*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
933*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 1; channels < 8; channels++) {
934*4bdc9457SAndroid Build Coastguard Worker         for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
935*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
936*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
937*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 8)
938*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
939*4bdc9457SAndroid Build Coastguard Worker             .input_offset(8)
940*4bdc9457SAndroid Build Coastguard Worker             .zero_index(zero_index)
941*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
942*4bdc9457SAndroid Build Coastguard Worker         }
943*4bdc9457SAndroid Build Coastguard Worker       }
944*4bdc9457SAndroid Build Coastguard Worker     }
945*4bdc9457SAndroid Build Coastguard Worker   }
946*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_lt_8_multipass_with_input_scale)947*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_lt_8_multipass_with_input_scale) {
948*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
949*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
950*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 1; channels < 8; channels++) {
951*4bdc9457SAndroid Build Coastguard Worker         for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
952*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
953*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
954*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 8)
955*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
956*4bdc9457SAndroid Build Coastguard Worker             .input_scale(scale)
957*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
958*4bdc9457SAndroid Build Coastguard Worker         }
959*4bdc9457SAndroid Build Coastguard Worker       }
960*4bdc9457SAndroid Build Coastguard Worker     }
961*4bdc9457SAndroid Build Coastguard Worker   }
962*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_lt_8_multipass_with_input_zero_point)963*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_lt_8_multipass_with_input_zero_point) {
964*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
965*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
966*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 1; channels < 8; channels++) {
967*4bdc9457SAndroid Build Coastguard Worker         for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
968*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
969*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
970*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 8)
971*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
972*4bdc9457SAndroid Build Coastguard Worker             .input_zero_point(zero_point)
973*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
974*4bdc9457SAndroid Build Coastguard Worker         }
975*4bdc9457SAndroid Build Coastguard Worker       }
976*4bdc9457SAndroid Build Coastguard Worker     }
977*4bdc9457SAndroid Build Coastguard Worker   }
978*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_lt_8_multipass_with_output_scale)979*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_lt_8_multipass_with_output_scale) {
980*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
981*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
982*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 1; channels < 8; channels++) {
983*4bdc9457SAndroid Build Coastguard Worker         for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
984*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
985*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
986*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 8)
987*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
988*4bdc9457SAndroid Build Coastguard Worker             .output_scale(scale)
989*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
990*4bdc9457SAndroid Build Coastguard Worker         }
991*4bdc9457SAndroid Build Coastguard Worker       }
992*4bdc9457SAndroid Build Coastguard Worker     }
993*4bdc9457SAndroid Build Coastguard Worker   }
994*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_lt_8_multipass_with_output_zero_point)995*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_lt_8_multipass_with_output_zero_point) {
996*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
997*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
998*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 1; channels < 8; channels++) {
999*4bdc9457SAndroid Build Coastguard Worker         for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
1000*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
1001*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
1002*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 8)
1003*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
1004*4bdc9457SAndroid Build Coastguard Worker             .output_zero_point(zero_point)
1005*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
1006*4bdc9457SAndroid Build Coastguard Worker         }
1007*4bdc9457SAndroid Build Coastguard Worker       }
1008*4bdc9457SAndroid Build Coastguard Worker     }
1009*4bdc9457SAndroid Build Coastguard Worker   }
1010*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_lt_8_multipass_with_qmin)1011*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_lt_8_multipass_with_qmin) {
1012*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
1013*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
1014*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 1; channels < 8; channels++) {
1015*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
1016*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
1017*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
1018*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
1019*4bdc9457SAndroid Build Coastguard Worker           .qmin(128)
1020*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
1021*4bdc9457SAndroid Build Coastguard Worker       }
1022*4bdc9457SAndroid Build Coastguard Worker     }
1023*4bdc9457SAndroid Build Coastguard Worker   }
1024*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_lt_8_multipass_with_qmax)1025*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_lt_8_multipass_with_qmax) {
1026*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
1027*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
1028*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 1; channels < 8; channels++) {
1029*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
1030*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
1031*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
1032*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
1033*4bdc9457SAndroid Build Coastguard Worker           .qmax(128)
1034*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
1035*4bdc9457SAndroid Build Coastguard Worker       }
1036*4bdc9457SAndroid Build Coastguard Worker     }
1037*4bdc9457SAndroid Build Coastguard Worker   }
1038*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_gt_8_multipass)1039*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_gt_8_multipass) {
1040*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
1041*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
1042*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 9; channels < 16; channels++) {
1043*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
1044*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
1045*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
1046*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
1047*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
1048*4bdc9457SAndroid Build Coastguard Worker       }
1049*4bdc9457SAndroid Build Coastguard Worker     }
1050*4bdc9457SAndroid Build Coastguard Worker   }
1051*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_gt_8_multipass_with_input_offset)1052*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_gt_8_multipass_with_input_offset) {
1053*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
1054*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
1055*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 9; channels < 16; channels++) {
1056*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
1057*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
1058*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
1059*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
1060*4bdc9457SAndroid Build Coastguard Worker           .input_offset(17)
1061*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
1062*4bdc9457SAndroid Build Coastguard Worker       }
1063*4bdc9457SAndroid Build Coastguard Worker     }
1064*4bdc9457SAndroid Build Coastguard Worker   }
1065*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_gt_8_multipass_with_zero)1066*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_gt_8_multipass_with_zero) {
1067*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
1068*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
1069*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 9; channels < 16; channels++) {
1070*4bdc9457SAndroid Build Coastguard Worker         for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
1071*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
1072*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
1073*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 8)
1074*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
1075*4bdc9457SAndroid Build Coastguard Worker             .input_offset(17)
1076*4bdc9457SAndroid Build Coastguard Worker             .zero_index(zero_index)
1077*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
1078*4bdc9457SAndroid Build Coastguard Worker         }
1079*4bdc9457SAndroid Build Coastguard Worker       }
1080*4bdc9457SAndroid Build Coastguard Worker     }
1081*4bdc9457SAndroid Build Coastguard Worker   }
1082*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_gt_8_multipass_with_input_scale)1083*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_gt_8_multipass_with_input_scale) {
1084*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
1085*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
1086*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 9; channels < 16; channels++) {
1087*4bdc9457SAndroid Build Coastguard Worker         for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
1088*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
1089*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
1090*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 8)
1091*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
1092*4bdc9457SAndroid Build Coastguard Worker             .input_scale(scale)
1093*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
1094*4bdc9457SAndroid Build Coastguard Worker         }
1095*4bdc9457SAndroid Build Coastguard Worker       }
1096*4bdc9457SAndroid Build Coastguard Worker     }
1097*4bdc9457SAndroid Build Coastguard Worker   }
1098*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_gt_8_multipass_with_input_zero_point)1099*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_gt_8_multipass_with_input_zero_point) {
1100*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
1101*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
1102*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 9; channels < 16; channels++) {
1103*4bdc9457SAndroid Build Coastguard Worker         for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
1104*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
1105*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
1106*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 8)
1107*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
1108*4bdc9457SAndroid Build Coastguard Worker             .input_zero_point(zero_point)
1109*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
1110*4bdc9457SAndroid Build Coastguard Worker         }
1111*4bdc9457SAndroid Build Coastguard Worker       }
1112*4bdc9457SAndroid Build Coastguard Worker     }
1113*4bdc9457SAndroid Build Coastguard Worker   }
1114*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_gt_8_multipass_with_output_scale)1115*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_gt_8_multipass_with_output_scale) {
1116*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
1117*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
1118*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 9; channels < 16; channels++) {
1119*4bdc9457SAndroid Build Coastguard Worker         for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
1120*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
1121*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
1122*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 8)
1123*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
1124*4bdc9457SAndroid Build Coastguard Worker             .output_scale(scale)
1125*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
1126*4bdc9457SAndroid Build Coastguard Worker         }
1127*4bdc9457SAndroid Build Coastguard Worker       }
1128*4bdc9457SAndroid Build Coastguard Worker     }
1129*4bdc9457SAndroid Build Coastguard Worker   }
1130*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_gt_8_multipass_with_output_zero_point)1131*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_gt_8_multipass_with_output_zero_point) {
1132*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
1133*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
1134*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 9; channels < 16; channels++) {
1135*4bdc9457SAndroid Build Coastguard Worker         for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
1136*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
1137*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
1138*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 8)
1139*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
1140*4bdc9457SAndroid Build Coastguard Worker             .output_zero_point(zero_point)
1141*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
1142*4bdc9457SAndroid Build Coastguard Worker         }
1143*4bdc9457SAndroid Build Coastguard Worker       }
1144*4bdc9457SAndroid Build Coastguard Worker     }
1145*4bdc9457SAndroid Build Coastguard Worker   }
1146*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_gt_8_multipass_with_qmin)1147*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_gt_8_multipass_with_qmin) {
1148*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
1149*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
1150*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 9; channels < 16; channels++) {
1151*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
1152*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
1153*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
1154*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
1155*4bdc9457SAndroid Build Coastguard Worker           .qmin(128)
1156*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
1157*4bdc9457SAndroid Build Coastguard Worker       }
1158*4bdc9457SAndroid Build Coastguard Worker     }
1159*4bdc9457SAndroid Build Coastguard Worker   }
1160*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,channels_gt_8_multipass_with_qmax)1161*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, channels_gt_8_multipass_with_qmax) {
1162*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
1163*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
1164*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 9; channels < 16; channels++) {
1165*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
1166*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
1167*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
1168*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
1169*4bdc9457SAndroid Build Coastguard Worker           .qmax(128)
1170*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
1171*4bdc9457SAndroid Build Coastguard Worker       }
1172*4bdc9457SAndroid Build Coastguard Worker     }
1173*4bdc9457SAndroid Build Coastguard Worker   }
1174*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,few_output_pixels)1175*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, few_output_pixels) {
1176*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
1177*4bdc9457SAndroid Build Coastguard Worker     for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
1178*4bdc9457SAndroid Build Coastguard Worker       for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
1179*4bdc9457SAndroid Build Coastguard Worker         for (size_t channels = 1; channels <= 40; channels += 7) {
1180*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
1181*4bdc9457SAndroid Build Coastguard Worker             .output_pixels(output_pixels)
1182*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
1183*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 8)
1184*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
1185*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
1186*4bdc9457SAndroid Build Coastguard Worker         }
1187*4bdc9457SAndroid Build Coastguard Worker       }
1188*4bdc9457SAndroid Build Coastguard Worker     }
1189*4bdc9457SAndroid Build Coastguard Worker   }
1190*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,few_output_pixels_with_input_offset)1191*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, few_output_pixels_with_input_offset) {
1192*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
1193*4bdc9457SAndroid Build Coastguard Worker     for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
1194*4bdc9457SAndroid Build Coastguard Worker       for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
1195*4bdc9457SAndroid Build Coastguard Worker         for (size_t channels = 1; channels <= 40; channels += 7) {
1196*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
1197*4bdc9457SAndroid Build Coastguard Worker             .output_pixels(output_pixels)
1198*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
1199*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 8)
1200*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
1201*4bdc9457SAndroid Build Coastguard Worker             .input_offset(43)
1202*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
1203*4bdc9457SAndroid Build Coastguard Worker         }
1204*4bdc9457SAndroid Build Coastguard Worker       }
1205*4bdc9457SAndroid Build Coastguard Worker     }
1206*4bdc9457SAndroid Build Coastguard Worker   }
1207*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,few_output_pixels_with_zero)1208*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, few_output_pixels_with_zero) {
1209*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
1210*4bdc9457SAndroid Build Coastguard Worker     for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
1211*4bdc9457SAndroid Build Coastguard Worker       for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
1212*4bdc9457SAndroid Build Coastguard Worker         for (size_t channels = 1; channels <= 40; channels += 7) {
1213*4bdc9457SAndroid Build Coastguard Worker           for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
1214*4bdc9457SAndroid Build Coastguard Worker             AvgPoolMicrokernelTester()
1215*4bdc9457SAndroid Build Coastguard Worker               .output_pixels(output_pixels)
1216*4bdc9457SAndroid Build Coastguard Worker               .pooling_elements(pooling_elements)
1217*4bdc9457SAndroid Build Coastguard Worker               .pooling_tile(9, 8)
1218*4bdc9457SAndroid Build Coastguard Worker               .channels(channels)
1219*4bdc9457SAndroid Build Coastguard Worker               .input_offset(43)
1220*4bdc9457SAndroid Build Coastguard Worker               .zero_index(zero_index)
1221*4bdc9457SAndroid Build Coastguard Worker               .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
1222*4bdc9457SAndroid Build Coastguard Worker           }
1223*4bdc9457SAndroid Build Coastguard Worker         }
1224*4bdc9457SAndroid Build Coastguard Worker       }
1225*4bdc9457SAndroid Build Coastguard Worker     }
1226*4bdc9457SAndroid Build Coastguard Worker   }
1227*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,few_output_pixels_with_input_scale)1228*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, few_output_pixels_with_input_scale) {
1229*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
1230*4bdc9457SAndroid Build Coastguard Worker     for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
1231*4bdc9457SAndroid Build Coastguard Worker       for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
1232*4bdc9457SAndroid Build Coastguard Worker         for (size_t channels = 1; channels <= 40; channels += 7) {
1233*4bdc9457SAndroid Build Coastguard Worker           for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
1234*4bdc9457SAndroid Build Coastguard Worker             AvgPoolMicrokernelTester()
1235*4bdc9457SAndroid Build Coastguard Worker               .output_pixels(output_pixels)
1236*4bdc9457SAndroid Build Coastguard Worker               .pooling_elements(pooling_elements)
1237*4bdc9457SAndroid Build Coastguard Worker               .pooling_tile(9, 8)
1238*4bdc9457SAndroid Build Coastguard Worker               .channels(channels)
1239*4bdc9457SAndroid Build Coastguard Worker               .input_scale(scale)
1240*4bdc9457SAndroid Build Coastguard Worker               .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
1241*4bdc9457SAndroid Build Coastguard Worker           }
1242*4bdc9457SAndroid Build Coastguard Worker         }
1243*4bdc9457SAndroid Build Coastguard Worker       }
1244*4bdc9457SAndroid Build Coastguard Worker     }
1245*4bdc9457SAndroid Build Coastguard Worker   }
1246*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,few_output_pixels_with_input_zero_point)1247*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, few_output_pixels_with_input_zero_point) {
1248*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
1249*4bdc9457SAndroid Build Coastguard Worker     for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
1250*4bdc9457SAndroid Build Coastguard Worker       for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
1251*4bdc9457SAndroid Build Coastguard Worker         for (size_t channels = 1; channels <= 40; channels += 7) {
1252*4bdc9457SAndroid Build Coastguard Worker           for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
1253*4bdc9457SAndroid Build Coastguard Worker             AvgPoolMicrokernelTester()
1254*4bdc9457SAndroid Build Coastguard Worker               .output_pixels(output_pixels)
1255*4bdc9457SAndroid Build Coastguard Worker               .pooling_elements(pooling_elements)
1256*4bdc9457SAndroid Build Coastguard Worker               .pooling_tile(9, 8)
1257*4bdc9457SAndroid Build Coastguard Worker               .channels(channels)
1258*4bdc9457SAndroid Build Coastguard Worker               .input_zero_point(zero_point)
1259*4bdc9457SAndroid Build Coastguard Worker               .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
1260*4bdc9457SAndroid Build Coastguard Worker           }
1261*4bdc9457SAndroid Build Coastguard Worker         }
1262*4bdc9457SAndroid Build Coastguard Worker       }
1263*4bdc9457SAndroid Build Coastguard Worker     }
1264*4bdc9457SAndroid Build Coastguard Worker   }
1265*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,few_output_pixels_with_output_scale)1266*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, few_output_pixels_with_output_scale) {
1267*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
1268*4bdc9457SAndroid Build Coastguard Worker     for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
1269*4bdc9457SAndroid Build Coastguard Worker       for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
1270*4bdc9457SAndroid Build Coastguard Worker         for (size_t channels = 1; channels <= 40; channels += 7) {
1271*4bdc9457SAndroid Build Coastguard Worker           for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
1272*4bdc9457SAndroid Build Coastguard Worker             AvgPoolMicrokernelTester()
1273*4bdc9457SAndroid Build Coastguard Worker               .output_pixels(output_pixels)
1274*4bdc9457SAndroid Build Coastguard Worker               .pooling_elements(pooling_elements)
1275*4bdc9457SAndroid Build Coastguard Worker               .pooling_tile(9, 8)
1276*4bdc9457SAndroid Build Coastguard Worker               .channels(channels)
1277*4bdc9457SAndroid Build Coastguard Worker               .output_scale(scale)
1278*4bdc9457SAndroid Build Coastguard Worker               .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
1279*4bdc9457SAndroid Build Coastguard Worker           }
1280*4bdc9457SAndroid Build Coastguard Worker         }
1281*4bdc9457SAndroid Build Coastguard Worker       }
1282*4bdc9457SAndroid Build Coastguard Worker     }
1283*4bdc9457SAndroid Build Coastguard Worker   }
1284*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,few_output_pixels_with_output_zero_point)1285*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, few_output_pixels_with_output_zero_point) {
1286*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
1287*4bdc9457SAndroid Build Coastguard Worker     for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
1288*4bdc9457SAndroid Build Coastguard Worker       for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
1289*4bdc9457SAndroid Build Coastguard Worker         for (size_t channels = 1; channels <= 40; channels += 7) {
1290*4bdc9457SAndroid Build Coastguard Worker           for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
1291*4bdc9457SAndroid Build Coastguard Worker             AvgPoolMicrokernelTester()
1292*4bdc9457SAndroid Build Coastguard Worker               .output_pixels(output_pixels)
1293*4bdc9457SAndroid Build Coastguard Worker               .pooling_elements(pooling_elements)
1294*4bdc9457SAndroid Build Coastguard Worker               .pooling_tile(9, 8)
1295*4bdc9457SAndroid Build Coastguard Worker               .channels(channels)
1296*4bdc9457SAndroid Build Coastguard Worker               .output_zero_point(zero_point)
1297*4bdc9457SAndroid Build Coastguard Worker               .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
1298*4bdc9457SAndroid Build Coastguard Worker           }
1299*4bdc9457SAndroid Build Coastguard Worker         }
1300*4bdc9457SAndroid Build Coastguard Worker       }
1301*4bdc9457SAndroid Build Coastguard Worker     }
1302*4bdc9457SAndroid Build Coastguard Worker   }
1303*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,few_output_pixels_with_qmin)1304*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, few_output_pixels_with_qmin) {
1305*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
1306*4bdc9457SAndroid Build Coastguard Worker     for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
1307*4bdc9457SAndroid Build Coastguard Worker       for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
1308*4bdc9457SAndroid Build Coastguard Worker         for (size_t channels = 1; channels <= 40; channels += 7) {
1309*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
1310*4bdc9457SAndroid Build Coastguard Worker             .output_pixels(output_pixels)
1311*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
1312*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 8)
1313*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
1314*4bdc9457SAndroid Build Coastguard Worker             .qmin(128)
1315*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
1316*4bdc9457SAndroid Build Coastguard Worker         }
1317*4bdc9457SAndroid Build Coastguard Worker       }
1318*4bdc9457SAndroid Build Coastguard Worker     }
1319*4bdc9457SAndroid Build Coastguard Worker   }
1320*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,few_output_pixels_with_qmax)1321*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, few_output_pixels_with_qmax) {
1322*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
1323*4bdc9457SAndroid Build Coastguard Worker     for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
1324*4bdc9457SAndroid Build Coastguard Worker       for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
1325*4bdc9457SAndroid Build Coastguard Worker         for (size_t channels = 1; channels <= 40; channels += 7) {
1326*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
1327*4bdc9457SAndroid Build Coastguard Worker             .output_pixels(output_pixels)
1328*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
1329*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 8)
1330*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
1331*4bdc9457SAndroid Build Coastguard Worker             .qmax(128)
1332*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
1333*4bdc9457SAndroid Build Coastguard Worker         }
1334*4bdc9457SAndroid Build Coastguard Worker       }
1335*4bdc9457SAndroid Build Coastguard Worker     }
1336*4bdc9457SAndroid Build Coastguard Worker   }
1337*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,few_output_pixels_with_output_stride)1338*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, few_output_pixels_with_output_stride) {
1339*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
1340*4bdc9457SAndroid Build Coastguard Worker     for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
1341*4bdc9457SAndroid Build Coastguard Worker       for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
1342*4bdc9457SAndroid Build Coastguard Worker         for (size_t channels = 1; channels <= 40; channels += 7) {
1343*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
1344*4bdc9457SAndroid Build Coastguard Worker             .output_pixels(output_pixels)
1345*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
1346*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 8)
1347*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
1348*4bdc9457SAndroid Build Coastguard Worker             .output_stride(43)
1349*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
1350*4bdc9457SAndroid Build Coastguard Worker         }
1351*4bdc9457SAndroid Build Coastguard Worker       }
1352*4bdc9457SAndroid Build Coastguard Worker     }
1353*4bdc9457SAndroid Build Coastguard Worker   }
1354*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8,few_output_pixels_with_step)1355*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__NEON_C8, few_output_pixels_with_step) {
1356*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
1357*4bdc9457SAndroid Build Coastguard Worker     for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
1358*4bdc9457SAndroid Build Coastguard Worker       for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
1359*4bdc9457SAndroid Build Coastguard Worker         for (size_t channels = 1; channels <= 40; channels += 7) {
1360*4bdc9457SAndroid Build Coastguard Worker           for (size_t step = 2; step <= pooling_elements; step++) {
1361*4bdc9457SAndroid Build Coastguard Worker             AvgPoolMicrokernelTester()
1362*4bdc9457SAndroid Build Coastguard Worker               .output_pixels(output_pixels)
1363*4bdc9457SAndroid Build Coastguard Worker               .pooling_elements(pooling_elements)
1364*4bdc9457SAndroid Build Coastguard Worker               .pooling_tile(9, 8)
1365*4bdc9457SAndroid Build Coastguard Worker               .step(step)
1366*4bdc9457SAndroid Build Coastguard Worker               .channels(channels)
1367*4bdc9457SAndroid Build Coastguard Worker               .output_stride(43)
1368*4bdc9457SAndroid Build Coastguard Worker               .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
1369*4bdc9457SAndroid Build Coastguard Worker           }
1370*4bdc9457SAndroid Build Coastguard Worker         }
1371*4bdc9457SAndroid Build Coastguard Worker       }
1372*4bdc9457SAndroid Build Coastguard Worker     }
1373*4bdc9457SAndroid Build Coastguard Worker   }
1374*4bdc9457SAndroid Build Coastguard Worker #endif  // XNN_ARCH_ARM || XNN_ARCH_ARM64
1375*4bdc9457SAndroid Build Coastguard Worker 
1376*4bdc9457SAndroid Build Coastguard Worker 
1377*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_eq_8_twopass_fulltile)1378*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_eq_8_twopass_fulltile) {
1379*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
1380*4bdc9457SAndroid Build Coastguard Worker     AvgPoolMicrokernelTester()
1381*4bdc9457SAndroid Build Coastguard Worker       .pooling_elements(17)
1382*4bdc9457SAndroid Build Coastguard Worker       .pooling_tile(9, 8)
1383*4bdc9457SAndroid Build Coastguard Worker       .channels(8)
1384*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
1385*4bdc9457SAndroid Build Coastguard Worker   }
1386*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_eq_8_twopass_fulltile_with_input_offset)1387*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_eq_8_twopass_fulltile_with_input_offset) {
1388*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
1389*4bdc9457SAndroid Build Coastguard Worker     AvgPoolMicrokernelTester()
1390*4bdc9457SAndroid Build Coastguard Worker       .pooling_elements(17)
1391*4bdc9457SAndroid Build Coastguard Worker       .pooling_tile(9, 8)
1392*4bdc9457SAndroid Build Coastguard Worker       .channels(8)
1393*4bdc9457SAndroid Build Coastguard Worker       .input_offset(11)
1394*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
1395*4bdc9457SAndroid Build Coastguard Worker   }
1396*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_eq_8_twopass_fulltile_with_zero)1397*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_eq_8_twopass_fulltile_with_zero) {
1398*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
1399*4bdc9457SAndroid Build Coastguard Worker     for (size_t zero_index = 0; zero_index < 17; zero_index++) {
1400*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
1401*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(17)
1402*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
1403*4bdc9457SAndroid Build Coastguard Worker         .channels(8)
1404*4bdc9457SAndroid Build Coastguard Worker         .input_offset(11)
1405*4bdc9457SAndroid Build Coastguard Worker         .zero_index(zero_index)
1406*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
1407*4bdc9457SAndroid Build Coastguard Worker     }
1408*4bdc9457SAndroid Build Coastguard Worker   }
1409*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_eq_8_twopass_fulltile_with_input_scale)1410*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_eq_8_twopass_fulltile_with_input_scale) {
1411*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
1412*4bdc9457SAndroid Build Coastguard Worker     for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
1413*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
1414*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(17)
1415*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
1416*4bdc9457SAndroid Build Coastguard Worker         .channels(8)
1417*4bdc9457SAndroid Build Coastguard Worker         .input_scale(scale)
1418*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
1419*4bdc9457SAndroid Build Coastguard Worker     }
1420*4bdc9457SAndroid Build Coastguard Worker   }
1421*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_eq_8_twopass_fulltile_with_input_zero_point)1422*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_eq_8_twopass_fulltile_with_input_zero_point) {
1423*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
1424*4bdc9457SAndroid Build Coastguard Worker     for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
1425*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
1426*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(17)
1427*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
1428*4bdc9457SAndroid Build Coastguard Worker         .channels(8)
1429*4bdc9457SAndroid Build Coastguard Worker         .input_zero_point(zero_point)
1430*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
1431*4bdc9457SAndroid Build Coastguard Worker     }
1432*4bdc9457SAndroid Build Coastguard Worker   }
1433*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_eq_8_twopass_fulltile_with_output_scale)1434*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_eq_8_twopass_fulltile_with_output_scale) {
1435*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
1436*4bdc9457SAndroid Build Coastguard Worker     for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
1437*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
1438*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(17)
1439*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
1440*4bdc9457SAndroid Build Coastguard Worker         .channels(8)
1441*4bdc9457SAndroid Build Coastguard Worker         .output_scale(scale)
1442*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
1443*4bdc9457SAndroid Build Coastguard Worker     }
1444*4bdc9457SAndroid Build Coastguard Worker   }
1445*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_eq_8_twopass_fulltile_with_output_zero_point)1446*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_eq_8_twopass_fulltile_with_output_zero_point) {
1447*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
1448*4bdc9457SAndroid Build Coastguard Worker     for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
1449*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
1450*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(17)
1451*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
1452*4bdc9457SAndroid Build Coastguard Worker         .channels(8)
1453*4bdc9457SAndroid Build Coastguard Worker         .output_zero_point(zero_point)
1454*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
1455*4bdc9457SAndroid Build Coastguard Worker     }
1456*4bdc9457SAndroid Build Coastguard Worker   }
1457*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_eq_8_twopass_fulltile_with_qmin)1458*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_eq_8_twopass_fulltile_with_qmin) {
1459*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
1460*4bdc9457SAndroid Build Coastguard Worker     AvgPoolMicrokernelTester()
1461*4bdc9457SAndroid Build Coastguard Worker       .pooling_elements(17)
1462*4bdc9457SAndroid Build Coastguard Worker       .pooling_tile(9, 8)
1463*4bdc9457SAndroid Build Coastguard Worker       .channels(8)
1464*4bdc9457SAndroid Build Coastguard Worker       .qmin(128)
1465*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
1466*4bdc9457SAndroid Build Coastguard Worker   }
1467*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_eq_8_twopass_fulltile_with_qmax)1468*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_eq_8_twopass_fulltile_with_qmax) {
1469*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
1470*4bdc9457SAndroid Build Coastguard Worker     AvgPoolMicrokernelTester()
1471*4bdc9457SAndroid Build Coastguard Worker       .pooling_elements(17)
1472*4bdc9457SAndroid Build Coastguard Worker       .pooling_tile(9, 8)
1473*4bdc9457SAndroid Build Coastguard Worker       .channels(8)
1474*4bdc9457SAndroid Build Coastguard Worker       .qmax(128)
1475*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
1476*4bdc9457SAndroid Build Coastguard Worker   }
1477*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_eq_8_twopass_subtile)1478*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_eq_8_twopass_subtile) {
1479*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
1480*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
1481*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
1482*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(pooling_elements)
1483*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
1484*4bdc9457SAndroid Build Coastguard Worker         .channels(8)
1485*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
1486*4bdc9457SAndroid Build Coastguard Worker     }
1487*4bdc9457SAndroid Build Coastguard Worker   }
1488*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_eq_8_twopass_subtile_with_input_offset)1489*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_eq_8_twopass_subtile_with_input_offset) {
1490*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
1491*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
1492*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
1493*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(pooling_elements)
1494*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
1495*4bdc9457SAndroid Build Coastguard Worker         .channels(8)
1496*4bdc9457SAndroid Build Coastguard Worker         .input_offset(11)
1497*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
1498*4bdc9457SAndroid Build Coastguard Worker     }
1499*4bdc9457SAndroid Build Coastguard Worker   }
1500*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_eq_8_twopass_subtile_with_zero)1501*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_eq_8_twopass_subtile_with_zero) {
1502*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
1503*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
1504*4bdc9457SAndroid Build Coastguard Worker       for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
1505*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
1506*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
1507*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
1508*4bdc9457SAndroid Build Coastguard Worker           .channels(8)
1509*4bdc9457SAndroid Build Coastguard Worker           .input_offset(11)
1510*4bdc9457SAndroid Build Coastguard Worker           .zero_index(zero_index)
1511*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
1512*4bdc9457SAndroid Build Coastguard Worker       }
1513*4bdc9457SAndroid Build Coastguard Worker     }
1514*4bdc9457SAndroid Build Coastguard Worker   }
1515*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_div_8_twopass_fulltile)1516*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_div_8_twopass_fulltile) {
1517*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
1518*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 16; channels < 64; channels += 8) {
1519*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
1520*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(17)
1521*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
1522*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1523*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
1524*4bdc9457SAndroid Build Coastguard Worker     }
1525*4bdc9457SAndroid Build Coastguard Worker   }
1526*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_div_8_twopass_fulltile_with_input_offset)1527*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_div_8_twopass_fulltile_with_input_offset) {
1528*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
1529*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 16; channels < 64; channels += 8) {
1530*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
1531*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(17)
1532*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
1533*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1534*4bdc9457SAndroid Build Coastguard Worker         .input_offset(41)
1535*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
1536*4bdc9457SAndroid Build Coastguard Worker     }
1537*4bdc9457SAndroid Build Coastguard Worker   }
1538*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_div_8_twopass_fulltile_with_zero)1539*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_div_8_twopass_fulltile_with_zero) {
1540*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
1541*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 16; channels < 64; channels += 8) {
1542*4bdc9457SAndroid Build Coastguard Worker       for (size_t zero_index = 0; zero_index < 17; zero_index++) {
1543*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
1544*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(17)
1545*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
1546*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
1547*4bdc9457SAndroid Build Coastguard Worker           .input_offset(41)
1548*4bdc9457SAndroid Build Coastguard Worker           .zero_index(zero_index)
1549*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
1550*4bdc9457SAndroid Build Coastguard Worker       }
1551*4bdc9457SAndroid Build Coastguard Worker     }
1552*4bdc9457SAndroid Build Coastguard Worker   }
1553*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_div_8_twopass_fulltile_with_input_scale)1554*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_div_8_twopass_fulltile_with_input_scale) {
1555*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
1556*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 16; channels < 64; channels += 8) {
1557*4bdc9457SAndroid Build Coastguard Worker       for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
1558*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
1559*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(17)
1560*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
1561*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
1562*4bdc9457SAndroid Build Coastguard Worker           .input_scale(scale)
1563*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
1564*4bdc9457SAndroid Build Coastguard Worker       }
1565*4bdc9457SAndroid Build Coastguard Worker     }
1566*4bdc9457SAndroid Build Coastguard Worker   }
1567*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_div_8_twopass_fulltile_with_input_zero_point)1568*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_div_8_twopass_fulltile_with_input_zero_point) {
1569*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
1570*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 16; channels < 64; channels += 8) {
1571*4bdc9457SAndroid Build Coastguard Worker       for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
1572*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
1573*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(17)
1574*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
1575*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
1576*4bdc9457SAndroid Build Coastguard Worker           .input_zero_point(zero_point)
1577*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
1578*4bdc9457SAndroid Build Coastguard Worker       }
1579*4bdc9457SAndroid Build Coastguard Worker     }
1580*4bdc9457SAndroid Build Coastguard Worker   }
1581*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_div_8_twopass_fulltile_with_output_scale)1582*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_div_8_twopass_fulltile_with_output_scale) {
1583*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
1584*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 16; channels < 64; channels += 8) {
1585*4bdc9457SAndroid Build Coastguard Worker       for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
1586*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
1587*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(17)
1588*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
1589*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
1590*4bdc9457SAndroid Build Coastguard Worker           .output_scale(scale)
1591*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
1592*4bdc9457SAndroid Build Coastguard Worker       }
1593*4bdc9457SAndroid Build Coastguard Worker     }
1594*4bdc9457SAndroid Build Coastguard Worker   }
1595*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_div_8_twopass_fulltile_with_output_zero_point)1596*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_div_8_twopass_fulltile_with_output_zero_point) {
1597*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
1598*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 16; channels < 64; channels += 8) {
1599*4bdc9457SAndroid Build Coastguard Worker       for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
1600*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
1601*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(17)
1602*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
1603*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
1604*4bdc9457SAndroid Build Coastguard Worker           .output_zero_point(zero_point)
1605*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
1606*4bdc9457SAndroid Build Coastguard Worker       }
1607*4bdc9457SAndroid Build Coastguard Worker     }
1608*4bdc9457SAndroid Build Coastguard Worker   }
1609*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_div_8_twopass_fulltile_with_qmin)1610*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_div_8_twopass_fulltile_with_qmin) {
1611*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
1612*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 16; channels < 64; channels += 8) {
1613*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
1614*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(17)
1615*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
1616*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1617*4bdc9457SAndroid Build Coastguard Worker         .qmin(128)
1618*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
1619*4bdc9457SAndroid Build Coastguard Worker     }
1620*4bdc9457SAndroid Build Coastguard Worker   }
1621*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_div_8_twopass_fulltile_with_qmax)1622*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_div_8_twopass_fulltile_with_qmax) {
1623*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
1624*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 16; channels < 64; channels += 8) {
1625*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
1626*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(17)
1627*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
1628*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1629*4bdc9457SAndroid Build Coastguard Worker         .qmax(128)
1630*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
1631*4bdc9457SAndroid Build Coastguard Worker     }
1632*4bdc9457SAndroid Build Coastguard Worker   }
1633*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_div_8_twopass_subtile)1634*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_div_8_twopass_subtile) {
1635*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
1636*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
1637*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 16; channels < 64; channels += 8) {
1638*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
1639*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
1640*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
1641*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
1642*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
1643*4bdc9457SAndroid Build Coastguard Worker       }
1644*4bdc9457SAndroid Build Coastguard Worker     }
1645*4bdc9457SAndroid Build Coastguard Worker   }
1646*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_div_8_twopass_subtile_with_input_offset)1647*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_div_8_twopass_subtile_with_input_offset) {
1648*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
1649*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
1650*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 16; channels < 64; channels += 8) {
1651*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
1652*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
1653*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
1654*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
1655*4bdc9457SAndroid Build Coastguard Worker           .input_offset(67)
1656*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
1657*4bdc9457SAndroid Build Coastguard Worker       }
1658*4bdc9457SAndroid Build Coastguard Worker     }
1659*4bdc9457SAndroid Build Coastguard Worker   }
1660*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_div_8_twopass_subtile_with_zero)1661*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_div_8_twopass_subtile_with_zero) {
1662*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
1663*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
1664*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 16; channels < 64; channels += 8) {
1665*4bdc9457SAndroid Build Coastguard Worker         for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
1666*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
1667*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
1668*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 8)
1669*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
1670*4bdc9457SAndroid Build Coastguard Worker             .input_offset(67)
1671*4bdc9457SAndroid Build Coastguard Worker             .zero_index(zero_index)
1672*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
1673*4bdc9457SAndroid Build Coastguard Worker         }
1674*4bdc9457SAndroid Build Coastguard Worker       }
1675*4bdc9457SAndroid Build Coastguard Worker     }
1676*4bdc9457SAndroid Build Coastguard Worker   }
1677*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_lt_8_twopass_fulltile)1678*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_lt_8_twopass_fulltile) {
1679*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
1680*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 1; channels < 8; channels++) {
1681*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
1682*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(17)
1683*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
1684*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1685*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
1686*4bdc9457SAndroid Build Coastguard Worker     }
1687*4bdc9457SAndroid Build Coastguard Worker   }
1688*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_lt_8_twopass_fulltile_with_input_offset)1689*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_lt_8_twopass_fulltile_with_input_offset) {
1690*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
1691*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 1; channels < 8; channels++) {
1692*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
1693*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(17)
1694*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
1695*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1696*4bdc9457SAndroid Build Coastguard Worker         .input_offset(11)
1697*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
1698*4bdc9457SAndroid Build Coastguard Worker     }
1699*4bdc9457SAndroid Build Coastguard Worker   }
1700*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_lt_8_twopass_fulltile_with_zero_index)1701*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_lt_8_twopass_fulltile_with_zero_index) {
1702*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
1703*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 1; channels < 8; channels++) {
1704*4bdc9457SAndroid Build Coastguard Worker       for (size_t zero_index = 0; zero_index < 17; zero_index++) {
1705*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
1706*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(17)
1707*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
1708*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
1709*4bdc9457SAndroid Build Coastguard Worker           .input_offset(11)
1710*4bdc9457SAndroid Build Coastguard Worker           .zero_index(zero_index)
1711*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
1712*4bdc9457SAndroid Build Coastguard Worker       }
1713*4bdc9457SAndroid Build Coastguard Worker     }
1714*4bdc9457SAndroid Build Coastguard Worker   }
1715*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_lt_8_twopass_fulltile_with_input_scale)1716*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_lt_8_twopass_fulltile_with_input_scale) {
1717*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
1718*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 1; channels < 8; channels++) {
1719*4bdc9457SAndroid Build Coastguard Worker       for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
1720*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
1721*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(17)
1722*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
1723*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
1724*4bdc9457SAndroid Build Coastguard Worker           .input_scale(scale)
1725*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
1726*4bdc9457SAndroid Build Coastguard Worker       }
1727*4bdc9457SAndroid Build Coastguard Worker     }
1728*4bdc9457SAndroid Build Coastguard Worker   }
1729*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_lt_8_twopass_fulltile_with_input_zero_point)1730*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_lt_8_twopass_fulltile_with_input_zero_point) {
1731*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
1732*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 1; channels < 8; channels++) {
1733*4bdc9457SAndroid Build Coastguard Worker       for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
1734*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
1735*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(17)
1736*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
1737*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
1738*4bdc9457SAndroid Build Coastguard Worker           .input_zero_point(zero_point)
1739*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
1740*4bdc9457SAndroid Build Coastguard Worker       }
1741*4bdc9457SAndroid Build Coastguard Worker     }
1742*4bdc9457SAndroid Build Coastguard Worker   }
1743*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_lt_8_twopass_fulltile_with_output_scale)1744*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_lt_8_twopass_fulltile_with_output_scale) {
1745*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
1746*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 1; channels < 8; channels++) {
1747*4bdc9457SAndroid Build Coastguard Worker       for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
1748*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
1749*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(17)
1750*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
1751*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
1752*4bdc9457SAndroid Build Coastguard Worker           .output_scale(scale)
1753*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
1754*4bdc9457SAndroid Build Coastguard Worker       }
1755*4bdc9457SAndroid Build Coastguard Worker     }
1756*4bdc9457SAndroid Build Coastguard Worker   }
1757*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_lt_8_twopass_fulltile_with_output_zero_point)1758*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_lt_8_twopass_fulltile_with_output_zero_point) {
1759*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
1760*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 1; channels < 8; channels++) {
1761*4bdc9457SAndroid Build Coastguard Worker       for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
1762*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
1763*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(17)
1764*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
1765*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
1766*4bdc9457SAndroid Build Coastguard Worker           .output_zero_point(zero_point)
1767*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
1768*4bdc9457SAndroid Build Coastguard Worker       }
1769*4bdc9457SAndroid Build Coastguard Worker     }
1770*4bdc9457SAndroid Build Coastguard Worker   }
1771*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_lt_8_twopass_fulltile_with_qmin)1772*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_lt_8_twopass_fulltile_with_qmin) {
1773*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
1774*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 1; channels < 8; channels++) {
1775*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
1776*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(17)
1777*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
1778*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1779*4bdc9457SAndroid Build Coastguard Worker         .qmin(128)
1780*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
1781*4bdc9457SAndroid Build Coastguard Worker     }
1782*4bdc9457SAndroid Build Coastguard Worker   }
1783*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_lt_8_twopass_fulltile_with_qmax)1784*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_lt_8_twopass_fulltile_with_qmax) {
1785*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
1786*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 1; channels < 8; channels++) {
1787*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
1788*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(17)
1789*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
1790*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1791*4bdc9457SAndroid Build Coastguard Worker         .qmax(128)
1792*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
1793*4bdc9457SAndroid Build Coastguard Worker     }
1794*4bdc9457SAndroid Build Coastguard Worker   }
1795*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_lt_8_twopass_subtile)1796*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_lt_8_twopass_subtile) {
1797*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
1798*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
1799*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 1; channels < 8; channels++) {
1800*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
1801*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
1802*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
1803*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
1804*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
1805*4bdc9457SAndroid Build Coastguard Worker       }
1806*4bdc9457SAndroid Build Coastguard Worker     }
1807*4bdc9457SAndroid Build Coastguard Worker   }
1808*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_lt_8_twopass_subtile_with_input_offset)1809*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_lt_8_twopass_subtile_with_input_offset) {
1810*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
1811*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
1812*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 1; channels < 8; channels++) {
1813*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
1814*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
1815*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
1816*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
1817*4bdc9457SAndroid Build Coastguard Worker           .input_offset(11)
1818*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
1819*4bdc9457SAndroid Build Coastguard Worker       }
1820*4bdc9457SAndroid Build Coastguard Worker     }
1821*4bdc9457SAndroid Build Coastguard Worker   }
1822*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_lt_8_twopass_subtile_with_zero)1823*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_lt_8_twopass_subtile_with_zero) {
1824*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
1825*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
1826*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 1; channels < 8; channels++) {
1827*4bdc9457SAndroid Build Coastguard Worker         for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
1828*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
1829*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
1830*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 8)
1831*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
1832*4bdc9457SAndroid Build Coastguard Worker             .input_offset(11)
1833*4bdc9457SAndroid Build Coastguard Worker             .zero_index(zero_index)
1834*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
1835*4bdc9457SAndroid Build Coastguard Worker         }
1836*4bdc9457SAndroid Build Coastguard Worker       }
1837*4bdc9457SAndroid Build Coastguard Worker     }
1838*4bdc9457SAndroid Build Coastguard Worker   }
1839*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_gt_8_twopass_fulltile)1840*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_gt_8_twopass_fulltile) {
1841*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
1842*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 9; channels < 16; channels++) {
1843*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
1844*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(17)
1845*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
1846*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1847*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
1848*4bdc9457SAndroid Build Coastguard Worker     }
1849*4bdc9457SAndroid Build Coastguard Worker   }
1850*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_gt_8_twopass_fulltile_with_input_offset)1851*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_gt_8_twopass_fulltile_with_input_offset) {
1852*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
1853*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 9; channels < 16; channels++) {
1854*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
1855*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(17)
1856*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
1857*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1858*4bdc9457SAndroid Build Coastguard Worker         .input_offset(17)
1859*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
1860*4bdc9457SAndroid Build Coastguard Worker     }
1861*4bdc9457SAndroid Build Coastguard Worker   }
1862*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_gt_8_twopass_fulltile_with_zero)1863*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_gt_8_twopass_fulltile_with_zero) {
1864*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
1865*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 9; channels < 16; channels++) {
1866*4bdc9457SAndroid Build Coastguard Worker       for (size_t zero_index = 0; zero_index < 17; zero_index++) {
1867*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
1868*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(17)
1869*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
1870*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
1871*4bdc9457SAndroid Build Coastguard Worker           .input_offset(17)
1872*4bdc9457SAndroid Build Coastguard Worker           .zero_index(zero_index)
1873*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
1874*4bdc9457SAndroid Build Coastguard Worker       }
1875*4bdc9457SAndroid Build Coastguard Worker     }
1876*4bdc9457SAndroid Build Coastguard Worker   }
1877*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_gt_8_twopass_fulltile_with_input_scale)1878*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_gt_8_twopass_fulltile_with_input_scale) {
1879*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
1880*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 9; channels < 16; channels++) {
1881*4bdc9457SAndroid Build Coastguard Worker       for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
1882*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
1883*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(17)
1884*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
1885*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
1886*4bdc9457SAndroid Build Coastguard Worker           .input_scale(scale)
1887*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
1888*4bdc9457SAndroid Build Coastguard Worker       }
1889*4bdc9457SAndroid Build Coastguard Worker     }
1890*4bdc9457SAndroid Build Coastguard Worker   }
1891*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_gt_8_twopass_fulltile_with_input_zero_point)1892*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_gt_8_twopass_fulltile_with_input_zero_point) {
1893*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
1894*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 9; channels < 16; channels++) {
1895*4bdc9457SAndroid Build Coastguard Worker       for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
1896*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
1897*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(17)
1898*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
1899*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
1900*4bdc9457SAndroid Build Coastguard Worker           .input_zero_point(zero_point)
1901*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
1902*4bdc9457SAndroid Build Coastguard Worker       }
1903*4bdc9457SAndroid Build Coastguard Worker     }
1904*4bdc9457SAndroid Build Coastguard Worker   }
1905*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_gt_8_twopass_fulltile_with_output_scale)1906*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_gt_8_twopass_fulltile_with_output_scale) {
1907*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
1908*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 9; channels < 16; channels++) {
1909*4bdc9457SAndroid Build Coastguard Worker       for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
1910*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
1911*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(17)
1912*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
1913*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
1914*4bdc9457SAndroid Build Coastguard Worker           .output_scale(scale)
1915*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
1916*4bdc9457SAndroid Build Coastguard Worker       }
1917*4bdc9457SAndroid Build Coastguard Worker     }
1918*4bdc9457SAndroid Build Coastguard Worker   }
1919*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_gt_8_twopass_fulltile_with_output_zero_point)1920*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_gt_8_twopass_fulltile_with_output_zero_point) {
1921*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
1922*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 9; channels < 16; channels++) {
1923*4bdc9457SAndroid Build Coastguard Worker       for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
1924*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
1925*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(17)
1926*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
1927*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
1928*4bdc9457SAndroid Build Coastguard Worker           .output_zero_point(zero_point)
1929*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
1930*4bdc9457SAndroid Build Coastguard Worker       }
1931*4bdc9457SAndroid Build Coastguard Worker     }
1932*4bdc9457SAndroid Build Coastguard Worker   }
1933*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_gt_8_twopass_fulltile_with_qmin)1934*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_gt_8_twopass_fulltile_with_qmin) {
1935*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
1936*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 9; channels < 16; channels++) {
1937*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
1938*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(17)
1939*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
1940*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1941*4bdc9457SAndroid Build Coastguard Worker         .qmin(128)
1942*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
1943*4bdc9457SAndroid Build Coastguard Worker     }
1944*4bdc9457SAndroid Build Coastguard Worker   }
1945*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_gt_8_twopass_fulltile_with_qmax)1946*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_gt_8_twopass_fulltile_with_qmax) {
1947*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
1948*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 9; channels < 16; channels++) {
1949*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
1950*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(17)
1951*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
1952*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1953*4bdc9457SAndroid Build Coastguard Worker         .qmax(128)
1954*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
1955*4bdc9457SAndroid Build Coastguard Worker     }
1956*4bdc9457SAndroid Build Coastguard Worker   }
1957*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_gt_8_twopass_subtile)1958*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_gt_8_twopass_subtile) {
1959*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
1960*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
1961*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 9; channels < 16; channels++) {
1962*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
1963*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
1964*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
1965*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
1966*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
1967*4bdc9457SAndroid Build Coastguard Worker       }
1968*4bdc9457SAndroid Build Coastguard Worker     }
1969*4bdc9457SAndroid Build Coastguard Worker   }
1970*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_gt_8_twopass_subtile_with_input_offset)1971*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_gt_8_twopass_subtile_with_input_offset) {
1972*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
1973*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
1974*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 9; channels < 16; channels++) {
1975*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
1976*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
1977*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
1978*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
1979*4bdc9457SAndroid Build Coastguard Worker           .input_offset(17)
1980*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
1981*4bdc9457SAndroid Build Coastguard Worker       }
1982*4bdc9457SAndroid Build Coastguard Worker     }
1983*4bdc9457SAndroid Build Coastguard Worker   }
1984*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_gt_8_twopass_subtile_with_zero)1985*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_gt_8_twopass_subtile_with_zero) {
1986*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
1987*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
1988*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 9; channels < 16; channels++) {
1989*4bdc9457SAndroid Build Coastguard Worker         for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
1990*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
1991*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
1992*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 8)
1993*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
1994*4bdc9457SAndroid Build Coastguard Worker             .input_offset(17)
1995*4bdc9457SAndroid Build Coastguard Worker             .zero_index(zero_index)
1996*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
1997*4bdc9457SAndroid Build Coastguard Worker         }
1998*4bdc9457SAndroid Build Coastguard Worker       }
1999*4bdc9457SAndroid Build Coastguard Worker     }
2000*4bdc9457SAndroid Build Coastguard Worker   }
2001*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_eq_8_multipass)2002*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_eq_8_multipass) {
2003*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
2004*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2005*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
2006*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(pooling_elements)
2007*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
2008*4bdc9457SAndroid Build Coastguard Worker         .channels(8)
2009*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
2010*4bdc9457SAndroid Build Coastguard Worker     }
2011*4bdc9457SAndroid Build Coastguard Worker   }
2012*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_eq_8_multipass_with_input_offset)2013*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_eq_8_multipass_with_input_offset) {
2014*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
2015*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2016*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
2017*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(pooling_elements)
2018*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
2019*4bdc9457SAndroid Build Coastguard Worker         .channels(8)
2020*4bdc9457SAndroid Build Coastguard Worker         .input_offset(11)
2021*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
2022*4bdc9457SAndroid Build Coastguard Worker     }
2023*4bdc9457SAndroid Build Coastguard Worker   }
2024*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_eq_8_multipass_with_zero)2025*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_eq_8_multipass_with_zero) {
2026*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
2027*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2028*4bdc9457SAndroid Build Coastguard Worker       for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
2029*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
2030*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
2031*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
2032*4bdc9457SAndroid Build Coastguard Worker           .channels(8)
2033*4bdc9457SAndroid Build Coastguard Worker           .input_offset(11)
2034*4bdc9457SAndroid Build Coastguard Worker           .zero_index(zero_index)
2035*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
2036*4bdc9457SAndroid Build Coastguard Worker       }
2037*4bdc9457SAndroid Build Coastguard Worker     }
2038*4bdc9457SAndroid Build Coastguard Worker   }
2039*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_eq_8_multipass_with_input_scale)2040*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_eq_8_multipass_with_input_scale) {
2041*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
2042*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2043*4bdc9457SAndroid Build Coastguard Worker       for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
2044*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
2045*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
2046*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
2047*4bdc9457SAndroid Build Coastguard Worker           .channels(8)
2048*4bdc9457SAndroid Build Coastguard Worker           .input_scale(scale)
2049*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
2050*4bdc9457SAndroid Build Coastguard Worker       }
2051*4bdc9457SAndroid Build Coastguard Worker     }
2052*4bdc9457SAndroid Build Coastguard Worker   }
2053*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_eq_8_multipass_with_input_zero_point)2054*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_eq_8_multipass_with_input_zero_point) {
2055*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
2056*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2057*4bdc9457SAndroid Build Coastguard Worker       for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
2058*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
2059*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
2060*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
2061*4bdc9457SAndroid Build Coastguard Worker           .channels(8)
2062*4bdc9457SAndroid Build Coastguard Worker           .input_zero_point(zero_point)
2063*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
2064*4bdc9457SAndroid Build Coastguard Worker       }
2065*4bdc9457SAndroid Build Coastguard Worker     }
2066*4bdc9457SAndroid Build Coastguard Worker   }
2067*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_eq_8_multipass_with_output_scale)2068*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_eq_8_multipass_with_output_scale) {
2069*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
2070*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2071*4bdc9457SAndroid Build Coastguard Worker       for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
2072*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
2073*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
2074*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
2075*4bdc9457SAndroid Build Coastguard Worker           .channels(8)
2076*4bdc9457SAndroid Build Coastguard Worker           .output_scale(scale)
2077*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
2078*4bdc9457SAndroid Build Coastguard Worker       }
2079*4bdc9457SAndroid Build Coastguard Worker     }
2080*4bdc9457SAndroid Build Coastguard Worker   }
2081*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_eq_8_multipass_with_output_zero_point)2082*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_eq_8_multipass_with_output_zero_point) {
2083*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
2084*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2085*4bdc9457SAndroid Build Coastguard Worker       for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
2086*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
2087*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
2088*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
2089*4bdc9457SAndroid Build Coastguard Worker           .channels(8)
2090*4bdc9457SAndroid Build Coastguard Worker           .output_zero_point(zero_point)
2091*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
2092*4bdc9457SAndroid Build Coastguard Worker       }
2093*4bdc9457SAndroid Build Coastguard Worker     }
2094*4bdc9457SAndroid Build Coastguard Worker   }
2095*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_eq_8_multipass_with_qmin)2096*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_eq_8_multipass_with_qmin) {
2097*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
2098*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2099*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
2100*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(pooling_elements)
2101*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
2102*4bdc9457SAndroid Build Coastguard Worker         .channels(8)
2103*4bdc9457SAndroid Build Coastguard Worker         .qmin(128)
2104*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
2105*4bdc9457SAndroid Build Coastguard Worker     }
2106*4bdc9457SAndroid Build Coastguard Worker   }
2107*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_eq_8_multipass_with_qmax)2108*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_eq_8_multipass_with_qmax) {
2109*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
2110*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2111*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
2112*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(pooling_elements)
2113*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
2114*4bdc9457SAndroid Build Coastguard Worker         .channels(8)
2115*4bdc9457SAndroid Build Coastguard Worker         .qmax(128)
2116*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
2117*4bdc9457SAndroid Build Coastguard Worker     }
2118*4bdc9457SAndroid Build Coastguard Worker   }
2119*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_div_8_multipass)2120*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_div_8_multipass) {
2121*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
2122*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2123*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 16; channels < 64; channels += 8) {
2124*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
2125*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
2126*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
2127*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
2128*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
2129*4bdc9457SAndroid Build Coastguard Worker       }
2130*4bdc9457SAndroid Build Coastguard Worker     }
2131*4bdc9457SAndroid Build Coastguard Worker   }
2132*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_div_8_multipass_with_input_offset)2133*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_div_8_multipass_with_input_offset) {
2134*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
2135*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2136*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 16; channels < 64; channels += 8) {
2137*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
2138*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
2139*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
2140*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
2141*4bdc9457SAndroid Build Coastguard Worker           .input_offset(67)
2142*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
2143*4bdc9457SAndroid Build Coastguard Worker       }
2144*4bdc9457SAndroid Build Coastguard Worker     }
2145*4bdc9457SAndroid Build Coastguard Worker   }
2146*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_div_8_multipass_with_zero)2147*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_div_8_multipass_with_zero) {
2148*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
2149*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2150*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 16; channels < 64; channels += 8) {
2151*4bdc9457SAndroid Build Coastguard Worker         for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
2152*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
2153*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
2154*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 8)
2155*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
2156*4bdc9457SAndroid Build Coastguard Worker             .input_offset(67)
2157*4bdc9457SAndroid Build Coastguard Worker             .zero_index(zero_index)
2158*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
2159*4bdc9457SAndroid Build Coastguard Worker         }
2160*4bdc9457SAndroid Build Coastguard Worker       }
2161*4bdc9457SAndroid Build Coastguard Worker     }
2162*4bdc9457SAndroid Build Coastguard Worker   }
2163*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_div_8_multipass_with_input_scale)2164*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_div_8_multipass_with_input_scale) {
2165*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
2166*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2167*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 16; channels < 64; channels += 8) {
2168*4bdc9457SAndroid Build Coastguard Worker         for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
2169*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
2170*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
2171*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 8)
2172*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
2173*4bdc9457SAndroid Build Coastguard Worker             .input_scale(scale)
2174*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
2175*4bdc9457SAndroid Build Coastguard Worker         }
2176*4bdc9457SAndroid Build Coastguard Worker       }
2177*4bdc9457SAndroid Build Coastguard Worker     }
2178*4bdc9457SAndroid Build Coastguard Worker   }
2179*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_div_8_multipass_with_input_zero_point)2180*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_div_8_multipass_with_input_zero_point) {
2181*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
2182*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2183*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 16; channels < 64; channels += 8) {
2184*4bdc9457SAndroid Build Coastguard Worker         for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
2185*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
2186*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
2187*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 8)
2188*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
2189*4bdc9457SAndroid Build Coastguard Worker             .input_zero_point(zero_point)
2190*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
2191*4bdc9457SAndroid Build Coastguard Worker         }
2192*4bdc9457SAndroid Build Coastguard Worker       }
2193*4bdc9457SAndroid Build Coastguard Worker     }
2194*4bdc9457SAndroid Build Coastguard Worker   }
2195*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_div_8_multipass_with_output_scale)2196*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_div_8_multipass_with_output_scale) {
2197*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
2198*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2199*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 16; channels < 64; channels += 8) {
2200*4bdc9457SAndroid Build Coastguard Worker         for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
2201*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
2202*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
2203*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 8)
2204*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
2205*4bdc9457SAndroid Build Coastguard Worker             .output_scale(scale)
2206*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
2207*4bdc9457SAndroid Build Coastguard Worker         }
2208*4bdc9457SAndroid Build Coastguard Worker       }
2209*4bdc9457SAndroid Build Coastguard Worker     }
2210*4bdc9457SAndroid Build Coastguard Worker   }
2211*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_div_8_multipass_with_output_zero_point)2212*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_div_8_multipass_with_output_zero_point) {
2213*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
2214*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2215*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 16; channels < 64; channels += 8) {
2216*4bdc9457SAndroid Build Coastguard Worker         for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
2217*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
2218*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
2219*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 8)
2220*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
2221*4bdc9457SAndroid Build Coastguard Worker             .output_zero_point(zero_point)
2222*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
2223*4bdc9457SAndroid Build Coastguard Worker         }
2224*4bdc9457SAndroid Build Coastguard Worker       }
2225*4bdc9457SAndroid Build Coastguard Worker     }
2226*4bdc9457SAndroid Build Coastguard Worker   }
2227*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_div_8_multipass_with_qmin)2228*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_div_8_multipass_with_qmin) {
2229*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
2230*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2231*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 16; channels < 64; channels += 8) {
2232*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
2233*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
2234*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
2235*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
2236*4bdc9457SAndroid Build Coastguard Worker           .qmin(128)
2237*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
2238*4bdc9457SAndroid Build Coastguard Worker       }
2239*4bdc9457SAndroid Build Coastguard Worker     }
2240*4bdc9457SAndroid Build Coastguard Worker   }
2241*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_div_8_multipass_with_qmax)2242*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_div_8_multipass_with_qmax) {
2243*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
2244*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2245*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 16; channels < 64; channels += 8) {
2246*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
2247*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
2248*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
2249*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
2250*4bdc9457SAndroid Build Coastguard Worker           .qmax(128)
2251*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
2252*4bdc9457SAndroid Build Coastguard Worker       }
2253*4bdc9457SAndroid Build Coastguard Worker     }
2254*4bdc9457SAndroid Build Coastguard Worker   }
2255*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_lt_8_multipass)2256*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_lt_8_multipass) {
2257*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
2258*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2259*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 1; channels < 8; channels++) {
2260*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
2261*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
2262*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
2263*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
2264*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
2265*4bdc9457SAndroid Build Coastguard Worker       }
2266*4bdc9457SAndroid Build Coastguard Worker     }
2267*4bdc9457SAndroid Build Coastguard Worker   }
2268*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_lt_8_multipass_with_input_offset)2269*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_lt_8_multipass_with_input_offset) {
2270*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
2271*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2272*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 1; channels < 8; channels++) {
2273*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
2274*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
2275*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
2276*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
2277*4bdc9457SAndroid Build Coastguard Worker           .input_offset(8)
2278*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
2279*4bdc9457SAndroid Build Coastguard Worker       }
2280*4bdc9457SAndroid Build Coastguard Worker     }
2281*4bdc9457SAndroid Build Coastguard Worker   }
2282*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_lt_8_multipass_with_zero)2283*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_lt_8_multipass_with_zero) {
2284*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
2285*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2286*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 1; channels < 8; channels++) {
2287*4bdc9457SAndroid Build Coastguard Worker         for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
2288*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
2289*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
2290*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 8)
2291*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
2292*4bdc9457SAndroid Build Coastguard Worker             .input_offset(8)
2293*4bdc9457SAndroid Build Coastguard Worker             .zero_index(zero_index)
2294*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
2295*4bdc9457SAndroid Build Coastguard Worker         }
2296*4bdc9457SAndroid Build Coastguard Worker       }
2297*4bdc9457SAndroid Build Coastguard Worker     }
2298*4bdc9457SAndroid Build Coastguard Worker   }
2299*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_lt_8_multipass_with_input_scale)2300*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_lt_8_multipass_with_input_scale) {
2301*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
2302*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2303*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 1; channels < 8; channels++) {
2304*4bdc9457SAndroid Build Coastguard Worker         for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
2305*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
2306*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
2307*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 8)
2308*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
2309*4bdc9457SAndroid Build Coastguard Worker             .input_scale(scale)
2310*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
2311*4bdc9457SAndroid Build Coastguard Worker         }
2312*4bdc9457SAndroid Build Coastguard Worker       }
2313*4bdc9457SAndroid Build Coastguard Worker     }
2314*4bdc9457SAndroid Build Coastguard Worker   }
2315*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_lt_8_multipass_with_input_zero_point)2316*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_lt_8_multipass_with_input_zero_point) {
2317*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
2318*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2319*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 1; channels < 8; channels++) {
2320*4bdc9457SAndroid Build Coastguard Worker         for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
2321*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
2322*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
2323*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 8)
2324*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
2325*4bdc9457SAndroid Build Coastguard Worker             .input_zero_point(zero_point)
2326*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
2327*4bdc9457SAndroid Build Coastguard Worker         }
2328*4bdc9457SAndroid Build Coastguard Worker       }
2329*4bdc9457SAndroid Build Coastguard Worker     }
2330*4bdc9457SAndroid Build Coastguard Worker   }
2331*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_lt_8_multipass_with_output_scale)2332*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_lt_8_multipass_with_output_scale) {
2333*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
2334*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2335*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 1; channels < 8; channels++) {
2336*4bdc9457SAndroid Build Coastguard Worker         for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
2337*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
2338*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
2339*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 8)
2340*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
2341*4bdc9457SAndroid Build Coastguard Worker             .output_scale(scale)
2342*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
2343*4bdc9457SAndroid Build Coastguard Worker         }
2344*4bdc9457SAndroid Build Coastguard Worker       }
2345*4bdc9457SAndroid Build Coastguard Worker     }
2346*4bdc9457SAndroid Build Coastguard Worker   }
2347*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_lt_8_multipass_with_output_zero_point)2348*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_lt_8_multipass_with_output_zero_point) {
2349*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
2350*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2351*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 1; channels < 8; channels++) {
2352*4bdc9457SAndroid Build Coastguard Worker         for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
2353*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
2354*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
2355*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 8)
2356*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
2357*4bdc9457SAndroid Build Coastguard Worker             .output_zero_point(zero_point)
2358*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
2359*4bdc9457SAndroid Build Coastguard Worker         }
2360*4bdc9457SAndroid Build Coastguard Worker       }
2361*4bdc9457SAndroid Build Coastguard Worker     }
2362*4bdc9457SAndroid Build Coastguard Worker   }
2363*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_lt_8_multipass_with_qmin)2364*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_lt_8_multipass_with_qmin) {
2365*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
2366*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2367*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 1; channels < 8; channels++) {
2368*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
2369*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
2370*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
2371*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
2372*4bdc9457SAndroid Build Coastguard Worker           .qmin(128)
2373*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
2374*4bdc9457SAndroid Build Coastguard Worker       }
2375*4bdc9457SAndroid Build Coastguard Worker     }
2376*4bdc9457SAndroid Build Coastguard Worker   }
2377*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_lt_8_multipass_with_qmax)2378*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_lt_8_multipass_with_qmax) {
2379*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
2380*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2381*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 1; channels < 8; channels++) {
2382*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
2383*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
2384*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
2385*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
2386*4bdc9457SAndroid Build Coastguard Worker           .qmax(128)
2387*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
2388*4bdc9457SAndroid Build Coastguard Worker       }
2389*4bdc9457SAndroid Build Coastguard Worker     }
2390*4bdc9457SAndroid Build Coastguard Worker   }
2391*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_gt_8_multipass)2392*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_gt_8_multipass) {
2393*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
2394*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2395*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 9; channels < 16; channels++) {
2396*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
2397*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
2398*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
2399*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
2400*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
2401*4bdc9457SAndroid Build Coastguard Worker       }
2402*4bdc9457SAndroid Build Coastguard Worker     }
2403*4bdc9457SAndroid Build Coastguard Worker   }
2404*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_gt_8_multipass_with_input_offset)2405*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_gt_8_multipass_with_input_offset) {
2406*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
2407*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2408*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 9; channels < 16; channels++) {
2409*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
2410*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
2411*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
2412*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
2413*4bdc9457SAndroid Build Coastguard Worker           .input_offset(17)
2414*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
2415*4bdc9457SAndroid Build Coastguard Worker       }
2416*4bdc9457SAndroid Build Coastguard Worker     }
2417*4bdc9457SAndroid Build Coastguard Worker   }
2418*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_gt_8_multipass_with_zero)2419*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_gt_8_multipass_with_zero) {
2420*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
2421*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2422*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 9; channels < 16; channels++) {
2423*4bdc9457SAndroid Build Coastguard Worker         for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
2424*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
2425*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
2426*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 8)
2427*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
2428*4bdc9457SAndroid Build Coastguard Worker             .input_offset(17)
2429*4bdc9457SAndroid Build Coastguard Worker             .zero_index(zero_index)
2430*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
2431*4bdc9457SAndroid Build Coastguard Worker         }
2432*4bdc9457SAndroid Build Coastguard Worker       }
2433*4bdc9457SAndroid Build Coastguard Worker     }
2434*4bdc9457SAndroid Build Coastguard Worker   }
2435*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_gt_8_multipass_with_input_scale)2436*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_gt_8_multipass_with_input_scale) {
2437*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
2438*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2439*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 9; channels < 16; channels++) {
2440*4bdc9457SAndroid Build Coastguard Worker         for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
2441*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
2442*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
2443*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 8)
2444*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
2445*4bdc9457SAndroid Build Coastguard Worker             .input_scale(scale)
2446*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
2447*4bdc9457SAndroid Build Coastguard Worker         }
2448*4bdc9457SAndroid Build Coastguard Worker       }
2449*4bdc9457SAndroid Build Coastguard Worker     }
2450*4bdc9457SAndroid Build Coastguard Worker   }
2451*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_gt_8_multipass_with_input_zero_point)2452*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_gt_8_multipass_with_input_zero_point) {
2453*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
2454*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2455*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 9; channels < 16; channels++) {
2456*4bdc9457SAndroid Build Coastguard Worker         for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
2457*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
2458*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
2459*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 8)
2460*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
2461*4bdc9457SAndroid Build Coastguard Worker             .input_zero_point(zero_point)
2462*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
2463*4bdc9457SAndroid Build Coastguard Worker         }
2464*4bdc9457SAndroid Build Coastguard Worker       }
2465*4bdc9457SAndroid Build Coastguard Worker     }
2466*4bdc9457SAndroid Build Coastguard Worker   }
2467*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_gt_8_multipass_with_output_scale)2468*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_gt_8_multipass_with_output_scale) {
2469*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
2470*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2471*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 9; channels < 16; channels++) {
2472*4bdc9457SAndroid Build Coastguard Worker         for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
2473*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
2474*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
2475*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 8)
2476*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
2477*4bdc9457SAndroid Build Coastguard Worker             .output_scale(scale)
2478*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
2479*4bdc9457SAndroid Build Coastguard Worker         }
2480*4bdc9457SAndroid Build Coastguard Worker       }
2481*4bdc9457SAndroid Build Coastguard Worker     }
2482*4bdc9457SAndroid Build Coastguard Worker   }
2483*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_gt_8_multipass_with_output_zero_point)2484*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_gt_8_multipass_with_output_zero_point) {
2485*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
2486*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2487*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 9; channels < 16; channels++) {
2488*4bdc9457SAndroid Build Coastguard Worker         for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
2489*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
2490*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
2491*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 8)
2492*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
2493*4bdc9457SAndroid Build Coastguard Worker             .output_zero_point(zero_point)
2494*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
2495*4bdc9457SAndroid Build Coastguard Worker         }
2496*4bdc9457SAndroid Build Coastguard Worker       }
2497*4bdc9457SAndroid Build Coastguard Worker     }
2498*4bdc9457SAndroid Build Coastguard Worker   }
2499*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_gt_8_multipass_with_qmin)2500*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_gt_8_multipass_with_qmin) {
2501*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
2502*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2503*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 9; channels < 16; channels++) {
2504*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
2505*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
2506*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
2507*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
2508*4bdc9457SAndroid Build Coastguard Worker           .qmin(128)
2509*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
2510*4bdc9457SAndroid Build Coastguard Worker       }
2511*4bdc9457SAndroid Build Coastguard Worker     }
2512*4bdc9457SAndroid Build Coastguard Worker   }
2513*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,channels_gt_8_multipass_with_qmax)2514*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, channels_gt_8_multipass_with_qmax) {
2515*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
2516*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2517*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 9; channels < 16; channels++) {
2518*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
2519*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
2520*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
2521*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
2522*4bdc9457SAndroid Build Coastguard Worker           .qmax(128)
2523*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
2524*4bdc9457SAndroid Build Coastguard Worker       }
2525*4bdc9457SAndroid Build Coastguard Worker     }
2526*4bdc9457SAndroid Build Coastguard Worker   }
2527*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,few_output_pixels)2528*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, few_output_pixels) {
2529*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
2530*4bdc9457SAndroid Build Coastguard Worker     for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
2531*4bdc9457SAndroid Build Coastguard Worker       for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
2532*4bdc9457SAndroid Build Coastguard Worker         for (size_t channels = 1; channels <= 40; channels += 7) {
2533*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
2534*4bdc9457SAndroid Build Coastguard Worker             .output_pixels(output_pixels)
2535*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
2536*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 8)
2537*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
2538*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
2539*4bdc9457SAndroid Build Coastguard Worker         }
2540*4bdc9457SAndroid Build Coastguard Worker       }
2541*4bdc9457SAndroid Build Coastguard Worker     }
2542*4bdc9457SAndroid Build Coastguard Worker   }
2543*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,few_output_pixels_with_input_offset)2544*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, few_output_pixels_with_input_offset) {
2545*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
2546*4bdc9457SAndroid Build Coastguard Worker     for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
2547*4bdc9457SAndroid Build Coastguard Worker       for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
2548*4bdc9457SAndroid Build Coastguard Worker         for (size_t channels = 1; channels <= 40; channels += 7) {
2549*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
2550*4bdc9457SAndroid Build Coastguard Worker             .output_pixels(output_pixels)
2551*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
2552*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 8)
2553*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
2554*4bdc9457SAndroid Build Coastguard Worker             .input_offset(43)
2555*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
2556*4bdc9457SAndroid Build Coastguard Worker         }
2557*4bdc9457SAndroid Build Coastguard Worker       }
2558*4bdc9457SAndroid Build Coastguard Worker     }
2559*4bdc9457SAndroid Build Coastguard Worker   }
2560*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,few_output_pixels_with_zero)2561*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, few_output_pixels_with_zero) {
2562*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
2563*4bdc9457SAndroid Build Coastguard Worker     for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
2564*4bdc9457SAndroid Build Coastguard Worker       for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
2565*4bdc9457SAndroid Build Coastguard Worker         for (size_t channels = 1; channels <= 40; channels += 7) {
2566*4bdc9457SAndroid Build Coastguard Worker           for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
2567*4bdc9457SAndroid Build Coastguard Worker             AvgPoolMicrokernelTester()
2568*4bdc9457SAndroid Build Coastguard Worker               .output_pixels(output_pixels)
2569*4bdc9457SAndroid Build Coastguard Worker               .pooling_elements(pooling_elements)
2570*4bdc9457SAndroid Build Coastguard Worker               .pooling_tile(9, 8)
2571*4bdc9457SAndroid Build Coastguard Worker               .channels(channels)
2572*4bdc9457SAndroid Build Coastguard Worker               .input_offset(43)
2573*4bdc9457SAndroid Build Coastguard Worker               .zero_index(zero_index)
2574*4bdc9457SAndroid Build Coastguard Worker               .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
2575*4bdc9457SAndroid Build Coastguard Worker           }
2576*4bdc9457SAndroid Build Coastguard Worker         }
2577*4bdc9457SAndroid Build Coastguard Worker       }
2578*4bdc9457SAndroid Build Coastguard Worker     }
2579*4bdc9457SAndroid Build Coastguard Worker   }
2580*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,few_output_pixels_with_input_scale)2581*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, few_output_pixels_with_input_scale) {
2582*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
2583*4bdc9457SAndroid Build Coastguard Worker     for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
2584*4bdc9457SAndroid Build Coastguard Worker       for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
2585*4bdc9457SAndroid Build Coastguard Worker         for (size_t channels = 1; channels <= 40; channels += 7) {
2586*4bdc9457SAndroid Build Coastguard Worker           for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
2587*4bdc9457SAndroid Build Coastguard Worker             AvgPoolMicrokernelTester()
2588*4bdc9457SAndroid Build Coastguard Worker               .output_pixels(output_pixels)
2589*4bdc9457SAndroid Build Coastguard Worker               .pooling_elements(pooling_elements)
2590*4bdc9457SAndroid Build Coastguard Worker               .pooling_tile(9, 8)
2591*4bdc9457SAndroid Build Coastguard Worker               .channels(channels)
2592*4bdc9457SAndroid Build Coastguard Worker               .input_scale(scale)
2593*4bdc9457SAndroid Build Coastguard Worker               .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
2594*4bdc9457SAndroid Build Coastguard Worker           }
2595*4bdc9457SAndroid Build Coastguard Worker         }
2596*4bdc9457SAndroid Build Coastguard Worker       }
2597*4bdc9457SAndroid Build Coastguard Worker     }
2598*4bdc9457SAndroid Build Coastguard Worker   }
2599*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,few_output_pixels_with_input_zero_point)2600*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, few_output_pixels_with_input_zero_point) {
2601*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
2602*4bdc9457SAndroid Build Coastguard Worker     for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
2603*4bdc9457SAndroid Build Coastguard Worker       for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
2604*4bdc9457SAndroid Build Coastguard Worker         for (size_t channels = 1; channels <= 40; channels += 7) {
2605*4bdc9457SAndroid Build Coastguard Worker           for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
2606*4bdc9457SAndroid Build Coastguard Worker             AvgPoolMicrokernelTester()
2607*4bdc9457SAndroid Build Coastguard Worker               .output_pixels(output_pixels)
2608*4bdc9457SAndroid Build Coastguard Worker               .pooling_elements(pooling_elements)
2609*4bdc9457SAndroid Build Coastguard Worker               .pooling_tile(9, 8)
2610*4bdc9457SAndroid Build Coastguard Worker               .channels(channels)
2611*4bdc9457SAndroid Build Coastguard Worker               .input_zero_point(zero_point)
2612*4bdc9457SAndroid Build Coastguard Worker               .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
2613*4bdc9457SAndroid Build Coastguard Worker           }
2614*4bdc9457SAndroid Build Coastguard Worker         }
2615*4bdc9457SAndroid Build Coastguard Worker       }
2616*4bdc9457SAndroid Build Coastguard Worker     }
2617*4bdc9457SAndroid Build Coastguard Worker   }
2618*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,few_output_pixels_with_output_scale)2619*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, few_output_pixels_with_output_scale) {
2620*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
2621*4bdc9457SAndroid Build Coastguard Worker     for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
2622*4bdc9457SAndroid Build Coastguard Worker       for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
2623*4bdc9457SAndroid Build Coastguard Worker         for (size_t channels = 1; channels <= 40; channels += 7) {
2624*4bdc9457SAndroid Build Coastguard Worker           for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
2625*4bdc9457SAndroid Build Coastguard Worker             AvgPoolMicrokernelTester()
2626*4bdc9457SAndroid Build Coastguard Worker               .output_pixels(output_pixels)
2627*4bdc9457SAndroid Build Coastguard Worker               .pooling_elements(pooling_elements)
2628*4bdc9457SAndroid Build Coastguard Worker               .pooling_tile(9, 8)
2629*4bdc9457SAndroid Build Coastguard Worker               .channels(channels)
2630*4bdc9457SAndroid Build Coastguard Worker               .output_scale(scale)
2631*4bdc9457SAndroid Build Coastguard Worker               .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
2632*4bdc9457SAndroid Build Coastguard Worker           }
2633*4bdc9457SAndroid Build Coastguard Worker         }
2634*4bdc9457SAndroid Build Coastguard Worker       }
2635*4bdc9457SAndroid Build Coastguard Worker     }
2636*4bdc9457SAndroid Build Coastguard Worker   }
2637*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,few_output_pixels_with_output_zero_point)2638*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, few_output_pixels_with_output_zero_point) {
2639*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
2640*4bdc9457SAndroid Build Coastguard Worker     for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
2641*4bdc9457SAndroid Build Coastguard Worker       for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
2642*4bdc9457SAndroid Build Coastguard Worker         for (size_t channels = 1; channels <= 40; channels += 7) {
2643*4bdc9457SAndroid Build Coastguard Worker           for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
2644*4bdc9457SAndroid Build Coastguard Worker             AvgPoolMicrokernelTester()
2645*4bdc9457SAndroid Build Coastguard Worker               .output_pixels(output_pixels)
2646*4bdc9457SAndroid Build Coastguard Worker               .pooling_elements(pooling_elements)
2647*4bdc9457SAndroid Build Coastguard Worker               .pooling_tile(9, 8)
2648*4bdc9457SAndroid Build Coastguard Worker               .channels(channels)
2649*4bdc9457SAndroid Build Coastguard Worker               .output_zero_point(zero_point)
2650*4bdc9457SAndroid Build Coastguard Worker               .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
2651*4bdc9457SAndroid Build Coastguard Worker           }
2652*4bdc9457SAndroid Build Coastguard Worker         }
2653*4bdc9457SAndroid Build Coastguard Worker       }
2654*4bdc9457SAndroid Build Coastguard Worker     }
2655*4bdc9457SAndroid Build Coastguard Worker   }
2656*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,few_output_pixels_with_qmin)2657*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, few_output_pixels_with_qmin) {
2658*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
2659*4bdc9457SAndroid Build Coastguard Worker     for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
2660*4bdc9457SAndroid Build Coastguard Worker       for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
2661*4bdc9457SAndroid Build Coastguard Worker         for (size_t channels = 1; channels <= 40; channels += 7) {
2662*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
2663*4bdc9457SAndroid Build Coastguard Worker             .output_pixels(output_pixels)
2664*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
2665*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 8)
2666*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
2667*4bdc9457SAndroid Build Coastguard Worker             .qmin(128)
2668*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
2669*4bdc9457SAndroid Build Coastguard Worker         }
2670*4bdc9457SAndroid Build Coastguard Worker       }
2671*4bdc9457SAndroid Build Coastguard Worker     }
2672*4bdc9457SAndroid Build Coastguard Worker   }
2673*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,few_output_pixels_with_qmax)2674*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, few_output_pixels_with_qmax) {
2675*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
2676*4bdc9457SAndroid Build Coastguard Worker     for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
2677*4bdc9457SAndroid Build Coastguard Worker       for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
2678*4bdc9457SAndroid Build Coastguard Worker         for (size_t channels = 1; channels <= 40; channels += 7) {
2679*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
2680*4bdc9457SAndroid Build Coastguard Worker             .output_pixels(output_pixels)
2681*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
2682*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 8)
2683*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
2684*4bdc9457SAndroid Build Coastguard Worker             .qmax(128)
2685*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
2686*4bdc9457SAndroid Build Coastguard Worker         }
2687*4bdc9457SAndroid Build Coastguard Worker       }
2688*4bdc9457SAndroid Build Coastguard Worker     }
2689*4bdc9457SAndroid Build Coastguard Worker   }
2690*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,few_output_pixels_with_output_stride)2691*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, few_output_pixels_with_output_stride) {
2692*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
2693*4bdc9457SAndroid Build Coastguard Worker     for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
2694*4bdc9457SAndroid Build Coastguard Worker       for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
2695*4bdc9457SAndroid Build Coastguard Worker         for (size_t channels = 1; channels <= 40; channels += 7) {
2696*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
2697*4bdc9457SAndroid Build Coastguard Worker             .output_pixels(output_pixels)
2698*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
2699*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 8)
2700*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
2701*4bdc9457SAndroid Build Coastguard Worker             .output_stride(43)
2702*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
2703*4bdc9457SAndroid Build Coastguard Worker         }
2704*4bdc9457SAndroid Build Coastguard Worker       }
2705*4bdc9457SAndroid Build Coastguard Worker     }
2706*4bdc9457SAndroid Build Coastguard Worker   }
2707*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8,few_output_pixels_with_step)2708*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9P8X__SSE2_C8, few_output_pixels_with_step) {
2709*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
2710*4bdc9457SAndroid Build Coastguard Worker     for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
2711*4bdc9457SAndroid Build Coastguard Worker       for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
2712*4bdc9457SAndroid Build Coastguard Worker         for (size_t channels = 1; channels <= 40; channels += 7) {
2713*4bdc9457SAndroid Build Coastguard Worker           for (size_t step = 2; step <= pooling_elements; step++) {
2714*4bdc9457SAndroid Build Coastguard Worker             AvgPoolMicrokernelTester()
2715*4bdc9457SAndroid Build Coastguard Worker               .output_pixels(output_pixels)
2716*4bdc9457SAndroid Build Coastguard Worker               .pooling_elements(pooling_elements)
2717*4bdc9457SAndroid Build Coastguard Worker               .pooling_tile(9, 8)
2718*4bdc9457SAndroid Build Coastguard Worker               .step(step)
2719*4bdc9457SAndroid Build Coastguard Worker               .channels(channels)
2720*4bdc9457SAndroid Build Coastguard Worker               .output_stride(43)
2721*4bdc9457SAndroid Build Coastguard Worker               .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
2722*4bdc9457SAndroid Build Coastguard Worker           }
2723*4bdc9457SAndroid Build Coastguard Worker         }
2724*4bdc9457SAndroid Build Coastguard Worker       }
2725*4bdc9457SAndroid Build Coastguard Worker     }
2726*4bdc9457SAndroid Build Coastguard Worker   }
2727*4bdc9457SAndroid Build Coastguard Worker #endif  // XNN_ARCH_X86 || XNN_ARCH_X86_64
2728*4bdc9457SAndroid Build Coastguard Worker 
2729*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_eq_1_twopass_fulltile)2730*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_eq_1_twopass_fulltile) {
2731*4bdc9457SAndroid Build Coastguard Worker   AvgPoolMicrokernelTester()
2732*4bdc9457SAndroid Build Coastguard Worker     .pooling_elements(17)
2733*4bdc9457SAndroid Build Coastguard Worker     .pooling_tile(9, 8)
2734*4bdc9457SAndroid Build Coastguard Worker     .channels(1)
2735*4bdc9457SAndroid Build Coastguard Worker     .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
2736*4bdc9457SAndroid Build Coastguard Worker }
2737*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_eq_1_twopass_fulltile_with_input_offset)2738*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_eq_1_twopass_fulltile_with_input_offset) {
2739*4bdc9457SAndroid Build Coastguard Worker   AvgPoolMicrokernelTester()
2740*4bdc9457SAndroid Build Coastguard Worker     .pooling_elements(17)
2741*4bdc9457SAndroid Build Coastguard Worker     .pooling_tile(9, 8)
2742*4bdc9457SAndroid Build Coastguard Worker     .channels(1)
2743*4bdc9457SAndroid Build Coastguard Worker     .input_offset(3)
2744*4bdc9457SAndroid Build Coastguard Worker     .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
2745*4bdc9457SAndroid Build Coastguard Worker }
2746*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_eq_1_twopass_fulltile_with_zero)2747*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_eq_1_twopass_fulltile_with_zero) {
2748*4bdc9457SAndroid Build Coastguard Worker   for (size_t zero_index = 0; zero_index < 17; zero_index++) {
2749*4bdc9457SAndroid Build Coastguard Worker     AvgPoolMicrokernelTester()
2750*4bdc9457SAndroid Build Coastguard Worker       .pooling_elements(17)
2751*4bdc9457SAndroid Build Coastguard Worker       .pooling_tile(9, 8)
2752*4bdc9457SAndroid Build Coastguard Worker       .channels(1)
2753*4bdc9457SAndroid Build Coastguard Worker       .input_offset(3)
2754*4bdc9457SAndroid Build Coastguard Worker       .zero_index(zero_index)
2755*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
2756*4bdc9457SAndroid Build Coastguard Worker   }
2757*4bdc9457SAndroid Build Coastguard Worker }
2758*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_eq_1_twopass_fulltile_with_input_scale)2759*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_eq_1_twopass_fulltile_with_input_scale) {
2760*4bdc9457SAndroid Build Coastguard Worker   for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
2761*4bdc9457SAndroid Build Coastguard Worker     AvgPoolMicrokernelTester()
2762*4bdc9457SAndroid Build Coastguard Worker       .pooling_elements(17)
2763*4bdc9457SAndroid Build Coastguard Worker       .pooling_tile(9, 8)
2764*4bdc9457SAndroid Build Coastguard Worker       .channels(1)
2765*4bdc9457SAndroid Build Coastguard Worker       .input_scale(scale)
2766*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
2767*4bdc9457SAndroid Build Coastguard Worker   }
2768*4bdc9457SAndroid Build Coastguard Worker }
2769*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_eq_1_twopass_fulltile_with_input_zero_point)2770*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_eq_1_twopass_fulltile_with_input_zero_point) {
2771*4bdc9457SAndroid Build Coastguard Worker   for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
2772*4bdc9457SAndroid Build Coastguard Worker     AvgPoolMicrokernelTester()
2773*4bdc9457SAndroid Build Coastguard Worker       .pooling_elements(17)
2774*4bdc9457SAndroid Build Coastguard Worker       .pooling_tile(9, 8)
2775*4bdc9457SAndroid Build Coastguard Worker       .channels(1)
2776*4bdc9457SAndroid Build Coastguard Worker       .input_zero_point(zero_point)
2777*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
2778*4bdc9457SAndroid Build Coastguard Worker   }
2779*4bdc9457SAndroid Build Coastguard Worker }
2780*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_eq_1_twopass_fulltile_with_output_scale)2781*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_eq_1_twopass_fulltile_with_output_scale) {
2782*4bdc9457SAndroid Build Coastguard Worker   for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
2783*4bdc9457SAndroid Build Coastguard Worker     AvgPoolMicrokernelTester()
2784*4bdc9457SAndroid Build Coastguard Worker       .pooling_elements(17)
2785*4bdc9457SAndroid Build Coastguard Worker       .pooling_tile(9, 8)
2786*4bdc9457SAndroid Build Coastguard Worker       .channels(1)
2787*4bdc9457SAndroid Build Coastguard Worker       .output_scale(scale)
2788*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
2789*4bdc9457SAndroid Build Coastguard Worker   }
2790*4bdc9457SAndroid Build Coastguard Worker }
2791*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_eq_1_twopass_fulltile_with_output_zero_point)2792*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_eq_1_twopass_fulltile_with_output_zero_point) {
2793*4bdc9457SAndroid Build Coastguard Worker   for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
2794*4bdc9457SAndroid Build Coastguard Worker     AvgPoolMicrokernelTester()
2795*4bdc9457SAndroid Build Coastguard Worker       .pooling_elements(17)
2796*4bdc9457SAndroid Build Coastguard Worker       .pooling_tile(9, 8)
2797*4bdc9457SAndroid Build Coastguard Worker       .channels(1)
2798*4bdc9457SAndroid Build Coastguard Worker       .output_zero_point(zero_point)
2799*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
2800*4bdc9457SAndroid Build Coastguard Worker   }
2801*4bdc9457SAndroid Build Coastguard Worker }
2802*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_eq_1_twopass_fulltile_with_qmin)2803*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_eq_1_twopass_fulltile_with_qmin) {
2804*4bdc9457SAndroid Build Coastguard Worker   AvgPoolMicrokernelTester()
2805*4bdc9457SAndroid Build Coastguard Worker     .pooling_elements(17)
2806*4bdc9457SAndroid Build Coastguard Worker     .pooling_tile(9, 8)
2807*4bdc9457SAndroid Build Coastguard Worker     .channels(1)
2808*4bdc9457SAndroid Build Coastguard Worker     .qmin(128)
2809*4bdc9457SAndroid Build Coastguard Worker     .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
2810*4bdc9457SAndroid Build Coastguard Worker }
2811*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_eq_1_twopass_fulltile_with_qmax)2812*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_eq_1_twopass_fulltile_with_qmax) {
2813*4bdc9457SAndroid Build Coastguard Worker   AvgPoolMicrokernelTester()
2814*4bdc9457SAndroid Build Coastguard Worker     .pooling_elements(17)
2815*4bdc9457SAndroid Build Coastguard Worker     .pooling_tile(9, 8)
2816*4bdc9457SAndroid Build Coastguard Worker     .channels(1)
2817*4bdc9457SAndroid Build Coastguard Worker     .qmax(128)
2818*4bdc9457SAndroid Build Coastguard Worker     .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
2819*4bdc9457SAndroid Build Coastguard Worker }
2820*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_eq_1_twopass_subtile)2821*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_eq_1_twopass_subtile) {
2822*4bdc9457SAndroid Build Coastguard Worker   for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
2823*4bdc9457SAndroid Build Coastguard Worker     AvgPoolMicrokernelTester()
2824*4bdc9457SAndroid Build Coastguard Worker       .pooling_elements(pooling_elements)
2825*4bdc9457SAndroid Build Coastguard Worker       .pooling_tile(9, 8)
2826*4bdc9457SAndroid Build Coastguard Worker       .channels(1)
2827*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
2828*4bdc9457SAndroid Build Coastguard Worker   }
2829*4bdc9457SAndroid Build Coastguard Worker }
2830*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_eq_1_twopass_subtile_with_input_offset)2831*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_eq_1_twopass_subtile_with_input_offset) {
2832*4bdc9457SAndroid Build Coastguard Worker   for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
2833*4bdc9457SAndroid Build Coastguard Worker     AvgPoolMicrokernelTester()
2834*4bdc9457SAndroid Build Coastguard Worker       .pooling_elements(pooling_elements)
2835*4bdc9457SAndroid Build Coastguard Worker       .pooling_tile(9, 8)
2836*4bdc9457SAndroid Build Coastguard Worker       .channels(1)
2837*4bdc9457SAndroid Build Coastguard Worker       .input_offset(3)
2838*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
2839*4bdc9457SAndroid Build Coastguard Worker   }
2840*4bdc9457SAndroid Build Coastguard Worker }
2841*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_eq_1_twopass_subtile_with_zero)2842*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_eq_1_twopass_subtile_with_zero) {
2843*4bdc9457SAndroid Build Coastguard Worker   for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
2844*4bdc9457SAndroid Build Coastguard Worker     for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
2845*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
2846*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(pooling_elements)
2847*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
2848*4bdc9457SAndroid Build Coastguard Worker         .channels(1)
2849*4bdc9457SAndroid Build Coastguard Worker         .input_offset(3)
2850*4bdc9457SAndroid Build Coastguard Worker         .zero_index(zero_index)
2851*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
2852*4bdc9457SAndroid Build Coastguard Worker     }
2853*4bdc9457SAndroid Build Coastguard Worker   }
2854*4bdc9457SAndroid Build Coastguard Worker }
2855*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_gt_1_twopass_fulltile)2856*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_gt_1_twopass_fulltile) {
2857*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 2; channels < 10; channels++) {
2858*4bdc9457SAndroid Build Coastguard Worker     AvgPoolMicrokernelTester()
2859*4bdc9457SAndroid Build Coastguard Worker       .pooling_elements(17)
2860*4bdc9457SAndroid Build Coastguard Worker       .pooling_tile(9, 8)
2861*4bdc9457SAndroid Build Coastguard Worker       .channels(channels)
2862*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
2863*4bdc9457SAndroid Build Coastguard Worker   }
2864*4bdc9457SAndroid Build Coastguard Worker }
2865*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_gt_1_twopass_fulltile_with_input_offset)2866*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_gt_1_twopass_fulltile_with_input_offset) {
2867*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 2; channels < 10; channels++) {
2868*4bdc9457SAndroid Build Coastguard Worker     AvgPoolMicrokernelTester()
2869*4bdc9457SAndroid Build Coastguard Worker       .pooling_elements(17)
2870*4bdc9457SAndroid Build Coastguard Worker       .pooling_tile(9, 8)
2871*4bdc9457SAndroid Build Coastguard Worker       .channels(channels)
2872*4bdc9457SAndroid Build Coastguard Worker       .input_offset(3)
2873*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
2874*4bdc9457SAndroid Build Coastguard Worker   }
2875*4bdc9457SAndroid Build Coastguard Worker }
2876*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_gt_1_twopass_fulltile_with_zero)2877*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_gt_1_twopass_fulltile_with_zero) {
2878*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 2; channels < 10; channels++) {
2879*4bdc9457SAndroid Build Coastguard Worker     for (size_t zero_index = 0; zero_index < 17; zero_index++) {
2880*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
2881*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(17)
2882*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
2883*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2884*4bdc9457SAndroid Build Coastguard Worker         .input_offset(3)
2885*4bdc9457SAndroid Build Coastguard Worker         .zero_index(zero_index)
2886*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
2887*4bdc9457SAndroid Build Coastguard Worker     }
2888*4bdc9457SAndroid Build Coastguard Worker   }
2889*4bdc9457SAndroid Build Coastguard Worker }
2890*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_gt_1_twopass_fulltile_with_input_scale)2891*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_gt_1_twopass_fulltile_with_input_scale) {
2892*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 2; channels < 10; channels++) {
2893*4bdc9457SAndroid Build Coastguard Worker     for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
2894*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
2895*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(17)
2896*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
2897*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2898*4bdc9457SAndroid Build Coastguard Worker         .input_scale(scale)
2899*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
2900*4bdc9457SAndroid Build Coastguard Worker     }
2901*4bdc9457SAndroid Build Coastguard Worker   }
2902*4bdc9457SAndroid Build Coastguard Worker }
2903*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_gt_1_twopass_fulltile_with_input_zero_point)2904*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_gt_1_twopass_fulltile_with_input_zero_point) {
2905*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 2; channels < 10; channels++) {
2906*4bdc9457SAndroid Build Coastguard Worker     for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
2907*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
2908*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(17)
2909*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
2910*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2911*4bdc9457SAndroid Build Coastguard Worker         .input_zero_point(zero_point)
2912*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
2913*4bdc9457SAndroid Build Coastguard Worker     }
2914*4bdc9457SAndroid Build Coastguard Worker   }
2915*4bdc9457SAndroid Build Coastguard Worker }
2916*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_gt_1_twopass_fulltile_with_output_scale)2917*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_gt_1_twopass_fulltile_with_output_scale) {
2918*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 2; channels < 10; channels++) {
2919*4bdc9457SAndroid Build Coastguard Worker     for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
2920*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
2921*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(17)
2922*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
2923*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2924*4bdc9457SAndroid Build Coastguard Worker         .output_scale(scale)
2925*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
2926*4bdc9457SAndroid Build Coastguard Worker     }
2927*4bdc9457SAndroid Build Coastguard Worker   }
2928*4bdc9457SAndroid Build Coastguard Worker }
2929*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_gt_1_twopass_fulltile_with_output_zero_point)2930*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_gt_1_twopass_fulltile_with_output_zero_point) {
2931*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 2; channels < 10; channels++) {
2932*4bdc9457SAndroid Build Coastguard Worker     for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
2933*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
2934*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(17)
2935*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
2936*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2937*4bdc9457SAndroid Build Coastguard Worker         .output_zero_point(zero_point)
2938*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
2939*4bdc9457SAndroid Build Coastguard Worker     }
2940*4bdc9457SAndroid Build Coastguard Worker   }
2941*4bdc9457SAndroid Build Coastguard Worker }
2942*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_gt_1_twopass_fulltile_with_qmin)2943*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_gt_1_twopass_fulltile_with_qmin) {
2944*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 2; channels < 10; channels++) {
2945*4bdc9457SAndroid Build Coastguard Worker     AvgPoolMicrokernelTester()
2946*4bdc9457SAndroid Build Coastguard Worker       .pooling_elements(17)
2947*4bdc9457SAndroid Build Coastguard Worker       .pooling_tile(9, 8)
2948*4bdc9457SAndroid Build Coastguard Worker       .channels(channels)
2949*4bdc9457SAndroid Build Coastguard Worker       .qmin(128)
2950*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
2951*4bdc9457SAndroid Build Coastguard Worker   }
2952*4bdc9457SAndroid Build Coastguard Worker }
2953*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_gt_1_twopass_fulltile_with_qmax)2954*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_gt_1_twopass_fulltile_with_qmax) {
2955*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 2; channels < 10; channels++) {
2956*4bdc9457SAndroid Build Coastguard Worker     AvgPoolMicrokernelTester()
2957*4bdc9457SAndroid Build Coastguard Worker       .pooling_elements(17)
2958*4bdc9457SAndroid Build Coastguard Worker       .pooling_tile(9, 8)
2959*4bdc9457SAndroid Build Coastguard Worker       .channels(channels)
2960*4bdc9457SAndroid Build Coastguard Worker       .qmax(128)
2961*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
2962*4bdc9457SAndroid Build Coastguard Worker   }
2963*4bdc9457SAndroid Build Coastguard Worker }
2964*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_gt_1_twopass_subtile)2965*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_gt_1_twopass_subtile) {
2966*4bdc9457SAndroid Build Coastguard Worker   for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
2967*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 2; channels < 10; channels++) {
2968*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
2969*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(pooling_elements)
2970*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
2971*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2972*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
2973*4bdc9457SAndroid Build Coastguard Worker     }
2974*4bdc9457SAndroid Build Coastguard Worker   }
2975*4bdc9457SAndroid Build Coastguard Worker }
2976*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_gt_1_twopass_subtile_with_input_offset)2977*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_gt_1_twopass_subtile_with_input_offset) {
2978*4bdc9457SAndroid Build Coastguard Worker   for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
2979*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 2; channels < 10; channels++) {
2980*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
2981*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(pooling_elements)
2982*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
2983*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2984*4bdc9457SAndroid Build Coastguard Worker         .input_offset(3)
2985*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
2986*4bdc9457SAndroid Build Coastguard Worker     }
2987*4bdc9457SAndroid Build Coastguard Worker   }
2988*4bdc9457SAndroid Build Coastguard Worker }
2989*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_gt_1_twopass_subtile_with_zero)2990*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_gt_1_twopass_subtile_with_zero) {
2991*4bdc9457SAndroid Build Coastguard Worker   for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
2992*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 2; channels < 10; channels++) {
2993*4bdc9457SAndroid Build Coastguard Worker       for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
2994*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
2995*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
2996*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
2997*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
2998*4bdc9457SAndroid Build Coastguard Worker           .input_offset(3)
2999*4bdc9457SAndroid Build Coastguard Worker           .zero_index(zero_index)
3000*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
3001*4bdc9457SAndroid Build Coastguard Worker       }
3002*4bdc9457SAndroid Build Coastguard Worker     }
3003*4bdc9457SAndroid Build Coastguard Worker   }
3004*4bdc9457SAndroid Build Coastguard Worker }
3005*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_eq_1_multipass)3006*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_eq_1_multipass) {
3007*4bdc9457SAndroid Build Coastguard Worker   for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
3008*4bdc9457SAndroid Build Coastguard Worker     AvgPoolMicrokernelTester()
3009*4bdc9457SAndroid Build Coastguard Worker       .pooling_elements(pooling_elements)
3010*4bdc9457SAndroid Build Coastguard Worker       .pooling_tile(9, 8)
3011*4bdc9457SAndroid Build Coastguard Worker       .channels(1)
3012*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
3013*4bdc9457SAndroid Build Coastguard Worker   }
3014*4bdc9457SAndroid Build Coastguard Worker }
3015*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_eq_1_multipass_with_input_offset)3016*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_eq_1_multipass_with_input_offset) {
3017*4bdc9457SAndroid Build Coastguard Worker   for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
3018*4bdc9457SAndroid Build Coastguard Worker     AvgPoolMicrokernelTester()
3019*4bdc9457SAndroid Build Coastguard Worker       .pooling_elements(pooling_elements)
3020*4bdc9457SAndroid Build Coastguard Worker       .pooling_tile(9, 8)
3021*4bdc9457SAndroid Build Coastguard Worker       .channels(1)
3022*4bdc9457SAndroid Build Coastguard Worker       .input_offset(3)
3023*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
3024*4bdc9457SAndroid Build Coastguard Worker   }
3025*4bdc9457SAndroid Build Coastguard Worker }
3026*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_eq_1_multipass_with_zero)3027*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_eq_1_multipass_with_zero) {
3028*4bdc9457SAndroid Build Coastguard Worker   for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
3029*4bdc9457SAndroid Build Coastguard Worker     for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
3030*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
3031*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(pooling_elements)
3032*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
3033*4bdc9457SAndroid Build Coastguard Worker         .channels(1)
3034*4bdc9457SAndroid Build Coastguard Worker         .input_offset(3)
3035*4bdc9457SAndroid Build Coastguard Worker         .zero_index(zero_index)
3036*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
3037*4bdc9457SAndroid Build Coastguard Worker     }
3038*4bdc9457SAndroid Build Coastguard Worker   }
3039*4bdc9457SAndroid Build Coastguard Worker }
3040*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_eq_1_multipass_with_input_scale)3041*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_eq_1_multipass_with_input_scale) {
3042*4bdc9457SAndroid Build Coastguard Worker   for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
3043*4bdc9457SAndroid Build Coastguard Worker     for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
3044*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
3045*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(pooling_elements)
3046*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
3047*4bdc9457SAndroid Build Coastguard Worker         .channels(1)
3048*4bdc9457SAndroid Build Coastguard Worker         .input_scale(scale)
3049*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
3050*4bdc9457SAndroid Build Coastguard Worker     }
3051*4bdc9457SAndroid Build Coastguard Worker   }
3052*4bdc9457SAndroid Build Coastguard Worker }
3053*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_eq_1_multipass_with_input_zero_point)3054*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_eq_1_multipass_with_input_zero_point) {
3055*4bdc9457SAndroid Build Coastguard Worker   for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
3056*4bdc9457SAndroid Build Coastguard Worker     for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
3057*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
3058*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(pooling_elements)
3059*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
3060*4bdc9457SAndroid Build Coastguard Worker         .channels(1)
3061*4bdc9457SAndroid Build Coastguard Worker         .input_zero_point(zero_point)
3062*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
3063*4bdc9457SAndroid Build Coastguard Worker     }
3064*4bdc9457SAndroid Build Coastguard Worker   }
3065*4bdc9457SAndroid Build Coastguard Worker }
3066*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_eq_1_multipass_with_output_scale)3067*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_eq_1_multipass_with_output_scale) {
3068*4bdc9457SAndroid Build Coastguard Worker   for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
3069*4bdc9457SAndroid Build Coastguard Worker     for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
3070*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
3071*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(pooling_elements)
3072*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
3073*4bdc9457SAndroid Build Coastguard Worker         .channels(1)
3074*4bdc9457SAndroid Build Coastguard Worker         .output_scale(scale)
3075*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
3076*4bdc9457SAndroid Build Coastguard Worker     }
3077*4bdc9457SAndroid Build Coastguard Worker   }
3078*4bdc9457SAndroid Build Coastguard Worker }
3079*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_eq_1_multipass_with_output_zero_point)3080*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_eq_1_multipass_with_output_zero_point) {
3081*4bdc9457SAndroid Build Coastguard Worker   for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
3082*4bdc9457SAndroid Build Coastguard Worker     for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
3083*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
3084*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(pooling_elements)
3085*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
3086*4bdc9457SAndroid Build Coastguard Worker         .channels(1)
3087*4bdc9457SAndroid Build Coastguard Worker         .output_zero_point(zero_point)
3088*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
3089*4bdc9457SAndroid Build Coastguard Worker     }
3090*4bdc9457SAndroid Build Coastguard Worker   }
3091*4bdc9457SAndroid Build Coastguard Worker }
3092*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_eq_1_multipass_with_qmin)3093*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_eq_1_multipass_with_qmin) {
3094*4bdc9457SAndroid Build Coastguard Worker   for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
3095*4bdc9457SAndroid Build Coastguard Worker     AvgPoolMicrokernelTester()
3096*4bdc9457SAndroid Build Coastguard Worker       .pooling_elements(pooling_elements)
3097*4bdc9457SAndroid Build Coastguard Worker       .pooling_tile(9, 8)
3098*4bdc9457SAndroid Build Coastguard Worker       .channels(1)
3099*4bdc9457SAndroid Build Coastguard Worker       .qmin(128)
3100*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
3101*4bdc9457SAndroid Build Coastguard Worker   }
3102*4bdc9457SAndroid Build Coastguard Worker }
3103*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_eq_1_multipass_with_qmax)3104*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_eq_1_multipass_with_qmax) {
3105*4bdc9457SAndroid Build Coastguard Worker   for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
3106*4bdc9457SAndroid Build Coastguard Worker     AvgPoolMicrokernelTester()
3107*4bdc9457SAndroid Build Coastguard Worker       .pooling_elements(pooling_elements)
3108*4bdc9457SAndroid Build Coastguard Worker       .pooling_tile(9, 8)
3109*4bdc9457SAndroid Build Coastguard Worker       .channels(1)
3110*4bdc9457SAndroid Build Coastguard Worker       .qmax(128)
3111*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
3112*4bdc9457SAndroid Build Coastguard Worker   }
3113*4bdc9457SAndroid Build Coastguard Worker }
3114*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_gt_1_multipass)3115*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_gt_1_multipass) {
3116*4bdc9457SAndroid Build Coastguard Worker   for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
3117*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 2; channels < 10; channels++) {
3118*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
3119*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(pooling_elements)
3120*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
3121*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
3122*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
3123*4bdc9457SAndroid Build Coastguard Worker     }
3124*4bdc9457SAndroid Build Coastguard Worker   }
3125*4bdc9457SAndroid Build Coastguard Worker }
3126*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_gt_1_multipass_with_input_offset)3127*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_gt_1_multipass_with_input_offset) {
3128*4bdc9457SAndroid Build Coastguard Worker   for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
3129*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 2; channels < 10; channels++) {
3130*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
3131*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(pooling_elements)
3132*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
3133*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
3134*4bdc9457SAndroid Build Coastguard Worker         .input_offset(3)
3135*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
3136*4bdc9457SAndroid Build Coastguard Worker     }
3137*4bdc9457SAndroid Build Coastguard Worker   }
3138*4bdc9457SAndroid Build Coastguard Worker }
3139*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_gt_1_multipass_with_zero)3140*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_gt_1_multipass_with_zero) {
3141*4bdc9457SAndroid Build Coastguard Worker   for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
3142*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 2; channels < 10; channels++) {
3143*4bdc9457SAndroid Build Coastguard Worker       for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
3144*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
3145*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
3146*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
3147*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
3148*4bdc9457SAndroid Build Coastguard Worker           .input_offset(3)
3149*4bdc9457SAndroid Build Coastguard Worker           .zero_index(zero_index)
3150*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
3151*4bdc9457SAndroid Build Coastguard Worker       }
3152*4bdc9457SAndroid Build Coastguard Worker     }
3153*4bdc9457SAndroid Build Coastguard Worker   }
3154*4bdc9457SAndroid Build Coastguard Worker }
3155*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_gt_1_multipass_with_input_scale)3156*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_gt_1_multipass_with_input_scale) {
3157*4bdc9457SAndroid Build Coastguard Worker   for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
3158*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 2; channels < 10; channels++) {
3159*4bdc9457SAndroid Build Coastguard Worker       for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
3160*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
3161*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
3162*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
3163*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
3164*4bdc9457SAndroid Build Coastguard Worker           .input_scale(scale)
3165*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
3166*4bdc9457SAndroid Build Coastguard Worker       }
3167*4bdc9457SAndroid Build Coastguard Worker     }
3168*4bdc9457SAndroid Build Coastguard Worker   }
3169*4bdc9457SAndroid Build Coastguard Worker }
3170*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_gt_1_multipass_with_input_zero_point)3171*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_gt_1_multipass_with_input_zero_point) {
3172*4bdc9457SAndroid Build Coastguard Worker   for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
3173*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 2; channels < 10; channels++) {
3174*4bdc9457SAndroid Build Coastguard Worker       for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
3175*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
3176*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
3177*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
3178*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
3179*4bdc9457SAndroid Build Coastguard Worker           .input_zero_point(zero_point)
3180*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
3181*4bdc9457SAndroid Build Coastguard Worker       }
3182*4bdc9457SAndroid Build Coastguard Worker     }
3183*4bdc9457SAndroid Build Coastguard Worker   }
3184*4bdc9457SAndroid Build Coastguard Worker }
3185*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_gt_1_multipass_with_output_scale)3186*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_gt_1_multipass_with_output_scale) {
3187*4bdc9457SAndroid Build Coastguard Worker   for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
3188*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 2; channels < 10; channels++) {
3189*4bdc9457SAndroid Build Coastguard Worker       for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
3190*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
3191*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
3192*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
3193*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
3194*4bdc9457SAndroid Build Coastguard Worker           .output_scale(scale)
3195*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
3196*4bdc9457SAndroid Build Coastguard Worker       }
3197*4bdc9457SAndroid Build Coastguard Worker     }
3198*4bdc9457SAndroid Build Coastguard Worker   }
3199*4bdc9457SAndroid Build Coastguard Worker }
3200*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_gt_1_multipass_with_output_zero_point)3201*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_gt_1_multipass_with_output_zero_point) {
3202*4bdc9457SAndroid Build Coastguard Worker   for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
3203*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 2; channels < 10; channels++) {
3204*4bdc9457SAndroid Build Coastguard Worker       for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
3205*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
3206*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
3207*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
3208*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
3209*4bdc9457SAndroid Build Coastguard Worker           .output_zero_point(zero_point)
3210*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
3211*4bdc9457SAndroid Build Coastguard Worker       }
3212*4bdc9457SAndroid Build Coastguard Worker     }
3213*4bdc9457SAndroid Build Coastguard Worker   }
3214*4bdc9457SAndroid Build Coastguard Worker }
3215*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_gt_1_multipass_with_qmin)3216*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_gt_1_multipass_with_qmin) {
3217*4bdc9457SAndroid Build Coastguard Worker   for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
3218*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 2; channels < 10; channels++) {
3219*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
3220*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(pooling_elements)
3221*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
3222*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
3223*4bdc9457SAndroid Build Coastguard Worker         .qmin(128)
3224*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
3225*4bdc9457SAndroid Build Coastguard Worker     }
3226*4bdc9457SAndroid Build Coastguard Worker   }
3227*4bdc9457SAndroid Build Coastguard Worker }
3228*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_gt_1_multipass_with_qmax)3229*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_gt_1_multipass_with_qmax) {
3230*4bdc9457SAndroid Build Coastguard Worker   for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
3231*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 2; channels < 10; channels++) {
3232*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
3233*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(pooling_elements)
3234*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9, 8)
3235*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
3236*4bdc9457SAndroid Build Coastguard Worker         .qmax(128)
3237*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
3238*4bdc9457SAndroid Build Coastguard Worker     }
3239*4bdc9457SAndroid Build Coastguard Worker   }
3240*4bdc9457SAndroid Build Coastguard Worker }
3241*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1,few_output_pixels)3242*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1, few_output_pixels) {
3243*4bdc9457SAndroid Build Coastguard Worker   for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
3244*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
3245*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 1; channels <= 5; channels += 1) {
3246*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
3247*4bdc9457SAndroid Build Coastguard Worker           .output_pixels(output_pixels)
3248*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
3249*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
3250*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
3251*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
3252*4bdc9457SAndroid Build Coastguard Worker       }
3253*4bdc9457SAndroid Build Coastguard Worker     }
3254*4bdc9457SAndroid Build Coastguard Worker   }
3255*4bdc9457SAndroid Build Coastguard Worker }
3256*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1,few_output_pixels_with_input_offset)3257*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1, few_output_pixels_with_input_offset) {
3258*4bdc9457SAndroid Build Coastguard Worker   for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
3259*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
3260*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 1; channels <= 5; channels += 1) {
3261*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
3262*4bdc9457SAndroid Build Coastguard Worker           .output_pixels(output_pixels)
3263*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
3264*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
3265*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
3266*4bdc9457SAndroid Build Coastguard Worker           .input_offset(7)
3267*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
3268*4bdc9457SAndroid Build Coastguard Worker       }
3269*4bdc9457SAndroid Build Coastguard Worker     }
3270*4bdc9457SAndroid Build Coastguard Worker   }
3271*4bdc9457SAndroid Build Coastguard Worker }
3272*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1,few_output_pixels_with_zero)3273*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1, few_output_pixels_with_zero) {
3274*4bdc9457SAndroid Build Coastguard Worker   for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
3275*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
3276*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 1; channels <= 5; channels += 1) {
3277*4bdc9457SAndroid Build Coastguard Worker         for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
3278*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
3279*4bdc9457SAndroid Build Coastguard Worker             .output_pixels(output_pixels)
3280*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
3281*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 8)
3282*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
3283*4bdc9457SAndroid Build Coastguard Worker             .input_offset(7)
3284*4bdc9457SAndroid Build Coastguard Worker             .zero_index(zero_index)
3285*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
3286*4bdc9457SAndroid Build Coastguard Worker         }
3287*4bdc9457SAndroid Build Coastguard Worker       }
3288*4bdc9457SAndroid Build Coastguard Worker     }
3289*4bdc9457SAndroid Build Coastguard Worker   }
3290*4bdc9457SAndroid Build Coastguard Worker }
3291*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1,few_output_pixels_with_input_scale)3292*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1, few_output_pixels_with_input_scale) {
3293*4bdc9457SAndroid Build Coastguard Worker   for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
3294*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
3295*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 1; channels <= 5; channels += 1) {
3296*4bdc9457SAndroid Build Coastguard Worker         for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
3297*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
3298*4bdc9457SAndroid Build Coastguard Worker             .output_pixels(output_pixels)
3299*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
3300*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 8)
3301*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
3302*4bdc9457SAndroid Build Coastguard Worker             .input_scale(scale)
3303*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
3304*4bdc9457SAndroid Build Coastguard Worker         }
3305*4bdc9457SAndroid Build Coastguard Worker       }
3306*4bdc9457SAndroid Build Coastguard Worker     }
3307*4bdc9457SAndroid Build Coastguard Worker   }
3308*4bdc9457SAndroid Build Coastguard Worker }
3309*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1,few_output_pixels_with_input_zero_point)3310*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1, few_output_pixels_with_input_zero_point) {
3311*4bdc9457SAndroid Build Coastguard Worker   for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
3312*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
3313*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 1; channels <= 5; channels += 1) {
3314*4bdc9457SAndroid Build Coastguard Worker         for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
3315*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
3316*4bdc9457SAndroid Build Coastguard Worker             .output_pixels(output_pixels)
3317*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
3318*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 8)
3319*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
3320*4bdc9457SAndroid Build Coastguard Worker             .input_zero_point(zero_point)
3321*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
3322*4bdc9457SAndroid Build Coastguard Worker         }
3323*4bdc9457SAndroid Build Coastguard Worker       }
3324*4bdc9457SAndroid Build Coastguard Worker     }
3325*4bdc9457SAndroid Build Coastguard Worker   }
3326*4bdc9457SAndroid Build Coastguard Worker }
3327*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1,few_output_pixels_with_output_scale)3328*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1, few_output_pixels_with_output_scale) {
3329*4bdc9457SAndroid Build Coastguard Worker   for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
3330*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
3331*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 1; channels <= 5; channels += 1) {
3332*4bdc9457SAndroid Build Coastguard Worker         for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
3333*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
3334*4bdc9457SAndroid Build Coastguard Worker             .output_pixels(output_pixels)
3335*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
3336*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 8)
3337*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
3338*4bdc9457SAndroid Build Coastguard Worker             .output_scale(scale)
3339*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
3340*4bdc9457SAndroid Build Coastguard Worker         }
3341*4bdc9457SAndroid Build Coastguard Worker       }
3342*4bdc9457SAndroid Build Coastguard Worker     }
3343*4bdc9457SAndroid Build Coastguard Worker   }
3344*4bdc9457SAndroid Build Coastguard Worker }
3345*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1,few_output_pixels_with_output_zero_point)3346*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1, few_output_pixels_with_output_zero_point) {
3347*4bdc9457SAndroid Build Coastguard Worker   for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
3348*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
3349*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 1; channels <= 5; channels += 1) {
3350*4bdc9457SAndroid Build Coastguard Worker         for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
3351*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
3352*4bdc9457SAndroid Build Coastguard Worker             .output_pixels(output_pixels)
3353*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
3354*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 8)
3355*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
3356*4bdc9457SAndroid Build Coastguard Worker             .output_zero_point(zero_point)
3357*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
3358*4bdc9457SAndroid Build Coastguard Worker         }
3359*4bdc9457SAndroid Build Coastguard Worker       }
3360*4bdc9457SAndroid Build Coastguard Worker     }
3361*4bdc9457SAndroid Build Coastguard Worker   }
3362*4bdc9457SAndroid Build Coastguard Worker }
3363*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1,few_output_pixels_with_qmin)3364*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1, few_output_pixels_with_qmin) {
3365*4bdc9457SAndroid Build Coastguard Worker   for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
3366*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
3367*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 1; channels <= 5; channels += 1) {
3368*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
3369*4bdc9457SAndroid Build Coastguard Worker           .output_pixels(output_pixels)
3370*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
3371*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
3372*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
3373*4bdc9457SAndroid Build Coastguard Worker           .qmin(128)
3374*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
3375*4bdc9457SAndroid Build Coastguard Worker       }
3376*4bdc9457SAndroid Build Coastguard Worker     }
3377*4bdc9457SAndroid Build Coastguard Worker   }
3378*4bdc9457SAndroid Build Coastguard Worker }
3379*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1,few_output_pixels_with_qmax)3380*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1, few_output_pixels_with_qmax) {
3381*4bdc9457SAndroid Build Coastguard Worker   for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
3382*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
3383*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 1; channels <= 5; channels += 1) {
3384*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
3385*4bdc9457SAndroid Build Coastguard Worker           .output_pixels(output_pixels)
3386*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
3387*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
3388*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
3389*4bdc9457SAndroid Build Coastguard Worker           .qmax(128)
3390*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
3391*4bdc9457SAndroid Build Coastguard Worker       }
3392*4bdc9457SAndroid Build Coastguard Worker     }
3393*4bdc9457SAndroid Build Coastguard Worker   }
3394*4bdc9457SAndroid Build Coastguard Worker }
3395*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1,few_output_pixels_with_output_stride)3396*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1, few_output_pixels_with_output_stride) {
3397*4bdc9457SAndroid Build Coastguard Worker   for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
3398*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
3399*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 1; channels <= 5; channels += 1) {
3400*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
3401*4bdc9457SAndroid Build Coastguard Worker           .output_pixels(output_pixels)
3402*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
3403*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 8)
3404*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
3405*4bdc9457SAndroid Build Coastguard Worker           .output_stride(7)
3406*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
3407*4bdc9457SAndroid Build Coastguard Worker       }
3408*4bdc9457SAndroid Build Coastguard Worker     }
3409*4bdc9457SAndroid Build Coastguard Worker   }
3410*4bdc9457SAndroid Build Coastguard Worker }
3411*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1,few_output_pixels_with_step)3412*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9P8X__SCALAR_C1, few_output_pixels_with_step) {
3413*4bdc9457SAndroid Build Coastguard Worker   for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
3414*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
3415*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 1; channels <= 5; channels += 1) {
3416*4bdc9457SAndroid Build Coastguard Worker         for (size_t step = 2; step <= pooling_elements; step++) {
3417*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
3418*4bdc9457SAndroid Build Coastguard Worker             .output_pixels(output_pixels)
3419*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
3420*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 8)
3421*4bdc9457SAndroid Build Coastguard Worker             .step(step)
3422*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
3423*4bdc9457SAndroid Build Coastguard Worker             .output_stride(7)
3424*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
3425*4bdc9457SAndroid Build Coastguard Worker         }
3426*4bdc9457SAndroid Build Coastguard Worker       }
3427*4bdc9457SAndroid Build Coastguard Worker     }
3428*4bdc9457SAndroid Build Coastguard Worker   }
3429*4bdc9457SAndroid Build Coastguard Worker }
3430*4bdc9457SAndroid Build Coastguard Worker 
3431*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,channels_eq_8_unipass_fulltile)3432*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, channels_eq_8_unipass_fulltile) {
3433*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
3434*4bdc9457SAndroid Build Coastguard Worker     AvgPoolMicrokernelTester()
3435*4bdc9457SAndroid Build Coastguard Worker       .pooling_elements(9)
3436*4bdc9457SAndroid Build Coastguard Worker       .pooling_tile(9)
3437*4bdc9457SAndroid Build Coastguard Worker       .channels(8)
3438*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
3439*4bdc9457SAndroid Build Coastguard Worker   }
3440*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,channels_eq_8_unipass_fulltile_with_input_offset)3441*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, channels_eq_8_unipass_fulltile_with_input_offset) {
3442*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
3443*4bdc9457SAndroid Build Coastguard Worker     AvgPoolMicrokernelTester()
3444*4bdc9457SAndroid Build Coastguard Worker       .pooling_elements(9)
3445*4bdc9457SAndroid Build Coastguard Worker       .pooling_tile(9)
3446*4bdc9457SAndroid Build Coastguard Worker       .channels(8)
3447*4bdc9457SAndroid Build Coastguard Worker       .input_offset(11)
3448*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
3449*4bdc9457SAndroid Build Coastguard Worker   }
3450*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,channels_eq_8_unipass_fulltile_with_zero)3451*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, channels_eq_8_unipass_fulltile_with_zero) {
3452*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
3453*4bdc9457SAndroid Build Coastguard Worker     for (size_t zero_index = 0; zero_index < 9; zero_index++) {
3454*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
3455*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(9)
3456*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9)
3457*4bdc9457SAndroid Build Coastguard Worker         .channels(8)
3458*4bdc9457SAndroid Build Coastguard Worker         .input_offset(11)
3459*4bdc9457SAndroid Build Coastguard Worker         .zero_index(zero_index)
3460*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
3461*4bdc9457SAndroid Build Coastguard Worker     }
3462*4bdc9457SAndroid Build Coastguard Worker   }
3463*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,channels_eq_8_unipass_fulltile_with_input_scale)3464*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, channels_eq_8_unipass_fulltile_with_input_scale) {
3465*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
3466*4bdc9457SAndroid Build Coastguard Worker     for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
3467*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
3468*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(9)
3469*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9)
3470*4bdc9457SAndroid Build Coastguard Worker         .channels(8)
3471*4bdc9457SAndroid Build Coastguard Worker         .input_scale(scale)
3472*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
3473*4bdc9457SAndroid Build Coastguard Worker     }
3474*4bdc9457SAndroid Build Coastguard Worker   }
3475*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,channels_eq_8_unipass_fulltile_with_input_zero_point)3476*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, channels_eq_8_unipass_fulltile_with_input_zero_point) {
3477*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
3478*4bdc9457SAndroid Build Coastguard Worker     for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
3479*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
3480*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(9)
3481*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9)
3482*4bdc9457SAndroid Build Coastguard Worker         .channels(8)
3483*4bdc9457SAndroid Build Coastguard Worker         .input_zero_point(zero_point)
3484*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
3485*4bdc9457SAndroid Build Coastguard Worker     }
3486*4bdc9457SAndroid Build Coastguard Worker   }
3487*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,channels_eq_8_unipass_fulltile_with_output_scale)3488*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, channels_eq_8_unipass_fulltile_with_output_scale) {
3489*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
3490*4bdc9457SAndroid Build Coastguard Worker     for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
3491*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
3492*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(9)
3493*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9)
3494*4bdc9457SAndroid Build Coastguard Worker         .channels(8)
3495*4bdc9457SAndroid Build Coastguard Worker         .output_scale(scale)
3496*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
3497*4bdc9457SAndroid Build Coastguard Worker     }
3498*4bdc9457SAndroid Build Coastguard Worker   }
3499*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,channels_eq_8_unipass_fulltile_with_output_zero_point)3500*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, channels_eq_8_unipass_fulltile_with_output_zero_point) {
3501*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
3502*4bdc9457SAndroid Build Coastguard Worker     for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
3503*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
3504*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(9)
3505*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9)
3506*4bdc9457SAndroid Build Coastguard Worker         .channels(8)
3507*4bdc9457SAndroid Build Coastguard Worker         .output_zero_point(zero_point)
3508*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
3509*4bdc9457SAndroid Build Coastguard Worker     }
3510*4bdc9457SAndroid Build Coastguard Worker   }
3511*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,channels_eq_8_unipass_fulltile_with_qmin)3512*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, channels_eq_8_unipass_fulltile_with_qmin) {
3513*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
3514*4bdc9457SAndroid Build Coastguard Worker     AvgPoolMicrokernelTester()
3515*4bdc9457SAndroid Build Coastguard Worker       .pooling_elements(9)
3516*4bdc9457SAndroid Build Coastguard Worker       .pooling_tile(9)
3517*4bdc9457SAndroid Build Coastguard Worker       .channels(8)
3518*4bdc9457SAndroid Build Coastguard Worker       .qmin(128)
3519*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
3520*4bdc9457SAndroid Build Coastguard Worker   }
3521*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,channels_eq_8_unipass_fulltile_with_qmax)3522*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, channels_eq_8_unipass_fulltile_with_qmax) {
3523*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
3524*4bdc9457SAndroid Build Coastguard Worker     AvgPoolMicrokernelTester()
3525*4bdc9457SAndroid Build Coastguard Worker       .pooling_elements(9)
3526*4bdc9457SAndroid Build Coastguard Worker       .pooling_tile(9)
3527*4bdc9457SAndroid Build Coastguard Worker       .channels(8)
3528*4bdc9457SAndroid Build Coastguard Worker       .qmax(128)
3529*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
3530*4bdc9457SAndroid Build Coastguard Worker   }
3531*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,channels_eq_8_unipass_subtile)3532*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, channels_eq_8_unipass_subtile) {
3533*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
3534*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
3535*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
3536*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(pooling_elements)
3537*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9)
3538*4bdc9457SAndroid Build Coastguard Worker         .channels(8)
3539*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
3540*4bdc9457SAndroid Build Coastguard Worker     }
3541*4bdc9457SAndroid Build Coastguard Worker   }
3542*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,channels_eq_8_unipass_subtile_with_input_offset)3543*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, channels_eq_8_unipass_subtile_with_input_offset) {
3544*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
3545*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
3546*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
3547*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(pooling_elements)
3548*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9)
3549*4bdc9457SAndroid Build Coastguard Worker         .channels(8)
3550*4bdc9457SAndroid Build Coastguard Worker         .input_offset(11)
3551*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
3552*4bdc9457SAndroid Build Coastguard Worker     }
3553*4bdc9457SAndroid Build Coastguard Worker   }
3554*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,channels_eq_8_unipass_subtile_with_zero)3555*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, channels_eq_8_unipass_subtile_with_zero) {
3556*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
3557*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
3558*4bdc9457SAndroid Build Coastguard Worker       for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
3559*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
3560*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
3561*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9)
3562*4bdc9457SAndroid Build Coastguard Worker           .channels(8)
3563*4bdc9457SAndroid Build Coastguard Worker           .input_offset(11)
3564*4bdc9457SAndroid Build Coastguard Worker           .zero_index(zero_index)
3565*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
3566*4bdc9457SAndroid Build Coastguard Worker       }
3567*4bdc9457SAndroid Build Coastguard Worker     }
3568*4bdc9457SAndroid Build Coastguard Worker   }
3569*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,channels_div_8_unipass_fulltile)3570*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, channels_div_8_unipass_fulltile) {
3571*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
3572*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 16; channels < 64; channels += 8) {
3573*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
3574*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(9)
3575*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9)
3576*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
3577*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
3578*4bdc9457SAndroid Build Coastguard Worker     }
3579*4bdc9457SAndroid Build Coastguard Worker   }
3580*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,channels_div_8_unipass_fulltile_with_input_offset)3581*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, channels_div_8_unipass_fulltile_with_input_offset) {
3582*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
3583*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 16; channels < 64; channels += 8) {
3584*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
3585*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(9)
3586*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9)
3587*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
3588*4bdc9457SAndroid Build Coastguard Worker         .input_offset(67)
3589*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
3590*4bdc9457SAndroid Build Coastguard Worker     }
3591*4bdc9457SAndroid Build Coastguard Worker   }
3592*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,channels_div_8_unipass_fulltile_with_zero)3593*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, channels_div_8_unipass_fulltile_with_zero) {
3594*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
3595*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 16; channels < 64; channels += 8) {
3596*4bdc9457SAndroid Build Coastguard Worker       for (size_t zero_index = 0; zero_index < 9; zero_index++) {
3597*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
3598*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(9)
3599*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9)
3600*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
3601*4bdc9457SAndroid Build Coastguard Worker           .input_offset(67)
3602*4bdc9457SAndroid Build Coastguard Worker           .zero_index(zero_index)
3603*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
3604*4bdc9457SAndroid Build Coastguard Worker       }
3605*4bdc9457SAndroid Build Coastguard Worker     }
3606*4bdc9457SAndroid Build Coastguard Worker   }
3607*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,channels_div_8_unipass_fulltile_with_input_scale)3608*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, channels_div_8_unipass_fulltile_with_input_scale) {
3609*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
3610*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 16; channels < 64; channels += 8) {
3611*4bdc9457SAndroid Build Coastguard Worker       for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
3612*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
3613*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(9)
3614*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9)
3615*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
3616*4bdc9457SAndroid Build Coastguard Worker           .input_scale(scale)
3617*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
3618*4bdc9457SAndroid Build Coastguard Worker       }
3619*4bdc9457SAndroid Build Coastguard Worker     }
3620*4bdc9457SAndroid Build Coastguard Worker   }
3621*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,channels_div_8_unipass_fulltile_with_input_zero_point)3622*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, channels_div_8_unipass_fulltile_with_input_zero_point) {
3623*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
3624*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 16; channels < 64; channels += 8) {
3625*4bdc9457SAndroid Build Coastguard Worker       for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
3626*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
3627*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(9)
3628*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9)
3629*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
3630*4bdc9457SAndroid Build Coastguard Worker           .input_zero_point(zero_point)
3631*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
3632*4bdc9457SAndroid Build Coastguard Worker       }
3633*4bdc9457SAndroid Build Coastguard Worker     }
3634*4bdc9457SAndroid Build Coastguard Worker   }
3635*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,channels_div_8_unipass_fulltile_with_output_scale)3636*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, channels_div_8_unipass_fulltile_with_output_scale) {
3637*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
3638*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 16; channels < 64; channels += 8) {
3639*4bdc9457SAndroid Build Coastguard Worker       for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
3640*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
3641*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(9)
3642*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9)
3643*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
3644*4bdc9457SAndroid Build Coastguard Worker           .output_scale(scale)
3645*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
3646*4bdc9457SAndroid Build Coastguard Worker       }
3647*4bdc9457SAndroid Build Coastguard Worker     }
3648*4bdc9457SAndroid Build Coastguard Worker   }
3649*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,channels_div_8_unipass_fulltile_with_output_zero_point)3650*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, channels_div_8_unipass_fulltile_with_output_zero_point) {
3651*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
3652*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 16; channels < 64; channels += 8) {
3653*4bdc9457SAndroid Build Coastguard Worker       for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
3654*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
3655*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(9)
3656*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9)
3657*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
3658*4bdc9457SAndroid Build Coastguard Worker           .output_zero_point(zero_point)
3659*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
3660*4bdc9457SAndroid Build Coastguard Worker       }
3661*4bdc9457SAndroid Build Coastguard Worker     }
3662*4bdc9457SAndroid Build Coastguard Worker   }
3663*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,channels_div_8_unipass_fulltile_with_qmin)3664*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, channels_div_8_unipass_fulltile_with_qmin) {
3665*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
3666*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 16; channels < 64; channels += 8) {
3667*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
3668*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(9)
3669*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9)
3670*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
3671*4bdc9457SAndroid Build Coastguard Worker         .qmin(128)
3672*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
3673*4bdc9457SAndroid Build Coastguard Worker     }
3674*4bdc9457SAndroid Build Coastguard Worker   }
3675*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,channels_div_8_unipass_fulltile_with_qmax)3676*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, channels_div_8_unipass_fulltile_with_qmax) {
3677*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
3678*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 16; channels < 64; channels += 8) {
3679*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
3680*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(9)
3681*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9)
3682*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
3683*4bdc9457SAndroid Build Coastguard Worker         .qmax(128)
3684*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
3685*4bdc9457SAndroid Build Coastguard Worker     }
3686*4bdc9457SAndroid Build Coastguard Worker   }
3687*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,channels_div_8_unipass_subtile)3688*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, channels_div_8_unipass_subtile) {
3689*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
3690*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
3691*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 16; channels < 64; channels += 8) {
3692*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
3693*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
3694*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9)
3695*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
3696*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
3697*4bdc9457SAndroid Build Coastguard Worker       }
3698*4bdc9457SAndroid Build Coastguard Worker     }
3699*4bdc9457SAndroid Build Coastguard Worker   }
3700*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,channels_div_8_unipass_subtile_with_input_offset)3701*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, channels_div_8_unipass_subtile_with_input_offset) {
3702*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
3703*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
3704*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 16; channels < 64; channels += 8) {
3705*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
3706*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
3707*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9)
3708*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
3709*4bdc9457SAndroid Build Coastguard Worker           .input_offset(67)
3710*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
3711*4bdc9457SAndroid Build Coastguard Worker       }
3712*4bdc9457SAndroid Build Coastguard Worker     }
3713*4bdc9457SAndroid Build Coastguard Worker   }
3714*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,channels_div_8_unipass_subtile_with_zero)3715*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, channels_div_8_unipass_subtile_with_zero) {
3716*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
3717*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
3718*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 16; channels < 64; channels += 8) {
3719*4bdc9457SAndroid Build Coastguard Worker         for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
3720*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
3721*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
3722*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9)
3723*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
3724*4bdc9457SAndroid Build Coastguard Worker             .input_offset(67)
3725*4bdc9457SAndroid Build Coastguard Worker             .zero_index(zero_index)
3726*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
3727*4bdc9457SAndroid Build Coastguard Worker         }
3728*4bdc9457SAndroid Build Coastguard Worker       }
3729*4bdc9457SAndroid Build Coastguard Worker     }
3730*4bdc9457SAndroid Build Coastguard Worker   }
3731*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,channels_lt_8_unipass_fulltile)3732*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, channels_lt_8_unipass_fulltile) {
3733*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
3734*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 1; channels < 8; channels++) {
3735*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
3736*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(9)
3737*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9)
3738*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
3739*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
3740*4bdc9457SAndroid Build Coastguard Worker     }
3741*4bdc9457SAndroid Build Coastguard Worker   }
3742*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,channels_lt_8_unipass_fulltile_with_input_offset)3743*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, channels_lt_8_unipass_fulltile_with_input_offset) {
3744*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
3745*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 1; channels < 8; channels++) {
3746*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
3747*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(9)
3748*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9)
3749*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
3750*4bdc9457SAndroid Build Coastguard Worker         .input_offset(11)
3751*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
3752*4bdc9457SAndroid Build Coastguard Worker     }
3753*4bdc9457SAndroid Build Coastguard Worker   }
3754*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,channels_lt_8_unipass_fulltile_with_zero)3755*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, channels_lt_8_unipass_fulltile_with_zero) {
3756*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
3757*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 1; channels < 8; channels++) {
3758*4bdc9457SAndroid Build Coastguard Worker       for (size_t zero_index = 0; zero_index < 9; zero_index++) {
3759*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
3760*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(9)
3761*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9)
3762*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
3763*4bdc9457SAndroid Build Coastguard Worker           .input_offset(11)
3764*4bdc9457SAndroid Build Coastguard Worker           .zero_index(zero_index)
3765*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
3766*4bdc9457SAndroid Build Coastguard Worker       }
3767*4bdc9457SAndroid Build Coastguard Worker     }
3768*4bdc9457SAndroid Build Coastguard Worker   }
3769*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,channels_lt_8_unipass_fulltile_with_input_scale)3770*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, channels_lt_8_unipass_fulltile_with_input_scale) {
3771*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
3772*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 1; channels < 8; channels++) {
3773*4bdc9457SAndroid Build Coastguard Worker       for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
3774*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
3775*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(9)
3776*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9)
3777*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
3778*4bdc9457SAndroid Build Coastguard Worker           .input_scale(scale)
3779*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
3780*4bdc9457SAndroid Build Coastguard Worker       }
3781*4bdc9457SAndroid Build Coastguard Worker     }
3782*4bdc9457SAndroid Build Coastguard Worker   }
3783*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,channels_lt_8_unipass_fulltile_with_input_zero_point)3784*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, channels_lt_8_unipass_fulltile_with_input_zero_point) {
3785*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
3786*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 1; channels < 8; channels++) {
3787*4bdc9457SAndroid Build Coastguard Worker       for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
3788*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
3789*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(9)
3790*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9)
3791*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
3792*4bdc9457SAndroid Build Coastguard Worker           .input_zero_point(zero_point)
3793*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
3794*4bdc9457SAndroid Build Coastguard Worker       }
3795*4bdc9457SAndroid Build Coastguard Worker     }
3796*4bdc9457SAndroid Build Coastguard Worker   }
3797*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,channels_lt_8_unipass_fulltile_with_output_scale)3798*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, channels_lt_8_unipass_fulltile_with_output_scale) {
3799*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
3800*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 1; channels < 8; channels++) {
3801*4bdc9457SAndroid Build Coastguard Worker       for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
3802*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
3803*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(9)
3804*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9)
3805*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
3806*4bdc9457SAndroid Build Coastguard Worker           .output_scale(scale)
3807*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
3808*4bdc9457SAndroid Build Coastguard Worker       }
3809*4bdc9457SAndroid Build Coastguard Worker     }
3810*4bdc9457SAndroid Build Coastguard Worker   }
3811*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,channels_lt_8_unipass_fulltile_with_output_zero_point)3812*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, channels_lt_8_unipass_fulltile_with_output_zero_point) {
3813*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
3814*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 1; channels < 8; channels++) {
3815*4bdc9457SAndroid Build Coastguard Worker       for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
3816*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
3817*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(9)
3818*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9)
3819*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
3820*4bdc9457SAndroid Build Coastguard Worker           .output_zero_point(zero_point)
3821*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
3822*4bdc9457SAndroid Build Coastguard Worker       }
3823*4bdc9457SAndroid Build Coastguard Worker     }
3824*4bdc9457SAndroid Build Coastguard Worker   }
3825*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,channels_lt_8_unipass_fulltile_with_qmin)3826*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, channels_lt_8_unipass_fulltile_with_qmin) {
3827*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
3828*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 1; channels < 8; channels++) {
3829*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
3830*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(9)
3831*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9)
3832*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
3833*4bdc9457SAndroid Build Coastguard Worker         .qmin(128)
3834*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
3835*4bdc9457SAndroid Build Coastguard Worker     }
3836*4bdc9457SAndroid Build Coastguard Worker   }
3837*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,channels_lt_8_unipass_fulltile_with_qmax)3838*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, channels_lt_8_unipass_fulltile_with_qmax) {
3839*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
3840*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 1; channels < 8; channels++) {
3841*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
3842*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(9)
3843*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9)
3844*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
3845*4bdc9457SAndroid Build Coastguard Worker         .qmax(128)
3846*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
3847*4bdc9457SAndroid Build Coastguard Worker     }
3848*4bdc9457SAndroid Build Coastguard Worker   }
3849*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,channels_lt_8_unipass_subtile)3850*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, channels_lt_8_unipass_subtile) {
3851*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
3852*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
3853*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 1; channels < 8; channels++) {
3854*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
3855*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
3856*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9)
3857*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
3858*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
3859*4bdc9457SAndroid Build Coastguard Worker       }
3860*4bdc9457SAndroid Build Coastguard Worker     }
3861*4bdc9457SAndroid Build Coastguard Worker   }
3862*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,channels_lt_8_unipass_subtile_with_input_offset)3863*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, channels_lt_8_unipass_subtile_with_input_offset) {
3864*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
3865*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
3866*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 1; channels < 8; channels++) {
3867*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
3868*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
3869*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9)
3870*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
3871*4bdc9457SAndroid Build Coastguard Worker           .input_offset(11)
3872*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
3873*4bdc9457SAndroid Build Coastguard Worker       }
3874*4bdc9457SAndroid Build Coastguard Worker     }
3875*4bdc9457SAndroid Build Coastguard Worker   }
3876*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,channels_lt_8_unipass_subtile_with_zero)3877*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, channels_lt_8_unipass_subtile_with_zero) {
3878*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
3879*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
3880*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 1; channels < 8; channels++) {
3881*4bdc9457SAndroid Build Coastguard Worker         for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
3882*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
3883*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
3884*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9)
3885*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
3886*4bdc9457SAndroid Build Coastguard Worker             .input_offset(11)
3887*4bdc9457SAndroid Build Coastguard Worker             .zero_index(zero_index)
3888*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
3889*4bdc9457SAndroid Build Coastguard Worker         }
3890*4bdc9457SAndroid Build Coastguard Worker       }
3891*4bdc9457SAndroid Build Coastguard Worker     }
3892*4bdc9457SAndroid Build Coastguard Worker   }
3893*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,channels_gt_8_unipass_fulltile)3894*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, channels_gt_8_unipass_fulltile) {
3895*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
3896*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 9; channels < 16; channels++) {
3897*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
3898*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(9)
3899*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9)
3900*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
3901*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
3902*4bdc9457SAndroid Build Coastguard Worker     }
3903*4bdc9457SAndroid Build Coastguard Worker   }
3904*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,channels_gt_8_unipass_fulltile_with_input_offset)3905*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, channels_gt_8_unipass_fulltile_with_input_offset) {
3906*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
3907*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 9; channels < 16; channels++) {
3908*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
3909*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(9)
3910*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9)
3911*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
3912*4bdc9457SAndroid Build Coastguard Worker         .input_offset(17)
3913*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
3914*4bdc9457SAndroid Build Coastguard Worker     }
3915*4bdc9457SAndroid Build Coastguard Worker   }
3916*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,channels_gt_8_unipass_fulltile_with_zero)3917*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, channels_gt_8_unipass_fulltile_with_zero) {
3918*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
3919*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 9; channels < 16; channels++) {
3920*4bdc9457SAndroid Build Coastguard Worker       for (size_t zero_index = 0; zero_index < 9; zero_index++) {
3921*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
3922*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(9)
3923*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9)
3924*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
3925*4bdc9457SAndroid Build Coastguard Worker           .input_offset(17)
3926*4bdc9457SAndroid Build Coastguard Worker           .zero_index(zero_index)
3927*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
3928*4bdc9457SAndroid Build Coastguard Worker       }
3929*4bdc9457SAndroid Build Coastguard Worker     }
3930*4bdc9457SAndroid Build Coastguard Worker   }
3931*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,channels_gt_8_unipass_fulltile_with_input_scale)3932*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, channels_gt_8_unipass_fulltile_with_input_scale) {
3933*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
3934*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 9; channels < 16; channels++) {
3935*4bdc9457SAndroid Build Coastguard Worker       for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
3936*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
3937*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(9)
3938*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9)
3939*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
3940*4bdc9457SAndroid Build Coastguard Worker           .input_scale(scale)
3941*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
3942*4bdc9457SAndroid Build Coastguard Worker       }
3943*4bdc9457SAndroid Build Coastguard Worker     }
3944*4bdc9457SAndroid Build Coastguard Worker   }
3945*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,channels_gt_8_unipass_fulltile_with_input_zero_point)3946*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, channels_gt_8_unipass_fulltile_with_input_zero_point) {
3947*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
3948*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 9; channels < 16; channels++) {
3949*4bdc9457SAndroid Build Coastguard Worker       for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
3950*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
3951*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(9)
3952*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9)
3953*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
3954*4bdc9457SAndroid Build Coastguard Worker           .input_zero_point(zero_point)
3955*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
3956*4bdc9457SAndroid Build Coastguard Worker       }
3957*4bdc9457SAndroid Build Coastguard Worker     }
3958*4bdc9457SAndroid Build Coastguard Worker   }
3959*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,channels_gt_8_unipass_fulltile_with_output_scale)3960*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, channels_gt_8_unipass_fulltile_with_output_scale) {
3961*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
3962*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 9; channels < 16; channels++) {
3963*4bdc9457SAndroid Build Coastguard Worker       for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
3964*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
3965*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(9)
3966*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9)
3967*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
3968*4bdc9457SAndroid Build Coastguard Worker           .output_scale(scale)
3969*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
3970*4bdc9457SAndroid Build Coastguard Worker       }
3971*4bdc9457SAndroid Build Coastguard Worker     }
3972*4bdc9457SAndroid Build Coastguard Worker   }
3973*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,channels_gt_8_unipass_fulltile_with_output_zero_point)3974*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, channels_gt_8_unipass_fulltile_with_output_zero_point) {
3975*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
3976*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 9; channels < 16; channels++) {
3977*4bdc9457SAndroid Build Coastguard Worker       for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
3978*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
3979*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(9)
3980*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9)
3981*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
3982*4bdc9457SAndroid Build Coastguard Worker           .output_zero_point(zero_point)
3983*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
3984*4bdc9457SAndroid Build Coastguard Worker       }
3985*4bdc9457SAndroid Build Coastguard Worker     }
3986*4bdc9457SAndroid Build Coastguard Worker   }
3987*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,channels_gt_8_unipass_fulltile_with_qmin)3988*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, channels_gt_8_unipass_fulltile_with_qmin) {
3989*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
3990*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 9; channels < 16; channels++) {
3991*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
3992*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(9)
3993*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9)
3994*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
3995*4bdc9457SAndroid Build Coastguard Worker         .qmin(128)
3996*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
3997*4bdc9457SAndroid Build Coastguard Worker     }
3998*4bdc9457SAndroid Build Coastguard Worker   }
3999*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,channels_gt_8_unipass_fulltile_with_qmax)4000*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, channels_gt_8_unipass_fulltile_with_qmax) {
4001*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
4002*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 9; channels < 16; channels++) {
4003*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
4004*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(9)
4005*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9)
4006*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
4007*4bdc9457SAndroid Build Coastguard Worker         .qmax(128)
4008*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
4009*4bdc9457SAndroid Build Coastguard Worker     }
4010*4bdc9457SAndroid Build Coastguard Worker   }
4011*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,channels_gt_8_unipass_subtile)4012*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, channels_gt_8_unipass_subtile) {
4013*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
4014*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
4015*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 9; channels < 16; channels++) {
4016*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
4017*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
4018*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9)
4019*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
4020*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
4021*4bdc9457SAndroid Build Coastguard Worker       }
4022*4bdc9457SAndroid Build Coastguard Worker     }
4023*4bdc9457SAndroid Build Coastguard Worker   }
4024*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,channels_gt_8_unipass_subtile_with_input_offset)4025*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, channels_gt_8_unipass_subtile_with_input_offset) {
4026*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
4027*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
4028*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 9; channels < 16; channels++) {
4029*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
4030*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
4031*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9)
4032*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
4033*4bdc9457SAndroid Build Coastguard Worker           .input_offset(17)
4034*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
4035*4bdc9457SAndroid Build Coastguard Worker       }
4036*4bdc9457SAndroid Build Coastguard Worker     }
4037*4bdc9457SAndroid Build Coastguard Worker   }
4038*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,channels_gt_8_unipass_subtile_with_zero)4039*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, channels_gt_8_unipass_subtile_with_zero) {
4040*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
4041*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
4042*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 9; channels < 16; channels++) {
4043*4bdc9457SAndroid Build Coastguard Worker         for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
4044*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
4045*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
4046*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9)
4047*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
4048*4bdc9457SAndroid Build Coastguard Worker             .input_offset(17)
4049*4bdc9457SAndroid Build Coastguard Worker             .zero_index(zero_index)
4050*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
4051*4bdc9457SAndroid Build Coastguard Worker         }
4052*4bdc9457SAndroid Build Coastguard Worker       }
4053*4bdc9457SAndroid Build Coastguard Worker     }
4054*4bdc9457SAndroid Build Coastguard Worker   }
4055*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,few_output_pixels)4056*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, few_output_pixels) {
4057*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
4058*4bdc9457SAndroid Build Coastguard Worker     for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
4059*4bdc9457SAndroid Build Coastguard Worker       for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
4060*4bdc9457SAndroid Build Coastguard Worker         for (size_t channels = 1; channels <= 40; channels += 7) {
4061*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
4062*4bdc9457SAndroid Build Coastguard Worker             .output_pixels(output_pixels)
4063*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
4064*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 0)
4065*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
4066*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
4067*4bdc9457SAndroid Build Coastguard Worker         }
4068*4bdc9457SAndroid Build Coastguard Worker       }
4069*4bdc9457SAndroid Build Coastguard Worker     }
4070*4bdc9457SAndroid Build Coastguard Worker   }
4071*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,few_output_pixels_with_input_offset)4072*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, few_output_pixels_with_input_offset) {
4073*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
4074*4bdc9457SAndroid Build Coastguard Worker     for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
4075*4bdc9457SAndroid Build Coastguard Worker       for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
4076*4bdc9457SAndroid Build Coastguard Worker         for (size_t channels = 1; channels <= 40; channels += 7) {
4077*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
4078*4bdc9457SAndroid Build Coastguard Worker             .output_pixels(output_pixels)
4079*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
4080*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 0)
4081*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
4082*4bdc9457SAndroid Build Coastguard Worker             .input_offset(43)
4083*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
4084*4bdc9457SAndroid Build Coastguard Worker         }
4085*4bdc9457SAndroid Build Coastguard Worker       }
4086*4bdc9457SAndroid Build Coastguard Worker     }
4087*4bdc9457SAndroid Build Coastguard Worker   }
4088*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,few_output_pixels_with_zero)4089*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, few_output_pixels_with_zero) {
4090*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
4091*4bdc9457SAndroid Build Coastguard Worker     for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
4092*4bdc9457SAndroid Build Coastguard Worker       for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
4093*4bdc9457SAndroid Build Coastguard Worker         for (size_t channels = 1; channels <= 40; channels += 7) {
4094*4bdc9457SAndroid Build Coastguard Worker           for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
4095*4bdc9457SAndroid Build Coastguard Worker             AvgPoolMicrokernelTester()
4096*4bdc9457SAndroid Build Coastguard Worker               .output_pixels(output_pixels)
4097*4bdc9457SAndroid Build Coastguard Worker               .pooling_elements(pooling_elements)
4098*4bdc9457SAndroid Build Coastguard Worker               .pooling_tile(9, 0)
4099*4bdc9457SAndroid Build Coastguard Worker               .channels(channels)
4100*4bdc9457SAndroid Build Coastguard Worker               .input_offset(43)
4101*4bdc9457SAndroid Build Coastguard Worker               .zero_index(zero_index)
4102*4bdc9457SAndroid Build Coastguard Worker               .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
4103*4bdc9457SAndroid Build Coastguard Worker           }
4104*4bdc9457SAndroid Build Coastguard Worker         }
4105*4bdc9457SAndroid Build Coastguard Worker       }
4106*4bdc9457SAndroid Build Coastguard Worker     }
4107*4bdc9457SAndroid Build Coastguard Worker   }
4108*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,few_output_pixels_with_input_scale)4109*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, few_output_pixels_with_input_scale) {
4110*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
4111*4bdc9457SAndroid Build Coastguard Worker     for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
4112*4bdc9457SAndroid Build Coastguard Worker       for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
4113*4bdc9457SAndroid Build Coastguard Worker         for (size_t channels = 1; channels <= 40; channels += 7) {
4114*4bdc9457SAndroid Build Coastguard Worker           for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
4115*4bdc9457SAndroid Build Coastguard Worker             AvgPoolMicrokernelTester()
4116*4bdc9457SAndroid Build Coastguard Worker               .output_pixels(output_pixels)
4117*4bdc9457SAndroid Build Coastguard Worker               .pooling_elements(pooling_elements)
4118*4bdc9457SAndroid Build Coastguard Worker               .pooling_tile(9)
4119*4bdc9457SAndroid Build Coastguard Worker               .channels(channels)
4120*4bdc9457SAndroid Build Coastguard Worker               .input_scale(scale)
4121*4bdc9457SAndroid Build Coastguard Worker               .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
4122*4bdc9457SAndroid Build Coastguard Worker           }
4123*4bdc9457SAndroid Build Coastguard Worker         }
4124*4bdc9457SAndroid Build Coastguard Worker       }
4125*4bdc9457SAndroid Build Coastguard Worker     }
4126*4bdc9457SAndroid Build Coastguard Worker   }
4127*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,few_output_pixels_with_input_zero_point)4128*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, few_output_pixels_with_input_zero_point) {
4129*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
4130*4bdc9457SAndroid Build Coastguard Worker     for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
4131*4bdc9457SAndroid Build Coastguard Worker       for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
4132*4bdc9457SAndroid Build Coastguard Worker         for (size_t channels = 1; channels <= 40; channels += 7) {
4133*4bdc9457SAndroid Build Coastguard Worker           for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
4134*4bdc9457SAndroid Build Coastguard Worker             AvgPoolMicrokernelTester()
4135*4bdc9457SAndroid Build Coastguard Worker               .output_pixels(output_pixels)
4136*4bdc9457SAndroid Build Coastguard Worker               .pooling_elements(pooling_elements)
4137*4bdc9457SAndroid Build Coastguard Worker               .pooling_tile(9)
4138*4bdc9457SAndroid Build Coastguard Worker               .channels(channels)
4139*4bdc9457SAndroid Build Coastguard Worker               .input_zero_point(zero_point)
4140*4bdc9457SAndroid Build Coastguard Worker               .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
4141*4bdc9457SAndroid Build Coastguard Worker           }
4142*4bdc9457SAndroid Build Coastguard Worker         }
4143*4bdc9457SAndroid Build Coastguard Worker       }
4144*4bdc9457SAndroid Build Coastguard Worker     }
4145*4bdc9457SAndroid Build Coastguard Worker   }
4146*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,few_output_pixels_with_output_scale)4147*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, few_output_pixels_with_output_scale) {
4148*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
4149*4bdc9457SAndroid Build Coastguard Worker     for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
4150*4bdc9457SAndroid Build Coastguard Worker       for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
4151*4bdc9457SAndroid Build Coastguard Worker         for (size_t channels = 1; channels <= 40; channels += 7) {
4152*4bdc9457SAndroid Build Coastguard Worker           for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
4153*4bdc9457SAndroid Build Coastguard Worker             AvgPoolMicrokernelTester()
4154*4bdc9457SAndroid Build Coastguard Worker               .output_pixels(output_pixels)
4155*4bdc9457SAndroid Build Coastguard Worker               .pooling_elements(pooling_elements)
4156*4bdc9457SAndroid Build Coastguard Worker               .pooling_tile(9)
4157*4bdc9457SAndroid Build Coastguard Worker               .channels(channels)
4158*4bdc9457SAndroid Build Coastguard Worker               .output_scale(scale)
4159*4bdc9457SAndroid Build Coastguard Worker               .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
4160*4bdc9457SAndroid Build Coastguard Worker           }
4161*4bdc9457SAndroid Build Coastguard Worker         }
4162*4bdc9457SAndroid Build Coastguard Worker       }
4163*4bdc9457SAndroid Build Coastguard Worker     }
4164*4bdc9457SAndroid Build Coastguard Worker   }
4165*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,few_output_pixels_with_output_zero_point)4166*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, few_output_pixels_with_output_zero_point) {
4167*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
4168*4bdc9457SAndroid Build Coastguard Worker     for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
4169*4bdc9457SAndroid Build Coastguard Worker       for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
4170*4bdc9457SAndroid Build Coastguard Worker         for (size_t channels = 1; channels <= 40; channels += 7) {
4171*4bdc9457SAndroid Build Coastguard Worker           for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
4172*4bdc9457SAndroid Build Coastguard Worker             AvgPoolMicrokernelTester()
4173*4bdc9457SAndroid Build Coastguard Worker               .output_pixels(output_pixels)
4174*4bdc9457SAndroid Build Coastguard Worker               .pooling_elements(pooling_elements)
4175*4bdc9457SAndroid Build Coastguard Worker               .pooling_tile(9)
4176*4bdc9457SAndroid Build Coastguard Worker               .channels(channels)
4177*4bdc9457SAndroid Build Coastguard Worker               .output_zero_point(zero_point)
4178*4bdc9457SAndroid Build Coastguard Worker               .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
4179*4bdc9457SAndroid Build Coastguard Worker           }
4180*4bdc9457SAndroid Build Coastguard Worker         }
4181*4bdc9457SAndroid Build Coastguard Worker       }
4182*4bdc9457SAndroid Build Coastguard Worker     }
4183*4bdc9457SAndroid Build Coastguard Worker   }
4184*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,few_output_pixels_with_qmin)4185*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, few_output_pixels_with_qmin) {
4186*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
4187*4bdc9457SAndroid Build Coastguard Worker     for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
4188*4bdc9457SAndroid Build Coastguard Worker       for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
4189*4bdc9457SAndroid Build Coastguard Worker         for (size_t channels = 1; channels <= 40; channels += 7) {
4190*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
4191*4bdc9457SAndroid Build Coastguard Worker             .output_pixels(output_pixels)
4192*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
4193*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 0)
4194*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
4195*4bdc9457SAndroid Build Coastguard Worker             .qmin(128)
4196*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
4197*4bdc9457SAndroid Build Coastguard Worker         }
4198*4bdc9457SAndroid Build Coastguard Worker       }
4199*4bdc9457SAndroid Build Coastguard Worker     }
4200*4bdc9457SAndroid Build Coastguard Worker   }
4201*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,few_output_pixels_with_qmax)4202*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, few_output_pixels_with_qmax) {
4203*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
4204*4bdc9457SAndroid Build Coastguard Worker     for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
4205*4bdc9457SAndroid Build Coastguard Worker       for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
4206*4bdc9457SAndroid Build Coastguard Worker         for (size_t channels = 1; channels <= 40; channels += 7) {
4207*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
4208*4bdc9457SAndroid Build Coastguard Worker             .output_pixels(output_pixels)
4209*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
4210*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 0)
4211*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
4212*4bdc9457SAndroid Build Coastguard Worker             .qmax(128)
4213*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
4214*4bdc9457SAndroid Build Coastguard Worker         }
4215*4bdc9457SAndroid Build Coastguard Worker       }
4216*4bdc9457SAndroid Build Coastguard Worker     }
4217*4bdc9457SAndroid Build Coastguard Worker   }
4218*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,few_output_pixels_with_output_stride)4219*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, few_output_pixels_with_output_stride) {
4220*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
4221*4bdc9457SAndroid Build Coastguard Worker     for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
4222*4bdc9457SAndroid Build Coastguard Worker       for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
4223*4bdc9457SAndroid Build Coastguard Worker         for (size_t channels = 1; channels <= 40; channels += 7) {
4224*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
4225*4bdc9457SAndroid Build Coastguard Worker             .output_pixels(output_pixels)
4226*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
4227*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 0)
4228*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
4229*4bdc9457SAndroid Build Coastguard Worker             .output_stride(43)
4230*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
4231*4bdc9457SAndroid Build Coastguard Worker         }
4232*4bdc9457SAndroid Build Coastguard Worker       }
4233*4bdc9457SAndroid Build Coastguard Worker     }
4234*4bdc9457SAndroid Build Coastguard Worker   }
4235*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8,few_output_pixels_with_step)4236*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__NEON_C8, few_output_pixels_with_step) {
4237*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_ARM_NEON;
4238*4bdc9457SAndroid Build Coastguard Worker     for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
4239*4bdc9457SAndroid Build Coastguard Worker       for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
4240*4bdc9457SAndroid Build Coastguard Worker         for (size_t channels = 1; channels <= 40; channels += 7) {
4241*4bdc9457SAndroid Build Coastguard Worker           for (size_t step = 2; step <= pooling_elements; step++) {
4242*4bdc9457SAndroid Build Coastguard Worker             AvgPoolMicrokernelTester()
4243*4bdc9457SAndroid Build Coastguard Worker               .output_pixels(output_pixels)
4244*4bdc9457SAndroid Build Coastguard Worker               .pooling_elements(pooling_elements)
4245*4bdc9457SAndroid Build Coastguard Worker               .pooling_tile(9, 0)
4246*4bdc9457SAndroid Build Coastguard Worker               .step(step)
4247*4bdc9457SAndroid Build Coastguard Worker               .channels(channels)
4248*4bdc9457SAndroid Build Coastguard Worker               .output_stride(43)
4249*4bdc9457SAndroid Build Coastguard Worker               .Test(xnn_qu8_avgpool_minmax_ukernel_9x__neon_c8, xnn_init_qu8_avgpool_minmax_neon_params);
4250*4bdc9457SAndroid Build Coastguard Worker           }
4251*4bdc9457SAndroid Build Coastguard Worker         }
4252*4bdc9457SAndroid Build Coastguard Worker       }
4253*4bdc9457SAndroid Build Coastguard Worker     }
4254*4bdc9457SAndroid Build Coastguard Worker   }
4255*4bdc9457SAndroid Build Coastguard Worker #endif  // XNN_ARCH_ARM || XNN_ARCH_ARM64
4256*4bdc9457SAndroid Build Coastguard Worker 
4257*4bdc9457SAndroid Build Coastguard Worker 
4258*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,channels_eq_8_unipass_fulltile)4259*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, channels_eq_8_unipass_fulltile) {
4260*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4261*4bdc9457SAndroid Build Coastguard Worker     AvgPoolMicrokernelTester()
4262*4bdc9457SAndroid Build Coastguard Worker       .pooling_elements(9)
4263*4bdc9457SAndroid Build Coastguard Worker       .pooling_tile(9)
4264*4bdc9457SAndroid Build Coastguard Worker       .channels(8)
4265*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4266*4bdc9457SAndroid Build Coastguard Worker   }
4267*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,channels_eq_8_unipass_fulltile_with_input_offset)4268*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, channels_eq_8_unipass_fulltile_with_input_offset) {
4269*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4270*4bdc9457SAndroid Build Coastguard Worker     AvgPoolMicrokernelTester()
4271*4bdc9457SAndroid Build Coastguard Worker       .pooling_elements(9)
4272*4bdc9457SAndroid Build Coastguard Worker       .pooling_tile(9)
4273*4bdc9457SAndroid Build Coastguard Worker       .channels(8)
4274*4bdc9457SAndroid Build Coastguard Worker       .input_offset(11)
4275*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4276*4bdc9457SAndroid Build Coastguard Worker   }
4277*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,channels_eq_8_unipass_fulltile_with_zero)4278*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, channels_eq_8_unipass_fulltile_with_zero) {
4279*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4280*4bdc9457SAndroid Build Coastguard Worker     for (size_t zero_index = 0; zero_index < 9; zero_index++) {
4281*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
4282*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(9)
4283*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9)
4284*4bdc9457SAndroid Build Coastguard Worker         .channels(8)
4285*4bdc9457SAndroid Build Coastguard Worker         .input_offset(11)
4286*4bdc9457SAndroid Build Coastguard Worker         .zero_index(zero_index)
4287*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4288*4bdc9457SAndroid Build Coastguard Worker     }
4289*4bdc9457SAndroid Build Coastguard Worker   }
4290*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,channels_eq_8_unipass_fulltile_with_input_scale)4291*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, channels_eq_8_unipass_fulltile_with_input_scale) {
4292*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4293*4bdc9457SAndroid Build Coastguard Worker     for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
4294*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
4295*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(9)
4296*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9)
4297*4bdc9457SAndroid Build Coastguard Worker         .channels(8)
4298*4bdc9457SAndroid Build Coastguard Worker         .input_scale(scale)
4299*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4300*4bdc9457SAndroid Build Coastguard Worker     }
4301*4bdc9457SAndroid Build Coastguard Worker   }
4302*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,channels_eq_8_unipass_fulltile_with_input_zero_point)4303*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, channels_eq_8_unipass_fulltile_with_input_zero_point) {
4304*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4305*4bdc9457SAndroid Build Coastguard Worker     for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
4306*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
4307*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(9)
4308*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9)
4309*4bdc9457SAndroid Build Coastguard Worker         .channels(8)
4310*4bdc9457SAndroid Build Coastguard Worker         .input_zero_point(zero_point)
4311*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4312*4bdc9457SAndroid Build Coastguard Worker     }
4313*4bdc9457SAndroid Build Coastguard Worker   }
4314*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,channels_eq_8_unipass_fulltile_with_output_scale)4315*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, channels_eq_8_unipass_fulltile_with_output_scale) {
4316*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4317*4bdc9457SAndroid Build Coastguard Worker     for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
4318*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
4319*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(9)
4320*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9)
4321*4bdc9457SAndroid Build Coastguard Worker         .channels(8)
4322*4bdc9457SAndroid Build Coastguard Worker         .output_scale(scale)
4323*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4324*4bdc9457SAndroid Build Coastguard Worker     }
4325*4bdc9457SAndroid Build Coastguard Worker   }
4326*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,channels_eq_8_unipass_fulltile_with_output_zero_point)4327*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, channels_eq_8_unipass_fulltile_with_output_zero_point) {
4328*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4329*4bdc9457SAndroid Build Coastguard Worker     for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
4330*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
4331*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(9)
4332*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9)
4333*4bdc9457SAndroid Build Coastguard Worker         .channels(8)
4334*4bdc9457SAndroid Build Coastguard Worker         .output_zero_point(zero_point)
4335*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4336*4bdc9457SAndroid Build Coastguard Worker     }
4337*4bdc9457SAndroid Build Coastguard Worker   }
4338*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,channels_eq_8_unipass_fulltile_with_qmin)4339*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, channels_eq_8_unipass_fulltile_with_qmin) {
4340*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4341*4bdc9457SAndroid Build Coastguard Worker     AvgPoolMicrokernelTester()
4342*4bdc9457SAndroid Build Coastguard Worker       .pooling_elements(9)
4343*4bdc9457SAndroid Build Coastguard Worker       .pooling_tile(9)
4344*4bdc9457SAndroid Build Coastguard Worker       .channels(8)
4345*4bdc9457SAndroid Build Coastguard Worker       .qmin(128)
4346*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4347*4bdc9457SAndroid Build Coastguard Worker   }
4348*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,channels_eq_8_unipass_fulltile_with_qmax)4349*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, channels_eq_8_unipass_fulltile_with_qmax) {
4350*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4351*4bdc9457SAndroid Build Coastguard Worker     AvgPoolMicrokernelTester()
4352*4bdc9457SAndroid Build Coastguard Worker       .pooling_elements(9)
4353*4bdc9457SAndroid Build Coastguard Worker       .pooling_tile(9)
4354*4bdc9457SAndroid Build Coastguard Worker       .channels(8)
4355*4bdc9457SAndroid Build Coastguard Worker       .qmax(128)
4356*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4357*4bdc9457SAndroid Build Coastguard Worker   }
4358*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,channels_eq_8_unipass_subtile)4359*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, channels_eq_8_unipass_subtile) {
4360*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4361*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
4362*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
4363*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(pooling_elements)
4364*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9)
4365*4bdc9457SAndroid Build Coastguard Worker         .channels(8)
4366*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4367*4bdc9457SAndroid Build Coastguard Worker     }
4368*4bdc9457SAndroid Build Coastguard Worker   }
4369*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,channels_eq_8_unipass_subtile_with_input_offset)4370*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, channels_eq_8_unipass_subtile_with_input_offset) {
4371*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4372*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
4373*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
4374*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(pooling_elements)
4375*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9)
4376*4bdc9457SAndroid Build Coastguard Worker         .channels(8)
4377*4bdc9457SAndroid Build Coastguard Worker         .input_offset(11)
4378*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4379*4bdc9457SAndroid Build Coastguard Worker     }
4380*4bdc9457SAndroid Build Coastguard Worker   }
4381*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,channels_eq_8_unipass_subtile_with_zero)4382*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, channels_eq_8_unipass_subtile_with_zero) {
4383*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4384*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
4385*4bdc9457SAndroid Build Coastguard Worker       for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
4386*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
4387*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
4388*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9)
4389*4bdc9457SAndroid Build Coastguard Worker           .channels(8)
4390*4bdc9457SAndroid Build Coastguard Worker           .input_offset(11)
4391*4bdc9457SAndroid Build Coastguard Worker           .zero_index(zero_index)
4392*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4393*4bdc9457SAndroid Build Coastguard Worker       }
4394*4bdc9457SAndroid Build Coastguard Worker     }
4395*4bdc9457SAndroid Build Coastguard Worker   }
4396*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,channels_div_8_unipass_fulltile)4397*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, channels_div_8_unipass_fulltile) {
4398*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4399*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 16; channels < 64; channels += 8) {
4400*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
4401*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(9)
4402*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9)
4403*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
4404*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4405*4bdc9457SAndroid Build Coastguard Worker     }
4406*4bdc9457SAndroid Build Coastguard Worker   }
4407*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,channels_div_8_unipass_fulltile_with_input_offset)4408*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, channels_div_8_unipass_fulltile_with_input_offset) {
4409*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4410*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 16; channels < 64; channels += 8) {
4411*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
4412*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(9)
4413*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9)
4414*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
4415*4bdc9457SAndroid Build Coastguard Worker         .input_offset(67)
4416*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4417*4bdc9457SAndroid Build Coastguard Worker     }
4418*4bdc9457SAndroid Build Coastguard Worker   }
4419*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,channels_div_8_unipass_fulltile_with_zero)4420*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, channels_div_8_unipass_fulltile_with_zero) {
4421*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4422*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 16; channels < 64; channels += 8) {
4423*4bdc9457SAndroid Build Coastguard Worker       for (size_t zero_index = 0; zero_index < 9; zero_index++) {
4424*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
4425*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(9)
4426*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9)
4427*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
4428*4bdc9457SAndroid Build Coastguard Worker           .input_offset(67)
4429*4bdc9457SAndroid Build Coastguard Worker           .zero_index(zero_index)
4430*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4431*4bdc9457SAndroid Build Coastguard Worker       }
4432*4bdc9457SAndroid Build Coastguard Worker     }
4433*4bdc9457SAndroid Build Coastguard Worker   }
4434*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,channels_div_8_unipass_fulltile_with_input_scale)4435*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, channels_div_8_unipass_fulltile_with_input_scale) {
4436*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4437*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 16; channels < 64; channels += 8) {
4438*4bdc9457SAndroid Build Coastguard Worker       for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
4439*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
4440*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(9)
4441*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9)
4442*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
4443*4bdc9457SAndroid Build Coastguard Worker           .input_scale(scale)
4444*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4445*4bdc9457SAndroid Build Coastguard Worker       }
4446*4bdc9457SAndroid Build Coastguard Worker     }
4447*4bdc9457SAndroid Build Coastguard Worker   }
4448*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,channels_div_8_unipass_fulltile_with_input_zero_point)4449*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, channels_div_8_unipass_fulltile_with_input_zero_point) {
4450*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4451*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 16; channels < 64; channels += 8) {
4452*4bdc9457SAndroid Build Coastguard Worker       for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
4453*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
4454*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(9)
4455*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9)
4456*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
4457*4bdc9457SAndroid Build Coastguard Worker           .input_zero_point(zero_point)
4458*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4459*4bdc9457SAndroid Build Coastguard Worker       }
4460*4bdc9457SAndroid Build Coastguard Worker     }
4461*4bdc9457SAndroid Build Coastguard Worker   }
4462*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,channels_div_8_unipass_fulltile_with_output_scale)4463*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, channels_div_8_unipass_fulltile_with_output_scale) {
4464*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4465*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 16; channels < 64; channels += 8) {
4466*4bdc9457SAndroid Build Coastguard Worker       for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
4467*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
4468*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(9)
4469*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9)
4470*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
4471*4bdc9457SAndroid Build Coastguard Worker           .output_scale(scale)
4472*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4473*4bdc9457SAndroid Build Coastguard Worker       }
4474*4bdc9457SAndroid Build Coastguard Worker     }
4475*4bdc9457SAndroid Build Coastguard Worker   }
4476*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,channels_div_8_unipass_fulltile_with_output_zero_point)4477*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, channels_div_8_unipass_fulltile_with_output_zero_point) {
4478*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4479*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 16; channels < 64; channels += 8) {
4480*4bdc9457SAndroid Build Coastguard Worker       for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
4481*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
4482*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(9)
4483*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9)
4484*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
4485*4bdc9457SAndroid Build Coastguard Worker           .output_zero_point(zero_point)
4486*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4487*4bdc9457SAndroid Build Coastguard Worker       }
4488*4bdc9457SAndroid Build Coastguard Worker     }
4489*4bdc9457SAndroid Build Coastguard Worker   }
4490*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,channels_div_8_unipass_fulltile_with_qmin)4491*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, channels_div_8_unipass_fulltile_with_qmin) {
4492*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4493*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 16; channels < 64; channels += 8) {
4494*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
4495*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(9)
4496*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9)
4497*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
4498*4bdc9457SAndroid Build Coastguard Worker         .qmin(128)
4499*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4500*4bdc9457SAndroid Build Coastguard Worker     }
4501*4bdc9457SAndroid Build Coastguard Worker   }
4502*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,channels_div_8_unipass_fulltile_with_qmax)4503*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, channels_div_8_unipass_fulltile_with_qmax) {
4504*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4505*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 16; channels < 64; channels += 8) {
4506*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
4507*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(9)
4508*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9)
4509*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
4510*4bdc9457SAndroid Build Coastguard Worker         .qmax(128)
4511*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4512*4bdc9457SAndroid Build Coastguard Worker     }
4513*4bdc9457SAndroid Build Coastguard Worker   }
4514*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,channels_div_8_unipass_subtile)4515*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, channels_div_8_unipass_subtile) {
4516*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4517*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
4518*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 16; channels < 64; channels += 8) {
4519*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
4520*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
4521*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9)
4522*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
4523*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4524*4bdc9457SAndroid Build Coastguard Worker       }
4525*4bdc9457SAndroid Build Coastguard Worker     }
4526*4bdc9457SAndroid Build Coastguard Worker   }
4527*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,channels_div_8_unipass_subtile_with_input_offset)4528*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, channels_div_8_unipass_subtile_with_input_offset) {
4529*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4530*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
4531*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 16; channels < 64; channels += 8) {
4532*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
4533*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
4534*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9)
4535*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
4536*4bdc9457SAndroid Build Coastguard Worker           .input_offset(67)
4537*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4538*4bdc9457SAndroid Build Coastguard Worker       }
4539*4bdc9457SAndroid Build Coastguard Worker     }
4540*4bdc9457SAndroid Build Coastguard Worker   }
4541*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,channels_div_8_unipass_subtile_with_zero)4542*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, channels_div_8_unipass_subtile_with_zero) {
4543*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4544*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
4545*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 16; channels < 64; channels += 8) {
4546*4bdc9457SAndroid Build Coastguard Worker         for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
4547*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
4548*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
4549*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9)
4550*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
4551*4bdc9457SAndroid Build Coastguard Worker             .input_offset(67)
4552*4bdc9457SAndroid Build Coastguard Worker             .zero_index(zero_index)
4553*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4554*4bdc9457SAndroid Build Coastguard Worker         }
4555*4bdc9457SAndroid Build Coastguard Worker       }
4556*4bdc9457SAndroid Build Coastguard Worker     }
4557*4bdc9457SAndroid Build Coastguard Worker   }
4558*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,channels_lt_8_unipass_fulltile)4559*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, channels_lt_8_unipass_fulltile) {
4560*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4561*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 1; channels < 8; channels++) {
4562*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
4563*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(9)
4564*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9)
4565*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
4566*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4567*4bdc9457SAndroid Build Coastguard Worker     }
4568*4bdc9457SAndroid Build Coastguard Worker   }
4569*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,channels_lt_8_unipass_fulltile_with_input_offset)4570*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, channels_lt_8_unipass_fulltile_with_input_offset) {
4571*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4572*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 1; channels < 8; channels++) {
4573*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
4574*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(9)
4575*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9)
4576*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
4577*4bdc9457SAndroid Build Coastguard Worker         .input_offset(11)
4578*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4579*4bdc9457SAndroid Build Coastguard Worker     }
4580*4bdc9457SAndroid Build Coastguard Worker   }
4581*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,channels_lt_8_unipass_fulltile_with_zero)4582*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, channels_lt_8_unipass_fulltile_with_zero) {
4583*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4584*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 1; channels < 8; channels++) {
4585*4bdc9457SAndroid Build Coastguard Worker       for (size_t zero_index = 0; zero_index < 9; zero_index++) {
4586*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
4587*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(9)
4588*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9)
4589*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
4590*4bdc9457SAndroid Build Coastguard Worker           .input_offset(11)
4591*4bdc9457SAndroid Build Coastguard Worker           .zero_index(zero_index)
4592*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4593*4bdc9457SAndroid Build Coastguard Worker       }
4594*4bdc9457SAndroid Build Coastguard Worker     }
4595*4bdc9457SAndroid Build Coastguard Worker   }
4596*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,channels_lt_8_unipass_fulltile_with_input_scale)4597*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, channels_lt_8_unipass_fulltile_with_input_scale) {
4598*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4599*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 1; channels < 8; channels++) {
4600*4bdc9457SAndroid Build Coastguard Worker       for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
4601*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
4602*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(9)
4603*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9)
4604*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
4605*4bdc9457SAndroid Build Coastguard Worker           .input_scale(scale)
4606*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4607*4bdc9457SAndroid Build Coastguard Worker       }
4608*4bdc9457SAndroid Build Coastguard Worker     }
4609*4bdc9457SAndroid Build Coastguard Worker   }
4610*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,channels_lt_8_unipass_fulltile_with_input_zero_point)4611*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, channels_lt_8_unipass_fulltile_with_input_zero_point) {
4612*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4613*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 1; channels < 8; channels++) {
4614*4bdc9457SAndroid Build Coastguard Worker       for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
4615*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
4616*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(9)
4617*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9)
4618*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
4619*4bdc9457SAndroid Build Coastguard Worker           .input_zero_point(zero_point)
4620*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4621*4bdc9457SAndroid Build Coastguard Worker       }
4622*4bdc9457SAndroid Build Coastguard Worker     }
4623*4bdc9457SAndroid Build Coastguard Worker   }
4624*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,channels_lt_8_unipass_fulltile_with_output_scale)4625*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, channels_lt_8_unipass_fulltile_with_output_scale) {
4626*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4627*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 1; channels < 8; channels++) {
4628*4bdc9457SAndroid Build Coastguard Worker       for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
4629*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
4630*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(9)
4631*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9)
4632*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
4633*4bdc9457SAndroid Build Coastguard Worker           .output_scale(scale)
4634*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4635*4bdc9457SAndroid Build Coastguard Worker       }
4636*4bdc9457SAndroid Build Coastguard Worker     }
4637*4bdc9457SAndroid Build Coastguard Worker   }
4638*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,channels_lt_8_unipass_fulltile_with_output_zero_point)4639*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, channels_lt_8_unipass_fulltile_with_output_zero_point) {
4640*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4641*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 1; channels < 8; channels++) {
4642*4bdc9457SAndroid Build Coastguard Worker       for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
4643*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
4644*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(9)
4645*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9)
4646*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
4647*4bdc9457SAndroid Build Coastguard Worker           .output_zero_point(zero_point)
4648*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4649*4bdc9457SAndroid Build Coastguard Worker       }
4650*4bdc9457SAndroid Build Coastguard Worker     }
4651*4bdc9457SAndroid Build Coastguard Worker   }
4652*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,channels_lt_8_unipass_fulltile_with_qmin)4653*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, channels_lt_8_unipass_fulltile_with_qmin) {
4654*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4655*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 1; channels < 8; channels++) {
4656*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
4657*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(9)
4658*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9)
4659*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
4660*4bdc9457SAndroid Build Coastguard Worker         .qmin(128)
4661*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4662*4bdc9457SAndroid Build Coastguard Worker     }
4663*4bdc9457SAndroid Build Coastguard Worker   }
4664*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,channels_lt_8_unipass_fulltile_with_qmax)4665*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, channels_lt_8_unipass_fulltile_with_qmax) {
4666*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4667*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 1; channels < 8; channels++) {
4668*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
4669*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(9)
4670*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9)
4671*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
4672*4bdc9457SAndroid Build Coastguard Worker         .qmax(128)
4673*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4674*4bdc9457SAndroid Build Coastguard Worker     }
4675*4bdc9457SAndroid Build Coastguard Worker   }
4676*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,channels_lt_8_unipass_subtile)4677*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, channels_lt_8_unipass_subtile) {
4678*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4679*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
4680*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 1; channels < 8; channels++) {
4681*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
4682*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
4683*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9)
4684*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
4685*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4686*4bdc9457SAndroid Build Coastguard Worker       }
4687*4bdc9457SAndroid Build Coastguard Worker     }
4688*4bdc9457SAndroid Build Coastguard Worker   }
4689*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,channels_lt_8_unipass_subtile_with_input_offset)4690*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, channels_lt_8_unipass_subtile_with_input_offset) {
4691*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4692*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
4693*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 1; channels < 8; channels++) {
4694*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
4695*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
4696*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9)
4697*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
4698*4bdc9457SAndroid Build Coastguard Worker           .input_offset(11)
4699*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4700*4bdc9457SAndroid Build Coastguard Worker       }
4701*4bdc9457SAndroid Build Coastguard Worker     }
4702*4bdc9457SAndroid Build Coastguard Worker   }
4703*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,channels_lt_8_unipass_subtile_with_zero)4704*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, channels_lt_8_unipass_subtile_with_zero) {
4705*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4706*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
4707*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 1; channels < 8; channels++) {
4708*4bdc9457SAndroid Build Coastguard Worker         for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
4709*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
4710*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
4711*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9)
4712*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
4713*4bdc9457SAndroid Build Coastguard Worker             .input_offset(11)
4714*4bdc9457SAndroid Build Coastguard Worker             .zero_index(zero_index)
4715*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4716*4bdc9457SAndroid Build Coastguard Worker         }
4717*4bdc9457SAndroid Build Coastguard Worker       }
4718*4bdc9457SAndroid Build Coastguard Worker     }
4719*4bdc9457SAndroid Build Coastguard Worker   }
4720*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,channels_gt_8_unipass_fulltile)4721*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, channels_gt_8_unipass_fulltile) {
4722*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4723*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 9; channels < 16; channels++) {
4724*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
4725*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(9)
4726*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9)
4727*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
4728*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4729*4bdc9457SAndroid Build Coastguard Worker     }
4730*4bdc9457SAndroid Build Coastguard Worker   }
4731*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,channels_gt_8_unipass_fulltile_with_input_offset)4732*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, channels_gt_8_unipass_fulltile_with_input_offset) {
4733*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4734*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 9; channels < 16; channels++) {
4735*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
4736*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(9)
4737*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9)
4738*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
4739*4bdc9457SAndroid Build Coastguard Worker         .input_offset(17)
4740*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4741*4bdc9457SAndroid Build Coastguard Worker     }
4742*4bdc9457SAndroid Build Coastguard Worker   }
4743*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,channels_gt_8_unipass_fulltile_with_zero)4744*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, channels_gt_8_unipass_fulltile_with_zero) {
4745*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4746*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 9; channels < 16; channels++) {
4747*4bdc9457SAndroid Build Coastguard Worker       for (size_t zero_index = 0; zero_index < 9; zero_index++) {
4748*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
4749*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(9)
4750*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9)
4751*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
4752*4bdc9457SAndroid Build Coastguard Worker           .input_offset(17)
4753*4bdc9457SAndroid Build Coastguard Worker           .zero_index(zero_index)
4754*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4755*4bdc9457SAndroid Build Coastguard Worker       }
4756*4bdc9457SAndroid Build Coastguard Worker     }
4757*4bdc9457SAndroid Build Coastguard Worker   }
4758*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,channels_gt_8_unipass_fulltile_with_input_scale)4759*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, channels_gt_8_unipass_fulltile_with_input_scale) {
4760*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4761*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 9; channels < 16; channels++) {
4762*4bdc9457SAndroid Build Coastguard Worker       for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
4763*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
4764*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(9)
4765*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9)
4766*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
4767*4bdc9457SAndroid Build Coastguard Worker           .input_scale(scale)
4768*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4769*4bdc9457SAndroid Build Coastguard Worker       }
4770*4bdc9457SAndroid Build Coastguard Worker     }
4771*4bdc9457SAndroid Build Coastguard Worker   }
4772*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,channels_gt_8_unipass_fulltile_with_input_zero_point)4773*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, channels_gt_8_unipass_fulltile_with_input_zero_point) {
4774*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4775*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 9; channels < 16; channels++) {
4776*4bdc9457SAndroid Build Coastguard Worker       for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
4777*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
4778*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(9)
4779*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9)
4780*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
4781*4bdc9457SAndroid Build Coastguard Worker           .input_zero_point(zero_point)
4782*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4783*4bdc9457SAndroid Build Coastguard Worker       }
4784*4bdc9457SAndroid Build Coastguard Worker     }
4785*4bdc9457SAndroid Build Coastguard Worker   }
4786*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,channels_gt_8_unipass_fulltile_with_output_scale)4787*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, channels_gt_8_unipass_fulltile_with_output_scale) {
4788*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4789*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 9; channels < 16; channels++) {
4790*4bdc9457SAndroid Build Coastguard Worker       for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
4791*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
4792*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(9)
4793*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9)
4794*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
4795*4bdc9457SAndroid Build Coastguard Worker           .output_scale(scale)
4796*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4797*4bdc9457SAndroid Build Coastguard Worker       }
4798*4bdc9457SAndroid Build Coastguard Worker     }
4799*4bdc9457SAndroid Build Coastguard Worker   }
4800*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,channels_gt_8_unipass_fulltile_with_output_zero_point)4801*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, channels_gt_8_unipass_fulltile_with_output_zero_point) {
4802*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4803*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 9; channels < 16; channels++) {
4804*4bdc9457SAndroid Build Coastguard Worker       for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
4805*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
4806*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(9)
4807*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9)
4808*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
4809*4bdc9457SAndroid Build Coastguard Worker           .output_zero_point(zero_point)
4810*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4811*4bdc9457SAndroid Build Coastguard Worker       }
4812*4bdc9457SAndroid Build Coastguard Worker     }
4813*4bdc9457SAndroid Build Coastguard Worker   }
4814*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,channels_gt_8_unipass_fulltile_with_qmin)4815*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, channels_gt_8_unipass_fulltile_with_qmin) {
4816*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4817*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 9; channels < 16; channels++) {
4818*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
4819*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(9)
4820*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9)
4821*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
4822*4bdc9457SAndroid Build Coastguard Worker         .qmin(128)
4823*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4824*4bdc9457SAndroid Build Coastguard Worker     }
4825*4bdc9457SAndroid Build Coastguard Worker   }
4826*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,channels_gt_8_unipass_fulltile_with_qmax)4827*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, channels_gt_8_unipass_fulltile_with_qmax) {
4828*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4829*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 9; channels < 16; channels++) {
4830*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
4831*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(9)
4832*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9)
4833*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
4834*4bdc9457SAndroid Build Coastguard Worker         .qmax(128)
4835*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4836*4bdc9457SAndroid Build Coastguard Worker     }
4837*4bdc9457SAndroid Build Coastguard Worker   }
4838*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,channels_gt_8_unipass_subtile)4839*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, channels_gt_8_unipass_subtile) {
4840*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4841*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
4842*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 9; channels < 16; channels++) {
4843*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
4844*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
4845*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9)
4846*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
4847*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4848*4bdc9457SAndroid Build Coastguard Worker       }
4849*4bdc9457SAndroid Build Coastguard Worker     }
4850*4bdc9457SAndroid Build Coastguard Worker   }
4851*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,channels_gt_8_unipass_subtile_with_input_offset)4852*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, channels_gt_8_unipass_subtile_with_input_offset) {
4853*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4854*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
4855*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 9; channels < 16; channels++) {
4856*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
4857*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
4858*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9)
4859*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
4860*4bdc9457SAndroid Build Coastguard Worker           .input_offset(17)
4861*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4862*4bdc9457SAndroid Build Coastguard Worker       }
4863*4bdc9457SAndroid Build Coastguard Worker     }
4864*4bdc9457SAndroid Build Coastguard Worker   }
4865*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,channels_gt_8_unipass_subtile_with_zero)4866*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, channels_gt_8_unipass_subtile_with_zero) {
4867*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4868*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
4869*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 9; channels < 16; channels++) {
4870*4bdc9457SAndroid Build Coastguard Worker         for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
4871*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
4872*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
4873*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9)
4874*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
4875*4bdc9457SAndroid Build Coastguard Worker             .input_offset(17)
4876*4bdc9457SAndroid Build Coastguard Worker             .zero_index(zero_index)
4877*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4878*4bdc9457SAndroid Build Coastguard Worker         }
4879*4bdc9457SAndroid Build Coastguard Worker       }
4880*4bdc9457SAndroid Build Coastguard Worker     }
4881*4bdc9457SAndroid Build Coastguard Worker   }
4882*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,few_output_pixels)4883*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, few_output_pixels) {
4884*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4885*4bdc9457SAndroid Build Coastguard Worker     for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
4886*4bdc9457SAndroid Build Coastguard Worker       for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
4887*4bdc9457SAndroid Build Coastguard Worker         for (size_t channels = 1; channels <= 40; channels += 7) {
4888*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
4889*4bdc9457SAndroid Build Coastguard Worker             .output_pixels(output_pixels)
4890*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
4891*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 0)
4892*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
4893*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4894*4bdc9457SAndroid Build Coastguard Worker         }
4895*4bdc9457SAndroid Build Coastguard Worker       }
4896*4bdc9457SAndroid Build Coastguard Worker     }
4897*4bdc9457SAndroid Build Coastguard Worker   }
4898*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,few_output_pixels_with_input_offset)4899*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, few_output_pixels_with_input_offset) {
4900*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4901*4bdc9457SAndroid Build Coastguard Worker     for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
4902*4bdc9457SAndroid Build Coastguard Worker       for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
4903*4bdc9457SAndroid Build Coastguard Worker         for (size_t channels = 1; channels <= 40; channels += 7) {
4904*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
4905*4bdc9457SAndroid Build Coastguard Worker             .output_pixels(output_pixels)
4906*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
4907*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 0)
4908*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
4909*4bdc9457SAndroid Build Coastguard Worker             .input_offset(43)
4910*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4911*4bdc9457SAndroid Build Coastguard Worker         }
4912*4bdc9457SAndroid Build Coastguard Worker       }
4913*4bdc9457SAndroid Build Coastguard Worker     }
4914*4bdc9457SAndroid Build Coastguard Worker   }
4915*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,few_output_pixels_with_zero)4916*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, few_output_pixels_with_zero) {
4917*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4918*4bdc9457SAndroid Build Coastguard Worker     for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
4919*4bdc9457SAndroid Build Coastguard Worker       for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
4920*4bdc9457SAndroid Build Coastguard Worker         for (size_t channels = 1; channels <= 40; channels += 7) {
4921*4bdc9457SAndroid Build Coastguard Worker           for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
4922*4bdc9457SAndroid Build Coastguard Worker             AvgPoolMicrokernelTester()
4923*4bdc9457SAndroid Build Coastguard Worker               .output_pixels(output_pixels)
4924*4bdc9457SAndroid Build Coastguard Worker               .pooling_elements(pooling_elements)
4925*4bdc9457SAndroid Build Coastguard Worker               .pooling_tile(9, 0)
4926*4bdc9457SAndroid Build Coastguard Worker               .channels(channels)
4927*4bdc9457SAndroid Build Coastguard Worker               .input_offset(43)
4928*4bdc9457SAndroid Build Coastguard Worker               .zero_index(zero_index)
4929*4bdc9457SAndroid Build Coastguard Worker               .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4930*4bdc9457SAndroid Build Coastguard Worker           }
4931*4bdc9457SAndroid Build Coastguard Worker         }
4932*4bdc9457SAndroid Build Coastguard Worker       }
4933*4bdc9457SAndroid Build Coastguard Worker     }
4934*4bdc9457SAndroid Build Coastguard Worker   }
4935*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,few_output_pixels_with_input_scale)4936*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, few_output_pixels_with_input_scale) {
4937*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4938*4bdc9457SAndroid Build Coastguard Worker     for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
4939*4bdc9457SAndroid Build Coastguard Worker       for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
4940*4bdc9457SAndroid Build Coastguard Worker         for (size_t channels = 1; channels <= 40; channels += 7) {
4941*4bdc9457SAndroid Build Coastguard Worker           for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
4942*4bdc9457SAndroid Build Coastguard Worker             AvgPoolMicrokernelTester()
4943*4bdc9457SAndroid Build Coastguard Worker               .output_pixels(output_pixels)
4944*4bdc9457SAndroid Build Coastguard Worker               .pooling_elements(pooling_elements)
4945*4bdc9457SAndroid Build Coastguard Worker               .pooling_tile(9)
4946*4bdc9457SAndroid Build Coastguard Worker               .channels(channels)
4947*4bdc9457SAndroid Build Coastguard Worker               .input_scale(scale)
4948*4bdc9457SAndroid Build Coastguard Worker               .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4949*4bdc9457SAndroid Build Coastguard Worker           }
4950*4bdc9457SAndroid Build Coastguard Worker         }
4951*4bdc9457SAndroid Build Coastguard Worker       }
4952*4bdc9457SAndroid Build Coastguard Worker     }
4953*4bdc9457SAndroid Build Coastguard Worker   }
4954*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,few_output_pixels_with_input_zero_point)4955*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, few_output_pixels_with_input_zero_point) {
4956*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4957*4bdc9457SAndroid Build Coastguard Worker     for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
4958*4bdc9457SAndroid Build Coastguard Worker       for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
4959*4bdc9457SAndroid Build Coastguard Worker         for (size_t channels = 1; channels <= 40; channels += 7) {
4960*4bdc9457SAndroid Build Coastguard Worker           for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
4961*4bdc9457SAndroid Build Coastguard Worker             AvgPoolMicrokernelTester()
4962*4bdc9457SAndroid Build Coastguard Worker               .output_pixels(output_pixels)
4963*4bdc9457SAndroid Build Coastguard Worker               .pooling_elements(pooling_elements)
4964*4bdc9457SAndroid Build Coastguard Worker               .pooling_tile(9)
4965*4bdc9457SAndroid Build Coastguard Worker               .channels(channels)
4966*4bdc9457SAndroid Build Coastguard Worker               .input_zero_point(zero_point)
4967*4bdc9457SAndroid Build Coastguard Worker               .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4968*4bdc9457SAndroid Build Coastguard Worker           }
4969*4bdc9457SAndroid Build Coastguard Worker         }
4970*4bdc9457SAndroid Build Coastguard Worker       }
4971*4bdc9457SAndroid Build Coastguard Worker     }
4972*4bdc9457SAndroid Build Coastguard Worker   }
4973*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,few_output_pixels_with_output_scale)4974*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, few_output_pixels_with_output_scale) {
4975*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4976*4bdc9457SAndroid Build Coastguard Worker     for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
4977*4bdc9457SAndroid Build Coastguard Worker       for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
4978*4bdc9457SAndroid Build Coastguard Worker         for (size_t channels = 1; channels <= 40; channels += 7) {
4979*4bdc9457SAndroid Build Coastguard Worker           for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
4980*4bdc9457SAndroid Build Coastguard Worker             AvgPoolMicrokernelTester()
4981*4bdc9457SAndroid Build Coastguard Worker               .output_pixels(output_pixels)
4982*4bdc9457SAndroid Build Coastguard Worker               .pooling_elements(pooling_elements)
4983*4bdc9457SAndroid Build Coastguard Worker               .pooling_tile(9)
4984*4bdc9457SAndroid Build Coastguard Worker               .channels(channels)
4985*4bdc9457SAndroid Build Coastguard Worker               .output_scale(scale)
4986*4bdc9457SAndroid Build Coastguard Worker               .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
4987*4bdc9457SAndroid Build Coastguard Worker           }
4988*4bdc9457SAndroid Build Coastguard Worker         }
4989*4bdc9457SAndroid Build Coastguard Worker       }
4990*4bdc9457SAndroid Build Coastguard Worker     }
4991*4bdc9457SAndroid Build Coastguard Worker   }
4992*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,few_output_pixels_with_output_zero_point)4993*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, few_output_pixels_with_output_zero_point) {
4994*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
4995*4bdc9457SAndroid Build Coastguard Worker     for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
4996*4bdc9457SAndroid Build Coastguard Worker       for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
4997*4bdc9457SAndroid Build Coastguard Worker         for (size_t channels = 1; channels <= 40; channels += 7) {
4998*4bdc9457SAndroid Build Coastguard Worker           for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
4999*4bdc9457SAndroid Build Coastguard Worker             AvgPoolMicrokernelTester()
5000*4bdc9457SAndroid Build Coastguard Worker               .output_pixels(output_pixels)
5001*4bdc9457SAndroid Build Coastguard Worker               .pooling_elements(pooling_elements)
5002*4bdc9457SAndroid Build Coastguard Worker               .pooling_tile(9)
5003*4bdc9457SAndroid Build Coastguard Worker               .channels(channels)
5004*4bdc9457SAndroid Build Coastguard Worker               .output_zero_point(zero_point)
5005*4bdc9457SAndroid Build Coastguard Worker               .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
5006*4bdc9457SAndroid Build Coastguard Worker           }
5007*4bdc9457SAndroid Build Coastguard Worker         }
5008*4bdc9457SAndroid Build Coastguard Worker       }
5009*4bdc9457SAndroid Build Coastguard Worker     }
5010*4bdc9457SAndroid Build Coastguard Worker   }
5011*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,few_output_pixels_with_qmin)5012*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, few_output_pixels_with_qmin) {
5013*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
5014*4bdc9457SAndroid Build Coastguard Worker     for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
5015*4bdc9457SAndroid Build Coastguard Worker       for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
5016*4bdc9457SAndroid Build Coastguard Worker         for (size_t channels = 1; channels <= 40; channels += 7) {
5017*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
5018*4bdc9457SAndroid Build Coastguard Worker             .output_pixels(output_pixels)
5019*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
5020*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 0)
5021*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
5022*4bdc9457SAndroid Build Coastguard Worker             .qmin(128)
5023*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
5024*4bdc9457SAndroid Build Coastguard Worker         }
5025*4bdc9457SAndroid Build Coastguard Worker       }
5026*4bdc9457SAndroid Build Coastguard Worker     }
5027*4bdc9457SAndroid Build Coastguard Worker   }
5028*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,few_output_pixels_with_qmax)5029*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, few_output_pixels_with_qmax) {
5030*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
5031*4bdc9457SAndroid Build Coastguard Worker     for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
5032*4bdc9457SAndroid Build Coastguard Worker       for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
5033*4bdc9457SAndroid Build Coastguard Worker         for (size_t channels = 1; channels <= 40; channels += 7) {
5034*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
5035*4bdc9457SAndroid Build Coastguard Worker             .output_pixels(output_pixels)
5036*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
5037*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 0)
5038*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
5039*4bdc9457SAndroid Build Coastguard Worker             .qmax(128)
5040*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
5041*4bdc9457SAndroid Build Coastguard Worker         }
5042*4bdc9457SAndroid Build Coastguard Worker       }
5043*4bdc9457SAndroid Build Coastguard Worker     }
5044*4bdc9457SAndroid Build Coastguard Worker   }
5045*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,few_output_pixels_with_output_stride)5046*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, few_output_pixels_with_output_stride) {
5047*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
5048*4bdc9457SAndroid Build Coastguard Worker     for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
5049*4bdc9457SAndroid Build Coastguard Worker       for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
5050*4bdc9457SAndroid Build Coastguard Worker         for (size_t channels = 1; channels <= 40; channels += 7) {
5051*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
5052*4bdc9457SAndroid Build Coastguard Worker             .output_pixels(output_pixels)
5053*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
5054*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 0)
5055*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
5056*4bdc9457SAndroid Build Coastguard Worker             .output_stride(43)
5057*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
5058*4bdc9457SAndroid Build Coastguard Worker         }
5059*4bdc9457SAndroid Build Coastguard Worker       }
5060*4bdc9457SAndroid Build Coastguard Worker     }
5061*4bdc9457SAndroid Build Coastguard Worker   }
5062*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8,few_output_pixels_with_step)5063*4bdc9457SAndroid Build Coastguard Worker   TEST(QU8_AVGPOOL_MINMAX_9X__SSE2_C8, few_output_pixels_with_step) {
5064*4bdc9457SAndroid Build Coastguard Worker     TEST_REQUIRES_X86_SSE2;
5065*4bdc9457SAndroid Build Coastguard Worker     for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
5066*4bdc9457SAndroid Build Coastguard Worker       for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
5067*4bdc9457SAndroid Build Coastguard Worker         for (size_t channels = 1; channels <= 40; channels += 7) {
5068*4bdc9457SAndroid Build Coastguard Worker           for (size_t step = 2; step <= pooling_elements; step++) {
5069*4bdc9457SAndroid Build Coastguard Worker             AvgPoolMicrokernelTester()
5070*4bdc9457SAndroid Build Coastguard Worker               .output_pixels(output_pixels)
5071*4bdc9457SAndroid Build Coastguard Worker               .pooling_elements(pooling_elements)
5072*4bdc9457SAndroid Build Coastguard Worker               .pooling_tile(9, 0)
5073*4bdc9457SAndroid Build Coastguard Worker               .step(step)
5074*4bdc9457SAndroid Build Coastguard Worker               .channels(channels)
5075*4bdc9457SAndroid Build Coastguard Worker               .output_stride(43)
5076*4bdc9457SAndroid Build Coastguard Worker               .Test(xnn_qu8_avgpool_minmax_ukernel_9x__sse2_c8, xnn_init_qu8_avgpool_minmax_sse2_params);
5077*4bdc9457SAndroid Build Coastguard Worker           }
5078*4bdc9457SAndroid Build Coastguard Worker         }
5079*4bdc9457SAndroid Build Coastguard Worker       }
5080*4bdc9457SAndroid Build Coastguard Worker     }
5081*4bdc9457SAndroid Build Coastguard Worker   }
5082*4bdc9457SAndroid Build Coastguard Worker #endif  // XNN_ARCH_X86 || XNN_ARCH_X86_64
5083*4bdc9457SAndroid Build Coastguard Worker 
5084*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1,channels_eq_1_unipass_fulltile)5085*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1, channels_eq_1_unipass_fulltile) {
5086*4bdc9457SAndroid Build Coastguard Worker   AvgPoolMicrokernelTester()
5087*4bdc9457SAndroid Build Coastguard Worker     .pooling_elements(9)
5088*4bdc9457SAndroid Build Coastguard Worker     .pooling_tile(9)
5089*4bdc9457SAndroid Build Coastguard Worker     .channels(1)
5090*4bdc9457SAndroid Build Coastguard Worker     .Test(xnn_qu8_avgpool_minmax_ukernel_9x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
5091*4bdc9457SAndroid Build Coastguard Worker }
5092*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1,channels_eq_1_unipass_fulltile_with_input_offset)5093*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1, channels_eq_1_unipass_fulltile_with_input_offset) {
5094*4bdc9457SAndroid Build Coastguard Worker   AvgPoolMicrokernelTester()
5095*4bdc9457SAndroid Build Coastguard Worker     .pooling_elements(9)
5096*4bdc9457SAndroid Build Coastguard Worker     .pooling_tile(9)
5097*4bdc9457SAndroid Build Coastguard Worker     .channels(1)
5098*4bdc9457SAndroid Build Coastguard Worker     .input_offset(3)
5099*4bdc9457SAndroid Build Coastguard Worker     .Test(xnn_qu8_avgpool_minmax_ukernel_9x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
5100*4bdc9457SAndroid Build Coastguard Worker }
5101*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1,channels_eq_1_unipass_fulltile_with_zero)5102*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1, channels_eq_1_unipass_fulltile_with_zero) {
5103*4bdc9457SAndroid Build Coastguard Worker   for (size_t zero_index = 0; zero_index < 9; zero_index++) {
5104*4bdc9457SAndroid Build Coastguard Worker     AvgPoolMicrokernelTester()
5105*4bdc9457SAndroid Build Coastguard Worker       .pooling_elements(9)
5106*4bdc9457SAndroid Build Coastguard Worker       .pooling_tile(9)
5107*4bdc9457SAndroid Build Coastguard Worker       .channels(1)
5108*4bdc9457SAndroid Build Coastguard Worker       .input_offset(3)
5109*4bdc9457SAndroid Build Coastguard Worker       .zero_index(zero_index)
5110*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_qu8_avgpool_minmax_ukernel_9x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
5111*4bdc9457SAndroid Build Coastguard Worker   }
5112*4bdc9457SAndroid Build Coastguard Worker }
5113*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1,channels_eq_1_unipass_fulltile_with_input_scale)5114*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1, channels_eq_1_unipass_fulltile_with_input_scale) {
5115*4bdc9457SAndroid Build Coastguard Worker   for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
5116*4bdc9457SAndroid Build Coastguard Worker     AvgPoolMicrokernelTester()
5117*4bdc9457SAndroid Build Coastguard Worker       .pooling_elements(9)
5118*4bdc9457SAndroid Build Coastguard Worker       .pooling_tile(9)
5119*4bdc9457SAndroid Build Coastguard Worker       .channels(1)
5120*4bdc9457SAndroid Build Coastguard Worker       .input_scale(scale)
5121*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_qu8_avgpool_minmax_ukernel_9x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
5122*4bdc9457SAndroid Build Coastguard Worker   }
5123*4bdc9457SAndroid Build Coastguard Worker }
5124*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1,channels_eq_1_unipass_fulltile_with_input_zero_point)5125*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1, channels_eq_1_unipass_fulltile_with_input_zero_point) {
5126*4bdc9457SAndroid Build Coastguard Worker   for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
5127*4bdc9457SAndroid Build Coastguard Worker     AvgPoolMicrokernelTester()
5128*4bdc9457SAndroid Build Coastguard Worker       .pooling_elements(9)
5129*4bdc9457SAndroid Build Coastguard Worker       .pooling_tile(9)
5130*4bdc9457SAndroid Build Coastguard Worker       .channels(1)
5131*4bdc9457SAndroid Build Coastguard Worker       .input_zero_point(zero_point)
5132*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_qu8_avgpool_minmax_ukernel_9x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
5133*4bdc9457SAndroid Build Coastguard Worker   }
5134*4bdc9457SAndroid Build Coastguard Worker }
5135*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1,channels_eq_1_unipass_fulltile_with_output_scale)5136*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1, channels_eq_1_unipass_fulltile_with_output_scale) {
5137*4bdc9457SAndroid Build Coastguard Worker   for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
5138*4bdc9457SAndroid Build Coastguard Worker     AvgPoolMicrokernelTester()
5139*4bdc9457SAndroid Build Coastguard Worker       .pooling_elements(9)
5140*4bdc9457SAndroid Build Coastguard Worker       .pooling_tile(9)
5141*4bdc9457SAndroid Build Coastguard Worker       .channels(1)
5142*4bdc9457SAndroid Build Coastguard Worker       .output_scale(scale)
5143*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_qu8_avgpool_minmax_ukernel_9x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
5144*4bdc9457SAndroid Build Coastguard Worker   }
5145*4bdc9457SAndroid Build Coastguard Worker }
5146*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1,channels_eq_1_unipass_fulltile_with_output_zero_point)5147*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1, channels_eq_1_unipass_fulltile_with_output_zero_point) {
5148*4bdc9457SAndroid Build Coastguard Worker   for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
5149*4bdc9457SAndroid Build Coastguard Worker     AvgPoolMicrokernelTester()
5150*4bdc9457SAndroid Build Coastguard Worker       .pooling_elements(9)
5151*4bdc9457SAndroid Build Coastguard Worker       .pooling_tile(9)
5152*4bdc9457SAndroid Build Coastguard Worker       .channels(1)
5153*4bdc9457SAndroid Build Coastguard Worker       .output_zero_point(zero_point)
5154*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_qu8_avgpool_minmax_ukernel_9x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
5155*4bdc9457SAndroid Build Coastguard Worker   }
5156*4bdc9457SAndroid Build Coastguard Worker }
5157*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1,channels_eq_1_unipass_fulltile_with_qmin)5158*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1, channels_eq_1_unipass_fulltile_with_qmin) {
5159*4bdc9457SAndroid Build Coastguard Worker   AvgPoolMicrokernelTester()
5160*4bdc9457SAndroid Build Coastguard Worker     .pooling_elements(9)
5161*4bdc9457SAndroid Build Coastguard Worker     .pooling_tile(9)
5162*4bdc9457SAndroid Build Coastguard Worker     .channels(1)
5163*4bdc9457SAndroid Build Coastguard Worker     .qmin(128)
5164*4bdc9457SAndroid Build Coastguard Worker     .Test(xnn_qu8_avgpool_minmax_ukernel_9x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
5165*4bdc9457SAndroid Build Coastguard Worker }
5166*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1,channels_eq_1_unipass_fulltile_with_qmax)5167*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1, channels_eq_1_unipass_fulltile_with_qmax) {
5168*4bdc9457SAndroid Build Coastguard Worker   AvgPoolMicrokernelTester()
5169*4bdc9457SAndroid Build Coastguard Worker     .pooling_elements(9)
5170*4bdc9457SAndroid Build Coastguard Worker     .pooling_tile(9)
5171*4bdc9457SAndroid Build Coastguard Worker     .channels(1)
5172*4bdc9457SAndroid Build Coastguard Worker     .qmax(128)
5173*4bdc9457SAndroid Build Coastguard Worker     .Test(xnn_qu8_avgpool_minmax_ukernel_9x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
5174*4bdc9457SAndroid Build Coastguard Worker }
5175*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1,channels_eq_1_unipass_subtile)5176*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1, channels_eq_1_unipass_subtile) {
5177*4bdc9457SAndroid Build Coastguard Worker   for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
5178*4bdc9457SAndroid Build Coastguard Worker     AvgPoolMicrokernelTester()
5179*4bdc9457SAndroid Build Coastguard Worker       .pooling_elements(pooling_elements)
5180*4bdc9457SAndroid Build Coastguard Worker       .pooling_tile(9)
5181*4bdc9457SAndroid Build Coastguard Worker       .channels(1)
5182*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_qu8_avgpool_minmax_ukernel_9x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
5183*4bdc9457SAndroid Build Coastguard Worker   }
5184*4bdc9457SAndroid Build Coastguard Worker }
5185*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1,channels_eq_1_unipass_subtile_with_input_offset)5186*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1, channels_eq_1_unipass_subtile_with_input_offset) {
5187*4bdc9457SAndroid Build Coastguard Worker   for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
5188*4bdc9457SAndroid Build Coastguard Worker     AvgPoolMicrokernelTester()
5189*4bdc9457SAndroid Build Coastguard Worker       .pooling_elements(pooling_elements)
5190*4bdc9457SAndroid Build Coastguard Worker       .pooling_tile(9)
5191*4bdc9457SAndroid Build Coastguard Worker       .channels(1)
5192*4bdc9457SAndroid Build Coastguard Worker       .input_offset(3)
5193*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_qu8_avgpool_minmax_ukernel_9x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
5194*4bdc9457SAndroid Build Coastguard Worker   }
5195*4bdc9457SAndroid Build Coastguard Worker }
5196*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1,channels_eq_1_unipass_subtile_with_zero)5197*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1, channels_eq_1_unipass_subtile_with_zero) {
5198*4bdc9457SAndroid Build Coastguard Worker   for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
5199*4bdc9457SAndroid Build Coastguard Worker     for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
5200*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
5201*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(pooling_elements)
5202*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9)
5203*4bdc9457SAndroid Build Coastguard Worker         .channels(1)
5204*4bdc9457SAndroid Build Coastguard Worker         .input_offset(3)
5205*4bdc9457SAndroid Build Coastguard Worker         .zero_index(zero_index)
5206*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
5207*4bdc9457SAndroid Build Coastguard Worker     }
5208*4bdc9457SAndroid Build Coastguard Worker   }
5209*4bdc9457SAndroid Build Coastguard Worker }
5210*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1,channels_gt_1_unipass_fulltile)5211*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1, channels_gt_1_unipass_fulltile) {
5212*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 2; channels < 10; channels++) {
5213*4bdc9457SAndroid Build Coastguard Worker     AvgPoolMicrokernelTester()
5214*4bdc9457SAndroid Build Coastguard Worker       .pooling_elements(9)
5215*4bdc9457SAndroid Build Coastguard Worker       .pooling_tile(9)
5216*4bdc9457SAndroid Build Coastguard Worker       .channels(channels)
5217*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_qu8_avgpool_minmax_ukernel_9x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
5218*4bdc9457SAndroid Build Coastguard Worker   }
5219*4bdc9457SAndroid Build Coastguard Worker }
5220*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1,channels_gt_1_unipass_fulltile_with_input_offset)5221*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1, channels_gt_1_unipass_fulltile_with_input_offset) {
5222*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 2; channels < 10; channels++) {
5223*4bdc9457SAndroid Build Coastguard Worker     AvgPoolMicrokernelTester()
5224*4bdc9457SAndroid Build Coastguard Worker       .pooling_elements(9)
5225*4bdc9457SAndroid Build Coastguard Worker       .pooling_tile(9)
5226*4bdc9457SAndroid Build Coastguard Worker       .channels(channels)
5227*4bdc9457SAndroid Build Coastguard Worker       .input_offset(3)
5228*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_qu8_avgpool_minmax_ukernel_9x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
5229*4bdc9457SAndroid Build Coastguard Worker   }
5230*4bdc9457SAndroid Build Coastguard Worker }
5231*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1,channels_gt_1_unipass_fulltile_with_zero)5232*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1, channels_gt_1_unipass_fulltile_with_zero) {
5233*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 2; channels < 10; channels++) {
5234*4bdc9457SAndroid Build Coastguard Worker     for (size_t zero_index = 0; zero_index < 9; zero_index++) {
5235*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
5236*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(9)
5237*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9)
5238*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
5239*4bdc9457SAndroid Build Coastguard Worker         .input_offset(3)
5240*4bdc9457SAndroid Build Coastguard Worker         .zero_index(zero_index)
5241*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
5242*4bdc9457SAndroid Build Coastguard Worker     }
5243*4bdc9457SAndroid Build Coastguard Worker   }
5244*4bdc9457SAndroid Build Coastguard Worker }
5245*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1,channels_gt_1_unipass_fulltile_with_input_scale)5246*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1, channels_gt_1_unipass_fulltile_with_input_scale) {
5247*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 2; channels < 10; channels++) {
5248*4bdc9457SAndroid Build Coastguard Worker     for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
5249*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
5250*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(9)
5251*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9)
5252*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
5253*4bdc9457SAndroid Build Coastguard Worker         .input_scale(scale)
5254*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
5255*4bdc9457SAndroid Build Coastguard Worker     }
5256*4bdc9457SAndroid Build Coastguard Worker   }
5257*4bdc9457SAndroid Build Coastguard Worker }
5258*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1,channels_gt_1_unipass_fulltile_with_input_zero_point)5259*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1, channels_gt_1_unipass_fulltile_with_input_zero_point) {
5260*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 2; channels < 10; channels++) {
5261*4bdc9457SAndroid Build Coastguard Worker     for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
5262*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
5263*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(9)
5264*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9)
5265*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
5266*4bdc9457SAndroid Build Coastguard Worker         .input_zero_point(zero_point)
5267*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
5268*4bdc9457SAndroid Build Coastguard Worker     }
5269*4bdc9457SAndroid Build Coastguard Worker   }
5270*4bdc9457SAndroid Build Coastguard Worker }
5271*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1,channels_gt_1_unipass_fulltile_with_output_scale)5272*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1, channels_gt_1_unipass_fulltile_with_output_scale) {
5273*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 2; channels < 10; channels++) {
5274*4bdc9457SAndroid Build Coastguard Worker     for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
5275*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
5276*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(9)
5277*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9)
5278*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
5279*4bdc9457SAndroid Build Coastguard Worker         .output_scale(scale)
5280*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
5281*4bdc9457SAndroid Build Coastguard Worker     }
5282*4bdc9457SAndroid Build Coastguard Worker   }
5283*4bdc9457SAndroid Build Coastguard Worker }
5284*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1,channels_gt_1_unipass_fulltile_with_output_zero_point)5285*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1, channels_gt_1_unipass_fulltile_with_output_zero_point) {
5286*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 2; channels < 10; channels++) {
5287*4bdc9457SAndroid Build Coastguard Worker     for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
5288*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
5289*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(9)
5290*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9)
5291*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
5292*4bdc9457SAndroid Build Coastguard Worker         .output_zero_point(zero_point)
5293*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
5294*4bdc9457SAndroid Build Coastguard Worker     }
5295*4bdc9457SAndroid Build Coastguard Worker   }
5296*4bdc9457SAndroid Build Coastguard Worker }
5297*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1,channels_gt_1_unipass_fulltile_with_qmin)5298*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1, channels_gt_1_unipass_fulltile_with_qmin) {
5299*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 2; channels < 10; channels++) {
5300*4bdc9457SAndroid Build Coastguard Worker     AvgPoolMicrokernelTester()
5301*4bdc9457SAndroid Build Coastguard Worker       .pooling_elements(9)
5302*4bdc9457SAndroid Build Coastguard Worker       .pooling_tile(9)
5303*4bdc9457SAndroid Build Coastguard Worker       .channels(channels)
5304*4bdc9457SAndroid Build Coastguard Worker       .qmin(128)
5305*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_qu8_avgpool_minmax_ukernel_9x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
5306*4bdc9457SAndroid Build Coastguard Worker   }
5307*4bdc9457SAndroid Build Coastguard Worker }
5308*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1,channels_gt_1_unipass_fulltile_with_qmax)5309*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1, channels_gt_1_unipass_fulltile_with_qmax) {
5310*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 2; channels < 10; channels++) {
5311*4bdc9457SAndroid Build Coastguard Worker     AvgPoolMicrokernelTester()
5312*4bdc9457SAndroid Build Coastguard Worker       .pooling_elements(9)
5313*4bdc9457SAndroid Build Coastguard Worker       .pooling_tile(9)
5314*4bdc9457SAndroid Build Coastguard Worker       .channels(channels)
5315*4bdc9457SAndroid Build Coastguard Worker       .qmax(128)
5316*4bdc9457SAndroid Build Coastguard Worker       .Test(xnn_qu8_avgpool_minmax_ukernel_9x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
5317*4bdc9457SAndroid Build Coastguard Worker   }
5318*4bdc9457SAndroid Build Coastguard Worker }
5319*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1,channels_gt_1_unipass_subtile)5320*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1, channels_gt_1_unipass_subtile) {
5321*4bdc9457SAndroid Build Coastguard Worker   for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
5322*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 2; channels < 10; channels++) {
5323*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
5324*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(pooling_elements)
5325*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9)
5326*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
5327*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
5328*4bdc9457SAndroid Build Coastguard Worker     }
5329*4bdc9457SAndroid Build Coastguard Worker   }
5330*4bdc9457SAndroid Build Coastguard Worker }
5331*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1,channels_gt_1_unipass_subtile_with_input_offset)5332*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1, channels_gt_1_unipass_subtile_with_input_offset) {
5333*4bdc9457SAndroid Build Coastguard Worker   for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
5334*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 2; channels < 10; channels++) {
5335*4bdc9457SAndroid Build Coastguard Worker       AvgPoolMicrokernelTester()
5336*4bdc9457SAndroid Build Coastguard Worker         .pooling_elements(pooling_elements)
5337*4bdc9457SAndroid Build Coastguard Worker         .pooling_tile(9)
5338*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
5339*4bdc9457SAndroid Build Coastguard Worker         .input_offset(3)
5340*4bdc9457SAndroid Build Coastguard Worker         .Test(xnn_qu8_avgpool_minmax_ukernel_9x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
5341*4bdc9457SAndroid Build Coastguard Worker     }
5342*4bdc9457SAndroid Build Coastguard Worker   }
5343*4bdc9457SAndroid Build Coastguard Worker }
5344*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1,channels_gt_1_unipass_subtile_with_zero)5345*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1, channels_gt_1_unipass_subtile_with_zero) {
5346*4bdc9457SAndroid Build Coastguard Worker   for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
5347*4bdc9457SAndroid Build Coastguard Worker     for (size_t channels = 2; channels < 10; channels++) {
5348*4bdc9457SAndroid Build Coastguard Worker       for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
5349*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
5350*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
5351*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9)
5352*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
5353*4bdc9457SAndroid Build Coastguard Worker           .input_offset(3)
5354*4bdc9457SAndroid Build Coastguard Worker           .zero_index(zero_index)
5355*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
5356*4bdc9457SAndroid Build Coastguard Worker       }
5357*4bdc9457SAndroid Build Coastguard Worker     }
5358*4bdc9457SAndroid Build Coastguard Worker   }
5359*4bdc9457SAndroid Build Coastguard Worker }
5360*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1,few_output_pixels)5361*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1, few_output_pixels) {
5362*4bdc9457SAndroid Build Coastguard Worker   for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
5363*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
5364*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 1; channels <= 5; channels += 1) {
5365*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
5366*4bdc9457SAndroid Build Coastguard Worker           .output_pixels(output_pixels)
5367*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
5368*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 0)
5369*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
5370*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
5371*4bdc9457SAndroid Build Coastguard Worker       }
5372*4bdc9457SAndroid Build Coastguard Worker     }
5373*4bdc9457SAndroid Build Coastguard Worker   }
5374*4bdc9457SAndroid Build Coastguard Worker }
5375*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1,few_output_pixels_with_input_offset)5376*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1, few_output_pixels_with_input_offset) {
5377*4bdc9457SAndroid Build Coastguard Worker   for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
5378*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
5379*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 1; channels <= 5; channels += 1) {
5380*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
5381*4bdc9457SAndroid Build Coastguard Worker           .output_pixels(output_pixels)
5382*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
5383*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 0)
5384*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
5385*4bdc9457SAndroid Build Coastguard Worker           .input_offset(7)
5386*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
5387*4bdc9457SAndroid Build Coastguard Worker       }
5388*4bdc9457SAndroid Build Coastguard Worker     }
5389*4bdc9457SAndroid Build Coastguard Worker   }
5390*4bdc9457SAndroid Build Coastguard Worker }
5391*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1,few_output_pixels_with_zero)5392*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1, few_output_pixels_with_zero) {
5393*4bdc9457SAndroid Build Coastguard Worker   for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
5394*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
5395*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 1; channels <= 5; channels += 1) {
5396*4bdc9457SAndroid Build Coastguard Worker         for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
5397*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
5398*4bdc9457SAndroid Build Coastguard Worker             .output_pixels(output_pixels)
5399*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
5400*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 0)
5401*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
5402*4bdc9457SAndroid Build Coastguard Worker             .input_offset(7)
5403*4bdc9457SAndroid Build Coastguard Worker             .zero_index(zero_index)
5404*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
5405*4bdc9457SAndroid Build Coastguard Worker         }
5406*4bdc9457SAndroid Build Coastguard Worker       }
5407*4bdc9457SAndroid Build Coastguard Worker     }
5408*4bdc9457SAndroid Build Coastguard Worker   }
5409*4bdc9457SAndroid Build Coastguard Worker }
5410*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1,few_output_pixels_with_input_scale)5411*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1, few_output_pixels_with_input_scale) {
5412*4bdc9457SAndroid Build Coastguard Worker   for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
5413*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
5414*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 1; channels <= 5; channels += 1) {
5415*4bdc9457SAndroid Build Coastguard Worker         for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
5416*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
5417*4bdc9457SAndroid Build Coastguard Worker             .output_pixels(output_pixels)
5418*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
5419*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9)
5420*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
5421*4bdc9457SAndroid Build Coastguard Worker             .input_scale(scale)
5422*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
5423*4bdc9457SAndroid Build Coastguard Worker         }
5424*4bdc9457SAndroid Build Coastguard Worker       }
5425*4bdc9457SAndroid Build Coastguard Worker     }
5426*4bdc9457SAndroid Build Coastguard Worker   }
5427*4bdc9457SAndroid Build Coastguard Worker }
5428*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1,few_output_pixels_with_input_zero_point)5429*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1, few_output_pixels_with_input_zero_point) {
5430*4bdc9457SAndroid Build Coastguard Worker   for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
5431*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
5432*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 1; channels <= 5; channels += 1) {
5433*4bdc9457SAndroid Build Coastguard Worker         for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
5434*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
5435*4bdc9457SAndroid Build Coastguard Worker             .output_pixels(output_pixels)
5436*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
5437*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9)
5438*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
5439*4bdc9457SAndroid Build Coastguard Worker             .input_zero_point(zero_point)
5440*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
5441*4bdc9457SAndroid Build Coastguard Worker         }
5442*4bdc9457SAndroid Build Coastguard Worker       }
5443*4bdc9457SAndroid Build Coastguard Worker     }
5444*4bdc9457SAndroid Build Coastguard Worker   }
5445*4bdc9457SAndroid Build Coastguard Worker }
5446*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1,few_output_pixels_with_output_scale)5447*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1, few_output_pixels_with_output_scale) {
5448*4bdc9457SAndroid Build Coastguard Worker   for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
5449*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
5450*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 1; channels <= 5; channels += 1) {
5451*4bdc9457SAndroid Build Coastguard Worker         for (float scale = 0.01f; scale < 100.0f; scale *= 3.14159265f) {
5452*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
5453*4bdc9457SAndroid Build Coastguard Worker             .output_pixels(output_pixels)
5454*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
5455*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9)
5456*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
5457*4bdc9457SAndroid Build Coastguard Worker             .output_scale(scale)
5458*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
5459*4bdc9457SAndroid Build Coastguard Worker         }
5460*4bdc9457SAndroid Build Coastguard Worker       }
5461*4bdc9457SAndroid Build Coastguard Worker     }
5462*4bdc9457SAndroid Build Coastguard Worker   }
5463*4bdc9457SAndroid Build Coastguard Worker }
5464*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1,few_output_pixels_with_output_zero_point)5465*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1, few_output_pixels_with_output_zero_point) {
5466*4bdc9457SAndroid Build Coastguard Worker   for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
5467*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
5468*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 1; channels <= 5; channels += 1) {
5469*4bdc9457SAndroid Build Coastguard Worker         for (int32_t zero_point = 0; zero_point <= 255; zero_point += 51) {
5470*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
5471*4bdc9457SAndroid Build Coastguard Worker             .output_pixels(output_pixels)
5472*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
5473*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9)
5474*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
5475*4bdc9457SAndroid Build Coastguard Worker             .output_zero_point(zero_point)
5476*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
5477*4bdc9457SAndroid Build Coastguard Worker         }
5478*4bdc9457SAndroid Build Coastguard Worker       }
5479*4bdc9457SAndroid Build Coastguard Worker     }
5480*4bdc9457SAndroid Build Coastguard Worker   }
5481*4bdc9457SAndroid Build Coastguard Worker }
5482*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1,few_output_pixels_with_qmin)5483*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1, few_output_pixels_with_qmin) {
5484*4bdc9457SAndroid Build Coastguard Worker   for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
5485*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
5486*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 1; channels <= 5; channels += 1) {
5487*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
5488*4bdc9457SAndroid Build Coastguard Worker           .output_pixels(output_pixels)
5489*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
5490*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 0)
5491*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
5492*4bdc9457SAndroid Build Coastguard Worker           .qmin(128)
5493*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
5494*4bdc9457SAndroid Build Coastguard Worker       }
5495*4bdc9457SAndroid Build Coastguard Worker     }
5496*4bdc9457SAndroid Build Coastguard Worker   }
5497*4bdc9457SAndroid Build Coastguard Worker }
5498*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1,few_output_pixels_with_qmax)5499*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1, few_output_pixels_with_qmax) {
5500*4bdc9457SAndroid Build Coastguard Worker   for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
5501*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
5502*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 1; channels <= 5; channels += 1) {
5503*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
5504*4bdc9457SAndroid Build Coastguard Worker           .output_pixels(output_pixels)
5505*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
5506*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 0)
5507*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
5508*4bdc9457SAndroid Build Coastguard Worker           .qmax(128)
5509*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
5510*4bdc9457SAndroid Build Coastguard Worker       }
5511*4bdc9457SAndroid Build Coastguard Worker     }
5512*4bdc9457SAndroid Build Coastguard Worker   }
5513*4bdc9457SAndroid Build Coastguard Worker }
5514*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1,few_output_pixels_with_output_stride)5515*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1, few_output_pixels_with_output_stride) {
5516*4bdc9457SAndroid Build Coastguard Worker   for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
5517*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
5518*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 1; channels <= 5; channels += 1) {
5519*4bdc9457SAndroid Build Coastguard Worker         AvgPoolMicrokernelTester()
5520*4bdc9457SAndroid Build Coastguard Worker           .output_pixels(output_pixels)
5521*4bdc9457SAndroid Build Coastguard Worker           .pooling_elements(pooling_elements)
5522*4bdc9457SAndroid Build Coastguard Worker           .pooling_tile(9, 0)
5523*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
5524*4bdc9457SAndroid Build Coastguard Worker           .output_stride(7)
5525*4bdc9457SAndroid Build Coastguard Worker           .Test(xnn_qu8_avgpool_minmax_ukernel_9x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
5526*4bdc9457SAndroid Build Coastguard Worker       }
5527*4bdc9457SAndroid Build Coastguard Worker     }
5528*4bdc9457SAndroid Build Coastguard Worker   }
5529*4bdc9457SAndroid Build Coastguard Worker }
5530*4bdc9457SAndroid Build Coastguard Worker 
TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1,few_output_pixels_with_step)5531*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_AVGPOOL_MINMAX_9X__SCALAR_C1, few_output_pixels_with_step) {
5532*4bdc9457SAndroid Build Coastguard Worker   for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
5533*4bdc9457SAndroid Build Coastguard Worker     for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
5534*4bdc9457SAndroid Build Coastguard Worker       for (size_t channels = 1; channels <= 5; channels += 1) {
5535*4bdc9457SAndroid Build Coastguard Worker         for (size_t step = 2; step <= pooling_elements; step++) {
5536*4bdc9457SAndroid Build Coastguard Worker           AvgPoolMicrokernelTester()
5537*4bdc9457SAndroid Build Coastguard Worker             .output_pixels(output_pixels)
5538*4bdc9457SAndroid Build Coastguard Worker             .pooling_elements(pooling_elements)
5539*4bdc9457SAndroid Build Coastguard Worker             .pooling_tile(9, 0)
5540*4bdc9457SAndroid Build Coastguard Worker             .step(step)
5541*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
5542*4bdc9457SAndroid Build Coastguard Worker             .output_stride(7)
5543*4bdc9457SAndroid Build Coastguard Worker             .Test(xnn_qu8_avgpool_minmax_ukernel_9x__scalar_c1, xnn_init_qu8_avgpool_minmax_scalar_params);
5544*4bdc9457SAndroid Build Coastguard Worker         }
5545*4bdc9457SAndroid Build Coastguard Worker       }
5546*4bdc9457SAndroid Build Coastguard Worker     }
5547*4bdc9457SAndroid Build Coastguard Worker   }
5548*4bdc9457SAndroid Build Coastguard Worker }